2022-06-29 10:35:35 +08:00
|
|
|
import {getAllModels} from "../getAll";
|
|
|
|
|
import {Tab} from "../Tab";
|
|
|
|
|
import {Graph} from "./Graph";
|
|
|
|
|
import {Outline} from "./Outline";
|
2023-08-15 16:55:32 +08:00
|
|
|
import {resizeTabs, switchWnd} from "../util";
|
2022-09-28 23:53:04 +08:00
|
|
|
import {Backlink} from "./Backlink";
|
2022-06-29 10:35:35 +08:00
|
|
|
|
2023-06-01 20:50:49 +08:00
|
|
|
export const openBacklink = (protyle: IProtyle) => {
|
2022-09-28 23:53:04 +08:00
|
|
|
const backlink = getAllModels().backlink.find(item => {
|
2022-06-29 10:35:35 +08:00
|
|
|
if (item.blockId === protyle.block.id && item.type === "local") {
|
|
|
|
|
item.parent.parent.removeTab(item.parent.id);
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
if (backlink) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
const newWnd = protyle.model.parent.parent.split("lr");
|
|
|
|
|
const tab = new Tab({
|
|
|
|
|
icon: "iconLink",
|
2023-04-25 19:36:42 +08:00
|
|
|
title: protyle.title.editElement.textContent || "Untitled",
|
2022-06-29 10:35:35 +08:00
|
|
|
callback(tab: Tab) {
|
2022-09-28 23:53:04 +08:00
|
|
|
tab.addModel(new Backlink({
|
2023-06-01 20:50:49 +08:00
|
|
|
app: protyle.app,
|
2022-06-29 10:35:35 +08:00
|
|
|
type: "local",
|
|
|
|
|
tab,
|
2022-10-27 22:41:12 +08:00
|
|
|
// 通过搜索打开的包含上下文,但不是缩放,因此需要传 rootID https://ld246.com/article/1666786639708
|
|
|
|
|
blockId: protyle.block.showAll ? protyle.block.id : protyle.block.rootID,
|
2022-06-29 10:35:35 +08:00
|
|
|
rootId: protyle.block.rootID,
|
|
|
|
|
}));
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
newWnd.addTab(tab);
|
|
|
|
|
};
|
|
|
|
|
|
2023-06-01 20:50:49 +08:00
|
|
|
export const openGraph = (protyle: IProtyle) => {
|
2022-06-29 10:35:35 +08:00
|
|
|
const graph = getAllModels().graph.find(item => {
|
|
|
|
|
if (item.blockId === protyle.block.id && item.type === "local") {
|
|
|
|
|
item.parent.parent.removeTab(item.parent.id);
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
if (graph) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
const wnd = protyle.model.parent.parent.split("lr");
|
|
|
|
|
const tab = new Tab({
|
|
|
|
|
icon: "iconGraph",
|
2023-04-25 19:36:42 +08:00
|
|
|
title: protyle.title.editElement.textContent || "Untitled",
|
2022-06-29 10:35:35 +08:00
|
|
|
callback(tab: Tab) {
|
|
|
|
|
tab.addModel(new Graph({
|
2023-06-01 20:50:49 +08:00
|
|
|
app: protyle.app,
|
2022-06-29 10:35:35 +08:00
|
|
|
type: "local",
|
|
|
|
|
tab,
|
|
|
|
|
blockId: protyle.block.id,
|
|
|
|
|
rootId: protyle.block.rootID,
|
|
|
|
|
}));
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
wnd.addTab(tab);
|
|
|
|
|
};
|
|
|
|
|
|
2023-06-01 20:50:49 +08:00
|
|
|
export const openOutline = (protyle: IProtyle) => {
|
2022-06-29 10:35:35 +08:00
|
|
|
const outlinePanel = getAllModels().outline.find(item => {
|
|
|
|
|
if (item.blockId === protyle.block.rootID && item.type === "local") {
|
|
|
|
|
item.parent.parent.removeTab(item.parent.id);
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
if (outlinePanel) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
const newWnd = protyle.model.parent.parent.split("lr");
|
|
|
|
|
const tab = new Tab({
|
|
|
|
|
icon: "iconAlignCenter",
|
2023-04-25 19:36:42 +08:00
|
|
|
title: protyle.title.editElement.textContent || "Untitled",
|
2022-06-29 10:35:35 +08:00
|
|
|
callback(tab: Tab) {
|
|
|
|
|
tab.addModel(new Outline({
|
2023-06-01 20:50:49 +08:00
|
|
|
app: protyle.app,
|
2022-06-29 10:35:35 +08:00
|
|
|
type: "local",
|
|
|
|
|
tab,
|
|
|
|
|
blockId: protyle.block.rootID,
|
2023-06-18 22:40:44 +08:00
|
|
|
isPreview: !protyle.preview.element.classList.contains("fn__none")
|
2022-06-29 10:35:35 +08:00
|
|
|
}));
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
newWnd.addTab(tab);
|
|
|
|
|
newWnd.element.classList.remove("fn__flex-1");
|
|
|
|
|
newWnd.element.style.width = "200px";
|
|
|
|
|
switchWnd(newWnd, protyle.model.parent.parent);
|
|
|
|
|
};
|
2023-02-11 21:21:13 +08:00
|
|
|
|
|
|
|
|
export const resetFloatDockSize = () => {
|
2023-02-13 15:47:06 +08:00
|
|
|
if (!window.siyuan.layout.leftDock.pin && window.siyuan.layout.leftDock.layout.element.style.opacity === "1") {
|
2023-02-15 11:41:50 +08:00
|
|
|
window.siyuan.layout.leftDock.showDock(true);
|
2023-02-11 21:21:13 +08:00
|
|
|
}
|
2023-02-15 11:41:50 +08:00
|
|
|
if (!window.siyuan.layout.rightDock.pin && window.siyuan.layout.rightDock.layout.element.style.opacity === "1") {
|
|
|
|
|
window.siyuan.layout.rightDock.showDock(true);
|
2023-02-11 21:21:13 +08:00
|
|
|
}
|
|
|
|
|
if (!window.siyuan.layout.bottomDock.pin && window.siyuan.layout.bottomDock.layout.element.style.opacity === "1") {
|
2023-02-17 15:46:46 +08:00
|
|
|
window.siyuan.layout.bottomDock.showDock(true);
|
2023-02-11 21:21:13 +08:00
|
|
|
}
|
2023-02-11 21:34:42 +08:00
|
|
|
};
|
2023-08-15 16:55:32 +08:00
|
|
|
|
|
|
|
|
export const toggleDockBar = (useElement:Element)=> {
|
|
|
|
|
const dockIsShow = useElement.getAttribute("xlink:href") === "#iconHideDock";
|
|
|
|
|
if (dockIsShow) {
|
|
|
|
|
useElement.setAttribute("xlink:href", "#iconDock");
|
|
|
|
|
} else {
|
|
|
|
|
useElement.setAttribute("xlink:href", "#iconHideDock");
|
|
|
|
|
}
|
|
|
|
|
document.querySelectorAll(".dock").forEach(item => {
|
|
|
|
|
if (dockIsShow) {
|
|
|
|
|
item.classList.add("fn__none");
|
|
|
|
|
} else if (item.querySelectorAll(".dock__item").length > 1) {
|
|
|
|
|
item.classList.remove("fn__none");
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
resizeTabs();
|
|
|
|
|
resetFloatDockSize();
|
2023-08-18 20:03:04 +08:00
|
|
|
};
|