import {focusByRange, getEditorRange} from "../protyle/util/selection"; import {fetchPost} from "../util/fetch"; import {Dialog} from "../dialog"; import {isMobile} from "../util/functions"; import {hideMessage, showMessage} from "../dialog/message"; const genCardItem = (item: { id: string, name: string }) => { return `
  • ${item.name}
  • `; }; export const makeCard = (nodeElement: Element[]) => { const range = getEditorRange(nodeElement[0]); fetchPost("/api/riff/getRiffDecks", {}, (response) => { let html = ""; const ids: string[] = []; nodeElement.forEach(item => { ids.push(item.getAttribute("data-node-id")); }); response.data.forEach((item: { id: string, name: string }) => { html += genCardItem(item); }); const dialog = new Dialog({ width: isMobile() ? "80vw" : "50vw", height: "70vh", title: window.siyuan.languages.riffCard, content: `
    `, destroyCallback() { focusByRange(range); } }); dialog.element.addEventListener("click", (event) => { let target = event.target as HTMLElement; while (target && !target.isSameNode(dialog.element)) { const type = target.getAttribute("data-type"); if (type === "create") { let msgId = ""; const inputElement = dialog.element.querySelector(".b3-text-field") as HTMLInputElement; if (inputElement.value) { if (msgId) { hideMessage(msgId); } fetchPost("/api/riff/createRiffDeck", {name: inputElement.value}, (response) => { dialog.element.querySelector(".b3-list").insertAdjacentHTML("afterbegin", genCardItem(response.data)); inputElement.value = ""; }); } else { msgId = showMessage(window.siyuan.languages._kernel[142]); } event.stopPropagation(); event.preventDefault(); break; } else if (type === "add") { fetchPost("/api/riff/addRiffCards", { deckID: target.parentElement.getAttribute("data-id"), blockIDs: ids }, () => { showMessage(window.siyuan.languages.addDeck); }); event.stopPropagation(); event.preventDefault(); break; } else if (type === "remove") { fetchPost("/api/riff/removeRiffCards", { deckID: target.parentElement.getAttribute("data-id"), blockIDs: ids }, () => { showMessage(window.siyuan.languages.removeDeck); }); event.stopPropagation(); event.preventDefault(); break; } target = target.parentElement; } }); }); };