mirror of
				https://github.com/TriliumNext/Notes.git
				synced 2025-10-22 23:32:01 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			78 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			78 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| "use strict";
 | |
| 
 | |
| const noteHistory = (function() {
 | |
|     const dialogEl = $("#note-history-dialog");
 | |
|     const listEl = $("#note-history-list");
 | |
|     const contentEl = $("#note-history-content");
 | |
|     const titleEl = $("#note-history-title");
 | |
| 
 | |
|     let historyItems = [];
 | |
| 
 | |
|     async function showCurrentNoteHistory() {
 | |
|         await showNoteHistoryDialog(noteEditor.getCurrentNoteId());
 | |
|     }
 | |
| 
 | |
|     async function showNoteHistoryDialog(noteId, noteHistoryId) {
 | |
|         glob.activeDialog = dialogEl;
 | |
| 
 | |
|         dialogEl.dialog({
 | |
|             modal: true,
 | |
|             width: 800,
 | |
|             height: 700
 | |
|         });
 | |
| 
 | |
|         listEl.empty();
 | |
|         contentEl.empty();
 | |
| 
 | |
|         historyItems = await server.get('notes-history/' + noteId);
 | |
| 
 | |
|         for (const item of historyItems) {
 | |
|             const dateModified = parseDate(item.date_modified_from);
 | |
| 
 | |
|             listEl.append($('<option>', {
 | |
|                 value: item.note_history_id,
 | |
|                 text: formatDateTime(dateModified)
 | |
|             }));
 | |
|         }
 | |
| 
 | |
|         if (historyItems.length > 0) {
 | |
|             if (!noteHistoryId) {
 | |
|                 noteHistoryId = listEl.find("option:first").val();
 | |
|             }
 | |
| 
 | |
|             listEl.val(noteHistoryId).trigger('change');
 | |
|         }
 | |
|         else {
 | |
|             titleEl.text("No history for this note yet...");
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     $(document).bind('keydown', 'alt+h', e => {
 | |
|         showCurrentNoteHistory();
 | |
| 
 | |
|         e.preventDefault();
 | |
|     });
 | |
| 
 | |
|     listEl.on('change', () => {
 | |
|         const optVal = listEl.find(":selected").val();
 | |
| 
 | |
|         const historyItem = historyItems.find(r => r.note_history_id === optVal);
 | |
| 
 | |
|         titleEl.html(historyItem.note_title);
 | |
|         contentEl.html(historyItem.note_text);
 | |
|     });
 | |
| 
 | |
|     $(document).on('click', "a[action='note-history']", event => {
 | |
|         const linkEl = $(event.target);
 | |
|         const noteId = linkEl.attr('note-path');
 | |
|         const noteHistoryId = linkEl.attr('note-history-id');
 | |
| 
 | |
|         showNoteHistoryDialog(noteId, noteHistoryId);
 | |
| 
 | |
|         return false;
 | |
|     });
 | |
| 
 | |
|     return {
 | |
|         showCurrentNoteHistory
 | |
|     };
 | |
| })(); | 
