@anu3ev/fabric-image-editor 0.5.22 → 0.5.23

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 +664 -555
  2. package/package.json +1 -1
package/dist/main.js CHANGED
@@ -1,25 +1,25 @@
1
1
  var ds = Object.defineProperty, ls = Object.defineProperties;
2
2
  var hs = Object.getOwnPropertyDescriptors;
3
3
  var ne = Object.getOwnPropertySymbols;
4
- var Ne = Object.prototype.hasOwnProperty, xe = Object.prototype.propertyIsEnumerable;
4
+ var xe = Object.prototype.hasOwnProperty, Ne = Object.prototype.propertyIsEnumerable;
5
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
- Ne.call(t, e) && _e(h, e, t[e]);
7
+ xe.call(t, e) && _e(h, e, t[e]);
8
8
  if (ne)
9
9
  for (var e of ne(t))
10
- xe.call(t, e) && _e(h, e, t[e]);
10
+ Ne.call(t, e) && _e(h, e, t[e]);
11
11
  return h;
12
- }, wt = (h, t) => ls(h, hs(t));
13
- var gt = (h, t) => {
12
+ }, St = (h, t) => ls(h, hs(t));
13
+ var pt = (h, t) => {
14
14
  var e = {};
15
15
  for (var s in h)
16
- Ne.call(h, s) && t.indexOf(s) < 0 && (e[s] = h[s]);
16
+ xe.call(h, s) && t.indexOf(s) < 0 && (e[s] = h[s]);
17
17
  if (h != null && ne)
18
18
  for (var s of ne(h))
19
- t.indexOf(s) < 0 && xe.call(h, s) && (e[s] = h[s]);
19
+ t.indexOf(s) < 0 && Ne.call(h, s) && (e[s] = h[s]);
20
20
  return e;
21
21
  };
