my-anees-package 1.0.15 → 1.0.16

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,19 +1,19 @@
1
1
  import e, { useRef as F, useEffect as R, useState as I, useMemo as te, useCallback as q } from "react";
2
2
  import { createPortal as K } from "react-dom";
3
3
  import { FontAwesomeIcon as Y } from "@fortawesome/react-fontawesome";
4
- import { faBold as ce, faItalic as he } from "@fortawesome/free-solid-svg-icons";
5
- import { CKEditor as fe } from "@ckeditor/ckeditor5-react";
6
- import "mathlive";
7
- import { Essentials as ve, Bold as Me, Italic as Ae, Underline as Ce, Paragraph as Le, Heading as Se, Table as Te, TableToolbar as We, TableCellProperties as Ie, TableProperties as Be, List as De, Link as Ne, Undo as Re, ClassicEditor as He, Plugin as me, ButtonView as ie, Widget as Oe, toWidget as Ue } from "ckeditor5";
4
+ import { faBold as de, faItalic as pe } from "@fortawesome/free-solid-svg-icons";
5
+ import { CKEditor as Ae } from "@ckeditor/ckeditor5-react";
6
+ import { MathfieldElement as ae } from "mathlive";
7
+ import { Essentials as Ce, Bold as Le, Italic as Se, Underline as Te, Paragraph as We, Heading as Ie, Table as Be, TableToolbar as De, TableCellProperties as Ne, TableProperties as Re, List as He, Link as Oe, Undo as Ue, ClassicEditor as Ve, Plugin as be, ButtonView as oe, Widget as Pe, toWidget as qe } from "ckeditor5";
8
8
  import "ckeditor5/ckeditor5.css";
