|
@@ -0,0 +1,71 @@
|
|
|
+import {Tree} from "../../util/Tree";
|
|
|
+import {fetchPost} from "../../util/fetch";
|
|
|
+import {Constants} from "../../constants";
|
|
|
+import {hasClosestByClassName} from "../../protyle/util/hasClosest";
|
|
|
+import {onGet} from "../../protyle/util/onGet";
|
|
|
+import {openMobileFileById} from "../editor";
|
|
|
+import {MenuItem} from "../../menus/Menu";
|
|
|
+
|
|
|
+export class MobileBookmarks {
|
|
|
+ public element: HTMLElement;
|
|
|
+ private tree: Tree;
|
|
|
+ private openNodes: string[];
|
|
|
+
|
|
|
+ constructor() {
|
|
|
+ this.element = document.querySelector('#sidebar [data-type="sidebar-bookmark"]');
|
|
|
+ this.element.innerHTML = `<div class="toolbar">
|
|
|
+ <div class="fn__space"></div>
|
|
|
+ <div class="toolbar__text">
|
|
|
+ ${window.siyuan.languages.bookmark}
|
|
|
+ </div>
|
|
|
+ <span class="fn__space"></span>
|
|
|
+ <svg data-type="expand" class="toolbar__icon"><use xlink:href="#iconFullscreen"></use></svg>
|
|
|
+ <span class="fn__space"></span>
|
|
|
+ <svg data-type="collapse" class="toolbar__icon"><use xlink:href="#iconContract"></use></svg>
|
|
|
+</div>
|
|
|
+<div class="fn__flex-1 bookmarkList"></div>
|
|
|
+<img style="position: absolute;top: 0;left: 0;height: 100%;width: 100%;padding: 30vw;box-sizing: border-box;" src="/stage/loading-pure.svg">`;
|
|
|
+
|
|
|
+ this.tree = new Tree({
|
|
|
+ element: this.element.querySelector(".bookmarkList") as HTMLElement,
|
|
|
+ data: null,
|
|
|
+ click(element: HTMLElement) {
|
|
|
+ openMobileFileById(element.getAttribute("data-node-id"), true, [Constants.CB_GET_FOCUS]);
|
|
|
+ }
|
|
|
+ });
|
|
|
+ this.element.addEventListener("click", (event) => {
|
|
|
+ let target = event.target as HTMLElement;
|
|
|
+ while (target && !target.isEqualNode(this.element)) {
|
|
|
+ if (target.classList.contains("toolbar__icon")) {
|
|
|
+ const type = target.getAttribute("data-type");
|
|
|
+ switch (type) {
|
|
|
+ case "collapse":
|
|
|
+ this.tree.collapseAll();
|
|
|
+ break;
|
|
|
+ case "expand":
|
|
|
+ this.tree.expandAll();
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ target = target.parentElement;
|
|
|
+ }
|
|
|
+ });
|
|
|
+ this.update();
|
|
|
+ }
|
|
|
+
|
|
|
+ public update() {
|
|
|
+ this.element.lastElementChild.classList.remove("fn__none")
|
|
|
+ fetchPost("/api/bookmark/getBookmark", {}, response => {
|
|
|
+ if (this.openNodes) {
|
|
|
+ this.openNodes = this.tree.getExpandIds();
|
|
|
+ }
|
|
|
+ this.tree.updateData(response.data);
|
|
|
+ if (this.openNodes) {
|
|
|
+ this.tree.setExpandIds(this.openNodes);
|
|
|
+ } else {
|
|
|
+ this.openNodes = this.tree.getExpandIds();
|
|
|
+ }
|
|
|
+ this.element.lastElementChild.classList.add("fn__none")
|
|
|
+ });
|
|
|
+ }
|
|
|
+}
|