my-anees-package 1.0.5 → 1.0.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,38 +1,38 @@
1
- import T, { useRef as W, useEffect as q, useState as R, useMemo as G, useCallback as H } from "react";
1
+ import l, { useRef as W, useEffect as L, useState as N, useMemo as G, useCallback as H } from "react";
2
2
  import { createPortal as _ } from "react-dom";
3
3
  import { FontAwesomeIcon as V } from "@fortawesome/react-fontawesome";
4
4
  import { faBold as ie, faItalic as ae } from "@fortawesome/free-solid-svg-icons";
5
5
  import { CKEditor as ge } from "@ckeditor/ckeditor5-react";
6
6
  import "mathlive";
7
- import { Essentials as fe, Bold as we, Italic as Ae, Underline as ye, Paragraph as Ce, Heading as ve, Table as ke, TableToolbar as Se, TableCellProperties as xe, TableProperties as Be, List as Ee, Link as De, Undo as Pe, ClassicEditor as Re, Plugin as ne, ButtonView as $, Widget as Te, toWidget as Ne } from "ckeditor5";
7
+ import { Essentials as fe, Bold as we, Italic as Ae, Underline as ye, Paragraph as Ce, Heading as ve, Table as ke, TableToolbar as Se, TableCellProperties as xe, TableProperties as Be, List as Ee, Link as De, Undo as Pe, ClassicEditor as Te, Plugin as ne, ButtonView as $, Widget as Ne, toWidget as qe } from "ckeditor5";
8
8
  import "ckeditor5/ckeditor5.css";
9
- const se = "data:image/png;base64,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", oe = "data:image/png;base64,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", ee = "data-cursor-pointer-fix", qe = `
9
+ const se = "data:image/png;base64,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", oe = "data:image/png;base64,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", ee = "data-cursor-pointer-fix", Le = `
10
10
  :host, :host * { cursor: pointer !important; }
11
11
  .ML__latex, .ML__content, .ML__container, .ML__virtual-keyboard-toggle { cursor: pointer !important; }