9
- const de = "data:image/png;base64,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", pe = "data:image/png;base64,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", ne = "data-mathfield-shadow-styles";
9
+ const ge = "data:image/png;base64,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", ke = "data:image/png;base64,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", se = "data-mathfield-shadow-styles";
10
10
  function G(r) {
11
11
  const l = r == null ? void 0 : r.shadowRoot;
12
12
  if (!l) return;
13
- const m = r.hasAttribute("read-only") || r.hasAttribute("readonly"), o = m ? "readonly" : "editable";
14
- let i = l.querySelector(`[${ne}]`);
15
- i && i.getAttribute("data-cache") === o || (i || (i = document.createElement("style"), i.setAttribute(ne, "true"), l.appendChild(i)), i.setAttribute("data-cache", o), i.textContent = `
16
- ${m ? `
13
+ const c = r.hasAttribute("read-only") || r.hasAttribute("readonly"), a = c ? "readonly" : "editable";
14
+ let i = l.querySelector(`[${se}]`);
15
+ i && i.getAttribute("data-cache") === a || (i || (i = document.createElement("style"), i.setAttribute(se, "true"), l.appendChild(i)), i.setAttribute("data-cache", a), i.textContent = `
16
+ ${c ? `
17
17
  :host, :host * { cursor: pointer !important; }
18
18
  .ML__latex, .ML__content, .ML__container, .ML__virtual-keyboard-toggle { cursor: pointer !important; }
19
19
  ` : ""}
@@ -31,13 +31,13 @@ function G(r) {
31
31
  }
32
32
  `);
33
33
  }
34
- function Ve() {
34
+ function Fe() {
35
35
  document.querySelectorAll("math-field").forEach(G);
36
36
  }
37
37
  let $ = null;
38
- function Pe() {
39
- $ || (Ve(), $ = new MutationObserver((r) => {
40
- var l, m, o;
38
+ function Ze() {
39
+ $ || (Fe(), $ = new MutationObserver((r) => {
40
+ var l, c, a;
41
41
  for (const i of r) {
42
42
  if (i.type === "attributes" && ((l = i.target.tagName) == null ? void 0 : l.toLowerCase()) === "math-field") {
43
43
  G(i.target);
@@ -45,7 +45,7 @@ function Pe() {
45
45
  }
46
46
  if (i.addedNodes)
47
47
  for (const s of i.addedNodes)
48
- s instanceof Element && (((m = s.tagName) == null ? void 0 : m.toLowerCase()) === "math-field" && requestAnimationFrame(() => G(s)), (o = s.querySelectorAll) == null || o.call(s, "math-field").forEach((a) => requestAnimationFrame(() => G(a))));
48
+ s instanceof Element && (((c = s.tagName) == null ? void 0 : c.toLowerCase()) === "math-field" && requestAnimationFrame(() => G(s)), (a = s.querySelectorAll) == null || a.call(s, "math-field").forEach((n) => requestAnimationFrame(() => G(n))));
49
49
  }
50
50
  }), $.observe(document.body, {
51
51
  childList: !0,
@@ -54,11 +54,11 @@ function Pe() {
54
54
  attributeFilter: ["read-only", "readonly"]
55
55
  }));
56
56
  }
57
- const qe = "§MATH§", Fe = "§END§";
58
- function ae(r) {
57
+ const Je = "§MATH§", je = "§END§";
58
+ function ce(r) {
59
59
  return r.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
60
60
  }
61
- function oe(r) {
61
+ function he(r) {
62
62
  const l = document.createElement("math-field");
63
63
  return l.setAttribute("read-only", ""), l.setAttribute(
64
64
  "style",
@@ -78,11 +78,11 @@ function oe(r) {
78
78
  l.setValue ? l.setValue(r) : l.value = r;
79
79
  }), l;
80
80
  }
81
- function se(r, l) {
81
+ function me(r, l) {
82
82
  if (!l) return;
83
- const m = document.createElement("div");
84
- m.innerHTML = l;
85
- const o = /* @__PURE__ */ new Set([
83
+ const c = document.createElement("div");
84
+ c.innerHTML = l;
85
+ const a = /* @__PURE__ */ new Set([
86
86
  "B",
87
87
  "STRONG",
88
88
  "I",
@@ -113,55 +113,55 @@ function se(r, l) {
113
113
  "FIGCAPTION",
114
114
  "COLGROUP",
115
115
  "COL"
116
- ]), i = (a, n) => {
117
- Array.from(a.childNodes).forEach((h) => {
118
- if (h.nodeType === Node.TEXT_NODE)
119
- n.appendChild(document.createTextNode(h.textContent));
120
- else if (h.nodeType === Node.ELEMENT_NODE) {
121
- const M = h.nodeName;
116
+ ]), i = (n, o) => {
117
+ Array.from(n.childNodes).forEach((m) => {
118
+ if (m.nodeType === Node.TEXT_NODE)
119
+ o.appendChild(document.createTextNode(m.textContent));
120
+ else if (m.nodeType === Node.ELEMENT_NODE) {
121
+ const M = m.nodeName;
122
122
  if (M === "MATH-FIELD")
123
- n.appendChild(h.cloneNode(!0));
123
+ o.appendChild(m.cloneNode(!0));
124
124
  else if (M === "BR")
125
- n.appendChild(document.createElement("br"));
126
- else if (M === "SPAN" && h.classList.contains("math-tex")) {
125
+ o.appendChild(document.createElement("br"));
126
+ else if (M === "SPAN" && m.classList.contains("math-tex")) {
127
127
  const u = document.createElement("span");
128
- u.className = "math-tex", h.getAttribute("data-latex") && u.setAttribute("data-latex", h.getAttribute("data-latex")), u.textContent = h.textContent, n.appendChild(u);
129
- } else if (o.has(M)) {
128
+ u.className = "math-tex", m.getAttribute("data-latex") && u.setAttribute("data-latex", m.getAttribute("data-latex")), u.textContent = m.textContent, o.appendChild(u);
129
+ } else if (a.has(M)) {
130
130
  const u = { STRONG: "b", EM: "i" }, S = document.createElement(u[M] || M.toLowerCase());
131
- M === "A" && h.getAttribute("href") && (S.setAttribute("href", h.getAttribute("href")), S.setAttribute("target", "_blank"), S.setAttribute("rel", "noopener noreferrer")), ["style", "class", "colspan", "rowspan"].forEach((x) => {
132
- h.getAttribute(x) && S.setAttribute(x, h.getAttribute(x));
133
- }), i(h, S), n.appendChild(S);
131
+ M === "A" && m.getAttribute("href") && (S.setAttribute("href", m.getAttribute("href")), S.setAttribute("target", "_blank"), S.setAttribute("rel", "noopener noreferrer")), ["style", "class", "colspan", "rowspan"].forEach((x) => {
132
+ m.getAttribute(x) && S.setAttribute(x, m.getAttribute(x));
133
+ }), i(m, S), o.appendChild(S);
134
134
  } else
135
- i(h, n);
135
+ i(m, o);
136
136
  }
137
137
  });
138
138
  }, s = document.createElement("span");
139
- for (i(m, s); s.firstChild; ) r.appendChild(s.firstChild);
139
+ for (i(c, s); s.firstChild; ) r.appendChild(s.firstChild);
140
140
  }
141
- function Ze({ value: r = "" }) {
141
+ function Qe({ value: r = "" }) {
142
142
  const l = F(null);
143
143
  return R(() => {
144
- const m = l.current;
145
- if (!m) return;
146
- m.innerHTML = "";
147
- const o = new RegExp(
148
- ae(qe) + "([\\s\\S]*?)" + ae(Fe),
144
+ const c = l.current;
145
+ if (!c) return;
146
+ c.innerHTML = "";
147
+ const a = new RegExp(
148
+ ce(Je) + "([\\s\\S]*?)" + ce(je),
149
149
  "g"
150
150
  );
151
151
  let i = 0, s;
152
- for (; (s = o.exec(r)) !== null; ) {
152
+ for (; (s = a.exec(r)) !== null; ) {
153
153
  if (s.index > i) {
154
- const n = r.slice(i, s.index);
155
- se(m, n);
154
+ const o = r.slice(i, s.index);
155
+ me(c, o);
156
156
  }
157
- const a = s[1];
158
- m.appendChild(oe(a)), i = s.index + s[0].length;
157
+ const n = s[1];
158
+ c.appendChild(he(n)), i = s.index + s[0].length;
159
159
  }
160
- i < r.length && se(m, r.slice(i)), m.querySelectorAll("span.math-tex").forEach((a) => {
161
- const n = a.getAttribute("data-latex") || a.textContent || "";
162
- if (n) {
163
- const h = oe(n);
164
- a.replaceWith(h);
160
+ i < r.length && me(c, r.slice(i)), c.querySelectorAll("span.math-tex").forEach((n) => {
161
+ const o = n.getAttribute("data-latex") || n.textContent || "";
162
+ if (o) {
163
+ const m = he(o);
164
+ n.replaceWith(m);
165
165
  }
166
166
  });
167
167
  }, [r]), /* @__PURE__ */ e.createElement(
@@ -172,7 +172,7 @@ function Ze({ value: r = "" }) {
172
172
  }
173
173
  );
174
174
  }
175
- const be = [
175
+ const ue = [
176
176
  { id: "All", name: "All" },
177
177
  { id: "Symbol", name: "Symbol", ranges: [[8704, 8959], [9728, 9983], [8592, 8703], [9984, 10175]] },
178
178
  { id: "Punctuation", name: "Punctuation", ranges: [[33, 47], [58, 64], [91, 96], [123, 126], [8208, 8231], [8240, 8286]] },
@@ -181,45 +181,45 @@ const be = [
181
181
  { id: "Number", name: "Number", ranges: [[48, 57], [8528, 8591], [8304, 8351]] },
182
182
  { id: "Phonetic", name: "Phonetic", ranges: [[592, 687], [7424, 7551]] },
183
183
  { id: "Other", name: "Other", ranges: [[8352, 8399], [8448, 8527], [9632, 9727]] }
184
- ], Je = () => {
184
+ ], ze = () => {
185
185
  const r = [];
186
- return be.slice(1).forEach((l) => {
187
- l.ranges.forEach((m) => {
188
- for (let o = m[0]; o <= m[1]; o++)
189
- o >= 127 && o <= 159 || r.push({
190
- code: o.toString(16).toUpperCase().padStart(4, "0"),
191
- char: String.fromCodePoint(o),
186
+ return ue.slice(1).forEach((l) => {
187
+ l.ranges.forEach((c) => {
188
+ for (let a = c[0]; a <= c[1]; a++)
189
+ a >= 127 && a <= 159 || r.push({
190
+ code: a.toString(16).toUpperCase().padStart(4, "0"),
191
+ char: String.fromCodePoint(a),
192
192
  category: l.id
193
193
  });
194
194
  });
195
195
  }), r;
196
- }, je = Je();
197
- function Qe({ isOpen: r, onClose: l, onInsert: m, position: o }) {
198
- const [i, s] = I(""), [a, n] = I("All");
196
+ }, Xe = ze();
197
+ function Ke({ isOpen: r, onClose: l, onInsert: c, position: a }) {
198
+ const [i, s] = I(""), [n, o] = I("All");
199
199
  R(() => {
200
- r && (s(""), n("All"));
200
+ r && (s(""), o("All"));
201
201
  }, [r]);
202
- const h = te(() => {
203
- let k = je;
204
- if (a !== "All" && (k = k.filter((x) => x.category === a)), i.trim()) {
202
+ const m = te(() => {
203
+ let k = Xe;
204
+ if (n !== "All" && (k = k.filter((x) => x.category === n)), i.trim()) {
205
205
  const x = i.trim().toUpperCase();
206
206
  k = k.filter((g) => g.code.includes(x));
207
207
  }
208
208
  return k;
209
- }, [a, i]), M = te(() => {
210
- if (a !== "All" && !i.trim())
211
- return { [a]: h };
209
+ }, [n, i]), M = te(() => {
210
+ if (n !== "All" && !i.trim())
211
+ return { [n]: m };
212
212
  const k = {};
213
- return h.forEach((x) => {
213
+ return m.forEach((x) => {
214
214
  k[x.category] || (k[x.category] = []), k[x.category].push(x);
215
215
  }), k;
216
- }, [h, a, i]), u = (k) => {
216
+ }, [m, n, i]), u = (k) => {
217
217
  k.key === "Escape" && l();
218
218
  };
219
219
  if (R(() => (r && window.addEventListener("keydown", u), () => window.removeEventListener("keydown", u)), [r]), !r) return null;
220
220
  let S = { top: "50%", left: "50%", transform: "translate(-50%, -50%)" };
221
- if (o) {
222
- let k = o.x - 120, x = o.y;
221
+ if (a) {
222
+ let k = a.x - 120, x = a.y;
223
223
  k < 10 && (k = 10), k + 230 > window.innerWidth && (k = window.innerWidth - 240), x + 200 > window.innerHeight && (x = window.innerHeight - 210), S = { top: `${x}px`, left: `${k}px` };
224
224
  }
225
225
  return /* @__PURE__ */ e.createElement("div", { className: "scm-overlay", onMouseDown: (k) => {
@@ -236,43 +236,64 @@ function Qe({ isOpen: r, onClose: l, onInsert: m, position: o }) {
236
236
  ), /* @__PURE__ */ e.createElement(
237
237
  "select",
238
238
  {
239
- value: a,
240
- onChange: (k) => n(k.target.value),
239
+ value: n,
240
+ onChange: (k) => o(k.target.value),
241
241
  className: "scm-category-select"
242
242
  },
243
- be.map((k) => /* @__PURE__ */ e.createElement("option", { key: k.id, value: k.id }, k.name))
243
+ ue.map((k) => /* @__PURE__ */ e.createElement("option", { key: k.id, value: k.id }, k.name))
244
244
  )), /* @__PURE__ */ e.createElement("div", { className: "scm-body" }, /* @__PURE__ */ e.createElement("div", { className: "scm-grid-container" }, Object.entries(M).map(([k, x]) => /* @__PURE__ */ e.createElement("div", { key: k, className: "scm-category-group" }, /* @__PURE__ */ e.createElement("div", { className: "scm-char-grid" }, x.map((g) => /* @__PURE__ */ e.createElement(
245
245
  "button",
246
246
  {
247
247
  key: g.code,
248
248
  className: "scm-char-btn",
249
249
  onClick: () => {
250
- m(g.char), l();
250
+ c(g.char), l();
251
251
  },
252
252
  title: `U+${g.code}`
253
253
  },
254
254
  g.char
255
- ))))), h.length === 0 && /* @__PURE__ */ e.createElement("div", { className: "scm-no-results" }, "No characters found.")))));
255
+ ))))), m.length === 0 && /* @__PURE__ */ e.createElement("div", { className: "scm-no-results" }, "No characters found.")))));
256
256
  }
257
+ typeof window < "u" && (window.MathfieldElement ? window.MathfieldElement.fontsDirectory = "https://cdn.jsdelivr.net/npm/mathlive/dist/fonts" : ae && (ae.fontsDirectory = "https://cdn.jsdelivr.net/npm/mathlive/dist/fonts"));
257
258
  window.__ckMathWidgets = window.__ckMathWidgets || /* @__PURE__ */ new Map();
258
259
  window.__ckMathWidgetClickHandler = null;
259
- function ge(r) {
260
- var m, o, i, s, a;
260
+ function ye(r) {
261
+ var c, a, i, s, n;
261
262
  if (!r) return null;
262
263
  const l = typeof r.composedPath == "function" ? r.composedPath() : [r];
263
- for (const n of l)
264
- if (n instanceof HTMLElement && ((m = n.classList) != null && m.contains("ck-math-widget") || (o = n.dataset) != null && o.mathId || (i = n.classList) != null && i.contains("ck-widget") && ((s = n.querySelector) != null && s.call(n, ".ck-math-widget-inner"))))
265
- return n;
266
- return r instanceof Element ? (a = r.closest) == null ? void 0 : a.call(r, ".ck-math-widget, [data-math-id]") : null;
264
+ for (const o of l)
265
+ if (o instanceof HTMLElement && ((c = o.classList) != null && c.contains("ck-math-widget") || (a = o.dataset) != null && a.mathId || (i = o.classList) != null && i.contains("ck-widget") && ((s = o.querySelector) != null && s.call(o, ".ck-math-widget-inner"))))
266
+ return o;
267
+ return r instanceof Element ? (n = r.closest) == null ? void 0 : n.call(r, ".ck-math-widget, [data-math-id]") : null;
268
+ }
269
+ function le(r) {
270
+ let l = "", c = 0;
271
+ const a = "\\text{";
272
+ for (; c < r.length; ) {
273
+ const i = r.indexOf(a, c);
274
+ if (i === -1) {
275
+ l += r.slice(c);
276
+ break;
277
+ }
278
+ l += r.slice(c, i);
279
+ let s = 1, n = i + a.length;
280
+ for (; n < r.length && s > 0; )
281
+ r[n] === "{" ? s++ : r[n] === "}" && s--, n++;
282
+ l += r.slice(i + a.length, n - 1), c = n;
283
+ }
284
+ return l;
285
+ }
286
+ function re(r) {
287
+ return r.replace(/\\enclose\{([^}]*)\}\[.*?\]/g, "\\enclose{$1}");
267
288
  }
268
289
  function Q(r) {
269
290
  if (!r) return "";
270
291
  const l = r.getAttribute("data-latex");
271
292
  if (l) return l;
272
- const m = r.querySelector("math-field");
273
- return m ? m.getValue ? m.getValue() : m.value || "" : "";
293
+ const c = r.querySelector("math-field");
294
+ return c ? c.getValue ? c.getValue() : c.value || "" : "";
274
295
  }
275
- function le(r, l) {
296
+ function ie(r, l) {
276
297
  if (!r || !l) return !1;
277
298
  try {
278
299
  return r.model.createPositionBefore(l), !0;
@@ -280,52 +301,52 @@ function le(r, l) {
280
301
  return !1;
281
302
  }
282
303
  }
283
- function ze(r, l) {
284
- var n;
304
+ function Ge(r, l) {
305
+ var o;
285
306
  if (!r || !l) return null;
286
- const m = r.model.document.selection.getSelectedElement();
287
- if ((m == null ? void 0 : m.name) === "mathInline") return m;
288
- const o = l.getAttribute("data-math-id");
289
- if (o) {
290
- const h = window.__ckMathWidgets.get(o);
291
- if (le(r, h)) return h;
307
+ const c = r.model.document.selection.getSelectedElement();
308
+ if ((c == null ? void 0 : c.name) === "mathInline") return c;
309
+ const a = l.getAttribute("data-math-id");
310
+ if (a) {
311
+ const m = window.__ckMathWidgets.get(a);
312
+ if (ie(r, m)) return m;
292
313
  }
293
314
  const i = r.editing.view.domConverter.mapDomToView(l);
294
315
  if (i) {
295
- const h = r.editing.mapper.toModelElement(i);
296
- if ((h == null ? void 0 : h.name) === "mathInline") return h;
316
+ const m = r.editing.mapper.toModelElement(i);
317
+ if ((m == null ? void 0 : m.name) === "mathInline") return m;
297
318
  }
298
319
  const s = Q(l);
299
320
  if (!s) return null;
300
- const a = r.model.document.getRoot();
301
- for (const { item: h } of r.model.createRangeIn(a))
302
- if ((n = h.is) != null && n.call(h, "element", "mathInline") && h.getAttribute("latex") === s)
303
- return h;
321
+ const n = r.model.document.getRoot();
322
+ for (const { item: m } of r.model.createRangeIn(n))
323
+ if ((o = m.is) != null && o.call(m, "element", "mathInline") && m.getAttribute("latex") === s)
324
+ return m;
304
325
  return null;
305
326
  }
306
- function re(r, l, m, o) {
327
+ function ne(r, l, c, a) {
307
328
  if (!r || r._mathWidgetOpening) return;
308
329
  r._mathWidgetOpening = !0, queueMicrotask(() => {
309
330
  r._mathWidgetOpening = !1;
310
331
  });
311
- const i = le(r, l) ? l : ze(r, o), s = (i == null ? void 0 : i.getAttribute("latex")) || m || Q(o);
332
+ const i = ie(r, l) ? l : Ge(r, a), s = (i == null ? void 0 : i.getAttribute("latex")) || c || Q(a);
312
333
  if (!s) return;
313
- i && r.model.change((n) => {
314
- n.setSelection(i, "on");
334
+ i && r.model.change((o) => {
335
+ o.setSelection(i, "on");
315
336
  });
316
- const a = r.mathWidgetClickHandler || window.__ckMathWidgetClickHandler;
317
- a == null || a(i, s);
337
+ const n = r.mathWidgetClickHandler || window.__ckMathWidgetClickHandler;
338
+ n == null || n(i, s);
318
339
  }
319
- function Xe(r, l) {
340
+ function Ye(r, l) {
320
341
  if (!l || l._ckMathClickBound) return;
321
342
  l._ckMathClickBound = !0;
322
- const m = (o) => {
343
+ const c = (a) => {
323
344
  var i;
324
- o.button === 0 && (o.preventDefault(), o.stopPropagation(), (i = o.stopImmediatePropagation) == null || i.call(o), re(r, null, Q(l), l));
345
+ a.button === 0 && (a.preventDefault(), a.stopPropagation(), (i = a.stopImmediatePropagation) == null || i.call(a), ne(r, null, Q(l), l));
325
346
  };
326
- l.addEventListener("mousedown", m, !0), l.addEventListener("click", m, !0);
347
+ l.addEventListener("mousedown", c, !0), l.addEventListener("click", c, !0);
327
348
  }
328
- const Ke = [
349
+ const _e = [
329
350
  {
330
351
  label: "√(□)",
331
352
  fontSize: "9px",
@@ -381,13 +402,13 @@ const Ke = [
381
402
  { label: "↷", action: "REDO", title: "Redo" },
382
403
  { type: "sep", cols: 2 },
383
404
  // 7. Formatting Group (2 cols)
384
- { label: /* @__PURE__ */ e.createElement(Y, { icon: ce }), action: "BOLD", cls: "template", title: "Bold" },
385
- { label: /* @__PURE__ */ e.createElement(Y, { icon: he }), action: "ITALIC", cls: "template", title: "Italic" },
405
+ { label: /* @__PURE__ */ e.createElement(Y, { icon: de }), action: "BOLD", cls: "template", title: "Bold" },
406
+ { label: /* @__PURE__ */ e.createElement(Y, { icon: pe }), action: "ITALIC", cls: "template", title: "Italic" },
386
407
  {
387
408
  label: /* @__PURE__ */ e.createElement(
388
409
  "img",
389
410
  {
390
- src: de,
411
+ src: ge,
391
412
  alt: "Omega",
392
413
  width: "18",
393
414
  height: "18",
@@ -401,7 +422,7 @@ const Ke = [
401
422
  label: /* @__PURE__ */ e.createElement(
402
423
  "img",
403
424
  {
404
- src: pe,
425
+ src: ke,
405
426
  alt: "Palette",
406
427
  width: "18",
407
428
  height: "18",
@@ -1756,7 +1777,7 @@ const Ke = [
1756
1777
  // { type: 'sep', cols: 2, cls: 'cme-trig-subgroup' }
1757
1778
  // ]
1758
1779
  // },
1759
- ], Ge = [
1780
+ ], $e = [
1760
1781
  {
1761
1782
  label: "H₂O",
1762
1783
  isChem: !0,
@@ -1977,13 +1998,13 @@ const Ke = [
1977
1998
  { label: "↷", action: "REDO", title: "Redo" },
1978
1999
  { type: "sep", cols: 2 },
1979
2000
  // 7. Formatting Group (2 cols)
1980
- { label: /* @__PURE__ */ e.createElement(Y, { icon: ce }), action: "BOLD", cls: "template", title: "Bold" },
1981
- { label: /* @__PURE__ */ e.createElement(Y, { icon: he }), action: "ITALIC", cls: "template", title: "Italic" },
2001
+ { label: /* @__PURE__ */ e.createElement(Y, { icon: de }), action: "BOLD", cls: "template", title: "Bold" },
2002
+ { label: /* @__PURE__ */ e.createElement(Y, { icon: pe }), action: "ITALIC", cls: "template", title: "Italic" },
1982
2003
  {
1983
2004
  label: /* @__PURE__ */ e.createElement(
1984
2005
  "img",
1985
2006
  {
1986
- src: de,
2007
+ src: ge,
1987
2008
  alt: "Omega",
1988
2009
  width: "18",
1989
2010
  height: "18",
@@ -1997,7 +2018,7 @@ const Ke = [
1997
2018
  label: /* @__PURE__ */ e.createElement(
1998
2019
  "img",
1999
2020
  {
2000
- src: pe,
2021
+ src: ke,
2001
2022
  alt: "Palette",
2002
2023
  width: "18",
2003
2024
  height: "18",
@@ -3353,20 +3374,20 @@ const Ke = [
3353
3374
  // ]
3354
3375
  // },
3355
3376
  ];
3356
- function Ye(r = "") {
3377
+ function et(r = "") {
3357
3378
  if (String(r).match(/^\\ce\{([\s\S]*)\}$/)) return r;
3358
- const m = r.replace(/\\text\{([^}]*)\}/g, "$1").replace(/\$/g, "").trim();
3359
- return m ? `\\ce{${m}}` : "";
3379
+ const c = r.replace(/\\text\{([^}]*)\}/g, "$1").replace(/\$/g, "").trim();
3380
+ return c ? `\\ce{${c}}` : "";
3360
3381
  }
3361
3382
  function ee(r) {
3362
3383
  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{}");
3363
3384
  }
3364
- class _e extends me {
3385
+ class tt extends be {
3365
3386
  static get pluginName() {
3366
3387
  return "MathInlinePlugin";
3367
3388
  }
3368
3389
  static get requires() {
3369
- return [Oe];
3390
+ return [Pe];
3370
3391
  }
3371
3392
  init() {
3372
3393
  const l = this.editor;
@@ -3375,20 +3396,20 @@ class _e extends me {
3375
3396
  isObject: !0,
3376
3397
  allowWhere: "$text",
3377
3398
  allowAttributes: ["latex"]
3378
- }), l.model.schema.addChildCheck((o, i) => {
3399
+ }), l.model.schema.addChildCheck((a, i) => {
3379
3400
  if (i.name === "mathInline")
3380
3401
  return !0;
3381
3402
  }), l.conversion.for("editingDowncast").elementToElement({
3382
3403
  model: "mathInline",
3383
- view: (o, { writer: i }) => {
3384
- const s = o.getAttribute("latex") || "", a = "math-" + Math.random().toString(36).substr(2, 9);
3385
- window.__ckMathWidgets.set(a, o);
3386
- const n = i.createContainerElement("span", {
3404
+ view: (a, { writer: i }) => {
3405
+ const s = a.getAttribute("latex") || "", n = "math-" + Math.random().toString(36).substr(2, 9);
3406
+ window.__ckMathWidgets.set(n, a);
3407
+ const o = i.createContainerElement("span", {
3387
3408
  class: "ck-math-widget ck-math-inline-word",
3388
3409
  contenteditable: "false",
3389
- "data-math-id": a,
3410
+ "data-math-id": n,
3390
3411
  "data-latex": s
3391
- }), h = i.createRawElement(
3412
+ }), m = i.createRawElement(
3392
3413
  "span",
3393
3414
  {
3394
3415
  class: "ck-math-widget-inner",
@@ -3398,24 +3419,28 @@ class _e extends me {
3398
3419
  const u = document.createElement("math-field");
3399
3420
  u.setAttribute("read-only", ""), u.setAttribute("math-virtual-keyboard-policy", "manual"), u.setAttribute("tabindex", "-1"), u.style.display = "inline-block", u.style.width = "auto", u.style.maxWidth = "100%", u.style.verticalAlign = "middle", u.style.border = "none", u.style.background = "transparent", u.style.outline = "none", u.style.fontSize = "inherit", u.style.minHeight = "auto", u.style.padding = "0 2px", u.style.margin = "0", u.style.pointerEvents = "none";
3400
3421
  const S = () => {
3401
- let x = s.replace(/\\placeholder\{[^}]*\}/g, "\\quad ").replace(/\\text\{([^}]*)\}/g, "$1");
3422
+ let x = re(
3423
+ le(
3424
+ s.replace(/\\placeholder\{[^}]*\}/g, "\\quad ")
3425
+ )
3426
+ );
3402
3427
  x.includes("\\enclose") && /^\\ce\{[\s\S]*\}$/i.test(x.trim()) && (x = x.trim().replace(/^\\ce\{([\s\S]*)\}$/i, "$1")), u.setValue ? u.setValue(x, { silenceNotifications: !0 }) : u.value = x;
3403
3428
  };
3404
3429
  customElements.get("math-field") ? requestAnimationFrame(S) : customElements.whenDefined("math-field").then(() => requestAnimationFrame(S)), M.appendChild(u);
3405
3430
  const k = () => {
3406
3431
  const x = M.parentElement;
3407
- x && Xe(l, x);
3432
+ x && Ye(l, x);
3408
3433
  };
3409
3434
  k(), requestAnimationFrame(k);
3410
3435
  }
3411
3436
  );
3412
- return i.insert(i.createPositionAt(n, 0), h), Ue(n, i, { label: "math formula" });
3437
+ return i.insert(i.createPositionAt(o, 0), m), qe(o, i, { label: "math formula" });
3413
3438
  }
3414
3439
  });
3415
- const m = l.editing.view.document;
3416
- this.listenTo(m, "mousedown", (o, i) => {
3417
- const s = ge(i.domTarget);
3418
- s && i.domEvent.button === 0 && (o.stop(), i.preventDefault(), re(
3440
+ const c = l.editing.view.document;
3441
+ this.listenTo(c, "mousedown", (a, i) => {
3442
+ const s = ye(i.domTarget);
3443
+ s && i.domEvent.button === 0 && (a.stop(), i.preventDefault(), ne(
3419
3444
  l,
3420
3445
  null,
3421
3446
  Q(s),
@@ -3423,93 +3448,97 @@ class _e extends me {
3423
3448
  ));
3424
3449
  }, { priority: "high" }), l.conversion.for("dataDowncast").elementToElement({
3425
3450
  model: "mathInline",
3426
- view: (o, { writer: i }) => {
3427
- const s = o.getAttribute("latex") || "", a = i.createContainerElement("span", {
3451
+ view: (a, { writer: i }) => {
3452
+ const s = a.getAttribute("latex") || "", n = i.createContainerElement("span", {
3428
3453
  class: "math-tex",
3429
3454
  "data-latex": s,
3430
3455
  // Keep raw latex in data-latex for restoring
3431
3456
  style: "display:inline;"
3432
3457
  });
3433
- let n = s.replace(/\\placeholder\{[^}]*\}/g, "\\quad ").replace(/\\text\{([^}]*)\}/g, "$1");
3434
- return n.includes("\\enclose") && /^\\ce\{[\s\S]*\}$/i.test(n.trim()) && (n = n.trim().replace(/^\\ce\{([\s\S]*)\}$/i, "$1")), i.insert(i.createPositionAt(a, 0), i.createText(n)), a;
3458
+ let o = re(
3459
+ le(
3460
+ s.replace(/\\placeholder\{[^}]*\}/g, "\\quad ")
3461
+ )
3462
+ );
3463
+ return o.includes("\\enclose") && /^\\ce\{[\s\S]*\}$/i.test(o.trim()) && (o = o.trim().replace(/^\\ce\{([\s\S]*)\}$/i, "$1")), i.insert(i.createPositionAt(n, 0), i.createText(o)), n;
3435
3464
  }
3436
3465
  }), l.conversion.for("upcast").elementToElement({
3437
3466
  view: {
3438
3467
  name: "span",
3439
3468
  classes: "math-tex"
3440
3469
  },
3441
- model: (o, { writer: i }) => {
3442
- const s = o.getAttribute("data-latex") || "";
3470
+ model: (a, { writer: i }) => {
3471
+ const s = a.getAttribute("data-latex") || "";
3443
3472
  return i.createElement("mathInline", { latex: s });
3444
3473
  }
3445
3474
  });
3446
3475
  }
3447
3476
  }
3448
- const $e = '<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>', et = '<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>';
3449
- function tt(r) {
3450
- return class extends me {
3477
+ const lt = '<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>', rt = '<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>';
3478
+ function it(r) {
3479
+ return class extends be {
3451
3480
  init() {
3452
- const m = this.editor;
3453
- m.ui.componentFactory.add("mathType", () => {
3454
- const o = new ie();
3455
- return o.set({ label: "Math", icon: $e, tooltip: "Insert Math Formula" }), o.on("execute", () => r("math")), o;
3456
- }), m.ui.componentFactory.add("chemType", () => {
3457
- const o = new ie();
3458
- return o.set({ label: "Chemistry", icon: et, tooltip: "Insert Chemistry Formula" }), o.on("execute", () => r("chem")), o;
3481
+ const c = this.editor;
3482
+ c.ui.componentFactory.add("mathType", () => {
3483
+ const a = new oe();
3484
+ return a.set({ label: "Math", icon: lt, tooltip: "Insert Math Formula" }), a.on("execute", () => r("math")), a;
3485
+ }), c.ui.componentFactory.add("chemType", () => {
3486
+ const a = new oe();
3487
+ return a.set({ label: "Chemistry", icon: rt, tooltip: "Insert Chemistry Formula" }), a.on("execute", () => r("chem")), a;
3459
3488
  });
3460
3489
  }
3461
3490
  };
3462
3491
  }
3463
- function lt({ matrixType: r, x: l, y: m, onSelect: o, onMouseEnter: i, onMouseLeave: s }) {
3464
- const [a, n] = I({ r: 2, c: 2 }), h = Math.max(10, parseInt(a.r, 10) || 0), M = Math.max(10, parseInt(a.c, 10) || 0), u = (g) => {
3492
+ function nt({ matrixType: r, x: l, y: c, onSelect: a, onMouseEnter: i, onMouseLeave: s }) {
3493
+ const [n, o] = I({ r: 2, c: 2 }), m = Math.max(10, parseInt(n.r, 10) || 0), M = Math.max(10, parseInt(n.c, 10) || 0), u = (g) => {
3465
3494
  const w = g.target.value;
3466
3495
  if (w === "") {
3467
- n((T) => ({ ...T, r: "" }));
3496
+ o((T) => ({ ...T, r: "" }));
3468
3497
  return;
3469
3498
  }
3470
3499
  const B = parseInt(w, 10);
3471
- isNaN(B) || n((T) => ({ ...T, r: Math.max(1, Math.min(10, B)) }));
3500
+ isNaN(B) || o((T) => ({ ...T, r: Math.max(1, Math.min(10, B)) }));
3472
3501
  }, S = () => {
3473
- (a.r === "" || isNaN(parseInt(a.r, 10))) && n((g) => ({ ...g, r: 1 }));
3502
+ (n.r === "" || isNaN(parseInt(n.r, 10))) && o((g) => ({ ...g, r: 1 }));
3474
3503
  }, k = (g) => {
3475
3504
  const w = g.target.value;
3476
3505
  if (w === "") {
3477
- n((T) => ({ ...T, c: "" }));
3506
+ o((T) => ({ ...T, c: "" }));
3478
3507
  return;
3479
3508
  }
3480
3509
  const B = parseInt(w, 10);
3481
- isNaN(B) || n((T) => ({ ...T, c: Math.max(1, Math.min(10, B)) }));
3510
+ isNaN(B) || o((T) => ({ ...T, c: Math.max(1, Math.min(10, B)) }));
3482
3511
  }, x = () => {
3483
- (a.c === "" || isNaN(parseInt(a.c, 10))) && n((g) => ({ ...g, c: 1 }));
3512
+ (n.c === "" || isNaN(parseInt(n.c, 10))) && o((g) => ({ ...g, c: 1 }));
3484
3513
  };
3485
3514
  return R(() => {
3486
3515
  const g = (w) => {
3487
3516
  if (w.key === "Enter") {
3488
3517
  w.preventDefault(), w.stopPropagation();
3489
- const B = parseInt(a.r, 10) || 1, T = parseInt(a.c, 10) || 1;
3490
- o(B, T);
3518
+ const B = parseInt(n.r, 10) || 1, T = parseInt(n.c, 10) || 1;
3519
+ a(B, T);
3491
3520
  }
3492
3521
  };
3493
3522
  return window.addEventListener("keydown", g, !0), () => window.removeEventListener("keydown", g, !0);
3494
- }, [a.r, a.c, o]), /* @__PURE__ */ e.createElement(
3523
+ }, [n.r, n.c, a]), /* @__PURE__ */ e.createElement(
3495
3524
  "div",
3496
3525
  {
3497
3526
  className: "cme-matrix-hover-popover ck-only",
3498
- style: { top: `${m}px`, left: `${l}px` },
3527
+ style: { top: `${c}px`, left: `${l}px` },
3499
3528
  onMouseDown: (g) => g.stopPropagation(),
3500
3529
  onMouseEnter: i,
3501
3530
  onMouseLeave: s
3502
3531
  },
3503
- /* @__PURE__ */ e.createElement("div", { className: "cme-matrix-hover-grid" }, Array.from({ length: h }).map((g, w) => /* @__PURE__ */ e.createElement("div", { key: w, className: "cme-matrix-hover-row" }, Array.from({ length: M }).map((B, T) => {
3504
- const U = parseInt(a.r, 10) || 0, A = parseInt(a.c, 10) || 0, L = w < U && T < A;
3532
+ /* @__PURE__ */ e.createElement("div", { className: "cme-matrix-hover-grid" }, Array.from({ length: m }).map((g, w) => /* @__PURE__ */ e.createElement("div", { key: w, className: "cme-matrix-hover-row" }, Array.from({ length: M }).map((B, T) => {
3533
+ const U = parseInt(n.r, 10) || 0, A = parseInt(n.c, 10) || 0, L = w < U && T < A;
3505
3534
  return /* @__PURE__ */ e.createElement(
3506
3535
  "div",
3507
3536
  {
3508
3537
  key: `${w}-${T}`,
3509
3538
  className: `cme-matrix-hover-cell${L ? " selected" : ""}`,
3510
- onMouseEnter: () => n({ r: w + 1, c: T + 1 }),
3539
+ onMouseEnter: () => o({ r: w + 1, c: T + 1 }),
3511
3540
  onClick: (C) => {
3512
- C.preventDefault(), C.stopPropagation(), o(w + 1, T + 1);
3541
+ C.preventDefault(), C.stopPropagation(), a(w + 1, T + 1);
3513
3542
  }
3514
3543
  }
3515
3544
  );
@@ -3519,16 +3548,16 @@ function lt({ matrixType: r, x: l, y: m, onSelect: o, onMouseEnter: i, onMouseLe
3519
3548
  {
3520
3549
  type: "number",
3521
3550
  className: "cme-counter-val",
3522
- value: a.r,
3551
+ value: n.r,
3523
3552
  onChange: u,
3524
3553
  onBlur: S,
3525
3554
  min: "1",
3526
3555
  max: "10"
3527
3556
  }
3528
- ), /* @__PURE__ */ e.createElement("div", { className: "cme-counter-btns" }, /* @__PURE__ */ e.createElement("button", { type: "button", onClick: () => n((g) => {
3557
+ ), /* @__PURE__ */ e.createElement("div", { className: "cme-counter-btns" }, /* @__PURE__ */ e.createElement("button", { type: "button", onClick: () => o((g) => {
3529
3558
  const w = parseInt(g.r, 10) || 1;
3530
3559
  return { ...g, r: Math.min(10, w + 1) };
3531
- }) }, "▲"), /* @__PURE__ */ e.createElement("button", { type: "button", onClick: () => n((g) => {
3560
+ }) }, "▲"), /* @__PURE__ */ e.createElement("button", { type: "button", onClick: () => o((g) => {
3532
3561
  const w = parseInt(g.r, 10) || 1;
3533
3562
  return { ...g, r: Math.max(1, w - 1) };
3534
3563
  }) }, "▼"))), /* @__PURE__ */ e.createElement("div", { className: "cme-matrix-counter" }, /* @__PURE__ */ e.createElement("span", null, "C"), /* @__PURE__ */ e.createElement(
@@ -3536,34 +3565,34 @@ function lt({ matrixType: r, x: l, y: m, onSelect: o, onMouseEnter: i, onMouseLe
3536
3565
  {
3537
3566
  type: "number",
3538
3567
  className: "cme-counter-val",
3539
- value: a.c,
3568
+ value: n.c,
3540
3569
  onChange: k,
3541
3570
  onBlur: x,
3542
3571
  min: "1",
3543
3572
  max: "10"
3544
3573
  }
3545
- ), /* @__PURE__ */ e.createElement("div", { className: "cme-counter-btns" }, /* @__PURE__ */ e.createElement("button", { type: "button", onClick: () => n((g) => {
3574
+ ), /* @__PURE__ */ e.createElement("div", { className: "cme-counter-btns" }, /* @__PURE__ */ e.createElement("button", { type: "button", onClick: () => o((g) => {
3546
3575
  const w = parseInt(g.c, 10) || 1;
3547
3576
  return { ...g, c: Math.min(10, w + 1) };
3548
- }) }, "▲"), /* @__PURE__ */ e.createElement("button", { type: "button", onClick: () => n((g) => {
3577
+ }) }, "▲"), /* @__PURE__ */ e.createElement("button", { type: "button", onClick: () => o((g) => {
3549
3578
  const w = parseInt(g.c, 10) || 1;
3550
3579
  return { ...g, c: Math.max(1, w - 1) };
3551
3580
  }) }, "▼"))))
3552
3581
  );
3553
3582
  }
3554
- function rt({ mode: r, onInsert: l, onClose: m, initialLatex: o, isEditing: i }) {
3555
- const s = F(null), [a, n] = I(0), [h, M] = I(null), [u, S] = I(null), [k, x] = I(null), [g, w] = I(null);
3583
+ function at({ mode: r, onInsert: l, onClose: c, initialLatex: a, isEditing: i }) {
3584
+ const s = F(null), [n, o] = I(0), [m, M] = I(null), [u, S] = I(null), [k, x] = I(null), [g, w] = I(null);
3556
3585
  F(null);
3557
3586
  const [B, T] = I({ x: 0, y: 0 }), [U, A] = I(!1), L = F({ x: 0, y: 0 });
3558
3587
  R(() => {
3559
- const t = (d) => {
3588
+ const t = (p) => {
3560
3589
  U && T({
3561
- x: d.clientX - L.current.x,
3562
- y: d.clientY - L.current.y
3590
+ x: p.clientX - L.current.x,
3591
+ y: p.clientY - L.current.y
3563
3592
  });
3564
- }, c = () => A(!1);
3565
- return U && (window.addEventListener("mousemove", t), window.addEventListener("mouseup", c)), () => {
3566
- window.removeEventListener("mousemove", t), window.removeEventListener("mouseup", c);
3593
+ }, h = () => A(!1);
3594
+ return U && (window.addEventListener("mousemove", t), window.addEventListener("mouseup", h)), () => {
3595
+ window.removeEventListener("mousemove", t), window.removeEventListener("mouseup", h);
3567
3596
  };
3568
3597
  }, [U]);
3569
3598
  const C = (t) => {
@@ -3571,7 +3600,7 @@ function rt({ mode: r, onInsert: l, onClose: m, initialLatex: o, isEditing: i })
3571
3600
  x: t.clientX - B.x,
3572
3601
  y: t.clientY - B.y
3573
3602
  });
3574
- }, v = r === "math" ? Ke : Ge, [p, D] = I({
3603
+ }, v = r === "math" ? _e : $e, [d, D] = I({
3575
3604
  bold: !1,
3576
3605
  italic: !1,
3577
3606
  color: "none",
@@ -3581,7 +3610,7 @@ function rt({ mode: r, onInsert: l, onClose: m, initialLatex: o, isEditing: i })
3581
3610
  const t = s.current;
3582
3611
  if (!(!t || typeof t.queryStyle != "function"))
3583
3612
  try {
3584
- const c = t.queryStyle({ fontSeries: "b" }) === "all" || t.queryStyle({ variantStyle: "bold" }) === "all", d = t.queryStyle({ variantStyle: "italic" }) === "all" || t.queryStyle({ shape: "it" }) === "all", y = ["roman", "sans-serif", "monospace"].find(
3613
+ const h = t.queryStyle({ fontSeries: "b" }) === "all" || t.queryStyle({ variantStyle: "bold" }) === "all", p = t.queryStyle({ variantStyle: "italic" }) === "all" || t.queryStyle({ shape: "it" }) === "all", y = ["roman", "sans-serif", "monospace"].find(
3585
3614
  (b) => t.queryStyle({ fontFamily: b }) === "all"
3586
3615
  ) || "none", E = [5, 7, 9].find(
3587
3616
  (b) => t.queryStyle({ fontSize: b }) === "all"
@@ -3620,101 +3649,103 @@ function rt({ mode: r, onInsert: l, onClose: m, initialLatex: o, isEditing: i })
3620
3649
  fontSize: String(E),
3621
3650
  color: f
3622
3651
  }));
3623
- } catch (c) {
3624
- console.warn("Failed to query active styles:", c);
3652
+ } catch (h) {
3653
+ console.warn("Failed to query active styles:", h);
3625
3654
  }
3626
3655
  }, []);
3627
3656
  R(() => {
3628
- if (!h && !k) return;
3629
- const t = (c) => {
3630
- !c.target.closest(".cme-matrix-hover-popover") && !c.target.closest(".cme-matrix-btn-wrapper") && M(null), !c.target.closest(".cme-color-picker-popup") && !c.target.closest('[title="Text Color"]') && x(null);
3657
+ if (!m && !k) return;
3658
+ const t = (h) => {
3659
+ !h.target.closest(".cme-matrix-hover-popover") && !h.target.closest(".cme-matrix-btn-wrapper") && M(null), !h.target.closest(".cme-color-picker-popup") && !h.target.closest('[title="Text Color"]') && x(null);
3631
3660
  };
3632
3661
  return window.addEventListener("mousedown", t, !0), window.addEventListener("pointerdown", t, !0), () => {
3633
3662
  window.removeEventListener("mousedown", t, !0), window.removeEventListener("pointerdown", t, !0);
3634
3663
  };
3635
- }, [h, k]), R(() => {
3664
+ }, [m, k]), R(() => {
3636
3665
  if (!g) return;
3637
- const t = (c) => {
3638
- !c.target.closest(".cme-more-popup") && !c.target.closest(".cme-more-trigger-btn") && w(null);
3666
+ const t = (h) => {
3667
+ !h.target.closest(".cme-more-popup") && !h.target.closest(".cme-more-trigger-btn") && w(null);
3639
3668
  };
3640
3669
  return window.addEventListener("mousedown", t, !0), window.addEventListener("pointerdown", t, !0), () => {
3641
3670
  window.removeEventListener("mousedown", t, !0), window.removeEventListener("pointerdown", t, !0);
3642
3671
  };
3643
3672
  }, [g]), R(() => {
3644
- const t = setTimeout(() => Pe(), 50);
3673
+ const t = setTimeout(() => Ze(), 50);
3645
3674
  return () => clearTimeout(t);
3646
- }, [a]), R(() => {
3675
+ }, [n]), R(() => {
3647
3676
  const t = s.current;
3648
3677
  if (!t) return;
3649
3678
  t.defaultMode = "math";
3650
- const c = () => {
3651
- if (typeof t.applyStyle == "function" && t.applyStyle({ variantStyle: "up" }), o) {
3652
- let d = o;
3679
+ const h = () => {
3680
+ if (typeof t.applyStyle == "function" && t.applyStyle({ variantStyle: "up" }), a) {
3681
+ let p = a;
3653
3682
  if (r === "chem") {
3654
- const y = d.match(/^\\ce\{([\s\S]*)\}$/i);
3655
- y && (d = y[1]);
3683
+ const y = p.match(/^\\ce\{([\s\S]*)\}$/i);
3684
+ y && (p = y[1]);
3656
3685
  }
3657
- d = d.replace(/\\text\{([^}]*)\}/g, "$1"), t.setValue ? t.setValue(d, { silenceNotifications: !0 }) : t.value = d;
3686
+ p = le(p), p = re(p), t.setValue ? t.setValue("", { silenceNotifications: !0 }) : t.value = "", t.executeCommand(["insert", p, { insertionMode: "replaceAll" }]);
3658
3687
  }
3659
3688
  requestAnimationFrame(() => t.focus());
3660
3689
  };
3661
- customElements.get("math-field") ? requestAnimationFrame(c) : customElements.whenDefined("math-field").then(() => requestAnimationFrame(c));
3662
- }, [r, o]), R(() => {
3690
+ customElements.get("math-field") ? requestAnimationFrame(h) : customElements.whenDefined("math-field").then(() => requestAnimationFrame(h));
3691
+ }, [r, a]), R(() => {
3663
3692
  const t = s.current;
3664
3693
  if (!t) return;
3665
- const c = (d) => {
3666
- if (d.key.length === 1 && !d.ctrlKey && !d.metaKey && !d.altKey && /[a-zA-Z0-9]/.test(d.key)) {
3667
- d.preventDefault(), d.stopPropagation();
3668
- let y = d.key;
3669
- p.bold && p.italic ? y = `\\mathbfit{${d.key}}` : p.bold ? y = `\\mathbf{${d.key}}` : p.italic ? y = `\\mathit{${d.key}}` : y = `\\mathrm{${d.key}}`, t.executeCommand(["insert", y]);
3694
+ const h = (p) => {
3695
+ if (p.key.length === 1 && !p.ctrlKey && !p.metaKey && !p.altKey && /[a-zA-Z0-9]/.test(p.key)) {
3696
+ if (!d.bold && !d.italic)
3697
+ return;
3698
+ p.preventDefault(), p.stopPropagation();
3699
+ let y = p.key;
3700
+ d.bold && d.italic ? y = `\\mathbfit{${p.key}}` : d.bold ? y = `\\mathbf{${p.key}}` : d.italic && (y = `\\mathit{${p.key}}`), t.executeCommand(["insert", y]);
3670
3701
  return;
3671
3702
  }
3672
- d.key === " " ? (d.preventDefault(), t.executeCommand(["insert", "\\, "])) : d.key === "Enter" && (d.preventDefault(), d.stopImmediatePropagation(), t.executeCommand("addRowAfter"), setTimeout(() => {
3703
+ p.key === " " ? (p.preventDefault(), t.executeCommand(["insert", "\\, "])) : p.key === "Enter" && (p.preventDefault(), p.stopImmediatePropagation(), t.executeCommand("addRowAfter"), setTimeout(() => {
3673
3704
  typeof t.applyStyle == "function" && (t.applyStyle({
3674
- fontSeries: p.bold ? "b" : "auto",
3675
- variantStyle: p.italic ? "italic" : "up"
3676
- }), p.color !== "none" && t.applyStyle({ color: p.color }), p.fontFamily !== "none" && t.applyStyle({ fontFamily: p.fontFamily }), p.fontSize !== "auto" && t.applyStyle({
3677
- fontSize: parseInt(p.fontSize, 10),
3678
- size: parseInt(p.fontSize, 10)
3705
+ fontSeries: d.bold ? "b" : "auto",
3706
+ variantStyle: d.italic ? "italic" : "up"
3707
+ }), d.color !== "none" && t.applyStyle({ color: d.color }), d.fontFamily !== "none" && t.applyStyle({ fontFamily: d.fontFamily }), d.fontSize !== "auto" && t.applyStyle({
3708
+ fontSize: parseInt(d.fontSize, 10),
3709
+ size: parseInt(d.fontSize, 10)
3679
3710
  }), H());
3680
3711
  }, 10));
3681
3712
  };
3682
- return t.addEventListener("keydown", c, !0), () => t.removeEventListener("keydown", c, !0);
3683
- }, [r, p, H]), R(() => {
3713
+ return t.addEventListener("keydown", h, !0), () => t.removeEventListener("keydown", h, !0);
3714
+ }, [r, d, H]), R(() => {
3684
3715
  const t = s.current;
3685
3716
  if (!t) return;
3686
- const c = () => {
3717
+ const h = () => {
3687
3718
  setTimeout(() => {
3688
- const d = t.shadowRoot;
3689
- if (!d) return;
3690
- const y = d.querySelector(".ML__caret") || d.querySelector('[class*="caret"]');
3719
+ const p = t.shadowRoot;
3720
+ if (!p) return;
3721
+ const y = p.querySelector(".ML__caret") || p.querySelector('[class*="caret"]');
3691
3722
  y && y.scrollIntoView({ behavior: "auto", block: "nearest", inline: "nearest" }), H();
3692
3723
  }, 0);
3693
3724
  };
3694
- return t.addEventListener("selection-change", c), t.addEventListener("input", c), t.addEventListener("keydown", c), setTimeout(H, 50), () => {
3695
- t.removeEventListener("selection-change", c), t.removeEventListener("input", c), t.removeEventListener("keydown", c);
3725
+ return t.addEventListener("selection-change", h), t.addEventListener("input", h), t.addEventListener("keydown", h), setTimeout(H, 50), () => {
3726
+ t.removeEventListener("selection-change", h), t.removeEventListener("input", h), t.removeEventListener("keydown", h);
3696
3727
  };
3697
3728
  }, [H]);
3698
3729
  const Z = q((t) => {
3699
- const c = s.current;
3700
- c && (c.focus(), c.executeCommand(["insert", t]));
3701
- }, []), ke = q((t, c, d) => {
3730
+ const h = s.current;
3731
+ h && (h.focus(), h.executeCommand(["insert", t]));
3732
+ }, []), xe = q((t, h, p) => {
3702
3733
  let y = `\\begin{${t}} `;
3703
- for (let E = 0; E < c; E++) {
3704
- for (let f = 0; f < d; f++)
3705
- y += "#?", f < d - 1 && (y += " & ");
3706
- E < c - 1 && (y += " \\\\ ");
3734
+ for (let E = 0; E < h; E++) {
3735
+ for (let f = 0; f < p; f++)
3736
+ y += "#?", f < p - 1 && (y += " & ");
3737
+ E < h - 1 && (y += " \\\\ ");
3707
3738
  }
3708
3739
  y += ` \\end{${t}}`, Z(y);
3709
- }, [Z]), ue = () => {
3740
+ }, [Z]), Ee = () => {
3710
3741
  const t = s.current;
3711
3742
  if (!t) return;
3712
- let c = t.getValue ? t.getValue() : t.value;
3713
- if (!c || c.trim() === "") {
3714
- m();
3743
+ let h = t.getValue ? t.getValue() : t.value;
3744
+ if (!h || h.trim() === "") {
3745
+ c();
3715
3746
  return;
3716
3747
  }
3717
- r === "chem" && (c = Ye(c)), l(c), t.setValue ? t.setValue("") : t.value = "", m();
3748
+ r === "chem" && (h = et(h)), l(h), t.setValue ? t.setValue("") : t.value = "", c();
3718
3749
  };
3719
3750
  return /* @__PURE__ */ e.createElement(
3720
3751
  "div",
@@ -3731,18 +3762,18 @@ function rt({ mode: r, onInsert: l, onClose: m, initialLatex: o, isEditing: i })
3731
3762
  style: { cursor: U ? "grabbing" : "grab" }
3732
3763
  },
3733
3764
  /* @__PURE__ */ e.createElement("span", null, i ? r === "math" ? "Edit Math Formula" : "Edit Chemistry Formula" : r === "math" ? "Math Editor" : "Chemistry Editor"),
3734
- /* @__PURE__ */ e.createElement("button", { type: "button", className: "cme-popup-close", onClick: m }, "×")
3765
+ /* @__PURE__ */ e.createElement("button", { type: "button", className: "cme-popup-close", onClick: c }, "×")
3735
3766
  ),
3736
- /* @__PURE__ */ e.createElement("div", { className: "cme-toolbar", role: "toolbar", "aria-label": "Symbol palette" }, /* @__PURE__ */ e.createElement("div", { className: "cme-toolbar-groups" }, v.map((t, c) => {
3737
- const d = a === c;
3767
+ /* @__PURE__ */ e.createElement("div", { className: "cme-toolbar", role: "toolbar", "aria-label": "Symbol palette" }, /* @__PURE__ */ e.createElement("div", { className: "cme-toolbar-groups" }, v.map((t, h) => {
3768
+ const p = n === h;
3738
3769
  return /* @__PURE__ */ e.createElement(
3739
3770
  "button",
3740
3771
  {
3741
3772
  key: t.isMatrix ? "matrix-tab" : t.label,
3742
- className: `cme-group-tab${d ? " active" : ""}`,
3773
+ className: `cme-group-tab${p ? " active" : ""}`,
3743
3774
  type: "button",
3744
3775
  onMouseDown: (y) => {
3745
- y.preventDefault(), n(c), M(null);
3776
+ y.preventDefault(), o(h), M(null);
3746
3777
  }
3747
3778
  },
3748
3779
  t.mathLabel ? /* @__PURE__ */ e.createElement(
@@ -3762,7 +3793,7 @@ function rt({ mode: r, onInsert: l, onClose: m, initialLatex: o, isEditing: i })
3762
3793
  padding: "0",
3763
3794
  margin: "0",
3764
3795
  boxShadow: "none",
3765
- color: d ? "#333333" : "#ffffff"
3796
+ color: p ? "#333333" : "#ffffff"
3766
3797
  }
3767
3798
  },
3768
3799
  t.mathLabel
@@ -3770,21 +3801,21 @@ function rt({ mode: r, onInsert: l, onClose: m, initialLatex: o, isEditing: i })
3770
3801
  );
3771
3802
  })), /* @__PURE__ */ e.createElement("div", { className: "cme-toolbar-items" }, (() => {
3772
3803
  var y;
3773
- const t = ((y = v[a]) == null ? void 0 : y.items) || [], c = t.some((E) => E.type === "sep"), d = [];
3774
- if (c) {
3804
+ const t = ((y = v[n]) == null ? void 0 : y.items) || [], h = t.some((E) => E.type === "sep"), p = [];
3805
+ if (h) {
3775
3806
  let E = { cols: 2, small: !1, cls: "", items: [], moreItems: null };
3776
3807
  for (const f of t)
3777
- f.type === "sep" ? (E.items.length > 0 && d.push(E), E = { cols: f.cols || 2, small: !!f.small, cls: f.cls || "", items: [], moreItems: f.moreItems || null, moreCols: f.moreCols || 1 }) : E.items.push(f);
3778
- E.items.length > 0 && d.push(E);
3808
+ f.type === "sep" ? (E.items.length > 0 && p.push(E), E = { cols: f.cols || 2, small: !!f.small, cls: f.cls || "", items: [], moreItems: f.moreItems || null, moreCols: f.moreCols || 1 }) : E.items.push(f);
3809
+ E.items.length > 0 && p.push(E);
3779
3810
  } else
3780
3811
  for (let f = 0; f < t.length; f += 4)
3781
- d.push({
3812
+ p.push({
3782
3813
  cols: 2,
3783
3814
  small: !1,
3784
3815
  cls: "",
3785
3816
  items: t.slice(f, f + 4)
3786
3817
  });
3787
- return d.map((E, f) => /* @__PURE__ */ e.createElement(
3818
+ return p.map((E, f) => /* @__PURE__ */ e.createElement(
3788
3819
  "div",
3789
3820
  {
3790
3821
  key: f,
@@ -3802,16 +3833,16 @@ function rt({ mode: r, onInsert: l, onClose: m, initialLatex: o, isEditing: i })
3802
3833
  w(null);
3803
3834
  else {
3804
3835
  const V = b.currentTarget.getBoundingClientRect();
3805
- w({ cx: V.left + V.width / 2, y: V.bottom, items: E.moreItems, cols: E.moreCols, isTemplate: v[a].isTemplate || v[a].label === "√(□)" || v[a].isMatrix });
3836
+ w({ cx: V.left + V.width / 2, y: V.bottom, items: E.moreItems, cols: E.moreCols, isTemplate: v[n].isTemplate || v[n].label === "√(□)" || v[n].isMatrix });
3806
3837
  }
3807
3838
  }
3808
3839
  },
3809
3840
  "▶"
3810
3841
  ),
3811
3842
  E.items.map((b, V) => {
3812
- const P = v[a];
3843
+ const P = v[n];
3813
3844
  if (b.type === "dropdown") {
3814
- const O = b.label === "Font...", W = b.label === "Size", z = O && p.fontFamily !== "none", X = W && p.fontSize !== "auto" && p.fontSize !== "5", N = O ? p.fontFamily === "none" ? "" : p.fontFamily : W ? p.fontSize === "auto" || p.fontSize === "5" ? "" : p.fontSize : "";
3845
+ const O = b.label === "Font...", W = b.label === "Size", z = O && d.fontFamily !== "none", X = W && d.fontSize !== "auto" && d.fontSize !== "5", N = O ? d.fontFamily === "none" ? "" : d.fontFamily : W ? d.fontSize === "auto" || d.fontSize === "5" ? "" : d.fontSize : "";
3815
3846
  return /* @__PURE__ */ e.createElement(
3816
3847
  "select",
3817
3848
  {
@@ -3855,7 +3886,7 @@ function rt({ mode: r, onInsert: l, onClose: m, initialLatex: o, isEditing: i })
3855
3886
  className: `cme-btn template${b.cls ? ` ${b.cls}` : ""}${P.isMatrix ? " cme-matrix-btn-small" : ""}`,
3856
3887
  title: b.title || b.label || b.insert,
3857
3888
  onMouseDown: (O) => {
3858
- if (O.preventDefault(), O.stopPropagation(), (h == null ? void 0 : h.type) === b.insert)
3889
+ if (O.preventDefault(), O.stopPropagation(), (m == null ? void 0 : m.type) === b.insert)
3859
3890
  M(null);
3860
3891
  else {
3861
3892
  const W = O.currentTarget.getBoundingClientRect();
@@ -3890,13 +3921,13 @@ function rt({ mode: r, onInsert: l, onClose: m, initialLatex: o, isEditing: i })
3890
3921
  )
3891
3922
  )
3892
3923
  );
3893
- const ye = b.action === "BOLD", xe = b.action === "ITALIC", Ee = b.action === "TEXT_COLOR", we = ye && p.bold || xe && p.italic || Ee && p.color !== "none" && p.color !== "black";
3924
+ const we = b.action === "BOLD", fe = b.action === "ITALIC", ve = b.action === "TEXT_COLOR", Me = we && d.bold || fe && d.italic || ve && d.color !== "none" && d.color !== "black";
3894
3925
  return /* @__PURE__ */ e.createElement(
3895
3926
  "button",
3896
3927
  {
3897
3928
  key: `${P.label}-${f * 4 + V}`,
3898
3929
  type: "button",
3899
- className: `cme-btn${P.isTemplate ? " template" : ""}${b.cls ? ` ${b.cls}` : ""}${we ? " active" : ""}`,
3930
+ className: `cme-btn${P.isTemplate ? " template" : ""}${b.cls ? ` ${b.cls}` : ""}${Me ? " active" : ""}`,
3900
3931
  title: b.title || b.label || b.insert,
3901
3932
  onMouseDown: (O) => {
3902
3933
  var z, X;
@@ -3911,18 +3942,18 @@ function rt({ mode: r, onInsert: l, onClose: m, initialLatex: o, isEditing: i })
3911
3942
  } else if (b.action === "BOLD") {
3912
3943
  if (W && typeof W.applyStyle == "function") {
3913
3944
  W.focus();
3914
- const N = !p.bold;
3945
+ const N = !d.bold;
3915
3946
  W.applyStyle({
3916
3947
  fontSeries: N ? "b" : "auto",
3917
- variantStyle: p.italic ? "italic" : "up"
3948
+ variantStyle: d.italic ? "italic" : "up"
3918
3949
  }), D((J) => ({ ...J, bold: N }));
3919
3950
  }
3920
3951
  } else if (b.action === "ITALIC") {
3921
3952
  if (W && typeof W.applyStyle == "function") {
3922
3953
  W.focus();
3923
- const N = !p.italic;
3954
+ const N = !d.italic;
3924
3955
  W.applyStyle({
3925
- fontSeries: p.bold ? "b" : "auto",
3956
+ fontSeries: d.bold ? "b" : "auto",
3926
3957
  variantStyle: N ? "italic" : "up"
3927
3958
  }), D((J) => ({ ...J, italic: N }));
3928
3959
  }
@@ -3959,13 +3990,13 @@ function rt({ mode: r, onInsert: l, onClose: m, initialLatex: o, isEditing: i })
3959
3990
  {
3960
3991
  ref: (t) => {
3961
3992
  t && requestAnimationFrame(() => {
3962
- const c = t.getBoundingClientRect(), d = document.querySelector(".cme-editor-popup");
3963
- let y = g.cx - c.width / 2, E = g.y;
3964
- if (d) {
3965
- const f = d.getBoundingClientRect();
3966
- y + c.width > f.right - 4 && (y = f.right - c.width - 4), y < f.left + 4 && (y = f.left + 4), E + c.height > f.bottom - 4 && (E = f.bottom - c.height - 4);
3993
+ const h = t.getBoundingClientRect(), p = document.querySelector(".cme-editor-popup");
3994
+ let y = g.cx - h.width / 2, E = g.y;
3995
+ if (p) {
3996
+ const f = p.getBoundingClientRect();
3997
+ y + h.width > f.right - 4 && (y = f.right - h.width - 4), y < f.left + 4 && (y = f.left + 4), E + h.height > f.bottom - 4 && (E = f.bottom - h.height - 4);
3967
3998
  }
3968
- y + c.width > window.innerWidth - 4 && (y = window.innerWidth - c.width - 4), E + c.height > window.innerHeight - 4 && (E = window.innerHeight - c.height - 4), y < 4 && (y = 4), t.style.left = `${y}px`, t.style.top = `${E}px`, t.style.transform = "none", t.style.visibility = "visible";
3999
+ y + h.width > window.innerWidth - 4 && (y = window.innerWidth - h.width - 4), E + h.height > window.innerHeight - 4 && (E = window.innerHeight - h.height - 4), y < 4 && (y = 4), t.style.left = `${y}px`, t.style.top = `${E}px`, t.style.transform = "none", t.style.visibility = "visible";
3969
4000
  });
3970
4001
  },
3971
4002
  className: "cme-more-popup",
@@ -3979,15 +4010,15 @@ function rt({ mode: r, onInsert: l, onClose: m, initialLatex: o, isEditing: i })
3979
4010
  gridTemplateColumns: `repeat(${g.cols || 1}, auto)`
3980
4011
  }
3981
4012
  },
3982
- g.items.map((t, c) => /* @__PURE__ */ e.createElement(
4013
+ g.items.map((t, h) => /* @__PURE__ */ e.createElement(
3983
4014
  "button",
3984
4015
  {
3985
- key: c,
4016
+ key: h,
3986
4017
  type: "button",
3987
4018
  className: `cme-more-popup-btn ${t.cls || ""}`,
3988
4019
  title: t.title || t.label || t.insert,
3989
- onMouseDown: (d) => {
3990
- d.preventDefault(), Z(t.insert), w(null);
4020
+ onMouseDown: (p) => {
4021
+ p.preventDefault(), Z(t.insert), w(null);
3991
4022
  }
3992
4023
  },
3993
4024
  t.insert && !t.action && (t.cls === "template" || t.isWidget) ? /* @__PURE__ */ e.createElement(
@@ -4019,8 +4050,8 @@ function rt({ mode: r, onInsert: l, onClose: m, initialLatex: o, isEditing: i })
4019
4050
  className: "cme-mathfield-container",
4020
4051
  onMouseDown: (t) => {
4021
4052
  s.current && (t.target === s.current || s.current.contains(t.target)) || (t.preventDefault(), requestAnimationFrame(() => {
4022
- var c, d;
4023
- (d = (c = s.current) == null ? void 0 : c.focus) == null || d.call(c);
4053
+ var h, p;
4054
+ (p = (h = s.current) == null ? void 0 : h.focus) == null || p.call(h);
4024
4055
  }));
4025
4056
  }
4026
4057
  },
@@ -4035,16 +4066,16 @@ function rt({ mode: r, onInsert: l, onClose: m, initialLatex: o, isEditing: i })
4035
4066
  }
4036
4067
  )
4037
4068
  ),
4038
- /* @__PURE__ */ e.createElement("div", { className: "cme-popup-footer" }, /* @__PURE__ */ e.createElement("button", { type: "button", className: "cme-insert-btn", onClick: ue }, i ? "Update" : "Insert"), /* @__PURE__ */ e.createElement("button", { type: "button", className: "cme-cancel-btn", onClick: m }, "Cancel")),
4039
- h && K(
4069
+ /* @__PURE__ */ e.createElement("div", { className: "cme-popup-footer" }, /* @__PURE__ */ e.createElement("button", { type: "button", className: "cme-insert-btn", onClick: Ee }, i ? "Update" : "Insert"), /* @__PURE__ */ e.createElement("button", { type: "button", className: "cme-cancel-btn", onClick: c }, "Cancel")),
4070
+ m && K(
4040
4071
  /* @__PURE__ */ e.createElement(
4041
- lt,
4072
+ nt,
4042
4073
  {
4043
- matrixType: h.type,
4044
- x: h.x,
4045
- y: h.y,
4046
- onSelect: (t, c) => {
4047
- ke(h.type, t, c), M(null);
4074
+ matrixType: m.type,
4075
+ x: m.x,
4076
+ y: m.y,
4077
+ onSelect: (t, h) => {
4078
+ xe(m.type, t, h), M(null);
4048
4079
  },
4049
4080
  onMouseEnter: () => {
4050
4081
  },
@@ -4056,7 +4087,7 @@ function rt({ mode: r, onInsert: l, onClose: m, initialLatex: o, isEditing: i })
4056
4087
  ),
4057
4088
  u && K(
4058
4089
  /* @__PURE__ */ e.createElement(
4059
- Qe,
4090
+ Ke,
4060
4091
  {
4061
4092
  isOpen: !!u,
4062
4093
  position: u,
@@ -4114,7 +4145,7 @@ function rt({ mode: r, onInsert: l, onClose: m, initialLatex: o, isEditing: i })
4114
4145
  "violet",
4115
4146
  "gold"
4116
4147
  ].map((t) => {
4117
- const c = p.color === t || t === "black" && (p.color === "none" || !p.color);
4148
+ const h = d.color === t || t === "black" && (d.color === "none" || !d.color);
4118
4149
  return /* @__PURE__ */ e.createElement(
4119
4150
  "div",
4120
4151
  {
@@ -4125,11 +4156,11 @@ function rt({ mode: r, onInsert: l, onClose: m, initialLatex: o, isEditing: i })
4125
4156
  height: "16px",
4126
4157
  backgroundColor: t,
4127
4158
  cursor: "pointer",
4128
- border: c ? "2px solid #e6c229" : "1px solid #000",
4159
+ border: h ? "2px solid #e6c229" : "1px solid #000",
4129
4160
  boxSizing: "border-box"
4130
4161
  },
4131
- onMouseDown: (d) => {
4132
- d.preventDefault(), d.stopPropagation();
4162
+ onMouseDown: (p) => {
4163
+ p.preventDefault(), p.stopPropagation();
4133
4164
  const y = s.current;
4134
4165
  y && typeof y.applyStyle == "function" && (y.focus(), y.applyStyle({ color: t === "black" ? "none" : t }), H()), x(null);
4135
4166
  }
@@ -4141,11 +4172,11 @@ function rt({ mode: r, onInsert: l, onClose: m, initialLatex: o, isEditing: i })
4141
4172
  )
4142
4173
  );
4143
4174
  }
4144
- function it(r) {
4175
+ function ot(r) {
4145
4176
  let l = r;
4146
- const m = l.match(/^\\ce\{([\s\S]*)\}$/);
4147
- m && (l = m[1]);
4148
- const o = [
4177
+ const c = l.match(/^\\ce\{([\s\S]*)\}$/);
4178
+ c && (l = c[1]);
4179
+ const a = [
4149
4180
  // Greek lowercase
4150
4181
  ["\\varepsilon", "ε"],
4151
4182
  ["\\varphi", "φ"],
@@ -4265,80 +4296,80 @@ function it(r) {
4265
4296
  ["\\cdots", "⋯"],
4266
4297
  ["\\ldots", "…"]
4267
4298
  ];
4268
- for (const [a, n] of o) {
4269
- const h = a.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
4270
- l = l.replace(new RegExp(h, "g"), n);
4299
+ for (const [n, o] of a) {
4300
+ const m = n.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
4301
+ l = l.replace(new RegExp(m, "g"), o);
4271
4302
  }
4272
4303
  l = l.replace(/\\frac\{([^}]*)\}\{([^}]*)\}/g, "$1/$2"), l = l.replace(/\\sqrt\[([^\]]*)\]\{([^}]*)\}/g, "$1√($2)"), l = l.replace(/\\sqrt\{([^}]*)\}/g, "√($1)"), l = l.replace(/\\vec\{([^}]*)\}/g, "$1⃗"), l = l.replace(/\\hat\{([^}]*)\}/g, "$1̂"), l = l.replace(/\\bar\{([^}]*)\}/g, "$1̄"), l = l.replace(/\\ddot\{([^}]*)\}/g, "$1̈"), l = l.replace(/\\dot\{([^}]*)\}/g, "$1̇"), l = l.replace(/\\text\{([^}]*)\}/g, "$1"), l = l.replace(
4273
4304
  /\\begin\{pmatrix\}([\s\S]*?)\\end\{pmatrix\}/g,
4274
- (a, n) => "[" + n.replace(/\\\\/g, "; ").replace(/&/g, ", ").trim() + "]"
4305
+ (n, o) => "[" + o.replace(/\\\\/g, "; ").replace(/&/g, ", ").trim() + "]"
4275
4306
  );
4276
4307
  const i = { 0: "⁰", 1: "¹", 2: "²", 3: "³", 4: "⁴", 5: "⁵", 6: "⁶", 7: "⁷", 8: "⁸", 9: "⁹", "+": "⁺", "-": "⁻", "=": "⁼", "(": "⁽", ")": "⁾", n: "ⁿ", i: "ⁱ" };
4277
4308
  l = l.replace(
4278
4309
  /\^\{([^}]*)\}/g,
4279
- (a, n) => n.split("").map((h) => i[h] || h).join("")
4280
- ), l = l.replace(/\^([a-zA-Z0-9])/g, (a, n) => i[n] || n);
4310
+ (n, o) => o.split("").map((m) => i[m] || m).join("")
4311
+ ), l = l.replace(/\^([a-zA-Z0-9])/g, (n, o) => i[o] || o);
4281
4312
  const s = { 0: "₀", 1: "₁", 2: "₂", 3: "₃", 4: "₄", 5: "₅", 6: "₆", 7: "₇", 8: "₈", 9: "₉", "+": "₊", "-": "₋", "=": "₌", "(": "₍", ")": "₎", a: "ₐ", e: "ₑ", o: "ₒ", x: "ₓ", i: "ᵢ", j: "ⱼ", n: "ₙ" };
4282
4313
  return l = l.replace(
4283
4314
  /_\{([^}]*)\}/g,
4284
- (a, n) => n.split("").map((h) => s[h] || h).join("")
4285
- ), l = l.replace(/_([a-zA-Z0-9])/g, (a, n) => s[n] || n), l = l.replace(/->/g, "→"), l = l.replace(/<=>/g, "⇌"), l = l.replace(/\\[a-zA-Z]+/g, ""), l = l.replace(/[{}]/g, ""), l = l.replace(/\s+/g, " "), l = l.replace(/\\\\/g, `
4315
+ (n, o) => o.split("").map((m) => s[m] || m).join("")
4316
+ ), l = l.replace(/_([a-zA-Z0-9])/g, (n, o) => s[o] || o), l = l.replace(/->/g, "→"), l = l.replace(/<=>/g, "⇌"), l = l.replace(/\\[a-zA-Z]+/g, ""), l = l.replace(/[{}]/g, ""), l = l.replace(/\s+/g, " "), l = l.replace(/\\\\/g, `
4286
4317
  `), l.trim();
4287
4318
  }
4288
- function bt({ value: r, onChange: l }) {
4289
- const m = F(null), o = F(!1), [i, s] = I(null), [a, n] = I(null);
4319
+ function ut({ value: r, onChange: l }) {
4320
+ const c = F(null), a = F(!1), [i, s] = I(null), [n, o] = I(null);
4290
4321
  R(() => {
4291
- o.current = !!i;
4322
+ a.current = !!i;
4292
4323
  }, [i]), R(() => () => {
4293
4324
  window.__ckMathWidgetClickHandler = null;
4294
4325
  }, []);
4295
- const h = q((A) => {
4296
- n(null), o.current = !0, s(A);
4326
+ const m = q((A) => {
4327
+ o(null), a.current = !0, s(A);
4297
4328
  }, []), M = q(() => {
4298
- o.current = !1, s(null), n(null);
4329
+ a.current = !1, s(null), o(null);
4299
4330
  }, []), [u, S] = I(!1), [k, x] = I(!1), [g, w] = I(!1), B = q((A) => {
4300
- const L = m.current;
4331
+ const L = c.current;
4301
4332
  if (!(!L || !(A != null && A.trim()))) {
4302
- if (a) {
4303
- const C = le(L, a.modelElement) ? a.modelElement : null;
4333
+ if (n) {
4334
+ const C = ie(L, n.modelElement) ? n.modelElement : null;
4304
4335
  C ? L.model.change((v) => {
4305
- const p = v.createElement("mathInline", { latex: A.trim() }), D = v.createPositionBefore(C);
4306
- v.insert(p, D), v.remove(C), v.setSelection(v.createPositionAfter(p));
4336
+ const d = v.createElement("mathInline", { latex: A.trim() }), D = v.createPositionBefore(C);
4337
+ v.insert(d, D), v.remove(C), v.setSelection(v.createPositionAfter(d));
4307
4338
  }) : L.model.change((v) => {
4308
- const p = v.createElement("mathInline", { latex: A.trim() });
4309
- L.model.insertContent(p);
4310
- }), n(null);
4339
+ const d = v.createElement("mathInline", { latex: A.trim() });
4340
+ L.model.insertContent(d);
4341
+ }), o(null);
4311
4342
  } else if (u) {
4312
- const C = it(A.trim());
4343
+ const C = ot(A.trim());
4313
4344
  if (!C) return;
4314
4345
  L.model.change((v) => {
4315
- const p = v.createText(C);
4316
- L.model.insertContent(p);
4346
+ const d = v.createText(C);
4347
+ L.model.insertContent(d);
4317
4348
  });
4318
4349
  } else
4319
4350
  L.model.change((C) => {
4320
4351
  const v = C.createElement("mathInline", { latex: A.trim() });
4321
4352
  L.model.insertContent(v);
4322
- const p = C.createPositionAfter(v);
4323
- C.insertText(" ", p), C.setSelection(p.getShiftedBy(1));
4353
+ const d = C.createPositionAfter(v);
4354
+ C.insertText(" ", d), C.setSelection(d.getShiftedBy(1));
4324
4355
  });
4325
4356
  L.editing.view.focus();
4326
4357
  }
4327
- }, [u, a]), T = te(() => tt(h), [h]), U = q((A) => {
4328
- m.current = A;
4329
- const L = (p, D) => {
4330
- if (o.current || !D) return;
4358
+ }, [u, n]), T = te(() => it(m), [m]), U = q((A) => {
4359
+ c.current = A;
4360
+ const L = (d, D) => {
4361
+ if (a.current || !D) return;
4331
4362
  const H = /^\\ce\{/.test(D);
4332
- o.current = !0, n({ modelElement: p, latex: D }), s(H ? "chem" : "math");
4363
+ a.current = !0, o({ modelElement: d, latex: D }), s(H ? "chem" : "math");
4333
4364
  };
4334
4365
  A.mathWidgetClickHandler = L, window.__ckMathWidgetClickHandler = L;
4335
4366
  const C = A.ui.getEditableElement();
4336
4367
  if (!C || C._ckMathClickAttached) return;
4337
4368
  C._ckMathClickAttached = !0;
4338
- const v = (p) => {
4369
+ const v = (d) => {
4339
4370
  var H;
4340
- const D = ge(p.target);
4341
- D && p.button === 0 && (p.preventDefault(), p.stopPropagation(), (H = p.stopImmediatePropagation) == null || H.call(p), re(A, null, Q(D), D));
4371
+ const D = ye(d.target);
4372
+ D && d.button === 0 && (d.preventDefault(), d.stopPropagation(), (H = d.stopImmediatePropagation) == null || H.call(d), ne(A, null, Q(D), D));
4342
4373
  };
4343
4374
  C.addEventListener("mousedown", v, !0), C.addEventListener("click", v, !0);
4344
4375
  }, []);
@@ -4422,7 +4453,7 @@ function bt({ value: r, onChange: l }) {
4422
4453
  style: { background: "transparent", border: "none", fontSize: "20px", cursor: "pointer" }
4423
4454
  },
4424
4455
  "×"
4425
- )), /* @__PURE__ */ e.createElement("div", { style: { fontSize: "16px", lineHeight: "1.6" } }, /* @__PURE__ */ e.createElement(Ze, { value: r })), /* @__PURE__ */ e.createElement("div", { style: { marginTop: "30px", textAlign: "right" } }, /* @__PURE__ */ e.createElement(
4456
+ )), /* @__PURE__ */ e.createElement("div", { style: { fontSize: "16px", lineHeight: "1.6" } }, /* @__PURE__ */ e.createElement(Qe, { value: r })), /* @__PURE__ */ e.createElement("div", { style: { marginTop: "30px", textAlign: "right" } }, /* @__PURE__ */ e.createElement(
4426
4457
  "button",
4427
4458
  {
4428
4459
  onClick: () => w(!1),
@@ -4430,17 +4461,14 @@ function bt({ value: r, onChange: l }) {
4430
4461
  },
4431
4462
  "Close"
4432
4463
  )))), /* @__PURE__ */ e.createElement(
4433
- fe,
4464
+ Ae,
4434
4465
  {
4435
- editor: He,
4466
+ editor: Ve,
4436
4467
  data: r,
4437
4468
  onReady: U,
4438
4469
  config: {
4439
4470
  licenseKey: "GPL",
4440
4471
  plugins: [
4441
- ve,
4442
- Me,
4443
- Ae,
4444
4472
  Ce,
4445
4473
  Le,
4446
4474
  Se,
@@ -4451,7 +4479,10 @@ function bt({ value: r, onChange: l }) {
4451
4479
  De,
4452
4480
  Ne,
4453
4481
  Re,
4454
- _e,
4482
+ He,
4483
+ Oe,
4484
+ Ue,
4485
+ tt,
4455
4486
  T
4456
4487
  ],
4457
4488
  toolbar: {
@@ -4491,16 +4522,16 @@ function bt({ value: r, onChange: l }) {
4491
4522
  }
4492
4523
  }
4493
4524
  ), i && /* @__PURE__ */ e.createElement(
4494
- rt,
4525
+ at,
4495
4526
  {
4496
4527
  mode: i,
4497
4528
  onInsert: B,
4498
4529
  onClose: M,
4499
- initialLatex: (a == null ? void 0 : a.latex) || "",
4500
- isEditing: !!a
4530
+ initialLatex: (n == null ? void 0 : n.latex) || "",
4531
+ isEditing: !!n
4501
4532
  }
4502
4533
  ));
4503
4534
  }
4504
4535
  export {
4505
- bt as CustomMathEditor
4536
+ ut as CustomMathEditor
4506
4537
  };