@anu3ev/fabric-image-editor 0.5.33 → 0.5.34

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 +1023 -791
  2. package/package.json +1 -1
package/dist/main.js CHANGED
@@ -1,22 +1,22 @@
1
- var In = Object.defineProperty, Tn = Object.defineProperties;
2
- var On = Object.getOwnPropertyDescriptors;
3
- var ce = Object.getOwnPropertySymbols;
4
- var Ge = Object.prototype.hasOwnProperty, Ve = Object.prototype.propertyIsEnumerable;
5
- var Ze = (h, t, e) => t in h ? In(h, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : h[t] = e, F = (h, t) => {
1
+ var On = Object.defineProperty, Tn = Object.defineProperties;
2
+ var En = Object.getOwnPropertyDescriptors;
3
+ var le = Object.getOwnPropertySymbols;
4
+ var Ve = Object.prototype.hasOwnProperty, Xe = Object.prototype.propertyIsEnumerable;
5
+ var Ge = (h, t, e) => t in h ? On(h, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : h[t] = e, F = (h, t) => {
6
6
  for (var e in t || (t = {}))
7
- Ge.call(t, e) && Ze(h, e, t[e]);
8
- if (ce)
9
- for (var e of ce(t))
10
- Ve.call(t, e) && Ze(h, e, t[e]);
7
+ Ve.call(t, e) && Ge(h, e, t[e]);
8
+ if (le)
9
+ for (var e of le(t))
10
+ Xe.call(t, e) && Ge(h, e, t[e]);
11
11
  return h;
12
- }, Ot = (h, t) => Tn(h, On(t));
13
- var jt = (h, t) => {
12
+ }, Et = (h, t) => Tn(h, En(t));
13
+ var Ct = (h, t) => {
14
14
  var e = {};
15
15
  for (var n in h)
16
- Ge.call(h, n) && t.indexOf(n) < 0 && (e[n] = h[n]);
17
- if (h != null && ce)
18
- for (var n of ce(h))
19
- t.indexOf(n) < 0 && Ve.call(h, n) && (e[n] = h[n]);
16
+ Ve.call(h, n) && t.indexOf(n) < 0 && (e[n] = h[n]);
17
+ if (h != null && le)
18
+ for (var n of le(h))
19
+ t.indexOf(n) < 0 && Xe.call(h, n) && (e[n] = h[n]);
20
20
  return e;
21
21
  };
22
22
  var G = (h, t, e) => new Promise((n, s) => {
@@ -35,16 +35,16 @@ var G = (h, 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(h, t)).next());
37
37
  });
38
- import { ActiveSelection as X, Textbox as ct, util as vt, controlsUtils as Xe, InteractiveFabricObject as Ke, Point as lt, FitContentLayout as qe, loadSVGFromURL as En, FabricImage as Kt, Gradient as Je, Rect as Dn, Circle as Ln, Triangle as _n, Group as Nt, Color as xn, classRegistry as Qe, loadSVGFromString as Rn, Canvas as kn, Pattern as Bn } from "fabric";
39
- import { create as Nn } from "jsondiffpatch";
38
+ import { ActiveSelection as X, Textbox as ct, util as bt, controlsUtils as Ke, InteractiveFabricObject as qe, Point as lt, FitContentLayout as Je, loadSVGFromURL as _n, FabricImage as qt, Gradient as Qe, Rect as Ln, Circle as Dn, Triangle as xn, Group as Pt, Color as Rn, classRegistry as $e, loadSVGFromString as kn, Canvas as Bn, Pattern as Nn } from "fabric";
39
+ import { create as Pn } from "jsondiffpatch";
40
40
  import zn from "diff-match-patch";
41
- var Pn = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict", et = function() {
41
+ var Fn = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict", et = 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 += Pn[n[t] & 63];
43
+ e += Fn[n[t] & 63];
44
44
  return e;
45
45
  };
46
- const $e = 300;
47
- class Be {
46
+ const tn = 300;
47
+ class Ne {
48
48
  /**
49
49
  * Конструктор принимает редактор и опции.
50
50
  * @param params
@@ -52,7 +52,6 @@ class Be {
52
52
  * @param params.options — настройки редактора (см. defaults.js)
53
53
  * @param params.options.canvasDragging — включить перетаскивание канваса
54
54
  * @param params.options.mouseWheelZooming — включить зум колесом мыши
55
- * @param params.options.bringToFrontOnSelection — поднимать объект на передний план при выборе
56
55
  * @param params.options.copyObjectsByHotkey — копировать объекты по Ctrl+C
57
56
  * @param params.options.pasteImageFromClipboard — вставлять изображения и объекты из буфера обмена
58
57
  * @param params.options.undoRedoByHotKeys — отмена/повтор по Ctrl+Z/Ctrl+Y
@@ -62,7 +61,7 @@ class Be {
62
61
  * @param params.options.adaptCanvasToContainerOnResize — адаптировать канвас к размерам контейнера при изменении размеров окна
63
62
  */
64
63
  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 = Be.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();
64
+ this.isDragging = !1, this.lastMouseX = 0, this.lastMouseY = 0, this.isUndoRedoKeyPressed = !1, this.isSpacePressed = !1, this.savedSelection = [], this.canvasDragging = !1, this.mouseWheelZooming = !1, this.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 = Ne.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.handleResetObjectFitBound = this.handleResetObjectFit.bind(this), this.init();
66
65
  }
67
66
  /**
68
67
  * Инициализация всех обработчиков согласно опциям.
@@ -72,49 +71,14 @@ class Be {
72
71
  adaptCanvasToContainerOnResize: t,
73
72
  canvasDragging: e,
74
73
  mouseWheelZooming: n,
75
- bringToFrontOnSelection: s,
76
- copyObjectsByHotkey: o,
77
- pasteImageFromClipboard: i,
78
- undoRedoByHotKeys: a,
79
- selectAllByHotkey: r,
80
- deleteObjectsByHotkey: c,
81
- resetObjectFitByDoubleClick: l
74
+ copyObjectsByHotkey: s,
75
+ pasteImageFromClipboard: o,
76
+ undoRedoByHotKeys: i,
77
+ selectAllByHotkey: a,
78
+ deleteObjectsByHotkey: r,
79
+ resetObjectFitByDoubleClick: c
82
80
  } = this.options;
83
- e && (this.canvas.on("mouse:down", this.handleCanvasDragStartBound), this.canvas.on("mouse:move", this.handleCanvasDraggingBound), this.canvas.on("mouse:up", this.handleCanvasDragEndBound), document.addEventListener("keydown", this.handleSpaceKeyDownBound, { capture: !0 }), document.addEventListener("keyup", this.handleSpaceKeyUpBound, { capture: !0 })), n && this.canvas.on("mouse:wheel", this.handleMouseWheelZoomBound), s && (this.canvas.on("selection:created", this.handleBringToFrontBound), this.canvas.on("selection:updated", this.handleBringToFrontBound)), l && this.canvas.on("mouse:dblclick", this.handleResetObjectFitBound), t && window.addEventListener("resize", this.handleContainerResizeBound, { capture: !0 }), o && document.addEventListener("keydown", this.handleCopyEventBound, { capture: !0 }), i && document.addEventListener("paste", this.handlePasteEventBound, { capture: !0 }), a && (document.addEventListener("keydown", this.handleUndoRedoEventBound, { capture: !0 }), document.addEventListener("keyup", this.handleUndoRedoKeyUpBound, { capture: !0 })), r && document.addEventListener("keydown", this.handleSelectAllEventBound, { capture: !0 }), c && document.addEventListener("keydown", this.handleDeleteObjectsEventBound, { capture: !0 }), this.canvas.on("object:modified", this.handleObjectModifiedHistoryBound), this.canvas.on("object:rotating", this.handleObjectRotatingHistoryBound), this.canvas.on("object:added", this.handleObjectAddedHistoryBound), this.canvas.on("object:removed", this.handleObjectRemovedHistoryBound), this.canvas.on("object:moving", this.handleObjectTransformStartBound), this.canvas.on("object:scaling", this.handleObjectTransformStartBound), this.canvas.on("object:rotating", this.handleObjectTransformStartBound), this.canvas.on("object:skewing", this.handleObjectTransformStartBound), this.canvas.on("object:resizing", this.handleObjectTransformStartBound), this.canvas.on("object:modified", this.handleObjectTransformEndBound), this.canvas.on("object:added", this.handleOverlayUpdateBound), this.canvas.on("selection:created", this.handleOverlayUpdateBound), this.canvas.on("selection:created", this.handleLockedSelectionBound), this.canvas.on("selection:updated", this.handleLockedSelectionBound), this.canvas.on("object:added", this.handleBackgroundUpdateBound), this.canvas.on("selection:created", this.handleBackgroundUpdateBound);
84
- }
85
- /**
86
- * При массовом выделении объектов удаляем из него залоченные.
87
- * @param params - параметры события
88
- * @param params.selected - массив выделенных объектов
89
- * @param params.e - событие указателя (опционально)
90
- */
91
- _filterLockedSelection({ selected: t, e }) {
92
- if (!(t != null && t.length) || !(e instanceof MouseEvent) || t.length === 1) return;
93
- const { lockedObjects: n, unlockedObjects: s } = t.reduce(
94
- (i, a) => a.locked ? (i.lockedObjects.push(a), i) : (i.unlockedObjects.push(a), i),
95
- { lockedObjects: [], unlockedObjects: [] }
96
- );
97
- if (n.length === 0) return;
98
- if (s.length > 0) {
99
- if (s.length === 1)
100
- this.canvas.setActiveObject(s[0]);
101
- else {
102
- const i = new X(s, {
103
- canvas: this.canvas
104
- });
105
- this.canvas.setActiveObject(i);
106
- }
107
- this.canvas.requestRenderAll();
108
- return;
109
- }
110
- const o = new X(t, {
111
- canvas: this.canvas
112
- });
113
- this.editor.objectLockManager.lockObject({
114
- object: o,
115
- skipInnerObjects: !0,
116
- withoutSave: !0
117
- }), this.canvas.setActiveObject(o), this.canvas.requestRenderAll();
81
+ e && (this.canvas.on("mouse:down", this.handleCanvasDragStartBound), this.canvas.on("mouse:move", this.handleCanvasDraggingBound), this.canvas.on("mouse:up", this.handleCanvasDragEndBound), document.addEventListener("keydown", this.handleSpaceKeyDownBound, { capture: !0 }), document.addEventListener("keyup", this.handleSpaceKeyUpBound, { capture: !0 })), n && this.canvas.on("mouse:wheel", this.handleMouseWheelZoomBound), c && this.canvas.on("mouse:dblclick", this.handleResetObjectFitBound), t && window.addEventListener("resize", this.handleContainerResizeBound, { capture: !0 }), s && document.addEventListener("keydown", this.handleCopyEventBound, { capture: !0 }), o && document.addEventListener("paste", this.handlePasteEventBound, { capture: !0 }), i && (document.addEventListener("keydown", this.handleUndoRedoEventBound, { capture: !0 }), document.addEventListener("keyup", this.handleUndoRedoKeyUpBound, { capture: !0 })), a && document.addEventListener("keydown", this.handleSelectAllEventBound, { capture: !0 }), r && document.addEventListener("keydown", this.handleDeleteObjectsEventBound, { capture: !0 }), this.canvas.on("object:modified", this.handleObjectModifiedHistoryBound), this.canvas.on("object:rotating", this.handleObjectRotatingHistoryBound), this.canvas.on("object:added", this.handleObjectAddedHistoryBound), this.canvas.on("object:removed", this.handleObjectRemovedHistoryBound), this.canvas.on("object:moving", this.handleObjectTransformStartBound), this.canvas.on("object:scaling", this.handleObjectTransformStartBound), this.canvas.on("object:rotating", this.handleObjectTransformStartBound), this.canvas.on("object:skewing", this.handleObjectTransformStartBound), this.canvas.on("object:resizing", this.handleObjectTransformStartBound), this.canvas.on("object:modified", this.handleObjectTransformEndBound), this.canvas.on("object:added", this.handleOverlayUpdateBound), this.canvas.on("selection:created", this.handleOverlayUpdateBound), this.canvas.on("object:added", this.handleBackgroundUpdateBound), this.canvas.on("selection:created", this.handleBackgroundUpdateBound);
118
82
  }
119
83
  /**
120
84
  * Обработчики для сохранения состояния редактора в истории.
@@ -123,14 +87,14 @@ class Be {
123
87
  handleObjectModifiedHistory() {
124
88
  const { historyManager: t, textManager: e } = this.editor;
125
89
  t.skipHistory || e.isTextEditingActive || t.scheduleSaveState({
126
- delayMs: $e,
90
+ delayMs: tn,
127
91
  reason: "object-modified"
128
92
  });
129
93
  }
130
94
  handleObjectRotatingHistory() {
131
95
  const { historyManager: t, textManager: e } = this.editor;
132
96
  t.skipHistory || e.isTextEditingActive || t.scheduleSaveState({
133
- delayMs: $e,
97
+ delayMs: tn,
134
98
  reason: "object-rotating"
135
99
  });
136
100
  }
@@ -354,23 +318,13 @@ class Be {
354
318
  const e = this._calculateAdaptiveZoomStep(t.deltaY);
355
319
  this.editor.zoomManager.handleMouseWheelZoom(e, t), t.preventDefault(), t.stopPropagation();
356
320
  }
357
- /**
358
- * Обработчик, поднимающий выделенные объекты на передний план.
359
- * @param event - объект события выделения
360
- * @param event.selected - массив выбранных объектов
361
- */
362
- handleBringToFront({ selected: t }) {
363
- t != null && t.length && t.forEach((e) => {
364
- this.editor.layerManager.bringToFront(e);
365
- });
366
- }
367
321
  /**
368
322
  * Обработчик сброса объекта по двойному клику.
369
323
  * @param options - объект события fabric
370
324
  */
371
325
  handleResetObjectFit(t) {
372
- const e = t == null ? void 0 : t.target;
373
- !e || e instanceof ct || this.editor.transformManager.resetObject({ object: e });
326
+ const { target: e, e: n } = t;
327
+ n && (n.ctrlKey || n.metaKey) || !e || e instanceof ct || this.editor.transformManager.resetObject({ object: e });
374
328
  }
375
329
  /**
376
330
  * Проверяет, должно ли событие клавиатуры быть проигнорировано
@@ -414,7 +368,7 @@ class Be {
414
368
  * Метод для удаления всех слушателей
415
369
  */
416
370
  destroy() {
417
- window.removeEventListener("resize", this.handleContainerResizeBound, { capture: !0 }), document.removeEventListener("keydown", this.handleCopyEventBound, { capture: !0 }), document.removeEventListener("paste", this.handlePasteEventBound, { capture: !0 }), document.removeEventListener("keydown", this.handleUndoRedoEventBound, { capture: !0 }), document.removeEventListener("keyup", this.handleUndoRedoKeyUpBound, { capture: !0 }), document.removeEventListener("keydown", this.handleSelectAllEventBound, { capture: !0 }), document.removeEventListener("keydown", this.handleDeleteObjectsEventBound, { capture: !0 }), this.options.canvasDragging && (this.canvas.off("mouse:down", this.handleCanvasDragStartBound), this.canvas.off("mouse:move", this.handleCanvasDraggingBound), this.canvas.off("mouse:up", this.handleCanvasDragEndBound), document.removeEventListener("keydown", this.handleSpaceKeyDownBound, { capture: !0 }), document.removeEventListener("keyup", this.handleSpaceKeyUpBound, { capture: !0 })), this.options.mouseWheelZooming && this.canvas.off("mouse:wheel", this.handleMouseWheelZoomBound), this.options.bringToFrontOnSelection && (this.canvas.off("selection:created", this.handleBringToFrontBound), this.canvas.off("selection:updated", this.handleBringToFrontBound)), this.options.resetObjectFitByDoubleClick && this.canvas.off("mouse:dblclick", this.handleResetObjectFitBound), this.canvas.off("object:modified", this.handleObjectModifiedHistoryBound), this.canvas.off("object:rotating", this.handleObjectRotatingHistoryBound), this.canvas.off("object:added", this.handleObjectAddedHistoryBound), this.canvas.off("object:removed", this.handleObjectRemovedHistoryBound), this.canvas.off("object:moving", this.handleObjectTransformStartBound), this.canvas.off("object:scaling", this.handleObjectTransformStartBound), this.canvas.off("object:rotating", this.handleObjectTransformStartBound), this.canvas.off("object:skewing", this.handleObjectTransformStartBound), this.canvas.off("object:resizing", this.handleObjectTransformStartBound), this.canvas.off("object:modified", this.handleObjectTransformEndBound), this.canvas.off("object:added", this.handleOverlayUpdateBound), this.canvas.off("selection:created", this.handleOverlayUpdateBound), this.canvas.off("object:added", this.handleBackgroundUpdateBound), this.canvas.off("selection:created", this.handleBackgroundUpdateBound), this.canvas.off("selection:created", this.handleLockedSelectionBound), this.canvas.off("selection:updated", this.handleLockedSelectionBound);
371
+ window.removeEventListener("resize", this.handleContainerResizeBound, { capture: !0 }), document.removeEventListener("keydown", this.handleCopyEventBound, { capture: !0 }), document.removeEventListener("paste", this.handlePasteEventBound, { capture: !0 }), document.removeEventListener("keydown", this.handleUndoRedoEventBound, { capture: !0 }), document.removeEventListener("keyup", this.handleUndoRedoKeyUpBound, { capture: !0 }), document.removeEventListener("keydown", this.handleSelectAllEventBound, { capture: !0 }), document.removeEventListener("keydown", this.handleDeleteObjectsEventBound, { capture: !0 }), this.options.canvasDragging && (this.canvas.off("mouse:down", this.handleCanvasDragStartBound), this.canvas.off("mouse:move", this.handleCanvasDraggingBound), this.canvas.off("mouse:up", this.handleCanvasDragEndBound), document.removeEventListener("keydown", this.handleSpaceKeyDownBound, { capture: !0 }), document.removeEventListener("keyup", this.handleSpaceKeyUpBound, { capture: !0 })), this.options.mouseWheelZooming && this.canvas.off("mouse:wheel", this.handleMouseWheelZoomBound), this.options.resetObjectFitByDoubleClick && this.canvas.off("mouse:dblclick", this.handleResetObjectFitBound), this.canvas.off("object:modified", this.handleObjectModifiedHistoryBound), this.canvas.off("object:rotating", this.handleObjectRotatingHistoryBound), this.canvas.off("object:added", this.handleObjectAddedHistoryBound), this.canvas.off("object:removed", this.handleObjectRemovedHistoryBound), this.canvas.off("object:moving", this.handleObjectTransformStartBound), this.canvas.off("object:scaling", this.handleObjectTransformStartBound), this.canvas.off("object:rotating", this.handleObjectTransformStartBound), this.canvas.off("object:skewing", this.handleObjectTransformStartBound), this.canvas.off("object:resizing", this.handleObjectTransformStartBound), this.canvas.off("object:modified", this.handleObjectTransformEndBound), this.canvas.off("object:added", this.handleOverlayUpdateBound), this.canvas.off("selection:created", this.handleOverlayUpdateBound), this.canvas.off("object:added", this.handleBackgroundUpdateBound), this.canvas.off("selection:created", this.handleBackgroundUpdateBound);
418
372
  }
419
373
  /**
420
374
  * Дебаунс для снижения частоты вызова функции.
@@ -431,7 +385,7 @@ class Be {
431
385
  };
432
386
  }
433
387
  }
434
- class Fn {
388
+ class Wn {
435
389
  /**
436
390
  * Класс для динамической загрузки внешних модулей.
437
391
  */
@@ -449,7 +403,7 @@ class Fn {
449
403
  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
404
  }
451
405
  }
452
- function Wn(h) {
406
+ function Un(h) {
453
407
  return new Worker(
454
408
  "" + new URL("assets/worker-2TM2HcqM.js", import.meta.url).href,
455
409
  {
@@ -457,13 +411,13 @@ function Wn(h) {
457
411
  }
458
412
  );
459
413
  }
460
- class Un {
414
+ class Yn {
461
415
  /**
462
416
  * @param scriptUrl — URL скрипта воркера.
463
417
  * По-умолчанию использует DefaultWorker из соседнего файла
464
418
  */
465
419
  constructor(t) {
466
- t ? this.worker = new Worker(t, { type: "module" }) : this.worker = new Wn(), this._callbacks = /* @__PURE__ */ new Map(), this.worker.onmessage = this._handleMessage.bind(this);
420
+ t ? this.worker = new Worker(t, { type: "module" }) : this.worker = new Un(), this._callbacks = /* @__PURE__ */ new Map(), this.worker.onmessage = this._handleMessage.bind(this);
467
421
  }
468
422
  /**
469
423
  * Обработчик сообщений от воркера
@@ -503,92 +457,92 @@ class Un {
503
457
  this.worker.terminate();
504
458
  }
505
459
  }
506
- const St = 12, Yn = 2, Ie = 8, Te = 20, Hn = 100, Oe = 20, Ee = 8, Zn = 100, ge = 32, Ne = 1, Gn = "#2B2D33", ze = "#3D8BF4", Pe = "#FFFFFF";
507
- function le(h, t, e, n, s) {
508
- const o = St, i = Yn;
509
- h.save(), h.translate(t, e), h.rotate(vt.degreesToRadians(s.angle)), h.fillStyle = Pe, h.strokeStyle = ze, h.lineWidth = Ne, h.beginPath(), h.roundRect(-o / 2, -o / 2, o, o, i), h.fill(), h.stroke(), h.restore();
510
- }
511
- function tn(h, t, e, n, s) {
512
- const o = Ie, i = Te, a = Hn;
513
- h.save(), h.translate(t, e), h.rotate(vt.degreesToRadians(s.angle)), h.fillStyle = Pe, h.strokeStyle = ze, h.lineWidth = Ne, h.beginPath(), h.roundRect(-o / 2, -i / 2, o, i, a), h.fill(), h.stroke(), h.restore();
460
+ const wt = 12, Hn = 2, Oe = 8, Te = 20, Zn = 100, Ee = 20, _e = 8, Gn = 100, pe = 32, Pe = 1, Vn = "#2B2D33", ze = "#3D8BF4", Fe = "#FFFFFF";
461
+ function de(h, t, e, n, s) {
462
+ const o = wt, i = Hn;
463
+ h.save(), h.translate(t, e), h.rotate(bt.degreesToRadians(s.angle)), h.fillStyle = Fe, h.strokeStyle = ze, h.lineWidth = Pe, h.beginPath(), h.roundRect(-o / 2, -o / 2, o, o, i), h.fill(), h.stroke(), h.restore();
514
464
  }
515
465
  function en(h, t, e, n, s) {
516
- const o = Oe, i = Ee, a = Zn;
517
- h.save(), h.translate(t, e), h.rotate(vt.degreesToRadians(s.angle)), h.fillStyle = Pe, h.strokeStyle = ze, h.lineWidth = Ne, h.beginPath(), h.roundRect(-o / 2, -i / 2, o, i, a), h.fill(), h.stroke(), h.restore();
466
+ const o = Oe, i = Te, a = Zn;
467
+ h.save(), h.translate(t, e), h.rotate(bt.degreesToRadians(s.angle)), h.fillStyle = Fe, h.strokeStyle = ze, h.lineWidth = Pe, h.beginPath(), h.roundRect(-o / 2, -i / 2, o, i, a), h.fill(), h.stroke(), h.restore();
518
468
  }
519
- const Vn = "", bn = new Image();
520
- bn.src = Vn;
521
- function Xn(h, t, e, n, s) {
522
- const i = ge / 2;
523
- h.save(), h.translate(t, e), h.rotate(vt.degreesToRadians(s.angle)), h.fillStyle = Gn, h.beginPath(), h.arc(0, 0, i, 0, 2 * Math.PI), h.fill(), h.drawImage(bn, -i / 2, -i / 2, i, i), h.restore();
469
+ function nn(h, t, e, n, s) {
470
+ const o = Ee, i = _e, a = Gn;
471
+ h.save(), h.translate(t, e), h.rotate(bt.degreesToRadians(s.angle)), h.fillStyle = Fe, h.strokeStyle = ze, h.lineWidth = Pe, h.beginPath(), h.roundRect(-o / 2, -i / 2, o, i, a), h.fill(), h.stroke(), h.restore();
524
472
  }
525
- const Kn = {
473
+ const Xn = "", Mn = new Image();
474
+ Mn.src = Xn;
475
+ function Kn(h, t, e, n, s) {
476
+ const i = pe / 2;
477
+ h.save(), h.translate(t, e), h.rotate(bt.degreesToRadians(s.angle)), h.fillStyle = Vn, h.beginPath(), h.arc(0, 0, i, 0, 2 * Math.PI), h.fill(), h.drawImage(Mn, -i / 2, -i / 2, i, i), h.restore();
478
+ }
479
+ const qn = {
526
480
  // Угловые точки
527
481
  tl: {
528
- render: le,
529
- sizeX: St,
530
- sizeY: St,
482
+ render: de,
483
+ sizeX: wt,
484
+ sizeY: wt,
531
485
  offsetX: 0,
532
486
  offsetY: 0
533
487
  },
534
488
  tr: {
535
- render: le,
536
- sizeX: St,
537
- sizeY: St,
489
+ render: de,
490
+ sizeX: wt,
491
+ sizeY: wt,
538
492
  offsetX: 0,
539
493
  offsetY: 0
540
494
  },
541
495
  bl: {
542
- render: le,
543
- sizeX: St,
544
- sizeY: St,
496
+ render: de,
497
+ sizeX: wt,
498
+ sizeY: wt,
545
499
  offsetX: 0,
546
500
  offsetY: 0
547
501
  },
548
502
  br: {
549
- render: le,
550
- sizeX: St,
551
- sizeY: St,
503
+ render: de,
504
+ sizeX: wt,
505
+ sizeY: wt,
552
506
  offsetX: 0,
553
507
  offsetY: 0
554
508
  },
555
509
  // Середина вертикалей
556
510
  ml: {
557
- render: tn,
558
- sizeX: Ie,
511
+ render: en,
512
+ sizeX: Oe,
559
513
  sizeY: Te,
560
514
  offsetX: 0,
561
515
  offsetY: 0
562
516
  },
563
517
  mr: {
564
- render: tn,
565
- sizeX: Ie,
518
+ render: en,
519
+ sizeX: Oe,
566
520
  sizeY: Te,
567
521
  offsetX: 0,
568
522
  offsetY: 0
569
523
  },
570
524
  // Середина горизонталей
571
525
  mt: {
572
- render: en,
573
- sizeX: Oe,
574
- sizeY: Ee,
526
+ render: nn,
527
+ sizeX: Ee,
528
+ sizeY: _e,
575
529
  offsetX: 0,
576
530
  offsetY: 0
577
531
  },
578
532
  mb: {
579
- render: en,
580
- sizeX: Oe,
581
- sizeY: Ee,
533
+ render: nn,
534
+ sizeX: Ee,
535
+ sizeY: _e,
582
536
  offsetX: 0,
583
537
  offsetY: 0
584
538
  },
585
539
  // Специальный «rotate» контрол
586
540
  mtr: {
587
- render: Xn,
588
- sizeX: ge,
589
- sizeY: ge,
541
+ render: Kn,
542
+ sizeX: pe,
543
+ sizeY: pe,
590
544
  offsetX: 0,
591
- offsetY: -ge
545
+ offsetY: -pe
592
546
  }
593
547
  };
594
548
  class ut {
@@ -607,7 +561,7 @@ class ut {
607
561
  * Применяет конфигурацию контролов к набору по ключам из DEFAULT_CONTROLS.
608
562
  */
609
563
  static applyControlOverrides(t) {
610
- Object.entries(Kn).forEach(([e, n]) => {
564
+ Object.entries(qn).forEach(([e, n]) => {
611
565
  const s = t[e];
612
566
  s && (Object.assign(s, n), e === "mtr" && (s.cursorStyle = "grab", s.mouseDownHandler = (o, i, a, r) => {
613
567
  var l;
@@ -620,10 +574,10 @@ class ut {
620
574
  * Регистрирует контролы и настройки поведения выделений.
621
575
  */
622
576
  static apply() {
623
- const t = Xe.createObjectDefaultControls();
624
- ut.applyControlOverrides(t), Ke.ownDefaults.controls = t;
625
- const e = Xe.createTextboxDefaultControls();
626
- ut.applyControlOverrides(e), e.mt && (e.mt.visible = !1), e.mb && (e.mb.visible = !1), ut.wrapWidthControl(e.ml), ut.wrapWidthControl(e.mr), ct.ownDefaults.controls = e, ut.patchActiveSelectionBounds(), Ke.ownDefaults.snapAngle = 1;
577
+ const t = Ke.createObjectDefaultControls();
578
+ ut.applyControlOverrides(t), qe.ownDefaults.controls = t;
579
+ const e = Ke.createTextboxDefaultControls();
580
+ ut.applyControlOverrides(e), e.mt && (e.mt.visible = !1), e.mb && (e.mb.visible = !1), ut.wrapWidthControl(e.ml), ut.wrapWidthControl(e.mr), ct.ownDefaults.controls = e, ut.patchActiveSelectionBounds(), qe.ownDefaults.snapAngle = 1;
627
581
  }
628
582
  /**
629
583
  * Обновляет алгоритм расчёта границ ActiveSelection, чтобы учитывать фон и отступы текстовых объектов.
@@ -670,8 +624,8 @@ class ut {
670
624
  height: f
671
625
  }), this.setPositionByOrigin(g, "center", "center"), this.setCoords(), a;
672
626
  };
673
- const s = qe.prototype.calcBoundingBox;
674
- qe.prototype.calcBoundingBox = function(o, i) {
627
+ const s = Je.prototype.calcBoundingBox;
628
+ Je.prototype.calcBoundingBox = function(o, i) {
675
629
  const { target: a, type: r, overrides: c } = i;
676
630
  if (r === "imperative" && c)
677
631
  return c;
@@ -894,8 +848,8 @@ V.registeredFontKeys = /* @__PURE__ */ new Set(), V.descriptorDefaults = {
894
848
  featureSettings: "normal",
895
849
  display: "auto"
896
850
  };
897
- let De = V;
898
- const qn = "", Jn = "", Qn = "", $n = "", ts = "", es = "", ns = "", ss = "", qt = {
851
+ let Le = V;
852
+ const Jn = "", Qn = "", $n = "", ts = "", es = "", ns = "", ss = "", is = "", Jt = {
899
853
  style: {
900
854
  position: "absolute",
901
855
  display: "none",
@@ -962,14 +916,14 @@ const qn = "
962
916
  ],
963
917
  offsetTop: 50,
964
918
  icons: {
965
- copyPaste: qn,
966
- delete: ss,
967
- lock: Jn,
968
- unlock: Qn,
969
- bringToFront: es,
970
- sendToBack: ns,
971
- bringForward: $n,
972
- sendBackwards: ts
919
+ copyPaste: Jn,
920
+ delete: is,
921
+ lock: Qn,
922
+ unlock: $n,
923
+ bringToFront: ns,
924
+ sendToBack: ss,
925
+ bringForward: ts,
926
+ sendBackwards: es
973
927
  },
974
928
  handlers: {
975
929
  copyPaste: (h) => G(null, null, function* () {
@@ -998,18 +952,18 @@ const qn = "
998
952
  }
999
953
  }
1000
954
  };
1001
- class is {
955
+ class os {
1002
956
  constructor({ editor: t }) {
1003
957
  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
958
  }
1005
959
  _initToolbar() {
1006
960
  if (!this.options.showToolbar) return;
1007
961
  const t = this.options.toolbar || {};
1008
- this.config = Ot(F(F({}, qt), t), {
1009
- style: F(F({}, qt.style), t.style || {}),
1010
- btnStyle: F(F({}, qt.btnStyle), t.btnStyle || {}),
1011
- icons: F(F({}, qt.icons), t.icons || {}),
1012
- handlers: F(F({}, qt.handlers), t.handlers || {})
962
+ this.config = Et(F(F({}, Jt), t), {
963
+ style: F(F({}, Jt.style), t.style || {}),
964
+ btnStyle: F(F({}, Jt.btnStyle), t.btnStyle || {}),
965
+ icons: F(F({}, Jt.icons), t.icons || {}),
966
+ handlers: F(F({}, Jt.handlers), t.handlers || {})
1013
967
  }), 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
968
  this.el.style.display = "none";
1015
969
  }, this._createDOM(), this._bindEvents();
@@ -1126,7 +1080,7 @@ class is {
1126
1080
  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
1081
  }
1128
1082
  }
1129
- const os = {
1083
+ const as = {
1130
1084
  position: "absolute",
1131
1085
  display: "none",
1132
1086
  background: "#2B2D33",
@@ -1140,8 +1094,8 @@ const os = {
1140
1094
  "pointer-events": "none",
1141
1095
  "white-space": "nowrap",
1142
1096
  "box-shadow": "0 2px 8px rgba(0, 0, 0, 0.2)"
1143
- }, nn = 16, sn = 16, as = "fabric-editor-angle-indicator";
1144
- class Fe {
1097
+ }, sn = 16, on = 16, rs = "fabric-editor-angle-indicator";
1098
+ class We {
1145
1099
  constructor({ editor: t }) {
1146
1100
  this.isActive = !1, this.currentAngle = 0, this.editor = t, this.canvas = t.canvas, this.options = t.options, this._createDOM(), this._bindEvents();
1147
1101
  }
@@ -1149,7 +1103,7 @@ class Fe {
1149
1103
  * Создание DOM-элемента индикатора
1150
1104
  */
1151
1105
  _createDOM() {
1152
- this.el = document.createElement("div"), this.el.className = as, Object.entries(os).forEach(([t, e]) => {
1106
+ this.el = document.createElement("div"), this.el.className = rs, Object.entries(as).forEach(([t, e]) => {
1153
1107
  this.el.style.setProperty(t, e);
1154
1108
  }), this.canvas.wrapperEl.appendChild(this.el);
1155
1109
  }
@@ -1169,7 +1123,7 @@ class Fe {
1169
1123
  return;
1170
1124
  }
1171
1125
  const n = e.angle || 0;
1172
- this.currentAngle = Fe._normalizeAngle(n), this.el.textContent = `${this.currentAngle}°`, this._positionIndicator(t.e), this.isActive || this._showIndicator();
1126
+ this.currentAngle = We._normalizeAngle(n), this.el.textContent = `${this.currentAngle}°`, this._positionIndicator(t.e), this.isActive || this._showIndicator();
1173
1127
  }
1174
1128
  /**
1175
1129
  * Обработчик отпускания кнопки мыши
@@ -1200,9 +1154,9 @@ class Fe {
1200
1154
  */
1201
1155
  _positionIndicator(t) {
1202
1156
  const e = this.canvas.wrapperEl.getBoundingClientRect();
1203
- let n = t.clientX - e.left + nn, s = t.clientY - e.top + sn;
1157
+ let n = t.clientX - e.left + sn, s = t.clientY - e.top + on;
1204
1158
  const o = this.el.getBoundingClientRect(), i = o.width, a = o.height;
1205
- n + i > e.width && (n = t.clientX - e.left - i - nn), s + a > e.height && (s = t.clientY - e.top - a - sn), this.el.style.left = `${n}px`, this.el.style.top = `${s}px`;
1159
+ n + i > e.width && (n = t.clientX - e.left - i - sn), s + a > e.height && (s = t.clientY - e.top - a - on), this.el.style.left = `${n}px`, this.el.style.top = `${s}px`;
1206
1160
  }
1207
1161
  /**
1208
1162
  * Показать индикатор
@@ -1233,7 +1187,7 @@ class Fe {
1233
1187
  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
1188
  }
1235
1189
  }
1236
- const Le = [
1190
+ const De = [
1237
1191
  "id",
1238
1192
  "backgroundId",
1239
1193
  "customData",
@@ -1284,7 +1238,7 @@ class J {
1284
1238
  return this.patches[this.currentIndex - 1] || null;
1285
1239
  }
1286
1240
  _createDiffPatcher() {
1287
- this.diffPatcher = Nn({
1241
+ this.diffPatcher = Pn({
1288
1242
  objectHash(t) {
1289
1243
  return [JSON.stringify(t)].join("-");
1290
1244
  },
@@ -1369,7 +1323,7 @@ class J {
1369
1323
  */
1370
1324
  _serializeCanvasState() {
1371
1325
  const { canvas: t } = this;
1372
- return t.toDatalessObject([...Le]);
1326
+ return t.toDatalessObject([...De]);
1373
1327
  }
1374
1328
  /**
1375
1329
  * Обрабатывает срабатывание отложенного сохранения.
@@ -1430,7 +1384,7 @@ class J {
1430
1384
  this._isSavingState = !0, console.time("saveState");
1431
1385
  try {
1432
1386
  const t = this._withTemporaryUnlock(
1433
- () => this.canvas.toDatalessObject([...Le])
1387
+ () => this.canvas.toDatalessObject([...De])
1434
1388
  );
1435
1389
  if (console.timeEnd("saveState"), !this.baseState) {
1436
1390
  this.baseState = t, this.patches = [], this.currentIndex = 0, console.log("Базовое состояние сохранено.");
@@ -1823,7 +1777,7 @@ class J {
1823
1777
  }
1824
1778
  }
1825
1779
  }
1826
- const rs = 0.1, cs = 2, on = 0.1, ls = 90, Qt = 16, $t = 16, zt = 4096, Pt = 4096, an = "application/image-editor:", de = [
1780
+ const cs = 0.1, ls = 2, an = 0.1, ds = 90, $t = 16, te = 16, zt = 4096, Ft = 4096, rn = "application/image-editor:", he = [
1827
1781
  "format",
1828
1782
  "uppercase",
1829
1783
  "textCaseRaw",
@@ -1838,8 +1792,8 @@ const rs = 0.1, cs = 2, on = 0.1, ls = 90, Qt = 16, $t = 16, zt = 4096, Pt = 409
1838
1792
  "radiusBottomRight",
1839
1793
  "radiusBottomLeft",
1840
1794
  "lineFontDefaults"
1841
- ], ds = 50;
1842
- class pt {
1795
+ ], hs = 50;
1796
+ class mt {
1843
1797
  constructor({ editor: t }) {
1844
1798
  this.editor = t, this.options = t.options, this._createdBlobUrls = [], this.acceptContentTypes = this.editor.options.acceptContentTypes, this.acceptFormats = this.getAllowedFormatsFromContentTypes();
1845
1799
  }
@@ -1868,14 +1822,14 @@ class pt {
1868
1822
  customData: c = null
1869
1823
  } = t;
1870
1824
  if (!e) return null;
1871
- const { canvas: l, montageArea: d, transformManager: u, historyManager: f, errorManager: g } = this.editor, m = yield this.getContentType(e), p = pt.getFormatFromContentType(m), { acceptContentTypes: y, acceptFormats: v } = this;
1825
+ const { canvas: l, montageArea: d, transformManager: u, historyManager: f, errorManager: g } = this.editor, m = yield this.getContentType(e), p = mt.getFormatFromContentType(m), { acceptContentTypes: y, acceptFormats: v } = this;
1872
1826
  if (!this.isAllowedContentType(m)) {
1873
- const j = `Неверный contentType для изображения: ${m}. Ожидается один из: ${this.acceptContentTypes.join(", ")}.`;
1827
+ const A = `Неверный contentType для изображения: ${m}. Ожидается один из: ${this.acceptContentTypes.join(", ")}.`;
1874
1828
  return g.emitError({
1875
1829
  origin: "ImageManager",
1876
1830
  method: "importImage",
1877
1831
  code: "INVALID_CONTENT_TYPE",
1878
- message: j,
1832
+ message: A,
1879
1833
  data: {
1880
1834
  source: e,
1881
1835
  format: p,
@@ -1892,12 +1846,12 @@ class pt {
1892
1846
  }
1893
1847
  f.suspendHistory();
1894
1848
  try {
1895
- let j, b;
1849
+ let A, b;
1896
1850
  if (e instanceof File)
1897
- j = URL.createObjectURL(e);
1851
+ A = URL.createObjectURL(e);
1898
1852
  else if (typeof e == "string") {
1899
1853
  const C = yield (yield fetch(e, { mode: "cors" })).blob();
1900
- j = URL.createObjectURL(C);
1854
+ A = URL.createObjectURL(C);
1901
1855
  } else
1902
1856
  return g.emitError({
1903
1857
  origin: "ImageManager",
@@ -1917,36 +1871,36 @@ class pt {
1917
1871
  customData: c
1918
1872
  }
1919
1873
  }), f.resumeHistory(), null;
1920
- if (this._createdBlobUrls.push(j), p === "svg") {
1921
- const w = yield En(j);
1922
- b = vt.groupSVGElements(w.objects, w.options);
1874
+ if (this._createdBlobUrls.push(A), p === "svg") {
1875
+ const w = yield _n(A);
1876
+ b = bt.groupSVGElements(w.objects, w.options);
1923
1877
  } else
1924
- b = yield Kt.fromURL(j, { crossOrigin: "anonymous" });
1925
- const { width: T, height: S } = b;
1926
- if (b instanceof Kt) {
1878
+ b = yield qt.fromURL(A, { crossOrigin: "anonymous" });
1879
+ const { width: O, height: S } = b;
1880
+ if (b instanceof qt) {
1927
1881
  const w = b.getElement();
1928
1882
  let C = "";
1929
- if (w instanceof HTMLImageElement ? C = w.src : w instanceof HTMLCanvasElement && (C = w.toDataURL()), S > Pt || T > zt) {
1930
- const A = yield this.resizeImageToBoundaries({
1883
+ if (w instanceof HTMLImageElement ? C = w.src : w instanceof HTMLCanvasElement && (C = w.toDataURL()), S > Ft || O > zt) {
1884
+ const j = yield this.resizeImageToBoundaries({
1931
1885
  dataURL: C,
1932
1886
  sizeType: "max",
1933
1887
  contentType: m
1934
- }), I = URL.createObjectURL(A);
1935
- this._createdBlobUrls.push(I), b = yield Kt.fromURL(I, { crossOrigin: "anonymous" });
1936
- } else if (S < $t || T < Qt) {
1937
- const A = yield this.resizeImageToBoundaries({
1888
+ }), I = URL.createObjectURL(j);
1889
+ this._createdBlobUrls.push(I), b = yield qt.fromURL(I, { crossOrigin: "anonymous" });
1890
+ } else if (S < te || O < $t) {
1891
+ const j = yield this.resizeImageToBoundaries({
1938
1892
  dataURL: C,
1939
1893
  sizeType: "min",
1940
1894
  contentType: m
1941
- }), I = URL.createObjectURL(A);
1942
- this._createdBlobUrls.push(I), b = yield Kt.fromURL(I, { crossOrigin: "anonymous" });
1895
+ }), I = URL.createObjectURL(j);
1896
+ this._createdBlobUrls.push(I), b = yield qt.fromURL(I, { crossOrigin: "anonymous" });
1943
1897
  }
1944
1898
  }
1945
1899
  if (b.set("id", `${b.type}-${et()}`), b.set("format", p), b.set("contentType", m), b.set("customData", c || null), n === "scale-montage")
1946
1900
  this.editor.canvasManager.scaleMontageAreaToImage({ object: b, withoutSave: !0 });
1947
1901
  else {
1948
- const { width: w, height: C } = d, A = this.calculateScaleFactor({ imageObject: b, scaleType: n });
1949
- n === "image-contain" && A < 1 ? u.fitObject({ object: b, type: "contain", withoutSave: !0 }) : n === "image-cover" && (T > w || S > C) && u.fitObject({ object: b, type: "cover", withoutSave: !0 });
1902
+ const { width: w, height: C } = d, j = this.calculateScaleFactor({ imageObject: b, scaleType: n });
1903
+ n === "image-contain" && j < 1 ? u.fitObject({ object: b, type: "contain", withoutSave: !0 }) : n === "image-cover" && (O > w || S > C) && u.fitObject({ object: b, type: "cover", withoutSave: !0 });
1950
1904
  }
1951
1905
  const M = {
1952
1906
  image: b,
@@ -1962,12 +1916,12 @@ class pt {
1962
1916
  customData: c
1963
1917
  };
1964
1918
  return r ? (f.resumeHistory(), l.fire("editor:image-imported", M), M) : (l.add(b), l.centerObject(b), a || l.setActiveObject(b), l.renderAll(), f.resumeHistory(), s || f.saveState(), l.fire("editor:image-imported", M), M);
1965
- } catch (j) {
1919
+ } catch (A) {
1966
1920
  return g.emitError({
1967
1921
  origin: "ImageManager",
1968
1922
  method: "importImage",
1969
1923
  code: "IMPORT_FAILED",
1970
- message: `Ошибка импорта изображения: ${j.message}`,
1924
+ message: `Ошибка импорта изображения: ${A.message}`,
1971
1925
  data: {
1972
1926
  source: e,
1973
1927
  format: p,
@@ -2009,9 +1963,9 @@ class pt {
2009
1963
  contentType: s = "image/png",
2010
1964
  quality: o = 1,
2011
1965
  maxWidth: i = zt,
2012
- maxHeight: a = Pt,
2013
- minWidth: r = Qt,
2014
- minHeight: c = $t,
1966
+ maxHeight: a = Ft,
1967
+ minWidth: r = $t,
1968
+ minHeight: c = te,
2015
1969
  asBase64: l = !1,
2016
1970
  emitMessage: d = !0
2017
1971
  } = t, { errorManager: u, workerManager: f } = this.editor, g = {
@@ -2066,22 +2020,22 @@ class pt {
2066
2020
  exportAsBlob: o = !1
2067
2021
  } = t, { canvas: i, montageArea: a, workerManager: r, interactionBlocker: c } = this.editor;
2068
2022
  try {
2069
- const l = n === "application/pdf", d = l ? "image/jpg" : n, u = pt.getFormatFromContentType(d);
2023
+ const l = n === "application/pdf", d = l ? "image/jpg" : n, u = mt.getFormatFromContentType(d);
2070
2024
  a.setCoords();
2071
2025
  const { left: f, top: g, width: m, height: p } = a.getBoundingRect(), y = yield i.clone(["id", "format", "locked"]);
2072
2026
  y.enableRetinaScaling = !1, ["image/jpg", "image/jpeg"].includes(d) && (y.backgroundColor = "#ffffff");
2073
- const v = y.getObjects().find((A) => A.id === a.id);
2027
+ const v = y.getObjects().find((j) => j.id === a.id);
2074
2028
  if (v && (v.visible = !1), c != null && c.isBlocked) {
2075
- const A = y.getObjects().find((I) => I.id === c.overlayMask.id);
2076
- A && (A.visible = !1);
2029
+ const j = y.getObjects().find((I) => I.id === c.overlayMask.id);
2030
+ j && (j.visible = !1);
2077
2031
  }
2078
2032
  y.viewportTransform = [1, 0, 0, 1, -f, -g], y.setDimensions({ width: m, height: p }, { backstoreOnly: !0 }), y.renderAll();
2079
- const j = y.getObjects().filter((A) => A.format).every((A) => A.format === "svg");
2080
- if (u === "svg" && j) {
2081
- const A = y.toSVG();
2033
+ const A = y.getObjects().filter((j) => j.format).every((j) => j.format === "svg");
2034
+ if (u === "svg" && A) {
2035
+ const j = y.toSVG();
2082
2036
  y.dispose();
2083
- const O = {
2084
- image: pt._exportSVGStringAsFile(A, {
2037
+ const T = {
2038
+ image: mt._exportSVGStringAsFile(j, {
2085
2039
  exportAsBase64: s,
2086
2040
  exportAsBlob: o,
2087
2041
  fileName: e
@@ -2090,51 +2044,51 @@ class pt {
2090
2044
  contentType: "image/svg+xml",
2091
2045
  fileName: e.replace(/\.[^/.]+$/, ".svg")
2092
2046
  };
2093
- return i.fire("editor:canvas-exported", O), O;
2047
+ return i.fire("editor:canvas-exported", T), T;
2094
2048
  }
2095
- const b = yield new Promise((A, I) => {
2049
+ const b = yield new Promise((j, I) => {
2096
2050
  y.getElement().toBlob(
2097
- (O) => {
2098
- O ? A(O) : I(new Error("Failed to create Blob from canvas"));
2051
+ (T) => {
2052
+ T ? j(T) : I(new Error("Failed to create Blob from canvas"));
2099
2053
  },
2100
2054
  d,
2101
2055
  1
2102
2056
  );
2103
2057
  });
2104
2058
  if (y.dispose(), o) {
2105
- const A = {
2059
+ const j = {
2106
2060
  image: b,
2107
2061
  format: u,
2108
2062
  contentType: d,
2109
2063
  fileName: e
2110
2064
  };
2111
- return i.fire("editor:canvas-exported", A), A;
2065
+ return i.fire("editor:canvas-exported", j), j;
2112
2066
  }
2113
- const T = yield createImageBitmap(b), S = yield r.post(
2067
+ const O = yield createImageBitmap(b), S = yield r.post(
2114
2068
  "toDataURL",
2115
2069
  {
2116
2070
  contentType: d,
2117
2071
  quality: 1,
2118
- bitmap: T
2072
+ bitmap: O
2119
2073
  },
2120
- [T]
2074
+ [O]
2121
2075
  );
2122
2076
  if (l) {
2123
- const I = m * 0.264583, O = p * 0.264583, k = (yield this.editor.moduleLoader.loadModule("jspdf")).jsPDF, D = new k({
2124
- orientation: I > O ? "landscape" : "portrait",
2077
+ const I = m * 0.264583, T = p * 0.264583, k = (yield this.editor.moduleLoader.loadModule("jspdf")).jsPDF, _ = new k({
2078
+ orientation: I > T ? "landscape" : "portrait",
2125
2079
  unit: "mm",
2126
- format: [I, O]
2080
+ format: [I, T]
2127
2081
  });
2128
- if (D.addImage(String(S), "JPG", 0, 0, I, O), s) {
2082
+ if (_.addImage(String(S), "JPG", 0, 0, I, T), s) {
2129
2083
  const B = {
2130
- image: D.output("datauristring"),
2084
+ image: _.output("datauristring"),
2131
2085
  format: "pdf",
2132
2086
  contentType: "application/pdf",
2133
2087
  fileName: e
2134
2088
  };
2135
2089
  return i.fire("editor:canvas-exported", B), B;
2136
2090
  }
2137
- const W = D.output("blob"), L = {
2091
+ const W = _.output("blob"), L = {
2138
2092
  image: new File([W], e, { type: "application/pdf" }),
2139
2093
  format: "pdf",
2140
2094
  contentType: "application/pdf",
@@ -2143,15 +2097,15 @@ class pt {
2143
2097
  return i.fire("editor:canvas-exported", L), L;
2144
2098
  }
2145
2099
  if (s) {
2146
- const A = {
2100
+ const j = {
2147
2101
  image: S,
2148
2102
  format: u,
2149
2103
  contentType: d,
2150
2104
  fileName: e
2151
2105
  };
2152
- return i.fire("editor:canvas-exported", A), A;
2106
+ return i.fire("editor:canvas-exported", j), j;
2153
2107
  }
2154
- const M = u === "svg" && !j ? e.replace(/\.[^/.]+$/, ".png") : e, C = {
2108
+ const M = u === "svg" && !A ? e.replace(/\.[^/.]+$/, ".png") : e, C = {
2155
2109
  image: new File([b], M, { type: d }),
2156
2110
  format: u,
2157
2111
  contentType: d,
@@ -2189,7 +2143,7 @@ class pt {
2189
2143
  contentType: s,
2190
2144
  exportAsBase64: o = !1,
2191
2145
  exportAsBlob: i = !1
2192
- } = t, { canvas: a, workerManager: r } = this.editor, c = e || a.getActiveObject(), l = s != null ? s : "image/png", d = pt.getFormatFromContentType(l) || "png", u = n != null ? n : `image.${d}`;
2146
+ } = t, { canvas: a, workerManager: r } = this.editor, c = e || a.getActiveObject(), l = s != null ? s : "image/png", d = mt.getFormatFromContentType(l) || "png", u = n != null ? n : `image.${d}`;
2193
2147
  if (!c)
2194
2148
  return this.editor.errorManager.emitError({
2195
2149
  origin: "ImageManager",
@@ -2198,10 +2152,10 @@ class pt {
2198
2152
  message: "Не выбран объект для экспорта",
2199
2153
  data: { contentType: l, fileName: u, exportAsBase64: o, exportAsBlob: i }
2200
2154
  }), null;
2201
- const { contentType: f, format: g = "" } = c, m = (v = s != null ? s : f) != null ? v : "image/png", p = pt.getFormatFromContentType(m) || g || "png", y = n != null ? n : `image.${p}`;
2155
+ const { contentType: f, format: g = "" } = c, m = (v = s != null ? s : f) != null ? v : "image/png", p = mt.getFormatFromContentType(m) || g || "png", y = n != null ? n : `image.${p}`;
2202
2156
  try {
2203
2157
  if (p === "svg") {
2204
- const M = c.toSVG(), w = pt._exportSVGStringAsFile(M, {
2158
+ const M = c.toSVG(), w = mt._exportSVGStringAsFile(M, {
2205
2159
  exportAsBase64: o,
2206
2160
  exportAsBlob: i,
2207
2161
  fileName: y
@@ -2214,7 +2168,7 @@ class pt {
2214
2168
  };
2215
2169
  return a.fire("editor:object-exported", C), C;
2216
2170
  }
2217
- if (o && c instanceof Kt) {
2171
+ if (o && c instanceof qt) {
2218
2172
  const M = yield createImageBitmap(c.getElement()), w = yield r.post(
2219
2173
  "toDataURL",
2220
2174
  {
@@ -2232,10 +2186,10 @@ class pt {
2232
2186
  };
2233
2187
  return a.fire("editor:object-exported", C), C;
2234
2188
  }
2235
- const j = c.toCanvasElement({
2189
+ const A = c.toCanvasElement({
2236
2190
  enableRetinaScaling: !1
2237
2191
  }), b = yield new Promise((M, w) => {
2238
- j.toBlob((C) => {
2192
+ A.toBlob((C) => {
2239
2193
  C ? M(C) : w(new Error("Failed to create Blob from canvas"));
2240
2194
  });
2241
2195
  });
@@ -2249,20 +2203,20 @@ class pt {
2249
2203
  };
2250
2204
  return a.fire("editor:object-exported", M), M;
2251
2205
  }
2252
- const T = new File([b], y, { type: m }), S = {
2206
+ const O = new File([b], y, { type: m }), S = {
2253
2207
  object: c,
2254
- image: T,
2208
+ image: O,
2255
2209
  format: p,
2256
2210
  contentType: m,
2257
2211
  fileName: y
2258
2212
  };
2259
2213
  return a.fire("editor:object-exported", S), S;
2260
- } catch (j) {
2214
+ } catch (A) {
2261
2215
  return this.editor.errorManager.emitError({
2262
2216
  origin: "ImageManager",
2263
2217
  method: "exportObjectAsImageFile",
2264
2218
  code: "IMAGE_EXPORT_FAILED",
2265
- message: `Ошибка экспорта объекта: ${j.message}`,
2219
+ message: `Ошибка экспорта объекта: ${A.message}`,
2266
2220
  data: {
2267
2221
  contentType: m,
2268
2222
  fileName: y,
@@ -2284,7 +2238,7 @@ class pt {
2284
2238
  * @returns массив допустимых форматов изображений
2285
2239
  */
2286
2240
  getAllowedFormatsFromContentTypes() {
2287
- return this.acceptContentTypes.map((t) => pt.getFormatFromContentType(t)).filter((t) => t);
2241
+ return this.acceptContentTypes.map((t) => mt.getFormatFromContentType(t)).filter((t) => t);
2288
2242
  }
2289
2243
  /**
2290
2244
  * Проверяет, является ли contentType допустимым типом изображения.
@@ -2337,7 +2291,7 @@ class pt {
2337
2291
  try {
2338
2292
  const s = (e = new URL(t).pathname.split(".").pop()) == null ? void 0 : e.toLowerCase(), o = {};
2339
2293
  return this.acceptContentTypes.forEach((i) => {
2340
- const a = pt.getFormatFromContentType(i);
2294
+ const a = mt.getFormatFromContentType(i);
2341
2295
  a && (o[a] = i);
2342
2296
  }), s && o[s] || "application/octet-stream";
2343
2297
  } catch (n) {
@@ -2390,11 +2344,11 @@ class pt {
2390
2344
  return e ? e[1] : "";
2391
2345
  }
2392
2346
  }
2393
- const Ct = (h, t, e) => Math.max(Math.min(h, e), t), rn = (h, t) => h * t, hs = (h, t) => new lt(h / 2, t / 2);
2394
- function us(h) {
2347
+ const It = (h, t, e) => Math.max(Math.min(h, e), t), cn = (h, t) => h * t, us = (h, t) => new lt(h / 2, t / 2);
2348
+ function fs(h) {
2395
2349
  return ((h == null ? void 0 : h.type) === "image" || (h == null ? void 0 : h.format) === "svg") && typeof (h == null ? void 0 : h.width) == "number" && typeof (h == null ? void 0 : h.height) == "number";
2396
2350
  }
2397
- class fs {
2351
+ class gs {
2398
2352
  /**
2399
2353
  * @param options
2400
2354
  * @param options.editor – экземпляр редактора
@@ -2414,11 +2368,11 @@ class fs {
2414
2368
  * Если точка находится за пределами монтажной области, она проецируется на ближайшую границу монтажной области.
2415
2369
  */
2416
2370
  getVisibleCenterPoint() {
2417
- const { canvas: t, montageArea: e } = this.editor, n = t.getZoom(), s = t.viewportTransform, o = t.getWidth(), i = t.getHeight(), a = (o / 2 - s[4]) / n, r = (i / 2 - s[5]) / n, c = e.width / 2, l = e.height / 2, d = Ct(
2371
+ const { canvas: t, montageArea: e } = this.editor, n = t.getZoom(), s = t.viewportTransform, o = t.getWidth(), i = t.getHeight(), a = (o / 2 - s[4]) / n, r = (i / 2 - s[5]) / n, c = e.width / 2, l = e.height / 2, d = It(
2418
2372
  a,
2419
2373
  e.left - c,
2420
2374
  e.left + c
2421
- ), u = Ct(
2375
+ ), u = It(
2422
2376
  r,
2423
2377
  e.top - l,
2424
2378
  e.top + l
@@ -2441,9 +2395,9 @@ class fs {
2441
2395
  canvas: o,
2442
2396
  montageArea: i,
2443
2397
  options: { canvasBackstoreWidth: a }
2444
- } = this.editor, { width: r, height: c } = i, l = Ct(Number(t), Qt, zt);
2398
+ } = this.editor, { width: r, height: c } = i, l = It(Number(t), $t, zt);
2445
2399
  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) {
2446
- const m = l / r, p = rn(c, m);
2400
+ const m = l / r, p = cn(c, m);
2447
2401
  this.setResolutionHeight(p);
2448
2402
  return;
2449
2403
  }
@@ -2471,9 +2425,9 @@ class fs {
2471
2425
  canvas: o,
2472
2426
  montageArea: i,
2473
2427
  options: { canvasBackstoreHeight: a }
2474
- } = this.editor, { width: r, height: c } = i, l = Ct(Number(t), $t, Pt);
2428
+ } = this.editor, { width: r, height: c } = i, l = It(Number(t), te, Ft);
2475
2429
  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) {
2476
- const m = l / c, p = rn(r, m);
2430
+ const m = l / c, p = cn(r, m);
2477
2431
  this.setResolutionWidth(p);
2478
2432
  return;
2479
2433
  }
@@ -2491,7 +2445,7 @@ class fs {
2491
2445
  */
2492
2446
  centerMontageArea() {
2493
2447
  var r;
2494
- const { canvas: t, montageArea: e } = this.editor, n = t.getWidth(), s = t.getHeight(), o = t.getZoom(), i = hs(n, s);
2448
+ const { canvas: t, montageArea: e } = this.editor, n = t.getWidth(), s = t.getHeight(), o = t.getZoom(), i = us(n, s);
2495
2449
  e.set({
2496
2450
  left: n / 2,
2497
2451
  top: s / 2
@@ -2524,7 +2478,7 @@ class fs {
2524
2478
  */
2525
2479
  setCanvasBackstoreWidth(t) {
2526
2480
  if (!t || typeof t != "number") return;
2527
- const e = Ct(t, Qt, zt);
2481
+ const e = It(t, $t, zt);
2528
2482
  this.editor.canvas.setDimensions({ width: e }, { backstoreOnly: !0 });
2529
2483
  }
2530
2484
  /**
@@ -2533,7 +2487,7 @@ class fs {
2533
2487
  */
2534
2488
  setCanvasBackstoreHeight(t) {
2535
2489
  if (!t || typeof t != "number") return;
2536
- const e = Ct(t, $t, Pt);
2490
+ const e = It(t, te, Ft);
2537
2491
  this.editor.canvas.setDimensions({ height: e }, { backstoreOnly: !0 });
2538
2492
  }
2539
2493
  /**
@@ -2542,7 +2496,7 @@ class fs {
2542
2496
  * с учётом минимальных и максимальных значений.
2543
2497
  */
2544
2498
  adaptCanvasToContainer() {
2545
- const { canvas: t } = this.editor, e = this.getEditorContainer(), n = e.clientWidth, s = e.clientHeight, o = Ct(n, Qt, zt), i = Ct(s, $t, Pt);
2499
+ const { canvas: t } = this.editor, e = this.getEditorContainer(), n = e.clientWidth, s = e.clientHeight, o = It(n, $t, zt), i = It(s, te, Ft);
2546
2500
  t.setDimensions({ width: o, height: i }, { backstoreOnly: !0 });
2547
2501
  }
2548
2502
  /**
@@ -2742,9 +2696,9 @@ class fs {
2742
2696
  montageAreaHeight: r
2743
2697
  }
2744
2698
  } = this.editor, c = t || s.getActiveObject();
2745
- if (!us(c)) return;
2699
+ if (!fs(c)) return;
2746
2700
  const { width: l, height: d } = c;
2747
- let u = Math.min(l, zt), f = Math.min(d, Pt);
2701
+ let u = Math.min(l, zt), f = Math.min(d, Ft);
2748
2702
  if (e) {
2749
2703
  const {
2750
2704
  width: g,
@@ -2802,7 +2756,7 @@ class fs {
2802
2756
  );
2803
2757
  }
2804
2758
  }
2805
- class gs {
2759
+ class ps {
2806
2760
  constructor({ editor: t }) {
2807
2761
  this.editor = t, this.options = t.options;
2808
2762
  }
@@ -2813,7 +2767,7 @@ class gs {
2813
2767
  * @param options.withoutSave - Не сохранять состояние
2814
2768
  * @fires editor:object-rotated
2815
2769
  */
2816
- rotate(t = ls, { withoutSave: e } = {}) {
2770
+ rotate(t = ds, { withoutSave: e } = {}) {
2817
2771
  const { canvas: n, historyManager: s } = this.editor, o = n.getActiveObject();
2818
2772
  if (!o) return;
2819
2773
  const i = o.angle + t;
@@ -2915,10 +2869,10 @@ class gs {
2915
2869
  */
2916
2870
  _fitSingleObject(t, e) {
2917
2871
  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), d = i * Math.abs(r), u = c * Math.PI / 180, f = Math.abs(Math.cos(u)), g = Math.abs(Math.sin(u)), m = l * f + d * g, p = l * g + d * f, y = s.width, v = s.height;
2918
- let j;
2919
- e === "contain" ? j = Math.min(y / m, v / p) : j = Math.max(y / m, v / p), t.set({
2920
- scaleX: a * j,
2921
- scaleY: r * j
2872
+ let A;
2873
+ e === "contain" ? A = Math.min(y / m, v / p) : A = Math.max(y / m, v / p), t.set({
2874
+ scaleX: a * A,
2875
+ scaleY: r * A
2922
2876
  }), n.centerObject(t);
2923
2877
  }
2924
2878
  /**
@@ -2968,9 +2922,9 @@ class gs {
2968
2922
  });
2969
2923
  }
2970
2924
  }
2971
- class ps {
2925
+ class ms {
2972
2926
  constructor({ editor: t }) {
2973
- this.editor = t, this.options = t.options, this.minZoom = this.options.minZoom || rs, this.maxZoom = this.options.maxZoom || cs, this.defaultZoom = this._normalizeDefaultZoom(this.options.defaultScale);
2927
+ this.editor = t, this.options = t.options, this.minZoom = this.options.minZoom || cs, this.maxZoom = this.options.maxZoom || ls, this.defaultZoom = this._normalizeDefaultZoom(this.options.defaultScale);
2974
2928
  }
2975
2929
  /**
2976
2930
  * Приводит значение defaultZoom к числу с двумя знаками после запятой, а также учитывает минимальное и максимальное значения.
@@ -3038,8 +2992,8 @@ class ps {
3038
2992
  _calculateEmptySpaceRatio(t) {
3039
2993
  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, d = -s[4] / t, u = (-s[4] + o) / t, f = -s[5] / t, g = (-s[5] + i) / t, m = d < a, p = u > r, y = f < c, v = g > l;
3040
2994
  if (!(m || p || y || v)) return 0;
3041
- const b = Math.max(0, a - d), T = Math.max(0, u - r), S = Math.max(0, c - f), M = Math.max(0, g - l), w = Math.max(b, T), C = Math.max(S, M), A = w / o, I = C / i;
3042
- return Math.max(A, I);
2995
+ const b = Math.max(0, a - d), O = Math.max(0, u - r), S = Math.max(0, c - f), M = Math.max(0, g - l), w = Math.max(b, O), C = Math.max(S, M), j = w / o, I = C / i;
2996
+ return Math.max(j, I);
3043
2997
  }
3044
2998
  /**
3045
2999
  * Вычисляет плавный шаг перемещения viewport к центру с ускорением
@@ -3055,8 +3009,8 @@ class ps {
3055
3009
  const { canvas: i, montageArea: a } = this.editor, r = i.viewportTransform, c = i.getWidth(), l = i.getHeight(), d = t.x - r[4], u = t.y - r[5], f = Math.abs(s), g = e - n;
3056
3010
  if (Math.abs(g) / f <= 0.1)
3057
3011
  return { x: d, y: u };
3058
- const p = c / 2, y = l / 2, v = a.left, j = a.top, b = p - v * n, T = y - j * n, S = (b - r[4]) / (e - n), M = (T - r[5]) / (e - n), w = S * f, C = M * f, A = w * o, I = C * o, O = Math.abs(A) > Math.abs(d) ? d : A, k = Math.abs(I) > Math.abs(u) ? u : I;
3059
- return { x: O, y: k };
3012
+ const p = c / 2, y = l / 2, v = a.left, A = a.top, b = p - v * n, O = y - A * n, S = (b - r[4]) / (e - n), M = (O - r[5]) / (e - n), w = S * f, C = M * f, j = w * o, I = C * o, T = Math.abs(j) > Math.abs(d) ? d : j, k = Math.abs(I) > Math.abs(u) ? u : I;
3013
+ return { x: T, y: k };
3060
3014
  }
3061
3015
  /**
3062
3016
  * Применяет плавное центрирование viewport при приближении к defaultZoom.
@@ -3068,7 +3022,7 @@ class ps {
3068
3022
  * @returns true если центрирование было применено
3069
3023
  * @private
3070
3024
  */
3071
- _applyViewportCentering(t, e = !1, n = on) {
3025
+ _applyViewportCentering(t, e = !1, n = an) {
3072
3026
  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;
3073
3027
  if (!(!r || l) && !e)
3074
3028
  return !1;
@@ -3143,7 +3097,7 @@ class ps {
3143
3097
  * @param options.pointY - Координата Y точки зума
3144
3098
  * @fires editor:zoom-changed
3145
3099
  */
3146
- zoom(t = on, e = {}) {
3100
+ zoom(t = an, e = {}) {
3147
3101
  var f, g;
3148
3102
  if (!t) return;
3149
3103
  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, d = new lt(c, l);
@@ -3181,7 +3135,7 @@ class ps {
3181
3135
  }), this.editor.panConstraintManager.updateBounds();
3182
3136
  }
3183
3137
  }
3184
- class ms {
3138
+ class ys {
3185
3139
  constructor({ editor: t }) {
3186
3140
  this.editor = t, this.isBlocked = !1, this.overlayMask = null, this._createOverlay();
3187
3141
  }
@@ -3238,7 +3192,7 @@ class ms {
3238
3192
  }), t.upperCanvasEl.style.pointerEvents = "", t.lowerCanvasEl.style.pointerEvents = "", this.overlayMask.visible = !1, t.requestRenderAll(), t.fire("editor:enabled"), n.resumeHistory();
3239
3193
  }
3240
3194
  }
3241
- class Ft {
3195
+ class Wt {
3242
3196
  constructor({ editor: t }) {
3243
3197
  this.editor = t, this.backgroundObject = null;
3244
3198
  }
@@ -3301,8 +3255,8 @@ class Ft {
3301
3255
  try {
3302
3256
  const { historyManager: i } = this.editor, { backgroundObject: a } = this;
3303
3257
  if (i.suspendHistory(), a && a.backgroundType === "gradient") {
3304
- const r = Ft._createFabricGradient(t);
3305
- if (Ft._isGradientEqual(a.fill, r)) {
3258
+ const r = Wt._createFabricGradient(t);
3259
+ if (Wt._isGradientEqual(a.fill, r)) {
3306
3260
  i.resumeHistory();
3307
3261
  return;
3308
3262
  }
@@ -3485,7 +3439,7 @@ class Ft {
3485
3439
  backgroundType: "gradient",
3486
3440
  backgroundId: `background-${et()}`
3487
3441
  }, { withoutSelection: !0 }), this.refresh();
3488
- const e = Ft._createFabricGradient(t);
3442
+ const e = Wt._createFabricGradient(t);
3489
3443
  this.backgroundObject.set("fill", e), this.editor.canvas.requestRenderAll();
3490
3444
  }
3491
3445
  /**
@@ -3545,8 +3499,8 @@ class Ft {
3545
3499
  { offset: 0, color: "#000000" },
3546
3500
  { offset: 1, color: "#ffffff" }
3547
3501
  ], t.type === "linear") {
3548
- const u = t.angle * Math.PI / 180, f = Ft._angleToCoords(u);
3549
- return new Je({
3502
+ const u = t.angle * Math.PI / 180, f = Wt._angleToCoords(u);
3503
+ return new Qe({
3550
3504
  type: "linear",
3551
3505
  gradientUnits: "percentage",
3552
3506
  coords: f,
@@ -3565,7 +3519,7 @@ class Ft {
3565
3519
  r1: 0,
3566
3520
  r2: l / 100
3567
3521
  };
3568
- return new Je({
3522
+ return new Qe({
3569
3523
  type: "radial",
3570
3524
  gradientUnits: "percentage",
3571
3525
  coords: d,
@@ -3600,7 +3554,7 @@ class Ft {
3600
3554
  }) ? !1 : t.type === "linear" && e.type === "linear" ? Math.abs(t.coords.x1 - e.coords.x1) < 1e-4 && Math.abs(t.coords.y1 - e.coords.y1) < 1e-4 && Math.abs(t.coords.x2 - e.coords.x2) < 1e-4 && Math.abs(t.coords.y2 - e.coords.y2) < 1e-4 : t.type === "radial" && e.type === "radial" ? Math.abs(t.coords.x1 - e.coords.x1) < 1e-4 && Math.abs(t.coords.y1 - e.coords.y1) < 1e-4 && Math.abs(t.coords.x2 - e.coords.x2) < 1e-4 && Math.abs(t.coords.y2 - e.coords.y2) < 1e-4 && Math.abs(t.coords.r1 - e.coords.r1) < 1e-4 && Math.abs(t.coords.r2 - e.coords.r2) < 1e-4 : !1;
3601
3555
  }
3602
3556
  }
3603
- class pe {
3557
+ class me {
3604
3558
  constructor({ editor: t }) {
3605
3559
  this.editor = t;
3606
3560
  }
@@ -3633,7 +3587,7 @@ class pe {
3633
3587
  const { canvas: n, historyManager: s } = this.editor;
3634
3588
  s.suspendHistory();
3635
3589
  const o = t || n.getActiveObject();
3636
- o && (o instanceof X ? pe._moveSelectionForward(n, o) : n.bringObjectForward(o), n.renderAll(), s.resumeHistory(), e || s.saveState(), n.fire("editor:object-bring-forward", {
3590
+ o && (o instanceof X ? me._moveSelectionForward(n, o) : n.bringObjectForward(o), n.renderAll(), s.resumeHistory(), e || s.saveState(), n.fire("editor:object-bring-forward", {
3637
3591
  object: o,
3638
3592
  withoutSave: e
3639
3593
  }));
@@ -3684,7 +3638,7 @@ class pe {
3684
3638
  } = this.editor;
3685
3639
  o.suspendHistory();
3686
3640
  const r = t || n.getActiveObject();
3687
- r && (r instanceof X ? pe._moveSelectionBackwards(n, r) : n.sendObjectBackwards(r), a && n.sendObjectToBack(a), n.sendObjectToBack(s), i && n.sendObjectToBack(i), n.renderAll(), o.resumeHistory(), e || o.saveState(), n.fire("editor:object-send-backwards", {
3641
+ r && (r instanceof X ? me._moveSelectionBackwards(n, r) : n.sendObjectBackwards(r), a && n.sendObjectToBack(a), n.sendObjectToBack(s), i && n.sendObjectToBack(i), n.renderAll(), o.resumeHistory(), e || o.saveState(), n.fire("editor:object-send-backwards", {
3688
3642
  object: r,
3689
3643
  withoutSave: e
3690
3644
  }));
@@ -3728,7 +3682,7 @@ class pe {
3728
3682
  });
3729
3683
  }
3730
3684
  }
3731
- class ys {
3685
+ class vs {
3732
3686
  /**
3733
3687
  * Менеджер фигур для редактора.
3734
3688
  * @param options - Опции и настройки менеджера фигур.
@@ -3760,7 +3714,7 @@ class ys {
3760
3714
  width: s = 100,
3761
3715
  height: o = 100,
3762
3716
  fill: i = "blue"
3763
- } = d, a = jt(d, [
3717
+ } = d, a = Ct(d, [
3764
3718
  "id",
3765
3719
  "left",
3766
3720
  "top",
@@ -3768,7 +3722,7 @@ class ys {
3768
3722
  "height",
3769
3723
  "fill"
3770
3724
  ]);
3771
- const { canvas: u } = this.editor, f = new Dn(F({
3725
+ const { canvas: u } = this.editor, f = new Ln(F({
3772
3726
  id: t,
3773
3727
  left: e,
3774
3728
  top: n,
@@ -3801,14 +3755,14 @@ class ys {
3801
3755
  top: n,
3802
3756
  radius: s = 50,
3803
3757
  fill: o = "green"
3804
- } = l, i = jt(l, [
3758
+ } = l, i = Ct(l, [
3805
3759
  "id",
3806
3760
  "left",
3807
3761
  "top",
3808
3762
  "radius",
3809
3763
  "fill"
3810
3764
  ]);
3811
- const { canvas: d } = this.editor, u = new Ln(F({
3765
+ const { canvas: d } = this.editor, u = new Dn(F({
3812
3766
  id: t,
3813
3767
  left: e,
3814
3768
  top: n,
@@ -3842,7 +3796,7 @@ class ys {
3842
3796
  width: s = 100,
3843
3797
  height: o = 100,
3844
3798
  fill: i = "yellow"
3845
- } = d, a = jt(d, [
3799
+ } = d, a = Ct(d, [
3846
3800
  "id",
3847
3801
  "left",
3848
3802
  "top",
@@ -3850,7 +3804,7 @@ class ys {
3850
3804
  "height",
3851
3805
  "fill"
3852
3806
  ]);
3853
- const { canvas: u } = this.editor, f = new _n(F({
3807
+ const { canvas: u } = this.editor, f = new xn(F({
3854
3808
  id: t,
3855
3809
  left: e,
3856
3810
  top: n,
@@ -3861,7 +3815,7 @@ class ys {
3861
3815
  return !e && !n && u.centerObject(f), c || (u.add(f), r || u.setActiveObject(f), u.renderAll()), f;
3862
3816
  }
3863
3817
  }
3864
- class vs {
3818
+ class bs {
3865
3819
  /**
3866
3820
  * @param options
3867
3821
  * @param options.editor - экземпляр редактора с доступом к canvas
@@ -3892,7 +3846,7 @@ class vs {
3892
3846
  return G(this, null, function* () {
3893
3847
  const { canvas: e, errorManager: n } = this.editor;
3894
3848
  try {
3895
- const s = yield t.clone(de);
3849
+ const s = yield t.clone(he);
3896
3850
  this.clipboard = s, e.fire("editor:object-copied", { object: s });
3897
3851
  } catch (s) {
3898
3852
  n.emitError({
@@ -3919,7 +3873,7 @@ class vs {
3919
3873
  message: "navigator.clipboard не поддерживается в этом браузере или отсутствует HTTPS-соединение."
3920
3874
  }), !1;
3921
3875
  try {
3922
- const n = t.toObject(de), s = JSON.stringify(n);
3876
+ const n = t.toObject(he), s = JSON.stringify(n);
3923
3877
  return t.type === "image" ? this._copyImageToClipboard(t, s) : this._copyTextToClipboard(s);
3924
3878
  } catch (n) {
3925
3879
  return e.emitError({
@@ -3960,7 +3914,7 @@ class vs {
3960
3914
  _copyTextToClipboard(t) {
3961
3915
  return G(this, null, function* () {
3962
3916
  try {
3963
- const e = `${an}${t}`;
3917
+ const e = `${rn}${t}`;
3964
3918
  return yield navigator.clipboard.writeText(e), console.info("Text copied to clipboard successfully"), !0;
3965
3919
  } catch (e) {
3966
3920
  const { errorManager: n } = this.editor;
@@ -4013,7 +3967,7 @@ class vs {
4013
3967
  const { canvas: e } = this.editor, n = t || e.getActiveObject();
4014
3968
  if (!n || n.locked) return !1;
4015
3969
  try {
4016
- const s = yield n.clone(de);
3970
+ const s = yield n.clone(he);
4017
3971
  return s instanceof X && s.forEachObject((o) => {
4018
3972
  o.set({
4019
3973
  id: `${o.type}-${et()}`,
@@ -4051,7 +4005,7 @@ class vs {
4051
4005
  return;
4052
4006
  }
4053
4007
  const n = t.getData("text/plain");
4054
- if (n && n.startsWith(an)) {
4008
+ if (n && n.startsWith(rn)) {
4055
4009
  this.paste();
4056
4010
  return;
4057
4011
  }
@@ -4099,7 +4053,7 @@ class vs {
4099
4053
  const { canvas: t } = this.editor;
4100
4054
  if (!this.clipboard) return !1;
4101
4055
  try {
4102
- const e = yield this.clipboard.clone(de);
4056
+ const e = yield this.clipboard.clone(he);
4103
4057
  return t.discardActiveObject(), e instanceof X && e.forEachObject((n) => {
4104
4058
  n.set({
4105
4059
  id: `${n.type}-${et()}`,
@@ -4124,7 +4078,7 @@ class vs {
4124
4078
  });
4125
4079
  }
4126
4080
  }
4127
- class me {
4081
+ class ye {
4128
4082
  constructor({ editor: t }) {
4129
4083
  this.editor = t;
4130
4084
  }
@@ -4150,7 +4104,7 @@ class me {
4150
4104
  editable: !1,
4151
4105
  locked: !0
4152
4106
  };
4153
- i.set(a), !e && me._isGroupOrSelection(i) && i.getObjects().forEach((c) => {
4107
+ i.set(a), !e && ye._isGroupOrSelection(i) && i.getObjects().forEach((c) => {
4154
4108
  c.set(a);
4155
4109
  }), i instanceof ct && i.isEditing && i.exitEditing(), s.renderAll(), n || o.saveState(), s.fire("editor:object-locked", {
4156
4110
  object: i,
@@ -4179,7 +4133,7 @@ class me {
4179
4133
  editable: !0,
4180
4134
  locked: !1
4181
4135
  };
4182
- o.set(i), me._isGroupOrSelection(o) && o.getObjects().forEach((a) => {
4136
+ o.set(i), ye._isGroupOrSelection(o) && o.getObjects().forEach((a) => {
4183
4137
  a.set(i);
4184
4138
  }), n.renderAll(), e || s.saveState(), n.fire("editor:object-unlocked", {
4185
4139
  object: o,
@@ -4187,10 +4141,10 @@ class me {
4187
4141
  });
4188
4142
  }
4189
4143
  static _isGroupOrSelection(t) {
4190
- return t instanceof X || t instanceof Nt;
4144
+ return t instanceof X || t instanceof Pt;
4191
4145
  }
4192
4146
  }
4193
- class bs {
4147
+ class Ms {
4194
4148
  constructor({ editor: t }) {
4195
4149
  this.editor = t;
4196
4150
  }
@@ -4210,20 +4164,20 @@ class bs {
4210
4164
  */
4211
4165
  _getGroupsToUngroup(t) {
4212
4166
  if (Array.isArray(t)) {
4213
- const n = t.filter((s) => s instanceof Nt);
4167
+ const n = t.filter((s) => s instanceof Pt);
4214
4168
  return n.length > 0 ? n : null;
4215
4169
  }
4216
4170
  if (t instanceof X) {
4217
- const n = t.getObjects().filter((s) => s instanceof Nt);
4171
+ const n = t.getObjects().filter((s) => s instanceof Pt);
4218
4172
  return n.length > 0 ? n : null;
4219
4173
  }
4220
4174
  const e = t || this.editor.canvas.getActiveObject();
4221
4175
  if (!e) return null;
4222
4176
  if (e instanceof X) {
4223
- const n = e.getObjects().filter((s) => s instanceof Nt);
4177
+ const n = e.getObjects().filter((s) => s instanceof Pt);
4224
4178
  return n.length > 0 ? n : null;
4225
4179
  }
4226
- return e instanceof Nt ? [e] : null;
4180
+ return e instanceof Pt ? [e] : null;
4227
4181
  }
4228
4182
  /**
4229
4183
  * Группировка объектов
@@ -4240,7 +4194,7 @@ class bs {
4240
4194
  if (!o) return null;
4241
4195
  try {
4242
4196
  s.suspendHistory();
4243
- const i = new Nt(o, {
4197
+ const i = new Pt(o, {
4244
4198
  id: `group-${et()}`
4245
4199
  });
4246
4200
  o.forEach((r) => n.remove(r)), n.add(i), n.setActiveObject(i), n.requestRenderAll();
@@ -4291,9 +4245,9 @@ class bs {
4291
4245
  }
4292
4246
  }
4293
4247
  }
4294
- class Ms {
4248
+ class ft {
4295
4249
  constructor({ editor: t }) {
4296
- this.editor = t;
4250
+ this.lastSelection = [], this.isCtrlSelectionBoxActive = !1, this.isSelectionMergeInProgress = !1, this.editor = t, this.selectionKey = this._resolveSelectionKey(), this.handleTextEditingEnteredBound = this._handleTextEditingEntered.bind(this), this.handleTextEditingExitedBound = this._handleTextEditingExited.bind(this), this.handleLockedSelectionBound = this._filterLockedSelection.bind(this), this.handleSelectionMergeBound = this._handleSelectionMerge.bind(this), this.handleSelectionChangeBound = this._handleSelectionChange.bind(this), this.handleSelectionClearedBound = this._handleSelectionCleared.bind(this), this.handleSelectionBoxStartBound = this._handleSelectionBoxStart.bind(this), this.handleSelectionBoxEndBound = this._handleSelectionBoxEnd.bind(this), this._applySelectionKey({ selectionKey: this.selectionKey }), this._bindEvents();
4297
4251
  }
4298
4252
  /**
4299
4253
  * Выделить все объекты
@@ -4305,8 +4259,286 @@ class Ms {
4305
4259
  const s = e.getObjects(), o = s.some((a) => a.locked), i = s.length > 1 ? new X(e.getObjects(), { canvas: t }) : s[0];
4306
4260
  o && n.lockObject({ object: i, skipInnerObjects: !0, withoutSave: !0 }), t.setActiveObject(i), t.requestRenderAll(), t.fire("editor:all-objects-selected", { selected: i });
4307
4261
  }
4262
+ /**
4263
+ * Снимает подписки SelectionManager.
4264
+ */
4265
+ destroy() {
4266
+ const { canvas: t } = this.editor;
4267
+ t.off("mouse:down", this.handleSelectionBoxStartBound), t.off("mouse:up", this.handleSelectionBoxEndBound), t.off("text:editing:entered", this.handleTextEditingEnteredBound), t.off("text:editing:exited", this.handleTextEditingExitedBound), t.off("selection:created", this.handleSelectionMergeBound), t.off("selection:updated", this.handleSelectionMergeBound), t.off("selection:created", this.handleLockedSelectionBound), t.off("selection:updated", this.handleLockedSelectionBound), t.off("selection:created", this.handleSelectionChangeBound), t.off("selection:updated", this.handleSelectionChangeBound), t.off("selection:cleared", this.handleSelectionClearedBound);
4268
+ }
4269
+ /**
4270
+ * Назначает ключ для мультивыделения.
4271
+ */
4272
+ _applySelectionKey({ selectionKey: t }) {
4273
+ const { canvas: e } = this.editor;
4274
+ e.selectionKey = t;
4275
+ }
4276
+ /**
4277
+ * Подписывается на события редактирования текста и выделения объектов.
4278
+ */
4279
+ _bindEvents() {
4280
+ const { canvas: t } = this.editor;
4281
+ t.on("text:editing:entered", this.handleTextEditingEnteredBound), t.on("text:editing:exited", this.handleTextEditingExitedBound), t.on("mouse:down", this.handleSelectionBoxStartBound), t.on("mouse:up", this.handleSelectionBoxEndBound), t.on("selection:created", this.handleSelectionMergeBound), t.on("selection:updated", this.handleSelectionMergeBound), t.on("selection:created", this.handleLockedSelectionBound), t.on("selection:updated", this.handleLockedSelectionBound), t.on("selection:created", this.handleSelectionChangeBound), t.on("selection:updated", this.handleSelectionChangeBound), t.on("selection:cleared", this.handleSelectionClearedBound);
4282
+ }
4283
+ /**
4284
+ * Отключает мультивыделение при входе в режим редактирования текста.
4285
+ */
4286
+ _handleTextEditingEntered(t) {
4287
+ this._applySelectionKey({ selectionKey: null });
4288
+ }
4289
+ /**
4290
+ * Восстанавливает мультивыделение после выхода из редактирования текста.
4291
+ */
4292
+ _handleTextEditingExited(t) {
4293
+ const { selectionKey: e } = this;
4294
+ this._applySelectionKey({ selectionKey: e });
4295
+ }
4296
+ /**
4297
+ * При массовом выделении объектов удаляет из него залоченные.
4298
+ * @param params - параметры события
4299
+ * @param params.selected - массив выделенных объектов
4300
+ * @param params.e - событие указателя (опционально)
4301
+ */
4302
+ _filterLockedSelection({ selected: t, e }) {
4303
+ const { editor: n } = this, { canvas: s } = n;
4304
+ if (!(e instanceof MouseEvent)) return;
4305
+ const o = s.getActiveObject();
4306
+ if (!o) return;
4307
+ const i = ft._collectSelectionObjects({ activeObject: o });
4308
+ if (i.length <= 1) return;
4309
+ const { lockedObjects: a, unlockedObjects: r } = ft._splitLockedObjects({ objects: i });
4310
+ if (a.length !== 0) {
4311
+ if (r.length > 0) {
4312
+ const c = t != null ? t : [];
4313
+ if (ft._shouldKeepLockedSelection({
4314
+ addedObjects: c,
4315
+ currentSelection: i,
4316
+ pointerEvent: e
4317
+ })) {
4318
+ this._applySelectionObjects({ objects: a }), s.requestRenderAll();
4319
+ return;
4320
+ }
4321
+ this._applySelectionObjects({ objects: r }), s.requestRenderAll();
4322
+ return;
4323
+ }
4324
+ this._applySelectionObjects({ objects: a }), s.requestRenderAll();
4325
+ }
4326
+ }
4327
+ /**
4328
+ * Объединяет выделение при выделении областью с зажатым Ctrl/Cmd.
4329
+ * @param params - параметры события
4330
+ * @param params.selected - массив новых объектов выделения
4331
+ * @param params.e - событие указателя (опционально)
4332
+ */
4333
+ _handleSelectionMerge({
4334
+ selected: t,
4335
+ e
4336
+ }) {
4337
+ const { canvas: n } = this.editor, { lastSelection: s, isCtrlSelectionBoxActive: o, isSelectionMergeInProgress: i } = this;
4338
+ if (i || !o || !(e instanceof MouseEvent)) return;
4339
+ const { ctrlKey: a, metaKey: r } = e;
4340
+ if (!!!(a || r) || s.length === 0 || t.length === 0) return;
4341
+ const l = n.getActiveObject(), d = ft._collectSelectionObjects({ activeObject: l });
4342
+ if (d.length === 0) return;
4343
+ const u = s, g = ft._isSelectionLockedOnly({ objects: u }) ? ft._filterLockedSelectionObjects({ objects: d }) : d, m = ft._mergeSelections({
4344
+ baseSelection: u,
4345
+ addedSelection: g
4346
+ });
4347
+ if (ft._areSelectionsEqual({
4348
+ left: m,
4349
+ right: d
4350
+ })) {
4351
+ this.isCtrlSelectionBoxActive = !1;
4352
+ return;
4353
+ }
4354
+ this.isSelectionMergeInProgress = !0, this._applySelectionObjects({ objects: m }), n.requestRenderAll(), this.isSelectionMergeInProgress = !1, this.isCtrlSelectionBoxActive = !1;
4355
+ }
4356
+ /**
4357
+ * Обрабатывает начало выделения областью при зажатом Ctrl/Cmd.
4358
+ * @param options - объект события fabric
4359
+ */
4360
+ _handleSelectionBoxStart({ e: t, target: e }) {
4361
+ if (!(t instanceof MouseEvent) || e) return;
4362
+ const { editor: n } = this, { canvas: s, textManager: o } = n;
4363
+ if (!s.selection || o.isTextEditingActive) return;
4364
+ const { ctrlKey: i, metaKey: a } = t;
4365
+ if (!!!(i || a)) return;
4366
+ const c = s.getActiveObject(), l = ft._collectSelectionObjects({ activeObject: c });
4367
+ this.lastSelection = l.slice(), this.isCtrlSelectionBoxActive = l.length > 0;
4368
+ }
4369
+ /**
4370
+ * Сбрасывает флаг выделения областью при зажатом Ctrl/Cmd.
4371
+ * @param options - объект события fabric
4372
+ */
4373
+ _handleSelectionBoxEnd({ e: t }) {
4374
+ t instanceof MouseEvent && (this.isCtrlSelectionBoxActive = !1);
4375
+ }
4376
+ /**
4377
+ * Сохраняет текущее выделение для возможного восстановления.
4378
+ */
4379
+ _handleSelectionChange() {
4380
+ const { canvas: t } = this.editor, e = t.getActiveObject(), n = ft._collectSelectionObjects({ activeObject: e });
4381
+ this.lastSelection = n.slice();
4382
+ }
4383
+ /**
4384
+ * Восстанавливает выделение при клике по пустой области с зажатым Ctrl/Cmd.
4385
+ * @param params - параметры события
4386
+ * @param params.e - событие указателя (опционально)
4387
+ */
4388
+ _handleSelectionCleared({ e: t }) {
4389
+ const { lastSelection: e } = this;
4390
+ if (e.length === 0) return;
4391
+ if (!(t instanceof MouseEvent)) {
4392
+ this.lastSelection = [];
4393
+ return;
4394
+ }
4395
+ const { ctrlKey: n, metaKey: s } = t;
4396
+ if (!!!(n || s)) {
4397
+ this.lastSelection = [];
4398
+ return;
4399
+ }
4400
+ const i = this._filterExistingObjects({ objects: e });
4401
+ if (i.length === 0) {
4402
+ this.lastSelection = [];
4403
+ return;
4404
+ }
4405
+ this._applySelectionObjects({ objects: i });
4406
+ }
4407
+ /**
4408
+ * Собирает объекты активного выделения.
4409
+ */
4410
+ static _collectSelectionObjects({ activeObject: t }) {
4411
+ return t ? t instanceof X ? t.getObjects() : [t] : [];
4412
+ }
4413
+ /**
4414
+ * Проверяет, что выборка состоит только из заблокированных объектов.
4415
+ */
4416
+ static _isSelectionLockedOnly({ objects: t }) {
4417
+ if (t.length === 0) return !1;
4418
+ for (const e of t)
4419
+ if (!e.locked) return !1;
4420
+ return !0;
4421
+ }
4422
+ /**
4423
+ * Оставляет только заблокированные объекты в выборке.
4424
+ */
4425
+ static _filterLockedSelectionObjects({ objects: t }) {
4426
+ const e = [];
4427
+ for (const n of t)
4428
+ n.locked && e.push(n);
4429
+ return e;
4430
+ }
4431
+ /**
4432
+ * Фильтрует объекты, которые ещё существуют на канвасе.
4433
+ */
4434
+ _filterExistingObjects({ objects: t }) {
4435
+ const { canvasManager: e } = this.editor, n = e.getObjects(), s = [];
4436
+ for (const o of t)
4437
+ n.includes(o) && s.push(o);
4438
+ return s;
4439
+ }
4440
+ /**
4441
+ * Проверяет равенство двух выборок без учёта порядка.
4442
+ */
4443
+ static _areSelectionsEqual({
4444
+ left: t,
4445
+ right: e
4446
+ }) {
4447
+ if (t.length !== e.length) return !1;
4448
+ if (t.length === 0) return !0;
4449
+ for (const n of t)
4450
+ if (!e.includes(n)) return !1;
4451
+ return !0;
4452
+ }
4453
+ /**
4454
+ * Объединяет список объектов без дубликатов.
4455
+ */
4456
+ static _mergeSelections({
4457
+ baseSelection: t,
4458
+ addedSelection: e
4459
+ }) {
4460
+ const n = [];
4461
+ for (const s of t)
4462
+ n.includes(s) || n.push(s);
4463
+ for (const s of e)
4464
+ n.includes(s) || n.push(s);
4465
+ return n;
4466
+ }
4467
+ /**
4468
+ * Делит объекты на заблокированные и доступные для редактирования.
4469
+ */
4470
+ static _splitLockedObjects({
4471
+ objects: t
4472
+ }) {
4473
+ const e = [], n = [];
4474
+ for (const s of t) {
4475
+ if (s.locked) {
4476
+ e.push(s);
4477
+ continue;
4478
+ }
4479
+ n.push(s);
4480
+ }
4481
+ return { lockedObjects: e, unlockedObjects: n };
4482
+ }
4483
+ /**
4484
+ * Определяет, нужно ли сохранить только заблокированное выделение при попытке добавить обычные объекты.
4485
+ */
4486
+ static _shouldKeepLockedSelection({
4487
+ addedObjects: t,
4488
+ currentSelection: e,
4489
+ pointerEvent: n
4490
+ }) {
4491
+ const { ctrlKey: s, metaKey: o } = n;
4492
+ if (!!!(s || o) || t.length === 0) return !1;
4493
+ let a = !1;
4494
+ for (const c of t)
4495
+ if (!c.locked) {
4496
+ a = !0;
4497
+ break;
4498
+ }
4499
+ if (!a) return !1;
4500
+ const r = [];
4501
+ for (const c of e)
4502
+ t.includes(c) || r.push(c);
4503
+ if (r.length === 0) return !1;
4504
+ for (const c of r)
4505
+ if (!c.locked) return !1;
4506
+ return !0;
4507
+ }
4508
+ /**
4509
+ * Применяет выделение и блокирует его, если в нём есть заблокированные объекты.
4510
+ */
4511
+ _applySelectionObjects({ objects: t }) {
4512
+ const { editor: e } = this, { canvas: n, objectLockManager: s } = e, o = this._filterExistingObjects({ objects: t });
4513
+ if (o.length === 0) return;
4514
+ if (o.length === 1) {
4515
+ n.setActiveObject(o[0]);
4516
+ return;
4517
+ }
4518
+ const i = new X(o, { canvas: n });
4519
+ ft._hasLockedObjects({ objects: o }) && s.lockObject({
4520
+ object: i,
4521
+ skipInnerObjects: !0,
4522
+ withoutSave: !0
4523
+ }), n.setActiveObject(i);
4524
+ }
4525
+ /**
4526
+ * Проверяет, есть ли среди объектов заблокированные.
4527
+ */
4528
+ static _hasLockedObjects({ objects: t }) {
4529
+ for (const e of t)
4530
+ if (e.locked) return !0;
4531
+ return !1;
4532
+ }
4533
+ /**
4534
+ * Определяет ключи для мультивыделения.
4535
+ */
4536
+ _resolveSelectionKey() {
4537
+ const { options: t } = this.editor, { selectionKey: e } = t;
4538
+ return e !== void 0 ? e : ["ctrlKey", "metaKey"];
4539
+ }
4308
4540
  }
4309
- class We {
4541
+ class Ue {
4310
4542
  constructor({ editor: t }) {
4311
4543
  this.editor = t;
4312
4544
  }
@@ -4353,7 +4585,7 @@ class We {
4353
4585
  n || o.suspendHistory();
4354
4586
  const r = [];
4355
4587
  if (a.forEach((l) => {
4356
- if (We._isUngroupableGroup(l)) {
4588
+ if (Ue._isUngroupableGroup(l)) {
4357
4589
  const d = this._handleGroupDeletion(l);
4358
4590
  r.push(...d);
4359
4591
  return;
@@ -4368,7 +4600,7 @@ class We {
4368
4600
  return s.fire("editor:objects-deleted", c), c;
4369
4601
  }
4370
4602
  }
4371
- const Dt = {
4603
+ const Lt = {
4372
4604
  IMAGE_MANAGER: {
4373
4605
  /**
4374
4606
  * Некорректный Content-Type изображения
@@ -4473,7 +4705,7 @@ const Dt = {
4473
4705
  APPLY_FAILED: "TEMPLATE_APPLY_FAILED"
4474
4706
  }
4475
4707
  };
4476
- class te {
4708
+ class ee {
4477
4709
  constructor({ editor: t }) {
4478
4710
  this._buffer = [], this.editor = t;
4479
4711
  }
@@ -4500,7 +4732,7 @@ class te {
4500
4732
  * @fires editor:error
4501
4733
  */
4502
4734
  emitError({ origin: t = "ImageEditor", method: e = "Unknown Method", code: n, data: s, message: o }) {
4503
- if (!te.isValidErrorCode(n)) {
4735
+ if (!ee.isValidErrorCode(n)) {
4504
4736
  console.warn("Неизвестный код ошибки: ", { code: n, origin: t, method: e });
4505
4737
  return;
4506
4738
  }
@@ -4529,7 +4761,7 @@ class te {
4529
4761
  * @fires editor:warning
4530
4762
  */
4531
4763
  emitWarning({ origin: t = "ImageEditor", method: e = "Unknown Method", code: n, message: s, data: o }) {
4532
- if (!te.isValidErrorCode(n)) {
4764
+ if (!ee.isValidErrorCode(n)) {
4533
4765
  console.warn("Неизвестный код предупреждения: ", { code: n, origin: t, method: e });
4534
4766
  return;
4535
4767
  }
@@ -4552,7 +4784,7 @@ class te {
4552
4784
  * @returns true, если код допустим, иначе false
4553
4785
  */
4554
4786
  static isValidErrorCode(t) {
4555
- return t ? Object.values(Dt).some((e) => Object.values(e).includes(t)) : !1;
4787
+ return t ? Object.values(Lt).some((e) => Object.values(e).includes(t)) : !1;
4556
4788
  }
4557
4789
  }
4558
4790
  class Ss {
@@ -4648,16 +4880,16 @@ const ws = ({ textbox: h }) => {
4648
4880
  start: Math.min(t, e),
4649
4881
  end: Math.max(t, e)
4650
4882
  };
4651
- }, As = ({ textbox: h }) => {
4883
+ }, js = ({ textbox: h }) => {
4652
4884
  var e, n;
4653
4885
  const t = (n = (e = h.text) == null ? void 0 : e.length) != null ? n : 0;
4654
4886
  return t <= 0 ? null : { start: 0, end: t };
4655
- }, js = ({ textbox: h, range: t }) => {
4887
+ }, As = ({ textbox: h, range: t }) => {
4656
4888
  var n, s;
4657
4889
  if (!t) return !1;
4658
4890
  const e = (s = (n = h.text) == null ? void 0 : n.length) != null ? s : 0;
4659
4891
  return e <= 0 ? !1 : t.start <= 0 && t.end >= e;
4660
- }, Se = ({
4892
+ }, we = ({
4661
4893
  textbox: h,
4662
4894
  styles: t,
4663
4895
  range: e
@@ -4665,7 +4897,7 @@ const ws = ({ textbox: h }) => {
4665
4897
  if (!t || !Object.keys(t).length) return !1;
4666
4898
  const { start: n, end: s } = e;
4667
4899
  return s <= n ? !1 : (h.setSelectionStyles(t, n, s), !0);
4668
- }, cn = ({
4900
+ }, ln = ({
4669
4901
  textbox: h,
4670
4902
  range: t,
4671
4903
  property: e
@@ -4679,11 +4911,11 @@ const ws = ({ textbox: h }) => {
4679
4911
  );
4680
4912
  if (n.length)
4681
4913
  return (s = n[0]) == null ? void 0 : s[e];
4682
- }, _e = ({ strokeColor: h, width: t }) => t <= 0 ? null : h != null ? h : "#000000", xe = ({ width: h = 0 }) => h ? Math.max(0, h) : 0, we = ({ value: h }) => typeof h == "string" ? h.toLocaleUpperCase() : "", Mt = ({
4914
+ }, xe = ({ strokeColor: h, width: t }) => t <= 0 ? null : h != null ? h : "#000000", Re = ({ width: h = 0 }) => h ? Math.max(0, h) : 0, je = ({ value: h }) => typeof h == "string" ? h.toLocaleUpperCase() : "", St = ({
4683
4915
  value: h,
4684
4916
  min: t,
4685
4917
  max: e
4686
- }) => Math.min(Math.max(h, t), e), Ut = class Ut extends ct {
4918
+ }) => Math.min(Math.max(h, t), e), Yt = class Yt extends ct {
4687
4919
  constructor(t, e = {}) {
4688
4920
  var n, s, o, i, a, r, c, l, d, u;
4689
4921
  super(t, e), this.backgroundOpacity = (n = e.backgroundOpacity) != null ? n : 1, this.lineFontDefaults = (s = e.lineFontDefaults) != null ? s : void 0, this.paddingTop = (o = e.paddingTop) != null ? o : 0, this.paddingRight = (i = e.paddingRight) != null ? i : 0, this.paddingBottom = (a = e.paddingBottom) != null ? a : 0, this.paddingLeft = (r = e.paddingLeft) != null ? r : 0, this.radiusTopLeft = (c = e.radiusTopLeft) != null ? c : 0, this.radiusTopRight = (l = e.radiusTopRight) != null ? l : 0, this.radiusBottomRight = (d = e.radiusBottomRight) != null ? d : 0, this.radiusBottomLeft = (u = e.radiusBottomLeft) != null ? u : 0, this._roundDimensions();
@@ -4708,7 +4940,7 @@ const ws = ({ textbox: h }) => {
4708
4940
  }
4709
4941
  _getTransformedDimensions(t = {}) {
4710
4942
  const { width: e, height: n } = this._getBackgroundDimensions();
4711
- return super._getTransformedDimensions(Ot(F({}, t), {
4943
+ return super._getTransformedDimensions(Et(F({}, t), {
4712
4944
  width: e,
4713
4945
  height: n
4714
4946
  }));
@@ -4718,7 +4950,7 @@ const ws = ({ textbox: h }) => {
4718
4950
  */
4719
4951
  toObject(t = []) {
4720
4952
  const e = super.toObject(t);
4721
- return Ot(F({}, e), {
4953
+ return Et(F({}, e), {
4722
4954
  backgroundOpacity: this.backgroundOpacity,
4723
4955
  lineFontDefaults: this.lineFontDefaults,
4724
4956
  paddingTop: this.paddingTop,
@@ -4736,7 +4968,7 @@ const ws = ({ textbox: h }) => {
4736
4968
  const e = this._getEffectiveBackgroundFill();
4737
4969
  if (e && e) {
4738
4970
  const o = this._getPadding(), i = (n = this.width) != null ? n : 0, a = (s = this.height) != null ? s : 0, r = i + o.left + o.right, c = a + o.top + o.bottom, l = this._getCornerRadii({ width: r, height: c }), d = this._getLeftOffset() - o.left, u = this._getTopOffset() - o.top;
4739
- t.save(), Ut._renderRoundedRect({
4971
+ t.save(), Yt._renderRoundedRect({
4740
4972
  ctx: t,
4741
4973
  height: c,
4742
4974
  left: d,
@@ -4771,42 +5003,42 @@ const ws = ({ textbox: h }) => {
4771
5003
  l += v;
4772
5004
  continue;
4773
5005
  }
4774
- const j = c[p], b = v / o, T = this._getLineLeftOffset(p);
4775
- let S = 0, M = 0, w = this.getValueOfPropertyAt(p, 0, e), C = this._getDecorationColorAt(p, 0), A = this.getValueOfPropertyAt(p, 0, "textDecorationThickness"), I = w, O = C, k = A;
4776
- const D = l + b * (1 - r);
5006
+ const A = c[p], b = v / o, O = this._getLineLeftOffset(p);
5007
+ let S = 0, M = 0, w = this.getValueOfPropertyAt(p, 0, e), C = this._getDecorationColorAt(p, 0), j = this.getValueOfPropertyAt(p, 0, "textDecorationThickness"), I = w, T = C, k = j;
5008
+ const _ = l + b * (1 - r);
4777
5009
  let W = this.getHeightOfChar(p, 0), E = this.getValueOfPropertyAt(p, 0, "deltaY");
4778
- for (let B = 0, P = j.length; B < P; B += 1) {
5010
+ for (let B = 0, z = A.length; B < z; B += 1) {
4779
5011
  const x = this.__charBounds[p][B];
4780
- I = this.getValueOfPropertyAt(p, B, e), O = this._getDecorationColorAt(p, B), k = this.getValueOfPropertyAt(p, B, "textDecorationThickness");
4781
- const _ = this.getHeightOfChar(p, B), R = this.getValueOfPropertyAt(p, B, "deltaY");
4782
- if (u && I && O) {
5012
+ I = this.getValueOfPropertyAt(p, B, e), T = this._getDecorationColorAt(p, B), k = this.getValueOfPropertyAt(p, B, "textDecorationThickness");
5013
+ const D = this.getHeightOfChar(p, B), R = this.getValueOfPropertyAt(p, B, "deltaY");
5014
+ if (u && I && T) {
4783
5015
  const N = s * k / 1e3;
4784
5016
  t.save(), t.fillStyle = C, t.translate(x.renderLeft, x.renderTop), t.rotate(x.angle), t.fillRect(
4785
5017
  -x.kernedWidth / 2,
4786
- g * _ + R - m * N,
5018
+ g * D + R - m * N,
4787
5019
  x.kernedWidth,
4788
5020
  N
4789
5021
  ), t.restore();
4790
- } else if ((I !== w || O !== C || _ !== W || k !== A || R !== E) && M > 0) {
4791
- const N = s * A / 1e3;
4792
- let K = d + T + S;
4793
- n === "rtl" && (K = a - K - M), w && C && A && (t.fillStyle = C, t.fillRect(
5022
+ } else if ((I !== w || T !== C || D !== W || k !== j || R !== E) && M > 0) {
5023
+ const N = s * j / 1e3;
5024
+ let K = d + O + S;
5025
+ n === "rtl" && (K = a - K - M), w && C && j && (t.fillStyle = C, t.fillRect(
4794
5026
  K,
4795
- D + g * W + E - m * N,
5027
+ _ + g * W + E - m * N,
4796
5028
  M,
4797
5029
  N
4798
- )), S = x.left, M = x.width, w = I, A = k, C = O, W = _, E = R;
5030
+ )), S = x.left, M = x.width, w = I, j = k, C = T, W = D, E = R;
4799
5031
  } else
4800
5032
  M += x.kernedWidth;
4801
5033
  }
4802
- let L = d + T + S;
4803
- n === "rtl" && (L = a - L - M), t.fillStyle = O;
4804
- const z = s * k / 1e3;
4805
- I && O && k && t.fillRect(
5034
+ let L = d + O + S;
5035
+ n === "rtl" && (L = a - L - M), t.fillStyle = T;
5036
+ const P = s * k / 1e3;
5037
+ I && T && k && t.fillRect(
4806
5038
  L,
4807
- D + g * W + E - m * z,
5039
+ _ + g * W + E - m * P,
4808
5040
  M - f,
4809
- z
5041
+ P
4810
5042
  ), l += v;
4811
5043
  }
4812
5044
  this._removeShadow(t);
@@ -4815,9 +5047,9 @@ const ws = ({ textbox: h }) => {
4815
5047
  * Возвращает цвет линии декорации для символа, учитывая обводку и заливку.
4816
5048
  */
4817
5049
  _getDecorationColorAt(t, e) {
4818
- const n = this.getValueOfPropertyAt(t, e, "strokeWidth"), s = xe({
5050
+ const n = this.getValueOfPropertyAt(t, e, "strokeWidth"), s = Re({
4819
5051
  width: typeof n == "number" && Number.isFinite(n) ? n : 0
4820
- }), o = this.getValueOfPropertyAt(t, e, "stroke"), i = o == null ? null : _e({ strokeColor: o, width: s });
5052
+ }), o = this.getValueOfPropertyAt(t, e, "stroke"), i = o == null ? null : xe({ strokeColor: o, width: s });
4821
5053
  if (s > 0 && i != null)
4822
5054
  return i;
4823
5055
  const a = this.getValueOfPropertyAt(t, e, "fill");
@@ -4835,10 +5067,10 @@ const ws = ({ textbox: h }) => {
4835
5067
  var i, a, r, c;
4836
5068
  const n = t / 2, s = e / 2, o = Math.min(n, s);
4837
5069
  return {
4838
- bottomLeft: Mt({ value: (i = this.radiusBottomLeft) != null ? i : 0, min: 0, max: o }),
4839
- bottomRight: Mt({ value: (a = this.radiusBottomRight) != null ? a : 0, min: 0, max: o }),
4840
- topLeft: Mt({ value: (r = this.radiusTopLeft) != null ? r : 0, min: 0, max: o }),
4841
- topRight: Mt({ value: (c = this.radiusTopRight) != null ? c : 0, min: 0, max: o })
5070
+ bottomLeft: St({ value: (i = this.radiusBottomLeft) != null ? i : 0, min: 0, max: o }),
5071
+ bottomRight: St({ value: (a = this.radiusBottomRight) != null ? a : 0, min: 0, max: o }),
5072
+ topLeft: St({ value: (r = this.radiusTopLeft) != null ? r : 0, min: 0, max: o }),
5073
+ topRight: St({ value: (c = this.radiusTopRight) != null ? c : 0, min: 0, max: o })
4842
5074
  };
4843
5075
  }
4844
5076
  _getPadding() {
@@ -4854,12 +5086,12 @@ const ws = ({ textbox: h }) => {
4854
5086
  var s;
4855
5087
  const t = this.backgroundColor;
4856
5088
  if (!t) return null;
4857
- const e = Mt({ value: (s = this.backgroundOpacity) != null ? s : 1, min: 0, max: 1 });
5089
+ const e = St({ value: (s = this.backgroundOpacity) != null ? s : 1, min: 0, max: 1 });
4858
5090
  let n;
4859
5091
  try {
4860
- n = new xn(t);
5092
+ n = new Rn(t);
4861
5093
  } catch (o) {
4862
- return te.emitError({
5094
+ return ee.emitError({
4863
5095
  origin: "BackgroundTextbox",
4864
5096
  method: "_getEffectiveBackgroundFill",
4865
5097
  code: "INVALID_COLOR_VALUE",
@@ -4882,7 +5114,7 @@ const ws = ({ textbox: h }) => {
4882
5114
  topRight: l,
4883
5115
  bottomRight: d,
4884
5116
  bottomLeft: u
4885
- } = s, f = Mt({ value: c, min: 0, max: i }), g = Mt({ value: l, min: 0, max: i }), m = Mt({ value: d, min: 0, max: i }), p = Mt({ value: u, min: 0, max: i });
5117
+ } = s, f = St({ value: c, min: 0, max: i }), g = St({ value: l, min: 0, max: i }), m = St({ value: d, min: 0, max: i }), p = St({ value: u, min: 0, max: i });
4886
5118
  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();
4887
5119
  }
4888
5120
  /**
@@ -4896,7 +5128,7 @@ const ws = ({ textbox: h }) => {
4896
5128
  n !== t && (this.width = Math.max(0, n)), s !== e && (this.height = Math.max(0, s));
4897
5129
  }
4898
5130
  };
4899
- Ut.type = "background-textbox", Ut.cacheProperties = [
5131
+ Yt.type = "background-textbox", Yt.cacheProperties = [
4900
5132
  ...Array.isArray(ct.cacheProperties) ? ct.cacheProperties : [],
4901
5133
  "backgroundColor",
4902
5134
  "backgroundOpacity",
@@ -4909,7 +5141,7 @@ Ut.type = "background-textbox", Ut.cacheProperties = [
4909
5141
  "radiusTopRight",
4910
5142
  "radiusBottomRight",
4911
5143
  "radiusBottomLeft"
4912
- ], Ut.stateProperties = [
5144
+ ], Yt.stateProperties = [
4913
5145
  ...Array.isArray(ct.stateProperties) ? ct.stateProperties : [],
4914
5146
  "backgroundColor",
4915
5147
  "backgroundOpacity",
@@ -4923,11 +5155,11 @@ Ut.type = "background-textbox", Ut.cacheProperties = [
4923
5155
  "radiusBottomRight",
4924
5156
  "radiusBottomLeft"
4925
5157
  ];
4926
- let ye = Ut;
5158
+ let ve = Yt;
4927
5159
  const Cs = () => {
4928
5160
  var h;
4929
- (h = Qe) != null && h.setClass && Qe.setClass(ye, "background-textbox");
4930
- }, it = 0.01, ln = ({
5161
+ (h = $e) != null && h.setClass && $e.setClass(ve, "background-textbox");
5162
+ }, it = 0.01, dn = ({
4931
5163
  textbox: h,
4932
5164
  lineIndices: t,
4933
5165
  updates: e
@@ -4988,7 +5220,7 @@ const Cs = () => {
4988
5220
  lineStyles: l,
4989
5221
  changed: d
4990
5222
  };
4991
- }, dn = ({
5223
+ }, hn = ({
4992
5224
  lineFontDefaults: h
4993
5225
  }) => {
4994
5226
  if (!h) return;
@@ -5001,7 +5233,7 @@ const Cs = () => {
5001
5233
  s && (t[n] = F({}, s));
5002
5234
  }
5003
5235
  return t;
5004
- }, hn = ({
5236
+ }, un = ({
5005
5237
  lineFontDefaults: h,
5006
5238
  scale: t
5007
5239
  }) => {
@@ -5019,7 +5251,7 @@ const Cs = () => {
5019
5251
  }
5020
5252
  if (!(!n || !s))
5021
5253
  return e;
5022
- }, Ts = ({
5254
+ }, Os = ({
5023
5255
  textbox: h
5024
5256
  }) => {
5025
5257
  var o, i;
@@ -5033,7 +5265,7 @@ const Cs = () => {
5033
5265
  s = l + 1, n.push({ start: c, end: l });
5034
5266
  }
5035
5267
  return n;
5036
- }, Os = ({
5268
+ }, Ts = ({
5037
5269
  range: h,
5038
5270
  text: t
5039
5271
  }) => {
@@ -5046,7 +5278,7 @@ const Cs = () => {
5046
5278
  textbox: h,
5047
5279
  range: t
5048
5280
  }) => {
5049
- const e = Ts({ textbox: h });
5281
+ const e = Os({ textbox: h });
5050
5282
  if (!e.length) return t;
5051
5283
  let { start: n } = t, { end: s } = t;
5052
5284
  for (let o = 0; o < e.length; o += 1) {
@@ -5056,7 +5288,7 @@ const Cs = () => {
5056
5288
  t.end > a && t.start < r && (n = Math.min(n, a), s = Math.max(s, r));
5057
5289
  }
5058
5290
  return { start: n, end: s };
5059
- }, Ds = ({
5291
+ }, _s = ({
5060
5292
  textbox: h,
5061
5293
  range: t
5062
5294
  }) => {
@@ -5086,7 +5318,7 @@ const Cs = () => {
5086
5318
  n <= u && s >= f && i.push(l), a = f + 1;
5087
5319
  }
5088
5320
  return i;
5089
- }, _s = ({
5321
+ }, Ds = ({
5090
5322
  previous: h,
5091
5323
  next: t
5092
5324
  }) => {
@@ -5139,10 +5371,10 @@ const Cs = () => {
5139
5371
  return !1;
5140
5372
  let a = 0;
5141
5373
  return s < t ? a = t - s : o > e && (a = e - o), Math.abs(a) <= it ? !1 : (h.set({ left: ((d = h.left) != null ? d : 0) + a }), !0);
5142
- }, un = ({
5374
+ }, fn = ({
5143
5375
  rawValue: h,
5144
5376
  calculatedValue: t
5145
- }) => typeof h == "number" ? h : typeof t == "number" ? t : 0, fn = ({
5377
+ }) => typeof h == "number" ? h : typeof t == "number" ? t : 0, gn = ({
5146
5378
  stylesList: h
5147
5379
  }) => {
5148
5380
  const t = h.length;
@@ -5161,13 +5393,13 @@ const Cs = () => {
5161
5393
  if (s !== void 0 || o !== void 0 || i !== void 0 || a !== void 0 || r !== void 0 || c !== void 0) return !0;
5162
5394
  }
5163
5395
  return !1;
5164
- }, Et = ({
5396
+ }, _t = ({
5165
5397
  textbox: h
5166
5398
  }) => {
5167
- const { width: t, height: e, calcTextWidth: n, calcTextHeight: s } = h, o = typeof n == "function" ? n.call(h) : void 0, i = typeof s == "function" ? s.call(h) : void 0, a = un({
5399
+ const { width: t, height: e, calcTextWidth: n, calcTextHeight: s } = h, o = typeof n == "function" ? n.call(h) : void 0, i = typeof s == "function" ? s.call(h) : void 0, a = fn({
5168
5400
  rawValue: t,
5169
5401
  calculatedValue: o
5170
- }), r = un({
5402
+ }), r = fn({
5171
5403
  rawValue: e,
5172
5404
  calculatedValue: i
5173
5405
  }), c = Number.isFinite(a) ? Math.round(a) : null, l = Number.isFinite(r) ? Math.round(r) : null, d = {};
@@ -5194,7 +5426,7 @@ class rt {
5194
5426
  if (!rt._isTextbox(s) || this.lineDefaultsSyncing.has(s)) return;
5195
5427
  const { text: o = "", uppercase: i, autoExpand: a } = s, r = !!i, c = a !== !1, l = o.toLocaleLowerCase();
5196
5428
  if (r) {
5197
- const f = we({ value: l });
5429
+ const f = je({ value: l });
5198
5430
  f !== o && s.set({ text: f }), s.textCaseRaw = l;
5199
5431
  } else
5200
5432
  s.textCaseRaw = o;
@@ -5202,7 +5434,7 @@ class rt {
5202
5434
  let d = !1;
5203
5435
  c && (d = this._autoExpandTextboxWidth(s));
5204
5436
  let u = !1;
5205
- d || (u = Et({ textbox: s })), (d || u) && (s.setCoords(), s.dirty = !0), this._syncLineFontDefaultsOnTextChanged({ textbox: s });
5437
+ d || (u = _t({ textbox: s })), (d || u) && (s.setCoords(), s.dirty = !0), this._syncLineFontDefaultsOnTextChanged({ textbox: s });
5206
5438
  }, this._handleTextEditingExited = (n) => {
5207
5439
  var c, l, d;
5208
5440
  const { target: s } = n;
@@ -5214,13 +5446,13 @@ class rt {
5214
5446
  s.textCaseRaw = u;
5215
5447
  } else
5216
5448
  s.textCaseRaw = o;
5217
- Et({ textbox: s }) && (s.setCoords(), s.dirty = !0, this.canvas.requestRenderAll()), s.locked || s.set({
5449
+ _t({ textbox: s }) && (s.setCoords(), s.dirty = !0, this.canvas.requestRenderAll()), s.locked || s.set({
5218
5450
  lockMovementX: !1,
5219
5451
  lockMovementY: !1
5220
5452
  });
5221
5453
  const { historyManager: r } = this.editor;
5222
5454
  r.endAction({ reason: "text-edit" }), r.scheduleSaveState({
5223
- delayMs: ds,
5455
+ delayMs: hs,
5224
5456
  reason: "text-edit"
5225
5457
  });
5226
5458
  }, this._handleObjectResizing = (n) => {
@@ -5237,10 +5469,10 @@ class rt {
5237
5469
  s.set({ width: m });
5238
5470
  const { width: p = 0 } = s, y = g - p;
5239
5471
  if (y !== 0 && o && o.corner === "ml") {
5240
- const j = ((l = s.angle) != null ? l : 0) * Math.PI / 180, b = Math.cos(j), T = Math.sin(j), S = (d = s.scaleX) != null ? d : 1, M = y * S;
5472
+ const A = ((l = s.angle) != null ? l : 0) * Math.PI / 180, b = Math.cos(A), O = Math.sin(A), S = (d = s.scaleX) != null ? d : 1, M = y * S;
5241
5473
  s.set({
5242
5474
  left: ((u = s.left) != null ? u : 0) + M * b,
5243
- top: ((f = s.top) != null ? f : 0) + M * T
5475
+ top: ((f = s.top) != null ? f : 0) + M * O
5244
5476
  });
5245
5477
  }
5246
5478
  }
@@ -5251,7 +5483,7 @@ class rt {
5251
5483
  event: i != null ? i : null
5252
5484
  });
5253
5485
  }, this._handleObjectScaling = (n) => {
5254
- var ne, ve, se, ie, oe, Rt, be, ae, Ht, Zt, Gt, Vt, Xt;
5486
+ var se, be, ie, oe, ae, kt, Me, re, Zt, Gt, Vt, Xt, Kt;
5255
5487
  const { target: s, transform: o } = n;
5256
5488
  if (s instanceof X || !rt._isTextbox(s) || !o) return;
5257
5489
  s.isScaling = !0;
@@ -5263,21 +5495,21 @@ class rt {
5263
5495
  baseRadii: d,
5264
5496
  baseStyles: u,
5265
5497
  baseLineFontDefaults: f
5266
- } = i, g = typeof ((ne = o.original) == null ? void 0 : ne.width) == "number" ? o.original.width : void 0, m = typeof ((ve = o.original) == null ? void 0 : ve.left) == "number" ? o.original.left : void 0, p = g != null ? g : a, y = m != null ? m : r, v = (se = o.corner) != null ? se : "", j = (ie = o.action) != null ? ie : "", b = ["ml", "mr"].includes(v) || j === "scaleX", T = ["mt", "mb"].includes(v) || j === "scaleY", S = ["tl", "tr", "bl", "br"].includes(v) || j === "scale", M = S || T;
5267
- if (!b && !T && !S) return;
5268
- const w = Math.abs((Rt = (oe = s.scaleX) != null ? oe : o.scaleX) != null ? Rt : 1) || 1, C = Math.abs((ae = (be = s.scaleY) != null ? be : o.scaleY) != null ? ae : 1) || 1, A = Math.max(1, p * w), I = Math.max(1, Math.round(A)), O = Math.max(1, c * C), {
5498
+ } = i, g = typeof ((se = o.original) == null ? void 0 : se.width) == "number" ? o.original.width : void 0, m = typeof ((be = o.original) == null ? void 0 : be.left) == "number" ? o.original.left : void 0, p = g != null ? g : a, y = m != null ? m : r, v = (ie = o.corner) != null ? ie : "", A = (oe = o.action) != null ? oe : "", b = ["ml", "mr"].includes(v) || A === "scaleX", O = ["mt", "mb"].includes(v) || A === "scaleY", S = ["tl", "tr", "bl", "br"].includes(v) || A === "scale", M = S || O;
5499
+ if (!b && !O && !S) return;
5500
+ const w = Math.abs((kt = (ae = s.scaleX) != null ? ae : o.scaleX) != null ? kt : 1) || 1, C = Math.abs((re = (Me = s.scaleY) != null ? Me : o.scaleY) != null ? re : 1) || 1, j = Math.max(1, p * w), I = Math.max(1, Math.round(j)), T = Math.max(1, c * C), {
5269
5501
  paddingTop: k = 0,
5270
- paddingRight: D = 0,
5502
+ paddingRight: _ = 0,
5271
5503
  paddingBottom: W = 0,
5272
5504
  paddingLeft: E = 0,
5273
5505
  radiusTopLeft: L = 0,
5274
- radiusTopRight: z = 0,
5506
+ radiusTopRight: P = 0,
5275
5507
  radiusBottomRight: B = 0,
5276
- radiusBottomLeft: P = 0,
5508
+ radiusBottomLeft: z = 0,
5277
5509
  fontSize: x,
5278
- width: _,
5510
+ width: D,
5279
5511
  originX: R = "left"
5280
- } = s, N = S || T, K = S || T, H = N ? {
5512
+ } = s, N = S || O, K = S || O, H = N ? {
5281
5513
  top: Math.max(0, l.top * C),
5282
5514
  right: Math.max(0, l.right * C),
5283
5515
  bottom: Math.max(0, l.bottom * C),
@@ -5290,30 +5522,30 @@ class rt {
5290
5522
  } : d, tt = Object.keys(u).length > 0;
5291
5523
  let at;
5292
5524
  if (M && tt) {
5293
- const kt = {};
5294
- Object.entries(u).forEach(([re, Q]) => {
5525
+ const Bt = {};
5526
+ Object.entries(u).forEach(([ce, Q]) => {
5295
5527
  if (!Q) return;
5296
5528
  const st = {};
5297
- Object.entries(Q).forEach(([Me, Bt]) => {
5298
- if (!Bt) return;
5299
- const He = F({}, Bt);
5300
- typeof Bt.fontSize == "number" && (He.fontSize = Math.max(1, Bt.fontSize * C)), st[Me] = He;
5301
- }), Object.keys(st).length && (kt[re] = st);
5302
- }), Object.keys(kt).length && (at = kt);
5529
+ Object.entries(Q).forEach(([Se, Nt]) => {
5530
+ if (!Nt) return;
5531
+ const Ze = F({}, Nt);
5532
+ typeof Nt.fontSize == "number" && (Ze.fontSize = Math.max(1, Nt.fontSize * C)), st[Se] = Ze;
5533
+ }), Object.keys(st).length && (Bt[ce] = st);
5534
+ }), Object.keys(Bt).length && (at = Bt);
5303
5535
  }
5304
- let ft;
5305
- M && (ft = hn({
5536
+ let gt;
5537
+ M && (gt = un({
5306
5538
  lineFontDefaults: f,
5307
5539
  scale: C
5308
5540
  }));
5309
- const wt = (Zt = (Ht = o.originX) != null ? Ht : R) != null ? Zt : "left", dt = y + p, ht = y + p / 2, It = _ != null ? _ : p, At = I !== It, Lt = Math.abs(O - (x != null ? x : c)) > it, _t = Math.abs(H.top - k) > it || Math.abs(H.right - D) > it || Math.abs(H.bottom - W) > it || Math.abs(H.left - E) > it, xt = Math.abs(q.topLeft - L) > it || Math.abs(q.topRight - z) > it || Math.abs(q.bottomRight - B) > it || Math.abs(q.bottomLeft - P) > it;
5310
- if (!At && !Lt && !_t && !xt) {
5541
+ const jt = (Gt = (Zt = o.originX) != null ? Zt : R) != null ? Gt : "left", dt = y + p, ht = y + p / 2, Ot = D != null ? D : p, At = I !== Ot, Dt = Math.abs(T - (x != null ? x : c)) > it, xt = Math.abs(H.top - k) > it || Math.abs(H.right - _) > it || Math.abs(H.bottom - W) > it || Math.abs(H.left - E) > it, Rt = Math.abs(q.topLeft - L) > it || Math.abs(q.topRight - P) > it || Math.abs(q.bottomRight - B) > it || Math.abs(q.bottomLeft - z) > it;
5542
+ if (!At && !Dt && !xt && !Rt) {
5311
5543
  s.set({ scaleX: 1, scaleY: 1 }), o.scaleX = 1, o.scaleY = 1;
5312
5544
  return;
5313
5545
  }
5314
- at && (s.styles = at), ft && (s.lineFontDefaults = ft), s.set({
5546
+ at && (s.styles = at), gt && (s.lineFontDefaults = gt), s.set({
5315
5547
  width: I,
5316
- fontSize: M ? O : c,
5548
+ fontSize: M ? T : c,
5317
5549
  paddingTop: H.top,
5318
5550
  paddingRight: H.right,
5319
5551
  paddingBottom: H.bottom,
@@ -5325,13 +5557,13 @@ class rt {
5325
5557
  scaleX: 1,
5326
5558
  scaleY: 1
5327
5559
  });
5328
- const Yt = Et({ textbox: s });
5329
- Yt && (s.dirty = !0);
5330
- const gt = (Gt = s.width) != null ? Gt : I, ee = gt !== It;
5560
+ const Ht = _t({ textbox: s });
5561
+ Ht && (s.dirty = !0);
5562
+ const pt = (Vt = s.width) != null ? Vt : I, ne = pt !== Ot;
5331
5563
  let Tt = y;
5332
- ee && (b || S) && (wt === "right" ? Tt = dt - gt : wt === "center" && (Tt = ht - gt / 2)), s.set({ left: Tt }), i.baseLeft = Tt, o.scaleX = 1, o.scaleY = 1;
5333
- const { original: bt } = o;
5334
- bt && (bt.scaleX = 1, bt.scaleY = 1, bt.width = gt, bt.height = s.height, bt.left = Tt), s.setCoords(), this.canvas.requestRenderAll(), i.baseWidth = gt, i.baseFontSize = (Vt = s.fontSize) != null ? Vt : O, i.baseStyles = JSON.parse(JSON.stringify((Xt = s.styles) != null ? Xt : {})), i.baseLineFontDefaults = dn({
5564
+ ne && (b || S) && (jt === "right" ? Tt = dt - pt : jt === "center" && (Tt = ht - pt / 2)), s.set({ left: Tt }), i.baseLeft = Tt, o.scaleX = 1, o.scaleY = 1;
5565
+ const { original: Mt } = o;
5566
+ Mt && (Mt.scaleX = 1, Mt.scaleY = 1, Mt.width = pt, Mt.height = s.height, Mt.left = Tt), s.setCoords(), this.canvas.requestRenderAll(), i.baseWidth = pt, i.baseFontSize = (Xt = s.fontSize) != null ? Xt : T, i.baseStyles = JSON.parse(JSON.stringify((Kt = s.styles) != null ? Kt : {})), i.baseLineFontDefaults = hn({
5335
5567
  lineFontDefaults: s.lineFontDefaults
5336
5568
  }), i.basePadding = {
5337
5569
  top: H.top,
@@ -5343,61 +5575,61 @@ class rt {
5343
5575
  topRight: q.topRight,
5344
5576
  bottomRight: q.bottomRight,
5345
5577
  bottomLeft: q.bottomLeft
5346
- }, i.hasWidthChange = ee || Lt || _t || xt || Yt;
5578
+ }, i.hasWidthChange = ne || Dt || xt || Rt || Ht;
5347
5579
  }, this._handleObjectModified = (n) => {
5348
- var v, j, b;
5580
+ var v, A, b;
5349
5581
  const { target: s } = n;
5350
5582
  if (s instanceof X) {
5351
- const T = s.getObjects();
5352
- if (!T.some((A) => rt._isTextbox(A))) return;
5583
+ const O = s.getObjects();
5584
+ if (!O.some((j) => rt._isTextbox(j))) return;
5353
5585
  const { scaleX: M = 1, scaleY: w = 1 } = s;
5354
5586
  if (Math.abs(M - 1) < it && Math.abs(w - 1) < it) return;
5355
- this.canvas.discardActiveObject(), T.forEach((A) => {
5356
- var I, O, k, D;
5357
- if (rt._isTextbox(A)) {
5358
- const W = (I = A.scaleX) != null ? I : 1, E = (O = A.scaleY) != null ? O : 1, L = ((k = A.fontSize) != null ? k : 16) * E, z = ((D = A.width) != null ? D : 0) * W, B = E, {
5359
- paddingTop: P = 0,
5587
+ this.canvas.discardActiveObject(), O.forEach((j) => {
5588
+ var I, T, k, _;
5589
+ if (rt._isTextbox(j)) {
5590
+ const W = (I = j.scaleX) != null ? I : 1, E = (T = j.scaleY) != null ? T : 1, L = ((k = j.fontSize) != null ? k : 16) * E, P = ((_ = j.width) != null ? _ : 0) * W, B = E, {
5591
+ paddingTop: z = 0,
5360
5592
  paddingRight: x = 0,
5361
- paddingBottom: _ = 0,
5593
+ paddingBottom: D = 0,
5362
5594
  paddingLeft: R = 0,
5363
5595
  radiusTopLeft: N = 0,
5364
5596
  radiusTopRight: K = 0,
5365
5597
  radiusBottomRight: H = 0,
5366
5598
  radiusBottomLeft: q = 0,
5367
5599
  styles: tt
5368
- } = A, at = {
5369
- paddingTop: Math.max(0, P * B),
5600
+ } = j, at = {
5601
+ paddingTop: Math.max(0, z * B),
5370
5602
  paddingRight: Math.max(0, x * B),
5371
- paddingBottom: Math.max(0, _ * B),
5603
+ paddingBottom: Math.max(0, D * B),
5372
5604
  paddingLeft: Math.max(0, R * B)
5373
- }, ft = {
5605
+ }, gt = {
5374
5606
  radiusTopLeft: Math.max(0, N * B),
5375
5607
  radiusTopRight: Math.max(0, K * B),
5376
5608
  radiusBottomRight: Math.max(0, H * B),
5377
5609
  radiusBottomLeft: Math.max(0, q * B)
5378
5610
  };
5379
- let wt = tt;
5380
- tt && Object.keys(tt).length > 0 && (wt = JSON.parse(JSON.stringify(tt)), Object.values(wt).forEach((It) => {
5381
- Object.values(It).forEach((At) => {
5611
+ let jt = tt;
5612
+ tt && Object.keys(tt).length > 0 && (jt = JSON.parse(JSON.stringify(tt)), Object.values(jt).forEach((Ot) => {
5613
+ Object.values(Ot).forEach((At) => {
5382
5614
  typeof At.fontSize == "number" && (At.fontSize = Math.max(1, At.fontSize * B));
5383
5615
  });
5384
5616
  }));
5385
- const dt = hn({
5386
- lineFontDefaults: A.lineFontDefaults,
5617
+ const dt = un({
5618
+ lineFontDefaults: j.lineFontDefaults,
5387
5619
  scale: B
5388
- }), ht = Ot(F(F({
5620
+ }), ht = Et(F(F({
5389
5621
  fontSize: L,
5390
- width: z,
5622
+ width: P,
5391
5623
  scaleX: 1,
5392
5624
  scaleY: 1
5393
- }, at), ft), {
5394
- styles: wt
5625
+ }, at), gt), {
5626
+ styles: jt
5395
5627
  });
5396
- dt && (ht.lineFontDefaults = dt), A.set(ht), Et({ textbox: A });
5628
+ dt && (ht.lineFontDefaults = dt), j.set(ht), _t({ textbox: j });
5397
5629
  }
5398
- A.setCoords();
5630
+ j.setCoords();
5399
5631
  });
5400
- const C = new X(T, {
5632
+ const C = new X(O, {
5401
5633
  canvas: this.canvas
5402
5634
  });
5403
5635
  this.canvas.setActiveObject(C), this.canvas.requestRenderAll();
@@ -5407,7 +5639,7 @@ class rt {
5407
5639
  s.isScaling = !1;
5408
5640
  const o = this.scalingState.get(s);
5409
5641
  if (this.scalingState.delete(s), !(o != null && o.hasWidthChange)) return;
5410
- const i = (v = s.width) != null ? v : s.calcTextWidth(), a = (b = (j = s.fontSize) != null ? j : o == null ? void 0 : o.baseFontSize) != null ? b : 16, r = !!(o.baseStyles && Object.keys(o.baseStyles).length), {
5642
+ const i = (v = s.width) != null ? v : s.calcTextWidth(), a = (b = (A = s.fontSize) != null ? A : o == null ? void 0 : o.baseFontSize) != null ? b : 16, r = !!(o.baseStyles && Object.keys(o.baseStyles).length), {
5411
5643
  paddingTop: c = 0,
5412
5644
  paddingRight: l = 0,
5413
5645
  paddingBottom: d = 0,
@@ -5438,8 +5670,8 @@ class rt {
5438
5670
  * @param options — настройки текста
5439
5671
  * @param flags — флаги поведения
5440
5672
  */
5441
- addText(D = {}, { withoutSelection: I = !1, withoutSave: O = !1, withoutAdding: k = !1 } = {}) {
5442
- var W = D, {
5673
+ addText(_ = {}, { withoutSelection: I = !1, withoutSave: T = !1, withoutAdding: k = !1 } = {}) {
5674
+ var W = _, {
5443
5675
  id: t = `text-${et()}`,
5444
5676
  text: e = "Новый текст",
5445
5677
  autoExpand: n = !0,
@@ -5458,14 +5690,14 @@ class rt {
5458
5690
  backgroundColor: p,
5459
5691
  backgroundOpacity: y = 1,
5460
5692
  paddingTop: v = 0,
5461
- paddingRight: j = 0,
5693
+ paddingRight: A = 0,
5462
5694
  paddingBottom: b = 0,
5463
- paddingLeft: T = 0,
5695
+ paddingLeft: O = 0,
5464
5696
  radiusTopLeft: S = 0,
5465
5697
  radiusTopRight: M = 0,
5466
5698
  radiusBottomRight: w = 0,
5467
5699
  radiusBottomLeft: C = 0
5468
- } = W, A = jt(W, [
5700
+ } = W, j = Ct(W, [
5469
5701
  "id",
5470
5702
  "text",
5471
5703
  "autoExpand",
@@ -5495,12 +5727,12 @@ class rt {
5495
5727
  var K;
5496
5728
  const { historyManager: E } = this.editor, { canvas: L } = this;
5497
5729
  E.suspendHistory();
5498
- const z = s != null ? s : this._getDefaultFontFamily(), B = xe({ width: g }), P = _e({
5730
+ const P = s != null ? s : this._getDefaultFontFamily(), B = Re({ width: g }), z = xe({
5499
5731
  strokeColor: f,
5500
5732
  width: B
5501
5733
  }), x = F({
5502
5734
  id: t,
5503
- fontFamily: z,
5735
+ fontFamily: P,
5504
5736
  fontSize: o,
5505
5737
  fontWeight: i ? "bold" : "normal",
5506
5738
  fontStyle: a ? "italic" : "normal",
@@ -5509,43 +5741,43 @@ class rt {
5509
5741
  linethrough: l,
5510
5742
  textAlign: d,
5511
5743
  fill: u,
5512
- stroke: P,
5744
+ stroke: z,
5513
5745
  strokeWidth: B,
5514
5746
  strokeUniform: !0,
5515
5747
  opacity: m,
5516
5748
  backgroundColor: p,
5517
5749
  backgroundOpacity: y,
5518
5750
  paddingTop: v,
5519
- paddingRight: j,
5751
+ paddingRight: A,
5520
5752
  paddingBottom: b,
5521
- paddingLeft: T,
5753
+ paddingLeft: O,
5522
5754
  radiusTopLeft: S,
5523
5755
  radiusTopRight: M,
5524
5756
  radiusBottomRight: w,
5525
5757
  radiusBottomLeft: C
5526
- }, A), _ = new ye(e, x), R = n !== !1;
5527
- if (_.autoExpand = R, _.textCaseRaw = (K = _.text) != null ? K : "", c) {
5528
- const H = we({ value: _.textCaseRaw });
5529
- H !== _.text && _.set({ text: H });
5530
- }
5531
- return Et({ textbox: _ }) && (_.dirty = !0), A.left === void 0 && A.top === void 0 && L.centerObject(_), k || L.add(_), I || L.setActiveObject(_), L.requestRenderAll(), E.resumeHistory(), O || E.saveState(), L.fire("editor:text-added", {
5532
- textbox: _,
5533
- options: Ot(F({}, x), {
5758
+ }, j), D = new ve(e, x), R = n !== !1;
5759
+ if (D.autoExpand = R, D.textCaseRaw = (K = D.text) != null ? K : "", c) {
5760
+ const H = je({ value: D.textCaseRaw });
5761
+ H !== D.text && D.set({ text: H });
5762
+ }
5763
+ return _t({ textbox: D }) && (D.dirty = !0), j.left === void 0 && j.top === void 0 && L.centerObject(D), k || L.add(D), I || L.setActiveObject(D), L.requestRenderAll(), E.resumeHistory(), T || E.saveState(), L.fire("editor:text-added", {
5764
+ textbox: D,
5765
+ options: Et(F({}, x), {
5534
5766
  text: e,
5535
5767
  bold: i,
5536
5768
  italic: a,
5537
5769
  strikethrough: l,
5538
5770
  align: d,
5539
5771
  color: u,
5540
- strokeColor: P,
5772
+ strokeColor: z,
5541
5773
  strokeWidth: B
5542
5774
  }),
5543
5775
  flags: {
5544
5776
  withoutSelection: !!I,
5545
- withoutSave: !!O,
5777
+ withoutSave: !!T,
5546
5778
  withoutAdding: !!k
5547
5779
  }
5548
- }), _;
5780
+ }), D;
5549
5781
  }
5550
5782
  /**
5551
5783
  * Обновляет текстовый объект.
@@ -5563,41 +5795,41 @@ class rt {
5563
5795
  skipRender: s,
5564
5796
  selectionRange: o
5565
5797
  } = {}) {
5566
- var Ht, Gt, Vt, Xt, kt, re;
5798
+ var Zt, Vt, Xt, Kt, Bt, ce;
5567
5799
  const i = this._resolveTextObject(t);
5568
5800
  if (!i) return null;
5569
5801
  const { text: a = "" } = i, { historyManager: r } = this.editor, { canvas: c } = this;
5570
5802
  r.suspendHistory();
5571
- const l = rt._getSnapshot(i), d = (Ht = i.originY) != null ? Ht : "top", u = i.getPointByOrigin("center", d), f = {
5803
+ const l = rt._getSnapshot(i), d = (Zt = i.originY) != null ? Zt : "top", u = i.getPointByOrigin("center", d), f = {
5572
5804
  originY: d,
5573
5805
  x: u.x,
5574
5806
  y: u.y
5575
- }, Zt = e, {
5807
+ }, Gt = e, {
5576
5808
  text: g,
5577
5809
  autoExpand: m,
5578
5810
  fontFamily: p,
5579
5811
  fontSize: y,
5580
5812
  bold: v,
5581
- italic: j,
5813
+ italic: A,
5582
5814
  underline: b,
5583
- uppercase: T,
5815
+ uppercase: O,
5584
5816
  strikethrough: S,
5585
5817
  align: M,
5586
5818
  color: w,
5587
5819
  strokeColor: C,
5588
- strokeWidth: A,
5820
+ strokeWidth: j,
5589
5821
  opacity: I,
5590
- backgroundColor: O,
5822
+ backgroundColor: T,
5591
5823
  backgroundOpacity: k,
5592
- paddingTop: D,
5824
+ paddingTop: _,
5593
5825
  paddingRight: W,
5594
5826
  paddingBottom: E,
5595
5827
  paddingLeft: L,
5596
- radiusTopLeft: z,
5828
+ radiusTopLeft: P,
5597
5829
  radiusTopRight: B,
5598
- radiusBottomRight: P,
5830
+ radiusBottomRight: z,
5599
5831
  radiusBottomLeft: x
5600
- } = Zt, _ = jt(Zt, [
5832
+ } = Gt, D = Ct(Gt, [
5601
5833
  "text",
5602
5834
  "autoExpand",
5603
5835
  "fontFamily",
@@ -5622,89 +5854,89 @@ class rt {
5622
5854
  "radiusTopRight",
5623
5855
  "radiusBottomRight",
5624
5856
  "radiusBottomLeft"
5625
- ]), R = F({}, _), N = o !== void 0 ? Os({
5857
+ ]), R = F({}, D), N = o !== void 0 ? Ts({
5626
5858
  text: a,
5627
5859
  range: o
5628
5860
  }) : ws({ textbox: i }), K = N ? Es({ textbox: i, range: N }) : null, H = {}, q = {}, tt = {};
5629
- let at, ft;
5630
- const wt = js({ textbox: i, range: N }), dt = !N || wt, ht = !N;
5861
+ let at, gt;
5862
+ const jt = As({ textbox: i, range: N }), dt = !N || jt, ht = !N;
5631
5863
  if (p !== void 0 && (K && (q.fontFamily = p), dt && (R.fontFamily = p, ht && (tt.fontFamily = p))), y !== void 0 && (K && (q.fontSize = y), dt && (R.fontSize = y, ht && (tt.fontSize = y))), v !== void 0) {
5632
5864
  const Q = v ? "bold" : "normal";
5633
5865
  N && (H.fontWeight = Q), dt && (R.fontWeight = Q, ht && (tt.fontWeight = Q));
5634
5866
  }
5635
- if (j !== void 0) {
5636
- const Q = j ? "italic" : "normal";
5867
+ if (A !== void 0) {
5868
+ const Q = A ? "italic" : "normal";
5637
5869
  N && (H.fontStyle = Q), dt && (R.fontStyle = Q, ht && (tt.fontStyle = Q));
5638
5870
  }
5639
- if (b !== void 0 && (N && (H.underline = b), dt && (R.underline = b, ht && (tt.underline = b))), S !== void 0 && (N && (H.linethrough = S), dt && (R.linethrough = S, ht && (tt.linethrough = S))), M !== void 0 && (R.textAlign = M), w !== void 0 && (N && (H.fill = w), dt && (R.fill = w, ht && (tt.fill = w))), C !== void 0 || A !== void 0) {
5640
- const Q = N ? cn({ textbox: i, range: N, property: "strokeWidth" }) : void 0, st = N ? cn({ textbox: i, range: N, property: "stroke" }) : void 0, Me = (Vt = (Gt = A != null ? A : Q) != null ? Gt : i.strokeWidth) != null ? Vt : 0;
5641
- ft = xe({ width: Me });
5642
- const Bt = (kt = (Xt = C != null ? C : st) != null ? Xt : i.stroke) != null ? kt : void 0;
5643
- at = _e({
5644
- strokeColor: Bt,
5645
- width: ft
5646
- }), N && (H.stroke = at, H.strokeWidth = ft), dt && (R.stroke = at, R.strokeWidth = ft, ht && (tt.stroke = at, tt.strokeWidth = ft));
5647
- }
5648
- I !== void 0 && (R.opacity = I), O !== void 0 && (R.backgroundColor = O), k !== void 0 && (R.backgroundOpacity = k), D !== void 0 && (R.paddingTop = D), W !== void 0 && (R.paddingRight = W), E !== void 0 && (R.paddingBottom = E), L !== void 0 && (R.paddingLeft = L), z !== void 0 && (R.radiusTopLeft = z), B !== void 0 && (R.radiusTopRight = B), P !== void 0 && (R.radiusBottomRight = P), x !== void 0 && (R.radiusBottomLeft = x);
5649
- const It = (re = i.textCaseRaw) != null ? re : a, At = !!i.uppercase, Lt = g !== void 0, _t = Lt ? g != null ? g : "" : It, xt = T != null ? T : At, Yt = xt !== At;
5650
- if (Lt || Yt) {
5651
- const Q = xt ? we({ value: _t }) : _t;
5652
- R.text = Q, i.textCaseRaw = _t;
5653
- } else i.textCaseRaw === void 0 && (i.textCaseRaw = It);
5654
- i.uppercase = xt, i.set(R);
5655
- let gt = !1;
5871
+ if (b !== void 0 && (N && (H.underline = b), dt && (R.underline = b, ht && (tt.underline = b))), S !== void 0 && (N && (H.linethrough = S), dt && (R.linethrough = S, ht && (tt.linethrough = S))), M !== void 0 && (R.textAlign = M), w !== void 0 && (N && (H.fill = w), dt && (R.fill = w, ht && (tt.fill = w))), C !== void 0 || j !== void 0) {
5872
+ const Q = N ? ln({ textbox: i, range: N, property: "strokeWidth" }) : void 0, st = N ? ln({ textbox: i, range: N, property: "stroke" }) : void 0, Se = (Xt = (Vt = j != null ? j : Q) != null ? Vt : i.strokeWidth) != null ? Xt : 0;
5873
+ gt = Re({ width: Se });
5874
+ const Nt = (Bt = (Kt = C != null ? C : st) != null ? Kt : i.stroke) != null ? Bt : void 0;
5875
+ at = xe({
5876
+ strokeColor: Nt,
5877
+ width: gt
5878
+ }), N && (H.stroke = at, H.strokeWidth = gt), dt && (R.stroke = at, R.strokeWidth = gt, ht && (tt.stroke = at, tt.strokeWidth = gt));
5879
+ }
5880
+ I !== void 0 && (R.opacity = I), T !== void 0 && (R.backgroundColor = T), k !== void 0 && (R.backgroundOpacity = k), _ !== void 0 && (R.paddingTop = _), W !== void 0 && (R.paddingRight = W), E !== void 0 && (R.paddingBottom = E), L !== void 0 && (R.paddingLeft = L), P !== void 0 && (R.radiusTopLeft = P), B !== void 0 && (R.radiusTopRight = B), z !== void 0 && (R.radiusBottomRight = z), x !== void 0 && (R.radiusBottomLeft = x);
5881
+ const Ot = (ce = i.textCaseRaw) != null ? ce : a, At = !!i.uppercase, Dt = g !== void 0, xt = Dt ? g != null ? g : "" : Ot, Rt = O != null ? O : At, Ht = Rt !== At;
5882
+ if (Dt || Ht) {
5883
+ const Q = Rt ? je({ value: xt }) : xt;
5884
+ R.text = Q, i.textCaseRaw = xt;
5885
+ } else i.textCaseRaw === void 0 && (i.textCaseRaw = Ot);
5886
+ i.uppercase = Rt, i.set(R);
5887
+ let pt = !1;
5656
5888
  if (N) {
5657
- const Q = Se({ textbox: i, styles: H, range: N }), st = K ? Se({ textbox: i, styles: q, range: K }) : !1;
5658
- gt = Q || st;
5889
+ const Q = we({ textbox: i, styles: H, range: N }), st = K ? we({ textbox: i, styles: q, range: K }) : !1;
5890
+ pt = Q || st;
5659
5891
  } else if (Object.keys(tt).length) {
5660
- const Q = As({ textbox: i });
5661
- Q && (gt = Se({ textbox: i, styles: tt, range: Q }));
5892
+ const Q = js({ textbox: i });
5893
+ Q && (pt = we({ textbox: i, styles: tt, range: Q }));
5662
5894
  }
5663
- const ee = gt && fn({
5895
+ const ne = pt && gn({
5664
5896
  stylesList: [
5665
5897
  H,
5666
5898
  q,
5667
5899
  tt
5668
5900
  ]
5669
5901
  });
5670
- if (gt && (i.dirty = !0), K && (p !== void 0 || y !== void 0)) {
5671
- const Q = Ds({
5902
+ if (pt && (i.dirty = !0), K && (p !== void 0 || y !== void 0)) {
5903
+ const Q = _s({
5672
5904
  textbox: i,
5673
5905
  range: K
5674
5906
  }), st = {};
5675
- p !== void 0 && (st.fontFamily = p), y !== void 0 && (st.fontSize = y), ln({
5907
+ p !== void 0 && (st.fontFamily = p), y !== void 0 && (st.fontSize = y), dn({
5676
5908
  textbox: i,
5677
5909
  lineIndices: Q,
5678
5910
  updates: st
5679
5911
  });
5680
5912
  }
5681
- if (N && (w !== void 0 || C !== void 0 || A !== void 0)) {
5913
+ if (N && (w !== void 0 || C !== void 0 || j !== void 0)) {
5682
5914
  const Q = Ls({
5683
5915
  textbox: i,
5684
5916
  range: N
5685
5917
  }), st = {};
5686
- w !== void 0 && (st.fill = w), (C !== void 0 || A !== void 0) && (at === null && (st.stroke = null), at != null && (st.stroke = at)), ln({
5918
+ w !== void 0 && (st.fill = w), (C !== void 0 || j !== void 0) && (at === null && (st.stroke = null), at != null && (st.stroke = at)), dn({
5687
5919
  textbox: i,
5688
5920
  lineIndices: Q,
5689
5921
  updates: st
5690
5922
  });
5691
5923
  }
5692
- ee && (i.initDimensions(), i.dirty = !0), (O !== void 0 || k !== void 0 || D !== void 0 || W !== void 0 || E !== void 0 || L !== void 0 || z !== void 0 || B !== void 0 || P !== void 0 || x !== void 0) && (i.dirty = !0);
5693
- const Tt = fn({
5924
+ ne && (i.initDimensions(), i.dirty = !0), (T !== void 0 || k !== void 0 || _ !== void 0 || W !== void 0 || E !== void 0 || L !== void 0 || P !== void 0 || B !== void 0 || z !== void 0 || x !== void 0) && (i.dirty = !0);
5925
+ const Tt = gn({
5694
5926
  stylesList: [
5695
5927
  R,
5696
5928
  H,
5697
5929
  q,
5698
5930
  tt
5699
5931
  ]
5700
- }), { autoExpand: bt } = i, ne = m !== void 0, se = (m != null ? m : bt) !== !1;
5701
- ne ? i.autoExpand = m !== !1 : bt === void 0 && (i.autoExpand = !0);
5702
- const ie = Object.prototype.hasOwnProperty.call(R, "width"), oe = se && !ie && (Lt || Yt || Tt);
5703
- let Rt = !1;
5704
- oe && (Rt = this._autoExpandTextboxWidth(i, {
5932
+ }), { autoExpand: Mt } = i, se = m !== void 0, ie = (m != null ? m : Mt) !== !1;
5933
+ se ? i.autoExpand = m !== !1 : Mt === void 0 && (i.autoExpand = !0);
5934
+ const oe = Object.prototype.hasOwnProperty.call(R, "width"), ae = ie && !oe && (Dt || Ht || Tt);
5935
+ let kt = !1;
5936
+ ae && (kt = this._autoExpandTextboxWidth(i, {
5705
5937
  anchor: f
5706
- }), Rt && (i.dirty = !0)), (Rt ? !1 : Et({ textbox: i })) && (i.dirty = !0), i.setCoords(), s || c.requestRenderAll(), r.resumeHistory(), n || r.saveState();
5707
- const ae = rt._getSnapshot(i);
5938
+ }), kt && (i.dirty = !0)), (kt ? !1 : _t({ textbox: i })) && (i.dirty = !0), i.setCoords(), s || c.requestRenderAll(), r.resumeHistory(), n || r.saveState();
5939
+ const re = rt._getSnapshot(i);
5708
5940
  return c.fire("editor:text-updated", {
5709
5941
  textbox: i,
5710
5942
  target: t,
@@ -5715,7 +5947,7 @@ class rt {
5715
5947
  },
5716
5948
  updates: R,
5717
5949
  before: l,
5718
- after: ae,
5950
+ after: re,
5719
5951
  selectionRange: N != null ? N : void 0,
5720
5952
  selectionStyles: N && Object.keys(H).length ? H : void 0
5721
5953
  }), i;
@@ -5725,7 +5957,7 @@ class rt {
5725
5957
  */
5726
5958
  // eslint-disable-next-line class-methods-use-this
5727
5959
  stylesFromArray(t, e) {
5728
- return vt.stylesFromArray(t, e);
5960
+ return bt.stylesFromArray(t, e);
5729
5961
  }
5730
5962
  /**
5731
5963
  * Уничтожает менеджер и снимает слушатели.
@@ -5767,7 +5999,7 @@ class rt {
5767
5999
  * Синхронизирует lineFontDefaults при изменении текста и сохраняет typing style для пустых строк.
5768
6000
  */
5769
6001
  _syncLineFontDefaultsOnTextChanged({ textbox: t }) {
5770
- var k, D, W;
6002
+ var k, _, W;
5771
6003
  const {
5772
6004
  text: e = "",
5773
6005
  lineFontDefaults: n,
@@ -5781,10 +6013,10 @@ class rt {
5781
6013
  } = t, d = e, u = (k = t.__lineDefaultsPrevText) != null ? k : d, f = u.split(`
5782
6014
  `), g = d.split(`
5783
6015
  `), m = f.length, y = g.length - m;
5784
- let v = n, j = !1, b = !1;
5785
- const T = typeof a == "string" ? a : void 0, S = typeof r == "string" ? r : void 0;
6016
+ let v = n, A = !1, b = !1;
6017
+ const O = typeof a == "string" ? a : void 0, S = typeof r == "string" ? r : void 0;
5786
6018
  if (y !== 0 && n && Object.keys(n).length) {
5787
- const E = _s({
6019
+ const E = Ds({
5788
6020
  previous: u,
5789
6021
  next: d
5790
6022
  }), L = xs({
@@ -5792,38 +6024,38 @@ class rt {
5792
6024
  charIndex: E
5793
6025
  });
5794
6026
  if (y > 0) {
5795
- const z = Rs({
6027
+ const P = Rs({
5796
6028
  text: u,
5797
6029
  lineIndex: L
5798
6030
  });
5799
6031
  let B = L + 1;
5800
- E === z && (B = L);
5801
- const P = {};
6032
+ E === P && (B = L);
6033
+ const z = {};
5802
6034
  for (const x in n) {
5803
6035
  if (!Object.prototype.hasOwnProperty.call(n, x)) continue;
5804
- const _ = Number(x);
5805
- if (!Number.isFinite(_)) continue;
5806
- const R = n[_];
6036
+ const D = Number(x);
6037
+ if (!Number.isFinite(D)) continue;
6038
+ const R = n[D];
5807
6039
  if (!R) continue;
5808
- const N = _ >= B ? _ + y : _;
5809
- P[N] = F({}, R);
6040
+ const N = D >= B ? D + y : D;
6041
+ z[N] = F({}, R);
5810
6042
  }
5811
- v = P, j = !0, b = !0;
6043
+ v = z, A = !0, b = !0;
5812
6044
  }
5813
6045
  if (y < 0) {
5814
- const z = Math.abs(y);
6046
+ const P = Math.abs(y);
5815
6047
  let B = L;
5816
6048
  u[E] === `
5817
- ` && ((D = f[L]) != null ? D : "").length > 0 && (B = L + 1);
5818
- const x = B + z - 1, _ = {};
6049
+ ` && ((_ = f[L]) != null ? _ : "").length > 0 && (B = L + 1);
6050
+ const x = B + P - 1, D = {};
5819
6051
  for (const R in n) {
5820
6052
  if (!Object.prototype.hasOwnProperty.call(n, R)) continue;
5821
6053
  const N = Number(R);
5822
6054
  if (!Number.isFinite(N)) continue;
5823
6055
  const K = n[N];
5824
- K && (N < B && (_[N] = F({}, K)), N > x && (_[N + y] = F({}, K)));
6056
+ K && (N < B && (D[N] = F({}, K)), N > x && (D[N + y] = F({}, K)));
5825
6057
  }
5826
- v = _, j = !0, b = !0;
6058
+ v = D, A = !0, b = !0;
5827
6059
  }
5828
6060
  }
5829
6061
  let M = null;
@@ -5831,30 +6063,30 @@ class rt {
5831
6063
  const E = t.get2DCursorLocation(c), { lineIndex: L } = E;
5832
6064
  Number.isFinite(L) && (M = L);
5833
6065
  }
5834
- let w = s, C = !1, A = !1, I, O = null;
6066
+ let w = s, C = !1, j = !1, I, T = null;
5835
6067
  for (let E = 0; E < g.length; E += 1) {
5836
- const L = (W = g[E]) != null ? W : "", z = v ? v[E] : void 0;
5837
- if (z && (I = z), L.length !== 0) {
5838
- if (z) {
6068
+ const L = (W = g[E]) != null ? W : "", P = v ? v[E] : void 0;
6069
+ if (P && (I = P), L.length !== 0) {
6070
+ if (P) {
5839
6071
  const N = Is({
5840
6072
  lineText: L,
5841
6073
  lineStyles: w ? w[E] : void 0,
5842
- lineDefaults: z
6074
+ lineDefaults: P
5843
6075
  });
5844
- N.changed && (w || (w = {}, A = !0), A || (w = F({}, w), A = !0), N.lineStyles && (w[E] = N.lineStyles), !N.lineStyles && w[E] && delete w[E], C = !0);
6076
+ N.changed && (w || (w = {}, j = !0), j || (w = F({}, w), j = !0), N.lineStyles && (w[E] = N.lineStyles), !N.lineStyles && w[E] && delete w[E], C = !0);
5845
6077
  }
5846
6078
  continue;
5847
6079
  }
5848
- const P = z != null ? z : I, x = {};
5849
- (P == null ? void 0 : P.fontFamily) !== void 0 ? x.fontFamily = P.fontFamily : o !== void 0 && (x.fontFamily = o), (P == null ? void 0 : P.fontSize) !== void 0 ? x.fontSize = P.fontSize : i !== void 0 && (x.fontSize = i), (P == null ? void 0 : P.fill) !== void 0 ? x.fill = P.fill : T !== void 0 && (x.fill = T), (P == null ? void 0 : P.stroke) !== void 0 ? x.stroke = P.stroke : S !== void 0 && (x.stroke = S), !z && Object.keys(x).length && (v || (v = {}, b = !0), b || (v = F({}, v), b = !0), v[E] = x, j = !0, I = x), z && (I = z), M !== null && M === E && (O = x);
5850
- const _ = {};
5851
- x.fontFamily !== void 0 && (_.fontFamily = x.fontFamily), x.fontSize !== void 0 && (_.fontSize = x.fontSize), x.fill !== void 0 && (_.fill = x.fill), x.stroke !== void 0 && (_.stroke = x.stroke);
5852
- const R = Object.keys(_).length > 0;
5853
- (R || w && w[E]) && (w || (w = {}, A = !0), A || (w = F({}, w), A = !0), R && (w[E] = { 0: _ }), !R && w[E] && delete w[E], C = !0);
5854
- }
5855
- if (j && v && (t.lineFontDefaults = v), C && (t.styles = w, t.dirty = !0), O && typeof c == "number") {
6080
+ const z = P != null ? P : I, x = {};
6081
+ (z == null ? void 0 : z.fontFamily) !== void 0 ? x.fontFamily = z.fontFamily : o !== void 0 && (x.fontFamily = o), (z == null ? void 0 : z.fontSize) !== void 0 ? x.fontSize = z.fontSize : i !== void 0 && (x.fontSize = i), (z == null ? void 0 : z.fill) !== void 0 ? x.fill = z.fill : O !== void 0 && (x.fill = O), (z == null ? void 0 : z.stroke) !== void 0 ? x.stroke = z.stroke : S !== void 0 && (x.stroke = S), !P && Object.keys(x).length && (v || (v = {}, b = !0), b || (v = F({}, v), b = !0), v[E] = x, A = !0, I = x), P && (I = P), M !== null && M === E && (T = x);
6082
+ const D = {};
6083
+ x.fontFamily !== void 0 && (D.fontFamily = x.fontFamily), x.fontSize !== void 0 && (D.fontSize = x.fontSize), x.fill !== void 0 && (D.fill = x.fill), x.stroke !== void 0 && (D.stroke = x.stroke);
6084
+ const R = Object.keys(D).length > 0;
6085
+ (R || w && w[E]) && (w || (w = {}, j = !0), j || (w = F({}, w), j = !0), R && (w[E] = { 0: D }), !R && w[E] && delete w[E], C = !0);
6086
+ }
6087
+ if (A && v && (t.lineFontDefaults = v), C && (t.styles = w, t.dirty = !0), T && typeof c == "number") {
5856
6088
  const E = {};
5857
- 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) {
6089
+ if (T.fontFamily !== void 0 && (E.fontFamily = T.fontFamily), T.fontSize !== void 0 && (E.fontSize = T.fontSize), T.fill !== void 0 && (E.fill = T.fill), T.stroke !== void 0 && (E.stroke = T.stroke), Object.keys(E).length) {
5858
6090
  this.lineDefaultsSyncing.add(t);
5859
6091
  try {
5860
6092
  t.setSelectionStyles(E, c, c);
@@ -5870,7 +6102,7 @@ class rt {
5870
6102
  * но не шире монтажной области, и удерживает объект в её пределах.
5871
6103
  */
5872
6104
  _autoExpandTextboxWidth(t, { anchor: e } = {}) {
5873
- var M, w, C, A, I, O, k, D, W, E, L, z, B;
6105
+ var M, w, C, j, I, T, k, _, W, E, L, P, B;
5874
6106
  const { montageArea: n } = this.editor;
5875
6107
  if (!n) return !1;
5876
6108
  const s = typeof t.text == "string" ? t.text : "";
@@ -5878,7 +6110,7 @@ class rt {
5878
6110
  n.setCoords();
5879
6111
  const o = n.getBoundingRect(!1, !0), i = (M = o.width) != null ? M : 0;
5880
6112
  if (!Number.isFinite(i) || i <= 0) return !1;
5881
- const a = e != null ? e : (w = this.editingAnchorState) == null ? void 0 : w.get(t), r = (A = (C = a == null ? void 0 : a.originY) != null ? C : t.originY) != null ? A : "top", c = Math.abs((I = t.scaleX) != null ? I : 1) || 1, l = (O = t.paddingLeft) != null ? O : 0, d = (k = t.paddingRight) != null ? k : 0, u = (D = t.strokeWidth) != null ? D : 0, f = Math.max(
6113
+ const a = e != null ? e : (w = this.editingAnchorState) == null ? void 0 : w.get(t), r = (j = (C = a == null ? void 0 : a.originY) != null ? C : t.originY) != null ? j : "top", c = Math.abs((I = t.scaleX) != null ? I : 1) || 1, l = (T = t.paddingLeft) != null ? T : 0, d = (k = t.paddingRight) != null ? k : 0, u = (_ = t.strokeWidth) != null ? _ : 0, f = Math.max(
5882
6114
  1,
5883
6115
  i / c - l - d - u
5884
6116
  );
@@ -5889,15 +6121,15 @@ class rt {
5889
6121
  Math.abs(((W = t.width) != null ? W : 0) - f) > it && (t.set({ width: f }), m = !0), t.initDimensions();
5890
6122
  const { textLines: p } = t, y = Array.isArray(p) && p.length > g, v = Math.ceil(
5891
6123
  ks({ textbox: t, text: s })
5892
- ), j = Math.min((E = t.minWidth) != null ? E : 1, f);
6124
+ ), A = Math.min((E = t.minWidth) != null ? E : 1, f);
5893
6125
  let b = Math.min(
5894
6126
  f,
5895
- Math.max(v, j)
6127
+ Math.max(v, A)
5896
6128
  );
5897
- y && (b = f), Math.abs(((L = t.width) != null ? L : 0) - b) > it && (t.set({ width: b }), t.initDimensions(), m = !0), Et({ textbox: t }) && (m = !0), a && (t.setPositionByOrigin(new lt(a.x, a.y), "center", r), m = !0);
6129
+ y && (b = f), Math.abs(((L = t.width) != null ? L : 0) - b) > it && (t.set({ width: b }), t.initDimensions(), m = !0), _t({ textbox: t }) && (m = !0), a && (t.setPositionByOrigin(new lt(a.x, a.y), "center", r), m = !0);
5898
6130
  const S = Bs({
5899
6131
  textbox: t,
5900
- montageLeft: (z = o.left) != null ? z : 0,
6132
+ montageLeft: (P = o.left) != null ? P : 0,
5901
6133
  montageRight: ((B = o.left) != null ? B : 0) + i
5902
6134
  });
5903
6135
  return m || S;
@@ -5943,7 +6175,7 @@ class rt {
5943
6175
  bottomLeft: v
5944
6176
  },
5945
6177
  baseStyles: JSON.parse(JSON.stringify(c)),
5946
- baseLineFontDefaults: dn({ lineFontDefaults: l }),
6178
+ baseLineFontDefaults: hn({ lineFontDefaults: l }),
5947
6179
  hasWidthChange: !1
5948
6180
  }, this.scalingState.set(t, e);
5949
6181
  }
@@ -5955,9 +6187,9 @@ class rt {
5955
6187
  static _getSnapshot(t) {
5956
6188
  const e = ({
5957
6189
  snapshot: x,
5958
- entries: _
6190
+ entries: D
5959
6191
  }) => {
5960
- Object.entries(_).forEach(([R, N]) => {
6192
+ Object.entries(D).forEach(([R, N]) => {
5961
6193
  N != null && (x[R] = N);
5962
6194
  });
5963
6195
  }, {
@@ -5977,30 +6209,30 @@ class rt {
5977
6209
  stroke: p,
5978
6210
  strokeWidth: y,
5979
6211
  opacity: v,
5980
- backgroundColor: j,
6212
+ backgroundColor: A,
5981
6213
  backgroundOpacity: b,
5982
- paddingTop: T,
6214
+ paddingTop: O,
5983
6215
  paddingRight: S,
5984
6216
  paddingBottom: M,
5985
6217
  paddingLeft: w,
5986
6218
  radiusTopLeft: C,
5987
- radiusTopRight: A,
6219
+ radiusTopRight: j,
5988
6220
  radiusBottomRight: I,
5989
- radiusBottomLeft: O,
6221
+ radiusBottomLeft: T,
5990
6222
  left: k,
5991
- top: D,
6223
+ top: _,
5992
6224
  width: W,
5993
6225
  height: E,
5994
6226
  angle: L,
5995
- scaleX: z,
6227
+ scaleX: P,
5996
6228
  scaleY: B
5997
- } = t, P = {
6229
+ } = t, z = {
5998
6230
  id: n,
5999
6231
  uppercase: !!i,
6000
6232
  textAlign: g
6001
6233
  };
6002
6234
  return e({
6003
- snapshot: P,
6235
+ snapshot: z,
6004
6236
  entries: {
6005
6237
  text: s,
6006
6238
  textCaseRaw: o,
@@ -6015,25 +6247,25 @@ class rt {
6015
6247
  stroke: p,
6016
6248
  strokeWidth: y,
6017
6249
  opacity: v,
6018
- backgroundColor: j,
6250
+ backgroundColor: A,
6019
6251
  backgroundOpacity: b,
6020
- paddingTop: T,
6252
+ paddingTop: O,
6021
6253
  paddingRight: S,
6022
6254
  paddingBottom: M,
6023
6255
  paddingLeft: w,
6024
6256
  radiusTopLeft: C,
6025
- radiusTopRight: A,
6257
+ radiusTopRight: j,
6026
6258
  radiusBottomRight: I,
6027
- radiusBottomLeft: O,
6259
+ radiusBottomLeft: T,
6028
6260
  left: k,
6029
- top: D,
6261
+ top: _,
6030
6262
  width: W,
6031
6263
  height: E,
6032
6264
  angle: L,
6033
- scaleX: z,
6265
+ scaleX: P,
6034
6266
  scaleY: B
6035
6267
  }
6036
- }), P;
6268
+ }), z;
6037
6269
  }
6038
6270
  /**
6039
6271
  * Возвращает первый доступный шрифт или дефолтный Arial.
@@ -6043,12 +6275,12 @@ class rt {
6043
6275
  return (e = (t = this.fonts[0]) == null ? void 0 : t.family) != null ? e : "Arial";
6044
6276
  }
6045
6277
  }
6046
- const he = ({
6278
+ const ue = ({
6047
6279
  value: h
6048
6280
  }) => Math.round(h / 2) * 2, nt = ({
6049
6281
  value: h,
6050
6282
  fallback: t = 0
6051
- }) => typeof h == "number" && Number.isFinite(h) ? h : typeof t == "number" && Number.isFinite(t) ? t : 0, ue = ({
6283
+ }) => typeof h == "number" && Number.isFinite(h) ? h : typeof t == "number" && Number.isFinite(t) ? t : 0, fe = ({
6052
6284
  value: h,
6053
6285
  dimension: t,
6054
6286
  useRelativePositions: e
@@ -6065,22 +6297,22 @@ const he = ({
6065
6297
  const o = h;
6066
6298
  if (typeof o[s.x] == "number" && typeof o[s.y] == "number")
6067
6299
  return {
6068
- x: ue({
6300
+ x: fe({
6069
6301
  value: o[s.x],
6070
6302
  dimension: t,
6071
6303
  useRelativePositions: n
6072
6304
  }),
6073
- y: ue({
6305
+ y: fe({
6074
6306
  value: o[s.y],
6075
6307
  dimension: e,
6076
6308
  useRelativePositions: n
6077
6309
  })
6078
6310
  };
6079
- const { left: a, top: r, width: c, height: l } = h, d = ue({
6311
+ const { left: a, top: r, width: c, height: l } = h, d = fe({
6080
6312
  value: a,
6081
6313
  dimension: t,
6082
6314
  useRelativePositions: n
6083
- }), u = ue({
6315
+ }), u = fe({
6084
6316
  value: r,
6085
6317
  dimension: e,
6086
6318
  useRelativePositions: n
@@ -6089,7 +6321,7 @@ const he = ({
6089
6321
  x: d + f / 2,
6090
6322
  y: u + g / 2
6091
6323
  };
6092
- }, zs = ({
6324
+ }, Ps = ({
6093
6325
  normalizedX: h,
6094
6326
  normalizedY: t,
6095
6327
  bounds: e,
@@ -6103,7 +6335,7 @@ const he = ({
6103
6335
  }
6104
6336
  const c = o + h * a, l = i + t * r;
6105
6337
  return new lt(c, l);
6106
- }, Ps = ({
6338
+ }, zs = ({
6107
6339
  object: h,
6108
6340
  montageArea: t,
6109
6341
  bounds: e
@@ -6118,7 +6350,7 @@ const he = ({
6118
6350
  } catch (n) {
6119
6351
  return null;
6120
6352
  }
6121
- }, mt = ({
6353
+ }, yt = ({
6122
6354
  object: h
6123
6355
  }) => {
6124
6356
  if (!h) return null;
@@ -6129,7 +6361,7 @@ const he = ({
6129
6361
  top: n = 0,
6130
6362
  width: s = 0,
6131
6363
  height: o = 0
6132
- } = t, i = e + s, a = n + o, r = he({ value: e }), c = he({ value: n }), l = he({ value: i }), d = he({ value: a }), u = l - r, f = d - c, g = r + u / 2, m = c + f / 2;
6364
+ } = t, i = e + s, a = n + o, r = ue({ value: e }), c = ue({ value: n }), l = ue({ value: i }), d = ue({ value: a }), u = l - r, f = d - c, g = r + u / 2, m = c + f / 2;
6133
6365
  return {
6134
6366
  left: r,
6135
6367
  right: l,
@@ -6182,7 +6414,7 @@ const he = ({
6182
6414
  };
6183
6415
  }
6184
6416
  return null;
6185
- }, Jt = "_templateCenterX", Ae = "_templateCenterY", fe = "_templateAnchorX", je = "_templateAnchorY";
6417
+ }, Qt = "_templateCenterX", Ae = "_templateCenterY", ge = "_templateAnchorX", Ce = "_templateAnchorY";
6186
6418
  class Z {
6187
6419
  constructor({ editor: t }) {
6188
6420
  this.editor = t;
@@ -6207,16 +6439,16 @@ class Z {
6207
6439
  return a.emitWarning({
6208
6440
  origin: "TemplateManager",
6209
6441
  method: "serializeSelection",
6210
- code: Dt.TEMPLATE_MANAGER.NO_OBJECTS_SELECTED,
6442
+ code: Lt.TEMPLATE_MANAGER.NO_OBJECTS_SELECTED,
6211
6443
  message: "Нет объектов для сериализации шаблона"
6212
6444
  }), null;
6213
- const g = Z._getBounds(i), m = Z._getMontageSize({ montageArea: i, bounds: g }), p = m.width, y = m.height, v = f.map((T) => Z._serializeObject({
6214
- object: T,
6445
+ const g = Z._getBounds(i), m = Z._getMontageSize({ montageArea: i, bounds: g }), p = m.width, y = m.height, v = f.map((O) => Z._serializeObject({
6446
+ object: O,
6215
6447
  bounds: g,
6216
6448
  baseWidth: p,
6217
6449
  baseHeight: y,
6218
6450
  montageArea: i != null ? i : null
6219
- })), j = Ot(F({}, n), {
6451
+ })), A = Et(F({}, n), {
6220
6452
  baseWidth: p,
6221
6453
  baseHeight: y,
6222
6454
  positionsNormalized: !0,
@@ -6224,7 +6456,7 @@ class Z {
6224
6456
  });
6225
6457
  return {
6226
6458
  id: t != null ? t : `template-${et()}`,
6227
- meta: j,
6459
+ meta: A,
6228
6460
  objects: v
6229
6461
  };
6230
6462
  }
@@ -6248,7 +6480,7 @@ class Z {
6248
6480
  return i.emitWarning({
6249
6481
  origin: "TemplateManager",
6250
6482
  method: "applyTemplate",
6251
- code: Dt.TEMPLATE_MANAGER.INVALID_TEMPLATE,
6483
+ code: Lt.TEMPLATE_MANAGER.INVALID_TEMPLATE,
6252
6484
  message: "Шаблон не содержит объектов"
6253
6485
  }), null;
6254
6486
  const d = Z._getBounds(s);
@@ -6256,7 +6488,7 @@ class Z {
6256
6488
  return i.emitWarning({
6257
6489
  origin: "TemplateManager",
6258
6490
  method: "applyTemplate",
6259
- code: Dt.TEMPLATE_MANAGER.INVALID_TARGET,
6491
+ code: Lt.TEMPLATE_MANAGER.INVALID_TARGET,
6260
6492
  message: "Не удалось определить границы монтажной области"
6261
6493
  }), null;
6262
6494
  const u = Z._getMontageSize({ montageArea: s, bounds: d }), f = Z._normalizeMeta({ meta: c, fallback: u }), g = Z._calculateScale({ meta: f, target: u }), m = !!f.positionsNormalized;
@@ -6268,16 +6500,16 @@ class Z {
6268
6500
  return i.emitWarning({
6269
6501
  origin: "TemplateManager",
6270
6502
  method: "applyTemplate",
6271
- code: Dt.TEMPLATE_MANAGER.INVALID_TEMPLATE,
6503
+ code: Lt.TEMPLATE_MANAGER.INVALID_TEMPLATE,
6272
6504
  message: "Не удалось создать объекты шаблона"
6273
6505
  }), null;
6274
- const { backgroundObject: j, contentObjects: b } = Z._extractBackgroundObject(v);
6275
- j && (y = yield Z._applyBackgroundFromObject({
6276
- backgroundObject: j,
6506
+ const { backgroundObject: A, contentObjects: b } = Z._extractBackgroundObject(v);
6507
+ A && (y = yield Z._applyBackgroundFromObject({
6508
+ backgroundObject: A,
6277
6509
  backgroundManager: a,
6278
6510
  errorManager: i
6279
6511
  }));
6280
- const T = b.map((S) => (this._adaptTextboxWidth({
6512
+ const O = b.map((S) => (this._adaptTextboxWidth({
6281
6513
  object: S,
6282
6514
  baseWidth: f.baseWidth
6283
6515
  }), Z._transformObject({
@@ -6293,16 +6525,16 @@ class Z {
6293
6525
  id: `${S.type}-${et()}`,
6294
6526
  evented: !0
6295
6527
  }), n.add(S), S));
6296
- return !T.length && !y ? null : (p = T.length > 0 || y, T.length && Z._activateObjects({ canvas: n, objects: T }), n.requestRenderAll(), n.fire("editor:template-applied", {
6528
+ return !O.length && !y ? null : (p = O.length > 0 || y, O.length && Z._activateObjects({ canvas: n, objects: O }), n.requestRenderAll(), n.fire("editor:template-applied", {
6297
6529
  template: t,
6298
- objects: T,
6530
+ objects: O,
6299
6531
  bounds: d
6300
- }), T);
6532
+ }), O);
6301
6533
  } catch (v) {
6302
6534
  return i.emitError({
6303
6535
  origin: "TemplateManager",
6304
6536
  method: "applyTemplate",
6305
- code: Dt.TEMPLATE_MANAGER.APPLY_FAILED,
6537
+ code: Lt.TEMPLATE_MANAGER.APPLY_FAILED,
6306
6538
  message: "Ошибка применения шаблона",
6307
6539
  data: {
6308
6540
  templateId: l,
@@ -6349,7 +6581,7 @@ class Z {
6349
6581
  if (i)
6350
6582
  return Z._restoreImageScale({ revived: i, serialized: n }), i;
6351
6583
  }
6352
- const s = yield vt.enlivenObjects([n]), o = s == null ? void 0 : s[0];
6584
+ const s = yield bt.enlivenObjects([n]), o = s == null ? void 0 : s[0];
6353
6585
  return o ? (Z._restoreImageScale({ revived: o, serialized: n }), o) : null;
6354
6586
  })))).filter((n) => !!n);
6355
6587
  });
@@ -6378,22 +6610,22 @@ class Z {
6378
6610
  naturalHeight: 0,
6379
6611
  width: 0,
6380
6612
  height: 0
6381
- }, m = nt({ value: d || f || c.width, fallback: 0 }), p = nt({ value: u || g || c.height, fallback: 0 }), y = nt({ value: s, fallback: m }), v = nt({ value: o, fallback: p }), j = nt({ value: i, fallback: c.scaleX || 1 }), b = nt({ value: a, fallback: c.scaleY || 1 }), T = y * j, S = v * b, M = m > 0, w = p > 0, C = T > 0, A = S > 0, I = Z._resolveImageFit({ customData: r }), O = {};
6382
- if (M && (O.width = m), w && (O.height = p), !M || !w) {
6383
- c.set(O);
6613
+ }, m = nt({ value: d || f || c.width, fallback: 0 }), p = nt({ value: u || g || c.height, fallback: 0 }), y = nt({ value: s, fallback: m }), v = nt({ value: o, fallback: p }), A = nt({ value: i, fallback: c.scaleX || 1 }), b = nt({ value: a, fallback: c.scaleY || 1 }), O = y * A, S = v * b, M = m > 0, w = p > 0, C = O > 0, j = S > 0, I = Z._resolveImageFit({ customData: r }), T = {};
6614
+ if (M && (T.width = m), w && (T.height = p), !M || !w) {
6615
+ c.set(T);
6384
6616
  return;
6385
6617
  }
6386
6618
  if (I === "stretch") {
6387
- const D = C ? T / m : null, W = A ? S / p : null;
6388
- D && D > 0 && (O.scaleX = D), W && W > 0 && (O.scaleY = W), c.set(O);
6619
+ const _ = C ? O / m : null, W = j ? S / p : null;
6620
+ _ && _ > 0 && (T.scaleX = _), W && W > 0 && (T.scaleY = W), c.set(T);
6389
6621
  return;
6390
6622
  }
6391
- if (!C || !A) {
6392
- c.set(O);
6623
+ if (!C || !j) {
6624
+ c.set(T);
6393
6625
  return;
6394
6626
  }
6395
- const k = Math.min(T / m, S / p);
6396
- Number.isFinite(k) && k > 0 && (O.scaleX = k, O.scaleY = k), c.set(O);
6627
+ const k = Math.min(O / m, S / p);
6628
+ Number.isFinite(k) && k > 0 && (T.scaleX = k, T.scaleY = k), c.set(T);
6397
6629
  }
6398
6630
  /**
6399
6631
  * Определяет режим вписывания изображения при восстановлении.
@@ -6419,7 +6651,7 @@ class Z {
6419
6651
  const e = typeof t.svgMarkup == "string" ? t.svgMarkup : null;
6420
6652
  if (!e) return null;
6421
6653
  try {
6422
- const n = yield Rn(e), s = vt.groupSVGElements(n.objects, n.options), o = yield vt.enlivenObjectEnlivables(
6654
+ const n = yield kn(e), s = bt.groupSVGElements(n.objects, n.options), o = yield bt.enlivenObjectEnlivables(
6423
6655
  Z._prepareSerializableProps(t)
6424
6656
  );
6425
6657
  return s.set(o), s.setCoords(), s;
@@ -6484,7 +6716,7 @@ class Z {
6484
6716
  baseHeight: i,
6485
6717
  useRelativePositions: r,
6486
6718
  centerKeys: {
6487
- x: Jt,
6719
+ x: Qt,
6488
6720
  y: Ae
6489
6721
  }
6490
6722
  }), { scaleX: u, scaleY: f } = t, g = nt({ value: u, fallback: 1 }), m = nt({ value: f, fallback: 1 }), p = Z._getPositioningBounds({
@@ -6493,19 +6725,19 @@ class Z {
6493
6725
  baseHeight: i,
6494
6726
  scale: e,
6495
6727
  useRelativePositions: r,
6496
- anchorX: Z._resolveAnchor(c, fe),
6497
- anchorY: Z._resolveAnchor(c, je)
6498
- }), y = zs({
6728
+ anchorX: Z._resolveAnchor(c, ge),
6729
+ anchorY: Z._resolveAnchor(c, Ce)
6730
+ }), y = Ps({
6499
6731
  normalizedX: l,
6500
6732
  normalizedY: d,
6501
6733
  bounds: p,
6502
6734
  targetSize: s,
6503
6735
  montageArea: a
6504
- }), v = g * e, j = m * e;
6736
+ }), v = g * e, A = m * e;
6505
6737
  t.set({
6506
6738
  scaleX: v,
6507
- scaleY: j
6508
- }), t.setPositionByOrigin(y, "center", "center"), t.setCoords(), delete c[Jt], delete c[Ae], delete c[fe], delete c[je];
6739
+ scaleY: A
6740
+ }), t.setPositionByOrigin(y, "center", "center"), t.setCoords(), delete c[Qt], delete c[Ae], delete c[ge], delete c[Ce];
6509
6741
  }
6510
6742
  /**
6511
6743
  * Возвращает bounds, в которых должны позиционироваться нормализованные объекты.
@@ -6552,7 +6784,7 @@ class Z {
6552
6784
  meta: t,
6553
6785
  fallback: e
6554
6786
  }) {
6555
- const { width: n, height: s } = e, r = t || {}, { baseWidth: o = n, baseHeight: i = s } = r, a = jt(r, ["baseWidth", "baseHeight"]);
6787
+ const { width: n, height: s } = e, r = t || {}, { baseWidth: o = n, baseHeight: i = s } = r, a = Ct(r, ["baseWidth", "baseHeight"]);
6556
6788
  return F({
6557
6789
  baseWidth: o,
6558
6790
  baseHeight: i
@@ -6604,16 +6836,16 @@ class Z {
6604
6836
  } = t, r = nt({ value: e, fallback: 0 }), c = t, l = nt({ value: c.paddingLeft, fallback: 0 }), d = nt({ value: c.paddingRight, fallback: 0 }), u = nt({ value: i, fallback: 1 }), f = nt({ value: a, fallback: 0 }) * u, g = nt({ value: o, fallback: 0 }), m = g * u, p = l * u, y = d * u, v = m + p + y + f;
6605
6837
  if (!s || !g || !r) return;
6606
6838
  t.setCoords();
6607
- const j = t, b = j[Jt], T = typeof b == "number" ? b : null, S = Z._resolveAnchor(j, fe), M = v / r, w = T !== null ? T - M / 2 : null, C = T !== null ? T + M / 2 : null, A = t.getCenterPoint();
6839
+ const A = t, b = A[Qt], O = typeof b == "number" ? b : null, S = Z._resolveAnchor(A, ge), M = v / r, w = O !== null ? O - M / 2 : null, C = O !== null ? O + M / 2 : null, j = t.getCenterPoint();
6608
6840
  t.set("width", s), t.initDimensions();
6609
6841
  const I = Z._getLongestLineWidth({
6610
6842
  textbox: t,
6611
6843
  text: n
6612
- }), O = I > g ? I + 1 : g;
6613
- t.set("width", O), t.initDimensions(), t.setPositionByOrigin(A, "center", "center"), t.setCoords();
6614
- const D = (O * u + p + y + f) / r;
6615
- let W = T;
6616
- S === "start" && w !== null ? W = Math.max(0, w) + D / 2 : S === "end" && C !== null && (W = Math.min(1, C) - D / 2), typeof W == "number" && (j[Jt] = W);
6844
+ }), T = I > g ? I + 1 : g;
6845
+ t.set("width", T), t.initDimensions(), t.setPositionByOrigin(j, "center", "center"), t.setCoords();
6846
+ const _ = (T * u + p + y + f) / r;
6847
+ let W = O;
6848
+ S === "start" && w !== null ? W = Math.max(0, w) + _ / 2 : S === "end" && C !== null && (W = Math.min(1, C) - _ / 2), typeof W == "number" && (A[Qt] = W);
6617
6849
  }
6618
6850
  /**
6619
6851
  * Возвращает ширину самой длинной строки текстового объекта.
@@ -6643,7 +6875,7 @@ class Z {
6643
6875
  baseHeight: s,
6644
6876
  montageArea: o
6645
6877
  }) {
6646
- const i = t.toDatalessObject([...Le]);
6878
+ const i = t.toDatalessObject([...De]);
6647
6879
  if (Z._isSvgObject(t)) {
6648
6880
  const b = Z._extractSvgMarkup(t);
6649
6881
  b && (i.svgMarkup = b, delete i.objects, delete i.path);
@@ -6654,7 +6886,7 @@ class Z {
6654
6886
  top: r,
6655
6887
  width: c,
6656
6888
  height: l
6657
- } = e, d = t.getBoundingRect(!1, !0), u = n || c || 1, f = s || l || 1, g = Ps({
6889
+ } = e, d = t.getBoundingRect(!1, !0), u = n || c || 1, f = s || l || 1, g = zs({
6658
6890
  object: t,
6659
6891
  montageArea: o,
6660
6892
  bounds: e
@@ -6664,15 +6896,15 @@ class Z {
6664
6896
  x: (b.x - a) / u,
6665
6897
  y: (b.y - r) / f
6666
6898
  };
6667
- })(), p = (d.left - a) / u, y = (d.top - r) / f, v = p + d.width / u, j = y + d.height / f;
6668
- return i[Jt] = m.x, i[Ae] = m.y, i[fe] = Z._detectAnchor({
6899
+ })(), p = (d.left - a) / u, y = (d.top - r) / f, v = p + d.width / u, A = y + d.height / f;
6900
+ return i[Qt] = m.x, i[Ae] = m.y, i[ge] = Z._detectAnchor({
6669
6901
  center: m.x,
6670
6902
  start: p,
6671
6903
  end: v
6672
- }), i[je] = Z._detectAnchor({
6904
+ }), i[Ce] = Z._detectAnchor({
6673
6905
  center: m.y,
6674
6906
  start: y,
6675
- end: j
6907
+ end: A
6676
6908
  }), i.left = p, i.top = y, i;
6677
6909
  }
6678
6910
  /**
@@ -6727,7 +6959,7 @@ class Z {
6727
6959
  n.emitWarning({
6728
6960
  origin: "TemplateManager",
6729
6961
  method: "applyTemplate",
6730
- code: Dt.TEMPLATE_MANAGER.APPLY_FAILED,
6962
+ code: Lt.TEMPLATE_MANAGER.APPLY_FAILED,
6731
6963
  message: "Не удалось применить фон из шаблона",
6732
6964
  data: o
6733
6965
  });
@@ -6783,16 +7015,16 @@ class Z {
6783
7015
  */
6784
7016
  // eslint-disable-next-line class-methods-use-this
6785
7017
  enlivenObjectEnlivables(t) {
6786
- return vt.enlivenObjectEnlivables(t);
7018
+ return bt.enlivenObjectEnlivables(t);
6787
7019
  }
6788
7020
  }
6789
- const Ce = 5, Mn = "#3D8BF4", Re = 1, ot = 2, Ue = ({
7021
+ const Ie = 5, Sn = "#3D8BF4", ke = 1, ot = 2, Ye = ({
6790
7022
  value: h,
6791
7023
  step: t
6792
- }) => Math.round(h / t) * t, yt = ({
7024
+ }) => Math.round(h / t) * t, vt = ({
6793
7025
  value: h,
6794
7026
  step: t
6795
- }) => Ue({ value: h, step: t }) === h, Sn = ({
7027
+ }) => Ye({ value: h, step: t }) === h, wn = ({
6796
7028
  items: h,
6797
7029
  axis: t
6798
7030
  }) => {
@@ -6806,7 +7038,7 @@ const Ce = 5, Mn = "#3D8BF4", Re = 1, ot = 2, Ue = ({
6806
7038
  }
6807
7039
  h[i + 1] = n;
6808
7040
  }
6809
- }, wn = ({
7041
+ }, jn = ({
6810
7042
  items: h
6811
7043
  }) => {
6812
7044
  for (let t = 0; t < h.length; t += 1) {
@@ -6830,7 +7062,7 @@ const Ce = 5, Mn = "#3D8BF4", Re = 1, ot = 2, Ue = ({
6830
7062
  });
6831
7063
  }
6832
7064
  return e;
6833
- }, gn = ({
7065
+ }, pn = ({
6834
7066
  anchors: h,
6835
7067
  positions: t,
6836
7068
  threshold: e
@@ -6850,11 +7082,11 @@ const Ce = 5, Mn = "#3D8BF4", Re = 1, ot = 2, Ue = ({
6850
7082
  threshold: t,
6851
7083
  anchors: e
6852
7084
  }) => {
6853
- const { left: n, right: s, centerX: o, top: i, bottom: a, centerY: r } = h, c = gn({
7085
+ const { left: n, right: s, centerX: o, top: i, bottom: a, centerY: r } = h, c = pn({
6854
7086
  anchors: e.vertical,
6855
7087
  positions: [n, o, s],
6856
7088
  threshold: t
6857
- }), l = gn({
7089
+ }), l = pn({
6858
7090
  anchors: e.horizontal,
6859
7091
  positions: [i, r, a],
6860
7092
  threshold: t
@@ -6892,40 +7124,40 @@ const Ce = 5, Mn = "#3D8BF4", Re = 1, ot = 2, Ue = ({
6892
7124
  const l = [];
6893
7125
  for (const S of c)
6894
7126
  l.push({ bounds: S, isActive: !1 });
6895
- l.push({ bounds: h, isActive: !0 }), Sn({ items: l, axis: "top" });
6896
- const d = wn({ items: l });
7127
+ l.push({ bounds: h, isActive: !0 }), wn({ items: l, axis: "top" });
7128
+ const d = jn({ items: l });
6897
7129
  if (d === -1)
6898
7130
  return { delta: 0, guide: null };
6899
7131
  const u = [], f = i - o, g = l[d - 1], m = l[d + 1];
6900
7132
  if (g && m) {
6901
7133
  const { bounds: S } = g, { bounds: M } = m, { bottom: w } = S, { top: C } = M, I = C - w - f;
6902
7134
  if (I >= 0) {
6903
- const O = I / 2;
6904
- if (yt({ value: O, step: ot })) {
6905
- const D = Ue({ value: O, step: ot }), W = o - w, E = C - i, L = Math.abs(W - D), z = Math.abs(E - D), B = Math.max(L, z);
7135
+ const T = I / 2;
7136
+ if (vt({ value: T, step: ot })) {
7137
+ const _ = Ye({ value: T, step: ot }), W = o - w, E = C - i, L = Math.abs(W - _), P = Math.abs(E - _), B = Math.max(L, P);
6906
7138
  if (B <= e) {
6907
- const P = D - W;
6908
- if (yt({ value: P, step: ot })) {
6909
- const _ = i + P, R = {
7139
+ const z = _ - W;
7140
+ if (vt({ value: z, step: ot })) {
7141
+ const D = i + z, R = {
6910
7142
  type: "vertical",
6911
7143
  axis: s,
6912
7144
  refStart: w,
6913
- refEnd: w + D,
6914
- activeStart: _,
6915
- activeEnd: _ + D,
6916
- distance: D
7145
+ refEnd: w + _,
7146
+ activeStart: D,
7147
+ activeEnd: D + _,
7148
+ distance: _
6917
7149
  };
6918
- u.push({ delta: P, guide: R, diff: B });
7150
+ u.push({ delta: z, guide: R, diff: B });
6919
7151
  }
6920
7152
  }
6921
7153
  }
6922
7154
  }
6923
7155
  }
6924
7156
  const p = An({ items: l, axis: "vertical" });
6925
- let y = null, v = null, j = null, b = null;
7157
+ let y = null, v = null, A = null, b = null;
6926
7158
  if (g) {
6927
- j = g.bounds;
6928
- const { bottom: S } = j, M = o - S;
7159
+ A = g.bounds;
7160
+ const { bottom: S } = A, M = o - S;
6929
7161
  M >= 0 && (y = M);
6930
7162
  }
6931
7163
  if (m) {
@@ -6938,56 +7170,56 @@ const Ce = 5, Mn = "#3D8BF4", Re = 1, ot = 2, Ue = ({
6938
7170
  beforeIndex: M,
6939
7171
  afterIndex: w,
6940
7172
  start: C,
6941
- end: A,
7173
+ end: j,
6942
7174
  distance: I
6943
7175
  } = S;
6944
- if (!(M === d || w === d || !yt({ value: I, step: ot }))) {
6945
- if (y !== null && j) {
7176
+ if (!(M === d || w === d || !vt({ value: I, step: ot }))) {
7177
+ if (y !== null && A) {
6946
7178
  const k = Math.abs(y - I);
6947
7179
  if (k <= e) {
6948
- const D = I - y;
6949
- if (!yt({ value: D, step: ot })) continue;
6950
- const E = o + D, { bottom: L } = j, z = {
7180
+ const _ = I - y;
7181
+ if (!vt({ value: _, step: ot })) continue;
7182
+ const E = o + _, { bottom: L } = A, P = {
6951
7183
  type: "vertical",
6952
7184
  axis: s,
6953
7185
  refStart: C,
6954
- refEnd: A,
7186
+ refEnd: j,
6955
7187
  activeStart: L,
6956
7188
  activeEnd: E,
6957
7189
  distance: I
6958
7190
  };
6959
- u.push({ delta: D, guide: z, diff: k });
7191
+ u.push({ delta: _, guide: P, diff: k });
6960
7192
  }
6961
7193
  }
6962
7194
  if (v !== null && b) {
6963
7195
  const k = Math.abs(v - I);
6964
7196
  if (k <= e) {
6965
- const D = v - I;
6966
- if (!yt({ value: D, step: ot })) continue;
6967
- const E = i + D, { top: L } = b, z = {
7197
+ const _ = v - I;
7198
+ if (!vt({ value: _, step: ot })) continue;
7199
+ const E = i + _, { top: L } = b, P = {
6968
7200
  type: "vertical",
6969
7201
  axis: s,
6970
7202
  refStart: C,
6971
- refEnd: A,
7203
+ refEnd: j,
6972
7204
  activeStart: E,
6973
7205
  activeEnd: L,
6974
7206
  distance: I
6975
7207
  };
6976
- u.push({ delta: D, guide: z, diff: k });
7208
+ u.push({ delta: _, guide: P, diff: k });
6977
7209
  }
6978
7210
  }
6979
7211
  }
6980
7212
  }
6981
7213
  if (!u.length)
6982
7214
  return { delta: 0, guide: null };
6983
- let T = u[0];
7215
+ let O = u[0];
6984
7216
  for (let S = 1; S < u.length; S += 1) {
6985
7217
  const M = u[S];
6986
- M.diff < T.diff && (T = M);
7218
+ M.diff < O.diff && (O = M);
6987
7219
  }
6988
7220
  return {
6989
- delta: T.delta,
6990
- guide: T.guide
7221
+ delta: O.delta,
7222
+ guide: O.guide
6991
7223
  };
6992
7224
  }, Hs = ({
6993
7225
  activeBounds: h,
@@ -7011,40 +7243,40 @@ const Ce = 5, Mn = "#3D8BF4", Re = 1, ot = 2, Ue = ({
7011
7243
  const l = [];
7012
7244
  for (const S of c)
7013
7245
  l.push({ bounds: S, isActive: !1 });
7014
- l.push({ bounds: h, isActive: !0 }), Sn({ items: l, axis: "left" });
7015
- const d = wn({ items: l });
7246
+ l.push({ bounds: h, isActive: !0 }), wn({ items: l, axis: "left" });
7247
+ const d = jn({ items: l });
7016
7248
  if (d === -1)
7017
7249
  return { delta: 0, guide: null };
7018
7250
  const u = [], f = i - o, g = l[d - 1], m = l[d + 1];
7019
7251
  if (g && m) {
7020
7252
  const { bounds: S } = g, { bounds: M } = m, { right: w } = S, { left: C } = M, I = C - w - f;
7021
7253
  if (I >= 0) {
7022
- const O = I / 2;
7023
- if (yt({ value: O, step: ot })) {
7024
- const D = Ue({ value: O, step: ot }), W = o - w, E = C - i, L = Math.abs(W - D), z = Math.abs(E - D), B = Math.max(L, z);
7254
+ const T = I / 2;
7255
+ if (vt({ value: T, step: ot })) {
7256
+ const _ = Ye({ value: T, step: ot }), W = o - w, E = C - i, L = Math.abs(W - _), P = Math.abs(E - _), B = Math.max(L, P);
7025
7257
  if (B <= e) {
7026
- const P = D - W;
7027
- if (yt({ value: P, step: ot })) {
7028
- const _ = i + P, R = {
7258
+ const z = _ - W;
7259
+ if (vt({ value: z, step: ot })) {
7260
+ const D = i + z, R = {
7029
7261
  type: "horizontal",
7030
7262
  axis: s,
7031
7263
  refStart: w,
7032
- refEnd: w + D,
7033
- activeStart: _,
7034
- activeEnd: _ + D,
7035
- distance: D
7264
+ refEnd: w + _,
7265
+ activeStart: D,
7266
+ activeEnd: D + _,
7267
+ distance: _
7036
7268
  };
7037
- u.push({ delta: P, guide: R, diff: B });
7269
+ u.push({ delta: z, guide: R, diff: B });
7038
7270
  }
7039
7271
  }
7040
7272
  }
7041
7273
  }
7042
7274
  }
7043
7275
  const p = An({ items: l, axis: "horizontal" });
7044
- let y = null, v = null, j = null, b = null;
7276
+ let y = null, v = null, A = null, b = null;
7045
7277
  if (g) {
7046
- j = g.bounds;
7047
- const { right: S } = j, M = o - S;
7278
+ A = g.bounds;
7279
+ const { right: S } = A, M = o - S;
7048
7280
  M >= 0 && (y = M);
7049
7281
  }
7050
7282
  if (m) {
@@ -7057,56 +7289,56 @@ const Ce = 5, Mn = "#3D8BF4", Re = 1, ot = 2, Ue = ({
7057
7289
  beforeIndex: M,
7058
7290
  afterIndex: w,
7059
7291
  start: C,
7060
- end: A,
7292
+ end: j,
7061
7293
  distance: I
7062
7294
  } = S;
7063
- if (!(M === d || w === d || !yt({ value: I, step: ot }))) {
7064
- if (y !== null && j) {
7295
+ if (!(M === d || w === d || !vt({ value: I, step: ot }))) {
7296
+ if (y !== null && A) {
7065
7297
  const k = Math.abs(y - I);
7066
7298
  if (k <= e) {
7067
- const D = I - y;
7068
- if (!yt({ value: D, step: ot })) continue;
7069
- const E = o + D, { right: L } = j, z = {
7299
+ const _ = I - y;
7300
+ if (!vt({ value: _, step: ot })) continue;
7301
+ const E = o + _, { right: L } = A, P = {
7070
7302
  type: "horizontal",
7071
7303
  axis: s,
7072
7304
  refStart: C,
7073
- refEnd: A,
7305
+ refEnd: j,
7074
7306
  activeStart: L,
7075
7307
  activeEnd: E,
7076
7308
  distance: I
7077
7309
  };
7078
- u.push({ delta: D, guide: z, diff: k });
7310
+ u.push({ delta: _, guide: P, diff: k });
7079
7311
  }
7080
7312
  }
7081
7313
  if (v !== null && b) {
7082
7314
  const k = Math.abs(v - I);
7083
7315
  if (k <= e) {
7084
- const D = v - I;
7085
- if (!yt({ value: D, step: ot })) continue;
7086
- const E = i + D, { left: L } = b, z = {
7316
+ const _ = v - I;
7317
+ if (!vt({ value: _, step: ot })) continue;
7318
+ const E = i + _, { left: L } = b, P = {
7087
7319
  type: "horizontal",
7088
7320
  axis: s,
7089
7321
  refStart: C,
7090
- refEnd: A,
7322
+ refEnd: j,
7091
7323
  activeStart: E,
7092
7324
  activeEnd: L,
7093
7325
  distance: I
7094
7326
  };
7095
- u.push({ delta: D, guide: z, diff: k });
7327
+ u.push({ delta: _, guide: P, diff: k });
7096
7328
  }
7097
7329
  }
7098
7330
  }
7099
7331
  }
7100
7332
  if (!u.length)
7101
7333
  return { delta: 0, guide: null };
7102
- let T = u[0];
7334
+ let O = u[0];
7103
7335
  for (let S = 1; S < u.length; S += 1) {
7104
7336
  const M = u[S];
7105
- M.diff < T.diff && (T = M);
7337
+ M.diff < O.diff && (O = M);
7106
7338
  }
7107
7339
  return {
7108
- delta: T.delta,
7109
- guide: T.guide
7340
+ delta: O.delta,
7341
+ guide: O.guide
7110
7342
  };
7111
7343
  }, Zs = ({
7112
7344
  activeBounds: h,
@@ -7140,7 +7372,7 @@ const Ce = 5, Mn = "#3D8BF4", Re = 1, ot = 2, Ue = ({
7140
7372
  }) => {
7141
7373
  const i = Math.min(o, n / 2, s / 2);
7142
7374
  h.moveTo(t + i, e), h.lineTo(t + n - i, e), h.quadraticCurveTo(t + n, e, t + n, e + i), h.lineTo(t + n, e + s - i), h.quadraticCurveTo(t + n, e + s, t + n - i, e + s), h.lineTo(t + i, e + s), h.quadraticCurveTo(t, e + s, t, e + s - i), h.lineTo(t, e + i), h.quadraticCurveTo(t, e, t + i, e), h.closePath();
7143
- }, ke = ({
7375
+ }, Be = ({
7144
7376
  context: h,
7145
7377
  type: t,
7146
7378
  axis: e,
@@ -7157,17 +7389,17 @@ const Ce = 5, Mn = "#3D8BF4", Re = 1, ot = 2, Ue = ({
7157
7389
  offsetAlongAxis: f = 0,
7158
7390
  offsetPerpendicular: g = 0
7159
7391
  }) => {
7160
- const m = i || 1, p = 12 / m, y = d / m, v = u / m, j = (n + s) / 2 + f, b = t === "vertical" ? e + g : j, T = t === "vertical" ? j : e + g;
7392
+ const m = i || 1, p = 12 / m, y = d / m, v = u / m, A = (n + s) / 2 + f, b = t === "vertical" ? e + g : A, O = t === "vertical" ? A : e + g;
7161
7393
  h.save(), h.setLineDash([]), h.fillStyle = a, h.strokeStyle = a, h.lineWidth = l / m, h.font = `${p}px ${c}`, h.textAlign = "center", h.textBaseline = "middle";
7162
- const M = h.measureText(o).width + y * 2, w = p + y * 2, C = b - M / 2, A = T - w / 2;
7394
+ const M = h.measureText(o).width + y * 2, w = p + y * 2, C = b - M / 2, j = O - w / 2;
7163
7395
  h.beginPath(), Gs({
7164
7396
  context: h,
7165
7397
  x: C,
7166
- y: A,
7398
+ y: j,
7167
7399
  width: M,
7168
7400
  height: w,
7169
7401
  radius: v
7170
- }), h.fill(), h.fillStyle = r, h.fillText(o, b, T), h.restore();
7402
+ }), h.fill(), h.fillStyle = r, h.fillText(o, b, O), h.restore();
7171
7403
  }, Vs = ({
7172
7404
  context: h,
7173
7405
  guide: t,
@@ -7183,8 +7415,8 @@ const Ce = 5, Mn = "#3D8BF4", Re = 1, ot = 2, Ue = ({
7183
7415
  distance: c
7184
7416
  } = t, l = Math.round(c).toString();
7185
7417
  h.beginPath(), n === "vertical" ? (h.moveTo(s, o), h.lineTo(s, i), h.moveTo(s, a), h.lineTo(s, r)) : (h.moveTo(o, s), h.lineTo(i, s), h.moveTo(a, s), h.lineTo(r, s)), h.stroke();
7186
- const d = Mn;
7187
- ke({
7418
+ const d = Sn;
7419
+ Be({
7188
7420
  context: h,
7189
7421
  type: n,
7190
7422
  axis: s,
@@ -7193,8 +7425,8 @@ const Ce = 5, Mn = "#3D8BF4", Re = 1, ot = 2, Ue = ({
7193
7425
  text: l,
7194
7426
  zoom: e,
7195
7427
  color: d,
7196
- lineWidth: Re
7197
- }), ke({
7428
+ lineWidth: ke
7429
+ }), Be({
7198
7430
  context: h,
7199
7431
  type: n,
7200
7432
  axis: s,
@@ -7203,9 +7435,9 @@ const Ce = 5, Mn = "#3D8BF4", Re = 1, ot = 2, Ue = ({
7203
7435
  text: l,
7204
7436
  zoom: e,
7205
7437
  color: d,
7206
- lineWidth: Re
7438
+ lineWidth: ke
7207
7439
  });
7208
- }, pn = ({
7440
+ }, mn = ({
7209
7441
  anchors: h,
7210
7442
  bounds: t
7211
7443
  }) => {
@@ -7218,7 +7450,7 @@ const Ce = 5, Mn = "#3D8BF4", Re = 1, ot = 2, Ue = ({
7218
7450
  centerY: a
7219
7451
  } = t;
7220
7452
  h.vertical.push(e, s, n), h.horizontal.push(o, a, i);
7221
- }, mn = ({
7453
+ }, yn = ({
7222
7454
  bounds: h,
7223
7455
  type: t,
7224
7456
  primaryStart: e,
@@ -7248,24 +7480,24 @@ const Ce = 5, Mn = "#3D8BF4", Re = 1, ot = 2, Ue = ({
7248
7480
  }, Xs = ({
7249
7481
  bounds: h
7250
7482
  }) => {
7251
- const t = mn({
7483
+ const t = yn({
7252
7484
  bounds: h,
7253
7485
  type: "vertical",
7254
7486
  primaryStart: "top",
7255
7487
  primaryEnd: "bottom"
7256
- }), e = mn({
7488
+ }), e = yn({
7257
7489
  bounds: h,
7258
7490
  type: "horizontal",
7259
7491
  primaryStart: "left",
7260
7492
  primaryEnd: "right"
7261
7493
  });
7262
7494
  return { vertical: t, horizontal: e };
7263
- }, Ks = ["montage-area", "background", "interaction-blocker"], jn = ({
7495
+ }, Ks = ["montage-area", "background", "interaction-blocker"], Cn = ({
7264
7496
  activeObject: h
7265
7497
  }) => {
7266
7498
  const t = /* @__PURE__ */ new Set();
7267
7499
  return h && (t.add(h), h instanceof X && h.getObjects().forEach((e) => t.add(e))), t;
7268
- }, Cn = ({
7500
+ }, In = ({
7269
7501
  object: h,
7270
7502
  excluded: t,
7271
7503
  ignoredIds: e = Ks
@@ -7334,12 +7566,12 @@ class $ {
7334
7566
  return;
7335
7567
  }
7336
7568
  $._applyMovementStep({ target: e }), !this.anchors.vertical.length && !this.anchors.horizontal.length && this._cacheAnchors({ activeObject: e });
7337
- let o = mt({ object: e });
7569
+ let o = yt({ object: e });
7338
7570
  if (!o) {
7339
7571
  this._clearGuides();
7340
7572
  return;
7341
7573
  }
7342
- const { canvas: i } = this, a = i.getZoom() || 1, r = Ce / a, c = Us({
7574
+ const { canvas: i } = this, a = i.getZoom() || 1, r = Ie / a, c = Us({
7343
7575
  activeBounds: o,
7344
7576
  threshold: r,
7345
7577
  anchors: this.anchors
@@ -7349,9 +7581,9 @@ class $ {
7349
7581
  e.set({
7350
7582
  left: y + l,
7351
7583
  top: v + d
7352
- }), e.setCoords(), o = (m = mt({ object: e })) != null ? m : o;
7584
+ }), e.setCoords(), o = (m = yt({ object: e })) != null ? m : o;
7353
7585
  }
7354
- const f = this.cachedTargetBounds.length ? this.cachedTargetBounds : this._collectTargets({ activeObject: e }).map((y) => mt({ object: y })).filter((y) => !!y), g = Zs({
7586
+ const f = this.cachedTargetBounds.length ? this.cachedTargetBounds : this._collectTargets({ activeObject: e }).map((y) => yt({ object: y })).filter((y) => !!y), g = Zs({
7355
7587
  activeBounds: o,
7356
7588
  candidates: f,
7357
7589
  threshold: r,
@@ -7362,7 +7594,7 @@ class $ {
7362
7594
  e.set({
7363
7595
  left: y + g.deltaX,
7364
7596
  top: v + g.deltaY
7365
- }), e.setCoords(), o = (p = mt({ object: e })) != null ? p : o;
7597
+ }), e.setCoords(), o = (p = yt({ object: e })) != null ? p : o;
7366
7598
  }
7367
7599
  this._applyGuides({
7368
7600
  guides: u,
@@ -7396,20 +7628,20 @@ class $ {
7396
7628
  horizontal: d
7397
7629
  } = c;
7398
7630
  !l.length && !d.length && this._cacheAnchors({ activeObject: e });
7399
- const u = mt({ object: e });
7631
+ const u = yt({ object: e });
7400
7632
  if (!u) {
7401
7633
  this._clearGuides();
7402
7634
  return;
7403
7635
  }
7404
- const { canvas: f } = this, g = f.getZoom() || 1, m = Ce / g, {
7636
+ const { canvas: f } = this, g = f.getZoom() || 1, m = Ie / g, {
7405
7637
  originX: p,
7406
7638
  originY: y
7407
7639
  } = s, {
7408
7640
  originX: v = "left",
7409
- originY: j = "top",
7641
+ originY: A = "top",
7410
7642
  scaleX: b = 1,
7411
- scaleY: T = 1
7412
- } = e, S = p != null ? p : v, M = y != null ? y : j, w = $._collectVerticalSnapCandidates({
7643
+ scaleY: O = 1
7644
+ } = e, S = p != null ? p : v, M = y != null ? y : A, w = $._collectVerticalSnapCandidates({
7413
7645
  bounds: u,
7414
7646
  originX: S,
7415
7647
  shouldSnapX: i
@@ -7417,7 +7649,7 @@ class $ {
7417
7649
  bounds: u,
7418
7650
  originY: M,
7419
7651
  shouldSnapY: a
7420
- }), A = $._findAxisSnapCandidate({
7652
+ }), j = $._findAxisSnapCandidate({
7421
7653
  anchors: l,
7422
7654
  candidates: w,
7423
7655
  threshold: m
@@ -7425,47 +7657,47 @@ class $ {
7425
7657
  anchors: d,
7426
7658
  candidates: C,
7427
7659
  threshold: m
7428
- }), { guidePosition: O } = A, { guidePosition: k } = I, D = O !== null, W = k !== null;
7429
- if (!D && !W) {
7660
+ }), { guidePosition: T } = j, { guidePosition: k } = I, _ = T !== null, W = k !== null;
7661
+ if (!_ && !W) {
7430
7662
  this._clearGuides();
7431
7663
  return;
7432
7664
  }
7433
7665
  const E = [];
7434
- let L = null, z = null;
7666
+ let L = null, P = null;
7435
7667
  if (r) {
7436
- const P = $._resolveUniformScale({
7668
+ const z = $._resolveUniformScale({
7437
7669
  bounds: u,
7438
7670
  originX: S,
7439
7671
  originY: M,
7440
- verticalSnap: A,
7672
+ verticalSnap: j,
7441
7673
  horizontalSnap: I
7442
7674
  });
7443
- if (P) {
7444
- const { scaleFactor: x, guide: _ } = P;
7445
- L = b * x, z = T * x, E.push(_);
7675
+ if (z) {
7676
+ const { scaleFactor: x, guide: D } = z;
7677
+ L = b * x, P = O * x, E.push(D);
7446
7678
  }
7447
7679
  }
7448
7680
  if (!r) {
7449
- const { angle: P = 0 } = e, { width: x, height: _ } = $._resolveBaseDimensions({ target: e }), R = Math.abs(b) || 1, N = Math.abs(T) || 1;
7450
- if (D) {
7681
+ const { angle: z = 0 } = e, { width: x, height: D } = $._resolveBaseDimensions({ target: e }), R = Math.abs(b) || 1, N = Math.abs(O) || 1;
7682
+ if (_) {
7451
7683
  const K = $._resolveDesiredWidth({
7452
7684
  bounds: u,
7453
7685
  originX: S,
7454
- snap: A
7686
+ snap: j
7455
7687
  });
7456
7688
  if (K !== null) {
7457
7689
  const H = $._resolveScaleForWidth({
7458
7690
  desiredWidth: K,
7459
7691
  baseWidth: x,
7460
- baseHeight: _,
7692
+ baseHeight: D,
7461
7693
  scaleY: N,
7462
- angle: P
7694
+ angle: z
7463
7695
  });
7464
7696
  if (H !== null) {
7465
7697
  const q = b < 0 ? -1 : 1;
7466
- L = H * q, O !== null && E.push({
7698
+ L = H * q, T !== null && E.push({
7467
7699
  type: "vertical",
7468
- position: O
7700
+ position: T
7469
7701
  });
7470
7702
  }
7471
7703
  }
@@ -7480,13 +7712,13 @@ class $ {
7480
7712
  const H = $._resolveScaleForHeight({
7481
7713
  desiredHeight: K,
7482
7714
  baseWidth: x,
7483
- baseHeight: _,
7715
+ baseHeight: D,
7484
7716
  scaleX: R,
7485
- angle: P
7717
+ angle: z
7486
7718
  });
7487
7719
  if (H !== null) {
7488
- const q = T < 0 ? -1 : 1;
7489
- z = H * q, k !== null && E.push({
7720
+ const q = O < 0 ? -1 : 1;
7721
+ P = H * q, k !== null && E.push({
7490
7722
  type: "horizontal",
7491
7723
  position: k
7492
7724
  });
@@ -7494,14 +7726,14 @@ class $ {
7494
7726
  }
7495
7727
  }
7496
7728
  }
7497
- const B = L !== null || z !== null;
7729
+ const B = L !== null || P !== null;
7498
7730
  if (!B && !E.length) {
7499
7731
  this._clearGuides();
7500
7732
  return;
7501
7733
  }
7502
7734
  if (B) {
7503
- const P = e.getRelativeCenterPoint(), x = e.translateToOriginPoint(P, S, M), _ = {};
7504
- L !== null && (_.scaleX = L, s.scaleX = L), z !== null && (_.scaleY = z, s.scaleY = z), Object.keys(_).length && (e.set(_), e.setPositionByOrigin(x, S, M), e.setCoords());
7735
+ const z = e.getRelativeCenterPoint(), x = e.translateToOriginPoint(z, S, M), D = {};
7736
+ L !== null && (D.scaleX = L, s.scaleX = L), P !== null && (D.scaleY = P, s.scaleY = P), Object.keys(D).length && (e.set(D), e.setPositionByOrigin(x, S, M), e.setCoords());
7505
7737
  }
7506
7738
  this._applyGuides({
7507
7739
  guides: E,
@@ -7535,23 +7767,23 @@ class $ {
7535
7767
  horizontal: c
7536
7768
  } = a;
7537
7769
  !r.length && !c.length && this._cacheAnchors({ activeObject: t });
7538
- const l = mt({ object: t });
7770
+ const l = yt({ object: t });
7539
7771
  if (!l) {
7540
7772
  this._clearGuides();
7541
7773
  return;
7542
7774
  }
7543
- const { canvas: d } = this, u = d.getZoom() || 1, f = Ce / u, { originX: g, originY: m } = e, {
7775
+ const { canvas: d } = this, u = d.getZoom() || 1, f = Ie / u, { originX: g, originY: m } = e, {
7544
7776
  originX: p = "left",
7545
7777
  originY: y = "top"
7546
- } = t, v = g != null ? g : p, j = m != null ? m : y, b = $._collectVerticalSnapCandidates({
7778
+ } = t, v = g != null ? g : p, A = m != null ? m : y, b = $._collectVerticalSnapCandidates({
7547
7779
  bounds: l,
7548
7780
  originX: v,
7549
7781
  shouldSnapX: !0
7550
- }), T = $._findAxisSnapCandidate({
7782
+ }), O = $._findAxisSnapCandidate({
7551
7783
  anchors: r,
7552
7784
  candidates: b,
7553
7785
  threshold: f
7554
- }), { guidePosition: S } = T;
7786
+ }), { guidePosition: S } = O;
7555
7787
  if (S === null) {
7556
7788
  this._clearGuides();
7557
7789
  return;
@@ -7559,7 +7791,7 @@ class $ {
7559
7791
  const M = $._resolveDesiredWidth({
7560
7792
  bounds: l,
7561
7793
  originX: v,
7562
- snap: T
7794
+ snap: O
7563
7795
  });
7564
7796
  if (M === null) {
7565
7797
  this._clearGuides();
@@ -7575,8 +7807,8 @@ class $ {
7575
7807
  }
7576
7808
  const { width: C = 0 } = t;
7577
7809
  if (w !== C) {
7578
- const A = t.getRelativeCenterPoint(), I = t.translateToOriginPoint(A, v, j);
7579
- t.set({ width: w }), t.setPositionByOrigin(I, v, j), t.setCoords();
7810
+ const j = t.getRelativeCenterPoint(), I = t.translateToOriginPoint(j, v, A);
7811
+ t.set({ width: w }), t.setPositionByOrigin(I, v, A), t.setCoords();
7580
7812
  }
7581
7813
  this._applyGuides({
7582
7814
  guides: [
@@ -7609,7 +7841,7 @@ class $ {
7609
7841
  const { canvas: t, guideBounds: e } = this, n = t.getSelectionContext();
7610
7842
  if (!n) return;
7611
7843
  const s = e != null ? e : this._calculateViewportBounds(), { left: o, right: i, top: a, bottom: r } = s, { viewportTransform: c } = t, l = t.getZoom() || 1;
7612
- n.save(), Array.isArray(c) && n.transform(...c), n.lineWidth = Re / l, n.strokeStyle = Mn, n.setLineDash([4, 4]);
7844
+ n.save(), Array.isArray(c) && n.transform(...c), n.lineWidth = ke / l, n.strokeStyle = Sn, n.setLineDash([4, 4]);
7613
7845
  for (const d of this.activeGuides)
7614
7846
  n.beginPath(), d.type === "vertical" ? (n.moveTo(d.position, a), n.lineTo(d.position, r)) : (n.moveTo(o, d.position), n.lineTo(i, d.position)), n.stroke();
7615
7847
  for (const d of this.activeSpacingGuides)
@@ -7754,31 +7986,31 @@ class $ {
7754
7986
  } = o;
7755
7987
  let p = null, y = null;
7756
7988
  if (u !== null && l > 0) {
7757
- const j = $._resolveDesiredWidth({
7989
+ const A = $._resolveDesiredWidth({
7758
7990
  bounds: t,
7759
7991
  originX: e,
7760
7992
  snap: s
7761
7993
  });
7762
- if (j !== null) {
7763
- const b = j / l;
7994
+ if (A !== null) {
7995
+ const b = A / l;
7764
7996
  Number.isFinite(b) && b > 0 && (p = b);
7765
7997
  }
7766
7998
  }
7767
7999
  if (g !== null && d > 0) {
7768
- const j = $._resolveDesiredHeight({
8000
+ const A = $._resolveDesiredHeight({
7769
8001
  bounds: t,
7770
8002
  originY: n,
7771
8003
  snap: o
7772
8004
  });
7773
- if (j !== null) {
7774
- const b = j / d;
8005
+ if (A !== null) {
8006
+ const b = A / d;
7775
8007
  Number.isFinite(b) && b > 0 && (y = b);
7776
8008
  }
7777
8009
  }
7778
8010
  let v = null;
7779
8011
  if (p !== null && y === null && (v = "x"), y !== null && p === null && (v = "y"), p !== null && y !== null) {
7780
- const j = Math.abs(f), b = Math.abs(m);
7781
- j <= b && (v = "x"), j > b && (v = "y");
8012
+ const A = Math.abs(f), b = Math.abs(m);
8013
+ A <= b && (v = "x"), A > b && (v = "y");
7782
8014
  }
7783
8015
  return v === "x" && p !== null && u !== null ? {
7784
8016
  scaleFactor: p,
@@ -7910,12 +8142,12 @@ class $ {
7910
8142
  _cacheAnchors({ activeObject: t }) {
7911
8143
  const e = this._collectTargets({ activeObject: t }), n = { vertical: [], horizontal: [] }, s = [];
7912
8144
  for (const a of e) {
7913
- const r = mt({ object: a });
7914
- r && (pn({ anchors: n, bounds: r }), s.push(r));
8145
+ const r = yt({ object: a });
8146
+ r && (mn({ anchors: n, bounds: r }), s.push(r));
7915
8147
  }
7916
- const { montageArea: o } = this.editor, i = mt({ object: o });
8148
+ const { montageArea: o } = this.editor, i = yt({ object: o });
7917
8149
  if (i) {
7918
- pn({ anchors: n, bounds: i });
8150
+ mn({ anchors: n, bounds: i });
7919
8151
  const { left: a, right: r, top: c, bottom: l } = i;
7920
8152
  this.guideBounds = {
7921
8153
  left: a,
@@ -7931,9 +8163,9 @@ class $ {
7931
8163
  * Собирает объекты, подходящие для прилипания, исключая активный объект и запрещённые id.
7932
8164
  */
7933
8165
  _collectTargets({ activeObject: t }) {
7934
- const e = jn({ activeObject: t }), n = [];
8166
+ const e = Cn({ activeObject: t }), n = [];
7935
8167
  return this.canvas.forEachObject((s) => {
7936
- Cn({ object: s, excluded: e }) || n.push(s);
8168
+ In({ object: s, excluded: e }) || n.push(s);
7937
8169
  }), n;
7938
8170
  }
7939
8171
  /**
@@ -7956,8 +8188,8 @@ class $ {
7956
8188
  };
7957
8189
  }
7958
8190
  }
7959
- const yn = "#3D8BF4", vn = 1;
7960
- class Wt {
8191
+ const vn = "#3D8BF4", bn = 1;
8192
+ class Ut {
7961
8193
  /**
7962
8194
  * Создаёт менеджер измерений и инициализирует события.
7963
8195
  */
@@ -8062,15 +8294,15 @@ class Wt {
8062
8294
  this._clearGuides();
8063
8295
  return;
8064
8296
  }
8065
- const o = mt({ object: s });
8297
+ const o = yt({ object: s });
8066
8298
  if (!o) {
8067
8299
  this._clearGuides();
8068
8300
  return;
8069
8301
  }
8070
- const i = Wt._resolveTarget({
8302
+ const i = Ut._resolveTarget({
8071
8303
  event: t,
8072
8304
  activeObject: s
8073
- }), { montageArea: a } = n, r = i != null ? i : a, c = r === a, l = mt({ object: r });
8305
+ }), { montageArea: a } = n, r = i != null ? i : a, c = r === a, l = yt({ object: r });
8074
8306
  if (!l) {
8075
8307
  this._clearGuides();
8076
8308
  return;
@@ -8079,7 +8311,7 @@ class Wt {
8079
8311
  this._clearGuides();
8080
8312
  return;
8081
8313
  }
8082
- const u = Wt._buildGuides({
8314
+ const u = Ut._buildGuides({
8083
8315
  activeBounds: o,
8084
8316
  targetBounds: l,
8085
8317
  targetIsMontageArea: c
@@ -8097,8 +8329,8 @@ class Wt {
8097
8329
  event: t,
8098
8330
  activeObject: e
8099
8331
  }) {
8100
- const { target: n } = t, s = jn({ activeObject: e });
8101
- return n && !Cn({ object: n, excluded: s }) ? n : null;
8332
+ const { target: n } = t, s = Cn({ activeObject: e });
8333
+ return n && !In({ object: n, excluded: s }) ? n : null;
8102
8334
  }
8103
8335
  /**
8104
8336
  * Собирает вертикальные и горизонтальные направляющие расстояний.
@@ -8108,11 +8340,11 @@ class Wt {
8108
8340
  targetBounds: e,
8109
8341
  targetIsMontageArea: n
8110
8342
  }) {
8111
- const s = Wt._buildHorizontalGuides({
8343
+ const s = Ut._buildHorizontalGuides({
8112
8344
  activeBounds: t,
8113
8345
  targetBounds: e,
8114
8346
  targetIsMontageArea: n
8115
- }), o = Wt._buildVerticalGuides({
8347
+ }), o = Ut._buildVerticalGuides({
8116
8348
  activeBounds: t,
8117
8349
  targetBounds: e,
8118
8350
  targetIsMontageArea: n
@@ -8163,21 +8395,21 @@ class Wt {
8163
8395
  }), s;
8164
8396
  }
8165
8397
  if (!n) return s;
8166
- const j = o < l, b = i > d, T = Math.min(o, l), S = Math.max(o, l), M = S - T;
8167
- M > 0 && !j && s.push({
8398
+ const A = o < l, b = i > d, O = Math.min(o, l), S = Math.max(o, l), M = S - O;
8399
+ M > 0 && !A && s.push({
8168
8400
  type: "horizontal",
8169
8401
  axis: v,
8170
- start: T,
8402
+ start: O,
8171
8403
  end: S,
8172
8404
  distance: M
8173
8405
  });
8174
- const w = Math.min(i, d), C = Math.max(i, d), A = C - w;
8175
- return A > 0 && !b && s.push({
8406
+ const w = Math.min(i, d), C = Math.max(i, d), j = C - w;
8407
+ return j > 0 && !b && s.push({
8176
8408
  type: "horizontal",
8177
8409
  axis: v,
8178
8410
  start: w,
8179
8411
  end: C,
8180
- distance: A
8412
+ distance: j
8181
8413
  }), s;
8182
8414
  }
8183
8415
  /**
@@ -8224,21 +8456,21 @@ class Wt {
8224
8456
  }), s;
8225
8457
  }
8226
8458
  if (!n) return s;
8227
- const j = o < l, b = i > d, T = Math.min(o, l), S = Math.max(o, l), M = S - T;
8228
- M > 0 && !j && s.push({
8459
+ const A = o < l, b = i > d, O = Math.min(o, l), S = Math.max(o, l), M = S - O;
8460
+ M > 0 && !A && s.push({
8229
8461
  type: "vertical",
8230
8462
  axis: v,
8231
- start: T,
8463
+ start: O,
8232
8464
  end: S,
8233
8465
  distance: M
8234
8466
  });
8235
- const w = Math.min(i, d), C = Math.max(i, d), A = C - w;
8236
- return A > 0 && !b && s.push({
8467
+ const w = Math.min(i, d), C = Math.max(i, d), j = C - w;
8468
+ return j > 0 && !b && s.push({
8237
8469
  type: "vertical",
8238
8470
  axis: v,
8239
8471
  start: w,
8240
8472
  end: C,
8241
- distance: A
8473
+ distance: j
8242
8474
  }), s;
8243
8475
  }
8244
8476
  /**
@@ -8266,10 +8498,10 @@ class Wt {
8266
8498
  const { canvas: t } = this, e = t.getSelectionContext();
8267
8499
  if (!e) return;
8268
8500
  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;
8269
- e.save(), Array.isArray(n) && e.transform(...n), e.lineWidth = vn / s, e.strokeStyle = yn, e.setLineDash([]);
8501
+ e.save(), Array.isArray(n) && e.transform(...n), e.lineWidth = bn / s, e.strokeStyle = vn, e.setLineDash([]);
8270
8502
  for (const c of this.activeGuides) {
8271
8503
  const { type: l, axis: d, start: u, end: f, distance: g } = c, m = Math.abs(f - u), p = u <= f ? -1 : 1, y = a ? p * (m / 2 + r) : 0, v = 0;
8272
- e.beginPath(), l === "vertical" ? (e.moveTo(d, u), e.lineTo(d, f)) : (e.moveTo(u, d), e.lineTo(f, d)), e.stroke(), ke({
8504
+ e.beginPath(), l === "vertical" ? (e.moveTo(d, u), e.lineTo(d, f)) : (e.moveTo(u, d), e.lineTo(f, d)), e.stroke(), Be({
8273
8505
  context: e,
8274
8506
  type: l,
8275
8507
  axis: d,
@@ -8277,8 +8509,8 @@ class Wt {
8277
8509
  end: f,
8278
8510
  text: Math.round(g).toString(),
8279
8511
  zoom: s,
8280
- color: yn,
8281
- lineWidth: vn,
8512
+ color: vn,
8513
+ lineWidth: bn,
8282
8514
  offsetAlongAxis: y,
8283
8515
  offsetPerpendicular: v
8284
8516
  });
@@ -8304,7 +8536,7 @@ class Wt {
8304
8536
  (e = t == null ? void 0 : t.showAfterTemporary) == null || e.call(t), this.isToolbarHidden = !1;
8305
8537
  }
8306
8538
  }
8307
- class Ye {
8539
+ class He {
8308
8540
  /**
8309
8541
  * Конструктор класса ImageEditor.
8310
8542
  * @param canvasId - идентификатор канваса, в котором будет создан редактор
@@ -8334,12 +8566,12 @@ class Ye {
8334
8566
  showRotationAngle: l,
8335
8567
  _onReadyCallback: d
8336
8568
  } = this.options;
8337
- if (ut.apply(), this.canvas = new kn(this.containerId, this.options), this.moduleLoader = new Fn(), this.workerManager = new Un(), this.errorManager = new te({ editor: this }), this.historyManager = new J({ editor: this }), this.toolbar = new is({ editor: this }), this.transformManager = new gs({ editor: this }), this.zoomManager = new ps({ editor: this }), this.canvasManager = new fs({ editor: this }), this.imageManager = new pt({ editor: this }), this.layerManager = new pe({ editor: this }), this.shapeManager = new ys({ editor: this }), this.interactionBlocker = new ms({ editor: this }), this.backgroundManager = new Ft({ editor: this }), this.clipboardManager = new vs({ editor: this }), this.objectLockManager = new me({ editor: this }), this.groupingManager = new bs({ editor: this }), this.selectionManager = new Ms({ editor: this }), this.deletionManager = new We({ editor: this }), this.panConstraintManager = new Ss({ editor: this }), this.snappingManager = new $({ editor: this }), this.measurementManager = new Wt({ editor: this }), this.fontManager = new De((u = this.options.fonts) != null ? u : []), this.textManager = new rt({ editor: this }), this.templateManager = new Z({ editor: this }), l && (this.angleIndicator = new Fe({ editor: this })), this._createMontageArea(), this._createClippingArea(), this.listeners = new Be({ 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) {
8569
+ if (ut.apply(), this.canvas = new Bn(this.containerId, this.options), this.moduleLoader = new Wn(), this.workerManager = new Yn(), this.errorManager = new ee({ editor: this }), this.historyManager = new J({ editor: this }), this.toolbar = new os({ editor: this }), this.transformManager = new ps({ editor: this }), this.zoomManager = new ms({ editor: this }), this.canvasManager = new gs({ editor: this }), this.imageManager = new mt({ editor: this }), this.layerManager = new me({ editor: this }), this.shapeManager = new vs({ editor: this }), this.interactionBlocker = new ys({ editor: this }), this.backgroundManager = new Wt({ editor: this }), this.clipboardManager = new bs({ editor: this }), this.objectLockManager = new ye({ editor: this }), this.groupingManager = new Ms({ editor: this }), this.selectionManager = new ft({ editor: this }), this.deletionManager = new Ue({ editor: this }), this.panConstraintManager = new Ss({ editor: this }), this.snappingManager = new $({ editor: this }), this.measurementManager = new Ut({ editor: this }), this.fontManager = new Le((u = this.options.fonts) != null ? u : []), this.textManager = new rt({ editor: this }), this.templateManager = new Z({ editor: this }), l && (this.angleIndicator = new We({ editor: this })), this._createMontageArea(), this._createClippingArea(), this.listeners = new Ne({ 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) {
8338
8570
  const f = a, {
8339
8571
  source: g,
8340
8572
  scale: m = `image-${c}`,
8341
8573
  withoutSave: p = !0
8342
- } = f, y = jt(f, [
8574
+ } = f, y = Ct(f, [
8343
8575
  "source",
8344
8576
  "scale",
8345
8577
  "withoutSave"
@@ -8360,7 +8592,7 @@ class Ye {
8360
8592
  this.montageArea = this.shapeManager.addRectangle({
8361
8593
  width: t,
8362
8594
  height: e,
8363
- fill: Ye._createMosaicPattern(),
8595
+ fill: He._createMosaicPattern(),
8364
8596
  stroke: null,
8365
8597
  strokeWidth: 0,
8366
8598
  selectable: !1,
@@ -8401,7 +8633,7 @@ class Ye {
8401
8633
  */
8402
8634
  destroy() {
8403
8635
  var t, e, n, s;
8404
- this.listeners.destroy(), (t = this.snappingManager) == null || t.destroy(), (e = this.measurementManager) == null || e.destroy(), this.toolbar.destroy(), (n = this.angleIndicator) == null || n.destroy(), (s = this.textManager) == null || s.destroy(), this.canvas.dispose(), this.workerManager.worker.terminate(), this.imageManager.revokeBlobUrls(), this.errorManager.cleanBuffer();
8636
+ this.listeners.destroy(), (t = this.snappingManager) == null || t.destroy(), (e = this.measurementManager) == null || e.destroy(), this.toolbar.destroy(), (n = this.angleIndicator) == null || n.destroy(), (s = this.textManager) == null || s.destroy(), this.selectionManager.destroy(), this.canvas.dispose(), this.workerManager.worker.terminate(), this.imageManager.revokeBlobUrls(), this.errorManager.cleanBuffer();
8405
8637
  }
8406
8638
  /**
8407
8639
  * Создает паттерн мозаики.
@@ -8411,7 +8643,7 @@ class Ye {
8411
8643
  const t = document.createElement("canvas");
8412
8644
  t.width = 20, t.height = 20;
8413
8645
  const e = t.getContext("2d");
8414
- 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 Bn({
8646
+ 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 Nn({
8415
8647
  source: t,
8416
8648
  repeat: "repeat"
8417
8649
  });
@@ -9254,6 +9486,7 @@ const U = [
9254
9486
  controlsAboveOverlay: !0,
9255
9487
  centeredRotation: !0,
9256
9488
  enableRetinaScaling: !1,
9489
+ selectionKey: ["ctrlKey", "metaKey"],
9257
9490
  /*
9258
9491
  * Кастомные опции
9259
9492
  */
@@ -9325,7 +9558,6 @@ const U = [
9325
9558
  * Настройки слушателей событий
9326
9559
  */
9327
9560
  adaptCanvasToContainerOnResize: !0,
9328
- bringToFrontOnSelection: !1,
9329
9561
  mouseWheelZooming: !0,
9330
9562
  canvasDragging: !0,
9331
9563
  copyObjectsByHotkey: !0,
@@ -9347,7 +9579,7 @@ function ni(h, t = {}) {
9347
9579
  const s = document.createElement("canvas");
9348
9580
  return s.id = `${h}-canvas`, n.appendChild(s), e.editorContainer = n, new Promise((o) => {
9349
9581
  e._onReadyCallback = o;
9350
- const i = new Ye(s.id, e);
9582
+ const i = new He(s.id, e);
9351
9583
  window[h] = i;
9352
9584
  });
9353
9585
  }