@anu3ev/fabric-image-editor 0.5.20 → 0.5.22

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.
Files changed (2) hide show
  1. package/dist/main.js +1096 -934
  2. package/package.json +1 -1
package/dist/main.js CHANGED
@@ -1,25 +1,25 @@
1
- var cs = Object.defineProperty, ds = Object.defineProperties;
2
- var ls = Object.getOwnPropertyDescriptors;
3
- var Vt = Object.getOwnPropertySymbols;
4
- var Re = Object.prototype.hasOwnProperty, _e = Object.prototype.propertyIsEnumerable;
5
- var De = (h, t, e) => t in h ? cs(h, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : h[t] = e, B = (h, t) => {
1
+ var ds = Object.defineProperty, ls = Object.defineProperties;
2
+ var hs = Object.getOwnPropertyDescriptors;
3
+ var ne = Object.getOwnPropertySymbols;
4
+ var Ne = Object.prototype.hasOwnProperty, xe = Object.prototype.propertyIsEnumerable;
5
+ var _e = (h, t, e) => t in h ? ds(h, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : h[t] = e, B = (h, t) => {
6
6
  for (var e in t || (t = {}))
7
- Re.call(t, e) && De(h, e, t[e]);
8
- if (Vt)
9
- for (var e of Vt(t))
10
- _e.call(t, e) && De(h, e, t[e]);
7
+ Ne.call(t, e) && _e(h, e, t[e]);
8
+ if (ne)
9
+ for (var e of ne(t))
10
+ xe.call(t, e) && _e(h, e, t[e]);
11
11
  return h;
12
- }, bt = (h, t) => ds(h, ls(t));
13
- var Mt = (h, t) => {
12
+ }, wt = (h, t) => ls(h, hs(t));
13
+ var gt = (h, t) => {
14
14
  var e = {};
15
15
  for (var s in h)
16
- Re.call(h, s) && t.indexOf(s) < 0 && (e[s] = h[s]);
17
- if (h != null && Vt)
18
- for (var s of Vt(h))
19
- t.indexOf(s) < 0 && _e.call(h, s) && (e[s] = h[s]);
16
+ Ne.call(h, s) && t.indexOf(s) < 0 && (e[s] = h[s]);
17
+ if (h != null && ne)
18
+ for (var s of ne(h))
19
+ t.indexOf(s) < 0 && xe.call(h, s) && (e[s] = h[s]);
20
20
  return e;
21
21
  };
22
- var k = (h, t, e) => new Promise((s, n) => {
22
+ var z = (h, t, e) => new Promise((s, n) => {
23
23
  var o = (r) => {
24
24
  try {
25
25
  a(e.next(r));
@@ -35,15 +35,15 @@ var k = (h, t, e) => new Promise((s, n) => {
35
35
  }, a = (r) => r.done ? s(r.value) : Promise.resolve(r.value).then(o, i);
36
36
  a((e = e.apply(h, t)).next());
37
37
  });
38
- import { ActiveSelection as U, Textbox as st, util as lt, controlsUtils as xe, InteractiveFabricObject as Ne, Point as tt, FitContentLayout as Be, loadSVGFromURL as hs, FabricImage as zt, Gradient as ke, Rect as us, Circle as fs, Triangle as gs, Group as Et, Color as ps, classRegistry as ze, loadSVGFromString as ms, Canvas as ys, Pattern as vs } from "fabric";
39
- import { create as bs } from "jsondiffpatch";
40
- import Ms from "diff-match-patch";
41
- var ws = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict", V = function() {
38
+ import { ActiveSelection as U, Textbox as ot, util as ut, controlsUtils as Be, InteractiveFabricObject as ke, Point as tt, FitContentLayout as We, loadSVGFromURL as us, FabricImage as Zt, Gradient as ze, Rect as fs, Circle as gs, Triangle as ps, Group as Et, Color as ms, classRegistry as Pe, loadSVGFromString as ys, Canvas as vs, Pattern as bs } from "fabric";
39
+ import { create as Ms } from "jsondiffpatch";
40
+ import ws from "diff-match-patch";
41
+ var Ss = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict", V = function() {
42
42
  for (var t = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : 21, e = "", s = crypto.getRandomValues(new Uint8Array(t |= 0)); t--; )
43
- e += ws[s[t] & 63];
43
+ e += Ss[s[t] & 63];
44
44
  return e;
45
45
  };
46
- class Ft {
46
+ class Xt {
47
47
  /**
48
48
  * Конструктор принимает редактор и опции.
49
49
  * @param params
@@ -61,7 +61,7 @@ class Ft {
61
61
  * @param params.options.adaptCanvasToContainerOnResize — адаптировать канвас к размерам контейнера при изменении размеров окна
62
62
  */
63
63
  constructor({ editor: t, options: e = {} }) {
64
- this.isDragging = !1, this.lastMouseX = 0, this.lastMouseY = 0, this.isUndoRedoKeyPressed = !1, this.isSpacePressed = !1, this.savedSelection = [], this.canvasDragging = !1, this.mouseWheelZooming = !1, this.bringToFrontOnSelection = !1, this.resetObjectFitByDoubleClick = !1, this.copyObjectsByHotkey = !1, this.pasteImageFromClipboard = !1, this.undoRedoByHotKeys = !1, this.selectAllByHotkey = !1, this.deleteObjectsByHotkey = !1, this.adaptCanvasToContainerOnResize = !1, this.editor = t, this.canvas = t.canvas, this.options = e, this.handleContainerResizeBound = Ft.debounce(this.handleContainerResize.bind(this), 500), this.handleCopyEventBound = this.handleCopyEvent.bind(this), this.handlePasteEventBound = this.handlePasteEvent.bind(this), this.handleUndoRedoEventBound = this.handleUndoRedoEvent.bind(this), this.handleUndoRedoKeyUpBound = this.handleUndoRedoKeyUp.bind(this), this.handleSelectAllEventBound = this.handleSelectAllEvent.bind(this), this.handleDeleteObjectsEventBound = this.handleDeleteObjectsEvent.bind(this), this.handleSpaceKeyDownBound = this.handleSpaceKeyDown.bind(this), this.handleSpaceKeyUpBound = this.handleSpaceKeyUp.bind(this), this.handleObjectModifiedHistoryBound = Ft.debounce(this.handleObjectModifiedHistory.bind(this), 300), this.handleObjectRotatingHistoryBound = Ft.debounce(this.handleObjectRotatingHistory.bind(this), 300), this.handleObjectAddedHistoryBound = this.handleObjectAddedHistory.bind(this), this.handleObjectRemovedHistoryBound = this.handleObjectRemovedHistory.bind(this), this.handleOverlayUpdateBound = this.handleOverlayUpdate.bind(this), this.handleBackgroundUpdateBound = this.handleBackgroundUpdate.bind(this), this.handleCanvasDragStartBound = this.handleCanvasDragStart.bind(this), this.handleCanvasDraggingBound = this.handleCanvasDragging.bind(this), this.handleCanvasDragEndBound = this.handleCanvasDragEnd.bind(this), this.handleMouseWheelZoomBound = this.handleMouseWheelZoom.bind(this), this.handleBringToFrontBound = this.handleBringToFront.bind(this), this.handleResetObjectFitBound = this.handleResetObjectFit.bind(this), this.handleLockedSelectionBound = this._filterLockedSelection.bind(this), this.init();
64
+ this.isDragging = !1, this.lastMouseX = 0, this.lastMouseY = 0, this.isUndoRedoKeyPressed = !1, this.isSpacePressed = !1, this.savedSelection = [], this.canvasDragging = !1, this.mouseWheelZooming = !1, this.bringToFrontOnSelection = !1, this.resetObjectFitByDoubleClick = !1, this.copyObjectsByHotkey = !1, this.pasteImageFromClipboard = !1, this.undoRedoByHotKeys = !1, this.selectAllByHotkey = !1, this.deleteObjectsByHotkey = !1, this.adaptCanvasToContainerOnResize = !1, this.editor = t, this.canvas = t.canvas, this.options = e, this.handleContainerResizeBound = Xt.debounce(this.handleContainerResize.bind(this), 500), this.handleCopyEventBound = this.handleCopyEvent.bind(this), this.handlePasteEventBound = this.handlePasteEvent.bind(this), this.handleUndoRedoEventBound = this.handleUndoRedoEvent.bind(this), this.handleUndoRedoKeyUpBound = this.handleUndoRedoKeyUp.bind(this), this.handleSelectAllEventBound = this.handleSelectAllEvent.bind(this), this.handleDeleteObjectsEventBound = this.handleDeleteObjectsEvent.bind(this), this.handleSpaceKeyDownBound = this.handleSpaceKeyDown.bind(this), this.handleSpaceKeyUpBound = this.handleSpaceKeyUp.bind(this), this.handleObjectModifiedHistoryBound = Xt.debounce(this.handleObjectModifiedHistory.bind(this), 300), this.handleObjectRotatingHistoryBound = Xt.debounce(this.handleObjectRotatingHistory.bind(this), 300), this.handleObjectAddedHistoryBound = this.handleObjectAddedHistory.bind(this), this.handleObjectRemovedHistoryBound = this.handleObjectRemovedHistory.bind(this), this.handleOverlayUpdateBound = this.handleOverlayUpdate.bind(this), this.handleBackgroundUpdateBound = this.handleBackgroundUpdate.bind(this), this.handleCanvasDragStartBound = this.handleCanvasDragStart.bind(this), this.handleCanvasDraggingBound = this.handleCanvasDragging.bind(this), this.handleCanvasDragEndBound = this.handleCanvasDragEnd.bind(this), this.handleMouseWheelZoomBound = this.handleMouseWheelZoom.bind(this), this.handleBringToFrontBound = this.handleBringToFront.bind(this), this.handleResetObjectFitBound = this.handleResetObjectFit.bind(this), this.handleLockedSelectionBound = this._filterLockedSelection.bind(this), this.init();
65
65
  }
66
66
  /**
67
67
  * Инициализация всех обработчиков согласно опциям.
@@ -175,7 +175,7 @@ class Ft {
175
175
  * @param event.code — код клавиши
176
176
  */
177
177
  handleUndoRedoEvent(t) {
178
- return k(this, null, function* () {
178
+ return z(this, null, function* () {
179
179
  const { ctrlKey: e, metaKey: s, code: n, repeat: o } = t;
180
180
  this._shouldIgnoreKeyboardEvent(t) || !e && !s || o || !/Mac/i.test(navigator.userAgent) && this.isUndoRedoKeyPressed || (n === "KeyZ" ? (t.preventDefault(), this.isUndoRedoKeyPressed = !0, yield this.editor.historyManager.undo()) : n === "KeyY" && (t.preventDefault(), this.isUndoRedoKeyPressed = !0, yield this.editor.historyManager.redo()));
181
181
  });
@@ -223,7 +223,7 @@ class Ft {
223
223
  }
224
224
  const { canvas: s, editor: n, isSpacePressed: o, isDragging: i } = this;
225
225
  if (o || i) return;
226
- this.isSpacePressed = !0, t.preventDefault();
226
+ n.historyManager.skipHistory || n.historyManager.saveState(), n.historyManager.suspendHistory(), this.isSpacePressed = !0, t.preventDefault();
227
227
  const a = s.getActiveObject() || null;
228
228
  a instanceof U ? this.savedSelection = a.getObjects().slice() : a && (this.savedSelection = [a]), s.discardActiveObject(), s.set({
229
229
  selection: !1,
@@ -244,7 +244,7 @@ class Ft {
244
244
  */
245
245
  handleSpaceKeyUp(t) {
246
246
  const { code: e } = t;
247
- e !== "Space" || this._shouldIgnoreKeyboardEvent(t) || this.isSpacePressed && (this.isSpacePressed = !1, this.isDragging && this.handleCanvasDragEnd(), this.canvas.set({
247
+ e === "Space" && (this._shouldIgnoreKeyboardEvent(t) && !this.isSpacePressed || this.isSpacePressed && (this.isSpacePressed = !1, this.isDragging && this.handleCanvasDragEnd(), this.canvas.set({
248
248
  defaultCursor: "default",
249
249
  selection: !0
250
250
  }), this.canvas.setCursor("default"), this.editor.canvasManager.getObjects().forEach((s) => {
@@ -252,7 +252,7 @@ class Ft {
252
252
  selectable: !0,
253
253
  evented: !0
254
254
  });
255
- }), this._restoreSelection(this.savedSelection), this.savedSelection = [], this.canvas.requestRenderAll());
255
+ }), this._restoreSelection(this.savedSelection), this.savedSelection = [], this.editor.historyManager.resumeHistory(), this.canvas.requestRenderAll()));
256
256
  }
257
257
  /**
258
258
  * Восстанавливает выделение с проверкой корректности объектов
@@ -347,7 +347,7 @@ class Ft {
347
347
  */
348
348
  handleResetObjectFit(t) {
349
349
  const e = t == null ? void 0 : t.target;
350
- !e || e instanceof st || this.editor.transformManager.resetObject({ object: e });
350
+ !e || e instanceof ot || this.editor.transformManager.resetObject({ object: e });
351
351
  }
352
352
  /**
353
353
  * Проверяет, должно ли событие клавиатуры быть проигнорировано
@@ -408,7 +408,7 @@ class Ft {
408
408
  };
409
409
  }
410
410
  }
411
- class Ss {
411
+ class As {
412
412
  /**
413
413
  * Класс для динамической загрузки внешних модулей.
414
414
  */
@@ -426,7 +426,7 @@ class Ss {
426
426
  return this.loaders[t] ? (this.cache.has(t) || this.cache.set(t, this.loaders[t]()), this.cache.get(t)) : Promise.reject(new Error(`Unknown module "${t}"`));
427
427
  }
428
428
  }
429
- function As(h) {
429
+ function js(h) {
430
430
  return new Worker(
431
431
  "" + new URL("assets/worker-CN39s7P7.js", import.meta.url).href,
432
432
  {
@@ -434,13 +434,13 @@ function As(h) {
434
434
  }
435
435
  );
436
436
  }
437
- class js {
437
+ class Is {
438
438
  /**
439
439
  * @param scriptUrl — URL скрипта воркера.
440
440
  * По-умолчанию использует DefaultWorker из соседнего файла
441
441
  */
442
442
  constructor(t) {
443
- t ? this.worker = new Worker(t, { type: "module" }) : this.worker = new As(), this._callbacks = /* @__PURE__ */ new Map(), this.worker.onmessage = this._handleMessage.bind(this);
443
+ t ? this.worker = new Worker(t, { type: "module" }) : this.worker = new js(), this._callbacks = /* @__PURE__ */ new Map(), this.worker.onmessage = this._handleMessage.bind(this);
444
444
  }
445
445
  /**
446
446
  * Обработчик сообщений от воркера
@@ -480,95 +480,95 @@ class js {
480
480
  this.worker.terminate();
481
481
  }
482
482
  }
483
- const ct = 12, Is = 2, le = 8, he = 20, Cs = 100, ue = 20, fe = 8, Ts = 100, $t = 32, ye = 1, Es = "#2B2D33", ve = "#3D8BF4", be = "#FFFFFF";
484
- function Xt(h, t, e, s, n) {
485
- const o = ct, i = Is;
486
- h.save(), h.translate(t, e), h.rotate(lt.degreesToRadians(n.angle)), h.fillStyle = be, h.strokeStyle = ve, h.lineWidth = ye, h.beginPath(), h.roundRect(-o / 2, -o / 2, o, o, i), h.fill(), h.stroke(), h.restore();
483
+ const lt = 12, Cs = 2, ve = 8, be = 20, Ts = 100, Me = 20, we = 8, Es = 100, de = 32, Ie = 1, Os = "#2B2D33", Ce = "#3D8BF4", Te = "#FFFFFF";
484
+ function oe(h, t, e, s, n) {
485
+ const o = lt, i = Cs;
486
+ h.save(), h.translate(t, e), h.rotate(ut.degreesToRadians(n.angle)), h.fillStyle = Te, h.strokeStyle = Ce, h.lineWidth = Ie, h.beginPath(), h.roundRect(-o / 2, -o / 2, o, o, i), h.fill(), h.stroke(), h.restore();
487
487
  }
488
488
  function Ue(h, t, e, s, n) {
489
- const o = le, i = he, a = Cs;
490
- h.save(), h.translate(t, e), h.rotate(lt.degreesToRadians(n.angle)), h.fillStyle = be, h.strokeStyle = ve, h.lineWidth = ye, h.beginPath(), h.roundRect(-o / 2, -i / 2, o, i, a), h.fill(), h.stroke(), h.restore();
489
+ const o = ve, i = be, a = Ts;
490
+ h.save(), h.translate(t, e), h.rotate(ut.degreesToRadians(n.angle)), h.fillStyle = Te, h.strokeStyle = Ce, h.lineWidth = Ie, h.beginPath(), h.roundRect(-o / 2, -i / 2, o, i, a), h.fill(), h.stroke(), h.restore();
491
491
  }
492
- function Pe(h, t, e, s, n) {
493
- const o = ue, i = fe, a = Ts;
494
- h.save(), h.translate(t, e), h.rotate(lt.degreesToRadians(n.angle)), h.fillStyle = be, h.strokeStyle = ve, h.lineWidth = ye, h.beginPath(), h.roundRect(-o / 2, -i / 2, o, i, a), h.fill(), h.stroke(), h.restore();
492
+ function Fe(h, t, e, s, n) {
493
+ const o = Me, i = we, a = Es;
494
+ h.save(), h.translate(t, e), h.rotate(ut.degreesToRadians(n.angle)), h.fillStyle = Te, h.strokeStyle = Ce, h.lineWidth = Ie, h.beginPath(), h.roundRect(-o / 2, -i / 2, o, i, a), h.fill(), h.stroke(), h.restore();
495
495
  }
496
- const Os = "", ts = new Image();
497
- ts.src = Os;
498
- function Ls(h, t, e, s, n) {
499
- const i = $t / 2;
500
- h.save(), h.translate(t, e), h.rotate(lt.degreesToRadians(n.angle)), h.fillStyle = Es, h.beginPath(), h.arc(0, 0, i, 0, 2 * Math.PI), h.fill(), h.drawImage(ts, -i / 2, -i / 2, i, i), h.restore();
496
+ const Ls = "", ss = new Image();
497
+ ss.src = Ls;
498
+ function Ds(h, t, e, s, n) {
499
+ const i = de / 2;
500
+ h.save(), h.translate(t, e), h.rotate(ut.degreesToRadians(n.angle)), h.fillStyle = Os, h.beginPath(), h.arc(0, 0, i, 0, 2 * Math.PI), h.fill(), h.drawImage(ss, -i / 2, -i / 2, i, i), h.restore();
501
501
  }
502
- const Ds = {
502
+ const Rs = {
503
503
  // Угловые точки
504
504
  tl: {
505
- render: Xt,
506
- sizeX: ct,
507
- sizeY: ct,
505
+ render: oe,
506
+ sizeX: lt,
507
+ sizeY: lt,
508
508
  offsetX: 0,
509
509
  offsetY: 0
510
510
  },
511
511
  tr: {
512
- render: Xt,
513
- sizeX: ct,
514
- sizeY: ct,
512
+ render: oe,
513
+ sizeX: lt,
514
+ sizeY: lt,
515
515
  offsetX: 0,
516
516
  offsetY: 0
517
517
  },
518
518
  bl: {
519
- render: Xt,
520
- sizeX: ct,
521
- sizeY: ct,
519
+ render: oe,
520
+ sizeX: lt,
521
+ sizeY: lt,
522
522
  offsetX: 0,
523
523
  offsetY: 0
524
524
  },
525
525
  br: {
526
- render: Xt,
527
- sizeX: ct,
528
- sizeY: ct,
526
+ render: oe,
527
+ sizeX: lt,
528
+ sizeY: lt,
529
529
  offsetX: 0,
530
530
  offsetY: 0
531
531
  },
532
532
  // Середина вертикалей
533
533
  ml: {
534
534
  render: Ue,
535
- sizeX: le,
536
- sizeY: he,
535
+ sizeX: ve,
536
+ sizeY: be,
537
537
  offsetX: 0,
538
538
  offsetY: 0
539
539
  },
540
540
  mr: {
541
541
  render: Ue,
542
- sizeX: le,
543
- sizeY: he,
542
+ sizeX: ve,
543
+ sizeY: be,
544
544
  offsetX: 0,
545
545
  offsetY: 0
546
546
  },
547
547
  // Середина горизонталей
548
548
  mt: {
549
- render: Pe,
550
- sizeX: ue,
551
- sizeY: fe,
549
+ render: Fe,
550
+ sizeX: Me,
551
+ sizeY: we,
552
552
  offsetX: 0,
553
553
  offsetY: 0
554
554
  },
555
555
  mb: {
556
- render: Pe,
557
- sizeX: ue,
558
- sizeY: fe,
556
+ render: Fe,
557
+ sizeX: Me,
558
+ sizeY: we,
559
559
  offsetX: 0,
560
560
  offsetY: 0
561
561
  },
562
562
  // Специальный «rotate» контрол
563
563
  mtr: {
564
- render: Ls,
565
- sizeX: $t,
566
- sizeY: $t,
564
+ render: Ds,
565
+ sizeX: de,
566
+ sizeY: de,
567
567
  offsetX: 0,
568
- offsetY: -$t
568
+ offsetY: -de
569
569
  }
570
570
  };
571
- class $ {
571
+ class et {
572
572
  /**
573
573
  * Отключает изменение ширины по оси X для заблокированных объектов, сохраняя поведение остального хэндлера.
574
574
  */
@@ -584,7 +584,7 @@ class $ {
584
584
  * Применяет конфигурацию контролов к набору по ключам из DEFAULT_CONTROLS.
585
585
  */
586
586
  static applyControlOverrides(t) {
587
- Object.entries(Ds).forEach(([e, s]) => {
587
+ Object.entries(Rs).forEach(([e, s]) => {
588
588
  const n = t[e];
589
589
  n && (Object.assign(n, s), e === "mtr" && (n.cursorStyle = "grab", n.mouseDownHandler = (o, i, a, r) => {
590
590
  var d;
@@ -597,10 +597,10 @@ class $ {
597
597
  * Регистрирует контролы и настройки поведения выделений.
598
598
  */
599
599
  static apply() {
600
- const t = xe.createObjectDefaultControls();
601
- $.applyControlOverrides(t), Ne.ownDefaults.controls = t;
602
- const e = xe.createTextboxDefaultControls();
603
- $.applyControlOverrides(e), e.mt && (e.mt.visible = !1), e.mb && (e.mb.visible = !1), $.wrapWidthControl(e.ml), $.wrapWidthControl(e.mr), st.ownDefaults.controls = e, $.patchActiveSelectionBounds(), Ne.ownDefaults.snapAngle = 1;
600
+ const t = Be.createObjectDefaultControls();
601
+ et.applyControlOverrides(t), ke.ownDefaults.controls = t;
602
+ const e = Be.createTextboxDefaultControls();
603
+ et.applyControlOverrides(e), e.mt && (e.mt.visible = !1), e.mb && (e.mb.visible = !1), et.wrapWidthControl(e.ml), et.wrapWidthControl(e.mr), ot.ownDefaults.controls = e, et.patchActiveSelectionBounds(), ke.ownDefaults.snapAngle = 1;
604
604
  }
605
605
  /**
606
606
  * Обновляет алгоритм расчёта границ ActiveSelection, чтобы учитывать фон и отступы текстовых объектов.
@@ -610,11 +610,11 @@ class $ {
610
610
  t._calcBoundsFromObjects = function(...o) {
611
611
  var f, g;
612
612
  const i = (g = (f = this.getObjects) == null ? void 0 : f.call(this)) != null ? g : [];
613
- $.applyTextSelectionScalingLock({
613
+ et.applyTextSelectionScalingLock({
614
614
  selection: this,
615
615
  objects: i
616
616
  });
617
- const a = $.calculateActiveSelectionBounds({
617
+ const a = et.calculateActiveSelectionBounds({
618
618
  objects: i
619
619
  });
620
620
  if (!a)
@@ -633,11 +633,11 @@ class $ {
633
633
  t._onAfterObjectsChange = function(o, i) {
634
634
  var p, m;
635
635
  const a = s ? s.call(this, o, i) : void 0, r = (m = (p = this.getObjects) == null ? void 0 : p.call(this)) != null ? m : [];
636
- $.applyTextSelectionScalingLock({
636
+ et.applyTextSelectionScalingLock({
637
637
  selection: this,
638
638
  objects: r
639
639
  });
640
- const c = $.calculateActiveSelectionBounds({
640
+ const c = et.calculateActiveSelectionBounds({
641
641
  objects: r
642
642
  });
643
643
  if (!c) return a;
@@ -647,18 +647,18 @@ class $ {
647
647
  height: f
648
648
  }), this.setPositionByOrigin(g, "center", "center"), this.setCoords(), a;
649
649
  };
650
- const n = Be.prototype.calcBoundingBox;
651
- Be.prototype.calcBoundingBox = function(o, i) {
650
+ const n = We.prototype.calcBoundingBox;
651
+ We.prototype.calcBoundingBox = function(o, i) {
652
652
  const { target: a, type: r, overrides: c } = i;
653
653
  if (r === "imperative" && c)
654
654
  return c;
655
655
  if (!(a instanceof U))
656
656
  return n.call(this, o, i);
657
- $.applyTextSelectionScalingLock({
657
+ et.applyTextSelectionScalingLock({
658
658
  selection: a,
659
659
  objects: o
660
660
  });
661
- const d = $.calculateActiveSelectionBounds({ objects: o });
661
+ const d = et.calculateActiveSelectionBounds({ objects: o });
662
662
  if (!d)
663
663
  return n.call(this, o, i);
664
664
  const { left: l, top: u, width: f, height: g } = d, p = new tt(f, g), m = new tt(l + f / 2, u + g / 2);
@@ -694,7 +694,7 @@ class $ {
694
694
  selection: t,
695
695
  objects: e
696
696
  }) {
697
- const s = e.some((n) => n instanceof st);
697
+ const s = e.some((n) => n instanceof ot);
698
698
  t.setControlsVisibility({
699
699
  mt: !s,
700
700
  mb: !s,
@@ -703,7 +703,7 @@ class $ {
703
703
  });
704
704
  }
705
705
  }
706
- const z = class z {
706
+ const P = class P {
707
707
  constructor(t = []) {
708
708
  this.fonts = t;
709
709
  }
@@ -711,36 +711,36 @@ const z = class z {
711
711
  this.fonts = t;
712
712
  }
713
713
  loadFonts() {
714
- return k(this, null, function* () {
714
+ return z(this, null, function* () {
715
715
  var n;
716
716
  const t = (n = this.fonts) != null ? n : [];
717
717
  if (!t.length) return;
718
718
  const e = typeof document != "undefined" ? document : void 0;
719
719
  if (!e) return;
720
- const s = t.map((o) => z.loadFont(o, e));
720
+ const s = t.map((o) => P.loadFont(o, e));
721
721
  yield Promise.allSettled(s);
722
722
  });
723
723
  }
724
724
  static loadFont(t, e) {
725
- return k(this, null, function* () {
725
+ return z(this, null, function* () {
726
726
  var c, d;
727
727
  const s = typeof FontFace != "undefined", n = (c = t.family) == null ? void 0 : c.trim(), o = (d = t.source) == null ? void 0 : d.trim();
728
728
  if (!n || !o) return;
729
- const i = z.normalizeFontSource(o), a = z.getDescriptorSnapshot(t.descriptors), r = z.getFontRegistrationKey(n, i, a);
730
- if (!z.registeredFontKeys.has(r)) {
731
- if (z.isFontFaceAlreadyApplied(e, n, a)) {
732
- z.registeredFontKeys.add(r);
729
+ const i = P.normalizeFontSource(o), a = P.getDescriptorSnapshot(t.descriptors), r = P.getFontRegistrationKey(n, i, a);
730
+ if (!P.registeredFontKeys.has(r)) {
731
+ if (P.isFontFaceAlreadyApplied(e, n, a)) {
732
+ P.registeredFontKeys.add(r);
733
733
  return;
734
734
  }
735
735
  if (s && e.fonts && typeof e.fonts.add == "function")
736
736
  try {
737
737
  const u = yield new FontFace(n, i, t.descriptors).load();
738
- e.fonts.add(u), z.registeredFontKeys.add(r);
738
+ e.fonts.add(u), P.registeredFontKeys.add(r);
739
739
  return;
740
740
  } catch (l) {
741
741
  console.warn(`Не удалось загрузить шрифт "${n}" через FontFace API`, l);
742
742
  }
743
- z.injectFontFace({
743
+ P.injectFontFace({
744
744
  font: t,
745
745
  source: i,
746
746
  doc: e,
@@ -760,15 +760,15 @@ const z = class z {
760
760
  if (!i) return;
761
761
  const a = s.createElement("style");
762
762
  a.setAttribute("data-editor-font", i), a.setAttribute("data-editor-font-key", n);
763
- const r = z.descriptorsToCss(o), c = [
763
+ const r = P.descriptorsToCss(o), c = [
764
764
  "@font-face {",
765
- ` font-family: ${z.formatFontFamilyForCss(i)};`,
765
+ ` font-family: ${P.formatFontFamilyForCss(i)};`,
766
766
  ` src: ${e};`,
767
767
  ...r.map((l) => ` ${l}`),
768
768
  "}"
769
769
  ];
770
770
  a.textContent = c.join(`
771
- `), s.head.appendChild(a), z.registeredFontKeys.add(n);
771
+ `), s.head.appendChild(a), P.registeredFontKeys.add(n);
772
772
  }
773
773
  static normalizeFontSource(t) {
774
774
  const e = t.trim();
@@ -791,15 +791,15 @@ const z = class z {
791
791
  return t ? t.trim().replace(/^['"]+|['"]+$/g, "").toLowerCase() : "";
792
792
  }
793
793
  static getDescriptorSnapshot(t) {
794
- const e = z.descriptorDefaults;
794
+ const e = P.descriptorDefaults;
795
795
  return {
796
- style: z.normalizeDescriptorValue(t == null ? void 0 : t.style, e.style),
797
- weight: z.normalizeDescriptorValue(t == null ? void 0 : t.weight, e.weight),
798
- stretch: z.normalizeDescriptorValue(t == null ? void 0 : t.stretch, e.stretch),
799
- unicodeRange: z.normalizeDescriptorValue(t == null ? void 0 : t.unicodeRange, e.unicodeRange),
800
- variant: z.normalizeDescriptorValue(t == null ? void 0 : t.variant, e.variant),
801
- featureSettings: z.normalizeDescriptorValue(t == null ? void 0 : t.featureSettings, e.featureSettings),
802
- display: z.normalizeDescriptorValue(t == null ? void 0 : t.display, e.display)
796
+ style: P.normalizeDescriptorValue(t == null ? void 0 : t.style, e.style),
797
+ weight: P.normalizeDescriptorValue(t == null ? void 0 : t.weight, e.weight),
798
+ stretch: P.normalizeDescriptorValue(t == null ? void 0 : t.stretch, e.stretch),
799
+ unicodeRange: P.normalizeDescriptorValue(t == null ? void 0 : t.unicodeRange, e.unicodeRange),
800
+ variant: P.normalizeDescriptorValue(t == null ? void 0 : t.variant, e.variant),
801
+ featureSettings: P.normalizeDescriptorValue(t == null ? void 0 : t.featureSettings, e.featureSettings),
802
+ display: P.normalizeDescriptorValue(t == null ? void 0 : t.display, e.display)
803
803
  };
804
804
  }
805
805
  static areDescriptorSnapshotsEqual(t, e) {
@@ -807,7 +807,7 @@ const z = class z {
807
807
  }
808
808
  static getFontRegistrationKey(t, e, s) {
809
809
  return [
810
- z.normalizeFamilyName(t),
810
+ P.normalizeFamilyName(t),
811
811
  e,
812
812
  s.style,
813
813
  s.weight,
@@ -821,12 +821,12 @@ const z = class z {
821
821
  static isFontFaceAlreadyApplied(t, e, s) {
822
822
  const n = t.fonts;
823
823
  if (!n || typeof n.forEach != "function") return !1;
824
- const o = z.normalizeFamilyName(e);
824
+ const o = P.normalizeFamilyName(e);
825
825
  let i = !1;
826
826
  try {
827
827
  n.forEach((a) => {
828
- if (i || z.normalizeFamilyName(a.family) !== o) return;
829
- const c = z.getDescriptorSnapshot({
828
+ if (i || P.normalizeFamilyName(a.family) !== o) return;
829
+ const c = P.getDescriptorSnapshot({
830
830
  style: a.style,
831
831
  weight: a.weight,
832
832
  stretch: a.stretch,
@@ -835,7 +835,7 @@ const z = class z {
835
835
  featureSettings: a.featureSettings,
836
836
  display: a.display
837
837
  });
838
- z.areDescriptorSnapshotsEqual(s, c) && (i = !0);
838
+ P.areDescriptorSnapshotsEqual(s, c) && (i = !0);
839
839
  });
840
840
  } catch (a) {
841
841
  return console.warn("Не удалось проверить, загружен ли шрифт ранее через FontFaceSet", a), !1;
@@ -862,7 +862,7 @@ const z = class z {
862
862
  });
863
863
  }
864
864
  };
865
- z.registeredFontKeys = /* @__PURE__ */ new Set(), z.descriptorDefaults = {
865
+ P.registeredFontKeys = /* @__PURE__ */ new Set(), P.descriptorDefaults = {
866
866
  style: "normal",
867
867
  weight: "normal",
868
868
  stretch: "normal",
@@ -871,8 +871,8 @@ z.registeredFontKeys = /* @__PURE__ */ new Set(), z.descriptorDefaults = {
871
871
  featureSettings: "normal",
872
872
  display: "auto"
873
873
  };
874
- let ge = z;
875
- const Rs = "", _s = "", xs = "", Ns = "", Bs = "", ks = "", zs = "", Us = "", Ut = {
874
+ let Se = P;
875
+ const _s = "", Ns = "", xs = "", Bs = "", ks = "", Ws = "", zs = "", Ps = "", Gt = {
876
876
  style: {
877
877
  position: "absolute",
878
878
  display: "none",
@@ -939,17 +939,17 @@ const Rs = "
939
939
  ],
940
940
  offsetTop: 50,
941
941
  icons: {
942
- copyPaste: Rs,
943
- delete: Us,
944
- lock: _s,
942
+ copyPaste: _s,
943
+ delete: Ps,
944
+ lock: Ns,
945
945
  unlock: xs,
946
- bringToFront: ks,
946
+ bringToFront: Ws,
947
947
  sendToBack: zs,
948
- bringForward: Ns,
949
- sendBackwards: Bs
948
+ bringForward: Bs,
949
+ sendBackwards: ks
950
950
  },
951
951
  handlers: {
952
- copyPaste: (h) => k(null, null, function* () {
952
+ copyPaste: (h) => z(null, null, function* () {
953
953
  h.clipboardManager.copyPaste();
954
954
  }),
955
955
  delete: (h) => {
@@ -975,18 +975,18 @@ const Rs = "
975
975
  }
976
976
  }
977
977
  };
978
- class Ps {
978
+ class Us {
979
979
  constructor({ editor: t }) {
980
980
  this.currentTarget = null, this.currentLocked = !1, this.isTransforming = !1, this.isTemporarilyHidden = !1, this.editor = t, this.canvas = t.canvas, this.options = t.options, this._initToolbar();
981
981
  }
982
982
  _initToolbar() {
983
983
  if (!this.options.showToolbar) return;
984
984
  const t = this.options.toolbar || {};
985
- this.config = bt(B(B({}, Ut), t), {
986
- style: B(B({}, Ut.style), t.style || {}),
987
- btnStyle: B(B({}, Ut.btnStyle), t.btnStyle || {}),
988
- icons: B(B({}, Ut.icons), t.icons || {}),
989
- handlers: B(B({}, Ut.handlers), t.handlers || {})
985
+ this.config = wt(B(B({}, Gt), t), {
986
+ style: B(B({}, Gt.style), t.style || {}),
987
+ btnStyle: B(B({}, Gt.btnStyle), t.btnStyle || {}),
988
+ icons: B(B({}, Gt.icons), t.icons || {}),
989
+ handlers: B(B({}, Gt.handlers), t.handlers || {})
990
990
  }), this.currentTarget = null, this.currentLocked = !1, this.isTransforming = !1, this.isTemporarilyHidden = !1, this._onMouseDown = this._handleMouseDown.bind(this), this._onObjectMoving = this._startTransform.bind(this), this._onObjectScaling = this._startTransform.bind(this), this._onObjectRotating = this._startTransform.bind(this), this._onMouseUp = this._endTransform.bind(this), this._onObjectModified = this._endTransform.bind(this), this._onSelectionChange = this._updateToolbar.bind(this), this._onSelectionClear = () => {
991
991
  this.el.style.display = "none";
992
992
  }, this._createDOM(), this._bindEvents();
@@ -1117,8 +1117,8 @@ const Fs = {
1117
1117
  "pointer-events": "none",
1118
1118
  "white-space": "nowrap",
1119
1119
  "box-shadow": "0 2px 8px rgba(0, 0, 0, 0.2)"
1120
- }, Fe = 16, We = 16, Ws = "fabric-editor-angle-indicator";
1121
- class Me {
1120
+ }, Ye = 16, He = 16, Ys = "fabric-editor-angle-indicator";
1121
+ class Ee {
1122
1122
  constructor({ editor: t }) {
1123
1123
  this.isActive = !1, this.currentAngle = 0, this.editor = t, this.canvas = t.canvas, this.options = t.options, this._createDOM(), this._bindEvents();
1124
1124
  }
@@ -1126,7 +1126,7 @@ class Me {
1126
1126
  * Создание DOM-элемента индикатора
1127
1127
  */
1128
1128
  _createDOM() {
1129
- this.el = document.createElement("div"), this.el.className = Ws, Object.entries(Fs).forEach(([t, e]) => {
1129
+ this.el = document.createElement("div"), this.el.className = Ys, Object.entries(Fs).forEach(([t, e]) => {
1130
1130
  this.el.style.setProperty(t, e);
1131
1131
  }), this.canvas.wrapperEl.appendChild(this.el);
1132
1132
  }
@@ -1146,7 +1146,7 @@ class Me {
1146
1146
  return;
1147
1147
  }
1148
1148
  const s = e.angle || 0;
1149
- this.currentAngle = Me._normalizeAngle(s), this.el.textContent = `${this.currentAngle}°`, this._positionIndicator(t.e), this.isActive || this._showIndicator();
1149
+ this.currentAngle = Ee._normalizeAngle(s), this.el.textContent = `${this.currentAngle}°`, this._positionIndicator(t.e), this.isActive || this._showIndicator();
1150
1150
  }
1151
1151
  /**
1152
1152
  * Обработчик отпускания кнопки мыши
@@ -1177,9 +1177,9 @@ class Me {
1177
1177
  */
1178
1178
  _positionIndicator(t) {
1179
1179
  const e = this.canvas.wrapperEl.getBoundingClientRect();
1180
- let s = t.clientX - e.left + Fe, n = t.clientY - e.top + We;
1180
+ let s = t.clientX - e.left + Ye, n = t.clientY - e.top + He;
1181
1181
  const o = this.el.getBoundingClientRect(), i = o.width, a = o.height;
1182
- s + i > e.width && (s = t.clientX - e.left - i - Fe), n + a > e.height && (n = t.clientY - e.top - a - We), this.el.style.left = `${s}px`, this.el.style.top = `${n}px`;
1182
+ s + i > e.width && (s = t.clientX - e.left - i - Ye), n + a > e.height && (n = t.clientY - e.top - a - He), this.el.style.left = `${s}px`, this.el.style.top = `${n}px`;
1183
1183
  }
1184
1184
  /**
1185
1185
  * Показать индикатор
@@ -1210,7 +1210,7 @@ class Me {
1210
1210
  this.canvas && (this.canvas.off("object:rotating", this._onObjectRotating), this.canvas.off("mouse:up", this._onMouseUp), this.canvas.off("object:modified", this._onObjectModified), this.canvas.off("selection:cleared", this._onSelectionCleared)), (t = this.el) != null && t.parentNode && this.el.parentNode.removeChild(this.el), this.el = null, this.editor = null, this.canvas = null, this.options = null;
1211
1211
  }
1212
1212
  }
1213
- const es = [
1213
+ const ns = [
1214
1214
  "selectable",
1215
1215
  "evented",
1216
1216
  "id",
@@ -1246,7 +1246,7 @@ const es = [
1246
1246
  "radiusBottomRight",
1247
1247
  "radiusBottomLeft"
1248
1248
  ];
1249
- class Ys {
1249
+ class Kt {
1250
1250
  constructor({ editor: t }) {
1251
1251
  this.editor = t, this.canvas = t.canvas, this._isSavingState = !1, this._historySuspendCount = 0, this.baseState = null, this.patches = [], this.currentIndex = 0, this.maxHistoryLength = t.options.maxHistoryLength, this.totalChangesCount = 0, this.baseStateChangesCount = 0, this._createDiffPatcher();
1252
1252
  }
@@ -1258,7 +1258,7 @@ class Ys {
1258
1258
  return this.patches[this.currentIndex - 1] || null;
1259
1259
  }
1260
1260
  _createDiffPatcher() {
1261
- this.diffPatcher = bs({
1261
+ this.diffPatcher = Ms({
1262
1262
  objectHash(t) {
1263
1263
  const e = t, s = t, n = s.styles ? JSON.stringify(s.styles) : "", o = e.customData ? JSON.stringify(e.customData) : "";
1264
1264
  return [
@@ -1308,7 +1308,7 @@ class Ys {
1308
1308
  includeValueOnMove: !1
1309
1309
  },
1310
1310
  textDiff: {
1311
- diffMatchPatch: Ms,
1311
+ diffMatchPatch: ws,
1312
1312
  minLength: 60
1313
1313
  }
1314
1314
  });
@@ -1351,13 +1351,15 @@ class Ys {
1351
1351
  this._isSavingState = !0, console.time("saveState");
1352
1352
  try {
1353
1353
  const t = this._withTemporaryUnlock(
1354
- () => this.canvas.toDatalessObject([...es])
1354
+ () => this.canvas.toDatalessObject([...ns])
1355
1355
  );
1356
1356
  if (console.timeEnd("saveState"), !this.baseState) {
1357
1357
  this.baseState = t, this.patches = [], this.currentIndex = 0, console.log("Базовое состояние сохранено.");
1358
1358
  return;
1359
1359
  }
1360
- const e = this.getFullState(), s = this.diffPatcher.diff(e, t);
1360
+ const e = this.getFullState();
1361
+ console.log("prevState", e);
1362
+ const s = this.diffPatcher.diff(e, t);
1361
1363
  if (!s) {
1362
1364
  console.log("Нет изменений для сохранения.");
1363
1365
  return;
@@ -1368,23 +1370,76 @@ class Ys {
1368
1370
  }
1369
1371
  }
1370
1372
  }
1373
+ /**
1374
+ * Создаёт безопасную копию состояния для загрузки в canvas.
1375
+ * customData сериализуется, чтобы Fabric не обрабатывал её как параметры объекта.
1376
+ *
1377
+ * @param state - полное состояние канваса
1378
+ */
1379
+ static _createLoadSafeState({ state: t }) {
1380
+ const e = JSON.parse(JSON.stringify(t)), { objects: s = [] } = e;
1381
+ for (let n = 0; n < s.length; n += 1) {
1382
+ const o = s[n], { customData: i } = o;
1383
+ !i || typeof i != "object" || (o.customData = JSON.stringify(i));
1384
+ }
1385
+ return e;
1386
+ }
1387
+ /**
1388
+ * Восстанавливает customData на объектах канваса из состояния истории.
1389
+ * Нужна, чтобы в истории всегда сохранялся объект, а не строка.
1390
+ *
1391
+ * @param state - исходное состояние с object customData
1392
+ * @param canvas - канвас, в который загружены объекты
1393
+ */
1394
+ static _applyCustomDataFromState({
1395
+ state: t,
1396
+ canvas: e
1397
+ }) {
1398
+ var a, r;
1399
+ const { objects: s = [] } = t, n = /* @__PURE__ */ new Map(), o = /* @__PURE__ */ new Map();
1400
+ for (let c = 0; c < s.length; c += 1) {
1401
+ const d = s[c], { customData: l, id: u } = d;
1402
+ if (!(!l || typeof l != "object")) {
1403
+ if (typeof u == "string") {
1404
+ n.set(u, l);
1405
+ continue;
1406
+ }
1407
+ o.set(c, l);
1408
+ }
1409
+ }
1410
+ const i = (r = (a = e.getObjects) == null ? void 0 : a.call(e)) != null ? r : [];
1411
+ for (let c = 0; c < i.length; c += 1) {
1412
+ const d = i[c], { id: l } = d;
1413
+ let u;
1414
+ typeof l == "string" && (u = n.get(l)), u || (u = o.get(c)), u && (d.customData = Kt._cloneCustomData({ customData: u }));
1415
+ }
1416
+ }
1417
+ /**
1418
+ * Делает глубокую копию customData, чтобы избежать общих ссылок со state.
1419
+ * @param customData - пользовательские данные объекта
1420
+ */
1421
+ static _cloneCustomData({ customData: t }) {
1422
+ return JSON.parse(JSON.stringify(t));
1423
+ }
1371
1424
  /**
1372
1425
  * Функция загрузки состояния в канвас.
1373
1426
  * @param fullState - полное состояние канваса
1374
1427
  * @fires editor:history-state-loaded
1375
1428
  */
1376
1429
  loadStateFromFullState(t) {
1377
- return k(this, null, function* () {
1430
+ return z(this, null, function* () {
1378
1431
  if (!t) return;
1379
1432
  console.log("loadStateFromFullState fullState", t);
1380
1433
  const { canvas: e, canvasManager: s, interactionBlocker: n, backgroundManager: o } = this.editor, { width: i, height: a } = e;
1381
- n.overlayMask = null, yield e.loadFromJSON(t);
1382
- const r = e.getObjects().find((l) => l.id === "montage-area");
1383
- r && (this.editor.montageArea = r, (i !== e.getWidth() || a !== e.getHeight()) && s.updateCanvas());
1384
- const c = e.getObjects().find((l) => l.id === "overlay-mask");
1385
- c && (n.overlayMask = c, n.overlayMask.visible = !1);
1386
- const d = e.getObjects().find((l) => l.id === "background");
1387
- d ? (o.backgroundObject = d, o.refresh()) : o.removeBackground({ withoutSave: !0 }), e.renderAll(), e.fire("editor:history-state-loaded", {
1434
+ n.overlayMask = null;
1435
+ const r = Kt._createLoadSafeState({ state: t });
1436
+ yield e.loadFromJSON(r), Kt._applyCustomDataFromState({ state: t, canvas: e });
1437
+ const c = e.getObjects().find((u) => u.id === "montage-area");
1438
+ c && (this.editor.montageArea = c, (i !== e.getWidth() || a !== e.getHeight()) && s.updateCanvas());
1439
+ const d = e.getObjects().find((u) => u.id === "overlay-mask");
1440
+ d && (n.overlayMask = d, n.overlayMask.visible = !1);
1441
+ const l = e.getObjects().find((u) => u.id === "background");
1442
+ l ? (o.backgroundObject = l, o.refresh()) : o.removeBackground({ withoutSave: !0 }), e.renderAll(), e.fire("editor:history-state-loaded", {
1388
1443
  fullState: t,
1389
1444
  currentIndex: this.currentIndex,
1390
1445
  totalChangesCount: this.totalChangesCount,
@@ -1399,7 +1454,7 @@ class Ys {
1399
1454
  * @fires editor:undo
1400
1455
  */
1401
1456
  undo() {
1402
- return k(this, null, function* () {
1457
+ return z(this, null, function* () {
1403
1458
  if (!this.skipHistory) {
1404
1459
  if (this.saveState(), this.currentIndex <= 0) {
1405
1460
  console.log("Нет предыдущих состояний для отмены.");
@@ -1436,7 +1491,7 @@ class Ys {
1436
1491
  * @fires editor:redo
1437
1492
  */
1438
1493
  redo() {
1439
- return k(this, null, function* () {
1494
+ return z(this, null, function* () {
1440
1495
  if (!this.skipHistory) {
1441
1496
  if (this.saveState(), this.currentIndex >= this.patches.length) {
1442
1497
  console.log("Нет состояний для повтора.");
@@ -1491,7 +1546,7 @@ class Ys {
1491
1546
  }
1492
1547
  }
1493
1548
  }
1494
- const Hs = 0.1, Zs = 2, Ye = 0.1, Gs = 90, Rt = 16, _t = 16, St = 4096, At = 4096, He = "application/image-editor:", Kt = [
1549
+ const Hs = 0.1, Zs = 2, Ze = 0.1, Gs = 90, Rt = 16, _t = 16, At = 4096, jt = 4096, Ge = "application/image-editor:", ie = [
1495
1550
  "format",
1496
1551
  "uppercase",
1497
1552
  "textCaseRaw",
@@ -1506,7 +1561,7 @@ const Hs = 0.1, Zs = 2, Ye = 0.1, Gs = 90, Rt = 16, _t = 16, St = 4096, At = 409
1506
1561
  "radiusBottomRight",
1507
1562
  "radiusBottomLeft"
1508
1563
  ], Vs = 50;
1509
- class dt {
1564
+ class ht {
1510
1565
  constructor({ editor: t }) {
1511
1566
  this.editor = t, this.options = t.options, this._createdBlobUrls = [], this.acceptContentTypes = this.editor.options.acceptContentTypes, this.acceptFormats = this.getAllowedFormatsFromContentTypes();
1512
1567
  }
@@ -1523,7 +1578,7 @@ class dt {
1523
1578
  * @returns возвращает Promise с объектом изображения или null в случае ошибки
1524
1579
  */
1525
1580
  importImage(t) {
1526
- return k(this, null, function* () {
1581
+ return z(this, null, function* () {
1527
1582
  const {
1528
1583
  source: e,
1529
1584
  scale: s = `image-${this.options.scaleType}`,
@@ -1531,110 +1586,115 @@ class dt {
1531
1586
  fromClipboard: o = !1,
1532
1587
  isBackground: i = !1,
1533
1588
  withoutSelection: a = !1,
1534
- withoutAdding: r = !1
1589
+ withoutAdding: r = !1,
1590
+ customData: c = null
1535
1591
  } = t;
1536
1592
  if (!e) return null;
1537
- const { canvas: c, montageArea: d, transformManager: l, historyManager: u, errorManager: f } = this.editor, g = yield this.getContentType(e), p = dt.getFormatFromContentType(g), { acceptContentTypes: m, acceptFormats: v } = this;
1538
- if (!this.isAllowedContentType(g)) {
1539
- const M = `Неверный contentType для изображения: ${g}. Ожидается один из: ${this.acceptContentTypes.join(", ")}.`;
1540
- return f.emitError({
1593
+ const { canvas: d, montageArea: l, transformManager: u, historyManager: f, errorManager: g } = this.editor, p = yield this.getContentType(e), m = ht.getFormatFromContentType(p), { acceptContentTypes: v, acceptFormats: S } = this;
1594
+ if (!this.isAllowedContentType(p)) {
1595
+ const A = `Неверный contentType для изображения: ${p}. Ожидается один из: ${this.acceptContentTypes.join(", ")}.`;
1596
+ return g.emitError({
1541
1597
  origin: "ImageManager",
1542
1598
  method: "importImage",
1543
1599
  code: "INVALID_CONTENT_TYPE",
1544
- message: M,
1600
+ message: A,
1545
1601
  data: {
1546
1602
  source: e,
1547
- format: p,
1548
- contentType: g,
1549
- acceptContentTypes: m,
1550
- acceptFormats: v,
1603
+ format: m,
1604
+ contentType: p,
1605
+ acceptContentTypes: v,
1606
+ acceptFormats: S,
1551
1607
  fromClipboard: o,
1552
1608
  isBackground: i,
1553
1609
  withoutSelection: a,
1554
- withoutAdding: r
1610
+ withoutAdding: r,
1611
+ customData: c
1555
1612
  }
1556
1613
  }), null;
1557
1614
  }
1558
- u.suspendHistory();
1615
+ f.suspendHistory();
1559
1616
  try {
1560
- let M, S;
1617
+ let A, y;
1561
1618
  if (e instanceof File)
1562
- M = URL.createObjectURL(e);
1619
+ A = URL.createObjectURL(e);
1563
1620
  else if (typeof e == "string") {
1564
- const A = yield (yield fetch(e, { mode: "cors" })).blob();
1565
- M = URL.createObjectURL(A);
1621
+ const T = yield (yield fetch(e, { mode: "cors" })).blob();
1622
+ A = URL.createObjectURL(T);
1566
1623
  } else
1567
- return f.emitError({
1624
+ return g.emitError({
1568
1625
  origin: "ImageManager",
1569
1626
  method: "importImage",
1570
1627
  code: "INVALID_SOURCE_TYPE",
1571
1628
  message: "Неверный тип источника изображения. Ожидается URL или объект File.",
1572
1629
  data: {
1573
1630
  source: e,
1574
- format: p,
1575
- contentType: g,
1576
- acceptContentTypes: m,
1577
- acceptFormats: v,
1631
+ format: m,
1632
+ contentType: p,
1633
+ acceptContentTypes: v,
1634
+ acceptFormats: S,
1578
1635
  fromClipboard: o,
1579
1636
  isBackground: i,
1580
1637
  withoutSelection: a,
1581
- withoutAdding: r
1638
+ withoutAdding: r,
1639
+ customData: c
1582
1640
  }
1583
1641
  }), null;
1584
- if (this._createdBlobUrls.push(M), p === "svg") {
1585
- const j = yield hs(M);
1586
- S = lt.groupSVGElements(j.objects, j.options);
1642
+ if (this._createdBlobUrls.push(A), m === "svg") {
1643
+ const w = yield us(A);
1644
+ y = ut.groupSVGElements(w.objects, w.options);
1587
1645
  } else
1588
- S = yield zt.fromURL(M, { crossOrigin: "anonymous" });
1589
- const { width: y, height: b } = S;
1590
- if (S instanceof zt) {
1591
- const j = S.getElement();
1592
- let A = "";
1593
- if (j instanceof HTMLImageElement ? A = j.src : j instanceof HTMLCanvasElement && (A = j.toDataURL()), b > At || y > St) {
1594
- const C = yield this.resizeImageToBoundaries(A, "max"), w = URL.createObjectURL(C);
1595
- this._createdBlobUrls.push(w), S = yield zt.fromURL(w, { crossOrigin: "anonymous" });
1596
- } else if (b < _t || y < Rt) {
1597
- const C = yield this.resizeImageToBoundaries(A, "min"), w = URL.createObjectURL(C);
1598
- this._createdBlobUrls.push(w), S = yield zt.fromURL(w, { crossOrigin: "anonymous" });
1646
+ y = yield Zt.fromURL(A, { crossOrigin: "anonymous" });
1647
+ const { width: b, height: j } = y;
1648
+ if (y instanceof Zt) {
1649
+ const w = y.getElement();
1650
+ let T = "";
1651
+ if (w instanceof HTMLImageElement ? T = w.src : w instanceof HTMLCanvasElement && (T = w.toDataURL()), j > jt || b > At) {
1652
+ const M = yield this.resizeImageToBoundaries(T, "max"), C = URL.createObjectURL(M);
1653
+ this._createdBlobUrls.push(C), y = yield Zt.fromURL(C, { crossOrigin: "anonymous" });
1654
+ } else if (j < _t || b < Rt) {
1655
+ const M = yield this.resizeImageToBoundaries(T, "min"), C = URL.createObjectURL(M);
1656
+ this._createdBlobUrls.push(C), y = yield Zt.fromURL(C, { crossOrigin: "anonymous" });
1599
1657
  }
1600
1658
  }
1601
- if (S.set("id", `${S.type}-${V()}`), S.set("format", p), s === "scale-montage")
1602
- this.editor.canvasManager.scaleMontageAreaToImage({ object: S, withoutSave: !0 });
1659
+ if (y.set("id", `${y.type}-${V()}`), y.set("format", m), y.set("customData", c || null), s === "scale-montage")
1660
+ this.editor.canvasManager.scaleMontageAreaToImage({ object: y, withoutSave: !0 });
1603
1661
  else {
1604
- const { width: j, height: A } = d, C = this.calculateScaleFactor({ imageObject: S, scaleType: s });
1605
- s === "image-contain" && C < 1 ? l.fitObject({ object: S, type: "contain", withoutSave: !0 }) : s === "image-cover" && (y > j || b > A) && l.fitObject({ object: S, type: "cover", withoutSave: !0 });
1662
+ const { width: w, height: T } = l, M = this.calculateScaleFactor({ imageObject: y, scaleType: s });
1663
+ s === "image-contain" && M < 1 ? u.fitObject({ object: y, type: "contain", withoutSave: !0 }) : s === "image-cover" && (b > w || j > T) && u.fitObject({ object: y, type: "cover", withoutSave: !0 });
1606
1664
  }
1607
1665
  const I = {
1608
- image: S,
1609
- format: p,
1610
- contentType: g,
1666
+ image: y,
1667
+ format: m,
1668
+ contentType: p,
1611
1669
  scale: s,
1612
1670
  withoutSave: n,
1613
1671
  source: e,
1614
1672
  fromClipboard: o,
1615
1673
  isBackground: i,
1616
1674
  withoutSelection: a,
1617
- withoutAdding: r
1675
+ withoutAdding: r,
1676
+ customData: c
1618
1677
  };
1619
- return r ? (u.resumeHistory(), c.fire("editor:image-imported", I), I) : (c.add(S), c.centerObject(S), a || c.setActiveObject(S), c.renderAll(), u.resumeHistory(), n || u.saveState(), c.fire("editor:image-imported", I), I);
1620
- } catch (M) {
1621
- return f.emitError({
1678
+ return r ? (f.resumeHistory(), d.fire("editor:image-imported", I), I) : (d.add(y), d.centerObject(y), a || d.setActiveObject(y), d.renderAll(), f.resumeHistory(), n || f.saveState(), d.fire("editor:image-imported", I), I);
1679
+ } catch (A) {
1680
+ return g.emitError({
1622
1681
  origin: "ImageManager",
1623
1682
  method: "importImage",
1624
1683
  code: "IMPORT_FAILED",
1625
- message: `Ошибка импорта изображения: ${M.message}`,
1684
+ message: `Ошибка импорта изображения: ${A.message}`,
1626
1685
  data: {
1627
1686
  source: e,
1628
- format: p,
1629
- contentType: g,
1687
+ format: m,
1688
+ contentType: p,
1630
1689
  scale: s,
1631
1690
  withoutSave: n,
1632
1691
  fromClipboard: o,
1633
1692
  isBackground: i,
1634
1693
  withoutSelection: a,
1635
- withoutAdding: r
1694
+ withoutAdding: r,
1695
+ customData: c
1636
1696
  }
1637
- }), u.resumeHistory(), null;
1697
+ }), f.resumeHistory(), null;
1638
1698
  }
1639
1699
  });
1640
1700
  }
@@ -1647,14 +1707,14 @@ class dt {
1647
1707
  * @returns возвращает Promise с Blob-объектом уменьшенного изображения
1648
1708
  */
1649
1709
  resizeImageToBoundaries(t, e = "max") {
1650
- return k(this, null, function* () {
1651
- let s = `Размер изображения больше максимального размера канваса, поэтому оно будет уменьшено до максимальных размеров c сохранением пропорций: ${St}x${At}`;
1710
+ return z(this, null, function* () {
1711
+ let s = `Размер изображения больше максимального размера канваса, поэтому оно будет уменьшено до максимальных размеров c сохранением пропорций: ${At}x${jt}`;
1652
1712
  e === "min" && (s = `Размер изображения меньше минимального размера канваса, поэтому оно будет увеличено до минимальных размеров c сохранением пропорций: ${Rt}x${_t}`);
1653
1713
  const n = {
1654
1714
  dataURL: t,
1655
1715
  sizeType: e,
1656
- maxWidth: St,
1657
- maxHeight: At,
1716
+ maxWidth: At,
1717
+ maxHeight: jt,
1658
1718
  minWidth: Rt,
1659
1719
  minHeight: _t
1660
1720
  };
@@ -1679,7 +1739,7 @@ class dt {
1679
1739
  * @fires editor:canvas-exported
1680
1740
  */
1681
1741
  exportCanvasAsImageFile() {
1682
- return k(this, arguments, function* (t = {}) {
1742
+ return z(this, arguments, function* (t = {}) {
1683
1743
  const {
1684
1744
  fileName: e = "image.png",
1685
1745
  contentType: s = "image/png",
@@ -1687,22 +1747,22 @@ class dt {
1687
1747
  exportAsBlob: o = !1
1688
1748
  } = t, { canvas: i, montageArea: a, workerManager: r, interactionBlocker: c } = this.editor;
1689
1749
  try {
1690
- const d = s === "application/pdf", l = d ? "image/jpg" : s, u = dt.getFormatFromContentType(l);
1750
+ const d = s === "application/pdf", l = d ? "image/jpg" : s, u = ht.getFormatFromContentType(l);
1691
1751
  a.setCoords();
1692
1752
  const { left: f, top: g, width: p, height: m } = a.getBoundingRect(), v = yield i.clone(["id", "format", "locked"]);
1693
1753
  v.enableRetinaScaling = !1, ["image/jpg", "image/jpeg"].includes(l) && (v.backgroundColor = "#ffffff");
1694
- const M = v.getObjects().find((w) => w.id === a.id);
1695
- if (M && (M.visible = !1), c != null && c.isBlocked) {
1696
- const w = v.getObjects().find((T) => T.id === c.overlayMask.id);
1697
- w && (w.visible = !1);
1754
+ const S = v.getObjects().find((M) => M.id === a.id);
1755
+ if (S && (S.visible = !1), c != null && c.isBlocked) {
1756
+ const M = v.getObjects().find((C) => C.id === c.overlayMask.id);
1757
+ M && (M.visible = !1);
1698
1758
  }
1699
1759
  v.viewportTransform = [1, 0, 0, 1, -f, -g], v.setDimensions({ width: p, height: m }, { backstoreOnly: !0 }), v.renderAll();
1700
- const S = v.getObjects().filter((w) => w.format).every((w) => w.format === "svg");
1701
- if (u === "svg" && S) {
1702
- const w = v.toSVG();
1760
+ const A = v.getObjects().filter((M) => M.format).every((M) => M.format === "svg");
1761
+ if (u === "svg" && A) {
1762
+ const M = v.toSVG();
1703
1763
  v.dispose();
1704
1764
  const E = {
1705
- image: dt._exportSVGStringAsFile(w, {
1765
+ image: ht._exportSVGStringAsFile(M, {
1706
1766
  exportAsBase64: n,
1707
1767
  exportAsBlob: o,
1708
1768
  fileName: e
@@ -1713,64 +1773,64 @@ class dt {
1713
1773
  };
1714
1774
  return i.fire("editor:canvas-exported", E), E;
1715
1775
  }
1716
- const y = yield new Promise((w, T) => {
1776
+ const y = yield new Promise((M, C) => {
1717
1777
  v.getElement().toBlob((E) => {
1718
- E ? w(E) : T(new Error("Failed to create Blob from canvas"));
1778
+ E ? M(E) : C(new Error("Failed to create Blob from canvas"));
1719
1779
  });
1720
1780
  });
1721
1781
  if (v.dispose(), o) {
1722
- const w = {
1782
+ const M = {
1723
1783
  image: y,
1724
1784
  format: u,
1725
1785
  contentType: l,
1726
1786
  fileName: e
1727
1787
  };
1728
- return i.fire("editor:canvas-exported", w), w;
1788
+ return i.fire("editor:canvas-exported", M), M;
1729
1789
  }
1730
- const b = yield createImageBitmap(y), I = yield r.post(
1790
+ const b = yield createImageBitmap(y), j = yield r.post(
1731
1791
  "toDataURL",
1732
1792
  { format: u, quality: 1, bitmap: b },
1733
1793
  [b]
1734
1794
  );
1735
1795
  if (d) {
1736
- const T = p * 0.264583, E = m * 0.264583, F = (yield this.editor.moduleLoader.loadModule("jspdf")).jsPDF, x = new F({
1737
- orientation: T > E ? "landscape" : "portrait",
1796
+ const C = p * 0.264583, E = m * 0.264583, W = (yield this.editor.moduleLoader.loadModule("jspdf")).jsPDF, N = new W({
1797
+ orientation: C > E ? "landscape" : "portrait",
1738
1798
  unit: "mm",
1739
- format: [T, E]
1799
+ format: [C, E]
1740
1800
  });
1741
- if (x.addImage(String(I), "JPG", 0, 0, T, E), n) {
1742
- const W = {
1743
- image: x.output("datauristring"),
1801
+ if (N.addImage(String(j), "JPG", 0, 0, C, E), n) {
1802
+ const H = {
1803
+ image: N.output("datauristring"),
1744
1804
  format: "pdf",
1745
1805
  contentType: "application/pdf",
1746
1806
  fileName: e
1747
1807
  };
1748
- return i.fire("editor:canvas-exported", W), W;
1808
+ return i.fire("editor:canvas-exported", H), H;
1749
1809
  }
1750
- const N = x.output("blob"), D = {
1751
- image: new File([N], e, { type: "application/pdf" }),
1810
+ const x = N.output("blob"), G = {
1811
+ image: new File([x], e, { type: "application/pdf" }),
1752
1812
  format: "pdf",
1753
1813
  contentType: "application/pdf",
1754
1814
  fileName: e
1755
1815
  };
1756
- return i.fire("editor:canvas-exported", D), D;
1816
+ return i.fire("editor:canvas-exported", G), G;
1757
1817
  }
1758
1818
  if (n) {
1759
- const w = {
1760
- image: I,
1819
+ const M = {
1820
+ image: j,
1761
1821
  format: u,
1762
1822
  contentType: l,
1763
1823
  fileName: e
1764
1824
  };
1765
- return i.fire("editor:canvas-exported", w), w;
1825
+ return i.fire("editor:canvas-exported", M), M;
1766
1826
  }
1767
- const j = u === "svg" && !S ? e.replace(/\.[^/.]+$/, ".png") : e, C = {
1768
- image: new File([y], j, { type: l }),
1827
+ const I = u === "svg" && !A ? e.replace(/\.[^/.]+$/, ".png") : e, T = {
1828
+ image: new File([y], I, { type: l }),
1769
1829
  format: u,
1770
1830
  contentType: l,
1771
- fileName: j
1831
+ fileName: I
1772
1832
  };
1773
- return i.fire("editor:canvas-exported", C), C;
1833
+ return i.fire("editor:canvas-exported", T), T;
1774
1834
  } catch (d) {
1775
1835
  return this.editor.errorManager.emitError({
1776
1836
  origin: "ImageManager",
@@ -1794,7 +1854,7 @@ class dt {
1794
1854
  * @fires editor:object-exported
1795
1855
  */
1796
1856
  exportObjectAsImageFile() {
1797
- return k(this, arguments, function* (t = {}) {
1857
+ return z(this, arguments, function* (t = {}) {
1798
1858
  const {
1799
1859
  object: e,
1800
1860
  fileName: s = "image.png",
@@ -1811,9 +1871,9 @@ class dt {
1811
1871
  data: { contentType: n, fileName: s, exportAsBase64: o, exportAsBlob: i }
1812
1872
  }), null;
1813
1873
  try {
1814
- const d = dt.getFormatFromContentType(n);
1874
+ const d = ht.getFormatFromContentType(n);
1815
1875
  if (d === "svg") {
1816
- const p = c.toSVG(), m = dt._exportSVGStringAsFile(p, {
1876
+ const p = c.toSVG(), m = ht._exportSVGStringAsFile(p, {
1817
1877
  exportAsBase64: o,
1818
1878
  exportAsBlob: i,
1819
1879
  fileName: s
@@ -1826,7 +1886,7 @@ class dt {
1826
1886
  };
1827
1887
  return a.fire("editor:object-exported", v), v;
1828
1888
  }
1829
- if (o && c instanceof zt) {
1889
+ if (o && c instanceof Zt) {
1830
1890
  const p = yield createImageBitmap(c.getElement()), m = yield r.post(
1831
1891
  "toDataURL",
1832
1892
  {
@@ -1891,7 +1951,7 @@ class dt {
1891
1951
  * @returns массив допустимых форматов изображений
1892
1952
  */
1893
1953
  getAllowedFormatsFromContentTypes() {
1894
- return this.acceptContentTypes.map((t) => dt.getFormatFromContentType(t)).filter((t) => t);
1954
+ return this.acceptContentTypes.map((t) => ht.getFormatFromContentType(t)).filter((t) => t);
1895
1955
  }
1896
1956
  /**
1897
1957
  * Проверяет, является ли contentType допустимым типом изображения.
@@ -1907,7 +1967,7 @@ class dt {
1907
1967
  * @public
1908
1968
  */
1909
1969
  getContentType(t) {
1910
- return k(this, null, function* () {
1970
+ return z(this, null, function* () {
1911
1971
  return typeof t == "string" ? this.getContentTypeFromUrl(t) : t.type || "application/octet-stream";
1912
1972
  });
1913
1973
  }
@@ -1918,7 +1978,7 @@ class dt {
1918
1978
  * @public
1919
1979
  */
1920
1980
  getContentTypeFromUrl(t) {
1921
- return k(this, null, function* () {
1981
+ return z(this, null, function* () {
1922
1982
  if (t.startsWith("data:")) {
1923
1983
  const e = t.match(/^data:([^;]+)/);
1924
1984
  return e ? e[1] : "application/octet-stream";
@@ -1944,7 +2004,7 @@ class dt {
1944
2004
  try {
1945
2005
  const n = (e = new URL(t).pathname.split(".").pop()) == null ? void 0 : e.toLowerCase(), o = {};
1946
2006
  return this.acceptContentTypes.forEach((i) => {
1947
- const a = dt.getFormatFromContentType(i);
2007
+ const a = ht.getFormatFromContentType(i);
1948
2008
  a && (o[a] = i);
1949
2009
  }), n && o[n] || "application/octet-stream";
1950
2010
  } catch (s) {
@@ -1997,7 +2057,7 @@ class dt {
1997
2057
  return e ? e[1] : "";
1998
2058
  }
1999
2059
  }
2000
- const gt = (h, t, e) => Math.max(Math.min(h, e), t), Ze = (h, t) => h * t, Xs = (h, t) => new tt(h / 2, t / 2);
2060
+ const pt = (h, t, e) => Math.max(Math.min(h, e), t), Ve = (h, t) => h * t, Xs = (h, t) => new tt(h / 2, t / 2);
2001
2061
  function Ks(h) {
2002
2062
  return ((h == null ? void 0 : h.type) === "image" || (h == null ? void 0 : h.format) === "svg") && typeof (h == null ? void 0 : h.width) == "number" && typeof (h == null ? void 0 : h.height) == "number";
2003
2063
  }
@@ -2021,11 +2081,11 @@ class Qs {
2021
2081
  * Если точка находится за пределами монтажной области, она проецируется на ближайшую границу монтажной области.
2022
2082
  */
2023
2083
  getVisibleCenterPoint() {
2024
- const { canvas: t, montageArea: e } = this.editor, s = t.getZoom(), n = t.viewportTransform, o = t.getWidth(), i = t.getHeight(), a = (o / 2 - n[4]) / s, r = (i / 2 - n[5]) / s, c = e.width / 2, d = e.height / 2, l = gt(
2084
+ const { canvas: t, montageArea: e } = this.editor, s = t.getZoom(), n = t.viewportTransform, o = t.getWidth(), i = t.getHeight(), a = (o / 2 - n[4]) / s, r = (i / 2 - n[5]) / s, c = e.width / 2, d = e.height / 2, l = pt(
2025
2085
  a,
2026
2086
  e.left - c,
2027
2087
  e.left + c
2028
- ), u = gt(
2088
+ ), u = pt(
2029
2089
  r,
2030
2090
  e.top - d,
2031
2091
  e.top + d
@@ -2048,9 +2108,9 @@ class Qs {
2048
2108
  canvas: o,
2049
2109
  montageArea: i,
2050
2110
  options: { canvasBackstoreWidth: a }
2051
- } = this.editor, { width: r, height: c } = i, d = gt(Number(t), Rt, St);
2111
+ } = this.editor, { width: r, height: c } = i, d = pt(Number(t), Rt, At);
2052
2112
  if (!a || a === "auto" || n ? this.adaptCanvasToContainer() : a ? this.setCanvasBackstoreWidth(Number(a)) : this.setCanvasBackstoreWidth(d), i.set({ width: d }), (g = o.clipPath) == null || g.set({ width: d }), e) {
2053
- const p = d / r, m = Ze(c, p);
2113
+ const p = d / r, m = Ve(c, p);
2054
2114
  this.setResolutionHeight(m);
2055
2115
  return;
2056
2116
  }
@@ -2078,9 +2138,9 @@ class Qs {
2078
2138
  canvas: o,
2079
2139
  montageArea: i,
2080
2140
  options: { canvasBackstoreHeight: a }
2081
- } = this.editor, { width: r, height: c } = i, d = gt(Number(t), _t, At);
2141
+ } = this.editor, { width: r, height: c } = i, d = pt(Number(t), _t, jt);
2082
2142
  if (!a || a === "auto" || n ? this.adaptCanvasToContainer() : a ? this.setCanvasBackstoreHeight(Number(a)) : this.setCanvasBackstoreHeight(d), i.set({ height: d }), (g = o.clipPath) == null || g.set({ height: d }), e) {
2083
- const p = d / c, m = Ze(r, p);
2143
+ const p = d / c, m = Ve(r, p);
2084
2144
  this.setResolutionWidth(m);
2085
2145
  return;
2086
2146
  }
@@ -2131,7 +2191,7 @@ class Qs {
2131
2191
  */
2132
2192
  setCanvasBackstoreWidth(t) {
2133
2193
  if (!t || typeof t != "number") return;
2134
- const e = gt(t, Rt, St);
2194
+ const e = pt(t, Rt, At);
2135
2195
  this.editor.canvas.setDimensions({ width: e }, { backstoreOnly: !0 });
2136
2196
  }
2137
2197
  /**
@@ -2140,7 +2200,7 @@ class Qs {
2140
2200
  */
2141
2201
  setCanvasBackstoreHeight(t) {
2142
2202
  if (!t || typeof t != "number") return;
2143
- const e = gt(t, _t, At);
2203
+ const e = pt(t, _t, jt);
2144
2204
  this.editor.canvas.setDimensions({ height: e }, { backstoreOnly: !0 });
2145
2205
  }
2146
2206
  /**
@@ -2149,7 +2209,7 @@ class Qs {
2149
2209
  * с учётом минимальных и максимальных значений.
2150
2210
  */
2151
2211
  adaptCanvasToContainer() {
2152
- const { canvas: t } = this.editor, e = this.getEditorContainer(), s = e.clientWidth, n = e.clientHeight, o = gt(s, Rt, St), i = gt(n, _t, At);
2212
+ const { canvas: t } = this.editor, e = this.getEditorContainer(), s = e.clientWidth, n = e.clientHeight, o = pt(s, Rt, At), i = pt(n, _t, jt);
2153
2213
  t.setDimensions({ width: o, height: i }, { backstoreOnly: !0 });
2154
2214
  }
2155
2215
  /**
@@ -2351,13 +2411,13 @@ class Qs {
2351
2411
  } = this.editor, c = t || n.getActiveObject();
2352
2412
  if (!Ks(c)) return;
2353
2413
  const { width: d, height: l } = c;
2354
- let u = Math.min(d, St), f = Math.min(l, At);
2414
+ let u = Math.min(d, At), f = Math.min(l, jt);
2355
2415
  if (e) {
2356
2416
  const {
2357
2417
  width: g,
2358
2418
  height: p
2359
- } = o, m = d / g, v = l / p, M = Math.max(m, v);
2360
- u = g * M, f = p * M;
2419
+ } = o, m = d / g, v = l / p, S = Math.max(m, v);
2420
+ u = g * S, f = p * S;
2361
2421
  }
2362
2422
  this.setResolutionWidth(u, { withoutSave: !0 }), this.setResolutionHeight(f, { withoutSave: !0 }), this.editor.backgroundManager.backgroundObject && this.editor.backgroundManager.refresh(), (d > a || l > r) && this.editor.zoomManager.calculateAndApplyDefaultZoom(), i.resetObject({ object: c, withoutSave: !0 }), n.centerObject(c), n.renderAll(), s || this.editor.historyManager.saveState(), n.fire("editor:montage-area-scaled-to-image", {
2363
2423
  object: c,
@@ -2409,7 +2469,7 @@ class Qs {
2409
2469
  );
2410
2470
  }
2411
2471
  }
2412
- class qs {
2472
+ class Js {
2413
2473
  constructor({ editor: t }) {
2414
2474
  this.editor = t, this.options = t.options;
2415
2475
  }
@@ -2521,11 +2581,11 @@ class qs {
2521
2581
  * @private
2522
2582
  */
2523
2583
  _fitSingleObject(t, e) {
2524
- const { canvas: s, montageArea: n } = this.editor, { width: o, height: i, scaleX: a = 1, scaleY: r = 1, angle: c = 0 } = t, d = o * Math.abs(a), l = i * Math.abs(r), u = c * Math.PI / 180, f = Math.abs(Math.cos(u)), g = Math.abs(Math.sin(u)), p = d * f + l * g, m = d * g + l * f, v = n.width, M = n.height;
2525
- let S;
2526
- e === "contain" ? S = Math.min(v / p, M / m) : S = Math.max(v / p, M / m), t.set({
2527
- scaleX: a * S,
2528
- scaleY: r * S
2584
+ const { canvas: s, montageArea: n } = this.editor, { width: o, height: i, scaleX: a = 1, scaleY: r = 1, angle: c = 0 } = t, d = o * Math.abs(a), l = i * Math.abs(r), u = c * Math.PI / 180, f = Math.abs(Math.cos(u)), g = Math.abs(Math.sin(u)), p = d * f + l * g, m = d * g + l * f, v = n.width, S = n.height;
2585
+ let A;
2586
+ e === "contain" ? A = Math.min(v / p, S / m) : A = Math.max(v / p, S / m), t.set({
2587
+ scaleX: a * A,
2588
+ scaleY: r * A
2529
2589
  }), s.centerObject(t);
2530
2590
  }
2531
2591
  /**
@@ -2575,7 +2635,7 @@ class qs {
2575
2635
  });
2576
2636
  }
2577
2637
  }
2578
- class Js {
2638
+ class qs {
2579
2639
  constructor({ editor: t }) {
2580
2640
  this.editor = t, this.options = t.options, this.minZoom = this.options.minZoom || Hs, this.maxZoom = this.options.maxZoom || Zs, this.defaultZoom = this._normalizeDefaultZoom(this.options.defaultScale);
2581
2641
  }
@@ -2643,10 +2703,10 @@ class Js {
2643
2703
  * @private
2644
2704
  */
2645
2705
  _calculateEmptySpaceRatio(t) {
2646
- const { canvas: e, montageArea: s } = this.editor, n = e.viewportTransform, o = e.getWidth(), i = e.getHeight(), a = s.left - s.width / 2, r = s.left + s.width / 2, c = s.top - s.height / 2, d = s.top + s.height / 2, l = -n[4] / t, u = (-n[4] + o) / t, f = -n[5] / t, g = (-n[5] + i) / t, p = l < a, m = u > r, v = f < c, M = g > d;
2647
- if (!(p || m || v || M)) return 0;
2648
- const y = Math.max(0, a - l), b = Math.max(0, u - r), I = Math.max(0, c - f), j = Math.max(0, g - d), A = Math.max(y, b), C = Math.max(I, j), w = A / o, T = C / i;
2649
- return Math.max(w, T);
2706
+ const { canvas: e, montageArea: s } = this.editor, n = e.viewportTransform, o = e.getWidth(), i = e.getHeight(), a = s.left - s.width / 2, r = s.left + s.width / 2, c = s.top - s.height / 2, d = s.top + s.height / 2, l = -n[4] / t, u = (-n[4] + o) / t, f = -n[5] / t, g = (-n[5] + i) / t, p = l < a, m = u > r, v = f < c, S = g > d;
2707
+ if (!(p || m || v || S)) return 0;
2708
+ const y = Math.max(0, a - l), b = Math.max(0, u - r), j = Math.max(0, c - f), I = Math.max(0, g - d), w = Math.max(y, b), T = Math.max(j, I), M = w / o, C = T / i;
2709
+ return Math.max(M, C);
2650
2710
  }
2651
2711
  /**
2652
2712
  * Вычисляет плавный шаг перемещения viewport к центру с ускорением
@@ -2662,8 +2722,8 @@ class Js {
2662
2722
  const { canvas: i, montageArea: a } = this.editor, r = i.viewportTransform, c = i.getWidth(), d = i.getHeight(), l = t.x - r[4], u = t.y - r[5], f = Math.abs(n), g = e - s;
2663
2723
  if (Math.abs(g) / f <= 0.1)
2664
2724
  return { x: l, y: u };
2665
- const m = c / 2, v = d / 2, M = a.left, S = a.top, y = m - M * s, b = v - S * s, I = (y - r[4]) / (e - s), j = (b - r[5]) / (e - s), A = I * f, C = j * f, w = A * o, T = C * o, E = Math.abs(w) > Math.abs(l) ? l : w, F = Math.abs(T) > Math.abs(u) ? u : T;
2666
- return { x: E, y: F };
2725
+ const m = c / 2, v = d / 2, S = a.left, A = a.top, y = m - S * s, b = v - A * s, j = (y - r[4]) / (e - s), I = (b - r[5]) / (e - s), w = j * f, T = I * f, M = w * o, C = T * o, E = Math.abs(M) > Math.abs(l) ? l : M, W = Math.abs(C) > Math.abs(u) ? u : C;
2726
+ return { x: E, y: W };
2667
2727
  }
2668
2728
  /**
2669
2729
  * Применяет плавное центрирование viewport при приближении к defaultZoom.
@@ -2675,7 +2735,7 @@ class Js {
2675
2735
  * @returns true если центрирование было применено
2676
2736
  * @private
2677
2737
  */
2678
- _applyViewportCentering(t, e = !1, s = Ye) {
2738
+ _applyViewportCentering(t, e = !1, s = Ze) {
2679
2739
  const { canvas: n } = this.editor, o = this._getScaledMontageDimensions(t), i = n.getWidth(), a = n.getHeight(), r = o.width > i || o.height > a, c = this._calculateFitZoom(), d = t - c;
2680
2740
  if (!(!r || d) && !e)
2681
2741
  return !1;
@@ -2750,7 +2810,7 @@ class Js {
2750
2810
  * @param options.pointY - Координата Y точки зума
2751
2811
  * @fires editor:zoom-changed
2752
2812
  */
2753
- zoom(t = Ye, e = {}) {
2813
+ zoom(t = Ze, e = {}) {
2754
2814
  var f, g;
2755
2815
  if (!t) return;
2756
2816
  const { minZoom: s, maxZoom: n } = this, { canvas: o } = this.editor, i = t < 0, a = o.getZoom(), r = o.getCenterPoint(), c = (f = e.pointX) != null ? f : r.x, d = (g = e.pointY) != null ? g : r.y, l = new tt(c, d);
@@ -3003,7 +3063,7 @@ class Ot {
3003
3063
  * @param options.withoutSave - Если true, не сохранять состояние в историю
3004
3064
  */
3005
3065
  setImageBackground(o) {
3006
- return k(this, arguments, function* ({
3066
+ return z(this, arguments, function* ({
3007
3067
  imageSource: t,
3008
3068
  customData: e = {},
3009
3069
  fromTemplate: s = !1,
@@ -3100,7 +3160,7 @@ class Ot {
3100
3160
  * @param source - источник изображения (URL или File)
3101
3161
  */
3102
3162
  _createImageBackground(t, e) {
3103
- return k(this, null, function* () {
3163
+ return z(this, null, function* () {
3104
3164
  var n;
3105
3165
  const { image: s } = (n = yield this.editor.imageManager.importImage({
3106
3166
  source: t,
@@ -3153,7 +3213,7 @@ class Ot {
3153
3213
  { offset: 1, color: "#ffffff" }
3154
3214
  ], t.type === "linear") {
3155
3215
  const u = t.angle * Math.PI / 180, f = Ot._angleToCoords(u);
3156
- return new ke({
3216
+ return new ze({
3157
3217
  type: "linear",
3158
3218
  gradientUnits: "percentage",
3159
3219
  coords: f,
@@ -3172,7 +3232,7 @@ class Ot {
3172
3232
  r1: 0,
3173
3233
  r2: d / 100
3174
3234
  };
3175
- return new ke({
3235
+ return new ze({
3176
3236
  type: "radial",
3177
3237
  gradientUnits: "percentage",
3178
3238
  coords: l,
@@ -3207,7 +3267,7 @@ class Ot {
3207
3267
  }) ? !1 : t.type === "linear" && e.type === "linear" ? Math.abs(t.coords.x1 - e.coords.x1) < 1e-4 && Math.abs(t.coords.y1 - e.coords.y1) < 1e-4 && Math.abs(t.coords.x2 - e.coords.x2) < 1e-4 && Math.abs(t.coords.y2 - e.coords.y2) < 1e-4 : t.type === "radial" && e.type === "radial" ? Math.abs(t.coords.x1 - e.coords.x1) < 1e-4 && Math.abs(t.coords.y1 - e.coords.y1) < 1e-4 && Math.abs(t.coords.x2 - e.coords.x2) < 1e-4 && Math.abs(t.coords.y2 - e.coords.y2) < 1e-4 && Math.abs(t.coords.r1 - e.coords.r1) < 1e-4 && Math.abs(t.coords.r2 - e.coords.r2) < 1e-4 : !1;
3208
3268
  }
3209
3269
  }
3210
- class te {
3270
+ class le {
3211
3271
  constructor({ editor: t }) {
3212
3272
  this.editor = t;
3213
3273
  }
@@ -3240,7 +3300,7 @@ class te {
3240
3300
  const { canvas: s, historyManager: n } = this.editor;
3241
3301
  n.suspendHistory();
3242
3302
  const o = t || s.getActiveObject();
3243
- o && (o instanceof U ? te._moveSelectionForward(s, o) : s.bringObjectForward(o), s.renderAll(), n.resumeHistory(), e || n.saveState(), s.fire("editor:object-bring-forward", {
3303
+ o && (o instanceof U ? le._moveSelectionForward(s, o) : s.bringObjectForward(o), s.renderAll(), n.resumeHistory(), e || n.saveState(), s.fire("editor:object-bring-forward", {
3244
3304
  object: o,
3245
3305
  withoutSave: e
3246
3306
  }));
@@ -3291,7 +3351,7 @@ class te {
3291
3351
  } = this.editor;
3292
3352
  o.suspendHistory();
3293
3353
  const r = t || s.getActiveObject();
3294
- r && (r instanceof U ? te._moveSelectionBackwards(s, r) : s.sendObjectBackwards(r), a && s.sendObjectToBack(a), s.sendObjectToBack(n), i && s.sendObjectToBack(i), s.renderAll(), o.resumeHistory(), e || o.saveState(), s.fire("editor:object-send-backwards", {
3354
+ r && (r instanceof U ? le._moveSelectionBackwards(s, r) : s.sendObjectBackwards(r), a && s.sendObjectToBack(a), s.sendObjectToBack(n), i && s.sendObjectToBack(i), s.renderAll(), o.resumeHistory(), e || o.saveState(), s.fire("editor:object-send-backwards", {
3295
3355
  object: r,
3296
3356
  withoutSave: e
3297
3357
  }));
@@ -3367,7 +3427,7 @@ class tn {
3367
3427
  width: n = 100,
3368
3428
  height: o = 100,
3369
3429
  fill: i = "blue"
3370
- } = l, a = Mt(l, [
3430
+ } = l, a = gt(l, [
3371
3431
  "id",
3372
3432
  "left",
3373
3433
  "top",
@@ -3375,7 +3435,7 @@ class tn {
3375
3435
  "height",
3376
3436
  "fill"
3377
3437
  ]);
3378
- const { canvas: u } = this.editor, f = new us(B({
3438
+ const { canvas: u } = this.editor, f = new fs(B({
3379
3439
  id: t,
3380
3440
  left: e,
3381
3441
  top: s,
@@ -3408,14 +3468,14 @@ class tn {
3408
3468
  top: s,
3409
3469
  radius: n = 50,
3410
3470
  fill: o = "green"
3411
- } = d, i = Mt(d, [
3471
+ } = d, i = gt(d, [
3412
3472
  "id",
3413
3473
  "left",
3414
3474
  "top",
3415
3475
  "radius",
3416
3476
  "fill"
3417
3477
  ]);
3418
- const { canvas: l } = this.editor, u = new fs(B({
3478
+ const { canvas: l } = this.editor, u = new gs(B({
3419
3479
  id: t,
3420
3480
  left: e,
3421
3481
  top: s,
@@ -3449,7 +3509,7 @@ class tn {
3449
3509
  width: n = 100,
3450
3510
  height: o = 100,
3451
3511
  fill: i = "yellow"
3452
- } = l, a = Mt(l, [
3512
+ } = l, a = gt(l, [
3453
3513
  "id",
3454
3514
  "left",
3455
3515
  "top",
@@ -3457,7 +3517,7 @@ class tn {
3457
3517
  "height",
3458
3518
  "fill"
3459
3519
  ]);
3460
- const { canvas: u } = this.editor, f = new gs(B({
3520
+ const { canvas: u } = this.editor, f = new ps(B({
3461
3521
  id: t,
3462
3522
  left: e,
3463
3523
  top: s,
@@ -3496,10 +3556,10 @@ class en {
3496
3556
  * Асинхронное клонирование для внутреннего буфера
3497
3557
  */
3498
3558
  _cloneToInternalClipboard(t) {
3499
- return k(this, null, function* () {
3559
+ return z(this, null, function* () {
3500
3560
  const { canvas: e, errorManager: s } = this.editor;
3501
3561
  try {
3502
- const n = yield t.clone(Kt);
3562
+ const n = yield t.clone(ie);
3503
3563
  this.clipboard = n, e.fire("editor:object-copied", { object: n });
3504
3564
  } catch (n) {
3505
3565
  s.emitError({
@@ -3516,7 +3576,7 @@ class en {
3516
3576
  * Копирование в системный буфер обмена
3517
3577
  */
3518
3578
  _copyToSystemClipboard(t) {
3519
- return k(this, null, function* () {
3579
+ return z(this, null, function* () {
3520
3580
  const { errorManager: e } = this.editor;
3521
3581
  if (typeof ClipboardItem == "undefined" || !navigator.clipboard)
3522
3582
  return e.emitWarning({
@@ -3526,7 +3586,7 @@ class en {
3526
3586
  message: "navigator.clipboard не поддерживается в этом браузере или отсутствует HTTPS-соединение."
3527
3587
  }), !1;
3528
3588
  try {
3529
- const s = t.toObject(Kt), n = JSON.stringify(s);
3589
+ const s = t.toObject(ie), n = JSON.stringify(s);
3530
3590
  return t.type === "image" ? this._copyImageToClipboard(t, n) : this._copyTextToClipboard(n);
3531
3591
  } catch (s) {
3532
3592
  return e.emitError({
@@ -3543,7 +3603,7 @@ class en {
3543
3603
  * Копирование изображения в буфер обмена
3544
3604
  */
3545
3605
  _copyImageToClipboard(t, e) {
3546
- return k(this, null, function* () {
3606
+ return z(this, null, function* () {
3547
3607
  try {
3548
3608
  const n = t.toCanvasElement({ enableRetinaScaling: !1 }).toDataURL(), o = n.slice(5).split(";")[0], i = n.split(",")[1], a = atob(i), r = new Uint8Array(a.length);
3549
3609
  for (let l = 0; l < a.length; l += 1)
@@ -3565,9 +3625,9 @@ class en {
3565
3625
  * Копирование текста в буфер обмена
3566
3626
  */
3567
3627
  _copyTextToClipboard(t) {
3568
- return k(this, null, function* () {
3628
+ return z(this, null, function* () {
3569
3629
  try {
3570
- const e = `${He}${t}`;
3630
+ const e = `${Ge}${t}`;
3571
3631
  return yield navigator.clipboard.writeText(e), console.info("Text copied to clipboard successfully"), !0;
3572
3632
  } catch (e) {
3573
3633
  const { errorManager: s } = this.editor;
@@ -3600,7 +3660,7 @@ class en {
3600
3660
  * @param source - источник изображения (data URL или URL)
3601
3661
  */
3602
3662
  _handleImageImport(t) {
3603
- return k(this, null, function* () {
3663
+ return z(this, null, function* () {
3604
3664
  var s;
3605
3665
  const { image: e } = (s = yield this.editor.imageManager.importImage({
3606
3666
  source: t,
@@ -3616,11 +3676,11 @@ class en {
3616
3676
  * @fires editor:object-pasted
3617
3677
  */
3618
3678
  copyPaste(t) {
3619
- return k(this, null, function* () {
3679
+ return z(this, null, function* () {
3620
3680
  const { canvas: e } = this.editor, s = t || e.getActiveObject();
3621
3681
  if (!s || s.locked) return !1;
3622
3682
  try {
3623
- const n = yield s.clone(Kt);
3683
+ const n = yield s.clone(ie);
3624
3684
  return n instanceof U && n.forEachObject((o) => {
3625
3685
  o.set({
3626
3686
  id: `${o.type}-${V()}`,
@@ -3651,14 +3711,14 @@ class en {
3651
3711
  * @param event.clipboardData.items — элементы буфера обмена
3652
3712
  */
3653
3713
  handlePasteEvent(e) {
3654
- return k(this, arguments, function* ({ clipboardData: t }) {
3714
+ return z(this, arguments, function* ({ clipboardData: t }) {
3655
3715
  var r;
3656
3716
  if (!((r = t == null ? void 0 : t.items) != null && r.length)) {
3657
3717
  this.paste();
3658
3718
  return;
3659
3719
  }
3660
3720
  const s = t.getData("text/plain");
3661
- if (s && s.startsWith(He)) {
3721
+ if (s && s.startsWith(Ge)) {
3662
3722
  this.paste();
3663
3723
  return;
3664
3724
  }
@@ -3702,11 +3762,11 @@ class en {
3702
3762
  * @fires editor:object-pasted
3703
3763
  */
3704
3764
  paste() {
3705
- return k(this, null, function* () {
3765
+ return z(this, null, function* () {
3706
3766
  const { canvas: t } = this.editor;
3707
3767
  if (!this.clipboard) return !1;
3708
3768
  try {
3709
- const e = yield this.clipboard.clone(Kt);
3769
+ const e = yield this.clipboard.clone(ie);
3710
3770
  return t.discardActiveObject(), e instanceof U && e.forEachObject((s) => {
3711
3771
  s.set({
3712
3772
  id: `${s.type}-${V()}`,
@@ -3731,7 +3791,7 @@ class en {
3731
3791
  });
3732
3792
  }
3733
3793
  }
3734
- class ee {
3794
+ class he {
3735
3795
  constructor({ editor: t }) {
3736
3796
  this.editor = t;
3737
3797
  }
@@ -3757,9 +3817,9 @@ class ee {
3757
3817
  editable: !1,
3758
3818
  locked: !0
3759
3819
  };
3760
- i.set(a), !e && ee._isGroupOrSelection(i) && i.getObjects().forEach((c) => {
3820
+ i.set(a), !e && he._isGroupOrSelection(i) && i.getObjects().forEach((c) => {
3761
3821
  c.set(a);
3762
- }), i instanceof st && i.isEditing && i.exitEditing(), n.renderAll(), s || o.saveState(), n.fire("editor:object-locked", {
3822
+ }), i instanceof ot && i.isEditing && i.exitEditing(), n.renderAll(), s || o.saveState(), n.fire("editor:object-locked", {
3763
3823
  object: i,
3764
3824
  skipInnerObjects: e,
3765
3825
  withoutSave: s
@@ -3786,7 +3846,7 @@ class ee {
3786
3846
  editable: !0,
3787
3847
  locked: !1
3788
3848
  };
3789
- o.set(i), ee._isGroupOrSelection(o) && o.getObjects().forEach((a) => {
3849
+ o.set(i), he._isGroupOrSelection(o) && o.getObjects().forEach((a) => {
3790
3850
  a.set(i);
3791
3851
  }), s.renderAll(), e || n.saveState(), s.fire("editor:object-unlocked", {
3792
3852
  object: o,
@@ -3913,7 +3973,7 @@ class nn {
3913
3973
  o && s.lockObject({ object: i, skipInnerObjects: !0, withoutSave: !0 }), t.setActiveObject(i), t.requestRenderAll(), t.fire("editor:all-objects-selected", { selected: i });
3914
3974
  }
3915
3975
  }
3916
- class we {
3976
+ class Oe {
3917
3977
  constructor({ editor: t }) {
3918
3978
  this.editor = t;
3919
3979
  }
@@ -3960,7 +4020,7 @@ class we {
3960
4020
  s || o.suspendHistory();
3961
4021
  const r = [];
3962
4022
  if (a.forEach((d) => {
3963
- if (we._isUngroupableGroup(d)) {
4023
+ if (Oe._isUngroupableGroup(d)) {
3964
4024
  const l = this._handleGroupDeletion(d);
3965
4025
  r.push(...l);
3966
4026
  return;
@@ -3975,7 +4035,7 @@ class we {
3975
4035
  return n.fire("editor:objects-deleted", c), c;
3976
4036
  }
3977
4037
  }
3978
- const wt = {
4038
+ const St = {
3979
4039
  IMAGE_MANAGER: {
3980
4040
  /**
3981
4041
  * Некорректный Content-Type изображения
@@ -4080,7 +4140,7 @@ const wt = {
4080
4140
  APPLY_FAILED: "TEMPLATE_APPLY_FAILED"
4081
4141
  }
4082
4142
  };
4083
- class Wt {
4143
+ class Qt {
4084
4144
  constructor({ editor: t }) {
4085
4145
  this._buffer = [], this.editor = t;
4086
4146
  }
@@ -4107,7 +4167,7 @@ class Wt {
4107
4167
  * @fires editor:error
4108
4168
  */
4109
4169
  emitError({ origin: t = "ImageEditor", method: e = "Unknown Method", code: s, data: n, message: o }) {
4110
- if (!Wt.isValidErrorCode(s)) {
4170
+ if (!Qt.isValidErrorCode(s)) {
4111
4171
  console.warn("Неизвестный код ошибки: ", { code: s, origin: t, method: e });
4112
4172
  return;
4113
4173
  }
@@ -4136,7 +4196,7 @@ class Wt {
4136
4196
  * @fires editor:warning
4137
4197
  */
4138
4198
  emitWarning({ origin: t = "ImageEditor", method: e = "Unknown Method", code: s, message: n, data: o }) {
4139
- if (!Wt.isValidErrorCode(s)) {
4199
+ if (!Qt.isValidErrorCode(s)) {
4140
4200
  console.warn("Неизвестный код предупреждения: ", { code: s, origin: t, method: e });
4141
4201
  return;
4142
4202
  }
@@ -4159,7 +4219,7 @@ class Wt {
4159
4219
  * @returns true, если код допустим, иначе false
4160
4220
  */
4161
4221
  static isValidErrorCode(t) {
4162
- return t ? Object.values(wt).some((e) => Object.values(e).includes(t)) : !1;
4222
+ return t ? Object.values(St).some((e) => Object.values(e).includes(t)) : !1;
4163
4223
  }
4164
4224
  }
4165
4225
  class on {
@@ -4247,11 +4307,11 @@ class on {
4247
4307
  this.currentBounds = this.calculatePanBounds();
4248
4308
  }
4249
4309
  }
4250
- const rt = ({
4310
+ const dt = ({
4251
4311
  value: h,
4252
4312
  min: t,
4253
4313
  max: e
4254
- }) => Math.min(Math.max(h, t), e), Dt = class Dt extends st {
4314
+ }) => Math.min(Math.max(h, t), e), Dt = class Dt extends ot {
4255
4315
  constructor(t, e = {}) {
4256
4316
  var s, n, o, i, a, r, c, d, l;
4257
4317
  super(t, e), this.backgroundOpacity = (s = e.backgroundOpacity) != null ? s : 1, this.paddingTop = (n = e.paddingTop) != null ? n : 0, this.paddingRight = (o = e.paddingRight) != null ? o : 0, this.paddingBottom = (i = e.paddingBottom) != null ? i : 0, this.paddingLeft = (a = e.paddingLeft) != null ? a : 0, this.radiusTopLeft = (r = e.radiusTopLeft) != null ? r : 0, this.radiusTopRight = (c = e.radiusTopRight) != null ? c : 0, this.radiusBottomRight = (d = e.radiusBottomRight) != null ? d : 0, this.radiusBottomLeft = (l = e.radiusBottomLeft) != null ? l : 0, this._roundDimensions();
@@ -4276,7 +4336,7 @@ const rt = ({
4276
4336
  }
4277
4337
  _getTransformedDimensions(t = {}) {
4278
4338
  const { width: e, height: s } = this._getBackgroundDimensions();
4279
- return super._getTransformedDimensions(bt(B({}, t), {
4339
+ return super._getTransformedDimensions(wt(B({}, t), {
4280
4340
  width: e,
4281
4341
  height: s
4282
4342
  }));
@@ -4286,7 +4346,7 @@ const rt = ({
4286
4346
  */
4287
4347
  toObject(t = []) {
4288
4348
  const e = super.toObject(t);
4289
- return bt(B({}, e), {
4349
+ return wt(B({}, e), {
4290
4350
  backgroundOpacity: this.backgroundOpacity,
4291
4351
  paddingTop: this.paddingTop,
4292
4352
  paddingRight: this.paddingRight,
@@ -4325,10 +4385,10 @@ const rt = ({
4325
4385
  var i, a, r, c;
4326
4386
  const s = t / 2, n = e / 2, o = Math.min(s, n);
4327
4387
  return {
4328
- bottomLeft: rt({ value: (i = this.radiusBottomLeft) != null ? i : 0, min: 0, max: o }),
4329
- bottomRight: rt({ value: (a = this.radiusBottomRight) != null ? a : 0, min: 0, max: o }),
4330
- topLeft: rt({ value: (r = this.radiusTopLeft) != null ? r : 0, min: 0, max: o }),
4331
- topRight: rt({ value: (c = this.radiusTopRight) != null ? c : 0, min: 0, max: o })
4388
+ bottomLeft: dt({ value: (i = this.radiusBottomLeft) != null ? i : 0, min: 0, max: o }),
4389
+ bottomRight: dt({ value: (a = this.radiusBottomRight) != null ? a : 0, min: 0, max: o }),
4390
+ topLeft: dt({ value: (r = this.radiusTopLeft) != null ? r : 0, min: 0, max: o }),
4391
+ topRight: dt({ value: (c = this.radiusTopRight) != null ? c : 0, min: 0, max: o })
4332
4392
  };
4333
4393
  }
4334
4394
  _getPadding() {
@@ -4344,12 +4404,12 @@ const rt = ({
4344
4404
  var n;
4345
4405
  const t = this.backgroundColor;
4346
4406
  if (!t) return null;
4347
- const e = rt({ value: (n = this.backgroundOpacity) != null ? n : 1, min: 0, max: 1 });
4407
+ const e = dt({ value: (n = this.backgroundOpacity) != null ? n : 1, min: 0, max: 1 });
4348
4408
  let s;
4349
4409
  try {
4350
- s = new ps(t);
4410
+ s = new ms(t);
4351
4411
  } catch (o) {
4352
- return Wt.emitError({
4412
+ return Qt.emitError({
4353
4413
  origin: "BackgroundTextbox",
4354
4414
  method: "_getEffectiveBackgroundFill",
4355
4415
  code: "INVALID_COLOR_VALUE",
@@ -4372,7 +4432,7 @@ const rt = ({
4372
4432
  topRight: d,
4373
4433
  bottomRight: l,
4374
4434
  bottomLeft: u
4375
- } = n, f = rt({ value: c, min: 0, max: i }), g = rt({ value: d, min: 0, max: i }), p = rt({ value: l, min: 0, max: i }), m = rt({ value: u, min: 0, max: i });
4435
+ } = n, f = dt({ value: c, min: 0, max: i }), g = dt({ value: d, min: 0, max: i }), p = dt({ value: l, min: 0, max: i }), m = dt({ value: u, min: 0, max: i });
4376
4436
  t.beginPath(), t.moveTo(s + f, o), t.lineTo(a - g, o), t.quadraticCurveTo(a, o, a, o + g), t.lineTo(a, r - p), t.quadraticCurveTo(a, r, a - p, r), t.lineTo(s + m, r), t.quadraticCurveTo(s, r, s, r - m), t.lineTo(s, o + f), t.quadraticCurveTo(s, o, s + f, o), t.closePath();
4377
4437
  }
4378
4438
  /**
@@ -4387,7 +4447,7 @@ const rt = ({
4387
4447
  }
4388
4448
  };
4389
4449
  Dt.type = "background-textbox", Dt.cacheProperties = [
4390
- ...Array.isArray(st.cacheProperties) ? st.cacheProperties : [],
4450
+ ...Array.isArray(ot.cacheProperties) ? ot.cacheProperties : [],
4391
4451
  "backgroundColor",
4392
4452
  "backgroundOpacity",
4393
4453
  "paddingTop",
@@ -4399,7 +4459,7 @@ Dt.type = "background-textbox", Dt.cacheProperties = [
4399
4459
  "radiusBottomRight",
4400
4460
  "radiusBottomLeft"
4401
4461
  ], Dt.stateProperties = [
4402
- ...Array.isArray(st.stateProperties) ? st.stateProperties : [],
4462
+ ...Array.isArray(ot.stateProperties) ? ot.stateProperties : [],
4403
4463
  "backgroundColor",
4404
4464
  "backgroundOpacity",
4405
4465
  "paddingTop",
@@ -4411,10 +4471,10 @@ Dt.type = "background-textbox", Dt.cacheProperties = [
4411
4471
  "radiusBottomRight",
4412
4472
  "radiusBottomLeft"
4413
4473
  ];
4414
- let se = Dt;
4474
+ let ue = Dt;
4415
4475
  const an = () => {
4416
4476
  var h;
4417
- (h = ze) != null && h.setClass && ze.setClass(se, "background-textbox");
4477
+ (h = Pe) != null && h.setClass && Pe.setClass(ue, "background-textbox");
4418
4478
  }, rn = ({ textbox: h }) => {
4419
4479
  var s, n;
4420
4480
  if (!h.isEditing) return null;
@@ -4432,7 +4492,7 @@ const an = () => {
4432
4492
  if (!t) return !1;
4433
4493
  const e = (n = (s = h.text) == null ? void 0 : s.length) != null ? n : 0;
4434
4494
  return e <= 0 ? !1 : t.start <= 0 && t.end >= e;
4435
- }, ae = ({
4495
+ }, ge = ({
4436
4496
  textbox: h,
4437
4497
  styles: t,
4438
4498
  range: e
@@ -4440,7 +4500,7 @@ const an = () => {
4440
4500
  if (!t || !Object.keys(t).length) return !1;
4441
4501
  const { start: s, end: n } = e;
4442
4502
  return n <= s ? !1 : (h.setSelectionStyles(t, s, n), !0);
4443
- }, Ge = ({
4503
+ }, Xe = ({
4444
4504
  textbox: h,
4445
4505
  range: t,
4446
4506
  property: e
@@ -4454,32 +4514,53 @@ const an = () => {
4454
4514
  );
4455
4515
  if (s.length)
4456
4516
  return (n = s[0]) == null ? void 0 : n[e];
4457
- }, Ve = ({ strokeColor: h, width: t }) => t <= 0 ? null : h != null ? h : "#000000", Xe = ({ width: h = 0 }) => h ? Math.max(0, h) : 0, re = ({ value: h }) => typeof h == "string" ? h.toLocaleUpperCase() : "", ot = 0.01;
4458
- class P {
4517
+ }, Ke = ({ strokeColor: h, width: t }) => t <= 0 ? null : h != null ? h : "#000000", Qe = ({ width: h = 0 }) => h ? Math.max(0, h) : 0, pe = ({ value: h }) => typeof h == "string" ? h.toLocaleUpperCase() : "", $ = 0.01;
4518
+ class k {
4459
4519
  constructor({ editor: t }) {
4460
4520
  var e;
4461
- this._handleTextEditingEntered = () => {
4521
+ this._handleTextEditingEntered = (s) => {
4522
+ var r;
4462
4523
  this.isTextEditingActive = !0;
4524
+ const { target: n } = s;
4525
+ if (!k._isTextbox(n)) return;
4526
+ const o = (r = n.originY) != null ? r : "top", i = n.getPointByOrigin("center", o);
4527
+ this._ensureEditingAnchorState().set(n, {
4528
+ originY: o,
4529
+ x: i.x,
4530
+ y: i.y
4531
+ });
4532
+ }, this._handleTextChanged = (s) => {
4533
+ const { target: n } = s;
4534
+ if (!k._isTextbox(n)) return;
4535
+ const { text: o = "", uppercase: i } = n, a = !!i, r = o.toLocaleLowerCase();
4536
+ if (a) {
4537
+ const l = pe({ value: r });
4538
+ l !== o && n.set({ text: l }), n.textCaseRaw = r;
4539
+ } else
4540
+ n.textCaseRaw = o;
4541
+ const c = this._autoExpandTextboxWidth(n), d = c ? !1 : k._roundTextboxDimensions({ textbox: n });
4542
+ (c || d) && (n.setCoords(), n.dirty = !0);
4463
4543
  }, this._handleTextEditingExited = (s) => {
4464
- var r, c;
4544
+ var r, c, d;
4465
4545
  const { target: n } = s;
4466
- if (!P._isTextbox(n)) return;
4467
- const o = (r = n.text) != null ? r : "";
4546
+ if (!k._isTextbox(n)) return;
4547
+ (r = this.editingAnchorState) == null || r.delete(n);
4548
+ const o = (c = n.text) != null ? c : "";
4468
4549
  if (!!n.uppercase) {
4469
- const d = (c = n.textCaseRaw) != null ? c : o.toLocaleLowerCase();
4470
- n.textCaseRaw = d;
4550
+ const l = (d = n.textCaseRaw) != null ? d : o.toLocaleLowerCase();
4551
+ n.textCaseRaw = l;
4471
4552
  } else
4472
4553
  n.textCaseRaw = o;
4473
- P._roundTextboxDimensions({ textbox: n }) && (n.setCoords(), n.dirty = !0, this.canvas.requestRenderAll()), n.locked || n.set({
4554
+ k._roundTextboxDimensions({ textbox: n }) && (n.setCoords(), n.dirty = !0, this.canvas.requestRenderAll()), n.locked || n.set({
4474
4555
  lockMovementX: !1,
4475
4556
  lockMovementY: !1
4476
4557
  }), setTimeout(() => {
4477
4558
  this.isTextEditingActive = !1, this.editor.historyManager.saveState();
4478
4559
  }, Vs);
4479
4560
  }, this._handleObjectScaling = (s) => {
4480
- var kt, K, Ct, Ht, vt, Zt, Tt, Ae, je, Ie, Ce, Te, Ee;
4561
+ var te, xt, Bt, kt, Wt, zt, Pt, Ut, Ft, X, Tt, ee, Mt;
4481
4562
  const { target: n, transform: o } = s;
4482
- if (n instanceof U || !P._isTextbox(n) || !o) return;
4563
+ if (n instanceof U || !k._isTextbox(n) || !o) return;
4483
4564
  n.isScaling = !0;
4484
4565
  const i = this._ensureScalingState(n), {
4485
4566
  baseWidth: a,
@@ -4488,56 +4569,56 @@ class P {
4488
4569
  basePadding: d,
4489
4570
  baseRadii: l,
4490
4571
  baseStyles: u
4491
- } = i, f = typeof ((kt = o.original) == null ? void 0 : kt.width) == "number" ? o.original.width : void 0, g = typeof ((K = o.original) == null ? void 0 : K.left) == "number" ? o.original.left : void 0, p = f != null ? f : a, m = g != null ? g : r, v = (Ct = o.corner) != null ? Ct : "", M = (Ht = o.action) != null ? Ht : "", S = ["ml", "mr"].includes(v) || M === "scaleX", y = ["mt", "mb"].includes(v) || M === "scaleY", b = ["tl", "tr", "bl", "br"].includes(v) || M === "scale", I = b || y;
4492
- if (!S && !y && !b) return;
4493
- const j = Math.abs((Zt = (vt = n.scaleX) != null ? vt : o.scaleX) != null ? Zt : 1) || 1, A = Math.abs((Ae = (Tt = n.scaleY) != null ? Tt : o.scaleY) != null ? Ae : 1) || 1, C = Math.max(1, p * j), w = Math.max(1, Math.round(C)), T = Math.max(1, c * A), {
4572
+ } = i, f = typeof ((te = o.original) == null ? void 0 : te.width) == "number" ? o.original.width : void 0, g = typeof ((xt = o.original) == null ? void 0 : xt.left) == "number" ? o.original.left : void 0, p = f != null ? f : a, m = g != null ? g : r, v = (Bt = o.corner) != null ? Bt : "", S = (kt = o.action) != null ? kt : "", A = ["ml", "mr"].includes(v) || S === "scaleX", y = ["mt", "mb"].includes(v) || S === "scaleY", b = ["tl", "tr", "bl", "br"].includes(v) || S === "scale", j = b || y;
4573
+ if (!A && !y && !b) return;
4574
+ const I = Math.abs((zt = (Wt = n.scaleX) != null ? Wt : o.scaleX) != null ? zt : 1) || 1, w = Math.abs((Ut = (Pt = n.scaleY) != null ? Pt : o.scaleY) != null ? Ut : 1) || 1, T = Math.max(1, p * I), M = Math.max(1, Math.round(T)), C = Math.max(1, c * w), {
4494
4575
  paddingTop: E = 0,
4495
- paddingRight: F = 0,
4496
- paddingBottom: x = 0,
4497
- paddingLeft: N = 0,
4498
- radiusTopLeft: Z = 0,
4499
- radiusTopRight: D = 0,
4500
- radiusBottomRight: _ = 0,
4501
- radiusBottomLeft: W = 0,
4502
- fontSize: G,
4503
- width: Y,
4504
- originX: X = "left"
4505
- } = n, et = b || y, J = b || y, H = et ? {
4506
- top: Math.max(0, d.top * A),
4507
- right: Math.max(0, d.right * A),
4508
- bottom: Math.max(0, d.bottom * A),
4509
- left: Math.max(0, d.left * A)
4510
- } : d, q = J ? {
4511
- topLeft: Math.max(0, l.topLeft * A),
4512
- topRight: Math.max(0, l.topRight * A),
4513
- bottomRight: Math.max(0, l.bottomRight * A),
4514
- bottomLeft: Math.max(0, l.bottomLeft * A)
4515
- } : l, jt = Object.keys(u).length > 0;
4516
- let nt;
4517
- if (I && jt) {
4518
- const oe = {};
4519
- Object.entries(u).forEach(([as, Oe]) => {
4520
- if (!Oe) return;
4521
- const ie = {};
4522
- Object.entries(Oe).forEach(([rs, Gt]) => {
4523
- if (!Gt) return;
4524
- const Le = B({}, Gt);
4525
- typeof Gt.fontSize == "number" && (Le.fontSize = Math.max(1, Gt.fontSize * A)), ie[rs] = Le;
4526
- }), Object.keys(ie).length && (oe[as] = ie);
4527
- }), Object.keys(oe).length && (nt = oe);
4576
+ paddingRight: W = 0,
4577
+ paddingBottom: N = 0,
4578
+ paddingLeft: x = 0,
4579
+ radiusTopLeft: Y = 0,
4580
+ radiusTopRight: G = 0,
4581
+ radiusBottomRight: K = 0,
4582
+ radiusBottomLeft: H = 0,
4583
+ fontSize: R,
4584
+ width: O,
4585
+ originX: it = "left"
4586
+ } = n, Z = b || y, st = b || y, F = Z ? {
4587
+ top: Math.max(0, d.top * w),
4588
+ right: Math.max(0, d.right * w),
4589
+ bottom: Math.max(0, d.bottom * w),
4590
+ left: Math.max(0, d.left * w)
4591
+ } : d, q = st ? {
4592
+ topLeft: Math.max(0, l.topLeft * w),
4593
+ topRight: Math.max(0, l.topRight * w),
4594
+ bottomRight: Math.max(0, l.bottomRight * w),
4595
+ bottomLeft: Math.max(0, l.bottomLeft * w)
4596
+ } : l, nt = Object.keys(u).length > 0;
4597
+ let J;
4598
+ if (j && nt) {
4599
+ const Yt = {};
4600
+ Object.entries(u).forEach(([Ht, De]) => {
4601
+ if (!De) return;
4602
+ const fe = {};
4603
+ Object.entries(De).forEach(([cs, se]) => {
4604
+ if (!se) return;
4605
+ const Re = B({}, se);
4606
+ typeof se.fontSize == "number" && (Re.fontSize = Math.max(1, se.fontSize * w)), fe[cs] = Re;
4607
+ }), Object.keys(fe).length && (Yt[Ht] = fe);
4608
+ }), Object.keys(Yt).length && (J = Yt);
4528
4609
  }
4529
- const ht = (Ie = (je = o.originX) != null ? je : X) != null ? Ie : "left", mt = m + p, It = m + p / 2, it = Y != null ? Y : p, yt = w !== it, ne = Math.abs(T - (G != null ? G : c)) > ot, Yt = Math.abs(H.top - E) > ot || Math.abs(H.right - F) > ot || Math.abs(H.bottom - x) > ot || Math.abs(H.left - N) > ot, xt = Math.abs(q.topLeft - Z) > ot || Math.abs(q.topRight - D) > ot || Math.abs(q.bottomRight - _) > ot || Math.abs(q.bottomLeft - W) > ot;
4530
- if (!yt && !ne && !Yt && !xt) {
4610
+ const yt = (X = (Ft = o.originX) != null ? Ft : it) != null ? X : "left", It = m + p, at = m + p / 2, ft = O != null ? O : p, rt = M !== ft, Nt = Math.abs(C - (R != null ? R : c)) > $, vt = Math.abs(F.top - E) > $ || Math.abs(F.right - W) > $ || Math.abs(F.bottom - N) > $ || Math.abs(F.left - x) > $, Jt = Math.abs(q.topLeft - Y) > $ || Math.abs(q.topRight - G) > $ || Math.abs(q.bottomRight - K) > $ || Math.abs(q.bottomLeft - H) > $;
4611
+ if (!rt && !Nt && !vt && !Jt) {
4531
4612
  n.set({ scaleX: 1, scaleY: 1 }), o.scaleX = 1, o.scaleY = 1;
4532
4613
  return;
4533
4614
  }
4534
- nt && (n.styles = nt), n.set({
4535
- width: w,
4536
- fontSize: I ? T : c,
4537
- paddingTop: H.top,
4538
- paddingRight: H.right,
4539
- paddingBottom: H.bottom,
4540
- paddingLeft: H.left,
4615
+ J && (n.styles = J), n.set({
4616
+ width: M,
4617
+ fontSize: j ? C : c,
4618
+ paddingTop: F.top,
4619
+ paddingRight: F.right,
4620
+ paddingBottom: F.bottom,
4621
+ paddingLeft: F.left,
4541
4622
  radiusTopLeft: q.topLeft,
4542
4623
  radiusTopRight: q.topRight,
4543
4624
  radiusBottomRight: q.bottomRight,
@@ -4545,82 +4626,82 @@ class P {
4545
4626
  scaleX: 1,
4546
4627
  scaleY: 1
4547
4628
  });
4548
- const Nt = P._roundTextboxDimensions({ textbox: n });
4549
- Nt && (n.dirty = !0);
4550
- const ut = (Ce = n.width) != null ? Ce : w, Bt = ut !== it;
4551
- let ft = m;
4552
- Bt && (S || b) && (ht === "right" ? ft = mt - ut : ht === "center" && (ft = It - ut / 2)), n.set({ left: ft }), i.baseLeft = ft, o.scaleX = 1, o.scaleY = 1;
4553
- const { original: at } = o;
4554
- at && (at.scaleX = 1, at.scaleY = 1, at.width = ut, at.height = n.height, at.left = ft), n.setCoords(), this.canvas.requestRenderAll(), i.baseWidth = ut, i.baseFontSize = (Te = n.fontSize) != null ? Te : T, i.baseStyles = JSON.parse(JSON.stringify((Ee = n.styles) != null ? Ee : {})), i.basePadding = {
4555
- top: H.top,
4556
- right: H.right,
4557
- bottom: H.bottom,
4558
- left: H.left
4629
+ const qt = k._roundTextboxDimensions({ textbox: n });
4630
+ qt && (n.dirty = !0);
4631
+ const Ct = (Tt = n.width) != null ? Tt : M, $t = Ct !== ft;
4632
+ let ct = m;
4633
+ $t && (A || b) && (yt === "right" ? ct = It - Ct : yt === "center" && (ct = at - Ct / 2)), n.set({ left: ct }), i.baseLeft = ct, o.scaleX = 1, o.scaleY = 1;
4634
+ const { original: bt } = o;
4635
+ bt && (bt.scaleX = 1, bt.scaleY = 1, bt.width = Ct, bt.height = n.height, bt.left = ct), n.setCoords(), this.canvas.requestRenderAll(), i.baseWidth = Ct, i.baseFontSize = (ee = n.fontSize) != null ? ee : C, i.baseStyles = JSON.parse(JSON.stringify((Mt = n.styles) != null ? Mt : {})), i.basePadding = {
4636
+ top: F.top,
4637
+ right: F.right,
4638
+ bottom: F.bottom,
4639
+ left: F.left
4559
4640
  }, i.baseRadii = {
4560
4641
  topLeft: q.topLeft,
4561
4642
  topRight: q.topRight,
4562
4643
  bottomRight: q.bottomRight,
4563
4644
  bottomLeft: q.bottomLeft
4564
- }, i.hasWidthChange = Bt || ne || Yt || xt || Nt;
4645
+ }, i.hasWidthChange = $t || Nt || vt || Jt || qt;
4565
4646
  }, this._handleObjectModified = (s) => {
4566
- var M, S, y;
4647
+ var S, A, y;
4567
4648
  const { target: n } = s;
4568
4649
  if (n instanceof U) {
4569
4650
  const b = n.getObjects();
4570
- if (!b.some((w) => P._isTextbox(w))) return;
4571
- const { scaleX: j = 1, scaleY: A = 1 } = n;
4572
- if (Math.abs(j - 1) < ot && Math.abs(A - 1) < ot) return;
4573
- this.canvas.discardActiveObject(), b.forEach((w) => {
4574
- var T, E, F, x;
4575
- if (P._isTextbox(w)) {
4576
- const N = (T = w.scaleX) != null ? T : 1, Z = (E = w.scaleY) != null ? E : 1, D = ((F = w.fontSize) != null ? F : 16) * Z, _ = ((x = w.width) != null ? x : 0) * N, W = Z, {
4577
- paddingTop: G = 0,
4578
- paddingRight: Y = 0,
4579
- paddingBottom: X = 0,
4580
- paddingLeft: et = 0,
4581
- radiusTopLeft: J = 0,
4582
- radiusTopRight: H = 0,
4651
+ if (!b.some((M) => k._isTextbox(M))) return;
4652
+ const { scaleX: I = 1, scaleY: w = 1 } = n;
4653
+ if (Math.abs(I - 1) < $ && Math.abs(w - 1) < $) return;
4654
+ this.canvas.discardActiveObject(), b.forEach((M) => {
4655
+ var C, E, W, N;
4656
+ if (k._isTextbox(M)) {
4657
+ const x = (C = M.scaleX) != null ? C : 1, Y = (E = M.scaleY) != null ? E : 1, G = ((W = M.fontSize) != null ? W : 16) * Y, K = ((N = M.width) != null ? N : 0) * x, H = Y, {
4658
+ paddingTop: R = 0,
4659
+ paddingRight: O = 0,
4660
+ paddingBottom: it = 0,
4661
+ paddingLeft: Z = 0,
4662
+ radiusTopLeft: st = 0,
4663
+ radiusTopRight: F = 0,
4583
4664
  radiusBottomRight: q = 0,
4584
- radiusBottomLeft: jt = 0,
4585
- styles: nt
4586
- } = w, ht = {
4587
- paddingTop: Math.max(0, G * W),
4588
- paddingRight: Math.max(0, Y * W),
4589
- paddingBottom: Math.max(0, X * W),
4590
- paddingLeft: Math.max(0, et * W)
4591
- }, mt = {
4592
- radiusTopLeft: Math.max(0, J * W),
4593
- radiusTopRight: Math.max(0, H * W),
4594
- radiusBottomRight: Math.max(0, q * W),
4595
- radiusBottomLeft: Math.max(0, jt * W)
4665
+ radiusBottomLeft: nt = 0,
4666
+ styles: J
4667
+ } = M, yt = {
4668
+ paddingTop: Math.max(0, R * H),
4669
+ paddingRight: Math.max(0, O * H),
4670
+ paddingBottom: Math.max(0, it * H),
4671
+ paddingLeft: Math.max(0, Z * H)
4672
+ }, It = {
4673
+ radiusTopLeft: Math.max(0, st * H),
4674
+ radiusTopRight: Math.max(0, F * H),
4675
+ radiusBottomRight: Math.max(0, q * H),
4676
+ radiusBottomLeft: Math.max(0, nt * H)
4596
4677
  };
4597
- let It = nt;
4598
- nt && Object.keys(nt).length > 0 && (It = JSON.parse(JSON.stringify(nt)), Object.values(It).forEach((it) => {
4599
- Object.values(it).forEach((yt) => {
4600
- typeof yt.fontSize == "number" && (yt.fontSize = Math.max(1, yt.fontSize * W));
4678
+ let at = J;
4679
+ J && Object.keys(J).length > 0 && (at = JSON.parse(JSON.stringify(J)), Object.values(at).forEach((ft) => {
4680
+ Object.values(ft).forEach((rt) => {
4681
+ typeof rt.fontSize == "number" && (rt.fontSize = Math.max(1, rt.fontSize * H));
4601
4682
  });
4602
- })), w.set(bt(B(B({
4603
- fontSize: D,
4604
- width: _,
4683
+ })), M.set(wt(B(B({
4684
+ fontSize: G,
4685
+ width: K,
4605
4686
  scaleX: 1,
4606
4687
  scaleY: 1
4607
- }, ht), mt), {
4608
- styles: It
4609
- })), P._roundTextboxDimensions({ textbox: w });
4688
+ }, yt), It), {
4689
+ styles: at
4690
+ })), k._roundTextboxDimensions({ textbox: M });
4610
4691
  }
4611
- w.setCoords();
4692
+ M.setCoords();
4612
4693
  });
4613
- const C = new U(b, {
4694
+ const T = new U(b, {
4614
4695
  canvas: this.canvas
4615
4696
  });
4616
- this.canvas.setActiveObject(C), this.canvas.requestRenderAll();
4697
+ this.canvas.setActiveObject(T), this.canvas.requestRenderAll();
4617
4698
  return;
4618
4699
  }
4619
- if (!P._isTextbox(n)) return;
4700
+ if (!k._isTextbox(n)) return;
4620
4701
  n.isScaling = !1;
4621
4702
  const o = this.scalingState.get(n);
4622
4703
  if (this.scalingState.delete(n), !(o != null && o.hasWidthChange)) return;
4623
- const i = (M = n.width) != null ? M : n.calcTextWidth(), a = (y = (S = n.fontSize) != null ? S : o == null ? void 0 : o.baseFontSize) != null ? y : 16, r = !!(o.baseStyles && Object.keys(o.baseStyles).length), {
4704
+ const i = (S = n.width) != null ? S : n.calcTextWidth(), a = (y = (A = n.fontSize) != null ? A : o == null ? void 0 : o.baseFontSize) != null ? y : 16, r = !!(o.baseStyles && Object.keys(o.baseStyles).length), {
4624
4705
  paddingTop: c = 0,
4625
4706
  paddingRight: d = 0,
4626
4707
  paddingBottom: l = 0,
@@ -4644,15 +4725,15 @@ class P {
4644
4725
  target: n,
4645
4726
  style: v
4646
4727
  }), n.set({ scaleX: 1, scaleY: 1 }), n.setCoords();
4647
- }, this.editor = t, this.canvas = t.canvas, this.fonts = (e = t.options.fonts) != null ? e : [], this.scalingState = /* @__PURE__ */ new WeakMap(), this.isTextEditingActive = !1, this._bindEvents(), an();
4728
+ }, this.editor = t, this.canvas = t.canvas, this.fonts = (e = t.options.fonts) != null ? e : [], this.scalingState = /* @__PURE__ */ new WeakMap(), this.editingAnchorState = /* @__PURE__ */ new WeakMap(), this.isTextEditingActive = !1, this._bindEvents(), an();
4648
4729
  }
4649
4730
  /**
4650
4731
  * Добавляет новый текстовый объект на канвас.
4651
4732
  * @param options — настройки текста
4652
4733
  * @param flags — флаги поведения
4653
4734
  */
4654
- addText(F = {}, { withoutSelection: w = !1, withoutSave: T = !1, withoutAdding: E = !1 } = {}) {
4655
- var x = F, {
4735
+ addText(W = {}, { withoutSelection: M = !1, withoutSave: C = !1, withoutAdding: E = !1 } = {}) {
4736
+ var N = W, {
4656
4737
  id: t = `text-${V()}`,
4657
4738
  text: e = "Новый текст",
4658
4739
  fontFamily: s,
@@ -4670,14 +4751,14 @@ class P {
4670
4751
  backgroundColor: p,
4671
4752
  backgroundOpacity: m = 1,
4672
4753
  paddingTop: v = 0,
4673
- paddingRight: M = 0,
4674
- paddingBottom: S = 0,
4754
+ paddingRight: S = 0,
4755
+ paddingBottom: A = 0,
4675
4756
  paddingLeft: y = 0,
4676
4757
  radiusTopLeft: b = 0,
4677
- radiusTopRight: I = 0,
4678
- radiusBottomRight: j = 0,
4679
- radiusBottomLeft: A = 0
4680
- } = x, C = Mt(x, [
4758
+ radiusTopRight: j = 0,
4759
+ radiusBottomRight: I = 0,
4760
+ radiusBottomLeft: w = 0
4761
+ } = N, T = gt(N, [
4681
4762
  "id",
4682
4763
  "text",
4683
4764
  "fontFamily",
@@ -4703,15 +4784,15 @@ class P {
4703
4784
  "radiusBottomRight",
4704
4785
  "radiusBottomLeft"
4705
4786
  ]);
4706
- var et;
4707
- const { historyManager: N } = this.editor, { canvas: Z } = this;
4708
- N.suspendHistory();
4709
- const D = s != null ? s : this._getDefaultFontFamily(), _ = Xe({ width: f }), W = Ve({
4787
+ var Z;
4788
+ const { historyManager: x } = this.editor, { canvas: Y } = this;
4789
+ x.suspendHistory();
4790
+ const G = s != null ? s : this._getDefaultFontFamily(), K = Qe({ width: f }), H = Ke({
4710
4791
  strokeColor: u,
4711
- width: _
4712
- }), G = B({
4792
+ width: K
4793
+ }), R = B({
4713
4794
  id: t,
4714
- fontFamily: D,
4795
+ fontFamily: G,
4715
4796
  fontSize: n,
4716
4797
  fontWeight: o ? "bold" : "normal",
4717
4798
  fontStyle: i ? "italic" : "normal",
@@ -4720,43 +4801,43 @@ class P {
4720
4801
  linethrough: c,
4721
4802
  textAlign: d,
4722
4803
  fill: l,
4723
- stroke: W,
4724
- strokeWidth: _,
4804
+ stroke: H,
4805
+ strokeWidth: K,
4725
4806
  strokeUniform: !0,
4726
4807
  opacity: g,
4727
4808
  backgroundColor: p,
4728
4809
  backgroundOpacity: m,
4729
4810
  paddingTop: v,
4730
- paddingRight: M,
4731
- paddingBottom: S,
4811
+ paddingRight: S,
4812
+ paddingBottom: A,
4732
4813
  paddingLeft: y,
4733
4814
  radiusTopLeft: b,
4734
- radiusTopRight: I,
4735
- radiusBottomRight: j,
4736
- radiusBottomLeft: A
4737
- }, C), Y = new se(e, G);
4738
- if (Y.textCaseRaw = (et = Y.text) != null ? et : "", r) {
4739
- const J = re({ value: Y.textCaseRaw });
4740
- J !== Y.text && Y.set({ text: J });
4741
- }
4742
- return P._roundTextboxDimensions({ textbox: Y }) && (Y.dirty = !0), C.left === void 0 && C.top === void 0 && Z.centerObject(Y), E || Z.add(Y), w || Z.setActiveObject(Y), Z.requestRenderAll(), N.resumeHistory(), T || N.saveState(), Z.fire("editor:text-added", {
4743
- textbox: Y,
4744
- options: bt(B({}, G), {
4815
+ radiusTopRight: j,
4816
+ radiusBottomRight: I,
4817
+ radiusBottomLeft: w
4818
+ }, T), O = new ue(e, R);
4819
+ if (O.textCaseRaw = (Z = O.text) != null ? Z : "", r) {
4820
+ const st = pe({ value: O.textCaseRaw });
4821
+ st !== O.text && O.set({ text: st });
4822
+ }
4823
+ return k._roundTextboxDimensions({ textbox: O }) && (O.dirty = !0), T.left === void 0 && T.top === void 0 && Y.centerObject(O), E || Y.add(O), M || Y.setActiveObject(O), Y.requestRenderAll(), x.resumeHistory(), C || x.saveState(), Y.fire("editor:text-added", {
4824
+ textbox: O,
4825
+ options: wt(B({}, R), {
4745
4826
  text: e,
4746
4827
  bold: o,
4747
4828
  italic: i,
4748
4829
  strikethrough: c,
4749
4830
  align: d,
4750
4831
  color: l,
4751
- strokeColor: W,
4752
- strokeWidth: _
4832
+ strokeColor: H,
4833
+ strokeWidth: K
4753
4834
  }),
4754
4835
  flags: {
4755
- withoutSelection: !!w,
4756
- withoutSave: !!T,
4836
+ withoutSelection: !!M,
4837
+ withoutSave: !!C,
4757
4838
  withoutAdding: !!E
4758
4839
  }
4759
- }), Y;
4840
+ }), O;
4760
4841
  }
4761
4842
  /**
4762
4843
  * Обновляет текстовый объект.
@@ -4767,36 +4848,40 @@ class P {
4767
4848
  * @param options.skipRender — не вызывать перерисовку канваса
4768
4849
  */
4769
4850
  updateText({ target: t, style: e = {}, withoutSave: s, skipRender: n } = {}) {
4770
- var Nt, ut, Bt, ft, at, kt;
4851
+ var xt, kt, Wt, zt, Pt, Ut, Ft;
4771
4852
  const o = this._resolveTextObject(t);
4772
4853
  if (!o) return null;
4773
4854
  const { historyManager: i } = this.editor, { canvas: a } = this;
4774
4855
  i.suspendHistory();
4775
- const r = P._getSnapshot(o), xt = e, {
4776
- text: c,
4777
- fontFamily: d,
4778
- fontSize: l,
4779
- bold: u,
4780
- italic: f,
4781
- underline: g,
4782
- uppercase: p,
4783
- strikethrough: m,
4784
- align: v,
4785
- color: M,
4786
- strokeColor: S,
4787
- strokeWidth: y,
4788
- opacity: b,
4789
- backgroundColor: I,
4790
- backgroundOpacity: j,
4791
- paddingTop: A,
4792
- paddingRight: C,
4793
- paddingBottom: w,
4794
- paddingLeft: T,
4795
- radiusTopLeft: E,
4796
- radiusTopRight: F,
4797
- radiusBottomRight: x,
4798
- radiusBottomLeft: N
4799
- } = xt, Z = Mt(xt, [
4856
+ const r = k._getSnapshot(o), c = (xt = o.originY) != null ? xt : "top", d = o.getPointByOrigin("center", c), l = {
4857
+ originY: c,
4858
+ x: d.x,
4859
+ y: d.y
4860
+ }, Bt = e, {
4861
+ text: u,
4862
+ fontFamily: f,
4863
+ fontSize: g,
4864
+ bold: p,
4865
+ italic: m,
4866
+ underline: v,
4867
+ uppercase: S,
4868
+ strikethrough: A,
4869
+ align: y,
4870
+ color: b,
4871
+ strokeColor: j,
4872
+ strokeWidth: I,
4873
+ opacity: w,
4874
+ backgroundColor: T,
4875
+ backgroundOpacity: M,
4876
+ paddingTop: C,
4877
+ paddingRight: E,
4878
+ paddingBottom: W,
4879
+ paddingLeft: N,
4880
+ radiusTopLeft: x,
4881
+ radiusTopRight: Y,
4882
+ radiusBottomRight: G,
4883
+ radiusBottomLeft: K
4884
+ } = Bt, H = gt(Bt, [
4800
4885
  "text",
4801
4886
  "fontFamily",
4802
4887
  "fontSize",
@@ -4820,46 +4905,58 @@ class P {
4820
4905
  "radiusTopRight",
4821
4906
  "radiusBottomRight",
4822
4907
  "radiusBottomLeft"
4823
- ]), D = B({}, Z), _ = rn({ textbox: o }), W = _ ? P._expandRangeToFullLines({ textbox: o, range: _ }) : null, G = {}, Y = {}, X = {}, et = dn({ textbox: o, range: _ }), J = !_ || et, H = !_;
4824
- if (d !== void 0 && (W && (Y.fontFamily = d), J && (D.fontFamily = d, H && (X.fontFamily = d))), l !== void 0 && (W && (Y.fontSize = l), J && (D.fontSize = l, H && (X.fontSize = l))), u !== void 0) {
4825
- const K = u ? "bold" : "normal";
4826
- _ && (G.fontWeight = K), J && (D.fontWeight = K, H && (X.fontWeight = K));
4827
- }
4828
- if (f !== void 0) {
4829
- const K = f ? "italic" : "normal";
4830
- _ && (G.fontStyle = K), J && (D.fontStyle = K, H && (X.fontStyle = K));
4831
- }
4832
- if (g !== void 0 && (_ && (G.underline = g), J && (D.underline = g, H && (X.underline = g))), m !== void 0 && (_ && (G.linethrough = m), J && (D.linethrough = m, H && (X.linethrough = m))), v !== void 0 && (D.textAlign = v), M !== void 0 && (_ && (G.fill = M), J && (D.fill = M, H && (X.fill = M))), S !== void 0 || y !== void 0) {
4833
- const K = _ ? Ge({ textbox: o, range: _, property: "strokeWidth" }) : void 0, Ct = _ ? Ge({ textbox: o, range: _, property: "stroke" }) : void 0, Ht = (ut = (Nt = y != null ? y : K) != null ? Nt : o.strokeWidth) != null ? ut : 0, vt = Xe({ width: Ht }), Zt = (ft = (Bt = S != null ? S : Ct) != null ? Bt : o.stroke) != null ? ft : void 0, Tt = Ve({
4834
- strokeColor: Zt,
4835
- width: vt
4908
+ ]), R = B({}, H), O = rn({ textbox: o }), it = O ? k._expandRangeToFullLines({ textbox: o, range: O }) : null, Z = {}, st = {}, F = {}, q = dn({ textbox: o, range: O }), nt = !O || q, J = !O;
4909
+ if (f !== void 0 && (it && (st.fontFamily = f), nt && (R.fontFamily = f, J && (F.fontFamily = f))), g !== void 0 && (it && (st.fontSize = g), nt && (R.fontSize = g, J && (F.fontSize = g))), p !== void 0) {
4910
+ const X = p ? "bold" : "normal";
4911
+ O && (Z.fontWeight = X), nt && (R.fontWeight = X, J && (F.fontWeight = X));
4912
+ }
4913
+ if (m !== void 0) {
4914
+ const X = m ? "italic" : "normal";
4915
+ O && (Z.fontStyle = X), nt && (R.fontStyle = X, J && (F.fontStyle = X));
4916
+ }
4917
+ if (v !== void 0 && (O && (Z.underline = v), nt && (R.underline = v, J && (F.underline = v))), A !== void 0 && (O && (Z.linethrough = A), nt && (R.linethrough = A, J && (F.linethrough = A))), y !== void 0 && (R.textAlign = y), b !== void 0 && (O && (Z.fill = b), nt && (R.fill = b, J && (F.fill = b))), j !== void 0 || I !== void 0) {
4918
+ const X = O ? Xe({ textbox: o, range: O, property: "strokeWidth" }) : void 0, Tt = O ? Xe({ textbox: o, range: O, property: "stroke" }) : void 0, ee = (Wt = (kt = I != null ? I : X) != null ? kt : o.strokeWidth) != null ? Wt : 0, Mt = Qe({ width: ee }), Yt = (Pt = (zt = j != null ? j : Tt) != null ? zt : o.stroke) != null ? Pt : void 0, Ht = Ke({
4919
+ strokeColor: Yt,
4920
+ width: Mt
4836
4921
  });
4837
- _ && (G.stroke = Tt, G.strokeWidth = vt), J && (D.stroke = Tt, D.strokeWidth = vt, H && (X.stroke = Tt, X.strokeWidth = vt));
4838
- }
4839
- b !== void 0 && (D.opacity = b), I !== void 0 && (D.backgroundColor = I), j !== void 0 && (D.backgroundOpacity = j), A !== void 0 && (D.paddingTop = A), C !== void 0 && (D.paddingRight = C), w !== void 0 && (D.paddingBottom = w), T !== void 0 && (D.paddingLeft = T), E !== void 0 && (D.radiusTopLeft = E), F !== void 0 && (D.radiusTopRight = F), x !== void 0 && (D.radiusBottomRight = x), N !== void 0 && (D.radiusBottomLeft = N);
4840
- const q = (kt = o.textCaseRaw) != null ? kt : (at = o.text) != null ? at : "", jt = !!o.uppercase, nt = c !== void 0, ht = nt ? c != null ? c : "" : q, mt = p != null ? p : jt;
4841
- if (nt || mt !== jt) {
4842
- const K = mt ? re({ value: ht }) : ht;
4843
- D.text = K, o.textCaseRaw = ht;
4844
- } else o.textCaseRaw === void 0 && (o.textCaseRaw = q);
4845
- o.uppercase = mt, o.set(D);
4846
- let it = !1;
4847
- if (_) {
4848
- const K = ae({ textbox: o, styles: G, range: _ }), Ct = W ? ae({ textbox: o, styles: Y, range: W }) : !1;
4849
- it = K || Ct;
4850
- } else if (Object.keys(X).length) {
4851
- const K = cn({ textbox: o });
4852
- K && (it = ae({ textbox: o, styles: X, range: K }));
4853
- }
4854
- const yt = it && P._hasLayoutAffectingStyles({
4922
+ O && (Z.stroke = Ht, Z.strokeWidth = Mt), nt && (R.stroke = Ht, R.strokeWidth = Mt, J && (F.stroke = Ht, F.strokeWidth = Mt));
4923
+ }
4924
+ w !== void 0 && (R.opacity = w), T !== void 0 && (R.backgroundColor = T), M !== void 0 && (R.backgroundOpacity = M), C !== void 0 && (R.paddingTop = C), E !== void 0 && (R.paddingRight = E), W !== void 0 && (R.paddingBottom = W), N !== void 0 && (R.paddingLeft = N), x !== void 0 && (R.radiusTopLeft = x), Y !== void 0 && (R.radiusTopRight = Y), G !== void 0 && (R.radiusBottomRight = G), K !== void 0 && (R.radiusBottomLeft = K);
4925
+ const yt = (Ft = o.textCaseRaw) != null ? Ft : (Ut = o.text) != null ? Ut : "", It = !!o.uppercase, at = u !== void 0, ft = at ? u != null ? u : "" : yt, rt = S != null ? S : It, Nt = rt !== It;
4926
+ if (at || Nt) {
4927
+ const X = rt ? pe({ value: ft }) : ft;
4928
+ R.text = X, o.textCaseRaw = ft;
4929
+ } else o.textCaseRaw === void 0 && (o.textCaseRaw = yt);
4930
+ o.uppercase = rt, o.set(R);
4931
+ let vt = !1;
4932
+ if (O) {
4933
+ const X = ge({ textbox: o, styles: Z, range: O }), Tt = it ? ge({ textbox: o, styles: st, range: it }) : !1;
4934
+ vt = X || Tt;
4935
+ } else if (Object.keys(F).length) {
4936
+ const X = cn({ textbox: o });
4937
+ X && (vt = ge({ textbox: o, styles: F, range: X }));
4938
+ }
4939
+ const Jt = vt && k._hasLayoutAffectingStyles({
4855
4940
  stylesList: [
4856
- G,
4857
- Y,
4858
- X
4941
+ Z,
4942
+ st,
4943
+ F
4859
4944
  ]
4860
4945
  });
4861
- it && (o.dirty = !0), yt && (o.initDimensions(), o.dirty = !0), (I !== void 0 || j !== void 0 || A !== void 0 || C !== void 0 || w !== void 0 || T !== void 0 || E !== void 0 || F !== void 0 || x !== void 0 || N !== void 0) && (o.dirty = !0), P._roundTextboxDimensions({ textbox: o }) && (o.dirty = !0), o.setCoords(), n || a.requestRenderAll(), i.resumeHistory(), s || i.saveState();
4862
- const Yt = P._getSnapshot(o);
4946
+ vt && (o.dirty = !0), Jt && (o.initDimensions(), o.dirty = !0), (T !== void 0 || M !== void 0 || C !== void 0 || E !== void 0 || W !== void 0 || N !== void 0 || x !== void 0 || Y !== void 0 || G !== void 0 || K !== void 0) && (o.dirty = !0);
4947
+ const qt = k._hasLayoutAffectingStyles({
4948
+ stylesList: [
4949
+ R,
4950
+ Z,
4951
+ st,
4952
+ F
4953
+ ]
4954
+ }), $t = !Object.prototype.hasOwnProperty.call(R, "width") && (at || Nt || qt);
4955
+ let ct = !1;
4956
+ $t && (ct = this._autoExpandTextboxWidth(o, {
4957
+ anchor: l
4958
+ }), ct && (o.dirty = !0)), (ct ? !1 : k._roundTextboxDimensions({ textbox: o })) && (o.dirty = !0), o.setCoords(), n || a.requestRenderAll(), i.resumeHistory(), s || i.saveState();
4959
+ const te = k._getSnapshot(o);
4863
4960
  return a.fire("editor:text-updated", {
4864
4961
  textbox: o,
4865
4962
  target: t,
@@ -4868,11 +4965,11 @@ class P {
4868
4965
  withoutSave: !!s,
4869
4966
  skipRender: !!n
4870
4967
  },
4871
- updates: D,
4968
+ updates: R,
4872
4969
  before: r,
4873
- after: Yt,
4874
- selectionRange: _ != null ? _ : void 0,
4875
- selectionStyles: _ && Object.keys(G).length ? G : void 0
4970
+ after: te,
4971
+ selectionRange: O != null ? O : void 0,
4972
+ selectionStyles: O && Object.keys(Z).length ? Z : void 0
4876
4973
  }), o;
4877
4974
  }
4878
4975
  /**
@@ -4880,20 +4977,20 @@ class P {
4880
4977
  */
4881
4978
  destroy() {
4882
4979
  const { canvas: t } = this;
4883
- t.off("object:scaling", this._handleObjectScaling), t.off("object:resizing", P._handleObjectResizing), t.off("object:modified", this._handleObjectModified), t.off("text:editing:exited", this._handleTextEditingExited), t.off("text:editing:entered", this._handleTextEditingEntered), t.off("text:changed", P._handleTextChanged);
4980
+ t.off("object:scaling", this._handleObjectScaling), t.off("object:resizing", k._handleObjectResizing), t.off("object:modified", this._handleObjectModified), t.off("text:editing:exited", this._handleTextEditingExited), t.off("text:editing:entered", this._handleTextEditingEntered), t.off("text:changed", this._handleTextChanged);
4884
4981
  }
4885
4982
  /**
4886
4983
  * Возвращает активный текст или ищет по id.
4887
4984
  */
4888
4985
  _resolveTextObject(t) {
4889
- if (t instanceof st) return t;
4986
+ if (t instanceof ot) return t;
4890
4987
  const { canvas: e } = this;
4891
4988
  if (!t) {
4892
4989
  const s = e.getActiveObject();
4893
- return P._isTextbox(s) ? s : null;
4990
+ return k._isTextbox(s) ? s : null;
4894
4991
  }
4895
4992
  if (typeof t == "string") {
4896
- const s = e.getObjects().find((n) => P._isTextbox(n) && n.id === t);
4993
+ const s = e.getObjects().find((n) => k._isTextbox(n) && n.id === t);
4897
4994
  return s != null ? s : null;
4898
4995
  }
4899
4996
  return null;
@@ -4902,28 +4999,83 @@ class P {
4902
4999
  * Проверяет, является ли объект текстовым блоком редактора.
4903
5000
  */
4904
5001
  static _isTextbox(t) {
4905
- return !!t && t instanceof st;
5002
+ return !!t && t instanceof ot;
4906
5003
  }
4907
5004
  /**
4908
5005
  * Вешает обработчики событий Fabric для работы с текстом.
4909
5006
  */
4910
5007
  _bindEvents() {
4911
5008
  const { canvas: t } = this;
4912
- t.on("object:scaling", this._handleObjectScaling), t.on("object:resizing", P._handleObjectResizing), t.on("object:modified", this._handleObjectModified), t.on("text:editing:entered", this._handleTextEditingEntered), t.on("text:editing:exited", this._handleTextEditingExited), t.on("text:changed", P._handleTextChanged);
5009
+ t.on("object:scaling", this._handleObjectScaling), t.on("object:resizing", k._handleObjectResizing), t.on("object:modified", this._handleObjectModified), t.on("text:editing:entered", this._handleTextEditingEntered), t.on("text:editing:exited", this._handleTextEditingExited), t.on("text:changed", this._handleTextChanged);
4913
5010
  }
4914
5011
  /**
4915
- * Реагирует на изменение текста в режиме редактирования: синхронизирует textCaseRaw и uppercase.
5012
+ * Автоматически увеличивает ширину текстового объекта до ширины текста,
5013
+ * но не шире монтажной области, и удерживает объект в её пределах.
4916
5014
  */
4917
- static _handleTextChanged(t) {
4918
- const { target: e } = t;
4919
- if (!P._isTextbox(e)) return;
4920
- const { text: s = "", uppercase: n } = e, o = !!n, i = s.toLocaleLowerCase();
4921
- if (o) {
4922
- const r = re({ value: i });
4923
- r !== s && e.set({ text: r }), e.textCaseRaw = i;
4924
- } else
4925
- e.textCaseRaw = s;
4926
- P._roundTextboxDimensions({ textbox: e }) && (e.setCoords(), e.dirty = !0);
5015
+ _autoExpandTextboxWidth(t, { anchor: e } = {}) {
5016
+ var I, w, T, M, C, E, W, N, x, Y, G, K, H;
5017
+ const { montageArea: s } = this.editor;
5018
+ if (!s) return !1;
5019
+ const n = typeof t.text == "string" ? t.text : "";
5020
+ if (!n.length) return !1;
5021
+ s.setCoords();
5022
+ const o = s.getBoundingRect(!1, !0), i = (I = o.width) != null ? I : 0;
5023
+ if (!Number.isFinite(i) || i <= 0) return !1;
5024
+ const a = e != null ? e : (w = this.editingAnchorState) == null ? void 0 : w.get(t), r = (M = (T = a == null ? void 0 : a.originY) != null ? T : t.originY) != null ? M : "top", c = Math.abs((C = t.scaleX) != null ? C : 1) || 1, d = (E = t.paddingLeft) != null ? E : 0, l = (W = t.paddingRight) != null ? W : 0, u = (N = t.strokeWidth) != null ? N : 0, f = Math.max(
5025
+ 1,
5026
+ i / c - d - l - u
5027
+ );
5028
+ if (!Number.isFinite(f) || f <= 0) return !1;
5029
+ const g = n.split(`
5030
+ `).length;
5031
+ let p = !1;
5032
+ Math.abs(((x = t.width) != null ? x : 0) - f) > $ && (t.set({ width: f }), p = !0), t.initDimensions();
5033
+ const { textLines: m } = t, v = Array.isArray(m) && m.length > g, S = Math.ceil(
5034
+ k._getLongestLineWidth({ textbox: t, text: n })
5035
+ ), A = Math.min((Y = t.minWidth) != null ? Y : 1, f);
5036
+ let y = Math.min(
5037
+ f,
5038
+ Math.max(S, A)
5039
+ );
5040
+ v && (y = f), Math.abs(((G = t.width) != null ? G : 0) - y) > $ && (t.set({ width: y }), t.initDimensions(), p = !0), k._roundTextboxDimensions({ textbox: t }) && (p = !0), a && (t.setPositionByOrigin(new tt(a.x, a.y), "center", r), p = !0);
5041
+ const j = k._clampTextboxToMontage({
5042
+ textbox: t,
5043
+ montageLeft: (K = o.left) != null ? K : 0,
5044
+ montageRight: ((H = o.left) != null ? H : 0) + i
5045
+ });
5046
+ return p || j;
5047
+ }
5048
+ /**
5049
+ * Возвращает ширину самой длинной строки текстового объекта.
5050
+ */
5051
+ static _getLongestLineWidth({
5052
+ textbox: t,
5053
+ text: e
5054
+ }) {
5055
+ const { textLines: s } = t, n = Array.isArray(s) && s.length > 0 ? s.length : Math.max(e.split(`
5056
+ `).length, 1);
5057
+ let o = 0;
5058
+ for (let i = 0; i < n; i += 1) {
5059
+ const a = t.getLineWidth(i);
5060
+ a > o && (o = a);
5061
+ }
5062
+ return o;
5063
+ }
5064
+ /**
5065
+ * Сдвигает текстовый объект по X, чтобы он не выходил за пределы монтажной области.
5066
+ */
5067
+ static _clampTextboxToMontage({
5068
+ textbox: t,
5069
+ montageLeft: e,
5070
+ montageRight: s
5071
+ }) {
5072
+ var c, d, l, u;
5073
+ t.setCoords();
5074
+ const n = t.getBoundingRect(!1, !0), o = (c = n.left) != null ? c : 0, i = o + ((d = n.width) != null ? d : 0), a = s - e;
5075
+ if (a > 0 && ((l = n.width) != null ? l : 0) >= a - $)
5076
+ return !1;
5077
+ let r = 0;
5078
+ return o < e ? r = e - o : i > s && (r = s - i), Math.abs(r) <= $ ? !1 : (t.set({ left: ((u = t.left) != null ? u : 0) + r }), !0);
4927
5079
  }
4928
5080
  /**
4929
5081
  * Обрабатывает изменение ширины текстового объекта (resizing).
@@ -4934,7 +5086,7 @@ class P {
4934
5086
  static _handleObjectResizing(t) {
4935
5087
  var l, u, f, g, p, m;
4936
5088
  const { target: e, transform: s } = t;
4937
- if (!P._isTextbox(e)) return;
5089
+ if (!k._isTextbox(e)) return;
4938
5090
  const {
4939
5091
  paddingLeft: n = 0,
4940
5092
  paddingRight: o = 0
@@ -4945,13 +5097,19 @@ class P {
4945
5097
  e.set({ width: r });
4946
5098
  const c = (u = e.width) != null ? u : 0, d = a - c;
4947
5099
  if (d !== 0 && s && s.corner === "ml") {
4948
- const M = ((f = e.angle) != null ? f : 0) * Math.PI / 180, S = Math.cos(M), y = Math.sin(M), b = (g = e.scaleX) != null ? g : 1, I = d * b;
5100
+ const S = ((f = e.angle) != null ? f : 0) * Math.PI / 180, A = Math.cos(S), y = Math.sin(S), b = (g = e.scaleX) != null ? g : 1, j = d * b;
4949
5101
  e.set({
4950
- left: ((p = e.left) != null ? p : 0) + I * S,
4951
- top: ((m = e.top) != null ? m : 0) + I * y
5102
+ left: ((p = e.left) != null ? p : 0) + j * A,
5103
+ top: ((m = e.top) != null ? m : 0) + j * y
4952
5104
  });
4953
5105
  }
4954
5106
  }
5107
+ /**
5108
+ * Возвращает хранилище якорей редактирования, создавая его при необходимости.
5109
+ */
5110
+ _ensureEditingAnchorState() {
5111
+ return this.editingAnchorState || (this.editingAnchorState = /* @__PURE__ */ new WeakMap()), this.editingAnchorState;
5112
+ }
4955
5113
  /**
4956
5114
  * Возвращает диапазоны символов для каждой строки текста без учёта символов переноса.
4957
5115
  */
@@ -4974,7 +5132,7 @@ class P {
4974
5132
  textbox: t,
4975
5133
  range: e
4976
5134
  }) {
4977
- const s = P._getLineRanges({ textbox: t });
5135
+ const s = k._getLineRanges({ textbox: t });
4978
5136
  if (!s.length) return e;
4979
5137
  let { start: n } = e, { end: o } = e;
4980
5138
  return s.forEach(({ start: i, end: a }) => {
@@ -5059,10 +5217,10 @@ class P {
5059
5217
  static _roundTextboxDimensions({
5060
5218
  textbox: t
5061
5219
  }) {
5062
- const { width: e, height: s, calcTextWidth: n, calcTextHeight: o } = t, i = typeof n == "function" ? n.call(t) : void 0, a = typeof o == "function" ? o.call(t) : void 0, r = P._resolveDimension({
5220
+ const { width: e, height: s, calcTextWidth: n, calcTextHeight: o } = t, i = typeof n == "function" ? n.call(t) : void 0, a = typeof o == "function" ? o.call(t) : void 0, r = k._resolveDimension({
5063
5221
  rawValue: e,
5064
5222
  calculatedValue: i
5065
- }), c = P._resolveDimension({
5223
+ }), c = k._resolveDimension({
5066
5224
  rawValue: s,
5067
5225
  calculatedValue: a
5068
5226
  }), d = Number.isFinite(r) ? Math.round(r) : null, l = Number.isFinite(c) ? Math.round(c) : null, u = {};
@@ -5073,11 +5231,11 @@ class P {
5073
5231
  */
5074
5232
  static _getSnapshot(t) {
5075
5233
  const e = ({
5076
- snapshot: G,
5077
- entries: Y
5234
+ snapshot: R,
5235
+ entries: O
5078
5236
  }) => {
5079
- Object.entries(Y).forEach(([X, et]) => {
5080
- et != null && (G[X] = et);
5237
+ Object.entries(O).forEach(([it, Z]) => {
5238
+ Z != null && (R[it] = Z);
5081
5239
  });
5082
5240
  }, {
5083
5241
  id: s,
@@ -5095,30 +5253,30 @@ class P {
5095
5253
  stroke: p,
5096
5254
  strokeWidth: m,
5097
5255
  opacity: v,
5098
- backgroundColor: M,
5099
- backgroundOpacity: S,
5256
+ backgroundColor: S,
5257
+ backgroundOpacity: A,
5100
5258
  paddingTop: y,
5101
5259
  paddingRight: b,
5102
- paddingBottom: I,
5103
- paddingLeft: j,
5104
- radiusTopLeft: A,
5105
- radiusTopRight: C,
5106
- radiusBottomRight: w,
5107
- radiusBottomLeft: T,
5260
+ paddingBottom: j,
5261
+ paddingLeft: I,
5262
+ radiusTopLeft: w,
5263
+ radiusTopRight: T,
5264
+ radiusBottomRight: M,
5265
+ radiusBottomLeft: C,
5108
5266
  left: E,
5109
- top: F,
5110
- width: x,
5111
- height: N,
5112
- angle: Z,
5113
- scaleX: D,
5114
- scaleY: _
5115
- } = t, W = {
5267
+ top: W,
5268
+ width: N,
5269
+ height: x,
5270
+ angle: Y,
5271
+ scaleX: G,
5272
+ scaleY: K
5273
+ } = t, H = {
5116
5274
  id: s,
5117
5275
  uppercase: !!i,
5118
5276
  textAlign: f
5119
5277
  };
5120
5278
  return e({
5121
- snapshot: W,
5279
+ snapshot: H,
5122
5280
  entries: {
5123
5281
  text: n,
5124
5282
  textCaseRaw: o,
@@ -5132,25 +5290,25 @@ class P {
5132
5290
  stroke: p,
5133
5291
  strokeWidth: m,
5134
5292
  opacity: v,
5135
- backgroundColor: M,
5136
- backgroundOpacity: S,
5293
+ backgroundColor: S,
5294
+ backgroundOpacity: A,
5137
5295
  paddingTop: y,
5138
5296
  paddingRight: b,
5139
- paddingBottom: I,
5140
- paddingLeft: j,
5141
- radiusTopLeft: A,
5142
- radiusTopRight: C,
5143
- radiusBottomRight: w,
5144
- radiusBottomLeft: T,
5297
+ paddingBottom: j,
5298
+ paddingLeft: I,
5299
+ radiusTopLeft: w,
5300
+ radiusTopRight: T,
5301
+ radiusBottomRight: M,
5302
+ radiusBottomLeft: C,
5145
5303
  left: E,
5146
- top: F,
5147
- width: x,
5148
- height: N,
5149
- angle: Z,
5150
- scaleX: D,
5151
- scaleY: _
5304
+ top: W,
5305
+ width: N,
5306
+ height: x,
5307
+ angle: Y,
5308
+ scaleX: G,
5309
+ scaleY: K
5152
5310
  }
5153
- }), W;
5311
+ }), H;
5154
5312
  }
5155
5313
  /**
5156
5314
  * Возвращает первый доступный шрифт или дефолтный Arial.
@@ -5163,7 +5321,7 @@ class P {
5163
5321
  const Q = ({
5164
5322
  value: h,
5165
5323
  fallback: t = 0
5166
- }) => typeof h == "number" && Number.isFinite(h) ? h : typeof t == "number" && Number.isFinite(t) ? t : 0, Qt = ({
5324
+ }) => typeof h == "number" && Number.isFinite(h) ? h : typeof t == "number" && Number.isFinite(t) ? t : 0, ae = ({
5167
5325
  value: h,
5168
5326
  dimension: t,
5169
5327
  useRelativePositions: e
@@ -5180,22 +5338,22 @@ const Q = ({
5180
5338
  const o = h;
5181
5339
  if (typeof o[n.x] == "number" && typeof o[n.y] == "number")
5182
5340
  return {
5183
- x: Qt({
5341
+ x: ae({
5184
5342
  value: o[n.x],
5185
5343
  dimension: t,
5186
5344
  useRelativePositions: s
5187
5345
  }),
5188
- y: Qt({
5346
+ y: ae({
5189
5347
  value: o[n.y],
5190
5348
  dimension: e,
5191
5349
  useRelativePositions: s
5192
5350
  })
5193
5351
  };
5194
- const { left: a, top: r, width: c, height: d } = h, l = Qt({
5352
+ const { left: a, top: r, width: c, height: d } = h, l = ae({
5195
5353
  value: a,
5196
5354
  dimension: t,
5197
5355
  useRelativePositions: s
5198
- }), u = Qt({
5356
+ }), u = ae({
5199
5357
  value: r,
5200
5358
  dimension: e,
5201
5359
  useRelativePositions: s
@@ -5233,7 +5391,7 @@ const Q = ({
5233
5391
  } catch (s) {
5234
5392
  return null;
5235
5393
  }
5236
- }, pt = ({
5394
+ }, mt = ({
5237
5395
  object: h
5238
5396
  }) => {
5239
5397
  if (!h) return null;
@@ -5297,8 +5455,8 @@ const Q = ({
5297
5455
  };
5298
5456
  }
5299
5457
  return null;
5300
- }, Pt = "_templateCenterX", ce = "_templateCenterY", qt = "_templateAnchorX", de = "_templateAnchorY";
5301
- class R {
5458
+ }, Vt = "_templateCenterX", me = "_templateCenterY", re = "_templateAnchorX", ye = "_templateAnchorY";
5459
+ class _ {
5302
5460
  constructor({ editor: t }) {
5303
5461
  this.editor = t;
5304
5462
  }
@@ -5317,21 +5475,21 @@ class R {
5317
5475
  montageArea: i,
5318
5476
  errorManager: a,
5319
5477
  backgroundManager: r
5320
- } = this.editor, c = o.getActiveObject(), d = R._collectObjects(c), { backgroundObject: l } = r != null ? r : {}, u = n && l ? [l] : [], f = [...d, ...u];
5478
+ } = this.editor, c = o.getActiveObject(), d = _._collectObjects(c), { backgroundObject: l } = r != null ? r : {}, u = n && l ? [l] : [], f = [...d, ...u];
5321
5479
  if (!f.length)
5322
5480
  return a.emitWarning({
5323
5481
  origin: "TemplateManager",
5324
5482
  method: "serializeSelection",
5325
- code: wt.TEMPLATE_MANAGER.NO_OBJECTS_SELECTED,
5483
+ code: St.TEMPLATE_MANAGER.NO_OBJECTS_SELECTED,
5326
5484
  message: "Нет объектов для сериализации шаблона"
5327
5485
  }), null;
5328
- const g = R._getBounds(i), p = R._getMontageSize({ montageArea: i, bounds: g }), m = p.width, v = p.height, M = f.map((b) => R._serializeObject({
5486
+ const g = _._getBounds(i), p = _._getMontageSize({ montageArea: i, bounds: g }), m = p.width, v = p.height, S = f.map((b) => _._serializeObject({
5329
5487
  object: b,
5330
5488
  bounds: g,
5331
5489
  baseWidth: m,
5332
5490
  baseHeight: v,
5333
5491
  montageArea: i != null ? i : null
5334
- })), S = bt(B({}, s), {
5492
+ })), A = wt(B({}, s), {
5335
5493
  baseWidth: m,
5336
5494
  baseHeight: v,
5337
5495
  positionsNormalized: !0,
@@ -5339,8 +5497,8 @@ class R {
5339
5497
  });
5340
5498
  return {
5341
5499
  id: t != null ? t : `template-${V()}`,
5342
- meta: S,
5343
- objects: M
5500
+ meta: A,
5501
+ objects: S
5344
5502
  };
5345
5503
  }
5346
5504
  /**
@@ -5350,7 +5508,7 @@ class R {
5350
5508
  * @param options.data - данные для заполнения текстов по customData.templateField
5351
5509
  */
5352
5510
  applyTemplate(s) {
5353
- return k(this, arguments, function* ({
5511
+ return z(this, arguments, function* ({
5354
5512
  template: t,
5355
5513
  data: e
5356
5514
  }) {
@@ -5365,40 +5523,40 @@ class R {
5365
5523
  return a.emitWarning({
5366
5524
  origin: "TemplateManager",
5367
5525
  method: "applyTemplate",
5368
- code: wt.TEMPLATE_MANAGER.INVALID_TEMPLATE,
5526
+ code: St.TEMPLATE_MANAGER.INVALID_TEMPLATE,
5369
5527
  message: "Шаблон не содержит объектов"
5370
5528
  }), null;
5371
- const u = R._getBounds(o);
5529
+ const u = _._getBounds(o);
5372
5530
  if (!u)
5373
5531
  return a.emitWarning({
5374
5532
  origin: "TemplateManager",
5375
5533
  method: "applyTemplate",
5376
- code: wt.TEMPLATE_MANAGER.INVALID_TARGET,
5534
+ code: St.TEMPLATE_MANAGER.INVALID_TARGET,
5377
5535
  message: "Не удалось определить границы монтажной области"
5378
5536
  }), null;
5379
- const f = R._getMontageSize({ montageArea: o, bounds: u }), g = R._normalizeMeta({ meta: d, fallback: f }), p = R._calculateScale({ meta: g, target: f }), m = !!g.positionsNormalized;
5380
- let v = !1, M = !1;
5537
+ const f = _._getMontageSize({ montageArea: o, bounds: u }), g = _._normalizeMeta({ meta: d, fallback: f }), p = _._calculateScale({ meta: g, target: f }), m = !!g.positionsNormalized;
5538
+ let v = !1, S = !1;
5381
5539
  i.suspendHistory();
5382
5540
  try {
5383
- const S = yield R._enlivenObjects(c);
5384
- if (!S.length)
5541
+ const A = yield _._enlivenObjects(c);
5542
+ if (!A.length)
5385
5543
  return a.emitWarning({
5386
5544
  origin: "TemplateManager",
5387
5545
  method: "applyTemplate",
5388
- code: wt.TEMPLATE_MANAGER.INVALID_TEMPLATE,
5546
+ code: St.TEMPLATE_MANAGER.INVALID_TEMPLATE,
5389
5547
  message: "Не удалось создать объекты шаблона"
5390
5548
  }), null;
5391
- const { backgroundObject: y, contentObjects: b } = R._extractBackgroundObject(S);
5392
- y && (M = yield R._applyBackgroundFromObject({
5549
+ const { backgroundObject: y, contentObjects: b } = _._extractBackgroundObject(A);
5550
+ y && (S = yield _._applyBackgroundFromObject({
5393
5551
  backgroundObject: y,
5394
5552
  backgroundManager: r,
5395
5553
  errorManager: a
5396
5554
  }));
5397
- const I = b.map((j) => (this._adaptTextboxWidth({
5398
- object: j,
5555
+ const j = b.map((I) => (this._adaptTextboxWidth({
5556
+ object: I,
5399
5557
  baseWidth: g.baseWidth
5400
- }), R._transformObject({
5401
- object: j,
5558
+ }), _._transformObject({
5559
+ object: I,
5402
5560
  scale: p,
5403
5561
  bounds: u,
5404
5562
  targetSize: f,
@@ -5406,24 +5564,24 @@ class R {
5406
5564
  baseHeight: g.baseHeight,
5407
5565
  montageArea: o,
5408
5566
  useRelativePositions: m
5409
- }), j.set({
5410
- id: `${j.type}-${V()}`,
5567
+ }), I.set({
5568
+ id: `${I.type}-${V()}`,
5411
5569
  evented: !0
5412
- }), n.add(j), j));
5413
- return !I.length && !M ? null : (v = I.length > 0 || M, I.length && R._activateObjects({ canvas: n, objects: I }), n.requestRenderAll(), n.fire("editor:template-applied", {
5570
+ }), n.add(I), I));
5571
+ return !j.length && !S ? null : (v = j.length > 0 || S, j.length && _._activateObjects({ canvas: n, objects: j }), n.requestRenderAll(), n.fire("editor:template-applied", {
5414
5572
  template: t,
5415
- objects: I,
5573
+ objects: j,
5416
5574
  bounds: u
5417
- }), I);
5418
- } catch (S) {
5575
+ }), j);
5576
+ } catch (A) {
5419
5577
  return a.emitError({
5420
5578
  origin: "TemplateManager",
5421
5579
  method: "applyTemplate",
5422
- code: wt.TEMPLATE_MANAGER.APPLY_FAILED,
5580
+ code: St.TEMPLATE_MANAGER.APPLY_FAILED,
5423
5581
  message: "Ошибка применения шаблона",
5424
5582
  data: {
5425
5583
  templateId: l,
5426
- error: S
5584
+ error: A
5427
5585
  }
5428
5586
  }), null;
5429
5587
  } finally {
@@ -5459,15 +5617,15 @@ class R {
5459
5617
  * Превращает plain-описание объектов в Fabric объекты.
5460
5618
  */
5461
5619
  static _enlivenObjects(t) {
5462
- return k(this, null, function* () {
5463
- return (yield Promise.all(t.map((s) => k(null, null, function* () {
5464
- if (R._hasSerializedSvgMarkup(s)) {
5465
- const i = yield R._reviveSvgObject(s);
5620
+ return z(this, null, function* () {
5621
+ return (yield Promise.all(t.map((s) => z(null, null, function* () {
5622
+ if (_._hasSerializedSvgMarkup(s)) {
5623
+ const i = yield _._reviveSvgObject(s);
5466
5624
  if (i)
5467
- return R._restoreImageScale({ revived: i, serialized: s }), i;
5625
+ return _._restoreImageScale({ revived: i, serialized: s }), i;
5468
5626
  }
5469
- const n = yield lt.enlivenObjects([s]), o = n == null ? void 0 : n[0];
5470
- return o ? (R._restoreImageScale({ revived: o, serialized: s }), o) : null;
5627
+ const n = yield ut.enlivenObjects([s]), o = n == null ? void 0 : n[0];
5628
+ return o ? (_._restoreImageScale({ revived: o, serialized: s }), o) : null;
5471
5629
  })))).filter((s) => !!s);
5472
5630
  });
5473
5631
  }
@@ -5495,22 +5653,22 @@ class R {
5495
5653
  naturalHeight: 0,
5496
5654
  width: 0,
5497
5655
  height: 0
5498
- }, p = Q({ value: l || f || c.width, fallback: 0 }), m = Q({ value: u || g || c.height, fallback: 0 }), v = Q({ value: n, fallback: p }), M = Q({ value: o, fallback: m }), S = Q({ value: i, fallback: c.scaleX || 1 }), y = Q({ value: a, fallback: c.scaleY || 1 }), b = v * S, I = M * y, j = p > 0, A = m > 0, C = b > 0, w = I > 0, T = R._resolveImageFit({ customData: r }), E = {};
5499
- if (j && (E.width = p), A && (E.height = m), !j || !A) {
5656
+ }, p = Q({ value: l || f || c.width, fallback: 0 }), m = Q({ value: u || g || c.height, fallback: 0 }), v = Q({ value: n, fallback: p }), S = Q({ value: o, fallback: m }), A = Q({ value: i, fallback: c.scaleX || 1 }), y = Q({ value: a, fallback: c.scaleY || 1 }), b = v * A, j = S * y, I = p > 0, w = m > 0, T = b > 0, M = j > 0, C = _._resolveImageFit({ customData: r }), E = {};
5657
+ if (I && (E.width = p), w && (E.height = m), !I || !w) {
5500
5658
  c.set(E);
5501
5659
  return;
5502
5660
  }
5503
- if (T === "stretch") {
5504
- const x = C ? b / p : null, N = w ? I / m : null;
5505
- x && x > 0 && (E.scaleX = x), N && N > 0 && (E.scaleY = N), c.set(E);
5661
+ if (C === "stretch") {
5662
+ const N = T ? b / p : null, x = M ? j / m : null;
5663
+ N && N > 0 && (E.scaleX = N), x && x > 0 && (E.scaleY = x), c.set(E);
5506
5664
  return;
5507
5665
  }
5508
- if (!C || !w) {
5666
+ if (!T || !M) {
5509
5667
  c.set(E);
5510
5668
  return;
5511
5669
  }
5512
- const F = Math.min(b / p, I / m);
5513
- Number.isFinite(F) && F > 0 && (E.scaleX = F, E.scaleY = F), c.set(E);
5670
+ const W = Math.min(b / p, j / m);
5671
+ Number.isFinite(W) && W > 0 && (E.scaleX = W, E.scaleY = W), c.set(E);
5514
5672
  }
5515
5673
  /**
5516
5674
  * Определяет режим вписывания изображения при восстановлении.
@@ -5532,12 +5690,12 @@ class R {
5532
5690
  * Восстанавливает SVG-объект из компактного описания.
5533
5691
  */
5534
5692
  static _reviveSvgObject(t) {
5535
- return k(this, null, function* () {
5693
+ return z(this, null, function* () {
5536
5694
  const e = typeof t.svgMarkup == "string" ? t.svgMarkup : null;
5537
5695
  if (!e) return null;
5538
5696
  try {
5539
- const s = yield ms(e), n = lt.groupSVGElements(s.objects, s.options), o = yield lt.enlivenObjectEnlivables(
5540
- R._prepareSerializableProps(t)
5697
+ const s = yield ys(e), n = ut.groupSVGElements(s.objects, s.options), o = yield ut.enlivenObjectEnlivables(
5698
+ _._prepareSerializableProps(t)
5541
5699
  );
5542
5700
  return n.set(o), n.setCoords(), n;
5543
5701
  } catch (s) {
@@ -5601,28 +5759,28 @@ class R {
5601
5759
  baseHeight: i,
5602
5760
  useRelativePositions: r,
5603
5761
  centerKeys: {
5604
- x: Pt,
5605
- y: ce
5762
+ x: Vt,
5763
+ y: me
5606
5764
  }
5607
- }), { scaleX: u, scaleY: f } = t, g = Q({ value: u, fallback: 1 }), p = Q({ value: f, fallback: 1 }), m = R._getPositioningBounds({
5765
+ }), { scaleX: u, scaleY: f } = t, g = Q({ value: u, fallback: 1 }), p = Q({ value: f, fallback: 1 }), m = _._getPositioningBounds({
5608
5766
  bounds: s,
5609
5767
  baseWidth: o,
5610
5768
  baseHeight: i,
5611
5769
  scale: e,
5612
5770
  useRelativePositions: r,
5613
- anchorX: R._resolveAnchor(c, qt),
5614
- anchorY: R._resolveAnchor(c, de)
5771
+ anchorX: _._resolveAnchor(c, re),
5772
+ anchorY: _._resolveAnchor(c, ye)
5615
5773
  }), v = hn({
5616
5774
  normalizedX: d,
5617
5775
  normalizedY: l,
5618
5776
  bounds: m,
5619
5777
  targetSize: n,
5620
5778
  montageArea: a
5621
- }), M = g * e, S = p * e;
5779
+ }), S = g * e, A = p * e;
5622
5780
  t.set({
5623
- scaleX: M,
5624
- scaleY: S
5625
- }), t.setPositionByOrigin(v, "center", "center"), t.setCoords(), delete c[Pt], delete c[ce], delete c[qt], delete c[de];
5781
+ scaleX: S,
5782
+ scaleY: A
5783
+ }), t.setPositionByOrigin(v, "center", "center"), t.setCoords(), delete c[Vt], delete c[me], delete c[re], delete c[ye];
5626
5784
  }
5627
5785
  /**
5628
5786
  * Возвращает bounds, в которых должны позиционироваться нормализованные объекты.
@@ -5638,7 +5796,7 @@ class R {
5638
5796
  anchorY: a
5639
5797
  }) {
5640
5798
  if (!o) return t;
5641
- const r = (e || t.width) * n, c = (s || t.height) * n, d = t.width - r, l = t.height - c, u = t.left + R._calculateAnchorOffset(i, d), f = t.top + R._calculateAnchorOffset(a, l);
5799
+ const r = (e || t.width) * n, c = (s || t.height) * n, d = t.width - r, l = t.height - c, u = t.left + _._calculateAnchorOffset(i, d), f = t.top + _._calculateAnchorOffset(a, l);
5642
5800
  return {
5643
5801
  left: u,
5644
5802
  top: f,
@@ -5669,7 +5827,7 @@ class R {
5669
5827
  meta: t,
5670
5828
  fallback: e
5671
5829
  }) {
5672
- const { width: s, height: n } = e, r = t || {}, { baseWidth: o = s, baseHeight: i = n } = r, a = Mt(r, ["baseWidth", "baseHeight"]);
5830
+ const { width: s, height: n } = e, r = t || {}, { baseWidth: o = s, baseHeight: i = n } = r, a = gt(r, ["baseWidth", "baseHeight"]);
5673
5831
  return B({
5674
5832
  baseWidth: o,
5675
5833
  baseHeight: i
@@ -5707,30 +5865,30 @@ class R {
5707
5865
  object: t,
5708
5866
  baseWidth: e
5709
5867
  }) {
5710
- var Z, D;
5711
- if (!(t instanceof st)) return;
5868
+ var Y, G;
5869
+ if (!(t instanceof ot)) return;
5712
5870
  const s = typeof t.text == "string" ? t.text : "";
5713
5871
  if (!s) return;
5714
5872
  const n = Q({
5715
- value: (D = (Z = this.editor) == null ? void 0 : Z.montageArea) == null ? void 0 : D.width,
5873
+ value: (G = (Y = this.editor) == null ? void 0 : Y.montageArea) == null ? void 0 : G.width,
5716
5874
  fallback: 0
5717
5875
  }), {
5718
5876
  width: o = 0,
5719
5877
  scaleX: i = 1,
5720
5878
  strokeWidth: a = 0
5721
- } = t, r = Q({ value: e, fallback: 0 }), c = t, d = Q({ value: c.paddingLeft, fallback: 0 }), l = Q({ value: c.paddingRight, fallback: 0 }), u = Q({ value: i, fallback: 1 }), f = Q({ value: a, fallback: 0 }) * u, g = Q({ value: o, fallback: 0 }), p = g * u, m = d * u, v = l * u, M = p + m + v + f;
5879
+ } = t, r = Q({ value: e, fallback: 0 }), c = t, d = Q({ value: c.paddingLeft, fallback: 0 }), l = Q({ value: c.paddingRight, fallback: 0 }), u = Q({ value: i, fallback: 1 }), f = Q({ value: a, fallback: 0 }) * u, g = Q({ value: o, fallback: 0 }), p = g * u, m = d * u, v = l * u, S = p + m + v + f;
5722
5880
  if (!n || !g || !r) return;
5723
5881
  t.setCoords();
5724
- const S = t, y = S[Pt], b = typeof y == "number" ? y : null, I = R._resolveAnchor(S, qt), j = M / r, A = b !== null ? b - j / 2 : null, C = b !== null ? b + j / 2 : null, w = t.getCenterPoint();
5882
+ const A = t, y = A[Vt], b = typeof y == "number" ? y : null, j = _._resolveAnchor(A, re), I = S / r, w = b !== null ? b - I / 2 : null, T = b !== null ? b + I / 2 : null, M = t.getCenterPoint();
5725
5883
  t.set("width", n), t.initDimensions();
5726
- const T = R._getLongestLineWidth({
5884
+ const C = _._getLongestLineWidth({
5727
5885
  textbox: t,
5728
5886
  text: s
5729
- }), E = T > g ? T + 1 : g;
5730
- t.set("width", E), t.initDimensions(), t.setPositionByOrigin(w, "center", "center"), t.setCoords();
5731
- const x = (E * u + m + v + f) / r;
5732
- let N = b;
5733
- I === "start" && A !== null ? N = Math.max(0, A) + x / 2 : I === "end" && C !== null && (N = Math.min(1, C) - x / 2), typeof N == "number" && (S[Pt] = N);
5887
+ }), E = C > g ? C + 1 : g;
5888
+ t.set("width", E), t.initDimensions(), t.setPositionByOrigin(M, "center", "center"), t.setCoords();
5889
+ const N = (E * u + m + v + f) / r;
5890
+ let x = b;
5891
+ j === "start" && w !== null ? x = Math.max(0, w) + N / 2 : j === "end" && T !== null && (x = Math.min(1, T) - N / 2), typeof x == "number" && (A[Vt] = x);
5734
5892
  }
5735
5893
  /**
5736
5894
  * Возвращает ширину самой длинной строки текстового объекта.
@@ -5760,9 +5918,9 @@ class R {
5760
5918
  baseHeight: n,
5761
5919
  montageArea: o
5762
5920
  }) {
5763
- const i = t.toDatalessObject([...es]);
5764
- if (R._isSvgObject(t)) {
5765
- const y = R._extractSvgMarkup(t);
5921
+ const i = t.toDatalessObject([...ns]);
5922
+ if (_._isSvgObject(t)) {
5923
+ const y = _._extractSvgMarkup(t);
5766
5924
  y && (i.svgMarkup = y, delete i.objects, delete i.path);
5767
5925
  }
5768
5926
  if (!e) return i;
@@ -5781,15 +5939,15 @@ class R {
5781
5939
  x: (y.x - a) / u,
5782
5940
  y: (y.y - r) / f
5783
5941
  };
5784
- })(), m = (l.left - a) / u, v = (l.top - r) / f, M = m + l.width / u, S = v + l.height / f;
5785
- return i[Pt] = p.x, i[ce] = p.y, i[qt] = R._detectAnchor({
5942
+ })(), m = (l.left - a) / u, v = (l.top - r) / f, S = m + l.width / u, A = v + l.height / f;
5943
+ return i[Vt] = p.x, i[me] = p.y, i[re] = _._detectAnchor({
5786
5944
  center: p.x,
5787
5945
  start: m,
5788
- end: M
5789
- }), i[de] = R._detectAnchor({
5946
+ end: S
5947
+ }), i[ye] = _._detectAnchor({
5790
5948
  center: p.y,
5791
5949
  start: v,
5792
- end: S
5950
+ end: A
5793
5951
  }), i.left = m, i.top = v, i;
5794
5952
  }
5795
5953
  /**
@@ -5806,13 +5964,13 @@ class R {
5806
5964
  * Применяет фоновый объект шаблона к текущему холсту через BackgroundManager.
5807
5965
  */
5808
5966
  static _applyBackgroundFromObject(n) {
5809
- return k(this, arguments, function* ({
5967
+ return z(this, arguments, function* ({
5810
5968
  backgroundObject: t,
5811
5969
  backgroundManager: e,
5812
5970
  errorManager: s
5813
5971
  }) {
5814
5972
  try {
5815
- const { fill: o, customData: i } = t, { backgroundType: a } = t, r = R._cloneCustomData(i);
5973
+ const { fill: o, customData: i } = t, { backgroundType: a } = t, r = _._cloneCustomData(i);
5816
5974
  if (a === "color" && typeof o == "string")
5817
5975
  return e.setColorBackground({
5818
5976
  color: o,
@@ -5831,7 +5989,7 @@ class R {
5831
5989
  }), !0;
5832
5990
  }
5833
5991
  if (a === "image") {
5834
- const c = R._getImageSource(t);
5992
+ const c = _._getImageSource(t);
5835
5993
  if (c)
5836
5994
  return yield e.setImageBackground({
5837
5995
  imageSource: c,
@@ -5844,7 +6002,7 @@ class R {
5844
6002
  s.emitWarning({
5845
6003
  origin: "TemplateManager",
5846
6004
  method: "applyTemplate",
5847
- code: wt.TEMPLATE_MANAGER.APPLY_FAILED,
6005
+ code: St.TEMPLATE_MANAGER.APPLY_FAILED,
5848
6006
  message: "Не удалось применить фон из шаблона",
5849
6007
  data: o
5850
6008
  });
@@ -5900,10 +6058,10 @@ class R {
5900
6058
  */
5901
6059
  // eslint-disable-next-line class-methods-use-this
5902
6060
  enlivenObjectEnlivables(t) {
5903
- return lt.enlivenObjectEnlivables(t);
6061
+ return ut.enlivenObjectEnlivables(t);
5904
6062
  }
5905
6063
  }
5906
- const pn = 5, ss = "#3D8BF4", pe = 1, Jt = 1, Ke = ({
6064
+ const pn = 5, os = "#3D8BF4", Ae = 1, ce = 1, Je = ({
5907
6065
  anchors: h,
5908
6066
  positions: t,
5909
6067
  threshold: e
@@ -5923,11 +6081,11 @@ const pn = 5, ss = "#3D8BF4", pe = 1, Jt = 1, Ke = ({
5923
6081
  threshold: t,
5924
6082
  anchors: e
5925
6083
  }) => {
5926
- const { left: s, right: n, centerX: o, top: i, bottom: a, centerY: r } = h, c = Ke({
6084
+ const { left: s, right: n, centerX: o, top: i, bottom: a, centerY: r } = h, c = Je({
5927
6085
  anchors: e.vertical,
5928
6086
  positions: [s, o, n],
5929
6087
  threshold: t
5930
- }), d = Ke({
6088
+ }), d = Je({
5931
6089
  anchors: e.horizontal,
5932
6090
  positions: [i, r, a],
5933
6091
  threshold: t
@@ -5943,7 +6101,7 @@ const pn = 5, ss = "#3D8BF4", pe = 1, Jt = 1, Ke = ({
5943
6101
  deltaY: d.delta,
5944
6102
  guides: l
5945
6103
  };
5946
- }, ns = ({
6104
+ }, is = ({
5947
6105
  activeBounds: h,
5948
6106
  aligned: t,
5949
6107
  threshold: e,
@@ -6040,66 +6198,66 @@ const pn = 5, ss = "#3D8BF4", pe = 1, Jt = 1, Ke = ({
6040
6198
  return { delta: 0, guide: null };
6041
6199
  const u = d[l - 1], f = d[l - 2], g = d[l + 1], p = d[l + 2], m = [], v = i - o;
6042
6200
  if (u && f) {
6043
- const { bounds: y } = u, { bounds: b } = f, I = y.top - b.bottom, j = o - y.bottom, A = Math.abs(j - I);
6044
- if (A <= e) {
6045
- const C = I - j, w = o + C, T = {
6201
+ const { bounds: y } = u, { bounds: b } = f, j = y.top - b.bottom, I = o - y.bottom, w = Math.abs(I - j);
6202
+ if (w <= e) {
6203
+ const T = j - I, M = o + T, C = {
6046
6204
  type: "vertical",
6047
6205
  axis: n,
6048
6206
  refStart: b.bottom,
6049
6207
  refEnd: y.top,
6050
6208
  activeStart: y.bottom,
6051
- activeEnd: w,
6052
- distance: I
6209
+ activeEnd: M,
6210
+ distance: j
6053
6211
  };
6054
- m.push({ delta: C, guide: T, diff: A });
6212
+ m.push({ delta: T, guide: C, diff: w });
6055
6213
  }
6056
6214
  }
6057
6215
  if (g && p) {
6058
- const { bounds: y } = g, { bounds: b } = p, I = b.top - y.bottom, j = y.top - i, A = Math.abs(j - I);
6059
- if (A <= e) {
6060
- const C = j - I, w = i + C, T = {
6216
+ const { bounds: y } = g, { bounds: b } = p, j = b.top - y.bottom, I = y.top - i, w = Math.abs(I - j);
6217
+ if (w <= e) {
6218
+ const T = I - j, M = i + T, C = {
6061
6219
  type: "vertical",
6062
6220
  axis: n,
6063
6221
  refStart: y.bottom,
6064
6222
  refEnd: b.top,
6065
- activeStart: w,
6223
+ activeStart: M,
6066
6224
  activeEnd: y.top,
6067
- distance: I
6225
+ distance: j
6068
6226
  };
6069
- m.push({ delta: C, guide: T, diff: A });
6227
+ m.push({ delta: T, guide: C, diff: w });
6070
6228
  }
6071
6229
  }
6072
6230
  if (u && g) {
6073
- const { bounds: y } = u, { bounds: b } = g, j = b.top - y.bottom - v;
6074
- if (j >= 0) {
6075
- const A = j / 2, C = o - y.bottom, w = b.top - i, T = Math.abs(C - A), E = Math.abs(w - A), F = Math.max(T, E);
6076
- if (F <= e) {
6077
- const x = A - C, N = i + x, Z = {
6231
+ const { bounds: y } = u, { bounds: b } = g, I = b.top - y.bottom - v;
6232
+ if (I >= 0) {
6233
+ const w = I / 2, T = o - y.bottom, M = b.top - i, C = Math.abs(T - w), E = Math.abs(M - w), W = Math.max(C, E);
6234
+ if (W <= e) {
6235
+ const N = w - T, x = i + N, Y = {
6078
6236
  type: "vertical",
6079
6237
  axis: n,
6080
6238
  refStart: y.bottom,
6081
- refEnd: y.bottom + A,
6082
- activeStart: N,
6083
- activeEnd: N + A,
6084
- distance: A
6239
+ refEnd: y.bottom + w,
6240
+ activeStart: x,
6241
+ activeEnd: x + w,
6242
+ distance: w
6085
6243
  };
6086
- m.push({ delta: x, guide: Z, diff: F });
6244
+ m.push({ delta: N, guide: Y, diff: W });
6087
6245
  }
6088
6246
  }
6089
6247
  }
6090
- const M = ns({
6248
+ const S = is({
6091
6249
  activeBounds: h,
6092
6250
  aligned: c,
6093
6251
  threshold: e,
6094
6252
  patterns: s,
6095
6253
  type: "vertical"
6096
6254
  });
6097
- if (m.push(...M), !m.length)
6255
+ if (m.push(...S), !m.length)
6098
6256
  return { delta: 0, guide: null };
6099
- const S = m.reduce((y, b) => b.diff < y.diff ? b : y, m[0]);
6257
+ const A = m.reduce((y, b) => b.diff < y.diff ? b : y, m[0]);
6100
6258
  return {
6101
- delta: S.delta,
6102
- guide: S.guide
6259
+ delta: A.delta,
6260
+ guide: A.guide
6103
6261
  };
6104
6262
  }, vn = ({
6105
6263
  activeBounds: h,
@@ -6126,66 +6284,66 @@ const pn = 5, ss = "#3D8BF4", pe = 1, Jt = 1, Ke = ({
6126
6284
  return { delta: 0, guide: null };
6127
6285
  const u = d[l - 1], f = d[l - 2], g = d[l + 1], p = d[l + 2], m = [], v = i - o;
6128
6286
  if (u && f) {
6129
- const { bounds: y } = u, { bounds: b } = f, I = y.left - b.right, j = o - y.right, A = Math.abs(j - I);
6130
- if (A <= e) {
6131
- const C = I - j, w = o + C, T = {
6287
+ const { bounds: y } = u, { bounds: b } = f, j = y.left - b.right, I = o - y.right, w = Math.abs(I - j);
6288
+ if (w <= e) {
6289
+ const T = j - I, M = o + T, C = {
6132
6290
  type: "horizontal",
6133
6291
  axis: n,
6134
6292
  refStart: b.right,
6135
6293
  refEnd: y.left,
6136
6294
  activeStart: y.right,
6137
- activeEnd: w,
6138
- distance: I
6295
+ activeEnd: M,
6296
+ distance: j
6139
6297
  };
6140
- m.push({ delta: C, guide: T, diff: A });
6298
+ m.push({ delta: T, guide: C, diff: w });
6141
6299
  }
6142
6300
  }
6143
6301
  if (g && p) {
6144
- const { bounds: y } = g, { bounds: b } = p, I = b.left - y.right, j = y.left - i, A = Math.abs(j - I);
6145
- if (A <= e) {
6146
- const C = j - I, w = i + C, T = {
6302
+ const { bounds: y } = g, { bounds: b } = p, j = b.left - y.right, I = y.left - i, w = Math.abs(I - j);
6303
+ if (w <= e) {
6304
+ const T = I - j, M = i + T, C = {
6147
6305
  type: "horizontal",
6148
6306
  axis: n,
6149
6307
  refStart: y.right,
6150
6308
  refEnd: b.left,
6151
- activeStart: w,
6309
+ activeStart: M,
6152
6310
  activeEnd: y.left,
6153
- distance: I
6311
+ distance: j
6154
6312
  };
6155
- m.push({ delta: C, guide: T, diff: A });
6313
+ m.push({ delta: T, guide: C, diff: w });
6156
6314
  }
6157
6315
  }
6158
6316
  if (u && g) {
6159
- const { bounds: y } = u, { bounds: b } = g, j = b.left - y.right - v;
6160
- if (j >= 0) {
6161
- const A = j / 2, C = o - y.right, w = b.left - i, T = Math.abs(C - A), E = Math.abs(w - A), F = Math.max(T, E);
6162
- if (F <= e) {
6163
- const x = A - C, N = i + x, Z = {
6317
+ const { bounds: y } = u, { bounds: b } = g, I = b.left - y.right - v;
6318
+ if (I >= 0) {
6319
+ const w = I / 2, T = o - y.right, M = b.left - i, C = Math.abs(T - w), E = Math.abs(M - w), W = Math.max(C, E);
6320
+ if (W <= e) {
6321
+ const N = w - T, x = i + N, Y = {
6164
6322
  type: "horizontal",
6165
6323
  axis: n,
6166
6324
  refStart: y.right,
6167
- refEnd: y.right + A,
6168
- activeStart: N,
6169
- activeEnd: N + A,
6170
- distance: A
6325
+ refEnd: y.right + w,
6326
+ activeStart: x,
6327
+ activeEnd: x + w,
6328
+ distance: w
6171
6329
  };
6172
- m.push({ delta: x, guide: Z, diff: F });
6330
+ m.push({ delta: N, guide: Y, diff: W });
6173
6331
  }
6174
6332
  }
6175
6333
  }
6176
- const M = ns({
6334
+ const S = is({
6177
6335
  activeBounds: h,
6178
6336
  aligned: c,
6179
6337
  threshold: e,
6180
6338
  patterns: s,
6181
6339
  type: "horizontal"
6182
6340
  });
6183
- if (m.push(...M), !m.length)
6341
+ if (m.push(...S), !m.length)
6184
6342
  return { delta: 0, guide: null };
6185
- const S = m.reduce((y, b) => b.diff < y.diff ? b : y, m[0]);
6343
+ const A = m.reduce((y, b) => b.diff < y.diff ? b : y, m[0]);
6186
6344
  return {
6187
- delta: S.delta,
6188
- guide: S.guide
6345
+ delta: A.delta,
6346
+ guide: A.guide
6189
6347
  };
6190
6348
  }, bn = ({
6191
6349
  activeBounds: h,
@@ -6219,7 +6377,7 @@ const pn = 5, ss = "#3D8BF4", pe = 1, Jt = 1, Ke = ({
6219
6377
  }) => {
6220
6378
  const i = Math.min(o, s / 2, n / 2);
6221
6379
  h.moveTo(t + i, e), h.lineTo(t + s - i, e), h.quadraticCurveTo(t + s, e, t + s, e + i), h.lineTo(t + s, e + n - i), h.quadraticCurveTo(t + s, e + n, t + s - i, e + n), h.lineTo(t + i, e + n), h.quadraticCurveTo(t, e + n, t, e + n - i), h.lineTo(t, e + i), h.quadraticCurveTo(t, e, t + i, e), h.closePath();
6222
- }, me = ({
6380
+ }, je = ({
6223
6381
  context: h,
6224
6382
  type: t,
6225
6383
  axis: e,
@@ -6236,16 +6394,16 @@ const pn = 5, ss = "#3D8BF4", pe = 1, Jt = 1, Ke = ({
6236
6394
  offsetAlongAxis: f = 0,
6237
6395
  offsetPerpendicular: g = 0
6238
6396
  }) => {
6239
- const p = i || 1, m = 12 / p, v = l / p, M = u / p, S = (s + n) / 2 + f, y = t === "vertical" ? e + g : S, b = t === "vertical" ? S : e + g;
6397
+ const p = i || 1, m = 12 / p, v = l / p, S = u / p, A = (s + n) / 2 + f, y = t === "vertical" ? e + g : A, b = t === "vertical" ? A : e + g;
6240
6398
  h.save(), h.setLineDash([]), h.fillStyle = a, h.strokeStyle = a, h.lineWidth = d / p, h.font = `${m}px ${c}`, h.textAlign = "center", h.textBaseline = "middle";
6241
- const j = h.measureText(o).width + v * 2, A = m + v * 2, C = y - j / 2, w = b - A / 2;
6399
+ const I = h.measureText(o).width + v * 2, w = m + v * 2, T = y - I / 2, M = b - w / 2;
6242
6400
  h.beginPath(), Mn({
6243
6401
  context: h,
6244
- x: C,
6245
- y: w,
6246
- width: j,
6247
- height: A,
6248
- radius: M
6402
+ x: T,
6403
+ y: M,
6404
+ width: I,
6405
+ height: w,
6406
+ radius: S
6249
6407
  }), h.fill(), h.fillStyle = r, h.fillText(o, y, b), h.restore();
6250
6408
  }, wn = ({
6251
6409
  context: h,
@@ -6262,8 +6420,8 @@ const pn = 5, ss = "#3D8BF4", pe = 1, Jt = 1, Ke = ({
6262
6420
  distance: c
6263
6421
  } = t, d = Math.round(c).toString();
6264
6422
  h.beginPath(), s === "vertical" ? (h.moveTo(n, o), h.lineTo(n, i), h.moveTo(n, a), h.lineTo(n, r)) : (h.moveTo(o, n), h.lineTo(i, n), h.moveTo(a, n), h.lineTo(r, n)), h.stroke();
6265
- const l = ss;
6266
- me({
6423
+ const l = os;
6424
+ je({
6267
6425
  context: h,
6268
6426
  type: s,
6269
6427
  axis: n,
@@ -6272,8 +6430,8 @@ const pn = 5, ss = "#3D8BF4", pe = 1, Jt = 1, Ke = ({
6272
6430
  text: d,
6273
6431
  zoom: e,
6274
6432
  color: l,
6275
- lineWidth: pe
6276
- }), me({
6433
+ lineWidth: Ae
6434
+ }), je({
6277
6435
  context: h,
6278
6436
  type: s,
6279
6437
  axis: n,
@@ -6282,9 +6440,9 @@ const pn = 5, ss = "#3D8BF4", pe = 1, Jt = 1, Ke = ({
6282
6440
  text: d,
6283
6441
  zoom: e,
6284
6442
  color: l,
6285
- lineWidth: pe
6443
+ lineWidth: Ae
6286
6444
  });
6287
- }, Qe = ({
6445
+ }, qe = ({
6288
6446
  anchors: h,
6289
6447
  bounds: t
6290
6448
  }) => {
@@ -6297,7 +6455,7 @@ const pn = 5, ss = "#3D8BF4", pe = 1, Jt = 1, Ke = ({
6297
6455
  centerY: a
6298
6456
  } = t;
6299
6457
  h.vertical.push(e, n, s), h.horizontal.push(o, a, i);
6300
- }, qe = ({
6458
+ }, $e = ({
6301
6459
  bounds: h,
6302
6460
  type: t,
6303
6461
  primaryStart: e,
@@ -6310,8 +6468,8 @@ const pn = 5, ss = "#3D8BF4", pe = 1, Jt = 1, Ke = ({
6310
6468
  for (let p = r + 1; p < a.length; p += 1) {
6311
6469
  const m = a[p];
6312
6470
  if (Math.min(c[i], m[i]) - Math.max(c[o], m[o]) < 0) continue;
6313
- const M = m[e] - c[s];
6314
- M < 0 || M < l && (l = M, d = m);
6471
+ const S = m[e] - c[s];
6472
+ S < 0 || S < l && (l = S, d = m);
6315
6473
  }
6316
6474
  if (!d || l === Number.POSITIVE_INFINITY) continue;
6317
6475
  const u = Math.max(c[o], d[o]), f = Math.min(c[i], d[i]), g = (u + f) / 2;
@@ -6327,24 +6485,24 @@ const pn = 5, ss = "#3D8BF4", pe = 1, Jt = 1, Ke = ({
6327
6485
  }, Sn = ({
6328
6486
  bounds: h
6329
6487
  }) => {
6330
- const t = qe({
6488
+ const t = $e({
6331
6489
  bounds: h,
6332
6490
  type: "vertical",
6333
6491
  primaryStart: "top",
6334
6492
  primaryEnd: "bottom"
6335
- }), e = qe({
6493
+ }), e = $e({
6336
6494
  bounds: h,
6337
6495
  type: "horizontal",
6338
6496
  primaryStart: "left",
6339
6497
  primaryEnd: "right"
6340
6498
  });
6341
6499
  return { vertical: t, horizontal: e };
6342
- }, An = ["montage-area", "background", "interaction-blocker"], os = ({
6500
+ }, An = ["montage-area", "background", "interaction-blocker"], as = ({
6343
6501
  activeObject: h
6344
6502
  }) => {
6345
6503
  const t = /* @__PURE__ */ new Set();
6346
6504
  return h && (t.add(h), h instanceof U && h.getObjects().forEach((e) => t.add(e))), t;
6347
- }, is = ({
6505
+ }, rs = ({
6348
6506
  object: h,
6349
6507
  excluded: t,
6350
6508
  ignoredIds: e = An
@@ -6413,7 +6571,7 @@ class jn {
6413
6571
  return;
6414
6572
  }
6415
6573
  !this.anchors.vertical.length && !this.anchors.horizontal.length && this._cacheAnchors({ activeObject: e });
6416
- let o = pt({ object: e });
6574
+ let o = mt({ object: e });
6417
6575
  if (!o) {
6418
6576
  this._clearGuides();
6419
6577
  return;
@@ -6424,24 +6582,24 @@ class jn {
6424
6582
  anchors: this.anchors
6425
6583
  }), { deltaX: d, deltaY: l, guides: u } = c;
6426
6584
  if (d !== 0 || l !== 0) {
6427
- const { left: v = 0, top: M = 0 } = e;
6585
+ const { left: v = 0, top: S = 0 } = e;
6428
6586
  e.set({
6429
6587
  left: v + d,
6430
- top: M + l
6431
- }), e.setCoords(), o = (p = pt({ object: e })) != null ? p : o;
6588
+ top: S + l
6589
+ }), e.setCoords(), o = (p = mt({ object: e })) != null ? p : o;
6432
6590
  }
6433
- const f = this.cachedTargetBounds.length ? this.cachedTargetBounds : this._collectTargets({ activeObject: e }).map((v) => pt({ object: v })).filter((v) => !!v), g = bn({
6591
+ const f = this.cachedTargetBounds.length ? this.cachedTargetBounds : this._collectTargets({ activeObject: e }).map((v) => mt({ object: v })).filter((v) => !!v), g = bn({
6434
6592
  activeBounds: o,
6435
6593
  candidates: f,
6436
6594
  threshold: r,
6437
6595
  spacingPatterns: this.spacingPatterns
6438
6596
  });
6439
6597
  if (g.deltaX !== 0 || g.deltaY !== 0) {
6440
- const { left: v = 0, top: M = 0 } = e;
6598
+ const { left: v = 0, top: S = 0 } = e;
6441
6599
  e.set({
6442
6600
  left: v + g.deltaX,
6443
- top: M + g.deltaY
6444
- }), e.setCoords(), o = (m = pt({ object: e })) != null ? m : o;
6601
+ top: S + g.deltaY
6602
+ }), e.setCoords(), o = (m = mt({ object: e })) != null ? m : o;
6445
6603
  }
6446
6604
  this._applyGuides({
6447
6605
  guides: u,
@@ -6469,7 +6627,7 @@ class jn {
6469
6627
  const { canvas: t, guideBounds: e } = this, s = t.getSelectionContext();
6470
6628
  if (!s) return;
6471
6629
  const n = e != null ? e : this._calculateViewportBounds(), { left: o, right: i, top: a, bottom: r } = n, { viewportTransform: c } = t, d = t.getZoom() || 1;
6472
- s.save(), Array.isArray(c) && s.transform(...c), s.lineWidth = pe / d, s.strokeStyle = ss, s.setLineDash([4, 4]);
6630
+ s.save(), Array.isArray(c) && s.transform(...c), s.lineWidth = Ae / d, s.strokeStyle = os, s.setLineDash([4, 4]);
6473
6631
  for (const l of this.activeGuides)
6474
6632
  s.beginPath(), l.type === "vertical" ? (s.moveTo(l.position, a), s.lineTo(l.position, r)) : (s.moveTo(o, l.position), s.lineTo(i, l.position)), s.stroke();
6475
6633
  for (const l of this.activeSpacingGuides)
@@ -6509,7 +6667,7 @@ class jn {
6509
6667
  * Применяет шаг перемещения, округляя координаты объекта к сетке MOVE_SNAP_STEP.
6510
6668
  */
6511
6669
  _applyMovementStep({ target: t }) {
6512
- const { left: e = 0, top: s = 0 } = t, n = Math.round(e / Jt) * Jt, o = Math.round(s / Jt) * Jt;
6670
+ const { left: e = 0, top: s = 0 } = t, n = Math.round(e / ce) * ce, o = Math.round(s / ce) * ce;
6513
6671
  n === e && o === s || (t.set({
6514
6672
  left: n,
6515
6673
  top: o
@@ -6521,12 +6679,12 @@ class jn {
6521
6679
  _cacheAnchors({ activeObject: t }) {
6522
6680
  const e = this._collectTargets({ activeObject: t }), s = { vertical: [], horizontal: [] }, n = [];
6523
6681
  for (const a of e) {
6524
- const r = pt({ object: a });
6525
- r && (Qe({ anchors: s, bounds: r }), n.push(r));
6682
+ const r = mt({ object: a });
6683
+ r && (qe({ anchors: s, bounds: r }), n.push(r));
6526
6684
  }
6527
- const { montageArea: o } = this.editor, i = pt({ object: o });
6685
+ const { montageArea: o } = this.editor, i = mt({ object: o });
6528
6686
  if (i) {
6529
- Qe({ anchors: s, bounds: i });
6687
+ qe({ anchors: s, bounds: i });
6530
6688
  const { left: a, right: r, top: c, bottom: d } = i;
6531
6689
  this.guideBounds = {
6532
6690
  left: a,
@@ -6542,9 +6700,9 @@ class jn {
6542
6700
  * Собирает объекты, подходящие для прилипания, исключая активный объект и запрещённые id.
6543
6701
  */
6544
6702
  _collectTargets({ activeObject: t }) {
6545
- const e = os({ activeObject: t }), s = [];
6703
+ const e = as({ activeObject: t }), s = [];
6546
6704
  return this.canvas.forEachObject((n) => {
6547
- is({ object: n, excluded: e }) || s.push(n);
6705
+ rs({ object: n, excluded: e }) || s.push(n);
6548
6706
  }), s;
6549
6707
  }
6550
6708
  /**
@@ -6567,7 +6725,7 @@ class jn {
6567
6725
  };
6568
6726
  }
6569
6727
  }
6570
- const Je = "#3D8BF4", $e = 1;
6728
+ const ts = "#3D8BF4", es = 1;
6571
6729
  class Lt {
6572
6730
  /**
6573
6731
  * Создаёт менеджер измерений и инициализирует события.
@@ -6673,7 +6831,7 @@ class Lt {
6673
6831
  this._clearGuides();
6674
6832
  return;
6675
6833
  }
6676
- const o = pt({ object: n });
6834
+ const o = mt({ object: n });
6677
6835
  if (!o) {
6678
6836
  this._clearGuides();
6679
6837
  return;
@@ -6681,7 +6839,7 @@ class Lt {
6681
6839
  const i = Lt._resolveTarget({
6682
6840
  event: t,
6683
6841
  activeObject: n
6684
- }), { montageArea: a } = s, r = i != null ? i : a, c = r === a, d = pt({ object: r });
6842
+ }), { montageArea: a } = s, r = i != null ? i : a, c = r === a, d = mt({ object: r });
6685
6843
  if (!d) {
6686
6844
  this._clearGuides();
6687
6845
  return;
@@ -6708,8 +6866,8 @@ class Lt {
6708
6866
  event: t,
6709
6867
  activeObject: e
6710
6868
  }) {
6711
- const { target: s } = t, n = os({ activeObject: e });
6712
- return s && !is({ object: s, excluded: n }) ? s : null;
6869
+ const { target: s } = t, n = as({ activeObject: e });
6870
+ return s && !rs({ object: s, excluded: n }) ? s : null;
6713
6871
  }
6714
6872
  /**
6715
6873
  * Собирает вертикальные и горизонтальные направляющие расстояний.
@@ -6750,45 +6908,45 @@ class Lt {
6750
6908
  top: u = 0,
6751
6909
  bottom: f = 0,
6752
6910
  centerY: g = 0
6753
- } = e, p = Math.max(a, u), m = Math.min(r, f), M = m >= p ? (p + m) / 2 : (c + g) / 2;
6911
+ } = e, p = Math.max(a, u), m = Math.min(r, f), S = m >= p ? (p + m) / 2 : (c + g) / 2;
6754
6912
  if (d >= i) {
6755
6913
  if (s) return n;
6756
- const T = d - i;
6757
- return T > 0 && n.push({
6914
+ const C = d - i;
6915
+ return C > 0 && n.push({
6758
6916
  type: "horizontal",
6759
- axis: M,
6917
+ axis: S,
6760
6918
  start: i,
6761
6919
  end: d,
6762
- distance: T
6920
+ distance: C
6763
6921
  }), n;
6764
6922
  }
6765
6923
  if (l <= o) {
6766
6924
  if (s) return n;
6767
- const T = o - l;
6768
- return T > 0 && n.push({
6925
+ const C = o - l;
6926
+ return C > 0 && n.push({
6769
6927
  type: "horizontal",
6770
- axis: M,
6928
+ axis: S,
6771
6929
  start: l,
6772
6930
  end: o,
6773
- distance: T
6931
+ distance: C
6774
6932
  }), n;
6775
6933
  }
6776
6934
  if (!s) return n;
6777
- const S = o < d, y = i > l, b = Math.min(o, d), I = Math.max(o, d), j = I - b;
6778
- j > 0 && !S && n.push({
6935
+ const A = o < d, y = i > l, b = Math.min(o, d), j = Math.max(o, d), I = j - b;
6936
+ I > 0 && !A && n.push({
6779
6937
  type: "horizontal",
6780
- axis: M,
6938
+ axis: S,
6781
6939
  start: b,
6782
- end: I,
6783
- distance: j
6940
+ end: j,
6941
+ distance: I
6784
6942
  });
6785
- const A = Math.min(i, l), C = Math.max(i, l), w = C - A;
6786
- return w > 0 && !y && n.push({
6943
+ const w = Math.min(i, l), T = Math.max(i, l), M = T - w;
6944
+ return M > 0 && !y && n.push({
6787
6945
  type: "horizontal",
6788
- axis: M,
6789
- start: A,
6790
- end: C,
6791
- distance: w
6946
+ axis: S,
6947
+ start: w,
6948
+ end: T,
6949
+ distance: M
6792
6950
  }), n;
6793
6951
  }
6794
6952
  /**
@@ -6811,45 +6969,45 @@ class Lt {
6811
6969
  left: u = 0,
6812
6970
  right: f = 0,
6813
6971
  centerX: g = 0
6814
- } = e, p = Math.max(a, u), m = Math.min(r, f), M = m >= p ? (p + m) / 2 : (c + g) / 2;
6972
+ } = e, p = Math.max(a, u), m = Math.min(r, f), S = m >= p ? (p + m) / 2 : (c + g) / 2;
6815
6973
  if (d >= i) {
6816
6974
  if (s) return n;
6817
- const T = d - i;
6818
- return T > 0 && n.push({
6975
+ const C = d - i;
6976
+ return C > 0 && n.push({
6819
6977
  type: "vertical",
6820
- axis: M,
6978
+ axis: S,
6821
6979
  start: i,
6822
6980
  end: d,
6823
- distance: T
6981
+ distance: C
6824
6982
  }), n;
6825
6983
  }
6826
6984
  if (l <= o) {
6827
6985
  if (s) return n;
6828
- const T = o - l;
6829
- return T > 0 && n.push({
6986
+ const C = o - l;
6987
+ return C > 0 && n.push({
6830
6988
  type: "vertical",
6831
- axis: M,
6989
+ axis: S,
6832
6990
  start: l,
6833
6991
  end: o,
6834
- distance: T
6992
+ distance: C
6835
6993
  }), n;
6836
6994
  }
6837
6995
  if (!s) return n;
6838
- const S = o < d, y = i > l, b = Math.min(o, d), I = Math.max(o, d), j = I - b;
6839
- j > 0 && !S && n.push({
6996
+ const A = o < d, y = i > l, b = Math.min(o, d), j = Math.max(o, d), I = j - b;
6997
+ I > 0 && !A && n.push({
6840
6998
  type: "vertical",
6841
- axis: M,
6999
+ axis: S,
6842
7000
  start: b,
6843
- end: I,
6844
- distance: j
7001
+ end: j,
7002
+ distance: I
6845
7003
  });
6846
- const A = Math.min(i, l), C = Math.max(i, l), w = C - A;
6847
- return w > 0 && !y && n.push({
7004
+ const w = Math.min(i, l), T = Math.max(i, l), M = T - w;
7005
+ return M > 0 && !y && n.push({
6848
7006
  type: "vertical",
6849
- axis: M,
6850
- start: A,
6851
- end: C,
6852
- distance: w
7007
+ axis: S,
7008
+ start: w,
7009
+ end: T,
7010
+ distance: M
6853
7011
  }), n;
6854
7012
  }
6855
7013
  /**
@@ -6877,10 +7035,10 @@ class Lt {
6877
7035
  const { canvas: t } = this, e = t.getSelectionContext();
6878
7036
  if (!e) return;
6879
7037
  const { viewportTransform: s } = t, n = t.getZoom() || 1, o = this.activeGuides.some((c) => c.type === "vertical"), i = this.activeGuides.some((c) => c.type === "horizontal"), a = o && i && !this.isTargetMontageArea, r = a ? 12 / n : 0;
6880
- e.save(), Array.isArray(s) && e.transform(...s), e.lineWidth = $e / n, e.strokeStyle = Je, e.setLineDash([]);
7038
+ e.save(), Array.isArray(s) && e.transform(...s), e.lineWidth = es / n, e.strokeStyle = ts, e.setLineDash([]);
6881
7039
  for (const c of this.activeGuides) {
6882
- const { type: d, axis: l, start: u, end: f, distance: g } = c, p = Math.abs(f - u), m = u <= f ? -1 : 1, v = a ? m * (p / 2 + r) : 0, M = 0;
6883
- e.beginPath(), d === "vertical" ? (e.moveTo(l, u), e.lineTo(l, f)) : (e.moveTo(u, l), e.lineTo(f, l)), e.stroke(), me({
7040
+ const { type: d, axis: l, start: u, end: f, distance: g } = c, p = Math.abs(f - u), m = u <= f ? -1 : 1, v = a ? m * (p / 2 + r) : 0, S = 0;
7041
+ e.beginPath(), d === "vertical" ? (e.moveTo(l, u), e.lineTo(l, f)) : (e.moveTo(u, l), e.lineTo(f, l)), e.stroke(), je({
6884
7042
  context: e,
6885
7043
  type: d,
6886
7044
  axis: l,
@@ -6888,10 +7046,10 @@ class Lt {
6888
7046
  end: f,
6889
7047
  text: Math.round(g).toString(),
6890
7048
  zoom: n,
6891
- color: Je,
6892
- lineWidth: $e,
7049
+ color: ts,
7050
+ lineWidth: es,
6893
7051
  offsetAlongAxis: v,
6894
- offsetPerpendicular: M
7052
+ offsetPerpendicular: S
6895
7053
  });
6896
7054
  }
6897
7055
  e.restore();
@@ -6915,7 +7073,7 @@ class Lt {
6915
7073
  (e = t == null ? void 0 : t.showAfterTemporary) == null || e.call(t), this.isToolbarHidden = !1;
6916
7074
  }
6917
7075
  }
6918
- class Se {
7076
+ class Le {
6919
7077
  /**
6920
7078
  * Конструктор класса ImageEditor.
6921
7079
  * @param canvasId - идентификатор канваса, в котором будет создан редактор
@@ -6930,7 +7088,7 @@ class Se {
6930
7088
  * @fires editor:ready
6931
7089
  */
6932
7090
  init() {
6933
- return k(this, null, function* () {
7091
+ return z(this, null, function* () {
6934
7092
  var u;
6935
7093
  const {
6936
7094
  editorContainerWidth: t,
@@ -6945,13 +7103,17 @@ class Se {
6945
7103
  showRotationAngle: d,
6946
7104
  _onReadyCallback: l
6947
7105
  } = this.options;
6948
- if ($.apply(), this.canvas = new ys(this.containerId, this.options), this.moduleLoader = new Ss(), this.workerManager = new js(), this.errorManager = new Wt({ editor: this }), this.historyManager = new Ys({ editor: this }), this.toolbar = new Ps({ editor: this }), this.transformManager = new qs({ editor: this }), this.zoomManager = new Js({ editor: this }), this.canvasManager = new Qs({ editor: this }), this.imageManager = new dt({ editor: this }), this.layerManager = new te({ editor: this }), this.shapeManager = new tn({ editor: this }), this.interactionBlocker = new $s({ editor: this }), this.backgroundManager = new Ot({ editor: this }), this.clipboardManager = new en({ editor: this }), this.objectLockManager = new ee({ editor: this }), this.groupingManager = new sn({ editor: this }), this.selectionManager = new nn({ editor: this }), this.deletionManager = new we({ editor: this }), this.panConstraintManager = new on({ editor: this }), this.snappingManager = new jn({ editor: this }), this.measurementManager = new Lt({ editor: this }), this.fontManager = new ge((u = this.options.fonts) != null ? u : []), this.textManager = new P({ editor: this }), this.templateManager = new R({ editor: this }), d && (this.angleIndicator = new Me({ editor: this })), this._createMontageArea(), this._createClippingArea(), this.listeners = new Ft({ editor: this, options: this.options }), this.canvasManager.setEditorContainerWidth(t), this.canvasManager.setEditorContainerHeight(e), this.canvasManager.setCanvasWrapperWidth(s), this.canvasManager.setCanvasWrapperHeight(n), this.canvasManager.setCanvasCSSWidth(o), this.canvasManager.setCanvasCSSHeight(i), this.canvasManager.updateCanvas(), this.zoomManager.calculateAndApplyDefaultZoom(), yield this.fontManager.loadFonts(), a != null && a.source) {
6949
- const {
6950
- source: f,
6951
- scale: g = `image-${c}`,
6952
- withoutSave: p = !0
6953
- } = a;
6954
- yield this.imageManager.importImage({ source: f, scale: g, withoutSave: p });
7106
+ if (et.apply(), this.canvas = new vs(this.containerId, this.options), this.moduleLoader = new As(), this.workerManager = new Is(), this.errorManager = new Qt({ editor: this }), this.historyManager = new Kt({ editor: this }), this.toolbar = new Us({ editor: this }), this.transformManager = new Js({ editor: this }), this.zoomManager = new qs({ editor: this }), this.canvasManager = new Qs({ editor: this }), this.imageManager = new ht({ editor: this }), this.layerManager = new le({ editor: this }), this.shapeManager = new tn({ editor: this }), this.interactionBlocker = new $s({ editor: this }), this.backgroundManager = new Ot({ editor: this }), this.clipboardManager = new en({ editor: this }), this.objectLockManager = new he({ editor: this }), this.groupingManager = new sn({ editor: this }), this.selectionManager = new nn({ editor: this }), this.deletionManager = new Oe({ editor: this }), this.panConstraintManager = new on({ editor: this }), this.snappingManager = new jn({ editor: this }), this.measurementManager = new Lt({ editor: this }), this.fontManager = new Se((u = this.options.fonts) != null ? u : []), this.textManager = new k({ editor: this }), this.templateManager = new _({ editor: this }), d && (this.angleIndicator = new Ee({ editor: this })), this._createMontageArea(), this._createClippingArea(), this.listeners = new Xt({ editor: this, options: this.options }), this.canvasManager.setEditorContainerWidth(t), this.canvasManager.setEditorContainerHeight(e), this.canvasManager.setCanvasWrapperWidth(s), this.canvasManager.setCanvasWrapperHeight(n), this.canvasManager.setCanvasCSSWidth(o), this.canvasManager.setCanvasCSSHeight(i), this.canvasManager.updateCanvas(), this.zoomManager.calculateAndApplyDefaultZoom(), yield this.fontManager.loadFonts(), a != null && a.source) {
7107
+ const f = a, {
7108
+ source: g,
7109
+ scale: p = `image-${c}`,
7110
+ withoutSave: m = !0
7111
+ } = f, v = gt(f, [
7112
+ "source",
7113
+ "scale",
7114
+ "withoutSave"
7115
+ ]);
7116
+ yield this.imageManager.importImage(B({ source: g, scale: p, withoutSave: m }, v));
6955
7117
  }
6956
7118
  r && this.historyManager.loadStateFromFullState(r), this.historyManager.saveState(), console.log("editor:ready"), this.canvas.fire("editor:ready", this), typeof l == "function" && l(this);
6957
7119
  });
@@ -6967,7 +7129,7 @@ class Se {
6967
7129
  this.montageArea = this.shapeManager.addRectangle({
6968
7130
  width: t,
6969
7131
  height: e,
6970
- fill: Se._createMosaicPattern(),
7132
+ fill: Le._createMosaicPattern(),
6971
7133
  stroke: null,
6972
7134
  strokeWidth: 0,
6973
7135
  selectable: !1,
@@ -7018,13 +7180,13 @@ class Se {
7018
7180
  const t = document.createElement("canvas");
7019
7181
  t.width = 20, t.height = 20;
7020
7182
  const e = t.getContext("2d");
7021
- return e.fillStyle = "#ddd", e.fillRect(0, 0, 40, 40), e.fillStyle = "#ccc", e.fillRect(0, 0, 10, 10), e.fillRect(10, 10, 10, 10), new vs({
7183
+ return e.fillStyle = "#ddd", e.fillRect(0, 0, 40, 40), e.fillStyle = "#ccc", e.fillRect(0, 0, 10, 10), e.fillRect(10, 10, 10, 10), new bs({
7022
7184
  source: t,
7023
7185
  repeat: "repeat"
7024
7186
  });
7025
7187
  }
7026
7188
  }
7027
- const O = [
7189
+ const L = [
7028
7190
  "U+0000-00FF",
7029
7191
  "U+0100-02BA",
7030
7192
  "U+02BB-02BC",
@@ -7054,7 +7216,7 @@ const O = [
7054
7216
  "U+A720-A7FF",
7055
7217
  "U+FEFF",
7056
7218
  "U+FFFD"
7057
- ].join(", "), L = [
7219
+ ].join(", "), D = [
7058
7220
  "U+0301",
7059
7221
  "U+0400-052F",
7060
7222
  "U+1C80-1C8A",
@@ -7080,7 +7242,7 @@ const O = [
7080
7242
  style: "normal",
7081
7243
  weight: "400",
7082
7244
  display: "swap",
7083
- unicodeRange: L
7245
+ unicodeRange: D
7084
7246
  }
7085
7247
  },
7086
7248
  {
@@ -7090,7 +7252,7 @@ const O = [
7090
7252
  style: "normal",
7091
7253
  weight: "400",
7092
7254
  display: "swap",
7093
- unicodeRange: O
7255
+ unicodeRange: L
7094
7256
  }
7095
7257
  },
7096
7258
  {
@@ -7100,7 +7262,7 @@ const O = [
7100
7262
  style: "normal",
7101
7263
  weight: "700",
7102
7264
  display: "swap",
7103
- unicodeRange: L
7265
+ unicodeRange: D
7104
7266
  }
7105
7267
  },
7106
7268
  {
@@ -7110,7 +7272,7 @@ const O = [
7110
7272
  style: "normal",
7111
7273
  weight: "700",
7112
7274
  display: "swap",
7113
- unicodeRange: O
7275
+ unicodeRange: L
7114
7276
  }
7115
7277
  },
7116
7278
  {
@@ -7120,7 +7282,7 @@ const O = [
7120
7282
  style: "normal",
7121
7283
  weight: "200 700",
7122
7284
  display: "swap",
7123
- unicodeRange: L
7285
+ unicodeRange: D
7124
7286
  }
7125
7287
  },
7126
7288
  {
@@ -7130,7 +7292,7 @@ const O = [
7130
7292
  style: "normal",
7131
7293
  weight: "200 700",
7132
7294
  display: "swap",
7133
- unicodeRange: O
7295
+ unicodeRange: L
7134
7296
  }
7135
7297
  },
7136
7298
  {
@@ -7140,7 +7302,7 @@ const O = [
7140
7302
  style: "normal",
7141
7303
  weight: "300 900",
7142
7304
  display: "swap",
7143
- unicodeRange: L
7305
+ unicodeRange: D
7144
7306
  }
7145
7307
  },
7146
7308
  {
@@ -7150,7 +7312,7 @@ const O = [
7150
7312
  style: "normal",
7151
7313
  weight: "300 900",
7152
7314
  display: "swap",
7153
- unicodeRange: O
7315
+ unicodeRange: L
7154
7316
  }
7155
7317
  },
7156
7318
  {
@@ -7160,7 +7322,7 @@ const O = [
7160
7322
  style: "normal",
7161
7323
  weight: "400 700",
7162
7324
  display: "swap",
7163
- unicodeRange: L
7325
+ unicodeRange: D
7164
7326
  }
7165
7327
  },
7166
7328
  {
@@ -7170,7 +7332,7 @@ const O = [
7170
7332
  style: "normal",
7171
7333
  weight: "400 700",
7172
7334
  display: "swap",
7173
- unicodeRange: O
7335
+ unicodeRange: L
7174
7336
  }
7175
7337
  },
7176
7338
  {
@@ -7180,7 +7342,7 @@ const O = [
7180
7342
  style: "normal",
7181
7343
  weight: "300 700",
7182
7344
  display: "swap",
7183
- unicodeRange: L
7345
+ unicodeRange: D
7184
7346
  }
7185
7347
  },
7186
7348
  {
@@ -7190,7 +7352,7 @@ const O = [
7190
7352
  style: "normal",
7191
7353
  weight: "300 700",
7192
7354
  display: "swap",
7193
- unicodeRange: O
7355
+ unicodeRange: L
7194
7356
  }
7195
7357
  },
7196
7358
  {
@@ -7200,7 +7362,7 @@ const O = [
7200
7362
  style: "normal",
7201
7363
  weight: "300 700",
7202
7364
  display: "swap",
7203
- unicodeRange: L
7365
+ unicodeRange: D
7204
7366
  }
7205
7367
  },
7206
7368
  {
@@ -7210,7 +7372,7 @@ const O = [
7210
7372
  style: "normal",
7211
7373
  weight: "300 700",
7212
7374
  display: "swap",
7213
- unicodeRange: O
7375
+ unicodeRange: L
7214
7376
  }
7215
7377
  },
7216
7378
  {
@@ -7220,7 +7382,7 @@ const O = [
7220
7382
  style: "normal",
7221
7383
  weight: "400",
7222
7384
  display: "swap",
7223
- unicodeRange: L
7385
+ unicodeRange: D
7224
7386
  }
7225
7387
  },
7226
7388
  {
@@ -7230,7 +7392,7 @@ const O = [
7230
7392
  style: "normal",
7231
7393
  weight: "400",
7232
7394
  display: "swap",
7233
- unicodeRange: O
7395
+ unicodeRange: L
7234
7396
  }
7235
7397
  },
7236
7398
  {
@@ -7240,7 +7402,7 @@ const O = [
7240
7402
  style: "normal",
7241
7403
  weight: "400 700",
7242
7404
  display: "swap",
7243
- unicodeRange: L
7405
+ unicodeRange: D
7244
7406
  }
7245
7407
  },
7246
7408
  {
@@ -7250,7 +7412,7 @@ const O = [
7250
7412
  style: "normal",
7251
7413
  weight: "400 700",
7252
7414
  display: "swap",
7253
- unicodeRange: O
7415
+ unicodeRange: L
7254
7416
  }
7255
7417
  },
7256
7418
  {
@@ -7260,7 +7422,7 @@ const O = [
7260
7422
  style: "normal",
7261
7423
  weight: "100 900",
7262
7424
  display: "swap",
7263
- unicodeRange: L
7425
+ unicodeRange: D
7264
7426
  }
7265
7427
  },
7266
7428
  {
@@ -7270,7 +7432,7 @@ const O = [
7270
7432
  style: "normal",
7271
7433
  weight: "100 900",
7272
7434
  display: "swap",
7273
- unicodeRange: O
7435
+ unicodeRange: L
7274
7436
  }
7275
7437
  },
7276
7438
  {
@@ -7280,7 +7442,7 @@ const O = [
7280
7442
  style: "normal",
7281
7443
  weight: "400",
7282
7444
  display: "swap",
7283
- unicodeRange: L
7445
+ unicodeRange: D
7284
7446
  }
7285
7447
  },
7286
7448
  {
@@ -7290,7 +7452,7 @@ const O = [
7290
7452
  style: "normal",
7291
7453
  weight: "400",
7292
7454
  display: "swap",
7293
- unicodeRange: O
7455
+ unicodeRange: L
7294
7456
  }
7295
7457
  },
7296
7458
  {
@@ -7300,7 +7462,7 @@ const O = [
7300
7462
  style: "normal",
7301
7463
  weight: "700",
7302
7464
  display: "swap",
7303
- unicodeRange: L
7465
+ unicodeRange: D
7304
7466
  }
7305
7467
  },
7306
7468
  {
@@ -7310,7 +7472,7 @@ const O = [
7310
7472
  style: "normal",
7311
7473
  weight: "700",
7312
7474
  display: "swap",
7313
- unicodeRange: O
7475
+ unicodeRange: L
7314
7476
  }
7315
7477
  },
7316
7478
  {
@@ -7320,7 +7482,7 @@ const O = [
7320
7482
  style: "normal",
7321
7483
  weight: "400 700",
7322
7484
  display: "swap",
7323
- unicodeRange: L
7485
+ unicodeRange: D
7324
7486
  }
7325
7487
  },
7326
7488
  {
@@ -7330,7 +7492,7 @@ const O = [
7330
7492
  style: "normal",
7331
7493
  weight: "400 700",
7332
7494
  display: "swap",
7333
- unicodeRange: O
7495
+ unicodeRange: L
7334
7496
  }
7335
7497
  },
7336
7498
  {
@@ -7340,7 +7502,7 @@ const O = [
7340
7502
  style: "normal",
7341
7503
  weight: "100 900",
7342
7504
  display: "swap",
7343
- unicodeRange: L
7505
+ unicodeRange: D
7344
7506
  }
7345
7507
  },
7346
7508
  {
@@ -7350,7 +7512,7 @@ const O = [
7350
7512
  style: "normal",
7351
7513
  weight: "100 900",
7352
7514
  display: "swap",
7353
- unicodeRange: O
7515
+ unicodeRange: L
7354
7516
  }
7355
7517
  },
7356
7518
  {
@@ -7360,7 +7522,7 @@ const O = [
7360
7522
  style: "normal",
7361
7523
  weight: "100",
7362
7524
  display: "swap",
7363
- unicodeRange: L
7525
+ unicodeRange: D
7364
7526
  }
7365
7527
  },
7366
7528
  {
@@ -7370,7 +7532,7 @@ const O = [
7370
7532
  style: "normal",
7371
7533
  weight: "100",
7372
7534
  display: "swap",
7373
- unicodeRange: O
7535
+ unicodeRange: L
7374
7536
  }
7375
7537
  },
7376
7538
  {
@@ -7380,7 +7542,7 @@ const O = [
7380
7542
  style: "normal",
7381
7543
  weight: "200",
7382
7544
  display: "swap",
7383
- unicodeRange: L
7545
+ unicodeRange: D
7384
7546
  }
7385
7547
  },
7386
7548
  {
@@ -7390,7 +7552,7 @@ const O = [
7390
7552
  style: "normal",
7391
7553
  weight: "200",
7392
7554
  display: "swap",
7393
- unicodeRange: O
7555
+ unicodeRange: L
7394
7556
  }
7395
7557
  },
7396
7558
  {
@@ -7400,7 +7562,7 @@ const O = [
7400
7562
  style: "normal",
7401
7563
  weight: "300",
7402
7564
  display: "swap",
7403
- unicodeRange: L
7565
+ unicodeRange: D
7404
7566
  }
7405
7567
  },
7406
7568
  {
@@ -7410,7 +7572,7 @@ const O = [
7410
7572
  style: "normal",
7411
7573
  weight: "300",
7412
7574
  display: "swap",
7413
- unicodeRange: O
7575
+ unicodeRange: L
7414
7576
  }
7415
7577
  },
7416
7578
  {
@@ -7420,7 +7582,7 @@ const O = [
7420
7582
  style: "normal",
7421
7583
  weight: "400",
7422
7584
  display: "swap",
7423
- unicodeRange: L
7585
+ unicodeRange: D
7424
7586
  }
7425
7587
  },
7426
7588
  {
@@ -7430,7 +7592,7 @@ const O = [
7430
7592
  style: "normal",
7431
7593
  weight: "400",
7432
7594
  display: "swap",
7433
- unicodeRange: O
7595
+ unicodeRange: L
7434
7596
  }
7435
7597
  },
7436
7598
  {
@@ -7440,7 +7602,7 @@ const O = [
7440
7602
  style: "normal",
7441
7603
  weight: "500",
7442
7604
  display: "swap",
7443
- unicodeRange: L
7605
+ unicodeRange: D
7444
7606
  }
7445
7607
  },
7446
7608
  {
@@ -7450,7 +7612,7 @@ const O = [
7450
7612
  style: "normal",
7451
7613
  weight: "500",
7452
7614
  display: "swap",
7453
- unicodeRange: O
7615
+ unicodeRange: L
7454
7616
  }
7455
7617
  },
7456
7618
  {
@@ -7460,7 +7622,7 @@ const O = [
7460
7622
  style: "normal",
7461
7623
  weight: "600",
7462
7624
  display: "swap",
7463
- unicodeRange: L
7625
+ unicodeRange: D
7464
7626
  }
7465
7627
  },
7466
7628
  {
@@ -7470,7 +7632,7 @@ const O = [
7470
7632
  style: "normal",
7471
7633
  weight: "600",
7472
7634
  display: "swap",
7473
- unicodeRange: O
7635
+ unicodeRange: L
7474
7636
  }
7475
7637
  },
7476
7638
  {
@@ -7480,7 +7642,7 @@ const O = [
7480
7642
  style: "normal",
7481
7643
  weight: "700",
7482
7644
  display: "swap",
7483
- unicodeRange: L
7645
+ unicodeRange: D
7484
7646
  }
7485
7647
  },
7486
7648
  {
@@ -7490,7 +7652,7 @@ const O = [
7490
7652
  style: "normal",
7491
7653
  weight: "700",
7492
7654
  display: "swap",
7493
- unicodeRange: O
7655
+ unicodeRange: L
7494
7656
  }
7495
7657
  },
7496
7658
  {
@@ -7500,7 +7662,7 @@ const O = [
7500
7662
  style: "normal",
7501
7663
  weight: "800",
7502
7664
  display: "swap",
7503
- unicodeRange: L
7665
+ unicodeRange: D
7504
7666
  }
7505
7667
  },
7506
7668
  {
@@ -7510,7 +7672,7 @@ const O = [
7510
7672
  style: "normal",
7511
7673
  weight: "800",
7512
7674
  display: "swap",
7513
- unicodeRange: O
7675
+ unicodeRange: L
7514
7676
  }
7515
7677
  },
7516
7678
  {
@@ -7520,7 +7682,7 @@ const O = [
7520
7682
  style: "normal",
7521
7683
  weight: "900",
7522
7684
  display: "swap",
7523
- unicodeRange: L
7685
+ unicodeRange: D
7524
7686
  }
7525
7687
  },
7526
7688
  {
@@ -7530,7 +7692,7 @@ const O = [
7530
7692
  style: "normal",
7531
7693
  weight: "900",
7532
7694
  display: "swap",
7533
- unicodeRange: O
7695
+ unicodeRange: L
7534
7696
  }
7535
7697
  },
7536
7698
  {
@@ -7540,7 +7702,7 @@ const O = [
7540
7702
  style: "normal",
7541
7703
  weight: "400",
7542
7704
  display: "swap",
7543
- unicodeRange: L
7705
+ unicodeRange: D
7544
7706
  }
7545
7707
  },
7546
7708
  {
@@ -7550,7 +7712,7 @@ const O = [
7550
7712
  style: "normal",
7551
7713
  weight: "400",
7552
7714
  display: "swap",
7553
- unicodeRange: O
7715
+ unicodeRange: L
7554
7716
  }
7555
7717
  },
7556
7718
  {
@@ -7560,7 +7722,7 @@ const O = [
7560
7722
  style: "normal",
7561
7723
  weight: "700",
7562
7724
  display: "swap",
7563
- unicodeRange: L
7725
+ unicodeRange: D
7564
7726
  }
7565
7727
  },
7566
7728
  {
@@ -7570,7 +7732,7 @@ const O = [
7570
7732
  style: "normal",
7571
7733
  weight: "700",
7572
7734
  display: "swap",
7573
- unicodeRange: O
7735
+ unicodeRange: L
7574
7736
  }
7575
7737
  },
7576
7738
  {
@@ -7580,7 +7742,7 @@ const O = [
7580
7742
  style: "normal",
7581
7743
  weight: "100 900",
7582
7744
  display: "swap",
7583
- unicodeRange: L
7745
+ unicodeRange: D
7584
7746
  }
7585
7747
  },
7586
7748
  {
@@ -7590,7 +7752,7 @@ const O = [
7590
7752
  style: "normal",
7591
7753
  weight: "100 900",
7592
7754
  display: "swap",
7593
- unicodeRange: O
7755
+ unicodeRange: L
7594
7756
  }
7595
7757
  },
7596
7758
  {
@@ -7600,7 +7762,7 @@ const O = [
7600
7762
  style: "normal",
7601
7763
  weight: "300 700",
7602
7764
  display: "swap",
7603
- unicodeRange: L
7765
+ unicodeRange: D
7604
7766
  }
7605
7767
  },
7606
7768
  {
@@ -7610,7 +7772,7 @@ const O = [
7610
7772
  style: "normal",
7611
7773
  weight: "300 700",
7612
7774
  display: "swap",
7613
- unicodeRange: O
7775
+ unicodeRange: L
7614
7776
  }
7615
7777
  },
7616
7778
  {
@@ -7620,7 +7782,7 @@ const O = [
7620
7782
  style: "normal",
7621
7783
  weight: "400",
7622
7784
  display: "swap",
7623
- unicodeRange: L
7785
+ unicodeRange: D
7624
7786
  }
7625
7787
  },
7626
7788
  {
@@ -7630,7 +7792,7 @@ const O = [
7630
7792
  style: "normal",
7631
7793
  weight: "400",
7632
7794
  display: "swap",
7633
- unicodeRange: O
7795
+ unicodeRange: L
7634
7796
  }
7635
7797
  },
7636
7798
  {
@@ -7640,7 +7802,7 @@ const O = [
7640
7802
  style: "normal",
7641
7803
  weight: "200 800",
7642
7804
  display: "swap",
7643
- unicodeRange: L
7805
+ unicodeRange: D
7644
7806
  }
7645
7807
  },
7646
7808
  {
@@ -7650,7 +7812,7 @@ const O = [
7650
7812
  style: "normal",
7651
7813
  weight: "200 800",
7652
7814
  display: "swap",
7653
- unicodeRange: O
7815
+ unicodeRange: L
7654
7816
  }
7655
7817
  },
7656
7818
  {
@@ -7660,7 +7822,7 @@ const O = [
7660
7822
  style: "normal",
7661
7823
  weight: "100 900",
7662
7824
  display: "swap",
7663
- unicodeRange: L
7825
+ unicodeRange: D
7664
7826
  }
7665
7827
  },
7666
7828
  {
@@ -7670,7 +7832,7 @@ const O = [
7670
7832
  style: "normal",
7671
7833
  weight: "100 900",
7672
7834
  display: "swap",
7673
- unicodeRange: O
7835
+ unicodeRange: L
7674
7836
  }
7675
7837
  },
7676
7838
  {
@@ -7680,7 +7842,7 @@ const O = [
7680
7842
  style: "normal",
7681
7843
  weight: "400",
7682
7844
  display: "swap",
7683
- unicodeRange: L
7845
+ unicodeRange: D
7684
7846
  }
7685
7847
  },
7686
7848
  {
@@ -7690,7 +7852,7 @@ const O = [
7690
7852
  style: "normal",
7691
7853
  weight: "400",
7692
7854
  display: "swap",
7693
- unicodeRange: O
7855
+ unicodeRange: L
7694
7856
  }
7695
7857
  },
7696
7858
  {
@@ -7700,7 +7862,7 @@ const O = [
7700
7862
  style: "normal",
7701
7863
  weight: "100 900",
7702
7864
  display: "swap",
7703
- unicodeRange: L
7865
+ unicodeRange: D
7704
7866
  }
7705
7867
  },
7706
7868
  {
@@ -7710,7 +7872,7 @@ const O = [
7710
7872
  style: "normal",
7711
7873
  weight: "100 900",
7712
7874
  display: "swap",
7713
- unicodeRange: O
7875
+ unicodeRange: L
7714
7876
  }
7715
7877
  },
7716
7878
  {
@@ -7720,7 +7882,7 @@ const O = [
7720
7882
  style: "normal",
7721
7883
  weight: "300 800",
7722
7884
  display: "swap",
7723
- unicodeRange: L
7885
+ unicodeRange: D
7724
7886
  }
7725
7887
  },
7726
7888
  {
@@ -7730,7 +7892,7 @@ const O = [
7730
7892
  style: "normal",
7731
7893
  weight: "300 800",
7732
7894
  display: "swap",
7733
- unicodeRange: O
7895
+ unicodeRange: L
7734
7896
  }
7735
7897
  },
7736
7898
  {
@@ -7740,7 +7902,7 @@ const O = [
7740
7902
  style: "normal",
7741
7903
  weight: "400",
7742
7904
  display: "swap",
7743
- unicodeRange: L
7905
+ unicodeRange: D
7744
7906
  }
7745
7907
  },
7746
7908
  {
@@ -7750,7 +7912,7 @@ const O = [
7750
7912
  style: "normal",
7751
7913
  weight: "400",
7752
7914
  display: "swap",
7753
- unicodeRange: O
7915
+ unicodeRange: L
7754
7916
  }
7755
7917
  },
7756
7918
  {
@@ -7760,7 +7922,7 @@ const O = [
7760
7922
  style: "normal",
7761
7923
  weight: "700",
7762
7924
  display: "swap",
7763
- unicodeRange: L
7925
+ unicodeRange: D
7764
7926
  }
7765
7927
  },
7766
7928
  {
@@ -7770,7 +7932,7 @@ const O = [
7770
7932
  style: "normal",
7771
7933
  weight: "700",
7772
7934
  display: "swap",
7773
- unicodeRange: O
7935
+ unicodeRange: L
7774
7936
  }
7775
7937
  },
7776
7938
  {
@@ -7780,7 +7942,7 @@ const O = [
7780
7942
  style: "normal",
7781
7943
  weight: "300 900",
7782
7944
  display: "swap",
7783
- unicodeRange: L
7945
+ unicodeRange: D
7784
7946
  }
7785
7947
  },
7786
7948
  {
@@ -7790,7 +7952,7 @@ const O = [
7790
7952
  style: "normal",
7791
7953
  weight: "300 900",
7792
7954
  display: "swap",
7793
- unicodeRange: O
7955
+ unicodeRange: L
7794
7956
  }
7795
7957
  },
7796
7958
  {
@@ -7800,7 +7962,7 @@ const O = [
7800
7962
  style: "normal",
7801
7963
  weight: "400",
7802
7964
  display: "swap",
7803
- unicodeRange: L
7965
+ unicodeRange: D
7804
7966
  }
7805
7967
  },
7806
7968
  {
@@ -7810,7 +7972,7 @@ const O = [
7810
7972
  style: "normal",
7811
7973
  weight: "400",
7812
7974
  display: "swap",
7813
- unicodeRange: O
7975
+ unicodeRange: L
7814
7976
  }
7815
7977
  },
7816
7978
  {
@@ -7820,7 +7982,7 @@ const O = [
7820
7982
  style: "normal",
7821
7983
  weight: "100 900",
7822
7984
  display: "swap",
7823
- unicodeRange: L
7985
+ unicodeRange: D
7824
7986
  }
7825
7987
  },
7826
7988
  {
@@ -7830,7 +7992,7 @@ const O = [
7830
7992
  style: "normal",
7831
7993
  weight: "100 900",
7832
7994
  display: "swap",
7833
- unicodeRange: O
7995
+ unicodeRange: L
7834
7996
  }
7835
7997
  },
7836
7998
  {
@@ -7840,7 +8002,7 @@ const O = [
7840
8002
  style: "normal",
7841
8003
  weight: "100 900",
7842
8004
  display: "swap",
7843
- unicodeRange: L
8005
+ unicodeRange: D
7844
8006
  }
7845
8007
  },
7846
8008
  {
@@ -7850,7 +8012,7 @@ const O = [
7850
8012
  style: "normal",
7851
8013
  weight: "100 900",
7852
8014
  display: "swap",
7853
- unicodeRange: O
8015
+ unicodeRange: L
7854
8016
  }
7855
8017
  }
7856
8018
  ], Cn = {
@@ -7954,7 +8116,7 @@ function Dn(h, t = {}) {
7954
8116
  const n = document.createElement("canvas");
7955
8117
  return n.id = `${h}-canvas`, s.appendChild(n), e.editorContainer = s, new Promise((o) => {
7956
8118
  e._onReadyCallback = o;
7957
- const i = new Se(n.id, e);
8119
+ const i = new Le(n.id, e);
7958
8120
  window[h] = i;
7959
8121
  });
7960
8122
  }