import treeService from '../services/tree.js'; import linkService from '../services/link.js'; import server from '../services/server.js'; import searchNotesService from '../services/search_notes.js'; const $dialog = $("#jump-to-note-dialog"); const $autoComplete = $("#jump-to-note-autocomplete"); const $showInFullTextButton = $("#show-in-full-text-button"); async function showDialog() { glob.activeDialog = $dialog; $autoComplete.val(''); $dialog.dialog({ modal: true, width: 800 }); await $autoComplete.autocomplete({ source: async function(request, response) { const result = await server.get('autocomplete?query=' + encodeURIComponent(request.term)); if (result.length > 0) { response(result); } else { response([{ label: "No results", value: "No results" }]); } }, focus: function(event, ui) { event.preventDefault(); }, minLength: 0, autoFocus: true, select: function (event, ui) { if (ui.item.value === 'No results') { return false; } treeService.activateNode(ui.item.value); $dialog.dialog('close'); } }); $autoComplete.autocomplete("search", ""); } function showInFullText(e) { // stop from propagating upwards (dangerous especially with ctrl+enter executable javascript notes) e.preventDefault(); e.stopPropagation(); const searchText = $autoComplete.val(); searchNotesService.resetSearch(); searchNotesService.showSearch(); searchNotesService.doSearch(searchText); $dialog.dialog('close'); } $showInFullTextButton.click(showInFullText); $dialog.bind('keydown', 'ctrl+return', showInFullText); export default { showDialog };