2017-11-05 07:38:50 +08:00
|
|
|
"use strict";
|
|
|
|
|
2017-11-05 07:33:39 +08:00
|
|
|
const contextMenu = (function() {
|
|
|
|
const treeEl = $("#tree");
|
2017-11-05 07:28:49 +08:00
|
|
|
|
2017-11-05 07:33:39 +08:00
|
|
|
function pasteAfter(node) {
|
2017-11-19 06:05:50 +08:00
|
|
|
const subjectNode = treeUtils.getNodeByNoteTreeId(noteTree.getClipboardNoteTreeId());
|
2017-10-16 08:55:38 +08:00
|
|
|
|
2017-11-05 10:10:41 +08:00
|
|
|
treeChanges.moveAfterNode(subjectNode, node);
|
2017-10-16 08:55:38 +08:00
|
|
|
|
2017-11-19 06:05:50 +08:00
|
|
|
noteTree.setClipboardNoteTreeId(null);
|
2017-11-05 07:33:39 +08:00
|
|
|
}
|
2017-10-16 08:55:38 +08:00
|
|
|
|
2017-11-05 07:33:39 +08:00
|
|
|
function pasteInto(node) {
|
2017-11-19 06:05:50 +08:00
|
|
|
const subjectNode = treeUtils.getNodeByNoteTreeId(noteTree.getClipboardNoteTreeId());
|
2017-10-16 08:55:38 +08:00
|
|
|
|
2017-11-05 10:10:41 +08:00
|
|
|
treeChanges.moveToNode(subjectNode, node);
|
2017-10-16 08:55:38 +08:00
|
|
|
|
2017-11-19 06:05:50 +08:00
|
|
|
noteTree.setClipboardNoteTreeId(null);
|
2017-11-05 07:33:39 +08:00
|
|
|
}
|
2017-10-16 08:55:38 +08:00
|
|
|
|
2017-11-05 07:33:39 +08:00
|
|
|
function cut(node) {
|
2017-11-19 06:05:50 +08:00
|
|
|
noteTree.setClipboardNoteTreeId(node.note_tree_id);
|
2017-11-05 07:33:39 +08:00
|
|
|
}
|
2017-10-16 08:55:38 +08:00
|
|
|
|
2017-11-05 07:33:39 +08:00
|
|
|
const contextMenuSettings = {
|
|
|
|
delegate: "span.fancytree-title",
|
|
|
|
autoFocus: true,
|
|
|
|
menu: [
|
|
|
|
{title: "Insert note here", cmd: "insertNoteHere", uiIcon: "ui-icon-pencil"},
|
|
|
|
{title: "Insert child note", cmd: "insertChildNote", uiIcon: "ui-icon-pencil"},
|
|
|
|
{title: "Delete", cmd: "delete", uiIcon: "ui-icon-trash"},
|
|
|
|
{title: "----"},
|
2017-11-15 13:04:26 +08:00
|
|
|
{title: "Protect sub-tree", cmd: "protectSubTree", uiIcon: "ui-icon-locked"},
|
|
|
|
{title: "Unprotect sub-tree", cmd: "unprotectSubTree", uiIcon: "ui-icon-unlocked"},
|
2017-11-05 07:33:39 +08:00
|
|
|
{title: "----"},
|
|
|
|
{title: "Cut", cmd: "cut", uiIcon: "ui-icon-scissors"},
|
|
|
|
{title: "Copy / clone", cmd: "copy", uiIcon: "ui-icon-copy"},
|
|
|
|
{title: "Paste after", cmd: "pasteAfter", uiIcon: "ui-icon-clipboard"},
|
|
|
|
{title: "Paste into", cmd: "pasteInto", uiIcon: "ui-icon-clipboard"}
|
|
|
|
],
|
|
|
|
beforeOpen: (event, ui) => {
|
|
|
|
const node = $.ui.fancytree.getNode(ui.target);
|
|
|
|
// Modify menu entries depending on node status
|
2017-11-19 06:05:50 +08:00
|
|
|
treeEl.contextmenu("enableEntry", "pasteAfter", noteTree.getClipboardNoteTreeId() !== null);
|
|
|
|
treeEl.contextmenu("enableEntry", "pasteInto", noteTree.getClipboardNoteTreeId() !== null);
|
2017-09-10 00:06:15 +08:00
|
|
|
|
2017-11-15 13:04:26 +08:00
|
|
|
treeEl.contextmenu("enableEntry", "protectSubTree", protected_session.isProtectedSessionAvailable());
|
|
|
|
treeEl.contextmenu("enableEntry", "unprotectSubTree", protected_session.isProtectedSessionAvailable());
|
|
|
|
|
2017-11-05 07:33:39 +08:00
|
|
|
// Activate node on right-click
|
|
|
|
node.setActive();
|
|
|
|
// Disable tree keyboard handling
|
|
|
|
ui.menu.prevKeyboard = node.tree.options.keyboard;
|
|
|
|
node.tree.options.keyboard = false;
|
|
|
|
},
|
|
|
|
close: (event, ui) => {},
|
|
|
|
select: (event, ui) => {
|
|
|
|
const node = $.ui.fancytree.getNode(ui.target);
|
2017-09-10 00:06:15 +08:00
|
|
|
|
2017-11-05 07:33:39 +08:00
|
|
|
if (ui.cmd === "insertNoteHere") {
|
2017-11-19 06:05:50 +08:00
|
|
|
const parentNoteTreeId = treeUtils.getParentNoteTreeId(node);
|
2017-11-15 12:01:23 +08:00
|
|
|
const isProtected = treeUtils.getParentProtectedStatus(node);
|
2017-09-10 00:06:15 +08:00
|
|
|
|
2017-11-19 06:05:50 +08:00
|
|
|
noteEditor.createNote(node, parentNoteTreeId, 'after', isProtected);
|
2017-11-05 07:33:39 +08:00
|
|
|
}
|
|
|
|
else if (ui.cmd === "insertChildNote") {
|
|
|
|
noteEditor.createNote(node, node.key, 'into');
|
|
|
|
}
|
2017-11-15 13:04:26 +08:00
|
|
|
else if (ui.cmd === "protectSubTree") {
|
|
|
|
protected_session.protectSubTree(node.key, true);
|
2017-11-05 07:33:39 +08:00
|
|
|
}
|
2017-11-15 13:04:26 +08:00
|
|
|
else if (ui.cmd === "unprotectSubTree") {
|
|
|
|
protected_session.protectSubTree(node.key, false);
|
2017-11-05 07:33:39 +08:00
|
|
|
}
|
|
|
|
else if (ui.cmd === "cut") {
|
|
|
|
cut(node);
|
|
|
|
}
|
|
|
|
else if (ui.cmd === "pasteAfter") {
|
|
|
|
pasteAfter(node);
|
|
|
|
}
|
|
|
|
else if (ui.cmd === "pasteInto") {
|
|
|
|
pasteInto(node);
|
|
|
|
}
|
|
|
|
else if (ui.cmd === "delete") {
|
2017-11-05 10:10:41 +08:00
|
|
|
treeChanges.deleteNode(node);
|
2017-11-05 07:33:39 +08:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
console.log("Unknown command: " + ui.cmd);
|
|
|
|
}
|
2017-09-10 00:06:15 +08:00
|
|
|
}
|
2017-11-05 07:33:39 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
return {
|
|
|
|
pasteAfter,
|
|
|
|
pasteInto,
|
|
|
|
cut,
|
|
|
|
contextMenuSettings
|
2017-09-10 00:06:15 +08:00
|
|
|
}
|
2017-11-05 07:33:39 +08:00
|
|
|
})();
|