mind-elixir 5.10.1-beta.1 → 5.11.0

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,4 +1,4 @@
1
- const qo = 0, Uo = 1, Jo = 2, ve = {
1
+ const ts = 0, ns = 1, os = 2, be = {
2
2
  name: "Latte",
3
3
  type: "light",
4
4
  palette: ["#dd7878", "#ea76cb", "#8839ef", "#e64553", "#fe640b", "#df8e1d", "#40a02b", "#209fb5", "#1e66f5", "#7287fd"],
@@ -25,7 +25,7 @@ const qo = 0, Uo = 1, Jo = 2, ve = {
25
25
  "--panel-border-color": "#eaeaea",
26
26
  "--map-padding": "50px 80px"
27
27
  }
28
- }, we = {
28
+ }, ve = {
29
29
  name: "Dark",
30
30
  type: "dark",
31
31
  palette: ["#848FA0", "#748BE9", "#D2F9FE", "#4145A5", "#789AFA", "#706CF4", "#EF987F", "#775DD5", "#FCEECF", "#DA7FBC"],
@@ -53,7 +53,7 @@ const qo = 0, Uo = 1, Jo = 2, ve = {
53
53
  "--map-padding": "50px 80px"
54
54
  }
55
55
  };
56
- function me(e) {
56
+ function ge(e) {
57
57
  return e.replace(/&/g, "&amp;").replace(/</g, "&lt;").replace(/"/g, "&quot;");
58
58
  }
59
59
  const le = function(e, t) {
@@ -67,10 +67,10 @@ const le = function(e, t) {
67
67
  return null;
68
68
  } else
69
69
  return null;
70
- }, V = (e, t) => {
70
+ }, G = (e, t) => {
71
71
  if (e.parent = t, e.children)
72
72
  for (let n = 0; n < e.children.length; n++)
73
- V(e.children[n], e);
73
+ G(e.children[n], e);
74
74
  }, U = (e, t, n) => {
75
75
  if (e.expanded = t, e.children)
76
76
  if (n === void 0 || n > 0) {
@@ -100,14 +100,14 @@ function ce(e, t, n, o) {
100
100
  function z() {
101
101
  return ((/* @__PURE__ */ new Date()).getTime().toString(16) + Math.random().toString(16).substring(2)).substring(2, 18);
102
102
  }
103
- const ut = function() {
103
+ const pt = function() {
104
104
  const e = z();
105
105
  return {
106
106
  topic: this.newTopicName,
107
107
  id: e
108
108
  };
109
109
  };
110
- function Ee(e) {
110
+ function we(e) {
111
111
  return JSON.parse(
112
112
  JSON.stringify(e, (n, o) => {
113
113
  if (n !== "parent")
@@ -115,15 +115,15 @@ function Ee(e) {
115
115
  })
116
116
  );
117
117
  }
118
- const H = (e, t) => {
118
+ const $ = (e, t) => {
119
119
  let n = 0, o = 0;
120
120
  for (; t && t !== e; )
121
121
  n += t.offsetLeft, o += t.offsetTop, t = t.offsetParent;
122
122
  return { offsetLeft: n, offsetTop: o };
123
- }, D = (e, t) => {
123
+ }, A = (e, t) => {
124
124
  for (const n in t)
125
125
  e.setAttribute(n, t[n]);
126
- }, re = (e) => e ? e.tagName === "ME-TPC" : !1, Ce = (e) => e.filter((t) => t.nodeObj.parent).filter((t, n, o) => {
126
+ }, ee = (e) => e ? e.tagName === "ME-TPC" : !1, Ee = (e) => e.filter((t) => t.nodeObj.parent).filter((t, n, o) => {
127
127
  for (let s = 0; s < o.length; s++) {
128
128
  if (t === o[s]) continue;
129
129
  const { parent: i } = t.nodeObj;
@@ -131,7 +131,7 @@ const H = (e, t) => {
131
131
  return !1;
132
132
  }
133
133
  return !0;
134
- }), Se = (e) => {
134
+ }), Ce = (e) => {
135
135
  const t = /translate3d\(([^,]+),\s*([^,]+)/, n = e.match(t);
136
136
  return n ? { x: parseFloat(n[1]), y: parseFloat(n[2]) } : { x: 0, y: 0 };
137
137
  }, Je = function(e) {
@@ -145,16 +145,129 @@ const H = (e, t) => {
145
145
  o.removeEventListener(s, i);
146
146
  }
147
147
  };
148
- }, Pe = (e, t) => {
148
+ }, Me = (e, t) => {
149
149
  const n = e.x - t.x, o = e.y - t.y;
150
150
  return Math.sqrt(n * n + o * o);
151
- }, B = {
151
+ }, gt = function(e, t) {
152
+ if (!t)
153
+ return de(e), e;
154
+ let n = e.querySelector(".insert-preview");
155
+ const o = `insert-preview ${t} show`;
156
+ return n || (n = document.createElement("div"), e.appendChild(n)), n.className = o, e;
157
+ }, de = function(e) {
158
+ if (!e) return;
159
+ const t = e.querySelectorAll(".insert-preview");
160
+ for (const n of t || [])
161
+ n.remove();
162
+ }, Pe = function(e, t) {
163
+ for (const n of t) {
164
+ const o = n.parentElement.parentElement.contains(e);
165
+ if (!(e && e.tagName === "ME-TPC" && e !== n && !o && e.nodeObj.parent)) return !1;
166
+ }
167
+ return !0;
168
+ }, mt = function(e) {
169
+ const t = document.createElement("div");
170
+ return t.className = "mind-elixir-ghost", e.container.appendChild(t), t;
171
+ };
172
+ class yt {
173
+ mind;
174
+ isMoving = !1;
175
+ interval = null;
176
+ speed = 20;
177
+ constructor(t) {
178
+ this.mind = t;
179
+ }
180
+ move(t, n) {
181
+ this.isMoving || (this.isMoving = !0, this.interval = setInterval(() => {
182
+ this.mind.move(t * this.speed * this.mind.scaleVal, n * this.speed * this.mind.scaleVal);
183
+ }, 100));
184
+ }
185
+ stop() {
186
+ this.isMoving = !1, this.interval && (clearInterval(this.interval), this.interval = null);
187
+ }
188
+ }
189
+ function bt(e) {
190
+ return {
191
+ isDragging: !1,
192
+ insertType: null,
193
+ meet: null,
194
+ ghost: mt(e),
195
+ edgeMoveController: new yt(e),
196
+ startX: 0,
197
+ startY: 0,
198
+ pointerId: null
199
+ };
200
+ }
201
+ const vt = 5;
202
+ function Oe(e, t, n, o = !1) {
203
+ if (e.spacePressed) return !1;
204
+ const s = n.target;
205
+ return s?.tagName !== "ME-TPC" || !s.nodeObj.parent ? !1 : (t.startX = n.clientX, t.startY = n.clientY, t.pointerId = n.pointerId, e.dragged = e.currentNodes, o && Qe(e, t), !0);
206
+ }
207
+ function Ze(e, t, n) {
208
+ e.style.transform = `translate(${t - 10}px, ${n - 10}px)`, e.style.display = "block";
209
+ }
210
+ function Qe(e, t) {
211
+ const { dragged: n } = e;
212
+ if (!n) return;
213
+ const o = document.activeElement;
214
+ o && o.isContentEditable && o.blur(), t.isDragging = !0, n.length > 1 ? t.ghost.innerHTML = n.length + "" : t.ghost.innerHTML = n[0].innerHTML;
215
+ for (const s of n)
216
+ s.parentElement.parentElement.style.opacity = "0.5";
217
+ e.panHelper.clear();
218
+ }
219
+ function xt(e, t, n) {
220
+ const { dragged: o } = e;
221
+ if (!o || t.pointerId !== n.pointerId) return;
222
+ const s = n.clientX - t.startX, i = n.clientY - t.startY, l = Math.sqrt(s * s + i * i);
223
+ if (!t.isDragging && l > vt && Qe(e, t), !t.isDragging) return;
224
+ const c = e.container.getBoundingClientRect();
225
+ Ze(t.ghost, n.clientX - c.x, n.clientY - c.y), n.clientX < c.x + 50 ? t.edgeMoveController.move(1, 0) : n.clientX > c.x + c.width - 50 ? t.edgeMoveController.move(-1, 0) : n.clientY < c.y + 50 ? t.edgeMoveController.move(0, 1) : n.clientY > c.y + c.height - 50 ? t.edgeMoveController.move(0, -1) : t.edgeMoveController.stop(), de(t.meet);
226
+ const r = 12 * e.scaleVal, a = document.elementFromPoint(n.clientX, n.clientY - r);
227
+ if (Pe(a, o)) {
228
+ t.meet = a;
229
+ const d = a.getBoundingClientRect(), h = d.y;
230
+ n.clientY > h + d.height ? t.insertType = "after" : t.insertType = "in";
231
+ } else {
232
+ const d = document.elementFromPoint(n.clientX, n.clientY + r);
233
+ if (Pe(d, o)) {
234
+ t.meet = d;
235
+ const u = d.getBoundingClientRect().y;
236
+ n.clientY < u ? t.insertType = "before" : t.insertType = "in";
237
+ } else
238
+ t.insertType = null, t.meet = null;
239
+ }
240
+ t.meet && gt(t.meet, t.insertType);
241
+ }
242
+ function wt(e, t, n) {
243
+ const { dragged: o } = e;
244
+ if (!(!o || t.pointerId !== n.pointerId)) {
245
+ t.edgeMoveController.stop();
246
+ for (const s of o)
247
+ s.parentElement.parentElement.style.opacity = "1";
248
+ t.ghost.style.display = "none", t.ghost.innerHTML = "", t.isDragging && t.meet && (de(t.meet), t.insertType === "before" ? e.moveNodeBefore(o, t.meet) : t.insertType === "after" ? e.moveNodeAfter(o, t.meet) : t.insertType === "in" && e.moveNodeIn(o, t.meet)), e.dragged = null, t.isDragging = !1, t.insertType = null, t.meet = null, t.pointerId = null;
249
+ }
250
+ }
251
+ function ue(e, t) {
252
+ const { dragged: n } = e;
253
+ if (n) {
254
+ t.edgeMoveController.stop();
255
+ for (const o of n)
256
+ o.parentElement.parentElement.style.opacity = "1";
257
+ t.meet && de(t.meet), t.ghost.style.display = "none", t.ghost.innerHTML = "", e.dragged = null, t.isDragging = !1, t.insertType = null, t.meet = null, t.pointerId = null;
258
+ }
259
+ }
260
+ function Et(e) {
261
+ return () => {
262
+ };
263
+ }
264
+ const B = {
152
265
  LHS: "lhs",
153
266
  RHS: "rhs"
154
- }, pt = function() {
267
+ }, Ct = function() {
155
268
  this.nodes.innerHTML = "";
156
269
  const e = this.createTopic(this.nodeData);
157
- Ne.call(this, e, this.nodeData), e.draggable = !1;
270
+ Se.call(this, e, this.nodeData), e.draggable = !1;
158
271
  const t = document.createElement("me-root");
159
272
  t.appendChild(e);
160
273
  const n = this.nodeData.children || [];
@@ -164,8 +277,8 @@ const H = (e, t) => {
164
277
  i.direction === 0 ? o += 1 : i.direction === 1 ? s += 1 : o <= s ? (i.direction = 0, o += 1) : (i.direction = 1, s += 1);
165
278
  });
166
279
  }
167
- gt(this, n, t);
168
- }, gt = function(e, t, n) {
280
+ St(this, n, t);
281
+ }, St = function(e, t, n) {
169
282
  const o = document.createElement("me-main");
170
283
  o.className = B.LHS;
171
284
  const s = document.createElement("me-main");
@@ -175,18 +288,18 @@ const H = (e, t) => {
175
288
  e.direction === 2 ? l.direction === 0 ? o.appendChild(c) : s.appendChild(c) : e.direction === 0 ? o.appendChild(c) : s.appendChild(c);
176
289
  }
177
290
  e.nodes.appendChild(o), e.nodes.appendChild(n), e.nodes.appendChild(s), e.nodes.appendChild(e.lines), e.nodes.appendChild(e.labelContainer);
178
- }, mt = function(e, t) {
291
+ }, Nt = function(e, t) {
179
292
  const n = document.createElement("me-children");
180
293
  for (let o = 0; o < t.length; o++) {
181
294
  const s = t[o], { grp: i } = e.createWrapper(s);
182
295
  n.appendChild(i);
183
296
  }
184
297
  return n;
185
- }, Ze = function(e, t) {
298
+ }, et = function(e, t) {
186
299
  const o = (this?.el ? this.el : t || document).querySelector(`[data-nodeid="me${e}"]`);
187
300
  if (!o) throw new Error(`FindEle: Node ${e} not found, maybe it's collapsed.`);
188
301
  return o;
189
- }, Ne = function(e, t) {
302
+ }, Se = function(e, t) {
190
303
  if (e.innerHTML = "", t.style) {
191
304
  const n = t.style;
192
305
  for (const o in n)
@@ -213,7 +326,7 @@ const H = (e, t) => {
213
326
  } else e.link && (e.link = void 0);
214
327
  if (t.icons && t.icons.length) {
215
328
  const n = document.createElement("span");
216
- n.className = "icons", n.innerHTML = t.icons.map((o) => `<span>${me(o)}</span>`).join(""), e.appendChild(n), e.icons = n;
329
+ n.className = "icons", n.innerHTML = t.icons.map((o) => `<span>${ge(o)}</span>`).join(""), e.appendChild(n), e.icons = n;
217
330
  } else e.icons && (e.icons = void 0);
218
331
  if (t.tags && t.tags.length) {
219
332
  const n = document.createElement("div");
@@ -222,35 +335,35 @@ const H = (e, t) => {
222
335
  typeof o == "string" ? s.textContent = o : (s.textContent = o.text, o.className && (s.className = o.className), o.style && Object.assign(s.style, o.style)), n.appendChild(s);
223
336
  }), e.appendChild(n), e.tags = n;
224
337
  } else e.tags && (e.tags = void 0);
225
- }, yt = function(e, t) {
338
+ }, Tt = function(e, t) {
226
339
  const n = document.createElement("me-wrapper"), { p: o, tpc: s } = this.createParent(e);
227
340
  if (n.appendChild(o), !t && e.children && e.children.length > 0) {
228
- const i = Te(e.expanded);
341
+ const i = Ne(e.expanded);
229
342
  if (o.appendChild(i), e.expanded !== !1) {
230
- const l = mt(this, e.children);
343
+ const l = Nt(this, e.children);
231
344
  n.appendChild(l);
232
345
  }
233
346
  }
234
347
  return { grp: n, top: o, tpc: s };
235
- }, bt = function(e) {
348
+ }, _t = function(e) {
236
349
  const t = document.createElement("me-parent"), n = this.createTopic(e);
237
- return Ne.call(this, n, e), t.appendChild(n), { p: t, tpc: n };
238
- }, vt = function(e) {
350
+ return Se.call(this, n, e), t.appendChild(n), { p: t, tpc: n };
351
+ }, kt = function(e) {
239
352
  const t = document.createElement("me-children");
240
353
  return t.append(...e), t;
241
- }, wt = function(e) {
354
+ }, Lt = function(e) {
242
355
  const t = document.createElement("me-tpc");
243
356
  return t.nodeObj = e, t.dataset.nodeid = "me" + e.id, t;
244
357
  };
245
- function Qe(e) {
358
+ function tt(e) {
246
359
  const t = document.createRange();
247
360
  t.selectNodeContents(e);
248
361
  const n = window.getSelection();
249
362
  n && (n.removeAllRanges(), n.addRange(t));
250
363
  }
251
- const xt = function(e) {
364
+ const Dt = function(e) {
252
365
  if (!e) return;
253
- const t = document.createElement("div"), n = e.nodeObj, o = n.topic, { offsetLeft: s, offsetTop: i } = H(this.nodes, e);
366
+ const t = document.createElement("div"), n = e.nodeObj, o = n.topic, { offsetLeft: s, offsetTop: i } = $(this.nodes, e);
254
367
  this.nodes.appendChild(t), t.id = "input-box", t.textContent = o, t.contentEditable = "plaintext-only", t.spellcheck = !1;
255
368
  const l = getComputedStyle(e);
256
369
  t.style.cssText = `
@@ -263,7 +376,7 @@ const xt = function(e) {
263
376
  margin:${l.margin};
264
377
  background-color:${l.backgroundColor !== "rgba(0, 0, 0, 0)" && l.backgroundColor};
265
378
  border: ${l.border};
266
- border-radius:${l.borderRadius}; `, this.direction === 0 && (t.style.right = "0"), Qe(t), this.bus.fire("operation", {
379
+ border-radius:${l.borderRadius}; `, this.direction === 0 && (t.style.right = "0"), tt(t), this.bus.fire("operation", {
267
380
  name: "beginEdit",
268
381
  obj: e.nodeObj
269
382
  }), t.addEventListener("keydown", (c) => {
@@ -283,39 +396,39 @@ const xt = function(e) {
283
396
  origin: o
284
397
  }));
285
398
  });
286
- }, Te = function(e) {
399
+ }, Ne = function(e) {
287
400
  const t = document.createElement("me-epd");
288
401
  return t.expanded = e !== !1, t.className = e !== !1 ? "minus" : "", t;
289
402
  }, J = (e) => {
290
403
  const t = e.parent?.children, n = t?.indexOf(e) ?? 0;
291
404
  return { siblings: t, index: n };
292
405
  };
293
- function Et(e) {
406
+ function At(e) {
294
407
  const { siblings: t, index: n } = J(e);
295
408
  if (t === void 0) return;
296
409
  const o = t[n];
297
410
  n === 0 ? (t[n] = t[t.length - 1], t[t.length - 1] = o) : (t[n] = t[n - 1], t[n - 1] = o);
298
411
  }
299
- function Ct(e) {
412
+ function Mt(e) {
300
413
  const { siblings: t, index: n } = J(e);
301
414
  if (t === void 0) return;
302
415
  const o = t[n];
303
416
  n === t.length - 1 ? (t[n] = t[0], t[0] = o) : (t[n] = t[n + 1], t[n + 1] = o);
304
417
  }
305
- function et(e) {
418
+ function nt(e) {
306
419
  const { siblings: t, index: n } = J(e);
307
420
  return t === void 0 ? 0 : (t.splice(n, 1), t.length);
308
421
  }
309
- function St(e, t, n) {
422
+ function Pt(e, t, n) {
310
423
  const { siblings: o, index: s } = J(n);
311
424
  o !== void 0 && (t === "before" ? o.splice(s, 0, e) : o.splice(s + 1, 0, e));
312
425
  }
313
- function Nt(e, t) {
426
+ function Ot(e, t) {
314
427
  const { siblings: n, index: o } = J(e);
315
428
  n !== void 0 && (n[o] = t, t.children = [e]);
316
429
  }
317
- function Tt(e, t, n) {
318
- if (et(t), n.parent?.parent || (t.direction = n.direction), e === "in")
430
+ function $t(e, t, n) {
431
+ if (nt(t), n.parent?.parent || (t.direction = n.direction), e === "in")
319
432
  n.children ? n.children.push(t) : n.children = [t];
320
433
  else {
321
434
  t.direction !== void 0 && (t.direction = n.direction);
@@ -324,7 +437,7 @@ function Tt(e, t, n) {
324
437
  e === "before" ? o.splice(s, 0, t) : o.splice(s + 1, 0, t);
325
438
  }
326
439
  }
327
- const _t = function({ map: e, direction: t }, n) {
440
+ const Ht = function({ map: e, direction: t }, n) {
328
441
  if (t === 0)
329
442
  return 0;
330
443
  if (t === 1)
@@ -333,48 +446,48 @@ const _t = function({ map: e, direction: t }, n) {
333
446
  const o = e.querySelector(".lhs")?.childElementCount || 0, s = e.querySelector(".rhs")?.childElementCount || 0;
334
447
  return o <= s ? (n.direction = 0, 0) : (n.direction = 1, 1);
335
448
  }
336
- }, tt = function(e, t, n) {
449
+ }, ot = function(e, t, n) {
337
450
  const o = n.children[0].children[0], s = t.parentElement;
338
451
  if (s.tagName === "ME-PARENT") {
339
- if (ee(o), s.children[1])
452
+ if (ne(o), s.children[1])
340
453
  s.nextSibling.appendChild(n);
341
454
  else {
342
455
  const i = e.createChildren([n]);
343
- s.appendChild(Te(!0)), s.insertAdjacentElement("afterend", i);
456
+ s.appendChild(Ne(!0)), s.insertAdjacentElement("afterend", i);
344
457
  }
345
458
  e.linkDiv(n.offsetParent);
346
- } else s.tagName === "ME-ROOT" && (_t(e, o.nodeObj) === 0 ? e.container.querySelector(".lhs")?.appendChild(n) : e.container.querySelector(".rhs")?.appendChild(n), e.linkDiv());
347
- }, kt = function(e, t) {
459
+ } else s.tagName === "ME-ROOT" && (Ht(e, o.nodeObj) === 0 ? e.container.querySelector(".lhs")?.appendChild(n) : e.container.querySelector(".rhs")?.appendChild(n), e.linkDiv());
460
+ }, jt = function(e, t) {
348
461
  const n = e.parentNode;
349
462
  if (t === 0) {
350
463
  const o = n.parentNode.parentNode;
351
464
  o.tagName !== "ME-MAIN" && (o.previousSibling.children[1].remove(), o.remove());
352
465
  }
353
466
  n.parentNode.remove();
354
- }, nt = {
467
+ }, st = {
355
468
  before: "beforebegin",
356
469
  after: "afterend"
357
- }, ee = function(e) {
470
+ }, ne = function(e) {
358
471
  const n = e.parentElement.parentElement.lastElementChild;
359
472
  n?.tagName === "svg" && n?.remove();
360
- }, Lt = function(e, t) {
361
- const n = e.nodeObj, o = Ee(n);
473
+ }, It = function(e, t) {
474
+ const n = e.nodeObj, o = we(n);
362
475
  o.style && t.style && (t.style = Object.assign(o.style, t.style));
363
476
  const s = Object.assign(n, t);
364
- Ne.call(this, e, s), this.linkDiv(), this.bus.fire("operation", {
477
+ Se.call(this, e, s), this.linkDiv(), this.bus.fire("operation", {
365
478
  name: "reshapeNode",
366
479
  obj: s,
367
480
  origin: o
368
481
  });
369
- }, _e = function(e, t, n) {
482
+ }, Te = function(e, t, n) {
370
483
  if (!t) return null;
371
484
  const o = t.nodeObj;
372
485
  o.expanded === !1 && (e.expandNode(t, !0), t = e.findEle(o.id));
373
486
  const s = n || e.generateNewObj();
374
- o.children ? o.children.push(s) : o.children = [s], V(e.nodeData);
487
+ o.children ? o.children.push(s) : o.children = [s], G(e.nodeData);
375
488
  const { grp: i, top: l } = e.createWrapper(s);
376
- return tt(e, t, i), { newTop: l, newNodeObj: s };
377
- }, Dt = function(e, t, n) {
489
+ return ot(e, t, i), { newTop: l, newNodeObj: s };
490
+ }, Rt = function(e, t, n) {
378
491
  const o = t || this.currentNode;
379
492
  if (!o) return;
380
493
  const s = o.nodeObj;
@@ -395,55 +508,55 @@ const _t = function({ map: e, direction: t }, n) {
395
508
  const a = o.closest("me-main").className === B.LHS ? 0 : 1;
396
509
  i.direction = a;
397
510
  }
398
- St(i, e, s), V(this.nodeData);
511
+ Pt(i, e, s), G(this.nodeData);
399
512
  const l = o.parentElement, { grp: c, top: r } = this.createWrapper(i);
400
- l.parentElement.insertAdjacentElement(nt[e], c), this.linkDiv(c.offsetParent), n || this.editTopic(r.firstChild), this.bus.fire("operation", {
513
+ l.parentElement.insertAdjacentElement(st[e], c), this.linkDiv(c.offsetParent), n || this.editTopic(r.firstChild), this.bus.fire("operation", {
401
514
  name: "insertSibling",
402
515
  type: e,
403
516
  obj: i
404
517
  }), this.selectNode(r.firstChild, !0);
405
- }, At = function(e, t) {
518
+ }, Bt = function(e, t) {
406
519
  const n = e || this.currentNode;
407
520
  if (!n) return;
408
- ee(n);
521
+ ne(n);
409
522
  const o = n.nodeObj;
410
523
  if (!o.parent)
411
524
  return;
412
525
  const s = t || this.generateNewObj();
413
- Nt(o, s), V(this.nodeData);
526
+ Ot(o, s), G(this.nodeData);
414
527
  const i = n.parentElement.parentElement, { grp: l, top: c } = this.createWrapper(s, !0);
415
- c.appendChild(Te(!0)), i.insertAdjacentElement("afterend", l);
528
+ c.appendChild(Ne(!0)), i.insertAdjacentElement("afterend", l);
416
529
  const r = this.createChildren([i]);
417
530
  c.insertAdjacentElement("afterend", r), this.linkDiv(), t || this.editTopic(c.firstChild), this.selectNode(c.firstChild, !0), this.bus.fire("operation", {
418
531
  name: "insertParent",
419
532
  obj: s
420
533
  });
421
- }, Mt = function(e, t) {
534
+ }, Wt = function(e, t) {
422
535
  const n = e || this.currentNode;
423
536
  if (!n) return;
424
- const o = _e(this, n, t);
537
+ const o = Te(this, n, t);
425
538
  if (!o) return;
426
539
  const { newTop: s, newNodeObj: i } = o;
427
540
  this.bus.fire("operation", {
428
541
  name: "addChild",
429
542
  obj: i
430
543
  }), t || this.editTopic(s.firstChild), this.selectNode(s.firstChild, !0);
431
- }, Pt = function(e, t) {
432
- const n = Ee(e.nodeObj);
544
+ }, Yt = function(e, t) {
545
+ const n = we(e.nodeObj);
433
546
  xe(n);
434
- const o = _e(this, t, n);
547
+ const o = Te(this, t, n);
435
548
  if (!o) return;
436
549
  const { newNodeObj: s } = o;
437
550
  this.selectNode(this.findEle(s.id)), this.bus.fire("operation", {
438
551
  name: "copyNode",
439
552
  obj: s
440
553
  });
441
- }, Ot = function(e, t) {
554
+ }, Xt = function(e, t) {
442
555
  const n = [];
443
556
  for (let o = 0; o < e.length; o++) {
444
- const s = e[o], i = Ee(s.nodeObj);
557
+ const s = e[o], i = we(s.nodeObj);
445
558
  xe(i);
446
- const l = _e(this, t, i);
559
+ const l = Te(this, t, i);
447
560
  if (!l) return;
448
561
  const { newNodeObj: c } = l;
449
562
  n.push(c);
@@ -452,51 +565,51 @@ const _t = function({ map: e, direction: t }, n) {
452
565
  name: "copyNodes",
453
566
  objs: n
454
567
  });
455
- }, $t = function(e) {
568
+ }, Ft = function(e) {
456
569
  const t = e || this.currentNode;
457
570
  if (!t) return;
458
571
  const n = t.nodeObj;
459
- Et(n);
572
+ At(n);
460
573
  const o = t.parentNode.parentNode;
461
574
  o.parentNode.insertBefore(o, o.previousSibling), this.linkDiv(), this.bus.fire("operation", {
462
575
  name: "moveUpNode",
463
576
  obj: n
464
577
  });
465
- }, Ht = function(e) {
578
+ }, Gt = function(e) {
466
579
  const t = e || this.currentNode;
467
580
  if (!t) return;
468
581
  const n = t.nodeObj;
469
- Ct(n);
582
+ Mt(n);
470
583
  const o = t.parentNode.parentNode;
471
584
  o.nextSibling ? o.nextSibling.insertAdjacentElement("afterend", o) : o.parentNode.prepend(o), this.linkDiv(), this.bus.fire("operation", {
472
585
  name: "moveDownNode",
473
586
  obj: n
474
587
  });
475
- }, jt = function(e) {
476
- if (e = Ce(e), e.length === 0) return;
588
+ }, zt = function(e) {
589
+ if (e = Ee(e), e.length === 0) return;
477
590
  for (const n of e) {
478
- const o = n.nodeObj, s = et(o);
479
- kt(n, s);
591
+ const o = n.nodeObj, s = nt(o);
592
+ jt(n, s);
480
593
  }
481
594
  const t = e[e.length - 1];
482
595
  this.selectNode(this.findEle(t.nodeObj.parent.id)), this.linkDiv(), this.bus.fire("operation", {
483
596
  name: "removeNodes",
484
597
  objs: e.map((n) => n.nodeObj)
485
598
  });
486
- }, ke = (e, t, n, o) => {
487
- e = Ce(e);
599
+ }, _e = (e, t, n, o) => {
600
+ e = Ee(e);
488
601
  let s = n.nodeObj;
489
602
  t === "in" && s.expanded === !1 && (o.expandNode(n, !0), n = o.findEle(s.id), s = n.nodeObj), t === "after" && (e = e.reverse());
490
603
  const i = [];
491
604
  for (const c of e) {
492
605
  const r = c.nodeObj;
493
- if (Tt(t, r, s), V(o.nodeData), t === "in") {
606
+ if ($t(t, r, s), G(o.nodeData), t === "in") {
494
607
  const a = c.parentElement;
495
- tt(o, n, a.parentElement);
608
+ ot(o, n, a.parentElement);
496
609
  } else {
497
- ee(c);
610
+ ne(c);
498
611
  const a = c.parentElement.parentNode;
499
- i.includes(a.parentElement) || i.push(a.parentElement), n.parentElement.parentNode.insertAdjacentElement(nt[t], a);
612
+ i.includes(a.parentElement) || i.push(a.parentElement), n.parentElement.parentNode.insertAdjacentElement(st[t], a);
500
613
  }
501
614
  }
502
615
  for (const c of i)
@@ -508,36 +621,36 @@ const _t = function({ map: e, direction: t }, n) {
508
621
  objs: e.map((c) => c.nodeObj),
509
622
  toObj: s
510
623
  });
511
- }, It = function(e, t) {
512
- ke(e, "in", t, this);
513
- }, Rt = function(e, t) {
514
- ke(e, "before", t, this);
515
- }, Bt = function(e, t) {
516
- ke(e, "after", t, this);
517
- }, Yt = function(e) {
624
+ }, Kt = function(e, t) {
625
+ _e(e, "in", t, this);
626
+ }, Vt = function(e, t) {
627
+ _e(e, "before", t, this);
628
+ }, qt = function(e, t) {
629
+ _e(e, "after", t, this);
630
+ }, Ut = function(e) {
518
631
  const t = e || this.currentNode;
519
632
  t && (t.nodeObj.dangerouslySetInnerHTML || this.editTopic(t));
520
- }, Wt = function(e, t) {
633
+ }, Jt = function(e, t) {
521
634
  e.text.textContent = t, e.nodeObj.topic = t, this.linkDiv();
522
- }, ot = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
635
+ }, it = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
523
636
  __proto__: null,
524
- addChild: Mt,
525
- beginEdit: Yt,
526
- copyNode: Pt,
527
- copyNodes: Ot,
528
- insertParent: At,
529
- insertSibling: Dt,
530
- moveDownNode: Ht,
531
- moveNodeAfter: Bt,
532
- moveNodeBefore: Rt,
533
- moveNodeIn: It,
534
- moveUpNode: $t,
535
- removeNodes: jt,
536
- reshapeNode: Lt,
537
- rmSubline: ee,
538
- setNodeTopic: Wt
637
+ addChild: Wt,
638
+ beginEdit: Ut,
639
+ copyNode: Yt,
640
+ copyNodes: Xt,
641
+ insertParent: Bt,
642
+ insertSibling: Rt,
643
+ moveDownNode: Gt,
644
+ moveNodeAfter: qt,
645
+ moveNodeBefore: Vt,
646
+ moveNodeIn: Kt,
647
+ moveUpNode: Ft,
648
+ removeNodes: zt,
649
+ reshapeNode: It,
650
+ rmSubline: ne,
651
+ setNodeTopic: Jt
539
652
  }, Symbol.toStringTag, { value: "Module" }));
540
- function Xt(e) {
653
+ function Zt(e) {
541
654
  return {
542
655
  nodeData: e.isFocusMode ? e.nodeDataBackup : e.nodeData,
543
656
  arrows: e.arrows,
@@ -546,49 +659,49 @@ function Xt(e) {
546
659
  theme: e.theme
547
660
  };
548
661
  }
549
- const Ft = function(e) {
662
+ const Qt = function(e) {
550
663
  const t = this.container, n = e.getBoundingClientRect(), o = t.getBoundingClientRect();
551
664
  if (n.top > o.bottom - 50 || n.bottom < o.top + 50 || n.left > o.right - 50 || n.right < o.left + 50) {
552
665
  const i = n.left + n.width / 2, l = n.top + n.height / 2, c = o.left + o.width / 2, r = o.top + o.height / 2, a = i - c, d = l - r;
553
666
  this.move(-a, -d, !0);
554
667
  }
555
- }, Gt = function(e, t, n) {
668
+ }, en = function(e, t, n) {
556
669
  this.clearSelection(), this.scrollIntoView(e), this.selection?.select(e), t && this.bus.fire("selectNewNode", e.nodeObj);
557
- }, Vt = function(e) {
670
+ }, tn = function(e) {
558
671
  this.selection?.select(e);
559
- }, zt = function(e) {
672
+ }, nn = function(e) {
560
673
  this.selection?.deselect(e);
561
- }, Kt = function() {
674
+ }, on = function() {
562
675
  this.unselectNodes(this.currentNodes), this.unselectSummary(), this.unselectArrow();
563
- }, Le = function(e) {
676
+ }, ke = function(e) {
564
677
  return JSON.stringify(e, (t, n) => {
565
678
  if (!(t === "parent" && typeof n != "string"))
566
679
  return n;
567
680
  });
568
- }, qt = function() {
569
- const e = Xt(this);
570
- return Le(e);
571
- }, Ut = function() {
681
+ }, sn = function() {
682
+ const e = Zt(this);
683
+ return ke(e);
684
+ }, rn = function() {
572
685
  return JSON.parse(this.getDataString());
573
- }, Jt = function() {
686
+ }, ln = function() {
574
687
  this.editable = !0;
575
- }, Zt = function() {
688
+ }, cn = function() {
576
689
  this.editable = !1;
577
- }, Qt = function(e, t = { x: 0, y: 0 }) {
690
+ }, an = function(e, t = { x: 0, y: 0 }) {
578
691
  if (e < this.scaleMin && e < this.scaleVal || e > this.scaleMax && e > this.scaleVal) return;
579
- const n = this.container.getBoundingClientRect(), o = t.x ? t.x - n.left - n.width / 2 : 0, s = t.y ? t.y - n.top - n.height / 2 : 0, { dx: i, dy: l } = De(this), c = this.map.style.transform, { x: r, y: a } = Se(c), d = r - i, h = a - l, u = this.scaleVal, y = (-o + d) * (1 - e / u), b = (-s + h) * (1 - e / u);
692
+ const n = this.container.getBoundingClientRect(), o = t.x ? t.x - n.left - n.width / 2 : 0, s = t.y ? t.y - n.top - n.height / 2 : 0, { dx: i, dy: l } = Le(this), c = this.map.style.transform, { x: r, y: a } = Ce(c), d = r - i, h = a - l, u = this.scaleVal, y = (-o + d) * (1 - e / u), b = (-s + h) * (1 - e / u);
580
693
  this.map.style.transform = `translate3d(${r - y}px, ${a - b}px, 0) scale(${e})`, this.scaleVal = e, this.bus.fire("scale", e);
581
- }, en = function() {
694
+ }, dn = function() {
582
695
  const e = this.nodes.offsetHeight / this.container.offsetHeight, t = this.nodes.offsetWidth / this.container.offsetWidth, n = 1 / Math.max(1, Math.max(e, t));
583
696
  this.scaleVal = n;
584
- const { dx: o, dy: s } = De(this, !0);
697
+ const { dx: o, dy: s } = Le(this, !0);
585
698
  this.map.style.transform = `translate3d(${o}px, ${s}px, 0) scale(${n})`, this.bus.fire("scale", n);
586
- }, tn = function(e, t, n = !1) {
699
+ }, hn = function(e, t, n = !1) {
587
700
  const { map: o, scaleVal: s, bus: i, container: l, nodes: c } = this;
588
701
  if (n && o.style.transition === "transform 0.3s")
589
702
  return;
590
703
  const r = o.style.transform;
591
- let { x: a, y: d } = Se(r);
704
+ let { x: a, y: d } = Ce(r);
592
705
  const h = l.getBoundingClientRect(), u = c.getBoundingClientRect(), y = u.left < h.right && u.right > h.left, b = u.top < h.bottom && u.bottom > h.top;
593
706
  if (y) {
594
707
  const p = u.left + e, g = u.right + e;
@@ -601,7 +714,7 @@ const Ft = function(e) {
601
714
  a += e, d += t, n && (o.style.transition = "transform 0.3s", setTimeout(() => {
602
715
  o.style.transition = "none";
603
716
  }, 300)), o.style.transform = `translate3d(${a}px, ${d}px, 0) scale(${s})`, i.fire("move", { dx: e, dy: t });
604
- }, De = (e, t = !1) => {
717
+ }, Le = (e, t = !1) => {
605
718
  const { container: n, map: o, nodes: s } = e;
606
719
  let i, l;
607
720
  if (e.alignment === "nodes" || t)
@@ -611,29 +724,29 @@ const Ft = function(e) {
611
724
  i = n.offsetWidth / 2 - a - d / 2, l = n.offsetHeight / 2 - r - h / 2, o.style.transformOrigin = `${a + d / 2}px 50%`;
612
725
  }
613
726
  return { dx: i, dy: l };
614
- }, nn = function() {
615
- const { map: e, container: t } = this, { dx: n, dy: o } = De(this);
727
+ }, fn = function() {
728
+ const { map: e, container: t } = this, { dx: n, dy: o } = Le(this);
616
729
  t.scrollTop = 0, t.scrollLeft = 0, e.style.transform = `translate3d(${n}px, ${o}px, 0) scale(${this.scaleVal})`;
617
- }, on = function(e) {
730
+ }, un = function(e) {
618
731
  e(this);
619
- }, sn = function(e) {
732
+ }, pn = function(e) {
620
733
  e.nodeObj.parent && (this.clearSelection(), this.tempDirection === null && (this.tempDirection = this.direction), this.isFocusMode || (this.nodeDataBackup = this.nodeData, this.isFocusMode = !0), this.nodeData = e.nodeObj, this.initRight(), this.toCenter());
621
- }, rn = function() {
734
+ }, gn = function() {
622
735
  this.isFocusMode = !1, this.tempDirection !== null && (this.nodeData = this.nodeDataBackup, this.direction = this.tempDirection, this.tempDirection = null, this.refresh(), this.toCenter());
623
- }, ln = function() {
736
+ }, mn = function() {
624
737
  this.direction = 0, this.refresh(), this.toCenter(), this.bus.fire("changeDirection", this.direction);
625
- }, cn = function() {
738
+ }, yn = function() {
626
739
  this.direction = 1, this.refresh(), this.toCenter(), this.bus.fire("changeDirection", this.direction);
627
- }, an = function() {
740
+ }, bn = function() {
628
741
  this.direction = 2, this.refresh(), this.toCenter(), this.bus.fire("changeDirection", this.direction);
629
- }, dn = function(e, t) {
742
+ }, vn = function(e, t) {
630
743
  const n = e.nodeObj;
631
744
  typeof t == "boolean" ? n.expanded = t : n.expanded !== !1 ? n.expanded = !1 : n.expanded = !0;
632
745
  const o = e.getBoundingClientRect(), s = {
633
746
  x: o.left,
634
747
  y: o.top
635
748
  }, i = e.parentNode, l = i.children[1];
636
- if (l.expanded = n.expanded, l.className = n.expanded ? "minus" : "", ee(e), n.expanded) {
749
+ if (l.expanded = n.expanded, l.className = n.expanded ? "minus" : "", ne(e), n.expanded) {
637
750
  const h = this.createChildren(
638
751
  n.children.map((u) => this.createWrapper(u).grp)
639
752
  );
@@ -646,7 +759,7 @@ const Ft = function(e) {
646
759
  y: c.top
647
760
  }, a = s.x - r.x, d = s.y - r.y;
648
761
  this.move(a, d), this.bus.fire("expandNode", n);
649
- }, hn = function(e, t) {
762
+ }, xn = function(e, t) {
650
763
  const n = e.nodeObj, o = e.getBoundingClientRect(), s = {
651
764
  x: o.left,
652
765
  y: o.top
@@ -657,71 +770,78 @@ const Ft = function(e) {
657
770
  y: i.top
658
771
  }, c = s.x - l.x, r = s.y - l.y;
659
772
  this.move(c, r);
660
- }, fn = function(e) {
661
- this.clearSelection(), e && (e = JSON.parse(JSON.stringify(e)), this.nodeData = e.nodeData, this.arrows = e.arrows || [], this.summaries = e.summaries || [], e.theme && this.changeTheme(e.theme)), V(this.nodeData), this.layout(), this.linkDiv();
662
- }, un = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
773
+ }, wn = function(e) {
774
+ this.clearSelection(), e && (e = JSON.parse(JSON.stringify(e)), this.nodeData = e.nodeData, this.arrows = e.arrows || [], this.summaries = e.summaries || [], e.theme && this.changeTheme(e.theme)), G(this.nodeData), this.layout(), this.linkDiv();
775
+ }, En = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
663
776
  __proto__: null,
664
- cancelFocus: rn,
665
- clearSelection: Kt,
666
- disableEdit: Zt,
667
- enableEdit: Jt,
668
- expandNode: dn,
669
- expandNodeAll: hn,
670
- focusNode: sn,
671
- getData: Ut,
672
- getDataString: qt,
673
- initLeft: ln,
674
- initRight: cn,
675
- initSide: an,
676
- install: on,
677
- move: tn,
678
- refresh: fn,
679
- scale: Qt,
680
- scaleFit: en,
681
- scrollIntoView: Ft,
682
- selectNode: Gt,
683
- selectNodes: Vt,
684
- stringifyData: Le,
685
- toCenter: nn,
686
- unselectNodes: zt
687
- }, Symbol.toStringTag, { value: "Module" })), Oe = "MIND-ELIXIR-WAIT-COPY", pn = (e, t) => {
777
+ cancelFocus: gn,
778
+ clearSelection: on,
779
+ disableEdit: cn,
780
+ enableEdit: ln,
781
+ expandNode: vn,
782
+ expandNodeAll: xn,
783
+ focusNode: pn,
784
+ getData: rn,
785
+ getDataString: sn,
786
+ initLeft: mn,
787
+ initRight: yn,
788
+ initSide: bn,
789
+ install: un,
790
+ move: hn,
791
+ refresh: wn,
792
+ scale: an,
793
+ scaleFit: dn,
794
+ scrollIntoView: Qt,
795
+ selectNode: en,
796
+ selectNodes: tn,
797
+ stringifyData: ke,
798
+ toCenter: fn,
799
+ unselectNodes: nn
800
+ }, Symbol.toStringTag, { value: "Module" })), $e = "MIND-ELIXIR-WAIT-COPY", Cn = 40, Sn = 10, Nn = ({ deltaMode: e, deltaY: t, viewportHeight: n }) => e === WheelEvent.DOM_DELTA_LINE ? t * Cn : e === WheelEvent.DOM_DELTA_PAGE ? t * n : t, Tn = ({ deltaMode: e, deltaY: t, scaleSensitivity: n, viewportHeight: o }) => {
801
+ const i = -Nn({ deltaMode: e, deltaY: t, viewportHeight: o }) / Sn * n;
802
+ return Math.max(-n, Math.min(n, i));
803
+ }, rt = (e, t, n) => {
804
+ t !== 0 && e.scale(e.scaleVal + t, n);
805
+ }, _n = (e, t) => {
688
806
  const n = e.map.querySelectorAll(`.${t}>me-wrapper>me-parent>me-tpc`);
689
807
  n.length !== 0 && e.selectNode(n[Math.ceil(n.length / 2) - 1]);
690
- }, gn = (e) => {
808
+ }, kn = (e) => {
691
809
  e.selectNode(e.map.querySelector("me-root>me-tpc"));
692
- }, mn = function(e, t) {
810
+ }, Ln = function(e, t) {
693
811
  const n = t.parentElement.parentElement.parentElement.previousSibling;
694
812
  if (n) {
695
813
  const o = n.firstChild;
696
814
  e.selectNode(o);
697
815
  }
698
- }, yn = function(e, t) {
816
+ }, Dn = function(e, t) {
699
817
  const n = t.parentElement.nextSibling;
700
818
  if (n && n.firstChild) {
701
819
  const o = n.firstChild.firstChild.firstChild;
702
820
  e.selectNode(o);
703
821
  }
704
- }, $e = function(e, t) {
822
+ }, He = function(e, t) {
705
823
  const n = e.currentNode || e.currentNodes?.[0];
706
824
  if (!n) return;
707
825
  const o = n.nodeObj, s = n.offsetParent.offsetParent.parentElement;
708
- o.parent ? s.className === t ? yn(e, n) : o.parent?.parent ? mn(e, n) : gn(e) : pn(e, t);
709
- }, He = function(e, t) {
826
+ o.parent ? s.className === t ? Dn(e, n) : o.parent?.parent ? Ln(e, n) : kn(e) : _n(e, t);
827
+ }, je = function(e, t) {
710
828
  const n = e.currentNode;
711
829
  if (!n || !n.nodeObj.parent) return;
712
830
  const s = t + "Sibling", i = n.parentElement.parentElement[s];
713
831
  i ? e.selectNode(i.firstChild.firstChild) : e.selectNode(n);
714
- }, ae = function(e, t, n) {
715
- const { scaleVal: o, scaleSensitivity: s } = e;
716
- switch (t) {
717
- case "in":
718
- e.scale(o + s, n);
719
- break;
720
- case "out":
721
- e.scale(o - s, n);
722
- }
832
+ }, Ie = function(e, t, n) {
833
+ const o = t === "in" ? e.scaleSensitivity : -e.scaleSensitivity;
834
+ rt(e, o, n);
835
+ }, An = (e, t) => {
836
+ const n = Tn({
837
+ deltaMode: t.deltaMode,
838
+ deltaY: t.deltaY,
839
+ scaleSensitivity: e.scaleSensitivity,
840
+ viewportHeight: e.container.clientHeight || window.innerHeight
841
+ });
842
+ rt(e, n, { x: t.clientX, y: t.clientY });
723
843
  };
724
- function bn(e, t) {
844
+ function Mn(e, t) {
725
845
  t = t === !0 ? {} : t;
726
846
  const n = () => {
727
847
  e.currentArrow ? e.removeArrow() : e.currentSummary ? e.removeSummary(e.currentSummary.summaryObj.id) : e.currentNodes && e.removeNodes(e.currentNodes);
@@ -758,31 +878,31 @@ function bn(e, t) {
758
878
  else {
759
879
  if (r.metaKey || r.ctrlKey)
760
880
  return e.initSide();
761
- He(e, "previous");
881
+ je(e, "previous");
762
882
  }
763
883
  },
764
884
  ArrowDown: (r) => {
765
- r.altKey ? e.moveDownNode() : He(e, "next");
885
+ r.altKey ? e.moveDownNode() : je(e, "next");
766
886
  },
767
887
  ArrowLeft: (r) => {
768
888
  if (r.metaKey || r.ctrlKey)
769
889
  return e.initLeft();
770
- $e(e, B.LHS);
890
+ He(e, B.LHS);
771
891
  },
772
892
  ArrowRight: (r) => {
773
893
  if (r.metaKey || r.ctrlKey)
774
894
  return e.initRight();
775
- $e(e, B.RHS);
895
+ He(e, B.RHS);
776
896
  },
777
897
  PageUp: () => e.moveUpNode(),
778
898
  PageDown: () => {
779
899
  e.moveDownNode();
780
900
  },
781
901
  "=": (r) => {
782
- (r.metaKey || r.ctrlKey) && ae(e, "in");
902
+ (r.metaKey || r.ctrlKey) && Ie(e, "in");
783
903
  },
784
904
  "-": (r) => {
785
- (r.metaKey || r.ctrlKey) && ae(e, "out");
905
+ (r.metaKey || r.ctrlKey) && Ie(e, "out");
786
906
  },
787
907
  0: (r) => {
788
908
  if (r.metaKey || r.ctrlKey) {
@@ -808,8 +928,8 @@ function bn(e, t) {
808
928
  const c = (r) => {
809
929
  if (r.target instanceof HTMLElement && r.target.id === "input-box" || e.currentNodes.length === 0) return !1;
810
930
  if (r.clipboardData) {
811
- const a = Ce(e.currentNodes).map((h) => h.nodeObj), d = Le({
812
- magic: Oe,
931
+ const a = Ee(e.currentNodes).map((h) => h.nodeObj), d = ke({
932
+ magic: $e,
813
933
  data: a
814
934
  });
815
935
  return r.clipboardData.setData("text/plain", d), r.preventDefault(), !0;
@@ -823,7 +943,7 @@ function bn(e, t) {
823
943
  if (a)
824
944
  try {
825
945
  const d = JSON.parse(a);
826
- if (d && d.magic === Oe && Array.isArray(d.data)) {
946
+ if (d && d.magic === $e && Array.isArray(d.data)) {
827
947
  const h = d.data, u = h.map((y) => ({ nodeObj: y }));
828
948
  h.length > 0 && e.currentNode && (e.copyNodes(u, e.currentNode), r.preventDefault());
829
949
  return;
@@ -833,158 +953,42 @@ function bn(e, t) {
833
953
  e.pasteHandler && e.pasteHandler(r);
834
954
  });
835
955
  }
836
- const vn = function(e, t) {
837
- if (!t)
838
- return he(e), e;
839
- let n = e.querySelector(".insert-preview");
840
- const o = `insert-preview ${t} show`;
841
- return n || (n = document.createElement("div"), e.appendChild(n)), n.className = o, e;
842
- }, he = function(e) {
843
- if (!e) return;
844
- const t = e.querySelectorAll(".insert-preview");
845
- for (const n of t || [])
846
- n.remove();
847
- }, je = function(e, t) {
848
- for (const n of t) {
849
- const o = n.parentElement.parentElement.contains(e);
850
- if (!(e && e.tagName === "ME-TPC" && e !== n && !o && e.nodeObj.parent)) return !1;
851
- }
852
- return !0;
853
- }, wn = function(e) {
854
- const t = document.createElement("div");
855
- return t.className = "mind-elixir-ghost", e.container.appendChild(t), t;
856
- };
857
- class xn {
858
- mind;
859
- isMoving = !1;
860
- interval = null;
861
- speed = 20;
862
- constructor(t) {
863
- this.mind = t;
864
- }
865
- move(t, n) {
866
- this.isMoving || (this.isMoving = !0, this.interval = setInterval(() => {
867
- this.mind.move(t * this.speed * this.mind.scaleVal, n * this.speed * this.mind.scaleVal);
868
- }, 100));
869
- }
870
- stop() {
871
- this.isMoving = !1, this.interval && (clearInterval(this.interval), this.interval = null);
872
- }
873
- }
874
- function En(e) {
875
- return {
876
- isDragging: !1,
877
- insertType: null,
878
- meet: null,
879
- ghost: wn(e),
880
- edgeMoveController: new xn(e),
881
- startX: 0,
882
- startY: 0,
883
- pointerId: null
884
- };
885
- }
886
- const Cn = 5;
887
- function Ie(e, t, n, o = !1) {
888
- if (e.spacePressed) return !1;
889
- const s = n.target;
890
- if (s?.tagName !== "ME-TPC" || !s.nodeObj.parent) return !1;
891
- t.startX = n.clientX, t.startY = n.clientY, t.pointerId = n.pointerId, e.selection?.cancel();
892
- let i = e.currentNodes;
893
- return i?.includes(s) || (e.selectNode(s), i = e.currentNodes), e.dragged = i, o && it(e, t), !0;
894
- }
895
- function st(e, t, n) {
896
- e.style.transform = `translate(${t - 10}px, ${n - 10}px)`, e.style.display = "block";
897
- }
898
- function it(e, t) {
899
- const { dragged: n } = e;
900
- if (!n) return;
901
- const o = document.activeElement;
902
- o && o.isContentEditable && o.blur(), t.isDragging = !0, n.length > 1 ? t.ghost.innerHTML = n.length + "" : t.ghost.innerHTML = n[0].innerHTML;
903
- for (const s of n)
904
- s.parentElement.parentElement.style.opacity = "0.5";
905
- e.dragMoveHelper.clear();
906
- }
907
- function Sn(e, t, n) {
908
- const { dragged: o } = e;
909
- if (!o || t.pointerId !== n.pointerId) return;
910
- const s = n.clientX - t.startX, i = n.clientY - t.startY, l = Math.sqrt(s * s + i * i);
911
- if (!t.isDragging && l > Cn && it(e, t), !t.isDragging) return;
912
- const c = e.container.getBoundingClientRect();
913
- st(t.ghost, n.clientX - c.x, n.clientY - c.y), n.clientX < c.x + 50 ? t.edgeMoveController.move(1, 0) : n.clientX > c.x + c.width - 50 ? t.edgeMoveController.move(-1, 0) : n.clientY < c.y + 50 ? t.edgeMoveController.move(0, 1) : n.clientY > c.y + c.height - 50 ? t.edgeMoveController.move(0, -1) : t.edgeMoveController.stop(), he(t.meet);
914
- const r = 12 * e.scaleVal, a = document.elementFromPoint(n.clientX, n.clientY - r);
915
- if (je(a, o)) {
916
- t.meet = a;
917
- const d = a.getBoundingClientRect(), h = d.y;
918
- n.clientY > h + d.height ? t.insertType = "after" : t.insertType = "in";
919
- } else {
920
- const d = document.elementFromPoint(n.clientX, n.clientY + r);
921
- if (je(d, o)) {
922
- t.meet = d;
923
- const u = d.getBoundingClientRect().y;
924
- n.clientY < u ? t.insertType = "before" : t.insertType = "in";
925
- } else
926
- t.insertType = null, t.meet = null;
927
- }
928
- t.meet && vn(t.meet, t.insertType);
929
- }
930
- function Nn(e, t, n) {
931
- const { dragged: o } = e;
932
- if (!(!o || t.pointerId !== n.pointerId)) {
933
- t.edgeMoveController.stop();
934
- for (const s of o)
935
- s.parentElement.parentElement.style.opacity = "1";
936
- t.ghost.style.display = "none", t.ghost.innerHTML = "", t.isDragging && t.meet && (he(t.meet), t.insertType === "before" ? e.moveNodeBefore(o, t.meet) : t.insertType === "after" ? e.moveNodeAfter(o, t.meet) : t.insertType === "in" && e.moveNodeIn(o, t.meet)), e.dragged = null, t.isDragging = !1, t.insertType = null, t.meet = null, t.pointerId = null;
937
- }
938
- }
939
- function pe(e, t) {
940
- const { dragged: n } = e;
941
- if (n) {
942
- t.edgeMoveController.stop();
943
- for (const o of n)
944
- o.parentElement.parentElement.style.opacity = "1";
945
- t.meet && he(t.meet), t.ghost.style.display = "none", t.ghost.innerHTML = "", e.dragged = null, t.isDragging = !1, t.insertType = null, t.meet = null, t.pointerId = null;
946
- }
947
- }
948
- function Tn(e) {
949
- return () => {
950
- };
951
- }
952
- function _n(e) {
953
- const { dragMoveHelper: t } = e;
954
- let n = 0;
956
+ function Pn(e) {
957
+ const { panHelper: t } = e;
958
+ let n = 0, o = null;
955
959
  e.spacePressed = !1;
956
- let o = null;
957
- const s = /* @__PURE__ */ new Map(), i = En(e);
958
- let l = null, c = null, r = null, a = null;
959
- const d = 500, h = 10, u = () => {
960
- l !== null && (clearTimeout(l), l = null, c = null, r = null, a = null);
961
- }, y = (f, w) => {
962
- f.hasPointerCapture && f.hasPointerCapture(w) && f.releasePointerCapture(w);
963
- }, b = (f, w) => {
960
+ let s = null;
961
+ const i = /* @__PURE__ */ new Map(), l = bt(e);
962
+ let c = null, r = null, a = null, d = null;
963
+ const h = 500, u = 10, y = () => {
964
+ c !== null && (clearTimeout(c), c = null, r = null, a = null, d = null);
965
+ }, b = (f, x) => {
966
+ f.hasPointerCapture && f.hasPointerCapture(x) && f.releasePointerCapture(x);
967
+ }, p = (f, x) => {
964
968
  if (f.id === "input-box" || f.closest("#input-box")) return !1;
965
969
  const T = f.closest(".svg-label");
966
970
  if (T) {
967
- const M = T.dataset.svgId, te = T.dataset.type, Z = document.getElementById(M);
968
- if (Z) {
969
- if (te === "arrow")
970
- return w ? e.editArrowLabel(Z) : e.selectArrow(Z), !0;
971
- if (te === "summary")
972
- return w ? e.editSummary(Z) : e.selectSummary(Z), !0;
971
+ const D = T.dataset.svgId, Z = T.dataset.type, Q = document.getElementById(D);
972
+ if (Q) {
973
+ if (Z === "arrow")
974
+ return x ? e.editArrowLabel(Q) : e.selectArrow(Q), !0;
975
+ if (Z === "summary")
976
+ return x ? e.editSummary(Q) : e.selectSummary(Q), !0;
973
977
  }
974
978
  }
975
979
  if (f.closest(".topiclinks")) {
976
- const M = f.closest("g");
977
- if (M)
978
- return w ? e.editArrowLabel(M) : e.selectArrow(M), !0;
980
+ const D = f.closest("g");
981
+ if (D)
982
+ return x ? e.editArrowLabel(D) : e.selectArrow(D), !0;
979
983
  }
980
984
  if (f.closest(".summary")) {
981
- const M = f.closest("g");
982
- if (M)
983
- return w ? e.editSummary(M) : e.selectSummary(M), !0;
985
+ const D = f.closest("g");
986
+ if (D)
987
+ return x ? e.editSummary(D) : e.selectSummary(D), !0;
984
988
  }
985
989
  return !1;
986
- }, p = (f) => {
987
- if (f.button !== 0) return;
990
+ }, g = (f) => {
991
+ if (f.pointerType === "mouse" && f.button !== 0) return;
988
992
  if (e.helper1?.moved) {
989
993
  e.helper1.clear();
990
994
  return;
@@ -997,116 +1001,125 @@ function _n(e) {
997
1001
  t.clear();
998
1002
  return;
999
1003
  }
1000
- if (i?.isDragging)
1004
+ if (l?.isDragging)
1001
1005
  return;
1002
- const w = f.target;
1003
- if (w.tagName === "ME-EPD")
1004
- f.ctrlKey || f.metaKey ? e.expandNodeAll(w.previousSibling) : e.expandNode(w.previousSibling);
1005
- else if (w.tagName === "ME-TPC" && e.currentNodes.length > 1)
1006
- e.selectNode(w);
1006
+ const x = f.target;
1007
+ if (x.tagName === "ME-EPD")
1008
+ f.ctrlKey || f.metaKey ? e.expandNodeAll(x.previousSibling) : e.expandNode(x.previousSibling);
1007
1009
  else if (!e.editable)
1008
1010
  return;
1009
- b(w, !1);
1010
- }, g = (f) => {
1011
- if (!e.editable) return;
1012
- const w = f.target;
1013
- re(w) && e.beginEdit(w), b(w, !0);
1011
+ p(x, !1);
1014
1012
  }, m = (f) => {
1015
- if (f.pointerType === "mouse" || s.size > 1) return;
1016
- const w = (/* @__PURE__ */ new Date()).getTime(), T = w - n;
1017
- T < 300 && T > 0 && g(f), n = w;
1013
+ if (!e.editable) return;
1014
+ const x = f.target;
1015
+ ee(x) && e.beginEdit(x), p(x, !0);
1018
1016
  }, v = (f) => {
1019
1017
  f.code === "Space" && (e.spacePressed = !0, e.container.classList.add("space-pressed"));
1020
1018
  }, E = (f) => {
1021
1019
  f.code === "Space" && (e.spacePressed = !1, e.container.classList.remove("space-pressed"));
1022
1020
  }, k = (f) => {
1023
- if (f.pointerType === "touch" && (s.set(f.pointerId, { x: f.clientX, y: f.clientY }), s.size === 2)) {
1024
- const [M, te] = Array.from(s.values());
1025
- o = Pe(M, te), u();
1021
+ if (f.pointerType === "touch" && (i.set(f.pointerId, { x: f.clientX, y: f.clientY }), i.size === 2)) {
1022
+ const [D, Z] = Array.from(i.values());
1023
+ s = Me(D, Z), y();
1026
1024
  }
1027
1025
  t.moved = !1;
1028
- const w = f.target, T = e.mouseSelectionButton === 0 ? 2 : 0;
1029
- if (e.editable && i && (f.button === 0 || f.pointerType === "touch")) {
1030
- if (f.pointerType === "touch" && s.size > 1)
1031
- (i.isDragging || i.pointerId !== null) && pe(e, i);
1032
- else if (f.pointerType === "touch" && s.size === 1)
1033
- (re(w) || w.closest("me-tpc")) && (c = { x: f.clientX, y: f.clientY }, r = w, a = f.pointerId, l = window.setTimeout(() => {
1034
- Ie(e, i, f, !0) && (r && r.setPointerCapture(f.pointerId), st(i.ghost, f.clientX, f.clientY)), l = null, c = null, r = null, a = null;
1035
- }, d));
1036
- else if (f.pointerType === "mouse" && Ie(e, i, f, !1)) {
1037
- w.setPointerCapture(f.pointerId);
1026
+ const x = f.target, T = e.mouseSelectionButton === 0 ? 2 : 0;
1027
+ if (e.editable && (f.button === 0 || f.pointerType === "touch") && ee(x)) {
1028
+ e.selection?.cancel();
1029
+ const D = e.currentNodes || [];
1030
+ if (f.ctrlKey || f.metaKey)
1031
+ if (D.includes(x)) {
1032
+ e.selection?.deselect(x);
1033
+ return;
1034
+ } else
1035
+ e.selection?.select(x);
1036
+ else D.includes(x) || e.selectNode(x);
1037
+ }
1038
+ if (e.editable && (f.button === 0 || f.pointerType === "touch")) {
1039
+ if (f.pointerType === "touch" && i.size > 1)
1040
+ (l.isDragging || l.pointerId !== null) && ue(e, l);
1041
+ else if (f.pointerType === "touch" && i.size === 1)
1042
+ (ee(x) || x.closest("me-tpc")) && (r = { x: f.clientX, y: f.clientY }, a = x, d = f.pointerId, c = window.setTimeout(() => {
1043
+ Oe(e, l, f, !0) && (a && a.setPointerCapture(f.pointerId), Ze(l.ghost, f.clientX, f.clientY)), c = null, r = null, a = null, d = null;
1044
+ }, h));
1045
+ else if (f.pointerType === "mouse" && Oe(e, l, f, !1)) {
1046
+ x.setPointerCapture(f.pointerId);
1038
1047
  return;
1039
1048
  }
1040
1049
  }
1041
- const O = e.spacePressed && f.button === 0 && f.pointerType === "mouse", X = !e.editable || f.button === T && f.pointerType === "mouse" || f.pointerType === "touch";
1042
- !O && !X || (t.x = f.clientX, t.y = f.clientY, w.className !== "circle" && w.contentEditable !== "plaintext-only" && (t.mousedown = !0, w.setPointerCapture(f.pointerId)));
1050
+ const P = e.spacePressed && f.button === 0 && f.pointerType === "mouse", Y = !e.editable || f.button === T && f.pointerType === "mouse" || f.pointerType === "touch";
1051
+ !P && !Y || (t.x = f.clientX, t.y = f.clientY, x.className !== "circle" && x.contentEditable !== "plaintext-only" && (t.mousedown = !0, x.setPointerCapture(f.pointerId)));
1043
1052
  }, _ = (f) => {
1044
- if (f.pointerType === "touch" && s.has(f.pointerId)) {
1045
- if (s.set(f.pointerId, { x: f.clientX, y: f.clientY }), l !== null && c !== null && f.pointerId === a) {
1046
- const w = f.clientX - c.x, T = f.clientY - c.y;
1047
- Math.sqrt(w * w + T * T) > h && u();
1053
+ if (f.pointerType === "touch" && i.has(f.pointerId)) {
1054
+ if (i.set(f.pointerId, { x: f.clientX, y: f.clientY }), c !== null && r !== null && f.pointerId === d) {
1055
+ const x = f.clientX - r.x, T = f.clientY - r.y;
1056
+ Math.sqrt(x * x + T * T) > u && y();
1048
1057
  }
1049
- if (s.size >= 2) {
1050
- const [w, T] = Array.from(s.values()), O = Pe(w, T);
1051
- if (o == null)
1052
- o = O;
1058
+ if (i.size >= 2) {
1059
+ const [x, T] = Array.from(i.values()), P = Me(x, T);
1060
+ if (s == null)
1061
+ s = P;
1053
1062
  else {
1054
- if (o > 0) {
1055
- const X = O / o;
1056
- e.scale(e.scaleVal * X, {
1057
- x: (w.x + T.x) / 2,
1058
- y: (w.y + T.y) / 2
1063
+ if (s > 0) {
1064
+ const Y = P / s;
1065
+ e.scale(e.scaleVal * Y, {
1066
+ x: (x.x + T.x) / 2,
1067
+ y: (x.y + T.y) / 2
1059
1068
  });
1060
1069
  }
1061
- o = O;
1070
+ s = P;
1062
1071
  }
1063
1072
  return;
1064
1073
  }
1065
1074
  }
1066
- if (!(i && i.pointerId !== null && (Sn(e, i, f), i.isDragging))) {
1075
+ if (!(l && l.pointerId !== null && (xt(e, l, f), l.isDragging))) {
1067
1076
  if (f.target.contentEditable !== "plaintext-only" || e.spacePressed && t.mousedown) {
1068
- const w = f.clientX - t.x, T = f.clientY - t.y;
1069
- t.onMove(w, T);
1077
+ const x = f.clientX - t.x, T = f.clientY - t.y;
1078
+ t.onMove(x, T);
1070
1079
  }
1071
1080
  t.x = f.clientX, t.y = f.clientY;
1072
1081
  }
1073
1082
  }, C = (f) => {
1074
- if (f.pointerType === "touch" && (s.delete(f.pointerId), s.size < 2 && (o = null), u()), i && i.pointerId !== null) {
1075
- const w = i.isDragging;
1076
- if (Nn(e, i, f), y(f.target, f.pointerId), w)
1083
+ if (f.pointerType === "touch" && (i.delete(f.pointerId), i.size < 2 && (s = null), y()), l && l.pointerId !== null) {
1084
+ const T = l.isDragging;
1085
+ if (wt(e, l, f), b(f.target, f.pointerId), T)
1077
1086
  return;
1078
1087
  }
1079
- t.mousedown && (y(f.target, f.pointerId), t.clear());
1080
- }, x = () => {
1081
- u(), t.mousedown && t.clear(), i && (i.isDragging || i.pointerId !== null) && pe(e, i);
1088
+ if (f.pointerType === "touch" && i.size === 0 && !t.moved) {
1089
+ const T = (/* @__PURE__ */ new Date()).getTime(), P = T - n;
1090
+ P < 300 && P > 0 && o === f.target && m(f), n = T, o = f.target;
1091
+ }
1092
+ t.mousedown && (b(f.target, f.pointerId), t.clear());
1093
+ }, w = () => {
1094
+ y(), t.mousedown && t.clear(), l && (l.isDragging || l.pointerId !== null) && ue(e, l);
1082
1095
  }, N = (f) => {
1083
- f.pointerType === "touch" && (s.delete(f.pointerId), s.size < 2 && (o = null), u()), i && i.pointerId === f.pointerId && pe(e, i), C(f);
1096
+ f.pointerType === "touch" && (i.delete(f.pointerId), i.size < 2 && (s = null), y()), l && l.pointerId === f.pointerId && ue(e, l), C(f);
1084
1097
  }, S = (f) => {
1085
1098
  if (f.preventDefault(), f.button !== 2 || !e.editable) return;
1086
- const w = f.target;
1087
- re(w) && !w.classList.contains("selected") && e.selectNode(w), setTimeout(() => {
1088
- e.dragMoveHelper.moved || e.bus.fire("showContextMenu", f);
1099
+ const x = f.target;
1100
+ ee(x) && !x.classList.contains("selected") && e.selectNode(x), setTimeout(() => {
1101
+ e.panHelper.moved || e.bus.fire("showContextMenu", f);
1089
1102
  }, 200);
1090
- }, A = (f) => {
1091
- f.stopPropagation(), f.preventDefault(), f.ctrlKey || f.metaKey ? f.deltaY < 0 ? ae(e, "in", e.dragMoveHelper) : e.scaleVal - e.scaleSensitivity > 0 && ae(e, "out", e.dragMoveHelper) : f.shiftKey ? e.move(-f.deltaY, 0) : e.move(-f.deltaX, -f.deltaY);
1103
+ }, M = (f) => {
1104
+ if (f.stopPropagation(), f.preventDefault(), f.ctrlKey || f.metaKey) return An(e, f);
1105
+ if (f.shiftKey) return e.move(-f.deltaY, 0);
1106
+ e.move(-f.deltaX, -f.deltaY);
1092
1107
  }, { container: L } = e;
1093
1108
  return Je([
1094
1109
  { dom: L, evt: "pointerdown", func: k },
1095
1110
  { dom: L, evt: "pointermove", func: _ },
1096
1111
  { dom: L, evt: "pointerup", func: C },
1097
1112
  { dom: L, evt: "pointercancel", func: N },
1098
- // Using pointerdown might cause iOS IME jitter, making it uneditable?
1099
- { dom: L, evt: "pointerup", func: m },
1100
- { dom: L, evt: "click", func: p },
1101
- { dom: L, evt: "dblclick", func: g },
1113
+ { dom: L, evt: "click", func: g },
1114
+ { dom: L, evt: "dblclick", func: m },
1102
1115
  { dom: L, evt: "contextmenu", func: S },
1103
- { dom: L, evt: "wheel", func: typeof e.handleWheel == "function" ? e.handleWheel : A },
1104
- { dom: L, evt: "blur", func: x },
1116
+ { dom: L, evt: "wheel", func: typeof e.handleWheel == "function" ? e.handleWheel : M },
1117
+ { dom: L, evt: "blur", func: w },
1105
1118
  { dom: L, evt: "keydown", func: v },
1106
1119
  { dom: L, evt: "keyup", func: E }
1107
1120
  ]);
1108
1121
  }
1109
- function kn() {
1122
+ function On() {
1110
1123
  return {
1111
1124
  handlers: {},
1112
1125
  addListener: function(e, t) {
@@ -1130,31 +1143,31 @@ function kn() {
1130
1143
  }
1131
1144
  };
1132
1145
  }
1133
- const j = "http://www.w3.org/2000/svg", fe = function(e) {
1146
+ const H = "http://www.w3.org/2000/svg", he = function(e) {
1134
1147
  const t = e.clientWidth, n = e.clientHeight, o = e.dataset, s = Number(o.x), i = Number(o.y), l = o.anchor;
1135
1148
  let c = s;
1136
1149
  l === "middle" ? c = s - t / 2 : l === "end" && (c = s - t), e.style.left = `${c}px`, e.style.top = `${i - n / 2}px`, e.style.visibility = "visible";
1137
- }, ye = function(e, t, n, o) {
1150
+ }, me = function(e, t, n, o) {
1138
1151
  const { anchor: s = "middle", color: i, dataType: l, svgId: c } = o, r = document.createElement("div");
1139
1152
  r.className = "svg-label", r.style.color = i || "#666";
1140
1153
  const a = "label-" + c;
1141
1154
  return r.id = a, r.innerHTML = e, r.dataset.type = l, r.dataset.svgId = c, r.dataset.x = t.toString(), r.dataset.y = n.toString(), r.dataset.anchor = s, r;
1142
- }, rt = function(e, t, n) {
1143
- const o = document.createElementNS(j, "path");
1144
- return D(o, {
1155
+ }, lt = function(e, t, n) {
1156
+ const o = document.createElementNS(H, "path");
1157
+ return A(o, {
1145
1158
  d: e,
1146
1159
  stroke: t || "#666",
1147
1160
  fill: "none",
1148
1161
  "stroke-width": n
1149
1162
  }), o;
1150
- }, Q = function(e) {
1151
- const t = document.createElementNS(j, "svg");
1163
+ }, te = function(e) {
1164
+ const t = document.createElementNS(H, "svg");
1152
1165
  return t.setAttribute("class", e), t.setAttribute("overflow", "visible"), t;
1153
1166
  }, Re = function() {
1154
- const e = document.createElementNS(j, "line");
1167
+ const e = document.createElementNS(H, "line");
1155
1168
  return e.setAttribute("stroke", "#4dc4ff"), e.setAttribute("fill", "none"), e.setAttribute("stroke-width", "2"), e.setAttribute("opacity", "0.45"), e;
1156
- }, Ln = function(e, t, n, o) {
1157
- const s = document.createElementNS(j, "g");
1169
+ }, $n = function(e, t, n, o) {
1170
+ const s = document.createElementNS(H, "g");
1158
1171
  return [
1159
1172
  {
1160
1173
  name: "line",
@@ -1169,30 +1182,30 @@ const j = "http://www.w3.org/2000/svg", fe = function(e) {
1169
1182
  d: n
1170
1183
  }
1171
1184
  ].forEach((l, c) => {
1172
- const r = l.d, a = document.createElementNS(j, "path"), d = {
1185
+ const r = l.d, a = document.createElementNS(H, "path"), d = {
1173
1186
  d: r,
1174
1187
  stroke: o?.stroke || "rgb(227, 125, 116)",
1175
1188
  fill: "none",
1176
1189
  "stroke-linecap": o?.strokeLinecap || "cap",
1177
1190
  "stroke-width": String(o?.strokeWidth || "2")
1178
1191
  };
1179
- o?.opacity !== void 0 && (d.opacity = String(o.opacity)), D(a, d), c === 0 && a.setAttribute("stroke-dasharray", o?.strokeDasharray || "8,2");
1180
- const h = document.createElementNS(j, "path");
1181
- D(h, {
1192
+ o?.opacity !== void 0 && (d.opacity = String(o.opacity)), A(a, d), c === 0 && a.setAttribute("stroke-dasharray", o?.strokeDasharray || "8,2");
1193
+ const h = document.createElementNS(H, "path");
1194
+ A(h, {
1182
1195
  d: r,
1183
1196
  stroke: "transparent",
1184
1197
  fill: "none",
1185
1198
  "stroke-width": "15"
1186
1199
  }), s.appendChild(h), s.appendChild(a), s[l.name] = a;
1187
1200
  }), s;
1188
- }, lt = function(e, t, n) {
1201
+ }, ct = function(e, t, n) {
1189
1202
  if (!t) return;
1190
1203
  const o = n.label, s = t.cloneNode(!0);
1191
1204
  e.nodes.appendChild(s), s.id = "input-box", s.textContent = o, s.contentEditable = "plaintext-only", s.spellcheck = !1, s.style.cssText = `
1192
1205
  left:${t.style.left};
1193
1206
  top:${t.style.top};
1194
1207
  max-width: 200px;
1195
- `, Qe(s), e.scrollIntoView(s), s.addEventListener("keydown", (i) => {
1208
+ `, tt(s), e.scrollIntoView(s), s.addEventListener("keydown", (i) => {
1196
1209
  i.stopPropagation();
1197
1210
  const l = i.key;
1198
1211
  if (l === "Enter" || l === "Tab") {
@@ -1202,7 +1215,7 @@ const j = "http://www.w3.org/2000/svg", fe = function(e) {
1202
1215
  }), s.addEventListener("blur", () => {
1203
1216
  if (!s) return;
1204
1217
  const i = s.innerText?.trim() || "";
1205
- i === "" ? n.label = o : n.label = i, s.remove(), i !== o && (e.markdown ? t.innerHTML = e.markdown(n.label, n) : t.textContent = n.label, fe(t), "parent" in n ? e.bus.fire("operation", {
1218
+ i === "" ? n.label = o : n.label = i, s.remove(), i !== o && (e.markdown ? t.innerHTML = e.markdown(n.label, n) : t.textContent = n.label, he(t), "parent" in n ? e.bus.fire("operation", {
1206
1219
  name: "finishEditSummary",
1207
1220
  obj: n
1208
1221
  }) : e.bus.fire("operation", {
@@ -1210,32 +1223,32 @@ const j = "http://www.w3.org/2000/svg", fe = function(e) {
1210
1223
  obj: n
1211
1224
  }));
1212
1225
  });
1213
- }, Dn = function(e) {
1226
+ }, Hn = function(e) {
1214
1227
  const t = this.map.querySelector("me-root"), n = t.offsetTop, o = t.offsetLeft, s = t.offsetWidth, i = t.offsetHeight, l = this.map.querySelectorAll("me-main > me-wrapper");
1215
1228
  this.lines.innerHTML = "";
1216
1229
  for (let c = 0; c < l.length; c++) {
1217
- const r = l[c], a = r.querySelector("me-tpc"), { offsetLeft: d, offsetTop: h } = H(this.nodes, a), u = a.offsetWidth, y = a.offsetHeight, b = r.parentNode.className, p = this.generateMainBranch({ pT: n, pL: o, pW: s, pH: i, cT: h, cL: d, cW: u, cH: y, direction: b, containerHeight: this.nodes.offsetHeight }), g = this.theme.palette, m = a.nodeObj.branchColor || g[c % g.length];
1218
- if (a.style.borderColor = m, this.lines.appendChild(rt(p, m, "3")), e && e !== r)
1230
+ const r = l[c], a = r.querySelector("me-tpc"), { offsetLeft: d, offsetTop: h } = $(this.nodes, a), u = a.offsetWidth, y = a.offsetHeight, b = r.parentNode.className, p = this.generateMainBranch({ pT: n, pL: o, pW: s, pH: i, cT: h, cL: d, cW: u, cH: y, direction: b, containerHeight: this.nodes.offsetHeight }), g = this.theme.palette, m = a.nodeObj.branchColor || g[c % g.length];
1231
+ if (a.style.borderColor = m, this.lines.appendChild(lt(p, m, "3")), e && e !== r)
1219
1232
  continue;
1220
- const v = Q("subLines"), E = r.lastChild;
1221
- E.tagName === "svg" && E.remove(), r.appendChild(v), ct(this, v, m, r, b, !0);
1233
+ const v = te("subLines"), E = r.lastChild;
1234
+ E.tagName === "svg" && E.remove(), r.appendChild(v), at(this, v, m, r, b, !0);
1222
1235
  }
1223
1236
  this.labelContainer.innerHTML = "", this.renderArrow(), this.renderSummary(), this.bus.fire("linkDiv");
1224
- }, ct = function(e, t, n, o, s, i) {
1237
+ }, at = function(e, t, n, o, s, i) {
1225
1238
  const l = o.firstChild, c = o.children[1].children;
1226
1239
  if (c.length === 0) return;
1227
1240
  const r = l.offsetTop, a = l.offsetLeft, d = l.offsetWidth, h = l.offsetHeight;
1228
1241
  for (let u = 0; u < c.length; u++) {
1229
1242
  const y = c[u], b = y.firstChild, p = b.offsetTop, g = b.offsetLeft, m = b.offsetWidth, v = b.offsetHeight, E = b.firstChild.nodeObj.branchColor || n, k = e.generateSubBranch({ pT: r, pL: a, pW: d, pH: h, cT: p, cL: g, cW: m, cH: v, direction: s, isFirst: i });
1230
- t.appendChild(rt(k, E, "2"));
1243
+ t.appendChild(lt(k, E, "2"));
1231
1244
  const _ = b.children[1];
1232
1245
  if (_) {
1233
1246
  if (!_.expanded) continue;
1234
1247
  } else
1235
1248
  continue;
1236
- ct(e, t, E, y, s);
1249
+ at(e, t, E, y, s);
1237
1250
  }
1238
- }, An = {
1251
+ }, jn = {
1239
1252
  addChild: "Add child",
1240
1253
  addParent: "Add parent",
1241
1254
  addSibling: "Add sibling",
@@ -1249,36 +1262,36 @@ const j = "http://www.w3.org/2000/svg", fe = function(e) {
1249
1262
  clickTips: "Please click the target node",
1250
1263
  summary: "Summary"
1251
1264
  };
1252
- function Mn(e, t) {
1265
+ function In(e, t) {
1253
1266
  const n = {
1254
1267
  focus: !0,
1255
1268
  link: !0,
1256
- locale: An
1269
+ locale: jn
1257
1270
  };
1258
1271
  t = t === !0 ? n : Object.assign(n, t);
1259
1272
  const o = (C) => {
1260
- const x = document.createElement("div");
1261
- return x.innerText = C, x.className = "tips", x;
1262
- }, s = (C, x, N) => {
1273
+ const w = document.createElement("div");
1274
+ return w.innerText = C, w.className = "tips", w;
1275
+ }, s = (C, w, N) => {
1263
1276
  const S = document.createElement("li");
1264
- return S.id = C, S.innerHTML = `<span>${me(x)}</span><span ${N ? 'class="key"' : ""}>${me(N)}</span>`, S;
1277
+ return S.id = C, S.innerHTML = `<span>${ge(w)}</span><span ${N ? 'class="key"' : ""}>${ge(N)}</span>`, S;
1265
1278
  }, i = t.locale, l = s("cm-add_child", i.addChild, "Tab"), c = s("cm-add_parent", i.addParent, "Ctrl + Enter"), r = s("cm-add_sibling", i.addSibling, "Enter"), a = s("cm-remove_child", i.removeNode, "Delete"), d = s("cm-fucus", i.focus, ""), h = s("cm-unfucus", i.cancelFocus, ""), u = s("cm-up", i.moveUp, "PgUp"), y = s("cm-down", i.moveDown, "Pgdn"), b = s("cm-link", i.link, ""), p = s("cm-link-bidirectional", i.linkBidirectional, ""), g = s("cm-summary", i.summary, ""), m = document.createElement("ul");
1266
1279
  if (m.className = "menu-list", m.appendChild(l), m.appendChild(c), m.appendChild(r), m.appendChild(a), t.focus && (m.appendChild(d), m.appendChild(h)), m.appendChild(u), m.appendChild(y), m.appendChild(g), t.link && (m.appendChild(b), m.appendChild(p)), t && t.extend)
1267
1280
  for (let C = 0; C < t.extend.length; C++) {
1268
- const x = t.extend[C], N = s(x.name, x.name, x.key || "");
1281
+ const w = t.extend[C], N = s(w.name, w.name, w.key || "");
1269
1282
  m.appendChild(N), N.onclick = (S) => {
1270
- x.onclick(S);
1283
+ w.onclick(S);
1271
1284
  };
1272
1285
  }
1273
1286
  const v = document.createElement("div");
1274
1287
  v.className = "context-menu", v.appendChild(m), v.hidden = !0, e.container.append(v);
1275
1288
  let E = !0;
1276
1289
  const k = (C) => {
1277
- const x = C.target;
1278
- if (re(x)) {
1279
- x.parentElement.tagName === "ME-ROOT" ? E = !0 : E = !1, E ? (d.className = "disabled", u.className = "disabled", y.className = "disabled", c.className = "disabled", r.className = "disabled", a.className = "disabled") : (d.className = "", u.className = "", y.className = "", c.className = "", r.className = "", a.className = ""), v.hidden = !1, m.style.top = "", m.style.bottom = "", m.style.left = "", m.style.right = "";
1280
- const N = m.offsetHeight, S = m.offsetWidth, A = m.getBoundingClientRect(), L = C.clientY - A.top, R = C.clientX - A.left;
1281
- N + L > window.innerHeight ? (m.style.top = "", m.style.bottom = "0px") : (m.style.bottom = "", m.style.top = L + 15 + "px"), S + R > window.innerWidth ? (m.style.left = "", m.style.right = "0px") : (m.style.right = "", m.style.left = R + 10 + "px");
1290
+ const w = C.target;
1291
+ if (ee(w)) {
1292
+ w.parentElement.tagName === "ME-ROOT" ? E = !0 : E = !1, E ? (d.className = "disabled", u.className = "disabled", y.className = "disabled", c.className = "disabled", r.className = "disabled", a.className = "disabled") : (d.className = "", u.className = "", y.className = "", c.className = "", r.className = "", a.className = ""), v.hidden = !1, m.style.top = "", m.style.bottom = "", m.style.left = "", m.style.right = "";
1293
+ const N = m.offsetHeight, S = m.offsetWidth, M = m.getBoundingClientRect(), L = C.clientY - M.top, I = C.clientX - M.left;
1294
+ N + L > window.innerHeight ? (m.style.top = "", m.style.bottom = "0px") : (m.style.bottom = "", m.style.top = L + 15 + "px"), S + I > window.innerWidth ? (m.style.left = "", m.style.right = "0px") : (m.style.right = "", m.style.left = I + 10 + "px");
1282
1295
  }
1283
1296
  };
1284
1297
  e.bus.addListener("showContextMenu", k), v.onclick = (C) => {
@@ -1302,13 +1315,13 @@ function Mn(e, t) {
1302
1315
  };
1303
1316
  const _ = (C) => {
1304
1317
  v.hidden = !0;
1305
- const x = e.currentNode, N = o(i.clickTips);
1318
+ const w = e.currentNode, N = o(i.clickTips);
1306
1319
  e.container.appendChild(N), e.map.addEventListener(
1307
1320
  "click",
1308
1321
  (S) => {
1309
1322
  S.preventDefault(), N.remove();
1310
- const A = S.target;
1311
- (A.parentElement.tagName === "ME-PARENT" || A.parentElement.tagName === "ME-ROOT") && e.createArrow(x, A, C);
1323
+ const M = S.target;
1324
+ (M.parentElement.tagName === "ME-PARENT" || M.parentElement.tagName === "ME-ROOT") && e.createArrow(w, M, C);
1312
1325
  },
1313
1326
  {
1314
1327
  once: !0
@@ -1321,7 +1334,7 @@ function Mn(e, t) {
1321
1334
  l.onclick = null, c.onclick = null, r.onclick = null, a.onclick = null, d.onclick = null, h.onclick = null, u.onclick = null, y.onclick = null, b.onclick = null, g.onclick = null, v.onclick = null, e.container.oncontextmenu = null;
1322
1335
  };
1323
1336
  }
1324
- const Pn = function(e) {
1337
+ const Rn = function(e) {
1325
1338
  return ["createSummary", "removeSummary", "finishEditSummary"].includes(e.name) ? {
1326
1339
  type: "summary",
1327
1340
  value: e.obj.id
@@ -1336,7 +1349,7 @@ const Pn = function(e) {
1336
1349
  value: [e.obj.id]
1337
1350
  };
1338
1351
  };
1339
- function On(e) {
1352
+ function Bn(e) {
1340
1353
  let t = [], n = -1, o = e.getData(), s = [];
1341
1354
  e.undo = function() {
1342
1355
  if (n > -1) {
@@ -1369,7 +1382,7 @@ function On(e) {
1369
1382
  prev: o,
1370
1383
  operation: r.name,
1371
1384
  currentSelected: s.map((h) => h.id),
1372
- currentTarget: Pn(r),
1385
+ currentTarget: Rn(r),
1373
1386
  next: a
1374
1387
  };
1375
1388
  t.push(d), o = a, n = t.length - 1;
@@ -1382,24 +1395,24 @@ function On(e) {
1382
1395
  e.bus.removeListener("operation", i), e.bus.removeListener("selectNodes", c), e.container.removeEventListener("keydown", l);
1383
1396
  };
1384
1397
  }
1385
- const $n = '<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1750169394918" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2021" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><path d="M851.91168 328.45312c-59.97056 0-108.6208 48.47104-108.91264 108.36992l-137.92768 38.4a109.14304 109.14304 0 0 0-63.46752-46.58688l1.39264-137.11872c47.29344-11.86816 82.31936-54.66624 82.31936-105.64096 0-60.15488-48.76288-108.91776-108.91776-108.91776s-108.91776 48.76288-108.91776 108.91776c0 49.18784 32.60928 90.75712 77.38368 104.27392l-1.41312 138.87488a109.19936 109.19936 0 0 0-63.50336 48.55808l-138.93632-39.48544 0.01024-0.72704c0-60.15488-48.76288-108.91776-108.91776-108.91776s-108.91776 48.75776-108.91776 108.91776c0 60.15488 48.76288 108.91264 108.91776 108.91264 39.3984 0 73.91232-20.92032 93.03552-52.2496l139.19232 39.552-0.00512 0.2304c0 25.8304 9.00096 49.5616 24.02816 68.23424l-90.14272 132.63872a108.7488 108.7488 0 0 0-34.2528-5.504c-60.15488 0-108.91776 48.768-108.91776 108.91776 0 60.16 48.76288 108.91776 108.91776 108.91776 60.16 0 108.92288-48.75776 108.92288-108.91776 0-27.14624-9.9328-51.968-26.36288-71.04l89.04704-131.03104a108.544 108.544 0 0 0 37.6832 6.70208 108.672 108.672 0 0 0 36.48512-6.272l93.13792 132.57216a108.48256 108.48256 0 0 0-24.69888 69.0688c0 60.16 48.768 108.92288 108.91776 108.92288 60.16 0 108.91776-48.76288 108.91776-108.92288 0-60.14976-48.75776-108.91776-108.91776-108.91776a108.80512 108.80512 0 0 0-36.69504 6.3488l-93.07136-132.48a108.48768 108.48768 0 0 0 24.79616-72.22784l136.09984-37.888c18.99008 31.93856 53.84192 53.3504 93.69088 53.3504 60.16 0 108.92288-48.75776 108.92288-108.91264-0.00512-60.15488-48.77312-108.92288-108.92288-108.92288z" p-id="2022"></path></svg>', Hn = '<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1750169375313" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="1775" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><path d="M639 463.30000001L639 285.1c0-36.90000001-26.4-68.5-61.3-68.5l-150.2 0c-1.5 0-3 0.1-4.5 0.3-10.2-38.7-45.5-67.3-87.5-67.3-50 0-90.5 40.5-90.5 90.5s40.5 90.5 90.5 90.5c42 0 77.3-28.6 87.5-67.39999999 1.4 0.3 2.9 0.4 4.5 0.39999999L577.7 263.6c6.8 0 14.3 8.9 14.3 21.49999999l0 427.00000001c0 12.7-7.40000001 21.5-14.30000001 21.5l-150.19999999 0c-1.5 0-3 0.2-4.5 0.4-10.2-38.8-45.5-67.3-87.5-67.3-50 0-90.5 40.5-90.5 90.4 0 49.9 40.5 90.6 90.5 90.59999999 42 0 77.3-28.6 87.5-67.39999999 1.4 0.2 2.9 0.4 4.49999999 0.4L577.7 780.7c34.80000001 0 61.3-31.6 61.3-68.50000001L639 510.3l79.1 0c10.4 38.5 45.49999999 67 87.4 67 50 0 90.5-40.5 90.5-90.5s-40.5-90.5-90.5-90.5c-41.79999999 0-77.00000001 28.4-87.4 67L639 463.30000001z" fill="currentColor" p-id="1776"></path></svg>', jn = '<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1750169667709" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="3037" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><path d="M385 560.69999999L385 738.9c0 36.90000001 26.4 68.5 61.3 68.5l150.2 0c1.5 0 3-0.1 4.5-0.3 10.2 38.7 45.5 67.3 87.5 67.3 50 0 90.5-40.5 90.5-90.5s-40.5-90.5-90.5-90.5c-42 0-77.3 28.6-87.5 67.39999999-1.4-0.3-2.9-0.4-4.5-0.39999999L446.3 760.4c-6.8 0-14.3-8.9-14.3-21.49999999l0-427.00000001c0-12.7 7.40000001-21.5 14.30000001-21.5l150.19999999 0c1.5 0 3-0.2 4.5-0.4 10.2 38.8 45.5 67.3 87.5 67.3 50 0 90.5-40.5 90.5-90.4 0-49.9-40.5-90.6-90.5-90.59999999-42 0-77.3 28.6-87.5 67.39999999-1.4-0.2-2.9-0.4-4.49999999-0.4L446.3 243.3c-34.80000001 0-61.3 31.6-61.3 68.50000001L385 513.7l-79.1 0c-10.4-38.5-45.49999999-67-87.4-67-50 0-90.5 40.5-90.5 90.5s40.5 90.5 90.5 90.5c41.79999999 0 77.00000001-28.4 87.4-67L385 560.69999999z" fill="currentColor" p-id="3038"></path></svg>', In = '<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1750169402629" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2170" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><path d="M639.328 416c8.032 0 16.096-3.008 22.304-9.056l202.624-197.184-0.8 143.808c-0.096 17.696 14.144 32.096 31.808 32.192 0.064 0 0.128 0 0.192 0 17.6 0 31.904-14.208 32-31.808l1.248-222.208c0-0.672-0.352-1.248-0.384-1.92 0.032-0.512 0.288-0.896 0.288-1.408 0.032-17.664-14.272-32-31.968-32.032L671.552 96l-0.032 0c-17.664 0-31.968 14.304-32 31.968C639.488 145.632 653.824 160 671.488 160l151.872 0.224-206.368 200.8c-12.672 12.32-12.928 32.608-0.64 45.248C622.656 412.736 630.976 416 639.328 416z" p-id="2171"></path><path d="M896.032 639.552 896.032 639.552c-17.696 0-32 14.304-32.032 31.968l-0.224 151.872-200.832-206.4c-12.32-12.64-32.576-12.96-45.248-0.64-12.672 12.352-12.928 32.608-0.64 45.248l197.184 202.624-143.808-0.8c-0.064 0-0.128 0-0.192 0-17.6 0-31.904 14.208-32 31.808-0.096 17.696 14.144 32.096 31.808 32.192l222.24 1.248c0.064 0 0.128 0 0.192 0 0.64 0 1.12-0.32 1.76-0.352 0.512 0.032 0.896 0.288 1.408 0.288l0.032 0c17.664 0 31.968-14.304 32-31.968L928 671.584C928.032 653.952 913.728 639.584 896.032 639.552z" p-id="2172"></path><path d="M209.76 159.744l143.808 0.8c0.064 0 0.128 0 0.192 0 17.6 0 31.904-14.208 32-31.808 0.096-17.696-14.144-32.096-31.808-32.192L131.68 95.328c-0.064 0-0.128 0-0.192 0-0.672 0-1.248 0.352-1.888 0.384-0.448 0-0.8-0.256-1.248-0.256 0 0-0.032 0-0.032 0-17.664 0-31.968 14.304-32 31.968L96 352.448c-0.032 17.664 14.272 32 31.968 32.032 0 0 0.032 0 0.032 0 17.664 0 31.968-14.304 32-31.968l0.224-151.936 200.832 206.4c6.272 6.464 14.624 9.696 22.944 9.696 8.032 0 16.096-3.008 22.304-9.056 12.672-12.32 12.96-32.608 0.64-45.248L209.76 159.744z" p-id="2173"></path><path d="M362.368 617.056l-202.624 197.184 0.8-143.808c0.096-17.696-14.144-32.096-31.808-32.192-0.064 0-0.128 0-0.192 0-17.6 0-31.904 14.208-32 31.808l-1.248 222.24c0 0.704 0.352 1.312 0.384 2.016 0 0.448-0.256 0.832-0.256 1.312-0.032 17.664 14.272 32 31.968 32.032L352.448 928c0 0 0.032 0 0.032 0 17.664 0 31.968-14.304 32-31.968s-14.272-32-31.968-32.032l-151.936-0.224 206.4-200.832c12.672-12.352 12.96-32.608 0.64-45.248S375.008 604.704 362.368 617.056z" p-id="2174"></path></svg>', Rn = '<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1750169573443" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2883" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><path d="M514.133333 488.533333m-106.666666 0a106.666667 106.666667 0 1 0 213.333333 0 106.666667 106.666667 0 1 0-213.333333 0Z" fill="currentColor" p-id="2884"></path><path d="M512 64C264.533333 64 64 264.533333 64 512c0 236.8 183.466667 428.8 416 445.866667v-134.4c-53.333333-59.733333-200.533333-230.4-200.533333-334.933334 0-130.133333 104.533333-234.666667 234.666666-234.666666s234.666667 104.533333 234.666667 234.666666c0 61.866667-49.066667 153.6-145.066667 270.933334l-59.733333 68.266666V960C776.533333 942.933333 960 748.8 960 512c0-247.466667-200.533333-448-448-448z" fill="currentColor" p-id="2885"></path></svg>', Bn = '<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1750169419447" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2480" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><path d="M863.328 482.56l-317.344-1.12L545.984 162.816c0-17.664-14.336-32-32-32s-32 14.336-32 32l0 318.4L159.616 480.064c-0.032 0-0.064 0-0.096 0-17.632 0-31.936 14.24-32 31.904C127.424 529.632 141.728 544 159.392 544.064l322.592 1.152 0 319.168c0 17.696 14.336 32 32 32s32-14.304 32-32l0-318.944 317.088 1.12c0.064 0 0.096 0 0.128 0 17.632 0 31.936-14.24 32-31.904C895.264 496.992 880.96 482.624 863.328 482.56z" p-id="2481"></path></svg>', Yn = '<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1750169426515" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2730" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><path d="M863.744 544 163.424 544c-17.664 0-32-14.336-32-32s14.336-32 32-32l700.32 0c17.696 0 32 14.336 32 32S881.44 544 863.744 544z" p-id="2731"></path></svg>', Wn = {
1386
- side: $n,
1387
- left: Hn,
1388
- right: jn,
1389
- full: In,
1390
- living: Rn,
1391
- zoomin: Bn,
1392
- zoomout: Yn
1393
- }, G = (e, t) => {
1398
+ const Wn = '<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1750169394918" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2021" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><path d="M851.91168 328.45312c-59.97056 0-108.6208 48.47104-108.91264 108.36992l-137.92768 38.4a109.14304 109.14304 0 0 0-63.46752-46.58688l1.39264-137.11872c47.29344-11.86816 82.31936-54.66624 82.31936-105.64096 0-60.15488-48.76288-108.91776-108.91776-108.91776s-108.91776 48.76288-108.91776 108.91776c0 49.18784 32.60928 90.75712 77.38368 104.27392l-1.41312 138.87488a109.19936 109.19936 0 0 0-63.50336 48.55808l-138.93632-39.48544 0.01024-0.72704c0-60.15488-48.76288-108.91776-108.91776-108.91776s-108.91776 48.75776-108.91776 108.91776c0 60.15488 48.76288 108.91264 108.91776 108.91264 39.3984 0 73.91232-20.92032 93.03552-52.2496l139.19232 39.552-0.00512 0.2304c0 25.8304 9.00096 49.5616 24.02816 68.23424l-90.14272 132.63872a108.7488 108.7488 0 0 0-34.2528-5.504c-60.15488 0-108.91776 48.768-108.91776 108.91776 0 60.16 48.76288 108.91776 108.91776 108.91776 60.16 0 108.92288-48.75776 108.92288-108.91776 0-27.14624-9.9328-51.968-26.36288-71.04l89.04704-131.03104a108.544 108.544 0 0 0 37.6832 6.70208 108.672 108.672 0 0 0 36.48512-6.272l93.13792 132.57216a108.48256 108.48256 0 0 0-24.69888 69.0688c0 60.16 48.768 108.92288 108.91776 108.92288 60.16 0 108.91776-48.76288 108.91776-108.92288 0-60.14976-48.75776-108.91776-108.91776-108.91776a108.80512 108.80512 0 0 0-36.69504 6.3488l-93.07136-132.48a108.48768 108.48768 0 0 0 24.79616-72.22784l136.09984-37.888c18.99008 31.93856 53.84192 53.3504 93.69088 53.3504 60.16 0 108.92288-48.75776 108.92288-108.91264-0.00512-60.15488-48.77312-108.92288-108.92288-108.92288z" p-id="2022"></path></svg>', Yn = '<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1750169375313" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="1775" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><path d="M639 463.30000001L639 285.1c0-36.90000001-26.4-68.5-61.3-68.5l-150.2 0c-1.5 0-3 0.1-4.5 0.3-10.2-38.7-45.5-67.3-87.5-67.3-50 0-90.5 40.5-90.5 90.5s40.5 90.5 90.5 90.5c42 0 77.3-28.6 87.5-67.39999999 1.4 0.3 2.9 0.4 4.5 0.39999999L577.7 263.6c6.8 0 14.3 8.9 14.3 21.49999999l0 427.00000001c0 12.7-7.40000001 21.5-14.30000001 21.5l-150.19999999 0c-1.5 0-3 0.2-4.5 0.4-10.2-38.8-45.5-67.3-87.5-67.3-50 0-90.5 40.5-90.5 90.4 0 49.9 40.5 90.6 90.5 90.59999999 42 0 77.3-28.6 87.5-67.39999999 1.4 0.2 2.9 0.4 4.49999999 0.4L577.7 780.7c34.80000001 0 61.3-31.6 61.3-68.50000001L639 510.3l79.1 0c10.4 38.5 45.49999999 67 87.4 67 50 0 90.5-40.5 90.5-90.5s-40.5-90.5-90.5-90.5c-41.79999999 0-77.00000001 28.4-87.4 67L639 463.30000001z" fill="currentColor" p-id="1776"></path></svg>', Xn = '<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1750169667709" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="3037" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><path d="M385 560.69999999L385 738.9c0 36.90000001 26.4 68.5 61.3 68.5l150.2 0c1.5 0 3-0.1 4.5-0.3 10.2 38.7 45.5 67.3 87.5 67.3 50 0 90.5-40.5 90.5-90.5s-40.5-90.5-90.5-90.5c-42 0-77.3 28.6-87.5 67.39999999-1.4-0.3-2.9-0.4-4.5-0.39999999L446.3 760.4c-6.8 0-14.3-8.9-14.3-21.49999999l0-427.00000001c0-12.7 7.40000001-21.5 14.30000001-21.5l150.19999999 0c1.5 0 3-0.2 4.5-0.4 10.2 38.8 45.5 67.3 87.5 67.3 50 0 90.5-40.5 90.5-90.4 0-49.9-40.5-90.6-90.5-90.59999999-42 0-77.3 28.6-87.5 67.39999999-1.4-0.2-2.9-0.4-4.49999999-0.4L446.3 243.3c-34.80000001 0-61.3 31.6-61.3 68.50000001L385 513.7l-79.1 0c-10.4-38.5-45.49999999-67-87.4-67-50 0-90.5 40.5-90.5 90.5s40.5 90.5 90.5 90.5c41.79999999 0 77.00000001-28.4 87.4-67L385 560.69999999z" fill="currentColor" p-id="3038"></path></svg>', Fn = '<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1750169402629" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2170" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><path d="M639.328 416c8.032 0 16.096-3.008 22.304-9.056l202.624-197.184-0.8 143.808c-0.096 17.696 14.144 32.096 31.808 32.192 0.064 0 0.128 0 0.192 0 17.6 0 31.904-14.208 32-31.808l1.248-222.208c0-0.672-0.352-1.248-0.384-1.92 0.032-0.512 0.288-0.896 0.288-1.408 0.032-17.664-14.272-32-31.968-32.032L671.552 96l-0.032 0c-17.664 0-31.968 14.304-32 31.968C639.488 145.632 653.824 160 671.488 160l151.872 0.224-206.368 200.8c-12.672 12.32-12.928 32.608-0.64 45.248C622.656 412.736 630.976 416 639.328 416z" p-id="2171"></path><path d="M896.032 639.552 896.032 639.552c-17.696 0-32 14.304-32.032 31.968l-0.224 151.872-200.832-206.4c-12.32-12.64-32.576-12.96-45.248-0.64-12.672 12.352-12.928 32.608-0.64 45.248l197.184 202.624-143.808-0.8c-0.064 0-0.128 0-0.192 0-17.6 0-31.904 14.208-32 31.808-0.096 17.696 14.144 32.096 31.808 32.192l222.24 1.248c0.064 0 0.128 0 0.192 0 0.64 0 1.12-0.32 1.76-0.352 0.512 0.032 0.896 0.288 1.408 0.288l0.032 0c17.664 0 31.968-14.304 32-31.968L928 671.584C928.032 653.952 913.728 639.584 896.032 639.552z" p-id="2172"></path><path d="M209.76 159.744l143.808 0.8c0.064 0 0.128 0 0.192 0 17.6 0 31.904-14.208 32-31.808 0.096-17.696-14.144-32.096-31.808-32.192L131.68 95.328c-0.064 0-0.128 0-0.192 0-0.672 0-1.248 0.352-1.888 0.384-0.448 0-0.8-0.256-1.248-0.256 0 0-0.032 0-0.032 0-17.664 0-31.968 14.304-32 31.968L96 352.448c-0.032 17.664 14.272 32 31.968 32.032 0 0 0.032 0 0.032 0 17.664 0 31.968-14.304 32-31.968l0.224-151.936 200.832 206.4c6.272 6.464 14.624 9.696 22.944 9.696 8.032 0 16.096-3.008 22.304-9.056 12.672-12.32 12.96-32.608 0.64-45.248L209.76 159.744z" p-id="2173"></path><path d="M362.368 617.056l-202.624 197.184 0.8-143.808c0.096-17.696-14.144-32.096-31.808-32.192-0.064 0-0.128 0-0.192 0-17.6 0-31.904 14.208-32 31.808l-1.248 222.24c0 0.704 0.352 1.312 0.384 2.016 0 0.448-0.256 0.832-0.256 1.312-0.032 17.664 14.272 32 31.968 32.032L352.448 928c0 0 0.032 0 0.032 0 17.664 0 31.968-14.304 32-31.968s-14.272-32-31.968-32.032l-151.936-0.224 206.4-200.832c12.672-12.352 12.96-32.608 0.64-45.248S375.008 604.704 362.368 617.056z" p-id="2174"></path></svg>', Gn = '<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1750169573443" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2883" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><path d="M514.133333 488.533333m-106.666666 0a106.666667 106.666667 0 1 0 213.333333 0 106.666667 106.666667 0 1 0-213.333333 0Z" fill="currentColor" p-id="2884"></path><path d="M512 64C264.533333 64 64 264.533333 64 512c0 236.8 183.466667 428.8 416 445.866667v-134.4c-53.333333-59.733333-200.533333-230.4-200.533333-334.933334 0-130.133333 104.533333-234.666667 234.666666-234.666666s234.666667 104.533333 234.666667 234.666666c0 61.866667-49.066667 153.6-145.066667 270.933334l-59.733333 68.266666V960C776.533333 942.933333 960 748.8 960 512c0-247.466667-200.533333-448-448-448z" fill="currentColor" p-id="2885"></path></svg>', zn = '<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1750169419447" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2480" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><path d="M863.328 482.56l-317.344-1.12L545.984 162.816c0-17.664-14.336-32-32-32s-32 14.336-32 32l0 318.4L159.616 480.064c-0.032 0-0.064 0-0.096 0-17.632 0-31.936 14.24-32 31.904C127.424 529.632 141.728 544 159.392 544.064l322.592 1.152 0 319.168c0 17.696 14.336 32 32 32s32-14.304 32-32l0-318.944 317.088 1.12c0.064 0 0.096 0 0.128 0 17.632 0 31.936-14.24 32-31.904C895.264 496.992 880.96 482.624 863.328 482.56z" p-id="2481"></path></svg>', Kn = '<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1750169426515" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2730" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><path d="M863.744 544 163.424 544c-17.664 0-32-14.336-32-32s14.336-32 32-32l700.32 0c17.696 0 32 14.336 32 32S881.44 544 863.744 544z" p-id="2731"></path></svg>', Vn = {
1399
+ side: Wn,
1400
+ left: Yn,
1401
+ right: Xn,
1402
+ full: Fn,
1403
+ living: Gn,
1404
+ zoomin: zn,
1405
+ zoomout: Kn
1406
+ }, F = (e, t) => {
1394
1407
  const n = document.createElement("span");
1395
- return n.id = e, n.innerHTML = Wn[t], n;
1408
+ return n.id = e, n.innerHTML = Vn[t], n;
1396
1409
  };
1397
- function Xn(e) {
1398
- const t = document.createElement("div"), n = G("fullscreen", "full"), o = G("toCenter", "living"), s = G("zoomout", "zoomout"), i = G("zoomin", "zoomin");
1410
+ function qn(e) {
1411
+ const t = document.createElement("div"), n = F("fullscreen", "full"), o = F("toCenter", "living"), s = F("zoomout", "zoomout"), i = F("zoomin", "zoomin");
1399
1412
  t.appendChild(n), t.appendChild(o), t.appendChild(s), t.appendChild(i), t.className = "mind-elixir-toolbar rb";
1400
1413
  let l = null;
1401
1414
  const c = () => {
1402
- const a = e.container.getBoundingClientRect(), d = Se(e.map.style.transform), h = a.width / 2, u = a.height / 2, y = (h - d.x) / e.scaleVal, b = (u - d.y) / e.scaleVal;
1415
+ const a = e.container.getBoundingClientRect(), d = Ce(e.map.style.transform), h = a.width / 2, u = a.height / 2, y = (h - d.x) / e.scaleVal, b = (u - d.y) / e.scaleVal;
1403
1416
  l = {
1404
1417
  containerRect: a,
1405
1418
  currentTransform: d,
@@ -1422,8 +1435,8 @@ function Xn(e) {
1422
1435
  e.scale(e.scaleVal + e.scaleSensitivity);
1423
1436
  }, t;
1424
1437
  }
1425
- function Fn(e) {
1426
- const t = document.createElement("div"), n = G("tbltl", "left"), o = G("tbltr", "right"), s = G("tblts", "side");
1438
+ function Un(e) {
1439
+ const t = document.createElement("div"), n = F("tbltl", "left"), o = F("tbltr", "right"), s = F("tblts", "side");
1427
1440
  return t.appendChild(n), t.appendChild(o), t.appendChild(s), t.className = "mind-elixir-toolbar lt", n.onclick = () => {
1428
1441
  e.initLeft();
1429
1442
  }, o.onclick = () => {
@@ -1432,10 +1445,10 @@ function Fn(e) {
1432
1445
  e.initSide();
1433
1446
  }, t;
1434
1447
  }
1435
- function Gn(e) {
1436
- e.container.append(Xn(e)), e.container.append(Fn(e));
1448
+ function Jn(e) {
1449
+ e.container.append(qn(e)), e.container.append(Un(e));
1437
1450
  }
1438
- class Vn {
1451
+ class Zn {
1439
1452
  _listeners = /* @__PURE__ */ new Map();
1440
1453
  addEventListener(t, n) {
1441
1454
  const o = this._listeners.get(t) ?? /* @__PURE__ */ new Set();
@@ -1458,15 +1471,15 @@ class Vn {
1458
1471
  off = this.removeEventListener;
1459
1472
  emit = this.dispatchEvent;
1460
1473
  }
1461
- const Be = (e, t = "px") => typeof e == "number" ? e + t : e, Y = ({ style: e }, t, n) => {
1474
+ const Be = (e, t = "px") => typeof e == "number" ? e + t : e, W = ({ style: e }, t, n) => {
1462
1475
  if (typeof t == "object")
1463
1476
  for (const [o, s] of Object.entries(t))
1464
1477
  s !== void 0 && (e[o] = Be(s));
1465
1478
  else n !== void 0 && (e[t] = Be(n));
1466
- }, Ye = (e = 0, t = 0, n = 0, o = 0) => {
1479
+ }, We = (e = 0, t = 0, n = 0, o = 0) => {
1467
1480
  const s = { x: e, y: t, width: n, height: o, top: t, left: e, right: e + n, bottom: t + o };
1468
1481
  return { ...s, toJSON: () => JSON.stringify(s) };
1469
- }, zn = (e) => {
1482
+ }, Qn = (e) => {
1470
1483
  let t, n = -1, o = !1;
1471
1484
  return {
1472
1485
  next: (...s) => {
@@ -1478,7 +1491,7 @@ const Be = (e, t = "px") => typeof e == "number" ? e + t : e, Y = ({ style: e },
1478
1491
  cancelAnimationFrame(n), o = !1;
1479
1492
  }
1480
1493
  };
1481
- }, We = (e, t, n = "touch") => {
1494
+ }, Ye = (e, t, n = "touch") => {
1482
1495
  switch (n) {
1483
1496
  case "center": {
1484
1497
  const o = t.left + t.width / 2, s = t.top + t.height / 2;
@@ -1489,16 +1502,16 @@ const Be = (e, t = "px") => typeof e == "number" ? e + t : e, Y = ({ style: e },
1489
1502
  case "touch":
1490
1503
  return e.right >= t.left && e.left <= t.right && e.bottom >= t.top && e.top <= t.bottom;
1491
1504
  }
1492
- }, Kn = () => matchMedia("(hover: none), (pointer: coarse)").matches, qn = () => "safari" in window, be = (e) => Array.isArray(e) ? e : [e], at = (e) => (t, n, o, s = {}) => {
1493
- (t instanceof HTMLCollection || t instanceof NodeList) && (t = Array.from(t)), n = be(n), t = be(t);
1505
+ }, eo = () => matchMedia("(hover: none), (pointer: coarse)").matches, to = () => "safari" in window, ye = (e) => Array.isArray(e) ? e : [e], dt = (e) => (t, n, o, s = {}) => {
1506
+ (t instanceof HTMLCollection || t instanceof NodeList) && (t = Array.from(t)), n = ye(n), t = ye(t);
1494
1507
  for (const i of t)
1495
1508
  if (i)
1496
1509
  for (const l of n)
1497
1510
  i[e](l, o, { capture: !1, ...s });
1498
- }, W = at("addEventListener"), $ = at("removeEventListener"), ne = (e) => {
1511
+ }, K = dt("addEventListener"), R = dt("removeEventListener"), oe = (e) => {
1499
1512
  const { clientX: t, clientY: n, target: o } = e.touches?.[0] ?? e;
1500
1513
  return { x: t, y: n, target: o };
1501
- }, K = (e, t = document) => be(e).map((n) => typeof n == "string" ? Array.from(t.querySelectorAll(n)) : n instanceof Element ? n : null).flat().filter(Boolean), Un = (e, t) => t.some((n) => typeof n == "number" ? e.button === n : typeof n == "object" ? n.button !== e.button ? !1 : n.modifiers.every((o) => {
1514
+ }, V = (e, t = document) => ye(e).map((n) => typeof n == "string" ? Array.from(t.querySelectorAll(n)) : n instanceof Element ? n : null).flat().filter(Boolean), no = (e, t) => t.some((n) => typeof n == "number" ? e.button === n : typeof n == "object" ? n.button !== e.button ? !1 : n.modifiers.every((o) => {
1502
1515
  switch (o) {
1503
1516
  case "alt":
1504
1517
  return e.altKey;
@@ -1507,18 +1520,18 @@ const Be = (e, t = "px") => typeof e == "number" ? e + t : e, Y = ({ style: e },
1507
1520
  case "shift":
1508
1521
  return e.shiftKey;
1509
1522
  }
1510
- }) : !1), { abs: F, max: Xe, min: Fe, ceil: Ge } = Math, Ve = (e = []) => ({
1523
+ }) : !1), { abs: X, max: Xe, min: Fe, ceil: Ge } = Math, ze = (e = []) => ({
1511
1524
  stored: e,
1512
1525
  selected: [],
1513
1526
  touched: [],
1514
1527
  changed: { added: [], removed: [] }
1515
1528
  });
1516
- class Jn extends Vn {
1529
+ class oo extends Zn {
1517
1530
  static version = "mind-elixir-fork";
1518
1531
  // Options
1519
1532
  _options;
1520
1533
  // Selection store
1521
- _selection = Ve();
1534
+ _selection = ze();
1522
1535
  // Area element and clipping element
1523
1536
  _area;
1524
1537
  _clippingElement;
@@ -1531,7 +1544,7 @@ class Jn extends Vn {
1531
1544
  _latestElement;
1532
1545
  // Dynamically constructed area rect
1533
1546
  _areaLocation = { y1: 0, x2: 0, y2: 0, x1: 0 };
1534
- _areaRect = Ye();
1547
+ _areaRect = We();
1535
1548
  // If a single click is being performed, it's a single-click until the user dragged the mouse
1536
1549
  _singleClick = !0;
1537
1550
  _frame;
@@ -1540,8 +1553,6 @@ class Jn extends Vn {
1540
1553
  _scrollingActive = !1;
1541
1554
  _scrollSpeed = { x: 0, y: 0 };
1542
1555
  _scrollDelta = { x: 0, y: 0 };
1543
- // Required for keydown scrolling
1544
- _lastMousePosition = { x: 0, y: 0 };
1545
1556
  constructor(t) {
1546
1557
  super(), this._options = {
1547
1558
  selectionAreaClass: "selection-area",
@@ -1562,7 +1573,6 @@ class Jn extends Vn {
1562
1573
  startThreshold: t.behaviour?.startThreshold ? typeof t.behaviour.startThreshold == "number" ? t.behaviour.startThreshold : { x: 10, y: 10, ...t.behaviour.startThreshold } : { x: 10, y: 10 },
1563
1574
  scrolling: {
1564
1575
  speedDivider: 10,
1565
- manualSpeed: 750,
1566
1576
  ...t.behaviour?.scrolling,
1567
1577
  startScrollMargins: {
1568
1578
  x: 0,
@@ -1586,44 +1596,44 @@ class Jn extends Vn {
1586
1596
  for (const i of Object.getOwnPropertyNames(Object.getPrototypeOf(this)))
1587
1597
  typeof this[i] == "function" && (this[i] = this[i].bind(this));
1588
1598
  const { document: n, selectionAreaClass: o, selectionContainerClass: s } = this._options;
1589
- this._area = n.createElement("div"), this._clippingElement = n.createElement("div"), this._clippingElement.appendChild(this._area), this._area.classList.add(o), s && this._clippingElement.classList.add(s), Y(this._area, {
1599
+ this._area = n.createElement("div"), this._clippingElement = n.createElement("div"), this._clippingElement.appendChild(this._area), this._area.classList.add(o), s && this._clippingElement.classList.add(s), W(this._area, {
1590
1600
  willChange: "top, left, bottom, right, width, height",
1591
1601
  top: 0,
1592
1602
  left: 0,
1593
1603
  position: "fixed"
1594
- }), Y(this._clippingElement, {
1604
+ }), W(this._clippingElement, {
1595
1605
  overflow: "hidden",
1596
1606
  position: "fixed",
1597
1607
  transform: "translate3d(0, 0, 0)",
1598
1608
  // https://stackoverflow.com/a/38268846
1599
1609
  pointerEvents: "none",
1600
1610
  zIndex: "1"
1601
- }), this._frame = zn((i) => {
1611
+ }), this._frame = Qn((i) => {
1602
1612
  this._recalculateSelectionAreaRect(), this._updateElementSelection(), this._emitEvent("move", i), this._redrawSelectionArea();
1603
1613
  }), this.enable();
1604
1614
  }
1605
1615
  _toggleStartEvents(t = !0) {
1606
- const { document: n, features: o } = this._options, s = t ? W : $;
1616
+ const { document: n, features: o } = this._options, s = t ? K : R;
1607
1617
  s(n, "mousedown", this._onTapStart), o.touch && s(n, "touchstart", this._onTapStart, { passive: !1 });
1608
1618
  }
1609
1619
  _onTapStart(t, n = !1) {
1610
- const { x: o, y: s, target: i } = ne(t), { document: l, startAreas: c, boundaries: r, features: a, behaviour: d } = this._options, h = i.getBoundingClientRect();
1611
- if (t instanceof MouseEvent && !Un(t, d.triggers))
1620
+ const { x: o, y: s, target: i } = oe(t), { document: l, startAreas: c, boundaries: r, features: a, behaviour: d } = this._options, h = i.getBoundingClientRect();
1621
+ if (t instanceof MouseEvent && !no(t, d.triggers))
1612
1622
  return;
1613
- const u = K(c, l), y = K(r, l);
1614
- this._targetElement = y.find((m) => We(m.getBoundingClientRect(), h));
1623
+ const u = V(c, l), y = V(r, l);
1624
+ this._targetElement = y.find((m) => Ye(m.getBoundingClientRect(), h));
1615
1625
  const b = t.composedPath(), p = u.find((m) => b.includes(m));
1616
1626
  if (this._targetBoundary = y.find((m) => b.includes(m)), !this._targetElement || !p || !this._targetBoundary || !n && this._emitEvent("beforestart", t) === !1)
1617
1627
  return;
1618
1628
  this._areaLocation = { x1: o, y1: s, x2: 0, y2: 0 };
1619
1629
  const g = l.scrollingElement ?? l.body;
1620
- this._scrollDelta = { x: g.scrollLeft, y: g.scrollTop }, this._singleClick = !0, this.clearSelection(!1, !0), W(l, ["touchmove", "mousemove"], this._delayedTapMove, { passive: !1 }), W(l, ["mouseup", "touchcancel", "touchend"], this._onTapStop), W(l, "scroll", this._onScroll), a.deselectOnBlur && (this._targetBoundaryScrolled = !1, W(this._targetBoundary, "scroll", this._onStartAreaScroll));
1630
+ this._scrollDelta = { x: g.scrollLeft, y: g.scrollTop }, this._singleClick = !0, this.clearSelection(!1, !0), K(l, ["touchmove", "mousemove"], this._delayedTapMove, { passive: !1 }), K(l, ["mouseup", "touchcancel", "touchend"], this._onTapStop), K(l, "scroll", this._onScroll), a.deselectOnBlur && (this._targetBoundaryScrolled = !1, K(this._targetBoundary, "scroll", this._onStartAreaScroll));
1621
1631
  }
1622
1632
  _onSingleTap(t) {
1623
1633
  const {
1624
1634
  singleTap: { intersect: n },
1625
1635
  range: o
1626
- } = this._options.features, s = ne(t);
1636
+ } = this._options.features, s = oe(t);
1627
1637
  let i;
1628
1638
  if (n === "native")
1629
1639
  i = s.target;
@@ -1659,45 +1669,43 @@ class Jn extends Vn {
1659
1669
  container: n,
1660
1670
  document: o,
1661
1671
  behaviour: { startThreshold: s }
1662
- } = this._options, { x1: i, y1: l } = this._areaLocation, { x: c, y: r } = ne(t);
1672
+ } = this._options, { x1: i, y1: l } = this._areaLocation, { x: c, y: r } = oe(t);
1663
1673
  if (
1664
1674
  // Single number for both coordinates
1665
- typeof s == "number" && F(c + r - (i + l)) >= s || // Different x and y threshold
1666
- typeof s == "object" && F(c - i) >= s.x || F(r - l) >= s.y
1675
+ typeof s == "number" && X(c + r - (i + l)) >= s || // Different x and y threshold
1676
+ typeof s == "object" && X(c - i) >= s.x || X(r - l) >= s.y
1667
1677
  ) {
1668
- if ($(o, ["mousemove", "touchmove"], this._delayedTapMove, { passive: !1 }), this._emitEvent("beforedrag", t) === !1) {
1669
- $(o, ["mouseup", "touchcancel", "touchend"], this._onTapStop);
1678
+ if (R(o, ["mousemove", "touchmove"], this._delayedTapMove, { passive: !1 }), this._emitEvent("beforedrag", t) === !1) {
1679
+ R(o, ["mouseup", "touchcancel", "touchend"], this._onTapStop);
1670
1680
  return;
1671
1681
  }
1672
- W(o, ["mousemove", "touchmove"], this._onTapMove, { passive: !1 }), Y(this._area, "display", "block"), K(n, o)[0].appendChild(this._clippingElement), this.resolveSelectables(), this._singleClick = !1, this._targetRect = this._targetElement.getBoundingClientRect(), this._scrollAvailable = this._targetElement.scrollHeight !== this._targetElement.clientHeight || this._targetElement.scrollWidth !== this._targetElement.clientWidth, this._scrollAvailable && (W(this._targetElement, "wheel", this._wheelScroll, { passive: !1 }), W(this._options.document, "keydown", this._keyboardScroll, { passive: !1 }), this._selectables = this._selectables.filter((a) => this._targetElement.contains(a))), this._setupSelectionArea(), this._emitEvent("start", t), this._onTapMove(t);
1682
+ K(o, ["mousemove", "touchmove"], this._onTapMove, { passive: !1 }), W(this._area, "display", "block"), V(n, o)[0].appendChild(this._clippingElement), this.resolveSelectables(), this._singleClick = !1, this._targetRect = this._targetElement.getBoundingClientRect(), this._scrollAvailable = this._targetElement.scrollHeight !== this._targetElement.clientHeight || this._targetElement.scrollWidth !== this._targetElement.clientWidth, this._scrollAvailable && (this._selectables = this._selectables.filter((a) => this._targetElement.contains(a))), this._setupSelectionArea(), this._emitEvent("start", t), this._onTapMove(t);
1673
1683
  }
1674
1684
  this._handleMoveEvent(t);
1675
1685
  }
1676
1686
  _setupSelectionArea() {
1677
1687
  const { _clippingElement: t, _targetElement: n, _area: o } = this, s = this._targetRect = n.getBoundingClientRect();
1678
- this._scrollAvailable ? (Y(t, {
1688
+ this._scrollAvailable ? (W(t, {
1679
1689
  top: s.top,
1680
1690
  left: s.left,
1681
1691
  width: s.width,
1682
1692
  height: s.height
1683
- }), Y(o, {
1693
+ }), W(o, {
1684
1694
  marginTop: -s.top,
1685
1695
  marginLeft: -s.left
1686
- })) : (Y(t, {
1696
+ })) : (W(t, {
1687
1697
  top: 0,
1688
1698
  left: 0,
1689
1699
  width: "100%",
1690
1700
  height: "100%"
1691
- }), Y(o, {
1701
+ }), W(o, {
1692
1702
  marginTop: 0,
1693
1703
  marginLeft: 0
1694
1704
  }));
1695
1705
  }
1696
1706
  _onTapMove(t) {
1697
- const { _scrollSpeed: n, _areaLocation: o, _options: s, _frame: i } = this, { speedDivider: l } = s.behaviour.scrolling;
1698
- this._targetElement;
1699
- const { x: c, y: r } = ne(t);
1700
- if (o.x2 = c, o.y2 = r, this._lastMousePosition.x = c, this._lastMousePosition.y = r, this._scrollAvailable && !this._scrollingActive && (n.y || n.x)) {
1707
+ const { _scrollSpeed: n, _areaLocation: o, _options: s, _frame: i } = this, { speedDivider: l } = s.behaviour.scrolling, { x: c, y: r } = oe(t);
1708
+ if (o.x2 = c, o.y2 = r, this._scrollAvailable && !this._scrollingActive && (n.y || n.x)) {
1701
1709
  this._scrollingActive = !0;
1702
1710
  const a = () => {
1703
1711
  if (!n.x && !n.y) {
@@ -1718,7 +1726,7 @@ class Jn extends Vn {
1718
1726
  }
1719
1727
  _handleMoveEvent(t) {
1720
1728
  const { features: n } = this._options;
1721
- (n.touch && Kn() || this._scrollAvailable && qn()) && t.preventDefault();
1729
+ (n.touch && eo() || this._scrollAvailable && to()) && t.preventDefault();
1722
1730
  }
1723
1731
  _onScroll() {
1724
1732
  const {
@@ -1728,20 +1736,7 @@ class Jn extends Vn {
1728
1736
  this._areaLocation.x1 += t.x - s, this._areaLocation.y1 += t.y - o, t.x = s, t.y = o, this._setupSelectionArea(), this._frame.next(null);
1729
1737
  }
1730
1738
  _onStartAreaScroll() {
1731
- this._targetBoundaryScrolled = !0, $(this._targetElement, "scroll", this._onStartAreaScroll);
1732
- }
1733
- _wheelScroll(t) {
1734
- const { manualSpeed: n } = this._options.behaviour.scrolling, o = t.deltaY ? t.deltaY > 0 ? 1 : -1 : 0, s = t.deltaX ? t.deltaX > 0 ? 1 : -1 : 0;
1735
- this._scrollSpeed.y += o * n, this._scrollSpeed.x += s * n, this._onTapMove(t), t.preventDefault();
1736
- }
1737
- _keyboardScroll(t) {
1738
- const { manualSpeed: n } = this._options.behaviour.scrolling, o = t.key === "ArrowLeft" ? -1 : t.key === "ArrowRight" ? 1 : 0, s = t.key === "ArrowUp" ? -1 : t.key === "ArrowDown" ? 1 : 0;
1739
- this._scrollSpeed.x += Math.sign(o) * n, this._scrollSpeed.y += Math.sign(s) * n, t.preventDefault(), this._onTapMove({
1740
- clientX: this._lastMousePosition.x,
1741
- clientY: this._lastMousePosition.y,
1742
- preventDefault: () => {
1743
- }
1744
- });
1739
+ this._targetBoundaryScrolled = !0, R(this._targetElement, "scroll", this._onStartAreaScroll);
1745
1740
  }
1746
1741
  _recalculateSelectionAreaRect() {
1747
1742
  const { _scrollSpeed: t, _areaLocation: n, _targetElement: o, _options: s } = this, i = this._targetRect, { x1: l, y1: c } = n;
@@ -1751,9 +1746,9 @@ class Jn extends Vn {
1751
1746
  scrolling: { startScrollMargins: d }
1752
1747
  }
1753
1748
  } = s;
1754
- r < i.left + d.x ? (t.x = -F(i.left - r + d.x), r = r < i.left ? i.left : r) : r > i.right - d.x ? (t.x = F(i.left + i.width - r - d.x), r = r > i.right ? i.right : r) : t.x = 0, a < i.top + d.y ? (t.y = -F(i.top - a + d.y), a = a < i.top ? i.top : a) : a > i.bottom - d.y ? (t.y = F(i.top + i.height - a - d.y), a = a > i.bottom ? i.bottom : a) : t.y = 0;
1749
+ r < i.left + d.x ? (t.x = -X(i.left - r + d.x), r = r < i.left ? i.left : r) : r > i.right - d.x ? (t.x = X(i.left + i.width - r - d.x), r = r > i.right ? i.right : r) : t.x = 0, a < i.top + d.y ? (t.y = -X(i.top - a + d.y), a = a < i.top ? i.top : a) : a > i.bottom - d.y ? (t.y = X(i.top + i.height - a - d.y), a = a > i.bottom ? i.bottom : a) : t.y = 0;
1755
1750
  const h = Fe(l, r), u = Fe(c, a), y = Xe(l, r), b = Xe(c, a);
1756
- this._areaRect = Ye(h, u, y - h, b - u);
1751
+ this._areaRect = We(h, u, y - h, b - u);
1757
1752
  }
1758
1753
  _redrawSelectionArea() {
1759
1754
  const { x: t, y: n, width: o, height: s } = this._areaRect, { style: i } = this._area;
@@ -1761,13 +1756,13 @@ class Jn extends Vn {
1761
1756
  }
1762
1757
  _onTapStop(t, n) {
1763
1758
  const { document: o, features: s } = this._options, { _singleClick: i } = this;
1764
- $(this._targetElement, "scroll", this._onStartAreaScroll), $(o, ["mousemove", "touchmove"], this._delayedTapMove), $(o, ["touchmove", "mousemove"], this._onTapMove), $(o, ["mouseup", "touchcancel", "touchend"], this._onTapStop), $(o, "scroll", this._onScroll), this._keepSelection(), t && i && s.singleTap.allow ? this._onSingleTap(t) : !i && !n && (this._updateElementSelection(), this._emitEvent("stop", t)), this._scrollSpeed.x = 0, this._scrollSpeed.y = 0, $(this._targetElement, "wheel", this._wheelScroll, { passive: !0 }), $(this._options.document, "keydown", this._keyboardScroll, { passive: !0 }), this._clippingElement.remove(), this._frame?.cancel(), Y(this._area, "display", "none");
1759
+ R(this._targetElement, "scroll", this._onStartAreaScroll), R(o, ["mousemove", "touchmove"], this._delayedTapMove), R(o, ["touchmove", "mousemove"], this._onTapMove), R(o, ["mouseup", "touchcancel", "touchend"], this._onTapStop), R(o, "scroll", this._onScroll), this._keepSelection(), t && i && s.singleTap.allow ? this._onSingleTap(t) : !i && !n && (this._updateElementSelection(), this._emitEvent("stop", t)), this._scrollSpeed.x = 0, this._scrollSpeed.y = 0, this._clippingElement.remove(), this._frame?.cancel(), W(this._area, "display", "none");
1765
1760
  }
1766
1761
  _updateElementSelection() {
1767
1762
  const { _selectables: t, _options: n, _selection: o, _areaRect: s } = this, { stored: i, selected: l, touched: c } = o, { intersect: r, overlap: a } = n.behaviour, d = a === "invert", h = [], u = [], y = [];
1768
1763
  for (let p = 0; p < t.length; p++) {
1769
1764
  const g = t[p];
1770
- if (We(s, g.getBoundingClientRect(), r)) {
1765
+ if (Ye(s, g.getBoundingClientRect(), r)) {
1771
1766
  if (l.includes(g))
1772
1767
  i.includes(g) && !c.includes(g) && c.push(g);
1773
1768
  else if (d && i.includes(g)) {
@@ -1837,7 +1832,7 @@ class Jn extends Vn {
1837
1832
  * Will update everything that can be selected
1838
1833
  */
1839
1834
  resolveSelectables() {
1840
- this._selectables = K(this._options.selectables, this._options.document);
1835
+ this._selectables = V(this._options.selectables, this._options.document);
1841
1836
  }
1842
1837
  /**
1843
1838
  * Same as deselecting, but for all elements currently selected
@@ -1846,7 +1841,7 @@ class Jn extends Vn {
1846
1841
  */
1847
1842
  clearSelection(t = !0, n = !1) {
1848
1843
  const { selected: o, stored: s, changed: i } = this._selection;
1849
- i.added = [], i.removed.push(...o, ...t ? s : []), n || (this._emitEvent("move", null), this._emitEvent("stop", null)), this._selection = Ve(t ? [] : s);
1844
+ i.added = [], i.removed.push(...o, ...t ? s : []), n || (this._emitEvent("move", null), this._emitEvent("stop", null)), this._selection = ze(t ? [] : s);
1850
1845
  }
1851
1846
  /**
1852
1847
  * @returns {Array} Selected elements
@@ -1906,7 +1901,7 @@ class Jn extends Vn {
1906
1901
  * @param quiet If this should not trigger the move event
1907
1902
  */
1908
1903
  select(t, n = !1) {
1909
- const { changed: o, selected: s, stored: i } = this._selection, l = K(t, this._options.document).filter((c) => !s.includes(c) && !i.includes(c));
1904
+ const { changed: o, selected: s, stored: i } = this._selection, l = V(t, this._options.document).filter((c) => !s.includes(c) && !i.includes(c));
1910
1905
  return i.push(...l), s.push(...l), o.added.push(...l), o.removed = [], this._latestElement = void 0, n || (this._emitEvent("move", null), this._emitEvent("stop", null)), l;
1911
1906
  }
1912
1907
  /**
@@ -1915,20 +1910,22 @@ class Jn extends Vn {
1915
1910
  * @param quiet If this should not trigger the move event
1916
1911
  */
1917
1912
  deselect(t, n = !1) {
1918
- const { selected: o, stored: s, changed: i } = this._selection, l = K(t, this._options.document).filter((c) => o.includes(c) || s.includes(c));
1913
+ const { selected: o, stored: s, changed: i } = this._selection, l = V(t, this._options.document).filter((c) => o.includes(c) || s.includes(c));
1919
1914
  this._selection.stored = s.filter((c) => !l.includes(c)), this._selection.selected = o.filter((c) => !l.includes(c)), this._selection.changed.added = [], this._selection.changed.removed.push(...l.filter((c) => !i.removed.includes(c))), this._latestElement = void 0, n || (this._emitEvent("move", null), this._emitEvent("stop", null));
1920
1915
  }
1921
1916
  }
1922
- function Zn(e) {
1923
- const t = e.mouseSelectionButton === 2 ? [2] : [0], n = new Jn({
1917
+ function so(e) {
1918
+ const t = e.mouseSelectionButton === 2 ? [2] : [0], n = new oo({
1924
1919
  selectables: [".map-container me-tpc"],
1925
1920
  boundaries: [e.container],
1926
1921
  container: e.selectionContainer,
1927
1922
  mindElixirInstance: e,
1928
1923
  // 传递 MindElixir 实例
1929
1924
  features: {
1930
- // deselectOnBlur: true,
1931
- touch: !1
1925
+ touch: !1,
1926
+ singleTap: {
1927
+ allow: !1
1928
+ }
1932
1929
  },
1933
1930
  behaviour: {
1934
1931
  triggers: t,
@@ -1960,29 +1957,35 @@ function Zn(e) {
1960
1957
  }
1961
1958
  }) => {
1962
1959
  if (o.length > 0 || s.length > 0, o.length > 0) {
1963
- for (const i of o)
1964
- i.className = "selected";
1965
- e.currentNodes = [...e.currentNodes, ...o], e.bus.fire(
1966
- "selectNodes",
1967
- o.map((i) => i.nodeObj)
1968
- );
1960
+ const i = o.filter((l) => !e.currentNodes?.includes(l));
1961
+ if (i.length > 0) {
1962
+ for (const l of i)
1963
+ l.className = "selected";
1964
+ e.currentNodes = [...e.currentNodes || [], ...i], e.bus.fire(
1965
+ "selectNodes",
1966
+ i.map((l) => l.nodeObj)
1967
+ );
1968
+ }
1969
1969
  }
1970
1970
  if (s.length > 0) {
1971
- for (const i of s)
1972
- i.classList.remove("selected");
1973
- e.currentNodes = e.currentNodes.filter((i) => !s?.includes(i)), e.bus.fire(
1974
- "unselectNodes",
1975
- s.map((i) => i.nodeObj)
1976
- );
1971
+ const i = s.filter((l) => e.currentNodes?.includes(l));
1972
+ if (i.length > 0) {
1973
+ for (const l of i)
1974
+ l.classList.remove("selected");
1975
+ e.currentNodes = (e.currentNodes || []).filter((l) => !i.includes(l)), e.bus.fire(
1976
+ "unselectNodes",
1977
+ i.map((l) => l.nodeObj)
1978
+ );
1979
+ }
1977
1980
  }
1978
1981
  }
1979
1982
  );
1980
1983
  e.selection = n;
1981
1984
  }
1982
- const Qn = function(e, t = !0) {
1985
+ const io = function(e, t = !0) {
1983
1986
  this.theme = e;
1984
1987
  const o = {
1985
- ...(e.type === "dark" ? we : ve).cssVar,
1988
+ ...(e.type === "dark" ? ve : be).cssVar,
1986
1989
  ...e.cssVar
1987
1990
  }, s = Object.keys(o);
1988
1991
  for (let i = 0; i < s.length; i++) {
@@ -1990,7 +1993,7 @@ const Qn = function(e, t = !0) {
1990
1993
  this.container.style.setProperty(l, o[l]);
1991
1994
  }
1992
1995
  t && this.refresh();
1993
- }, eo = function(e) {
1996
+ }, ro = function(e) {
1994
1997
  return {
1995
1998
  dom: e,
1996
1999
  moved: !1,
@@ -2025,27 +2028,27 @@ const Qn = function(e, t = !0) {
2025
2028
  this.moved = !1, this.pointerdown = !1;
2026
2029
  }
2027
2030
  };
2028
- }, ze = {
2029
- create: eo
2030
- }, to = "#4dc4ff";
2031
- function dt(e, t, n, o, s, i, l, c) {
2031
+ }, Ke = {
2032
+ create: ro
2033
+ }, lo = "#4dc4ff";
2034
+ function ht(e, t, n, o, s, i, l, c) {
2032
2035
  return {
2033
2036
  x: e / 8 + n * 3 / 8 + s * 3 / 8 + l / 8,
2034
2037
  y: t / 8 + o * 3 / 8 + i * 3 / 8 + c / 8
2035
2038
  };
2036
2039
  }
2037
- function no(e, t, n) {
2038
- e && (e.dataset.x = t.toString(), e.dataset.y = n.toString(), fe(e));
2040
+ function co(e, t, n) {
2041
+ e && (e.dataset.x = t.toString(), e.dataset.y = n.toString(), he(e));
2039
2042
  }
2040
- function oe(e, t, n, o, s) {
2041
- D(e, {
2043
+ function se(e, t, n, o, s) {
2044
+ A(e, {
2042
2045
  x1: t + "",
2043
2046
  y1: n + "",
2044
2047
  x2: o + "",
2045
2048
  y2: s + ""
2046
2049
  });
2047
2050
  }
2048
- function Ke(e, t, n, o, s, i, l, c, r, a) {
2051
+ function Ve(e, t, n, o, s, i, l, c, r, a) {
2049
2052
  const d = `M ${t} ${n} C ${o} ${s} ${i} ${l} ${c} ${r}`;
2050
2053
  if (e.line.setAttribute("d", d), a.style) {
2051
2054
  const p = a.style;
@@ -2071,15 +2074,15 @@ function Ke(e, t, n, o, s, i, l, c, r, a) {
2071
2074
  }
2072
2075
  }
2073
2076
  }
2074
- const { x: y, y: b } = dt(t, n, o, s, i, l, c, r);
2075
- if (e.labelEl && no(e.labelEl, y, b), a.style?.labelColor) {
2077
+ const { x: y, y: b } = ht(t, n, o, s, i, l, c, r);
2078
+ if (e.labelEl && co(e.labelEl, y, b), a.style?.labelColor) {
2076
2079
  const p = e.labelEl;
2077
2080
  p && (p.style.color = a.style.labelColor);
2078
2081
  }
2079
- fo(e);
2082
+ bo(e);
2080
2083
  }
2081
- function de(e, t, n) {
2082
- const { offsetLeft: o, offsetTop: s } = H(e.nodes, t), i = t.offsetWidth, l = t.offsetHeight, c = o + i / 2, r = s + l / 2, a = c + n.x, d = r + n.y;
2084
+ function ae(e, t, n) {
2085
+ const { offsetLeft: o, offsetTop: s } = $(e.nodes, t), i = t.offsetWidth, l = t.offsetHeight, c = o + i / 2, r = s + l / 2, a = c + n.x, d = r + n.y;
2083
2086
  return {
2084
2087
  w: i,
2085
2088
  h: l,
@@ -2097,8 +2100,8 @@ function q(e) {
2097
2100
  y: n
2098
2101
  };
2099
2102
  }
2100
- const oo = function(e, t, n) {
2101
- const o = H(e.nodes, t), s = H(e.nodes, n), i = o.offsetLeft + t.offsetWidth / 2, l = o.offsetTop + t.offsetHeight / 2, c = s.offsetLeft + n.offsetWidth / 2, r = s.offsetTop + n.offsetHeight / 2, a = c - i, d = r - l, h = Math.sqrt(a * a + d * d), u = Math.max(50, Math.min(200, h * 0.3)), y = Math.abs(a), b = Math.abs(d);
2103
+ const ao = function(e, t, n) {
2104
+ const o = $(e.nodes, t), s = $(e.nodes, n), i = o.offsetLeft + t.offsetWidth / 2, l = o.offsetTop + t.offsetHeight / 2, c = s.offsetLeft + n.offsetWidth / 2, r = s.offsetTop + n.offsetHeight / 2, a = c - i, d = r - l, h = Math.sqrt(a * a + d * d), u = Math.max(50, Math.min(200, h * 0.3)), y = Math.abs(a), b = Math.abs(d);
2102
2105
  let p, g;
2103
2106
  if (h < 150) {
2104
2107
  const v = t.closest("me-main").className === "lhs" ? -1 : 1;
@@ -2110,18 +2113,21 @@ const oo = function(e, t, n) {
2110
2113
  const v = d > 0 ? t.offsetHeight / 2 : -t.offsetHeight / 2, E = d > 0 ? -n.offsetHeight / 2 : n.offsetHeight / 2;
2111
2114
  p = { x: 0, y: v + (d > 0 ? u : -u) }, g = { x: 0, y: E + (d > 0 ? -u : u) };
2112
2115
  } else {
2113
- const v = Math.atan2(d, a), E = t.offsetWidth / 2 * Math.cos(v), k = t.offsetHeight / 2 * Math.sin(v), _ = -(n.offsetWidth / 2) * Math.cos(v), C = -(n.offsetHeight / 2) * Math.sin(v), x = u * 0.7 * (a > 0 ? 1 : -1), N = u * 0.7 * (d > 0 ? 1 : -1);
2114
- p = { x: E + x, y: k + N }, g = { x: _ - x, y: C - N };
2116
+ const v = Math.atan2(d, a), E = t.offsetWidth / 2 * Math.cos(v), k = t.offsetHeight / 2 * Math.sin(v), _ = -(n.offsetWidth / 2) * Math.cos(v), C = -(n.offsetHeight / 2) * Math.sin(v), w = u * 0.7 * (a > 0 ? 1 : -1), N = u * 0.7 * (d > 0 ? 1 : -1);
2117
+ p = { x: E + w, y: k + N }, g = { x: _ - w, y: C - N };
2115
2118
  }
2116
- return { delta1: p, delta2: g };
2117
- }, Ae = function(e, t, n, o, s) {
2119
+ return {
2120
+ delta1: { x: Math.round(p.x), y: Math.round(p.y) },
2121
+ delta2: { x: Math.round(g.x), y: Math.round(g.y) }
2122
+ };
2123
+ }, De = function(e, t, n, o, s) {
2118
2124
  if (!t || !n)
2119
2125
  return;
2120
2126
  if (!o.delta1 || !o.delta2) {
2121
- const S = oo(e, t, n);
2127
+ const S = ao(e, t, n);
2122
2128
  o.delta1 = S.delta1, o.delta2 = S.delta2;
2123
2129
  }
2124
- const i = de(e, t, o.delta1), l = de(e, n, o.delta2), { x: c, y: r } = q(i), { ctrlX: a, ctrlY: d } = i, { ctrlX: h, ctrlY: u } = l, { x: y, y: b } = q(l), p = ce(h, u, y, b);
2130
+ const i = ae(e, t, o.delta1), l = ae(e, n, o.delta2), { x: c, y: r } = q(i), { ctrlX: a, ctrlY: d } = i, { ctrlX: h, ctrlY: u } = l, { x: y, y: b } = q(l), p = ce(h, u, y, b);
2125
2131
  if (!p) return;
2126
2132
  const g = `M ${p.x1} ${p.y1} L ${y} ${b} L ${p.x2} ${p.y2}`;
2127
2133
  let m = "";
@@ -2130,16 +2136,16 @@ const oo = function(e, t, n) {
2130
2136
  if (!S) return;
2131
2137
  m = `M ${S.x1} ${S.y1} L ${c} ${r} L ${S.x2} ${S.y2}`;
2132
2138
  }
2133
- const v = Ln(`M ${c} ${r} C ${a} ${d} ${h} ${u} ${y} ${b}`, g, m, o.style), { x: E, y: k } = dt(c, r, a, d, h, u, y, b), _ = o.style?.labelColor || "rgb(235, 95, 82)", C = "arrow-" + o.id;
2139
+ const v = $n(`M ${c} ${r} C ${a} ${d} ${h} ${u} ${y} ${b}`, g, m, o.style), { x: E, y: k } = ht(c, r, a, d, h, u, y, b), _ = o.style?.labelColor || "rgb(235, 95, 82)", C = "arrow-" + o.id;
2134
2140
  v.id = C;
2135
- const x = e.markdown ? e.markdown(o.label, o) : o.label, N = ye(x, E, k, {
2141
+ const w = e.markdown ? e.markdown(o.label, o) : o.label, N = me(w, E, k, {
2136
2142
  anchor: "middle",
2137
2143
  color: _,
2138
2144
  dataType: "arrow",
2139
2145
  svgId: C
2140
2146
  });
2141
- v.labelEl = N, v.arrowObj = o, v.dataset.linkid = o.id, e.labelContainer.appendChild(N), e.linkSvgGroup.appendChild(v), fe(N), s || (e.arrows.push(o), e.currentArrow = v, ht(e, o, i, l));
2142
- }, so = function(e, t, n = {}) {
2147
+ v.labelEl = N, v.arrowObj = o, v.dataset.linkid = o.id, e.labelContainer.appendChild(N), e.linkSvgGroup.appendChild(v), he(N), s || (e.arrows.push(o), e.currentArrow = v, ft(e, o, i, l));
2148
+ }, ho = function(e, t, n = {}) {
2143
2149
  const o = {
2144
2150
  id: z(),
2145
2151
  label: "Custom Link",
@@ -2147,21 +2153,21 @@ const oo = function(e, t, n) {
2147
2153
  to: t.nodeObj.id,
2148
2154
  ...n
2149
2155
  };
2150
- Ae(this, e, t, o), this.bus.fire("operation", {
2156
+ De(this, e, t, o), this.bus.fire("operation", {
2151
2157
  name: "createArrow",
2152
2158
  obj: o
2153
2159
  });
2154
- }, io = function(e) {
2155
- ue(this);
2160
+ }, fo = function(e) {
2161
+ fe(this);
2156
2162
  const t = { ...e, id: z() };
2157
- Ae(this, this.findEle(t.from), this.findEle(t.to), t), this.bus.fire("operation", {
2163
+ De(this, this.findEle(t.from), this.findEle(t.to), t), this.bus.fire("operation", {
2158
2164
  name: "createArrow",
2159
2165
  obj: t
2160
2166
  });
2161
- }, ro = function(e) {
2167
+ }, uo = function(e) {
2162
2168
  let t;
2163
2169
  if (e ? t = e : t = this.currentArrow, !t) return;
2164
- ue(this);
2170
+ fe(this);
2165
2171
  const n = t.arrowObj.id;
2166
2172
  this.arrows = this.arrows.filter((o) => o.id !== n), t.labelEl?.remove(), t.remove(), this.bus.fire("operation", {
2167
2173
  name: "removeArrow",
@@ -2169,15 +2175,15 @@ const oo = function(e, t, n) {
2169
2175
  id: n
2170
2176
  }
2171
2177
  });
2172
- }, lo = function(e) {
2178
+ }, po = function(e) {
2173
2179
  this.currentArrow = e;
2174
- const t = e.arrowObj, n = this.findEle(t.from), o = this.findEle(t.to), s = de(this, n, t.delta1), i = de(this, o, t.delta2);
2175
- ht(this, t, s, i);
2176
- }, co = function() {
2177
- ue(this), this.currentArrow = null;
2178
- }, ge = function(e, t) {
2179
- const n = document.createElementNS(j, "path");
2180
- return D(n, {
2180
+ const t = e.arrowObj, n = this.findEle(t.from), o = this.findEle(t.to), s = ae(this, n, t.delta1), i = ae(this, o, t.delta2);
2181
+ ft(this, t, s, i);
2182
+ }, go = function() {
2183
+ fe(this), this.currentArrow = null;
2184
+ }, pe = function(e, t) {
2185
+ const n = document.createElementNS(H, "path");
2186
+ return A(n, {
2181
2187
  d: e,
2182
2188
  stroke: t,
2183
2189
  fill: "none",
@@ -2185,70 +2191,70 @@ const oo = function(e, t, n) {
2185
2191
  "stroke-linecap": "round",
2186
2192
  "stroke-linejoin": "round"
2187
2193
  }), n;
2188
- }, ao = function(e, t) {
2189
- const n = document.createElementNS(j, "g");
2194
+ }, mo = function(e, t) {
2195
+ const n = document.createElementNS(H, "g");
2190
2196
  n.setAttribute("class", "arrow-highlight"), n.setAttribute("opacity", "0.45");
2191
- const o = ge(e.line.getAttribute("d"), t);
2197
+ const o = pe(e.line.getAttribute("d"), t);
2192
2198
  n.appendChild(o);
2193
- const s = ge(e.arrow1.getAttribute("d"), t);
2199
+ const s = pe(e.arrow1.getAttribute("d"), t);
2194
2200
  if (n.appendChild(s), e.arrow2.getAttribute("d")) {
2195
- const i = ge(e.arrow2.getAttribute("d"), t);
2201
+ const i = pe(e.arrow2.getAttribute("d"), t);
2196
2202
  n.appendChild(i);
2197
2203
  }
2198
2204
  e.insertBefore(n, e.firstChild);
2199
- }, ho = function(e) {
2205
+ }, yo = function(e) {
2200
2206
  const t = e.querySelector(".arrow-highlight");
2201
2207
  t && t.remove();
2202
- }, fo = function(e) {
2208
+ }, bo = function(e) {
2203
2209
  const t = e.querySelector(".arrow-highlight");
2204
2210
  if (!t) return;
2205
2211
  const n = t.querySelectorAll("path");
2206
2212
  n.length >= 1 && n[0].setAttribute("d", e.line.getAttribute("d")), n.length >= 2 && n[1].setAttribute("d", e.arrow1.getAttribute("d")), n.length >= 3 && e.arrow2.getAttribute("d") && n[2].setAttribute("d", e.arrow2.getAttribute("d"));
2207
- }, ue = function(e) {
2208
- e.helper1?.destroy(), e.helper2?.destroy(), e.linkController.style.display = "none", e.P2.style.display = "none", e.P3.style.display = "none", e.currentArrow && ho(e.currentArrow);
2209
- }, ht = function(e, t, n, o) {
2213
+ }, fe = function(e) {
2214
+ e.helper1?.destroy(), e.helper2?.destroy(), e.linkController.style.display = "none", e.P2.style.display = "none", e.P3.style.display = "none", e.currentArrow && yo(e.currentArrow);
2215
+ }, ft = function(e, t, n, o) {
2210
2216
  const { linkController: s, P2: i, P3: l, line1: c, line2: r, nodes: a, map: d, currentArrow: h, bus: u } = e;
2211
2217
  if (!h) return;
2212
- s.style.display = "initial", i.style.display = "initial", l.style.display = "initial", a.appendChild(s), a.appendChild(i), a.appendChild(l), ao(h, to);
2218
+ s.style.display = "initial", i.style.display = "initial", l.style.display = "initial", a.appendChild(s), a.appendChild(i), a.appendChild(l), mo(h, lo);
2213
2219
  let { x: y, y: b } = q(n), { ctrlX: p, ctrlY: g } = n, { ctrlX: m, ctrlY: v } = o, { x: E, y: k } = q(o);
2214
- i.style.cssText = `top:${g}px;left:${p}px;`, l.style.cssText = `top:${v}px;left:${m}px;`, oe(c, y, b, p, g), oe(r, m, v, E, k), e.helper1 = ze.create(i), e.helper2 = ze.create(l), e.helper1.init(d, (_, C) => {
2220
+ i.style.cssText = `top:${g}px;left:${p}px;`, l.style.cssText = `top:${v}px;left:${m}px;`, se(c, y, b, p, g), se(r, m, v, E, k), e.helper1 = Ke.create(i), e.helper2 = Ke.create(l), e.helper1.init(d, (_, C) => {
2215
2221
  p = p + _ / e.scaleVal, g = g + C / e.scaleVal;
2216
- const x = q({ ...n, ctrlX: p, ctrlY: g });
2217
- y = x.x, b = x.y, i.style.top = g + "px", i.style.left = p + "px", Ke(h, y, b, p, g, m, v, E, k, t), oe(c, y, b, p, g), t.delta1.x = p - n.cx, t.delta1.y = g - n.cy, u.fire("updateArrowDelta", t);
2222
+ const w = q({ ...n, ctrlX: p, ctrlY: g });
2223
+ y = w.x, b = w.y, i.style.top = g + "px", i.style.left = p + "px", Ve(h, y, b, p, g, m, v, E, k, t), se(c, y, b, p, g), t.delta1.x = Math.round(p - n.cx), t.delta1.y = Math.round(g - n.cy), u.fire("updateArrowDelta", t);
2218
2224
  }), e.helper2.init(d, (_, C) => {
2219
2225
  m = m + _ / e.scaleVal, v = v + C / e.scaleVal;
2220
- const x = q({ ...o, ctrlX: m, ctrlY: v });
2221
- E = x.x, k = x.y, l.style.top = v + "px", l.style.left = m + "px", Ke(h, y, b, p, g, m, v, E, k, t), oe(r, m, v, E, k), t.delta2.x = m - o.cx, t.delta2.y = v - o.cy, u.fire("updateArrowDelta", t);
2226
+ const w = q({ ...o, ctrlX: m, ctrlY: v });
2227
+ E = w.x, k = w.y, l.style.top = v + "px", l.style.left = m + "px", Ve(h, y, b, p, g, m, v, E, k, t), se(r, m, v, E, k), t.delta2.x = Math.round(m - o.cx), t.delta2.y = Math.round(v - o.cy), u.fire("updateArrowDelta", t);
2222
2228
  });
2223
2229
  };
2224
- function uo() {
2230
+ function vo() {
2225
2231
  this.linkSvgGroup.innerHTML = "", this.labelContainer.querySelectorAll('.svg-label[data-type="arrow"]').forEach((t) => t.remove());
2226
2232
  for (let t = 0; t < this.arrows.length; t++) {
2227
2233
  const n = this.arrows[t];
2228
2234
  try {
2229
- Ae(this, this.findEle(n.from), this.findEle(n.to), n, !0);
2235
+ De(this, this.findEle(n.from), this.findEle(n.to), n, !0);
2230
2236
  } catch {
2231
2237
  }
2232
2238
  }
2233
2239
  this.nodes.appendChild(this.linkSvgGroup);
2234
2240
  }
2235
- function po(e) {
2236
- ue(this), e && e.labelEl && lt(this, e.labelEl, e.arrowObj);
2241
+ function xo(e) {
2242
+ fe(this), e && e.labelEl && ct(this, e.labelEl, e.arrowObj);
2237
2243
  }
2238
- function go() {
2244
+ function wo() {
2239
2245
  this.arrows = this.arrows.filter((e) => le(e.from, this.nodeData) && le(e.to, this.nodeData));
2240
2246
  }
2241
- const mo = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
2247
+ const Eo = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
2242
2248
  __proto__: null,
2243
- createArrow: so,
2244
- createArrowFrom: io,
2245
- editArrowLabel: po,
2246
- removeArrow: ro,
2247
- renderArrow: uo,
2248
- selectArrow: lo,
2249
- tidyArrow: go,
2250
- unselectArrow: co
2251
- }, Symbol.toStringTag, { value: "Module" })), yo = function(e) {
2249
+ createArrow: ho,
2250
+ createArrowFrom: fo,
2251
+ editArrowLabel: xo,
2252
+ removeArrow: uo,
2253
+ renderArrow: vo,
2254
+ selectArrow: po,
2255
+ tidyArrow: wo,
2256
+ unselectArrow: go
2257
+ }, Symbol.toStringTag, { value: "Module" })), Co = function(e) {
2252
2258
  if (e.length === 0) throw new Error("No selected node.");
2253
2259
  if (e.length === 1) {
2254
2260
  const r = e[0].nodeObj, a = e[0].nodeObj.parent;
@@ -2285,101 +2291,101 @@ const mo = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
2285
2291
  start: i,
2286
2292
  end: l
2287
2293
  };
2288
- }, bo = function(e) {
2289
- const t = document.createElementNS(j, "g");
2294
+ }, So = function(e) {
2295
+ const t = document.createElementNS(H, "g");
2290
2296
  return t.setAttribute("id", e), t;
2291
2297
  }, qe = function(e, t) {
2292
- const n = document.createElementNS(j, "path");
2293
- return D(n, {
2298
+ const n = document.createElementNS(H, "path");
2299
+ return A(n, {
2294
2300
  d: e,
2295
2301
  stroke: t || "#666",
2296
2302
  fill: "none",
2297
2303
  "stroke-linecap": "round",
2298
2304
  "stroke-width": "2"
2299
2305
  }), n;
2300
- }, vo = (e) => e.parentElement.parentElement, wo = function(e, { parent: t, start: n }) {
2306
+ }, No = (e) => e.parentElement.parentElement, To = function(e, { parent: t, start: n }) {
2301
2307
  const o = e.findEle(t), s = o.nodeObj;
2302
2308
  let i;
2303
2309
  return s.parent ? i = o.closest("me-main").className : i = e.findEle(s.children[n].id).closest("me-main").className, i;
2304
- }, Me = function(e, t) {
2305
- const { id: n, label: o, parent: s, start: i, end: l, style: c } = t, { nodes: r, theme: a, summarySvg: d } = e, u = e.findEle(s).nodeObj, y = wo(e, t);
2310
+ }, Ae = function(e, t) {
2311
+ const { id: n, label: o, parent: s, start: i, end: l, style: c } = t, { nodes: r, theme: a, summarySvg: d } = e, u = e.findEle(s).nodeObj, y = To(e, t);
2306
2312
  let b = 1 / 0, p = 0, g = 0, m = 0;
2307
2313
  for (let f = i; f <= l; f++) {
2308
- const w = u.children?.[f];
2309
- if (!w)
2314
+ const x = u.children?.[f];
2315
+ if (!x)
2310
2316
  return e.removeSummary(n), null;
2311
- const T = vo(e.findEle(w.id)), { offsetLeft: O, offsetTop: X } = H(r, T), M = i === l ? 10 : 20;
2312
- f === i && (g = X + M), f === l && (m = X + T.offsetHeight - M), O < b && (b = O), T.offsetWidth + O > p && (p = T.offsetWidth + O);
2317
+ const T = No(e.findEle(x.id)), { offsetLeft: P, offsetTop: Y } = $(r, T), D = i === l ? 10 : 20;
2318
+ f === i && (g = Y + D), f === l && (m = Y + T.offsetHeight - D), P < b && (b = P), T.offsetWidth + P > p && (p = T.offsetWidth + P);
2313
2319
  }
2314
2320
  let v, E;
2315
- const k = u.parent ? 10 : 0, _ = g + k, C = m + k, x = (_ + C) / 2, N = c?.stroke || a.cssVar["--color"], S = c?.labelColor || a.cssVar["--color"], A = "s-" + n, L = e.markdown ? e.markdown(o, t) : o;
2316
- y === B.LHS ? (v = qe(`M ${b + 10} ${_} c -5 0 -10 5 -10 10 L ${b} ${C - 10} c 0 5 5 10 10 10 M ${b} ${x} h -10`, N), E = ye(L, b - 20, x, { anchor: "end", color: S, dataType: "summary", svgId: A })) : (v = qe(`M ${p - 10} ${_} c 5 0 10 5 10 10 L ${p} ${C - 10} c 0 5 -5 10 -10 10 M ${p} ${x} h 10`, N), E = ye(L, p + 20, x, { anchor: "start", color: S, dataType: "summary", svgId: A }));
2317
- const R = bo(A);
2318
- return R.appendChild(v), e.labelContainer.appendChild(E), fe(E), R.summaryObj = t, R.labelEl = E, d.appendChild(R), R;
2319
- }, xo = function(e = {}) {
2321
+ const k = u.parent ? 10 : 0, _ = g + k, C = m + k, w = (_ + C) / 2, N = c?.stroke || a.cssVar["--color"], S = c?.labelColor || a.cssVar["--color"], M = "s-" + n, L = e.markdown ? e.markdown(o, t) : o;
2322
+ y === B.LHS ? (v = qe(`M ${b + 10} ${_} c -5 0 -10 5 -10 10 L ${b} ${C - 10} c 0 5 5 10 10 10 M ${b} ${w} h -10`, N), E = me(L, b - 20, w, { anchor: "end", color: S, dataType: "summary", svgId: M })) : (v = qe(`M ${p - 10} ${_} c 5 0 10 5 10 10 L ${p} ${C - 10} c 0 5 -5 10 -10 10 M ${p} ${w} h 10`, N), E = me(L, p + 20, w, { anchor: "start", color: S, dataType: "summary", svgId: M }));
2323
+ const I = So(M);
2324
+ return I.appendChild(v), e.labelContainer.appendChild(E), he(E), I.summaryObj = t, I.labelEl = E, d.appendChild(I), I;
2325
+ }, _o = function(e = {}) {
2320
2326
  if (!this.currentNodes) return;
2321
- const { currentNodes: t, summaries: n, bus: o } = this, { parent: s, start: i, end: l } = yo(t), c = { id: z(), parent: s, start: i, end: l, label: "summary", style: e.style }, r = Me(this, c);
2327
+ const { currentNodes: t, summaries: n, bus: o } = this, { parent: s, start: i, end: l } = Co(t), c = { id: z(), parent: s, start: i, end: l, label: "summary", style: e.style }, r = Ae(this, c);
2322
2328
  n.push(c), this.editSummary(r), o.fire("operation", {
2323
2329
  name: "createSummary",
2324
2330
  obj: c
2325
2331
  });
2326
- }, Eo = function(e) {
2332
+ }, ko = function(e) {
2327
2333
  const t = z(), n = { ...e, id: t };
2328
- Me(this, n), this.summaries.push(n), this.bus.fire("operation", {
2334
+ Ae(this, n), this.summaries.push(n), this.bus.fire("operation", {
2329
2335
  name: "createSummary",
2330
2336
  obj: n
2331
2337
  });
2332
- }, Co = function(e) {
2338
+ }, Lo = function(e) {
2333
2339
  const t = this.summaries.findIndex((n) => n.id === e);
2334
2340
  t > -1 && (this.summaries.splice(t, 1), this.nodes.querySelector("#s-" + e)?.remove(), this.nodes.querySelector("#label-s-" + e)?.remove()), this.bus.fire("operation", {
2335
2341
  name: "removeSummary",
2336
2342
  obj: { id: e }
2337
2343
  });
2338
- }, So = function(e) {
2344
+ }, Do = function(e) {
2339
2345
  const t = e.labelEl;
2340
2346
  t && t.classList.add("selected"), this.currentSummary = e;
2341
- }, No = function() {
2347
+ }, Ao = function() {
2342
2348
  this.currentSummary?.labelEl?.classList.remove("selected"), this.currentSummary = null;
2343
- }, To = function() {
2349
+ }, Mo = function() {
2344
2350
  this.summarySvg.innerHTML = "", this.summaries.forEach((e) => {
2345
2351
  try {
2346
- Me(this, e);
2352
+ Ae(this, e);
2347
2353
  } catch {
2348
2354
  }
2349
2355
  }), this.nodes.insertAdjacentElement("beforeend", this.summarySvg);
2350
- }, _o = function(e) {
2351
- e && e.labelEl && lt(this, e.labelEl, e.summaryObj);
2352
- }, ko = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
2356
+ }, Po = function(e) {
2357
+ e && e.labelEl && ct(this, e.labelEl, e.summaryObj);
2358
+ }, Oo = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
2353
2359
  __proto__: null,
2354
- createSummary: xo,
2355
- createSummaryFrom: Eo,
2356
- editSummary: _o,
2357
- removeSummary: Co,
2358
- renderSummary: To,
2359
- selectSummary: So,
2360
- unselectSummary: No
2361
- }, Symbol.toStringTag, { value: "Module" })), P = "http://www.w3.org/2000/svg";
2362
- function Lo(e, t) {
2363
- const n = document.createElementNS(P, "svg");
2364
- return D(n, {
2360
+ createSummary: _o,
2361
+ createSummaryFrom: ko,
2362
+ editSummary: Po,
2363
+ removeSummary: Lo,
2364
+ renderSummary: Mo,
2365
+ selectSummary: Do,
2366
+ unselectSummary: Ao
2367
+ }, Symbol.toStringTag, { value: "Module" })), O = "http://www.w3.org/2000/svg";
2368
+ function $o(e, t) {
2369
+ const n = document.createElementNS(O, "svg");
2370
+ return A(n, {
2365
2371
  version: "1.1",
2366
- xmlns: P,
2372
+ xmlns: O,
2367
2373
  height: e,
2368
2374
  width: t
2369
2375
  }), n;
2370
2376
  }
2371
- function Do(e, t) {
2377
+ function Ho(e, t) {
2372
2378
  return (parseInt(e) - parseInt(t)) / 2;
2373
2379
  }
2374
- function Ao(e, t, n, o) {
2375
- const s = document.createElementNS(P, "g");
2380
+ function jo(e, t, n, o) {
2381
+ const s = document.createElementNS(O, "g");
2376
2382
  let i = "";
2377
2383
  return e.text ? i = e.text.textContent : i = e.childNodes[0].textContent, i.split(`
2378
2384
  `).forEach((c, r) => {
2379
- const a = document.createElementNS(P, "text");
2380
- D(a, {
2385
+ const a = document.createElementNS(O, "text");
2386
+ A(a, {
2381
2387
  x: n + parseInt(t.paddingLeft) + "",
2382
- y: o + parseInt(t.paddingTop) + Do(t.lineHeight, t.fontSize) * (r + 1) + parseFloat(t.fontSize) * (r + 1) + "",
2388
+ y: o + parseInt(t.paddingTop) + Ho(t.lineHeight, t.fontSize) * (r + 1) + parseFloat(t.fontSize) * (r + 1) + "",
2383
2389
  "text-anchor": "start",
2384
2390
  "font-family": t.fontFamily,
2385
2391
  "font-size": `${t.fontSize}`,
@@ -2388,25 +2394,25 @@ function Ao(e, t, n, o) {
2388
2394
  }), a.innerHTML = c, s.appendChild(a);
2389
2395
  }), s;
2390
2396
  }
2391
- function Mo(e, t, n, o) {
2397
+ function Io(e, t, n, o) {
2392
2398
  let s = "";
2393
2399
  e.nodeObj?.dangerouslySetInnerHTML ? s = e.nodeObj.dangerouslySetInnerHTML : e.text ? s = e.text.textContent : s = e.childNodes[0].textContent;
2394
- const i = document.createElementNS(P, "foreignObject");
2395
- D(i, {
2400
+ const i = document.createElementNS(O, "foreignObject");
2401
+ A(i, {
2396
2402
  x: n + parseInt(t.paddingLeft) + "",
2397
2403
  y: o + parseInt(t.paddingTop) + "",
2398
2404
  width: t.width,
2399
2405
  height: t.height
2400
2406
  });
2401
2407
  const l = document.createElement("div");
2402
- return D(l, {
2408
+ return A(l, {
2403
2409
  xmlns: "http://www.w3.org/1999/xhtml",
2404
2410
  style: `font-family: ${t.fontFamily}; font-size: ${t.fontSize}; font-weight: ${t.fontWeight}; color: ${t.color}; white-space: pre-wrap;`
2405
2411
  }), l.innerHTML = s, i.appendChild(l), i;
2406
2412
  }
2407
- function Po(e, t) {
2408
- const n = getComputedStyle(t), { offsetLeft: o, offsetTop: s } = H(e.nodes, t), i = document.createElementNS(P, "rect");
2409
- return D(i, {
2413
+ function Ro(e, t) {
2414
+ const n = getComputedStyle(t), { offsetLeft: o, offsetTop: s } = $(e.nodes, t), i = document.createElementNS(O, "rect");
2415
+ return A(i, {
2410
2416
  x: o + "",
2411
2417
  y: s + "",
2412
2418
  rx: n.borderRadius,
@@ -2418,9 +2424,9 @@ function Po(e, t) {
2418
2424
  "stroke-width": n.borderWidth
2419
2425
  }), i;
2420
2426
  }
2421
- function se(e, t, n = !1) {
2422
- const o = getComputedStyle(t), { offsetLeft: s, offsetTop: i } = H(e.nodes, t), l = document.createElementNS(P, "rect");
2423
- D(l, {
2427
+ function ie(e, t, n = !1) {
2428
+ const o = getComputedStyle(t), { offsetLeft: s, offsetTop: i } = $(e.nodes, t), l = document.createElementNS(O, "rect");
2429
+ A(l, {
2424
2430
  x: s + "",
2425
2431
  y: i + "",
2426
2432
  rx: o.borderRadius,
@@ -2431,14 +2437,14 @@ function se(e, t, n = !1) {
2431
2437
  stroke: o.borderColor,
2432
2438
  "stroke-width": o.borderWidth
2433
2439
  });
2434
- const c = document.createElementNS(P, "g");
2440
+ const c = document.createElementNS(O, "g");
2435
2441
  c.appendChild(l);
2436
2442
  let r;
2437
- return n ? r = Mo(t, o, s, i) : r = Ao(t, o, s, i), c.appendChild(r), c;
2443
+ return n ? r = Io(t, o, s, i) : r = jo(t, o, s, i), c.appendChild(r), c;
2438
2444
  }
2439
- function Oo(e, t) {
2440
- const n = getComputedStyle(t), { offsetLeft: o, offsetTop: s } = H(e.nodes, t), i = document.createElementNS(P, "a"), l = document.createElementNS(P, "text");
2441
- return D(l, {
2445
+ function Bo(e, t) {
2446
+ const n = getComputedStyle(t), { offsetLeft: o, offsetTop: s } = $(e.nodes, t), i = document.createElementNS(O, "a"), l = document.createElementNS(O, "text");
2447
+ return A(l, {
2442
2448
  x: o + "",
2443
2449
  y: s + parseInt(n.fontSize) + "",
2444
2450
  "text-anchor": "start",
@@ -2448,9 +2454,9 @@ function Oo(e, t) {
2448
2454
  fill: `${n.color}`
2449
2455
  }), l.innerHTML = t.textContent, i.appendChild(l), i.setAttribute("href", t.href), i;
2450
2456
  }
2451
- function $o(e, t) {
2452
- const n = getComputedStyle(t), { offsetLeft: o, offsetTop: s } = H(e.nodes, t), i = document.createElementNS(P, "image");
2453
- return D(i, {
2457
+ function Wo(e, t) {
2458
+ const n = getComputedStyle(t), { offsetLeft: o, offsetTop: s } = $(e.nodes, t), i = document.createElementNS(O, "image");
2459
+ return A(i, {
2454
2460
  x: o + "",
2455
2461
  y: s + "",
2456
2462
  width: n.width + "",
@@ -2458,16 +2464,16 @@ function $o(e, t) {
2458
2464
  href: t.src
2459
2465
  }), i;
2460
2466
  }
2461
- const ie = 100, Ho = '<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">', jo = (e, t = !1) => {
2462
- const n = e.nodes, o = n.offsetHeight + ie * 2, s = n.offsetWidth + ie * 2, i = Lo(o + "px", s + "px"), l = document.createElementNS(P, "svg"), c = document.createElementNS(P, "rect");
2463
- D(c, {
2467
+ const re = 100, Yo = '<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">', Xo = (e, t = !1) => {
2468
+ const n = e.nodes, o = n.offsetHeight + re * 2, s = n.offsetWidth + re * 2, i = $o(o + "px", s + "px"), l = document.createElementNS(O, "svg"), c = document.createElementNS(O, "rect");
2469
+ A(c, {
2464
2470
  x: "0",
2465
2471
  y: "0",
2466
2472
  width: `${s}`,
2467
2473
  height: `${o}`,
2468
2474
  fill: e.theme.cssVar["--bgcolor"]
2469
2475
  }), i.appendChild(c), n.querySelectorAll(".subLines").forEach((h) => {
2470
- const u = h.cloneNode(!0), { offsetLeft: y, offsetTop: b } = H(n, h.parentElement);
2476
+ const u = h.cloneNode(!0), { offsetLeft: y, offsetTop: b } = $(n, h.parentElement);
2471
2477
  u.setAttribute("x", `${y}`), u.setAttribute("y", `${b}`), l.appendChild(u);
2472
2478
  });
2473
2479
  const r = n.querySelector(".lines")?.cloneNode(!0);
@@ -2476,22 +2482,22 @@ const ie = 100, Ho = '<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC
2476
2482
  a && l.appendChild(a);
2477
2483
  const d = n.querySelector(".summary")?.cloneNode(!0);
2478
2484
  return d && l.appendChild(d), n.querySelectorAll("me-tpc").forEach((h) => {
2479
- h.nodeObj.dangerouslySetInnerHTML ? l.appendChild(se(e, h, !t)) : (l.appendChild(Po(e, h)), l.appendChild(se(e, h.text, !t)));
2485
+ h.nodeObj.dangerouslySetInnerHTML ? l.appendChild(ie(e, h, !t)) : (l.appendChild(Ro(e, h)), l.appendChild(ie(e, h.text, !t)));
2480
2486
  }), n.querySelectorAll(".tags > span").forEach((h) => {
2481
- l.appendChild(se(e, h));
2487
+ l.appendChild(ie(e, h));
2482
2488
  }), n.querySelectorAll(".icons > span").forEach((h) => {
2483
- l.appendChild(se(e, h));
2489
+ l.appendChild(ie(e, h));
2484
2490
  }), n.querySelectorAll(".hyper-link").forEach((h) => {
2485
- l.appendChild(Oo(e, h));
2491
+ l.appendChild(Bo(e, h));
2486
2492
  }), n.querySelectorAll("img").forEach((h) => {
2487
- l.appendChild($o(e, h));
2488
- }), D(l, {
2489
- x: ie + "",
2490
- y: ie + "",
2493
+ l.appendChild(Wo(e, h));
2494
+ }), A(l, {
2495
+ x: re + "",
2496
+ y: re + "",
2491
2497
  overflow: "visible"
2492
2498
  }), i.appendChild(l), i;
2493
- }, Io = (e, t) => (t && e.insertAdjacentHTML("afterbegin", "<style>" + t + "</style>"), Ho + e.outerHTML);
2494
- function Ro(e) {
2499
+ }, Fo = (e, t) => (t && e.insertAdjacentHTML("afterbegin", "<style>" + t + "</style>"), Yo + e.outerHTML);
2500
+ function Go(e) {
2495
2501
  return new Promise((t, n) => {
2496
2502
  const o = new FileReader();
2497
2503
  o.onload = (s) => {
@@ -2501,11 +2507,11 @@ function Ro(e) {
2501
2507
  }, o.readAsDataURL(e);
2502
2508
  });
2503
2509
  }
2504
- const Bo = function(e = !1, t) {
2505
- const n = jo(this, e), o = Io(n, t);
2510
+ const zo = function(e = !1, t) {
2511
+ const n = Xo(this, e), o = Fo(n, t);
2506
2512
  return new Blob([o], { type: "image/svg+xml" });
2507
- }, Yo = async function(e = !1, t) {
2508
- const n = this.exportSvg(e, t), o = await Ro(n);
2513
+ }, Ko = async function(e = !1, t) {
2514
+ const n = this.exportSvg(e, t), o = await Go(n);
2509
2515
  return new Promise((s, i) => {
2510
2516
  const l = new Image();
2511
2517
  l.setAttribute("crossOrigin", "anonymous"), l.onload = () => {
@@ -2513,48 +2519,48 @@ const Bo = function(e = !1, t) {
2513
2519
  c.width = l.width, c.height = l.height, c.getContext("2d").drawImage(l, 0, 0), c.toBlob(s, "image/png", 1);
2514
2520
  }, l.src = o, l.onerror = i;
2515
2521
  });
2516
- }, Wo = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
2522
+ }, Vo = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
2517
2523
  __proto__: null,
2518
- exportPng: Yo,
2519
- exportSvg: Bo
2524
+ exportPng: Ko,
2525
+ exportSvg: zo
2520
2526
  }, Symbol.toStringTag, { value: "Module" }));
2521
- function Xo(e, t) {
2527
+ function qo(e, t) {
2522
2528
  return async function(...n) {
2523
2529
  const o = this.before[t];
2524
2530
  o && !await o.apply(this, n) || e.apply(this, n);
2525
2531
  };
2526
2532
  }
2527
- const Ue = Object.keys(ot), ft = {};
2533
+ const Ue = Object.keys(it), ut = {};
2528
2534
  for (let e = 0; e < Ue.length; e++) {
2529
2535
  const t = Ue[e];
2530
- ft[t] = Xo(ot[t], t);
2536
+ ut[t] = qo(it[t], t);
2531
2537
  }
2532
- const Fo = {
2538
+ const Uo = {
2533
2539
  getObjById: le,
2534
- generateNewObj: ut,
2535
- layout: pt,
2536
- linkDiv: Dn,
2537
- editTopic: xt,
2538
- createWrapper: yt,
2539
- createParent: bt,
2540
- createChildren: vt,
2541
- createTopic: wt,
2542
- findEle: Ze,
2543
- changeTheme: Qn,
2544
- ...un,
2545
- ...ft,
2546
- ...mo,
2547
- ...ko,
2548
- ...Wo,
2540
+ generateNewObj: pt,
2541
+ layout: Ct,
2542
+ linkDiv: Hn,
2543
+ editTopic: Dt,
2544
+ createWrapper: Tt,
2545
+ createParent: _t,
2546
+ createChildren: kt,
2547
+ createTopic: Lt,
2548
+ findEle: et,
2549
+ changeTheme: io,
2550
+ ...En,
2551
+ ...ut,
2552
+ ...Eo,
2553
+ ...Oo,
2554
+ ...Vo,
2549
2555
  init(e) {
2550
2556
  if (e = JSON.parse(JSON.stringify(e)), !e || !e.nodeData) return new Error("MindElixir: `data` is required");
2551
- e.direction !== void 0 && (this.direction = e.direction), this.changeTheme(e.theme || this.theme, !1), this.nodeData = e.nodeData, V(this.nodeData), this.arrows = e.arrows || [], this.summaries = e.summaries || [], this.tidyArrow(), this.toolBar && Gn(this), this.keypress && bn(this, this.keypress), Zn(this), this.disposable.push(Tn()), this.contextMenu && this.disposable.push(Mn(this, this.contextMenu)), this.allowUndo && this.disposable.push(On(this)), this.layout(), this.linkDiv(), this.toCenter();
2557
+ e.direction !== void 0 && (this.direction = e.direction), this.changeTheme(e.theme || this.theme, !1), this.nodeData = e.nodeData, G(this.nodeData), this.arrows = e.arrows || [], this.summaries = e.summaries || [], this.tidyArrow(), this.toolBar && Jn(this), this.keypress && Mn(this, this.keypress), so(this), this.disposable.push(Et()), this.contextMenu && this.disposable.push(In(this, this.contextMenu)), this.allowUndo && this.disposable.push(Bn(this)), this.layout(), this.linkDiv(), this.toCenter();
2552
2558
  },
2553
2559
  destroy() {
2554
2560
  this.disposable.forEach((e) => e()), this.el && (this.el.innerHTML = ""), this.el = void 0, this.nodeData = void 0, this.arrows = void 0, this.summaries = void 0, this.currentArrow = void 0, this.currentNodes = void 0, this.currentSummary = void 0, this.theme = void 0, this.direction = void 0, this.bus = void 0, this.container = void 0, this.map = void 0, this.lines = void 0, this.linkController = void 0, this.linkSvgGroup = void 0, this.P2 = void 0, this.P3 = void 0, this.line1 = void 0, this.line2 = void 0, this.nodes = void 0, this.selection?.destroy(), this.selection = void 0;
2555
2561
  }
2556
2562
  };
2557
- function Go({ pT: e, pL: t, pW: n, pH: o, cT: s, cL: i, cW: l, cH: c, direction: r, containerHeight: a }) {
2563
+ function Jo({ pT: e, pL: t, pW: n, pH: o, cT: s, cL: i, cW: l, cH: c, direction: r, containerHeight: a }) {
2558
2564
  let d = t + n / 2;
2559
2565
  const h = e + o / 2;
2560
2566
  let u;
@@ -2562,7 +2568,7 @@ function Go({ pT: e, pL: t, pW: n, pH: o, cT: s, cL: i, cW: l, cH: c, direction:
2562
2568
  const y = s + c / 2, p = (1 - Math.abs(y - h) / a) * 0.25 * (n / 2);
2563
2569
  return r === B.LHS ? d = d - n / 10 - p : d = d + n / 10 + p, `M ${d} ${h} Q ${d} ${y} ${u} ${y}`;
2564
2570
  }
2565
- function Vo({ pT: e, pL: t, pW: n, pH: o, cT: s, cL: i, cW: l, cH: c, direction: r, isFirst: a }) {
2571
+ function Zo({ pT: e, pL: t, pW: n, pH: o, cT: s, cL: i, cW: l, cH: c, direction: r, isFirst: a }) {
2566
2572
  const d = parseInt(this.container.style.getPropertyValue("--node-gap-x"));
2567
2573
  let h = 0, u = 0;
2568
2574
  a ? h = e + o / 2 : h = e + o;
@@ -2571,8 +2577,8 @@ function Vo({ pT: e, pL: t, pW: n, pH: o, cT: s, cL: i, cW: l, cH: c, direction:
2571
2577
  const m = Math.abs(h - y) / 300 * d;
2572
2578
  return r === B.LHS ? (g = t, b = g + d, p = g - d, u = i + d, `M ${b} ${h} C ${g} ${h} ${g + m} ${y} ${p} ${y} H ${u}`) : (g = t + n, b = g - d, p = g + d, u = i + l - d, `M ${b} ${h} C ${g} ${h} ${g - m} ${y} ${p} ${y} H ${u}`);
2573
2579
  }
2574
- const zo = "5.10.1-beta.1";
2575
- function Ko(e) {
2580
+ const Qo = "5.11.0";
2581
+ function es(e) {
2576
2582
  return {
2577
2583
  x: 0,
2578
2584
  y: 0,
@@ -2587,7 +2593,7 @@ function Ko(e) {
2587
2593
  }
2588
2594
  };
2589
2595
  }
2590
- function I({
2596
+ function j({
2591
2597
  el: e,
2592
2598
  direction: t,
2593
2599
  editable: n,
@@ -2612,30 +2618,30 @@ function I({
2612
2618
  imageProxy: _,
2613
2619
  pasteHandler: C
2614
2620
  }) {
2615
- let x = null;
2621
+ let w = null;
2616
2622
  const N = Object.prototype.toString.call(e);
2617
- if (N === "[object HTMLDivElement]" ? x = e : N === "[object String]" && (x = document.querySelector(e)), !x) throw new Error("MindElixir: el is not a valid element");
2618
- x.style.position = "relative", x.innerHTML = "", this.el = x, this.disposable = [], this.before = r || {}, this.newTopicName = a || "New Node", this.contextMenu = o ?? !0, this.toolBar = s ?? !0, this.keypress = i ?? !0, this.mouseSelectionButton = l ?? 0, this.direction = t ?? 1, this.editable = n ?? !0, this.allowUndo = d ?? !0, this.scaleSensitivity = g ?? 0.1, this.scaleMax = m ?? 1.4, this.scaleMin = v ?? 0.2, this.generateMainBranch = h || Go, this.generateSubBranch = u || Vo, this.overflowHidden = y ?? !1, this.alignment = p ?? "root", this.handleWheel = E ?? !0, this.markdown = k || void 0, this.imageProxy = _ || void 0, this.currentNodes = [], this.currentArrow = null, this.scaleVal = 1, this.tempDirection = null, this.dragMoveHelper = Ko(this), this.bus = kn(), this.container = document.createElement("div"), this.selectionContainer = c || this.container, this.container.className = "map-container";
2623
+ if (N === "[object HTMLDivElement]" ? w = e : N === "[object String]" && (w = document.querySelector(e)), !w) throw new Error("MindElixir: el is not a valid element");
2624
+ w.style.position = "relative", w.innerHTML = "", this.el = w, this.disposable = [], this.before = r || {}, this.newTopicName = a || "New Node", this.contextMenu = o ?? !0, this.toolBar = s ?? !0, this.keypress = i ?? !0, this.mouseSelectionButton = l ?? 0, this.direction = t ?? 1, this.editable = n ?? !0, this.allowUndo = d ?? !0, this.scaleSensitivity = g ?? 0.1, this.scaleMax = m ?? 1.4, this.scaleMin = v ?? 0.2, this.generateMainBranch = h || Jo, this.generateSubBranch = u || Zo, this.overflowHidden = y ?? !1, this.alignment = p ?? "root", this.handleWheel = E ?? !0, this.markdown = k || void 0, this.imageProxy = _ || void 0, this.currentNodes = [], this.currentArrow = null, this.scaleVal = 1, this.tempDirection = null, this.panHelper = es(this), this.bus = On(), this.container = document.createElement("div"), this.selectionContainer = c || this.container, this.container.className = "map-container";
2619
2625
  const S = window.matchMedia("(prefers-color-scheme: dark)");
2620
- this.theme = b || (S.matches ? we : ve);
2621
- const A = document.createElement("div");
2622
- A.className = "map-canvas", this.map = A, this.container.setAttribute("tabindex", "0"), this.container.appendChild(this.map), this.el.appendChild(this.container), this.nodes = document.createElement("me-nodes"), this.lines = Q("lines"), this.summarySvg = Q("summary"), this.linkController = Q("linkcontroller"), this.P2 = document.createElement("div"), this.P3 = document.createElement("div"), this.P2.className = this.P3.className = "circle", this.P2.style.display = this.P3.style.display = "none", this.line1 = Re(), this.line2 = Re(), this.linkController.appendChild(this.line1), this.linkController.appendChild(this.line2), this.linkSvgGroup = Q("topiclinks"), this.labelContainer = document.createElement("div"), this.labelContainer.className = "label-container", this.map.appendChild(this.nodes), this.overflowHidden ? this.container.style.overflow = "hidden" : this.disposable.push(_n(this)), C && (this.pasteHandler = C);
2626
+ this.theme = b || (S.matches ? ve : be);
2627
+ const M = document.createElement("div");
2628
+ M.className = "map-canvas", this.map = M, this.container.setAttribute("tabindex", "0"), this.container.appendChild(this.map), this.el.appendChild(this.container), this.nodes = document.createElement("me-nodes"), this.lines = te("lines"), this.summarySvg = te("summary"), this.linkController = te("linkcontroller"), this.P2 = document.createElement("div"), this.P3 = document.createElement("div"), this.P2.className = this.P3.className = "circle", this.P2.style.display = this.P3.style.display = "none", this.line1 = Re(), this.line2 = Re(), this.linkController.appendChild(this.line1), this.linkController.appendChild(this.line2), this.linkSvgGroup = te("topiclinks"), this.labelContainer = document.createElement("div"), this.labelContainer.className = "label-container", this.map.appendChild(this.nodes), this.overflowHidden ? this.container.style.overflow = "hidden" : this.disposable.push(Pn(this)), C && (this.pasteHandler = C);
2623
2629
  }
2624
- I.prototype = Fo;
2625
- Object.defineProperty(I.prototype, "currentNode", {
2630
+ j.prototype = Uo;
2631
+ Object.defineProperty(j.prototype, "currentNode", {
2626
2632
  get() {
2627
2633
  return this.currentNodes[this.currentNodes.length - 1];
2628
2634
  },
2629
2635
  enumerable: !0
2630
2636
  });
2631
- I.LEFT = 0;
2632
- I.RIGHT = 1;
2633
- I.SIDE = 2;
2634
- I.THEME = ve;
2635
- I.DARK_THEME = we;
2636
- I.version = zo;
2637
- I.E = Ze;
2638
- I.new = (e) => ({
2637
+ j.LEFT = 0;
2638
+ j.RIGHT = 1;
2639
+ j.SIDE = 2;
2640
+ j.THEME = be;
2641
+ j.DARK_THEME = ve;
2642
+ j.version = Qo;
2643
+ j.E = et;
2644
+ j.new = (e) => ({
2639
2645
  nodeData: {
2640
2646
  id: z(),
2641
2647
  topic: e || "new topic",
@@ -2643,10 +2649,10 @@ I.new = (e) => ({
2643
2649
  }
2644
2650
  });
2645
2651
  export {
2646
- we as DARK_THEME,
2647
- qo as LEFT,
2648
- Uo as RIGHT,
2649
- Jo as SIDE,
2650
- ve as THEME,
2651
- I as default
2652
+ ve as DARK_THEME,
2653
+ ts as LEFT,
2654
+ ns as RIGHT,
2655
+ os as SIDE,
2656
+ be as THEME,
2657
+ j as default
2652
2658
  };