12
12
  `;
13
- function Y(l) {
14
- const t = l == null ? void 0 : l.shadowRoot;
13
+ function Y(r) {
14
+ const t = r == null ? void 0 : r.shadowRoot;
15
15
  if (!t || t.querySelector(`[${ee}]`)) return;
16
- const c = document.createElement("style");
17
- c.setAttribute(ee, "true"), c.textContent = qe, t.appendChild(c);
16
+ const b = document.createElement("style");
17
+ b.setAttribute(ee, "true"), b.textContent = Le, t.appendChild(b);
18
18
  }
19
- function Le() {
19
+ function Ie() {
20
20
  document.querySelectorAll("math-field[read-only], math-field[readonly]").forEach(Y);
21
21
  }
22
22
  let Z = null;
23
- function Ie() {
24
- Z || (Le(), Z = new MutationObserver((l) => {
25
- var t, c;
26
- for (const n of l)
27
- for (const i of n.addedNodes)
28
- i instanceof Element && (((t = i.tagName) == null ? void 0 : t.toLowerCase()) === "math-field" && requestAnimationFrame(() => Y(i)), (c = i.querySelectorAll) == null || c.call(i, "math-field[read-only], math-field[readonly]").forEach((o) => requestAnimationFrame(() => Y(o))));
23
+ function Re() {
24
+ Z || (Ie(), Z = new MutationObserver((r) => {
25
+ var t, b;
26
+ for (const s of r)
27
+ for (const a of s.addedNodes)
28
+ a instanceof Element && (((t = a.tagName) == null ? void 0 : t.toLowerCase()) === "math-field" && requestAnimationFrame(() => Y(a)), (b = a.querySelectorAll) == null || b.call(a, "math-field[read-only], math-field[readonly]").forEach((m) => requestAnimationFrame(() => Y(m))));
29
29
  }), Z.observe(document.body, { childList: !0, subtree: !0 }));
30
30
  }
31
31
  const Me = "§MATH§", He = "§END§";
32
- function te(l) {
33
- return l.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
32
+ function te(r) {
33
+ return r.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
34
34
  }
35
- function le(l) {
35
+ function le(r) {
36
36
  const t = document.createElement("math-field");
37
37
  return t.setAttribute("read-only", ""), t.setAttribute(
38
38
  "style",
@@ -49,14 +49,14 @@ function le(l) {
49
49
  "--primary-color:#0f766e"
50
50
  ].join(";")
51
51
  ), requestAnimationFrame(() => {
52
- t.setValue ? t.setValue(l) : t.value = l;
52
+ t.setValue ? t.setValue(r) : t.value = r;
53
53
  }), t;
54
54
  }
55
- function re(l, t) {
55
+ function re(r, t) {
56
56
  if (!t) return;
57
- const c = document.createElement("div");
58
- c.innerHTML = t;
59
- const n = /* @__PURE__ */ new Set([
57
+ const b = document.createElement("div");
58
+ b.innerHTML = t;
59
+ const s = /* @__PURE__ */ new Set([
60
60
  "B",
61
61
  "STRONG",
62
62
  "I",
@@ -87,58 +87,58 @@ function re(l, t) {
87
87
  "FIGCAPTION",
88
88
  "COLGROUP",
89
89
  "COL"
90
- ]), i = (a, s) => {
91
- Array.from(a.childNodes).forEach((m) => {
92
- if (m.nodeType === Node.TEXT_NODE)
93
- s.appendChild(document.createTextNode(m.textContent));
94
- else if (m.nodeType === Node.ELEMENT_NODE) {
95
- const S = m.nodeName;
96
- if (S === "MATH-FIELD")
97
- s.appendChild(m.cloneNode(!0));
98
- else if (S === "BR")
99
- s.appendChild(document.createElement("br"));
100
- else if (S === "SPAN" && m.classList.contains("math-tex")) {
101
- const g = document.createElement("span");
102
- g.className = "math-tex", m.getAttribute("data-latex") && g.setAttribute("data-latex", m.getAttribute("data-latex")), g.textContent = m.textContent, s.appendChild(g);
103
- } else if (n.has(S)) {
104
- const g = { STRONG: "b", EM: "i" }, x = document.createElement(g[S] || S.toLowerCase());
105
- S === "A" && m.getAttribute("href") && (x.setAttribute("href", m.getAttribute("href")), x.setAttribute("target", "_blank"), x.setAttribute("rel", "noopener noreferrer")), ["style", "class", "colspan", "rowspan"].forEach((C) => {
106
- m.getAttribute(C) && x.setAttribute(C, m.getAttribute(C));
107
- }), i(m, x), s.appendChild(x);
90
+ ]), a = (n, o) => {
91
+ Array.from(n.childNodes).forEach((c) => {
92
+ if (c.nodeType === Node.TEXT_NODE)
93
+ o.appendChild(document.createTextNode(c.textContent));
94
+ else if (c.nodeType === Node.ELEMENT_NODE) {
95
+ const x = c.nodeName;
96
+ if (x === "MATH-FIELD")
97
+ o.appendChild(c.cloneNode(!0));
98
+ else if (x === "BR")
99
+ o.appendChild(document.createElement("br"));
100
+ else if (x === "SPAN" && c.classList.contains("math-tex")) {
101
+ const f = document.createElement("span");
102
+ f.className = "math-tex", c.getAttribute("data-latex") && f.setAttribute("data-latex", c.getAttribute("data-latex")), f.textContent = c.textContent, o.appendChild(f);
103
+ } else if (s.has(x)) {
104
+ const f = { STRONG: "b", EM: "i" }, B = document.createElement(f[x] || x.toLowerCase());
105
+ x === "A" && c.getAttribute("href") && (B.setAttribute("href", c.getAttribute("href")), B.setAttribute("target", "_blank"), B.setAttribute("rel", "noopener noreferrer")), ["style", "class", "colspan", "rowspan"].forEach((v) => {
106
+ c.getAttribute(v) && B.setAttribute(v, c.getAttribute(v));
107
+ }), a(c, B), o.appendChild(B);
108
108
  } else
109
- i(m, s);
109
+ a(c, o);
110
110
  }
111
111
  });
112
- }, o = document.createElement("span");
113
- for (i(c, o); o.firstChild; ) l.appendChild(o.firstChild);
112
+ }, m = document.createElement("span");
113
+ for (a(b, m); m.firstChild; ) r.appendChild(m.firstChild);
114
114
  }
115
- function Oe({ value: l = "" }) {
115
+ function Oe({ value: r = "" }) {
116
116
  const t = W(null);
117
- return q(() => {
118
- const c = t.current;
119
- if (!c) return;
120
- c.innerHTML = "";
121
- const n = new RegExp(
117
+ return L(() => {
118
+ const b = t.current;
119
+ if (!b) return;
120
+ b.innerHTML = "";
121
+ const s = new RegExp(
122
122
  te(Me) + "([\\s\\S]*?)" + te(He),
123
123
  "g"
124
124
  );
125
- let i = 0, o;
126
- for (; (o = n.exec(l)) !== null; ) {
127
- if (o.index > i) {
128
- const s = l.slice(i, o.index);
129
- re(c, s);
125
+ let a = 0, m;
126
+ for (; (m = s.exec(r)) !== null; ) {
127
+ if (m.index > a) {
128
+ const o = r.slice(a, m.index);
129
+ re(b, o);
130
130
  }
131
- const a = o[1];
132
- c.appendChild(le(a)), i = o.index + o[0].length;
131
+ const n = m[1];
132
+ b.appendChild(le(n)), a = m.index + m[0].length;
133
133
  }
134
- i < l.length && re(c, l.slice(i)), c.querySelectorAll("span.math-tex").forEach((a) => {
135
- const s = a.getAttribute("data-latex") || a.textContent || "";
136
- if (s) {
137
- const m = le(s);
138
- a.replaceWith(m);
134
+ a < r.length && re(b, r.slice(a)), b.querySelectorAll("span.math-tex").forEach((n) => {
135
+ const o = n.getAttribute("data-latex") || n.textContent || "";
136
+ if (o) {
137
+ const c = le(o);
138
+ n.replaceWith(c);
139
139
  }
140
140
  });
141
- }, [l]), /* @__PURE__ */ T.createElement(
141
+ }, [r]), /* @__PURE__ */ l.createElement(
142
142
  "span",
143
143
  {
144
144
  ref: t,
@@ -156,148 +156,148 @@ const me = [
156
156
  { id: "Phonetic", name: "Phonetic", ranges: [[592, 687], [7424, 7551]] },
157
157
  { id: "Other", name: "Other", ranges: [[8352, 8399], [8448, 8527], [9632, 9727]] }
158
158
  ], Ue = () => {
159
- const l = [];
159
+ const r = [];
160
160
  return me.slice(1).forEach((t) => {
161
- t.ranges.forEach((c) => {
162
- for (let n = c[0]; n <= c[1]; n++)
163
- n >= 127 && n <= 159 || l.push({
164
- code: n.toString(16).toUpperCase().padStart(4, "0"),
165
- char: String.fromCodePoint(n),
161
+ t.ranges.forEach((b) => {
162
+ for (let s = b[0]; s <= b[1]; s++)
163
+ s >= 127 && s <= 159 || r.push({
164
+ code: s.toString(16).toUpperCase().padStart(4, "0"),
165
+ char: String.fromCodePoint(s),
166
166
  category: t.id
167
167
  });
168
168
  });
169
- }), l;
169
+ }), r;
170
170
  }, We = Ue();
171
- function Je({ isOpen: l, onClose: t, onInsert: c, position: n }) {
172
- const [i, o] = R(""), [a, s] = R("All");
173
- q(() => {
174
- l && (o(""), s("All"));
175
- }, [l]);
176
- const m = G(() => {
177
- let u = We;
178
- if (a !== "All" && (u = u.filter((C) => C.category === a)), i.trim()) {
179
- const C = i.trim().toUpperCase();
180
- u = u.filter((p) => p.code.includes(C));
171
+ function Je({ isOpen: r, onClose: t, onInsert: b, position: s }) {
172
+ const [a, m] = N(""), [n, o] = N("All");
173
+ L(() => {
174
+ r && (m(""), o("All"));
175
+ }, [r]);
176
+ const c = G(() => {
177
+ let h = We;
178
+ if (n !== "All" && (h = h.filter((v) => v.category === n)), a.trim()) {
179
+ const v = a.trim().toUpperCase();
180
+ h = h.filter((u) => u.code.includes(v));
181
181
  }
182
- return u;
183
- }, [a, i]), S = G(() => {
184
- if (a !== "All" && !i.trim())
185
- return { [a]: m };
186
- const u = {};
187
- return m.forEach((C) => {
188
- u[C.category] || (u[C.category] = []), u[C.category].push(C);
189
- }), u;
190
- }, [m, a, i]), g = (u) => {
191
- u.key === "Escape" && t();
182
+ return h;
183
+ }, [n, a]), x = G(() => {
184
+ if (n !== "All" && !a.trim())
185
+ return { [n]: c };
186
+ const h = {};
187
+ return c.forEach((v) => {
188
+ h[v.category] || (h[v.category] = []), h[v.category].push(v);
189
+ }), h;
190
+ }, [c, n, a]), f = (h) => {
191
+ h.key === "Escape" && t();
192
192
  };
193
- if (q(() => (l && window.addEventListener("keydown", g), () => window.removeEventListener("keydown", g)), [l]), !l) return null;
194
- let x = { top: "50%", left: "50%", transform: "translate(-50%, -50%)" };
195
- if (n) {
196
- let u = n.x - 120, C = n.y;
197
- u < 10 && (u = 10), u + 230 > window.innerWidth && (u = window.innerWidth - 240), C + 200 > window.innerHeight && (C = window.innerHeight - 210), x = { top: `${C}px`, left: `${u}px` };
193
+ if (L(() => (r && window.addEventListener("keydown", f), () => window.removeEventListener("keydown", f)), [r]), !r) return null;
194
+ let B = { top: "50%", left: "50%", transform: "translate(-50%, -50%)" };
195
+ if (s) {
196
+ let h = s.x - 120, v = s.y;
197
+ h < 10 && (h = 10), h + 230 > window.innerWidth && (h = window.innerWidth - 240), v + 200 > window.innerHeight && (v = window.innerHeight - 210), B = { top: `${v}px`, left: `${h}px` };
198
198
  }
199
- return /* @__PURE__ */ T.createElement("div", { className: "scm-overlay", onMouseDown: (u) => {
200
- u.stopPropagation(), t();
201
- } }, /* @__PURE__ */ T.createElement("div", { className: "scm-modal", style: x, onMouseDown: (u) => u.stopPropagation() }, /* @__PURE__ */ T.createElement("div", { className: "scm-toolbar" }, /* @__PURE__ */ T.createElement(
199
+ return /* @__PURE__ */ l.createElement("div", { className: "scm-overlay", onMouseDown: (h) => {
200
+ h.stopPropagation(), t();
201
+ } }, /* @__PURE__ */ l.createElement("div", { className: "scm-modal", style: B, onMouseDown: (h) => h.stopPropagation() }, /* @__PURE__ */ l.createElement("div", { className: "scm-toolbar" }, /* @__PURE__ */ l.createElement(
202
202
  "input",
203
203
  {
204
204
  type: "text",
205
205
  placeholder: "Code",
206
- value: i,
207
- onChange: (u) => o(u.target.value),
206
+ value: a,
207
+ onChange: (h) => m(h.target.value),
208
208
  className: "scm-code-input"
209
209
  }
210
- ), /* @__PURE__ */ T.createElement(
210
+ ), /* @__PURE__ */ l.createElement(
211
211
  "select",
212
212
  {
213
- value: a,
214
- onChange: (u) => s(u.target.value),
213
+ value: n,
214
+ onChange: (h) => o(h.target.value),
215
215
  className: "scm-category-select"
216
216
  },
217
- me.map((u) => /* @__PURE__ */ T.createElement("option", { key: u.id, value: u.id }, u.name))
218
- )), /* @__PURE__ */ T.createElement("div", { className: "scm-body" }, /* @__PURE__ */ T.createElement("div", { className: "scm-grid-container" }, Object.entries(S).map(([u, C]) => /* @__PURE__ */ T.createElement("div", { key: u, className: "scm-category-group" }, /* @__PURE__ */ T.createElement("div", { className: "scm-char-grid" }, C.map((p) => /* @__PURE__ */ T.createElement(
217
+ me.map((h) => /* @__PURE__ */ l.createElement("option", { key: h.id, value: h.id }, h.name))
218
+ )), /* @__PURE__ */ l.createElement("div", { className: "scm-body" }, /* @__PURE__ */ l.createElement("div", { className: "scm-grid-container" }, Object.entries(x).map(([h, v]) => /* @__PURE__ */ l.createElement("div", { key: h, className: "scm-category-group" }, /* @__PURE__ */ l.createElement("div", { className: "scm-char-grid" }, v.map((u) => /* @__PURE__ */ l.createElement(
219
219
  "button",
220
220
  {
221
- key: p.code,
221
+ key: u.code,
222
222
  className: "scm-char-btn",
223
223
  onClick: () => {
224
- c(p.char), t();
224
+ b(u.char), t();
225
225
  },
226
- title: `U+${p.code}`
226
+ title: `U+${u.code}`
227
227
  },
228
- p.char
229
- ))))), m.length === 0 && /* @__PURE__ */ T.createElement("div", { className: "scm-no-results" }, "No characters found.")))));
228
+ u.char
229
+ ))))), c.length === 0 && /* @__PURE__ */ l.createElement("div", { className: "scm-no-results" }, "No characters found.")))));
230
230
  }
231
231
  window.__ckMathWidgets = window.__ckMathWidgets || /* @__PURE__ */ new Map();
232
232
  window.__ckMathWidgetClickHandler = null;
233
- function ce(l) {
234
- var c, n, i, o, a;
235
- if (!l) return null;
236
- const t = typeof l.composedPath == "function" ? l.composedPath() : [l];
237
- for (const s of t)
238
- if (s instanceof HTMLElement && ((c = s.classList) != null && c.contains("ck-math-widget") || (n = s.dataset) != null && n.mathId || (i = s.classList) != null && i.contains("ck-widget") && ((o = s.querySelector) != null && o.call(s, ".ck-math-widget-inner"))))
239
- return s;
240
- return l instanceof Element ? (a = l.closest) == null ? void 0 : a.call(l, ".ck-math-widget, [data-math-id]") : null;
233
+ function ce(r) {
234
+ var b, s, a, m, n;
235
+ if (!r) return null;
236
+ const t = typeof r.composedPath == "function" ? r.composedPath() : [r];
237
+ for (const o of t)
238
+ if (o instanceof HTMLElement && ((b = o.classList) != null && b.contains("ck-math-widget") || (s = o.dataset) != null && s.mathId || (a = o.classList) != null && a.contains("ck-widget") && ((m = o.querySelector) != null && m.call(o, ".ck-math-widget-inner"))))
239
+ return o;
240
+ return r instanceof Element ? (n = r.closest) == null ? void 0 : n.call(r, ".ck-math-widget, [data-math-id]") : null;
241
241
  }
242
- function J(l) {
243
- if (!l) return "";
244
- const t = l.getAttribute("data-latex");
242
+ function J(r) {
243
+ if (!r) return "";
244
+ const t = r.getAttribute("data-latex");
245
245
  if (t) return t;
246
- const c = l.querySelector("math-field");
247
- return c ? c.getValue ? c.getValue() : c.value || "" : "";
246
+ const b = r.querySelector("math-field");
247
+ return b ? b.getValue ? b.getValue() : b.value || "" : "";
248
248
  }
249
- function z(l, t) {
250
- if (!l || !t) return !1;
249
+ function z(r, t) {
250
+ if (!r || !t) return !1;
251
251
  try {
252
- return l.model.createPositionBefore(t), !0;
252
+ return r.model.createPositionBefore(t), !0;
253
253
  } catch {
254
254
  return !1;
255
255
  }
256
256
  }
257
- function Fe(l, t) {
258
- var s;
259
- if (!l || !t) return null;
260
- const c = l.model.document.selection.getSelectedElement();
261
- if ((c == null ? void 0 : c.name) === "mathInline") return c;
262
- const n = t.getAttribute("data-math-id");
263
- if (n) {
264
- const m = window.__ckMathWidgets.get(n);
265
- if (z(l, m)) return m;
257
+ function Fe(r, t) {
258
+ var o;
259
+ if (!r || !t) return null;
260
+ const b = r.model.document.selection.getSelectedElement();
261
+ if ((b == null ? void 0 : b.name) === "mathInline") return b;
262
+ const s = t.getAttribute("data-math-id");
263
+ if (s) {
264
+ const c = window.__ckMathWidgets.get(s);
265
+ if (z(r, c)) return c;
266
266
  }
267
- const i = l.editing.view.domConverter.mapDomToView(t);
268
- if (i) {
269
- const m = l.editing.mapper.toModelElement(i);
270
- if ((m == null ? void 0 : m.name) === "mathInline") return m;
267
+ const a = r.editing.view.domConverter.mapDomToView(t);
268
+ if (a) {
269
+ const c = r.editing.mapper.toModelElement(a);
270
+ if ((c == null ? void 0 : c.name) === "mathInline") return c;
271
271
  }
272
- const o = J(t);
273
- if (!o) return null;
274
- const a = l.model.document.getRoot();
275
- for (const { item: m } of l.model.createRangeIn(a))
276
- if ((s = m.is) != null && s.call(m, "element", "mathInline") && m.getAttribute("latex") === o)
277
- return m;
272
+ const m = J(t);
273
+ if (!m) return null;
274
+ const n = r.model.document.getRoot();
275
+ for (const { item: c } of r.model.createRangeIn(n))
276
+ if ((o = c.is) != null && o.call(c, "element", "mathInline") && c.getAttribute("latex") === m)
277
+ return c;
278
278
  return null;
279
279
  }
280
- function j(l, t, c, n) {
281
- if (!l || l._mathWidgetOpening) return;
282
- l._mathWidgetOpening = !0, queueMicrotask(() => {
283
- l._mathWidgetOpening = !1;
280
+ function j(r, t, b, s) {
281
+ if (!r || r._mathWidgetOpening) return;
282
+ r._mathWidgetOpening = !0, queueMicrotask(() => {
283
+ r._mathWidgetOpening = !1;
284
284
  });
285
- const i = z(l, t) ? t : Fe(l, n), o = (i == null ? void 0 : i.getAttribute("latex")) || c || J(n);
286
- if (!o) return;
287
- i && l.model.change((s) => {
288
- s.setSelection(i, "on");
285
+ const a = z(r, t) ? t : Fe(r, s), m = (a == null ? void 0 : a.getAttribute("latex")) || b || J(s);
286
+ if (!m) return;
287
+ a && r.model.change((o) => {
288
+ o.setSelection(a, "on");
289
289
  });
290
- const a = l.mathWidgetClickHandler || window.__ckMathWidgetClickHandler;
291
- a == null || a(i, o);
290
+ const n = r.mathWidgetClickHandler || window.__ckMathWidgetClickHandler;
291
+ n == null || n(a, m);
292
292
  }
293
- function Qe(l, t) {
293
+ function Qe(r, t) {
294
294
  if (!t || t._ckMathClickBound) return;
295
295
  t._ckMathClickBound = !0;
296
- const c = (n) => {
297
- var i;
298
- n.button === 0 && (n.preventDefault(), n.stopPropagation(), (i = n.stopImmediatePropagation) == null || i.call(n), j(l, null, J(t), t));
296
+ const b = (s) => {
297
+ var a;
298
+ s.button === 0 && (s.preventDefault(), s.stopPropagation(), (a = s.stopImmediatePropagation) == null || a.call(s), j(r, null, J(t), t));
299
299
  };
300
- t.addEventListener("mousedown", c, !0), t.addEventListener("click", c, !0);
300
+ t.addEventListener("mousedown", b, !0), t.addEventListener("click", b, !0);
301
301
  }
302
302
  const Ve = [
303
303
  {
@@ -351,10 +351,10 @@ const Ve = [
351
351
  { label: "↷", action: "REDO", title: "Redo" },
352
352
  { type: "sep", cols: 2 },
353
353
  // 7. Formatting Group (2 cols)
354
- { label: /* @__PURE__ */ React.createElement(V, { icon: ie }), action: "BOLD", cls: "template", title: "Bold" },
355
- { label: /* @__PURE__ */ React.createElement(V, { icon: ae }), action: "ITALIC", cls: "template", title: "Italic" },
354
+ { label: /* @__PURE__ */ l.createElement(V, { icon: ie }), action: "BOLD", cls: "template", title: "Bold" },
355
+ { label: /* @__PURE__ */ l.createElement(V, { icon: ae }), action: "ITALIC", cls: "template", title: "Italic" },
356
356
  {
357
- label: /* @__PURE__ */ React.createElement(
357
+ label: /* @__PURE__ */ l.createElement(
358
358
  "img",
359
359
  {
360
360
  src: se,
@@ -368,7 +368,7 @@ const Ve = [
368
368
  action: "SPECIAL_CHARS"
369
369
  },
370
370
  {
371
- label: /* @__PURE__ */ React.createElement(
371
+ label: /* @__PURE__ */ l.createElement(
372
372
  "img",
373
373
  {
374
374
  src: oe,
@@ -1233,7 +1233,7 @@ const Ve = [
1233
1233
  { label: "Sub", insert: "\\square_{#?}", isWidget: !0, title: "Subscript" },
1234
1234
  { type: "sep", cols: 2, cls: "cme-matrix-subgroup" },
1235
1235
  {
1236
- label: /* @__PURE__ */ React.createElement("svg", { width: "24", height: "18", viewBox: "0 0 24 18", fill: "none", stroke: "currentColor", strokeWidth: "1.5", strokeDasharray: "3 2", style: { display: "inline-block", verticalAlign: "middle", color: "#107c41" } }, /* @__PURE__ */ React.createElement("rect", { x: "2", y: "2", width: "8", height: "14", rx: "1" }), /* @__PURE__ */ React.createElement("rect", { x: "14", y: "2", width: "8", height: "14", rx: "1" })),
1236
+ label: /* @__PURE__ */ l.createElement("svg", { width: "24", height: "18", viewBox: "0 0 24 18", fill: "none", stroke: "currentColor", strokeWidth: "1.5", strokeDasharray: "3 2", style: { display: "inline-block", verticalAlign: "middle", color: "#107c41" } }, /* @__PURE__ */ l.createElement("rect", { x: "2", y: "2", width: "8", height: "14", rx: "1" }), /* @__PURE__ */ l.createElement("rect", { x: "14", y: "2", width: "8", height: "14", rx: "1" })),
1237
1237
  insert: "\\hphantom{0}",
1238
1238
  cls: "template",
1239
1239
  directInsert: !0,
@@ -1241,7 +1241,7 @@ const Ve = [
1241
1241
  title: "Horizontal Phantom Space"
1242
1242
  },
1243
1243
  {
1244
- label: /* @__PURE__ */ React.createElement("svg", { width: "16", height: "18", viewBox: "0 0 16 18", fill: "none", stroke: "currentColor", strokeWidth: "1.5", strokeDasharray: "3 2", style: { display: "inline-block", verticalAlign: "middle", color: "#107c41" } }, /* @__PURE__ */ React.createElement("rect", { x: "2", y: "2", width: "12", height: "14", rx: "1" })),
1244
+ label: /* @__PURE__ */ l.createElement("svg", { width: "16", height: "18", viewBox: "0 0 16 18", fill: "none", stroke: "currentColor", strokeWidth: "1.5", strokeDasharray: "3 2", style: { display: "inline-block", verticalAlign: "middle", color: "#107c41" } }, /* @__PURE__ */ l.createElement("rect", { x: "2", y: "2", width: "12", height: "14", rx: "1" })),
1245
1245
  insert: "\\,",
1246
1246
  cls: "template",
1247
1247
  directInsert: !0,
@@ -1249,7 +1249,7 @@ const Ve = [
1249
1249
  title: "Thin Space"
1250
1250
  },
1251
1251
  {
1252
- label: /* @__PURE__ */ React.createElement("svg", { width: "16", height: "18", viewBox: "0 0 16 18", fill: "none", stroke: "currentColor", strokeWidth: "1.5", strokeDasharray: "3 2", style: { display: "inline-block", verticalAlign: "middle", color: "#107c41" } }, /* @__PURE__ */ React.createElement("rect", { x: "2", y: "2", width: "12", height: "14", rx: "1" }), /* @__PURE__ */ React.createElement("path", { d: "M11 9H5M5 9l2.5-2.5M5 9l2.5 2.5", strokeDasharray: "none", strokeLinecap: "round", strokeLinejoin: "round" })),
1252
+ label: /* @__PURE__ */ l.createElement("svg", { width: "16", height: "18", viewBox: "0 0 16 18", fill: "none", stroke: "currentColor", strokeWidth: "1.5", strokeDasharray: "3 2", style: { display: "inline-block", verticalAlign: "middle", color: "#107c41" } }, /* @__PURE__ */ l.createElement("rect", { x: "2", y: "2", width: "12", height: "14", rx: "1" }), /* @__PURE__ */ l.createElement("path", { d: "M11 9H5M5 9l2.5-2.5M5 9l2.5 2.5", strokeDasharray: "none", strokeLinecap: "round", strokeLinejoin: "round" })),
1253
1253
  insert: "\\!",
1254
1254
  cls: "template",
1255
1255
  directInsert: !0,
@@ -1522,7 +1522,7 @@ const Ve = [
1522
1522
  ]
1523
1523
  },
1524
1524
  {
1525
- label: /* @__PURE__ */ React.createElement(
1525
+ label: /* @__PURE__ */ l.createElement(
1526
1526
  "svg",
1527
1527
  {
1528
1528
  xmlns: "http://www.w3.org/2000/svg",
@@ -1536,9 +1536,9 @@ const Ve = [
1536
1536
  strokeLinejoin: "round",
1537
1537
  style: { verticalAlign: "middle" }
1538
1538
  },
1539
- /* @__PURE__ */ React.createElement("path", { d: "M32 12 L24 24 H40 Z", fill: "currentColor" }),
1540
- /* @__PURE__ */ React.createElement("path", { d: "M16 36 C16 48, 48 48, 48 36" }),
1541
- /* @__PURE__ */ React.createElement("path", { d: "M22 36 C22 43, 42 43, 42 36" })
1539
+ /* @__PURE__ */ l.createElement("path", { d: "M32 12 L24 24 H40 Z", fill: "currentColor" }),
1540
+ /* @__PURE__ */ l.createElement("path", { d: "M16 36 C16 48, 48 48, 48 36" }),
1541
+ /* @__PURE__ */ l.createElement("path", { d: "M22 36 C22 43, 42 43, 42 36" })
1542
1542
  ),
1543
1543
  items: []
1544
1544
  }
@@ -1746,10 +1746,10 @@ const Ve = [
1746
1746
  { label: "↷", action: "REDO", title: "Redo" },
1747
1747
  { type: "sep", cols: 2 },
1748
1748
  // 7. Formatting Group (2 cols)
1749
- { label: /* @__PURE__ */ React.createElement(V, { icon: ie }), action: "BOLD", cls: "template", title: "Bold" },
1750
- { label: /* @__PURE__ */ React.createElement(V, { icon: ae }), action: "ITALIC", cls: "template", title: "Italic" },
1749
+ { label: /* @__PURE__ */ l.createElement(V, { icon: ie }), action: "BOLD", cls: "template", title: "Bold" },
1750
+ { label: /* @__PURE__ */ l.createElement(V, { icon: ae }), action: "ITALIC", cls: "template", title: "Italic" },
1751
1751
  {
1752
- label: /* @__PURE__ */ React.createElement(
1752
+ label: /* @__PURE__ */ l.createElement(
1753
1753
  "img",
1754
1754
  {
1755
1755
  src: se,
@@ -1763,7 +1763,7 @@ const Ve = [
1763
1763
  action: "SPECIAL_CHARS"
1764
1764
  },
1765
1765
  {
1766
- label: /* @__PURE__ */ React.createElement(
1766
+ label: /* @__PURE__ */ l.createElement(
1767
1767
  "img",
1768
1768
  {
1769
1769
  src: oe,
@@ -2887,7 +2887,7 @@ const Ve = [
2887
2887
  ]
2888
2888
  },
2889
2889
  {
2890
- label: /* @__PURE__ */ React.createElement(
2890
+ label: /* @__PURE__ */ l.createElement(
2891
2891
  "svg",
2892
2892
  {
2893
2893
  xmlns: "http://www.w3.org/2000/svg",
@@ -2901,27 +2901,27 @@ const Ve = [
2901
2901
  strokeLinejoin: "round",
2902
2902
  style: { verticalAlign: "middle" }
2903
2903
  },
2904
- /* @__PURE__ */ React.createElement("path", { d: "M32 12 L24 24 H40 Z", fill: "currentColor" }),
2905
- /* @__PURE__ */ React.createElement("path", { d: "M16 36 C16 48, 48 48, 48 36" }),
2906
- /* @__PURE__ */ React.createElement("path", { d: "M22 36 C22 43, 42 43, 42 36" })
2904
+ /* @__PURE__ */ l.createElement("path", { d: "M32 12 L24 24 H40 Z", fill: "currentColor" }),
2905
+ /* @__PURE__ */ l.createElement("path", { d: "M16 36 C16 48, 48 48, 48 36" }),
2906
+ /* @__PURE__ */ l.createElement("path", { d: "M22 36 C22 43, 42 43, 42 36" })
2907
2907
  ),
2908
2908
  items: []
2909
2909
  }
2910
2910
  ];
2911
- function Ze(l = "") {
2912
- if (String(l).match(/^\\ce\{([\s\S]*)\}$/)) return l;
2913
- const c = l.replace(/\\text\{([^}]*)\}/g, "$1").replace(/\$/g, "").trim();
2914
- return c ? `\\ce{${c}}` : "";
2911
+ function Ze(r = "") {
2912
+ if (String(r).match(/^\\ce\{([\s\S]*)\}$/)) return r;
2913
+ const b = r.replace(/\\text\{([^}]*)\}/g, "$1").replace(/\$/g, "").trim();
2914
+ return b ? `\\ce{${b}}` : "";
2915
2915
  }
2916
- function K(l) {
2917
- return l === "matrix" ? "\\begin{matrix} \\placeholder{} & \\placeholder{} \\\\ \\placeholder{} & \\placeholder{} \\end{matrix}" : l === "bmatrix" ? "\\begin{bmatrix} \\placeholder{} & \\placeholder{} \\\\ \\placeholder{} & \\placeholder{} \\end{bmatrix}" : l === "pmatrix" ? "\\begin{pmatrix} \\placeholder{} & \\placeholder{} \\\\ \\placeholder{} & \\placeholder{} \\end{pmatrix}" : l === "vmatrix" ? "\\begin{vmatrix} \\placeholder{} & \\placeholder{} \\\\ \\placeholder{} & \\placeholder{} \\end{vmatrix}" : l.replace(/#0|#\?/g, "\\placeholder{}");
2916
+ function K(r) {
2917
+ return r === "matrix" ? "\\begin{matrix} \\placeholder{} & \\placeholder{} \\\\ \\placeholder{} & \\placeholder{} \\end{matrix}" : r === "bmatrix" ? "\\begin{bmatrix} \\placeholder{} & \\placeholder{} \\\\ \\placeholder{} & \\placeholder{} \\end{bmatrix}" : r === "pmatrix" ? "\\begin{pmatrix} \\placeholder{} & \\placeholder{} \\\\ \\placeholder{} & \\placeholder{} \\end{pmatrix}" : r === "vmatrix" ? "\\begin{vmatrix} \\placeholder{} & \\placeholder{} \\\\ \\placeholder{} & \\placeholder{} \\end{vmatrix}" : r.replace(/#0|#\?/g, "\\placeholder{}");
2918
2918
  }
2919
2919
  class Ke extends ne {
2920
2920
  static get pluginName() {
2921
2921
  return "MathInlinePlugin";
2922
2922
  }
2923
2923
  static get requires() {
2924
- return [Te];
2924
+ return [Ne];
2925
2925
  }
2926
2926
  init() {
2927
2927
  const t = this.editor;
@@ -2930,197 +2930,197 @@ class Ke extends ne {
2930
2930
  isObject: !0,
2931
2931
  allowWhere: "$text",
2932
2932
  allowAttributes: ["latex"]
2933
- }), t.model.schema.addChildCheck((n, i) => {
2934
- if (i.name === "mathInline")
2933
+ }), t.model.schema.addChildCheck((s, a) => {
2934
+ if (a.name === "mathInline")
2935
2935
  return !0;
2936
2936
  }), t.conversion.for("editingDowncast").elementToElement({
2937
2937
  model: "mathInline",
2938
- view: (n, { writer: i }) => {
2939
- const o = n.getAttribute("latex") || "", a = "math-" + Math.random().toString(36).substr(2, 9);
2940
- window.__ckMathWidgets.set(a, n);
2941
- const s = i.createContainerElement("span", {
2938
+ view: (s, { writer: a }) => {
2939
+ const m = s.getAttribute("latex") || "", n = "math-" + Math.random().toString(36).substr(2, 9);
2940
+ window.__ckMathWidgets.set(n, s);
2941
+ const o = a.createContainerElement("span", {
2942
2942
  class: "ck-math-widget ck-math-inline-word",
2943
2943
  contenteditable: "false",
2944
- "data-math-id": a,
2945
- "data-latex": o
2946
- }), m = i.createRawElement(
2944
+ "data-math-id": n,
2945
+ "data-latex": m
2946
+ }), c = a.createRawElement(
2947
2947
  "span",
2948
2948
  {
2949
2949
  class: "ck-math-widget-inner",
2950
2950
  style: "display:inline-block;vertical-align:middle;margin:0 2px;cursor:pointer;width:auto;max-width:100%;pointer-events:none;"
2951
2951
  },
2952
- (S) => {
2953
- const g = document.createElement("math-field");
2954
- g.setAttribute("read-only", ""), g.setAttribute("math-virtual-keyboard-policy", "manual"), g.setAttribute("tabindex", "-1"), g.style.display = "inline-block", g.style.width = "auto", g.style.maxWidth = "100%", g.style.verticalAlign = "middle", g.style.border = "none", g.style.background = "transparent", g.style.outline = "none", g.style.fontSize = "inherit", g.style.minHeight = "auto", g.style.padding = "0 2px", g.style.margin = "0", g.style.pointerEvents = "none";
2955
- const x = () => {
2956
- g.setValue ? g.setValue(o, { silenceNotifications: !0 }) : g.value = o;
2952
+ (x) => {
2953
+ const f = document.createElement("math-field");
2954
+ f.setAttribute("read-only", ""), f.setAttribute("math-virtual-keyboard-policy", "manual"), f.setAttribute("tabindex", "-1"), f.style.display = "inline-block", f.style.width = "auto", f.style.maxWidth = "100%", f.style.verticalAlign = "middle", f.style.border = "none", f.style.background = "transparent", f.style.outline = "none", f.style.fontSize = "inherit", f.style.minHeight = "auto", f.style.padding = "0 2px", f.style.margin = "0", f.style.pointerEvents = "none";
2955
+ const B = () => {
2956
+ f.setValue ? f.setValue(m, { silenceNotifications: !0 }) : f.value = m;
2957
2957
  };
2958
- customElements.get("math-field") ? requestAnimationFrame(x) : customElements.whenDefined("math-field").then(() => requestAnimationFrame(x)), S.appendChild(g);
2959
- const u = () => {
2960
- const C = S.parentElement;
2961
- C && Qe(t, C);
2958
+ customElements.get("math-field") ? requestAnimationFrame(B) : customElements.whenDefined("math-field").then(() => requestAnimationFrame(B)), x.appendChild(f);
2959
+ const h = () => {
2960
+ const v = x.parentElement;
2961
+ v && Qe(t, v);
2962
2962
  };
2963
- u(), requestAnimationFrame(u);
2963
+ h(), requestAnimationFrame(h);
2964
2964
  }
2965
2965
  );
2966
- return i.insert(i.createPositionAt(s, 0), m), Ne(s, i, { label: "math formula" });
2966
+ return a.insert(a.createPositionAt(o, 0), c), qe(o, a, { label: "math formula" });
2967
2967
  }
2968
2968
  });
2969
- const c = t.editing.view.document;
2970
- this.listenTo(c, "mousedown", (n, i) => {
2971
- const o = ce(i.domTarget);
2972
- o && i.domEvent.button === 0 && (n.stop(), i.preventDefault(), j(
2969
+ const b = t.editing.view.document;
2970
+ this.listenTo(b, "mousedown", (s, a) => {
2971
+ const m = ce(a.domTarget);
2972
+ m && a.domEvent.button === 0 && (s.stop(), a.preventDefault(), j(
2973
2973
  t,
2974
2974
  null,
2975
- J(o),
2976
- o
2975
+ J(m),
2976
+ m
2977
2977
  ));
2978
2978
  }, { priority: "high" }), t.conversion.for("dataDowncast").elementToElement({
2979
2979
  model: "mathInline",
2980
- view: (n, { writer: i }) => {
2981
- const o = n.getAttribute("latex") || "", a = i.createContainerElement("span", {
2980
+ view: (s, { writer: a }) => {
2981
+ const m = s.getAttribute("latex") || "", n = a.createContainerElement("span", {
2982
2982
  class: "math-tex",
2983
- "data-latex": o,
2983
+ "data-latex": m,
2984
2984
  style: "display:inline;"
2985
2985
  });
2986
- return i.insert(i.createPositionAt(a, 0), i.createText(o)), a;
2986
+ return a.insert(a.createPositionAt(n, 0), a.createText(m)), n;
2987
2987
  }
2988
2988
  }), t.conversion.for("upcast").elementToElement({
2989
2989
  view: {
2990
2990
  name: "span",
2991
2991
  classes: "math-tex"
2992
2992
  },
2993
- model: (n, { writer: i }) => {
2994
- const o = n.getAttribute("data-latex") || "";
2995
- return i.createElement("mathInline", { latex: o });
2993
+ model: (s, { writer: a }) => {
2994
+ const m = s.getAttribute("data-latex") || "";
2995
+ return a.createElement("mathInline", { latex: m });
2996
2996
  }
2997
2997
  });
2998
2998
  }
2999
2999
  }
3000
3000
  const Ge = '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="20" height="20"><path d="M4 12h3l3 6l5-12h5" fill="none" stroke="currentColor" stroke-width="2.5" stroke-linecap="round" stroke-linejoin="round"/></svg>', Ye = '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="20" height="20"><rect x="3" y="3" width="18" height="18" rx="3" fill="none" stroke="currentColor" stroke-width="2"/><text x="12" y="16" text-anchor="middle" font-size="12" font-weight="bold" fill="currentColor" font-family="system-ui, sans-serif">C</text><text x="6" y="8" font-size="4" font-weight="bold" fill="currentColor" font-family="system-ui, sans-serif">6</text></svg>';
3001
- function ze(l) {
3001
+ function ze(r) {
3002
3002
  return class extends ne {
3003
3003
  init() {
3004
- const c = this.editor;
3005
- c.ui.componentFactory.add("mathType", () => {
3006
- const n = new $();
3007
- return n.set({ label: "Math", icon: Ge, tooltip: "Insert Math Formula" }), n.on("execute", () => l("math")), n;
3008
- }), c.ui.componentFactory.add("chemType", () => {
3009
- const n = new $();
3010
- return n.set({ label: "Chemistry", icon: Ye, tooltip: "Insert Chemistry Formula" }), n.on("execute", () => l("chem")), n;
3004
+ const b = this.editor;
3005
+ b.ui.componentFactory.add("mathType", () => {
3006
+ const s = new $();
3007
+ return s.set({ label: "Math", icon: Ge, tooltip: "Insert Math Formula" }), s.on("execute", () => r("math")), s;
3008
+ }), b.ui.componentFactory.add("chemType", () => {
3009
+ const s = new $();
3010
+ return s.set({ label: "Chemistry", icon: Ye, tooltip: "Insert Chemistry Formula" }), s.on("execute", () => r("chem")), s;
3011
3011
  });
3012
3012
  }
3013
3013
  };
3014
3014
  }
3015
- function je({ matrixType: l, x: t, y: c, onSelect: n, onMouseEnter: i, onMouseLeave: o }) {
3016
- const [a, s] = R({ r: 2, c: 2 }), m = Math.max(10, parseInt(a.r, 10) || 0), S = Math.max(10, parseInt(a.c, 10) || 0), g = (p) => {
3017
- const w = p.target.value;
3018
- if (w === "") {
3019
- s((h) => ({ ...h, r: "" }));
3015
+ function je({ matrixType: r, x: t, y: b, onSelect: s, onMouseEnter: a, onMouseLeave: m }) {
3016
+ const [n, o] = N({ r: 2, c: 2 }), c = Math.max(10, parseInt(n.r, 10) || 0), x = Math.max(10, parseInt(n.c, 10) || 0), f = (u) => {
3017
+ const A = u.target.value;
3018
+ if (A === "") {
3019
+ o((d) => ({ ...d, r: "" }));
3020
3020
  return;
3021
3021
  }
3022
- const E = parseInt(w, 10);
3023
- isNaN(E) || s((h) => ({ ...h, r: Math.max(1, Math.min(10, E)) }));
3024
- }, x = () => {
3025
- (a.r === "" || isNaN(parseInt(a.r, 10))) && s((p) => ({ ...p, r: 1 }));
3026
- }, u = (p) => {
3027
- const w = p.target.value;
3028
- if (w === "") {
3029
- s((h) => ({ ...h, c: "" }));
3022
+ const D = parseInt(A, 10);
3023
+ isNaN(D) || o((d) => ({ ...d, r: Math.max(1, Math.min(10, D)) }));
3024
+ }, B = () => {
3025
+ (n.r === "" || isNaN(parseInt(n.r, 10))) && o((u) => ({ ...u, r: 1 }));
3026
+ }, h = (u) => {
3027
+ const A = u.target.value;
3028
+ if (A === "") {
3029
+ o((d) => ({ ...d, c: "" }));
3030
3030
  return;
3031
3031
  }
3032
- const E = parseInt(w, 10);
3033
- isNaN(E) || s((h) => ({ ...h, c: Math.max(1, Math.min(10, E)) }));
3034
- }, C = () => {
3035
- (a.c === "" || isNaN(parseInt(a.c, 10))) && s((p) => ({ ...p, c: 1 }));
3032
+ const D = parseInt(A, 10);
3033
+ isNaN(D) || o((d) => ({ ...d, c: Math.max(1, Math.min(10, D)) }));
3034
+ }, v = () => {
3035
+ (n.c === "" || isNaN(parseInt(n.c, 10))) && o((u) => ({ ...u, c: 1 }));
3036
3036
  };
3037
- return q(() => {
3038
- const p = (w) => {
3039
- if (w.key === "Enter") {
3040
- w.preventDefault(), w.stopPropagation();
3041
- const E = parseInt(a.r, 10) || 1, h = parseInt(a.c, 10) || 1;
3042
- n(E, h);
3037
+ return L(() => {
3038
+ const u = (A) => {
3039
+ if (A.key === "Enter") {
3040
+ A.preventDefault(), A.stopPropagation();
3041
+ const D = parseInt(n.r, 10) || 1, d = parseInt(n.c, 10) || 1;
3042
+ s(D, d);
3043
3043
  }
3044
3044
  };
3045
- return window.addEventListener("keydown", p, !0), () => window.removeEventListener("keydown", p, !0);
3046
- }, [a.r, a.c, n]), /* @__PURE__ */ React.createElement(
3045
+ return window.addEventListener("keydown", u, !0), () => window.removeEventListener("keydown", u, !0);
3046
+ }, [n.r, n.c, s]), /* @__PURE__ */ l.createElement(
3047
3047
  "div",
3048
3048
  {
3049
3049
  className: "cme-matrix-hover-popover ck-only",
3050
- style: { top: `${c}px`, left: `${t}px` },
3051
- onMouseDown: (p) => p.stopPropagation(),
3052
- onMouseEnter: i,
3053
- onMouseLeave: o
3050
+ style: { top: `${b}px`, left: `${t}px` },
3051
+ onMouseDown: (u) => u.stopPropagation(),
3052
+ onMouseEnter: a,
3053
+ onMouseLeave: m
3054
3054
  },
3055
- /* @__PURE__ */ React.createElement("div", { className: "cme-matrix-hover-grid" }, Array.from({ length: m }).map((p, w) => /* @__PURE__ */ React.createElement("div", { key: w, className: "cme-matrix-hover-row" }, Array.from({ length: S }).map((E, h) => {
3056
- const O = parseInt(a.r, 10) || 0, A = parseInt(a.c, 10) || 0, k = w < O && h < A;
3057
- return /* @__PURE__ */ React.createElement(
3055
+ /* @__PURE__ */ l.createElement("div", { className: "cme-matrix-hover-grid" }, Array.from({ length: c }).map((u, A) => /* @__PURE__ */ l.createElement("div", { key: A, className: "cme-matrix-hover-row" }, Array.from({ length: x }).map((D, d) => {
3056
+ const O = parseInt(n.r, 10) || 0, y = parseInt(n.c, 10) || 0, S = A < O && d < y;
3057
+ return /* @__PURE__ */ l.createElement(
3058
3058
  "div",
3059
3059
  {
3060
- key: `${w}-${h}`,
3061
- className: `cme-matrix-hover-cell${k ? " selected" : ""}`,
3062
- onMouseEnter: () => s({ r: w + 1, c: h + 1 }),
3063
- onClick: (B) => {
3064
- B.preventDefault(), B.stopPropagation(), n(w + 1, h + 1);
3060
+ key: `${A}-${d}`,
3061
+ className: `cme-matrix-hover-cell${S ? " selected" : ""}`,
3062
+ onMouseEnter: () => o({ r: A + 1, c: d + 1 }),
3063
+ onClick: (E) => {
3064
+ E.preventDefault(), E.stopPropagation(), s(A + 1, d + 1);
3065
3065
  }
3066
3066
  }
3067
3067
  );
3068
3068
  })))),
3069
- /* @__PURE__ */ React.createElement("div", { className: "cme-matrix-hover-footer" }, /* @__PURE__ */ React.createElement("div", { className: "cme-matrix-counter" }, /* @__PURE__ */ React.createElement("span", null, "R"), /* @__PURE__ */ React.createElement(
3069
+ /* @__PURE__ */ l.createElement("div", { className: "cme-matrix-hover-footer" }, /* @__PURE__ */ l.createElement("div", { className: "cme-matrix-counter" }, /* @__PURE__ */ l.createElement("span", null, "R"), /* @__PURE__ */ l.createElement(
3070
3070
  "input",
3071
3071
  {
3072
3072
  type: "number",
3073
3073
  className: "cme-counter-val",
3074
- value: a.r,
3075
- onChange: g,
3076
- onBlur: x,
3074
+ value: n.r,
3075
+ onChange: f,
3076
+ onBlur: B,
3077
3077
  min: "1",
3078
3078
  max: "10"
3079
3079
  }
3080
- ), /* @__PURE__ */ React.createElement("div", { className: "cme-counter-btns" }, /* @__PURE__ */ React.createElement("button", { type: "button", onClick: () => s((p) => {
3081
- const w = parseInt(p.r, 10) || 1;
3082
- return { ...p, r: Math.min(10, w + 1) };
3083
- }) }, "▲"), /* @__PURE__ */ React.createElement("button", { type: "button", onClick: () => s((p) => {
3084
- const w = parseInt(p.r, 10) || 1;
3085
- return { ...p, r: Math.max(1, w - 1) };
3086
- }) }, "▼"))), /* @__PURE__ */ React.createElement("div", { className: "cme-matrix-counter" }, /* @__PURE__ */ React.createElement("span", null, "C"), /* @__PURE__ */ React.createElement(
3080
+ ), /* @__PURE__ */ l.createElement("div", { className: "cme-counter-btns" }, /* @__PURE__ */ l.createElement("button", { type: "button", onClick: () => o((u) => {
3081
+ const A = parseInt(u.r, 10) || 1;
3082
+ return { ...u, r: Math.min(10, A + 1) };
3083
+ }) }, "▲"), /* @__PURE__ */ l.createElement("button", { type: "button", onClick: () => o((u) => {
3084
+ const A = parseInt(u.r, 10) || 1;
3085
+ return { ...u, r: Math.max(1, A - 1) };
3086
+ }) }, "▼"))), /* @__PURE__ */ l.createElement("div", { className: "cme-matrix-counter" }, /* @__PURE__ */ l.createElement("span", null, "C"), /* @__PURE__ */ l.createElement(
3087
3087
  "input",
3088
3088
  {
3089
3089
  type: "number",
3090
3090
  className: "cme-counter-val",
3091
- value: a.c,
3092
- onChange: u,
3093
- onBlur: C,
3091
+ value: n.c,
3092
+ onChange: h,
3093
+ onBlur: v,
3094
3094
  min: "1",
3095
3095
  max: "10"
3096
3096
  }
3097
- ), /* @__PURE__ */ React.createElement("div", { className: "cme-counter-btns" }, /* @__PURE__ */ React.createElement("button", { type: "button", onClick: () => s((p) => {
3098
- const w = parseInt(p.c, 10) || 1;
3099
- return { ...p, c: Math.min(10, w + 1) };
3100
- }) }, "▲"), /* @__PURE__ */ React.createElement("button", { type: "button", onClick: () => s((p) => {
3101
- const w = parseInt(p.c, 10) || 1;
3102
- return { ...p, c: Math.max(1, w - 1) };
3097
+ ), /* @__PURE__ */ l.createElement("div", { className: "cme-counter-btns" }, /* @__PURE__ */ l.createElement("button", { type: "button", onClick: () => o((u) => {
3098
+ const A = parseInt(u.c, 10) || 1;
3099
+ return { ...u, c: Math.min(10, A + 1) };
3100
+ }) }, "▲"), /* @__PURE__ */ l.createElement("button", { type: "button", onClick: () => o((u) => {
3101
+ const A = parseInt(u.c, 10) || 1;
3102
+ return { ...u, c: Math.max(1, A - 1) };
3103
3103
  }) }, "▼"))))
3104
3104
  );
3105
3105
  }
3106
- function _e({ mode: l, onInsert: t, onClose: c, initialLatex: n, isEditing: i }) {
3107
- const o = W(null), [a, s] = R(0), [m, S] = R(null), [g, x] = R(null), [u, C] = R(null), [p, w] = R(null);
3106
+ function _e({ mode: r, onInsert: t, onClose: b, initialLatex: s, isEditing: a }) {
3107
+ const m = W(null), [n, o] = N(0), [c, x] = N(null), [f, B] = N(null), [h, v] = N(null), [u, A] = N(null);
3108
3108
  W(null);
3109
- const E = l === "math" ? Ve : Xe, [h, O] = R({
3109
+ const D = r === "math" ? Ve : Xe, [d, O] = N({
3110
3110
  bold: !1,
3111
3111
  italic: !1,
3112
3112
  color: "none",
3113
3113
  fontFamily: "none",
3114
3114
  fontSize: "auto"
3115
- }), A = H(() => {
3116
- const e = o.current;
3115
+ }), y = H(() => {
3116
+ const e = m.current;
3117
3117
  if (!(!e || typeof e.queryStyle != "function"))
3118
3118
  try {
3119
- const r = e.queryStyle({ fontSeries: "b" }) === "all" || e.queryStyle({ variantStyle: "bold" }) === "all", b = e.queryStyle({ variantStyle: "italic" }) === "all" || e.queryStyle({ shape: "it" }) === "all", y = ["roman", "sans-serif", "monospace"].find(
3120
- (d) => e.queryStyle({ fontFamily: d }) === "all"
3121
- ) || "none", f = [5, 7, 9].find(
3122
- (d) => e.queryStyle({ fontSize: d }) === "all"
3123
- ) || "auto", v = [
3119
+ const i = e.queryStyle({ fontSeries: "b" }) === "all" || e.queryStyle({ variantStyle: "bold" }) === "all", p = e.queryStyle({ variantStyle: "italic" }) === "all" || e.queryStyle({ shape: "it" }) === "all", C = ["roman", "sans-serif", "monospace"].find(
3120
+ (g) => e.queryStyle({ fontFamily: g }) === "all"
3121
+ ) || "none", w = [5, 7, 9].find(
3122
+ (g) => e.queryStyle({ fontSize: g }) === "all"
3123
+ ) || "auto", k = [
3124
3124
  "black",
3125
3125
  "dimgray",
3126
3126
  "gray",
@@ -3146,123 +3146,123 @@ function _e({ mode: l, onInsert: t, onClose: c, initialLatex: n, isEditing: i })
3146
3146
  "violet",
3147
3147
  "gold"
3148
3148
  ].find(
3149
- (d) => e.queryStyle({ color: d }) === "all"
3149
+ (g) => e.queryStyle({ color: g }) === "all"
3150
3150
  ) || "none";
3151
3151
  O({
3152
- bold: r,
3153
- italic: b,
3154
- fontFamily: y,
3155
- fontSize: String(f),
3156
- color: v
3152
+ bold: i,
3153
+ italic: p,
3154
+ fontFamily: C,
3155
+ fontSize: String(w),
3156
+ color: k
3157
3157
  });
3158
- } catch (r) {
3159
- console.warn("Failed to query active styles:", r);
3158
+ } catch (i) {
3159
+ console.warn("Failed to query active styles:", i);
3160
3160
  }
3161
3161
  }, []);
3162
- q(() => {
3163
- if (!m && !u) return;
3164
- const e = (r) => {
3165
- !r.target.closest(".cme-matrix-hover-popover") && !r.target.closest(".cme-matrix-btn-wrapper") && S(null), !r.target.closest(".cme-color-picker-popup") && !r.target.closest('[title="Text Color"]') && C(null);
3162
+ L(() => {
3163
+ if (!c && !h) return;
3164
+ const e = (i) => {
3165
+ !i.target.closest(".cme-matrix-hover-popover") && !i.target.closest(".cme-matrix-btn-wrapper") && x(null), !i.target.closest(".cme-color-picker-popup") && !i.target.closest('[title="Text Color"]') && v(null);
3166
3166
  };
3167
3167
  return window.addEventListener("mousedown", e, !0), window.addEventListener("pointerdown", e, !0), () => {
3168
3168
  window.removeEventListener("mousedown", e, !0), window.removeEventListener("pointerdown", e, !0);
3169
3169
  };
3170
- }, [m, u]), q(() => {
3171
- if (!p) return;
3172
- const e = (r) => {
3173
- !r.target.closest(".cme-more-popup") && !r.target.closest(".cme-more-trigger-btn") && w(null);
3170
+ }, [c, h]), L(() => {
3171
+ if (!u) return;
3172
+ const e = (i) => {
3173
+ !i.target.closest(".cme-more-popup") && !i.target.closest(".cme-more-trigger-btn") && A(null);
3174
3174
  };
3175
3175
  return window.addEventListener("mousedown", e, !0), window.addEventListener("pointerdown", e, !0), () => {
3176
3176
  window.removeEventListener("mousedown", e, !0), window.removeEventListener("pointerdown", e, !0);
3177
3177
  };
3178
- }, [p]), q(() => {
3179
- const e = setTimeout(() => Ie(), 50);
3178
+ }, [u]), L(() => {
3179
+ const e = setTimeout(() => Re(), 50);
3180
3180
  return () => clearTimeout(e);
3181
- }, [a]), q(() => {
3182
- const e = o.current;
3181
+ }, [n]), L(() => {
3182
+ const e = m.current;
3183
3183
  if (!e) return;
3184
- e.defaultMode = l === "chem" ? "text" : "math";
3185
- const r = () => {
3186
- if (n) {
3187
- let b = n;
3188
- if (l === "chem") {
3189
- const y = b.match(/^\\ce\{([\s\S]*)\}$/);
3190
- y && (b = y[1]);
3184
+ e.defaultMode = r === "chem" ? "text" : "math";
3185
+ const i = () => {
3186
+ if (s) {
3187
+ let p = s;
3188
+ if (r === "chem") {
3189
+ const C = p.match(/^\\ce\{([\s\S]*)\}$/);
3190
+ C && (p = C[1]);
3191
3191
  }
3192
- e.setValue ? e.setValue(b, { silenceNotifications: !0 }) : e.value = b;
3192
+ e.setValue ? e.setValue(p, { silenceNotifications: !0 }) : e.value = p;
3193
3193
  }
3194
3194
  requestAnimationFrame(() => e.focus());
3195
3195
  };
3196
- customElements.get("math-field") ? requestAnimationFrame(r) : customElements.whenDefined("math-field").then(() => requestAnimationFrame(r));
3197
- }, [l, n]), q(() => {
3198
- const e = o.current;
3196
+ customElements.get("math-field") ? requestAnimationFrame(i) : customElements.whenDefined("math-field").then(() => requestAnimationFrame(i));
3197
+ }, [r, s]), L(() => {
3198
+ const e = m.current;
3199
3199
  if (!e) return;
3200
- const r = (b) => {
3201
- if (h.italic && b.key.length === 1 && !b.ctrlKey && !b.metaKey && !b.altKey) {
3202
- b.preventDefault(), e.executeCommand(["insert", `\\textit{${b.key}}`]);
3200
+ const i = (p) => {
3201
+ if (d.italic && p.key.length === 1 && !p.ctrlKey && !p.metaKey && !p.altKey) {
3202
+ p.preventDefault(), e.executeCommand(["insert", `\\textit{${p.key}}`]);
3203
3203
  return;
3204
3204
  }
3205
- b.key === " " ? (b.preventDefault(), e.executeCommand(["insert", "\\, "])) : b.key === "Enter" && (b.preventDefault(), e.executeCommand(["insert", "\\\\"]), setTimeout(() => {
3206
- typeof e.applyStyle == "function" && (h.bold && e.applyStyle({
3205
+ p.key === " " ? (p.preventDefault(), e.executeCommand(["insert", "\\, "])) : p.key === "Enter" && (p.preventDefault(), e.executeCommand(["insert", "\\\\"]), setTimeout(() => {
3206
+ typeof e.applyStyle == "function" && (d.bold && e.applyStyle({
3207
3207
  variantStyle: "bold",
3208
3208
  fontSeries: "b"
3209
- }), h.color !== "none" && e.applyStyle({ color: h.color }), h.fontFamily !== "none" && e.applyStyle({ fontFamily: h.fontFamily }), h.fontSize !== "auto" && e.applyStyle({
3210
- fontSize: parseInt(h.fontSize, 10),
3211
- size: parseInt(h.fontSize, 10)
3212
- }), A());
3209
+ }), d.color !== "none" && e.applyStyle({ color: d.color }), d.fontFamily !== "none" && e.applyStyle({ fontFamily: d.fontFamily }), d.fontSize !== "auto" && e.applyStyle({
3210
+ fontSize: parseInt(d.fontSize, 10),
3211
+ size: parseInt(d.fontSize, 10)
3212
+ }), y());
3213
3213
  }, 10));
3214
3214
  };
3215
- return e.addEventListener("keydown", r), () => e.removeEventListener("keydown", r);
3216
- }, [l, h, A]), q(() => {
3217
- const e = o.current;
3215
+ return e.addEventListener("keydown", i), () => e.removeEventListener("keydown", i);
3216
+ }, [r, d, y]), L(() => {
3217
+ const e = m.current;
3218
3218
  if (!e) return;
3219
- const r = () => {
3219
+ const i = () => {
3220
3220
  setTimeout(() => {
3221
- const b = e.shadowRoot;
3222
- if (!b) return;
3223
- const y = b.querySelector(".ML__caret") || b.querySelector('[class*="caret"]');
3224
- y && y.scrollIntoView({ behavior: "auto", block: "nearest", inline: "nearest" }), A();
3221
+ const p = e.shadowRoot;
3222
+ if (!p) return;
3223
+ const C = p.querySelector(".ML__caret") || p.querySelector('[class*="caret"]');
3224
+ C && C.scrollIntoView({ behavior: "auto", block: "nearest", inline: "nearest" }), y();
3225
3225
  }, 0);
3226
3226
  };
3227
- return e.addEventListener("selection-change", r), e.addEventListener("input", r), e.addEventListener("keydown", r), setTimeout(A, 50), () => {
3228
- e.removeEventListener("selection-change", r), e.removeEventListener("input", r), e.removeEventListener("keydown", r);
3227
+ return e.addEventListener("selection-change", i), e.addEventListener("input", i), e.addEventListener("keydown", i), setTimeout(y, 50), () => {
3228
+ e.removeEventListener("selection-change", i), e.removeEventListener("input", i), e.removeEventListener("keydown", i);
3229
3229
  };
3230
- }, [A]);
3231
- const k = H((e) => {
3232
- const r = o.current;
3233
- r && (r.focus(), r.executeCommand(["insert", e]));
3234
- }, []), B = H((e, r, b) => {
3235
- let y = `\\begin{${e}} `;
3236
- for (let f = 0; f < r; f++) {
3237
- for (let v = 0; v < b; v++)
3238
- y += "#?", v < b - 1 && (y += " & ");
3239
- f < r - 1 && (y += " \\\\ ");
3230
+ }, [y]);
3231
+ const S = H((e) => {
3232
+ const i = m.current;
3233
+ i && (i.focus(), i.executeCommand(["insert", e]));
3234
+ }, []), E = H((e, i, p) => {
3235
+ let C = `\\begin{${e}} `;
3236
+ for (let w = 0; w < i; w++) {
3237
+ for (let k = 0; k < p; k++)
3238
+ C += "#?", k < p - 1 && (C += " & ");
3239
+ w < i - 1 && (C += " \\\\ ");
3240
3240
  }
3241
- y += ` \\end{${e}}`, k(y);
3242
- }, [k]), D = () => {
3243
- const e = o.current;
3241
+ C += ` \\end{${e}}`, S(C);
3242
+ }, [S]), P = () => {
3243
+ const e = m.current;
3244
3244
  if (!e) return;
3245
- let r = e.getValue ? e.getValue() : e.value;
3246
- if (!r || r.trim() === "") {
3247
- c();
3245
+ let i = e.getValue ? e.getValue() : e.value;
3246
+ if (!i || i.trim() === "") {
3247
+ b();
3248
3248
  return;
3249
3249
  }
3250
- l === "chem" && (r = Ze(r)), t(r), e.setValue ? e.setValue("") : e.value = "", c();
3250
+ r === "chem" && (i = Ze(i)), t(i), e.setValue ? e.setValue("") : e.value = "", b();
3251
3251
  };
3252
- return /* @__PURE__ */ React.createElement("div", { className: "cme-editor-popup", onMouseDown: (e) => e.stopPropagation() }, /* @__PURE__ */ React.createElement("div", { className: "cme-popup-header" }, /* @__PURE__ */ React.createElement("span", null, i ? l === "math" ? "Edit Math Formula" : "Edit Chemistry Formula" : l === "math" ? "Math Editor" : "Chemistry Editor"), /* @__PURE__ */ React.createElement("button", { type: "button", className: "cme-popup-close", onClick: c }, "×")), /* @__PURE__ */ React.createElement("div", { className: "cme-toolbar", role: "toolbar", "aria-label": "Symbol palette" }, /* @__PURE__ */ React.createElement("div", { className: "cme-toolbar-groups" }, E.map((e, r) => {
3253
- const b = a === r, y = r === E.length - 1;
3254
- return /* @__PURE__ */ React.createElement(
3252
+ return /* @__PURE__ */ l.createElement("div", { className: "cme-editor-popup", onMouseDown: (e) => e.stopPropagation() }, /* @__PURE__ */ l.createElement("div", { className: "cme-popup-header" }, /* @__PURE__ */ l.createElement("span", null, a ? r === "math" ? "Edit Math Formula" : "Edit Chemistry Formula" : r === "math" ? "Math Editor" : "Chemistry Editor"), /* @__PURE__ */ l.createElement("button", { type: "button", className: "cme-popup-close", onClick: b }, "×")), /* @__PURE__ */ l.createElement("div", { className: "cme-toolbar", role: "toolbar", "aria-label": "Symbol palette" }, /* @__PURE__ */ l.createElement("div", { className: "cme-toolbar-groups" }, D.map((e, i) => {
3253
+ const p = n === i, C = i === D.length - 1;
3254
+ return /* @__PURE__ */ l.createElement(
3255
3255
  "button",
3256
3256
  {
3257
3257
  key: e.isMatrix ? "matrix-tab" : e.label,
3258
- className: `cme-group-tab${b ? " active" : ""}`,
3259
- style: !b && y ? { backgroundColor: "#DC9E9E" } : {},
3258
+ className: `cme-group-tab${p ? " active" : ""}`,
3259
+ style: !p && C ? { backgroundColor: "#DC9E9E" } : {},
3260
3260
  type: "button",
3261
- onMouseDown: (f) => {
3262
- f.preventDefault(), s(r), S(null);
3261
+ onMouseDown: (w) => {
3262
+ w.preventDefault(), o(i), x(null);
3263
3263
  }
3264
3264
  },
3265
- e.mathLabel ? /* @__PURE__ */ React.createElement(
3265
+ e.mathLabel ? /* @__PURE__ */ l.createElement(
3266
3266
  "math-field",
3267
3267
  {
3268
3268
  "read-only": !0,
@@ -3279,64 +3279,64 @@ function _e({ mode: l, onInsert: t, onClose: c, initialLatex: n, isEditing: i })
3279
3279
  padding: "0",
3280
3280
  margin: "0",
3281
3281
  boxShadow: "none",
3282
- color: b ? "#333333" : "#ffffff"
3282
+ color: p ? "#333333" : "#ffffff"
3283
3283
  }
3284
3284
  },
3285
3285
  e.mathLabel
3286
3286
  ) : e.label
3287
3287
  );
3288
- })), /* @__PURE__ */ React.createElement("div", { className: "cme-toolbar-items" }, (() => {
3289
- var y;
3290
- const e = ((y = E[a]) == null ? void 0 : y.items) || [], r = e.some((f) => f.type === "sep"), b = [];
3291
- if (r) {
3292
- let f = { cols: 2, small: !1, cls: "", items: [], moreItems: null };
3293
- for (const v of e)
3294
- v.type === "sep" ? (f.items.length > 0 && b.push(f), f = { cols: v.cols || 2, small: !!v.small, cls: v.cls || "", items: [], moreItems: v.moreItems || null, moreCols: v.moreCols || 1 }) : f.items.push(v);
3295
- f.items.length > 0 && b.push(f);
3288
+ })), /* @__PURE__ */ l.createElement("div", { className: "cme-toolbar-items" }, (() => {
3289
+ var C;
3290
+ const e = ((C = D[n]) == null ? void 0 : C.items) || [], i = e.some((w) => w.type === "sep"), p = [];
3291
+ if (i) {
3292
+ let w = { cols: 2, small: !1, cls: "", items: [], moreItems: null };
3293
+ for (const k of e)
3294
+ k.type === "sep" ? (w.items.length > 0 && p.push(w), w = { cols: k.cols || 2, small: !!k.small, cls: k.cls || "", items: [], moreItems: k.moreItems || null, moreCols: k.moreCols || 1 }) : w.items.push(k);
3295
+ w.items.length > 0 && p.push(w);
3296
3296
  } else
3297
- for (let v = 0; v < e.length; v += 4)
3298
- b.push({
3297
+ for (let k = 0; k < e.length; k += 4)
3298
+ p.push({
3299
3299
  cols: 2,
3300
3300
  small: !1,
3301
3301
  cls: "",
3302
- items: e.slice(v, v + 4)
3302
+ items: e.slice(k, k + 4)
3303
3303
  });
3304
- return b.map((f, v) => /* @__PURE__ */ React.createElement(
3304
+ return p.map((w, k) => /* @__PURE__ */ l.createElement(
3305
3305
  "div",
3306
3306
  {
3307
- key: v,
3308
- className: `cme-symbol-subgroup${f.small ? " cme-symbol-subgroup--small" : ""}${f.cls ? ` ${f.cls}` : ""}${f.moreItems ? " cme-subgroup-has-more" : ""}`,
3309
- style: { gridTemplateColumns: `repeat(${f.cols}, auto)`, position: "relative" }
3307
+ key: k,
3308
+ className: `cme-symbol-subgroup${w.small ? " cme-symbol-subgroup--small" : ""}${w.cls ? ` ${w.cls}` : ""}${w.moreItems ? " cme-subgroup-has-more" : ""}`,
3309
+ style: { gridTemplateColumns: `repeat(${w.cols}, auto)`, position: "relative" }
3310
3310
  },
3311
- f.moreItems && /* @__PURE__ */ React.createElement(
3311
+ w.moreItems && /* @__PURE__ */ l.createElement(
3312
3312
  "button",
3313
3313
  {
3314
3314
  type: "button",
3315
3315
  className: "cme-more-trigger-btn",
3316
3316
  title: "more",
3317
- onMouseDown: (d) => {
3318
- if (d.preventDefault(), p && p.items === f.moreItems)
3319
- w(null);
3317
+ onMouseDown: (g) => {
3318
+ if (g.preventDefault(), u && u.items === w.moreItems)
3319
+ A(null);
3320
3320
  else {
3321
- const L = d.currentTarget.getBoundingClientRect();
3322
- w({ cx: L.left + L.width / 2, y: L.bottom, items: f.moreItems, cols: f.moreCols, isTemplate: E[a].isTemplate || E[a].label === "√(□)" || E[a].isMatrix });
3321
+ const I = g.currentTarget.getBoundingClientRect();
3322
+ A({ cx: I.left + I.width / 2, y: I.bottom, items: w.moreItems, cols: w.moreCols, isTemplate: D[n].isTemplate || D[n].label === "√(□)" || D[n].isMatrix });
3323
3323
  }
3324
3324
  }
3325
3325
  },
3326
3326
  "▶"
3327
3327
  ),
3328
- f.items.map((d, L) => {
3329
- const I = E[a];
3330
- if (d.type === "dropdown") {
3331
- const N = d.label === "Font...", P = d.label === "Size", F = N && h.fontFamily !== "none", Q = P && h.fontSize !== "auto" && h.fontSize !== "5", M = N ? h.fontFamily === "none" ? "" : h.fontFamily : P ? h.fontSize === "auto" || h.fontSize === "5" ? "" : h.fontSize : "";
3332
- return /* @__PURE__ */ React.createElement(
3328
+ w.items.map((g, I) => {
3329
+ const R = D[n];
3330
+ if (g.type === "dropdown") {
3331
+ const q = g.label === "Font...", T = g.label === "Size", F = q && d.fontFamily !== "none", Q = T && d.fontSize !== "auto" && d.fontSize !== "5", M = q ? d.fontFamily === "none" ? "" : d.fontFamily : T ? d.fontSize === "auto" || d.fontSize === "5" ? "" : d.fontSize : "";
3332
+ return /* @__PURE__ */ l.createElement(
3333
3333
  "select",
3334
3334
  {
3335
- key: L,
3335
+ key: I,
3336
3336
  className: `cme-btn template${F || Q ? " active" : ""}`,
3337
3337
  value: M,
3338
3338
  style: {
3339
- width: d.width || "60px",
3339
+ width: g.width || "60px",
3340
3340
  height: "18px",
3341
3341
  minHeight: "18px",
3342
3342
  maxHeight: "18px",
@@ -3346,45 +3346,45 @@ function _e({ mode: l, onInsert: t, onClose: c, initialLatex: n, isEditing: i })
3346
3346
  fontSize: "10px",
3347
3347
  padding: "0",
3348
3348
  margin: "2px 0",
3349
- gridColumn: f.cols === 3 || f.cols === 1 ? "span 1" : "span 2"
3349
+ gridColumn: w.cols === 3 || w.cols === 1 ? "span 1" : "span 2"
3350
3350
  },
3351
3351
  onChange: (de) => {
3352
- const X = de.target.value, U = o.current;
3353
- !U || typeof U.applyStyle != "function" || (U.focus(), N ? U.applyStyle({ fontFamily: X || "none" }) : P && U.applyStyle({ fontSize: X ? parseInt(X, 10) : "auto" }), A());
3352
+ const X = de.target.value, U = m.current;
3353
+ !U || typeof U.applyStyle != "function" || (U.focus(), q ? U.applyStyle({ fontFamily: X || "none" }) : T && U.applyStyle({ fontSize: X ? parseInt(X, 10) : "auto" }), y());
3354
3354
  }
3355
3355
  },
3356
- /* @__PURE__ */ React.createElement("option", { value: "" }, d.label),
3357
- N && /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement("option", { value: "roman" }, "Times"), /* @__PURE__ */ React.createElement("option", { value: "sans-serif" }, "Helvetica"), /* @__PURE__ */ React.createElement("option", { value: "monospace" }, "Courier")),
3358
- P && /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement("option", { value: "5" }, "12px"), /* @__PURE__ */ React.createElement("option", { value: "7" }, "16px"), /* @__PURE__ */ React.createElement("option", { value: "9" }, "20px"))
3356
+ /* @__PURE__ */ l.createElement("option", { value: "" }, g.label),
3357
+ q && /* @__PURE__ */ l.createElement(l.Fragment, null, /* @__PURE__ */ l.createElement("option", { value: "roman" }, "Times"), /* @__PURE__ */ l.createElement("option", { value: "sans-serif" }, "Helvetica"), /* @__PURE__ */ l.createElement("option", { value: "monospace" }, "Courier")),
3358
+ T && /* @__PURE__ */ l.createElement(l.Fragment, null, /* @__PURE__ */ l.createElement("option", { value: "5" }, "12px"), /* @__PURE__ */ l.createElement("option", { value: "7" }, "16px"), /* @__PURE__ */ l.createElement("option", { value: "9" }, "20px"))
3359
3359
  );
3360
3360
  }
3361
- if (I.isMatrix && !d.directInsert)
3362
- return /* @__PURE__ */ React.createElement(
3361
+ if (R.isMatrix && !g.directInsert)
3362
+ return /* @__PURE__ */ l.createElement(
3363
3363
  "div",
3364
3364
  {
3365
- key: L,
3365
+ key: I,
3366
3366
  className: "cme-matrix-btn-wrapper"
3367
3367
  },
3368
- /* @__PURE__ */ React.createElement(
3368
+ /* @__PURE__ */ l.createElement(
3369
3369
  "button",
3370
3370
  {
3371
3371
  type: "button",
3372
- className: `cme-btn template${d.cls ? ` ${d.cls}` : ""}${I.isMatrix ? " cme-matrix-btn-small" : ""}`,
3373
- title: d.insert,
3374
- onMouseDown: (N) => {
3375
- if (N.preventDefault(), N.stopPropagation(), (m == null ? void 0 : m.type) === d.insert)
3376
- S(null);
3372
+ className: `cme-btn template${g.cls ? ` ${g.cls}` : ""}${R.isMatrix ? " cme-matrix-btn-small" : ""}`,
3373
+ title: g.insert,
3374
+ onMouseDown: (q) => {
3375
+ if (q.preventDefault(), q.stopPropagation(), (c == null ? void 0 : c.type) === g.insert)
3376
+ x(null);
3377
3377
  else {
3378
- const P = N.currentTarget.getBoundingClientRect();
3379
- S({
3380
- type: d.insert,
3381
- x: P.left + P.width / 2,
3382
- y: P.bottom
3378
+ const T = q.currentTarget.getBoundingClientRect();
3379
+ x({
3380
+ type: g.insert,
3381
+ x: T.left + T.width / 2,
3382
+ y: T.bottom
3383
3383
  });
3384
3384
  }
3385
3385
  }
3386
3386
  },
3387
- /* @__PURE__ */ React.createElement(
3387
+ /* @__PURE__ */ l.createElement(
3388
3388
  "math-field",
3389
3389
  {
3390
3390
  "read-only": !0,
@@ -3403,37 +3403,37 @@ function _e({ mode: l, onInsert: t, onClose: c, initialLatex: n, isEditing: i })
3403
3403
  cursor: "pointer"
3404
3404
  }
3405
3405
  },
3406
- K(d.mathLabel != null ? d.mathLabel : d.insert)
3406
+ K(g.mathLabel != null ? g.mathLabel : g.insert)
3407
3407
  )
3408
3408
  )
3409
3409
  );
3410
- const be = d.action === "BOLD", pe = d.action === "ITALIC", ue = d.action === "TEXT_COLOR", he = be && h.bold || pe && h.italic || ue && h.color !== "none" && h.color !== "black";
3411
- return /* @__PURE__ */ React.createElement(
3410
+ const be = g.action === "BOLD", pe = g.action === "ITALIC", ue = g.action === "TEXT_COLOR", he = be && d.bold || pe && d.italic || ue && d.color !== "none" && d.color !== "black";
3411
+ return /* @__PURE__ */ l.createElement(
3412
3412
  "button",
3413
3413
  {
3414
- key: `${I.label}-${v * 4 + L}`,
3414
+ key: `${R.label}-${k * 4 + I}`,
3415
3415
  type: "button",
3416
- className: `cme-btn${I.isTemplate ? " template" : ""}${d.cls ? ` ${d.cls}` : ""}${he ? " active" : ""}`,
3417
- title: d.title || d.label || d.insert,
3418
- onMouseDown: (N) => {
3416
+ className: `cme-btn${R.isTemplate ? " template" : ""}${g.cls ? ` ${g.cls}` : ""}${he ? " active" : ""}`,
3417
+ title: g.title || g.label || g.insert,
3418
+ onMouseDown: (q) => {
3419
3419
  var F, Q;
3420
- N.preventDefault();
3421
- const P = o.current;
3422
- if (d.action === "SPECIAL_CHARS") {
3423
- const M = N.currentTarget.getBoundingClientRect();
3424
- x({ x: M.left, y: M.bottom + 4 });
3425
- } else if (d.action === "TEXT_COLOR") {
3426
- const M = N.currentTarget.getBoundingClientRect();
3427
- C({ x: M.left, y: M.bottom + 4 });
3428
- } else d.action === "BOLD" ? P && typeof P.applyStyle == "function" && (P.focus(), P.applyStyle({
3429
- variantStyle: h.bold ? "" : "bold",
3430
- fontSeries: h.bold ? "auto" : "b"
3431
- }), A()) : d.action === "ITALIC" ? P && typeof P.applyStyle == "function" && (P.focus(), P.applyStyle({
3432
- variantStyle: h.italic ? "" : "italic"
3433
- }), A()) : d.action === "UNDO" ? (F = o.current) == null || F.executeCommand("undo") : d.action === "REDO" ? (Q = o.current) == null || Q.executeCommand("redo") : k(d.insert);
3420
+ q.preventDefault();
3421
+ const T = m.current;
3422
+ if (g.action === "SPECIAL_CHARS") {
3423
+ const M = q.currentTarget.getBoundingClientRect();
3424
+ B({ x: M.left, y: M.bottom + 4 });
3425
+ } else if (g.action === "TEXT_COLOR") {
3426
+ const M = q.currentTarget.getBoundingClientRect();
3427
+ v({ x: M.left, y: M.bottom + 4 });
3428
+ } else g.action === "BOLD" ? T && typeof T.applyStyle == "function" && (T.focus(), T.applyStyle({
3429
+ variantStyle: d.bold ? "" : "bold",
3430
+ fontSeries: d.bold ? "auto" : "b"
3431
+ }), y()) : g.action === "ITALIC" ? T && typeof T.applyStyle == "function" && (T.focus(), T.applyStyle({
3432
+ variantStyle: d.italic ? "" : "italic"
3433
+ }), y()) : g.action === "UNDO" ? (F = m.current) == null || F.executeCommand("undo") : g.action === "REDO" ? (Q = m.current) == null || Q.executeCommand("redo") : S(g.insert);
3434
3434
  }
3435
3435
  },
3436
- (I.isTemplate || I.label === "√(□)" || I.isMatrix || d.isWidget) && d.insert && !d.action ? /* @__PURE__ */ React.createElement(
3436
+ (R.isTemplate || R.label === "√(□)" || R.isMatrix || g.isWidget) && g.insert && !g.action ? /* @__PURE__ */ l.createElement(
3437
3437
  "math-field",
3438
3438
  {
3439
3439
  "read-only": !0,
@@ -3452,48 +3452,48 @@ function _e({ mode: l, onInsert: t, onClose: c, initialLatex: n, isEditing: i })
3452
3452
  cursor: "pointer"
3453
3453
  }
3454
3454
  },
3455
- K(d.insert)
3456
- ) : d.label
3455
+ K(g.insert)
3456
+ ) : g.label
3457
3457
  );
3458
3458
  })
3459
3459
  ));
3460
- })())), p && /* @__PURE__ */ React.createElement(
3460
+ })())), u && /* @__PURE__ */ l.createElement(
3461
3461
  "div",
3462
3462
  {
3463
3463
  ref: (e) => {
3464
3464
  if (e) {
3465
- const r = e.getBoundingClientRect(), b = document.querySelector(".cme-editor-popup");
3466
- let y = p.cx - r.width / 2, f = p.y;
3467
- if (b) {
3468
- const v = b.getBoundingClientRect();
3469
- y < v.left + 4 && (y = v.left + 4), y + r.width > v.right - 4 && (y = v.right - r.width - 4), f + r.height > v.bottom - 4 && (f = v.bottom - r.height - 4);
3465
+ const i = e.getBoundingClientRect(), p = document.querySelector(".cme-editor-popup");
3466
+ let C = u.cx - i.width / 2, w = u.y;
3467
+ if (p) {
3468
+ const k = p.getBoundingClientRect();
3469
+ C < k.left + 4 && (C = k.left + 4), C + i.width > k.right - 4 && (C = k.right - i.width - 4), w + i.height > k.bottom - 4 && (w = k.bottom - i.height - 4);
3470
3470
  }
3471
- f + r.height > window.innerHeight - 4 && (f = window.innerHeight - r.height - 4), e.style.left = `${y}px`, e.style.top = `${f}px`, e.style.transform = "none", e.style.visibility = "visible";
3471
+ w + i.height > window.innerHeight - 4 && (w = window.innerHeight - i.height - 4), e.style.left = `${C}px`, e.style.top = `${w}px`, e.style.transform = "none", e.style.visibility = "visible";
3472
3472
  }
3473
3473
  },
3474
3474
  className: "cme-more-popup",
3475
3475
  style: {
3476
3476
  position: "fixed",
3477
- left: `${p.cx}px`,
3478
- top: `${p.y}px`,
3477
+ left: `${u.cx}px`,
3478
+ top: `${u.y}px`,
3479
3479
  transform: "translateX(-50%)",
3480
3480
  visibility: "hidden",
3481
3481
  zIndex: 1e5,
3482
- gridTemplateColumns: `repeat(${p.cols || 1}, auto)`
3482
+ gridTemplateColumns: `repeat(${u.cols || 1}, auto)`
3483
3483
  }
3484
3484
  },
3485
- p.items.map((e, r) => /* @__PURE__ */ React.createElement(
3485
+ u.items.map((e, i) => /* @__PURE__ */ l.createElement(
3486
3486
  "button",
3487
3487
  {
3488
- key: r,
3488
+ key: i,
3489
3489
  type: "button",
3490
3490
  className: `cme-more-popup-btn ${e.cls || ""}`,
3491
3491
  title: e.title || e.label || e.insert,
3492
- onMouseDown: (b) => {
3493
- b.preventDefault(), k(e.insert), w(null);
3492
+ onMouseDown: (p) => {
3493
+ p.preventDefault(), S(e.insert), A(null);
3494
3494
  }
3495
3495
  },
3496
- p.isTemplate && e.insert && !e.action && e.isWidget ? /* @__PURE__ */ React.createElement(
3496
+ u.isTemplate && e.insert && !e.action && e.isWidget ? /* @__PURE__ */ l.createElement(
3497
3497
  "math-field",
3498
3498
  {
3499
3499
  "read-only": !0,
@@ -3515,63 +3515,63 @@ function _e({ mode: l, onInsert: t, onClose: c, initialLatex: n, isEditing: i })
3515
3515
  K(e.mathLabel != null ? e.mathLabel : e.insert)
3516
3516
  ) : e.label
3517
3517
  ))
3518
- ), /* @__PURE__ */ React.createElement(
3518
+ ), /* @__PURE__ */ l.createElement(
3519
3519
  "div",
3520
3520
  {
3521
3521
  className: "cme-mathfield-container",
3522
3522
  onMouseDown: (e) => {
3523
- o.current && (e.target === o.current || o.current.contains(e.target)) || (e.preventDefault(), requestAnimationFrame(() => {
3524
- var r, b;
3525
- (b = (r = o.current) == null ? void 0 : r.focus) == null || b.call(r);
3523
+ m.current && (e.target === m.current || m.current.contains(e.target)) || (e.preventDefault(), requestAnimationFrame(() => {
3524
+ var i, p;
3525
+ (p = (i = m.current) == null ? void 0 : i.focus) == null || p.call(i);
3526
3526
  }));
3527
3527
  }
3528
3528
  },
3529
- /* @__PURE__ */ React.createElement(
3529
+ /* @__PURE__ */ l.createElement(
3530
3530
  "math-field",
3531
3531
  {
3532
- ref: o,
3532
+ ref: m,
3533
3533
  class: "cme-mathfield",
3534
3534
  tabIndex: 0,
3535
3535
  "math-virtual-keyboard-policy": "manual",
3536
3536
  placeholder: ""
3537
3537
  }
3538
3538
  )
3539
- ), /* @__PURE__ */ React.createElement("div", { className: "cme-popup-footer" }, /* @__PURE__ */ React.createElement("button", { type: "button", className: "cme-insert-btn", onClick: D }, i ? "Update" : "Insert"), /* @__PURE__ */ React.createElement("button", { type: "button", className: "cme-cancel-btn", onClick: c }, "Cancel")), m && /* @__PURE__ */ React.createElement(
3539
+ ), /* @__PURE__ */ l.createElement("div", { className: "cme-popup-footer" }, /* @__PURE__ */ l.createElement("button", { type: "button", className: "cme-insert-btn", onClick: P }, a ? "Update" : "Insert"), /* @__PURE__ */ l.createElement("button", { type: "button", className: "cme-cancel-btn", onClick: b }, "Cancel")), c && /* @__PURE__ */ l.createElement(
3540
3540
  je,
3541
3541
  {
3542
- matrixType: m.type,
3543
- x: m.x,
3544
- y: m.y,
3545
- onSelect: (e, r) => {
3546
- B(m.type, e, r), S(null);
3542
+ matrixType: c.type,
3543
+ x: c.x,
3544
+ y: c.y,
3545
+ onSelect: (e, i) => {
3546
+ E(c.type, e, i), x(null);
3547
3547
  },
3548
3548
  onMouseEnter: () => {
3549
3549
  },
3550
3550
  onMouseLeave: () => {
3551
3551
  }
3552
3552
  }
3553
- ), g && _(
3554
- /* @__PURE__ */ React.createElement(
3553
+ ), f && _(
3554
+ /* @__PURE__ */ l.createElement(
3555
3555
  Je,
3556
3556
  {
3557
- isOpen: !!g,
3558
- position: g,
3559
- onClose: () => x(null),
3557
+ isOpen: !!f,
3558
+ position: f,
3559
+ onClose: () => B(null),
3560
3560
  onInsert: (e) => {
3561
- k(e), x(null);
3561
+ S(e), B(null);
3562
3562
  }
3563
3563
  }
3564
3564
  ),
3565
3565
  document.body
3566
- ), u && _(
3567
- /* @__PURE__ */ React.createElement(
3566
+ ), h && _(
3567
+ /* @__PURE__ */ l.createElement(
3568
3568
  "div",
3569
3569
  {
3570
3570
  className: "cme-color-picker-popup",
3571
3571
  style: {
3572
3572
  position: "fixed",
3573
- left: Math.min(u.x, window.innerWidth - 160) + "px",
3574
- top: Math.min(u.y, window.innerHeight - 100) + "px",
3573
+ left: Math.min(h.x, window.innerWidth - 160) + "px",
3574
+ top: Math.min(h.y, window.innerHeight - 100) + "px",
3575
3575
  zIndex: 1e5,
3576
3576
  background: "#fff",
3577
3577
  border: "1px solid #ccc",
@@ -3609,8 +3609,8 @@ function _e({ mode: l, onInsert: t, onClose: c, initialLatex: n, isEditing: i })
3609
3609
  "violet",
3610
3610
  "gold"
3611
3611
  ].map((e) => {
3612
- const r = h.color === e || e === "black" && (h.color === "none" || !h.color);
3613
- return /* @__PURE__ */ React.createElement(
3612
+ const i = d.color === e || e === "black" && (d.color === "none" || !d.color);
3613
+ return /* @__PURE__ */ l.createElement(
3614
3614
  "div",
3615
3615
  {
3616
3616
  key: e,
@@ -3620,13 +3620,13 @@ function _e({ mode: l, onInsert: t, onClose: c, initialLatex: n, isEditing: i })
3620
3620
  height: "16px",
3621
3621
  backgroundColor: e,
3622
3622
  cursor: "pointer",
3623
- border: r ? "2px solid #e6c229" : "1px solid #000",
3623
+ border: i ? "2px solid #e6c229" : "1px solid #000",
3624
3624
  boxSizing: "border-box"
3625
3625
  },
3626
- onMouseDown: (b) => {
3627
- b.preventDefault(), b.stopPropagation();
3628
- const y = o.current;
3629
- y && typeof y.applyStyle == "function" && (y.focus(), y.applyStyle({ color: e === "black" ? "none" : e }), A()), C(null);
3626
+ onMouseDown: (p) => {
3627
+ p.preventDefault(), p.stopPropagation();
3628
+ const C = m.current;
3629
+ C && typeof C.applyStyle == "function" && (C.focus(), C.applyStyle({ color: e === "black" ? "none" : e }), y()), v(null);
3630
3630
  }
3631
3631
  }
3632
3632
  );
@@ -3635,11 +3635,11 @@ function _e({ mode: l, onInsert: t, onClose: c, initialLatex: n, isEditing: i })
3635
3635
  document.body
3636
3636
  ));
3637
3637
  }
3638
- function $e(l) {
3639
- let t = l;
3640
- const c = t.match(/^\\ce\{([\s\S]*)\}$/);
3641
- c && (t = c[1]);
3642
- const n = [
3638
+ function $e(r) {
3639
+ let t = r;
3640
+ const b = t.match(/^\\ce\{([\s\S]*)\}$/);
3641
+ b && (t = b[1]);
3642
+ const s = [
3643
3643
  // Greek lowercase
3644
3644
  ["\\varepsilon", "ε"],
3645
3645
  ["\\varphi", "φ"],
@@ -3759,86 +3759,86 @@ function $e(l) {
3759
3759
  ["\\cdots", "⋯"],
3760
3760
  ["\\ldots", "…"]
3761
3761
  ];
3762
- for (const [a, s] of n) {
3763
- const m = a.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
3764
- t = t.replace(new RegExp(m, "g"), s);
3762
+ for (const [n, o] of s) {
3763
+ const c = n.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
3764
+ t = t.replace(new RegExp(c, "g"), o);
3765
3765
  }
3766
3766
  t = t.replace(/\\frac\{([^}]*)\}\{([^}]*)\}/g, "$1/$2"), t = t.replace(/\\sqrt\[([^\]]*)\]\{([^}]*)\}/g, "$1√($2)"), t = t.replace(/\\sqrt\{([^}]*)\}/g, "√($1)"), t = t.replace(/\\vec\{([^}]*)\}/g, "$1⃗"), t = t.replace(/\\hat\{([^}]*)\}/g, "$1̂"), t = t.replace(/\\bar\{([^}]*)\}/g, "$1̄"), t = t.replace(/\\ddot\{([^}]*)\}/g, "$1̈"), t = t.replace(/\\dot\{([^}]*)\}/g, "$1̇"), t = t.replace(/\\text\{([^}]*)\}/g, "$1"), t = t.replace(
3767
3767
  /\\begin\{pmatrix\}([\s\S]*?)\\end\{pmatrix\}/g,
3768
- (a, s) => "[" + s.replace(/\\\\/g, "; ").replace(/&/g, ", ").trim() + "]"
3768
+ (n, o) => "[" + o.replace(/\\\\/g, "; ").replace(/&/g, ", ").trim() + "]"
3769
3769
  );
3770
- const i = { 0: "⁰", 1: "¹", 2: "²", 3: "³", 4: "⁴", 5: "⁵", 6: "⁶", 7: "⁷", 8: "⁸", 9: "⁹", "+": "⁺", "-": "⁻", "=": "⁼", "(": "⁽", ")": "⁾", n: "ⁿ", i: "ⁱ" };
3770
+ const a = { 0: "⁰", 1: "¹", 2: "²", 3: "³", 4: "⁴", 5: "⁵", 6: "⁶", 7: "⁷", 8: "⁸", 9: "⁹", "+": "⁺", "-": "⁻", "=": "⁼", "(": "⁽", ")": "⁾", n: "ⁿ", i: "ⁱ" };
3771
3771
  t = t.replace(
3772
3772
  /\^\{([^}]*)\}/g,
3773
- (a, s) => s.split("").map((m) => i[m] || m).join("")
3774
- ), t = t.replace(/\^([a-zA-Z0-9])/g, (a, s) => i[s] || s);
3775
- const o = { 0: "₀", 1: "₁", 2: "₂", 3: "₃", 4: "₄", 5: "₅", 6: "₆", 7: "₇", 8: "₈", 9: "₉", "+": "₊", "-": "₋", "=": "₌", "(": "₍", ")": "₎", a: "ₐ", e: "ₑ", o: "ₒ", x: "ₓ", i: "ᵢ", j: "ⱼ", n: "ₙ" };
3773
+ (n, o) => o.split("").map((c) => a[c] || c).join("")
3774
+ ), t = t.replace(/\^([a-zA-Z0-9])/g, (n, o) => a[o] || o);
3775
+ const m = { 0: "₀", 1: "₁", 2: "₂", 3: "₃", 4: "₄", 5: "₅", 6: "₆", 7: "₇", 8: "₈", 9: "₉", "+": "₊", "-": "₋", "=": "₌", "(": "₍", ")": "₎", a: "ₐ", e: "ₑ", o: "ₒ", x: "ₓ", i: "ᵢ", j: "ⱼ", n: "ₙ" };
3776
3776
  return t = t.replace(
3777
3777
  /_\{([^}]*)\}/g,
3778
- (a, s) => s.split("").map((m) => o[m] || m).join("")
3779
- ), t = t.replace(/_([a-zA-Z0-9])/g, (a, s) => o[s] || s), t = t.replace(/->/g, "→"), t = t.replace(/<=>/g, "⇌"), t = t.replace(/\\[a-zA-Z]+/g, ""), t = t.replace(/[{}]/g, ""), t = t.replace(/\s+/g, " "), t = t.replace(/\\\\/g, `
3778
+ (n, o) => o.split("").map((c) => m[c] || c).join("")
3779
+ ), t = t.replace(/_([a-zA-Z0-9])/g, (n, o) => m[o] || o), t = t.replace(/->/g, "→"), t = t.replace(/<=>/g, "⇌"), t = t.replace(/\\[a-zA-Z]+/g, ""), t = t.replace(/[{}]/g, ""), t = t.replace(/\s+/g, " "), t = t.replace(/\\\\/g, `
3780
3780
  `), t.trim();
