mirror of
https://github.com/siyuan-note/siyuan.git
synced 2025-05-14 08:01:19 +08:00
128 lines
6.5 KiB
TypeScript
128 lines
6.5 KiB
TypeScript
import {fetchPost} from "../util/fetch";
|
|
|
|
export const fileTree = {
|
|
element: undefined as Element,
|
|
genHTML: () => {
|
|
return `<label class="fn__flex b3-label">
|
|
<div class="fn__flex-1">
|
|
${window.siyuan.languages.selectOpen}
|
|
<div class="b3-label__text">${window.siyuan.languages.fileTree2}</div>
|
|
</div>
|
|
<span class="fn__space"></span>
|
|
<input class="b3-switch fn__flex-center" id="alwaysSelectOpenedFile" type="checkbox"${window.siyuan.config.fileTree.alwaysSelectOpenedFile ? " checked" : ""}/>
|
|
</label>
|
|
<label class="fn__flex b3-label">
|
|
<div class="fn__flex-1">
|
|
${window.siyuan.languages.fileTree7}
|
|
<div class="b3-label__text">${window.siyuan.languages.fileTree8}</div>
|
|
</div>
|
|
<span class="fn__space"></span>
|
|
<input class="b3-switch fn__flex-center" id="openFilesUseCurrentTab" type="checkbox"${window.siyuan.config.fileTree.openFilesUseCurrentTab ? " checked" : ""}/>
|
|
</label>
|
|
<label class="fn__flex b3-label">
|
|
<div class="fn__flex-1">
|
|
${window.siyuan.languages.fileTree9}
|
|
<div class="b3-label__text">${window.siyuan.languages.fileTree10}</div>
|
|
</div>
|
|
<span class="fn__space"></span>
|
|
<input class="b3-switch fn__flex-center" id="closeTabsOnStart" type="checkbox"${window.siyuan.config.fileTree.closeTabsOnStart ? " checked" : ""}/>
|
|
</label>
|
|
<label class="fn__flex b3-label">
|
|
<div class="fn__flex-1">
|
|
${window.siyuan.languages.fileTree18}
|
|
<div class="b3-label__text">${window.siyuan.languages.fileTree19}</div>
|
|
</div>
|
|
<span class="fn__space"></span>
|
|
<input class="b3-switch fn__flex-center" id="allowCreateDeeper" type="checkbox"${window.siyuan.config.fileTree.allowCreateDeeper ? " checked" : ""}/>
|
|
</label>
|
|
<label class="fn__flex b3-label">
|
|
<div class="fn__flex-1">
|
|
${window.siyuan.languages.fileTree3}
|
|
<div class="b3-label__text">${window.siyuan.languages.fileTree4}</div>
|
|
</div>
|
|
<span class="fn__space"></span>
|
|
<input class="b3-switch fn__flex-center" id="removeDocWithoutConfirm" type="checkbox"${window.siyuan.config.fileTree.removeDocWithoutConfirm ? " checked" : ""}/>
|
|
</label>
|
|
<label class="fn__flex b3-label">
|
|
<div class="fn__flex-1">
|
|
${window.siyuan.languages.fileTree20}
|
|
<div class="b3-label__text">${window.siyuan.languages.fileTree21}</div>
|
|
</div>
|
|
<span class="fn__space"></span>
|
|
<input class="b3-switch fn__flex-center" id="useSingleLineSave" type="checkbox"${window.siyuan.config.fileTree.useSingleLineSave ? " checked" : ""}/>
|
|
</label>
|
|
<label class="fn__flex b3-label config__item">
|
|
<div class="fn__flex-1">
|
|
${window.siyuan.languages.fileTree12}
|
|
<div class="b3-label__text">${window.siyuan.languages.fileTree13}</div>
|
|
</div>
|
|
<span class="fn__space"></span>
|
|
<input class="b3-text-field fn__flex-center fn__size200" id="docCreateSavePath" value="">
|
|
</label>
|
|
<label class="b3-label fn__flex config__item">
|
|
<div class="fn__flex-1">
|
|
${window.siyuan.languages.fileTree5}
|
|
<div class="b3-label__text">${window.siyuan.languages.fileTree6}</div>
|
|
</div>
|
|
<span class="fn__space"></span>
|
|
<input class="b3-text-field fn__flex-center fn__size200" id="refCreateSavePath" value="${window.siyuan.config.fileTree.refCreateSavePath}">
|
|
</label>
|
|
<label class="fn__flex b3-label config__item">
|
|
<div class="fn__flex-1">
|
|
${window.siyuan.languages.fileTree16}
|
|
<div class="b3-label__text">${window.siyuan.languages.fileTree17}</div>
|
|
</div>
|
|
<span class="fn__space"></span>
|
|
<input class="b3-text-field fn__flex-center fn__size200" id="maxListCount" type="number" min="1" max="10240" value="${window.siyuan.config.fileTree.maxListCount}">
|
|
</label>
|
|
<label class="fn__flex b3-label config__item">
|
|
<div class="fn__flex-1">
|
|
${window.siyuan.languages.tabLimit}
|
|
<div class="b3-label__text">${window.siyuan.languages.tabLimit1}</div>
|
|
</div>
|
|
<span class="fn__space"></span>
|
|
<input class="b3-text-field fn__flex-center fn__size200" id="maxOpenTabCount" type="number" min="1" max="32" value="${window.siyuan.config.fileTree.maxOpenTabCount}">
|
|
</label>`;
|
|
},
|
|
_send() {
|
|
// 限制页签最大打开数量为 `32` https://github.com/siyuan-note/siyuan/issues/6303
|
|
let inputMaxOpenTabCount = parseInt((fileTree.element.querySelector("#maxOpenTabCount") as HTMLInputElement).value);
|
|
if (32 < inputMaxOpenTabCount) {
|
|
inputMaxOpenTabCount = 32;
|
|
(fileTree.element.querySelector("#maxOpenTabCount") as HTMLInputElement).value = "32";
|
|
}
|
|
if (1 > inputMaxOpenTabCount) {
|
|
inputMaxOpenTabCount = 1;
|
|
(fileTree.element.querySelector("#maxOpenTabCount") as HTMLInputElement).value = "1";
|
|
}
|
|
|
|
fetchPost("/api/setting/setFiletree", {
|
|
sort: window.siyuan.config.fileTree.sort,
|
|
alwaysSelectOpenedFile: (fileTree.element.querySelector("#alwaysSelectOpenedFile") as HTMLInputElement).checked,
|
|
refCreateSavePath: (fileTree.element.querySelector("#refCreateSavePath") as HTMLInputElement).value,
|
|
docCreateSavePath: (fileTree.element.querySelector("#docCreateSavePath") as HTMLInputElement).value,
|
|
openFilesUseCurrentTab: (fileTree.element.querySelector("#openFilesUseCurrentTab") as HTMLInputElement).checked,
|
|
closeTabsOnStart: (fileTree.element.querySelector("#closeTabsOnStart") as HTMLInputElement).checked,
|
|
allowCreateDeeper: (fileTree.element.querySelector("#allowCreateDeeper") as HTMLInputElement).checked,
|
|
removeDocWithoutConfirm: (fileTree.element.querySelector("#removeDocWithoutConfirm") as HTMLInputElement).checked,
|
|
useSingleLineSave: (fileTree.element.querySelector("#useSingleLineSave") as HTMLInputElement).checked,
|
|
maxListCount: parseInt((fileTree.element.querySelector("#maxListCount") as HTMLInputElement).value),
|
|
maxOpenTabCount: inputMaxOpenTabCount,
|
|
}, response => {
|
|
fileTree.onSetfiletree(response.data);
|
|
});
|
|
},
|
|
bindEvent: () => {
|
|
(fileTree.element.querySelector("#docCreateSavePath") as HTMLInputElement).value = window.siyuan.config.fileTree.docCreateSavePath;
|
|
(fileTree.element.querySelector("#refCreateSavePath") as HTMLInputElement).value = window.siyuan.config.fileTree.refCreateSavePath;
|
|
fileTree.element.querySelectorAll("input").forEach((item) => {
|
|
item.addEventListener("change", () => {
|
|
fileTree._send();
|
|
});
|
|
});
|
|
},
|
|
onSetfiletree: (fileTree: IFileTree) => {
|
|
window.siyuan.config.fileTree = fileTree;
|
|
}
|
|
};
|