2017-11-05 01:39:26 +08:00
|
|
|
const recentNotes = (function() {
|
|
|
|
const dialog = $("#recent-notes-dialog");
|
|
|
|
const selectBox = $('#recent-notes-select-box');
|
|
|
|
const jumpToButton = $('#recentNotesJumpTo');
|
|
|
|
const addLinkButton = $('#recentNotesAddLink');
|
2017-11-05 01:21:41 +08:00
|
|
|
const noteDetail = $('#note-detail');
|
2017-11-05 01:39:26 +08:00
|
|
|
let list = [];
|
2017-09-10 00:06:15 +08:00
|
|
|
|
2017-11-05 01:21:41 +08:00
|
|
|
function addRecentNote(noteTreeId, noteContentId) {
|
|
|
|
setTimeout(() => {
|
|
|
|
// we include the note into recent list only if the user stayed on the note at least 5 seconds
|
|
|
|
if (noteTreeId === glob.currentNote.detail.note_id || noteContentId === glob.currentNote.detail.note_id) {
|
|
|
|
// if it's already there, remove the note
|
2017-11-05 01:39:26 +08:00
|
|
|
list = list.filter(note => note !== noteTreeId);
|
2017-10-02 11:07:32 +08:00
|
|
|
|
2017-11-05 01:39:26 +08:00
|
|
|
list.unshift(noteTreeId);
|
2017-11-05 01:21:41 +08:00
|
|
|
}
|
|
|
|
}, 1500);
|
|
|
|
}
|
2017-09-10 00:06:15 +08:00
|
|
|
|
2017-11-05 01:39:26 +08:00
|
|
|
function removeRecentNote(noteIdToRemove) {
|
|
|
|
list = list.filter(note => note !== noteIdToRemove);
|
|
|
|
}
|
|
|
|
|
|
|
|
function showDialog() {
|
2017-11-05 01:21:41 +08:00
|
|
|
noteDetail.summernote('editor.saveRange');
|
2017-09-10 00:06:15 +08:00
|
|
|
|
2017-11-05 01:39:26 +08:00
|
|
|
dialog.dialog({
|
2017-11-05 01:21:41 +08:00
|
|
|
modal: true,
|
|
|
|
width: 800
|
|
|
|
});
|
2017-09-10 00:06:15 +08:00
|
|
|
|
2017-11-05 01:39:26 +08:00
|
|
|
selectBox.find('option').remove();
|
2017-09-10 00:06:15 +08:00
|
|
|
|
2017-11-05 01:21:41 +08:00
|
|
|
// remove the current note
|
2017-11-05 01:39:26 +08:00
|
|
|
const recNotes = list.filter(note => note !== glob.currentNote.detail.note_id);
|
2017-09-10 00:06:15 +08:00
|
|
|
|
2017-11-05 01:21:41 +08:00
|
|
|
$.each(recNotes, (key, valueNoteId) => {
|
|
|
|
const noteTitle = getFullName(valueNoteId);
|
2017-09-10 00:06:15 +08:00
|
|
|
|
2017-11-05 01:21:41 +08:00
|
|
|
if (!noteTitle) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
const option = $("<option></option>")
|
2017-09-10 00:06:15 +08:00
|
|
|
.attr("value", valueNoteId)
|
|
|
|
.text(noteTitle);
|
|
|
|
|
2017-11-05 01:21:41 +08:00
|
|
|
// select the first one (most recent one) by default
|
|
|
|
if (key === 0) {
|
|
|
|
option.attr("selected", "selected");
|
|
|
|
}
|
2017-09-10 00:06:15 +08:00
|
|
|
|
2017-11-05 01:39:26 +08:00
|
|
|
selectBox.append(option);
|
2017-11-05 01:21:41 +08:00
|
|
|
});
|
|
|
|
}
|
2017-10-07 10:46:30 +08:00
|
|
|
|
2017-11-05 01:21:41 +08:00
|
|
|
function getSelectedNoteIdFromRecentNotes() {
|
2017-11-05 01:39:26 +08:00
|
|
|
return selectBox.find("option:selected").val();
|
2017-11-05 01:21:41 +08:00
|
|
|
}
|
2017-10-02 11:07:32 +08:00
|
|
|
|
2017-11-05 01:21:41 +08:00
|
|
|
function setActiveNoteBasedOnRecentNotes() {
|
|
|
|
const noteId = getSelectedNoteIdFromRecentNotes();
|
2017-09-10 00:06:15 +08:00
|
|
|
|
2017-11-05 01:21:41 +08:00
|
|
|
getNodeByKey(noteId).setActive();
|
2017-09-10 00:06:15 +08:00
|
|
|
|
2017-11-05 01:39:26 +08:00
|
|
|
dialog.dialog('close');
|
2017-11-05 01:21:41 +08:00
|
|
|
}
|
2017-09-10 00:06:15 +08:00
|
|
|
|
2017-11-05 01:21:41 +08:00
|
|
|
function addLinkBasedOnRecentNotes() {
|
|
|
|
const noteId = getSelectedNoteIdFromRecentNotes();
|
2017-10-02 11:07:32 +08:00
|
|
|
|
2017-11-05 01:21:41 +08:00
|
|
|
const linkTitle = getNoteTitle(noteId);
|
2017-10-02 11:07:32 +08:00
|
|
|
|
2017-11-05 01:39:26 +08:00
|
|
|
dialog.dialog("close");
|
2017-10-02 11:07:32 +08:00
|
|
|
|
2017-11-05 01:21:41 +08:00
|
|
|
noteDetail.summernote('editor.restoreRange');
|
2017-10-02 11:07:32 +08:00
|
|
|
|
2017-11-05 01:21:41 +08:00
|
|
|
noteDetail.summernote('createLink', {
|
|
|
|
text: linkTitle,
|
|
|
|
url: 'app#' + noteId,
|
|
|
|
isNewWindow: true
|
|
|
|
});
|
|
|
|
}
|
2017-10-02 11:07:32 +08:00
|
|
|
|
2017-11-05 01:39:26 +08:00
|
|
|
selectBox.keydown(e => {
|
2017-11-05 01:21:41 +08:00
|
|
|
const key = e.which;
|
2017-09-10 00:06:15 +08:00
|
|
|
|
2017-11-05 01:21:41 +08:00
|
|
|
if (key === 13)// the enter key code
|
|
|
|
{
|
|
|
|
setActiveNoteBasedOnRecentNotes();
|
|
|
|
}
|
|
|
|
else if (key === 76 /* l */) {
|
|
|
|
addLinkBasedOnRecentNotes();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
return; // avoid prevent default
|
|
|
|
}
|
|
|
|
|
|
|
|
e.preventDefault();
|
|
|
|
});
|
2017-10-02 11:07:32 +08:00
|
|
|
|
2017-11-05 01:39:26 +08:00
|
|
|
$(document).bind('keydown', 'alt+q', showDialog);
|
|
|
|
|
|
|
|
selectBox.dblclick(e => {
|
2017-11-05 01:21:41 +08:00
|
|
|
setActiveNoteBasedOnRecentNotes();
|
|
|
|
});
|
2017-09-10 00:06:15 +08:00
|
|
|
|
2017-11-05 01:39:26 +08:00
|
|
|
jumpToButton.click(setActiveNoteBasedOnRecentNotes);
|
|
|
|
addLinkButton.click(addLinkBasedOnRecentNotes);
|
2017-10-02 11:07:32 +08:00
|
|
|
|
2017-11-05 01:21:41 +08:00
|
|
|
return {
|
2017-11-05 01:39:26 +08:00
|
|
|
showDialog,
|
|
|
|
addRecentNote,
|
|
|
|
removeRecentNote
|
2017-11-05 01:21:41 +08:00
|
|
|
};
|
|
|
|
})();
|