mirror of
https://github.com/zadam/trilium.git
synced 2025-01-08 16:19:17 +08:00
185 lines
No EOL
4.5 KiB
JavaScript
185 lines
No EOL
4.5 KiB
JavaScript
"use strict";
|
|
|
|
const noteEditor = (function() {
|
|
const noteTitleEl = $("#note-title");
|
|
const noteDetailEl = $('#note-detail');
|
|
const protectButton = $("#protect-button");
|
|
const unprotectButton = $("#unprotect-button");
|
|
const noteDetailWrapperEl = $("#note-detail-wrapper");
|
|
const noteIdDisplayEl = $("#note-id-display");
|
|
|
|
let editor = null;
|
|
|
|
let currentNote = null;
|
|
|
|
let noteChangeDisabled = false;
|
|
|
|
let isNoteChanged = false;
|
|
|
|
function getCurrentNote() {
|
|
return currentNote;
|
|
}
|
|
|
|
function getCurrentNoteId() {
|
|
return currentNote ? currentNote.detail.note_id : null;
|
|
}
|
|
|
|
function noteChanged() {
|
|
if (noteChangeDisabled) {
|
|
return;
|
|
}
|
|
|
|
isNoteChanged = true;
|
|
}
|
|
|
|
async function reload() {
|
|
// no saving here
|
|
|
|
await loadNoteToEditor(getCurrentNoteId());
|
|
}
|
|
|
|
async function switchToNote(noteId) {
|
|
if (getCurrentNoteId() !== noteId) {
|
|
await saveNoteIfChanged();
|
|
|
|
await loadNoteToEditor(noteId);
|
|
}
|
|
}
|
|
|
|
async function saveNoteIfChanged() {
|
|
if (!isNoteChanged) {
|
|
return;
|
|
}
|
|
|
|
const note = noteEditor.getCurrentNote();
|
|
|
|
updateNoteFromInputs(note);
|
|
|
|
await saveNoteToServer(note);
|
|
|
|
if (note.detail.is_protected) {
|
|
protected_session.touchProtectedSession();
|
|
}
|
|
}
|
|
|
|
function updateNoteFromInputs(note) {
|
|
note.detail.note_text = editor.getData();
|
|
|
|
const title = noteTitleEl.val();
|
|
|
|
note.detail.note_title = title;
|
|
|
|
noteTree.setNoteTitle(note.detail.note_id, title);
|
|
}
|
|
|
|
async function saveNoteToServer(note) {
|
|
await server.put('notes/' + note.detail.note_id, note);
|
|
|
|
isNoteChanged = false;
|
|
|
|
showMessage("Saved!");
|
|
}
|
|
|
|
function setNoteBackgroundIfProtected(note) {
|
|
const isProtected = !!note.detail.is_protected;
|
|
|
|
noteDetailWrapperEl.toggleClass("protected", isProtected);
|
|
protectButton.toggle(!isProtected);
|
|
unprotectButton.toggle(isProtected);
|
|
}
|
|
|
|
let isNewNoteCreated = false;
|
|
|
|
function newNoteCreated() {
|
|
isNewNoteCreated = true;
|
|
}
|
|
|
|
async function loadNoteToEditor(noteId) {
|
|
currentNote = await loadNote(noteId);
|
|
|
|
if (isNewNoteCreated) {
|
|
isNewNoteCreated = false;
|
|
|
|
noteTitleEl.focus().select();
|
|
}
|
|
|
|
noteIdDisplayEl.html(noteId);
|
|
|
|
await protected_session.ensureProtectedSession(currentNote.detail.is_protected, false);
|
|
|
|
if (currentNote.detail.is_protected) {
|
|
protected_session.touchProtectedSession();
|
|
}
|
|
|
|
// this might be important if we focused on protected note when not in protected note and we got a dialog
|
|
// to login, but we chose instead to come to another node - at that point the dialog is still visible and this will close it.
|
|
protected_session.ensureDialogIsClosed();
|
|
|
|
noteDetailWrapperEl.show();
|
|
|
|
noteChangeDisabled = true;
|
|
|
|
noteTitleEl.val(currentNote.detail.note_title);
|
|
|
|
editor.setData(currentNote.detail.note_text);
|
|
|
|
noteChangeDisabled = false;
|
|
|
|
setNoteBackgroundIfProtected(currentNote);
|
|
noteTree.setNoteTreeBackgroundBasedOnProtectedStatus(noteId);
|
|
|
|
// after loading new note make sure editor is scrolled to the top
|
|
noteDetailWrapperEl.scrollTop(0);
|
|
|
|
showAppIfHidden();
|
|
}
|
|
|
|
async function loadNote(noteId) {
|
|
return await server.get('notes/' + noteId);
|
|
}
|
|
|
|
function getEditor() {
|
|
return editor;
|
|
}
|
|
|
|
$(document).ready(() => {
|
|
noteTitleEl.on('input', () => {
|
|
noteChanged();
|
|
|
|
const title = noteTitleEl.val();
|
|
|
|
noteTree.setNoteTitle(getCurrentNoteId(), title);
|
|
});
|
|
|
|
BalloonEditor
|
|
.create(document.querySelector('#note-detail'), {
|
|
})
|
|
.then(edit => {
|
|
editor = edit;
|
|
|
|
editor.document.on('change', noteChanged);
|
|
})
|
|
.catch(error => {
|
|
console.error(error);
|
|
});
|
|
|
|
// so that tab jumps from note title (which has tabindex 1)
|
|
noteDetailEl.attr("tabindex", 2);
|
|
});
|
|
|
|
setInterval(saveNoteIfChanged, 5000);
|
|
|
|
return {
|
|
reload,
|
|
switchToNote,
|
|
saveNoteIfChanged,
|
|
updateNoteFromInputs,
|
|
saveNoteToServer,
|
|
setNoteBackgroundIfProtected,
|
|
loadNote,
|
|
getCurrentNote,
|
|
getCurrentNoteId,
|
|
newNoteCreated,
|
|
getEditor
|
|
};
|
|
})(); |