2022-06-30 18:15:13 +08:00
|
|
|
/// #if !MOBILE
|
2022-05-26 15:18:53 +08:00
|
|
|
import {getInstanceById} from "../layout/util";
|
|
|
|
|
import {Tab} from "../layout/Tab";
|
|
|
|
|
import {initSearchMenu} from "./search";
|
|
|
|
|
import {initDockMenu} from "./dock";
|
2022-06-30 18:15:13 +08:00
|
|
|
import {initNavigationMenu, initFileMenu} from "./navigation";
|
|
|
|
|
import {initTabMenu} from "./tab";
|
|
|
|
|
/// #endif
|
2022-05-26 15:18:53 +08:00
|
|
|
import {Menu} from "./Menu";
|
2022-06-30 18:15:13 +08:00
|
|
|
import {hasTopClosestByTag} from "../protyle/util/hasClosest";
|
|
|
|
|
|
2022-05-26 15:18:53 +08:00
|
|
|
|
|
|
|
|
export class Menus {
|
|
|
|
|
public menu: Menu;
|
|
|
|
|
|
|
|
|
|
constructor() {
|
|
|
|
|
this.menu = new Menu();
|
2022-06-30 18:15:13 +08:00
|
|
|
/// #if !MOBILE
|
2022-05-26 15:18:53 +08:00
|
|
|
window.addEventListener("contextmenu", (event) => {
|
|
|
|
|
let target = event.target as HTMLElement;
|
|
|
|
|
while (target && !target.parentElement.isEqualNode(document.querySelector("body"))) {
|
|
|
|
|
event.preventDefault();
|
|
|
|
|
const dataType = target.getAttribute("data-type");
|
|
|
|
|
if (dataType === "tab-header") {
|
|
|
|
|
this.unselect();
|
2022-08-11 11:03:16 +08:00
|
|
|
initTabMenu((getInstanceById(target.getAttribute("data-id")) as Tab)).popup({
|
2022-05-26 15:18:53 +08:00
|
|
|
x: event.clientX,
|
|
|
|
|
y: event.clientY
|
|
|
|
|
});
|
|
|
|
|
event.stopPropagation();
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (dataType === "navigation-root" && !window.siyuan.config.readonly) {
|
|
|
|
|
if (target.querySelector(".b3-list-item__text").classList.contains("ft__on-surface")) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
this.unselect();
|
|
|
|
|
// navigation 根上:新建文档/文件夹/取消挂在/打开文件位置
|
|
|
|
|
initNavigationMenu(target).popup({x: event.clientX, y: event.clientY});
|
|
|
|
|
event.stopPropagation();
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (dataType === "navigation-file") {
|
|
|
|
|
this.unselect();
|
|
|
|
|
// navigation 文件上:删除/重命名/打开文件位置/导出
|
2022-07-01 22:08:00 +08:00
|
|
|
initFileMenu(this.getDir(target), target.getAttribute("data-path"), target).popup({
|
2022-05-26 15:18:53 +08:00
|
|
|
x: event.clientX,
|
|
|
|
|
y: event.clientY
|
|
|
|
|
});
|
|
|
|
|
event.stopPropagation();
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (dataType === "search-item") {
|
|
|
|
|
initSearchMenu(target.getAttribute("data-node-id")).popup({x: event.clientX, y: event.clientY});
|
|
|
|
|
event.stopPropagation();
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (target.classList.contains("dock__item")) {
|
|
|
|
|
initDockMenu(target).popup({x: event.clientX, y: event.clientY});
|
|
|
|
|
event.stopPropagation();
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
target = target.parentElement;
|
|
|
|
|
}
|
|
|
|
|
}, false);
|
2022-06-30 18:15:13 +08:00
|
|
|
/// #endif
|
2022-05-26 15:18:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private getDir(target: HTMLElement) {
|
|
|
|
|
const rootElement = hasTopClosestByTag(target, "UL");
|
|
|
|
|
if (rootElement) {
|
|
|
|
|
return rootElement.getAttribute("data-url");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private unselect() {
|
|
|
|
|
if (getSelection().rangeCount > 0) {
|
|
|
|
|
getSelection().getRangeAt(0).collapse(true);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|