mirror of
https://github.com/siyuan-note/siyuan.git
synced 2025-12-21 17:10:12 +01:00
207 lines
10 KiB
TypeScript
207 lines
10 KiB
TypeScript
import {popSearch} from "./search";
|
||
import {initAppearance} from "../settings/appearance";
|
||
import {closePanel} from "../util/closePanel";
|
||
import {mountHelp, newDailyNote, newNotebook} from "../../util/mount";
|
||
import {repos} from "../../config/repos";
|
||
import {exitSiYuan, lockScreen, processSync} from "../../dialog/processSystem";
|
||
import {openHistory} from "../../history/history";
|
||
import {syncGuide} from "../../sync/syncGuide";
|
||
import {openCard} from "../../card/openCard";
|
||
import {activeBlur, hideKeyboardToolbar} from "../util/keyboardToolbar";
|
||
import {initAI} from "../settings/ai";
|
||
import {initRiffCard} from "../settings/riffCard";
|
||
import {login, showAccountInfo} from "../settings/account";
|
||
import {openModel} from "./model";
|
||
import {initAbout} from "../settings/about";
|
||
import {getRecentDocs} from "./getRecentDocs";
|
||
|
||
export const popMenu = () => {
|
||
activeBlur();
|
||
hideKeyboardToolbar();
|
||
const menuElement = document.getElementById("menu");
|
||
if (menuElement.innerHTML !== "") {
|
||
menuElement.style.right = "0";
|
||
return;
|
||
}
|
||
let accountHTML = "";
|
||
if (window.siyuan.user && !window.siyuan.config.readonly) {
|
||
accountHTML = `<div class="b3-menu__item" id="menuAccount">
|
||
<img class="b3-menu__icon" src="${window.siyuan.user.userAvatarURL}"/>
|
||
<span class="b3-menu__label">${window.siyuan.user.userName}</span>
|
||
</div>`;
|
||
} else if (!window.siyuan.config.readonly) {
|
||
accountHTML = `<div class="b3-menu__item" id="menuAccount">
|
||
<svg class="b3-menu__icon"><use xlink:href="#iconAccount"></use></svg><span class="b3-menu__label">${window.siyuan.languages.login}</span>
|
||
</div>`;
|
||
}
|
||
menuElement.innerHTML = `<div class="b3-menu__title">
|
||
<svg class="b3-menu__icon"><use xlink:href="#iconLeft"></use></svg>
|
||
<span class="b3-menu__label">${window.siyuan.languages.back}</span>
|
||
</div>
|
||
<div class="b3-menu__separator"></div>
|
||
${accountHTML}
|
||
<div id="menuRecent" class="b3-menu__item">
|
||
<svg class="b3-menu__icon"><use xlink:href="#iconList"></use></svg><span class="b3-menu__label">${window.siyuan.languages.recentDocs}</span>
|
||
</div>
|
||
<div id="menuSearch" class="b3-menu__item">
|
||
<svg class="b3-menu__icon"><use xlink:href="#iconSearch"></use></svg><span class="b3-menu__label">${window.siyuan.languages.search}</span>
|
||
</div>
|
||
<div class="b3-menu__item${window.siyuan.config.readonly ? " fn__none" : ""}" id="menuSyncNow">
|
||
<svg class="b3-menu__icon"><use xlink:href="#iconCloudSucc"></use></svg><span class="b3-menu__label">${window.siyuan.languages.syncNow}</span>
|
||
</div>
|
||
<div class="b3-menu__item${window.siyuan.config.readonly ? " fn__none" : ""}" id="menuNewNotebook">
|
||
<svg class="b3-menu__icon"><use xlink:href="#iconFilesRoot"></use></svg><span class="b3-menu__label">${window.siyuan.languages.newNotebook}</span>
|
||
</div>
|
||
<div class="b3-menu__separator"></div>
|
||
<div id="menuNewDaily" class="b3-menu__item${window.siyuan.config.readonly ? " fn__none" : ""}">
|
||
<svg class="b3-menu__icon"><use xlink:href="#iconCalendar"></use></svg><span class="b3-menu__label">${window.siyuan.languages.dailyNote}</span>
|
||
</div>
|
||
<div id="menuCard" class="b3-menu__item${window.siyuan.config.readonly ? " fn__none" : ""}">
|
||
<svg class="b3-menu__icon" style="color: var(--b3-theme-secondary)"><use xlink:href="#iconRiffCard"></use></svg><span class="b3-menu__label">${window.siyuan.languages.riffCard}</span>
|
||
</div>
|
||
<div class="b3-menu__item${window.siyuan.config.readonly ? " fn__none" : ""}" id="menuLock">
|
||
<svg class="b3-menu__icon"><use xlink:href="#iconLock"></use></svg><span class="b3-menu__label">${window.siyuan.languages.lockScreen}</span>
|
||
</div>
|
||
<div class="b3-menu__item${window.siyuan.config.readonly ? " fn__none" : ""}" id="menuHistory">
|
||
<svg class="b3-menu__icon"><use xlink:href="#iconHistory"></use></svg><span class="b3-menu__label">${window.siyuan.languages.dataHistory}</span>
|
||
</div>
|
||
<div class="b3-menu__separator"></div>
|
||
<div class="b3-menu__item${window.siyuan.config.readonly ? " fn__none" : ""}" id="menuRiffCard">
|
||
<svg class="b3-menu__icon"><use xlink:href="#iconRiffCard"></use></svg><span class="b3-menu__label">${window.siyuan.languages.riffCard}</span>
|
||
</div>
|
||
<div class="b3-menu__item${window.siyuan.config.readonly ? " fn__none" : ""}" id="menuAI">
|
||
<svg class="b3-menu__icon"><use xlink:href="#iconSparkles"></use></svg><span class="b3-menu__label">AI</span>
|
||
</div>
|
||
<div class="b3-menu__item${window.siyuan.config.readonly ? " fn__none" : ""}" id="menuAppearance">
|
||
<svg class="b3-menu__icon"><use xlink:href="#iconTheme"></use></svg><span class="b3-menu__label">${window.siyuan.languages.appearance}</span>
|
||
</div>
|
||
<div id="menuSync" class="b3-menu__item${window.siyuan.config.readonly ? " fn__none" : ""}">
|
||
<svg class="b3-menu__icon"><use xlink:href="#iconCloud"></use></svg><span class="b3-menu__label">${window.siyuan.languages.cloud}</span>
|
||
</div>
|
||
<div class="b3-menu__item" id="menuAbout">
|
||
<svg class="b3-menu__icon"><use xlink:href="#iconInfo"></use></svg><span class="b3-menu__label">${window.siyuan.languages.about}</span>
|
||
</div>
|
||
<div class="b3-menu__separator"></div>
|
||
<div class="b3-menu__item" id="menuHelp">
|
||
<svg class="b3-menu__icon"><use xlink:href="#iconHelp"></use></svg><span class="b3-menu__label">${window.siyuan.languages.help}</span>
|
||
</div>
|
||
<a class="b3-menu__item" href="${"zh_CN" === window.siyuan.config.lang ? "https://ld246.com/article/1649901726096" : "https://github.com/siyuan-note/siyuan/issues"}" target="_blank">
|
||
<svg class="b3-menu__icon"><use xlink:href="#iconHeart"></use></svg>
|
||
<span class="b3-menu__label">${window.siyuan.languages.feedback}</span>
|
||
</a>
|
||
<div class="b3-menu__separator${(window.webkit?.messageHandlers || window.JSAndroid) ? "" : " fn__none"}"></div>
|
||
<div class="b3-menu__item${(window.webkit?.messageHandlers || window.JSAndroid) ? "" : " fn__none"}" id="menuSafeQuit">
|
||
<svg class="b3-menu__icon"><use xlink:href="#iconQuit"></use></svg><span class="b3-menu__label">${window.siyuan.languages.safeQuit}</span>
|
||
</div>`;
|
||
processSync();
|
||
// 只能用 click,否则无法上下滚动 https://github.com/siyuan-note/siyuan/issues/6628
|
||
menuElement.addEventListener("click", (event) => {
|
||
let target = event.target as HTMLElement;
|
||
while (target && !target.isEqualNode(menuElement)) {
|
||
if (target.classList.contains("b3-menu__title")) {
|
||
closePanel();
|
||
event.preventDefault();
|
||
event.stopPropagation();
|
||
break;
|
||
} else if (target.id === "menuSearch") {
|
||
popSearch();
|
||
event.preventDefault();
|
||
event.stopPropagation();
|
||
break;
|
||
} else if (target.id === "menuRecent") {
|
||
getRecentDocs();
|
||
event.preventDefault();
|
||
event.stopPropagation();
|
||
break;
|
||
} else if (target.id === "menuAppearance") {
|
||
initAppearance();
|
||
event.preventDefault();
|
||
event.stopPropagation();
|
||
break;
|
||
} else if (target.id === "menuAI") {
|
||
initAI();
|
||
event.preventDefault();
|
||
event.stopPropagation();
|
||
break;
|
||
} else if (target.id === "menuRiffCard") {
|
||
initRiffCard();
|
||
event.preventDefault();
|
||
event.stopPropagation();
|
||
break;
|
||
} else if (target.id === "menuSafeQuit") {
|
||
exitSiYuan();
|
||
event.preventDefault();
|
||
event.stopPropagation();
|
||
break;
|
||
} else if (target.id === "menuAbout") {
|
||
initAbout();
|
||
event.preventDefault();
|
||
event.stopPropagation();
|
||
break;
|
||
} else if (target.id === "menuNewDaily") {
|
||
newDailyNote();
|
||
closePanel();
|
||
event.preventDefault();
|
||
event.stopPropagation();
|
||
break;
|
||
} else if (target.id === "menuCard") {
|
||
openCard();
|
||
closePanel();
|
||
event.preventDefault();
|
||
event.stopPropagation();
|
||
break;
|
||
} else if (target.id === "menuNewNotebook") {
|
||
newNotebook();
|
||
closePanel();
|
||
event.preventDefault();
|
||
event.stopPropagation();
|
||
break;
|
||
} else if (target.id === "menuHelp") {
|
||
mountHelp();
|
||
event.preventDefault();
|
||
event.stopPropagation();
|
||
break;
|
||
} else if (target.id === "menuLock") {
|
||
lockScreen();
|
||
event.preventDefault();
|
||
event.stopPropagation();
|
||
break;
|
||
} else if (target.id === "menuSync") {
|
||
openModel({
|
||
title: window.siyuan.languages.cloud,
|
||
icon: "iconCloud",
|
||
html: repos.genHTML(),
|
||
bindEvent(modelMainElement: HTMLElement) {
|
||
repos.element = modelMainElement;
|
||
repos.bindEvent();
|
||
}
|
||
});
|
||
event.preventDefault();
|
||
event.stopPropagation();
|
||
break;
|
||
} else if (target.id === "menuSyncNow") {
|
||
syncGuide();
|
||
event.preventDefault();
|
||
event.stopPropagation();
|
||
break;
|
||
} else if (target.id === "menuHistory" && !window.siyuan.config.readonly) {
|
||
openHistory();
|
||
closePanel();
|
||
event.preventDefault();
|
||
event.stopPropagation();
|
||
break;
|
||
} else if (target.id === "menuAccount") {
|
||
event.preventDefault();
|
||
event.stopPropagation();
|
||
if (document.querySelector("#menuAccount img")) {
|
||
showAccountInfo();
|
||
return;
|
||
}
|
||
login();
|
||
break;
|
||
}
|
||
target = target.parentElement;
|
||
}
|
||
});
|
||
menuElement.style.right = "0";
|
||
};
|