@anu3ev/fabric-image-editor 0.5.27 → 0.5.29

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 +1050 -968
  2. package/package.json +1 -1
package/dist/main.js CHANGED
@@ -1,22 +1,22 @@
1
- var bn = Object.defineProperty, Mn = Object.defineProperties;
2
- var Sn = Object.getOwnPropertyDescriptors;
1
+ var Mn = Object.defineProperty, Sn = Object.defineProperties;
2
+ var wn = Object.getOwnPropertyDescriptors;
3
3
  var oe = Object.getOwnPropertySymbols;
4
- var Pe = Object.prototype.hasOwnProperty, Fe = Object.prototype.propertyIsEnumerable;
5
- var ze = (d, t, e) => t in d ? bn(d, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : d[t] = e, L = (d, t) => {
4
+ var Ue = Object.prototype.hasOwnProperty, Ye = Object.prototype.propertyIsEnumerable;
5
+ var We = (d, t, e) => t in d ? Mn(d, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : d[t] = e, x = (d, t) => {
6
6
  for (var e in t || (t = {}))
7
- Pe.call(t, e) && ze(d, e, t[e]);
7
+ Ue.call(t, e) && We(d, e, t[e]);
8
8
  if (oe)
9
9
  for (var e of oe(t))
10
- Fe.call(t, e) && ze(d, e, t[e]);
10
+ Ye.call(t, e) && We(d, e, t[e]);
11
11
  return d;
12
- }, It = (d, t) => Mn(d, Sn(t));
12
+ }, It = (d, t) => Sn(d, wn(t));
13
13
  var Mt = (d, t) => {
14
14
  var e = {};
15
15
  for (var n in d)
16
- Pe.call(d, n) && t.indexOf(n) < 0 && (e[n] = d[n]);
16
+ Ue.call(d, n) && t.indexOf(n) < 0 && (e[n] = d[n]);
17
17
  if (d != null && oe)
18
18
  for (var n of oe(d))
19
- t.indexOf(n) < 0 && Fe.call(d, n) && (e[n] = d[n]);
19
+ t.indexOf(n) < 0 && Ye.call(d, n) && (e[n] = d[n]);
20
20
  return e;
21
21
  };
22
22
  var Z = (d, t, e) => new Promise((n, s) => {
@@ -35,16 +35,16 @@ var Z = (d, t, e) => new Promise((n, s) => {
35
35
  }, a = (r) => r.done ? n(r.value) : Promise.resolve(r.value).then(o, i);
36
36
  a((e = e.apply(d, t)).next());
37
37
  });
38
- import { ActiveSelection as X, Textbox as dt, util as yt, controlsUtils as Ue, InteractiveFabricObject as We, Point as at, FitContentLayout as Ye, loadSVGFromURL as wn, FabricImage as Xt, Gradient as He, Rect as An, Circle as jn, Triangle as In, Group as Nt, Color as Cn, classRegistry as Ze, loadSVGFromString as Tn, Canvas as On, Pattern as En } from "fabric";
39
- import { create as Ln } from "jsondiffpatch";
40
- import Dn from "diff-match-patch";
41
- var _n = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict", $ = function() {
38
+ import { ActiveSelection as X, Textbox as dt, util as ft, controlsUtils as He, InteractiveFabricObject as Ze, Point as at, FitContentLayout as Ge, loadSVGFromURL as An, FabricImage as Xt, Gradient as Ve, Rect as jn, Circle as In, Triangle as Cn, Group as Nt, Color as Tn, classRegistry as Xe, loadSVGFromString as On, Canvas as En, Pattern as Ln } from "fabric";
39
+ import { create as Dn } from "jsondiffpatch";
40
+ import _n from "diff-match-patch";
41
+ var xn = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict", tt = function() {
42
42
  for (var t = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : 21, e = "", n = crypto.getRandomValues(new Uint8Array(t |= 0)); t--; )
43
- e += _n[n[t] & 63];
43
+ e += xn[n[t] & 63];
44
44
  return e;
45
45
  };
46
- const Ge = 300;
47
- class Le {
46
+ const Ke = 300;
47
+ class xe {
48
48
  /**
49
49
  * Конструктор принимает редактор и опции.
50
50
  * @param params
@@ -62,7 +62,7 @@ class Le {
62
62
  * @param params.options.adaptCanvasToContainerOnResize — адаптировать канвас к размерам контейнера при изменении размеров окна
63
63
  */
64
64
  constructor({ editor: t, options: e = {} }) {
65
- 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 = Le.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 = this.handleObjectModifiedHistory.bind(this), this.handleObjectRotatingHistoryBound = this.handleObjectRotatingHistory.bind(this), this.handleObjectTransformStartBound = this.handleObjectTransformStart.bind(this), this.handleObjectTransformEndBound = this.handleObjectTransformEnd.bind(this), 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
+ 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 = xe.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 = this.handleObjectModifiedHistory.bind(this), this.handleObjectRotatingHistoryBound = this.handleObjectRotatingHistory.bind(this), this.handleObjectTransformStartBound = this.handleObjectTransformStart.bind(this), this.handleObjectTransformEndBound = this.handleObjectTransformEnd.bind(this), 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();
66
66
  }
67
67
  /**
68
68
  * Инициализация всех обработчиков согласно опциям.
@@ -123,14 +123,14 @@ class Le {
123
123
  handleObjectModifiedHistory() {
124
124
  const { historyManager: t, textManager: e } = this.editor;
125
125
  t.skipHistory || e.isTextEditingActive || t.scheduleSaveState({
126
- delayMs: Ge,
126
+ delayMs: Ke,
127
127
  reason: "object-modified"
128
128
  });
129
129
  }
130
130
  handleObjectRotatingHistory() {
131
131
  const { historyManager: t, textManager: e } = this.editor;
132
132
  t.skipHistory || e.isTextEditingActive || t.scheduleSaveState({
133
- delayMs: Ge,
133
+ delayMs: Ke,
134
134
  reason: "object-rotating"
135
135
  });
136
136
  }
@@ -431,7 +431,7 @@ class Le {
431
431
  };
432
432
  }
433
433
  }
434
- class xn {
434
+ class Rn {
435
435
  /**
436
436
  * Класс для динамической загрузки внешних модулей.
437
437
  */
@@ -449,7 +449,7 @@ class xn {
449
449
  return this.loaders[t] ? (this.cache.has(t) || this.cache.set(t, this.loaders[t]()), this.cache.get(t)) : Promise.reject(new Error(`Unknown module "${t}"`));
450
450
  }
451
451
  }
452
- function Rn(d) {
452
+ function kn(d) {
453
453
  return new Worker(
454
454
  "" + new URL("assets/worker-CN39s7P7.js", import.meta.url).href,
455
455
  {
@@ -457,13 +457,13 @@ function Rn(d) {
457
457
  }
458
458
  );
459
459
  }
460
- class kn {
460
+ class Nn {
461
461
  /**
462
462
  * @param scriptUrl — URL скрипта воркера.
463
463
  * По-умолчанию использует DefaultWorker из соседнего файла
464
464
  */
465
465
  constructor(t) {
466
- t ? this.worker = new Worker(t, { type: "module" }) : this.worker = new Rn(), this._callbacks = /* @__PURE__ */ new Map(), this.worker.onmessage = this._handleMessage.bind(this);
466
+ t ? this.worker = new Worker(t, { type: "module" }) : this.worker = new kn(), this._callbacks = /* @__PURE__ */ new Map(), this.worker.onmessage = this._handleMessage.bind(this);
467
467
  }
468
468
  /**
469
469
  * Обработчик сообщений от воркера
@@ -491,7 +491,7 @@ class kn {
491
491
  * @returns Promise, который будет выполнен, когда воркер вернет ответ
492
492
  */
493
493
  post(t, e, n = []) {
494
- const s = `${t}:${$(8)}`;
494
+ const s = `${t}:${tt(8)}`;
495
495
  return new Promise((o, i) => {
496
496
  this._callbacks.set(s, { resolve: o, reject: i }), this.worker.postMessage({ action: t, payload: e, requestId: s }, n);
497
497
  });
@@ -503,82 +503,82 @@ class kn {
503
503
  this.worker.terminate();
504
504
  }
505
505
  }
506
- const pt = 12, Nn = 2, we = 8, Ae = 20, Bn = 100, je = 20, Ie = 8, zn = 100, he = 32, De = 1, Pn = "#2B2D33", _e = "#3D8BF4", xe = "#FFFFFF";
506
+ const mt = 12, Bn = 2, Ae = 8, je = 20, zn = 100, Ie = 20, Ce = 8, Pn = 100, he = 32, Re = 1, Fn = "#2B2D33", ke = "#3D8BF4", Ne = "#FFFFFF";
507
507
  function ae(d, t, e, n, s) {
508
- const o = pt, i = Nn;
509
- d.save(), d.translate(t, e), d.rotate(yt.degreesToRadians(s.angle)), d.fillStyle = xe, d.strokeStyle = _e, d.lineWidth = De, d.beginPath(), d.roundRect(-o / 2, -o / 2, o, o, i), d.fill(), d.stroke(), d.restore();
508
+ const o = mt, i = Bn;
509
+ d.save(), d.translate(t, e), d.rotate(ft.degreesToRadians(s.angle)), d.fillStyle = Ne, d.strokeStyle = ke, d.lineWidth = Re, d.beginPath(), d.roundRect(-o / 2, -o / 2, o, o, i), d.fill(), d.stroke(), d.restore();
510
510
  }
511
- function Ve(d, t, e, n, s) {
512
- const o = we, i = Ae, a = Bn;
513
- d.save(), d.translate(t, e), d.rotate(yt.degreesToRadians(s.angle)), d.fillStyle = xe, d.strokeStyle = _e, d.lineWidth = De, d.beginPath(), d.roundRect(-o / 2, -i / 2, o, i, a), d.fill(), d.stroke(), d.restore();
511
+ function qe(d, t, e, n, s) {
512
+ const o = Ae, i = je, a = zn;
513
+ d.save(), d.translate(t, e), d.rotate(ft.degreesToRadians(s.angle)), d.fillStyle = Ne, d.strokeStyle = ke, d.lineWidth = Re, d.beginPath(), d.roundRect(-o / 2, -i / 2, o, i, a), d.fill(), d.stroke(), d.restore();
514
514
  }
515
- function Xe(d, t, e, n, s) {
516
- const o = je, i = Ie, a = zn;
517
- d.save(), d.translate(t, e), d.rotate(yt.degreesToRadians(s.angle)), d.fillStyle = xe, d.strokeStyle = _e, d.lineWidth = De, d.beginPath(), d.roundRect(-o / 2, -i / 2, o, i, a), d.fill(), d.stroke(), d.restore();
515
+ function Je(d, t, e, n, s) {
516
+ const o = Ie, i = Ce, a = Pn;
517
+ d.save(), d.translate(t, e), d.rotate(ft.degreesToRadians(s.angle)), d.fillStyle = Ne, d.strokeStyle = ke, d.lineWidth = Re, d.beginPath(), d.roundRect(-o / 2, -i / 2, o, i, a), d.fill(), d.stroke(), d.restore();
518
518
  }
519
- const Fn = "", gn = new Image();
520
- gn.src = Fn;
519
+ const Wn = "", pn = new Image();
520
+ pn.src = Wn;
521
521
  function Un(d, t, e, n, s) {
522
522
  const i = he / 2;
523
- d.save(), d.translate(t, e), d.rotate(yt.degreesToRadians(s.angle)), d.fillStyle = Pn, d.beginPath(), d.arc(0, 0, i, 0, 2 * Math.PI), d.fill(), d.drawImage(gn, -i / 2, -i / 2, i, i), d.restore();
523
+ d.save(), d.translate(t, e), d.rotate(ft.degreesToRadians(s.angle)), d.fillStyle = Fn, d.beginPath(), d.arc(0, 0, i, 0, 2 * Math.PI), d.fill(), d.drawImage(pn, -i / 2, -i / 2, i, i), d.restore();
524
524
  }
525
- const Wn = {
525
+ const Yn = {
526
526
  // Угловые точки
527
527
  tl: {
528
528
  render: ae,
529
- sizeX: pt,
530
- sizeY: pt,
529
+ sizeX: mt,
530
+ sizeY: mt,
531
531
  offsetX: 0,
532
532
  offsetY: 0
533
533
  },
534
534
  tr: {
535
535
  render: ae,
536
- sizeX: pt,
537
- sizeY: pt,
536
+ sizeX: mt,
537
+ sizeY: mt,
538
538
  offsetX: 0,
539
539
  offsetY: 0
540
540
  },
541
541
  bl: {
542
542
  render: ae,
543
- sizeX: pt,
544
- sizeY: pt,
543
+ sizeX: mt,
544
+ sizeY: mt,
545
545
  offsetX: 0,
546
546
  offsetY: 0
547
547
  },
548
548
  br: {
549
549
  render: ae,
550
- sizeX: pt,
551
- sizeY: pt,
550
+ sizeX: mt,
551
+ sizeY: mt,
552
552
  offsetX: 0,
553
553
  offsetY: 0
554
554
  },
555
555
  // Середина вертикалей
556
556
  ml: {
557
- render: Ve,
558
- sizeX: we,
559
- sizeY: Ae,
557
+ render: qe,
558
+ sizeX: Ae,
559
+ sizeY: je,
560
560
  offsetX: 0,
561
561
  offsetY: 0
562
562
  },
563
563
  mr: {
564
- render: Ve,
565
- sizeX: we,
566
- sizeY: Ae,
564
+ render: qe,
565
+ sizeX: Ae,
566
+ sizeY: je,
567
567
  offsetX: 0,
568
568
  offsetY: 0
569
569
  },
570
570
  // Середина горизонталей
571
571
  mt: {
572
- render: Xe,
573
- sizeX: je,
574
- sizeY: Ie,
572
+ render: Je,
573
+ sizeX: Ie,
574
+ sizeY: Ce,
575
575
  offsetX: 0,
576
576
  offsetY: 0
577
577
  },
578
578
  mb: {
579
- render: Xe,
580
- sizeX: je,
581
- sizeY: Ie,
579
+ render: Je,
580
+ sizeX: Ie,
581
+ sizeY: Ce,
582
582
  offsetX: 0,
583
583
  offsetY: 0
584
584
  },
@@ -607,7 +607,7 @@ class lt {
607
607
  * Применяет конфигурацию контролов к набору по ключам из DEFAULT_CONTROLS.
608
608
  */
609
609
  static applyControlOverrides(t) {
610
- Object.entries(Wn).forEach(([e, n]) => {
610
+ Object.entries(Yn).forEach(([e, n]) => {
611
611
  const s = t[e];
612
612
  s && (Object.assign(s, n), e === "mtr" && (s.cursorStyle = "grab", s.mouseDownHandler = (o, i, a, r) => {
613
613
  var l;
@@ -620,10 +620,10 @@ class lt {
620
620
  * Регистрирует контролы и настройки поведения выделений.
621
621
  */
622
622
  static apply() {
623
- const t = Ue.createObjectDefaultControls();
624
- lt.applyControlOverrides(t), We.ownDefaults.controls = t;
625
- const e = Ue.createTextboxDefaultControls();
626
- lt.applyControlOverrides(e), e.mt && (e.mt.visible = !1), e.mb && (e.mb.visible = !1), lt.wrapWidthControl(e.ml), lt.wrapWidthControl(e.mr), dt.ownDefaults.controls = e, lt.patchActiveSelectionBounds(), We.ownDefaults.snapAngle = 1;
623
+ const t = He.createObjectDefaultControls();
624
+ lt.applyControlOverrides(t), Ze.ownDefaults.controls = t;
625
+ const e = He.createTextboxDefaultControls();
626
+ lt.applyControlOverrides(e), e.mt && (e.mt.visible = !1), e.mb && (e.mb.visible = !1), lt.wrapWidthControl(e.ml), lt.wrapWidthControl(e.mr), dt.ownDefaults.controls = e, lt.patchActiveSelectionBounds(), Ze.ownDefaults.snapAngle = 1;
627
627
  }
628
628
  /**
629
629
  * Обновляет алгоритм расчёта границ ActiveSelection, чтобы учитывать фон и отступы текстовых объектов.
@@ -631,8 +631,8 @@ class lt {
631
631
  static patchActiveSelectionBounds() {
632
632
  const t = X.prototype, e = t._calcBoundsFromObjects;
633
633
  t._calcBoundsFromObjects = function(...o) {
634
- var f, g;
635
- const i = (g = (f = this.getObjects) == null ? void 0 : f.call(this)) != null ? g : [];
634
+ var f, p;
635
+ const i = (p = (f = this.getObjects) == null ? void 0 : f.call(this)) != null ? p : [];
636
636
  lt.applyTextSelectionScalingLock({
637
637
  selection: this,
638
638
  objects: i
@@ -654,8 +654,8 @@ class lt {
654
654
  };
655
655
  const n = t._onAfterObjectsChange;
656
656
  t._onAfterObjectsChange = function(o, i) {
657
- var m, p;
658
- const a = n ? n.call(this, o, i) : void 0, r = (p = (m = this.getObjects) == null ? void 0 : m.call(this)) != null ? p : [];
657
+ var m, g;
658
+ const a = n ? n.call(this, o, i) : void 0, r = (g = (m = this.getObjects) == null ? void 0 : m.call(this)) != null ? g : [];
659
659
  lt.applyTextSelectionScalingLock({
660
660
  selection: this,
661
661
  objects: r
@@ -664,14 +664,14 @@ class lt {
664
664
  objects: r
665
665
  });
666
666
  if (!c) return a;
667
- const { left: l, top: h, width: u, height: f } = c, g = new at(l + u / 2, h + f / 2);
667
+ const { left: l, top: h, width: u, height: f } = c, p = new at(l + u / 2, h + f / 2);
668
668
  return this.set({
669
669
  width: u,
670
670
  height: f
671
- }), this.setPositionByOrigin(g, "center", "center"), this.setCoords(), a;
671
+ }), this.setPositionByOrigin(p, "center", "center"), this.setCoords(), a;
672
672
  };
673
- const s = Ye.prototype.calcBoundingBox;
674
- Ye.prototype.calcBoundingBox = function(o, i) {
673
+ const s = Ge.prototype.calcBoundingBox;
674
+ Ge.prototype.calcBoundingBox = function(o, i) {
675
675
  const { target: a, type: r, overrides: c } = i;
676
676
  if (r === "imperative" && c)
677
677
  return c;
@@ -684,13 +684,13 @@ class lt {
684
684
  const l = lt.calculateActiveSelectionBounds({ objects: o });
685
685
  if (!l)
686
686
  return s.call(this, o, i);
687
- const { left: h, top: u, width: f, height: g } = l, m = new at(f, g), p = new at(h + f / 2, u + g / 2);
687
+ const { left: h, top: u, width: f, height: p } = l, m = new at(f, p), g = new at(h + f / 2, u + p / 2);
688
688
  return r === "initialization" ? {
689
- center: p,
689
+ center: g,
690
690
  relativeCorrection: new at(0, 0),
691
691
  size: m
692
692
  } : {
693
- center: p,
693
+ center: g,
694
694
  size: m
695
695
  };
696
696
  };
@@ -894,8 +894,8 @@ V.registeredFontKeys = /* @__PURE__ */ new Set(), V.descriptorDefaults = {
894
894
  featureSettings: "normal",
895
895
  display: "auto"
896
896
  };
897
- let Ce = V;
898
- const Yn = "", Hn = "", Zn = "", Gn = "", Vn = "", Xn = "", Kn = "", qn = "", Kt = {
897
+ let Te = V;
898
+ const Hn = "", Zn = "", Gn = "", Vn = "", Xn = "", Kn = "", qn = "", Jn = "", Kt = {
899
899
  style: {
900
900
  position: "absolute",
901
901
  display: "none",
@@ -962,14 +962,14 @@ const Yn = "
962
962
  ],
963
963
  offsetTop: 50,
964
964
  icons: {
965
- copyPaste: Yn,
966
- delete: qn,
967
- lock: Hn,
968
- unlock: Zn,
969
- bringToFront: Xn,
970
- sendToBack: Kn,
971
- bringForward: Gn,
972
- sendBackwards: Vn
965
+ copyPaste: Hn,
966
+ delete: Jn,
967
+ lock: Zn,
968
+ unlock: Gn,
969
+ bringToFront: Kn,
970
+ sendToBack: qn,
971
+ bringForward: Vn,
972
+ sendBackwards: Xn
973
973
  },
974
974
  handlers: {
975
975
  copyPaste: (d) => Z(null, null, function* () {
@@ -998,18 +998,18 @@ const Yn = "
998
998
  }
999
999
  }
1000
1000
  };
1001
- class Jn {
1001
+ class Qn {
1002
1002
  constructor({ editor: t }) {
1003
1003
  this.currentTarget = null, this.currentLocked = !1, this.isTransforming = !1, this.isTemporarilyHidden = !1, this.editor = t, this.canvas = t.canvas, this.options = t.options, this._initToolbar();
1004
1004
  }
1005
1005
  _initToolbar() {
1006
1006
  if (!this.options.showToolbar) return;
1007
1007
  const t = this.options.toolbar || {};
1008
- this.config = It(L(L({}, Kt), t), {
1009
- style: L(L({}, Kt.style), t.style || {}),
1010
- btnStyle: L(L({}, Kt.btnStyle), t.btnStyle || {}),
1011
- icons: L(L({}, Kt.icons), t.icons || {}),
1012
- handlers: L(L({}, Kt.handlers), t.handlers || {})
1008
+ this.config = It(x(x({}, Kt), t), {
1009
+ style: x(x({}, Kt.style), t.style || {}),
1010
+ btnStyle: x(x({}, Kt.btnStyle), t.btnStyle || {}),
1011
+ icons: x(x({}, Kt.icons), t.icons || {}),
1012
+ handlers: x(x({}, Kt.handlers), t.handlers || {})
1013
1013
  }), 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 = () => {
1014
1014
  this.el.style.display = "none";
1015
1015
  }, this._createDOM(), this._bindEvents();
@@ -1112,10 +1112,10 @@ class Jn {
1112
1112
  }
1113
1113
  const { el: e, config: n, canvas: s } = this;
1114
1114
  t.setCoords();
1115
- const o = s.getZoom(), [, , , , i, a] = s.viewportTransform, { x: r } = t.getCenterPoint(), { top: c, height: l } = t.getBoundingRect(), u = r * o + i - e.offsetWidth / 2, f = n.offsetTop || 0, g = (c + l) * o + a + f;
1115
+ const o = s.getZoom(), [, , , , i, a] = s.viewportTransform, { x: r } = t.getCenterPoint(), { top: c, height: l } = t.getBoundingRect(), u = r * o + i - e.offsetWidth / 2, f = n.offsetTop || 0, p = (c + l) * o + a + f;
1116
1116
  Object.assign(e.style, {
1117
1117
  left: `${u}px`,
1118
- top: `${g}px`,
1118
+ top: `${p}px`,
1119
1119
  display: "flex"
1120
1120
  });
1121
1121
  }
@@ -1126,7 +1126,7 @@ class Jn {
1126
1126
  this.el.removeEventListener("mouseover", this._onBtnOver), this.el.removeEventListener("mouseout", this._onBtnOut), this.canvas.off("mouse:down", this._onMouseDown), this.canvas.off("object:moving", this._onObjectMoving), this.canvas.off("object:scaling", this._onObjectScaling), this.canvas.off("object:rotating", this._onObjectRotating), this.canvas.off("mouse:up", this._onMouseUp), this.canvas.off("object:modified", this._onObjectModified), this.canvas.off("selection:created", this._onSelectionChange), this.canvas.off("selection:updated", this._onSelectionChange), this.canvas.off("after:render", this._onSelectionChange), this.canvas.off("selection:cleared", this._onSelectionClear), this.el.remove();
1127
1127
  }
1128
1128
  }
1129
- const Qn = {
1129
+ const $n = {
1130
1130
  position: "absolute",
1131
1131
  display: "none",
1132
1132
  background: "#2B2D33",
@@ -1140,8 +1140,8 @@ const Qn = {
1140
1140
  "pointer-events": "none",
1141
1141
  "white-space": "nowrap",
1142
1142
  "box-shadow": "0 2px 8px rgba(0, 0, 0, 0.2)"
1143
- }, Ke = 16, qe = 16, $n = "fabric-editor-angle-indicator";
1144
- class Re {
1143
+ }, Qe = 16, $e = 16, ts = "fabric-editor-angle-indicator";
1144
+ class Be {
1145
1145
  constructor({ editor: t }) {
1146
1146
  this.isActive = !1, this.currentAngle = 0, this.editor = t, this.canvas = t.canvas, this.options = t.options, this._createDOM(), this._bindEvents();
1147
1147
  }
@@ -1149,7 +1149,7 @@ class Re {
1149
1149
  * Создание DOM-элемента индикатора
1150
1150
  */
1151
1151
  _createDOM() {
1152
- this.el = document.createElement("div"), this.el.className = $n, Object.entries(Qn).forEach(([t, e]) => {
1152
+ this.el = document.createElement("div"), this.el.className = ts, Object.entries($n).forEach(([t, e]) => {
1153
1153
  this.el.style.setProperty(t, e);
1154
1154
  }), this.canvas.wrapperEl.appendChild(this.el);
1155
1155
  }
@@ -1169,7 +1169,7 @@ class Re {
1169
1169
  return;
1170
1170
  }
1171
1171
  const n = e.angle || 0;
1172
- this.currentAngle = Re._normalizeAngle(n), this.el.textContent = `${this.currentAngle}°`, this._positionIndicator(t.e), this.isActive || this._showIndicator();
1172
+ this.currentAngle = Be._normalizeAngle(n), this.el.textContent = `${this.currentAngle}°`, this._positionIndicator(t.e), this.isActive || this._showIndicator();
1173
1173
  }
1174
1174
  /**
1175
1175
  * Обработчик отпускания кнопки мыши
@@ -1200,9 +1200,9 @@ class Re {
1200
1200
  */
1201
1201
  _positionIndicator(t) {
1202
1202
  const e = this.canvas.wrapperEl.getBoundingClientRect();
1203
- let n = t.clientX - e.left + Ke, s = t.clientY - e.top + qe;
1203
+ let n = t.clientX - e.left + Qe, s = t.clientY - e.top + $e;
1204
1204
  const o = this.el.getBoundingClientRect(), i = o.width, a = o.height;
1205
- n + i > e.width && (n = t.clientX - e.left - i - Ke), s + a > e.height && (s = t.clientY - e.top - a - qe), this.el.style.left = `${n}px`, this.el.style.top = `${s}px`;
1205
+ n + i > e.width && (n = t.clientX - e.left - i - Qe), s + a > e.height && (s = t.clientY - e.top - a - $e), this.el.style.left = `${n}px`, this.el.style.top = `${s}px`;
1206
1206
  }
1207
1207
  /**
1208
1208
  * Показать индикатор
@@ -1233,7 +1233,7 @@ class Re {
1233
1233
  this.canvas && (this.canvas.off("object:rotating", this._onObjectRotating), this.canvas.off("mouse:up", this._onMouseUp), this.canvas.off("object:modified", this._onObjectModified), this.canvas.off("selection:cleared", this._onSelectionCleared)), (t = this.el) != null && t.parentNode && this.el.parentNode.removeChild(this.el), this.el = null, this.editor = null, this.canvas = null, this.options = null;
1234
1234
  }
1235
1235
  }
1236
- const Te = [
1236
+ const Oe = [
1237
1237
  "id",
1238
1238
  "backgroundId",
1239
1239
  "customData",
@@ -1283,7 +1283,7 @@ class K {
1283
1283
  return this.patches[this.currentIndex - 1] || null;
1284
1284
  }
1285
1285
  _createDiffPatcher() {
1286
- this.diffPatcher = Ln({
1286
+ this.diffPatcher = Dn({
1287
1287
  objectHash(t) {
1288
1288
  return [JSON.stringify(t)].join("-");
1289
1289
  },
@@ -1292,7 +1292,7 @@ class K {
1292
1292
  includeValueOnMove: !1
1293
1293
  },
1294
1294
  textDiff: {
1295
- diffMatchPatch: Dn,
1295
+ diffMatchPatch: _n,
1296
1296
  minLength: 60
1297
1297
  }
1298
1298
  });
@@ -1368,7 +1368,7 @@ class K {
1368
1368
  */
1369
1369
  _serializeCanvasState() {
1370
1370
  const { canvas: t } = this;
1371
- return t.toDatalessObject([...Te]);
1371
+ return t.toDatalessObject([...Oe]);
1372
1372
  }
1373
1373
  /**
1374
1374
  * Обрабатывает срабатывание отложенного сохранения.
@@ -1429,7 +1429,7 @@ class K {
1429
1429
  this._isSavingState = !0, console.time("saveState");
1430
1430
  try {
1431
1431
  const t = this._withTemporaryUnlock(
1432
- () => this.canvas.toDatalessObject([...Te])
1432
+ () => this.canvas.toDatalessObject([...Oe])
1433
1433
  );
1434
1434
  if (console.timeEnd("saveState"), !this.baseState) {
1435
1435
  this.baseState = t, this.patches = [], this.currentIndex = 0, console.log("Базовое состояние сохранено.");
@@ -1453,7 +1453,7 @@ class K {
1453
1453
  console.log("statesEqual. Нет изменений для сохранения.");
1454
1454
  return;
1455
1455
  }
1456
- 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: $(), 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);
1456
+ 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: tt(), 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);
1457
1457
  } finally {
1458
1458
  this._isSavingState = !1;
1459
1459
  }
@@ -1576,14 +1576,14 @@ class K {
1576
1576
  id: "montage-area"
1577
1577
  });
1578
1578
  f && (f.left = a, f.top = r);
1579
- const g = K._getClipPathPosition({ clipPath: s });
1580
- if (g && i && typeof i == "object") {
1581
- const { left: p, top: v } = g, M = i;
1582
- M.left = p, M.top = v;
1579
+ const p = K._getClipPathPosition({ clipPath: s });
1580
+ if (p && i && typeof i == "object") {
1581
+ const { left: g, top: v } = p, M = i;
1582
+ M.left = g, M.top = v;
1583
1583
  }
1584
1584
  const m = K._getTranslationIgnoredIds();
1585
- for (let p = 0; p < o.length; p += 1) {
1586
- const v = o[p], { id: M } = v;
1585
+ for (let g = 0; g < o.length; g += 1) {
1586
+ const v = o[g], { id: M } = v;
1587
1587
  M && m.has(M) || (typeof v.left == "number" && (v.left -= h), typeof v.top == "number" && (v.top -= u));
1588
1588
  }
1589
1589
  }
@@ -1822,7 +1822,7 @@ class K {
1822
1822
  }
1823
1823
  }
1824
1824
  }
1825
- const ts = 0.1, es = 2, Je = 0.1, ns = 90, Ft = 16, Ut = 16, Ot = 4096, Et = 4096, Qe = "application/image-editor:", re = [
1825
+ const es = 0.1, ns = 2, tn = 0.1, ss = 90, Ft = 16, Wt = 16, Ot = 4096, Et = 4096, en = "application/image-editor:", re = [
1826
1826
  "format",
1827
1827
  "uppercase",
1828
1828
  "textCaseRaw",
@@ -1837,8 +1837,8 @@ const ts = 0.1, es = 2, Je = 0.1, ns = 90, Ft = 16, Ut = 16, Ot = 4096, Et = 409
1837
1837
  "radiusBottomRight",
1838
1838
  "radiusBottomLeft",
1839
1839
  "lineFontDefaults"
1840
- ], ss = 50;
1841
- class mt {
1840
+ ], is = 50;
1841
+ class yt {
1842
1842
  constructor({ editor: t }) {
1843
1843
  this.editor = t, this.options = t.options, this._createdBlobUrls = [], this.acceptContentTypes = this.editor.options.acceptContentTypes, this.acceptFormats = this.getAllowedFormatsFromContentTypes();
1844
1844
  }
@@ -1867,17 +1867,17 @@ class mt {
1867
1867
  customData: c = null
1868
1868
  } = t;
1869
1869
  if (!e) return null;
1870
- const { canvas: l, montageArea: h, transformManager: u, historyManager: f, errorManager: g } = this.editor, m = yield this.getContentType(e), p = mt.getFormatFromContentType(m), { acceptContentTypes: v, acceptFormats: M } = this;
1870
+ const { canvas: l, montageArea: h, transformManager: u, historyManager: f, errorManager: p } = this.editor, m = yield this.getContentType(e), g = yt.getFormatFromContentType(m), { acceptContentTypes: v, acceptFormats: M } = this;
1871
1871
  if (!this.isAllowedContentType(m)) {
1872
- const j = `Неверный contentType для изображения: ${m}. Ожидается один из: ${this.acceptContentTypes.join(", ")}.`;
1873
- return g.emitError({
1872
+ const C = `Неверный contentType для изображения: ${m}. Ожидается один из: ${this.acceptContentTypes.join(", ")}.`;
1873
+ return p.emitError({
1874
1874
  origin: "ImageManager",
1875
1875
  method: "importImage",
1876
1876
  code: "INVALID_CONTENT_TYPE",
1877
- message: j,
1877
+ message: C,
1878
1878
  data: {
1879
1879
  source: e,
1880
- format: p,
1880
+ format: g,
1881
1881
  contentType: m,
1882
1882
  acceptContentTypes: v,
1883
1883
  acceptFormats: M,
@@ -1891,21 +1891,21 @@ class mt {
1891
1891
  }
1892
1892
  f.suspendHistory();
1893
1893
  try {
1894
- let j, y;
1894
+ let C, y;
1895
1895
  if (e instanceof File)
1896
- j = URL.createObjectURL(e);
1896
+ C = URL.createObjectURL(e);
1897
1897
  else if (typeof e == "string") {
1898
1898
  const A = yield (yield fetch(e, { mode: "cors" })).blob();
1899
- j = URL.createObjectURL(A);
1899
+ C = URL.createObjectURL(A);
1900
1900
  } else
1901
- return g.emitError({
1901
+ return p.emitError({
1902
1902
  origin: "ImageManager",
1903
1903
  method: "importImage",
1904
1904
  code: "INVALID_SOURCE_TYPE",
1905
1905
  message: "Неверный тип источника изображения. Ожидается URL или объект File.",
1906
1906
  data: {
1907
1907
  source: e,
1908
- format: p,
1908
+ format: g,
1909
1909
  contentType: m,
1910
1910
  acceptContentTypes: v,
1911
1911
  acceptFormats: M,
@@ -1916,32 +1916,32 @@ class mt {
1916
1916
  customData: c
1917
1917
  }
1918
1918
  }), null;
1919
- if (this._createdBlobUrls.push(j), p === "svg") {
1920
- const b = yield wn(j);
1921
- y = yt.groupSVGElements(b.objects, b.options);
1919
+ if (this._createdBlobUrls.push(C), g === "svg") {
1920
+ const b = yield An(C);
1921
+ y = ft.groupSVGElements(b.objects, b.options);
1922
1922
  } else
1923
- y = yield Xt.fromURL(j, { crossOrigin: "anonymous" });
1924
- const { width: w, height: I } = y;
1923
+ y = yield Xt.fromURL(C, { crossOrigin: "anonymous" });
1924
+ const { width: w, height: j } = y;
1925
1925
  if (y instanceof Xt) {
1926
1926
  const b = y.getElement();
1927
1927
  let A = "";
1928
- if (b instanceof HTMLImageElement ? A = b.src : b instanceof HTMLCanvasElement && (A = b.toDataURL()), I > Et || w > Ot) {
1929
- const S = yield this.resizeImageToBoundaries(A, "max"), T = URL.createObjectURL(S);
1930
- this._createdBlobUrls.push(T), y = yield Xt.fromURL(T, { crossOrigin: "anonymous" });
1931
- } else if (I < Ut || w < Ft) {
1932
- const S = yield this.resizeImageToBoundaries(A, "min"), T = URL.createObjectURL(S);
1933
- this._createdBlobUrls.push(T), y = yield Xt.fromURL(T, { crossOrigin: "anonymous" });
1928
+ if (b instanceof HTMLImageElement ? A = b.src : b instanceof HTMLCanvasElement && (A = b.toDataURL()), j > Et || w > Ot) {
1929
+ const S = yield this.resizeImageToBoundaries(A, "max"), I = URL.createObjectURL(S);
1930
+ this._createdBlobUrls.push(I), y = yield Xt.fromURL(I, { crossOrigin: "anonymous" });
1931
+ } else if (j < Wt || w < Ft) {
1932
+ const S = yield this.resizeImageToBoundaries(A, "min"), I = URL.createObjectURL(S);
1933
+ this._createdBlobUrls.push(I), y = yield Xt.fromURL(I, { crossOrigin: "anonymous" });
1934
1934
  }
1935
1935
  }
1936
- if (y.set("id", `${y.type}-${$()}`), y.set("format", p), y.set("customData", c || null), n === "scale-montage")
1936
+ if (y.set("id", `${y.type}-${tt()}`), y.set("format", g), y.set("customData", c || null), n === "scale-montage")
1937
1937
  this.editor.canvasManager.scaleMontageAreaToImage({ object: y, withoutSave: !0 });
1938
1938
  else {
1939
1939
  const { width: b, height: A } = h, S = this.calculateScaleFactor({ imageObject: y, scaleType: n });
1940
- n === "image-contain" && S < 1 ? u.fitObject({ object: y, type: "contain", withoutSave: !0 }) : n === "image-cover" && (w > b || I > A) && u.fitObject({ object: y, type: "cover", withoutSave: !0 });
1940
+ n === "image-contain" && S < 1 ? u.fitObject({ object: y, type: "contain", withoutSave: !0 }) : n === "image-cover" && (w > b || j > A) && u.fitObject({ object: y, type: "cover", withoutSave: !0 });
1941
1941
  }
1942
- const C = {
1942
+ const T = {
1943
1943
  image: y,
1944
- format: p,
1944
+ format: g,
1945
1945
  contentType: m,
1946
1946
  scale: n,
1947
1947
  withoutSave: s,
@@ -1952,16 +1952,16 @@ class mt {
1952
1952
  withoutAdding: r,
1953
1953
  customData: c
1954
1954
  };
1955
- return r ? (f.resumeHistory(), l.fire("editor:image-imported", C), C) : (l.add(y), l.centerObject(y), a || l.setActiveObject(y), l.renderAll(), f.resumeHistory(), s || f.saveState(), l.fire("editor:image-imported", C), C);
1956
- } catch (j) {
1957
- return g.emitError({
1955
+ return r ? (f.resumeHistory(), l.fire("editor:image-imported", T), T) : (l.add(y), l.centerObject(y), a || l.setActiveObject(y), l.renderAll(), f.resumeHistory(), s || f.saveState(), l.fire("editor:image-imported", T), T);
1956
+ } catch (C) {
1957
+ return p.emitError({
1958
1958
  origin: "ImageManager",
1959
1959
  method: "importImage",
1960
1960
  code: "IMPORT_FAILED",
1961
- message: `Ошибка импорта изображения: ${j.message}`,
1961
+ message: `Ошибка импорта изображения: ${C.message}`,
1962
1962
  data: {
1963
1963
  source: e,
1964
- format: p,
1964
+ format: g,
1965
1965
  contentType: m,
1966
1966
  scale: n,
1967
1967
  withoutSave: s,
@@ -1986,14 +1986,14 @@ class mt {
1986
1986
  resizeImageToBoundaries(t, e = "max") {
1987
1987
  return Z(this, null, function* () {
1988
1988
  let n = `Размер изображения больше максимального размера канваса, поэтому оно будет уменьшено до максимальных размеров c сохранением пропорций: ${Ot}x${Et}`;
1989
- e === "min" && (n = `Размер изображения меньше минимального размера канваса, поэтому оно будет увеличено до минимальных размеров c сохранением пропорций: ${Ft}x${Ut}`);
1989
+ e === "min" && (n = `Размер изображения меньше минимального размера канваса, поэтому оно будет увеличено до минимальных размеров c сохранением пропорций: ${Ft}x${Wt}`);
1990
1990
  const s = {
1991
1991
  dataURL: t,
1992
1992
  sizeType: e,
1993
1993
  maxWidth: Ot,
1994
1994
  maxHeight: Et,
1995
1995
  minWidth: Ft,
1996
- minHeight: Ut
1996
+ minHeight: Wt
1997
1997
  };
1998
1998
  return this.editor.errorManager.emitWarning({
1999
1999
  origin: "ImageManager",
@@ -2024,22 +2024,22 @@ class mt {
2024
2024
  exportAsBlob: o = !1
2025
2025
  } = t, { canvas: i, montageArea: a, workerManager: r, interactionBlocker: c } = this.editor;
2026
2026
  try {
2027
- const l = n === "application/pdf", h = l ? "image/jpg" : n, u = mt.getFormatFromContentType(h);
2027
+ const l = n === "application/pdf", h = l ? "image/jpg" : n, u = yt.getFormatFromContentType(h);
2028
2028
  a.setCoords();
2029
- const { left: f, top: g, width: m, height: p } = a.getBoundingRect(), v = yield i.clone(["id", "format", "locked"]);
2029
+ const { left: f, top: p, width: m, height: g } = a.getBoundingRect(), v = yield i.clone(["id", "format", "locked"]);
2030
2030
  v.enableRetinaScaling = !1, ["image/jpg", "image/jpeg"].includes(h) && (v.backgroundColor = "#ffffff");
2031
2031
  const M = v.getObjects().find((S) => S.id === a.id);
2032
2032
  if (M && (M.visible = !1), c != null && c.isBlocked) {
2033
- const S = v.getObjects().find((T) => T.id === c.overlayMask.id);
2033
+ const S = v.getObjects().find((I) => I.id === c.overlayMask.id);
2034
2034
  S && (S.visible = !1);
2035
2035
  }
2036
- v.viewportTransform = [1, 0, 0, 1, -f, -g], v.setDimensions({ width: m, height: p }, { backstoreOnly: !0 }), v.renderAll();
2037
- const j = v.getObjects().filter((S) => S.format).every((S) => S.format === "svg");
2038
- if (u === "svg" && j) {
2036
+ v.viewportTransform = [1, 0, 0, 1, -f, -p], v.setDimensions({ width: m, height: g }, { backstoreOnly: !0 }), v.renderAll();
2037
+ const C = v.getObjects().filter((S) => S.format).every((S) => S.format === "svg");
2038
+ if (u === "svg" && C) {
2039
2039
  const S = v.toSVG();
2040
2040
  v.dispose();
2041
2041
  const O = {
2042
- image: mt._exportSVGStringAsFile(S, {
2042
+ image: yt._exportSVGStringAsFile(S, {
2043
2043
  exportAsBase64: s,
2044
2044
  exportAsBlob: o,
2045
2045
  fileName: e
@@ -2050,9 +2050,9 @@ class mt {
2050
2050
  };
2051
2051
  return i.fire("editor:canvas-exported", O), O;
2052
2052
  }
2053
- const y = yield new Promise((S, T) => {
2053
+ const y = yield new Promise((S, I) => {
2054
2054
  v.getElement().toBlob((O) => {
2055
- O ? S(O) : T(new Error("Failed to create Blob from canvas"));
2055
+ O ? S(O) : I(new Error("Failed to create Blob from canvas"));
2056
2056
  });
2057
2057
  });
2058
2058
  if (v.dispose(), o) {
@@ -2064,28 +2064,28 @@ class mt {
2064
2064
  };
2065
2065
  return i.fire("editor:canvas-exported", S), S;
2066
2066
  }
2067
- const w = yield createImageBitmap(y), I = yield r.post(
2067
+ const w = yield createImageBitmap(y), j = yield r.post(
2068
2068
  "toDataURL",
2069
2069
  { format: u, quality: 1, bitmap: w },
2070
2070
  [w]
2071
2071
  );
2072
2072
  if (l) {
2073
- const T = m * 0.264583, O = p * 0.264583, P = (yield this.editor.moduleLoader.loadModule("jspdf")).jsPDF, U = new P({
2074
- orientation: T > O ? "landscape" : "portrait",
2073
+ const I = m * 0.264583, O = g * 0.264583, N = (yield this.editor.moduleLoader.loadModule("jspdf")).jsPDF, W = new N({
2074
+ orientation: I > O ? "landscape" : "portrait",
2075
2075
  unit: "mm",
2076
- format: [T, O]
2076
+ format: [I, O]
2077
2077
  });
2078
- if (U.addImage(String(I), "JPG", 0, 0, T, O), s) {
2079
- const z = {
2080
- image: U.output("datauristring"),
2078
+ if (W.addImage(String(j), "JPG", 0, 0, I, O), s) {
2079
+ const R = {
2080
+ image: W.output("datauristring"),
2081
2081
  format: "pdf",
2082
2082
  contentType: "application/pdf",
2083
2083
  fileName: e
2084
2084
  };
2085
- return i.fire("editor:canvas-exported", z), z;
2085
+ return i.fire("editor:canvas-exported", R), R;
2086
2086
  }
2087
- const F = U.output("blob"), B = {
2088
- image: new File([F], e, { type: "application/pdf" }),
2087
+ const z = W.output("blob"), B = {
2088
+ image: new File([z], e, { type: "application/pdf" }),
2089
2089
  format: "pdf",
2090
2090
  contentType: "application/pdf",
2091
2091
  fileName: e
@@ -2094,18 +2094,18 @@ class mt {
2094
2094
  }
2095
2095
  if (s) {
2096
2096
  const S = {
2097
- image: I,
2097
+ image: j,
2098
2098
  format: u,
2099
2099
  contentType: h,
2100
2100
  fileName: e
2101
2101
  };
2102
2102
  return i.fire("editor:canvas-exported", S), S;
2103
2103
  }
2104
- const C = u === "svg" && !j ? e.replace(/\.[^/.]+$/, ".png") : e, A = {
2105
- image: new File([y], C, { type: h }),
2104
+ const T = u === "svg" && !C ? e.replace(/\.[^/.]+$/, ".png") : e, A = {
2105
+ image: new File([y], T, { type: h }),
2106
2106
  format: u,
2107
2107
  contentType: h,
2108
- fileName: C
2108
+ fileName: T
2109
2109
  };
2110
2110
  return i.fire("editor:canvas-exported", A), A;
2111
2111
  } catch (l) {
@@ -2148,15 +2148,15 @@ class mt {
2148
2148
  data: { contentType: s, fileName: n, exportAsBase64: o, exportAsBlob: i }
2149
2149
  }), null;
2150
2150
  try {
2151
- const l = mt.getFormatFromContentType(s);
2151
+ const l = yt.getFormatFromContentType(s);
2152
2152
  if (l === "svg") {
2153
- const m = c.toSVG(), p = mt._exportSVGStringAsFile(m, {
2153
+ const m = c.toSVG(), g = yt._exportSVGStringAsFile(m, {
2154
2154
  exportAsBase64: o,
2155
2155
  exportAsBlob: i,
2156
2156
  fileName: n
2157
2157
  }), v = {
2158
2158
  object: c,
2159
- image: p,
2159
+ image: g,
2160
2160
  format: l,
2161
2161
  contentType: "image/svg+xml",
2162
2162
  fileName: n.replace(/\.[^/.]+$/, ".svg")
@@ -2164,7 +2164,7 @@ class mt {
2164
2164
  return a.fire("editor:object-exported", v), v;
2165
2165
  }
2166
2166
  if (o && c instanceof Xt) {
2167
- const m = yield createImageBitmap(c.getElement()), p = yield r.post(
2167
+ const m = yield createImageBitmap(c.getElement()), g = yield r.post(
2168
2168
  "toDataURL",
2169
2169
  {
2170
2170
  format: l,
@@ -2174,7 +2174,7 @@ class mt {
2174
2174
  [m]
2175
2175
  ), v = {
2176
2176
  object: c,
2177
- image: p,
2177
+ image: g,
2178
2178
  format: l,
2179
2179
  contentType: s,
2180
2180
  fileName: n
@@ -2183,9 +2183,9 @@ class mt {
2183
2183
  }
2184
2184
  const h = c.toCanvasElement({
2185
2185
  enableRetinaScaling: !1
2186
- }), u = yield new Promise((m, p) => {
2186
+ }), u = yield new Promise((m, g) => {
2187
2187
  h.toBlob((v) => {
2188
- v ? m(v) : p(new Error("Failed to create Blob from canvas"));
2188
+ v ? m(v) : g(new Error("Failed to create Blob from canvas"));
2189
2189
  });
2190
2190
  });
2191
2191
  if (i) {
@@ -2198,14 +2198,14 @@ class mt {
2198
2198
  };
2199
2199
  return a.fire("editor:object-exported", m), m;
2200
2200
  }
2201
- const f = new File([u], n, { type: s }), g = {
2201
+ const f = new File([u], n, { type: s }), p = {
2202
2202
  object: c,
2203
2203
  image: f,
2204
2204
  format: l,
2205
2205
  contentType: s,
2206
2206
  fileName: n
2207
2207
  };
2208
- return a.fire("editor:object-exported", g), g;
2208
+ return a.fire("editor:object-exported", p), p;
2209
2209
  } catch (l) {
2210
2210
  return this.editor.errorManager.emitError({
2211
2211
  origin: "ImageManager",
@@ -2228,7 +2228,7 @@ class mt {
2228
2228
  * @returns массив допустимых форматов изображений
2229
2229
  */
2230
2230
  getAllowedFormatsFromContentTypes() {
2231
- return this.acceptContentTypes.map((t) => mt.getFormatFromContentType(t)).filter((t) => t);
2231
+ return this.acceptContentTypes.map((t) => yt.getFormatFromContentType(t)).filter((t) => t);
2232
2232
  }
2233
2233
  /**
2234
2234
  * Проверяет, является ли contentType допустимым типом изображения.
@@ -2281,7 +2281,7 @@ class mt {
2281
2281
  try {
2282
2282
  const s = (e = new URL(t).pathname.split(".").pop()) == null ? void 0 : e.toLowerCase(), o = {};
2283
2283
  return this.acceptContentTypes.forEach((i) => {
2284
- const a = mt.getFormatFromContentType(i);
2284
+ const a = yt.getFormatFromContentType(i);
2285
2285
  a && (o[a] = i);
2286
2286
  }), s && o[s] || "application/octet-stream";
2287
2287
  } catch (n) {
@@ -2334,11 +2334,11 @@ class mt {
2334
2334
  return e ? e[1] : "";
2335
2335
  }
2336
2336
  }
2337
- const St = (d, t, e) => Math.max(Math.min(d, e), t), $e = (d, t) => d * t, is = (d, t) => new at(d / 2, t / 2);
2338
- function os(d) {
2337
+ const St = (d, t, e) => Math.max(Math.min(d, e), t), nn = (d, t) => d * t, os = (d, t) => new at(d / 2, t / 2);
2338
+ function as(d) {
2339
2339
  return ((d == null ? void 0 : d.type) === "image" || (d == null ? void 0 : d.format) === "svg") && typeof (d == null ? void 0 : d.width) == "number" && typeof (d == null ? void 0 : d.height) == "number";
2340
2340
  }
2341
- class as {
2341
+ class rs {
2342
2342
  /**
2343
2343
  * @param options
2344
2344
  * @param options.editor – экземпляр редактора
@@ -2379,16 +2379,16 @@ class as {
2379
2379
  * @fires editor:resolution-width-changed
2380
2380
  */
2381
2381
  setResolutionWidth(t, { preserveProportional: e, withoutSave: n, adaptCanvasToContainer: s } = {}) {
2382
- var g;
2382
+ var p;
2383
2383
  if (!t) return;
2384
2384
  const {
2385
2385
  canvas: o,
2386
2386
  montageArea: i,
2387
2387
  options: { canvasBackstoreWidth: a }
2388
2388
  } = this.editor, { width: r, height: c } = i, l = St(Number(t), Ft, Ot);
2389
- if (!a || a === "auto" || s ? this.adaptCanvasToContainer() : a ? this.setCanvasBackstoreWidth(Number(a)) : this.setCanvasBackstoreWidth(l), i.set({ width: l }), (g = o.clipPath) == null || g.set({ width: l }), e) {
2390
- const m = l / r, p = $e(c, m);
2391
- this.setResolutionHeight(p);
2389
+ if (!a || a === "auto" || s ? this.adaptCanvasToContainer() : a ? this.setCanvasBackstoreWidth(Number(a)) : this.setCanvasBackstoreWidth(l), i.set({ width: l }), (p = o.clipPath) == null || p.set({ width: l }), e) {
2390
+ const m = l / r, g = nn(c, m);
2391
+ this.setResolutionHeight(g);
2392
2392
  return;
2393
2393
  }
2394
2394
  const { left: h, top: u } = this.getObjectDefaultCoords(i), f = o.getZoom();
@@ -2409,16 +2409,16 @@ class as {
2409
2409
  * @fires editor:resolution-height-changed
2410
2410
  */
2411
2411
  setResolutionHeight(t, { preserveProportional: e, withoutSave: n, adaptCanvasToContainer: s } = {}) {
2412
- var g;
2412
+ var p;
2413
2413
  if (!t) return;
2414
2414
  const {
2415
2415
  canvas: o,
2416
2416
  montageArea: i,
2417
2417
  options: { canvasBackstoreHeight: a }
2418
- } = this.editor, { width: r, height: c } = i, l = St(Number(t), Ut, Et);
2419
- if (!a || a === "auto" || s ? this.adaptCanvasToContainer() : a ? this.setCanvasBackstoreHeight(Number(a)) : this.setCanvasBackstoreHeight(l), i.set({ height: l }), (g = o.clipPath) == null || g.set({ height: l }), e) {
2420
- const m = l / c, p = $e(r, m);
2421
- this.setResolutionWidth(p);
2418
+ } = this.editor, { width: r, height: c } = i, l = St(Number(t), Wt, Et);
2419
+ if (!a || a === "auto" || s ? this.adaptCanvasToContainer() : a ? this.setCanvasBackstoreHeight(Number(a)) : this.setCanvasBackstoreHeight(l), i.set({ height: l }), (p = o.clipPath) == null || p.set({ height: l }), e) {
2420
+ const m = l / c, g = nn(r, m);
2421
+ this.setResolutionWidth(g);
2422
2422
  return;
2423
2423
  }
2424
2424
  const { left: h, top: u } = this.getObjectDefaultCoords(i), f = o.getZoom();
@@ -2435,7 +2435,7 @@ class as {
2435
2435
  */
2436
2436
  centerMontageArea() {
2437
2437
  var r;
2438
- const { canvas: t, montageArea: e } = this.editor, n = t.getWidth(), s = t.getHeight(), o = t.getZoom(), i = is(n, s);
2438
+ const { canvas: t, montageArea: e } = this.editor, n = t.getWidth(), s = t.getHeight(), o = t.getZoom(), i = os(n, s);
2439
2439
  e.set({
2440
2440
  left: n / 2,
2441
2441
  top: s / 2
@@ -2477,7 +2477,7 @@ class as {
2477
2477
  */
2478
2478
  setCanvasBackstoreHeight(t) {
2479
2479
  if (!t || typeof t != "number") return;
2480
- const e = St(t, Ut, Et);
2480
+ const e = St(t, Wt, Et);
2481
2481
  this.editor.canvas.setDimensions({ height: e }, { backstoreOnly: !0 });
2482
2482
  }
2483
2483
  /**
@@ -2486,7 +2486,7 @@ class as {
2486
2486
  * с учётом минимальных и максимальных значений.
2487
2487
  */
2488
2488
  adaptCanvasToContainer() {
2489
- const { canvas: t } = this.editor, e = this.getEditorContainer(), n = e.clientWidth, s = e.clientHeight, o = St(n, Ft, Ot), i = St(s, Ut, Et);
2489
+ const { canvas: t } = this.editor, e = this.getEditorContainer(), n = e.clientWidth, s = e.clientHeight, o = St(n, Ft, Ot), i = St(s, Wt, Et);
2490
2490
  t.setDimensions({ width: o, height: i }, { backstoreOnly: !0 });
2491
2491
  }
2492
2492
  /**
@@ -2686,15 +2686,15 @@ class as {
2686
2686
  montageAreaHeight: r
2687
2687
  }
2688
2688
  } = this.editor, c = t || s.getActiveObject();
2689
- if (!os(c)) return;
2689
+ if (!as(c)) return;
2690
2690
  const { width: l, height: h } = c;
2691
2691
  let u = Math.min(l, Ot), f = Math.min(h, Et);
2692
2692
  if (e) {
2693
2693
  const {
2694
- width: g,
2694
+ width: p,
2695
2695
  height: m
2696
- } = o, p = l / g, v = h / m, M = Math.max(p, v);
2697
- u = g * M, f = m * M;
2696
+ } = o, g = l / p, v = h / m, M = Math.max(g, v);
2697
+ u = p * M, f = m * M;
2698
2698
  }
2699
2699
  this.setResolutionWidth(u, { withoutSave: !0 }), this.setResolutionHeight(f, { withoutSave: !0 }), this.editor.backgroundManager.backgroundObject && this.editor.backgroundManager.refresh(), (l > a || h > r) && this.editor.zoomManager.calculateAndApplyDefaultZoom(), i.resetObject({ object: c, withoutSave: !0 }), s.centerObject(c), s.renderAll(), n || this.editor.historyManager.saveState(), s.fire("editor:montage-area-scaled-to-image", {
2700
2700
  object: c,
@@ -2746,7 +2746,7 @@ class as {
2746
2746
  );
2747
2747
  }
2748
2748
  }
2749
- class rs {
2749
+ class cs {
2750
2750
  constructor({ editor: t }) {
2751
2751
  this.editor = t, this.options = t.options;
2752
2752
  }
@@ -2757,7 +2757,7 @@ class rs {
2757
2757
  * @param options.withoutSave - Не сохранять состояние
2758
2758
  * @fires editor:object-rotated
2759
2759
  */
2760
- rotate(t = ns, { withoutSave: e } = {}) {
2760
+ rotate(t = ss, { withoutSave: e } = {}) {
2761
2761
  const { canvas: n, historyManager: s } = this.editor, o = n.getActiveObject();
2762
2762
  if (!o) return;
2763
2763
  const i = o.angle + t;
@@ -2858,11 +2858,11 @@ class rs {
2858
2858
  * @private
2859
2859
  */
2860
2860
  _fitSingleObject(t, e) {
2861
- const { canvas: n, montageArea: s } = this.editor, { width: o, height: i, scaleX: a = 1, scaleY: r = 1, angle: c = 0 } = t, l = o * Math.abs(a), h = i * Math.abs(r), u = c * Math.PI / 180, f = Math.abs(Math.cos(u)), g = Math.abs(Math.sin(u)), m = l * f + h * g, p = l * g + h * f, v = s.width, M = s.height;
2862
- let j;
2863
- e === "contain" ? j = Math.min(v / m, M / p) : j = Math.max(v / m, M / p), t.set({
2864
- scaleX: a * j,
2865
- scaleY: r * j
2861
+ const { canvas: n, montageArea: s } = this.editor, { width: o, height: i, scaleX: a = 1, scaleY: r = 1, angle: c = 0 } = t, l = o * Math.abs(a), h = i * Math.abs(r), u = c * Math.PI / 180, f = Math.abs(Math.cos(u)), p = Math.abs(Math.sin(u)), m = l * f + h * p, g = l * p + h * f, v = s.width, M = s.height;
2862
+ let C;
2863
+ e === "contain" ? C = Math.min(v / m, M / g) : C = Math.max(v / m, M / g), t.set({
2864
+ scaleX: a * C,
2865
+ scaleY: r * C
2866
2866
  }), n.centerObject(t);
2867
2867
  }
2868
2868
  /**
@@ -2899,11 +2899,11 @@ class rs {
2899
2899
  }), e)
2900
2900
  this.fitObject({ object: c, withoutSave: !0, fitAsOneObject: !0 });
2901
2901
  else {
2902
- const { width: h, height: u } = o, { width: f, height: g } = c, m = i.calculateScaleFactor({
2902
+ const { width: h, height: u } = o, { width: f, height: p } = c, m = i.calculateScaleFactor({
2903
2903
  imageObject: c,
2904
2904
  scaleType: r
2905
2905
  });
2906
- r === "contain" && m < 1 || r === "cover" && (f > h || g > u) ? this.fitObject({ object: c, withoutSave: !0, fitAsOneObject: !0 }) : c.set({ scaleX: 1, scaleY: 1 });
2906
+ r === "contain" && m < 1 || r === "cover" && (f > h || p > u) ? this.fitObject({ object: c, withoutSave: !0, fitAsOneObject: !0 }) : c.set({ scaleX: 1, scaleY: 1 });
2907
2907
  }
2908
2908
  c.set({ flipX: !1, flipY: !1, angle: 0 }), s.centerObject(c), s.renderAll(), a.resumeHistory(), n || a.saveState(), s.fire("editor:object-reset", {
2909
2909
  object: c,
@@ -2912,9 +2912,9 @@ class rs {
2912
2912
  });
2913
2913
  }
2914
2914
  }
2915
- class cs {
2915
+ class ls {
2916
2916
  constructor({ editor: t }) {
2917
- this.editor = t, this.options = t.options, this.minZoom = this.options.minZoom || ts, this.maxZoom = this.options.maxZoom || es, this.defaultZoom = this._normalizeDefaultZoom(this.options.defaultScale);
2917
+ this.editor = t, this.options = t.options, this.minZoom = this.options.minZoom || es, this.maxZoom = this.options.maxZoom || ns, this.defaultZoom = this._normalizeDefaultZoom(this.options.defaultScale);
2918
2918
  }
2919
2919
  /**
2920
2920
  * Приводит значение defaultZoom к числу с двумя знаками после запятой, а также учитывает минимальное и максимальное значения.
@@ -2945,10 +2945,10 @@ class cs {
2945
2945
  * @private
2946
2946
  */
2947
2947
  _getClampedPointerCoordinates(t) {
2948
- const { canvas: e, montageArea: n } = this.editor, s = e.getPointer(t, !0), o = e.viewportTransform, i = e.getZoom(), a = n.left - n.width / 2, r = n.left + n.width / 2, c = n.top - n.height / 2, l = n.top + n.height / 2, h = a * i + o[4], u = r * i + o[4], f = c * i + o[5], g = l * i + o[5], m = Math.max(h, Math.min(u, s.x)), p = Math.max(f, Math.min(g, s.y));
2948
+ const { canvas: e, montageArea: n } = this.editor, s = e.getPointer(t, !0), o = e.viewportTransform, i = e.getZoom(), a = n.left - n.width / 2, r = n.left + n.width / 2, c = n.top - n.height / 2, l = n.top + n.height / 2, h = a * i + o[4], u = r * i + o[4], f = c * i + o[5], p = l * i + o[5], m = Math.max(h, Math.min(u, s.x)), g = Math.max(f, Math.min(p, s.y));
2949
2949
  return {
2950
2950
  x: m,
2951
- y: p
2951
+ y: g
2952
2952
  };
2953
2953
  }
2954
2954
  /**
@@ -2980,10 +2980,10 @@ class cs {
2980
2980
  * @private
2981
2981
  */
2982
2982
  _calculateEmptySpaceRatio(t) {
2983
- const { canvas: e, montageArea: n } = this.editor, s = e.viewportTransform, o = e.getWidth(), i = e.getHeight(), a = n.left - n.width / 2, r = n.left + n.width / 2, c = n.top - n.height / 2, l = n.top + n.height / 2, h = -s[4] / t, u = (-s[4] + o) / t, f = -s[5] / t, g = (-s[5] + i) / t, m = h < a, p = u > r, v = f < c, M = g > l;
2984
- if (!(m || p || v || M)) return 0;
2985
- const y = Math.max(0, a - h), w = Math.max(0, u - r), I = Math.max(0, c - f), C = Math.max(0, g - l), b = Math.max(y, w), A = Math.max(I, C), S = b / o, T = A / i;
2986
- return Math.max(S, T);
2983
+ const { canvas: e, montageArea: n } = this.editor, s = e.viewportTransform, o = e.getWidth(), i = e.getHeight(), a = n.left - n.width / 2, r = n.left + n.width / 2, c = n.top - n.height / 2, l = n.top + n.height / 2, h = -s[4] / t, u = (-s[4] + o) / t, f = -s[5] / t, p = (-s[5] + i) / t, m = h < a, g = u > r, v = f < c, M = p > l;
2984
+ if (!(m || g || v || M)) return 0;
2985
+ const y = Math.max(0, a - h), w = Math.max(0, u - r), j = Math.max(0, c - f), T = Math.max(0, p - l), b = Math.max(y, w), A = Math.max(j, T), S = b / o, I = A / i;
2986
+ return Math.max(S, I);
2987
2987
  }
2988
2988
  /**
2989
2989
  * Вычисляет плавный шаг перемещения viewport к центру с ускорением
@@ -2996,11 +2996,11 @@ class cs {
2996
2996
  * @private
2997
2997
  */
2998
2998
  _calculateSmoothCenteringStep(t, e, n, s, o) {
2999
- const { canvas: i, montageArea: a } = this.editor, r = i.viewportTransform, c = i.getWidth(), l = i.getHeight(), h = t.x - r[4], u = t.y - r[5], f = Math.abs(s), g = e - n;
3000
- if (Math.abs(g) / f <= 0.1)
2999
+ const { canvas: i, montageArea: a } = this.editor, r = i.viewportTransform, c = i.getWidth(), l = i.getHeight(), h = t.x - r[4], u = t.y - r[5], f = Math.abs(s), p = e - n;
3000
+ if (Math.abs(p) / f <= 0.1)
3001
3001
  return { x: h, y: u };
3002
- const p = c / 2, v = l / 2, M = a.left, j = a.top, y = p - M * n, w = v - j * n, I = (y - r[4]) / (e - n), C = (w - r[5]) / (e - n), b = I * f, A = C * f, S = b * o, T = A * o, O = Math.abs(S) > Math.abs(h) ? h : S, P = Math.abs(T) > Math.abs(u) ? u : T;
3003
- return { x: O, y: P };
3002
+ const g = c / 2, v = l / 2, M = a.left, C = a.top, y = g - M * n, w = v - C * n, j = (y - r[4]) / (e - n), T = (w - r[5]) / (e - n), b = j * f, A = T * f, S = b * o, I = A * o, O = Math.abs(S) > Math.abs(h) ? h : S, N = Math.abs(I) > Math.abs(u) ? u : I;
3003
+ return { x: O, y: N };
3004
3004
  }
3005
3005
  /**
3006
3006
  * Применяет плавное центрирование viewport при приближении к defaultZoom.
@@ -3012,7 +3012,7 @@ class cs {
3012
3012
  * @returns true если центрирование было применено
3013
3013
  * @private
3014
3014
  */
3015
- _applyViewportCentering(t, e = !1, n = Je) {
3015
+ _applyViewportCentering(t, e = !1, n = tn) {
3016
3016
  const { canvas: s } = this.editor, o = this._getScaledMontageDimensions(t), i = s.getWidth(), a = s.getHeight(), r = o.width > i || o.height > a, c = this._calculateFitZoom(), l = t - c;
3017
3017
  if (!(!r || l) && !e)
3018
3018
  return !1;
@@ -3020,9 +3020,9 @@ class cs {
3020
3020
  if (!r)
3021
3021
  return u[4] = f.x, u[5] = f.y, s.setViewportTransform(u), !0;
3022
3022
  if (e && !r) {
3023
- const g = this._calculateEmptySpaceRatio(t);
3024
- if (g > 0) {
3025
- const m = this._calculateSmoothCenteringStep(f, t, c, n, g);
3023
+ const p = this._calculateEmptySpaceRatio(t);
3024
+ if (p > 0) {
3025
+ const m = this._calculateSmoothCenteringStep(f, t, c, n, p);
3026
3026
  return u[4] += m.x, u[5] += m.y, s.setViewportTransform(u), !0;
3027
3027
  }
3028
3028
  }
@@ -3087,10 +3087,10 @@ class cs {
3087
3087
  * @param options.pointY - Координата Y точки зума
3088
3088
  * @fires editor:zoom-changed
3089
3089
  */
3090
- zoom(t = Je, e = {}) {
3091
- var f, g;
3090
+ zoom(t = tn, e = {}) {
3091
+ var f, p;
3092
3092
  if (!t) return;
3093
- const { minZoom: n, maxZoom: s } = this, { canvas: o } = this.editor, i = t < 0, a = o.getZoom(), r = o.getCenterPoint(), c = (f = e.pointX) != null ? f : r.x, l = (g = e.pointY) != null ? g : r.y, h = new at(c, l);
3093
+ const { minZoom: n, maxZoom: s } = this, { canvas: o } = this.editor, i = t < 0, a = o.getZoom(), r = o.getCenterPoint(), c = (f = e.pointX) != null ? f : r.x, l = (p = e.pointY) != null ? p : r.y, h = new at(c, l);
3094
3094
  this.editor.montageArea.setCoords(), this.editor.canvas.requestRenderAll();
3095
3095
  let u = Number((a + Number(t)).toFixed(2));
3096
3096
  u > s && (u = s), u < n && (u = n), o.zoomToPoint(h, u), this.editor.panConstraintManager.updateBounds(), this._applyViewportCentering(u, i, t), o.fire("editor:zoom-changed", {
@@ -3125,7 +3125,7 @@ class cs {
3125
3125
  }), this.editor.panConstraintManager.updateBounds();
3126
3126
  }
3127
3127
  }
3128
- class ls {
3128
+ class ds {
3129
3129
  constructor({ editor: t }) {
3130
3130
  this.editor = t, this.isBlocked = !1, this.overlayMask = null, this._createOverlay();
3131
3131
  }
@@ -3208,7 +3208,7 @@ class Bt {
3208
3208
  }
3209
3209
  a.set({
3210
3210
  fill: t,
3211
- backgroundId: `background-${$()}`
3211
+ backgroundId: `background-${tt()}`
3212
3212
  }), this.editor.canvas.requestRenderAll();
3213
3213
  } else
3214
3214
  this._removeCurrentBackground(), this._createColorBackground(t);
@@ -3252,7 +3252,7 @@ class Bt {
3252
3252
  }
3253
3253
  a.set({
3254
3254
  fill: r,
3255
- backgroundId: `background-${$()}`
3255
+ backgroundId: `background-${tt()}`
3256
3256
  }), this.editor.canvas.requestRenderAll();
3257
3257
  } else
3258
3258
  this._removeCurrentBackground(), this._createGradientBackground(t);
@@ -3410,7 +3410,7 @@ class Bt {
3410
3410
  hasControls: !1,
3411
3411
  id: "background",
3412
3412
  backgroundType: "color",
3413
- backgroundId: `background-${$()}`
3413
+ backgroundId: `background-${tt()}`
3414
3414
  }, { withoutSelection: !0 }), this.refresh();
3415
3415
  }
3416
3416
  /**
@@ -3427,7 +3427,7 @@ class Bt {
3427
3427
  hasControls: !1,
3428
3428
  id: "background",
3429
3429
  backgroundType: "gradient",
3430
- backgroundId: `background-${$()}`
3430
+ backgroundId: `background-${tt()}`
3431
3431
  }, { withoutSelection: !0 }), this.refresh();
3432
3432
  const e = Bt._createFabricGradient(t);
3433
3433
  this.backgroundObject.set("fill", e), this.editor.canvas.requestRenderAll();
@@ -3455,7 +3455,7 @@ class Bt {
3455
3455
  hasControls: !1,
3456
3456
  id: "background",
3457
3457
  backgroundType: "image",
3458
- backgroundId: `background-${$()}`,
3458
+ backgroundId: `background-${tt()}`,
3459
3459
  customData: e
3460
3460
  }), this._removeCurrentBackground(), this.backgroundObject = n, this.refresh();
3461
3461
  });
@@ -3490,7 +3490,7 @@ class Bt {
3490
3490
  { offset: 1, color: "#ffffff" }
3491
3491
  ], t.type === "linear") {
3492
3492
  const u = t.angle * Math.PI / 180, f = Bt._angleToCoords(u);
3493
- return new He({
3493
+ return new Ve({
3494
3494
  type: "linear",
3495
3495
  gradientUnits: "percentage",
3496
3496
  coords: f,
@@ -3509,7 +3509,7 @@ class Bt {
3509
3509
  r1: 0,
3510
3510
  r2: l / 100
3511
3511
  };
3512
- return new He({
3512
+ return new Ve({
3513
3513
  type: "radial",
3514
3514
  gradientUnits: "percentage",
3515
3515
  coords: h,
@@ -3672,7 +3672,7 @@ class ue {
3672
3672
  });
3673
3673
  }
3674
3674
  }
3675
- class ds {
3675
+ class hs {
3676
3676
  /**
3677
3677
  * Менеджер фигур для редактора.
3678
3678
  * @param options - Опции и настройки менеджера фигур.
@@ -3698,7 +3698,7 @@ class ds {
3698
3698
  */
3699
3699
  addRectangle(l = {}, { withoutSelection: r, withoutAdding: c } = {}) {
3700
3700
  var h = l, {
3701
- id: t = `rect-${$()}`,
3701
+ id: t = `rect-${tt()}`,
3702
3702
  left: e,
3703
3703
  top: n,
3704
3704
  width: s = 100,
@@ -3712,7 +3712,7 @@ class ds {
3712
3712
  "height",
3713
3713
  "fill"
3714
3714
  ]);
3715
- const { canvas: u } = this.editor, f = new An(L({
3715
+ const { canvas: u } = this.editor, f = new jn(x({
3716
3716
  id: t,
3717
3717
  left: e,
3718
3718
  top: n,
@@ -3740,7 +3740,7 @@ class ds {
3740
3740
  */
3741
3741
  addCircle(c = {}, { withoutSelection: a, withoutAdding: r } = {}) {
3742
3742
  var l = c, {
3743
- id: t = `circle-${$()}`,
3743
+ id: t = `circle-${tt()}`,
3744
3744
  left: e,
3745
3745
  top: n,
3746
3746
  radius: s = 50,
@@ -3752,7 +3752,7 @@ class ds {
3752
3752
  "radius",
3753
3753
  "fill"
3754
3754
  ]);
3755
- const { canvas: h } = this.editor, u = new jn(L({
3755
+ const { canvas: h } = this.editor, u = new In(x({
3756
3756
  id: t,
3757
3757
  left: e,
3758
3758
  top: n,
@@ -3780,7 +3780,7 @@ class ds {
3780
3780
  */
3781
3781
  addTriangle(l = {}, { withoutSelection: r, withoutAdding: c } = {}) {
3782
3782
  var h = l, {
3783
- id: t = `triangle-${$()}`,
3783
+ id: t = `triangle-${tt()}`,
3784
3784
  left: e,
3785
3785
  top: n,
3786
3786
  width: s = 100,
@@ -3794,7 +3794,7 @@ class ds {
3794
3794
  "height",
3795
3795
  "fill"
3796
3796
  ]);
3797
- const { canvas: u } = this.editor, f = new In(L({
3797
+ const { canvas: u } = this.editor, f = new Cn(x({
3798
3798
  id: t,
3799
3799
  left: e,
3800
3800
  top: n,
@@ -3805,7 +3805,7 @@ class ds {
3805
3805
  return !e && !n && u.centerObject(f), c || (u.add(f), r || u.setActiveObject(f), u.renderAll()), f;
3806
3806
  }
3807
3807
  }
3808
- class hs {
3808
+ class us {
3809
3809
  /**
3810
3810
  * @param options
3811
3811
  * @param options.editor - экземпляр редактора с доступом к canvas
@@ -3904,7 +3904,7 @@ class hs {
3904
3904
  _copyTextToClipboard(t) {
3905
3905
  return Z(this, null, function* () {
3906
3906
  try {
3907
- const e = `${Qe}${t}`;
3907
+ const e = `${en}${t}`;
3908
3908
  return yield navigator.clipboard.writeText(e), console.info("Text copied to clipboard successfully"), !0;
3909
3909
  } catch (e) {
3910
3910
  const { errorManager: n } = this.editor;
@@ -3960,11 +3960,11 @@ class hs {
3960
3960
  const s = yield n.clone(re);
3961
3961
  return s instanceof X && s.forEachObject((o) => {
3962
3962
  o.set({
3963
- id: `${o.type}-${$()}`,
3963
+ id: `${o.type}-${tt()}`,
3964
3964
  evented: !0
3965
3965
  });
3966
3966
  }), s.set({
3967
- id: `${s.type}-${$()}`,
3967
+ id: `${s.type}-${tt()}`,
3968
3968
  left: s.left + 10,
3969
3969
  top: s.top + 10,
3970
3970
  evented: !0
@@ -3995,7 +3995,7 @@ class hs {
3995
3995
  return;
3996
3996
  }
3997
3997
  const n = t.getData("text/plain");
3998
- if (n && n.startsWith(Qe)) {
3998
+ if (n && n.startsWith(en)) {
3999
3999
  this.paste();
4000
4000
  return;
4001
4001
  }
@@ -4046,11 +4046,11 @@ class hs {
4046
4046
  const e = yield this.clipboard.clone(re);
4047
4047
  return t.discardActiveObject(), e instanceof X && e.forEachObject((n) => {
4048
4048
  n.set({
4049
- id: `${n.type}-${$()}`,
4049
+ id: `${n.type}-${tt()}`,
4050
4050
  evented: !0
4051
4051
  });
4052
4052
  }), e.set({
4053
- id: `${e.type}-${$()}`,
4053
+ id: `${e.type}-${tt()}`,
4054
4054
  left: e.left + 10,
4055
4055
  top: e.top + 10,
4056
4056
  evented: !0
@@ -4134,7 +4134,7 @@ class fe {
4134
4134
  return t instanceof X || t instanceof Nt;
4135
4135
  }
4136
4136
  }
4137
- class us {
4137
+ class fs {
4138
4138
  constructor({ editor: t }) {
4139
4139
  this.editor = t;
4140
4140
  }
@@ -4185,7 +4185,7 @@ class us {
4185
4185
  try {
4186
4186
  s.suspendHistory();
4187
4187
  const i = new Nt(o, {
4188
- id: `group-${$()}`
4188
+ id: `group-${tt()}`
4189
4189
  });
4190
4190
  o.forEach((r) => n.remove(r)), n.add(i), n.setActiveObject(i), n.requestRenderAll();
4191
4191
  const a = {
@@ -4235,7 +4235,7 @@ class us {
4235
4235
  }
4236
4236
  }
4237
4237
  }
4238
- class fs {
4238
+ class gs {
4239
4239
  constructor({ editor: t }) {
4240
4240
  this.editor = t;
4241
4241
  }
@@ -4250,7 +4250,7 @@ class fs {
4250
4250
  o && n.lockObject({ object: i, skipInnerObjects: !0, withoutSave: !0 }), t.setActiveObject(i), t.requestRenderAll(), t.fire("editor:all-objects-selected", { selected: i });
4251
4251
  }
4252
4252
  }
4253
- class ke {
4253
+ class ze {
4254
4254
  constructor({ editor: t }) {
4255
4255
  this.editor = t;
4256
4256
  }
@@ -4297,7 +4297,7 @@ class ke {
4297
4297
  n || o.suspendHistory();
4298
4298
  const r = [];
4299
4299
  if (a.forEach((l) => {
4300
- if (ke._isUngroupableGroup(l)) {
4300
+ if (ze._isUngroupableGroup(l)) {
4301
4301
  const h = this._handleGroupDeletion(l);
4302
4302
  r.push(...h);
4303
4303
  return;
@@ -4458,7 +4458,7 @@ class Jt {
4458
4458
  message: i,
4459
4459
  data: s
4460
4460
  };
4461
- this._buffer.push(L({
4461
+ this._buffer.push(x({
4462
4462
  type: "editor:error"
4463
4463
  }, a)), this.editor.canvas.fire("editor:error", a);
4464
4464
  }
@@ -4486,7 +4486,7 @@ class Jt {
4486
4486
  message: i,
4487
4487
  data: o
4488
4488
  };
4489
- this._buffer.push(L({
4489
+ this._buffer.push(x({
4490
4490
  type: "editor:warning"
4491
4491
  }, a)), this.editor.canvas.fire("editor:warning", a);
4492
4492
  }
@@ -4499,7 +4499,7 @@ class Jt {
4499
4499
  return t ? Object.values(Tt).some((e) => Object.values(e).includes(t)) : !1;
4500
4500
  }
4501
4501
  }
4502
- class gs {
4502
+ class ps {
4503
4503
  constructor({ editor: t }) {
4504
4504
  this.currentBounds = null, this.editor = t;
4505
4505
  }
@@ -4555,9 +4555,9 @@ class gs {
4555
4555
  ), f = Math.max(
4556
4556
  this.currentBounds.minY,
4557
4557
  Math.min(this.currentBounds.maxY, h)
4558
- ), g = u + r - i * o, m = f + c - a * o;
4558
+ ), p = u + r - i * o, m = f + c - a * o;
4559
4559
  return {
4560
- x: g,
4560
+ x: p,
4561
4561
  y: m
4562
4562
  };
4563
4563
  }
@@ -4584,7 +4584,46 @@ class gs {
4584
4584
  this.currentBounds = this.calculatePanBounds();
4585
4585
  }
4586
4586
  }
4587
- const gt = ({
4587
+ const ms = ({ textbox: d }) => {
4588
+ var n, s;
4589
+ if (!d.isEditing) return null;
4590
+ const t = (n = d.selectionStart) != null ? n : 0, e = (s = d.selectionEnd) != null ? s : t;
4591
+ return t === e ? null : {
4592
+ start: Math.min(t, e),
4593
+ end: Math.max(t, e)
4594
+ };
4595
+ }, ys = ({ textbox: d }) => {
4596
+ var e, n;
4597
+ const t = (n = (e = d.text) == null ? void 0 : e.length) != null ? n : 0;
4598
+ return t <= 0 ? null : { start: 0, end: t };
4599
+ }, vs = ({ textbox: d, range: t }) => {
4600
+ var n, s;
4601
+ if (!t) return !1;
4602
+ const e = (s = (n = d.text) == null ? void 0 : n.length) != null ? s : 0;
4603
+ return e <= 0 ? !1 : t.start <= 0 && t.end >= e;
4604
+ }, be = ({
4605
+ textbox: d,
4606
+ styles: t,
4607
+ range: e
4608
+ }) => {
4609
+ if (!t || !Object.keys(t).length) return !1;
4610
+ const { start: n, end: s } = e;
4611
+ return s <= n ? !1 : (d.setSelectionStyles(t, n, s), !0);
4612
+ }, sn = ({
4613
+ textbox: d,
4614
+ range: t,
4615
+ property: e
4616
+ }) => {
4617
+ var s;
4618
+ if (!t) return;
4619
+ const n = d.getSelectionStyles(
4620
+ t.start,
4621
+ t.end,
4622
+ !0
4623
+ );
4624
+ if (n.length)
4625
+ return (s = n[0]) == null ? void 0 : s[e];
4626
+ }, Ee = ({ strokeColor: d, width: t }) => t <= 0 ? null : d != null ? d : "#000000", Le = ({ width: d = 0 }) => d ? Math.max(0, d) : 0, Me = ({ value: d }) => typeof d == "string" ? d.toLocaleUpperCase() : "", pt = ({
4588
4627
  value: d,
4589
4628
  min: t,
4590
4629
  max: e
@@ -4613,7 +4652,7 @@ const gt = ({
4613
4652
  }
4614
4653
  _getTransformedDimensions(t = {}) {
4615
4654
  const { width: e, height: n } = this._getBackgroundDimensions();
4616
- return super._getTransformedDimensions(It(L({}, t), {
4655
+ return super._getTransformedDimensions(It(x({}, t), {
4617
4656
  width: e,
4618
4657
  height: n
4619
4658
  }));
@@ -4623,7 +4662,7 @@ const gt = ({
4623
4662
  */
4624
4663
  toObject(t = []) {
4625
4664
  const e = super.toObject(t);
4626
- return It(L({}, e), {
4665
+ return It(x({}, e), {
4627
4666
  backgroundOpacity: this.backgroundOpacity,
4628
4667
  lineFontDefaults: this.lineFontDefaults,
4629
4668
  paddingTop: this.paddingTop,
@@ -4651,6 +4690,83 @@ const gt = ({
4651
4690
  }), t.fillStyle = e, t.fill(), t.restore();
4652
4691
  }
4653
4692
  }
4693
+ /**
4694
+ * Рисует линии декорации текста с учетом активной обводки или заливки.
4695
+ */
4696
+ _renderTextDecoration(t, e) {
4697
+ if (!this[e] && !this.styleHas(e))
4698
+ return;
4699
+ const {
4700
+ direction: n,
4701
+ fontSize: s,
4702
+ lineHeight: o,
4703
+ offsets: i,
4704
+ width: a,
4705
+ _fontSizeFraction: r,
4706
+ _textLines: c
4707
+ } = this;
4708
+ let l = this._getTopOffset();
4709
+ const h = this._getLeftOffset(), { path: u } = this, f = this._getWidthOfCharSpacing(), p = i[e];
4710
+ let m = 0;
4711
+ e === "linethrough" ? m = 0.5 : e === "overline" && (m = 1);
4712
+ for (let g = 0, v = c.length; g < v; g += 1) {
4713
+ const M = this.getHeightOfLine(g);
4714
+ if (!this[e] && !this.styleHas(e, g)) {
4715
+ l += M;
4716
+ continue;
4717
+ }
4718
+ const C = c[g], y = M / o, w = this._getLineLeftOffset(g);
4719
+ let j = 0, T = 0, b = this.getValueOfPropertyAt(g, 0, e), A = this._getDecorationColorAt(g, 0), S = this.getValueOfPropertyAt(g, 0, "textDecorationThickness"), I = b, O = A, N = S;
4720
+ const W = l + y * (1 - r);
4721
+ let z = this.getHeightOfChar(g, 0), E = this.getValueOfPropertyAt(g, 0, "deltaY");
4722
+ for (let R = 0, U = C.length; R < U; R += 1) {
4723
+ const D = this.__charBounds[g][R];
4724
+ I = this.getValueOfPropertyAt(g, R, e), O = this._getDecorationColorAt(g, R), N = this.getValueOfPropertyAt(g, R, "textDecorationThickness");
4725
+ const k = this.getHeightOfChar(g, R), _ = this.getValueOfPropertyAt(g, R, "deltaY");
4726
+ if (u && I && O) {
4727
+ const L = s * N / 1e3;
4728
+ t.save(), t.fillStyle = A, t.translate(D.renderLeft, D.renderTop), t.rotate(D.angle), t.fillRect(
4729
+ -D.kernedWidth / 2,
4730
+ p * k + _ - m * L,
4731
+ D.kernedWidth,
4732
+ L
4733
+ ), t.restore();
4734
+ } else if ((I !== b || O !== A || k !== z || N !== S || _ !== E) && T > 0) {
4735
+ const L = s * S / 1e3;
4736
+ let J = h + w + j;
4737
+ n === "rtl" && (J = a - J - T), b && A && S && (t.fillStyle = A, t.fillRect(
4738
+ J,
4739
+ W + p * z + E - m * L,
4740
+ T,
4741
+ L
4742
+ )), j = D.left, T = D.width, b = I, S = N, A = O, z = k, E = _;
4743
+ } else
4744
+ T += D.kernedWidth;
4745
+ }
4746
+ let B = h + w + j;
4747
+ n === "rtl" && (B = a - B - T), t.fillStyle = O;
4748
+ const Y = s * N / 1e3;
4749
+ I && O && N && t.fillRect(
4750
+ B,
4751
+ W + p * z + E - m * Y,
4752
+ T - f,
4753
+ Y
4754
+ ), l += M;
4755
+ }
4756
+ this._removeShadow(t);
4757
+ }
4758
+ /**
4759
+ * Возвращает цвет линии декорации для символа, учитывая обводку и заливку.
4760
+ */
4761
+ _getDecorationColorAt(t, e) {
4762
+ const n = this.getValueOfPropertyAt(t, e, "strokeWidth"), s = Le({
4763
+ width: typeof n == "number" && Number.isFinite(n) ? n : 0
4764
+ }), o = this.getValueOfPropertyAt(t, e, "stroke"), i = o == null ? null : Ee({ strokeColor: o, width: s });
4765
+ if (s > 0 && i != null)
4766
+ return i;
4767
+ const a = this.getValueOfPropertyAt(t, e, "fill");
4768
+ return a != null ? a : null;
4769
+ }
4654
4770
  _getBackgroundDimensions() {
4655
4771
  var s, o, i, a;
4656
4772
  const t = (o = (s = this.width) != null ? s : this.calcTextWidth()) != null ? o : 0, e = (a = (i = this.height) != null ? i : this.calcTextHeight()) != null ? a : 0, n = this._getPadding();
@@ -4663,10 +4779,10 @@ const gt = ({
4663
4779
  var i, a, r, c;
4664
4780
  const n = t / 2, s = e / 2, o = Math.min(n, s);
4665
4781
  return {
4666
- bottomLeft: gt({ value: (i = this.radiusBottomLeft) != null ? i : 0, min: 0, max: o }),
4667
- bottomRight: gt({ value: (a = this.radiusBottomRight) != null ? a : 0, min: 0, max: o }),
4668
- topLeft: gt({ value: (r = this.radiusTopLeft) != null ? r : 0, min: 0, max: o }),
4669
- topRight: gt({ value: (c = this.radiusTopRight) != null ? c : 0, min: 0, max: o })
4782
+ bottomLeft: pt({ value: (i = this.radiusBottomLeft) != null ? i : 0, min: 0, max: o }),
4783
+ bottomRight: pt({ value: (a = this.radiusBottomRight) != null ? a : 0, min: 0, max: o }),
4784
+ topLeft: pt({ value: (r = this.radiusTopLeft) != null ? r : 0, min: 0, max: o }),
4785
+ topRight: pt({ value: (c = this.radiusTopRight) != null ? c : 0, min: 0, max: o })
4670
4786
  };
4671
4787
  }
4672
4788
  _getPadding() {
@@ -4682,10 +4798,10 @@ const gt = ({
4682
4798
  var s;
4683
4799
  const t = this.backgroundColor;
4684
4800
  if (!t) return null;
4685
- const e = gt({ value: (s = this.backgroundOpacity) != null ? s : 1, min: 0, max: 1 });
4801
+ const e = pt({ value: (s = this.backgroundOpacity) != null ? s : 1, min: 0, max: 1 });
4686
4802
  let n;
4687
4803
  try {
4688
- n = new Cn(t);
4804
+ n = new Tn(t);
4689
4805
  } catch (o) {
4690
4806
  return Jt.emitError({
4691
4807
  origin: "BackgroundTextbox",
@@ -4710,8 +4826,8 @@ const gt = ({
4710
4826
  topRight: l,
4711
4827
  bottomRight: h,
4712
4828
  bottomLeft: u
4713
- } = s, f = gt({ value: c, min: 0, max: i }), g = gt({ value: l, min: 0, max: i }), m = gt({ value: h, min: 0, max: i }), p = gt({ value: u, min: 0, max: i });
4714
- t.beginPath(), t.moveTo(n + f, o), t.lineTo(a - g, o), t.quadraticCurveTo(a, o, a, o + g), t.lineTo(a, r - m), t.quadraticCurveTo(a, r, a - m, r), t.lineTo(n + p, r), t.quadraticCurveTo(n, r, n, r - p), t.lineTo(n, o + f), t.quadraticCurveTo(n, o, n + f, o), t.closePath();
4829
+ } = s, f = pt({ value: c, min: 0, max: i }), p = pt({ value: l, min: 0, max: i }), m = pt({ value: h, min: 0, max: i }), g = pt({ value: u, min: 0, max: i });
4830
+ t.beginPath(), t.moveTo(n + f, o), t.lineTo(a - p, o), t.quadraticCurveTo(a, o, a, o + p), t.lineTo(a, r - m), t.quadraticCurveTo(a, r, a - m, r), t.lineTo(n + g, r), t.quadraticCurveTo(n, r, n, r - g), t.lineTo(n, o + f), t.quadraticCurveTo(n, o, n + f, o), t.closePath();
4715
4831
  }
4716
4832
  /**
4717
4833
  * Округляет текущие значения ширины и высоты до ближайших целых.
@@ -4752,10 +4868,10 @@ Pt.type = "background-textbox", Pt.cacheProperties = [
4752
4868
  "radiusBottomLeft"
4753
4869
  ];
4754
4870
  let ge = Pt;
4755
- const ps = () => {
4871
+ const bs = () => {
4756
4872
  var d;
4757
- (d = Ze) != null && d.setClass && Ze.setClass(ge, "background-textbox");
4758
- }, it = 0.01, tn = ({
4873
+ (d = Xe) != null && d.setClass && Xe.setClass(ge, "background-textbox");
4874
+ }, it = 0.01, on = ({
4759
4875
  textbox: d,
4760
4876
  lineIndices: t,
4761
4877
  updates: e
@@ -4773,12 +4889,12 @@ const ps = () => {
4773
4889
  for (let u = 0; u < t.length; u += 1) {
4774
4890
  const f = t[u];
4775
4891
  if (!Number.isFinite(f)) continue;
4776
- const g = h ? c[f] : r == null ? void 0 : r[f], m = g ? L({}, g) : {};
4777
- let p = !1;
4778
- n !== void 0 && (g == null ? void 0 : g.fontFamily) !== n && (m.fontFamily = n, p = !0), s !== void 0 && (g == null ? void 0 : g.fontSize) !== s && (m.fontSize = s, p = !0), o !== void 0 && (g == null ? void 0 : g.fill) !== o && (m.fill = o, p = !0), i !== void 0 && (i === null && (g == null ? void 0 : g.stroke) !== void 0 && (delete m.stroke, p = !0), i !== null && (g == null ? void 0 : g.stroke) !== i && (m.stroke = i, p = !0)), p && (h || (c = L({}, c), h = !0), c[f] = m, l = !0);
4892
+ const p = h ? c[f] : r == null ? void 0 : r[f], m = p ? x({}, p) : {};
4893
+ let g = !1;
4894
+ n !== void 0 && (p == null ? void 0 : p.fontFamily) !== n && (m.fontFamily = n, g = !0), s !== void 0 && (p == null ? void 0 : p.fontSize) !== s && (m.fontSize = s, g = !0), o !== void 0 && (p == null ? void 0 : p.fill) !== o && (m.fill = o, g = !0), i !== void 0 && (i === null && (p == null ? void 0 : p.stroke) !== void 0 && (delete m.stroke, g = !0), i !== null && (p == null ? void 0 : p.stroke) !== i && (m.stroke = i, g = !0)), g && (h || (c = x({}, c), h = !0), c[f] = m, l = !0);
4779
4895
  }
4780
4896
  return l && (d.lineFontDefaults = c), l;
4781
- }, ms = ({
4897
+ }, Ms = ({
4782
4898
  lineText: d,
4783
4899
  lineStyles: t,
4784
4900
  lineDefaults: e
@@ -4800,23 +4916,23 @@ const ps = () => {
4800
4916
  if (t)
4801
4917
  for (const f in t) {
4802
4918
  if (!Object.prototype.hasOwnProperty.call(t, f)) continue;
4803
- const g = Number(f);
4804
- Number.isInteger(g) && g >= 0 && g < n || (u || (l = L({}, t), u = !0), l && Object.prototype.hasOwnProperty.call(l, f) && delete l[f], h = !0);
4919
+ const p = Number(f);
4920
+ Number.isInteger(p) && p >= 0 && p < n || (u || (l = x({}, t), u = !0), l && Object.prototype.hasOwnProperty.call(l, f) && delete l[f], h = !0);
4805
4921
  }
4806
4922
  for (let f = 0; f < n; f += 1) {
4807
- const g = l != null ? l : t, m = g ? g[f] : void 0;
4923
+ const p = l != null ? l : t, m = p ? p[f] : void 0;
4808
4924
  if (!m) {
4809
- l || (l = {}, u = !0), u || (l = L({}, l), u = !0), l[f] = L({}, c), h = !0;
4925
+ l || (l = {}, u = !0), u || (l = x({}, l), u = !0), l[f] = x({}, c), h = !0;
4810
4926
  continue;
4811
4927
  }
4812
- let p = null;
4813
- s !== void 0 && m.fontFamily === void 0 && (p = L({}, m), p.fontFamily = s), o !== void 0 && m.fontSize === void 0 && (p || (p = L({}, m)), p.fontSize = o), i !== void 0 && m.fill === void 0 && (p || (p = L({}, m)), p.fill = i), a !== void 0 && m.stroke === void 0 && (p || (p = L({}, m)), p.stroke = a), p && (l || (l = {}, u = !0), u || (l = L({}, l), u = !0), l[f] = p, h = !0);
4928
+ let g = null;
4929
+ s !== void 0 && m.fontFamily === void 0 && (g = x({}, m), g.fontFamily = s), o !== void 0 && m.fontSize === void 0 && (g || (g = x({}, m)), g.fontSize = o), i !== void 0 && m.fill === void 0 && (g || (g = x({}, m)), g.fill = i), a !== void 0 && m.stroke === void 0 && (g || (g = x({}, m)), g.stroke = a), g && (l || (l = {}, u = !0), u || (l = x({}, l), u = !0), l[f] = g, h = !0);
4814
4930
  }
4815
4931
  return {
4816
4932
  lineStyles: l,
4817
4933
  changed: h
4818
4934
  };
4819
- }, en = ({
4935
+ }, an = ({
4820
4936
  lineFontDefaults: d
4821
4937
  }) => {
4822
4938
  if (!d) return;
@@ -4826,10 +4942,10 @@ const ps = () => {
4826
4942
  const n = Number(e);
4827
4943
  if (!Number.isFinite(n)) continue;
4828
4944
  const s = d[n];
4829
- s && (t[n] = L({}, s));
4945
+ s && (t[n] = x({}, s));
4830
4946
  }
4831
4947
  return t;
4832
- }, nn = ({
4948
+ }, rn = ({
4833
4949
  lineFontDefaults: d,
4834
4950
  scale: t
4835
4951
  }) => {
@@ -4842,12 +4958,12 @@ const ps = () => {
4842
4958
  if (!Number.isFinite(i)) continue;
4843
4959
  const a = d[i];
4844
4960
  if (!a) continue;
4845
- const r = L({}, a);
4961
+ const r = x({}, a);
4846
4962
  typeof a.fontSize == "number" && (r.fontSize = Math.max(1, a.fontSize * t), s = !0), e[i] = r, n = !0;
4847
4963
  }
4848
4964
  if (!(!n || !s))
4849
4965
  return e;
4850
- }, ys = ({
4966
+ }, Ss = ({
4851
4967
  textbox: d
4852
4968
  }) => {
4853
4969
  var o, i;
@@ -4861,7 +4977,7 @@ const ps = () => {
4861
4977
  s = l + 1, n.push({ start: c, end: l });
4862
4978
  }
4863
4979
  return n;
4864
- }, vs = ({
4980
+ }, ws = ({
4865
4981
  range: d,
4866
4982
  text: t
4867
4983
  }) => {
@@ -4870,11 +4986,11 @@ const ps = () => {
4870
4986
  if (e <= 0) return null;
4871
4987
  const { start: n, end: s } = d, o = Number.isFinite(n) ? n : 0, i = Number.isFinite(s) ? s : o, a = Math.max(0, Math.min(o, e)), r = Math.max(0, Math.min(i, e)), c = Math.min(a, r), l = Math.max(a, r);
4872
4988
  return c === l ? null : { start: c, end: l };
4873
- }, bs = ({
4989
+ }, As = ({
4874
4990
  textbox: d,
4875
4991
  range: t
4876
4992
  }) => {
4877
- const e = ys({ textbox: d });
4993
+ const e = Ss({ textbox: d });
4878
4994
  if (!e.length) return t;
4879
4995
  let { start: n } = t, { end: s } = t;
4880
4996
  for (let o = 0; o < e.length; o += 1) {
@@ -4884,7 +5000,7 @@ const ps = () => {
4884
5000
  t.end > a && t.start < r && (n = Math.min(n, a), s = Math.max(s, r));
4885
5001
  }
4886
5002
  return { start: n, end: s };
4887
- }, Ms = ({
5003
+ }, js = ({
4888
5004
  textbox: d,
4889
5005
  range: t
4890
5006
  }) => {
@@ -4899,7 +5015,7 @@ const ps = () => {
4899
5015
  s > u && n < f && i.push(l), a = f + 1;
4900
5016
  }
4901
5017
  return i;
4902
- }, Ss = ({
5018
+ }, Is = ({
4903
5019
  textbox: d,
4904
5020
  range: t
4905
5021
  }) => {
@@ -4914,7 +5030,7 @@ const ps = () => {
4914
5030
  n <= u && s >= f && i.push(l), a = f + 1;
4915
5031
  }
4916
5032
  return i;
4917
- }, ws = ({
5033
+ }, Cs = ({
4918
5034
  previous: d,
4919
5035
  next: t
4920
5036
  }) => {
@@ -4922,7 +5038,7 @@ const ps = () => {
4922
5038
  for (let n = 0; n < e; n += 1)
4923
5039
  if (d[n] !== t[n]) return n;
4924
5040
  return e;
4925
- }, As = ({
5041
+ }, Ts = ({
4926
5042
  text: d,
4927
5043
  charIndex: t
4928
5044
  }) => {
@@ -4932,7 +5048,7 @@ const ps = () => {
4932
5048
  d[s] === `
4933
5049
  ` && (n += 1);
4934
5050
  return n;
4935
- }, js = ({
5051
+ }, Os = ({
4936
5052
  text: d,
4937
5053
  lineIndex: t
4938
5054
  }) => {
@@ -4943,7 +5059,7 @@ const ps = () => {
4943
5059
  ` && (e += 1, e === t))
4944
5060
  return n + 1;
4945
5061
  return d.length;
4946
- }, Is = ({
5062
+ }, Es = ({
4947
5063
  textbox: d,
4948
5064
  text: t
4949
5065
  }) => {
@@ -4955,7 +5071,7 @@ const ps = () => {
4955
5071
  i > s && (s = i);
4956
5072
  }
4957
5073
  return s;
4958
- }, Cs = ({
5074
+ }, Ls = ({
4959
5075
  textbox: d,
4960
5076
  montageLeft: t,
4961
5077
  montageRight: e
@@ -4967,10 +5083,10 @@ const ps = () => {
4967
5083
  return !1;
4968
5084
  let a = 0;
4969
5085
  return s < t ? a = t - s : o > e && (a = e - o), Math.abs(a) <= it ? !1 : (d.set({ left: ((h = d.left) != null ? h : 0) + a }), !0);
4970
- }, sn = ({
5086
+ }, cn = ({
4971
5087
  rawValue: d,
4972
5088
  calculatedValue: t
4973
- }) => typeof d == "number" ? d : typeof t == "number" ? t : 0, on = ({
5089
+ }) => typeof d == "number" ? d : typeof t == "number" ? t : 0, ln = ({
4974
5090
  stylesList: d
4975
5091
  }) => {
4976
5092
  const t = d.length;
@@ -4992,54 +5108,15 @@ const ps = () => {
4992
5108
  }, Ct = ({
4993
5109
  textbox: d
4994
5110
  }) => {
4995
- const { width: t, height: e, calcTextWidth: n, calcTextHeight: s } = d, o = typeof n == "function" ? n.call(d) : void 0, i = typeof s == "function" ? s.call(d) : void 0, a = sn({
5111
+ const { width: t, height: e, calcTextWidth: n, calcTextHeight: s } = d, o = typeof n == "function" ? n.call(d) : void 0, i = typeof s == "function" ? s.call(d) : void 0, a = cn({
4996
5112
  rawValue: t,
4997
5113
  calculatedValue: o
4998
- }), r = sn({
5114
+ }), r = cn({
4999
5115
  rawValue: e,
5000
5116
  calculatedValue: i
5001
5117
  }), c = Number.isFinite(a) ? Math.round(a) : null, l = Number.isFinite(r) ? Math.round(r) : null, h = {};
5002
5118
  return c !== null && c !== a && (h.width = Math.max(0, c)), l !== null && l !== r && (h.height = Math.max(0, l)), Object.keys(h).length ? (d.set(h), !0) : !1;
5003
- }, Ts = ({ textbox: d }) => {
5004
- var n, s;
5005
- if (!d.isEditing) return null;
5006
- const t = (n = d.selectionStart) != null ? n : 0, e = (s = d.selectionEnd) != null ? s : t;
5007
- return t === e ? null : {
5008
- start: Math.min(t, e),
5009
- end: Math.max(t, e)
5010
- };
5011
- }, Os = ({ textbox: d }) => {
5012
- var e, n;
5013
- const t = (n = (e = d.text) == null ? void 0 : e.length) != null ? n : 0;
5014
- return t <= 0 ? null : { start: 0, end: t };
5015
- }, Es = ({ textbox: d, range: t }) => {
5016
- var n, s;
5017
- if (!t) return !1;
5018
- const e = (s = (n = d.text) == null ? void 0 : n.length) != null ? s : 0;
5019
- return e <= 0 ? !1 : t.start <= 0 && t.end >= e;
5020
- }, ve = ({
5021
- textbox: d,
5022
- styles: t,
5023
- range: e
5024
- }) => {
5025
- if (!t || !Object.keys(t).length) return !1;
5026
- const { start: n, end: s } = e;
5027
- return s <= n ? !1 : (d.setSelectionStyles(t, n, s), !0);
5028
- }, an = ({
5029
- textbox: d,
5030
- range: t,
5031
- property: e
5032
- }) => {
5033
- var s;
5034
- if (!t) return;
5035
- const n = d.getSelectionStyles(
5036
- t.start,
5037
- t.end,
5038
- !0
5039
- );
5040
- if (n.length)
5041
- return (s = n[0]) == null ? void 0 : s[e];
5042
- }, rn = ({ strokeColor: d, width: t }) => t <= 0 ? null : d != null ? d : "#000000", cn = ({ width: d = 0 }) => d ? Math.max(0, d) : 0, be = ({ value: d }) => typeof d == "string" ? d.toLocaleUpperCase() : "";
5119
+ };
5043
5120
  class st {
5044
5121
  constructor({ editor: t }) {
5045
5122
  var e;
@@ -5061,7 +5138,7 @@ class st {
5061
5138
  if (!st._isTextbox(s) || this.lineDefaultsSyncing.has(s)) return;
5062
5139
  const { text: o = "", uppercase: i, autoExpand: a } = s, r = !!i, c = a !== !1, l = o.toLocaleLowerCase();
5063
5140
  if (r) {
5064
- const f = be({ value: l });
5141
+ const f = Me({ value: l });
5065
5142
  f !== o && s.set({ text: f }), s.textCaseRaw = l;
5066
5143
  } else
5067
5144
  s.textCaseRaw = o;
@@ -5087,11 +5164,11 @@ class st {
5087
5164
  });
5088
5165
  const { historyManager: r } = this.editor;
5089
5166
  r.endAction({ reason: "text-edit" }), r.scheduleSaveState({
5090
- delayMs: ss,
5167
+ delayMs: is,
5091
5168
  reason: "text-edit"
5092
5169
  });
5093
5170
  }, this._handleObjectScaling = (n) => {
5094
- var $t, pe, te, ee, ne, xt, me, se, Yt, Ht, Zt, Gt, Vt;
5171
+ var $t, me, te, ee, ne, xt, ye, se, Yt, Ht, Zt, Gt, Vt;
5095
5172
  const { target: s, transform: o } = n;
5096
5173
  if (s instanceof X || !st._isTextbox(s) || !o) return;
5097
5174
  s.isScaling = !0;
@@ -5103,75 +5180,75 @@ class st {
5103
5180
  baseRadii: h,
5104
5181
  baseStyles: u,
5105
5182
  baseLineFontDefaults: f
5106
- } = i, g = typeof (($t = o.original) == null ? void 0 : $t.width) == "number" ? o.original.width : void 0, m = typeof ((pe = o.original) == null ? void 0 : pe.left) == "number" ? o.original.left : void 0, p = g != null ? g : a, v = m != null ? m : r, M = (te = o.corner) != null ? te : "", j = (ee = o.action) != null ? ee : "", y = ["ml", "mr"].includes(M) || j === "scaleX", w = ["mt", "mb"].includes(M) || j === "scaleY", I = ["tl", "tr", "bl", "br"].includes(M) || j === "scale", C = I || w;
5107
- if (!y && !w && !I) return;
5108
- const b = Math.abs((xt = (ne = s.scaleX) != null ? ne : o.scaleX) != null ? xt : 1) || 1, A = Math.abs((se = (me = s.scaleY) != null ? me : o.scaleY) != null ? se : 1) || 1, S = Math.max(1, p * b), T = Math.max(1, Math.round(S)), O = Math.max(1, c * A), {
5109
- paddingTop: P = 0,
5110
- paddingRight: U = 0,
5111
- paddingBottom: F = 0,
5183
+ } = i, p = typeof (($t = o.original) == null ? void 0 : $t.width) == "number" ? o.original.width : void 0, m = typeof ((me = o.original) == null ? void 0 : me.left) == "number" ? o.original.left : void 0, g = p != null ? p : a, v = m != null ? m : r, M = (te = o.corner) != null ? te : "", C = (ee = o.action) != null ? ee : "", y = ["ml", "mr"].includes(M) || C === "scaleX", w = ["mt", "mb"].includes(M) || C === "scaleY", j = ["tl", "tr", "bl", "br"].includes(M) || C === "scale", T = j || w;
5184
+ if (!y && !w && !j) return;
5185
+ const b = Math.abs((xt = (ne = s.scaleX) != null ? ne : o.scaleX) != null ? xt : 1) || 1, A = Math.abs((se = (ye = s.scaleY) != null ? ye : o.scaleY) != null ? se : 1) || 1, S = Math.max(1, g * b), I = Math.max(1, Math.round(S)), O = Math.max(1, c * A), {
5186
+ paddingTop: N = 0,
5187
+ paddingRight: W = 0,
5188
+ paddingBottom: z = 0,
5112
5189
  paddingLeft: E = 0,
5113
5190
  radiusTopLeft: B = 0,
5114
- radiusTopRight: H = 0,
5115
- radiusBottomRight: z = 0,
5116
- radiusBottomLeft: W = 0,
5117
- fontSize: x,
5118
- width: R,
5191
+ radiusTopRight: Y = 0,
5192
+ radiusBottomRight: R = 0,
5193
+ radiusBottomLeft: U = 0,
5194
+ fontSize: D,
5195
+ width: k,
5119
5196
  originX: _ = "left"
5120
- } = s, D = I || w, et = I || w, G = D ? {
5197
+ } = s, L = j || w, J = j || w, G = L ? {
5121
5198
  top: Math.max(0, l.top * A),
5122
5199
  right: Math.max(0, l.right * A),
5123
5200
  bottom: Math.max(0, l.bottom * A),
5124
5201
  left: Math.max(0, l.left * A)
5125
- } : l, J = et ? {
5202
+ } : l, Q = J ? {
5126
5203
  topLeft: Math.max(0, h.topLeft * A),
5127
5204
  topRight: Math.max(0, h.topRight * A),
5128
5205
  bottomRight: Math.max(0, h.bottomRight * A),
5129
5206
  bottomLeft: Math.max(0, h.bottomLeft * A)
5130
- } : h, Q = Object.keys(u).length > 0;
5207
+ } : h, $ = Object.keys(u).length > 0;
5131
5208
  let ot;
5132
- if (C && Q) {
5209
+ if (T && $) {
5133
5210
  const Rt = {};
5134
5211
  Object.entries(u).forEach(([ie, q]) => {
5135
5212
  if (!q) return;
5136
5213
  const nt = {};
5137
- Object.entries(q).forEach(([ye, kt]) => {
5214
+ Object.entries(q).forEach(([ve, kt]) => {
5138
5215
  if (!kt) return;
5139
- const Be = L({}, kt);
5140
- typeof kt.fontSize == "number" && (Be.fontSize = Math.max(1, kt.fontSize * A)), nt[ye] = Be;
5216
+ const Fe = x({}, kt);
5217
+ typeof kt.fontSize == "number" && (Fe.fontSize = Math.max(1, kt.fontSize * A)), nt[ve] = Fe;
5141
5218
  }), Object.keys(nt).length && (Rt[ie] = nt);
5142
5219
  }), Object.keys(Rt).length && (ot = Rt);
5143
5220
  }
5144
5221
  let ht;
5145
- C && (ht = nn({
5222
+ T && (ht = rn({
5146
5223
  lineFontDefaults: f,
5147
5224
  scale: A
5148
5225
  }));
5149
- const vt = (Ht = (Yt = o.originX) != null ? Yt : _) != null ? Ht : "left", rt = v + p, ct = v + p / 2, At = R != null ? R : p, bt = T !== At, Lt = Math.abs(O - (x != null ? x : c)) > it, Dt = Math.abs(G.top - P) > it || Math.abs(G.right - U) > it || Math.abs(G.bottom - F) > it || Math.abs(G.left - E) > it, _t = Math.abs(J.topLeft - B) > it || Math.abs(J.topRight - H) > it || Math.abs(J.bottomRight - z) > it || Math.abs(J.bottomLeft - W) > it;
5226
+ const vt = (Ht = (Yt = o.originX) != null ? Yt : _) != null ? Ht : "left", rt = v + g, ct = v + g / 2, At = k != null ? k : g, bt = I !== At, Lt = Math.abs(O - (D != null ? D : c)) > it, Dt = Math.abs(G.top - N) > it || Math.abs(G.right - W) > it || Math.abs(G.bottom - z) > it || Math.abs(G.left - E) > it, _t = Math.abs(Q.topLeft - B) > it || Math.abs(Q.topRight - Y) > it || Math.abs(Q.bottomRight - R) > it || Math.abs(Q.bottomLeft - U) > it;
5150
5227
  if (!bt && !Lt && !Dt && !_t) {
5151
5228
  s.set({ scaleX: 1, scaleY: 1 }), o.scaleX = 1, o.scaleY = 1;
5152
5229
  return;
5153
5230
  }
5154
5231
  ot && (s.styles = ot), ht && (s.lineFontDefaults = ht), s.set({
5155
- width: T,
5156
- fontSize: C ? O : c,
5232
+ width: I,
5233
+ fontSize: T ? O : c,
5157
5234
  paddingTop: G.top,
5158
5235
  paddingRight: G.right,
5159
5236
  paddingBottom: G.bottom,
5160
5237
  paddingLeft: G.left,
5161
- radiusTopLeft: J.topLeft,
5162
- radiusTopRight: J.topRight,
5163
- radiusBottomRight: J.bottomRight,
5164
- radiusBottomLeft: J.bottomLeft,
5238
+ radiusTopLeft: Q.topLeft,
5239
+ radiusTopRight: Q.topRight,
5240
+ radiusBottomRight: Q.bottomRight,
5241
+ radiusBottomLeft: Q.bottomLeft,
5165
5242
  scaleX: 1,
5166
5243
  scaleY: 1
5167
5244
  });
5168
- const Wt = Ct({ textbox: s });
5169
- Wt && (s.dirty = !0);
5170
- const ut = (Zt = s.width) != null ? Zt : T, Qt = ut !== At;
5245
+ const Ut = Ct({ textbox: s });
5246
+ Ut && (s.dirty = !0);
5247
+ const ut = (Zt = s.width) != null ? Zt : I, Qt = ut !== At;
5171
5248
  let jt = v;
5172
- Qt && (y || I) && (vt === "right" ? jt = rt - ut : vt === "center" && (jt = ct - ut / 2)), s.set({ left: jt }), i.baseLeft = jt, o.scaleX = 1, o.scaleY = 1;
5173
- const { original: ft } = o;
5174
- ft && (ft.scaleX = 1, ft.scaleY = 1, ft.width = ut, ft.height = s.height, ft.left = jt), s.setCoords(), this.canvas.requestRenderAll(), i.baseWidth = ut, i.baseFontSize = (Gt = s.fontSize) != null ? Gt : O, i.baseStyles = JSON.parse(JSON.stringify((Vt = s.styles) != null ? Vt : {})), i.baseLineFontDefaults = en({
5249
+ Qt && (y || j) && (vt === "right" ? jt = rt - ut : vt === "center" && (jt = ct - ut / 2)), s.set({ left: jt }), i.baseLeft = jt, o.scaleX = 1, o.scaleY = 1;
5250
+ const { original: gt } = o;
5251
+ gt && (gt.scaleX = 1, gt.scaleY = 1, gt.width = ut, gt.height = s.height, gt.left = jt), s.setCoords(), this.canvas.requestRenderAll(), i.baseWidth = ut, i.baseFontSize = (Gt = s.fontSize) != null ? Gt : O, i.baseStyles = JSON.parse(JSON.stringify((Vt = s.styles) != null ? Vt : {})), i.baseLineFontDefaults = an({
5175
5252
  lineFontDefaults: s.lineFontDefaults
5176
5253
  }), i.basePadding = {
5177
5254
  top: G.top,
@@ -5179,55 +5256,55 @@ class st {
5179
5256
  bottom: G.bottom,
5180
5257
  left: G.left
5181
5258
  }, i.baseRadii = {
5182
- topLeft: J.topLeft,
5183
- topRight: J.topRight,
5184
- bottomRight: J.bottomRight,
5185
- bottomLeft: J.bottomLeft
5186
- }, i.hasWidthChange = Qt || Lt || Dt || _t || Wt;
5259
+ topLeft: Q.topLeft,
5260
+ topRight: Q.topRight,
5261
+ bottomRight: Q.bottomRight,
5262
+ bottomLeft: Q.bottomLeft
5263
+ }, i.hasWidthChange = Qt || Lt || Dt || _t || Ut;
5187
5264
  }, this._handleObjectModified = (n) => {
5188
- var M, j, y;
5265
+ var M, C, y;
5189
5266
  const { target: s } = n;
5190
5267
  if (s instanceof X) {
5191
5268
  const w = s.getObjects();
5192
5269
  if (!w.some((S) => st._isTextbox(S))) return;
5193
- const { scaleX: C = 1, scaleY: b = 1 } = s;
5194
- if (Math.abs(C - 1) < it && Math.abs(b - 1) < it) return;
5270
+ const { scaleX: T = 1, scaleY: b = 1 } = s;
5271
+ if (Math.abs(T - 1) < it && Math.abs(b - 1) < it) return;
5195
5272
  this.canvas.discardActiveObject(), w.forEach((S) => {
5196
- var T, O, P, U;
5273
+ var I, O, N, W;
5197
5274
  if (st._isTextbox(S)) {
5198
- const F = (T = S.scaleX) != null ? T : 1, E = (O = S.scaleY) != null ? O : 1, B = ((P = S.fontSize) != null ? P : 16) * E, H = ((U = S.width) != null ? U : 0) * F, z = E, {
5199
- paddingTop: W = 0,
5200
- paddingRight: x = 0,
5201
- paddingBottom: R = 0,
5275
+ const z = (I = S.scaleX) != null ? I : 1, E = (O = S.scaleY) != null ? O : 1, B = ((N = S.fontSize) != null ? N : 16) * E, Y = ((W = S.width) != null ? W : 0) * z, R = E, {
5276
+ paddingTop: U = 0,
5277
+ paddingRight: D = 0,
5278
+ paddingBottom: k = 0,
5202
5279
  paddingLeft: _ = 0,
5203
- radiusTopLeft: D = 0,
5204
- radiusTopRight: et = 0,
5280
+ radiusTopLeft: L = 0,
5281
+ radiusTopRight: J = 0,
5205
5282
  radiusBottomRight: G = 0,
5206
- radiusBottomLeft: J = 0,
5207
- styles: Q
5283
+ radiusBottomLeft: Q = 0,
5284
+ styles: $
5208
5285
  } = S, ot = {
5209
- paddingTop: Math.max(0, W * z),
5210
- paddingRight: Math.max(0, x * z),
5211
- paddingBottom: Math.max(0, R * z),
5212
- paddingLeft: Math.max(0, _ * z)
5286
+ paddingTop: Math.max(0, U * R),
5287
+ paddingRight: Math.max(0, D * R),
5288
+ paddingBottom: Math.max(0, k * R),
5289
+ paddingLeft: Math.max(0, _ * R)
5213
5290
  }, ht = {
5214
- radiusTopLeft: Math.max(0, D * z),
5215
- radiusTopRight: Math.max(0, et * z),
5216
- radiusBottomRight: Math.max(0, G * z),
5217
- radiusBottomLeft: Math.max(0, J * z)
5291
+ radiusTopLeft: Math.max(0, L * R),
5292
+ radiusTopRight: Math.max(0, J * R),
5293
+ radiusBottomRight: Math.max(0, G * R),
5294
+ radiusBottomLeft: Math.max(0, Q * R)
5218
5295
  };
5219
- let vt = Q;
5220
- Q && Object.keys(Q).length > 0 && (vt = JSON.parse(JSON.stringify(Q)), Object.values(vt).forEach((At) => {
5296
+ let vt = $;
5297
+ $ && Object.keys($).length > 0 && (vt = JSON.parse(JSON.stringify($)), Object.values(vt).forEach((At) => {
5221
5298
  Object.values(At).forEach((bt) => {
5222
- typeof bt.fontSize == "number" && (bt.fontSize = Math.max(1, bt.fontSize * z));
5299
+ typeof bt.fontSize == "number" && (bt.fontSize = Math.max(1, bt.fontSize * R));
5223
5300
  });
5224
5301
  }));
5225
- const rt = nn({
5302
+ const rt = rn({
5226
5303
  lineFontDefaults: S.lineFontDefaults,
5227
- scale: z
5228
- }), ct = It(L(L({
5304
+ scale: R
5305
+ }), ct = It(x(x({
5229
5306
  fontSize: B,
5230
- width: H,
5307
+ width: Y,
5231
5308
  scaleX: 1,
5232
5309
  scaleY: 1
5233
5310
  }, ot), ht), {
@@ -5247,15 +5324,15 @@ class st {
5247
5324
  s.isScaling = !1;
5248
5325
  const o = this.scalingState.get(s);
5249
5326
  if (this.scalingState.delete(s), !(o != null && o.hasWidthChange)) return;
5250
- const i = (M = s.width) != null ? M : s.calcTextWidth(), a = (y = (j = s.fontSize) != null ? j : o == null ? void 0 : o.baseFontSize) != null ? y : 16, r = !!(o.baseStyles && Object.keys(o.baseStyles).length), {
5327
+ const i = (M = s.width) != null ? M : s.calcTextWidth(), a = (y = (C = s.fontSize) != null ? C : o == null ? void 0 : o.baseFontSize) != null ? y : 16, r = !!(o.baseStyles && Object.keys(o.baseStyles).length), {
5251
5328
  paddingTop: c = 0,
5252
5329
  paddingRight: l = 0,
5253
5330
  paddingBottom: h = 0,
5254
5331
  paddingLeft: u = 0,
5255
5332
  radiusTopLeft: f = 0,
5256
- radiusTopRight: g = 0,
5333
+ radiusTopRight: p = 0,
5257
5334
  radiusBottomRight: m = 0,
5258
- radiusBottomLeft: p = 0
5335
+ radiusBottomLeft: g = 0
5259
5336
  } = s, v = {
5260
5337
  width: i,
5261
5338
  paddingTop: c,
@@ -5263,24 +5340,24 @@ class st {
5263
5340
  paddingBottom: h,
5264
5341
  paddingLeft: u,
5265
5342
  radiusTopLeft: f,
5266
- radiusTopRight: g,
5343
+ radiusTopRight: p,
5267
5344
  radiusBottomRight: m,
5268
- radiusBottomLeft: p
5345
+ radiusBottomLeft: g
5269
5346
  };
5270
5347
  r || (v.fontSize = a), this.updateText({
5271
5348
  target: s,
5272
5349
  style: v
5273
5350
  }), s.set({ scaleX: 1, scaleY: 1 }), s.setCoords();
5274
- }, this.editor = t, this.canvas = t.canvas, this.fonts = (e = t.options.fonts) != null ? e : [], this.scalingState = /* @__PURE__ */ new WeakMap(), this.editingAnchorState = /* @__PURE__ */ new WeakMap(), this.lineDefaultsSyncing = /* @__PURE__ */ new WeakSet(), this.isTextEditingActive = !1, this._bindEvents(), ps();
5351
+ }, this.editor = t, this.canvas = t.canvas, this.fonts = (e = t.options.fonts) != null ? e : [], this.scalingState = /* @__PURE__ */ new WeakMap(), this.editingAnchorState = /* @__PURE__ */ new WeakMap(), this.lineDefaultsSyncing = /* @__PURE__ */ new WeakSet(), this.isTextEditingActive = !1, this._bindEvents(), bs();
5275
5352
  }
5276
5353
  /**
5277
5354
  * Добавляет новый текстовый объект на канвас.
5278
5355
  * @param options — настройки текста
5279
5356
  * @param flags — флаги поведения
5280
5357
  */
5281
- addText(U = {}, { withoutSelection: T = !1, withoutSave: O = !1, withoutAdding: P = !1 } = {}) {
5282
- var F = U, {
5283
- id: t = `text-${$()}`,
5358
+ addText(W = {}, { withoutSelection: I = !1, withoutSave: O = !1, withoutAdding: N = !1 } = {}) {
5359
+ var z = W, {
5360
+ id: t = `text-${tt()}`,
5284
5361
  text: e = "Новый текст",
5285
5362
  autoExpand: n = !0,
5286
5363
  fontFamily: s,
@@ -5293,19 +5370,19 @@ class st {
5293
5370
  align: h = "left",
5294
5371
  color: u = "#000000",
5295
5372
  strokeColor: f,
5296
- strokeWidth: g = 0,
5373
+ strokeWidth: p = 0,
5297
5374
  opacity: m = 1,
5298
- backgroundColor: p,
5375
+ backgroundColor: g,
5299
5376
  backgroundOpacity: v = 1,
5300
5377
  paddingTop: M = 0,
5301
- paddingRight: j = 0,
5378
+ paddingRight: C = 0,
5302
5379
  paddingBottom: y = 0,
5303
5380
  paddingLeft: w = 0,
5304
- radiusTopLeft: I = 0,
5305
- radiusTopRight: C = 0,
5381
+ radiusTopLeft: j = 0,
5382
+ radiusTopRight: T = 0,
5306
5383
  radiusBottomRight: b = 0,
5307
5384
  radiusBottomLeft: A = 0
5308
- } = F, S = Mt(F, [
5385
+ } = z, S = Mt(z, [
5309
5386
  "id",
5310
5387
  "text",
5311
5388
  "autoExpand",
@@ -5332,15 +5409,15 @@ class st {
5332
5409
  "radiusBottomRight",
5333
5410
  "radiusBottomLeft"
5334
5411
  ]);
5335
- var et;
5412
+ var J;
5336
5413
  const { historyManager: E } = this.editor, { canvas: B } = this;
5337
5414
  E.suspendHistory();
5338
- const H = s != null ? s : this._getDefaultFontFamily(), z = cn({ width: g }), W = rn({
5415
+ const Y = s != null ? s : this._getDefaultFontFamily(), R = Le({ width: p }), U = Ee({
5339
5416
  strokeColor: f,
5340
- width: z
5341
- }), x = L({
5417
+ width: R
5418
+ }), D = x({
5342
5419
  id: t,
5343
- fontFamily: H,
5420
+ fontFamily: Y,
5344
5421
  fontSize: o,
5345
5422
  fontWeight: i ? "bold" : "normal",
5346
5423
  fontStyle: a ? "italic" : "normal",
@@ -5349,43 +5426,43 @@ class st {
5349
5426
  linethrough: l,
5350
5427
  textAlign: h,
5351
5428
  fill: u,
5352
- stroke: W,
5353
- strokeWidth: z,
5429
+ stroke: U,
5430
+ strokeWidth: R,
5354
5431
  strokeUniform: !0,
5355
5432
  opacity: m,
5356
- backgroundColor: p,
5433
+ backgroundColor: g,
5357
5434
  backgroundOpacity: v,
5358
5435
  paddingTop: M,
5359
- paddingRight: j,
5436
+ paddingRight: C,
5360
5437
  paddingBottom: y,
5361
5438
  paddingLeft: w,
5362
- radiusTopLeft: I,
5363
- radiusTopRight: C,
5439
+ radiusTopLeft: j,
5440
+ radiusTopRight: T,
5364
5441
  radiusBottomRight: b,
5365
5442
  radiusBottomLeft: A
5366
- }, S), R = new ge(e, x), _ = n !== !1;
5367
- if (R.autoExpand = _, R.textCaseRaw = (et = R.text) != null ? et : "", c) {
5368
- const G = be({ value: R.textCaseRaw });
5369
- G !== R.text && R.set({ text: G });
5370
- }
5371
- return Ct({ textbox: R }) && (R.dirty = !0), S.left === void 0 && S.top === void 0 && B.centerObject(R), P || B.add(R), T || B.setActiveObject(R), B.requestRenderAll(), E.resumeHistory(), O || E.saveState(), B.fire("editor:text-added", {
5372
- textbox: R,
5373
- options: It(L({}, x), {
5443
+ }, S), k = new ge(e, D), _ = n !== !1;
5444
+ if (k.autoExpand = _, k.textCaseRaw = (J = k.text) != null ? J : "", c) {
5445
+ const G = Me({ value: k.textCaseRaw });
5446
+ G !== k.text && k.set({ text: G });
5447
+ }
5448
+ return Ct({ textbox: k }) && (k.dirty = !0), S.left === void 0 && S.top === void 0 && B.centerObject(k), N || B.add(k), I || B.setActiveObject(k), B.requestRenderAll(), E.resumeHistory(), O || E.saveState(), B.fire("editor:text-added", {
5449
+ textbox: k,
5450
+ options: It(x({}, D), {
5374
5451
  text: e,
5375
5452
  bold: i,
5376
5453
  italic: a,
5377
5454
  strikethrough: l,
5378
5455
  align: h,
5379
5456
  color: u,
5380
- strokeColor: W,
5381
- strokeWidth: z
5457
+ strokeColor: U,
5458
+ strokeWidth: R
5382
5459
  }),
5383
5460
  flags: {
5384
- withoutSelection: !!T,
5461
+ withoutSelection: !!I,
5385
5462
  withoutSave: !!O,
5386
- withoutAdding: !!P
5463
+ withoutAdding: !!N
5387
5464
  }
5388
- }), R;
5465
+ }), k;
5389
5466
  }
5390
5467
  /**
5391
5468
  * Обновляет текстовый объект.
@@ -5413,31 +5490,31 @@ class st {
5413
5490
  x: u.x,
5414
5491
  y: u.y
5415
5492
  }, Ht = e, {
5416
- text: g,
5493
+ text: p,
5417
5494
  autoExpand: m,
5418
- fontFamily: p,
5495
+ fontFamily: g,
5419
5496
  fontSize: v,
5420
5497
  bold: M,
5421
- italic: j,
5498
+ italic: C,
5422
5499
  underline: y,
5423
5500
  uppercase: w,
5424
- strikethrough: I,
5425
- align: C,
5501
+ strikethrough: j,
5502
+ align: T,
5426
5503
  color: b,
5427
5504
  strokeColor: A,
5428
5505
  strokeWidth: S,
5429
- opacity: T,
5506
+ opacity: I,
5430
5507
  backgroundColor: O,
5431
- backgroundOpacity: P,
5432
- paddingTop: U,
5433
- paddingRight: F,
5508
+ backgroundOpacity: N,
5509
+ paddingTop: W,
5510
+ paddingRight: z,
5434
5511
  paddingBottom: E,
5435
5512
  paddingLeft: B,
5436
- radiusTopLeft: H,
5437
- radiusTopRight: z,
5438
- radiusBottomRight: W,
5439
- radiusBottomLeft: x
5440
- } = Ht, R = Mt(Ht, [
5513
+ radiusTopLeft: Y,
5514
+ radiusTopRight: R,
5515
+ radiusBottomRight: U,
5516
+ radiusBottomLeft: D
5517
+ } = Ht, k = Mt(Ht, [
5441
5518
  "text",
5442
5519
  "autoExpand",
5443
5520
  "fontFamily",
@@ -5462,84 +5539,84 @@ class st {
5462
5539
  "radiusTopRight",
5463
5540
  "radiusBottomRight",
5464
5541
  "radiusBottomLeft"
5465
- ]), _ = L({}, R), D = o !== void 0 ? vs({
5542
+ ]), _ = x({}, k), L = o !== void 0 ? ws({
5466
5543
  text: a,
5467
5544
  range: o
5468
- }) : Ts({ textbox: i }), et = D ? bs({ textbox: i, range: D }) : null, G = {}, J = {}, Q = {};
5545
+ }) : ms({ textbox: i }), J = L ? As({ textbox: i, range: L }) : null, G = {}, Q = {}, $ = {};
5469
5546
  let ot, ht;
5470
- const vt = Es({ textbox: i, range: D }), rt = !D || vt, ct = !D;
5471
- if (p !== void 0 && (et && (J.fontFamily = p), rt && (_.fontFamily = p, ct && (Q.fontFamily = p))), v !== void 0 && (et && (J.fontSize = v), rt && (_.fontSize = v, ct && (Q.fontSize = v))), M !== void 0) {
5547
+ const vt = vs({ textbox: i, range: L }), rt = !L || vt, ct = !L;
5548
+ if (g !== void 0 && (J && (Q.fontFamily = g), rt && (_.fontFamily = g, ct && ($.fontFamily = g))), v !== void 0 && (J && (Q.fontSize = v), rt && (_.fontSize = v, ct && ($.fontSize = v))), M !== void 0) {
5472
5549
  const q = M ? "bold" : "normal";
5473
- D && (G.fontWeight = q), rt && (_.fontWeight = q, ct && (Q.fontWeight = q));
5550
+ L && (G.fontWeight = q), rt && (_.fontWeight = q, ct && ($.fontWeight = q));
5474
5551
  }
5475
- if (j !== void 0) {
5476
- const q = j ? "italic" : "normal";
5477
- D && (G.fontStyle = q), rt && (_.fontStyle = q, ct && (Q.fontStyle = q));
5552
+ if (C !== void 0) {
5553
+ const q = C ? "italic" : "normal";
5554
+ L && (G.fontStyle = q), rt && (_.fontStyle = q, ct && ($.fontStyle = q));
5478
5555
  }
5479
- if (y !== void 0 && (D && (G.underline = y), rt && (_.underline = y, ct && (Q.underline = y))), I !== void 0 && (D && (G.linethrough = I), rt && (_.linethrough = I, ct && (Q.linethrough = I))), C !== void 0 && (_.textAlign = C), b !== void 0 && (D && (G.fill = b), rt && (_.fill = b, ct && (Q.fill = b))), A !== void 0 || S !== void 0) {
5480
- const q = D ? an({ textbox: i, range: D, property: "strokeWidth" }) : void 0, nt = D ? an({ textbox: i, range: D, property: "stroke" }) : void 0, ye = (Gt = (Zt = S != null ? S : q) != null ? Zt : i.strokeWidth) != null ? Gt : 0;
5481
- ht = cn({ width: ye });
5556
+ if (y !== void 0 && (L && (G.underline = y), rt && (_.underline = y, ct && ($.underline = y))), j !== void 0 && (L && (G.linethrough = j), rt && (_.linethrough = j, ct && ($.linethrough = j))), T !== void 0 && (_.textAlign = T), b !== void 0 && (L && (G.fill = b), rt && (_.fill = b, ct && ($.fill = b))), A !== void 0 || S !== void 0) {
5557
+ const q = L ? sn({ textbox: i, range: L, property: "strokeWidth" }) : void 0, nt = L ? sn({ textbox: i, range: L, property: "stroke" }) : void 0, ve = (Gt = (Zt = S != null ? S : q) != null ? Zt : i.strokeWidth) != null ? Gt : 0;
5558
+ ht = Le({ width: ve });
5482
5559
  const kt = (Rt = (Vt = A != null ? A : nt) != null ? Vt : i.stroke) != null ? Rt : void 0;
5483
- ot = rn({
5560
+ ot = Ee({
5484
5561
  strokeColor: kt,
5485
5562
  width: ht
5486
- }), D && (G.stroke = ot, G.strokeWidth = ht), rt && (_.stroke = ot, _.strokeWidth = ht, ct && (Q.stroke = ot, Q.strokeWidth = ht));
5563
+ }), L && (G.stroke = ot, G.strokeWidth = ht), rt && (_.stroke = ot, _.strokeWidth = ht, ct && ($.stroke = ot, $.strokeWidth = ht));
5487
5564
  }
5488
- T !== void 0 && (_.opacity = T), O !== void 0 && (_.backgroundColor = O), P !== void 0 && (_.backgroundOpacity = P), U !== void 0 && (_.paddingTop = U), F !== void 0 && (_.paddingRight = F), E !== void 0 && (_.paddingBottom = E), B !== void 0 && (_.paddingLeft = B), H !== void 0 && (_.radiusTopLeft = H), z !== void 0 && (_.radiusTopRight = z), W !== void 0 && (_.radiusBottomRight = W), x !== void 0 && (_.radiusBottomLeft = x);
5489
- const At = (ie = i.textCaseRaw) != null ? ie : a, bt = !!i.uppercase, Lt = g !== void 0, Dt = Lt ? g != null ? g : "" : At, _t = w != null ? w : bt, Wt = _t !== bt;
5490
- if (Lt || Wt) {
5491
- const q = _t ? be({ value: Dt }) : Dt;
5565
+ I !== void 0 && (_.opacity = I), O !== void 0 && (_.backgroundColor = O), N !== void 0 && (_.backgroundOpacity = N), W !== void 0 && (_.paddingTop = W), z !== void 0 && (_.paddingRight = z), E !== void 0 && (_.paddingBottom = E), B !== void 0 && (_.paddingLeft = B), Y !== void 0 && (_.radiusTopLeft = Y), R !== void 0 && (_.radiusTopRight = R), U !== void 0 && (_.radiusBottomRight = U), D !== void 0 && (_.radiusBottomLeft = D);
5566
+ const At = (ie = i.textCaseRaw) != null ? ie : a, bt = !!i.uppercase, Lt = p !== void 0, Dt = Lt ? p != null ? p : "" : At, _t = w != null ? w : bt, Ut = _t !== bt;
5567
+ if (Lt || Ut) {
5568
+ const q = _t ? Me({ value: Dt }) : Dt;
5492
5569
  _.text = q, i.textCaseRaw = Dt;
5493
5570
  } else i.textCaseRaw === void 0 && (i.textCaseRaw = At);
5494
5571
  i.uppercase = _t, i.set(_);
5495
5572
  let ut = !1;
5496
- if (D) {
5497
- const q = ve({ textbox: i, styles: G, range: D }), nt = et ? ve({ textbox: i, styles: J, range: et }) : !1;
5573
+ if (L) {
5574
+ const q = be({ textbox: i, styles: G, range: L }), nt = J ? be({ textbox: i, styles: Q, range: J }) : !1;
5498
5575
  ut = q || nt;
5499
- } else if (Object.keys(Q).length) {
5500
- const q = Os({ textbox: i });
5501
- q && (ut = ve({ textbox: i, styles: Q, range: q }));
5576
+ } else if (Object.keys($).length) {
5577
+ const q = ys({ textbox: i });
5578
+ q && (ut = be({ textbox: i, styles: $, range: q }));
5502
5579
  }
5503
- const Qt = ut && on({
5580
+ const Qt = ut && ln({
5504
5581
  stylesList: [
5505
5582
  G,
5506
- J,
5507
- Q
5583
+ Q,
5584
+ $
5508
5585
  ]
5509
5586
  });
5510
- if (ut && (i.dirty = !0), et && (p !== void 0 || v !== void 0)) {
5511
- const q = Ms({
5587
+ if (ut && (i.dirty = !0), J && (g !== void 0 || v !== void 0)) {
5588
+ const q = js({
5512
5589
  textbox: i,
5513
- range: et
5590
+ range: J
5514
5591
  }), nt = {};
5515
- p !== void 0 && (nt.fontFamily = p), v !== void 0 && (nt.fontSize = v), tn({
5592
+ g !== void 0 && (nt.fontFamily = g), v !== void 0 && (nt.fontSize = v), on({
5516
5593
  textbox: i,
5517
5594
  lineIndices: q,
5518
5595
  updates: nt
5519
5596
  });
5520
5597
  }
5521
- if (D && (b !== void 0 || A !== void 0 || S !== void 0)) {
5522
- const q = Ss({
5598
+ if (L && (b !== void 0 || A !== void 0 || S !== void 0)) {
5599
+ const q = Is({
5523
5600
  textbox: i,
5524
- range: D
5601
+ range: L
5525
5602
  }), nt = {};
5526
- b !== void 0 && (nt.fill = b), (A !== void 0 || S !== void 0) && (ot === null && (nt.stroke = null), ot != null && (nt.stroke = ot)), tn({
5603
+ b !== void 0 && (nt.fill = b), (A !== void 0 || S !== void 0) && (ot === null && (nt.stroke = null), ot != null && (nt.stroke = ot)), on({
5527
5604
  textbox: i,
5528
5605
  lineIndices: q,
5529
5606
  updates: nt
5530
5607
  });
5531
5608
  }
5532
- Qt && (i.initDimensions(), i.dirty = !0), (O !== void 0 || P !== void 0 || U !== void 0 || F !== void 0 || E !== void 0 || B !== void 0 || H !== void 0 || z !== void 0 || W !== void 0 || x !== void 0) && (i.dirty = !0);
5533
- const jt = on({
5609
+ Qt && (i.initDimensions(), i.dirty = !0), (O !== void 0 || N !== void 0 || W !== void 0 || z !== void 0 || E !== void 0 || B !== void 0 || Y !== void 0 || R !== void 0 || U !== void 0 || D !== void 0) && (i.dirty = !0);
5610
+ const jt = ln({
5534
5611
  stylesList: [
5535
5612
  _,
5536
5613
  G,
5537
- J,
5538
- Q
5614
+ Q,
5615
+ $
5539
5616
  ]
5540
- }), { autoExpand: ft } = i, $t = m !== void 0, te = (m != null ? m : ft) !== !1;
5541
- $t ? i.autoExpand = m !== !1 : ft === void 0 && (i.autoExpand = !0);
5542
- const ee = Object.prototype.hasOwnProperty.call(_, "width"), ne = te && !ee && (Lt || Wt || jt);
5617
+ }), { autoExpand: gt } = i, $t = m !== void 0, te = (m != null ? m : gt) !== !1;
5618
+ $t ? i.autoExpand = m !== !1 : gt === void 0 && (i.autoExpand = !0);
5619
+ const ee = Object.prototype.hasOwnProperty.call(_, "width"), ne = te && !ee && (Lt || Ut || jt);
5543
5620
  let xt = !1;
5544
5621
  ne && (xt = this._autoExpandTextboxWidth(i, {
5545
5622
  anchor: f
@@ -5556,10 +5633,17 @@ class st {
5556
5633
  updates: _,
5557
5634
  before: l,
5558
5635
  after: se,
5559
- selectionRange: D != null ? D : void 0,
5560
- selectionStyles: D && Object.keys(G).length ? G : void 0
5636
+ selectionRange: L != null ? L : void 0,
5637
+ selectionStyles: L && Object.keys(G).length ? G : void 0
5561
5638
  }), i;
5562
5639
  }
5640
+ /**
5641
+ * Преобразует стили из массивного формата Fabric в объектный.
5642
+ */
5643
+ // eslint-disable-next-line class-methods-use-this
5644
+ stylesFromArray(t, e) {
5645
+ return ft.stylesFromArray(t, e);
5646
+ }
5563
5647
  /**
5564
5648
  * Уничтожает менеджер и снимает слушатели.
5565
5649
  */
@@ -5600,7 +5684,7 @@ class st {
5600
5684
  * Синхронизирует lineFontDefaults при изменении текста и сохраняет typing style для пустых строк.
5601
5685
  */
5602
5686
  _syncLineFontDefaultsOnTextChanged({ textbox: t }) {
5603
- var P, U, F;
5687
+ var N, W, z;
5604
5688
  const {
5605
5689
  text: e = "",
5606
5690
  lineFontDefaults: n,
@@ -5611,81 +5695,81 @@ class st {
5611
5695
  stroke: r,
5612
5696
  selectionStart: c,
5613
5697
  isEditing: l
5614
- } = t, h = e, u = (P = t.__lineDefaultsPrevText) != null ? P : h, f = u.split(`
5615
- `), g = h.split(`
5616
- `), m = f.length, v = g.length - m;
5617
- let M = n, j = !1, y = !1;
5618
- const w = typeof a == "string" ? a : void 0, I = typeof r == "string" ? r : void 0;
5698
+ } = t, h = e, u = (N = t.__lineDefaultsPrevText) != null ? N : h, f = u.split(`
5699
+ `), p = h.split(`
5700
+ `), m = f.length, v = p.length - m;
5701
+ let M = n, C = !1, y = !1;
5702
+ const w = typeof a == "string" ? a : void 0, j = typeof r == "string" ? r : void 0;
5619
5703
  if (v !== 0 && n && Object.keys(n).length) {
5620
- const E = ws({
5704
+ const E = Cs({
5621
5705
  previous: u,
5622
5706
  next: h
5623
- }), B = As({
5707
+ }), B = Ts({
5624
5708
  text: u,
5625
5709
  charIndex: E
5626
5710
  });
5627
5711
  if (v > 0) {
5628
- const H = js({
5712
+ const Y = Os({
5629
5713
  text: u,
5630
5714
  lineIndex: B
5631
5715
  });
5632
- let z = B + 1;
5633
- E === H && (z = B);
5634
- const W = {};
5635
- for (const x in n) {
5636
- if (!Object.prototype.hasOwnProperty.call(n, x)) continue;
5637
- const R = Number(x);
5638
- if (!Number.isFinite(R)) continue;
5639
- const _ = n[R];
5716
+ let R = B + 1;
5717
+ E === Y && (R = B);
5718
+ const U = {};
5719
+ for (const D in n) {
5720
+ if (!Object.prototype.hasOwnProperty.call(n, D)) continue;
5721
+ const k = Number(D);
5722
+ if (!Number.isFinite(k)) continue;
5723
+ const _ = n[k];
5640
5724
  if (!_) continue;
5641
- const D = R >= z ? R + v : R;
5642
- W[D] = L({}, _);
5725
+ const L = k >= R ? k + v : k;
5726
+ U[L] = x({}, _);
5643
5727
  }
5644
- M = W, j = !0, y = !0;
5728
+ M = U, C = !0, y = !0;
5645
5729
  }
5646
5730
  if (v < 0) {
5647
- const H = Math.abs(v);
5648
- let z = B;
5731
+ const Y = Math.abs(v);
5732
+ let R = B;
5649
5733
  u[E] === `
5650
- ` && ((U = f[B]) != null ? U : "").length > 0 && (z = B + 1);
5651
- const x = z + H - 1, R = {};
5734
+ ` && ((W = f[B]) != null ? W : "").length > 0 && (R = B + 1);
5735
+ const D = R + Y - 1, k = {};
5652
5736
  for (const _ in n) {
5653
5737
  if (!Object.prototype.hasOwnProperty.call(n, _)) continue;
5654
- const D = Number(_);
5655
- if (!Number.isFinite(D)) continue;
5656
- const et = n[D];
5657
- et && (D < z && (R[D] = L({}, et)), D > x && (R[D + v] = L({}, et)));
5738
+ const L = Number(_);
5739
+ if (!Number.isFinite(L)) continue;
5740
+ const J = n[L];
5741
+ J && (L < R && (k[L] = x({}, J)), L > D && (k[L + v] = x({}, J)));
5658
5742
  }
5659
- M = R, j = !0, y = !0;
5743
+ M = k, C = !0, y = !0;
5660
5744
  }
5661
5745
  }
5662
- let C = null;
5746
+ let T = null;
5663
5747
  if (l && typeof c == "number") {
5664
5748
  const E = t.get2DCursorLocation(c), { lineIndex: B } = E;
5665
- Number.isFinite(B) && (C = B);
5666
- }
5667
- let b = s, A = !1, S = !1, T, O = null;
5668
- for (let E = 0; E < g.length; E += 1) {
5669
- const B = (F = g[E]) != null ? F : "", H = M ? M[E] : void 0;
5670
- if (H && (T = H), B.length !== 0) {
5671
- if (H) {
5672
- const D = ms({
5749
+ Number.isFinite(B) && (T = B);
5750
+ }
5751
+ let b = s, A = !1, S = !1, I, O = null;
5752
+ for (let E = 0; E < p.length; E += 1) {
5753
+ const B = (z = p[E]) != null ? z : "", Y = M ? M[E] : void 0;
5754
+ if (Y && (I = Y), B.length !== 0) {
5755
+ if (Y) {
5756
+ const L = Ms({
5673
5757
  lineText: B,
5674
5758
  lineStyles: b ? b[E] : void 0,
5675
- lineDefaults: H
5759
+ lineDefaults: Y
5676
5760
  });
5677
- D.changed && (b || (b = {}, S = !0), S || (b = L({}, b), S = !0), D.lineStyles && (b[E] = D.lineStyles), !D.lineStyles && b[E] && delete b[E], A = !0);
5761
+ L.changed && (b || (b = {}, S = !0), S || (b = x({}, b), S = !0), L.lineStyles && (b[E] = L.lineStyles), !L.lineStyles && b[E] && delete b[E], A = !0);
5678
5762
  }
5679
5763
  continue;
5680
5764
  }
5681
- const W = H != null ? H : T, x = {};
5682
- (W == null ? void 0 : W.fontFamily) !== void 0 ? x.fontFamily = W.fontFamily : o !== void 0 && (x.fontFamily = o), (W == null ? void 0 : W.fontSize) !== void 0 ? x.fontSize = W.fontSize : i !== void 0 && (x.fontSize = i), (W == null ? void 0 : W.fill) !== void 0 ? x.fill = W.fill : w !== void 0 && (x.fill = w), (W == null ? void 0 : W.stroke) !== void 0 ? x.stroke = W.stroke : I !== void 0 && (x.stroke = I), !H && Object.keys(x).length && (M || (M = {}, y = !0), y || (M = L({}, M), y = !0), M[E] = x, j = !0, T = x), H && (T = H), C !== null && C === E && (O = x);
5683
- const R = {};
5684
- x.fontFamily !== void 0 && (R.fontFamily = x.fontFamily), x.fontSize !== void 0 && (R.fontSize = x.fontSize), x.fill !== void 0 && (R.fill = x.fill), x.stroke !== void 0 && (R.stroke = x.stroke);
5685
- const _ = Object.keys(R).length > 0;
5686
- (_ || b && b[E]) && (b || (b = {}, S = !0), S || (b = L({}, b), S = !0), _ && (b[E] = { 0: R }), !_ && b[E] && delete b[E], A = !0);
5687
- }
5688
- if (j && M && (t.lineFontDefaults = M), A && (t.styles = b, t.dirty = !0), O && typeof c == "number") {
5765
+ const U = Y != null ? Y : I, D = {};
5766
+ (U == null ? void 0 : U.fontFamily) !== void 0 ? D.fontFamily = U.fontFamily : o !== void 0 && (D.fontFamily = o), (U == null ? void 0 : U.fontSize) !== void 0 ? D.fontSize = U.fontSize : i !== void 0 && (D.fontSize = i), (U == null ? void 0 : U.fill) !== void 0 ? D.fill = U.fill : w !== void 0 && (D.fill = w), (U == null ? void 0 : U.stroke) !== void 0 ? D.stroke = U.stroke : j !== void 0 && (D.stroke = j), !Y && Object.keys(D).length && (M || (M = {}, y = !0), y || (M = x({}, M), y = !0), M[E] = D, C = !0, I = D), Y && (I = Y), T !== null && T === E && (O = D);
5767
+ const k = {};
5768
+ D.fontFamily !== void 0 && (k.fontFamily = D.fontFamily), D.fontSize !== void 0 && (k.fontSize = D.fontSize), D.fill !== void 0 && (k.fill = D.fill), D.stroke !== void 0 && (k.stroke = D.stroke);
5769
+ const _ = Object.keys(k).length > 0;
5770
+ (_ || b && b[E]) && (b || (b = {}, S = !0), S || (b = x({}, b), S = !0), _ && (b[E] = { 0: k }), !_ && b[E] && delete b[E], A = !0);
5771
+ }
5772
+ if (C && M && (t.lineFontDefaults = M), A && (t.styles = b, t.dirty = !0), O && typeof c == "number") {
5689
5773
  const E = {};
5690
5774
  if (O.fontFamily !== void 0 && (E.fontFamily = O.fontFamily), O.fontSize !== void 0 && (E.fontSize = O.fontSize), O.fill !== void 0 && (E.fill = O.fill), O.stroke !== void 0 && (E.stroke = O.stroke), Object.keys(E).length) {
5691
5775
  this.lineDefaultsSyncing.add(t);
@@ -5703,37 +5787,37 @@ class st {
5703
5787
  * но не шире монтажной области, и удерживает объект в её пределах.
5704
5788
  */
5705
5789
  _autoExpandTextboxWidth(t, { anchor: e } = {}) {
5706
- var C, b, A, S, T, O, P, U, F, E, B, H, z;
5790
+ var T, b, A, S, I, O, N, W, z, E, B, Y, R;
5707
5791
  const { montageArea: n } = this.editor;
5708
5792
  if (!n) return !1;
5709
5793
  const s = typeof t.text == "string" ? t.text : "";
5710
5794
  if (!s.length) return !1;
5711
5795
  n.setCoords();
5712
- const o = n.getBoundingRect(!1, !0), i = (C = o.width) != null ? C : 0;
5796
+ const o = n.getBoundingRect(!1, !0), i = (T = o.width) != null ? T : 0;
5713
5797
  if (!Number.isFinite(i) || i <= 0) return !1;
5714
- const a = e != null ? e : (b = this.editingAnchorState) == null ? void 0 : b.get(t), r = (S = (A = a == null ? void 0 : a.originY) != null ? A : t.originY) != null ? S : "top", c = Math.abs((T = t.scaleX) != null ? T : 1) || 1, l = (O = t.paddingLeft) != null ? O : 0, h = (P = t.paddingRight) != null ? P : 0, u = (U = t.strokeWidth) != null ? U : 0, f = Math.max(
5798
+ const a = e != null ? e : (b = this.editingAnchorState) == null ? void 0 : b.get(t), r = (S = (A = a == null ? void 0 : a.originY) != null ? A : t.originY) != null ? S : "top", c = Math.abs((I = t.scaleX) != null ? I : 1) || 1, l = (O = t.paddingLeft) != null ? O : 0, h = (N = t.paddingRight) != null ? N : 0, u = (W = t.strokeWidth) != null ? W : 0, f = Math.max(
5715
5799
  1,
5716
5800
  i / c - l - h - u
5717
5801
  );
5718
5802
  if (!Number.isFinite(f) || f <= 0) return !1;
5719
- const g = s.split(`
5803
+ const p = s.split(`
5720
5804
  `).length;
5721
5805
  let m = !1;
5722
- Math.abs(((F = t.width) != null ? F : 0) - f) > it && (t.set({ width: f }), m = !0), t.initDimensions();
5723
- const { textLines: p } = t, v = Array.isArray(p) && p.length > g, M = Math.ceil(
5724
- Is({ textbox: t, text: s })
5725
- ), j = Math.min((E = t.minWidth) != null ? E : 1, f);
5806
+ Math.abs(((z = t.width) != null ? z : 0) - f) > it && (t.set({ width: f }), m = !0), t.initDimensions();
5807
+ const { textLines: g } = t, v = Array.isArray(g) && g.length > p, M = Math.ceil(
5808
+ Es({ textbox: t, text: s })
5809
+ ), C = Math.min((E = t.minWidth) != null ? E : 1, f);
5726
5810
  let y = Math.min(
5727
5811
  f,
5728
- Math.max(M, j)
5812
+ Math.max(M, C)
5729
5813
  );
5730
5814
  v && (y = f), Math.abs(((B = t.width) != null ? B : 0) - y) > it && (t.set({ width: y }), t.initDimensions(), m = !0), Ct({ textbox: t }) && (m = !0), a && (t.setPositionByOrigin(new at(a.x, a.y), "center", r), m = !0);
5731
- const I = Cs({
5815
+ const j = Ls({
5732
5816
  textbox: t,
5733
- montageLeft: (H = o.left) != null ? H : 0,
5734
- montageRight: ((z = o.left) != null ? z : 0) + i
5817
+ montageLeft: (Y = o.left) != null ? Y : 0,
5818
+ montageRight: ((R = o.left) != null ? R : 0) + i
5735
5819
  });
5736
- return m || I;
5820
+ return m || j;
5737
5821
  }
5738
5822
  /**
5739
5823
  * Обрабатывает изменение ширины текстового объекта (resizing).
@@ -5742,7 +5826,7 @@ class st {
5742
5826
  * Также корректирует позицию при ресайзе слева, чтобы компенсировать смещение.
5743
5827
  */
5744
5828
  static _handleObjectResizing(t) {
5745
- var h, u, f, g, m, p;
5829
+ var h, u, f, p, m, g;
5746
5830
  const { target: e, transform: n } = t;
5747
5831
  if (!st._isTextbox(e)) return;
5748
5832
  const {
@@ -5755,10 +5839,10 @@ class st {
5755
5839
  e.set({ width: r });
5756
5840
  const c = (u = e.width) != null ? u : 0, l = a - c;
5757
5841
  if (l !== 0 && n && n.corner === "ml") {
5758
- const M = ((f = e.angle) != null ? f : 0) * Math.PI / 180, j = Math.cos(M), y = Math.sin(M), w = (g = e.scaleX) != null ? g : 1, I = l * w;
5842
+ const M = ((f = e.angle) != null ? f : 0) * Math.PI / 180, C = Math.cos(M), y = Math.sin(M), w = (p = e.scaleX) != null ? p : 1, j = l * w;
5759
5843
  e.set({
5760
- left: ((m = e.left) != null ? m : 0) + I * j,
5761
- top: ((p = e.top) != null ? p : 0) + I * y
5844
+ left: ((m = e.left) != null ? m : 0) + j * C,
5845
+ top: ((g = e.top) != null ? g : 0) + j * y
5762
5846
  });
5763
5847
  }
5764
5848
  }
@@ -5779,10 +5863,10 @@ class st {
5779
5863
  paddingTop: h = 0,
5780
5864
  paddingRight: u = 0,
5781
5865
  paddingBottom: f = 0,
5782
- paddingLeft: g = 0
5866
+ paddingLeft: p = 0
5783
5867
  } = t, {
5784
5868
  radiusTopLeft: m = 0,
5785
- radiusTopRight: p = 0,
5869
+ radiusTopRight: g = 0,
5786
5870
  radiusBottomRight: v = 0,
5787
5871
  radiusBottomLeft: M = 0
5788
5872
  } = t;
@@ -5794,16 +5878,16 @@ class st {
5794
5878
  top: h,
5795
5879
  right: u,
5796
5880
  bottom: f,
5797
- left: g
5881
+ left: p
5798
5882
  },
5799
5883
  baseRadii: {
5800
5884
  topLeft: m,
5801
- topRight: p,
5885
+ topRight: g,
5802
5886
  bottomRight: v,
5803
5887
  bottomLeft: M
5804
5888
  },
5805
5889
  baseStyles: JSON.parse(JSON.stringify(c)),
5806
- baseLineFontDefaults: en({ lineFontDefaults: l }),
5890
+ baseLineFontDefaults: an({ lineFontDefaults: l }),
5807
5891
  hasWidthChange: !1
5808
5892
  }, this.scalingState.set(t, e);
5809
5893
  }
@@ -5814,11 +5898,11 @@ class st {
5814
5898
  */
5815
5899
  static _getSnapshot(t) {
5816
5900
  const e = ({
5817
- snapshot: x,
5818
- entries: R
5901
+ snapshot: D,
5902
+ entries: k
5819
5903
  }) => {
5820
- Object.entries(R).forEach(([_, D]) => {
5821
- D != null && (x[_] = D);
5904
+ Object.entries(k).forEach(([_, L]) => {
5905
+ L != null && (D[_] = L);
5822
5906
  });
5823
5907
  }, {
5824
5908
  id: n,
@@ -5832,35 +5916,35 @@ class st {
5832
5916
  fontStyle: h,
5833
5917
  underline: u,
5834
5918
  linethrough: f,
5835
- textAlign: g,
5919
+ textAlign: p,
5836
5920
  fill: m,
5837
- stroke: p,
5921
+ stroke: g,
5838
5922
  strokeWidth: v,
5839
5923
  opacity: M,
5840
- backgroundColor: j,
5924
+ backgroundColor: C,
5841
5925
  backgroundOpacity: y,
5842
5926
  paddingTop: w,
5843
- paddingRight: I,
5844
- paddingBottom: C,
5927
+ paddingRight: j,
5928
+ paddingBottom: T,
5845
5929
  paddingLeft: b,
5846
5930
  radiusTopLeft: A,
5847
5931
  radiusTopRight: S,
5848
- radiusBottomRight: T,
5932
+ radiusBottomRight: I,
5849
5933
  radiusBottomLeft: O,
5850
- left: P,
5851
- top: U,
5852
- width: F,
5934
+ left: N,
5935
+ top: W,
5936
+ width: z,
5853
5937
  height: E,
5854
5938
  angle: B,
5855
- scaleX: H,
5856
- scaleY: z
5857
- } = t, W = {
5939
+ scaleX: Y,
5940
+ scaleY: R
5941
+ } = t, U = {
5858
5942
  id: n,
5859
5943
  uppercase: !!i,
5860
- textAlign: g
5944
+ textAlign: p
5861
5945
  };
5862
5946
  return e({
5863
- snapshot: W,
5947
+ snapshot: U,
5864
5948
  entries: {
5865
5949
  text: s,
5866
5950
  textCaseRaw: o,
@@ -5872,28 +5956,28 @@ class st {
5872
5956
  underline: u,
5873
5957
  linethrough: f,
5874
5958
  fill: m,
5875
- stroke: p,
5959
+ stroke: g,
5876
5960
  strokeWidth: v,
5877
5961
  opacity: M,
5878
- backgroundColor: j,
5962
+ backgroundColor: C,
5879
5963
  backgroundOpacity: y,
5880
5964
  paddingTop: w,
5881
- paddingRight: I,
5882
- paddingBottom: C,
5965
+ paddingRight: j,
5966
+ paddingBottom: T,
5883
5967
  paddingLeft: b,
5884
5968
  radiusTopLeft: A,
5885
5969
  radiusTopRight: S,
5886
- radiusBottomRight: T,
5970
+ radiusBottomRight: I,
5887
5971
  radiusBottomLeft: O,
5888
- left: P,
5889
- top: U,
5890
- width: F,
5972
+ left: N,
5973
+ top: W,
5974
+ width: z,
5891
5975
  height: E,
5892
5976
  angle: B,
5893
- scaleX: H,
5894
- scaleY: z
5977
+ scaleX: Y,
5978
+ scaleY: R
5895
5979
  }
5896
- }), W;
5980
+ }), U;
5897
5981
  }
5898
5982
  /**
5899
5983
  * Возвращает первый доступный шрифт или дефолтный Arial.
@@ -5903,7 +5987,7 @@ class st {
5903
5987
  return (e = (t = this.fonts[0]) == null ? void 0 : t.family) != null ? e : "Arial";
5904
5988
  }
5905
5989
  }
5906
- const tt = ({
5990
+ const et = ({
5907
5991
  value: d,
5908
5992
  fallback: t = 0
5909
5993
  }) => typeof d == "number" && Number.isFinite(d) ? d : typeof t == "number" && Number.isFinite(t) ? t : 0, ce = ({
@@ -5911,9 +5995,9 @@ const tt = ({
5911
5995
  dimension: t,
5912
5996
  useRelativePositions: e
5913
5997
  }) => {
5914
- const n = tt({ value: d });
5998
+ const n = et({ value: d });
5915
5999
  return e ? n : n / (t || 1);
5916
- }, Ls = ({
6000
+ }, Ds = ({
5917
6001
  object: d,
5918
6002
  baseWidth: t,
5919
6003
  baseHeight: e,
@@ -5942,12 +6026,12 @@ const tt = ({
5942
6026
  value: r,
5943
6027
  dimension: e,
5944
6028
  useRelativePositions: n
5945
- }), f = tt({ value: c }) / (t || 1), g = tt({ value: l }) / (e || 1);
6029
+ }), f = et({ value: c }) / (t || 1), p = et({ value: l }) / (e || 1);
5946
6030
  return {
5947
6031
  x: h + f / 2,
5948
- y: u + g / 2
6032
+ y: u + p / 2
5949
6033
  };
5950
- }, Ds = ({
6034
+ }, _s = ({
5951
6035
  normalizedX: d,
5952
6036
  normalizedY: t,
5953
6037
  bounds: e,
@@ -5956,12 +6040,12 @@ const tt = ({
5956
6040
  }) => {
5957
6041
  const { left: o, top: i, width: a, height: r } = e;
5958
6042
  if (!s) {
5959
- const { width: h, height: u } = n, f = o + d * (h || a), g = i + t * (u || r);
5960
- return new at(f, g);
6043
+ const { width: h, height: u } = n, f = o + d * (h || a), p = i + t * (u || r);
6044
+ return new at(f, p);
5961
6045
  }
5962
6046
  const c = o + d * a, l = i + t * r;
5963
6047
  return new at(c, l);
5964
- }, _s = ({
6048
+ }, xs = ({
5965
6049
  object: d,
5966
6050
  montageArea: t,
5967
6051
  bounds: e
@@ -5999,12 +6083,12 @@ const tt = ({
5999
6083
  } catch (t) {
6000
6084
  return null;
6001
6085
  }
6002
- }, xs = ({
6086
+ }, Rs = ({
6003
6087
  x1: d,
6004
6088
  y1: t,
6005
6089
  x2: e,
6006
6090
  y2: n
6007
- }) => (Math.atan2(n - t, e - d) * 180 / Math.PI + 360) % 360, Rs = (d) => {
6091
+ }) => (Math.atan2(n - t, e - d) * 180 / Math.PI + 360) % 360, ks = (d) => {
6008
6092
  if (!d || typeof d != "object") return null;
6009
6093
  const { type: t, coords: e, colorStops: n } = d, s = Array.isArray(n) ? n : [], o = s[0], i = s[s.length - 1], a = typeof (o == null ? void 0 : o.color) == "string" ? o.color : void 0, r = typeof (i == null ? void 0 : i.color) == "string" ? i.color : a, c = typeof (o == null ? void 0 : o.offset) == "number" ? o.offset * 100 : void 0, l = typeof (i == null ? void 0 : i.offset) == "number" ? i.offset * 100 : void 0, h = s.map((u) => ({
6010
6094
  color: typeof u.color == "string" ? u.color : "#000000",
@@ -6012,11 +6096,11 @@ const tt = ({
6012
6096
  }));
6013
6097
  if (!a || !r || !e) return null;
6014
6098
  if (t === "linear") {
6015
- const { x1: u, y1: f, x2: g, y2: m } = e;
6016
- if (typeof u == "number" && typeof f == "number" && typeof g == "number" && typeof m == "number")
6099
+ const { x1: u, y1: f, x2: p, y2: m } = e;
6100
+ if (typeof u == "number" && typeof f == "number" && typeof p == "number" && typeof m == "number")
6017
6101
  return {
6018
6102
  type: "linear",
6019
- angle: xs({ x1: u, y1: f, x2: g, y2: m }),
6103
+ angle: Rs({ x1: u, y1: f, x2: p, y2: m }),
6020
6104
  startColor: a,
6021
6105
  endColor: r,
6022
6106
  startPosition: c,
@@ -6025,13 +6109,13 @@ const tt = ({
6025
6109
  };
6026
6110
  }
6027
6111
  if (t === "radial") {
6028
- const { x1: u, y1: f, r2: g } = e;
6029
- if (typeof u == "number" && typeof f == "number" && typeof g == "number")
6112
+ const { x1: u, y1: f, r2: p } = e;
6113
+ if (typeof u == "number" && typeof f == "number" && typeof p == "number")
6030
6114
  return {
6031
6115
  type: "radial",
6032
6116
  centerX: u * 100,
6033
6117
  centerY: f * 100,
6034
- radius: g * 100,
6118
+ radius: p * 100,
6035
6119
  startColor: a,
6036
6120
  endColor: r,
6037
6121
  startPosition: c,
@@ -6040,8 +6124,8 @@ const tt = ({
6040
6124
  };
6041
6125
  }
6042
6126
  return null;
6043
- }, qt = "_templateCenterX", Me = "_templateCenterY", le = "_templateAnchorX", Se = "_templateAnchorY";
6044
- class Y {
6127
+ }, qt = "_templateCenterX", Se = "_templateCenterY", le = "_templateAnchorX", we = "_templateAnchorY";
6128
+ class H {
6045
6129
  constructor({ editor: t }) {
6046
6130
  this.editor = t;
6047
6131
  }
@@ -6060,7 +6144,7 @@ class Y {
6060
6144
  montageArea: i,
6061
6145
  errorManager: a,
6062
6146
  backgroundManager: r
6063
- } = this.editor, c = o.getActiveObject(), l = Y._collectObjects(c), { backgroundObject: h } = r != null ? r : {}, u = s && h ? [h] : [], f = [...l, ...u];
6147
+ } = this.editor, c = o.getActiveObject(), l = H._collectObjects(c), { backgroundObject: h } = r != null ? r : {}, u = s && h ? [h] : [], f = [...l, ...u];
6064
6148
  if (!f.length)
6065
6149
  return a.emitWarning({
6066
6150
  origin: "TemplateManager",
@@ -6068,21 +6152,21 @@ class Y {
6068
6152
  code: Tt.TEMPLATE_MANAGER.NO_OBJECTS_SELECTED,
6069
6153
  message: "Нет объектов для сериализации шаблона"
6070
6154
  }), null;
6071
- const g = Y._getBounds(i), m = Y._getMontageSize({ montageArea: i, bounds: g }), p = m.width, v = m.height, M = f.map((w) => Y._serializeObject({
6155
+ const p = H._getBounds(i), m = H._getMontageSize({ montageArea: i, bounds: p }), g = m.width, v = m.height, M = f.map((w) => H._serializeObject({
6072
6156
  object: w,
6073
- bounds: g,
6074
- baseWidth: p,
6157
+ bounds: p,
6158
+ baseWidth: g,
6075
6159
  baseHeight: v,
6076
6160
  montageArea: i != null ? i : null
6077
- })), j = It(L({}, n), {
6078
- baseWidth: p,
6161
+ })), C = It(x({}, n), {
6162
+ baseWidth: g,
6079
6163
  baseHeight: v,
6080
6164
  positionsNormalized: !0,
6081
6165
  previewId: e != null ? e : n.previewId
6082
6166
  });
6083
6167
  return {
6084
- id: t != null ? t : `template-${$()}`,
6085
- meta: j,
6168
+ id: t != null ? t : `template-${tt()}`,
6169
+ meta: C,
6086
6170
  objects: M
6087
6171
  };
6088
6172
  }
@@ -6090,87 +6174,85 @@ class Y {
6090
6174
  * Применяет шаблон к монтажной области без очистки текущих объектов.
6091
6175
  * @param options
6092
6176
  * @param options.template - описание шаблона
6093
- * @param options.data - данные для заполнения текстов по customData.templateField
6094
6177
  */
6095
- applyTemplate(n) {
6178
+ applyTemplate(e) {
6096
6179
  return Z(this, arguments, function* ({
6097
- template: t,
6098
- data: e
6180
+ template: t
6099
6181
  }) {
6100
6182
  const {
6101
- canvas: s,
6102
- montageArea: o,
6103
- historyManager: i,
6104
- errorManager: a,
6105
- backgroundManager: r
6106
- } = this.editor, { objects: c, meta: l, id: h } = t != null ? t : {};
6107
- if (!(c != null && c.length))
6108
- return a.emitWarning({
6183
+ canvas: n,
6184
+ montageArea: s,
6185
+ historyManager: o,
6186
+ errorManager: i,
6187
+ backgroundManager: a
6188
+ } = this.editor, { objects: r, meta: c, id: l } = t != null ? t : {};
6189
+ if (!(r != null && r.length))
6190
+ return i.emitWarning({
6109
6191
  origin: "TemplateManager",
6110
6192
  method: "applyTemplate",
6111
6193
  code: Tt.TEMPLATE_MANAGER.INVALID_TEMPLATE,
6112
6194
  message: "Шаблон не содержит объектов"
6113
6195
  }), null;
6114
- const u = Y._getBounds(o);
6115
- if (!u)
6116
- return a.emitWarning({
6196
+ const h = H._getBounds(s);
6197
+ if (!h)
6198
+ return i.emitWarning({
6117
6199
  origin: "TemplateManager",
6118
6200
  method: "applyTemplate",
6119
6201
  code: Tt.TEMPLATE_MANAGER.INVALID_TARGET,
6120
6202
  message: "Не удалось определить границы монтажной области"
6121
6203
  }), null;
6122
- const f = Y._getMontageSize({ montageArea: o, bounds: u }), g = Y._normalizeMeta({ meta: l, fallback: f }), m = Y._calculateScale({ meta: g, target: f }), p = !!g.positionsNormalized;
6123
- let v = !1, M = !1;
6124
- i.suspendHistory();
6204
+ const u = H._getMontageSize({ montageArea: s, bounds: h }), f = H._normalizeMeta({ meta: c, fallback: u }), p = H._calculateScale({ meta: f, target: u }), m = !!f.positionsNormalized;
6205
+ let g = !1, v = !1;
6206
+ o.suspendHistory();
6125
6207
  try {
6126
- const j = yield Y._enlivenObjects(c);
6127
- if (!j.length)
6128
- return a.emitWarning({
6208
+ const M = yield H._enlivenObjects(r);
6209
+ if (!M.length)
6210
+ return i.emitWarning({
6129
6211
  origin: "TemplateManager",
6130
6212
  method: "applyTemplate",
6131
6213
  code: Tt.TEMPLATE_MANAGER.INVALID_TEMPLATE,
6132
6214
  message: "Не удалось создать объекты шаблона"
6133
6215
  }), null;
6134
- const { backgroundObject: y, contentObjects: w } = Y._extractBackgroundObject(j);
6135
- y && (M = yield Y._applyBackgroundFromObject({
6136
- backgroundObject: y,
6137
- backgroundManager: r,
6138
- errorManager: a
6216
+ const { backgroundObject: C, contentObjects: y } = H._extractBackgroundObject(M);
6217
+ C && (v = yield H._applyBackgroundFromObject({
6218
+ backgroundObject: C,
6219
+ backgroundManager: a,
6220
+ errorManager: i
6139
6221
  }));
6140
- const I = w.map((C) => (this._adaptTextboxWidth({
6141
- object: C,
6142
- baseWidth: g.baseWidth
6143
- }), Y._transformObject({
6144
- object: C,
6145
- scale: m,
6146
- bounds: u,
6147
- targetSize: f,
6148
- baseWidth: g.baseWidth,
6149
- baseHeight: g.baseHeight,
6150
- montageArea: o,
6151
- useRelativePositions: p
6152
- }), C.set({
6153
- id: `${C.type}-${$()}`,
6222
+ const w = y.map((j) => (this._adaptTextboxWidth({
6223
+ object: j,
6224
+ baseWidth: f.baseWidth
6225
+ }), H._transformObject({
6226
+ object: j,
6227
+ scale: p,
6228
+ bounds: h,
6229
+ targetSize: u,
6230
+ baseWidth: f.baseWidth,
6231
+ baseHeight: f.baseHeight,
6232
+ montageArea: s,
6233
+ useRelativePositions: m
6234
+ }), j.set({
6235
+ id: `${j.type}-${tt()}`,
6154
6236
  evented: !0
6155
- }), s.add(C), C));
6156
- return !I.length && !M ? null : (v = I.length > 0 || M, I.length && Y._activateObjects({ canvas: s, objects: I }), s.requestRenderAll(), s.fire("editor:template-applied", {
6237
+ }), n.add(j), j));
6238
+ return !w.length && !v ? null : (g = w.length > 0 || v, w.length && H._activateObjects({ canvas: n, objects: w }), n.requestRenderAll(), n.fire("editor:template-applied", {
6157
6239
  template: t,
6158
- objects: I,
6159
- bounds: u
6160
- }), I);
6161
- } catch (j) {
6162
- return a.emitError({
6240
+ objects: w,
6241
+ bounds: h
6242
+ }), w);
6243
+ } catch (M) {
6244
+ return i.emitError({
6163
6245
  origin: "TemplateManager",
6164
6246
  method: "applyTemplate",
6165
6247
  code: Tt.TEMPLATE_MANAGER.APPLY_FAILED,
6166
6248
  message: "Ошибка применения шаблона",
6167
6249
  data: {
6168
- templateId: h,
6169
- error: j
6250
+ templateId: l,
6251
+ error: M
6170
6252
  }
6171
6253
  }), null;
6172
6254
  } finally {
6173
- i.resumeHistory(), v && i.saveState();
6255
+ o.resumeHistory(), g && o.saveState();
6174
6256
  }
6175
6257
  });
6176
6258
  }
@@ -6204,13 +6286,13 @@ class Y {
6204
6286
  static _enlivenObjects(t) {
6205
6287
  return Z(this, null, function* () {
6206
6288
  return (yield Promise.all(t.map((n) => Z(null, null, function* () {
6207
- if (Y._hasSerializedSvgMarkup(n)) {
6208
- const i = yield Y._reviveSvgObject(n);
6289
+ if (H._hasSerializedSvgMarkup(n)) {
6290
+ const i = yield H._reviveSvgObject(n);
6209
6291
  if (i)
6210
- return Y._restoreImageScale({ revived: i, serialized: n }), i;
6292
+ return H._restoreImageScale({ revived: i, serialized: n }), i;
6211
6293
  }
6212
- const s = yield yt.enlivenObjects([n]), o = s == null ? void 0 : s[0];
6213
- return o ? (Y._restoreImageScale({ revived: o, serialized: n }), o) : null;
6294
+ const s = yield ft.enlivenObjects([n]), o = s == null ? void 0 : s[0];
6295
+ return o ? (H._restoreImageScale({ revived: o, serialized: n }), o) : null;
6214
6296
  })))).filter((n) => !!n);
6215
6297
  });
6216
6298
  }
@@ -6232,28 +6314,28 @@ class Y {
6232
6314
  naturalWidth: h = 0,
6233
6315
  naturalHeight: u = 0,
6234
6316
  width: f = 0,
6235
- height: g = 0
6317
+ height: p = 0
6236
6318
  } = l instanceof HTMLImageElement ? l : {
6237
6319
  naturalWidth: 0,
6238
6320
  naturalHeight: 0,
6239
6321
  width: 0,
6240
6322
  height: 0
6241
- }, m = tt({ value: h || f || c.width, fallback: 0 }), p = tt({ value: u || g || c.height, fallback: 0 }), v = tt({ value: s, fallback: m }), M = tt({ value: o, fallback: p }), j = tt({ value: i, fallback: c.scaleX || 1 }), y = tt({ value: a, fallback: c.scaleY || 1 }), w = v * j, I = M * y, C = m > 0, b = p > 0, A = w > 0, S = I > 0, T = Y._resolveImageFit({ customData: r }), O = {};
6242
- if (C && (O.width = m), b && (O.height = p), !C || !b) {
6323
+ }, m = et({ value: h || f || c.width, fallback: 0 }), g = et({ value: u || p || c.height, fallback: 0 }), v = et({ value: s, fallback: m }), M = et({ value: o, fallback: g }), C = et({ value: i, fallback: c.scaleX || 1 }), y = et({ value: a, fallback: c.scaleY || 1 }), w = v * C, j = M * y, T = m > 0, b = g > 0, A = w > 0, S = j > 0, I = H._resolveImageFit({ customData: r }), O = {};
6324
+ if (T && (O.width = m), b && (O.height = g), !T || !b) {
6243
6325
  c.set(O);
6244
6326
  return;
6245
6327
  }
6246
- if (T === "stretch") {
6247
- const U = A ? w / m : null, F = S ? I / p : null;
6248
- U && U > 0 && (O.scaleX = U), F && F > 0 && (O.scaleY = F), c.set(O);
6328
+ if (I === "stretch") {
6329
+ const W = A ? w / m : null, z = S ? j / g : null;
6330
+ W && W > 0 && (O.scaleX = W), z && z > 0 && (O.scaleY = z), c.set(O);
6249
6331
  return;
6250
6332
  }
6251
6333
  if (!A || !S) {
6252
6334
  c.set(O);
6253
6335
  return;
6254
6336
  }
6255
- const P = Math.min(w / m, I / p);
6256
- Number.isFinite(P) && P > 0 && (O.scaleX = P, O.scaleY = P), c.set(O);
6337
+ const N = Math.min(w / m, j / g);
6338
+ Number.isFinite(N) && N > 0 && (O.scaleX = N, O.scaleY = N), c.set(O);
6257
6339
  }
6258
6340
  /**
6259
6341
  * Определяет режим вписывания изображения при восстановлении.
@@ -6279,8 +6361,8 @@ class Y {
6279
6361
  const e = typeof t.svgMarkup == "string" ? t.svgMarkup : null;
6280
6362
  if (!e) return null;
6281
6363
  try {
6282
- const n = yield Tn(e), s = yt.groupSVGElements(n.objects, n.options), o = yield yt.enlivenObjectEnlivables(
6283
- Y._prepareSerializableProps(t)
6364
+ const n = yield On(e), s = ft.groupSVGElements(n.objects, n.options), o = yield ft.enlivenObjectEnlivables(
6365
+ H._prepareSerializableProps(t)
6284
6366
  );
6285
6367
  return s.set(o), s.setCoords(), s;
6286
6368
  } catch (n) {
@@ -6292,7 +6374,7 @@ class Y {
6292
6374
  * Убирает технические поля сериализации, оставляя только применимые свойства.
6293
6375
  */
6294
6376
  static _prepareSerializableProps(t) {
6295
- const e = L({}, t);
6377
+ const e = x({}, t);
6296
6378
  return delete e.svgMarkup, delete e.objects, delete e.path, delete e.paths, delete e.type, delete e.version, e;
6297
6379
  }
6298
6380
  /**
@@ -6338,34 +6420,34 @@ class Y {
6338
6420
  montageArea: a,
6339
6421
  useRelativePositions: r
6340
6422
  }) {
6341
- const c = t, { x: l, y: h } = Ls({
6423
+ const c = t, { x: l, y: h } = Ds({
6342
6424
  object: t,
6343
6425
  baseWidth: o,
6344
6426
  baseHeight: i,
6345
6427
  useRelativePositions: r,
6346
6428
  centerKeys: {
6347
6429
  x: qt,
6348
- y: Me
6430
+ y: Se
6349
6431
  }
6350
- }), { scaleX: u, scaleY: f } = t, g = tt({ value: u, fallback: 1 }), m = tt({ value: f, fallback: 1 }), p = Y._getPositioningBounds({
6432
+ }), { scaleX: u, scaleY: f } = t, p = et({ value: u, fallback: 1 }), m = et({ value: f, fallback: 1 }), g = H._getPositioningBounds({
6351
6433
  bounds: n,
6352
6434
  baseWidth: o,
6353
6435
  baseHeight: i,
6354
6436
  scale: e,
6355
6437
  useRelativePositions: r,
6356
- anchorX: Y._resolveAnchor(c, le),
6357
- anchorY: Y._resolveAnchor(c, Se)
6358
- }), v = Ds({
6438
+ anchorX: H._resolveAnchor(c, le),
6439
+ anchorY: H._resolveAnchor(c, we)
6440
+ }), v = _s({
6359
6441
  normalizedX: l,
6360
6442
  normalizedY: h,
6361
- bounds: p,
6443
+ bounds: g,
6362
6444
  targetSize: s,
6363
6445
  montageArea: a
6364
- }), M = g * e, j = m * e;
6446
+ }), M = p * e, C = m * e;
6365
6447
  t.set({
6366
6448
  scaleX: M,
6367
- scaleY: j
6368
- }), t.setPositionByOrigin(v, "center", "center"), t.setCoords(), delete c[qt], delete c[Me], delete c[le], delete c[Se];
6449
+ scaleY: C
6450
+ }), t.setPositionByOrigin(v, "center", "center"), t.setCoords(), delete c[qt], delete c[Se], delete c[le], delete c[we];
6369
6451
  }
6370
6452
  /**
6371
6453
  * Возвращает bounds, в которых должны позиционироваться нормализованные объекты.
@@ -6381,7 +6463,7 @@ class Y {
6381
6463
  anchorY: a
6382
6464
  }) {
6383
6465
  if (!o) return t;
6384
- const r = (e || t.width) * s, c = (n || t.height) * s, l = t.width - r, h = t.height - c, u = t.left + Y._calculateAnchorOffset(i, l), f = t.top + Y._calculateAnchorOffset(a, h);
6466
+ const r = (e || t.width) * s, c = (n || t.height) * s, l = t.width - r, h = t.height - c, u = t.left + H._calculateAnchorOffset(i, l), f = t.top + H._calculateAnchorOffset(a, h);
6385
6467
  return {
6386
6468
  left: u,
6387
6469
  top: f,
@@ -6413,7 +6495,7 @@ class Y {
6413
6495
  fallback: e
6414
6496
  }) {
6415
6497
  const { width: n, height: s } = e, r = t || {}, { baseWidth: o = n, baseHeight: i = s } = r, a = Mt(r, ["baseWidth", "baseHeight"]);
6416
- return L({
6498
+ return x({
6417
6499
  baseWidth: o,
6418
6500
  baseHeight: i
6419
6501
  }, a);
@@ -6454,26 +6536,26 @@ class Y {
6454
6536
  if (!(t instanceof dt)) return;
6455
6537
  const n = typeof t.text == "string" ? t.text : "";
6456
6538
  if (!n) return;
6457
- const s = tt({
6539
+ const s = et({
6458
6540
  value: (B = (E = this.editor) == null ? void 0 : E.montageArea) == null ? void 0 : B.width,
6459
6541
  fallback: 0
6460
6542
  }), {
6461
6543
  width: o = 0,
6462
6544
  scaleX: i = 1,
6463
6545
  strokeWidth: a = 0
6464
- } = t, r = tt({ value: e, fallback: 0 }), c = t, l = tt({ value: c.paddingLeft, fallback: 0 }), h = tt({ value: c.paddingRight, fallback: 0 }), u = tt({ value: i, fallback: 1 }), f = tt({ value: a, fallback: 0 }) * u, g = tt({ value: o, fallback: 0 }), m = g * u, p = l * u, v = h * u, M = m + p + v + f;
6465
- if (!s || !g || !r) return;
6546
+ } = t, r = et({ value: e, fallback: 0 }), c = t, l = et({ value: c.paddingLeft, fallback: 0 }), h = et({ value: c.paddingRight, fallback: 0 }), u = et({ value: i, fallback: 1 }), f = et({ value: a, fallback: 0 }) * u, p = et({ value: o, fallback: 0 }), m = p * u, g = l * u, v = h * u, M = m + g + v + f;
6547
+ if (!s || !p || !r) return;
6466
6548
  t.setCoords();
6467
- const j = t, y = j[qt], w = typeof y == "number" ? y : null, I = Y._resolveAnchor(j, le), C = M / r, b = w !== null ? w - C / 2 : null, A = w !== null ? w + C / 2 : null, S = t.getCenterPoint();
6549
+ const C = t, y = C[qt], w = typeof y == "number" ? y : null, j = H._resolveAnchor(C, le), T = M / r, b = w !== null ? w - T / 2 : null, A = w !== null ? w + T / 2 : null, S = t.getCenterPoint();
6468
6550
  t.set("width", s), t.initDimensions();
6469
- const T = Y._getLongestLineWidth({
6551
+ const I = H._getLongestLineWidth({
6470
6552
  textbox: t,
6471
6553
  text: n
6472
- }), O = T > g ? T + 1 : g;
6554
+ }), O = I > p ? I + 1 : p;
6473
6555
  t.set("width", O), t.initDimensions(), t.setPositionByOrigin(S, "center", "center"), t.setCoords();
6474
- const U = (O * u + p + v + f) / r;
6475
- let F = w;
6476
- I === "start" && b !== null ? F = Math.max(0, b) + U / 2 : I === "end" && A !== null && (F = Math.min(1, A) - U / 2), typeof F == "number" && (j[qt] = F);
6556
+ const W = (O * u + g + v + f) / r;
6557
+ let z = w;
6558
+ j === "start" && b !== null ? z = Math.max(0, b) + W / 2 : j === "end" && A !== null && (z = Math.min(1, A) - W / 2), typeof z == "number" && (C[qt] = z);
6477
6559
  }
6478
6560
  /**
6479
6561
  * Возвращает ширину самой длинной строки текстового объекта.
@@ -6503,9 +6585,9 @@ class Y {
6503
6585
  baseHeight: s,
6504
6586
  montageArea: o
6505
6587
  }) {
6506
- const i = t.toDatalessObject([...Te]);
6507
- if (Y._isSvgObject(t)) {
6508
- const y = Y._extractSvgMarkup(t);
6588
+ const i = t.toDatalessObject([...Oe]);
6589
+ if (H._isSvgObject(t)) {
6590
+ const y = H._extractSvgMarkup(t);
6509
6591
  y && (i.svgMarkup = y, delete i.objects, delete i.path);
6510
6592
  }
6511
6593
  if (!e) return i;
@@ -6514,26 +6596,26 @@ class Y {
6514
6596
  top: r,
6515
6597
  width: c,
6516
6598
  height: l
6517
- } = e, h = t.getBoundingRect(!1, !0), u = n || c || 1, f = s || l || 1, g = _s({
6599
+ } = e, h = t.getBoundingRect(!1, !0), u = n || c || 1, f = s || l || 1, p = xs({
6518
6600
  object: t,
6519
6601
  montageArea: o,
6520
6602
  bounds: e
6521
- }), m = g != null ? g : (() => {
6603
+ }), m = p != null ? p : (() => {
6522
6604
  const y = t.getCenterPoint();
6523
6605
  return {
6524
6606
  x: (y.x - a) / u,
6525
6607
  y: (y.y - r) / f
6526
6608
  };
6527
- })(), p = (h.left - a) / u, v = (h.top - r) / f, M = p + h.width / u, j = v + h.height / f;
6528
- return i[qt] = m.x, i[Me] = m.y, i[le] = Y._detectAnchor({
6609
+ })(), g = (h.left - a) / u, v = (h.top - r) / f, M = g + h.width / u, C = v + h.height / f;
6610
+ return i[qt] = m.x, i[Se] = m.y, i[le] = H._detectAnchor({
6529
6611
  center: m.x,
6530
- start: p,
6612
+ start: g,
6531
6613
  end: M
6532
- }), i[Se] = Y._detectAnchor({
6614
+ }), i[we] = H._detectAnchor({
6533
6615
  center: m.y,
6534
6616
  start: v,
6535
- end: j
6536
- }), i.left = p, i.top = v, i;
6617
+ end: C
6618
+ }), i.left = g, i.top = v, i;
6537
6619
  }
6538
6620
  /**
6539
6621
  * Делит список объектов на фон и контент по id === 'background'.
@@ -6555,7 +6637,7 @@ class Y {
6555
6637
  errorManager: n
6556
6638
  }) {
6557
6639
  try {
6558
- const { fill: o, customData: i } = t, { backgroundType: a } = t, r = Y._cloneCustomData(i);
6640
+ const { fill: o, customData: i } = t, { backgroundType: a } = t, r = H._cloneCustomData(i);
6559
6641
  if (a === "color" && typeof o == "string")
6560
6642
  return e.setColorBackground({
6561
6643
  color: o,
@@ -6564,7 +6646,7 @@ class Y {
6564
6646
  withoutSave: !0
6565
6647
  }), !0;
6566
6648
  if (a === "gradient") {
6567
- const c = Rs(o);
6649
+ const c = ks(o);
6568
6650
  if (c)
6569
6651
  return e.setGradientBackground({
6570
6652
  gradient: c,
@@ -6574,7 +6656,7 @@ class Y {
6574
6656
  }), !0;
6575
6657
  }
6576
6658
  if (a === "image") {
6577
- const c = Y._getImageSource(t);
6659
+ const c = H._getImageSource(t);
6578
6660
  if (c)
6579
6661
  return yield e.setImageBackground({
6580
6662
  imageSource: c,
@@ -6617,7 +6699,7 @@ class Y {
6617
6699
  */
6618
6700
  static _cloneCustomData(t) {
6619
6701
  if (!(!t || typeof t != "object"))
6620
- return L({}, t);
6702
+ return x({}, t);
6621
6703
  }
6622
6704
  /**
6623
6705
  * Извлекает src изображения из FabricImage или его исходного элемента.
@@ -6643,10 +6725,10 @@ class Y {
6643
6725
  */
6644
6726
  // eslint-disable-next-line class-methods-use-this
6645
6727
  enlivenObjectEnlivables(t) {
6646
- return yt.enlivenObjectEnlivables(t);
6728
+ return ft.enlivenObjectEnlivables(t);
6647
6729
  }
6648
6730
  }
6649
- const ks = 5, pn = "#3D8BF4", Oe = 1, de = 1, ln = ({
6731
+ const Ns = 5, mn = "#3D8BF4", De = 1, de = 1, dn = ({
6650
6732
  anchors: d,
6651
6733
  positions: t,
6652
6734
  threshold: e
@@ -6661,16 +6743,16 @@ const ks = 5, pn = "#3D8BF4", Oe = 1, de = 1, ln = ({
6661
6743
  delta: n,
6662
6744
  guidePosition: o
6663
6745
  };
6664
- }, Ns = ({
6746
+ }, Bs = ({
6665
6747
  activeBounds: d,
6666
6748
  threshold: t,
6667
6749
  anchors: e
6668
6750
  }) => {
6669
- const { left: n, right: s, centerX: o, top: i, bottom: a, centerY: r } = d, c = ln({
6751
+ const { left: n, right: s, centerX: o, top: i, bottom: a, centerY: r } = d, c = dn({
6670
6752
  anchors: e.vertical,
6671
6753
  positions: [n, o, s],
6672
6754
  threshold: t
6673
- }), l = ln({
6755
+ }), l = dn({
6674
6756
  anchors: e.horizontal,
6675
6757
  positions: [i, r, a],
6676
6758
  threshold: t
@@ -6686,7 +6768,7 @@ const ks = 5, pn = "#3D8BF4", Oe = 1, de = 1, ln = ({
6686
6768
  deltaY: l.delta,
6687
6769
  guides: h
6688
6770
  };
6689
- }, mn = ({
6771
+ }, yn = ({
6690
6772
  activeBounds: d,
6691
6773
  aligned: t,
6692
6774
  threshold: e,
@@ -6705,7 +6787,7 @@ const ks = 5, pn = "#3D8BF4", Oe = 1, de = 1, ln = ({
6705
6787
  if (s === "vertical") {
6706
6788
  const u = o - h.bottom, f = Math.abs(u - l.distance);
6707
6789
  if (f <= e) {
6708
- const p = l.distance - u, v = {
6790
+ const g = l.distance - u, v = {
6709
6791
  type: s,
6710
6792
  axis: l.axis,
6711
6793
  refStart: l.start,
@@ -6714,11 +6796,11 @@ const ks = 5, pn = "#3D8BF4", Oe = 1, de = 1, ln = ({
6714
6796
  activeEnd: h.bottom + l.distance,
6715
6797
  distance: l.distance
6716
6798
  };
6717
- c.push({ delta: p, guide: v, diff: f });
6799
+ c.push({ delta: g, guide: v, diff: f });
6718
6800
  }
6719
- const g = h.top - i, m = Math.abs(g - l.distance);
6801
+ const p = h.top - i, m = Math.abs(p - l.distance);
6720
6802
  if (m <= e) {
6721
- const p = l.distance - g, v = {
6803
+ const g = l.distance - p, v = {
6722
6804
  type: s,
6723
6805
  axis: l.axis,
6724
6806
  refStart: l.start,
@@ -6727,12 +6809,12 @@ const ks = 5, pn = "#3D8BF4", Oe = 1, de = 1, ln = ({
6727
6809
  activeEnd: h.top,
6728
6810
  distance: l.distance
6729
6811
  };
6730
- c.push({ delta: p, guide: v, diff: m });
6812
+ c.push({ delta: g, guide: v, diff: m });
6731
6813
  }
6732
6814
  } else {
6733
6815
  const u = a - h.right, f = Math.abs(u - l.distance);
6734
6816
  if (f <= e) {
6735
- const p = l.distance - u, v = {
6817
+ const g = l.distance - u, v = {
6736
6818
  type: s,
6737
6819
  axis: l.axis,
6738
6820
  refStart: l.start,
@@ -6741,11 +6823,11 @@ const ks = 5, pn = "#3D8BF4", Oe = 1, de = 1, ln = ({
6741
6823
  activeEnd: h.right + l.distance,
6742
6824
  distance: l.distance
6743
6825
  };
6744
- c.push({ delta: p, guide: v, diff: f });
6826
+ c.push({ delta: g, guide: v, diff: f });
6745
6827
  }
6746
- const g = h.left - r, m = Math.abs(g - l.distance);
6828
+ const p = h.left - r, m = Math.abs(p - l.distance);
6747
6829
  if (m <= e) {
6748
- const p = l.distance - g, v = {
6830
+ const g = l.distance - p, v = {
6749
6831
  type: s,
6750
6832
  axis: l.axis,
6751
6833
  refStart: l.start,
@@ -6754,11 +6836,11 @@ const ks = 5, pn = "#3D8BF4", Oe = 1, de = 1, ln = ({
6754
6836
  activeEnd: h.left,
6755
6837
  distance: l.distance
6756
6838
  };
6757
- c.push({ delta: p, guide: v, diff: m });
6839
+ c.push({ delta: g, guide: v, diff: m });
6758
6840
  }
6759
6841
  }
6760
6842
  return c;
6761
- }, Bs = ({
6843
+ }, zs = ({
6762
6844
  activeBounds: d,
6763
6845
  candidates: t,
6764
6846
  threshold: e,
@@ -6781,70 +6863,70 @@ const ks = 5, pn = "#3D8BF4", Oe = 1, de = 1, ln = ({
6781
6863
  const h = l.findIndex((y) => y.isActive);
6782
6864
  if (h === -1)
6783
6865
  return { delta: 0, guide: null };
6784
- const u = l[h - 1], f = l[h - 2], g = l[h + 1], m = l[h + 2], p = [], v = i - o;
6866
+ const u = l[h - 1], f = l[h - 2], p = l[h + 1], m = l[h + 2], g = [], v = i - o;
6785
6867
  if (u && f) {
6786
- const { bounds: y } = u, { bounds: w } = f, I = y.top - w.bottom, C = o - y.bottom, b = Math.abs(C - I);
6868
+ const { bounds: y } = u, { bounds: w } = f, j = y.top - w.bottom, T = o - y.bottom, b = Math.abs(T - j);
6787
6869
  if (b <= e) {
6788
- const A = I - C, S = o + A, T = {
6870
+ const A = j - T, S = o + A, I = {
6789
6871
  type: "vertical",
6790
6872
  axis: s,
6791
6873
  refStart: w.bottom,
6792
6874
  refEnd: y.top,
6793
6875
  activeStart: y.bottom,
6794
6876
  activeEnd: S,
6795
- distance: I
6877
+ distance: j
6796
6878
  };
6797
- p.push({ delta: A, guide: T, diff: b });
6879
+ g.push({ delta: A, guide: I, diff: b });
6798
6880
  }
6799
6881
  }
6800
- if (g && m) {
6801
- const { bounds: y } = g, { bounds: w } = m, I = w.top - y.bottom, C = y.top - i, b = Math.abs(C - I);
6882
+ if (p && m) {
6883
+ const { bounds: y } = p, { bounds: w } = m, j = w.top - y.bottom, T = y.top - i, b = Math.abs(T - j);
6802
6884
  if (b <= e) {
6803
- const A = C - I, S = i + A, T = {
6885
+ const A = T - j, S = i + A, I = {
6804
6886
  type: "vertical",
6805
6887
  axis: s,
6806
6888
  refStart: y.bottom,
6807
6889
  refEnd: w.top,
6808
6890
  activeStart: S,
6809
6891
  activeEnd: y.top,
6810
- distance: I
6892
+ distance: j
6811
6893
  };
6812
- p.push({ delta: A, guide: T, diff: b });
6894
+ g.push({ delta: A, guide: I, diff: b });
6813
6895
  }
6814
6896
  }
6815
- if (u && g) {
6816
- const { bounds: y } = u, { bounds: w } = g, C = w.top - y.bottom - v;
6817
- if (C >= 0) {
6818
- const b = C / 2, A = o - y.bottom, S = w.top - i, T = Math.abs(A - b), O = Math.abs(S - b), P = Math.max(T, O);
6819
- if (P <= e) {
6820
- const U = b - A, F = i + U, E = {
6897
+ if (u && p) {
6898
+ const { bounds: y } = u, { bounds: w } = p, T = w.top - y.bottom - v;
6899
+ if (T >= 0) {
6900
+ const b = T / 2, A = o - y.bottom, S = w.top - i, I = Math.abs(A - b), O = Math.abs(S - b), N = Math.max(I, O);
6901
+ if (N <= e) {
6902
+ const W = b - A, z = i + W, E = {
6821
6903
  type: "vertical",
6822
6904
  axis: s,
6823
6905
  refStart: y.bottom,
6824
6906
  refEnd: y.bottom + b,
6825
- activeStart: F,
6826
- activeEnd: F + b,
6907
+ activeStart: z,
6908
+ activeEnd: z + b,
6827
6909
  distance: b
6828
6910
  };
6829
- p.push({ delta: U, guide: E, diff: P });
6911
+ g.push({ delta: W, guide: E, diff: N });
6830
6912
  }
6831
6913
  }
6832
6914
  }
6833
- const M = mn({
6915
+ const M = yn({
6834
6916
  activeBounds: d,
6835
6917
  aligned: c,
6836
6918
  threshold: e,
6837
6919
  patterns: n,
6838
6920
  type: "vertical"
6839
6921
  });
6840
- if (p.push(...M), !p.length)
6922
+ if (g.push(...M), !g.length)
6841
6923
  return { delta: 0, guide: null };
6842
- const j = p.reduce((y, w) => w.diff < y.diff ? w : y, p[0]);
6924
+ const C = g.reduce((y, w) => w.diff < y.diff ? w : y, g[0]);
6843
6925
  return {
6844
- delta: j.delta,
6845
- guide: j.guide
6926
+ delta: C.delta,
6927
+ guide: C.guide
6846
6928
  };
6847
- }, zs = ({
6929
+ }, Ps = ({
6848
6930
  activeBounds: d,
6849
6931
  candidates: t,
6850
6932
  threshold: e,
@@ -6867,81 +6949,81 @@ const ks = 5, pn = "#3D8BF4", Oe = 1, de = 1, ln = ({
6867
6949
  const h = l.findIndex((y) => y.isActive);
6868
6950
  if (h === -1)
6869
6951
  return { delta: 0, guide: null };
6870
- const u = l[h - 1], f = l[h - 2], g = l[h + 1], m = l[h + 2], p = [], v = i - o;
6952
+ const u = l[h - 1], f = l[h - 2], p = l[h + 1], m = l[h + 2], g = [], v = i - o;
6871
6953
  if (u && f) {
6872
- const { bounds: y } = u, { bounds: w } = f, I = y.left - w.right, C = o - y.right, b = Math.abs(C - I);
6954
+ const { bounds: y } = u, { bounds: w } = f, j = y.left - w.right, T = o - y.right, b = Math.abs(T - j);
6873
6955
  if (b <= e) {
6874
- const A = I - C, S = o + A, T = {
6956
+ const A = j - T, S = o + A, I = {
6875
6957
  type: "horizontal",
6876
6958
  axis: s,
6877
6959
  refStart: w.right,
6878
6960
  refEnd: y.left,
6879
6961
  activeStart: y.right,
6880
6962
  activeEnd: S,
6881
- distance: I
6963
+ distance: j
6882
6964
  };
6883
- p.push({ delta: A, guide: T, diff: b });
6965
+ g.push({ delta: A, guide: I, diff: b });
6884
6966
  }
6885
6967
  }
6886
- if (g && m) {
6887
- const { bounds: y } = g, { bounds: w } = m, I = w.left - y.right, C = y.left - i, b = Math.abs(C - I);
6968
+ if (p && m) {
6969
+ const { bounds: y } = p, { bounds: w } = m, j = w.left - y.right, T = y.left - i, b = Math.abs(T - j);
6888
6970
  if (b <= e) {
6889
- const A = C - I, S = i + A, T = {
6971
+ const A = T - j, S = i + A, I = {
6890
6972
  type: "horizontal",
6891
6973
  axis: s,
6892
6974
  refStart: y.right,
6893
6975
  refEnd: w.left,
6894
6976
  activeStart: S,
6895
6977
  activeEnd: y.left,
6896
- distance: I
6978
+ distance: j
6897
6979
  };
6898
- p.push({ delta: A, guide: T, diff: b });
6980
+ g.push({ delta: A, guide: I, diff: b });
6899
6981
  }
6900
6982
  }
6901
- if (u && g) {
6902
- const { bounds: y } = u, { bounds: w } = g, C = w.left - y.right - v;
6903
- if (C >= 0) {
6904
- const b = C / 2, A = o - y.right, S = w.left - i, T = Math.abs(A - b), O = Math.abs(S - b), P = Math.max(T, O);
6905
- if (P <= e) {
6906
- const U = b - A, F = i + U, E = {
6983
+ if (u && p) {
6984
+ const { bounds: y } = u, { bounds: w } = p, T = w.left - y.right - v;
6985
+ if (T >= 0) {
6986
+ const b = T / 2, A = o - y.right, S = w.left - i, I = Math.abs(A - b), O = Math.abs(S - b), N = Math.max(I, O);
6987
+ if (N <= e) {
6988
+ const W = b - A, z = i + W, E = {
6907
6989
  type: "horizontal",
6908
6990
  axis: s,
6909
6991
  refStart: y.right,
6910
6992
  refEnd: y.right + b,
6911
- activeStart: F,
6912
- activeEnd: F + b,
6993
+ activeStart: z,
6994
+ activeEnd: z + b,
6913
6995
  distance: b
6914
6996
  };
6915
- p.push({ delta: U, guide: E, diff: P });
6997
+ g.push({ delta: W, guide: E, diff: N });
6916
6998
  }
6917
6999
  }
6918
7000
  }
6919
- const M = mn({
7001
+ const M = yn({
6920
7002
  activeBounds: d,
6921
7003
  aligned: c,
6922
7004
  threshold: e,
6923
7005
  patterns: n,
6924
7006
  type: "horizontal"
6925
7007
  });
6926
- if (p.push(...M), !p.length)
7008
+ if (g.push(...M), !g.length)
6927
7009
  return { delta: 0, guide: null };
6928
- const j = p.reduce((y, w) => w.diff < y.diff ? w : y, p[0]);
7010
+ const C = g.reduce((y, w) => w.diff < y.diff ? w : y, g[0]);
6929
7011
  return {
6930
- delta: j.delta,
6931
- guide: j.guide
7012
+ delta: C.delta,
7013
+ guide: C.guide
6932
7014
  };
6933
- }, Ps = ({
7015
+ }, Fs = ({
6934
7016
  activeBounds: d,
6935
7017
  candidates: t,
6936
7018
  threshold: e,
6937
7019
  spacingPatterns: n
6938
7020
  }) => {
6939
- const s = Bs({
7021
+ const s = zs({
6940
7022
  activeBounds: d,
6941
7023
  candidates: t,
6942
7024
  threshold: e,
6943
7025
  patterns: n.vertical
6944
- }), o = zs({
7026
+ }), o = Ps({
6945
7027
  activeBounds: d,
6946
7028
  candidates: t,
6947
7029
  threshold: e,
@@ -6952,7 +7034,7 @@ const ks = 5, pn = "#3D8BF4", Oe = 1, de = 1, ln = ({
6952
7034
  deltaY: s.delta,
6953
7035
  guides: i
6954
7036
  };
6955
- }, Fs = ({
7037
+ }, Ws = ({
6956
7038
  context: d,
6957
7039
  x: t,
6958
7040
  y: e,
@@ -6962,7 +7044,7 @@ const ks = 5, pn = "#3D8BF4", Oe = 1, de = 1, ln = ({
6962
7044
  }) => {
6963
7045
  const i = Math.min(o, n / 2, s / 2);
6964
7046
  d.moveTo(t + i, e), d.lineTo(t + n - i, e), d.quadraticCurveTo(t + n, e, t + n, e + i), d.lineTo(t + n, e + s - i), d.quadraticCurveTo(t + n, e + s, t + n - i, e + s), d.lineTo(t + i, e + s), d.quadraticCurveTo(t, e + s, t, e + s - i), d.lineTo(t, e + i), d.quadraticCurveTo(t, e, t + i, e), d.closePath();
6965
- }, Ee = ({
7047
+ }, _e = ({
6966
7048
  context: d,
6967
7049
  type: t,
6968
7050
  axis: e,
@@ -6977,16 +7059,16 @@ const ks = 5, pn = "#3D8BF4", Oe = 1, de = 1, ln = ({
6977
7059
  padding: h = 4,
6978
7060
  radius: u = 4,
6979
7061
  offsetAlongAxis: f = 0,
6980
- offsetPerpendicular: g = 0
7062
+ offsetPerpendicular: p = 0
6981
7063
  }) => {
6982
- const m = i || 1, p = 12 / m, v = h / m, M = u / m, j = (n + s) / 2 + f, y = t === "vertical" ? e + g : j, w = t === "vertical" ? j : e + g;
6983
- d.save(), d.setLineDash([]), d.fillStyle = a, d.strokeStyle = a, d.lineWidth = l / m, d.font = `${p}px ${c}`, d.textAlign = "center", d.textBaseline = "middle";
6984
- const C = d.measureText(o).width + v * 2, b = p + v * 2, A = y - C / 2, S = w - b / 2;
6985
- d.beginPath(), Fs({
7064
+ const m = i || 1, g = 12 / m, v = h / m, M = u / m, C = (n + s) / 2 + f, y = t === "vertical" ? e + p : C, w = t === "vertical" ? C : e + p;
7065
+ d.save(), d.setLineDash([]), d.fillStyle = a, d.strokeStyle = a, d.lineWidth = l / m, d.font = `${g}px ${c}`, d.textAlign = "center", d.textBaseline = "middle";
7066
+ const T = d.measureText(o).width + v * 2, b = g + v * 2, A = y - T / 2, S = w - b / 2;
7067
+ d.beginPath(), Ws({
6986
7068
  context: d,
6987
7069
  x: A,
6988
7070
  y: S,
6989
- width: C,
7071
+ width: T,
6990
7072
  height: b,
6991
7073
  radius: M
6992
7074
  }), d.fill(), d.fillStyle = r, d.fillText(o, y, w), d.restore();
@@ -7005,8 +7087,8 @@ const ks = 5, pn = "#3D8BF4", Oe = 1, de = 1, ln = ({
7005
7087
  distance: c
7006
7088
  } = t, l = Math.round(c).toString();
7007
7089
  d.beginPath(), n === "vertical" ? (d.moveTo(s, o), d.lineTo(s, i), d.moveTo(s, a), d.lineTo(s, r)) : (d.moveTo(o, s), d.lineTo(i, s), d.moveTo(a, s), d.lineTo(r, s)), d.stroke();
7008
- const h = pn;
7009
- Ee({
7090
+ const h = mn;
7091
+ _e({
7010
7092
  context: d,
7011
7093
  type: n,
7012
7094
  axis: s,
@@ -7015,8 +7097,8 @@ const ks = 5, pn = "#3D8BF4", Oe = 1, de = 1, ln = ({
7015
7097
  text: l,
7016
7098
  zoom: e,
7017
7099
  color: h,
7018
- lineWidth: Oe
7019
- }), Ee({
7100
+ lineWidth: De
7101
+ }), _e({
7020
7102
  context: d,
7021
7103
  type: n,
7022
7104
  axis: s,
@@ -7025,9 +7107,9 @@ const ks = 5, pn = "#3D8BF4", Oe = 1, de = 1, ln = ({
7025
7107
  text: l,
7026
7108
  zoom: e,
7027
7109
  color: h,
7028
- lineWidth: Oe
7110
+ lineWidth: De
7029
7111
  });
7030
- }, dn = ({
7112
+ }, hn = ({
7031
7113
  anchors: d,
7032
7114
  bounds: t
7033
7115
  }) => {
@@ -7040,7 +7122,7 @@ const ks = 5, pn = "#3D8BF4", Oe = 1, de = 1, ln = ({
7040
7122
  centerY: a
7041
7123
  } = t;
7042
7124
  d.vertical.push(e, s, n), d.horizontal.push(o, a, i);
7043
- }, hn = ({
7125
+ }, un = ({
7044
7126
  bounds: d,
7045
7127
  type: t,
7046
7128
  primaryStart: e,
@@ -7051,46 +7133,46 @@ const ks = 5, pn = "#3D8BF4", Oe = 1, de = 1, ln = ({
7051
7133
  const c = a[r];
7052
7134
  let l = null, h = Number.POSITIVE_INFINITY;
7053
7135
  for (let m = r + 1; m < a.length; m += 1) {
7054
- const p = a[m];
7055
- if (Math.min(c[i], p[i]) - Math.max(c[o], p[o]) < 0) continue;
7056
- const M = p[e] - c[n];
7057
- M < 0 || M < h && (h = M, l = p);
7136
+ const g = a[m];
7137
+ if (Math.min(c[i], g[i]) - Math.max(c[o], g[o]) < 0) continue;
7138
+ const M = g[e] - c[n];
7139
+ M < 0 || M < h && (h = M, l = g);
7058
7140
  }
7059
7141
  if (!l || h === Number.POSITIVE_INFINITY) continue;
7060
- const u = Math.max(c[o], l[o]), f = Math.min(c[i], l[i]), g = (u + f) / 2;
7142
+ const u = Math.max(c[o], l[o]), f = Math.min(c[i], l[i]), p = (u + f) / 2;
7061
7143
  s.push({
7062
7144
  type: t,
7063
- axis: g,
7145
+ axis: p,
7064
7146
  start: c[n],
7065
7147
  end: l[e],
7066
7148
  distance: l[e] - c[n]
7067
7149
  });
7068
7150
  }
7069
7151
  return s;
7070
- }, Ws = ({
7152
+ }, Ys = ({
7071
7153
  bounds: d
7072
7154
  }) => {
7073
- const t = hn({
7155
+ const t = un({
7074
7156
  bounds: d,
7075
7157
  type: "vertical",
7076
7158
  primaryStart: "top",
7077
7159
  primaryEnd: "bottom"
7078
- }), e = hn({
7160
+ }), e = un({
7079
7161
  bounds: d,
7080
7162
  type: "horizontal",
7081
7163
  primaryStart: "left",
7082
7164
  primaryEnd: "right"
7083
7165
  });
7084
7166
  return { vertical: t, horizontal: e };
7085
- }, Ys = ["montage-area", "background", "interaction-blocker"], yn = ({
7167
+ }, Hs = ["montage-area", "background", "interaction-blocker"], vn = ({
7086
7168
  activeObject: d
7087
7169
  }) => {
7088
7170
  const t = /* @__PURE__ */ new Set();
7089
7171
  return d && (t.add(d), d instanceof X && d.getObjects().forEach((e) => t.add(e))), t;
7090
- }, vn = ({
7172
+ }, bn = ({
7091
7173
  object: d,
7092
7174
  excluded: t,
7093
- ignoredIds: e = Ys
7175
+ ignoredIds: e = Hs
7094
7176
  }) => {
7095
7177
  if (t.has(d)) return !0;
7096
7178
  const { visible: n = !0 } = d;
@@ -7098,7 +7180,7 @@ const ks = 5, pn = "#3D8BF4", Oe = 1, de = 1, ln = ({
7098
7180
  const { id: s } = d;
7099
7181
  return !!(s && e.includes(s));
7100
7182
  };
7101
- class Hs {
7183
+ class pe {
7102
7184
  /**
7103
7185
  * Создаёт менеджер прилипания и инициализирует слушатели событий.
7104
7186
  */
@@ -7145,14 +7227,14 @@ class Hs {
7145
7227
  * Выполняет привязку объекта к ближайшим линиям при его перемещении.
7146
7228
  */
7147
7229
  _handleObjectMoving(t) {
7148
- var m, p;
7230
+ var m, g;
7149
7231
  const { target: e, e: n } = t;
7150
7232
  if (!e) {
7151
7233
  this._clearGuides();
7152
7234
  return;
7153
7235
  }
7154
7236
  if (!!(n != null && n.ctrlKey)) {
7155
- this._clearGuides(), this._applyMovementStep({ target: e });
7237
+ this._clearGuides(), pe._applyMovementStep({ target: e });
7156
7238
  return;
7157
7239
  }
7158
7240
  !this.anchors.vertical.length && !this.anchors.horizontal.length && this._cacheAnchors({ activeObject: e });
@@ -7161,7 +7243,7 @@ class Hs {
7161
7243
  this._clearGuides();
7162
7244
  return;
7163
7245
  }
7164
- const { canvas: i } = this, a = i.getZoom() || 1, r = ks / a, c = Ns({
7246
+ const { canvas: i } = this, a = i.getZoom() || 1, r = Ns / a, c = Bs({
7165
7247
  activeBounds: o,
7166
7248
  threshold: r,
7167
7249
  anchors: this.anchors
@@ -7173,23 +7255,23 @@ class Hs {
7173
7255
  top: M + h
7174
7256
  }), e.setCoords(), o = (m = wt({ object: e })) != null ? m : o;
7175
7257
  }
7176
- const f = this.cachedTargetBounds.length ? this.cachedTargetBounds : this._collectTargets({ activeObject: e }).map((v) => wt({ object: v })).filter((v) => !!v), g = Ps({
7258
+ const f = this.cachedTargetBounds.length ? this.cachedTargetBounds : this._collectTargets({ activeObject: e }).map((v) => wt({ object: v })).filter((v) => !!v), p = Fs({
7177
7259
  activeBounds: o,
7178
7260
  candidates: f,
7179
7261
  threshold: r,
7180
7262
  spacingPatterns: this.spacingPatterns
7181
7263
  });
7182
- if (g.deltaX !== 0 || g.deltaY !== 0) {
7264
+ if (p.deltaX !== 0 || p.deltaY !== 0) {
7183
7265
  const { left: v = 0, top: M = 0 } = e;
7184
7266
  e.set({
7185
- left: v + g.deltaX,
7186
- top: M + g.deltaY
7187
- }), e.setCoords(), o = (p = wt({ object: e })) != null ? p : o;
7267
+ left: v + p.deltaX,
7268
+ top: M + p.deltaY
7269
+ }), e.setCoords(), o = (g = wt({ object: e })) != null ? g : o;
7188
7270
  }
7189
7271
  this._applyGuides({
7190
7272
  guides: u,
7191
- spacingGuides: g.guides
7192
- }), this._applyMovementStep({ target: e });
7273
+ spacingGuides: p.guides
7274
+ }), pe._applyMovementStep({ target: e });
7193
7275
  }
7194
7276
  /**
7195
7277
  * Очищает направляющие и кеш после окончания перетаскивания.
@@ -7212,7 +7294,7 @@ class Hs {
7212
7294
  const { canvas: t, guideBounds: e } = this, n = t.getSelectionContext();
7213
7295
  if (!n) return;
7214
7296
  const s = e != null ? e : this._calculateViewportBounds(), { left: o, right: i, top: a, bottom: r } = s, { viewportTransform: c } = t, l = t.getZoom() || 1;
7215
- n.save(), Array.isArray(c) && n.transform(...c), n.lineWidth = Oe / l, n.strokeStyle = pn, n.setLineDash([4, 4]);
7297
+ n.save(), Array.isArray(c) && n.transform(...c), n.lineWidth = De / l, n.strokeStyle = mn, n.setLineDash([4, 4]);
7216
7298
  for (const h of this.activeGuides)
7217
7299
  n.beginPath(), h.type === "vertical" ? (n.moveTo(h.position, a), n.lineTo(h.position, r)) : (n.moveTo(o, h.position), n.lineTo(i, h.position)), n.stroke();
7218
7300
  for (const h of this.activeSpacingGuides)
@@ -7251,7 +7333,7 @@ class Hs {
7251
7333
  /**
7252
7334
  * Применяет шаг перемещения, округляя координаты объекта к сетке MOVE_SNAP_STEP.
7253
7335
  */
7254
- _applyMovementStep({ target: t }) {
7336
+ static _applyMovementStep({ target: t }) {
7255
7337
  const { left: e = 0, top: n = 0 } = t, s = Math.round(e / de) * de, o = Math.round(n / de) * de;
7256
7338
  s === e && o === n || (t.set({
7257
7339
  left: s,
@@ -7265,11 +7347,11 @@ class Hs {
7265
7347
  const e = this._collectTargets({ activeObject: t }), n = { vertical: [], horizontal: [] }, s = [];
7266
7348
  for (const a of e) {
7267
7349
  const r = wt({ object: a });
7268
- r && (dn({ anchors: n, bounds: r }), s.push(r));
7350
+ r && (hn({ anchors: n, bounds: r }), s.push(r));
7269
7351
  }
7270
7352
  const { montageArea: o } = this.editor, i = wt({ object: o });
7271
7353
  if (i) {
7272
- dn({ anchors: n, bounds: i });
7354
+ hn({ anchors: n, bounds: i });
7273
7355
  const { left: a, right: r, top: c, bottom: l } = i;
7274
7356
  this.guideBounds = {
7275
7357
  left: a,
@@ -7279,15 +7361,15 @@ class Hs {
7279
7361
  };
7280
7362
  } else
7281
7363
  this.guideBounds = this._calculateViewportBounds();
7282
- this.anchors = n, this.spacingPatterns = Ws({ bounds: s }), this.cachedTargetBounds = s;
7364
+ this.anchors = n, this.spacingPatterns = Ys({ bounds: s }), this.cachedTargetBounds = s;
7283
7365
  }
7284
7366
  /**
7285
7367
  * Собирает объекты, подходящие для прилипания, исключая активный объект и запрещённые id.
7286
7368
  */
7287
7369
  _collectTargets({ activeObject: t }) {
7288
- const e = yn({ activeObject: t }), n = [];
7370
+ const e = vn({ activeObject: t }), n = [];
7289
7371
  return this.canvas.forEachObject((s) => {
7290
- vn({ object: s, excluded: e }) || n.push(s);
7372
+ bn({ object: s, excluded: e }) || n.push(s);
7291
7373
  }), n;
7292
7374
  }
7293
7375
  /**
@@ -7310,7 +7392,7 @@ class Hs {
7310
7392
  };
7311
7393
  }
7312
7394
  }
7313
- const un = "#3D8BF4", fn = 1;
7395
+ const fn = "#3D8BF4", gn = 1;
7314
7396
  class zt {
7315
7397
  /**
7316
7398
  * Создаёт менеджер измерений и инициализирует события.
@@ -7451,8 +7533,8 @@ class zt {
7451
7533
  event: t,
7452
7534
  activeObject: e
7453
7535
  }) {
7454
- const { target: n } = t, s = yn({ activeObject: e });
7455
- return n && !vn({ object: n, excluded: s }) ? n : null;
7536
+ const { target: n } = t, s = vn({ activeObject: e });
7537
+ return n && !bn({ object: n, excluded: s }) ? n : null;
7456
7538
  }
7457
7539
  /**
7458
7540
  * Собирает вертикальные и горизонтальные направляющие расстояний.
@@ -7492,38 +7574,38 @@ class zt {
7492
7574
  right: h = 0,
7493
7575
  top: u = 0,
7494
7576
  bottom: f = 0,
7495
- centerY: g = 0
7496
- } = e, m = Math.max(a, u), p = Math.min(r, f), M = p >= m ? (m + p) / 2 : (c + g) / 2;
7577
+ centerY: p = 0
7578
+ } = e, m = Math.max(a, u), g = Math.min(r, f), M = g >= m ? (m + g) / 2 : (c + p) / 2;
7497
7579
  if (l >= i) {
7498
7580
  if (n) return s;
7499
- const T = l - i;
7500
- return T > 0 && s.push({
7581
+ const I = l - i;
7582
+ return I > 0 && s.push({
7501
7583
  type: "horizontal",
7502
7584
  axis: M,
7503
7585
  start: i,
7504
7586
  end: l,
7505
- distance: T
7587
+ distance: I
7506
7588
  }), s;
7507
7589
  }
7508
7590
  if (h <= o) {
7509
7591
  if (n) return s;
7510
- const T = o - h;
7511
- return T > 0 && s.push({
7592
+ const I = o - h;
7593
+ return I > 0 && s.push({
7512
7594
  type: "horizontal",
7513
7595
  axis: M,
7514
7596
  start: h,
7515
7597
  end: o,
7516
- distance: T
7598
+ distance: I
7517
7599
  }), s;
7518
7600
  }
7519
7601
  if (!n) return s;
7520
- const j = o < l, y = i > h, w = Math.min(o, l), I = Math.max(o, l), C = I - w;
7521
- C > 0 && !j && s.push({
7602
+ const C = o < l, y = i > h, w = Math.min(o, l), j = Math.max(o, l), T = j - w;
7603
+ T > 0 && !C && s.push({
7522
7604
  type: "horizontal",
7523
7605
  axis: M,
7524
7606
  start: w,
7525
- end: I,
7526
- distance: C
7607
+ end: j,
7608
+ distance: T
7527
7609
  });
7528
7610
  const b = Math.min(i, h), A = Math.max(i, h), S = A - b;
7529
7611
  return S > 0 && !y && s.push({
@@ -7553,38 +7635,38 @@ class zt {
7553
7635
  bottom: h = 0,
7554
7636
  left: u = 0,
7555
7637
  right: f = 0,
7556
- centerX: g = 0
7557
- } = e, m = Math.max(a, u), p = Math.min(r, f), M = p >= m ? (m + p) / 2 : (c + g) / 2;
7638
+ centerX: p = 0
7639
+ } = e, m = Math.max(a, u), g = Math.min(r, f), M = g >= m ? (m + g) / 2 : (c + p) / 2;
7558
7640
  if (l >= i) {
7559
7641
  if (n) return s;
7560
- const T = l - i;
7561
- return T > 0 && s.push({
7642
+ const I = l - i;
7643
+ return I > 0 && s.push({
7562
7644
  type: "vertical",
7563
7645
  axis: M,
7564
7646
  start: i,
7565
7647
  end: l,
7566
- distance: T
7648
+ distance: I
7567
7649
  }), s;
7568
7650
  }
7569
7651
  if (h <= o) {
7570
7652
  if (n) return s;
7571
- const T = o - h;
7572
- return T > 0 && s.push({
7653
+ const I = o - h;
7654
+ return I > 0 && s.push({
7573
7655
  type: "vertical",
7574
7656
  axis: M,
7575
7657
  start: h,
7576
7658
  end: o,
7577
- distance: T
7659
+ distance: I
7578
7660
  }), s;
7579
7661
  }
7580
7662
  if (!n) return s;
7581
- const j = o < l, y = i > h, w = Math.min(o, l), I = Math.max(o, l), C = I - w;
7582
- C > 0 && !j && s.push({
7663
+ const C = o < l, y = i > h, w = Math.min(o, l), j = Math.max(o, l), T = j - w;
7664
+ T > 0 && !C && s.push({
7583
7665
  type: "vertical",
7584
7666
  axis: M,
7585
7667
  start: w,
7586
- end: I,
7587
- distance: C
7668
+ end: j,
7669
+ distance: T
7588
7670
  });
7589
7671
  const b = Math.min(i, h), A = Math.max(i, h), S = A - b;
7590
7672
  return S > 0 && !y && s.push({
@@ -7620,19 +7702,19 @@ class zt {
7620
7702
  const { canvas: t } = this, e = t.getSelectionContext();
7621
7703
  if (!e) return;
7622
7704
  const { viewportTransform: n } = t, s = 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 / s : 0;
7623
- e.save(), Array.isArray(n) && e.transform(...n), e.lineWidth = fn / s, e.strokeStyle = un, e.setLineDash([]);
7705
+ e.save(), Array.isArray(n) && e.transform(...n), e.lineWidth = gn / s, e.strokeStyle = fn, e.setLineDash([]);
7624
7706
  for (const c of this.activeGuides) {
7625
- const { type: l, axis: h, start: u, end: f, distance: g } = c, m = Math.abs(f - u), p = u <= f ? -1 : 1, v = a ? p * (m / 2 + r) : 0, M = 0;
7626
- e.beginPath(), l === "vertical" ? (e.moveTo(h, u), e.lineTo(h, f)) : (e.moveTo(u, h), e.lineTo(f, h)), e.stroke(), Ee({
7707
+ const { type: l, axis: h, start: u, end: f, distance: p } = c, m = Math.abs(f - u), g = u <= f ? -1 : 1, v = a ? g * (m / 2 + r) : 0, M = 0;
7708
+ e.beginPath(), l === "vertical" ? (e.moveTo(h, u), e.lineTo(h, f)) : (e.moveTo(u, h), e.lineTo(f, h)), e.stroke(), _e({
7627
7709
  context: e,
7628
7710
  type: l,
7629
7711
  axis: h,
7630
7712
  start: u,
7631
7713
  end: f,
7632
- text: Math.round(g).toString(),
7714
+ text: Math.round(p).toString(),
7633
7715
  zoom: s,
7634
- color: un,
7635
- lineWidth: fn,
7716
+ color: fn,
7717
+ lineWidth: gn,
7636
7718
  offsetAlongAxis: v,
7637
7719
  offsetPerpendicular: M
7638
7720
  });
@@ -7658,14 +7740,14 @@ class zt {
7658
7740
  (e = t == null ? void 0 : t.showAfterTemporary) == null || e.call(t), this.isToolbarHidden = !1;
7659
7741
  }
7660
7742
  }
7661
- class Ne {
7743
+ class Pe {
7662
7744
  /**
7663
7745
  * Конструктор класса ImageEditor.
7664
7746
  * @param canvasId - идентификатор канваса, в котором будет создан редактор
7665
7747
  * @param options - опции и настройки редактора
7666
7748
  */
7667
7749
  constructor(t, e) {
7668
- this.options = e, this.containerId = t, this.editorId = `${t}-${$()}`, this.clipboard = null, this.init();
7750
+ this.options = e, this.containerId = t, this.editorId = `${t}-${tt()}`, this.clipboard = null, this.init();
7669
7751
  }
7670
7752
  /**
7671
7753
  * Инициализация редактора.
@@ -7688,17 +7770,17 @@ class Ne {
7688
7770
  showRotationAngle: l,
7689
7771
  _onReadyCallback: h
7690
7772
  } = this.options;
7691
- if (lt.apply(), this.canvas = new On(this.containerId, this.options), this.moduleLoader = new xn(), this.workerManager = new kn(), this.errorManager = new Jt({ editor: this }), this.historyManager = new K({ editor: this }), this.toolbar = new Jn({ editor: this }), this.transformManager = new rs({ editor: this }), this.zoomManager = new cs({ editor: this }), this.canvasManager = new as({ editor: this }), this.imageManager = new mt({ editor: this }), this.layerManager = new ue({ editor: this }), this.shapeManager = new ds({ editor: this }), this.interactionBlocker = new ls({ editor: this }), this.backgroundManager = new Bt({ editor: this }), this.clipboardManager = new hs({ editor: this }), this.objectLockManager = new fe({ editor: this }), this.groupingManager = new us({ editor: this }), this.selectionManager = new fs({ editor: this }), this.deletionManager = new ke({ editor: this }), this.panConstraintManager = new gs({ editor: this }), this.snappingManager = new Hs({ editor: this }), this.measurementManager = new zt({ editor: this }), this.fontManager = new Ce((u = this.options.fonts) != null ? u : []), this.textManager = new st({ editor: this }), this.templateManager = new Y({ editor: this }), l && (this.angleIndicator = new Re({ editor: this })), this._createMontageArea(), this._createClippingArea(), this.listeners = new Le({ editor: this, options: this.options }), this.canvasManager.setEditorContainerWidth(t), this.canvasManager.setEditorContainerHeight(e), this.canvasManager.setCanvasWrapperWidth(n), this.canvasManager.setCanvasWrapperHeight(s), this.canvasManager.setCanvasCSSWidth(o), this.canvasManager.setCanvasCSSHeight(i), this.canvasManager.updateCanvas(), this.zoomManager.calculateAndApplyDefaultZoom(), yield this.fontManager.loadFonts(), a != null && a.source) {
7773
+ if (lt.apply(), this.canvas = new En(this.containerId, this.options), this.moduleLoader = new Rn(), this.workerManager = new Nn(), this.errorManager = new Jt({ editor: this }), this.historyManager = new K({ editor: this }), this.toolbar = new Qn({ editor: this }), this.transformManager = new cs({ editor: this }), this.zoomManager = new ls({ editor: this }), this.canvasManager = new rs({ editor: this }), this.imageManager = new yt({ editor: this }), this.layerManager = new ue({ editor: this }), this.shapeManager = new hs({ editor: this }), this.interactionBlocker = new ds({ editor: this }), this.backgroundManager = new Bt({ editor: this }), this.clipboardManager = new us({ editor: this }), this.objectLockManager = new fe({ editor: this }), this.groupingManager = new fs({ editor: this }), this.selectionManager = new gs({ editor: this }), this.deletionManager = new ze({ editor: this }), this.panConstraintManager = new ps({ editor: this }), this.snappingManager = new pe({ editor: this }), this.measurementManager = new zt({ editor: this }), this.fontManager = new Te((u = this.options.fonts) != null ? u : []), this.textManager = new st({ editor: this }), this.templateManager = new H({ editor: this }), l && (this.angleIndicator = new Be({ editor: this })), this._createMontageArea(), this._createClippingArea(), this.listeners = new xe({ editor: this, options: this.options }), this.canvasManager.setEditorContainerWidth(t), this.canvasManager.setEditorContainerHeight(e), this.canvasManager.setCanvasWrapperWidth(n), this.canvasManager.setCanvasWrapperHeight(s), this.canvasManager.setCanvasCSSWidth(o), this.canvasManager.setCanvasCSSHeight(i), this.canvasManager.updateCanvas(), this.zoomManager.calculateAndApplyDefaultZoom(), yield this.fontManager.loadFonts(), a != null && a.source) {
7692
7774
  const f = a, {
7693
- source: g,
7775
+ source: p,
7694
7776
  scale: m = `image-${c}`,
7695
- withoutSave: p = !0
7777
+ withoutSave: g = !0
7696
7778
  } = f, v = Mt(f, [
7697
7779
  "source",
7698
7780
  "scale",
7699
7781
  "withoutSave"
7700
7782
  ]);
7701
- yield this.imageManager.importImage(L({ source: g, scale: m, withoutSave: p }, v));
7783
+ yield this.imageManager.importImage(x({ source: p, scale: m, withoutSave: g }, v));
7702
7784
  }
7703
7785
  r && this.historyManager.loadStateFromFullState(r), this.historyManager.saveState(), console.log("editor:ready"), this.canvas.fire("editor:ready", this), typeof h == "function" && h(this);
7704
7786
  });
@@ -7714,7 +7796,7 @@ class Ne {
7714
7796
  this.montageArea = this.shapeManager.addRectangle({
7715
7797
  width: t,
7716
7798
  height: e,
7717
- fill: Ne._createMosaicPattern(),
7799
+ fill: Pe._createMosaicPattern(),
7718
7800
  stroke: null,
7719
7801
  strokeWidth: 0,
7720
7802
  selectable: !1,
@@ -7765,13 +7847,13 @@ class Ne {
7765
7847
  const t = document.createElement("canvas");
7766
7848
  t.width = 20, t.height = 20;
7767
7849
  const e = t.getContext("2d");
7768
- return e.fillStyle = "#ddd", e.fillRect(0, 0, 40, 40), e.fillStyle = "#ccc", e.fillRect(0, 0, 10, 10), e.fillRect(10, 10, 10, 10), new En({
7850
+ return e.fillStyle = "#ddd", e.fillRect(0, 0, 40, 40), e.fillStyle = "#ccc", e.fillRect(0, 0, 10, 10), e.fillRect(10, 10, 10, 10), new Ln({
7769
7851
  source: t,
7770
7852
  repeat: "repeat"
7771
7853
  });
7772
7854
  }
7773
7855
  }
7774
- const k = [
7856
+ const P = [
7775
7857
  "U+0000-00FF",
7776
7858
  "U+0100-02BA",
7777
7859
  "U+02BB-02BC",
@@ -7801,7 +7883,7 @@ const k = [
7801
7883
  "U+A720-A7FF",
7802
7884
  "U+FEFF",
7803
7885
  "U+FFFD"
7804
- ].join(", "), N = [
7886
+ ].join(", "), F = [
7805
7887
  "U+0301",
7806
7888
  "U+0400-052F",
7807
7889
  "U+1C80-1C8A",
@@ -7827,7 +7909,7 @@ const k = [
7827
7909
  style: "normal",
7828
7910
  weight: "400",
7829
7911
  display: "swap",
7830
- unicodeRange: N
7912
+ unicodeRange: F
7831
7913
  }
7832
7914
  },
7833
7915
  {
@@ -7837,7 +7919,7 @@ const k = [
7837
7919
  style: "normal",
7838
7920
  weight: "400",
7839
7921
  display: "swap",
7840
- unicodeRange: k
7922
+ unicodeRange: P
7841
7923
  }
7842
7924
  },
7843
7925
  {
@@ -7847,7 +7929,7 @@ const k = [
7847
7929
  style: "normal",
7848
7930
  weight: "700",
7849
7931
  display: "swap",
7850
- unicodeRange: N
7932
+ unicodeRange: F
7851
7933
  }
7852
7934
  },
7853
7935
  {
@@ -7857,7 +7939,7 @@ const k = [
7857
7939
  style: "normal",
7858
7940
  weight: "700",
7859
7941
  display: "swap",
7860
- unicodeRange: k
7942
+ unicodeRange: P
7861
7943
  }
7862
7944
  },
7863
7945
  {
@@ -7867,7 +7949,7 @@ const k = [
7867
7949
  style: "normal",
7868
7950
  weight: "200 700",
7869
7951
  display: "swap",
7870
- unicodeRange: N
7952
+ unicodeRange: F
7871
7953
  }
7872
7954
  },
7873
7955
  {
@@ -7877,7 +7959,7 @@ const k = [
7877
7959
  style: "normal",
7878
7960
  weight: "200 700",
7879
7961
  display: "swap",
7880
- unicodeRange: k
7962
+ unicodeRange: P
7881
7963
  }
7882
7964
  },
7883
7965
  {
@@ -7887,7 +7969,7 @@ const k = [
7887
7969
  style: "normal",
7888
7970
  weight: "300 900",
7889
7971
  display: "swap",
7890
- unicodeRange: N
7972
+ unicodeRange: F
7891
7973
  }
7892
7974
  },
7893
7975
  {
@@ -7897,7 +7979,7 @@ const k = [
7897
7979
  style: "normal",
7898
7980
  weight: "300 900",
7899
7981
  display: "swap",
7900
- unicodeRange: k
7982
+ unicodeRange: P
7901
7983
  }
7902
7984
  },
7903
7985
  {
@@ -7907,7 +7989,7 @@ const k = [
7907
7989
  style: "normal",
7908
7990
  weight: "400 700",
7909
7991
  display: "swap",
7910
- unicodeRange: N
7992
+ unicodeRange: F
7911
7993
  }
7912
7994
  },
7913
7995
  {
@@ -7917,7 +7999,7 @@ const k = [
7917
7999
  style: "normal",
7918
8000
  weight: "400 700",
7919
8001
  display: "swap",
7920
- unicodeRange: k
8002
+ unicodeRange: P
7921
8003
  }
7922
8004
  },
7923
8005
  {
@@ -7927,7 +8009,7 @@ const k = [
7927
8009
  style: "normal",
7928
8010
  weight: "300 700",
7929
8011
  display: "swap",
7930
- unicodeRange: N
8012
+ unicodeRange: F
7931
8013
  }
7932
8014
  },
7933
8015
  {
@@ -7937,7 +8019,7 @@ const k = [
7937
8019
  style: "normal",
7938
8020
  weight: "300 700",
7939
8021
  display: "swap",
7940
- unicodeRange: k
8022
+ unicodeRange: P
7941
8023
  }
7942
8024
  },
7943
8025
  {
@@ -7947,7 +8029,7 @@ const k = [
7947
8029
  style: "normal",
7948
8030
  weight: "300 700",
7949
8031
  display: "swap",
7950
- unicodeRange: N
8032
+ unicodeRange: F
7951
8033
  }
7952
8034
  },
7953
8035
  {
@@ -7957,7 +8039,7 @@ const k = [
7957
8039
  style: "normal",
7958
8040
  weight: "300 700",
7959
8041
  display: "swap",
7960
- unicodeRange: k
8042
+ unicodeRange: P
7961
8043
  }
7962
8044
  },
7963
8045
  {
@@ -7967,7 +8049,7 @@ const k = [
7967
8049
  style: "normal",
7968
8050
  weight: "400",
7969
8051
  display: "swap",
7970
- unicodeRange: N
8052
+ unicodeRange: F
7971
8053
  }
7972
8054
  },
7973
8055
  {
@@ -7977,7 +8059,7 @@ const k = [
7977
8059
  style: "normal",
7978
8060
  weight: "400",
7979
8061
  display: "swap",
7980
- unicodeRange: k
8062
+ unicodeRange: P
7981
8063
  }
7982
8064
  },
7983
8065
  {
@@ -7987,7 +8069,7 @@ const k = [
7987
8069
  style: "normal",
7988
8070
  weight: "400 700",
7989
8071
  display: "swap",
7990
- unicodeRange: N
8072
+ unicodeRange: F
7991
8073
  }
7992
8074
  },
7993
8075
  {
@@ -7997,7 +8079,7 @@ const k = [
7997
8079
  style: "normal",
7998
8080
  weight: "400 700",
7999
8081
  display: "swap",
8000
- unicodeRange: k
8082
+ unicodeRange: P
8001
8083
  }
8002
8084
  },
8003
8085
  {
@@ -8007,7 +8089,7 @@ const k = [
8007
8089
  style: "normal",
8008
8090
  weight: "100 900",
8009
8091
  display: "swap",
8010
- unicodeRange: N
8092
+ unicodeRange: F
8011
8093
  }
8012
8094
  },
8013
8095
  {
@@ -8017,7 +8099,7 @@ const k = [
8017
8099
  style: "normal",
8018
8100
  weight: "100 900",
8019
8101
  display: "swap",
8020
- unicodeRange: k
8102
+ unicodeRange: P
8021
8103
  }
8022
8104
  },
8023
8105
  {
@@ -8027,7 +8109,7 @@ const k = [
8027
8109
  style: "normal",
8028
8110
  weight: "400",
8029
8111
  display: "swap",
8030
- unicodeRange: N
8112
+ unicodeRange: F
8031
8113
  }
8032
8114
  },
8033
8115
  {
@@ -8037,7 +8119,7 @@ const k = [
8037
8119
  style: "normal",
8038
8120
  weight: "400",
8039
8121
  display: "swap",
8040
- unicodeRange: k
8122
+ unicodeRange: P
8041
8123
  }
8042
8124
  },
8043
8125
  {
@@ -8047,7 +8129,7 @@ const k = [
8047
8129
  style: "normal",
8048
8130
  weight: "700",
8049
8131
  display: "swap",
8050
- unicodeRange: N
8132
+ unicodeRange: F
8051
8133
  }
8052
8134
  },
8053
8135
  {
@@ -8057,7 +8139,7 @@ const k = [
8057
8139
  style: "normal",
8058
8140
  weight: "700",
8059
8141
  display: "swap",
8060
- unicodeRange: k
8142
+ unicodeRange: P
8061
8143
  }
8062
8144
  },
8063
8145
  {
@@ -8067,7 +8149,7 @@ const k = [
8067
8149
  style: "normal",
8068
8150
  weight: "400 700",
8069
8151
  display: "swap",
8070
- unicodeRange: N
8152
+ unicodeRange: F
8071
8153
  }
8072
8154
  },
8073
8155
  {
@@ -8077,7 +8159,7 @@ const k = [
8077
8159
  style: "normal",
8078
8160
  weight: "400 700",
8079
8161
  display: "swap",
8080
- unicodeRange: k
8162
+ unicodeRange: P
8081
8163
  }
8082
8164
  },
8083
8165
  {
@@ -8087,7 +8169,7 @@ const k = [
8087
8169
  style: "normal",
8088
8170
  weight: "100 900",
8089
8171
  display: "swap",
8090
- unicodeRange: N
8172
+ unicodeRange: F
8091
8173
  }
8092
8174
  },
8093
8175
  {
@@ -8097,7 +8179,7 @@ const k = [
8097
8179
  style: "normal",
8098
8180
  weight: "100 900",
8099
8181
  display: "swap",
8100
- unicodeRange: k
8182
+ unicodeRange: P
8101
8183
  }
8102
8184
  },
8103
8185
  {
@@ -8107,7 +8189,7 @@ const k = [
8107
8189
  style: "normal",
8108
8190
  weight: "100",
8109
8191
  display: "swap",
8110
- unicodeRange: N
8192
+ unicodeRange: F
8111
8193
  }
8112
8194
  },
8113
8195
  {
@@ -8117,7 +8199,7 @@ const k = [
8117
8199
  style: "normal",
8118
8200
  weight: "100",
8119
8201
  display: "swap",
8120
- unicodeRange: k
8202
+ unicodeRange: P
8121
8203
  }
8122
8204
  },
8123
8205
  {
@@ -8127,7 +8209,7 @@ const k = [
8127
8209
  style: "normal",
8128
8210
  weight: "200",
8129
8211
  display: "swap",
8130
- unicodeRange: N
8212
+ unicodeRange: F
8131
8213
  }
8132
8214
  },
8133
8215
  {
@@ -8137,7 +8219,7 @@ const k = [
8137
8219
  style: "normal",
8138
8220
  weight: "200",
8139
8221
  display: "swap",
8140
- unicodeRange: k
8222
+ unicodeRange: P
8141
8223
  }
8142
8224
  },
8143
8225
  {
@@ -8147,7 +8229,7 @@ const k = [
8147
8229
  style: "normal",
8148
8230
  weight: "300",
8149
8231
  display: "swap",
8150
- unicodeRange: N
8232
+ unicodeRange: F
8151
8233
  }
8152
8234
  },
8153
8235
  {
@@ -8157,7 +8239,7 @@ const k = [
8157
8239
  style: "normal",
8158
8240
  weight: "300",
8159
8241
  display: "swap",
8160
- unicodeRange: k
8242
+ unicodeRange: P
8161
8243
  }
8162
8244
  },
8163
8245
  {
@@ -8167,7 +8249,7 @@ const k = [
8167
8249
  style: "normal",
8168
8250
  weight: "400",
8169
8251
  display: "swap",
8170
- unicodeRange: N
8252
+ unicodeRange: F
8171
8253
  }
8172
8254
  },
8173
8255
  {
@@ -8177,7 +8259,7 @@ const k = [
8177
8259
  style: "normal",
8178
8260
  weight: "400",
8179
8261
  display: "swap",
8180
- unicodeRange: k
8262
+ unicodeRange: P
8181
8263
  }
8182
8264
  },
8183
8265
  {
@@ -8187,7 +8269,7 @@ const k = [
8187
8269
  style: "normal",
8188
8270
  weight: "500",
8189
8271
  display: "swap",
8190
- unicodeRange: N
8272
+ unicodeRange: F
8191
8273
  }
8192
8274
  },
8193
8275
  {
@@ -8197,7 +8279,7 @@ const k = [
8197
8279
  style: "normal",
8198
8280
  weight: "500",
8199
8281
  display: "swap",
8200
- unicodeRange: k
8282
+ unicodeRange: P
8201
8283
  }
8202
8284
  },
8203
8285
  {
@@ -8207,7 +8289,7 @@ const k = [
8207
8289
  style: "normal",
8208
8290
  weight: "600",
8209
8291
  display: "swap",
8210
- unicodeRange: N
8292
+ unicodeRange: F
8211
8293
  }
8212
8294
  },
8213
8295
  {
@@ -8217,7 +8299,7 @@ const k = [
8217
8299
  style: "normal",
8218
8300
  weight: "600",
8219
8301
  display: "swap",
8220
- unicodeRange: k
8302
+ unicodeRange: P
8221
8303
  }
8222
8304
  },
8223
8305
  {
@@ -8227,7 +8309,7 @@ const k = [
8227
8309
  style: "normal",
8228
8310
  weight: "700",
8229
8311
  display: "swap",
8230
- unicodeRange: N
8312
+ unicodeRange: F
8231
8313
  }
8232
8314
  },
8233
8315
  {
@@ -8237,7 +8319,7 @@ const k = [
8237
8319
  style: "normal",
8238
8320
  weight: "700",
8239
8321
  display: "swap",
8240
- unicodeRange: k
8322
+ unicodeRange: P
8241
8323
  }
8242
8324
  },
8243
8325
  {
@@ -8247,7 +8329,7 @@ const k = [
8247
8329
  style: "normal",
8248
8330
  weight: "800",
8249
8331
  display: "swap",
8250
- unicodeRange: N
8332
+ unicodeRange: F
8251
8333
  }
8252
8334
  },
8253
8335
  {
@@ -8257,7 +8339,7 @@ const k = [
8257
8339
  style: "normal",
8258
8340
  weight: "800",
8259
8341
  display: "swap",
8260
- unicodeRange: k
8342
+ unicodeRange: P
8261
8343
  }
8262
8344
  },
8263
8345
  {
@@ -8267,7 +8349,7 @@ const k = [
8267
8349
  style: "normal",
8268
8350
  weight: "900",
8269
8351
  display: "swap",
8270
- unicodeRange: N
8352
+ unicodeRange: F
8271
8353
  }
8272
8354
  },
8273
8355
  {
@@ -8277,7 +8359,7 @@ const k = [
8277
8359
  style: "normal",
8278
8360
  weight: "900",
8279
8361
  display: "swap",
8280
- unicodeRange: k
8362
+ unicodeRange: P
8281
8363
  }
8282
8364
  },
8283
8365
  {
@@ -8287,7 +8369,7 @@ const k = [
8287
8369
  style: "normal",
8288
8370
  weight: "400",
8289
8371
  display: "swap",
8290
- unicodeRange: N
8372
+ unicodeRange: F
8291
8373
  }
8292
8374
  },
8293
8375
  {
@@ -8297,7 +8379,7 @@ const k = [
8297
8379
  style: "normal",
8298
8380
  weight: "400",
8299
8381
  display: "swap",
8300
- unicodeRange: k
8382
+ unicodeRange: P
8301
8383
  }
8302
8384
  },
8303
8385
  {
@@ -8307,7 +8389,7 @@ const k = [
8307
8389
  style: "normal",
8308
8390
  weight: "700",
8309
8391
  display: "swap",
8310
- unicodeRange: N
8392
+ unicodeRange: F
8311
8393
  }
8312
8394
  },
8313
8395
  {
@@ -8317,7 +8399,7 @@ const k = [
8317
8399
  style: "normal",
8318
8400
  weight: "700",
8319
8401
  display: "swap",
8320
- unicodeRange: k
8402
+ unicodeRange: P
8321
8403
  }
8322
8404
  },
8323
8405
  {
@@ -8327,7 +8409,7 @@ const k = [
8327
8409
  style: "normal",
8328
8410
  weight: "100 900",
8329
8411
  display: "swap",
8330
- unicodeRange: N
8412
+ unicodeRange: F
8331
8413
  }
8332
8414
  },
8333
8415
  {
@@ -8337,7 +8419,7 @@ const k = [
8337
8419
  style: "normal",
8338
8420
  weight: "100 900",
8339
8421
  display: "swap",
8340
- unicodeRange: k
8422
+ unicodeRange: P
8341
8423
  }
8342
8424
  },
8343
8425
  {
@@ -8347,7 +8429,7 @@ const k = [
8347
8429
  style: "normal",
8348
8430
  weight: "300 700",
8349
8431
  display: "swap",
8350
- unicodeRange: N
8432
+ unicodeRange: F
8351
8433
  }
8352
8434
  },
8353
8435
  {
@@ -8357,7 +8439,7 @@ const k = [
8357
8439
  style: "normal",
8358
8440
  weight: "300 700",
8359
8441
  display: "swap",
8360
- unicodeRange: k
8442
+ unicodeRange: P
8361
8443
  }
8362
8444
  },
8363
8445
  {
@@ -8367,7 +8449,7 @@ const k = [
8367
8449
  style: "normal",
8368
8450
  weight: "400",
8369
8451
  display: "swap",
8370
- unicodeRange: N
8452
+ unicodeRange: F
8371
8453
  }
8372
8454
  },
8373
8455
  {
@@ -8377,7 +8459,7 @@ const k = [
8377
8459
  style: "normal",
8378
8460
  weight: "400",
8379
8461
  display: "swap",
8380
- unicodeRange: k
8462
+ unicodeRange: P
8381
8463
  }
8382
8464
  },
8383
8465
  {
@@ -8387,7 +8469,7 @@ const k = [
8387
8469
  style: "normal",
8388
8470
  weight: "200 800",
8389
8471
  display: "swap",
8390
- unicodeRange: N
8472
+ unicodeRange: F
8391
8473
  }
8392
8474
  },
8393
8475
  {
@@ -8397,7 +8479,7 @@ const k = [
8397
8479
  style: "normal",
8398
8480
  weight: "200 800",
8399
8481
  display: "swap",
8400
- unicodeRange: k
8482
+ unicodeRange: P
8401
8483
  }
8402
8484
  },
8403
8485
  {
@@ -8407,7 +8489,7 @@ const k = [
8407
8489
  style: "normal",
8408
8490
  weight: "100 900",
8409
8491
  display: "swap",
8410
- unicodeRange: N
8492
+ unicodeRange: F
8411
8493
  }
8412
8494
  },
8413
8495
  {
@@ -8417,7 +8499,7 @@ const k = [
8417
8499
  style: "normal",
8418
8500
  weight: "100 900",
8419
8501
  display: "swap",
8420
- unicodeRange: k
8502
+ unicodeRange: P
8421
8503
  }
8422
8504
  },
8423
8505
  {
@@ -8427,7 +8509,7 @@ const k = [
8427
8509
  style: "normal",
8428
8510
  weight: "400",
8429
8511
  display: "swap",
8430
- unicodeRange: N
8512
+ unicodeRange: F
8431
8513
  }
8432
8514
  },
8433
8515
  {
@@ -8437,7 +8519,7 @@ const k = [
8437
8519
  style: "normal",
8438
8520
  weight: "400",
8439
8521
  display: "swap",
8440
- unicodeRange: k
8522
+ unicodeRange: P
8441
8523
  }
8442
8524
  },
8443
8525
  {
@@ -8447,7 +8529,7 @@ const k = [
8447
8529
  style: "normal",
8448
8530
  weight: "100 900",
8449
8531
  display: "swap",
8450
- unicodeRange: N
8532
+ unicodeRange: F
8451
8533
  }
8452
8534
  },
8453
8535
  {
@@ -8457,7 +8539,7 @@ const k = [
8457
8539
  style: "normal",
8458
8540
  weight: "100 900",
8459
8541
  display: "swap",
8460
- unicodeRange: k
8542
+ unicodeRange: P
8461
8543
  }
8462
8544
  },
8463
8545
  {
@@ -8467,7 +8549,7 @@ const k = [
8467
8549
  style: "normal",
8468
8550
  weight: "300 800",
8469
8551
  display: "swap",
8470
- unicodeRange: N
8552
+ unicodeRange: F
8471
8553
  }
8472
8554
  },
8473
8555
  {
@@ -8477,7 +8559,7 @@ const k = [
8477
8559
  style: "normal",
8478
8560
  weight: "300 800",
8479
8561
  display: "swap",
8480
- unicodeRange: k
8562
+ unicodeRange: P
8481
8563
  }
8482
8564
  },
8483
8565
  {
@@ -8487,7 +8569,7 @@ const k = [
8487
8569
  style: "normal",
8488
8570
  weight: "400",
8489
8571
  display: "swap",
8490
- unicodeRange: N
8572
+ unicodeRange: F
8491
8573
  }
8492
8574
  },
8493
8575
  {
@@ -8497,7 +8579,7 @@ const k = [
8497
8579
  style: "normal",
8498
8580
  weight: "400",
8499
8581
  display: "swap",
8500
- unicodeRange: k
8582
+ unicodeRange: P
8501
8583
  }
8502
8584
  },
8503
8585
  {
@@ -8507,7 +8589,7 @@ const k = [
8507
8589
  style: "normal",
8508
8590
  weight: "700",
8509
8591
  display: "swap",
8510
- unicodeRange: N
8592
+ unicodeRange: F
8511
8593
  }
8512
8594
  },
8513
8595
  {
@@ -8517,7 +8599,7 @@ const k = [
8517
8599
  style: "normal",
8518
8600
  weight: "700",
8519
8601
  display: "swap",
8520
- unicodeRange: k
8602
+ unicodeRange: P
8521
8603
  }
8522
8604
  },
8523
8605
  {
@@ -8527,7 +8609,7 @@ const k = [
8527
8609
  style: "normal",
8528
8610
  weight: "300 900",
8529
8611
  display: "swap",
8530
- unicodeRange: N
8612
+ unicodeRange: F
8531
8613
  }
8532
8614
  },
8533
8615
  {
@@ -8537,7 +8619,7 @@ const k = [
8537
8619
  style: "normal",
8538
8620
  weight: "300 900",
8539
8621
  display: "swap",
8540
- unicodeRange: k
8622
+ unicodeRange: P
8541
8623
  }
8542
8624
  },
8543
8625
  {
@@ -8547,7 +8629,7 @@ const k = [
8547
8629
  style: "normal",
8548
8630
  weight: "400",
8549
8631
  display: "swap",
8550
- unicodeRange: N
8632
+ unicodeRange: F
8551
8633
  }
8552
8634
  },
8553
8635
  {
@@ -8557,7 +8639,7 @@ const k = [
8557
8639
  style: "normal",
8558
8640
  weight: "400",
8559
8641
  display: "swap",
8560
- unicodeRange: k
8642
+ unicodeRange: P
8561
8643
  }
8562
8644
  },
8563
8645
  {
@@ -8567,7 +8649,7 @@ const k = [
8567
8649
  style: "normal",
8568
8650
  weight: "100 900",
8569
8651
  display: "swap",
8570
- unicodeRange: N
8652
+ unicodeRange: F
8571
8653
  }
8572
8654
  },
8573
8655
  {
@@ -8577,7 +8659,7 @@ const k = [
8577
8659
  style: "normal",
8578
8660
  weight: "100 900",
8579
8661
  display: "swap",
8580
- unicodeRange: k
8662
+ unicodeRange: P
8581
8663
  }
8582
8664
  },
8583
8665
  {
@@ -8587,7 +8669,7 @@ const k = [
8587
8669
  style: "normal",
8588
8670
  weight: "100 900",
8589
8671
  display: "swap",
8590
- unicodeRange: N
8672
+ unicodeRange: F
8591
8673
  }
8592
8674
  },
8593
8675
  {
@@ -8597,7 +8679,7 @@ const k = [
8597
8679
  style: "normal",
8598
8680
  weight: "100 900",
8599
8681
  display: "swap",
8600
- unicodeRange: k
8682
+ unicodeRange: P
8601
8683
  }
8602
8684
  }
8603
8685
  ], Gs = {
@@ -8695,13 +8777,13 @@ const k = [
8695
8777
  fonts: Zs
8696
8778
  };
8697
8779
  function Js(d, t = {}) {
8698
- const e = L(L({}, Gs), t), n = document.getElementById(d);
8780
+ const e = x(x({}, Gs), t), n = document.getElementById(d);
8699
8781
  if (!n)
8700
8782
  return Promise.reject(new Error(`Контейнер с ID "${d}" не найден.`));
8701
8783
  const s = document.createElement("canvas");
8702
8784
  return s.id = `${d}-canvas`, n.appendChild(s), e.editorContainer = n, new Promise((o) => {
8703
8785
  e._onReadyCallback = o;
8704
- const i = new Ne(s.id, e);
8786
+ const i = new Pe(s.id, e);
8705
8787
  window[d] = i;
8706
8788
  });
8707
8789
  }