2022-05-26 15:18:53 +08:00
|
|
|
|
import {Constants} from "../constants";
|
|
|
|
|
|
import {fetchPost} from "../util/fetch";
|
|
|
|
|
|
/// #if !MOBILE
|
2022-06-29 20:25:30 +08:00
|
|
|
|
import {exportLayout} from "../layout/util";
|
2022-05-26 15:18:53 +08:00
|
|
|
|
/// #endif
|
2023-02-26 10:19:47 +08:00
|
|
|
|
/// #if !BROWSER
|
|
|
|
|
|
import {ipcRenderer} from "electron";
|
|
|
|
|
|
import {getCurrentWindow} from "@electron/remote";
|
|
|
|
|
|
/// #endif
|
2022-09-09 10:10:38 +08:00
|
|
|
|
import {hideMessage, showMessage} from "./message";
|
2022-05-26 15:18:53 +08:00
|
|
|
|
import {Dialog} from "./index";
|
2023-04-19 11:27:32 +08:00
|
|
|
|
import {isMobile} from "../util/functions";
|
2022-09-08 22:40:01 +08:00
|
|
|
|
import {confirmDialog} from "./confirmDialog";
|
2023-01-16 16:01:48 +08:00
|
|
|
|
import {escapeHtml} from "../util/escape";
|
2023-01-16 21:33:20 +08:00
|
|
|
|
import {getWorkspaceName} from "../util/noRelyPCFunction";
|
2023-01-24 12:13:57 +08:00
|
|
|
|
import {needSubscribe} from "../util/needSubscribe";
|
2023-05-01 15:40:12 +08:00
|
|
|
|
import {redirectToCheckAuth, setNoteBook} from "../util/pathName";
|
2023-04-25 18:53:41 +08:00
|
|
|
|
import {getAllModels} from "../layout/getAll";
|
|
|
|
|
|
import {reloadProtyle} from "../protyle/util/reload";
|
2023-04-25 19:36:42 +08:00
|
|
|
|
import {Tab} from "../layout/Tab";
|
2023-04-27 10:14:58 +08:00
|
|
|
|
import {setEmpty} from "../mobile/util/setEmpty";
|
|
|
|
|
|
import {hideElements} from "../protyle/ui/hideElements";
|
2023-05-18 19:27:21 +08:00
|
|
|
|
import {App} from "../index";
|
2023-04-25 18:53:41 +08:00
|
|
|
|
|
2023-04-25 19:36:42 +08:00
|
|
|
|
const updateTitle = (rootID: string, tab: Tab) => {
|
|
|
|
|
|
fetchPost("/api/block/getDocInfo", {
|
|
|
|
|
|
id: rootID
|
|
|
|
|
|
}, (response) => {
|
2023-04-25 19:38:31 +08:00
|
|
|
|
tab.updateTitle(response.data.name);
|
|
|
|
|
|
});
|
|
|
|
|
|
};
|
2023-04-27 10:14:58 +08:00
|
|
|
|
|
2023-05-18 19:27:21 +08:00
|
|
|
|
export const reloadSync = (app: App, data: { upsertRootIDs: string[], removeRootIDs: string[] }) => {
|
2023-05-06 00:10:30 +08:00
|
|
|
|
hideMessage();
|
2023-04-27 10:14:58 +08:00
|
|
|
|
/// #if MOBILE
|
|
|
|
|
|
if (window.siyuan.mobile.popEditor) {
|
|
|
|
|
|
if (data.removeRootIDs.includes(window.siyuan.mobile.popEditor.protyle.block.rootID)) {
|
|
|
|
|
|
hideElements(["dialog"]);
|
|
|
|
|
|
} else {
|
2023-06-01 14:56:21 +08:00
|
|
|
|
reloadProtyle(window.siyuan.mobile.popEditor.protyle, app, false);
|
2023-04-27 10:26:40 +08:00
|
|
|
|
window.siyuan.mobile.popEditor.protyle.breadcrumb.render(window.siyuan.mobile.popEditor.protyle, true);
|
2023-04-27 10:14:58 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
if (window.siyuan.mobile.editor) {
|
|
|
|
|
|
if (data.removeRootIDs.includes(window.siyuan.mobile.editor.protyle.block.rootID)) {
|
2023-05-18 19:27:21 +08:00
|
|
|
|
setEmpty(app);
|
2023-04-27 10:14:58 +08:00
|
|
|
|
} else {
|
2023-06-01 14:56:21 +08:00
|
|
|
|
reloadProtyle(window.siyuan.mobile.editor.protyle, app, false);
|
2023-04-27 10:14:58 +08:00
|
|
|
|
fetchPost("/api/block/getDocInfo", {
|
|
|
|
|
|
id: window.siyuan.mobile.editor.protyle.block.rootID
|
|
|
|
|
|
}, (response) => {
|
2023-04-27 10:26:40 +08:00
|
|
|
|
(document.getElementById("toolbarName") as HTMLInputElement).value = response.data.name === "Untitled" ? "" : response.data.name;
|
2023-04-27 10:14:58 +08:00
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2023-05-01 15:40:12 +08:00
|
|
|
|
setNoteBook(() => {
|
|
|
|
|
|
window.siyuan.mobile.files.init(false);
|
|
|
|
|
|
});
|
2023-04-27 10:14:58 +08:00
|
|
|
|
/// #else
|
2023-04-25 19:38:31 +08:00
|
|
|
|
const allModels = getAllModels();
|
2023-04-25 18:53:41 +08:00
|
|
|
|
allModels.editor.forEach(item => {
|
|
|
|
|
|
if (data.upsertRootIDs.includes(item.editor.protyle.block.rootID)) {
|
2023-06-01 14:56:21 +08:00
|
|
|
|
reloadProtyle(item.editor.protyle, app, false);
|
2023-04-25 19:36:42 +08:00
|
|
|
|
updateTitle(item.editor.protyle.block.rootID, item.parent);
|
2023-04-25 18:53:41 +08:00
|
|
|
|
} else if (data.removeRootIDs.includes(item.editor.protyle.block.rootID)) {
|
|
|
|
|
|
item.parent.parent.removeTab(item.parent.id, false, false, false);
|
|
|
|
|
|
}
|
2023-04-25 19:38:31 +08:00
|
|
|
|
});
|
2023-04-25 18:53:41 +08:00
|
|
|
|
allModels.graph.forEach(item => {
|
2023-04-25 18:58:48 +08:00
|
|
|
|
if (item.type === "local" && data.removeRootIDs.includes(item.rootId)) {
|
|
|
|
|
|
item.parent.parent.removeTab(item.parent.id, false, false, false);
|
2023-04-25 19:36:42 +08:00
|
|
|
|
} else if (item.type !== "local" || data.upsertRootIDs.includes(item.rootId)) {
|
2023-04-25 18:58:48 +08:00
|
|
|
|
item.searchGraph(false);
|
2023-04-25 19:36:42 +08:00
|
|
|
|
if (item.type === "local") {
|
|
|
|
|
|
updateTitle(item.rootId, item.parent);
|
|
|
|
|
|
}
|
2023-04-25 18:58:48 +08:00
|
|
|
|
}
|
2023-04-25 19:38:31 +08:00
|
|
|
|
});
|
2023-04-25 18:53:41 +08:00
|
|
|
|
allModels.outline.forEach(item => {
|
|
|
|
|
|
if (item.type === "local" && data.removeRootIDs.includes(item.blockId)) {
|
|
|
|
|
|
item.parent.parent.removeTab(item.parent.id, false, false, false);
|
2023-04-25 19:36:42 +08:00
|
|
|
|
} else if (item.type !== "local" || data.upsertRootIDs.includes(item.blockId)) {
|
2023-04-25 18:53:41 +08:00
|
|
|
|
fetchPost("/api/outline/getDocOutline", {
|
|
|
|
|
|
id: item.blockId,
|
|
|
|
|
|
}, response => {
|
|
|
|
|
|
item.update(response);
|
|
|
|
|
|
});
|
2023-04-25 19:36:42 +08:00
|
|
|
|
if (item.type === "local") {
|
|
|
|
|
|
updateTitle(item.blockId, item.parent);
|
|
|
|
|
|
}
|
2023-04-25 18:53:41 +08:00
|
|
|
|
}
|
2023-04-25 19:38:31 +08:00
|
|
|
|
});
|
2023-04-25 18:53:41 +08:00
|
|
|
|
allModels.backlink.forEach(item => {
|
|
|
|
|
|
if (item.type === "local" && data.removeRootIDs.includes(item.rootId)) {
|
|
|
|
|
|
item.parent.parent.removeTab(item.parent.id, false, false, false);
|
|
|
|
|
|
} else {
|
|
|
|
|
|
item.refresh();
|
2023-04-25 19:36:42 +08:00
|
|
|
|
if (item.type === "local") {
|
|
|
|
|
|
updateTitle(item.rootId, item.parent);
|
|
|
|
|
|
}
|
2023-04-25 18:53:41 +08:00
|
|
|
|
}
|
2023-04-25 19:38:31 +08:00
|
|
|
|
});
|
2023-04-25 18:53:41 +08:00
|
|
|
|
allModels.files.forEach(item => {
|
2023-05-01 15:40:12 +08:00
|
|
|
|
setNoteBook(() => {
|
|
|
|
|
|
item.init(false);
|
|
|
|
|
|
});
|
2023-04-25 19:38:31 +08:00
|
|
|
|
});
|
2023-04-25 18:53:41 +08:00
|
|
|
|
allModels.bookmark.forEach(item => {
|
|
|
|
|
|
item.update();
|
2023-04-25 19:38:31 +08:00
|
|
|
|
});
|
2023-04-25 18:53:41 +08:00
|
|
|
|
allModels.tag.forEach(item => {
|
|
|
|
|
|
item.update();
|
2023-04-25 19:38:31 +08:00
|
|
|
|
});
|
2023-04-25 18:53:41 +08:00
|
|
|
|
// NOTE asset 无法获取推送地址,先不处理
|
|
|
|
|
|
allModels.search.forEach(item => {
|
2023-04-26 11:19:53 +08:00
|
|
|
|
item.parent.panelElement.querySelector("#searchInput").dispatchEvent(new CustomEvent("input"));
|
2023-04-25 19:38:31 +08:00
|
|
|
|
});
|
2023-04-28 12:02:08 +08:00
|
|
|
|
allModels.custom.forEach(item => {
|
|
|
|
|
|
if (item.update) {
|
|
|
|
|
|
item.update();
|
|
|
|
|
|
}
|
|
|
|
|
|
});
|
2023-04-27 10:14:58 +08:00
|
|
|
|
/// #endif
|
2023-04-25 19:38:31 +08:00
|
|
|
|
};
|
2023-01-12 15:53:57 +08:00
|
|
|
|
|
|
|
|
|
|
export const lockScreen = () => {
|
2023-03-10 10:00:03 +08:00
|
|
|
|
if (window.siyuan.config.readonly) {
|
2023-03-13 10:53:42 +08:00
|
|
|
|
return;
|
2023-03-10 10:00:03 +08:00
|
|
|
|
}
|
2023-01-12 15:53:57 +08:00
|
|
|
|
/// #if BROWSER
|
2023-01-12 16:43:22 +08:00
|
|
|
|
fetchPost("/api/system/logoutAuth", {}, () => {
|
2023-04-18 19:07:58 +08:00
|
|
|
|
redirectToCheckAuth();
|
2023-01-12 16:43:22 +08:00
|
|
|
|
});
|
2023-01-12 15:53:57 +08:00
|
|
|
|
/// #else
|
2023-02-27 10:58:07 +08:00
|
|
|
|
ipcRenderer.send(Constants.SIYUAN_SEND_WINDOWS, {cmd: "lockscreen"});
|
2023-01-12 15:53:57 +08:00
|
|
|
|
/// #endif
|
2023-01-12 17:36:19 +08:00
|
|
|
|
};
|
2022-05-26 15:18:53 +08:00
|
|
|
|
|
|
|
|
|
|
export const kernelError = () => {
|
2023-04-22 19:07:57 +08:00
|
|
|
|
if (document.querySelector("#errorLog")) {
|
2023-04-21 21:58:57 +08:00
|
|
|
|
return;
|
|
|
|
|
|
}
|
2022-05-26 15:18:53 +08:00
|
|
|
|
let iosReStart = "";
|
|
|
|
|
|
if (window.siyuan.config.system.container === "ios" && window.webkit?.messageHandlers) {
|
|
|
|
|
|
iosReStart = `<div class="fn__hr"></div><div class="fn__flex"><div class="fn__flex-1"></div><button class="b3-button">${window.siyuan.languages.retry}</button></div>`;
|
|
|
|
|
|
}
|
2023-04-21 09:51:04 +08:00
|
|
|
|
const dialog = new Dialog({
|
|
|
|
|
|
disableClose: true,
|
|
|
|
|
|
title: `💔 ${window.siyuan.languages.kernelFault0} <small>v${Constants.SIYUAN_VERSION}</small>`,
|
|
|
|
|
|
width: isMobile() ? "92vw" : "520px",
|
2023-04-22 19:07:57 +08:00
|
|
|
|
content: `<div class="b3-dialog__content">
|
2023-04-21 09:51:04 +08:00
|
|
|
|
<div class="ft__breakword">
|
|
|
|
|
|
<div>${window.siyuan.languages.kernelFault1}</div>
|
|
|
|
|
|
<div class="fn__hr"></div>
|
|
|
|
|
|
<div>${window.siyuan.languages.kernelFault2}</div>
|
|
|
|
|
|
${iosReStart}
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>`
|
|
|
|
|
|
});
|
2023-04-22 19:22:53 +08:00
|
|
|
|
dialog.element.id = "errorLog";
|
2023-04-21 09:51:04 +08:00
|
|
|
|
const restartElement = dialog.element.querySelector(".b3-button");
|
|
|
|
|
|
if (restartElement) {
|
2022-05-26 15:18:53 +08:00
|
|
|
|
restartElement.addEventListener("click", () => {
|
2023-04-21 09:51:04 +08:00
|
|
|
|
dialog.destroy();
|
2022-05-26 15:18:53 +08:00
|
|
|
|
window.webkit.messageHandlers.startKernelFast.postMessage("startKernelFast");
|
|
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
export const exitSiYuan = () => {
|
|
|
|
|
|
fetchPost("/api/system/exit", {force: false}, (response) => {
|
2022-09-08 09:55:29 +08:00
|
|
|
|
if (response.code === 1) { // 同步执行失败
|
2022-06-06 23:04:56 +08:00
|
|
|
|
const msgId = showMessage(response.msg, response.data.closeTimeout, "error");
|
|
|
|
|
|
const buttonElement = document.querySelector(`#message [data-id="${msgId}"] button`);
|
2022-05-26 15:18:53 +08:00
|
|
|
|
if (buttonElement) {
|
|
|
|
|
|
buttonElement.addEventListener("click", () => {
|
|
|
|
|
|
fetchPost("/api/system/exit", {force: true}, () => {
|
|
|
|
|
|
/// #if !BROWSER
|
2023-03-19 11:57:22 +08:00
|
|
|
|
ipcRenderer.send(Constants.SIYUAN_QUIT, location.port);
|
2022-05-26 15:18:53 +08:00
|
|
|
|
/// #else
|
|
|
|
|
|
if (["ios", "android"].includes(window.siyuan.config.system.container) && (window.webkit?.messageHandlers || window.JSAndroid)) {
|
|
|
|
|
|
window.location.href = "siyuan://api/system/exit";
|
|
|
|
|
|
}
|
|
|
|
|
|
/// #endif
|
|
|
|
|
|
});
|
|
|
|
|
|
});
|
|
|
|
|
|
}
|
2022-09-08 09:55:29 +08:00
|
|
|
|
} else if (response.code === 2) { // 提示新安装包
|
2022-09-09 10:10:38 +08:00
|
|
|
|
hideMessage();
|
2022-09-08 22:40:01 +08:00
|
|
|
|
confirmDialog(window.siyuan.languages.tip, response.msg, () => {
|
|
|
|
|
|
fetchPost("/api/system/exit", {
|
|
|
|
|
|
force: true,
|
|
|
|
|
|
execInstallPkg: 2 // 0:默认检查新版本,1:不执行新版本安装,2:执行新版本安装
|
|
|
|
|
|
}, () => {
|
|
|
|
|
|
/// #if !BROWSER
|
2022-11-11 10:09:36 +08:00
|
|
|
|
// 桌面端退出拉起更新安装时有时需要重启两次 https://github.com/siyuan-note/siyuan/issues/6544
|
|
|
|
|
|
// 这里先将主界面隐藏
|
|
|
|
|
|
setTimeout(() => {
|
|
|
|
|
|
getCurrentWindow().hide();
|
|
|
|
|
|
}, 2000);
|
|
|
|
|
|
// 然后等待一段时间后再退出,避免界面主进程退出以后内核子进程被杀死
|
|
|
|
|
|
setTimeout(() => {
|
2023-03-19 11:57:22 +08:00
|
|
|
|
ipcRenderer.send(Constants.SIYUAN_QUIT, location.port);
|
2022-11-11 10:09:36 +08:00
|
|
|
|
}, 4000);
|
2022-09-08 22:40:01 +08:00
|
|
|
|
/// #endif
|
2022-09-08 09:55:29 +08:00
|
|
|
|
});
|
2022-09-08 22:40:01 +08:00
|
|
|
|
}, () => {
|
|
|
|
|
|
fetchPost("/api/system/exit", {
|
|
|
|
|
|
force: true,
|
|
|
|
|
|
execInstallPkg: 1 // 0:默认检查新版本,1:不执行新版本安装,2:执行新版本安装
|
|
|
|
|
|
}, () => {
|
|
|
|
|
|
/// #if !BROWSER
|
2023-03-19 11:57:22 +08:00
|
|
|
|
ipcRenderer.send(Constants.SIYUAN_QUIT, location.port);
|
2022-09-08 22:40:01 +08:00
|
|
|
|
/// #endif
|
|
|
|
|
|
});
|
2022-09-09 09:45:18 +08:00
|
|
|
|
});
|
2022-09-08 09:55:29 +08:00
|
|
|
|
} else { // 正常退出
|
2022-05-26 15:18:53 +08:00
|
|
|
|
/// #if !BROWSER
|
2023-03-19 11:57:22 +08:00
|
|
|
|
ipcRenderer.send(Constants.SIYUAN_QUIT, location.port);
|
2022-05-26 15:18:53 +08:00
|
|
|
|
/// #else
|
|
|
|
|
|
if (["ios", "android"].includes(window.siyuan.config.system.container) && (window.webkit?.messageHandlers || window.JSAndroid)) {
|
|
|
|
|
|
window.location.href = "siyuan://api/system/exit";
|
|
|
|
|
|
}
|
|
|
|
|
|
/// #endif
|
|
|
|
|
|
}
|
|
|
|
|
|
});
|
|
|
|
|
|
};
|
|
|
|
|
|
|
2023-03-21 09:25:52 +08:00
|
|
|
|
export const transactionError = () => {
|
2022-05-26 15:18:53 +08:00
|
|
|
|
if (document.getElementById("transactionError")) {
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
const dialog = new Dialog({
|
|
|
|
|
|
disableClose: true,
|
|
|
|
|
|
title: `${window.siyuan.languages.stateExcepted} v${Constants.SIYUAN_VERSION}`,
|
|
|
|
|
|
content: `<div class="b3-dialog__content" id="transactionError">${window.siyuan.languages.rebuildIndexTip}</div>
|
|
|
|
|
|
<div class="b3-dialog__action">
|
|
|
|
|
|
<button class="b3-button b3-button--text">${window.siyuan.languages._kernel[97]}</button>
|
|
|
|
|
|
<div class="fn__space"></div>
|
|
|
|
|
|
<button class="b3-button">${window.siyuan.languages.rebuildIndex}</button>
|
|
|
|
|
|
</div>`,
|
2023-04-20 10:05:24 +08:00
|
|
|
|
width: isMobile() ? "92vw" : "520px",
|
2022-05-26 15:18:53 +08:00
|
|
|
|
});
|
|
|
|
|
|
const btnsElement = dialog.element.querySelectorAll(".b3-button");
|
|
|
|
|
|
btnsElement[0].addEventListener("click", () => {
|
2022-06-29 20:25:30 +08:00
|
|
|
|
/// #if MOBILE
|
|
|
|
|
|
exitSiYuan();
|
|
|
|
|
|
/// #else
|
2023-05-11 12:22:53 +08:00
|
|
|
|
exportLayout({
|
|
|
|
|
|
reload: false,
|
|
|
|
|
|
onlyData: false,
|
|
|
|
|
|
errorExit: true,
|
|
|
|
|
|
cb: exitSiYuan
|
|
|
|
|
|
});
|
2022-06-29 20:25:30 +08:00
|
|
|
|
/// #endif
|
2022-05-26 15:18:53 +08:00
|
|
|
|
});
|
|
|
|
|
|
btnsElement[1].addEventListener("click", () => {
|
|
|
|
|
|
fetchPost("/api/filetree/refreshFiletree", {});
|
2023-01-25 21:28:23 +08:00
|
|
|
|
dialog.destroy();
|
2022-05-26 15:18:53 +08:00
|
|
|
|
});
|
|
|
|
|
|
};
|
|
|
|
|
|
|
2022-06-25 20:40:07 +08:00
|
|
|
|
export const progressStatus = (data: IWebSocketData) => {
|
2023-01-20 11:24:11 +08:00
|
|
|
|
const statusElement = document.querySelector("#status") as HTMLElement;
|
|
|
|
|
|
if (!statusElement) {
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
2022-08-28 12:41:49 +08:00
|
|
|
|
if (isMobile()) {
|
2023-03-01 18:58:39 +08:00
|
|
|
|
if (!document.querySelector("#keyboardToolbar").classList.contains("fn__none")) {
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
2022-08-28 12:41:49 +08:00
|
|
|
|
statusElement.innerHTML = data.msg;
|
2022-08-28 12:44:28 +08:00
|
|
|
|
statusElement.classList.remove("status--hide");
|
2023-03-01 18:58:39 +08:00
|
|
|
|
statusElement.style.bottom = "0";
|
2022-08-28 12:41:49 +08:00
|
|
|
|
return;
|
|
|
|
|
|
}
|
2023-01-24 11:23:41 +08:00
|
|
|
|
const msgElement = statusElement.querySelector(".status__msg");
|
|
|
|
|
|
if (msgElement) {
|
|
|
|
|
|
msgElement.innerHTML = data.msg;
|
|
|
|
|
|
}
|
2022-06-25 20:40:07 +08:00
|
|
|
|
};
|
|
|
|
|
|
|
2022-05-26 15:18:53 +08:00
|
|
|
|
export const progressLoading = (data: IWebSocketData) => {
|
|
|
|
|
|
let progressElement = document.getElementById("progress");
|
|
|
|
|
|
if (!progressElement) {
|
|
|
|
|
|
document.body.insertAdjacentHTML("beforeend", '<div id="progress"></div>');
|
|
|
|
|
|
progressElement = document.getElementById("progress");
|
|
|
|
|
|
}
|
|
|
|
|
|
// code 0: 有进度;1: 无进度;2: 关闭
|
|
|
|
|
|
if (data.code === 2) {
|
|
|
|
|
|
progressElement.remove();
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
if (data.code === 0) {
|
|
|
|
|
|
progressElement.innerHTML = `<div class="b3-dialog__scrim" style="z-index:400;opacity: 1"></div>
|
|
|
|
|
|
<div style="position: fixed;top: 45vh;width: 70vw;left: 15vw;color:#fff;z-index:400;">
|
|
|
|
|
|
<div style="text-align: right">${data.data.current}/${data.data.total}</div>
|
|
|
|
|
|
<div style="margin: 8px 0;height: 8px;border-radius: 4px;overflow: hidden;background-color:#fff;"><div style="width: ${data.data.current / data.data.total * 100}%;transition: var(--b3-transition);background-color: var(--b3-theme-primary);height: 8px;"></div></div>
|
|
|
|
|
|
<div>${data.msg}</div>
|
|
|
|
|
|
</div>`;
|
|
|
|
|
|
} else if (data.code === 1) {
|
|
|
|
|
|
if (progressElement.lastElementChild) {
|
|
|
|
|
|
progressElement.lastElementChild.lastElementChild.innerHTML = data.msg;
|
|
|
|
|
|
} else {
|
|
|
|
|
|
progressElement.innerHTML = `<div class="b3-dialog__scrim" style="z-index:400;opacity: 1"></div>
|
|
|
|
|
|
<div style="position: fixed;top: 45vh;width: 70vw;left: 15vw;color:#fff;z-index:400;">
|
|
|
|
|
|
<div style="margin: 8px 0;height: 8px;border-radius: 4px;overflow: hidden;background-color:#fff;"><div style="background-color: var(--b3-theme-primary);height: 8px;background-image: linear-gradient(-45deg, rgba(255, 255, 255, 0.2) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.2) 50%, rgba(255, 255, 255, 0.2) 75%, transparent 75%, transparent);animation: stripMove 450ms linear infinite;background-size: 50px 50px;"></div></div>
|
|
|
|
|
|
<div>${data.msg}</div>
|
|
|
|
|
|
</div>`;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
};
|
|
|
|
|
|
|
2023-02-20 19:37:42 +08:00
|
|
|
|
export const progressBackgroundTask = (tasks: { action: string }[]) => {
|
2023-01-24 20:31:35 +08:00
|
|
|
|
const backgroundTaskElement = document.querySelector(".status__backgroundtask");
|
|
|
|
|
|
if (!backgroundTaskElement) {
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
if (tasks.length === 0) {
|
|
|
|
|
|
backgroundTaskElement.classList.add("fn__none");
|
|
|
|
|
|
if (!window.siyuan.menus.menu.element.classList.contains("fn__none") &&
|
|
|
|
|
|
window.siyuan.menus.menu.element.getAttribute("data-name") === "statusBackgroundTask") {
|
|
|
|
|
|
window.siyuan.menus.menu.remove();
|
|
|
|
|
|
}
|
|
|
|
|
|
} else {
|
|
|
|
|
|
backgroundTaskElement.classList.remove("fn__none");
|
|
|
|
|
|
backgroundTaskElement.setAttribute("data-tasks", JSON.stringify(tasks));
|
|
|
|
|
|
backgroundTaskElement.innerHTML = tasks[0].action + "<div><div></div></div>";
|
|
|
|
|
|
}
|
2023-01-24 20:33:13 +08:00
|
|
|
|
};
|
2023-01-24 20:31:35 +08:00
|
|
|
|
|
2022-05-26 15:18:53 +08:00
|
|
|
|
export const bootSync = () => {
|
|
|
|
|
|
fetchPost("/api/sync/getBootSync", {}, response => {
|
|
|
|
|
|
if (response.code === 1) {
|
|
|
|
|
|
const dialog = new Dialog({
|
2023-04-20 10:05:24 +08:00
|
|
|
|
width: isMobile() ? "92vw" : "50vw",
|
2022-05-26 15:18:53 +08:00
|
|
|
|
title: "🌩️ " + window.siyuan.languages.bootSyncFailed,
|
|
|
|
|
|
content: `<div class="b3-dialog__content">${response.msg}</div>
|
|
|
|
|
|
<div class="b3-dialog__action">
|
|
|
|
|
|
<button class="b3-button b3-button--cancel">${window.siyuan.languages.cancel}</button><div class="fn__space"></div>
|
|
|
|
|
|
<button class="b3-button b3-button--text">${window.siyuan.languages.syncNow}</button>
|
|
|
|
|
|
</div>`
|
|
|
|
|
|
});
|
|
|
|
|
|
const btnsElement = dialog.element.querySelectorAll(".b3-button");
|
|
|
|
|
|
btnsElement[0].addEventListener("click", () => {
|
|
|
|
|
|
dialog.destroy();
|
|
|
|
|
|
});
|
|
|
|
|
|
btnsElement[1].addEventListener("click", () => {
|
|
|
|
|
|
if (btnsElement[1].getAttribute("disabled")) {
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
btnsElement[1].setAttribute("disabled", "disabled");
|
|
|
|
|
|
fetchPost("/api/sync/performBootSync", {}, (syncResponse) => {
|
|
|
|
|
|
if (syncResponse.code === 0) {
|
|
|
|
|
|
dialog.destroy();
|
|
|
|
|
|
}
|
|
|
|
|
|
btnsElement[1].removeAttribute("disabled");
|
|
|
|
|
|
});
|
|
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
});
|
|
|
|
|
|
};
|
|
|
|
|
|
|
2023-01-16 22:54:07 +08:00
|
|
|
|
export const setTitle = (title: string) => {
|
2022-05-26 15:18:53 +08:00
|
|
|
|
const dragElement = document.getElementById("drag");
|
2023-01-10 22:51:04 +08:00
|
|
|
|
const workspaceName = getWorkspaceName();
|
2022-05-26 15:18:53 +08:00
|
|
|
|
if (title === window.siyuan.languages.siyuanNote) {
|
2023-01-05 22:31:01 +08:00
|
|
|
|
const versionTitle = `${title} - ${workspaceName} - v${Constants.SIYUAN_VERSION}`;
|
2022-05-26 15:18:53 +08:00
|
|
|
|
document.title = versionTitle;
|
2023-01-16 21:33:20 +08:00
|
|
|
|
if (dragElement) {
|
|
|
|
|
|
dragElement.textContent = versionTitle;
|
|
|
|
|
|
dragElement.setAttribute("title", versionTitle);
|
|
|
|
|
|
}
|
2022-05-26 15:18:53 +08:00
|
|
|
|
} else {
|
2022-10-04 12:00:21 +08:00
|
|
|
|
title = title || "Untitled";
|
2023-01-16 16:01:48 +08:00
|
|
|
|
document.title = `${title} - ${workspaceName} - ${window.siyuan.languages.siyuanNote} v${Constants.SIYUAN_VERSION}`;
|
2023-01-16 21:33:20 +08:00
|
|
|
|
if (!dragElement) {
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
2023-01-16 16:01:48 +08:00
|
|
|
|
dragElement.setAttribute("title", title);
|
2023-01-16 22:36:01 +08:00
|
|
|
|
dragElement.innerHTML = escapeHtml(title);
|
2023-01-12 21:53:27 +08:00
|
|
|
|
}
|
2023-01-16 00:00:53 +08:00
|
|
|
|
};
|
2023-01-12 21:53:27 +08:00
|
|
|
|
|
2022-05-26 15:18:53 +08:00
|
|
|
|
export const downloadProgress = (data: { id: string, percent: number }) => {
|
2023-03-13 15:16:26 +08:00
|
|
|
|
const bazzarSideElement = document.querySelector("#configBazaarReadme .item__side");
|
|
|
|
|
|
if (!bazzarSideElement) {
|
2022-05-26 15:18:53 +08:00
|
|
|
|
return;
|
|
|
|
|
|
}
|
2023-03-13 15:16:26 +08:00
|
|
|
|
if (data.id !== JSON.parse(bazzarSideElement.getAttribute("data-obj")).repoURL) {
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
const btnElement = bazzarSideElement.querySelector('[data-type="install"]') as HTMLElement;
|
2022-05-26 15:18:53 +08:00
|
|
|
|
if (btnElement) {
|
|
|
|
|
|
if (data.percent >= 1) {
|
|
|
|
|
|
btnElement.parentElement.classList.add("fn__none");
|
2023-02-20 19:37:42 +08:00
|
|
|
|
btnElement.parentElement.nextElementSibling.classList.add("fn__none");
|
2022-05-26 15:18:53 +08:00
|
|
|
|
} else {
|
|
|
|
|
|
btnElement.classList.add("b3-button--progress");
|
2023-02-20 19:37:42 +08:00
|
|
|
|
btnElement.parentElement.nextElementSibling.firstElementChild.classList.add("b3-button--progress");
|
2022-05-26 15:18:53 +08:00
|
|
|
|
btnElement.innerHTML = `<span style="width: ${data.percent * 100}%"></span>`;
|
2023-02-20 19:37:42 +08:00
|
|
|
|
btnElement.parentElement.nextElementSibling.firstElementChild.innerHTML = `<span style="width: ${data.percent * 100}%"></span>`;
|
2022-05-26 15:18:53 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
};
|
2023-01-24 11:18:02 +08:00
|
|
|
|
|
2023-01-24 12:13:57 +08:00
|
|
|
|
export const processSync = (data?: IWebSocketData) => {
|
2023-03-10 10:43:15 +08:00
|
|
|
|
/// #if MOBILE
|
|
|
|
|
|
const menuSyncUseElement = document.querySelector("#menuSyncNow use");
|
|
|
|
|
|
const barSyncUseElement = document.querySelector("#toolbarSync use");
|
|
|
|
|
|
if (!data) {
|
|
|
|
|
|
if (!window.siyuan.config.sync.enabled || (0 === window.siyuan.config.sync.provider && needSubscribe(""))) {
|
|
|
|
|
|
menuSyncUseElement?.setAttribute("xlink:href", "#iconCloudOff");
|
|
|
|
|
|
barSyncUseElement.setAttribute("xlink:href", "#iconCloudOff");
|
|
|
|
|
|
} else {
|
|
|
|
|
|
menuSyncUseElement?.setAttribute("xlink:href", "#iconCloudSucc");
|
|
|
|
|
|
barSyncUseElement.setAttribute("xlink:href", "#iconCloudSucc");
|
|
|
|
|
|
}
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
menuSyncUseElement?.parentElement.classList.remove("fn__rotate");
|
|
|
|
|
|
barSyncUseElement.parentElement.classList.remove("fn__rotate");
|
|
|
|
|
|
if (data.code === 0) { // syncing
|
|
|
|
|
|
menuSyncUseElement?.parentElement.classList.add("fn__rotate");
|
|
|
|
|
|
barSyncUseElement.parentElement.classList.add("fn__rotate");
|
|
|
|
|
|
menuSyncUseElement?.setAttribute("xlink:href", "#iconRefresh");
|
|
|
|
|
|
barSyncUseElement.setAttribute("xlink:href", "#iconRefresh");
|
|
|
|
|
|
} else if (data.code === 2) { // error
|
|
|
|
|
|
menuSyncUseElement?.setAttribute("xlink:href", "#iconCloudError");
|
|
|
|
|
|
barSyncUseElement.setAttribute("xlink:href", "#iconCloudError");
|
|
|
|
|
|
} else if (data.code === 1) { // success
|
|
|
|
|
|
menuSyncUseElement?.setAttribute("xlink:href", "#iconCloudSucc");
|
|
|
|
|
|
barSyncUseElement.setAttribute("xlink:href", "#iconCloudSucc");
|
|
|
|
|
|
}
|
|
|
|
|
|
/// #else
|
|
|
|
|
|
const iconElement = document.querySelector("#barSync");
|
2023-01-24 15:05:25 +08:00
|
|
|
|
if (!iconElement) {
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
2023-01-24 20:33:13 +08:00
|
|
|
|
const useElement = iconElement.querySelector("use");
|
2023-01-24 12:13:57 +08:00
|
|
|
|
if (!data) {
|
2023-01-25 23:01:16 +08:00
|
|
|
|
iconElement.classList.remove("toolbar__item--active");
|
2023-01-24 12:13:57 +08:00
|
|
|
|
if (!window.siyuan.config.sync.enabled || (0 === window.siyuan.config.sync.provider && needSubscribe(""))) {
|
|
|
|
|
|
iconElement.setAttribute("aria-label", window.siyuan.languages["_kernel"]["53"]);
|
2023-01-24 20:33:13 +08:00
|
|
|
|
useElement.setAttribute("xlink:href", "#iconCloudOff");
|
2023-01-24 12:13:57 +08:00
|
|
|
|
} else {
|
2023-01-24 20:33:13 +08:00
|
|
|
|
useElement.setAttribute("xlink:href", "#iconCloudSucc");
|
2023-01-24 12:13:57 +08:00
|
|
|
|
}
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
2023-01-27 14:33:03 +08:00
|
|
|
|
iconElement.firstElementChild.classList.remove("fn__rotate");
|
2023-01-24 11:18:02 +08:00
|
|
|
|
if (data.code === 0) { // syncing
|
|
|
|
|
|
iconElement.classList.add("toolbar__item--active");
|
2023-01-27 14:33:03 +08:00
|
|
|
|
iconElement.firstElementChild.classList.add("fn__rotate");
|
|
|
|
|
|
useElement.setAttribute("xlink:href", "#iconRefresh");
|
2023-01-24 11:18:02 +08:00
|
|
|
|
} else if (data.code === 2) { // error
|
2023-01-24 17:39:27 +08:00
|
|
|
|
iconElement.classList.remove("toolbar__item--active");
|
2023-01-24 20:33:13 +08:00
|
|
|
|
useElement.setAttribute("xlink:href", "#iconCloudError");
|
2023-01-24 11:18:02 +08:00
|
|
|
|
} else if (data.code === 1) { // success
|
|
|
|
|
|
iconElement.classList.remove("toolbar__item--active");
|
2023-01-24 20:33:13 +08:00
|
|
|
|
useElement.setAttribute("xlink:href", "#iconCloudSucc");
|
2023-01-24 11:18:02 +08:00
|
|
|
|
}
|
|
|
|
|
|
iconElement.setAttribute("aria-label", data.msg);
|
2023-03-10 10:43:15 +08:00
|
|
|
|
/// #endif
|
2023-01-24 20:33:13 +08:00
|
|
|
|
};
|