import { CustomSelectV2 } from "./chunk-T5V6LQ42.js"; import { apiFetch, uiPatterns } from "./chunk-VOGCL6QZ.js"; import "./chunk-JSBRDJBE.js"; // frontend/js/vendor/nanoid.js var a = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict"; var nanoid = (e = 21) => { let t = "", r = crypto.getRandomValues(new Uint8Array(e)); for (let n = 0; n < e; n++) t += a[63 & r[n]]; return t; }; // frontend/js/vendor/marked.min.js function L() { return { async: false, breaks: false, extensions: null, gfm: true, hooks: null, pedantic: false, renderer: null, silent: false, tokenizer: null, walkTokens: null }; } var T = L(); function Z(u3) { T = u3; } var C = { exec: () => null }; function k(u3, e = "") { let t = typeof u3 == "string" ? u3 : u3.source, n = { replace: (r, i) => { let s = typeof i == "string" ? i : i.source; return s = s.replace(m.caret, "$1"), t = t.replace(r, s), n; }, getRegex: () => new RegExp(t, e) }; return n; } var me = (() => { try { return !!new RegExp("(?<=1)(?/, blockquoteSetextReplace: /\n {0,3}((?:=+|-+) *)(?=\n|$)/g, blockquoteSetextReplace2: /^ {0,3}>[ \t]?/gm, listReplaceTabs: /^\t+/, listReplaceNesting: /^ {1,4}(?=( {4})*[^ ])/g, listIsTask: /^\[[ xX]\] +\S/, listReplaceTask: /^\[[ xX]\] +/, listTaskCheckbox: /\[[ xX]\]/, anyLine: /\n.*\n/, hrefBrackets: /^<(.*)>$/, tableDelimiter: /[:|]/, tableAlignChars: /^\||\| *$/g, tableRowBlankLine: /\n[ \t]*$/, tableAlignRight: /^ *-+: *$/, tableAlignCenter: /^ *:-+: *$/, tableAlignLeft: /^ *:-+ *$/, startATag: /^/i, startPreScriptTag: /^<(pre|code|kbd|script)(\s|>)/i, endPreScriptTag: /^<\/(pre|code|kbd|script)(\s|>)/i, startAngleBracket: /^$/, pedanticHrefTitle: /^([^'"]*[^\s])\s+(['"])(.*)\2/, unicodeAlphaNumeric: /[\p{L}\p{N}]/u, escapeTest: /[&<>"']/, escapeReplace: /[&<>"']/g, escapeTestNoEncode: /[<>"']|&(?!(#\d{1,7}|#[Xx][a-fA-F0-9]{1,6}|\w+);)/, escapeReplaceNoEncode: /[<>"']|&(?!(#\d{1,7}|#[Xx][a-fA-F0-9]{1,6}|\w+);)/g, unescapeTest: /&(#(?:\d+)|(?:#x[0-9A-Fa-f]+)|(?:\w+));?/ig, caret: /(^|[^\[])\^/g, percentDecode: /%25/g, findPipe: /\|/g, splitPipe: / \|/, slashPipe: /\\\|/g, carriageReturn: /\r\n|\r/g, spaceLine: /^ +$/gm, notSpaceStart: /^\S*/, endingNewline: /\n$/, listItemRegex: (u3) => new RegExp(`^( {0,3}${u3})((?:[ ][^\\n]*)?(?:\\n|$))`), nextBulletRegex: (u3) => new RegExp(`^ {0,${Math.min(3, u3 - 1)}}(?:[*+-]|\\d{1,9}[.)])((?:[ ][^\\n]*)?(?:\\n|$))`), hrRegex: (u3) => new RegExp(`^ {0,${Math.min(3, u3 - 1)}}((?:- *){3,}|(?:_ *){3,}|(?:\\* *){3,})(?:\\n+|$)`), fencesBeginRegex: (u3) => new RegExp(`^ {0,${Math.min(3, u3 - 1)}}(?:\`\`\`|~~~)`), headingBeginRegex: (u3) => new RegExp(`^ {0,${Math.min(3, u3 - 1)}}#`), htmlBeginRegex: (u3) => new RegExp(`^ {0,${Math.min(3, u3 - 1)}}<(?:[a-z].*>|!--)`, "i") }; var xe = /^(?:[ \t]*(?:\n|$))+/; var be = /^((?: {4}| {0,3}\t)[^\n]+(?:\n(?:[ \t]*(?:\n|$))*)?)+/; var Re = /^ {0,3}(`{3,}(?=[^`\n]*(?:\n|$))|~{3,})([^\n]*)(?:\n|$)(?:|([\s\S]*?)(?:\n|$))(?: {0,3}\1[~`]* *(?=\n|$)|$)/; var I = /^ {0,3}((?:-[\t ]*){3,}|(?:_[ \t]*){3,}|(?:\*[ \t]*){3,})(?:\n+|$)/; var Te = /^ {0,3}(#{1,6})(?=\s|$)(.*)(?:\n+|$)/; var N = /(?:[*+-]|\d{1,9}[.)])/; var re = /^(?!bull |blockCode|fences|blockquote|heading|html|table)((?:.|\n(?!\s*?\n|bull |blockCode|fences|blockquote|heading|html|table))+?)\n {0,3}(=+|-+) *(?:\n+|$)/; var se = k(re).replace(/bull/g, N).replace(/blockCode/g, /(?: {4}| {0,3}\t)/).replace(/fences/g, / {0,3}(?:`{3,}|~{3,})/).replace(/blockquote/g, / {0,3}>/).replace(/heading/g, / {0,3}#{1,6}/).replace(/html/g, / {0,3}<[^\n>]+>\n/).replace(/\|table/g, "").getRegex(); var Oe = k(re).replace(/bull/g, N).replace(/blockCode/g, /(?: {4}| {0,3}\t)/).replace(/fences/g, / {0,3}(?:`{3,}|~{3,})/).replace(/blockquote/g, / {0,3}>/).replace(/heading/g, / {0,3}#{1,6}/).replace(/html/g, / {0,3}<[^\n>]+>\n/).replace(/table/g, / {0,3}\|?(?:[:\- ]*\|)+[\:\- ]*\n/).getRegex(); var Q = /^([^\n]+(?:\n(?!hr|heading|lheading|blockquote|fences|list|html|table| +\n)[^\n]+)*)/; var we = /^[^\n]+/; var F = /(?!\s*\])(?:\\[\s\S]|[^\[\]\\])+/; var ye = k(/^ {0,3}\[(label)\]: *(?:\n[ \t]*)?([^<\s][^\s]*|<.*?>)(?:(?: +(?:\n[ \t]*)?| *\n[ \t]*)(title))? *(?:\n+|$)/).replace("label", F).replace("title", /(?:"(?:\\"?|[^"\\])*"|'[^'\n]*(?:\n[^'\n]+)*\n?'|\([^()]*\))/).getRegex(); var Pe = k(/^( {0,3}bull)([ \t][^\n]+?)?(?:\n|$)/).replace(/bull/g, N).getRegex(); var v = "address|article|aside|base|basefont|blockquote|body|caption|center|col|colgroup|dd|details|dialog|dir|div|dl|dt|fieldset|figcaption|figure|footer|form|frame|frameset|h[1-6]|head|header|hr|html|iframe|legend|li|link|main|menu|menuitem|meta|nav|noframes|ol|optgroup|option|p|param|search|section|summary|table|tbody|td|tfoot|th|thead|title|tr|track|ul"; var j = /|$))/; var Se = k("^ {0,3}(?:<(script|pre|style|textarea)[\\s>][\\s\\S]*?(?:[^\\n]*\\n+|$)|comment[^\\n]*(\\n+|$)|<\\?[\\s\\S]*?(?:\\?>\\n*|$)|\\n*|$)|\\n*|$)|)[\\s\\S]*?(?:(?:\\n[ ]*)+\\n|$)|<(?!script|pre|style|textarea)([a-z][\\w-]*)(?:attribute)*? */?>(?=[ \\t]*(?:\\n|$))[\\s\\S]*?(?:(?:\\n[ ]*)+\\n|$)|(?=[ \\t]*(?:\\n|$))[\\s\\S]*?(?:(?:\\n[ ]*)+\\n|$))", "i").replace("comment", j).replace("tag", v).replace("attribute", / +[a-zA-Z:_][\w.:-]*(?: *= *"[^"\n]*"| *= *'[^'\n]*'| *= *[^\s"'=<>`]+)?/).getRegex(); var ie = k(Q).replace("hr", I).replace("heading", " {0,3}#{1,6}(?:\\s|$)").replace("|lheading", "").replace("|table", "").replace("blockquote", " {0,3}>").replace("fences", " {0,3}(?:`{3,}(?=[^`\\n]*\\n)|~{3,})[^\\n]*\\n").replace("list", " {0,3}(?:[*+-]|1[.)]) ").replace("html", ")|<(?:script|pre|style|textarea|!--)").replace("tag", v).getRegex(); var $e = k(/^( {0,3}> ?(paragraph|[^\n]*)(?:\n|$))+/).replace("paragraph", ie).getRegex(); var U = { blockquote: $e, code: be, def: ye, fences: Re, heading: Te, hr: I, html: Se, lheading: se, list: Pe, newline: xe, paragraph: ie, table: C, text: we }; var te = k("^ *([^\\n ].*)\\n {0,3}((?:\\| *)?:?-+:? *(?:\\| *:?-+:? *)*(?:\\| *)?)(?:\\n((?:(?! *\\n|hr|heading|blockquote|code|fences|list|html).*(?:\\n|$))*)\\n*|$)").replace("hr", I).replace("heading", " {0,3}#{1,6}(?:\\s|$)").replace("blockquote", " {0,3}>").replace("code", "(?: {4}| {0,3} )[^\\n]").replace("fences", " {0,3}(?:`{3,}(?=[^`\\n]*\\n)|~{3,})[^\\n]*\\n").replace("list", " {0,3}(?:[*+-]|1[.)]) ").replace("html", ")|<(?:script|pre|style|textarea|!--)").replace("tag", v).getRegex(); var _e = { ...U, lheading: Oe, table: te, paragraph: k(Q).replace("hr", I).replace("heading", " {0,3}#{1,6}(?:\\s|$)").replace("|lheading", "").replace("table", te).replace("blockquote", " {0,3}>").replace("fences", " {0,3}(?:`{3,}(?=[^`\\n]*\\n)|~{3,})[^\\n]*\\n").replace("list", " {0,3}(?:[*+-]|1[.)]) ").replace("html", ")|<(?:script|pre|style|textarea|!--)").replace("tag", v).getRegex() }; var Le = { ...U, html: k(`^ *(?:comment *(?:\\n|\\s*$)|<(tag)[\\s\\S]+? *(?:\\n{2,}|\\s*$)|\\s]*)*?/?> *(?:\\n{2,}|\\s*$))`).replace("comment", j).replace(/tag/g, "(?!(?:a|em|strong|small|s|cite|q|dfn|abbr|data|time|code|var|samp|kbd|sub|sup|i|b|u|mark|ruby|rt|rp|bdi|bdo|span|br|wbr|ins|del|img)\\b)\\w+(?!:|[^\\w\\s@]*@)\\b").getRegex(), def: /^ *\[([^\]]+)\]: *]+)>?(?: +(["(][^\n]+[")]))? *(?:\n+|$)/, heading: /^(#{1,6})(.*)(?:\n+|$)/, fences: C, lheading: /^(.+?)\n {0,3}(=+|-+) *(?:\n+|$)/, paragraph: k(Q).replace("hr", I).replace("heading", ` *#{1,6} *[^ ]`).replace("lheading", se).replace("|table", "").replace("blockquote", " {0,3}>").replace("|fences", "").replace("|list", "").replace("|html", "").replace("|tag", "").getRegex() }; var Me = /^\\([!"#$%&'()*+,\-./:;<=>?@\[\]\\^_`{|}~])/; var ze = /^(`+)([^`]|[^`][\s\S]*?[^`])\1(?!`)/; var oe = /^( {2,}|\\)\n(?!\s*$)/; var Ae = /^(`+|[^`])(?:(?= {2,}\n)|[\s\S]*?(?:(?=[\\`+)[^`]+\k(?!`))*?\]\((?:\\[\s\S]|[^\\\(\)]|\((?:\\[\s\S]|[^\\\(\)])*\))*\)/).replace("precode-", me ? "(?`+)[^`]+\k(?!`)/).replace("html", /<(?! )[^<>]*?>/).getRegex(); var ue = /^(?:\*+(?:((?!\*)punct)|[^\s*]))|^_+(?:((?!_)punct)|([^\s_]))/; var qe = k(ue, "u").replace(/punct/g, D).getRegex(); var ve = k(ue, "u").replace(/punct/g, le).getRegex(); var pe = "^[^_*]*?__[^_*]*?\\*[^_*]*?(?=__)|[^*]+(?=[^*])|(?!\\*)punct(\\*+)(?=[\\s]|$)|notPunctSpace(\\*+)(?!\\*)(?=punctSpace|$)|(?!\\*)punctSpace(\\*+)(?=notPunctSpace)|[\\s](\\*+)(?!\\*)(?=punct)|(?!\\*)punct(\\*+)(?!\\*)(?=punct)|notPunctSpace(\\*+)(?=notPunctSpace)"; var De = k(pe, "gu").replace(/notPunctSpace/g, ae).replace(/punctSpace/g, K).replace(/punct/g, D).getRegex(); var He = k(pe, "gu").replace(/notPunctSpace/g, Ee).replace(/punctSpace/g, Ie).replace(/punct/g, le).getRegex(); var Ze = k("^[^_*]*?\\*\\*[^_*]*?_[^_*]*?(?=\\*\\*)|[^_]+(?=[^_])|(?!_)punct(_+)(?=[\\s]|$)|notPunctSpace(_+)(?!_)(?=punctSpace|$)|(?!_)punctSpace(_+)(?=notPunctSpace)|[\\s](_+)(?!_)(?=punct)|(?!_)punct(_+)(?!_)(?=punct)", "gu").replace(/notPunctSpace/g, ae).replace(/punctSpace/g, K).replace(/punct/g, D).getRegex(); var Ge = k(/\\(punct)/, "gu").replace(/punct/g, D).getRegex(); var Ne = k(/^<(scheme:[^\s\x00-\x1f<>]*|email)>/).replace("scheme", /[a-zA-Z][a-zA-Z0-9+.-]{1,31}/).replace("email", /[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+(@)[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+(?![-_])/).getRegex(); var Qe = k(j).replace("(?:-->|$)", "-->").getRegex(); var Fe = k("^comment|^|^<[a-zA-Z][\\w-]*(?:attribute)*?\\s*/?>|^<\\?[\\s\\S]*?\\?>|^|^").replace("comment", Qe).replace("attribute", /\s+[a-zA-Z:_][\w.:-]*(?:\s*=\s*"[^"]*"|\s*=\s*'[^']*'|\s*=\s*[^\s"'=<>`]+)?/).getRegex(); var q = /(?:\[(?:\\[\s\S]|[^\[\]\\])*\]|\\[\s\S]|`+[^`]*?`+(?!`)|[^\[\]\\`])*?/; var je = k(/^!?\[(label)\]\(\s*(href)(?:(?:[ \t]*(?:\n[ \t]*)?)(title))?\s*\)/).replace("label", q).replace("href", /<(?:\\.|[^\n<>\\])+>|[^ \t\n\x00-\x1f]*/).replace("title", /"(?:\\"?|[^"\\])*"|'(?:\\'?|[^'\\])*'|\((?:\\\)?|[^)\\])*\)/).getRegex(); var ce = k(/^!?\[(label)\]\[(ref)\]/).replace("label", q).replace("ref", F).getRegex(); var he = k(/^!?\[(ref)\](?:\[\])?/).replace("ref", F).getRegex(); var Ue = k("reflink|nolink(?!\\()", "g").replace("reflink", ce).replace("nolink", he).getRegex(); var ne = /[hH][tT][tT][pP][sS]?|[fF][tT][pP]/; var W = { _backpedal: C, anyPunctuation: Ge, autolink: Ne, blockSkip: Be, br: oe, code: ze, del: C, emStrongLDelim: qe, emStrongRDelimAst: De, emStrongRDelimUnd: Ze, escape: Me, link: je, nolink: he, punctuation: Ce, reflink: ce, reflinkSearch: Ue, tag: Fe, text: Ae, url: C }; var Ke = { ...W, link: k(/^!?\[(label)\]\((.*?)\)/).replace("label", q).getRegex(), reflink: k(/^!?\[(label)\]\s*\[([^\]]*)\]/).replace("label", q).getRegex() }; var G = { ...W, emStrongRDelimAst: He, emStrongLDelim: ve, url: k(/^((?:protocol):\/\/|www\.)(?:[a-zA-Z0-9\-]+\.?)+[^\s<]*|^email/).replace("protocol", ne).replace("email", /[A-Za-z0-9._+-]+(@)[a-zA-Z0-9-_]+(?:\.[a-zA-Z0-9-_]*[a-zA-Z0-9])+(?![-_])/).getRegex(), _backpedal: /(?:[^?!.,:;*_'"~()&]+|\([^)]*\)|&(?![a-zA-Z0-9]+;$)|[?!.,:;*_'"~)]+(?!$))+/, del: /^(~~?)(?=[^\s~])((?:\\[\s\S]|[^\\])*?(?:\\[\s\S]|[^\s~\\]))\1(?=[^~]|$)/, text: k(/^([`~]+|[^`~])(?:(?= {2,}\n)|(?=[a-zA-Z0-9.!#$%&'*+\/=?_`{\|}~-]+@)|[\s\S]*?(?:(?=[\\": ">", '"': """, "'": "'" }; var ke = (u3) => Xe[u3]; function w(u3, e) { if (e) { if (m.escapeTest.test(u3)) return u3.replace(m.escapeReplace, ke); } else if (m.escapeTestNoEncode.test(u3)) return u3.replace(m.escapeReplaceNoEncode, ke); return u3; } function X(u3) { try { u3 = encodeURI(u3).replace(m.percentDecode, "%"); } catch { return null; } return u3; } function J(u3, e) { let t = u3.replace(m.findPipe, (i, s, a2) => { let o = false, l = s; for (; --l >= 0 && a2[l] === "\\"; ) o = !o; return o ? "|" : " |"; }), n = t.split(m.splitPipe), r = 0; if (n[0].trim() || n.shift(), n.length > 0 && !n.at(-1)?.trim() && n.pop(), e) if (n.length > e) n.splice(e); else for (; n.length < e; ) n.push(""); for (; r < n.length; r++) n[r] = n[r].trim().replace(m.slashPipe, "|"); return n; } function z(u3, e, t) { let n = u3.length; if (n === 0) return ""; let r = 0; for (; r < n; ) { let i = u3.charAt(n - r - 1); if (i === e && !t) r++; else if (i !== e && t) r++; else break; } return u3.slice(0, n - r); } function de(u3, e) { if (u3.indexOf(e[1]) === -1) return -1; let t = 0; for (let n = 0; n < u3.length; n++) if (u3[n] === "\\") n++; else if (u3[n] === e[0]) t++; else if (u3[n] === e[1] && (t--, t < 0)) return n; return t > 0 ? -2 : -1; } function ge(u3, e, t, n, r) { let i = e.href, s = e.title || null, a2 = u3[1].replace(r.other.outputLinkReplace, "$1"); n.state.inLink = true; let o = { type: u3[0].charAt(0) === "!" ? "image" : "link", raw: t, href: i, title: s, text: a2, tokens: n.inlineTokens(a2) }; return n.state.inLink = false, o; } function Je(u3, e, t) { let n = u3.match(t.other.indentCodeCompensation); if (n === null) return e; let r = n[1]; return e.split(` `).map((i) => { let s = i.match(t.other.beginningSpace); if (s === null) return i; let [a2] = s; return a2.length >= r.length ? i.slice(r.length) : i; }).join(` `); } var y = class { options; rules; lexer; constructor(e) { this.options = e || T; } space(e) { let t = this.rules.block.newline.exec(e); if (t && t[0].length > 0) return { type: "space", raw: t[0] }; } code(e) { let t = this.rules.block.code.exec(e); if (t) { let n = t[0].replace(this.rules.other.codeRemoveIndent, ""); return { type: "code", raw: t[0], codeBlockStyle: "indented", text: this.options.pedantic ? n : z(n, ` `) }; } } fences(e) { let t = this.rules.block.fences.exec(e); if (t) { let n = t[0], r = Je(n, t[3] || "", this.rules); return { type: "code", raw: n, lang: t[2] ? t[2].trim().replace(this.rules.inline.anyPunctuation, "$1") : t[2], text: r }; } } heading(e) { let t = this.rules.block.heading.exec(e); if (t) { let n = t[2].trim(); if (this.rules.other.endingHash.test(n)) { let r = z(n, "#"); (this.options.pedantic || !r || this.rules.other.endingSpaceChar.test(r)) && (n = r.trim()); } return { type: "heading", raw: t[0], depth: t[1].length, text: n, tokens: this.lexer.inline(n) }; } } hr(e) { let t = this.rules.block.hr.exec(e); if (t) return { type: "hr", raw: z(t[0], ` `) }; } blockquote(e) { let t = this.rules.block.blockquote.exec(e); if (t) { let n = z(t[0], ` `).split(` `), r = "", i = "", s = []; for (; n.length > 0; ) { let a2 = false, o = [], l; for (l = 0; l < n.length; l++) if (this.rules.other.blockquoteStart.test(n[l])) o.push(n[l]), a2 = true; else if (!a2) o.push(n[l]); else break; n = n.slice(l); let p = o.join(` `), c = p.replace(this.rules.other.blockquoteSetextReplace, ` $1`).replace(this.rules.other.blockquoteSetextReplace2, ""); r = r ? `${r} ${p}` : p, i = i ? `${i} ${c}` : c; let g = this.lexer.state.top; if (this.lexer.state.top = true, this.lexer.blockTokens(c, s, true), this.lexer.state.top = g, n.length === 0) break; let h = s.at(-1); if (h?.type === "code") break; if (h?.type === "blockquote") { let R = h, f = R.raw + ` ` + n.join(` `), O = this.blockquote(f); s[s.length - 1] = O, r = r.substring(0, r.length - R.raw.length) + O.raw, i = i.substring(0, i.length - R.text.length) + O.text; break; } else if (h?.type === "list") { let R = h, f = R.raw + ` ` + n.join(` `), O = this.list(f); s[s.length - 1] = O, r = r.substring(0, r.length - h.raw.length) + O.raw, i = i.substring(0, i.length - R.raw.length) + O.raw, n = f.substring(s.at(-1).raw.length).split(` `); continue; } } return { type: "blockquote", raw: r, tokens: s, text: i }; } } list(e) { let t = this.rules.block.list.exec(e); if (t) { let n = t[1].trim(), r = n.length > 1, i = { type: "list", raw: "", ordered: r, start: r ? +n.slice(0, -1) : "", loose: false, items: [] }; n = r ? `\\d{1,9}\\${n.slice(-1)}` : `\\${n}`, this.options.pedantic && (n = r ? n : "[*+-]"); let s = this.rules.other.listItemRegex(n), a2 = false; for (; e; ) { let l = false, p = "", c = ""; if (!(t = s.exec(e)) || this.rules.block.hr.test(e)) break; p = t[0], e = e.substring(p.length); let g = t[2].split(` `, 1)[0].replace(this.rules.other.listReplaceTabs, (O) => " ".repeat(3 * O.length)), h = e.split(` `, 1)[0], R = !g.trim(), f = 0; if (this.options.pedantic ? (f = 2, c = g.trimStart()) : R ? f = t[1].length + 1 : (f = t[2].search(this.rules.other.nonSpaceChar), f = f > 4 ? 1 : f, c = g.slice(f), f += t[1].length), R && this.rules.other.blankLine.test(h) && (p += h + ` `, e = e.substring(h.length + 1), l = true), !l) { let O = this.rules.other.nextBulletRegex(f), V = this.rules.other.hrRegex(f), Y = this.rules.other.fencesBeginRegex(f), ee = this.rules.other.headingBeginRegex(f), fe = this.rules.other.htmlBeginRegex(f); for (; e; ) { let H = e.split(` `, 1)[0], A; if (h = H, this.options.pedantic ? (h = h.replace(this.rules.other.listReplaceNesting, " "), A = h) : A = h.replace(this.rules.other.tabCharGlobal, " "), Y.test(h) || ee.test(h) || fe.test(h) || O.test(h) || V.test(h)) break; if (A.search(this.rules.other.nonSpaceChar) >= f || !h.trim()) c += ` ` + A.slice(f); else { if (R || g.replace(this.rules.other.tabCharGlobal, " ").search(this.rules.other.nonSpaceChar) >= 4 || Y.test(g) || ee.test(g) || V.test(g)) break; c += ` ` + h; } !R && !h.trim() && (R = true), p += H + ` `, e = e.substring(H.length + 1), g = A.slice(f); } } i.loose || (a2 ? i.loose = true : this.rules.other.doubleBlankLine.test(p) && (a2 = true)), i.items.push({ type: "list_item", raw: p, task: !!this.options.gfm && this.rules.other.listIsTask.test(c), loose: false, text: c, tokens: [] }), i.raw += p; } let o = i.items.at(-1); if (o) o.raw = o.raw.trimEnd(), o.text = o.text.trimEnd(); else return; i.raw = i.raw.trimEnd(); for (let l of i.items) { if (this.lexer.state.top = false, l.tokens = this.lexer.blockTokens(l.text, []), l.task) { if (l.text = l.text.replace(this.rules.other.listReplaceTask, ""), l.tokens[0]?.type === "text" || l.tokens[0]?.type === "paragraph") { l.tokens[0].raw = l.tokens[0].raw.replace(this.rules.other.listReplaceTask, ""), l.tokens[0].text = l.tokens[0].text.replace(this.rules.other.listReplaceTask, ""); for (let c = this.lexer.inlineQueue.length - 1; c >= 0; c--) if (this.rules.other.listIsTask.test(this.lexer.inlineQueue[c].src)) { this.lexer.inlineQueue[c].src = this.lexer.inlineQueue[c].src.replace(this.rules.other.listReplaceTask, ""); break; } } let p = this.rules.other.listTaskCheckbox.exec(l.raw); if (p) { let c = { type: "checkbox", raw: p[0] + " ", checked: p[0] !== "[ ]" }; l.checked = c.checked, i.loose ? l.tokens[0] && ["paragraph", "text"].includes(l.tokens[0].type) && "tokens" in l.tokens[0] && l.tokens[0].tokens ? (l.tokens[0].raw = c.raw + l.tokens[0].raw, l.tokens[0].text = c.raw + l.tokens[0].text, l.tokens[0].tokens.unshift(c)) : l.tokens.unshift({ type: "paragraph", raw: c.raw, text: c.raw, tokens: [c] }) : l.tokens.unshift(c); } } if (!i.loose) { let p = l.tokens.filter((g) => g.type === "space"), c = p.length > 0 && p.some((g) => this.rules.other.anyLine.test(g.raw)); i.loose = c; } } if (i.loose) for (let l of i.items) { l.loose = true; for (let p of l.tokens) p.type === "text" && (p.type = "paragraph"); } return i; } } html(e) { let t = this.rules.block.html.exec(e); if (t) return { type: "html", block: true, raw: t[0], pre: t[1] === "pre" || t[1] === "script" || t[1] === "style", text: t[0] }; } def(e) { let t = this.rules.block.def.exec(e); if (t) { let n = t[1].toLowerCase().replace(this.rules.other.multipleSpaceGlobal, " "), r = t[2] ? t[2].replace(this.rules.other.hrefBrackets, "$1").replace(this.rules.inline.anyPunctuation, "$1") : "", i = t[3] ? t[3].substring(1, t[3].length - 1).replace(this.rules.inline.anyPunctuation, "$1") : t[3]; return { type: "def", tag: n, raw: t[0], href: r, title: i }; } } table(e) { let t = this.rules.block.table.exec(e); if (!t || !this.rules.other.tableDelimiter.test(t[2])) return; let n = J(t[1]), r = t[2].replace(this.rules.other.tableAlignChars, "").split("|"), i = t[3]?.trim() ? t[3].replace(this.rules.other.tableRowBlankLine, "").split(` `) : [], s = { type: "table", raw: t[0], header: [], align: [], rows: [] }; if (n.length === r.length) { for (let a2 of r) this.rules.other.tableAlignRight.test(a2) ? s.align.push("right") : this.rules.other.tableAlignCenter.test(a2) ? s.align.push("center") : this.rules.other.tableAlignLeft.test(a2) ? s.align.push("left") : s.align.push(null); for (let a2 = 0; a2 < n.length; a2++) s.header.push({ text: n[a2], tokens: this.lexer.inline(n[a2]), header: true, align: s.align[a2] }); for (let a2 of i) s.rows.push(J(a2, s.header.length).map((o, l) => ({ text: o, tokens: this.lexer.inline(o), header: false, align: s.align[l] }))); return s; } } lheading(e) { let t = this.rules.block.lheading.exec(e); if (t) return { type: "heading", raw: t[0], depth: t[2].charAt(0) === "=" ? 1 : 2, text: t[1], tokens: this.lexer.inline(t[1]) }; } paragraph(e) { let t = this.rules.block.paragraph.exec(e); if (t) { let n = t[1].charAt(t[1].length - 1) === ` ` ? t[1].slice(0, -1) : t[1]; return { type: "paragraph", raw: t[0], text: n, tokens: this.lexer.inline(n) }; } } text(e) { let t = this.rules.block.text.exec(e); if (t) return { type: "text", raw: t[0], text: t[0], tokens: this.lexer.inline(t[0]) }; } escape(e) { let t = this.rules.inline.escape.exec(e); if (t) return { type: "escape", raw: t[0], text: t[1] }; } tag(e) { let t = this.rules.inline.tag.exec(e); if (t) return !this.lexer.state.inLink && this.rules.other.startATag.test(t[0]) ? this.lexer.state.inLink = true : this.lexer.state.inLink && this.rules.other.endATag.test(t[0]) && (this.lexer.state.inLink = false), !this.lexer.state.inRawBlock && this.rules.other.startPreScriptTag.test(t[0]) ? this.lexer.state.inRawBlock = true : this.lexer.state.inRawBlock && this.rules.other.endPreScriptTag.test(t[0]) && (this.lexer.state.inRawBlock = false), { type: "html", raw: t[0], inLink: this.lexer.state.inLink, inRawBlock: this.lexer.state.inRawBlock, block: false, text: t[0] }; } link(e) { let t = this.rules.inline.link.exec(e); if (t) { let n = t[2].trim(); if (!this.options.pedantic && this.rules.other.startAngleBracket.test(n)) { if (!this.rules.other.endAngleBracket.test(n)) return; let s = z(n.slice(0, -1), "\\"); if ((n.length - s.length) % 2 === 0) return; } else { let s = de(t[2], "()"); if (s === -2) return; if (s > -1) { let o = (t[0].indexOf("!") === 0 ? 5 : 4) + t[1].length + s; t[2] = t[2].substring(0, s), t[0] = t[0].substring(0, o).trim(), t[3] = ""; } } let r = t[2], i = ""; if (this.options.pedantic) { let s = this.rules.other.pedanticHrefTitle.exec(r); s && (r = s[1], i = s[3]); } else i = t[3] ? t[3].slice(1, -1) : ""; return r = r.trim(), this.rules.other.startAngleBracket.test(r) && (this.options.pedantic && !this.rules.other.endAngleBracket.test(n) ? r = r.slice(1) : r = r.slice(1, -1)), ge(t, { href: r && r.replace(this.rules.inline.anyPunctuation, "$1"), title: i && i.replace(this.rules.inline.anyPunctuation, "$1") }, t[0], this.lexer, this.rules); } } reflink(e, t) { let n; if ((n = this.rules.inline.reflink.exec(e)) || (n = this.rules.inline.nolink.exec(e))) { let r = (n[2] || n[1]).replace(this.rules.other.multipleSpaceGlobal, " "), i = t[r.toLowerCase()]; if (!i) { let s = n[0].charAt(0); return { type: "text", raw: s, text: s }; } return ge(n, i, n[0], this.lexer, this.rules); } } emStrong(e, t, n = "") { let r = this.rules.inline.emStrongLDelim.exec(e); if (!r || r[3] && n.match(this.rules.other.unicodeAlphaNumeric)) return; if (!(r[1] || r[2] || "") || !n || this.rules.inline.punctuation.exec(n)) { let s = [...r[0]].length - 1, a2, o, l = s, p = 0, c = r[0][0] === "*" ? this.rules.inline.emStrongRDelimAst : this.rules.inline.emStrongRDelimUnd; for (c.lastIndex = 0, t = t.slice(-1 * e.length + s); (r = c.exec(t)) != null; ) { if (a2 = r[1] || r[2] || r[3] || r[4] || r[5] || r[6], !a2) continue; if (o = [...a2].length, r[3] || r[4]) { l += o; continue; } else if ((r[5] || r[6]) && s % 3 && !((s + o) % 3)) { p += o; continue; } if (l -= o, l > 0) continue; o = Math.min(o, o + l + p); let g = [...r[0]][0].length, h = e.slice(0, s + r.index + g + o); if (Math.min(s, o) % 2) { let f = h.slice(1, -1); return { type: "em", raw: h, text: f, tokens: this.lexer.inlineTokens(f) }; } let R = h.slice(2, -2); return { type: "strong", raw: h, text: R, tokens: this.lexer.inlineTokens(R) }; } } } codespan(e) { let t = this.rules.inline.code.exec(e); if (t) { let n = t[2].replace(this.rules.other.newLineCharGlobal, " "), r = this.rules.other.nonSpaceChar.test(n), i = this.rules.other.startingSpaceChar.test(n) && this.rules.other.endingSpaceChar.test(n); return r && i && (n = n.substring(1, n.length - 1)), { type: "codespan", raw: t[0], text: n }; } } br(e) { let t = this.rules.inline.br.exec(e); if (t) return { type: "br", raw: t[0] }; } del(e) { let t = this.rules.inline.del.exec(e); if (t) return { type: "del", raw: t[0], text: t[2], tokens: this.lexer.inlineTokens(t[2]) }; } autolink(e) { let t = this.rules.inline.autolink.exec(e); if (t) { let n, r; return t[2] === "@" ? (n = t[1], r = "mailto:" + n) : (n = t[1], r = n), { type: "link", raw: t[0], text: n, href: r, tokens: [{ type: "text", raw: n, text: n }] }; } } url(e) { let t; if (t = this.rules.inline.url.exec(e)) { let n, r; if (t[2] === "@") n = t[0], r = "mailto:" + n; else { let i; do i = t[0], t[0] = this.rules.inline._backpedal.exec(t[0])?.[0] ?? ""; while (i !== t[0]); n = t[0], t[1] === "www." ? r = "http://" + t[0] : r = t[0]; } return { type: "link", raw: t[0], text: n, href: r, tokens: [{ type: "text", raw: n, text: n }] }; } } inlineText(e) { let t = this.rules.inline.text.exec(e); if (t) { let n = this.lexer.state.inRawBlock; return { type: "text", raw: t[0], text: t[0], escaped: n }; } } }; var x = class u { tokens; options; state; inlineQueue; tokenizer; constructor(e) { this.tokens = [], this.tokens.links = /* @__PURE__ */ Object.create(null), this.options = e || T, this.options.tokenizer = this.options.tokenizer || new y(), this.tokenizer = this.options.tokenizer, this.tokenizer.options = this.options, this.tokenizer.lexer = this, this.inlineQueue = [], this.state = { inLink: false, inRawBlock: false, top: true }; let t = { other: m, block: E.normal, inline: M.normal }; this.options.pedantic ? (t.block = E.pedantic, t.inline = M.pedantic) : this.options.gfm && (t.block = E.gfm, this.options.breaks ? t.inline = M.breaks : t.inline = M.gfm), this.tokenizer.rules = t; } static get rules() { return { block: E, inline: M }; } static lex(e, t) { return new u(t).lex(e); } static lexInline(e, t) { return new u(t).inlineTokens(e); } lex(e) { e = e.replace(m.carriageReturn, ` `), this.blockTokens(e, this.tokens); for (let t = 0; t < this.inlineQueue.length; t++) { let n = this.inlineQueue[t]; this.inlineTokens(n.src, n.tokens); } return this.inlineQueue = [], this.tokens; } blockTokens(e, t = [], n = false) { for (this.options.pedantic && (e = e.replace(m.tabCharGlobal, " ").replace(m.spaceLine, "")); e; ) { let r; if (this.options.extensions?.block?.some((s) => (r = s.call({ lexer: this }, e, t)) ? (e = e.substring(r.raw.length), t.push(r), true) : false)) continue; if (r = this.tokenizer.space(e)) { e = e.substring(r.raw.length); let s = t.at(-1); r.raw.length === 1 && s !== void 0 ? s.raw += ` ` : t.push(r); continue; } if (r = this.tokenizer.code(e)) { e = e.substring(r.raw.length); let s = t.at(-1); s?.type === "paragraph" || s?.type === "text" ? (s.raw += (s.raw.endsWith(` `) ? "" : ` `) + r.raw, s.text += ` ` + r.text, this.inlineQueue.at(-1).src = s.text) : t.push(r); continue; } if (r = this.tokenizer.fences(e)) { e = e.substring(r.raw.length), t.push(r); continue; } if (r = this.tokenizer.heading(e)) { e = e.substring(r.raw.length), t.push(r); continue; } if (r = this.tokenizer.hr(e)) { e = e.substring(r.raw.length), t.push(r); continue; } if (r = this.tokenizer.blockquote(e)) { e = e.substring(r.raw.length), t.push(r); continue; } if (r = this.tokenizer.list(e)) { e = e.substring(r.raw.length), t.push(r); continue; } if (r = this.tokenizer.html(e)) { e = e.substring(r.raw.length), t.push(r); continue; } if (r = this.tokenizer.def(e)) { e = e.substring(r.raw.length); let s = t.at(-1); s?.type === "paragraph" || s?.type === "text" ? (s.raw += (s.raw.endsWith(` `) ? "" : ` `) + r.raw, s.text += ` ` + r.raw, this.inlineQueue.at(-1).src = s.text) : this.tokens.links[r.tag] || (this.tokens.links[r.tag] = { href: r.href, title: r.title }, t.push(r)); continue; } if (r = this.tokenizer.table(e)) { e = e.substring(r.raw.length), t.push(r); continue; } if (r = this.tokenizer.lheading(e)) { e = e.substring(r.raw.length), t.push(r); continue; } let i = e; if (this.options.extensions?.startBlock) { let s = 1 / 0, a2 = e.slice(1), o; this.options.extensions.startBlock.forEach((l) => { o = l.call({ lexer: this }, a2), typeof o == "number" && o >= 0 && (s = Math.min(s, o)); }), s < 1 / 0 && s >= 0 && (i = e.substring(0, s + 1)); } if (this.state.top && (r = this.tokenizer.paragraph(i))) { let s = t.at(-1); n && s?.type === "paragraph" ? (s.raw += (s.raw.endsWith(` `) ? "" : ` `) + r.raw, s.text += ` ` + r.text, this.inlineQueue.pop(), this.inlineQueue.at(-1).src = s.text) : t.push(r), n = i.length !== e.length, e = e.substring(r.raw.length); continue; } if (r = this.tokenizer.text(e)) { e = e.substring(r.raw.length); let s = t.at(-1); s?.type === "text" ? (s.raw += (s.raw.endsWith(` `) ? "" : ` `) + r.raw, s.text += ` ` + r.text, this.inlineQueue.pop(), this.inlineQueue.at(-1).src = s.text) : t.push(r); continue; } if (e) { let s = "Infinite loop on byte: " + e.charCodeAt(0); if (this.options.silent) { console.error(s); break; } else throw new Error(s); } } return this.state.top = true, t; } inline(e, t = []) { return this.inlineQueue.push({ src: e, tokens: t }), t; } inlineTokens(e, t = []) { let n = e, r = null; if (this.tokens.links) { let o = Object.keys(this.tokens.links); if (o.length > 0) for (; (r = this.tokenizer.rules.inline.reflinkSearch.exec(n)) != null; ) o.includes(r[0].slice(r[0].lastIndexOf("[") + 1, -1)) && (n = n.slice(0, r.index) + "[" + "a".repeat(r[0].length - 2) + "]" + n.slice(this.tokenizer.rules.inline.reflinkSearch.lastIndex)); } for (; (r = this.tokenizer.rules.inline.anyPunctuation.exec(n)) != null; ) n = n.slice(0, r.index) + "++" + n.slice(this.tokenizer.rules.inline.anyPunctuation.lastIndex); let i; for (; (r = this.tokenizer.rules.inline.blockSkip.exec(n)) != null; ) i = r[2] ? r[2].length : 0, n = n.slice(0, r.index + i) + "[" + "a".repeat(r[0].length - i - 2) + "]" + n.slice(this.tokenizer.rules.inline.blockSkip.lastIndex); n = this.options.hooks?.emStrongMask?.call({ lexer: this }, n) ?? n; let s = false, a2 = ""; for (; e; ) { s || (a2 = ""), s = false; let o; if (this.options.extensions?.inline?.some((p) => (o = p.call({ lexer: this }, e, t)) ? (e = e.substring(o.raw.length), t.push(o), true) : false)) continue; if (o = this.tokenizer.escape(e)) { e = e.substring(o.raw.length), t.push(o); continue; } if (o = this.tokenizer.tag(e)) { e = e.substring(o.raw.length), t.push(o); continue; } if (o = this.tokenizer.link(e)) { e = e.substring(o.raw.length), t.push(o); continue; } if (o = this.tokenizer.reflink(e, this.tokens.links)) { e = e.substring(o.raw.length); let p = t.at(-1); o.type === "text" && p?.type === "text" ? (p.raw += o.raw, p.text += o.text) : t.push(o); continue; } if (o = this.tokenizer.emStrong(e, n, a2)) { e = e.substring(o.raw.length), t.push(o); continue; } if (o = this.tokenizer.codespan(e)) { e = e.substring(o.raw.length), t.push(o); continue; } if (o = this.tokenizer.br(e)) { e = e.substring(o.raw.length), t.push(o); continue; } if (o = this.tokenizer.del(e)) { e = e.substring(o.raw.length), t.push(o); continue; } if (o = this.tokenizer.autolink(e)) { e = e.substring(o.raw.length), t.push(o); continue; } if (!this.state.inLink && (o = this.tokenizer.url(e))) { e = e.substring(o.raw.length), t.push(o); continue; } let l = e; if (this.options.extensions?.startInline) { let p = 1 / 0, c = e.slice(1), g; this.options.extensions.startInline.forEach((h) => { g = h.call({ lexer: this }, c), typeof g == "number" && g >= 0 && (p = Math.min(p, g)); }), p < 1 / 0 && p >= 0 && (l = e.substring(0, p + 1)); } if (o = this.tokenizer.inlineText(l)) { e = e.substring(o.raw.length), o.raw.slice(-1) !== "_" && (a2 = o.raw.slice(-1)), s = true; let p = t.at(-1); p?.type === "text" ? (p.raw += o.raw, p.text += o.text) : t.push(o); continue; } if (e) { let p = "Infinite loop on byte: " + e.charCodeAt(0); if (this.options.silent) { console.error(p); break; } else throw new Error(p); } } return t; } }; var P = class { options; parser; constructor(e) { this.options = e || T; } space(e) { return ""; } code({ text: e, lang: t, escaped: n }) { let r = (t || "").match(m.notSpaceStart)?.[0], i = e.replace(m.endingNewline, "") + ` `; return r ? '
' + (n ? i : w(i, true)) + `
` : "
" + (n ? i : w(i, true)) + `
`; } blockquote({ tokens: e }) { return `
${this.parser.parse(e)}
`; } html({ text: e }) { return e; } def(e) { return ""; } heading({ tokens: e, depth: t }) { return `${this.parser.parseInline(e)} `; } hr(e) { return `
`; } list(e) { let t = e.ordered, n = e.start, r = ""; for (let a2 = 0; a2 < e.items.length; a2++) { let o = e.items[a2]; r += this.listitem(o); } let i = t ? "ol" : "ul", s = t && n !== 1 ? ' start="' + n + '"' : ""; return "<" + i + s + `> ` + r + " `; } listitem(e) { return `
  • ${this.parser.parse(e.tokens)}
  • `; } checkbox({ checked: e }) { return " '; } paragraph({ tokens: e }) { return `

    ${this.parser.parseInline(e)}

    `; } table(e) { let t = "", n = ""; for (let i = 0; i < e.header.length; i++) n += this.tablecell(e.header[i]); t += this.tablerow({ text: n }); let r = ""; for (let i = 0; i < e.rows.length; i++) { let s = e.rows[i]; n = ""; for (let a2 = 0; a2 < s.length; a2++) n += this.tablecell(s[a2]); r += this.tablerow({ text: n }); } return r && (r = `${r}`), ` ` + t + ` ` + r + `
    `; } tablerow({ text: e }) { return ` ${e} `; } tablecell(e) { let t = this.parser.parseInline(e.tokens), n = e.header ? "th" : "td"; return (e.align ? `<${n} align="${e.align}">` : `<${n}>`) + t + ` `; } strong({ tokens: e }) { return `${this.parser.parseInline(e)}`; } em({ tokens: e }) { return `${this.parser.parseInline(e)}`; } codespan({ text: e }) { return `${w(e, true)}`; } br(e) { return "
    "; } del({ tokens: e }) { return `${this.parser.parseInline(e)}`; } link({ href: e, title: t, tokens: n }) { let r = this.parser.parseInline(n), i = X(e); if (i === null) return r; e = i; let s = '
    ", s; } image({ href: e, title: t, text: n, tokens: r }) { r && (n = this.parser.parseInline(r, this.parser.textRenderer)); let i = X(e); if (i === null) return w(n); e = i; let s = `${n} { let a2 = i[s].flat(1 / 0); n = n.concat(this.walkTokens(a2, t)); }) : i.tokens && (n = n.concat(this.walkTokens(i.tokens, t))); } } return n; } use(...e) { let t = this.defaults.extensions || { renderers: {}, childTokens: {} }; return e.forEach((n) => { let r = { ...n }; if (r.async = this.defaults.async || r.async || false, n.extensions && (n.extensions.forEach((i) => { if (!i.name) throw new Error("extension name required"); if ("renderer" in i) { let s = t.renderers[i.name]; s ? t.renderers[i.name] = function(...a2) { let o = i.renderer.apply(this, a2); return o === false && (o = s.apply(this, a2)), o; } : t.renderers[i.name] = i.renderer; } if ("tokenizer" in i) { if (!i.level || i.level !== "block" && i.level !== "inline") throw new Error("extension level must be 'block' or 'inline'"); let s = t[i.level]; s ? s.unshift(i.tokenizer) : t[i.level] = [i.tokenizer], i.start && (i.level === "block" ? t.startBlock ? t.startBlock.push(i.start) : t.startBlock = [i.start] : i.level === "inline" && (t.startInline ? t.startInline.push(i.start) : t.startInline = [i.start])); } "childTokens" in i && i.childTokens && (t.childTokens[i.name] = i.childTokens); }), r.extensions = t), n.renderer) { let i = this.defaults.renderer || new P(this.defaults); for (let s in n.renderer) { if (!(s in i)) throw new Error(`renderer '${s}' does not exist`); if (["options", "parser"].includes(s)) continue; let a2 = s, o = n.renderer[a2], l = i[a2]; i[a2] = (...p) => { let c = o.apply(i, p); return c === false && (c = l.apply(i, p)), c || ""; }; } r.renderer = i; } if (n.tokenizer) { let i = this.defaults.tokenizer || new y(this.defaults); for (let s in n.tokenizer) { if (!(s in i)) throw new Error(`tokenizer '${s}' does not exist`); if (["options", "rules", "lexer"].includes(s)) continue; let a2 = s, o = n.tokenizer[a2], l = i[a2]; i[a2] = (...p) => { let c = o.apply(i, p); return c === false && (c = l.apply(i, p)), c; }; } r.tokenizer = i; } if (n.hooks) { let i = this.defaults.hooks || new S(); for (let s in n.hooks) { if (!(s in i)) throw new Error(`hook '${s}' does not exist`); if (["options", "block"].includes(s)) continue; let a2 = s, o = n.hooks[a2], l = i[a2]; S.passThroughHooks.has(s) ? i[a2] = (p) => { if (this.defaults.async && S.passThroughHooksRespectAsync.has(s)) return (async () => { let g = await o.call(i, p); return l.call(i, g); })(); let c = o.call(i, p); return l.call(i, c); } : i[a2] = (...p) => { if (this.defaults.async) return (async () => { let g = await o.apply(i, p); return g === false && (g = await l.apply(i, p)), g; })(); let c = o.apply(i, p); return c === false && (c = l.apply(i, p)), c; }; } r.hooks = i; } if (n.walkTokens) { let i = this.defaults.walkTokens, s = n.walkTokens; r.walkTokens = function(a2) { let o = []; return o.push(s.call(this, a2)), i && (o = o.concat(i.call(this, a2))), o; }; } this.defaults = { ...this.defaults, ...r }; }), this; } setOptions(e) { return this.defaults = { ...this.defaults, ...e }, this; } lexer(e, t) { return x.lex(e, t ?? this.defaults); } parser(e, t) { return b.parse(e, t ?? this.defaults); } parseMarkdown(e) { return (n, r) => { let i = { ...r }, s = { ...this.defaults, ...i }, a2 = this.onError(!!s.silent, !!s.async); if (this.defaults.async === true && i.async === false) return a2(new Error("marked(): The async option was set to true by an extension. Remove async: false from the parse options object to return a Promise.")); if (typeof n > "u" || n === null) return a2(new Error("marked(): input parameter is undefined or null")); if (typeof n != "string") return a2(new Error("marked(): input parameter is of type " + Object.prototype.toString.call(n) + ", string expected")); if (s.hooks && (s.hooks.options = s, s.hooks.block = e), s.async) return (async () => { let o = s.hooks ? await s.hooks.preprocess(n) : n, p = await (s.hooks ? await s.hooks.provideLexer() : e ? x.lex : x.lexInline)(o, s), c = s.hooks ? await s.hooks.processAllTokens(p) : p; s.walkTokens && await Promise.all(this.walkTokens(c, s.walkTokens)); let h = await (s.hooks ? await s.hooks.provideParser() : e ? b.parse : b.parseInline)(c, s); return s.hooks ? await s.hooks.postprocess(h) : h; })().catch(a2); try { s.hooks && (n = s.hooks.preprocess(n)); let l = (s.hooks ? s.hooks.provideLexer() : e ? x.lex : x.lexInline)(n, s); s.hooks && (l = s.hooks.processAllTokens(l)), s.walkTokens && this.walkTokens(l, s.walkTokens); let c = (s.hooks ? s.hooks.provideParser() : e ? b.parse : b.parseInline)(l, s); return s.hooks && (c = s.hooks.postprocess(c)), c; } catch (o) { return a2(o); } }; } onError(e, t) { return (n) => { if (n.message += ` Please report this to https://github.com/markedjs/marked.`, e) { let r = "

    An error occurred:

    " + w(n.message + "", true) + "
    "; return t ? Promise.resolve(r) : r; } if (t) return Promise.reject(n); throw n; }; } }; var _ = new B(); function d(u3, e) { return _.parse(u3, e); } d.options = d.setOptions = function(u3) { return _.setOptions(u3), d.defaults = _.defaults, Z(d.defaults), d; }; d.getDefaults = L; d.defaults = T; d.use = function(...u3) { return _.use(...u3), d.defaults = _.defaults, Z(d.defaults), d; }; d.walkTokens = function(u3, e) { return _.walkTokens(u3, e); }; d.parseInline = _.parseInline; d.Parser = b; d.parser = b.parse; d.Renderer = P; d.TextRenderer = $; d.Lexer = x; d.lexer = x.lex; d.Tokenizer = y; d.Hooks = S; d.parse = d; var Dt = d.options; var Ht = d.setOptions; var Zt = d.use; var Gt = d.walkTokens; var Nt = d.parseInline; var Ft = b.parse; var jt = x.lex; // frontend/js/pages/chat/SessionManager.js import { nanoid as nanoid2 } from "https://cdn.jsdelivr.net/npm/nanoid/nanoid.js"; var LOCAL_STORAGE_KEY = "gemini_chat_state"; var SessionManager = class { constructor() { this.state = null; } /** * Initializes the manager by loading state from localStorage or creating a default state. */ init() { this._loadState(); } // --- Public API for state access --- getSessions() { return this.state.sessions; } getCurrentSessionId() { return this.state.currentSessionId; } getCurrentSession() { return this.state.sessions.find((s) => s.id === this.state.currentSessionId); } // --- Public API for state mutation --- /** * Creates a new, empty session and sets it as the current one. */ createSession() { const newSessionId = nanoid2(); const newSession = { id: newSessionId, name: "\u65B0\u4F1A\u8BDD", systemPrompt: "", messages: [], modelConfig: { model: "gemini-2.0-flash-lite" }, params: { temperature: 0.7 } }; this.state.sessions.unshift(newSession); this.state.currentSessionId = newSessionId; this._saveState(); } /** * Switches the current session to the one with the given ID. * @param {string} sessionId The ID of the session to switch to. */ switchSession(sessionId) { if (this.state.currentSessionId === sessionId) return; this.state.currentSessionId = sessionId; this._saveState(); } /** * Deletes a session by its ID. * @param {string} sessionId The ID of the session to delete. */ deleteSession(sessionId) { this.state.sessions = this.state.sessions.filter((s) => s.id !== sessionId); if (this.state.currentSessionId === sessionId) { this.state.currentSessionId = this.state.sessions[0]?.id || null; if (!this.state.currentSessionId) { this._createInitialState(); } } this._saveState(); } /** * [NEW] Clears all messages from the currently active session. */ clearCurrentSession() { const currentSession = this.getCurrentSession(); if (currentSession) { currentSession.messages = []; this._saveState(); } } /** * Adds a message to the current session and updates the session name if it's the first message. * @param {object} message The message object to add. * @returns {object} The session that was updated. */ addMessage(message) { const currentSession = this.getCurrentSession(); if (currentSession) { if (currentSession.messages.length === 0 && message.role === "user") { currentSession.name = message.content.substring(0, 30); } currentSession.messages.push(message); this._saveState(); return currentSession; } return null; } deleteMessage(messageId) { const currentSession = this.getCurrentSession(); if (currentSession) { const messageIndex = currentSession.messages.findIndex((m2) => m2.id === messageId); if (messageIndex > -1) { currentSession.messages.splice(messageIndex, 1); this._saveState(); console.log(`Message ${messageId} deleted.`); } } } truncateMessagesAfter(messageId) { const currentSession = this.getCurrentSession(); if (currentSession) { const messageIndex = currentSession.messages.findIndex((m2) => m2.id === messageId); if (messageIndex > -1 && messageIndex < currentSession.messages.length - 1) { currentSession.messages.splice(messageIndex + 1); this._saveState(); console.log(`Truncated messages after ${messageId}.`); } } } // --- Private persistence methods --- _saveState() { try { localStorage.setItem(LOCAL_STORAGE_KEY, JSON.stringify(this.state)); } catch (error) { console.error("Failed to save session state:", error); } } _loadState() { try { const stateString = localStorage.getItem(LOCAL_STORAGE_KEY); if (stateString) { this.state = JSON.parse(stateString); } else { this._createInitialState(); } } catch (error) { console.error("Failed to load session state, creating initial state:", error); this._createInitialState(); } } _createInitialState() { const initialSessionId = nanoid2(); this.state = { sessions: [{ id: initialSessionId, name: "\u65B0\u4F1A\u8BDD", systemPrompt: "", messages: [], modelConfig: { model: "gemini-2.0-flash-lite" }, params: { temperature: 0.7 } }], currentSessionId: initialSessionId, settings: {} }; this._saveState(); } }; // frontend/js/pages/chat/chatSettings.js var ChatSettings = class { constructor(elements) { this.elements = {}; this.elements.root = elements; this._initScopedDOMElements(); this.elements.quickSettingsPanel.style.gridTemplateRows = "0fr"; this.elements.sessionParamsPanel.style.gridTemplateRows = "0fr"; } // [NEW] A dedicated method to find elements within their specific panels _initScopedDOMElements() { this.elements.quickSettingsPanel = this.elements.root.quickSettingsPanel; this.elements.sessionParamsPanel = this.elements.root.sessionParamsPanel; this.elements.toggleQuickSettingsBtn = this.elements.root.toggleQuickSettingsBtn; this.elements.toggleSessionParamsBtn = this.elements.root.toggleSessionParamsBtn; this.elements.btnGroups = this.elements.quickSettingsPanel.querySelectorAll(".btn-group"); this.elements.directRoutingOptions = this.elements.quickSettingsPanel.querySelector("#direct-routing-options"); this.elements.temperatureSlider = this.elements.sessionParamsPanel.querySelector("#temperature-slider"); this.elements.temperatureValue = this.elements.sessionParamsPanel.querySelector("#temperature-value"); this.elements.contextSlider = this.elements.sessionParamsPanel.querySelector("#context-slider"); this.elements.contextValue = this.elements.sessionParamsPanel.querySelector("#context-value"); } init() { if (!this.elements.toggleQuickSettingsBtn) { console.warn("ChatSettings: Aborting initialization, required elements not found."); return; } this._initPanelToggleListeners(); this._initButtonGroupListeners(); this._initSliderListeners(); } _initPanelToggleListeners() { this.elements.toggleQuickSettingsBtn.addEventListener( "click", () => this._togglePanel(this.elements.quickSettingsPanel, this.elements.toggleQuickSettingsBtn) ); this.elements.toggleSessionParamsBtn.addEventListener( "click", () => this._togglePanel(this.elements.sessionParamsPanel, this.elements.toggleSessionParamsBtn) ); } _initButtonGroupListeners() { this.elements.btnGroups.forEach((group) => { group.addEventListener("click", (e) => { const button = e.target.closest(".btn-group-item"); if (!button) return; group.querySelectorAll(".btn-group-item").forEach((btn) => btn.removeAttribute("data-active")); button.setAttribute("data-active", "true"); if (button.dataset.group === "routing-mode") { this._handleRoutingModeChange(button.dataset.value); } }); }); } _initSliderListeners() { if (this.elements.temperatureSlider) { this.elements.temperatureSlider.addEventListener("input", () => { this.elements.temperatureValue.textContent = parseFloat(this.elements.temperatureSlider.value).toFixed(1); }); } if (this.elements.contextSlider) { this.elements.contextSlider.addEventListener("input", () => { this.elements.contextValue.textContent = `${this.elements.contextSlider.value}k`; }); } } _handleRoutingModeChange(selectedValue) { if (this.elements.directRoutingOptions) { if (selectedValue === "direct") { this.elements.directRoutingOptions.classList.remove("hidden"); } else { this.elements.directRoutingOptions.classList.add("hidden"); } } } _togglePanel(panel, button) { const isExpanded = panel.hasAttribute("data-expanded"); this.elements.quickSettingsPanel.removeAttribute("data-expanded"); this.elements.sessionParamsPanel.removeAttribute("data-expanded"); this.elements.toggleQuickSettingsBtn.removeAttribute("data-active"); this.elements.toggleSessionParamsBtn.removeAttribute("data-active"); this.elements.quickSettingsPanel.style.gridTemplateRows = "0fr"; this.elements.sessionParamsPanel.style.gridTemplateRows = "0fr"; if (!isExpanded) { panel.setAttribute("data-expanded", "true"); button.setAttribute("data-active", "true"); panel.style.gridTemplateRows = "1fr"; } } }; // frontend/js/pages/chat/index.js d.use({ breaks: true, gfm: true }); function getCookie(name) { let cookieValue = null; if (document.cookie && document.cookie !== "") { const cookies = document.cookie.split(";"); for (let i = 0; i < cookies.length; i++) { const cookie = cookies[i].trim(); if (cookie.substring(0, name.length + 1) === name + "=") { cookieValue = decodeURIComponent(cookie.substring(name.length + 1)); break; } } } return cookieValue; } var ChatPage = class { constructor() { this.sessionManager = new SessionManager(); this.isStreaming = false; this.elements = {}; this.initialized = false; this.searchTerm = ""; this.settingsManager = null; } init() { if (!document.querySelector('[data-page-id="chat"]')) { return; } this.sessionManager.init(); this.initialized = true; this._initDOMElements(); this._initComponents(); this._initEventListeners(); this._render(); console.log("ChatPage initialized. Session management is delegated.", this.sessionManager.state); } _initDOMElements() { this.elements.chatScrollContainer = document.getElementById("chat-scroll-container"); this.elements.chatMessagesContainer = document.getElementById("chat-messages-container"); this.elements.messageForm = document.getElementById("message-form"); this.elements.messageInput = document.getElementById("message-input"); this.elements.sendBtn = document.getElementById("send-btn"); this.elements.newSessionBtn = document.getElementById("new-session-btn"); this.elements.sessionListContainer = document.getElementById("session-list-container"); this.elements.chatHeaderTitle = document.querySelector(".chat-header-title"); this.elements.clearSessionBtn = document.getElementById("clear-session-btn"); this.elements.sessionSearchInput = document.getElementById("session-search-input"); this.elements.toggleQuickSettingsBtn = document.getElementById("toggle-quick-settings"); this.elements.toggleSessionParamsBtn = document.getElementById("toggle-session-params"); this.elements.quickSettingsPanel = document.getElementById("quick-settings-panel"); this.elements.sessionParamsPanel = document.getElementById("session-params-panel"); this.elements.directRoutingOptions = document.getElementById("direct-routing-options"); this.elements.btnGroups = document.querySelectorAll(".btn-group"); this.elements.temperatureSlider = document.getElementById("temperature-slider"); this.elements.temperatureValue = document.getElementById("temperature-value"); this.elements.contextSlider = document.getElementById("context-slider"); this.elements.contextValue = document.getElementById("context-value"); this.elements.groupSelectContainer = document.getElementById("group-select-container"); } // [NEW] A dedicated method for initializing complex UI components _initComponents() { if (this.elements.groupSelectContainer) { new CustomSelectV2(this.elements.groupSelectContainer); } } _initEventListeners() { this.settingsManager = new ChatSettings(this.elements); this.settingsManager.init(); this.elements.messageForm.addEventListener("submit", (e) => { e.preventDefault(); this._handleSendMessage(); }); this.elements.messageInput.addEventListener("keydown", (e) => { if (e.key === "Enter" && !e.shiftKey) { e.preventDefault(); this._handleSendMessage(); } }); this.elements.messageInput.addEventListener("input", () => this._autoResizeTextarea()); this.elements.newSessionBtn.addEventListener("click", () => { this.sessionManager.createSession(); this._render(); this.elements.messageInput.focus(); }); this.elements.sessionListContainer.addEventListener("click", (e) => { const sessionItem = e.target.closest("[data-session-id]"); const deleteBtn = e.target.closest(".delete-session-btn"); if (deleteBtn) { e.preventDefault(); const sessionId = deleteBtn.closest("[data-session-id]").dataset.sessionId; this._handleDeleteSession(sessionId); } else if (sessionItem) { e.preventDefault(); const sessionId = sessionItem.dataset.sessionId; this.sessionManager.switchSession(sessionId); this._render(); this.elements.messageInput.focus(); } }); this.elements.clearSessionBtn.addEventListener("click", () => this._handleClearSession()); this.elements.sessionSearchInput.addEventListener("input", (e) => { this.searchTerm = e.target.value.trim(); this._renderSessionList(); }); this.elements.chatMessagesContainer.addEventListener("click", (e) => { const messageElement = e.target.closest("[data-message-id]"); if (!messageElement) return; const messageId = messageElement.dataset.messageId; const copyBtn = e.target.closest(".action-copy"); const deleteBtn = e.target.closest(".action-delete"); const retryBtn = e.target.closest(".action-retry"); if (copyBtn) { this._handleCopyMessage(messageId); } else if (deleteBtn) { this._handleDeleteMessage(messageId, e.target); } else if (retryBtn) { this._handleRetryMessage(messageId); } }); } _handleCopyMessage(messageId) { const currentSession = this.sessionManager.getCurrentSession(); if (!currentSession) return; const message = currentSession.messages.find((m2) => m2.id === messageId); if (!message || !message.content) { console.error("Message content not found for copying."); return; } let textToCopy = message.content; if (textToCopy.includes("<") && textToCopy.includes(">")) { const tempDiv = document.createElement("div"); tempDiv.innerHTML = textToCopy; textToCopy = tempDiv.textContent || tempDiv.innerText || ""; } navigator.clipboard.writeText(textToCopy).then(() => { Swal.fire({ toast: true, position: "top-end", icon: "success", title: "\u5DF2\u590D\u5236", showConfirmButton: false, timer: 1500, customClass: { popup: `${document.documentElement.classList.contains("dark") ? "swal2-dark" : ""}` } }); }).catch((err) => { console.error("Failed to copy text: ", err); Swal.fire({ toast: true, position: "top-end", icon: "error", title: "\u590D\u5236\u5931\u8D25", showConfirmButton: false, timer: 1500, customClass: { popup: `${document.documentElement.classList.contains("dark") ? "swal2-dark" : ""}` } }); }); } _handleDeleteMessage(messageId, targetElement) { const existingPopover = document.getElementById("delete-confirmation-popover"); if (existingPopover) { existingPopover.remove(); } const popover = document.createElement("div"); popover.id = "delete-confirmation-popover"; popover.className = "absolute z-50 p-3 w-45 border border-border rounded-md shadow-lg bg-background text-popover-foreground flex flex-col items-center"; popover.innerHTML = `

    \u786E\u8BA4\u5220\u9664\u6B64\u6D88\u606F\u5417?

    `; document.body.appendChild(popover); const iconRect = targetElement.closest("button").getBoundingClientRect(); const popoverRect = popover.getBoundingClientRect(); popover.style.top = `${window.scrollY + iconRect.top - popoverRect.height - 8}px`; popover.style.left = `${window.scrollX + iconRect.left + iconRect.width / 2 - popoverRect.width / 2}px`; const outsideClickListener = (event) => { if (!popover.contains(event.target) && event.target !== targetElement) { popover.remove(); document.removeEventListener("click", outsideClickListener); } }; setTimeout(() => document.addEventListener("click", outsideClickListener), 0); popover.querySelector(".popover-confirm").addEventListener("click", () => { this.sessionManager.deleteMessage(messageId); this._renderChatMessages(); this._renderSessionList(); popover.remove(); document.removeEventListener("click", outsideClickListener); }); popover.querySelector(".popover-cancel").addEventListener("click", () => { popover.remove(); document.removeEventListener("click", outsideClickListener); }); } _handleRetryMessage(messageId) { if (this.isStreaming) return; const currentSession = this.sessionManager.getCurrentSession(); if (!currentSession) return; const message = currentSession.messages.find((m2) => m2.id === messageId); if (!message) return; if (message.role === "user") { this.sessionManager.truncateMessagesAfter(messageId); } else if (message.role === "assistant") { this.sessionManager.deleteMessage(messageId); } this._renderChatMessages(); this._renderSessionList(); this._getAssistantResponse(); } _autoResizeTextarea() { const el = this.elements.messageInput; el.style.height = "auto"; el.style.height = el.scrollHeight + "px"; } _handleSendMessage() { if (this.isStreaming) return; const content = this.elements.messageInput.value.trim(); if (!content) return; const userMessage = { id: nanoid(), role: "user", content }; this.sessionManager.addMessage(userMessage); this._renderChatMessages(); this._renderSessionList(); this.elements.messageInput.value = ""; this._autoResizeTextarea(); this.elements.messageInput.focus(); this._getAssistantResponse(); } async _getAssistantResponse() { this.isStreaming = true; this._setLoadingState(true); const currentSession = this.sessionManager.getCurrentSession(); const assistantMessageId = nanoid(); let finalAssistantMessage = { id: assistantMessageId, role: "assistant", content: "" }; const placeholderHtml = `
    `; this.elements.chatMessagesContainer.insertAdjacentHTML("beforeend", placeholderHtml); this._scrollToBottom(); const assistantMessageContentEl = this.elements.chatMessagesContainer.querySelector(`[data-message-id="${assistantMessageId}"] .message-content`); try { const token = getCookie("gemini_admin_session"); const headers = { "Authorization": `Bearer ${token}` }; const response = await apiFetch("/v1/chat/completions", { method: "POST", headers, body: JSON.stringify({ model: currentSession.modelConfig.model, messages: currentSession.messages.filter((m2) => m2.content).map(({ role, content }) => ({ role, content })), stream: true }) }); if (!response.body) throw new Error("Response body is null."); const reader = response.body.getReader(); const decoder = new TextDecoder(); while (true) { const { value, done } = await reader.read(); if (done) break; const chunk = decoder.decode(value); const lines = chunk.split("\n").filter((line) => line.trim().startsWith("data:")); for (const line of lines) { const dataStr = line.replace(/^data: /, "").trim(); if (dataStr !== "[DONE]") { try { const data = JSON.parse(dataStr); const deltaContent = data.choices[0]?.delta?.content; if (deltaContent) { finalAssistantMessage.content += deltaContent; assistantMessageContentEl.innerHTML = d.parse(finalAssistantMessage.content); this._scrollToBottom(); } } catch (e) { } } } } } catch (error) { console.error("Fetch stream error:", error); const errorMessage = error.rawMessageFromServer || error.message; finalAssistantMessage.content = `\u8BF7\u6C42\u5931\u8D25: ${errorMessage}`; } finally { this.sessionManager.addMessage(finalAssistantMessage); this._renderChatMessages(); this._renderSessionList(); this.isStreaming = false; this._setLoadingState(false); this.elements.messageInput.focus(); } } _renderMessage(message, replace = false, isLastMessage = false) { let contentHtml; if (message.role === "user") { const escapedContent = message.content.replace(//g, ">"); contentHtml = `

    ${escapedContent.replace(/\n/g, "
    ")}

    `; } else { const isErrorHtml = message.content && message.content.includes(''); contentHtml = isErrorHtml ? `
    ${message.content}
    ` : `
    ${d.parse(message.content || "")}
    `; } let actionsHtml = ""; let retryButton = ""; if (message.role === "user") { retryButton = ` `; } else if (message.role === "assistant" && isLastMessage) { retryButton = ` `; } const toolbarBaseClasses = "message-actions flex items-center gap-1 transition-opacity duration-200"; const toolbarPositionClass = isLastMessage ? "mt-2" : "absolute bottom-2.5 right-2.5"; const visibilityClass = isLastMessage ? "" : "opacity-0 group-hover:opacity-100"; actionsHtml = `
    ${retryButton}
    `; const messageBubbleClasses = `relative group rounded-lg p-5 ${message.role === "user" ? "bg-muted" : "bg-primary/10 border/20"}`; const messageHtml = `
    ${contentHtml} ${actionsHtml}
    `; const existingElement = this.elements.chatMessagesContainer.querySelector(`[data-message-id="${message.id}"]`); if (replace && existingElement) { existingElement.outerHTML = messageHtml; } else if (!existingElement) { this.elements.chatMessagesContainer.insertAdjacentHTML("beforeend", messageHtml); } if (!replace) { this._scrollToBottom(); } } _scrollToBottom() { this.elements.chatScrollContainer.scrollTop = this.elements.chatScrollContainer.scrollHeight; } _render() { this._renderSessionList(); this._renderChatMessages(); this._renderChatHeader(); } _renderSessionList() { let sessions = this.sessionManager.getSessions(); const currentSessionId = this.sessionManager.getCurrentSessionId(); if (this.searchTerm) { const lowerCaseSearchTerm = this.searchTerm.toLowerCase(); sessions = sessions.filter((session) => { const titleMatch = session.name.toLowerCase().includes(lowerCaseSearchTerm); const messageMatch = session.messages.some( (message) => message.content && message.content.toLowerCase().includes(lowerCaseSearchTerm) ); return titleMatch || messageMatch; }); } this.elements.sessionListContainer.innerHTML = sessions.map((session) => { const isActive = session.id === currentSessionId; const lastMessage = session.messages.length > 0 ? session.messages[session.messages.length - 1].content : "\u65B0\u4F1A\u8BDD"; return `
    ${session.name}
    ${session.messages.length > 0 ? lastMessage.includes('') ? "[\u8BF7\u6C42\u5931\u8D25]" : lastMessage : "\u65B0\u4F1A\u8BDD"}
    `; }).join(""); } _renderChatMessages() { this.elements.chatMessagesContainer.innerHTML = ""; const currentSession = this.sessionManager.getCurrentSession(); if (currentSession) { const messages = currentSession.messages; const lastMessageIndex = messages.length > 0 ? messages.length - 1 : -1; messages.forEach((message, index) => { const isLastMessage = index === lastMessageIndex; this._renderMessage(message, false, isLastMessage); }); } } _renderChatHeader() { const currentSession = this.sessionManager.getCurrentSession(); if (currentSession && this.elements.chatHeaderTitle) { this.elements.chatHeaderTitle.textContent = currentSession.name; } } _setLoadingState(isLoading) { this.elements.messageInput.disabled = isLoading; this.elements.sendBtn.disabled = isLoading; if (isLoading) { uiPatterns.setButtonLoading(this.elements.sendBtn); } else { uiPatterns.clearButtonLoading(this.elements.sendBtn); } } _handleClearSession() { Swal.fire({ width: "22rem", backdrop: `rgba(0,0,0,0.5)`, heightAuto: false, customClass: { popup: `swal2-custom-style ${document.documentElement.classList.contains("dark") ? "swal2-dark" : ""}` }, title: "\u786E\u5B9A\u8981\u6E05\u7A7A\u4F1A\u8BDD\u5417\uFF1F", text: "\u5F53\u524D\u4F1A\u8BDD\u7684\u6240\u6709\u804A\u5929\u8BB0\u5F55\u5C06\u88AB\u5220\u9664\uFF0C\u4F46\u4F1A\u8BDD\u672C\u8EAB\u4F1A\u4FDD\u7559\u3002", showCancelButton: true, confirmButtonText: "\u786E\u8BA4\u6E05\u7A7A", cancelButtonText: "\u53D6\u6D88", reverseButtons: false, confirmButtonColor: "#ef4444", cancelButtonColor: "#6b7280", focusConfirm: false, focusCancel: true }).then((result) => { if (result.isConfirmed) { this.sessionManager.clearCurrentSession(); this._render(); } }); } _handleDeleteSession(sessionId) { Swal.fire({ width: "22rem", backdrop: `rgba(0,0,0,0.5)`, heightAuto: false, customClass: { popup: `swal2-custom-style ${document.documentElement.classList.contains("dark") ? "swal2-dark" : ""}` }, title: "\u786E\u5B9A\u8981\u5220\u9664\u5417\uFF1F", text: "\u6B64\u4F1A\u8BDD\u7684\u6240\u6709\u8BB0\u5F55\u5C06\u88AB\u6C38\u4E45\u5220\u9664\uFF0C\u65E0\u6CD5\u64A4\u9500\u3002", showCancelButton: true, confirmButtonText: "\u786E\u8BA4\u5220\u9664", cancelButtonText: "\u53D6\u6D88", reverseButtons: false, confirmButtonColor: "#ef4444", cancelButtonColor: "#6b7280", focusConfirm: false, focusCancel: true }).then((result) => { if (result.isConfirmed) { this.sessionManager.deleteSession(sessionId); this._render(); } }); } }; function chat_default() { const page = new ChatPage(); page.init(); } export { chat_default as default };