mirror of https://github.com/TriliumNext/Notes
refactored all mentions of "history" to "revision"
parent
a69d8737ce
commit
47eb1e3e02
@ -0,0 +1 @@
|
|||||||
|
UPDATE options SET name = 'note_revision_snapshot_time_interval' WHERE name = 'history_snapshot_time_interval';
|
||||||
@ -1,72 +0,0 @@
|
|||||||
import noteDetailService from '../services/note_detail.js';
|
|
||||||
import utils from '../services/utils.js';
|
|
||||||
import server from '../services/server.js';
|
|
||||||
|
|
||||||
const $dialog = $("#note-history-dialog");
|
|
||||||
const $list = $("#note-history-list");
|
|
||||||
const $content = $("#note-history-content");
|
|
||||||
const $title = $("#note-history-title");
|
|
||||||
|
|
||||||
let historyItems = [];
|
|
||||||
|
|
||||||
async function showCurrentNoteHistory() {
|
|
||||||
await showNoteHistoryDialog(noteDetailService.getCurrentNoteId());
|
|
||||||
}
|
|
||||||
|
|
||||||
async function showNoteHistoryDialog(noteId, noteRevisionId) {
|
|
||||||
glob.activeDialog = $dialog;
|
|
||||||
|
|
||||||
$dialog.dialog({
|
|
||||||
modal: true,
|
|
||||||
width: 800,
|
|
||||||
height: 700
|
|
||||||
});
|
|
||||||
|
|
||||||
$list.empty();
|
|
||||||
$content.empty();
|
|
||||||
|
|
||||||
historyItems = await server.get('notes-history/' + noteId);
|
|
||||||
|
|
||||||
for (const item of historyItems) {
|
|
||||||
const dateModified = utils.parseDate(item.dateModifiedFrom);
|
|
||||||
|
|
||||||
$list.append($('<option>', {
|
|
||||||
value: item.noteRevisionId,
|
|
||||||
text: utils.formatDateTime(dateModified)
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (historyItems.length > 0) {
|
|
||||||
if (!noteRevisionId) {
|
|
||||||
noteRevisionId = $list.find("option:first").val();
|
|
||||||
}
|
|
||||||
|
|
||||||
$list.val(noteRevisionId).trigger('change');
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
$title.text("No history for this note yet...");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$list.on('change', () => {
|
|
||||||
const optVal = $list.find(":selected").val();
|
|
||||||
|
|
||||||
const historyItem = historyItems.find(r => r.noteRevisionId === optVal);
|
|
||||||
|
|
||||||
$title.html(historyItem.title);
|
|
||||||
$content.html(historyItem.content);
|
|
||||||
});
|
|
||||||
|
|
||||||
$(document).on('click', "a[action='note-history']", event => {
|
|
||||||
const linkEl = $(event.target);
|
|
||||||
const noteId = linkEl.attr('note-path');
|
|
||||||
const noteRevisionId = linkEl.attr('note-history-id');
|
|
||||||
|
|
||||||
showNoteHistoryDialog(noteId, noteRevisionId);
|
|
||||||
|
|
||||||
return false;
|
|
||||||
});
|
|
||||||
|
|
||||||
export default {
|
|
||||||
showCurrentNoteHistory
|
|
||||||
};
|
|
||||||
@ -0,0 +1,72 @@
|
|||||||
|
import noteDetailService from '../services/note_detail.js';
|
||||||
|
import utils from '../services/utils.js';
|
||||||
|
import server from '../services/server.js';
|
||||||
|
|
||||||
|
const $dialog = $("#note-revisions-dialog");
|
||||||
|
const $list = $("#note-revision-list");
|
||||||
|
const $content = $("#note-revision-content");
|
||||||
|
const $title = $("#note-revision-title");
|
||||||
|
|
||||||
|
let revisionItems = [];
|
||||||
|
|
||||||
|
async function showCurrentNoteRevisions() {
|
||||||
|
await showNoteRevisionsDialog(noteDetailService.getCurrentNoteId());
|
||||||
|
}
|
||||||
|
|
||||||
|
async function showNoteRevisionsDialog(noteId, noteRevisionId) {
|
||||||
|
glob.activeDialog = $dialog;
|
||||||
|
|
||||||
|
$dialog.dialog({
|
||||||
|
modal: true,
|
||||||
|
width: 800,
|
||||||
|
height: 700
|
||||||
|
});
|
||||||
|
|
||||||
|
$list.empty();
|
||||||
|
$content.empty();
|
||||||
|
|
||||||
|
revisionItems = await server.get('notes-revisions/' + noteId);
|
||||||
|
|
||||||
|
for (const item of revisionItems) {
|
||||||
|
const dateModified = utils.parseDate(item.dateModifiedFrom);
|
||||||
|
|
||||||
|
$list.append($('<option>', {
|
||||||
|
value: item.noteRevisionId,
|
||||||
|
text: utils.formatDateTime(dateModified)
|
||||||
|
}));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (revisionItems.length > 0) {
|
||||||
|
if (!noteRevisionId) {
|
||||||
|
noteRevisionId = $list.find("option:first").val();
|
||||||
|
}
|
||||||
|
|
||||||
|
$list.val(noteRevisionId).trigger('change');
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$title.text("No revisions for this note yet...");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$list.on('change', () => {
|
||||||
|
const optVal = $list.find(":selected").val();
|
||||||
|
|
||||||
|
const revisionItem = revisionItems.find(r => r.noteRevisionId === optVal);
|
||||||
|
|
||||||
|
$title.html(revisionItem.title);
|
||||||
|
$content.html(revisionItem.content);
|
||||||
|
});
|
||||||
|
|
||||||
|
$(document).on('click', "a[action='note-revision']", event => {
|
||||||
|
const linkEl = $(event.target);
|
||||||
|
const noteId = linkEl.attr('note-path');
|
||||||
|
const noteRevisionId = linkEl.attr('note-revision-id');
|
||||||
|
|
||||||
|
showNoteRevisionsDialog(noteId, noteRevisionId);
|
||||||
|
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
|
||||||
|
export default {
|
||||||
|
showCurrentNoteRevisions
|
||||||
|
};
|
||||||
Loading…
Reference in New Issue