mirror of
				https://github.com/zadam/trilium.git
				synced 2025-11-03 20:06:08 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			83 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			83 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
// hot keys are active also inside inputs and content editables
 | 
						|
jQuery.hotkeys.options.filterInputAcceptingElements = true;
 | 
						|
jQuery.hotkeys.options.filterContentEditable = true;
 | 
						|
 | 
						|
$(document).bind('keydown', 'alt+m', () => {
 | 
						|
    const toggle = $(".hide-toggle");
 | 
						|
    const hidden = toggle.css('visibility') === 'hidden';
 | 
						|
 | 
						|
    toggle.css('visibility', hidden ? 'visible' : 'hidden');
 | 
						|
});
 | 
						|
 | 
						|
// hide (toggle) everything except for the note content for distraction free writing
 | 
						|
$(document).bind('keydown', 'alt+t', () => {
 | 
						|
    const date = new Date();
 | 
						|
    const dateString = formatDateTime(date);
 | 
						|
 | 
						|
    $('#note-detail').summernote('insertText', dateString);
 | 
						|
});
 | 
						|
 | 
						|
$(window).on('beforeunload', () => {
 | 
						|
    // this makes sure that when user e.g. reloads the page or navigates away from the page, the note's content is saved
 | 
						|
    // this sends the request asynchronously and doesn't wait for result
 | 
						|
    saveNoteIfChanged();
 | 
						|
});
 | 
						|
 | 
						|
// Overrides the default autocomplete filter function to search for matched on atleast 1 word in each of the input term's words
 | 
						|
$.ui.autocomplete.filter = (array, terms) => {
 | 
						|
    if (!terms) {
 | 
						|
        return [];
 | 
						|
    }
 | 
						|
 | 
						|
    const startDate = new Date();
 | 
						|
 | 
						|
    const results = [];
 | 
						|
    const tokens = terms.toLowerCase().split(" ");
 | 
						|
 | 
						|
    for (const item of array) {
 | 
						|
        let found = true;
 | 
						|
        const lcValue = item.value.toLowerCase();
 | 
						|
 | 
						|
        for (const token of tokens) {
 | 
						|
            if (lcValue.indexOf(token) === -1) {
 | 
						|
                found = false;
 | 
						|
                break;
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        if (found) {
 | 
						|
            results.push(item);
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    console.log("Search took " + (new Date().getTime() - startDate.getTime()) + "ms");
 | 
						|
 | 
						|
    return results;
 | 
						|
};
 | 
						|
 | 
						|
$(document).tooltip({
 | 
						|
    items: ".note-editable a",
 | 
						|
    content: function(callback) {
 | 
						|
        const noteId = getNoteIdFromLink($(this).attr("href"));
 | 
						|
 | 
						|
        if (noteId !== null) {
 | 
						|
            loadNote(noteId, note => {
 | 
						|
                callback(note.detail.note_text);
 | 
						|
            });
 | 
						|
        }
 | 
						|
    },
 | 
						|
    close: function(event, ui)
 | 
						|
    {
 | 
						|
        ui.tooltip.hover(function()
 | 
						|
        {
 | 
						|
            $(this).stop(true).fadeTo(400, 1);
 | 
						|
        },
 | 
						|
        function()
 | 
						|
        {
 | 
						|
            $(this).fadeOut('400', function()
 | 
						|
            {
 | 
						|
                $(this).remove();
 | 
						|
            });
 | 
						|
        });
 | 
						|
    }
 | 
						|
}); |