22
- var z = (h, t, e) => new Promise((s, n) => {
22
+ var P = (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 z = (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 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";
38
+ import { ActiveSelection as U, Textbox as it, util as ft, controlsUtils as Be, InteractiveFabricObject as ke, Point as et, FitContentLayout as ze, loadSVGFromURL as us, FabricImage as Gt, Gradient as Pe, Rect as fs, Circle as gs, Triangle as ps, Group as Ot, Color as ms, classRegistry as We, loadSVGFromString as ys, Canvas as vs, Pattern as bs } from "fabric";
39
39
  import { create as Ms } from "jsondiffpatch";
40
40
  import ws from "diff-match-patch";
41
- var Ss = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict", V = function() {
41
+ var Ss = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict", X = 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
43
  e += Ss[s[t] & 63];
44
44
  return e;
45
45
  };
46
- class Xt {
46
+ class Kt {
47
47
  /**
48
48
  * Конструктор принимает редактор и опции.
49
49
  * @param params
@@ -61,7 +61,7 @@ class Xt {
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 = 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();
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 = Kt.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 = Kt.debounce(this.handleObjectModifiedHistory.bind(this), 300), this.handleObjectRotatingHistoryBound = Kt.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 Xt {
175
175
  * @param event.code — код клавиши
176
176
  */
177
177
  handleUndoRedoEvent(t) {
178
- return z(this, null, function* () {
178
+ return P(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
  });
@@ -347,7 +347,7 @@ class Xt {
347
347
  */
348
348
  handleResetObjectFit(t) {
349
349
  const e = t == null ? void 0 : t.target;
350
- !e || e instanceof ot || this.editor.transformManager.resetObject({ object: e });
350
+ !e || e instanceof it || this.editor.transformManager.resetObject({ object: e });
351
351
  }
352
352
  /**
353
353
  * Проверяет, должно ли событие клавиатуры быть проигнорировано
@@ -468,7 +468,7 @@ class Is {
468
468
  * @returns Promise, который будет выполнен, когда воркер вернет ответ
469
469
  */
470
470
  post(t, e, s = []) {
471
- const n = `${t}:${V(8)}`;
471
+ const n = `${t}:${X(8)}`;
472
472
  return new Promise((o, i) => {
473
473
  this._callbacks.set(n, { resolve: o, reject: i }), this.worker.postMessage({ action: t, payload: e, requestId: n }, s);
474
474
  });
@@ -480,52 +480,52 @@ class Is {
480
480
  this.worker.terminate();
481
481
  }
482
482
  }
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";
483
+ const ht = 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
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();
485
+ const o = ht, i = Cs;
486
+ h.save(), h.translate(t, e), h.rotate(ft.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
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();
490
+ h.save(), h.translate(t, e), h.rotate(ft.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
492
  function Fe(h, t, e, s, n) {
493
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();
494
+ h.save(), h.translate(t, e), h.rotate(ft.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
496
  const Ls = "", ss = new Image();
497
497
  ss.src = Ls;
498
498
  function Ds(h, t, e, s, n) {
499
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();
500
+ h.save(), h.translate(t, e), h.rotate(ft.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
502
  const Rs = {
503
503
  // Угловые точки
504
504
  tl: {
505
505
  render: oe,
506
- sizeX: lt,
507
- sizeY: lt,
506
+ sizeX: ht,
507
+ sizeY: ht,
508
508
  offsetX: 0,
509
509
  offsetY: 0
510
510
  },
511
511
  tr: {
512
512
  render: oe,
513
- sizeX: lt,
514
- sizeY: lt,
513
+ sizeX: ht,
514
+ sizeY: ht,
515
515
  offsetX: 0,
516
516
  offsetY: 0
517
517
  },
518
518
  bl: {
519
519
  render: oe,
520
- sizeX: lt,
521
- sizeY: lt,
520
+ sizeX: ht,
521
+ sizeY: ht,
522
522
  offsetX: 0,
523
523
  offsetY: 0
524
524
  },
525
525
  br: {
526
526
  render: oe,
527
- sizeX: lt,
528
- sizeY: lt,
527
+ sizeX: ht,
528
+ sizeY: ht,
529
529
  offsetX: 0,
530
530
  offsetY: 0
531
531
  },
@@ -568,7 +568,7 @@ const Rs = {
568
568
  offsetY: -de
569
569
  }
570
570
  };
571
- class et {
571
+ class st {
572
572
  /**
573
573
  * Отключает изменение ширины по оси X для заблокированных объектов, сохраняя поведение остального хэндлера.
574
574
  */
@@ -598,9 +598,9 @@ class et {
598
598
  */
599
599
  static apply() {
600
600
  const t = Be.createObjectDefaultControls();
601
- et.applyControlOverrides(t), ke.ownDefaults.controls = t;
601
+ st.applyControlOverrides(t), ke.ownDefaults.controls = t;
602
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;
603
+ st.applyControlOverrides(e), e.mt && (e.mt.visible = !1), e.mb && (e.mb.visible = !1), st.wrapWidthControl(e.ml), st.wrapWidthControl(e.mr), it.ownDefaults.controls = e, st.patchActiveSelectionBounds(), ke.ownDefaults.snapAngle = 1;
604
604
  }
605
605
  /**
606
606
  * Обновляет алгоритм расчёта границ ActiveSelection, чтобы учитывать фон и отступы текстовых объектов.
@@ -610,11 +610,11 @@ class et {
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
- et.applyTextSelectionScalingLock({
613
+ st.applyTextSelectionScalingLock({
614
614
  selection: this,
615
615
  objects: i
616
616
  });
617
- const a = et.calculateActiveSelectionBounds({
617
+ const a = st.calculateActiveSelectionBounds({
618
618
  objects: i
619
619
  });
620
620
  if (!a)
@@ -626,45 +626,45 @@ class et {
626
626
  width: d,
627
627
  height: l
628
628
  });
629
- const u = new tt(r + d / 2, c + l / 2);
629
+ const u = new et(r + d / 2, c + l / 2);
630
630
  return this.setPositionByOrigin(u, "center", "center"), a;
631
631
  };
632
632
  const s = t._onAfterObjectsChange;
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
- et.applyTextSelectionScalingLock({
636
+ st.applyTextSelectionScalingLock({
637
637
  selection: this,
638
638
  objects: r
639
639
  });
640
- const c = et.calculateActiveSelectionBounds({
640
+ const c = st.calculateActiveSelectionBounds({
641
641
  objects: r
642
642
  });
643
643
  if (!c) return a;
644
- const { left: d, top: l, width: u, height: f } = c, g = new tt(d + u / 2, l + f / 2);
644
+ const { left: d, top: l, width: u, height: f } = c, g = new et(d + u / 2, l + f / 2);
645
645
  return this.set({
646
646
  width: u,
647
647
  height: f
648
648
  }), this.setPositionByOrigin(g, "center", "center"), this.setCoords(), a;
649
649
  };
650
- const n = We.prototype.calcBoundingBox;
651
- We.prototype.calcBoundingBox = function(o, i) {
650
+ const n = ze.prototype.calcBoundingBox;
651
+ ze.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
- et.applyTextSelectionScalingLock({
657
+ st.applyTextSelectionScalingLock({
658
658
  selection: a,
659
659
  objects: o
660
660
  });
661
- const d = et.calculateActiveSelectionBounds({ objects: o });
661
+ const d = st.calculateActiveSelectionBounds({ objects: o });
662
662
  if (!d)
663
663
  return n.call(this, o, i);
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);
664
+ const { left: l, top: u, width: f, height: g } = d, p = new et(f, g), m = new et(l + f / 2, u + g / 2);
665
665
  return r === "initialization" ? {
666
666
  center: m,
667
- relativeCorrection: new tt(0, 0),
667
+ relativeCorrection: new et(0, 0),
668
668
  size: p
669
669
  } : {
670
670
  center: m,
@@ -694,7 +694,7 @@ class et {
694
694
  selection: t,
695
695
  objects: e
696
696
  }) {
697
- const s = e.some((n) => n instanceof ot);
697
+ const s = e.some((n) => n instanceof it);
698
698
  t.setControlsVisibility({
699
699
  mt: !s,
700
700
  mb: !s,
@@ -703,7 +703,7 @@ class et {
703
703
  });
704
704
  }
705
705
  }
706
- const P = class P {
706
+ const W = class W {
707
707
  constructor(t = []) {
708
708
  this.fonts = t;
709
709
  }
@@ -711,36 +711,36 @@ const P = class P {
711
711
  this.fonts = t;
712
712
  }
713
713
  loadFonts() {
714
- return z(this, null, function* () {
714
+ return P(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) => P.loadFont(o, e));
720
+ const s = t.map((o) => W.loadFont(o, e));
721
721
  yield Promise.allSettled(s);
722
722
  });
723
723
  }
724
724
  static loadFont(t, e) {
725
- return z(this, null, function* () {
725
+ return P(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 = 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);
729
+ const i = W.normalizeFontSource(o), a = W.getDescriptorSnapshot(t.descriptors), r = W.getFontRegistrationKey(n, i, a);
730
+ if (!W.registeredFontKeys.has(r)) {
731
+ if (W.isFontFaceAlreadyApplied(e, n, a)) {
732
+ W.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), P.registeredFontKeys.add(r);
738
+ e.fonts.add(u), W.registeredFontKeys.add(r);
739
739
  return;
740
740
  } catch (l) {
741
741
  console.warn(`Не удалось загрузить шрифт "${n}" через FontFace API`, l);
742
742
  }
743
- P.injectFontFace({
743
+ W.injectFontFace({
744
744
  font: t,
745
745
  source: i,
746
746
  doc: e,
@@ -760,15 +760,15 @@ const P = class P {
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 = P.descriptorsToCss(o), c = [
763
+ const r = W.descriptorsToCss(o), c = [
764
764
  "@font-face {",
765
- ` font-family: ${P.formatFontFamilyForCss(i)};`,
765
+ ` font-family: ${W.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), P.registeredFontKeys.add(n);
771
+ `), s.head.appendChild(a), W.registeredFontKeys.add(n);
772
772
  }
773
773
  static normalizeFontSource(t) {
774
774
  const e = t.trim();
@@ -791,15 +791,15 @@ const P = class P {
791
791
  return t ? t.trim().replace(/^['"]+|['"]+$/g, "").toLowerCase() : "";
792
792
  }
793
793
  static getDescriptorSnapshot(t) {
794
- const e = P.descriptorDefaults;
794
+ const e = W.descriptorDefaults;
795
795
  return {
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)
796
+ style: W.normalizeDescriptorValue(t == null ? void 0 : t.style, e.style),
797
+ weight: W.normalizeDescriptorValue(t == null ? void 0 : t.weight, e.weight),
798
+ stretch: W.normalizeDescriptorValue(t == null ? void 0 : t.stretch, e.stretch),
799
+ unicodeRange: W.normalizeDescriptorValue(t == null ? void 0 : t.unicodeRange, e.unicodeRange),
800
+ variant: W.normalizeDescriptorValue(t == null ? void 0 : t.variant, e.variant),
801
+ featureSettings: W.normalizeDescriptorValue(t == null ? void 0 : t.featureSettings, e.featureSettings),
802
+ display: W.normalizeDescriptorValue(t == null ? void 0 : t.display, e.display)
803
803
  };
804
804
  }
805
805
  static areDescriptorSnapshotsEqual(t, e) {
@@ -807,7 +807,7 @@ const P = class P {
807
807
  }
808
808
  static getFontRegistrationKey(t, e, s) {
809
809
  return [
810
- P.normalizeFamilyName(t),
810
+ W.normalizeFamilyName(t),
811
811
  e,
812
812
  s.style,
813
813
  s.weight,
@@ -821,12 +821,12 @@ const P = class P {
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 = P.normalizeFamilyName(e);
824
+ const o = W.normalizeFamilyName(e);
825
825
  let i = !1;
826
826
  try {
827
827
  n.forEach((a) => {
828
- if (i || P.normalizeFamilyName(a.family) !== o) return;
829
- const c = P.getDescriptorSnapshot({
828
+ if (i || W.normalizeFamilyName(a.family) !== o) return;
829
+ const c = W.getDescriptorSnapshot({
830
830
  style: a.style,
831
831
  weight: a.weight,
832
832
  stretch: a.stretch,
@@ -835,7 +835,7 @@ const P = class P {
835
835
  featureSettings: a.featureSettings,
836
836
  display: a.display
837
837
  });
838
- P.areDescriptorSnapshotsEqual(s, c) && (i = !0);
838
+ W.areDescriptorSnapshotsEqual(s, c) && (i = !0);
839
839
  });
840
840
  } catch (a) {
841
841
  return console.warn("Не удалось проверить, загружен ли шрифт ранее через FontFaceSet", a), !1;
@@ -862,7 +862,7 @@ const P = class P {
862
862
  });
863
863
  }
864
864
  };
865
- P.registeredFontKeys = /* @__PURE__ */ new Set(), P.descriptorDefaults = {
865
+ W.registeredFontKeys = /* @__PURE__ */ new Set(), W.descriptorDefaults = {
866
866
  style: "normal",
867
867
  weight: "normal",
868
868
  stretch: "normal",
@@ -871,8 +871,8 @@ P.registeredFontKeys = /* @__PURE__ */ new Set(), P.descriptorDefaults = {
871
871
  featureSettings: "normal",
872
872
  display: "auto"
873
873
  };
874
- let Se = P;
875
- const _s = "", Ns = "", xs = "", Bs = "", ks = "", Ws = "", zs = "", Ps = "", Gt = {
874
+ let Se = W;
875
+ const _s = "", xs = "", Ns = "", Bs = "", ks = "", zs = "", Ps = "", Ws = "", Vt = {
876
876
  style: {
877
877
  position: "absolute",
878
878
  display: "none",
@@ -940,16 +940,16 @@ const _s = "
940
940
  offsetTop: 50,
941
941
  icons: {
942
942
  copyPaste: _s,
943
- delete: Ps,
944
- lock: Ns,
945
- unlock: xs,
946
- bringToFront: Ws,
947
- sendToBack: zs,
943
+ delete: Ws,
944
+ lock: xs,
945
+ unlock: Ns,
946
+ bringToFront: zs,
947
+ sendToBack: Ps,
948
948
  bringForward: Bs,
949
949
  sendBackwards: ks
950
950
  },
951
951
  handlers: {
952
- copyPaste: (h) => z(null, null, function* () {
952
+ copyPaste: (h) => P(null, null, function* () {
953
953
  h.clipboardManager.copyPaste();
954
954
  }),
955
955
  delete: (h) => {
@@ -982,11 +982,11 @@ class Us {
982
982
  _initToolbar() {
983
983
  if (!this.options.showToolbar) return;
984
984
  const t = this.options.toolbar || {};
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 || {})
985
+ this.config = St(B(B({}, Vt), t), {
986
+ style: B(B({}, Vt.style), t.style || {}),
987
+ btnStyle: B(B({}, Vt.btnStyle), t.btnStyle || {}),
988
+ icons: B(B({}, Vt.icons), t.icons || {}),
989
+ handlers: B(B({}, Vt.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();
@@ -1211,8 +1211,6 @@ class Ee {
1211
1211
  }
1212
1212
  }
1213
1213
  const ns = [
1214
- "selectable",
1215
- "evented",
1216
1214
  "id",
1217
1215
  "backgroundId",
1218
1216
  "customData",
@@ -1222,6 +1220,8 @@ const ns = [
1222
1220
  "height",
1223
1221
  "locked",
1224
1222
  "editable",
1223
+ "evented",
1224
+ "selectable",
1225
1225
  "lockMovementX",
1226
1226
  "lockMovementY",
1227
1227
  "lockRotation",
@@ -1246,7 +1246,7 @@ const ns = [
1246
1246
  "radiusBottomRight",
1247
1247
  "radiusBottomLeft"
1248
1248
  ];
1249
- class Kt {
1249
+ class G {
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
  }
@@ -1260,48 +1260,7 @@ class Kt {
1260
1260
  _createDiffPatcher() {
1261
1261
  this.diffPatcher = Ms({
1262
1262
  objectHash(t) {
1263
- const e = t, s = t, n = s.styles ? JSON.stringify(s.styles) : "", o = e.customData ? JSON.stringify(e.customData) : "";
1264
- return [
1265
- e.id,
1266
- e.backgroundId,
1267
- e.format,
1268
- e.locked,
1269
- e.left,
1270
- e.top,
1271
- e.width,
1272
- e.height,
1273
- e.flipX,
1274
- e.flipY,
1275
- e.scaleX,
1276
- e.scaleY,
1277
- e.angle,
1278
- e.opacity,
1279
- o,
1280
- s.text,
1281
- s.textCaseRaw,
1282
- s.uppercase,
1283
- s.fontFamily,
1284
- s.fontSize,
1285
- s.fontWeight,
1286
- s.fontStyle,
1287
- s.underline,
1288
- s.linethrough,
1289
- s.textAlign,
1290
- s.fill,
1291
- s.stroke,
1292
- s.strokeWidth,
1293
- n,
1294
- s.paddingTop,
1295
- s.paddingRight,
1296
- s.paddingBottom,
1297
- s.paddingLeft,
1298
- s.backgroundColor,
1299
- s.backgroundOpacity,
1300
- s.radiusTopLeft,
1301
- s.radiusTopRight,
1302
- s.radiusBottomRight,
1303
- s.radiusBottomLeft
1304
- ].join("-");
1263
+ return [JSON.stringify(t)].join("-");
1305
1264
  },
1306
1265
  arrays: {
1307
1266
  detectMove: !0,
@@ -1359,17 +1318,167 @@ class Kt {
1359
1318
  }
1360
1319
  const e = this.getFullState();
1361
1320
  console.log("prevState", e);
1362
- const s = this.diffPatcher.diff(e, t);
1363
- if (!s) {
1321
+ const {
1322
+ prevState: s,
1323
+ nextState: n
1324
+ } = G._prepareStatesForDiff({
1325
+ prevState: e,
1326
+ nextState: t
1327
+ }), o = this.diffPatcher.diff(s, n);
1328
+ if (!o) {
1364
1329
  console.log("Нет изменений для сохранения.");
1365
1330
  return;
1366
1331
  }
1367
- console.log("baseState", this.baseState), this.currentIndex < this.patches.length && this.patches.splice(this.currentIndex), console.log("diff", s), this.totalChangesCount += 1, this.patches.push({ id: V(), diff: s }), this.currentIndex += 1, this.patches.length > this.maxHistoryLength && (this.baseState = this.diffPatcher.patch(this.baseState, this.patches[0].diff), this.patches.shift(), this.currentIndex -= 1, this.baseStateChangesCount += 1), console.log("Состояние сохранено. Текущий индекс истории:", this.currentIndex);
1332
+ console.log("baseState", this.baseState), this.currentIndex < this.patches.length && this.patches.splice(this.currentIndex), console.log("diff", o), this.totalChangesCount += 1, this.patches.push({ id: X(), diff: o }), this.currentIndex += 1, this.patches.length > this.maxHistoryLength && (this.baseState = this.diffPatcher.patch(this.baseState, this.patches[0].diff), this.patches.shift(), this.currentIndex -= 1, this.baseStateChangesCount += 1), console.log("Состояние сохранено. Текущий индекс истории:", this.currentIndex);
1368
1333
  } finally {
1369
1334
  this._isSavingState = !1;
1370
1335
  }
1371
1336
  }
1372
1337
  }
1338
+ /**
1339
+ * Подготавливает состояния для расчёта diff: нормализует технические изменения
1340
+ * и компенсирует смещения при ресайзе окна.
1341
+ */
1342
+ static _prepareStatesForDiff({
1343
+ prevState: t,
1344
+ nextState: e
1345
+ }) {
1346
+ const s = G._cloneState({ state: t }), n = G._cloneState({ state: e });
1347
+ return G._normalizeTextBackground({ objects: s.objects }), G._normalizeTextBackground({ objects: n.objects }), G._normalizeCanvasSize({
1348
+ prevState: s,
1349
+ nextState: n
1350
+ }), G._normalizeTranslation({
1351
+ prevState: s,
1352
+ nextState: n
1353
+ }), {
1354
+ prevState: s,
1355
+ nextState: n
1356
+ };
1357
+ }
1358
+ /**
1359
+ * Делает глубокую копию состояния канваса.
1360
+ * @param state - исходное состояние
1361
+ */
1362
+ static _cloneState({ state: t }) {
1363
+ return JSON.parse(JSON.stringify(t));
1364
+ }
1365
+ /**
1366
+ * Нормализует backgroundColor у текстовых объектов без фона, чтобы избежать шумовых диффов.
1367
+ * @param objects - список объектов канваса
1368
+ */
1369
+ static _normalizeTextBackground({ objects: t }) {
1370
+ for (let e = 0; e < t.length; e += 1) {
1371
+ const s = t[e], { type: n } = s, o = s.backgroundOpacity, i = typeof o == "number" ? o : 0;
1372
+ (n === "textbox" || n === "i-text" || n === "text") && (i > 0 || (s.backgroundColor = null));
1373
+ }
1374
+ }
1375
+ /**
1376
+ * Игнорирует изменения размеров канваса, если размер монтажной области не менялся.
1377
+ * Это устраняет диффы от ресайза окна без влияния на историю документа.
1378
+ */
1379
+ static _normalizeCanvasSize({
1380
+ prevState: t,
1381
+ nextState: e
1382
+ }) {
1383
+ const { width: s, height: n, objects: o } = t, { objects: i } = e, {
1384
+ width: a,
1385
+ height: r
1386
+ } = G._getMontageAreaSize({ objects: o }), {
1387
+ width: c,
1388
+ height: d
1389
+ } = G._getMontageAreaSize({ objects: i });
1390
+ a !== c || r !== d || (e.width = s, e.height = n);
1391
+ }
1392
+ /**
1393
+ * Компенсирует смещение монтажной области, чтобы не сохранять ресайз как изменение истории.
1394
+ */
1395
+ static _normalizeTranslation({
1396
+ prevState: t,
1397
+ nextState: e
1398
+ }) {
1399
+ const { objects: s, clipPath: n } = t, { objects: o, clipPath: i } = e, {
1400
+ left: a,
1401
+ top: r
1402
+ } = G._getMontageAreaPosition({ objects: s }), {
1403
+ left: c,
1404
+ top: d
1405
+ } = G._getMontageAreaPosition({ objects: o }), l = c - a, u = d - r;
1406
+ if (l === 0 && u === 0) return;
1407
+ const f = G._getObjectById({
1408
+ objects: o,
1409
+ id: "montage-area"
1410
+ });
1411
+ f && (f.left = a, f.top = r);
1412
+ const g = G._getClipPathPosition({ clipPath: n });
1413
+ if (g && i && typeof i == "object") {
1414
+ const { left: m, top: v } = g, w = i;
1415
+ w.left = m, w.top = v;
1416
+ }
1417
+ const p = G._getTranslationIgnoredIds();
1418
+ for (let m = 0; m < o.length; m += 1) {
1419
+ const v = o[m], { id: w } = v;
1420
+ w && p.has(w) || (typeof v.left == "number" && (v.left -= l), typeof v.top == "number" && (v.top -= u));
1421
+ }
1422
+ }
1423
+ /**
1424
+ * Возвращает позицию clipPath из состояния, если она доступна.
1425
+ */
1426
+ static _getClipPathPosition({
1427
+ clipPath: t
1428
+ }) {
1429
+ if (!t || typeof t != "object") return null;
1430
+ const { left: e, top: s } = t;
1431
+ return typeof e != "number" || typeof s != "number" ? null : { left: e, top: s };
1432
+ }
1433
+ /**
1434
+ * Возвращает позицию монтажной области из списка объектов.
1435
+ */
1436
+ static _getMontageAreaPosition({
1437
+ objects: t
1438
+ }) {
1439
+ const e = G._getObjectById({
1440
+ objects: t,
1441
+ id: "montage-area"
1442
+ });
1443
+ if (!e)
1444
+ return { left: 0, top: 0 };
1445
+ const { left: s = 0, top: n = 0 } = e;
1446
+ return { left: s, top: n };
1447
+ }
1448
+ /**
1449
+ * Возвращает размеры монтажной области из списка объектов.
1450
+ */
1451
+ static _getMontageAreaSize({
1452
+ objects: t
1453
+ }) {
1454
+ const e = G._getObjectById({
1455
+ objects: t,
1456
+ id: "montage-area"
1457
+ });
1458
+ if (!e)
1459
+ return { width: 0, height: 0 };
1460
+ const { width: s = 0, height: n = 0 } = e;
1461
+ return { width: s, height: n };
1462
+ }
1463
+ /**
1464
+ * Находит объект по id в массиве объектов канваса.
1465
+ */
1466
+ static _getObjectById({
1467
+ objects: t,
1468
+ id: e
1469
+ }) {
1470
+ for (let s = 0; s < t.length; s += 1) {
1471
+ const n = t[s];
1472
+ if (n.id === e) return n;
1473
+ }
1474
+ return null;
1475
+ }
1476
+ /**
1477
+ * Возвращает набор id объектов, которые не должны сдвигаться при нормализации.
1478
+ */
1479
+ static _getTranslationIgnoredIds() {
1480
+ return /* @__PURE__ */ new Set(["montage-area", "overlay-mask", "background"]);
1481
+ }
1373
1482
  /**
1374
1483
  * Создаёт безопасную копию состояния для загрузки в canvas.
1375
1484
  * customData сериализуется, чтобы Fabric не обрабатывал её как параметры объекта.
@@ -1411,7 +1520,7 @@ class Kt {
1411
1520
  for (let c = 0; c < i.length; c += 1) {
1412
1521
  const d = i[c], { id: l } = d;
1413
1522
  let u;
1414
- typeof l == "string" && (u = n.get(l)), u || (u = o.get(c)), u && (d.customData = Kt._cloneCustomData({ customData: u }));
1523
+ typeof l == "string" && (u = n.get(l)), u || (u = o.get(c)), u && (d.customData = G._cloneCustomData({ customData: u }));
1415
1524
  }
1416
1525
  }
1417
1526
  /**
@@ -1427,13 +1536,13 @@ class Kt {
1427
1536
  * @fires editor:history-state-loaded
1428
1537
  */
1429
1538
  loadStateFromFullState(t) {
1430
- return z(this, null, function* () {
1539
+ return P(this, null, function* () {
1431
1540
  if (!t) return;
1432
1541
  console.log("loadStateFromFullState fullState", t);
1433
1542
  const { canvas: e, canvasManager: s, interactionBlocker: n, backgroundManager: o } = this.editor, { width: i, height: a } = e;
1434
1543
  n.overlayMask = null;
1435
- const r = Kt._createLoadSafeState({ state: t });
1436
- yield e.loadFromJSON(r), Kt._applyCustomDataFromState({ state: t, canvas: e });
1544
+ const r = G._createLoadSafeState({ state: t });
1545
+ yield e.loadFromJSON(r), G._applyCustomDataFromState({ state: t, canvas: e });
1437
1546
  const c = e.getObjects().find((u) => u.id === "montage-area");
1438
1547
  c && (this.editor.montageArea = c, (i !== e.getWidth() || a !== e.getHeight()) && s.updateCanvas());
1439
1548
  const d = e.getObjects().find((u) => u.id === "overlay-mask");
@@ -1454,7 +1563,7 @@ class Kt {
1454
1563
  * @fires editor:undo
1455
1564
  */
1456
1565
  undo() {
1457
- return z(this, null, function* () {
1566
+ return P(this, null, function* () {
1458
1567
  if (!this.skipHistory) {
1459
1568
  if (this.saveState(), this.currentIndex <= 0) {
1460
1569
  console.log("Нет предыдущих состояний для отмены.");
@@ -1491,9 +1600,9 @@ class Kt {
1491
1600
  * @fires editor:redo
1492
1601
  */
1493
1602
  redo() {
1494
- return z(this, null, function* () {
1603
+ return P(this, null, function* () {
1495
1604
  if (!this.skipHistory) {
1496
- if (this.saveState(), this.currentIndex >= this.patches.length) {
1605
+ if (this.currentIndex >= this.patches.length) {
1497
1606
  console.log("Нет состояний для повтора.");
1498
1607
  return;
1499
1608
  }
@@ -1546,7 +1655,7 @@ class Kt {
1546
1655
  }
1547
1656
  }
1548
1657
  }
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 = [
1658
+ const Hs = 0.1, Zs = 2, Ze = 0.1, Gs = 90, _t = 16, xt = 16, jt = 4096, It = 4096, Ge = "application/image-editor:", ie = [
1550
1659
  "format",
1551
1660
  "uppercase",
1552
1661
  "textCaseRaw",
@@ -1561,7 +1670,7 @@ const Hs = 0.1, Zs = 2, Ze = 0.1, Gs = 90, Rt = 16, _t = 16, At = 4096, jt = 409
1561
1670
  "radiusBottomRight",
1562
1671
  "radiusBottomLeft"
1563
1672
  ], Vs = 50;
1564
- class ht {
1673
+ class ut {
1565
1674
  constructor({ editor: t }) {
1566
1675
  this.editor = t, this.options = t.options, this._createdBlobUrls = [], this.acceptContentTypes = this.editor.options.acceptContentTypes, this.acceptFormats = this.getAllowedFormatsFromContentTypes();
1567
1676
  }
@@ -1578,7 +1687,7 @@ class ht {
1578
1687
  * @returns возвращает Promise с объектом изображения или null в случае ошибки
1579
1688
  */
1580
1689
  importImage(t) {
1581
- return z(this, null, function* () {
1690
+ return P(this, null, function* () {
1582
1691
  const {
1583
1692
  source: e,
1584
1693
  scale: s = `image-${this.options.scaleType}`,
@@ -1590,7 +1699,7 @@ class ht {
1590
1699
  customData: c = null
1591
1700
  } = t;
1592
1701
  if (!e) return null;
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;
1702
+ const { canvas: d, montageArea: l, transformManager: u, historyManager: f, errorManager: g } = this.editor, p = yield this.getContentType(e), m = ut.getFormatFromContentType(p), { acceptContentTypes: v, acceptFormats: w } = this;
1594
1703
  if (!this.isAllowedContentType(p)) {
1595
1704
  const A = `Неверный contentType для изображения: ${p}. Ожидается один из: ${this.acceptContentTypes.join(", ")}.`;
1596
1705
  return g.emitError({
@@ -1603,7 +1712,7 @@ class ht {
1603
1712
  format: m,
1604
1713
  contentType: p,
1605
1714
  acceptContentTypes: v,
1606
- acceptFormats: S,
1715
+ acceptFormats: w,
1607
1716
  fromClipboard: o,
1608
1717
  isBackground: i,
1609
1718
  withoutSelection: a,
@@ -1631,7 +1740,7 @@ class ht {
1631
1740
  format: m,
1632
1741
  contentType: p,
1633
1742
  acceptContentTypes: v,
1634
- acceptFormats: S,
1743
+ acceptFormats: w,
1635
1744
  fromClipboard: o,
1636
1745
  isBackground: i,
1637
1746
  withoutSelection: a,
@@ -1640,27 +1749,27 @@ class ht {
1640
1749
  }
1641
1750
  }), null;
1642
1751
  if (this._createdBlobUrls.push(A), m === "svg") {
1643
- const w = yield us(A);
1644
- y = ut.groupSVGElements(w.objects, w.options);
1752
+ const S = yield us(A);
1753
+ y = ft.groupSVGElements(S.objects, S.options);
1645
1754
  } else
1646
- y = yield Zt.fromURL(A, { crossOrigin: "anonymous" });
1755
+ y = yield Gt.fromURL(A, { crossOrigin: "anonymous" });
1647
1756
  const { width: b, height: j } = y;
1648
- if (y instanceof Zt) {
1649
- const w = y.getElement();
1757
+ if (y instanceof Gt) {
1758
+ const S = y.getElement();
1650
1759
  let T = "";
1651
- if (w instanceof HTMLImageElement ? T = w.src : w instanceof HTMLCanvasElement && (T = w.toDataURL()), j > jt || b > At) {
1760
+ if (S instanceof HTMLImageElement ? T = S.src : S instanceof HTMLCanvasElement && (T = S.toDataURL()), j > It || b > jt) {
1652
1761
  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) {
1762
+ this._createdBlobUrls.push(C), y = yield Gt.fromURL(C, { crossOrigin: "anonymous" });
1763
+ } else if (j < xt || b < _t) {
1655
1764
  const M = yield this.resizeImageToBoundaries(T, "min"), C = URL.createObjectURL(M);
1656
- this._createdBlobUrls.push(C), y = yield Zt.fromURL(C, { crossOrigin: "anonymous" });
1765
+ this._createdBlobUrls.push(C), y = yield Gt.fromURL(C, { crossOrigin: "anonymous" });
1657
1766
  }
1658
1767
  }
1659
- if (y.set("id", `${y.type}-${V()}`), y.set("format", m), y.set("customData", c || null), s === "scale-montage")
1768
+ if (y.set("id", `${y.type}-${X()}`), y.set("format", m), y.set("customData", c || null), s === "scale-montage")
1660
1769
  this.editor.canvasManager.scaleMontageAreaToImage({ object: y, withoutSave: !0 });
1661
1770
  else {
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 });
1771
+ const { width: S, height: T } = l, M = this.calculateScaleFactor({ imageObject: y, scaleType: s });
1772
+ s === "image-contain" && M < 1 ? u.fitObject({ object: y, type: "contain", withoutSave: !0 }) : s === "image-cover" && (b > S || j > T) && u.fitObject({ object: y, type: "cover", withoutSave: !0 });
1664
1773
  }
1665
1774
  const I = {
1666
1775
  image: y,
@@ -1707,16 +1816,16 @@ class ht {
1707
1816
  * @returns возвращает Promise с Blob-объектом уменьшенного изображения
1708
1817
  */
1709
1818
  resizeImageToBoundaries(t, e = "max") {
1710
- return z(this, null, function* () {
1711
- let s = `Размер изображения больше максимального размера канваса, поэтому оно будет уменьшено до максимальных размеров c сохранением пропорций: ${At}x${jt}`;
1712
- e === "min" && (s = `Размер изображения меньше минимального размера канваса, поэтому оно будет увеличено до минимальных размеров c сохранением пропорций: ${Rt}x${_t}`);
1819
+ return P(this, null, function* () {
1820
+ let s = `Размер изображения больше максимального размера канваса, поэтому оно будет уменьшено до максимальных размеров c сохранением пропорций: ${jt}x${It}`;
1821
+ e === "min" && (s = `Размер изображения меньше минимального размера канваса, поэтому оно будет увеличено до минимальных размеров c сохранением пропорций: ${_t}x${xt}`);
1713
1822
  const n = {
1714
1823
  dataURL: t,
1715
1824
  sizeType: e,
1716
- maxWidth: At,
1717
- maxHeight: jt,
1718
- minWidth: Rt,
1719
- minHeight: _t
1825
+ maxWidth: jt,
1826
+ maxHeight: It,
1827
+ minWidth: _t,
1828
+ minHeight: xt
1720
1829
  };
1721
1830
  return this.editor.errorManager.emitWarning({
1722
1831
  origin: "ImageManager",
@@ -1739,7 +1848,7 @@ class ht {
1739
1848
  * @fires editor:canvas-exported
1740
1849
  */
1741
1850
  exportCanvasAsImageFile() {
1742
- return z(this, arguments, function* (t = {}) {
1851
+ return P(this, arguments, function* (t = {}) {
1743
1852
  const {
1744
1853
  fileName: e = "image.png",
1745
1854
  contentType: s = "image/png",
@@ -1747,12 +1856,12 @@ class ht {
1747
1856
  exportAsBlob: o = !1
1748
1857
  } = t, { canvas: i, montageArea: a, workerManager: r, interactionBlocker: c } = this.editor;
1749
1858
  try {
1750
- const d = s === "application/pdf", l = d ? "image/jpg" : s, u = ht.getFormatFromContentType(l);
1859
+ const d = s === "application/pdf", l = d ? "image/jpg" : s, u = ut.getFormatFromContentType(l);
1751
1860
  a.setCoords();
1752
1861
  const { left: f, top: g, width: p, height: m } = a.getBoundingRect(), v = yield i.clone(["id", "format", "locked"]);
1753
1862
  v.enableRetinaScaling = !1, ["image/jpg", "image/jpeg"].includes(l) && (v.backgroundColor = "#ffffff");
1754
- const S = v.getObjects().find((M) => M.id === a.id);
1755
- if (S && (S.visible = !1), c != null && c.isBlocked) {
1863
+ const w = v.getObjects().find((M) => M.id === a.id);
1864
+ if (w && (w.visible = !1), c != null && c.isBlocked) {
1756
1865
  const M = v.getObjects().find((C) => C.id === c.overlayMask.id);
1757
1866
  M && (M.visible = !1);
1758
1867
  }
@@ -1762,7 +1871,7 @@ class ht {
1762
1871
  const M = v.toSVG();
1763
1872
  v.dispose();
1764
1873
  const E = {
1765
- image: ht._exportSVGStringAsFile(M, {
1874
+ image: ut._exportSVGStringAsFile(M, {
1766
1875
  exportAsBase64: n,
1767
1876
  exportAsBlob: o,
1768
1877
  fileName: e
@@ -1793,27 +1902,27 @@ class ht {
1793
1902
  [b]
1794
1903
  );
1795
1904
  if (d) {
1796
- const C = p * 0.264583, E = m * 0.264583, W = (yield this.editor.moduleLoader.loadModule("jspdf")).jsPDF, N = new W({
1905
+ const C = p * 0.264583, E = m * 0.264583, z = (yield this.editor.moduleLoader.loadModule("jspdf")).jsPDF, x = new z({
1797
1906
  orientation: C > E ? "landscape" : "portrait",
1798
1907
  unit: "mm",
1799
1908
  format: [C, E]
1800
1909
  });
1801
- if (N.addImage(String(j), "JPG", 0, 0, C, E), n) {
1910
+ if (x.addImage(String(j), "JPG", 0, 0, C, E), n) {
1802
1911
  const H = {
1803
- image: N.output("datauristring"),
1912
+ image: x.output("datauristring"),
1804
1913
  format: "pdf",
1805
1914
  contentType: "application/pdf",
1806
1915
  fileName: e
1807
1916
  };
1808
1917
  return i.fire("editor:canvas-exported", H), H;
1809
1918
  }
1810
- const x = N.output("blob"), G = {
1811
- image: new File([x], e, { type: "application/pdf" }),
1919
+ const N = x.output("blob"), V = {
1920
+ image: new File([N], e, { type: "application/pdf" }),
1812
1921
  format: "pdf",
1813
1922
  contentType: "application/pdf",
1814
1923
  fileName: e
1815
1924
  };
1816
- return i.fire("editor:canvas-exported", G), G;
1925
+ return i.fire("editor:canvas-exported", V), V;
1817
1926
  }
1818
1927
  if (n) {
1819
1928
  const M = {
@@ -1854,7 +1963,7 @@ class ht {
1854
1963
  * @fires editor:object-exported
1855
1964
  */
1856
1965
  exportObjectAsImageFile() {
1857
- return z(this, arguments, function* (t = {}) {
1966
+ return P(this, arguments, function* (t = {}) {
1858
1967
  const {
1859
1968
  object: e,
1860
1969
  fileName: s = "image.png",
@@ -1871,9 +1980,9 @@ class ht {
1871
1980
  data: { contentType: n, fileName: s, exportAsBase64: o, exportAsBlob: i }
1872
1981
  }), null;
1873
1982
  try {
1874
- const d = ht.getFormatFromContentType(n);
1983
+ const d = ut.getFormatFromContentType(n);
1875
1984
  if (d === "svg") {
1876
- const p = c.toSVG(), m = ht._exportSVGStringAsFile(p, {
1985
+ const p = c.toSVG(), m = ut._exportSVGStringAsFile(p, {
1877
1986
  exportAsBase64: o,
1878
1987
  exportAsBlob: i,
1879
1988
  fileName: s
@@ -1886,7 +1995,7 @@ class ht {
1886
1995
  };
1887
1996
  return a.fire("editor:object-exported", v), v;
1888
1997
  }
1889
- if (o && c instanceof Zt) {
1998
+ if (o && c instanceof Gt) {
1890
1999
  const p = yield createImageBitmap(c.getElement()), m = yield r.post(
1891
2000
  "toDataURL",
1892
2001
  {
@@ -1951,7 +2060,7 @@ class ht {
1951
2060
  * @returns массив допустимых форматов изображений
1952
2061
  */
1953
2062
  getAllowedFormatsFromContentTypes() {
1954
- return this.acceptContentTypes.map((t) => ht.getFormatFromContentType(t)).filter((t) => t);
2063
+ return this.acceptContentTypes.map((t) => ut.getFormatFromContentType(t)).filter((t) => t);
1955
2064
  }
1956
2065
  /**
1957
2066
  * Проверяет, является ли contentType допустимым типом изображения.
@@ -1967,7 +2076,7 @@ class ht {
1967
2076
  * @public
1968
2077
  */
1969
2078
  getContentType(t) {
1970
- return z(this, null, function* () {
2079
+ return P(this, null, function* () {
1971
2080
  return typeof t == "string" ? this.getContentTypeFromUrl(t) : t.type || "application/octet-stream";
1972
2081
  });
1973
2082
  }
@@ -1978,7 +2087,7 @@ class ht {
1978
2087
  * @public
1979
2088
  */
1980
2089
  getContentTypeFromUrl(t) {
1981
- return z(this, null, function* () {
2090
+ return P(this, null, function* () {
1982
2091
  if (t.startsWith("data:")) {
1983
2092
  const e = t.match(/^data:([^;]+)/);
1984
2093
  return e ? e[1] : "application/octet-stream";
@@ -2004,7 +2113,7 @@ class ht {
2004
2113
  try {
2005
2114
  const n = (e = new URL(t).pathname.split(".").pop()) == null ? void 0 : e.toLowerCase(), o = {};
2006
2115
  return this.acceptContentTypes.forEach((i) => {
2007
- const a = ht.getFormatFromContentType(i);
2116
+ const a = ut.getFormatFromContentType(i);
2008
2117
  a && (o[a] = i);
2009
2118
  }), n && o[n] || "application/octet-stream";
2010
2119
  } catch (s) {
@@ -2057,7 +2166,7 @@ class ht {
2057
2166
  return e ? e[1] : "";
2058
2167
  }
2059
2168
  }
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);
2169
+ const mt = (h, t, e) => Math.max(Math.min(h, e), t), Ve = (h, t) => h * t, Xs = (h, t) => new et(h / 2, t / 2);
2061
2170
  function Ks(h) {
2062
2171
  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";
2063
2172
  }
@@ -2081,16 +2190,16 @@ class Qs {
2081
2190
  * Если точка находится за пределами монтажной области, она проецируется на ближайшую границу монтажной области.
2082
2191
  */
2083
2192
  getVisibleCenterPoint() {
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(
2193
+ 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 = mt(
2085
2194
  a,
2086
2195
  e.left - c,
2087
2196
  e.left + c
2088
- ), u = pt(
2197
+ ), u = mt(
2089
2198
  r,
2090
2199
  e.top - d,
2091
2200
  e.top + d
2092
2201
  );
2093
- return new tt(l, u);
2202
+ return new et(l, u);
2094
2203
  }
2095
2204
  /**
2096
2205
  * Устанавливаем внутреннюю ширину канваса (для экспорта)
@@ -2108,7 +2217,7 @@ class Qs {
2108
2217
  canvas: o,
2109
2218
  montageArea: i,
2110
2219
  options: { canvasBackstoreWidth: a }
2111
- } = this.editor, { width: r, height: c } = i, d = pt(Number(t), Rt, At);
2220
+ } = this.editor, { width: r, height: c } = i, d = mt(Number(t), _t, jt);
2112
2221
  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) {
2113
2222
  const p = d / r, m = Ve(c, p);
2114
2223
  this.setResolutionHeight(m);
@@ -2138,7 +2247,7 @@ class Qs {
2138
2247
  canvas: o,
2139
2248
  montageArea: i,
2140
2249
  options: { canvasBackstoreHeight: a }
2141
- } = this.editor, { width: r, height: c } = i, d = pt(Number(t), _t, jt);
2250
+ } = this.editor, { width: r, height: c } = i, d = mt(Number(t), xt, It);
2142
2251
  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) {
2143
2252
  const p = d / c, m = Ve(r, p);
2144
2253
  this.setResolutionWidth(m);
@@ -2191,7 +2300,7 @@ class Qs {
2191
2300
  */
2192
2301
  setCanvasBackstoreWidth(t) {
2193
2302
  if (!t || typeof t != "number") return;
2194
- const e = pt(t, Rt, At);
2303
+ const e = mt(t, _t, jt);
2195
2304
  this.editor.canvas.setDimensions({ width: e }, { backstoreOnly: !0 });
2196
2305
  }
2197
2306
  /**
@@ -2200,7 +2309,7 @@ class Qs {
2200
2309
  */
2201
2310
  setCanvasBackstoreHeight(t) {
2202
2311
  if (!t || typeof t != "number") return;
2203
- const e = pt(t, _t, jt);
2312
+ const e = mt(t, xt, It);
2204
2313
  this.editor.canvas.setDimensions({ height: e }, { backstoreOnly: !0 });
2205
2314
  }
2206
2315
  /**
@@ -2209,7 +2318,7 @@ class Qs {
2209
2318
  * с учётом минимальных и максимальных значений.
2210
2319
  */
2211
2320
  adaptCanvasToContainer() {
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);
2321
+ const { canvas: t } = this.editor, e = this.getEditorContainer(), s = e.clientWidth, n = e.clientHeight, o = mt(s, _t, jt), i = mt(n, xt, It);
2213
2322
  t.setDimensions({ width: o, height: i }, { backstoreOnly: !0 });
2214
2323
  }
2215
2324
  /**
@@ -2411,13 +2520,13 @@ class Qs {
2411
2520
  } = this.editor, c = t || n.getActiveObject();
2412
2521
  if (!Ks(c)) return;
2413
2522
  const { width: d, height: l } = c;
2414
- let u = Math.min(d, At), f = Math.min(l, jt);
2523
+ let u = Math.min(d, jt), f = Math.min(l, It);
2415
2524
  if (e) {
2416
2525
  const {
2417
2526
  width: g,
2418
2527
  height: p
2419
- } = o, m = d / g, v = l / p, S = Math.max(m, v);
2420
- u = g * S, f = p * S;
2528
+ } = o, m = d / g, v = l / p, w = Math.max(m, v);
2529
+ u = g * w, f = p * w;
2421
2530
  }
2422
2531
  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", {
2423
2532
  object: c,
@@ -2581,9 +2690,9 @@ class Js {
2581
2690
  * @private
2582
2691
  */
2583
2692
  _fitSingleObject(t, e) {
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;
2693
+ 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, w = n.height;
2585
2694
  let A;
2586
- e === "contain" ? A = Math.min(v / p, S / m) : A = Math.max(v / p, S / m), t.set({
2695
+ e === "contain" ? A = Math.min(v / p, w / m) : A = Math.max(v / p, w / m), t.set({
2587
2696
  scaleX: a * A,
2588
2697
  scaleY: r * A
2589
2698
  }), s.centerObject(t);
@@ -2703,9 +2812,9 @@ class qs {
2703
2812
  * @private
2704
2813
  */
2705
2814
  _calculateEmptySpaceRatio(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;
2815
+ 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, w = g > d;
2816
+ if (!(p || m || v || w)) return 0;
2817
+ 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), S = Math.max(y, b), T = Math.max(j, I), M = S / o, C = T / i;
2709
2818
  return Math.max(M, C);
2710
2819
  }
2711
2820
  /**
@@ -2722,8 +2831,8 @@ class qs {
2722
2831
  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;
2723
2832
  if (Math.abs(g) / f <= 0.1)
2724
2833
  return { x: l, y: u };
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 };
2834
+ const m = c / 2, v = d / 2, w = a.left, A = a.top, y = m - w * s, b = v - A * s, j = (y - r[4]) / (e - s), I = (b - r[5]) / (e - s), S = j * f, T = I * f, M = S * o, C = T * o, E = Math.abs(M) > Math.abs(l) ? l : M, z = Math.abs(C) > Math.abs(u) ? u : C;
2835
+ return { x: E, y: z };
2727
2836
  }
2728
2837
  /**
2729
2838
  * Применяет плавное центрирование viewport при приближении к defaultZoom.
@@ -2813,7 +2922,7 @@ class qs {
2813
2922
  zoom(t = Ze, e = {}) {
2814
2923
  var f, g;
2815
2924
  if (!t) return;
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);
2925
+ 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 et(c, d);
2817
2926
  this.editor.montageArea.setCoords(), this.editor.canvas.requestRenderAll();
2818
2927
  let u = Number((a + Number(t)).toFixed(2));
2819
2928
  u > n && (u = n), u < s && (u = s), o.zoomToPoint(l, u), this.editor.panConstraintManager.updateBounds(), this._applyViewportCentering(u, i, t), o.fire("editor:zoom-changed", {
@@ -2828,7 +2937,7 @@ class qs {
2828
2937
  * @fires editor:zoom-changed
2829
2938
  */
2830
2939
  setZoom(t = this.defaultZoom) {
2831
- const { minZoom: e, maxZoom: s } = this, { canvas: n } = this.editor, o = new tt(n.getCenterPoint());
2940
+ const { minZoom: e, maxZoom: s } = this, { canvas: n } = this.editor, o = new et(n.getCenterPoint());
2832
2941
  let i = t;
2833
2942
  t > s && (i = s), t < e && (i = e), n.zoomToPoint(o, i), n.fire("editor:zoom-changed", {
2834
2943
  currentZoom: n.getZoom(),
@@ -2841,7 +2950,7 @@ class qs {
2841
2950
  * @fires editor:zoom-changed
2842
2951
  */
2843
2952
  resetZoom() {
2844
- const { canvas: t } = this.editor, e = new tt(t.getCenterPoint());
2953
+ const { canvas: t } = this.editor, e = new et(t.getCenterPoint());
2845
2954
  t.zoomToPoint(e, this.defaultZoom), this.editor.canvas.fire("editor:zoom-changed", {
2846
2955
  currentZoom: t.getZoom(),
2847
2956
  point: e
@@ -2905,7 +3014,7 @@ class $s {
2905
3014
  }), t.upperCanvasEl.style.pointerEvents = "", t.lowerCanvasEl.style.pointerEvents = "", this.overlayMask.visible = !1, t.requestRenderAll(), t.fire("editor:enabled"), s.resumeHistory();
2906
3015
  }
2907
3016
  }
2908
- class Ot {
3017
+ class Lt {
2909
3018
  constructor({ editor: t }) {
2910
3019
  this.editor = t, this.backgroundObject = null;
2911
3020
  }
@@ -2931,7 +3040,7 @@ class Ot {
2931
3040
  }
2932
3041
  a.set({
2933
3042
  fill: t,
2934
- backgroundId: `background-${V()}`
3043
+ backgroundId: `background-${X()}`
2935
3044
  }), this.editor.canvas.requestRenderAll();
2936
3045
  } else
2937
3046
  this._removeCurrentBackground(), this._createColorBackground(t);
@@ -2968,14 +3077,14 @@ class Ot {
2968
3077
  try {
2969
3078
  const { historyManager: i } = this.editor, { backgroundObject: a } = this;
2970
3079
  if (i.suspendHistory(), a && a.backgroundType === "gradient") {
2971
- const r = Ot._createFabricGradient(t);
2972
- if (Ot._isGradientEqual(a.fill, r)) {
3080
+ const r = Lt._createFabricGradient(t);
3081
+ if (Lt._isGradientEqual(a.fill, r)) {
2973
3082
  i.resumeHistory();
2974
3083
  return;
2975
3084
  }
2976
3085
  a.set({
2977
3086
  fill: r,
2978
- backgroundId: `background-${V()}`
3087
+ backgroundId: `background-${X()}`
2979
3088
  }), this.editor.canvas.requestRenderAll();
2980
3089
  } else
2981
3090
  this._removeCurrentBackground(), this._createGradientBackground(t);
@@ -3063,7 +3172,7 @@ class Ot {
3063
3172
  * @param options.withoutSave - Если true, не сохранять состояние в историю
3064
3173
  */
3065
3174
  setImageBackground(o) {
3066
- return z(this, arguments, function* ({
3175
+ return P(this, arguments, function* ({
3067
3176
  imageSource: t,
3068
3177
  customData: e = {},
3069
3178
  fromTemplate: s = !1,
@@ -3133,7 +3242,7 @@ class Ot {
3133
3242
  hasControls: !1,
3134
3243
  id: "background",
3135
3244
  backgroundType: "color",
3136
- backgroundId: `background-${V()}`
3245
+ backgroundId: `background-${X()}`
3137
3246
  }, { withoutSelection: !0 }), this.refresh();
3138
3247
  }
3139
3248
  /**
@@ -3150,9 +3259,9 @@ class Ot {
3150
3259
  hasControls: !1,
3151
3260
  id: "background",
3152
3261
  backgroundType: "gradient",
3153
- backgroundId: `background-${V()}`
3262
+ backgroundId: `background-${X()}`
3154
3263
  }, { withoutSelection: !0 }), this.refresh();
3155
- const e = Ot._createFabricGradient(t);
3264
+ const e = Lt._createFabricGradient(t);
3156
3265
  this.backgroundObject.set("fill", e), this.editor.canvas.requestRenderAll();
3157
3266
  }
3158
3267
  /**
@@ -3160,7 +3269,7 @@ class Ot {
3160
3269
  * @param source - источник изображения (URL или File)
3161
3270
  */
3162
3271
  _createImageBackground(t, e) {
3163
- return z(this, null, function* () {
3272
+ return P(this, null, function* () {
3164
3273
  var n;
3165
3274
  const { image: s } = (n = yield this.editor.imageManager.importImage({
3166
3275
  source: t,
@@ -3178,7 +3287,7 @@ class Ot {
3178
3287
  hasControls: !1,
3179
3288
  id: "background",
3180
3289
  backgroundType: "image",
3181
- backgroundId: `background-${V()}`,
3290
+ backgroundId: `background-${X()}`,
3182
3291
  customData: e
3183
3292
  }), this._removeCurrentBackground(), this.backgroundObject = s, this.refresh();
3184
3293
  });
@@ -3212,8 +3321,8 @@ class Ot {
3212
3321
  { offset: 0, color: "#000000" },
3213
3322
  { offset: 1, color: "#ffffff" }
3214
3323
  ], t.type === "linear") {
3215
- const u = t.angle * Math.PI / 180, f = Ot._angleToCoords(u);
3216
- return new ze({
3324
+ const u = t.angle * Math.PI / 180, f = Lt._angleToCoords(u);
3325
+ return new Pe({
3217
3326
  type: "linear",
3218
3327
  gradientUnits: "percentage",
3219
3328
  coords: f,
@@ -3232,7 +3341,7 @@ class Ot {
3232
3341
  r1: 0,
3233
3342
  r2: d / 100
3234
3343
  };
3235
- return new ze({
3344
+ return new Pe({
3236
3345
  type: "radial",
3237
3346
  gradientUnits: "percentage",
3238
3347
  coords: l,
@@ -3421,13 +3530,13 @@ class tn {
3421
3530
  */
3422
3531
  addRectangle(d = {}, { withoutSelection: r, withoutAdding: c } = {}) {
3423
3532
  var l = d, {
3424
- id: t = `rect-${V()}`,
3533
+ id: t = `rect-${X()}`,
3425
3534
  left: e,
3426
3535
  top: s,
3427
3536
  width: n = 100,
3428
3537
  height: o = 100,
3429
3538
  fill: i = "blue"
3430
- } = l, a = gt(l, [
3539
+ } = l, a = pt(l, [
3431
3540
  "id",
3432
3541
  "left",
3433
3542
  "top",
@@ -3463,12 +3572,12 @@ class tn {
3463
3572
  */
3464
3573
  addCircle(c = {}, { withoutSelection: a, withoutAdding: r } = {}) {
3465
3574
  var d = c, {
3466
- id: t = `circle-${V()}`,
3575
+ id: t = `circle-${X()}`,
3467
3576
  left: e,
3468
3577
  top: s,
3469
3578
  radius: n = 50,
3470
3579
  fill: o = "green"
3471
- } = d, i = gt(d, [
3580
+ } = d, i = pt(d, [
3472
3581
  "id",
3473
3582
  "left",
3474
3583
  "top",
@@ -3503,13 +3612,13 @@ class tn {
3503
3612
  */
3504
3613
  addTriangle(d = {}, { withoutSelection: r, withoutAdding: c } = {}) {
3505
3614
  var l = d, {
3506
- id: t = `triangle-${V()}`,
3615
+ id: t = `triangle-${X()}`,
3507
3616
  left: e,
3508
3617
  top: s,
3509
3618
  width: n = 100,
3510
3619
  height: o = 100,
3511
3620
  fill: i = "yellow"
3512
- } = l, a = gt(l, [
3621
+ } = l, a = pt(l, [
3513
3622
  "id",
3514
3623
  "left",
3515
3624
  "top",
@@ -3556,7 +3665,7 @@ class en {
3556
3665
  * Асинхронное клонирование для внутреннего буфера
3557
3666
  */
3558
3667
  _cloneToInternalClipboard(t) {
3559
- return z(this, null, function* () {
3668
+ return P(this, null, function* () {
3560
3669
  const { canvas: e, errorManager: s } = this.editor;
3561
3670
  try {
3562
3671
  const n = yield t.clone(ie);
@@ -3576,7 +3685,7 @@ class en {
3576
3685
  * Копирование в системный буфер обмена
3577
3686
  */
3578
3687
  _copyToSystemClipboard(t) {
3579
- return z(this, null, function* () {
3688
+ return P(this, null, function* () {
3580
3689
  const { errorManager: e } = this.editor;
3581
3690
  if (typeof ClipboardItem == "undefined" || !navigator.clipboard)
3582
3691
  return e.emitWarning({
@@ -3603,7 +3712,7 @@ class en {
3603
3712
  * Копирование изображения в буфер обмена
3604
3713
  */
3605
3714
  _copyImageToClipboard(t, e) {
3606
- return z(this, null, function* () {
3715
+ return P(this, null, function* () {
3607
3716
  try {
3608
3717
  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);
3609
3718
  for (let l = 0; l < a.length; l += 1)
@@ -3625,7 +3734,7 @@ class en {
3625
3734
  * Копирование текста в буфер обмена
3626
3735
  */
3627
3736
  _copyTextToClipboard(t) {
3628
- return z(this, null, function* () {
3737
+ return P(this, null, function* () {
3629
3738
  try {
3630
3739
  const e = `${Ge}${t}`;
3631
3740
  return yield navigator.clipboard.writeText(e), console.info("Text copied to clipboard successfully"), !0;
@@ -3660,7 +3769,7 @@ class en {
3660
3769
  * @param source - источник изображения (data URL или URL)
3661
3770
  */
3662
3771
  _handleImageImport(t) {
3663
- return z(this, null, function* () {
3772
+ return P(this, null, function* () {
3664
3773
  var s;
3665
3774
  const { image: e } = (s = yield this.editor.imageManager.importImage({
3666
3775
  source: t,
@@ -3676,18 +3785,18 @@ class en {
3676
3785
  * @fires editor:object-pasted
3677
3786
  */
3678
3787
  copyPaste(t) {
3679
- return z(this, null, function* () {
3788
+ return P(this, null, function* () {
3680
3789
  const { canvas: e } = this.editor, s = t || e.getActiveObject();
3681
3790
  if (!s || s.locked) return !1;
3682
3791
  try {
3683
3792
  const n = yield s.clone(ie);
3684
3793
  return n instanceof U && n.forEachObject((o) => {
3685
3794
  o.set({
3686
- id: `${o.type}-${V()}`,
3795
+ id: `${o.type}-${X()}`,
3687
3796
  evented: !0
3688
3797
  });
3689
3798
  }), n.set({
3690
- id: `${n.type}-${V()}`,
3799
+ id: `${n.type}-${X()}`,
3691
3800
  left: n.left + 10,
3692
3801
  top: n.top + 10,
3693
3802
  evented: !0
@@ -3711,7 +3820,7 @@ class en {
3711
3820
  * @param event.clipboardData.items — элементы буфера обмена
3712
3821
  */
3713
3822
  handlePasteEvent(e) {
3714
- return z(this, arguments, function* ({ clipboardData: t }) {
3823
+ return P(this, arguments, function* ({ clipboardData: t }) {
3715
3824
  var r;
3716
3825
  if (!((r = t == null ? void 0 : t.items) != null && r.length)) {
3717
3826
  this.paste();
@@ -3762,18 +3871,18 @@ class en {
3762
3871
  * @fires editor:object-pasted
3763
3872
  */
3764
3873
  paste() {
3765
- return z(this, null, function* () {
3874
+ return P(this, null, function* () {
3766
3875
  const { canvas: t } = this.editor;
3767
3876
  if (!this.clipboard) return !1;
3768
3877
  try {
3769
3878
  const e = yield this.clipboard.clone(ie);
3770
3879
  return t.discardActiveObject(), e instanceof U && e.forEachObject((s) => {
3771
3880
  s.set({
3772
- id: `${s.type}-${V()}`,
3881
+ id: `${s.type}-${X()}`,
3773
3882
  evented: !0
3774
3883
  });
3775
3884
  }), e.set({
3776
- id: `${e.type}-${V()}`,
3885
+ id: `${e.type}-${X()}`,
3777
3886
  left: e.left + 10,
3778
3887
  top: e.top + 10,
3779
3888
  evented: !0
@@ -3819,7 +3928,7 @@ class he {
3819
3928
  };
3820
3929
  i.set(a), !e && he._isGroupOrSelection(i) && i.getObjects().forEach((c) => {
3821
3930
  c.set(a);
3822
- }), i instanceof ot && i.isEditing && i.exitEditing(), n.renderAll(), s || o.saveState(), n.fire("editor:object-locked", {
3931
+ }), i instanceof it && i.isEditing && i.exitEditing(), n.renderAll(), s || o.saveState(), n.fire("editor:object-locked", {
3823
3932
  object: i,
3824
3933
  skipInnerObjects: e,
3825
3934
  withoutSave: s
@@ -3854,7 +3963,7 @@ class he {
3854
3963
  });
3855
3964
  }
3856
3965
  static _isGroupOrSelection(t) {
3857
- return t instanceof U || t instanceof Et;
3966
+ return t instanceof U || t instanceof Ot;
3858
3967
  }
3859
3968
  }
3860
3969
  class sn {
@@ -3877,20 +3986,20 @@ class sn {
3877
3986
  */
3878
3987
  _getGroupsToUngroup(t) {
3879
3988
  if (Array.isArray(t)) {
3880
- const s = t.filter((n) => n instanceof Et);
3989
+ const s = t.filter((n) => n instanceof Ot);
3881
3990
  return s.length > 0 ? s : null;
3882
3991
  }
3883
3992
  if (t instanceof U) {
3884
- const s = t.getObjects().filter((n) => n instanceof Et);
3993
+ const s = t.getObjects().filter((n) => n instanceof Ot);
3885
3994
  return s.length > 0 ? s : null;
3886
3995
  }
3887
3996
  const e = t || this.editor.canvas.getActiveObject();
3888
3997
  if (!e) return null;
3889
3998
  if (e instanceof U) {
3890
- const s = e.getObjects().filter((n) => n instanceof Et);
3999
+ const s = e.getObjects().filter((n) => n instanceof Ot);
3891
4000
  return s.length > 0 ? s : null;
3892
4001
  }
3893
- return e instanceof Et ? [e] : null;
4002
+ return e instanceof Ot ? [e] : null;
3894
4003
  }
3895
4004
  /**
3896
4005
  * Группировка объектов
@@ -3907,8 +4016,8 @@ class sn {
3907
4016
  if (!o) return null;
3908
4017
  try {
3909
4018
  n.suspendHistory();
3910
- const i = new Et(o, {
3911
- id: `group-${V()}`
4019
+ const i = new Ot(o, {
4020
+ id: `group-${X()}`
3912
4021
  });
3913
4022
  o.forEach((r) => s.remove(r)), s.add(i), s.setActiveObject(i), s.requestRenderAll();
3914
4023
  const a = {
@@ -4035,7 +4144,7 @@ class Oe {
4035
4144
  return n.fire("editor:objects-deleted", c), c;
4036
4145
  }
4037
4146
  }
4038
- const St = {
4147
+ const At = {
4039
4148
  IMAGE_MANAGER: {
4040
4149
  /**
4041
4150
  * Некорректный Content-Type изображения
@@ -4219,7 +4328,7 @@ class Qt {
4219
4328
  * @returns true, если код допустим, иначе false
4220
4329
  */
4221
4330
  static isValidErrorCode(t) {
4222
- return t ? Object.values(St).some((e) => Object.values(e).includes(t)) : !1;
4331
+ return t ? Object.values(At).some((e) => Object.values(e).includes(t)) : !1;
4223
4332
  }
4224
4333
  }
4225
4334
  class on {
@@ -4307,11 +4416,11 @@ class on {
4307
4416
  this.currentBounds = this.calculatePanBounds();
4308
4417
  }
4309
4418
  }
4310
- const dt = ({
4419
+ const lt = ({
4311
4420
  value: h,
4312
4421
  min: t,
4313
4422
  max: e
4314
- }) => Math.min(Math.max(h, t), e), Dt = class Dt extends ot {
4423
+ }) => Math.min(Math.max(h, t), e), Rt = class Rt extends it {
4315
4424
  constructor(t, e = {}) {
4316
4425
  var s, n, o, i, a, r, c, d, l;
4317
4426
  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();
@@ -4332,11 +4441,11 @@ const dt = ({
4332
4441
  }
4333
4442
  _getNonTransformedDimensions() {
4334
4443
  const { width: t, height: e } = this._getBackgroundDimensions();
4335
- return new tt(t, e).scalarAdd(this.strokeWidth);
4444
+ return new et(t, e).scalarAdd(this.strokeWidth);
4336
4445
  }
4337
4446
  _getTransformedDimensions(t = {}) {
4338
4447
  const { width: e, height: s } = this._getBackgroundDimensions();
4339
- return super._getTransformedDimensions(wt(B({}, t), {
4448
+ return super._getTransformedDimensions(St(B({}, t), {
4340
4449
  width: e,
4341
4450
  height: s
4342
4451
  }));
@@ -4346,7 +4455,7 @@ const dt = ({
4346
4455
  */
4347
4456
  toObject(t = []) {
4348
4457
  const e = super.toObject(t);
4349
- return wt(B({}, e), {
4458
+ return St(B({}, e), {
4350
4459
  backgroundOpacity: this.backgroundOpacity,
4351
4460
  paddingTop: this.paddingTop,
4352
4461
  paddingRight: this.paddingRight,
@@ -4363,7 +4472,7 @@ const dt = ({
4363
4472
  const e = this._getEffectiveBackgroundFill();
4364
4473
  if (e && e) {
4365
4474
  const o = this._getPadding(), i = (s = this.width) != null ? s : 0, a = (n = this.height) != null ? n : 0, r = i + o.left + o.right, c = a + o.top + o.bottom, d = this._getCornerRadii({ width: r, height: c }), l = this._getLeftOffset() - o.left, u = this._getTopOffset() - o.top;
4366
- t.save(), Dt._renderRoundedRect({
4475
+ t.save(), Rt._renderRoundedRect({
4367
4476
  ctx: t,
4368
4477
  height: c,
4369
4478
  left: l,
@@ -4385,10 +4494,10 @@ const dt = ({
4385
4494
  var i, a, r, c;
4386
4495
  const s = t / 2, n = e / 2, o = Math.min(s, n);
4387
4496
  return {
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 })
4497
+ bottomLeft: lt({ value: (i = this.radiusBottomLeft) != null ? i : 0, min: 0, max: o }),
4498
+ bottomRight: lt({ value: (a = this.radiusBottomRight) != null ? a : 0, min: 0, max: o }),
4499
+ topLeft: lt({ value: (r = this.radiusTopLeft) != null ? r : 0, min: 0, max: o }),
4500
+ topRight: lt({ value: (c = this.radiusTopRight) != null ? c : 0, min: 0, max: o })
4392
4501
  };
4393
4502
  }
4394
4503
  _getPadding() {
@@ -4404,7 +4513,7 @@ const dt = ({
4404
4513
  var n;
4405
4514
  const t = this.backgroundColor;
4406
4515
  if (!t) return null;
4407
- const e = dt({ value: (n = this.backgroundOpacity) != null ? n : 1, min: 0, max: 1 });
4516
+ const e = lt({ value: (n = this.backgroundOpacity) != null ? n : 1, min: 0, max: 1 });
4408
4517
  let s;
4409
4518
  try {
4410
4519
  s = new ms(t);
@@ -4432,7 +4541,7 @@ const dt = ({
4432
4541
  topRight: d,
4433
4542
  bottomRight: l,
4434
4543
  bottomLeft: u
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 });
4544
+ } = n, f = lt({ value: c, min: 0, max: i }), g = lt({ value: d, min: 0, max: i }), p = lt({ value: l, min: 0, max: i }), m = lt({ value: u, min: 0, max: i });
4436
4545
  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();
4437
4546
  }
4438
4547
  /**
@@ -4446,8 +4555,8 @@ const dt = ({
4446
4555
  s !== t && (this.width = Math.max(0, s)), n !== e && (this.height = Math.max(0, n));
4447
4556
  }
4448
4557
  };
4449
- Dt.type = "background-textbox", Dt.cacheProperties = [
4450
- ...Array.isArray(ot.cacheProperties) ? ot.cacheProperties : [],
4558
+ Rt.type = "background-textbox", Rt.cacheProperties = [
4559
+ ...Array.isArray(it.cacheProperties) ? it.cacheProperties : [],
4451
4560
  "backgroundColor",
4452
4561
  "backgroundOpacity",
4453
4562
  "paddingTop",
@@ -4458,8 +4567,8 @@ Dt.type = "background-textbox", Dt.cacheProperties = [
4458
4567
  "radiusTopRight",
4459
4568
  "radiusBottomRight",
4460
4569
  "radiusBottomLeft"
4461
- ], Dt.stateProperties = [
4462
- ...Array.isArray(ot.stateProperties) ? ot.stateProperties : [],
4570
+ ], Rt.stateProperties = [
4571
+ ...Array.isArray(it.stateProperties) ? it.stateProperties : [],
4463
4572
  "backgroundColor",
4464
4573
  "backgroundOpacity",
4465
4574
  "paddingTop",
@@ -4471,10 +4580,10 @@ Dt.type = "background-textbox", Dt.cacheProperties = [
4471
4580
  "radiusBottomRight",
4472
4581
  "radiusBottomLeft"
4473
4582
  ];
4474
- let ue = Dt;
4583
+ let ue = Rt;
4475
4584
  const an = () => {
4476
4585
  var h;
4477
- (h = Pe) != null && h.setClass && Pe.setClass(ue, "background-textbox");
4586
+ (h = We) != null && h.setClass && We.setClass(ue, "background-textbox");
4478
4587
  }, rn = ({ textbox: h }) => {
4479
4588
  var s, n;
4480
4589
  if (!h.isEditing) return null;
@@ -4514,7 +4623,7 @@ const an = () => {
4514
4623
  );
4515
4624
  if (s.length)
4516
4625
  return (n = s[0]) == null ? void 0 : n[e];
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;
4626
+ }, 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() : "", tt = 0.01;
4518
4627
  class k {
4519
4628
  constructor({ editor: t }) {
4520
4629
  var e;
@@ -4558,7 +4667,7 @@ class k {
4558
4667
  this.isTextEditingActive = !1, this.editor.historyManager.saveState();
4559
4668
  }, Vs);
4560
4669
  }, this._handleObjectScaling = (s) => {
4561
- var te, xt, Bt, kt, Wt, zt, Pt, Ut, Ft, X, Tt, ee, Mt;
4670
+ var te, Bt, kt, zt, Pt, Wt, Ut, Ft, Yt, K, Et, ee, wt;
4562
4671
  const { target: n, transform: o } = s;
4563
4672
  if (n instanceof U || !k._isTextbox(n) || !o) return;
4564
4673
  n.isScaling = !0;
@@ -4569,124 +4678,124 @@ class k {
4569
4678
  basePadding: d,
4570
4679
  baseRadii: l,
4571
4680
  baseStyles: u
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;
4681
+ } = i, f = typeof ((te = o.original) == null ? void 0 : te.width) == "number" ? o.original.width : void 0, g = typeof ((Bt = o.original) == null ? void 0 : Bt.left) == "number" ? o.original.left : void 0, p = f != null ? f : a, m = g != null ? g : r, v = (kt = o.corner) != null ? kt : "", w = (zt = o.action) != null ? zt : "", A = ["ml", "mr"].includes(v) || w === "scaleX", y = ["mt", "mb"].includes(v) || w === "scaleY", b = ["tl", "tr", "bl", "br"].includes(v) || w === "scale", j = b || y;
4573
4682
  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), {
4683
+ const I = Math.abs((Wt = (Pt = n.scaleX) != null ? Pt : o.scaleX) != null ? Wt : 1) || 1, S = Math.abs((Ft = (Ut = n.scaleY) != null ? Ut : o.scaleY) != null ? Ft : 1) || 1, T = Math.max(1, p * I), M = Math.max(1, Math.round(T)), C = Math.max(1, c * S), {
4575
4684
  paddingTop: E = 0,
4576
- paddingRight: W = 0,
4577
- paddingBottom: N = 0,
4578
- paddingLeft: x = 0,
4685
+ paddingRight: z = 0,
4686
+ paddingBottom: x = 0,
4687
+ paddingLeft: N = 0,
4579
4688
  radiusTopLeft: Y = 0,
4580
- radiusTopRight: G = 0,
4581
- radiusBottomRight: K = 0,
4689
+ radiusTopRight: V = 0,
4690
+ radiusBottomRight: Q = 0,
4582
4691
  radiusBottomLeft: H = 0,
4583
4692
  fontSize: R,
4584
4693
  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]) => {
4694
+ originX: at = "left"
4695
+ } = n, Z = b || y, nt = b || y, F = Z ? {
4696
+ top: Math.max(0, d.top * S),
4697
+ right: Math.max(0, d.right * S),
4698
+ bottom: Math.max(0, d.bottom * S),
4699
+ left: Math.max(0, d.left * S)
4700
+ } : d, $ = nt ? {
4701
+ topLeft: Math.max(0, l.topLeft * S),
4702
+ topRight: Math.max(0, l.topRight * S),
4703
+ bottomRight: Math.max(0, l.bottomRight * S),
4704
+ bottomLeft: Math.max(0, l.bottomLeft * S)
4705
+ } : l, ot = Object.keys(u).length > 0;
4706
+ let q;
4707
+ if (j && ot) {
4708
+ const Ht = {};
4709
+ Object.entries(u).forEach(([Zt, De]) => {
4601
4710
  if (!De) return;
4602
4711
  const fe = {};
4603
4712
  Object.entries(De).forEach(([cs, se]) => {
4604
4713
  if (!se) return;
4605
4714
  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);
4715
+ typeof se.fontSize == "number" && (Re.fontSize = Math.max(1, se.fontSize * S)), fe[cs] = Re;
4716
+ }), Object.keys(fe).length && (Ht[Zt] = fe);
4717
+ }), Object.keys(Ht).length && (q = Ht);
4609
4718
  }
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) {
4719
+ const vt = (K = (Yt = o.originX) != null ? Yt : at) != null ? K : "left", Ct = m + p, rt = m + p / 2, gt = O != null ? O : p, ct = M !== gt, Nt = Math.abs(C - (R != null ? R : c)) > tt, bt = Math.abs(F.top - E) > tt || Math.abs(F.right - z) > tt || Math.abs(F.bottom - x) > tt || Math.abs(F.left - N) > tt, Jt = Math.abs($.topLeft - Y) > tt || Math.abs($.topRight - V) > tt || Math.abs($.bottomRight - Q) > tt || Math.abs($.bottomLeft - H) > tt;
4720
+ if (!ct && !Nt && !bt && !Jt) {
4612
4721
  n.set({ scaleX: 1, scaleY: 1 }), o.scaleX = 1, o.scaleY = 1;
4613
4722
  return;
4614
4723
  }
4615
- J && (n.styles = J), n.set({
4724
+ q && (n.styles = q), n.set({
4616
4725
  width: M,
4617
4726
  fontSize: j ? C : c,
4618
4727
  paddingTop: F.top,
4619
4728
  paddingRight: F.right,
4620
4729
  paddingBottom: F.bottom,
4621
4730
  paddingLeft: F.left,
4622
- radiusTopLeft: q.topLeft,
4623
- radiusTopRight: q.topRight,
4624
- radiusBottomRight: q.bottomRight,
4625
- radiusBottomLeft: q.bottomLeft,
4731
+ radiusTopLeft: $.topLeft,
4732
+ radiusTopRight: $.topRight,
4733
+ radiusBottomRight: $.bottomRight,
4734
+ radiusBottomLeft: $.bottomLeft,
4626
4735
  scaleX: 1,
4627
4736
  scaleY: 1
4628
4737
  });
4629
4738
  const qt = k._roundTextboxDimensions({ textbox: n });
4630
4739
  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 = {
4740
+ const Tt = (Et = n.width) != null ? Et : M, $t = Tt !== gt;
4741
+ let dt = m;
4742
+ $t && (A || b) && (vt === "right" ? dt = Ct - Tt : vt === "center" && (dt = rt - Tt / 2)), n.set({ left: dt }), i.baseLeft = dt, o.scaleX = 1, o.scaleY = 1;
4743
+ const { original: Mt } = o;
4744
+ Mt && (Mt.scaleX = 1, Mt.scaleY = 1, Mt.width = Tt, Mt.height = n.height, Mt.left = dt), n.setCoords(), this.canvas.requestRenderAll(), i.baseWidth = Tt, i.baseFontSize = (ee = n.fontSize) != null ? ee : C, i.baseStyles = JSON.parse(JSON.stringify((wt = n.styles) != null ? wt : {})), i.basePadding = {
4636
4745
  top: F.top,
4637
4746
  right: F.right,
4638
4747
  bottom: F.bottom,
4639
4748
  left: F.left
4640
4749
  }, i.baseRadii = {
4641
- topLeft: q.topLeft,
4642
- topRight: q.topRight,
4643
- bottomRight: q.bottomRight,
4644
- bottomLeft: q.bottomLeft
4645
- }, i.hasWidthChange = $t || Nt || vt || Jt || qt;
4750
+ topLeft: $.topLeft,
4751
+ topRight: $.topRight,
4752
+ bottomRight: $.bottomRight,
4753
+ bottomLeft: $.bottomLeft
4754
+ }, i.hasWidthChange = $t || Nt || bt || Jt || qt;
4646
4755
  }, this._handleObjectModified = (s) => {
4647
- var S, A, y;
4756
+ var w, A, y;
4648
4757
  const { target: n } = s;
4649
4758
  if (n instanceof U) {
4650
4759
  const b = n.getObjects();
4651
4760
  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;
4761
+ const { scaleX: I = 1, scaleY: S = 1 } = n;
4762
+ if (Math.abs(I - 1) < tt && Math.abs(S - 1) < tt) return;
4654
4763
  this.canvas.discardActiveObject(), b.forEach((M) => {
4655
- var C, E, W, N;
4764
+ var C, E, z, x;
4656
4765
  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, {
4766
+ const N = (C = M.scaleX) != null ? C : 1, Y = (E = M.scaleY) != null ? E : 1, V = ((z = M.fontSize) != null ? z : 16) * Y, Q = ((x = M.width) != null ? x : 0) * N, H = Y, {
4658
4767
  paddingTop: R = 0,
4659
4768
  paddingRight: O = 0,
4660
- paddingBottom: it = 0,
4769
+ paddingBottom: at = 0,
4661
4770
  paddingLeft: Z = 0,
4662
- radiusTopLeft: st = 0,
4771
+ radiusTopLeft: nt = 0,
4663
4772
  radiusTopRight: F = 0,
4664
- radiusBottomRight: q = 0,
4665
- radiusBottomLeft: nt = 0,
4666
- styles: J
4667
- } = M, yt = {
4773
+ radiusBottomRight: $ = 0,
4774
+ radiusBottomLeft: ot = 0,
4775
+ styles: q
4776
+ } = M, vt = {
4668
4777
  paddingTop: Math.max(0, R * H),
4669
4778
  paddingRight: Math.max(0, O * H),
4670
- paddingBottom: Math.max(0, it * H),
4779
+ paddingBottom: Math.max(0, at * H),
4671
4780
  paddingLeft: Math.max(0, Z * H)
4672
- }, It = {
4673
- radiusTopLeft: Math.max(0, st * H),
4781
+ }, Ct = {
4782
+ radiusTopLeft: Math.max(0, nt * H),
4674
4783
  radiusTopRight: Math.max(0, F * H),
4675
- radiusBottomRight: Math.max(0, q * H),
4676
- radiusBottomLeft: Math.max(0, nt * H)
4784
+ radiusBottomRight: Math.max(0, $ * H),
4785
+ radiusBottomLeft: Math.max(0, ot * H)
4677
4786
  };
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));
4787
+ let rt = q;
4788
+ q && Object.keys(q).length > 0 && (rt = JSON.parse(JSON.stringify(q)), Object.values(rt).forEach((gt) => {
4789
+ Object.values(gt).forEach((ct) => {
4790
+ typeof ct.fontSize == "number" && (ct.fontSize = Math.max(1, ct.fontSize * H));
4682
4791
  });
4683
- })), M.set(wt(B(B({
4684
- fontSize: G,
4685
- width: K,
4792
+ })), M.set(St(B(B({
4793
+ fontSize: V,
4794
+ width: Q,
4686
4795
  scaleX: 1,
4687
4796
  scaleY: 1
4688
- }, yt), It), {
4689
- styles: at
4797
+ }, vt), Ct), {
4798
+ styles: rt
4690
4799
  })), k._roundTextboxDimensions({ textbox: M });
4691
4800
  }
4692
4801
  M.setCoords();
@@ -4701,7 +4810,7 @@ class k {
4701
4810
  n.isScaling = !1;
4702
4811
  const o = this.scalingState.get(n);
4703
4812
  if (this.scalingState.delete(n), !(o != null && o.hasWidthChange)) return;
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), {
4813
+ const i = (w = n.width) != null ? w : 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), {
4705
4814
  paddingTop: c = 0,
4706
4815
  paddingRight: d = 0,
4707
4816
  paddingBottom: l = 0,
@@ -4732,9 +4841,9 @@ class k {
4732
4841
  * @param options — настройки текста
4733
4842
  * @param flags — флаги поведения
4734
4843
  */
4735
- addText(W = {}, { withoutSelection: M = !1, withoutSave: C = !1, withoutAdding: E = !1 } = {}) {
4736
- var N = W, {
4737
- id: t = `text-${V()}`,
4844
+ addText(z = {}, { withoutSelection: M = !1, withoutSave: C = !1, withoutAdding: E = !1 } = {}) {
4845
+ var x = z, {
4846
+ id: t = `text-${X()}`,
4738
4847
  text: e = "Новый текст",
4739
4848
  fontFamily: s,
4740
4849
  fontSize: n = 48,
@@ -4751,14 +4860,14 @@ class k {
4751
4860
  backgroundColor: p,
4752
4861
  backgroundOpacity: m = 1,
4753
4862
  paddingTop: v = 0,
4754
- paddingRight: S = 0,
4863
+ paddingRight: w = 0,
4755
4864
  paddingBottom: A = 0,
4756
4865
  paddingLeft: y = 0,
4757
4866
  radiusTopLeft: b = 0,
4758
4867
  radiusTopRight: j = 0,
4759
4868
  radiusBottomRight: I = 0,
4760
- radiusBottomLeft: w = 0
4761
- } = N, T = gt(N, [
4869
+ radiusBottomLeft: S = 0
4870
+ } = x, T = pt(x, [
4762
4871
  "id",
4763
4872
  "text",
4764
4873
  "fontFamily",
@@ -4785,14 +4894,14 @@ class k {
4785
4894
  "radiusBottomLeft"
4786
4895
  ]);
4787
4896
  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({
4897
+ const { historyManager: N } = this.editor, { canvas: Y } = this;
4898
+ N.suspendHistory();
4899
+ const V = s != null ? s : this._getDefaultFontFamily(), Q = Qe({ width: f }), H = Ke({
4791
4900
  strokeColor: u,
4792
- width: K
4901
+ width: Q
4793
4902
  }), R = B({
4794
4903
  id: t,
4795
- fontFamily: G,
4904
+ fontFamily: V,
4796
4905
  fontSize: n,
4797
4906
  fontWeight: o ? "bold" : "normal",
4798
4907
  fontStyle: i ? "italic" : "normal",
@@ -4802,27 +4911,27 @@ class k {
4802
4911
  textAlign: d,
4803
4912
  fill: l,
4804
4913
  stroke: H,
4805
- strokeWidth: K,
4914
+ strokeWidth: Q,
4806
4915
  strokeUniform: !0,
4807
4916
  opacity: g,
4808
4917
  backgroundColor: p,
4809
4918
  backgroundOpacity: m,
4810
4919
  paddingTop: v,
4811
- paddingRight: S,
4920
+ paddingRight: w,
4812
4921
  paddingBottom: A,
4813
4922
  paddingLeft: y,
4814
4923
  radiusTopLeft: b,
4815
4924
  radiusTopRight: j,
4816
4925
  radiusBottomRight: I,
4817
- radiusBottomLeft: w
4926
+ radiusBottomLeft: S
4818
4927
  }, T), O = new ue(e, R);
4819
4928
  if (O.textCaseRaw = (Z = O.text) != null ? Z : "", r) {
4820
- const st = pe({ value: O.textCaseRaw });
4821
- st !== O.text && O.set({ text: st });
4929
+ const nt = pe({ value: O.textCaseRaw });
4930
+ nt !== O.text && O.set({ text: nt });
4822
4931
  }
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", {
4932
+ 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(), N.resumeHistory(), C || N.saveState(), Y.fire("editor:text-added", {
4824
4933
  textbox: O,
4825
- options: wt(B({}, R), {
4934
+ options: St(B({}, R), {
4826
4935
  text: e,
4827
4936
  bold: o,
4828
4937
  italic: i,
@@ -4830,7 +4939,7 @@ class k {
4830
4939
  align: d,
4831
4940
  color: l,
4832
4941
  strokeColor: H,
4833
- strokeWidth: K
4942
+ strokeWidth: Q
4834
4943
  }),
4835
4944
  flags: {
4836
4945
  withoutSelection: !!M,
@@ -4848,40 +4957,40 @@ class k {
4848
4957
  * @param options.skipRender — не вызывать перерисовку канваса
4849
4958
  */
4850
4959
  updateText({ target: t, style: e = {}, withoutSave: s, skipRender: n } = {}) {
4851
- var xt, kt, Wt, zt, Pt, Ut, Ft;
4960
+ var Bt, zt, Pt, Wt, Ut, Ft, Yt;
4852
4961
  const o = this._resolveTextObject(t);
4853
4962
  if (!o) return null;
4854
4963
  const { historyManager: i } = this.editor, { canvas: a } = this;
4855
4964
  i.suspendHistory();
4856
- const r = k._getSnapshot(o), c = (xt = o.originY) != null ? xt : "top", d = o.getPointByOrigin("center", c), l = {
4965
+ const r = k._getSnapshot(o), c = (Bt = o.originY) != null ? Bt : "top", d = o.getPointByOrigin("center", c), l = {
4857
4966
  originY: c,
4858
4967
  x: d.x,
4859
4968
  y: d.y
4860
- }, Bt = e, {
4969
+ }, kt = e, {
4861
4970
  text: u,
4862
4971
  fontFamily: f,
4863
4972
  fontSize: g,
4864
4973
  bold: p,
4865
4974
  italic: m,
4866
4975
  underline: v,
4867
- uppercase: S,
4976
+ uppercase: w,
4868
4977
  strikethrough: A,
4869
4978
  align: y,
4870
4979
  color: b,
4871
4980
  strokeColor: j,
4872
4981
  strokeWidth: I,
4873
- opacity: w,
4982
+ opacity: S,
4874
4983
  backgroundColor: T,
4875
4984
  backgroundOpacity: M,
4876
4985
  paddingTop: C,
4877
4986
  paddingRight: E,
4878
- paddingBottom: W,
4879
- paddingLeft: N,
4880
- radiusTopLeft: x,
4987
+ paddingBottom: z,
4988
+ paddingLeft: x,
4989
+ radiusTopLeft: N,
4881
4990
  radiusTopRight: Y,
4882
- radiusBottomRight: G,
4883
- radiusBottomLeft: K
4884
- } = Bt, H = gt(Bt, [
4991
+ radiusBottomRight: V,
4992
+ radiusBottomLeft: Q
4993
+ } = kt, H = pt(kt, [
4885
4994
  "text",
4886
4995
  "fontFamily",
4887
4996
  "fontSize",
@@ -4905,57 +5014,57 @@ class k {
4905
5014
  "radiusTopRight",
4906
5015
  "radiusBottomRight",
4907
5016
  "radiusBottomLeft"
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));
5017
+ ]), R = B({}, H), O = rn({ textbox: o }), at = O ? k._expandRangeToFullLines({ textbox: o, range: O }) : null, Z = {}, nt = {}, F = {}, $ = dn({ textbox: o, range: O }), ot = !O || $, q = !O;
5018
+ if (f !== void 0 && (at && (nt.fontFamily = f), ot && (R.fontFamily = f, q && (F.fontFamily = f))), g !== void 0 && (at && (nt.fontSize = g), ot && (R.fontSize = g, q && (F.fontSize = g))), p !== void 0) {
5019
+ const K = p ? "bold" : "normal";
5020
+ O && (Z.fontWeight = K), ot && (R.fontWeight = K, q && (F.fontWeight = K));
4912
5021
  }
4913
5022
  if (m !== void 0) {
4914
- const X = m ? "italic" : "normal";
4915
- O && (Z.fontStyle = X), nt && (R.fontStyle = X, J && (F.fontStyle = X));
5023
+ const K = m ? "italic" : "normal";
5024
+ O && (Z.fontStyle = K), ot && (R.fontStyle = K, q && (F.fontStyle = K));
4916
5025
  }
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
5026
+ if (v !== void 0 && (O && (Z.underline = v), ot && (R.underline = v, q && (F.underline = v))), A !== void 0 && (O && (Z.linethrough = A), ot && (R.linethrough = A, q && (F.linethrough = A))), y !== void 0 && (R.textAlign = y), b !== void 0 && (O && (Z.fill = b), ot && (R.fill = b, q && (F.fill = b))), j !== void 0 || I !== void 0) {
5027
+ const K = O ? Xe({ textbox: o, range: O, property: "strokeWidth" }) : void 0, Et = O ? Xe({ textbox: o, range: O, property: "stroke" }) : void 0, ee = (Pt = (zt = I != null ? I : K) != null ? zt : o.strokeWidth) != null ? Pt : 0, wt = Qe({ width: ee }), Ht = (Ut = (Wt = j != null ? j : Et) != null ? Wt : o.stroke) != null ? Ut : void 0, Zt = Ke({
5028
+ strokeColor: Ht,
5029
+ width: wt
4921
5030
  });
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;
5031
+ O && (Z.stroke = Zt, Z.strokeWidth = wt), ot && (R.stroke = Zt, R.strokeWidth = wt, q && (F.stroke = Zt, F.strokeWidth = wt));
5032
+ }
5033
+ S !== void 0 && (R.opacity = S), T !== void 0 && (R.backgroundColor = T), M !== void 0 && (R.backgroundOpacity = M), C !== void 0 && (R.paddingTop = C), E !== void 0 && (R.paddingRight = E), z !== void 0 && (R.paddingBottom = z), x !== void 0 && (R.paddingLeft = x), N !== void 0 && (R.radiusTopLeft = N), Y !== void 0 && (R.radiusTopRight = Y), V !== void 0 && (R.radiusBottomRight = V), Q !== void 0 && (R.radiusBottomLeft = Q);
5034
+ const vt = (Yt = o.textCaseRaw) != null ? Yt : (Ft = o.text) != null ? Ft : "", Ct = !!o.uppercase, rt = u !== void 0, gt = rt ? u != null ? u : "" : vt, ct = w != null ? w : Ct, Nt = ct !== Ct;
5035
+ if (rt || Nt) {
5036
+ const K = ct ? pe({ value: gt }) : gt;
5037
+ R.text = K, o.textCaseRaw = gt;
5038
+ } else o.textCaseRaw === void 0 && (o.textCaseRaw = vt);
5039
+ o.uppercase = ct, o.set(R);
5040
+ let bt = !1;
4932
5041
  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;
5042
+ const K = ge({ textbox: o, styles: Z, range: O }), Et = at ? ge({ textbox: o, styles: nt, range: at }) : !1;
5043
+ bt = K || Et;
4935
5044
  } else if (Object.keys(F).length) {
4936
- const X = cn({ textbox: o });
4937
- X && (vt = ge({ textbox: o, styles: F, range: X }));
5045
+ const K = cn({ textbox: o });
5046
+ K && (bt = ge({ textbox: o, styles: F, range: K }));
4938
5047
  }
4939
- const Jt = vt && k._hasLayoutAffectingStyles({
5048
+ const Jt = bt && k._hasLayoutAffectingStyles({
4940
5049
  stylesList: [
4941
5050
  Z,
4942
- st,
5051
+ nt,
4943
5052
  F
4944
5053
  ]
4945
5054
  });
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);
5055
+ bt && (o.dirty = !0), Jt && (o.initDimensions(), o.dirty = !0), (T !== void 0 || M !== void 0 || C !== void 0 || E !== void 0 || z !== void 0 || x !== void 0 || N !== void 0 || Y !== void 0 || V !== void 0 || Q !== void 0) && (o.dirty = !0);
4947
5056
  const qt = k._hasLayoutAffectingStyles({
4948
5057
  stylesList: [
4949
5058
  R,
4950
5059
  Z,
4951
- st,
5060
+ nt,
4952
5061
  F
4953
5062
  ]
4954
- }), $t = !Object.prototype.hasOwnProperty.call(R, "width") && (at || Nt || qt);
4955
- let ct = !1;
4956
- $t && (ct = this._autoExpandTextboxWidth(o, {
5063
+ }), $t = !Object.prototype.hasOwnProperty.call(R, "width") && (rt || Nt || qt);
5064
+ let dt = !1;
5065
+ $t && (dt = this._autoExpandTextboxWidth(o, {
4957
5066
  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();
5067
+ }), dt && (o.dirty = !0)), (dt ? !1 : k._roundTextboxDimensions({ textbox: o })) && (o.dirty = !0), o.setCoords(), n || a.requestRenderAll(), i.resumeHistory(), s || i.saveState();
4959
5068
  const te = k._getSnapshot(o);
4960
5069
  return a.fire("editor:text-updated", {
4961
5070
  textbox: o,
@@ -4983,7 +5092,7 @@ class k {
4983
5092
  * Возвращает активный текст или ищет по id.
4984
5093
  */
4985
5094
  _resolveTextObject(t) {
4986
- if (t instanceof ot) return t;
5095
+ if (t instanceof it) return t;
4987
5096
  const { canvas: e } = this;
4988
5097
  if (!t) {
4989
5098
  const s = e.getActiveObject();
@@ -4999,7 +5108,7 @@ class k {
4999
5108
  * Проверяет, является ли объект текстовым блоком редактора.
5000
5109
  */
5001
5110
  static _isTextbox(t) {
5002
- return !!t && t instanceof ot;
5111
+ return !!t && t instanceof it;
5003
5112
  }
5004
5113
  /**
5005
5114
  * Вешает обработчики событий Fabric для работы с текстом.
@@ -5013,7 +5122,7 @@ class k {
5013
5122
  * но не шире монтажной области, и удерживает объект в её пределах.
5014
5123
  */
5015
5124
  _autoExpandTextboxWidth(t, { anchor: e } = {}) {
5016
- var I, w, T, M, C, E, W, N, x, Y, G, K, H;
5125
+ var I, S, T, M, C, E, z, x, N, Y, V, Q, H;
5017
5126
  const { montageArea: s } = this.editor;
5018
5127
  if (!s) return !1;
5019
5128
  const n = typeof t.text == "string" ? t.text : "";
@@ -5021,7 +5130,7 @@ class k {
5021
5130
  s.setCoords();
5022
5131
  const o = s.getBoundingRect(!1, !0), i = (I = o.width) != null ? I : 0;
5023
5132
  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(
5133
+ const a = e != null ? e : (S = this.editingAnchorState) == null ? void 0 : S.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 = (z = t.paddingRight) != null ? z : 0, u = (x = t.strokeWidth) != null ? x : 0, f = Math.max(
5025
5134
  1,
5026
5135
  i / c - d - l - u
5027
5136
  );
@@ -5029,18 +5138,18 @@ class k {
5029
5138
  const g = n.split(`
5030
5139
  `).length;
5031
5140
  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(
5141
+ Math.abs(((N = t.width) != null ? N : 0) - f) > tt && (t.set({ width: f }), p = !0), t.initDimensions();
5142
+ const { textLines: m } = t, v = Array.isArray(m) && m.length > g, w = Math.ceil(
5034
5143
  k._getLongestLineWidth({ textbox: t, text: n })
5035
5144
  ), A = Math.min((Y = t.minWidth) != null ? Y : 1, f);
5036
5145
  let y = Math.min(
5037
5146
  f,
5038
- Math.max(S, A)
5147
+ Math.max(w, A)
5039
5148
  );
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);
5149
+ v && (y = f), Math.abs(((V = t.width) != null ? V : 0) - y) > tt && (t.set({ width: y }), t.initDimensions(), p = !0), k._roundTextboxDimensions({ textbox: t }) && (p = !0), a && (t.setPositionByOrigin(new et(a.x, a.y), "center", r), p = !0);
5041
5150
  const j = k._clampTextboxToMontage({
5042
5151
  textbox: t,
5043
- montageLeft: (K = o.left) != null ? K : 0,
5152
+ montageLeft: (Q = o.left) != null ? Q : 0,
5044
5153
  montageRight: ((H = o.left) != null ? H : 0) + i
5045
5154
  });
5046
5155
  return p || j;
@@ -5072,10 +5181,10 @@ class k {
5072
5181
  var c, d, l, u;
5073
5182
  t.setCoords();
5074
5183
  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 - $)
5184
+ if (a > 0 && ((l = n.width) != null ? l : 0) >= a - tt)
5076
5185
  return !1;
5077
5186
  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);
5187
+ return o < e ? r = e - o : i > s && (r = s - i), Math.abs(r) <= tt ? !1 : (t.set({ left: ((u = t.left) != null ? u : 0) + r }), !0);
5079
5188
  }
5080
5189
  /**
5081
5190
  * Обрабатывает изменение ширины текстового объекта (resizing).
@@ -5097,7 +5206,7 @@ class k {
5097
5206
  e.set({ width: r });
5098
5207
  const c = (u = e.width) != null ? u : 0, d = a - c;
5099
5208
  if (d !== 0 && s && s.corner === "ml") {
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;
5209
+ const w = ((f = e.angle) != null ? f : 0) * Math.PI / 180, A = Math.cos(w), y = Math.sin(w), b = (g = e.scaleX) != null ? g : 1, j = d * b;
5101
5210
  e.set({
5102
5211
  left: ((p = e.left) != null ? p : 0) + j * A,
5103
5212
  top: ((m = e.top) != null ? m : 0) + j * y
@@ -5234,8 +5343,8 @@ class k {
5234
5343
  snapshot: R,
5235
5344
  entries: O
5236
5345
  }) => {
5237
- Object.entries(O).forEach(([it, Z]) => {
5238
- Z != null && (R[it] = Z);
5346
+ Object.entries(O).forEach(([at, Z]) => {
5347
+ Z != null && (R[at] = Z);
5239
5348
  });
5240
5349
  }, {
5241
5350
  id: s,
@@ -5253,23 +5362,23 @@ class k {
5253
5362
  stroke: p,
5254
5363
  strokeWidth: m,
5255
5364
  opacity: v,
5256
- backgroundColor: S,
5365
+ backgroundColor: w,
5257
5366
  backgroundOpacity: A,
5258
5367
  paddingTop: y,
5259
5368
  paddingRight: b,
5260
5369
  paddingBottom: j,
5261
5370
  paddingLeft: I,
5262
- radiusTopLeft: w,
5371
+ radiusTopLeft: S,
5263
5372
  radiusTopRight: T,
5264
5373
  radiusBottomRight: M,
5265
5374
  radiusBottomLeft: C,
5266
5375
  left: E,
5267
- top: W,
5268
- width: N,
5269
- height: x,
5376
+ top: z,
5377
+ width: x,
5378
+ height: N,
5270
5379
  angle: Y,
5271
- scaleX: G,
5272
- scaleY: K
5380
+ scaleX: V,
5381
+ scaleY: Q
5273
5382
  } = t, H = {
5274
5383
  id: s,
5275
5384
  uppercase: !!i,
@@ -5290,23 +5399,23 @@ class k {
5290
5399
  stroke: p,
5291
5400
  strokeWidth: m,
5292
5401
  opacity: v,
5293
- backgroundColor: S,
5402
+ backgroundColor: w,
5294
5403
  backgroundOpacity: A,
5295
5404
  paddingTop: y,
5296
5405
  paddingRight: b,
5297
5406
  paddingBottom: j,
5298
5407
  paddingLeft: I,
5299
- radiusTopLeft: w,
5408
+ radiusTopLeft: S,
5300
5409
  radiusTopRight: T,
5301
5410
  radiusBottomRight: M,
5302
5411
  radiusBottomLeft: C,
5303
5412
  left: E,
5304
- top: W,
5305
- width: N,
5306
- height: x,
5413
+ top: z,
5414
+ width: x,
5415
+ height: N,
5307
5416
  angle: Y,
5308
- scaleX: G,
5309
- scaleY: K
5417
+ scaleX: V,
5418
+ scaleY: Q
5310
5419
  }
5311
5420
  }), H;
5312
5421
  }
@@ -5318,7 +5427,7 @@ class k {
5318
5427
  return (e = (t = this.fonts[0]) == null ? void 0 : t.family) != null ? e : "Arial";
5319
5428
  }
5320
5429
  }
5321
- const Q = ({
5430
+ const J = ({
5322
5431
  value: h,
5323
5432
  fallback: t = 0
5324
5433
  }) => typeof h == "number" && Number.isFinite(h) ? h : typeof t == "number" && Number.isFinite(t) ? t : 0, ae = ({
@@ -5326,7 +5435,7 @@ const Q = ({
5326
5435
  dimension: t,
5327
5436
  useRelativePositions: e
5328
5437
  }) => {
5329
- const s = Q({ value: h });
5438
+ const s = J({ value: h });
5330
5439
  return e ? s : s / (t || 1);
5331
5440
  }, ln = ({
5332
5441
  object: h,
@@ -5357,7 +5466,7 @@ const Q = ({
5357
5466
  value: r,
5358
5467
  dimension: e,
5359
5468
  useRelativePositions: s
5360
- }), f = Q({ value: c }) / (t || 1), g = Q({ value: d }) / (e || 1);
5469
+ }), f = J({ value: c }) / (t || 1), g = J({ value: d }) / (e || 1);
5361
5470
  return {
5362
5471
  x: l + f / 2,
5363
5472
  y: u + g / 2
@@ -5372,10 +5481,10 @@ const Q = ({
5372
5481
  const { left: o, top: i, width: a, height: r } = e;
5373
5482
  if (!n) {
5374
5483
  const { width: l, height: u } = s, f = o + h * (l || a), g = i + t * (u || r);
5375
- return new tt(f, g);
5484
+ return new et(f, g);
5376
5485
  }
5377
5486
  const c = o + h * a, d = i + t * r;
5378
- return new tt(c, d);
5487
+ return new et(c, d);
5379
5488
  }, un = ({
5380
5489
  object: h,
5381
5490
  montageArea: t,
@@ -5391,7 +5500,7 @@ const Q = ({
5391
5500
  } catch (s) {
5392
5501
  return null;
5393
5502
  }
5394
- }, mt = ({
5503
+ }, yt = ({
5395
5504
  object: h
5396
5505
  }) => {
5397
5506
  if (!h) return null;
@@ -5455,7 +5564,7 @@ const Q = ({
5455
5564
  };
5456
5565
  }
5457
5566
  return null;
5458
- }, Vt = "_templateCenterX", me = "_templateCenterY", re = "_templateAnchorX", ye = "_templateAnchorY";
5567
+ }, Xt = "_templateCenterX", me = "_templateCenterY", re = "_templateAnchorX", ye = "_templateAnchorY";
5459
5568
  class _ {
5460
5569
  constructor({ editor: t }) {
5461
5570
  this.editor = t;
@@ -5480,25 +5589,25 @@ class _ {
5480
5589
  return a.emitWarning({
5481
5590
  origin: "TemplateManager",
5482
5591
  method: "serializeSelection",
5483
- code: St.TEMPLATE_MANAGER.NO_OBJECTS_SELECTED,
5592
+ code: At.TEMPLATE_MANAGER.NO_OBJECTS_SELECTED,
5484
5593
  message: "Нет объектов для сериализации шаблона"
5485
5594
  }), null;
5486
- const g = _._getBounds(i), p = _._getMontageSize({ montageArea: i, bounds: g }), m = p.width, v = p.height, S = f.map((b) => _._serializeObject({
5595
+ const g = _._getBounds(i), p = _._getMontageSize({ montageArea: i, bounds: g }), m = p.width, v = p.height, w = f.map((b) => _._serializeObject({
5487
5596
  object: b,
5488
5597
  bounds: g,
5489
5598
  baseWidth: m,
5490
5599
  baseHeight: v,
5491
5600
  montageArea: i != null ? i : null
5492
- })), A = wt(B({}, s), {
5601
+ })), A = St(B({}, s), {
5493
5602
  baseWidth: m,
5494
5603
  baseHeight: v,
5495
5604
  positionsNormalized: !0,
5496
5605
  previewId: e != null ? e : s.previewId
5497
5606
  });
5498
5607
  return {
5499
- id: t != null ? t : `template-${V()}`,
5608
+ id: t != null ? t : `template-${X()}`,
5500
5609
  meta: A,
5501
- objects: S
5610
+ objects: w
5502
5611
  };
5503
5612
  }
5504
5613
  /**
@@ -5508,7 +5617,7 @@ class _ {
5508
5617
  * @param options.data - данные для заполнения текстов по customData.templateField
5509
5618
  */
5510
5619
  applyTemplate(s) {
5511
- return z(this, arguments, function* ({
5620
+ return P(this, arguments, function* ({
5512
5621
  template: t,
5513
5622
  data: e
5514
5623
  }) {
@@ -5523,7 +5632,7 @@ class _ {
5523
5632
  return a.emitWarning({
5524
5633
  origin: "TemplateManager",
5525
5634
  method: "applyTemplate",
5526
- code: St.TEMPLATE_MANAGER.INVALID_TEMPLATE,
5635
+ code: At.TEMPLATE_MANAGER.INVALID_TEMPLATE,
5527
5636
  message: "Шаблон не содержит объектов"
5528
5637
  }), null;
5529
5638
  const u = _._getBounds(o);
@@ -5531,11 +5640,11 @@ class _ {
5531
5640
  return a.emitWarning({
5532
5641
  origin: "TemplateManager",
5533
5642
  method: "applyTemplate",
5534
- code: St.TEMPLATE_MANAGER.INVALID_TARGET,
5643
+ code: At.TEMPLATE_MANAGER.INVALID_TARGET,
5535
5644
  message: "Не удалось определить границы монтажной области"
5536
5645
  }), null;
5537
5646
  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;
5647
+ let v = !1, w = !1;
5539
5648
  i.suspendHistory();
5540
5649
  try {
5541
5650
  const A = yield _._enlivenObjects(c);
@@ -5543,11 +5652,11 @@ class _ {
5543
5652
  return a.emitWarning({
5544
5653
  origin: "TemplateManager",
5545
5654
  method: "applyTemplate",
5546
- code: St.TEMPLATE_MANAGER.INVALID_TEMPLATE,
5655
+ code: At.TEMPLATE_MANAGER.INVALID_TEMPLATE,
5547
5656
  message: "Не удалось создать объекты шаблона"
5548
5657
  }), null;
5549
5658
  const { backgroundObject: y, contentObjects: b } = _._extractBackgroundObject(A);
5550
- y && (S = yield _._applyBackgroundFromObject({
5659
+ y && (w = yield _._applyBackgroundFromObject({
5551
5660
  backgroundObject: y,
5552
5661
  backgroundManager: r,
5553
5662
  errorManager: a
@@ -5565,10 +5674,10 @@ class _ {
5565
5674
  montageArea: o,
5566
5675
  useRelativePositions: m
5567
5676
  }), I.set({
5568
- id: `${I.type}-${V()}`,
5677
+ id: `${I.type}-${X()}`,
5569
5678
  evented: !0
5570
5679
  }), 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", {
5680
+ return !j.length && !w ? null : (v = j.length > 0 || w, j.length && _._activateObjects({ canvas: n, objects: j }), n.requestRenderAll(), n.fire("editor:template-applied", {
5572
5681
  template: t,
5573
5682
  objects: j,
5574
5683
  bounds: u
@@ -5577,7 +5686,7 @@ class _ {
5577
5686
  return a.emitError({
5578
5687
  origin: "TemplateManager",
5579
5688
  method: "applyTemplate",
5580
- code: St.TEMPLATE_MANAGER.APPLY_FAILED,
5689
+ code: At.TEMPLATE_MANAGER.APPLY_FAILED,
5581
5690
  message: "Ошибка применения шаблона",
5582
5691
  data: {
5583
5692
  templateId: l,
@@ -5617,14 +5726,14 @@ class _ {
5617
5726
  * Превращает plain-описание объектов в Fabric объекты.
5618
5727
  */
5619
5728
  static _enlivenObjects(t) {
5620
- return z(this, null, function* () {
5621
- return (yield Promise.all(t.map((s) => z(null, null, function* () {
5729
+ return P(this, null, function* () {
5730
+ return (yield Promise.all(t.map((s) => P(null, null, function* () {
5622
5731
  if (_._hasSerializedSvgMarkup(s)) {
5623
5732
  const i = yield _._reviveSvgObject(s);
5624
5733
  if (i)
5625
5734
  return _._restoreImageScale({ revived: i, serialized: s }), i;
5626
5735
  }
5627
- const n = yield ut.enlivenObjects([s]), o = n == null ? void 0 : n[0];
5736
+ const n = yield ft.enlivenObjects([s]), o = n == null ? void 0 : n[0];
5628
5737
  return o ? (_._restoreImageScale({ revived: o, serialized: s }), o) : null;
5629
5738
  })))).filter((s) => !!s);
5630
5739
  });
@@ -5653,22 +5762,22 @@ class _ {
5653
5762
  naturalHeight: 0,
5654
5763
  width: 0,
5655
5764
  height: 0
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) {
5765
+ }, p = J({ value: l || f || c.width, fallback: 0 }), m = J({ value: u || g || c.height, fallback: 0 }), v = J({ value: n, fallback: p }), w = J({ value: o, fallback: m }), A = J({ value: i, fallback: c.scaleX || 1 }), y = J({ value: a, fallback: c.scaleY || 1 }), b = v * A, j = w * y, I = p > 0, S = m > 0, T = b > 0, M = j > 0, C = _._resolveImageFit({ customData: r }), E = {};
5766
+ if (I && (E.width = p), S && (E.height = m), !I || !S) {
5658
5767
  c.set(E);
5659
5768
  return;
5660
5769
  }
5661
5770
  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);
5771
+ const x = T ? b / p : null, N = M ? j / m : null;
5772
+ x && x > 0 && (E.scaleX = x), N && N > 0 && (E.scaleY = N), c.set(E);
5664
5773
  return;
5665
5774
  }
5666
5775
  if (!T || !M) {
5667
5776
  c.set(E);
5668
5777
  return;
5669
5778
  }
5670
- const W = Math.min(b / p, j / m);
5671
- Number.isFinite(W) && W > 0 && (E.scaleX = W, E.scaleY = W), c.set(E);
5779
+ const z = Math.min(b / p, j / m);
5780
+ Number.isFinite(z) && z > 0 && (E.scaleX = z, E.scaleY = z), c.set(E);
5672
5781
  }
5673
5782
  /**
5674
5783
  * Определяет режим вписывания изображения при восстановлении.
@@ -5690,11 +5799,11 @@ class _ {
5690
5799
  * Восстанавливает SVG-объект из компактного описания.
5691
5800
  */
5692
5801
  static _reviveSvgObject(t) {
5693
- return z(this, null, function* () {
5802
+ return P(this, null, function* () {
5694
5803
  const e = typeof t.svgMarkup == "string" ? t.svgMarkup : null;
5695
5804
  if (!e) return null;
5696
5805
  try {
5697
- const s = yield ys(e), n = ut.groupSVGElements(s.objects, s.options), o = yield ut.enlivenObjectEnlivables(
5806
+ const s = yield ys(e), n = ft.groupSVGElements(s.objects, s.options), o = yield ft.enlivenObjectEnlivables(
5698
5807
  _._prepareSerializableProps(t)
5699
5808
  );
5700
5809
  return n.set(o), n.setCoords(), n;
@@ -5759,10 +5868,10 @@ class _ {
5759
5868
  baseHeight: i,
5760
5869
  useRelativePositions: r,
5761
5870
  centerKeys: {
5762
- x: Vt,
5871
+ x: Xt,
5763
5872
  y: me
5764
5873
  }
5765
- }), { scaleX: u, scaleY: f } = t, g = Q({ value: u, fallback: 1 }), p = Q({ value: f, fallback: 1 }), m = _._getPositioningBounds({
5874
+ }), { scaleX: u, scaleY: f } = t, g = J({ value: u, fallback: 1 }), p = J({ value: f, fallback: 1 }), m = _._getPositioningBounds({
5766
5875
  bounds: s,
5767
5876
  baseWidth: o,
5768
5877
  baseHeight: i,
@@ -5776,11 +5885,11 @@ class _ {
5776
5885
  bounds: m,
5777
5886
  targetSize: n,
5778
5887
  montageArea: a
5779
- }), S = g * e, A = p * e;
5888
+ }), w = g * e, A = p * e;
5780
5889
  t.set({
5781
- scaleX: S,
5890
+ scaleX: w,
5782
5891
  scaleY: A
5783
- }), t.setPositionByOrigin(v, "center", "center"), t.setCoords(), delete c[Vt], delete c[me], delete c[re], delete c[ye];
5892
+ }), t.setPositionByOrigin(v, "center", "center"), t.setCoords(), delete c[Xt], delete c[me], delete c[re], delete c[ye];
5784
5893
  }
5785
5894
  /**
5786
5895
  * Возвращает bounds, в которых должны позиционироваться нормализованные объекты.
@@ -5827,7 +5936,7 @@ class _ {
5827
5936
  meta: t,
5828
5937
  fallback: e
5829
5938
  }) {
5830
- const { width: s, height: n } = e, r = t || {}, { baseWidth: o = s, baseHeight: i = n } = r, a = gt(r, ["baseWidth", "baseHeight"]);
5939
+ const { width: s, height: n } = e, r = t || {}, { baseWidth: o = s, baseHeight: i = n } = r, a = pt(r, ["baseWidth", "baseHeight"]);
5831
5940
  return B({
5832
5941
  baseWidth: o,
5833
5942
  baseHeight: i
@@ -5865,30 +5974,30 @@ class _ {
5865
5974
  object: t,
5866
5975
  baseWidth: e
5867
5976
  }) {
5868
- var Y, G;
5869
- if (!(t instanceof ot)) return;
5977
+ var Y, V;
5978
+ if (!(t instanceof it)) return;
5870
5979
  const s = typeof t.text == "string" ? t.text : "";
5871
5980
  if (!s) return;
5872
- const n = Q({
5873
- value: (G = (Y = this.editor) == null ? void 0 : Y.montageArea) == null ? void 0 : G.width,
5981
+ const n = J({
5982
+ value: (V = (Y = this.editor) == null ? void 0 : Y.montageArea) == null ? void 0 : V.width,
5874
5983
  fallback: 0
5875
5984
  }), {
5876
5985
  width: o = 0,
5877
5986
  scaleX: i = 1,
5878
5987
  strokeWidth: a = 0
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;
5988
+ } = t, r = J({ value: e, fallback: 0 }), c = t, d = J({ value: c.paddingLeft, fallback: 0 }), l = J({ value: c.paddingRight, fallback: 0 }), u = J({ value: i, fallback: 1 }), f = J({ value: a, fallback: 0 }) * u, g = J({ value: o, fallback: 0 }), p = g * u, m = d * u, v = l * u, w = p + m + v + f;
5880
5989
  if (!n || !g || !r) return;
5881
5990
  t.setCoords();
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();
5991
+ const A = t, y = A[Xt], b = typeof y == "number" ? y : null, j = _._resolveAnchor(A, re), I = w / r, S = b !== null ? b - I / 2 : null, T = b !== null ? b + I / 2 : null, M = t.getCenterPoint();
5883
5992
  t.set("width", n), t.initDimensions();
5884
5993
  const C = _._getLongestLineWidth({
5885
5994
  textbox: t,
5886
5995
  text: s
5887
5996
  }), E = C > g ? C + 1 : g;
5888
5997
  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);
5998
+ const x = (E * u + m + v + f) / r;
5999
+ let N = b;
6000
+ j === "start" && S !== null ? N = Math.max(0, S) + x / 2 : j === "end" && T !== null && (N = Math.min(1, T) - x / 2), typeof N == "number" && (A[Xt] = N);
5892
6001
  }
5893
6002
  /**
5894
6003
  * Возвращает ширину самой длинной строки текстового объекта.
@@ -5939,11 +6048,11 @@ class _ {
5939
6048
  x: (y.x - a) / u,
5940
6049
  y: (y.y - r) / f
5941
6050
  };
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({
6051
+ })(), m = (l.left - a) / u, v = (l.top - r) / f, w = m + l.width / u, A = v + l.height / f;
6052
+ return i[Xt] = p.x, i[me] = p.y, i[re] = _._detectAnchor({
5944
6053
  center: p.x,
5945
6054
  start: m,
5946
- end: S
6055
+ end: w
5947
6056
  }), i[ye] = _._detectAnchor({
5948
6057
  center: p.y,
5949
6058
  start: v,
@@ -5964,7 +6073,7 @@ class _ {
5964
6073
  * Применяет фоновый объект шаблона к текущему холсту через BackgroundManager.
5965
6074
  */
5966
6075
  static _applyBackgroundFromObject(n) {
5967
- return z(this, arguments, function* ({
6076
+ return P(this, arguments, function* ({
5968
6077
  backgroundObject: t,
5969
6078
  backgroundManager: e,
5970
6079
  errorManager: s
@@ -6002,7 +6111,7 @@ class _ {
6002
6111
  s.emitWarning({
6003
6112
  origin: "TemplateManager",
6004
6113
  method: "applyTemplate",
6005
- code: St.TEMPLATE_MANAGER.APPLY_FAILED,
6114
+ code: At.TEMPLATE_MANAGER.APPLY_FAILED,
6006
6115
  message: "Не удалось применить фон из шаблона",
6007
6116
  data: o
6008
6117
  });
@@ -6058,7 +6167,7 @@ class _ {
6058
6167
  */
6059
6168
  // eslint-disable-next-line class-methods-use-this
6060
6169
  enlivenObjectEnlivables(t) {
6061
- return ut.enlivenObjectEnlivables(t);
6170
+ return ft.enlivenObjectEnlivables(t);
6062
6171
  }
6063
6172
  }
6064
6173
  const pn = 5, os = "#3D8BF4", Ae = 1, ce = 1, Je = ({
@@ -6198,8 +6307,8 @@ const pn = 5, os = "#3D8BF4", Ae = 1, ce = 1, Je = ({
6198
6307
  return { delta: 0, guide: null };
6199
6308
  const u = d[l - 1], f = d[l - 2], g = d[l + 1], p = d[l + 2], m = [], v = i - o;
6200
6309
  if (u && f) {
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) {
6310
+ const { bounds: y } = u, { bounds: b } = f, j = y.top - b.bottom, I = o - y.bottom, S = Math.abs(I - j);
6311
+ if (S <= e) {
6203
6312
  const T = j - I, M = o + T, C = {
6204
6313
  type: "vertical",
6205
6314
  axis: n,
@@ -6209,12 +6318,12 @@ const pn = 5, os = "#3D8BF4", Ae = 1, ce = 1, Je = ({
6209
6318
  activeEnd: M,
6210
6319
  distance: j
6211
6320
  };
6212
- m.push({ delta: T, guide: C, diff: w });
6321
+ m.push({ delta: T, guide: C, diff: S });
6213
6322
  }
6214
6323
  }
6215
6324
  if (g && p) {
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) {
6325
+ const { bounds: y } = g, { bounds: b } = p, j = b.top - y.bottom, I = y.top - i, S = Math.abs(I - j);
6326
+ if (S <= e) {
6218
6327
  const T = I - j, M = i + T, C = {
6219
6328
  type: "vertical",
6220
6329
  axis: n,
@@ -6224,35 +6333,35 @@ const pn = 5, os = "#3D8BF4", Ae = 1, ce = 1, Je = ({
6224
6333
  activeEnd: y.top,
6225
6334
  distance: j
6226
6335
  };
6227
- m.push({ delta: T, guide: C, diff: w });
6336
+ m.push({ delta: T, guide: C, diff: S });
6228
6337
  }
6229
6338
  }
6230
6339
  if (u && g) {
6231
6340
  const { bounds: y } = u, { bounds: b } = g, I = b.top - y.bottom - v;
6232
6341
  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 = {
6342
+ const S = I / 2, T = o - y.bottom, M = b.top - i, C = Math.abs(T - S), E = Math.abs(M - S), z = Math.max(C, E);
6343
+ if (z <= e) {
6344
+ const x = S - T, N = i + x, Y = {
6236
6345
  type: "vertical",
6237
6346
  axis: n,
6238
6347
  refStart: y.bottom,
6239
- refEnd: y.bottom + w,
6240
- activeStart: x,
6241
- activeEnd: x + w,
6242
- distance: w
6348
+ refEnd: y.bottom + S,
6349
+ activeStart: N,
6350
+ activeEnd: N + S,
6351
+ distance: S
6243
6352
  };
6244
- m.push({ delta: N, guide: Y, diff: W });
6353
+ m.push({ delta: x, guide: Y, diff: z });
6245
6354
  }
6246
6355
  }
6247
6356
  }
6248
- const S = is({
6357
+ const w = is({
6249
6358
  activeBounds: h,
6250
6359
  aligned: c,
6251
6360
  threshold: e,
6252
6361
  patterns: s,
6253
6362
  type: "vertical"
6254
6363
  });
6255
- if (m.push(...S), !m.length)
6364
+ if (m.push(...w), !m.length)
6256
6365
  return { delta: 0, guide: null };
6257
6366
  const A = m.reduce((y, b) => b.diff < y.diff ? b : y, m[0]);
6258
6367
  return {
@@ -6284,8 +6393,8 @@ const pn = 5, os = "#3D8BF4", Ae = 1, ce = 1, Je = ({
6284
6393
  return { delta: 0, guide: null };
6285
6394
  const u = d[l - 1], f = d[l - 2], g = d[l + 1], p = d[l + 2], m = [], v = i - o;
6286
6395
  if (u && f) {
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) {
6396
+ const { bounds: y } = u, { bounds: b } = f, j = y.left - b.right, I = o - y.right, S = Math.abs(I - j);
6397
+ if (S <= e) {
6289
6398
  const T = j - I, M = o + T, C = {
6290
6399
  type: "horizontal",
6291
6400
  axis: n,
@@ -6295,12 +6404,12 @@ const pn = 5, os = "#3D8BF4", Ae = 1, ce = 1, Je = ({
6295
6404
  activeEnd: M,
6296
6405
  distance: j
6297
6406
  };
6298
- m.push({ delta: T, guide: C, diff: w });
6407
+ m.push({ delta: T, guide: C, diff: S });
6299
6408
  }
6300
6409
  }
6301
6410
  if (g && p) {
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) {
6411
+ const { bounds: y } = g, { bounds: b } = p, j = b.left - y.right, I = y.left - i, S = Math.abs(I - j);
6412
+ if (S <= e) {
6304
6413
  const T = I - j, M = i + T, C = {
6305
6414
  type: "horizontal",
6306
6415
  axis: n,
@@ -6310,35 +6419,35 @@ const pn = 5, os = "#3D8BF4", Ae = 1, ce = 1, Je = ({
6310
6419
  activeEnd: y.left,
6311
6420
  distance: j
6312
6421
  };
6313
- m.push({ delta: T, guide: C, diff: w });
6422
+ m.push({ delta: T, guide: C, diff: S });
6314
6423
  }
6315
6424
  }
6316
6425
  if (u && g) {
6317
6426
  const { bounds: y } = u, { bounds: b } = g, I = b.left - y.right - v;
6318
6427
  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 = {
6428
+ const S = I / 2, T = o - y.right, M = b.left - i, C = Math.abs(T - S), E = Math.abs(M - S), z = Math.max(C, E);
6429
+ if (z <= e) {
6430
+ const x = S - T, N = i + x, Y = {
6322
6431
  type: "horizontal",
6323
6432
  axis: n,
6324
6433
  refStart: y.right,
6325
- refEnd: y.right + w,
6326
- activeStart: x,
6327
- activeEnd: x + w,
6328
- distance: w
6434
+ refEnd: y.right + S,
6435
+ activeStart: N,
6436
+ activeEnd: N + S,
6437
+ distance: S
6329
6438
  };
6330
- m.push({ delta: N, guide: Y, diff: W });
6439
+ m.push({ delta: x, guide: Y, diff: z });
6331
6440
  }
6332
6441
  }
6333
6442
  }
6334
- const S = is({
6443
+ const w = is({
6335
6444
  activeBounds: h,
6336
6445
  aligned: c,
6337
6446
  threshold: e,
6338
6447
  patterns: s,
6339
6448
  type: "horizontal"
6340
6449
  });
6341
- if (m.push(...S), !m.length)
6450
+ if (m.push(...w), !m.length)
6342
6451
  return { delta: 0, guide: null };
6343
6452
  const A = m.reduce((y, b) => b.diff < y.diff ? b : y, m[0]);
6344
6453
  return {
@@ -6394,16 +6503,16 @@ const pn = 5, os = "#3D8BF4", Ae = 1, ce = 1, Je = ({
6394
6503
  offsetAlongAxis: f = 0,
6395
6504
  offsetPerpendicular: g = 0
6396
6505
  }) => {
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;
6506
+ const p = i || 1, m = 12 / p, v = l / p, w = u / p, A = (s + n) / 2 + f, y = t === "vertical" ? e + g : A, b = t === "vertical" ? A : e + g;
6398
6507
  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";
6399
- const I = h.measureText(o).width + v * 2, w = m + v * 2, T = y - I / 2, M = b - w / 2;
6508
+ const I = h.measureText(o).width + v * 2, S = m + v * 2, T = y - I / 2, M = b - S / 2;
6400
6509
  h.beginPath(), Mn({
6401
6510
  context: h,
6402
6511
  x: T,
6403
6512
  y: M,
6404
6513
  width: I,
6405
- height: w,
6406
- radius: S
6514
+ height: S,
6515
+ radius: w
6407
6516
  }), h.fill(), h.fillStyle = r, h.fillText(o, y, b), h.restore();
6408
6517
  }, wn = ({
6409
6518
  context: h,
@@ -6468,8 +6577,8 @@ const pn = 5, os = "#3D8BF4", Ae = 1, ce = 1, Je = ({
6468
6577
  for (let p = r + 1; p < a.length; p += 1) {
6469
6578
  const m = a[p];
6470
6579
  if (Math.min(c[i], m[i]) - Math.max(c[o], m[o]) < 0) continue;
6471
- const S = m[e] - c[s];
6472
- S < 0 || S < l && (l = S, d = m);
6580
+ const w = m[e] - c[s];
6581
+ w < 0 || w < l && (l = w, d = m);
6473
6582
  }
6474
6583
  if (!d || l === Number.POSITIVE_INFINITY) continue;
6475
6584
  const u = Math.max(c[o], d[o]), f = Math.min(c[i], d[i]), g = (u + f) / 2;
@@ -6571,7 +6680,7 @@ class jn {
6571
6680
  return;
6572
6681
  }
6573
6682
  !this.anchors.vertical.length && !this.anchors.horizontal.length && this._cacheAnchors({ activeObject: e });
6574
- let o = mt({ object: e });
6683
+ let o = yt({ object: e });
6575
6684
  if (!o) {
6576
6685
  this._clearGuides();
6577
6686
  return;
@@ -6582,24 +6691,24 @@ class jn {
6582
6691
  anchors: this.anchors
6583
6692
  }), { deltaX: d, deltaY: l, guides: u } = c;
6584
6693
  if (d !== 0 || l !== 0) {
6585
- const { left: v = 0, top: S = 0 } = e;
6694
+ const { left: v = 0, top: w = 0 } = e;
6586
6695
  e.set({
6587
6696
  left: v + d,
6588
- top: S + l
6589
- }), e.setCoords(), o = (p = mt({ object: e })) != null ? p : o;
6697
+ top: w + l
6698
+ }), e.setCoords(), o = (p = yt({ object: e })) != null ? p : o;
6590
6699
  }
6591
- const f = this.cachedTargetBounds.length ? this.cachedTargetBounds : this._collectTargets({ activeObject: e }).map((v) => mt({ object: v })).filter((v) => !!v), g = bn({
6700
+ const f = this.cachedTargetBounds.length ? this.cachedTargetBounds : this._collectTargets({ activeObject: e }).map((v) => yt({ object: v })).filter((v) => !!v), g = bn({
6592
6701
  activeBounds: o,
6593
6702
  candidates: f,
6594
6703
  threshold: r,
6595
6704
  spacingPatterns: this.spacingPatterns
6596
6705
  });
6597
6706
  if (g.deltaX !== 0 || g.deltaY !== 0) {
6598
- const { left: v = 0, top: S = 0 } = e;
6707
+ const { left: v = 0, top: w = 0 } = e;
6599
6708
  e.set({
6600
6709
  left: v + g.deltaX,
6601
- top: S + g.deltaY
6602
- }), e.setCoords(), o = (m = mt({ object: e })) != null ? m : o;
6710
+ top: w + g.deltaY
6711
+ }), e.setCoords(), o = (m = yt({ object: e })) != null ? m : o;
6603
6712
  }
6604
6713
  this._applyGuides({
6605
6714
  guides: u,
@@ -6679,10 +6788,10 @@ class jn {
6679
6788
  _cacheAnchors({ activeObject: t }) {
6680
6789
  const e = this._collectTargets({ activeObject: t }), s = { vertical: [], horizontal: [] }, n = [];
6681
6790
  for (const a of e) {
6682
- const r = mt({ object: a });
6791
+ const r = yt({ object: a });
6683
6792
  r && (qe({ anchors: s, bounds: r }), n.push(r));
6684
6793
  }
6685
- const { montageArea: o } = this.editor, i = mt({ object: o });
6794
+ const { montageArea: o } = this.editor, i = yt({ object: o });
6686
6795
  if (i) {
6687
6796
  qe({ anchors: s, bounds: i });
6688
6797
  const { left: a, right: r, top: c, bottom: d } = i;
@@ -6726,7 +6835,7 @@ class jn {
6726
6835
  }
6727
6836
  }
6728
6837
  const ts = "#3D8BF4", es = 1;
6729
- class Lt {
6838
+ class Dt {
6730
6839
  /**
6731
6840
  * Создаёт менеджер измерений и инициализирует события.
6732
6841
  */
@@ -6831,15 +6940,15 @@ class Lt {
6831
6940
  this._clearGuides();
6832
6941
  return;
6833
6942
  }
6834
- const o = mt({ object: n });
6943
+ const o = yt({ object: n });
6835
6944
  if (!o) {
6836
6945
  this._clearGuides();
6837
6946
  return;
6838
6947
  }
6839
- const i = Lt._resolveTarget({
6948
+ const i = Dt._resolveTarget({
6840
6949
  event: t,
6841
6950
  activeObject: n
6842
- }), { montageArea: a } = s, r = i != null ? i : a, c = r === a, d = mt({ object: r });
6951
+ }), { montageArea: a } = s, r = i != null ? i : a, c = r === a, d = yt({ object: r });
6843
6952
  if (!d) {
6844
6953
  this._clearGuides();
6845
6954
  return;
@@ -6848,7 +6957,7 @@ class Lt {
6848
6957
  this._clearGuides();
6849
6958
  return;
6850
6959
  }
6851
- const u = Lt._buildGuides({
6960
+ const u = Dt._buildGuides({
6852
6961
  activeBounds: o,
6853
6962
  targetBounds: d,
6854
6963
  targetIsMontageArea: c
@@ -6877,11 +6986,11 @@ class Lt {
6877
6986
  targetBounds: e,
6878
6987
  targetIsMontageArea: s
6879
6988
  }) {
6880
- const n = Lt._buildHorizontalGuides({
6989
+ const n = Dt._buildHorizontalGuides({
6881
6990
  activeBounds: t,
6882
6991
  targetBounds: e,
6883
6992
  targetIsMontageArea: s
6884
- }), o = Lt._buildVerticalGuides({
6993
+ }), o = Dt._buildVerticalGuides({
6885
6994
  activeBounds: t,
6886
6995
  targetBounds: e,
6887
6996
  targetIsMontageArea: s
@@ -6908,13 +7017,13 @@ class Lt {
6908
7017
  top: u = 0,
6909
7018
  bottom: f = 0,
6910
7019
  centerY: g = 0
6911
- } = e, p = Math.max(a, u), m = Math.min(r, f), S = m >= p ? (p + m) / 2 : (c + g) / 2;
7020
+ } = e, p = Math.max(a, u), m = Math.min(r, f), w = m >= p ? (p + m) / 2 : (c + g) / 2;
6912
7021
  if (d >= i) {
6913
7022
  if (s) return n;
6914
7023
  const C = d - i;
6915
7024
  return C > 0 && n.push({
6916
7025
  type: "horizontal",
6917
- axis: S,
7026
+ axis: w,
6918
7027
  start: i,
6919
7028
  end: d,
6920
7029
  distance: C
@@ -6925,7 +7034,7 @@ class Lt {
6925
7034
  const C = o - l;
6926
7035
  return C > 0 && n.push({
6927
7036
  type: "horizontal",
6928
- axis: S,
7037
+ axis: w,
6929
7038
  start: l,
6930
7039
  end: o,
6931
7040
  distance: C
@@ -6935,16 +7044,16 @@ class Lt {
6935
7044
  const A = o < d, y = i > l, b = Math.min(o, d), j = Math.max(o, d), I = j - b;
6936
7045
  I > 0 && !A && n.push({
6937
7046
  type: "horizontal",
6938
- axis: S,
7047
+ axis: w,
6939
7048
  start: b,
6940
7049
  end: j,
6941
7050
  distance: I
6942
7051
  });
6943
- const w = Math.min(i, l), T = Math.max(i, l), M = T - w;
7052
+ const S = Math.min(i, l), T = Math.max(i, l), M = T - S;
6944
7053
  return M > 0 && !y && n.push({
6945
7054
  type: "horizontal",
6946
- axis: S,
6947
- start: w,
7055
+ axis: w,
7056
+ start: S,
6948
7057
  end: T,
6949
7058
  distance: M
6950
7059
  }), n;
@@ -6969,13 +7078,13 @@ class Lt {
6969
7078
  left: u = 0,
6970
7079
  right: f = 0,
6971
7080
  centerX: g = 0
6972
- } = e, p = Math.max(a, u), m = Math.min(r, f), S = m >= p ? (p + m) / 2 : (c + g) / 2;
7081
+ } = e, p = Math.max(a, u), m = Math.min(r, f), w = m >= p ? (p + m) / 2 : (c + g) / 2;
6973
7082
  if (d >= i) {
6974
7083
  if (s) return n;
6975
7084
  const C = d - i;
6976
7085
  return C > 0 && n.push({
6977
7086
  type: "vertical",
6978
- axis: S,
7087
+ axis: w,
6979
7088
  start: i,
6980
7089
  end: d,
6981
7090
  distance: C
@@ -6986,7 +7095,7 @@ class Lt {
6986
7095
  const C = o - l;
6987
7096
  return C > 0 && n.push({
6988
7097
  type: "vertical",
6989
- axis: S,
7098
+ axis: w,
6990
7099
  start: l,
6991
7100
  end: o,
6992
7101
  distance: C
@@ -6996,16 +7105,16 @@ class Lt {
6996
7105
  const A = o < d, y = i > l, b = Math.min(o, d), j = Math.max(o, d), I = j - b;
6997
7106
  I > 0 && !A && n.push({
6998
7107
  type: "vertical",
6999
- axis: S,
7108
+ axis: w,
7000
7109
  start: b,
7001
7110
  end: j,
7002
7111
  distance: I
7003
7112
  });
7004
- const w = Math.min(i, l), T = Math.max(i, l), M = T - w;
7113
+ const S = Math.min(i, l), T = Math.max(i, l), M = T - S;
7005
7114
  return M > 0 && !y && n.push({
7006
7115
  type: "vertical",
7007
- axis: S,
7008
- start: w,
7116
+ axis: w,
7117
+ start: S,
7009
7118
  end: T,
7010
7119
  distance: M
7011
7120
  }), n;
@@ -7037,7 +7146,7 @@ class Lt {
7037
7146
  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;
7038
7147
  e.save(), Array.isArray(s) && e.transform(...s), e.lineWidth = es / n, e.strokeStyle = ts, e.setLineDash([]);
7039
7148
  for (const c of this.activeGuides) {
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;
7149
+ 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, w = 0;
7041
7150
  e.beginPath(), d === "vertical" ? (e.moveTo(l, u), e.lineTo(l, f)) : (e.moveTo(u, l), e.lineTo(f, l)), e.stroke(), je({
7042
7151
  context: e,
7043
7152
  type: d,
@@ -7049,7 +7158,7 @@ class Lt {
7049
7158
  color: ts,
7050
7159
  lineWidth: es,
7051
7160
  offsetAlongAxis: v,
7052
- offsetPerpendicular: S
7161
+ offsetPerpendicular: w
7053
7162
  });
7054
7163
  }
7055
7164
  e.restore();
@@ -7080,7 +7189,7 @@ class Le {
7080
7189
  * @param options - опции и настройки редактора
7081
7190
  */
7082
7191
  constructor(t, e) {
7083
- this.options = e, this.containerId = t, this.editorId = `${t}-${V()}`, this.clipboard = null, this.init();
7192
+ this.options = e, this.containerId = t, this.editorId = `${t}-${X()}`, this.clipboard = null, this.init();
7084
7193
  }
7085
7194
  /**
7086
7195
  * Инициализация редактора.
@@ -7088,7 +7197,7 @@ class Le {
7088
7197
  * @fires editor:ready
7089
7198
  */
7090
7199
  init() {
7091
- return z(this, null, function* () {
7200
+ return P(this, null, function* () {
7092
7201
  var u;
7093
7202
  const {
7094
7203
  editorContainerWidth: t,
@@ -7103,12 +7212,12 @@ class Le {
7103
7212
  showRotationAngle: d,
7104
7213
  _onReadyCallback: l
7105
7214
  } = this.options;
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) {
7215
+ if (st.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 G({ 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 ut({ editor: this }), this.layerManager = new le({ editor: this }), this.shapeManager = new tn({ editor: this }), this.interactionBlocker = new $s({ editor: this }), this.backgroundManager = new Lt({ 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 Dt({ 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 Kt({ 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
7216
  const f = a, {
7108
7217
  source: g,
7109
7218
  scale: p = `image-${c}`,
7110
7219
  withoutSave: m = !0
7111
- } = f, v = gt(f, [
7220
+ } = f, v = pt(f, [
7112
7221
  "source",
7113
7222
  "scale",
7114
7223
  "withoutSave"