import {fetchPost} from "../../util/fetch"; import {hasClosestByClassName} from "../../protyle/util/hasClosest"; import {Dialog} from "../../dialog"; export const renderSnippet = () => { fetchPost("/api/snippet/getSnippet", {type: "all", enabled: 2}, (response) => { response.data.snippets.forEach((item: ISnippet) => { const id = `snippet${item.type === "css" ? "CSS" : "JS"}${item.id}`; let exitElement = document.getElementById(id) as HTMLScriptElement; if (!item.enabled) { if (exitElement) { exitElement.remove(); } return; } if (exitElement) { if (exitElement.innerHTML === item.content) { return; } exitElement.remove(); } if (item.type === "css") { document.head.insertAdjacentHTML("beforeend", ``); } else if (item.type === "js") { exitElement = document.createElement("script"); exitElement.type = "text/javascript"; exitElement.text = item.content; exitElement.id = id; document.head.appendChild(exitElement); } }); }); }; export const openSnippets = () => { fetchPost("/api/snippet/getSnippet", {type: "all", enabled: 2}, (response) => { let cssHTML = ""; let jsHTML = ""; response.data.snippets.forEach((item: ISnippet) => { if (item.type === "css") { cssHTML += genSnippet(item); } else { jsHTML += genSnippet(item); } }); const dialog = new Dialog({ width: "70vw", height: "80vh", content: `
CSS
JS
${cssHTML}
${jsHTML}
` }); response.data.snippets.forEach((item: ISnippet) => { const nameElement = (dialog.element.querySelector(`[data-id="${item.id}"] input`) as HTMLInputElement); nameElement.value = item.name; const contentElement = dialog.element.querySelector(`[data-id="${item.id}"] textarea`) as HTMLTextAreaElement; contentElement.textContent = item.content; }); const removeIds: string[] = []; dialog.element.addEventListener("click", (event) => { const target = event.target as HTMLElement; if (target.id === "addCodeSnippetCSS" || target.id === "addCodeSnippetJS") { target.parentElement.insertAdjacentHTML("beforebegin", genSnippet({ type: target.id === "addCodeSnippetCSS" ? "css" : "js", name: "", content: "", enabled: false })); return; } if (target.classList.contains("b3-button--cancel")) { dialog.destroy(); return; } if (target.classList.contains("b3-button--text")) { const snippets: ISnippet[] = []; dialog.element.querySelectorAll("[data-id]").forEach((item) => { snippets.push({ id: item.getAttribute("data-id"), name: item.querySelector("input").value, type: item.getAttribute("data-type"), content: item.querySelector("textarea").value, enabled: (item.querySelector(".b3-switch") as HTMLInputElement).checked }); }); fetchPost("/api/snippet/setSnippet", {snippets}, () => { removeIds.forEach(item => { const rmElement = document.querySelector(item); if (rmElement) { rmElement.remove(); } }); renderSnippet(); dialog.destroy(); }); return; } const tabElement = hasClosestByClassName(target, "item"); if (tabElement) { if (tabElement.getAttribute("data-type") === "css") { tabElement.classList.add("item--focus"); tabElement.nextElementSibling.classList.remove("item--focus"); tabElement.parentElement.nextElementSibling.firstElementChild.classList.remove("fn__none"); tabElement.parentElement.nextElementSibling.lastElementChild.classList.add("fn__none"); } else { tabElement.classList.add("item--focus"); tabElement.previousElementSibling.classList.remove("item--focus"); tabElement.parentElement.nextElementSibling.firstElementChild.classList.add("fn__none"); tabElement.parentElement.nextElementSibling.lastElementChild.classList.remove("fn__none"); } return; } const removeElement = hasClosestByClassName(target, "b3-tooltips"); if (removeElement) { const itemElement = removeElement.parentElement.parentElement; removeIds.push("#snippet" + (itemElement.getAttribute("data-type") === "css" ? "CSS" : "JS") + itemElement.getAttribute("data-id")); itemElement.nextElementSibling.remove(); itemElement.remove(); } }); }); }; const genSnippet = (options: ISnippet) => { return `
`; };