3781
3781
  }
3782
- function mt({ value: l, onChange: t }) {
3783
- const c = W(null), n = W(!1), [i, o] = R(null), [a, s] = R(null);
3784
- q(() => {
3785
- n.current = !!i;
3786
- }, [i]), q(() => () => {
3782
+ function mt({ value: r, onChange: t }) {
3783
+ const b = W(null), s = W(!1), [a, m] = N(null), [n, o] = N(null);
3784
+ L(() => {
3785
+ s.current = !!a;
3786
+ }, [a]), L(() => () => {
3787
3787
  window.__ckMathWidgetClickHandler = null;
3788
3788
  }, []);
3789
- const m = H((A) => {
3790
- s(null), n.current = !0, o(A);
3791
- }, []), S = H(() => {
3792
- n.current = !1, o(null), s(null);
3793
- const A = c.current;
3794
- A && A.model.change((k) => {
3795
- k.setSelection(null);
3789
+ const c = H((y) => {
3790
+ o(null), s.current = !0, m(y);
3791
+ }, []), x = H(() => {
3792
+ s.current = !1, m(null), o(null);
3793
+ const y = b.current;
3794
+ y && y.model.change((S) => {
3795
+ S.setSelection(null);
3796
3796
  });
3797
- }, []), [g, x] = R(!1), [u, C] = R(!1), [p, w] = R(!1), E = H((A) => {
3798
- const k = c.current;
3799
- if (!(!k || !(A != null && A.trim()))) {
3800
- if (a) {
3801
- const B = z(k, a.modelElement) ? a.modelElement : null;
3802
- B ? k.model.change((D) => {
3803
- const e = D.createElement("mathInline", { latex: A.trim() }), r = D.createPositionBefore(B);
3804
- D.insert(e, r), D.remove(B), D.setSelection(D.createPositionAfter(e));
3805
- }) : k.model.change((D) => {
3806
- const e = D.createElement("mathInline", { latex: A.trim() });
3807
- k.model.insertContent(e);
3808
- }), s(null);
3809
- } else if (g) {
3810
- const B = $e(A.trim());
3811
- if (!B) return;
3812
- k.model.change((D) => {
3813
- const e = D.createText(B);
3814
- k.model.insertContent(e);
3797
+ }, []), [f, B] = N(!1), [h, v] = N(!1), [u, A] = N(!1), D = H((y) => {
3798
+ const S = b.current;
3799
+ if (!(!S || !(y != null && y.trim()))) {
3800
+ if (n) {
3801
+ const E = z(S, n.modelElement) ? n.modelElement : null;
3802
+ E ? S.model.change((P) => {
3803
+ const e = P.createElement("mathInline", { latex: y.trim() }), i = P.createPositionBefore(E);
3804
+ P.insert(e, i), P.remove(E), P.setSelection(P.createPositionAfter(e));
3805
+ }) : S.model.change((P) => {
3806
+ const e = P.createElement("mathInline", { latex: y.trim() });
3807
+ S.model.insertContent(e);
3808
+ }), o(null);
3809
+ } else if (f) {
3810
+ const E = $e(y.trim());
3811
+ if (!E) return;
3812
+ S.model.change((P) => {
3813
+ const e = P.createText(E);
3814
+ S.model.insertContent(e);
3815
3815
  });
3816
3816
  } else
3817
- k.model.change((B) => {
3818
- const D = B.createElement("mathInline", { latex: A.trim() });
3819
- k.model.insertContent(D), k.model.insertContent(B.createText(" "));
3817
+ S.model.change((E) => {
3818
+ const P = E.createElement("mathInline", { latex: y.trim() });
3819
+ S.model.insertContent(P), S.model.insertContent(E.createText(" "));
3820
3820
  });
3821
- k.editing.view.focus();
3821
+ S.editing.view.focus();
3822
3822
  }
3823
- }, [g, a]), h = G(() => ze(m), [m]), O = H((A) => {
3824
- c.current = A;
3825
- const k = (e, r) => {
3826
- if (n.current || !r) return;
3827
- const b = /^\\ce\{/.test(r);
3828
- n.current = !0, s({ modelElement: e, latex: r }), o(b ? "chem" : "math");
3823
+ }, [f, n]), d = G(() => ze(c), [c]), O = H((y) => {
3824
+ b.current = y;
3825
+ const S = (e, i) => {
3826
+ if (s.current || !i) return;
3827
+ const p = /^\\ce\{/.test(i);
3828
+ s.current = !0, o({ modelElement: e, latex: i }), m(p ? "chem" : "math");
3829
3829
  };
3830
- A.mathWidgetClickHandler = k, window.__ckMathWidgetClickHandler = k;
3831
- const B = A.ui.getEditableElement();
3832
- if (!B || B._ckMathClickAttached) return;
3833
- B._ckMathClickAttached = !0;
3834
- const D = (e) => {
3835
- var b;
3836
- const r = ce(e.target);
3837
- r && e.button === 0 && (e.preventDefault(), e.stopPropagation(), (b = e.stopImmediatePropagation) == null || b.call(e), j(A, null, J(r), r));
3830
+ y.mathWidgetClickHandler = S, window.__ckMathWidgetClickHandler = S;
3831
+ const E = y.ui.getEditableElement();
3832
+ if (!E || E._ckMathClickAttached) return;
3833
+ E._ckMathClickAttached = !0;
3834
+ const P = (e) => {
3835
+ var p;
3836
+ const i = ce(e.target);
3837
+ i && e.button === 0 && (e.preventDefault(), e.stopPropagation(), (p = e.stopImmediatePropagation) == null || p.call(e), j(y, null, J(i), i));
3838
3838
  };
3839
- B.addEventListener("mousedown", D, !0), B.addEventListener("click", D, !0);
3839
+ E.addEventListener("mousedown", P, !0), E.addEventListener("click", P, !0);
3840
3840
  }, []);
3841
- return /* @__PURE__ */ React.createElement("div", { style: { position: "relative", display: "flex", flexDirection: "column", gap: "8px" } }, /* @__PURE__ */ React.createElement("style", null, `
3841
+ return /* @__PURE__ */ l.createElement("div", { style: { position: "relative", display: "flex", flexDirection: "column", gap: "8px" } }, /* @__PURE__ */ l.createElement("style", null, `
3842
3842
  .ck-powered-by { display: none !important; }
3843
3843
  .ck-math-widget {
3844
3844
  display: inline-block !important;
@@ -3864,19 +3864,19 @@ function mt({ value: l, onChange: t }) {
3864
3864
  }
3865
3865
  .ck-math-widget:hover,
3866
3866
  .ck-math-widget.ck-widget_selected { outline: 2px solid #0f766e; outline-offset: 1px; border-radius: 4px; }
3867
- `), /* @__PURE__ */ React.createElement("div", { style: { display: "flex", alignItems: "center", gap: "8px", padding: "2px 4px" } }, /* @__PURE__ */ React.createElement("label", { style: { display: "inline-flex", flexDirection: "row", alignItems: "center", gap: "8px", cursor: "pointer", userSelect: "none", width: "auto", fontSize: "13px", color: "var(--text)", fontWeight: 600 } }, /* @__PURE__ */ React.createElement(
3867
+ `), /* @__PURE__ */ l.createElement("div", { style: { display: "flex", alignItems: "center", gap: "8px", padding: "2px 4px" } }, /* @__PURE__ */ l.createElement("label", { style: { display: "inline-flex", flexDirection: "row", alignItems: "center", gap: "8px", cursor: "pointer", userSelect: "none", width: "auto", fontSize: "13px", color: "var(--text)", fontWeight: 600 } }, /* @__PURE__ */ l.createElement(
3868
3868
  "input",
3869
3869
  {
3870
3870
  type: "checkbox",
3871
- checked: g,
3872
- onChange: (A) => x(A.target.checked),
3871
+ checked: f,
3872
+ onChange: (y) => B(y.target.checked),
3873
3873
  style: { width: "16px", minHeight: "16px", cursor: "pointer", margin: 0 }
3874
3874
  }
3875
- ), /* @__PURE__ */ React.createElement("span", null, "Insert as editable Unicode text (allows character-by-character deletion)"))), /* @__PURE__ */ React.createElement("div", { style: { marginTop: "10px", marginBottom: "10px" } }, /* @__PURE__ */ React.createElement(
3875
+ ), /* @__PURE__ */ l.createElement("span", null, "Insert as editable Unicode text (allows character-by-character deletion)"))), /* @__PURE__ */ l.createElement("div", { style: { marginTop: "10px", marginBottom: "10px" } }, /* @__PURE__ */ l.createElement(
3876
3876
  "button",
3877
3877
  {
3878
3878
  type: "button",
3879
- onClick: () => w(!0),
3879
+ onClick: () => A(!0),
3880
3880
  style: {
3881
3881
  padding: "6px 12px",
3882
3882
  backgroundColor: "#0f766e",
@@ -3889,7 +3889,7 @@ function mt({ value: l, onChange: t }) {
3889
3889
  }
3890
3890
  },
3891
3891
  "Preview Question"
3892
- )), p && /* @__PURE__ */ React.createElement("div", { style: {
3892
+ )), u && /* @__PURE__ */ l.createElement("div", { style: {
3893
3893
  position: "fixed",
3894
3894
  top: 0,
3895
3895
  left: 0,
@@ -3900,7 +3900,7 @@ function mt({ value: l, onChange: t }) {
3900
3900
  justifyContent: "center",
3901
3901
  alignItems: "center",
3902
3902
  zIndex: 1e4
3903
- } }, /* @__PURE__ */ React.createElement("div", { style: {
3903
+ } }, /* @__PURE__ */ l.createElement("div", { style: {
3904
3904
  background: "white",
3905
3905
  padding: "20px",
3906
3906
  borderRadius: "8px",
@@ -3911,25 +3911,25 @@ function mt({ value: l, onChange: t }) {
3911
3911
  boxShadow: "0 4px 12px rgba(0,0,0,0.15)",
3912
3912
  display: "flex",
3913
3913
  flexDirection: "column"
3914
- } }, /* @__PURE__ */ React.createElement("div", { style: { display: "flex", justifyContent: "space-between", alignItems: "center", borderBottom: "1px solid #ccc", paddingBottom: "10px", marginBottom: "20px" } }, /* @__PURE__ */ React.createElement("h3", { style: { margin: 0 } }, "Question Preview"), /* @__PURE__ */ React.createElement(
3914
+ } }, /* @__PURE__ */ l.createElement("div", { style: { display: "flex", justifyContent: "space-between", alignItems: "center", borderBottom: "1px solid #ccc", paddingBottom: "10px", marginBottom: "20px" } }, /* @__PURE__ */ l.createElement("h3", { style: { margin: 0 } }, "Question Preview"), /* @__PURE__ */ l.createElement(
3915
3915
  "button",
3916
3916
  {
3917
- onClick: () => w(!1),
3917
+ onClick: () => A(!1),
3918
3918
  style: { background: "transparent", border: "none", fontSize: "20px", cursor: "pointer" }
3919
3919
  },
3920
3920
  "×"
3921
- )), /* @__PURE__ */ React.createElement("div", { style: { fontSize: "16px", lineHeight: "1.6" } }, /* @__PURE__ */ React.createElement(Oe, { value: l })), /* @__PURE__ */ React.createElement("div", { style: { marginTop: "30px", textAlign: "right" } }, /* @__PURE__ */ React.createElement(
3921
+ )), /* @__PURE__ */ l.createElement("div", { style: { fontSize: "16px", lineHeight: "1.6" } }, /* @__PURE__ */ l.createElement(Oe, { value: r })), /* @__PURE__ */ l.createElement("div", { style: { marginTop: "30px", textAlign: "right" } }, /* @__PURE__ */ l.createElement(
3922
3922
  "button",
3923
3923
  {
3924
- onClick: () => w(!1),
3924
+ onClick: () => A(!1),
3925
3925
  style: { padding: "8px 16px", backgroundColor: "#e2e8f0", border: "none", borderRadius: "4px", cursor: "pointer" }
3926
3926
  },
3927
3927
  "Close"
3928
- )))), /* @__PURE__ */ React.createElement(
3928
+ )))), /* @__PURE__ */ l.createElement(
3929
3929
  ge,
3930
3930
  {
3931
- editor: Re,
3932
- data: l,
3931
+ editor: Te,
3932
+ data: r,
3933
3933
  onReady: O,
3934
3934
  config: {
3935
3935
  licenseKey: "GPL",
@@ -3948,7 +3948,7 @@ function mt({ value: l, onChange: t }) {
3948
3948
  De,
3949
3949
  Pe,
3950
3950
  Ke,
3951
- h
3951
+ d
3952
3952
  ],
3953
3953
  toolbar: {
3954
3954
  items: [
@@ -3982,18 +3982,18 @@ function mt({ value: l, onChange: t }) {
3982
3982
  ]
3983
3983
  }
3984
3984
  },
3985
- onChange: (A, k) => {
3986
- t && t(k.getData());
3985
+ onChange: (y, S) => {
3986
+ t && t(S.getData());
3987
3987
  }
3988
3988
  }
3989
- ), i && /* @__PURE__ */ React.createElement(
3989
+ ), a && /* @__PURE__ */ l.createElement(
3990
3990
  _e,
3991
3991
  {
3992
- mode: i,
3993
- onInsert: E,
3994
- onClose: S,
3995
- initialLatex: (a == null ? void 0 : a.latex) || "",
3996
- isEditing: !!a
3992
+ mode: a,
3993
+ onInsert: D,
3994
+ onClose: x,
3995
+ initialLatex: (n == null ? void 0 : n.latex) || "",
3996
+ isEditing: !!n
3997
3997
  }
3998
3998
  ));
3999
3999
  }