@anu3ev/fabric-image-editor 0.1.56 → 0.1.58

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 +391 -393
  2. package/package.json +1 -1
package/dist/main.js CHANGED
@@ -2,40 +2,40 @@ var fe = Object.defineProperty, je = Object.defineProperties;
2
2
  var be = Object.getOwnPropertyDescriptors;
3
3
  var H = Object.getOwnPropertySymbols;
4
4
  var ce = Object.prototype.hasOwnProperty, de = Object.prototype.propertyIsEnumerable;
5
- var re = (d, e, t) => e in d ? fe(d, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : d[e] = t, p = (d, e) => {
5
+ var re = (c, e, t) => e in c ? fe(c, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : c[e] = t, y = (c, e) => {
6
6
  for (var t in e || (e = {}))
7
- ce.call(e, t) && re(d, t, e[t]);
7
+ ce.call(e, t) && re(c, t, e[t]);
8
8
  if (H)
9
9
  for (var t of H(e))
10
- de.call(e, t) && re(d, t, e[t]);
11
- return d;
12
- }, le = (d, e) => je(d, be(e));
13
- var Y = (d, e) => {
10
+ de.call(e, t) && re(c, t, e[t]);
11
+ return c;
12
+ }, le = (c, e) => je(c, be(e));
13
+ var Y = (c, e) => {
14
14
  var t = {};
15
- for (var s in d)
16
- ce.call(d, s) && e.indexOf(s) < 0 && (t[s] = d[s]);
17
- if (d != null && H)
18
- for (var s of H(d))
19
- e.indexOf(s) < 0 && de.call(d, s) && (t[s] = d[s]);
15
+ for (var s in c)
16
+ ce.call(c, s) && e.indexOf(s) < 0 && (t[s] = c[s]);
17
+ if (c != null && H)
18
+ for (var s of H(c))
19
+ e.indexOf(s) < 0 && de.call(c, s) && (t[s] = c[s]);
20
20
  return t;
21
21
  };
22
- var I = (d, e, t) => new Promise((s, i) => {
23
- var n = (c) => {
22
+ var I = (c, e, t) => new Promise((s, n) => {
23
+ var i = (d) => {
24
24
  try {
25
- o(t.next(c));
25
+ o(t.next(d));
26
26
  } catch (r) {
27
- i(r);
27
+ n(r);
28
28
  }
29
- }, a = (c) => {
29
+ }, a = (d) => {
30
30
  try {
31
- o(t.throw(c));
31
+ o(t.throw(d));
32
32
  } catch (r) {
33
- i(r);
33
+ n(r);
34
34
  }
35
- }, o = (c) => c.done ? s(c.value) : Promise.resolve(c.value).then(n, a);
36
- o((t = t.apply(d, e)).next());
35
+ }, o = (d) => d.done ? s(d.value) : Promise.resolve(d.value).then(i, a);
36
+ o((t = t.apply(c, e)).next());
37
37
  });
38
- import { ActiveSelection as v, util as R, controlsUtils as pe, InteractiveFabricObject as ye, loadSVGFromURL as Ie, FabricImage as Z, Point as _, Rect as ve, Circle as Ae, Triangle as Se, Group as X, Canvas as Ce, Pattern as Ne } from "fabric";
38
+ import { ActiveSelection as v, util as R, controlsUtils as ye, InteractiveFabricObject as pe, loadSVGFromURL as Ie, FabricImage as Z, Point as _, Rect as ve, Circle as Ae, Triangle as Se, Group as X, Canvas as Ce, Pattern as Ne } from "fabric";
39
39
  import { create as De } from "jsondiffpatch";
40
40
  import Le from "diff-match-patch";
41
41
  var we = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict", L = function() {
@@ -71,15 +71,15 @@ class z {
71
71
  adaptCanvasToContainerOnResize: e,
72
72
  canvasDragging: t,
73
73
  mouseWheelZooming: s,
74
- bringToFrontOnSelection: i,
75
- copyObjectsByHotkey: n,
74
+ bringToFrontOnSelection: n,
75
+ copyObjectsByHotkey: i,
76
76
  pasteImageFromClipboard: a,
77
77
  undoRedoByHotKeys: o,
78
- selectAllByHotkey: c,
78
+ selectAllByHotkey: d,
79
79
  deleteObjectsByHotkey: r,
80
80
  resetObjectFitByDoubleClick: l
81
81
  } = this.options;
82
- t && (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 })), s && this.canvas.on("mouse:wheel", this.handleMouseWheelZoomBound), i && (this.canvas.on("selection:created", this.handleBringToFrontBound), this.canvas.on("selection:updated", this.handleBringToFrontBound)), l && this.canvas.on("mouse:dblclick", this.handleResetObjectFitBound), e && window.addEventListener("resize", this.handleContainerResizeBound, { capture: !0 }), n && document.addEventListener("keydown", this.handleCopyEventBound, { capture: !0 }), a && document.addEventListener("paste", this.handlePasteEventBound, { capture: !0 }), o && (document.addEventListener("keydown", this.handleUndoRedoEventBound, { capture: !0 }), document.addEventListener("keyup", this.handleUndoRedoKeyUpBound, { capture: !0 })), c && 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:added", this.handleOverlayUpdateBound), this.canvas.on("selection:created", this.handleOverlayUpdateBound), this.canvas.on("selection:created", this.handleLockedSelectionBound), this.canvas.on("selection:updated", this.handleLockedSelectionBound);
82
+ t && (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 })), s && this.canvas.on("mouse:wheel", this.handleMouseWheelZoomBound), n && (this.canvas.on("selection:created", this.handleBringToFrontBound), this.canvas.on("selection:updated", this.handleBringToFrontBound)), l && this.canvas.on("mouse:dblclick", this.handleResetObjectFitBound), e && window.addEventListener("resize", this.handleContainerResizeBound, { capture: !0 }), i && document.addEventListener("keydown", this.handleCopyEventBound, { capture: !0 }), a && document.addEventListener("paste", this.handlePasteEventBound, { capture: !0 }), o && (document.addEventListener("keydown", this.handleUndoRedoEventBound, { capture: !0 }), document.addEventListener("keyup", this.handleUndoRedoKeyUpBound, { capture: !0 })), d && 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:added", this.handleOverlayUpdateBound), this.canvas.on("selection:created", this.handleOverlayUpdateBound), this.canvas.on("selection:created", this.handleLockedSelectionBound), this.canvas.on("selection:updated", this.handleLockedSelectionBound);
83
83
  }
84
84
  /**
85
85
  * При массовом выделении объектов удаляем из него залоченные.
@@ -89,19 +89,19 @@ class z {
89
89
  */
90
90
  _filterLockedSelection({ selected: e, e: t }) {
91
91
  if (!(e != null && e.length) || !(t instanceof MouseEvent) || e.length === 1 || !e.some((a) => a.locked)) return;
92
- const i = e.filter((a) => !a.locked);
93
- if (i.length === 0) {
92
+ const n = e.filter((a) => !a.locked);
93
+ if (n.length === 0) {
94
94
  this.canvas.discardActiveObject();
95
95
  return;
96
96
  }
97
- if (i.length === 1) {
98
- this.canvas.setActiveObject(i[0]);
97
+ if (n.length === 1) {
98
+ this.canvas.setActiveObject(n[0]);
99
99
  return;
100
100
  }
101
- const n = new v(i, {
101
+ const i = new v(n, {
102
102
  canvas: this.canvas
103
103
  });
104
- this.canvas.setActiveObject(n), this.canvas.requestRenderAll();
104
+ this.canvas.setActiveObject(i), this.canvas.requestRenderAll();
105
105
  }
106
106
  /**
107
107
  * Обработчики для сохранения состояния редактора в истории.
@@ -132,7 +132,7 @@ class z {
132
132
  * Адаптирует канвас к размерам контейнера, сохраняя позиции объектов.
133
133
  */
134
134
  handleContainerResize() {
135
- this.editor.canvasManager.updateCanvasAndFitObjects();
135
+ this.editor.canvasManager.updateCanvas();
136
136
  }
137
137
  /**
138
138
  * Обработчик для Ctrl+C (копирование).
@@ -142,8 +142,8 @@ class z {
142
142
  * @param event.code — код клавиши
143
143
  */
144
144
  handleCopyEvent(e) {
145
- const { ctrlKey: t, metaKey: s, code: i } = e;
146
- !t && !s || i !== "KeyC" || (e.preventDefault(), this.editor.clipboardManager.copy());
145
+ const { ctrlKey: t, metaKey: s, code: n } = e;
146
+ !t && !s || n !== "KeyC" || (e.preventDefault(), this.editor.clipboardManager.copy());
147
147
  }
148
148
  /**
149
149
  * Обработчик вставки объекта или изображения из буфера обмена.
@@ -161,8 +161,8 @@ class z {
161
161
  */
162
162
  handleUndoRedoEvent(e) {
163
163
  return I(this, null, function* () {
164
- const { ctrlKey: t, metaKey: s, code: i, repeat: n } = e;
165
- !t && !s || n || !/Mac/i.test(navigator.userAgent) && this.isUndoRedoKeyPressed || (i === "KeyZ" ? (e.preventDefault(), this.isUndoRedoKeyPressed = !0, yield this.editor.historyManager.undo()) : i === "KeyY" && (e.preventDefault(), this.isUndoRedoKeyPressed = !0, yield this.editor.historyManager.redo()));
164
+ const { ctrlKey: t, metaKey: s, code: n, repeat: i } = e;
165
+ !t && !s || i || !/Mac/i.test(navigator.userAgent) && this.isUndoRedoKeyPressed || (n === "KeyZ" ? (e.preventDefault(), this.isUndoRedoKeyPressed = !0, yield this.editor.historyManager.undo()) : n === "KeyY" && (e.preventDefault(), this.isUndoRedoKeyPressed = !0, yield this.editor.historyManager.redo()));
166
166
  });
167
167
  }
168
168
  /**
@@ -181,8 +181,8 @@ class z {
181
181
  * @param event.code — код клавиши
182
182
  */
183
183
  handleSelectAllEvent(e) {
184
- const { ctrlKey: t, metaKey: s, code: i } = e;
185
- !t && !s || i !== "KeyA" || (e.preventDefault(), this.editor.selectionManager.selectAll());
184
+ const { ctrlKey: t, metaKey: s, code: n } = e;
185
+ !t && !s || n !== "KeyA" || (e.preventDefault(), this.editor.selectionManager.selectAll());
186
186
  }
187
187
  /**
188
188
  * Обработчик для удаления объектов (Delete).
@@ -200,8 +200,8 @@ class z {
200
200
  */
201
201
  handleSpaceKeyDown(e) {
202
202
  if (e.code !== "Space") return;
203
- const { canvas: t, editor: s, isSpacePressed: i, isDragging: n } = this;
204
- i || n || (this.isSpacePressed = !0, e.preventDefault(), t.set({
203
+ const { canvas: t, editor: s, isSpacePressed: n, isDragging: i } = this;
204
+ n || i || (this.isSpacePressed = !0, e.preventDefault(), t.set({
205
205
  selection: !1,
206
206
  defaultCursor: "grab"
207
207
  }), t.setCursor("grab"), s.canvasManager.getObjects().forEach((a) => {
@@ -299,9 +299,9 @@ class z {
299
299
  */
300
300
  static debounce(e, t) {
301
301
  let s = null;
302
- return function(...i) {
302
+ return function(...n) {
303
303
  s !== null && clearTimeout(s), s = setTimeout(() => {
304
- e.apply(this, i);
304
+ e.apply(this, n);
305
305
  }, t);
306
306
  };
307
307
  }
@@ -324,11 +324,11 @@ class Ee {
324
324
  return this.loaders[e] ? (this.cache.has(e) || this.cache.set(e, this.loaders[e]()), this.cache.get(e)) : Promise.reject(new Error(`Unknown module "${e}"`));
325
325
  }
326
326
  }
327
- function Oe(d) {
327
+ function Oe(c) {
328
328
  return new Worker(
329
329
  "" + new URL("assets/worker-Cmho-Hr0.js", import.meta.url).href,
330
330
  {
331
- name: d == null ? void 0 : d.name
331
+ name: c == null ? void 0 : c.name
332
332
  }
333
333
  );
334
334
  }
@@ -351,12 +351,12 @@ class Te {
351
351
  * @returns
352
352
  */
353
353
  _handleMessage({ data: e }) {
354
- const { requestId: t, success: s, data: i, error: n } = e, a = this._callbacks.get(t);
354
+ const { requestId: t, success: s, data: n, error: i } = e, a = this._callbacks.get(t);
355
355
  if (!a) {
356
356
  console.warn(`No callback found for requestId: ${t}`);
357
357
  return;
358
358
  }
359
- s ? a.resolve(i) : a.reject(new Error(n)), this._callbacks.delete(t);
359
+ s ? a.resolve(n) : a.reject(new Error(i)), this._callbacks.delete(t);
360
360
  }
361
361
  /**
362
362
  * Универсальный метод отправки команды в воркер
@@ -366,9 +366,9 @@ class Te {
366
366
  * @returns Promise, который будет выполнен, когда воркер вернет ответ
367
367
  */
368
368
  post(e, t, s = []) {
369
- const i = `${e}:${L(8)}`;
370
- return new Promise((n, a) => {
371
- this._callbacks.set(i, { resolve: n, reject: a }), this.worker.postMessage({ action: e, payload: t, requestId: i }, s);
369
+ const n = `${e}:${L(8)}`;
370
+ return new Promise((i, a) => {
371
+ this._callbacks.set(n, { resolve: i, reject: a }), this.worker.postMessage({ action: e, payload: t, requestId: n }, s);
372
372
  });
373
373
  }
374
374
  /**
@@ -379,23 +379,23 @@ class Te {
379
379
  }
380
380
  }
381
381
  const N = 12, ke = 2, Q = 8, J = 20, xe = 100, $ = 20, K = 8, Be = 100, q = 32, ee = 1, Ze = "#2B2D33", te = "#3D8BF4", se = "#FFFFFF";
382
- function W(d, e, t, s, i) {
383
- const n = N, a = ke;
384
- d.save(), d.translate(e, t), d.rotate(R.degreesToRadians(i.angle)), d.fillStyle = se, d.strokeStyle = te, d.lineWidth = ee, d.beginPath(), d.roundRect(-12 / 2, -12 / 2, n, n, a), d.fill(), d.stroke(), d.restore();
382
+ function W(c, e, t, s, n) {
383
+ const i = N, a = ke;
384
+ c.save(), c.translate(e, t), c.rotate(R.degreesToRadians(n.angle)), c.fillStyle = se, c.strokeStyle = te, c.lineWidth = ee, c.beginPath(), c.roundRect(-12 / 2, -12 / 2, i, i, a), c.fill(), c.stroke(), c.restore();
385
385
  }
386
- function he(d, e, t, s, i) {
387
- const n = Q, a = J, o = xe;
388
- d.save(), d.translate(e, t), d.rotate(R.degreesToRadians(i.angle)), d.fillStyle = se, d.strokeStyle = te, d.lineWidth = ee, d.beginPath(), d.roundRect(-8 / 2, -20 / 2, n, a, o), d.fill(), d.stroke(), d.restore();
386
+ function he(c, e, t, s, n) {
387
+ const i = Q, a = J, o = xe;
388
+ c.save(), c.translate(e, t), c.rotate(R.degreesToRadians(n.angle)), c.fillStyle = se, c.strokeStyle = te, c.lineWidth = ee, c.beginPath(), c.roundRect(-8 / 2, -20 / 2, i, a, o), c.fill(), c.stroke(), c.restore();
389
389
  }
390
- function ge(d, e, t, s, i) {
391
- const n = $, a = K, o = Be;
392
- d.save(), d.translate(e, t), d.rotate(R.degreesToRadians(i.angle)), d.fillStyle = se, d.strokeStyle = te, d.lineWidth = ee, d.beginPath(), d.roundRect(-20 / 2, -8 / 2, n, a, o), d.fill(), d.stroke(), d.restore();
390
+ function ge(c, e, t, s, n) {
391
+ const i = $, a = K, o = Be;
392
+ c.save(), c.translate(e, t), c.rotate(R.degreesToRadians(n.angle)), c.fillStyle = se, c.strokeStyle = te, c.lineWidth = ee, c.beginPath(), c.roundRect(-20 / 2, -8 / 2, i, a, o), c.fill(), c.stroke(), c.restore();
393
393
  }
394
394
  const Ue = "", ue = new Image();
395
395
  ue.src = Ue;
396
- function ze(d, e, t, s, i) {
396
+ function ze(c, e, t, s, n) {
397
397
  const a = q / 2;
398
- d.save(), d.translate(e, t), d.rotate(R.degreesToRadians(i.angle)), d.fillStyle = Ze, d.beginPath(), d.arc(0, 0, a, 0, 2 * Math.PI), d.fill(), d.drawImage(ue, -16 / 2, -16 / 2, a, a), d.restore();
398
+ c.save(), c.translate(e, t), c.rotate(R.degreesToRadians(n.angle)), c.fillStyle = Ze, c.beginPath(), c.arc(0, 0, a, 0, 2 * Math.PI), c.fill(), c.drawImage(ue, -16 / 2, -16 / 2, a, a), c.restore();
399
399
  }
400
400
  const Re = {
401
401
  // Угловые точки
@@ -468,7 +468,7 @@ const Re = {
468
468
  };
469
469
  class He {
470
470
  static apply() {
471
- const e = pe.createObjectDefaultControls();
471
+ const e = ye.createObjectDefaultControls();
472
472
  Object.entries(Re).forEach(([t, s]) => {
473
473
  Object.assign(e[t], {
474
474
  render: s.render,
@@ -476,11 +476,11 @@ class He {
476
476
  sizeY: s.sizeY,
477
477
  offsetX: s.offsetX,
478
478
  offsetY: s.offsetY
479
- }), t === "mtr" && (e[t].cursorStyle = "grab", e[t].mouseDownHandler = (n, a, o, c) => {
479
+ }), t === "mtr" && (e[t].cursorStyle = "grab", e[t].mouseDownHandler = (i, a, o, d) => {
480
480
  var l;
481
481
  (l = a.target.canvas) == null || l.setCursor("grabbing");
482
482
  });
483
- }), ye.ownDefaults.controls = e;
483
+ }), pe.ownDefaults.controls = e;
484
484
  }
485
485
  }
486
486
  const Ye = "", We = "", _e = "", Pe = "", Fe = "", Ve = "", Ge = "", Xe = "", U = {
@@ -560,29 +560,29 @@ const Ye = "
560
560
  sendBackwards: Fe
561
561
  },
562
562
  handlers: {
563
- copyPaste: (d) => I(void 0, null, function* () {
564
- yield d.clipboardManager.copy(), yield d.clipboardManager.paste();
563
+ copyPaste: (c) => I(void 0, null, function* () {
564
+ yield c.clipboardManager.copy(), yield c.clipboardManager.paste();
565
565
  }),
566
- delete: (d) => {
567
- d.deletionManager.deleteSelectedObjects();
566
+ delete: (c) => {
567
+ c.deletionManager.deleteSelectedObjects();
568
568
  },
569
- lock: (d) => {
570
- d.objectLockManager.lockObject();
569
+ lock: (c) => {
570
+ c.objectLockManager.lockObject();
571
571
  },
572
- unlock: (d) => {
573
- d.objectLockManager.unlockObject();
572
+ unlock: (c) => {
573
+ c.objectLockManager.unlockObject();
574
574
  },
575
- bringForward: (d) => {
576
- d.layerManager.bringForward();
575
+ bringForward: (c) => {
576
+ c.layerManager.bringForward();
577
577
  },
578
- bringToFront: (d) => {
579
- d.layerManager.bringToFront();
578
+ bringToFront: (c) => {
579
+ c.layerManager.bringToFront();
580
580
  },
581
- sendToBack: (d) => {
582
- d.layerManager.sendToBack();
581
+ sendToBack: (c) => {
582
+ c.layerManager.sendToBack();
583
583
  },
584
- sendBackwards: (d) => {
585
- d.layerManager.sendBackwards();
584
+ sendBackwards: (c) => {
585
+ c.layerManager.sendBackwards();
586
586
  }
587
587
  }
588
588
  };
@@ -593,11 +593,11 @@ class Qe {
593
593
  _initToolbar() {
594
594
  if (!this.options.showToolbar) return;
595
595
  const e = this.options.toolbar || {};
596
- this.config = le(p(p({}, U), e), {
597
- style: p(p({}, U.style), e.style || {}),
598
- btnStyle: p(p({}, U.btnStyle), e.btnStyle || {}),
599
- icons: p(p({}, U.icons), e.icons || {}),
600
- handlers: p(p({}, U.handlers), e.handlers || {})
596
+ this.config = le(y(y({}, U), e), {
597
+ style: y(y({}, U.style), e.style || {}),
598
+ btnStyle: y(y({}, U.btnStyle), e.btnStyle || {}),
599
+ icons: y(y({}, U.icons), e.icons || {}),
600
+ handlers: y(y({}, U.handlers), e.handlers || {})
601
601
  }), this.currentTarget = null, this.currentLocked = !1, this.isTransforming = !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 = () => {
602
602
  this.el.style.display = "none";
603
603
  }, this._createDOM(), this._bindEvents();
@@ -608,11 +608,11 @@ class Qe {
608
608
  _createDOM() {
609
609
  const { style: e } = this.config;
610
610
  this.el = document.createElement("div"), Object.assign(this.el.style, e), this.canvas.wrapperEl.appendChild(this.el), this._onBtnOver = (t) => {
611
- const i = t.target.closest("button");
612
- i && Object.assign(i.style, this.config.btnHover);
611
+ const n = t.target.closest("button");
612
+ n && Object.assign(n.style, this.config.btnHover);
613
613
  }, this._onBtnOut = (t) => {
614
- const i = t.target.closest("button");
615
- i && Object.assign(i.style, this.config.btnStyle);
614
+ const n = t.target.closest("button");
615
+ n && Object.assign(n.style, this.config.btnStyle);
616
616
  }, this.el.addEventListener("mouseover", this._onBtnOver), this.el.addEventListener("mouseout", this._onBtnOut);
617
617
  }
618
618
  /**
@@ -624,11 +624,11 @@ class Qe {
624
624
  _renderButtons(e) {
625
625
  this.el.innerHTML = "";
626
626
  for (const t of e) {
627
- const { name: s, handle: i } = t, { icons: n = {}, btnStyle: a, handlers: o = {} } = this.config, c = document.createElement("button");
628
- c.innerHTML = n[i] ? `<img src="${n[i]}" title="${s}" />` : s, Object.assign(c.style, a), c.onclick = () => {
627
+ const { name: s, handle: n } = t, { icons: i = {}, btnStyle: a, handlers: o = {} } = this.config, d = document.createElement("button");
628
+ d.innerHTML = i[n] ? `<img src="${i[n]}" title="${s}" />` : s, Object.assign(d.style, a), d.onclick = () => {
629
629
  var r;
630
- return (r = o[i]) == null ? void 0 : r.call(o, this.editor);
631
- }, this.el.appendChild(c);
630
+ return (r = o[n]) == null ? void 0 : r.call(o, this.editor);
631
+ }, this.el.appendChild(d);
632
632
  }
633
633
  }
634
634
  /**
@@ -684,9 +684,9 @@ class Qe {
684
684
  this.el.style.display = "none";
685
685
  return;
686
686
  }
687
- const { el: t, config: s, canvas: i } = this;
687
+ const { el: t, config: s, canvas: n } = this;
688
688
  e.setCoords();
689
- const n = i.getZoom(), [, , , , a, o] = i.viewportTransform, { x: c } = e.getCenterPoint(), { top: r, height: l } = e.getBoundingRect(), g = c * n + a - t.offsetWidth / 2, u = s.offsetTop || 0, m = (r + l) * n + o + u;
689
+ const i = n.getZoom(), [, , , , a, o] = n.viewportTransform, { x: d } = e.getCenterPoint(), { top: r, height: l } = e.getBoundingRect(), g = d * i + a - t.offsetWidth / 2, u = s.offsetTop || 0, m = (r + l) * i + o + u;
690
690
  Object.assign(t.style, {
691
691
  left: `${g}px`,
692
692
  top: `${m}px`,
@@ -766,10 +766,10 @@ class Je {
766
766
  */
767
767
  getFullState() {
768
768
  const { baseState: e, currentIndex: t, patches: s } = this;
769
- let i = JSON.parse(JSON.stringify(e));
770
- for (let n = 0; n < t; n += 1)
771
- i = this.diffPatcher.patch(i, s[n].diff);
772
- return console.log("getFullState state", i), i;
769
+ let n = JSON.parse(JSON.stringify(e));
770
+ for (let i = 0; i < t; i += 1)
771
+ n = this.diffPatcher.patch(n, s[i].diff);
772
+ return console.log("getFullState state", n), n;
773
773
  }
774
774
  /**
775
775
  * Сохраняем текущее состояние в виде диффа от последнего сохранённого полного состояния.
@@ -813,12 +813,12 @@ class Je {
813
813
  return I(this, null, function* () {
814
814
  if (!e) return;
815
815
  console.log("loadStateFromFullState fullState", e);
816
- const { canvas: t, canvasManager: s, interactionBlocker: i } = this.editor, { width: n, height: a } = t;
816
+ const { canvas: t, canvasManager: s, interactionBlocker: n } = this.editor, { width: i, height: a } = t;
817
817
  yield t.loadFromJSON(e);
818
818
  const o = t.getObjects().find((r) => r.id === "montage-area");
819
- o && (this.editor.montageArea = o, (n !== t.getWidth() || a !== t.getHeight()) && s.updateCanvas());
820
- const c = t.getObjects().find((r) => r.id === "overlay-mask");
821
- c && (i.overlayMask = c, i.overlayMask.visible = !1), t.renderAll(), t.fire("editor:history-state-loaded", {
819
+ o && (this.editor.montageArea = o, (i !== t.getWidth() || a !== t.getHeight()) && s.updateCanvas());
820
+ const d = t.getObjects().find((r) => r.id === "overlay-mask");
821
+ d && (n.overlayMask = d, n.overlayMask.visible = !1), t.renderAll(), t.fire("editor:history-state-loaded", {
822
822
  fullState: e,
823
823
  currentIndex: this.currentIndex,
824
824
  totalChangesCount: this.totalChangesCount,
@@ -925,10 +925,10 @@ class D {
925
925
  const {
926
926
  source: t,
927
927
  scale: s = `image-${this.options.scaleType}`,
928
- withoutSave: i = !1
928
+ withoutSave: n = !1
929
929
  } = e;
930
930
  if (!t) return null;
931
- const { canvas: n, montageArea: a, transformManager: o, historyManager: c, errorManager: r } = this.editor, l = yield this.getContentType(t), h = D.getFormatFromContentType(l), { acceptContentTypes: g, acceptFormats: u } = this;
931
+ const { canvas: i, montageArea: a, transformManager: o, historyManager: d, errorManager: r } = this.editor, l = yield this.getContentType(t), h = D.getFormatFromContentType(l), { acceptContentTypes: g, acceptFormats: u } = this;
932
932
  if (!this.isAllowedContentType(l)) {
933
933
  const m = `Неверный contentType для изображения: ${l}. Ожидается один из: ${this.acceptContentTypes.join(", ")}.`;
934
934
  return r.emitError({
@@ -939,7 +939,7 @@ class D {
939
939
  data: { source: t, format: h, contentType: l, acceptContentTypes: g, acceptFormats: u }
940
940
  }), null;
941
941
  }
942
- c.suspendHistory();
942
+ d.suspendHistory();
943
943
  try {
944
944
  let m, M;
945
945
  if (t instanceof File)
@@ -978,24 +978,24 @@ class D {
978
978
  const { width: b, height: S } = a, w = this.calculateScaleFactor({ imageObject: M, scaleType: s });
979
979
  s === "image-contain" && w < 1 ? o.fitObject({ object: M, type: "contain", withoutSave: !0 }) : s === "image-cover" && (f > b || j > S) && o.fitObject({ object: M, type: "cover", withoutSave: !0 });
980
980
  }
981
- n.add(M), n.centerObject(M), n.setActiveObject(M), n.renderAll(), c.resumeHistory(), i || c.saveState();
981
+ i.add(M), i.centerObject(M), i.setActiveObject(M), i.renderAll(), d.resumeHistory(), n || d.saveState();
982
982
  const A = {
983
983
  image: M,
984
984
  format: h,
985
985
  contentType: l,
986
986
  scale: s,
987
- withoutSave: i,
987
+ withoutSave: n,
988
988
  source: t
989
989
  };
990
- return n.fire("editor:image-imported", A), A;
990
+ return i.fire("editor:image-imported", A), A;
991
991
  } catch (m) {
992
992
  return r.emitError({
993
993
  origin: "ImageManager",
994
994
  method: "importImage",
995
995
  code: "IMPORT_FAILED",
996
996
  message: `Ошибка импорта изображения: ${m.message}`,
997
- data: { source: t, format: h, contentType: l, scale: s, withoutSave: i }
998
- }), c.resumeHistory(), null;
997
+ data: { source: t, format: h, contentType: l, scale: s, withoutSave: n }
998
+ }), d.resumeHistory(), null;
999
999
  }
1000
1000
  });
1001
1001
  }
@@ -1011,7 +1011,7 @@ class D {
1011
1011
  return I(this, null, function* () {
1012
1012
  let s = `Размер изображения больше максимального размера канваса, поэтому оно будет уменьшено до максимальных размеров c сохранением пропорций: ${O}x${T}`;
1013
1013
  t === "min" && (s = `Размер изображения меньше минимального размера канваса, поэтому оно будет увеличено до минимальных размеров c сохранением пропорций: ${x}x${B}`);
1014
- const i = {
1014
+ const n = {
1015
1015
  dataURL: e,
1016
1016
  sizeType: t,
1017
1017
  maxWidth: O,
@@ -1024,8 +1024,8 @@ class D {
1024
1024
  method: "resizeImageToBoundaries",
1025
1025
  code: "IMAGE_RESIZE_WARNING",
1026
1026
  message: s,
1027
- data: i
1028
- }), this.editor.workerManager.post("resizeImage", i);
1027
+ data: n
1028
+ }), this.editor.workerManager.post("resizeImage", n);
1029
1029
  });
1030
1030
  }
1031
1031
  /**
@@ -1044,24 +1044,24 @@ class D {
1044
1044
  const {
1045
1045
  fileName: t = "image.png",
1046
1046
  contentType: s = "image/png",
1047
- exportAsBase64: i = !1,
1048
- exportAsBlob: n = !1
1049
- } = e, { canvas: a, montageArea: o, workerManager: c } = this.editor;
1047
+ exportAsBase64: n = !1,
1048
+ exportAsBlob: i = !1
1049
+ } = e, { canvas: a, montageArea: o, workerManager: d } = this.editor;
1050
1050
  try {
1051
1051
  const r = s === "application/pdf", l = r ? "image/jpg" : s, h = D.getFormatFromContentType(l);
1052
1052
  o.setCoords();
1053
1053
  const { left: g, top: u, width: m, height: M } = o.getBoundingRect(), f = yield a.clone(["id", "format", "locked"]);
1054
1054
  ["image/jpg", "image/jpeg"].includes(l) && (f.backgroundColor = "#ffffff");
1055
- const j = f.getObjects().find((y) => y.id === o.id);
1055
+ const j = f.getObjects().find((p) => p.id === o.id);
1056
1056
  j && (j.visible = !1), f.viewportTransform = [1, 0, 0, 1, -g, -u], f.setDimensions({ width: m, height: M }, { backstoreOnly: !0 }), f.renderAll();
1057
- const A = f.getObjects().filter((y) => y.format).every((y) => y.format === "svg");
1057
+ const A = f.getObjects().filter((p) => p.format).every((p) => p.format === "svg");
1058
1058
  if (h === "svg" && A) {
1059
- const y = f.toSVG();
1059
+ const p = f.toSVG();
1060
1060
  f.dispose();
1061
1061
  const C = {
1062
- image: D._exportSVGStringAsFile(y, {
1063
- exportAsBase64: i,
1064
- exportAsBlob: n,
1062
+ image: D._exportSVGStringAsFile(p, {
1063
+ exportAsBase64: n,
1064
+ exportAsBlob: i,
1065
1065
  fileName: t
1066
1066
  }),
1067
1067
  format: "svg",
@@ -1070,21 +1070,21 @@ class D {
1070
1070
  };
1071
1071
  return a.fire("editor:canvas-exported", C), C;
1072
1072
  }
1073
- const b = yield new Promise((y, k) => {
1073
+ const b = yield new Promise((p, k) => {
1074
1074
  f.getElement().toBlob((C) => {
1075
- C ? y(C) : k(new Error("Failed to create Blob from canvas"));
1075
+ C ? p(C) : k(new Error("Failed to create Blob from canvas"));
1076
1076
  });
1077
1077
  });
1078
- if (f.dispose(), n) {
1079
- const y = {
1078
+ if (f.dispose(), i) {
1079
+ const p = {
1080
1080
  image: b,
1081
1081
  format: h,
1082
1082
  contentType: l,
1083
1083
  fileName: t
1084
1084
  };
1085
- return a.fire("editor:canvas-exported", y), y;
1085
+ return a.fire("editor:canvas-exported", p), p;
1086
1086
  }
1087
- const S = yield createImageBitmap(b), w = yield c.post(
1087
+ const S = yield createImageBitmap(b), w = yield d.post(
1088
1088
  "toDataURL",
1089
1089
  { format: h, quality: 1, bitmap: S },
1090
1090
  [S]
@@ -1095,7 +1095,7 @@ class D {
1095
1095
  unit: "mm",
1096
1096
  format: [k, C]
1097
1097
  });
1098
- if (G.addImage(String(w), "JPG", 0, 0, k, C), i) {
1098
+ if (G.addImage(String(w), "JPG", 0, 0, k, C), n) {
1099
1099
  const oe = {
1100
1100
  image: G.output("datauristring"),
1101
1101
  format: "pdf",
@@ -1112,29 +1112,29 @@ class D {
1112
1112
  };
1113
1113
  return a.fire("editor:canvas-exported", ae), ae;
1114
1114
  }
1115
- if (i) {
1116
- const y = {
1115
+ if (n) {
1116
+ const p = {
1117
1117
  image: w,
1118
1118
  format: h,
1119
1119
  contentType: l,
1120
1120
  fileName: t
1121
1121
  };
1122
- return a.fire("editor:canvas-exported", y), y;
1122
+ return a.fire("editor:canvas-exported", p), p;
1123
1123
  }
1124
- const E = h === "svg" && !A ? t.replace(/\.[^/.]+$/, ".png") : t, ne = {
1124
+ const E = h === "svg" && !A ? t.replace(/\.[^/.]+$/, ".png") : t, ie = {
1125
1125
  image: new File([b], E, { type: l }),
1126
1126
  format: h,
1127
1127
  contentType: l,
1128
1128
  fileName: E
1129
1129
  };
1130
- return a.fire("editor:canvas-exported", ne), ne;
1130
+ return a.fire("editor:canvas-exported", ie), ie;
1131
1131
  } catch (r) {
1132
1132
  return this.editor.errorManager.emitError({
1133
1133
  origin: "ImageManager",
1134
1134
  method: "exportCanvasAsImageFile",
1135
1135
  code: "IMAGE_EXPORT_FAILED",
1136
1136
  message: `Ошибка экспорта изображения: ${r.message}`,
1137
- data: { contentType: s, fileName: t, exportAsBase64: i, exportAsBlob: n }
1137
+ data: { contentType: s, fileName: t, exportAsBase64: n, exportAsBlob: i }
1138
1138
  }), null;
1139
1139
  }
1140
1140
  });
@@ -1155,23 +1155,23 @@ class D {
1155
1155
  const {
1156
1156
  object: t,
1157
1157
  fileName: s = "image.png",
1158
- contentType: i = "image/png",
1159
- exportAsBase64: n = !1,
1158
+ contentType: n = "image/png",
1159
+ exportAsBase64: i = !1,
1160
1160
  exportAsBlob: a = !1
1161
- } = e, { canvas: o, workerManager: c } = this.editor, r = t || o.getActiveObject();
1161
+ } = e, { canvas: o, workerManager: d } = this.editor, r = t || o.getActiveObject();
1162
1162
  if (!r)
1163
1163
  return this.editor.errorManager.emitError({
1164
1164
  origin: "ImageManager",
1165
1165
  method: "exportObjectAsImageFile",
1166
1166
  code: "NO_OBJECT_SELECTED",
1167
1167
  message: "Не выбран объект для экспорта",
1168
- data: { contentType: i, fileName: s, exportAsBase64: n, exportAsBlob: a }
1168
+ data: { contentType: n, fileName: s, exportAsBase64: i, exportAsBlob: a }
1169
1169
  }), null;
1170
1170
  try {
1171
- const l = D.getFormatFromContentType(i);
1171
+ const l = D.getFormatFromContentType(n);
1172
1172
  if (l === "svg") {
1173
1173
  const M = r.toSVG(), f = D._exportSVGStringAsFile(M, {
1174
- exportAsBase64: n,
1174
+ exportAsBase64: i,
1175
1175
  exportAsBlob: a,
1176
1176
  fileName: s
1177
1177
  }), j = {
@@ -1183,8 +1183,8 @@ class D {
1183
1183
  };
1184
1184
  return o.fire("editor:object-exported", j), j;
1185
1185
  }
1186
- if (n && r instanceof Z) {
1187
- const M = yield createImageBitmap(r.getElement()), f = yield c.post(
1186
+ if (i && r instanceof Z) {
1187
+ const M = yield createImageBitmap(r.getElement()), f = yield d.post(
1188
1188
  "toDataURL",
1189
1189
  {
1190
1190
  format: l,
@@ -1196,7 +1196,7 @@ class D {
1196
1196
  object: r,
1197
1197
  image: f,
1198
1198
  format: l,
1199
- contentType: i,
1199
+ contentType: n,
1200
1200
  fileName: s
1201
1201
  };
1202
1202
  return o.fire("editor:object-exported", j), j;
@@ -1211,16 +1211,16 @@ class D {
1211
1211
  object: r,
1212
1212
  image: g,
1213
1213
  format: l,
1214
- contentType: i,
1214
+ contentType: n,
1215
1215
  fileName: s
1216
1216
  };
1217
1217
  return o.fire("editor:object-exported", M), M;
1218
1218
  }
1219
- const u = new File([g], s, { type: i }), m = {
1219
+ const u = new File([g], s, { type: n }), m = {
1220
1220
  object: r,
1221
1221
  image: u,
1222
1222
  format: l,
1223
- contentType: i,
1223
+ contentType: n,
1224
1224
  fileName: s
1225
1225
  };
1226
1226
  return o.fire("editor:object-exported", m), m;
@@ -1230,7 +1230,7 @@ class D {
1230
1230
  method: "exportObjectAsImageFile",
1231
1231
  code: "IMAGE_EXPORT_FAILED",
1232
1232
  message: `Ошибка экспорта объекта: ${l.message}`,
1233
- data: { contentType: i, fileName: s, exportAsBase64: n, exportAsBlob: a }
1233
+ data: { contentType: n, fileName: s, exportAsBase64: i, exportAsBlob: a }
1234
1234
  }), null;
1235
1235
  }
1236
1236
  });
@@ -1297,11 +1297,11 @@ class D {
1297
1297
  getContentTypeFromExtension(e) {
1298
1298
  var t;
1299
1299
  try {
1300
- const i = (t = new URL(e).pathname.split(".").pop()) == null ? void 0 : t.toLowerCase(), n = {};
1300
+ const n = (t = new URL(e).pathname.split(".").pop()) == null ? void 0 : t.toLowerCase(), i = {};
1301
1301
  return this.acceptContentTypes.forEach((a) => {
1302
1302
  const o = D.getFormatFromContentType(a);
1303
- o && (n[o] = a);
1304
- }), i && n[i] || "application/octet-stream";
1303
+ o && (i[o] = a);
1304
+ }), n && i[n] || "application/octet-stream";
1305
1305
  } catch (s) {
1306
1306
  return console.warn("Не удалось определить расширение из URL:", e, s), "application/octet-stream";
1307
1307
  }
@@ -1319,8 +1319,8 @@ class D {
1319
1319
  }) {
1320
1320
  const { montageArea: s } = this.editor;
1321
1321
  if (!s || !e) return 1;
1322
- const i = s.width, n = s.height, { width: a, height: o } = e;
1323
- return t === "contain" || t === "image-contain" ? Math.min(i / a, n / o) : t === "cover" || t === "image-cover" ? Math.max(i / a, n / o) : 1;
1322
+ const n = s.width, i = s.height, { width: a, height: o } = e;
1323
+ return t === "contain" || t === "image-contain" ? Math.min(n / a, i / o) : t === "cover" || t === "image-cover" ? Math.max(n / a, i / o) : 1;
1324
1324
  }
1325
1325
  /**
1326
1326
  * Преобразует SVG-строку в Blob, файл, или base64
@@ -1336,9 +1336,9 @@ class D {
1336
1336
  static _exportSVGStringAsFile(e, {
1337
1337
  exportAsBase64: t,
1338
1338
  exportAsBlob: s,
1339
- fileName: i = "image.svg"
1339
+ fileName: n = "image.svg"
1340
1340
  } = {}) {
1341
- return s ? new Blob([e], { type: "image/svg+xml" }) : t ? `data:image/svg+xml;base64,${window.btoa(encodeURIComponent(e))}` : new File([e], i.replace(/\.[^/.]+$/, ".svg"), { type: "image/svg+xml" });
1341
+ return s ? new Blob([e], { type: "image/svg+xml" }) : t ? `data:image/svg+xml;base64,${window.btoa(encodeURIComponent(e))}` : new File([e], n.replace(/\.[^/.]+$/, ".svg"), { type: "image/svg+xml" });
1342
1342
  }
1343
1343
  /**
1344
1344
  * Извлекает чистый формат (subtype) из contentType,
@@ -1369,25 +1369,25 @@ class tt {
1369
1369
  * @param options.adaptCanvasToContainer - Адаптировать канвас к контейнеру
1370
1370
  * @fires editor:resolution-width-changed
1371
1371
  */
1372
- setResolutionWidth(e, { preserveProportional: t, withoutSave: s, adaptCanvasToContainer: i } = {}) {
1372
+ setResolutionWidth(e, { preserveProportional: t, withoutSave: s, adaptCanvasToContainer: n } = {}) {
1373
1373
  var m;
1374
1374
  if (!e) return;
1375
1375
  const {
1376
- canvas: n,
1376
+ canvas: i,
1377
1377
  montageArea: a,
1378
1378
  options: { canvasBackstoreWidth: o }
1379
- } = this.editor, { width: c, height: r } = a, l = Math.max(Math.min(Number(e), O), x);
1380
- if (!o || o === "auto" || i ? this.adaptCanvasToContainer() : o ? this.setCanvasBackstoreWidth(Number(o)) : this.setCanvasBackstoreWidth(l), a.set({ width: l }), (m = n.clipPath) == null || m.set({ width: l }), t) {
1381
- const M = l / c, f = r * M;
1379
+ } = this.editor, { width: d, height: r } = a, l = Math.max(Math.min(Number(e), O), x);
1380
+ if (!o || o === "auto" || n ? this.adaptCanvasToContainer() : o ? this.setCanvasBackstoreWidth(Number(o)) : this.setCanvasBackstoreWidth(l), a.set({ width: l }), (m = i.clipPath) == null || m.set({ width: l }), t) {
1381
+ const M = l / d, f = r * M;
1382
1382
  this.setResolutionHeight(f);
1383
1383
  return;
1384
1384
  }
1385
- const { left: h, top: g } = this.getObjectDefaultCoords(a), u = n.getZoom();
1386
- n.setViewportTransform([u, 0, 0, u, h, g]), this.centerMontageArea(), s || this.editor.historyManager.saveState(), n.fire("editor:resolution-width-changed", {
1385
+ const { left: h, top: g } = this.getObjectDefaultCoords(a), u = i.getZoom();
1386
+ i.setViewportTransform([u, 0, 0, u, h, g]), this.centerMontageArea(), s || this.editor.historyManager.saveState(), i.fire("editor:resolution-width-changed", {
1387
1387
  width: l,
1388
1388
  preserveProportional: t,
1389
1389
  withoutSave: s,
1390
- adaptCanvasToContainer: i
1390
+ adaptCanvasToContainer: n
1391
1391
  });
1392
1392
  }
1393
1393
  /**
@@ -1399,25 +1399,25 @@ class tt {
1399
1399
  * @param options.adaptCanvasToContainer - Адаптировать канвас к контейнеру
1400
1400
  * @fires editor:resolution-height-changed
1401
1401
  */
1402
- setResolutionHeight(e, { preserveProportional: t, withoutSave: s, adaptCanvasToContainer: i } = {}) {
1402
+ setResolutionHeight(e, { preserveProportional: t, withoutSave: s, adaptCanvasToContainer: n } = {}) {
1403
1403
  var m;
1404
1404
  if (!e) return;
1405
1405
  const {
1406
- canvas: n,
1406
+ canvas: i,
1407
1407
  montageArea: a,
1408
1408
  options: { canvasBackstoreHeight: o }
1409
- } = this.editor, { width: c, height: r } = a, l = Math.max(Math.min(Number(e), T), B);
1410
- if (!o || o === "auto" || i ? this.adaptCanvasToContainer() : o ? this.setCanvasBackstoreHeight(Number(o)) : this.setCanvasBackstoreHeight(l), a.set({ height: l }), (m = n.clipPath) == null || m.set({ height: l }), t) {
1411
- const M = l / r, f = c * M;
1409
+ } = this.editor, { width: d, height: r } = a, l = Math.max(Math.min(Number(e), T), B);
1410
+ if (!o || o === "auto" || n ? this.adaptCanvasToContainer() : o ? this.setCanvasBackstoreHeight(Number(o)) : this.setCanvasBackstoreHeight(l), a.set({ height: l }), (m = i.clipPath) == null || m.set({ height: l }), t) {
1411
+ const M = l / r, f = d * M;
1412
1412
  this.setResolutionWidth(f);
1413
1413
  return;
1414
1414
  }
1415
- const { left: h, top: g } = this.getObjectDefaultCoords(a), u = n.getZoom();
1416
- n.setViewportTransform([u, 0, 0, u, h, g]), this.centerMontageArea(), s || this.editor.historyManager.saveState(), n.fire("editor:resolution-height-changed", {
1415
+ const { left: h, top: g } = this.getObjectDefaultCoords(a), u = i.getZoom();
1416
+ i.setViewportTransform([u, 0, 0, u, h, g]), this.centerMontageArea(), s || this.editor.historyManager.saveState(), i.fire("editor:resolution-height-changed", {
1417
1417
  height: l,
1418
1418
  preserveProportional: t,
1419
1419
  withoutSave: s,
1420
- adaptCanvasToContainer: i
1420
+ adaptCanvasToContainer: n
1421
1421
  });
1422
1422
  }
1423
1423
  /**
@@ -1425,17 +1425,17 @@ class tt {
1425
1425
  * и устанавливает правильный viewportTransform.
1426
1426
  */
1427
1427
  centerMontageArea() {
1428
- var c;
1429
- const { canvas: e, montageArea: t } = this.editor, s = e.getWidth(), i = e.getHeight(), n = e.getZoom(), a = new _(s / 2, i / 2);
1428
+ var d;
1429
+ const { canvas: e, montageArea: t } = this.editor, s = e.getWidth(), n = e.getHeight(), i = e.getZoom(), a = new _(s / 2, n / 2);
1430
1430
  t.set({
1431
1431
  left: s / 2,
1432
- top: i / 2
1433
- }), (c = e.clipPath) == null || c.set({
1432
+ top: n / 2
1433
+ }), (d = e.clipPath) == null || d.set({
1434
1434
  left: s / 2,
1435
- top: i / 2
1435
+ top: n / 2
1436
1436
  }), e.renderAll();
1437
1437
  const o = e.viewportTransform;
1438
- o[4] = s / 2 - a.x * n, o[5] = i / 2 - a.y * n, e.setViewportTransform(o), e.renderAll();
1438
+ o[4] = s / 2 - a.x * i, o[5] = n / 2 - a.y * i, e.setViewportTransform(o), e.renderAll();
1439
1439
  }
1440
1440
  /**
1441
1441
  * Метод для получения координат объекта с учетом текущего зума
@@ -1451,8 +1451,8 @@ class tt {
1451
1451
  code: "NO_ACTIVE_OBJECT",
1452
1452
  message: "Не выбран объект для получения координат"
1453
1453
  }), { left: 0, top: 0 };
1454
- const { width: i, height: n } = s, a = t.getZoom(), o = (i - i * a) / 2, c = (n - n * a) / 2;
1455
- return { left: o, top: c };
1454
+ const { width: n, height: i } = s, a = t.getZoom(), o = (n - n * a) / 2, d = (i - i * a) / 2;
1455
+ return { left: o, top: d };
1456
1456
  }
1457
1457
  /**
1458
1458
  * Устанавливаем ширину канваса в backstore (для экспорта)
@@ -1477,8 +1477,8 @@ class tt {
1477
1477
  * с учётом минимальных и максимальных значений.
1478
1478
  */
1479
1479
  adaptCanvasToContainer() {
1480
- const { canvas: e } = this.editor, t = e.editorContainer, s = t.clientWidth, i = t.clientHeight, n = Math.max(Math.min(s, O), x), a = Math.max(Math.min(i, T), B);
1481
- console.log("adaptCanvasToContainer newWidth", n), console.log("adaptCanvasToContainer newHeight", a), e.setDimensions({ width: n, height: a }, { backstoreOnly: !0 });
1480
+ const { canvas: e } = this.editor, t = e.editorContainer, s = t.clientWidth, n = t.clientHeight, i = Math.max(Math.min(s, O), x), a = Math.max(Math.min(n, T), B);
1481
+ console.log("adaptCanvasToContainer newWidth", i), console.log("adaptCanvasToContainer newHeight", a), e.setDimensions({ width: i, height: a }, { backstoreOnly: !0 });
1482
1482
  }
1483
1483
  /**
1484
1484
  * Обновляет размеры канваса без изменения позиций объектов.
@@ -1491,12 +1491,12 @@ class tt {
1491
1491
  montageArea: t,
1492
1492
  montageArea: {
1493
1493
  width: s,
1494
- height: i
1494
+ height: n
1495
1495
  }
1496
- } = this.editor, n = t.left, a = t.top;
1497
- this.setResolutionWidth(s, { adaptCanvasToContainer: !0, withoutSave: !0 }), this.setResolutionHeight(i, { adaptCanvasToContainer: !0, withoutSave: !0 }), this.centerMontageArea();
1498
- const o = t.left - n, c = t.top - a;
1499
- if (o !== 0 || c !== 0) {
1496
+ } = this.editor, i = t.left, a = t.top;
1497
+ this.setResolutionWidth(s, { adaptCanvasToContainer: !0, withoutSave: !0 }), this.setResolutionHeight(n, { adaptCanvasToContainer: !0, withoutSave: !0 }), this.centerMontageArea();
1498
+ const o = t.left - i, d = t.top - a;
1499
+ if (o !== 0 || d !== 0) {
1500
1500
  const r = e.getActiveObject(), l = [];
1501
1501
  if ((r == null ? void 0 : r.type) === "activeselection") {
1502
1502
  const h = r;
@@ -1505,7 +1505,7 @@ class tt {
1505
1505
  if (e.getObjects().forEach((h) => {
1506
1506
  h.id === "montage-area" || h.id === "overlay-mask" || (h.set({
1507
1507
  left: h.left + o,
1508
- top: h.top + c
1508
+ top: h.top + d
1509
1509
  }), h.setCoords());
1510
1510
  }), l.length > 0)
1511
1511
  if (l.length === 1)
@@ -1519,7 +1519,7 @@ class tt {
1519
1519
  }
1520
1520
  e.renderAll(), e.fire("editor:canvas-updated", {
1521
1521
  width: s,
1522
- height: i
1522
+ height: n
1523
1523
  });
1524
1524
  }
1525
1525
  /**
@@ -1534,11 +1534,11 @@ class tt {
1534
1534
  * @param zoom — текущее значение zoom (например, 1, 1.2, 2 и т.д.)
1535
1535
  */
1536
1536
  updateCssDimensionsForZoom(e) {
1537
- const { canvas: t, montageArea: s } = this.editor, i = s.width * e, n = s.height * e, a = t.wrapperEl.parentNode;
1537
+ const { canvas: t, montageArea: s } = this.editor, n = s.width * e, i = s.height * e, a = t.wrapperEl.parentNode;
1538
1538
  if (!(a instanceof HTMLElement)) return;
1539
- const o = i <= a.clientWidth ? "100%" : i, c = n <= a.clientHeight ? "100%" : n;
1539
+ const o = n <= a.clientWidth ? "100%" : n, d = i <= a.clientHeight ? "100%" : i;
1540
1540
  t.setDimensions(
1541
- { width: o, height: c },
1541
+ { width: o, height: d },
1542
1542
  { cssOnly: !0 }
1543
1543
  );
1544
1544
  }
@@ -1625,19 +1625,19 @@ class tt {
1625
1625
  */
1626
1626
  setDisplayDimension({ element: e = "canvas", dimension: t, value: s } = {}) {
1627
1627
  if (!s) return;
1628
- const { canvas: i, options: { editorContainer: n } } = this.editor, a = [];
1628
+ const { canvas: n, options: { editorContainer: i } } = this.editor, a = [];
1629
1629
  switch (e) {
1630
1630
  case "canvas":
1631
- a.push(i.lowerCanvasEl, i.upperCanvasEl);
1631
+ a.push(n.lowerCanvasEl, n.upperCanvasEl);
1632
1632
  break;
1633
1633
  case "wrapper":
1634
- a.push(i.wrapperEl);
1634
+ a.push(n.wrapperEl);
1635
1635
  break;
1636
1636
  case "container":
1637
- a.push(n);
1637
+ a.push(i);
1638
1638
  break;
1639
1639
  default:
1640
- a.push(i.lowerCanvasEl, i.upperCanvasEl);
1640
+ a.push(n.lowerCanvasEl, n.upperCanvasEl);
1641
1641
  }
1642
1642
  const o = t === "width" ? "width" : "height";
1643
1643
  if (typeof s == "string") {
@@ -1647,10 +1647,10 @@ class tt {
1647
1647
  return;
1648
1648
  }
1649
1649
  if (isNaN(s)) return;
1650
- const c = `${s}px`;
1650
+ const d = `${s}px`;
1651
1651
  a.forEach((r) => {
1652
- r.style[o] = c;
1653
- }), i.fire(`editor:display-${e}-${o}-changed`, {
1652
+ r.style[o] = d;
1653
+ }), n.fire(`editor:display-${e}-${o}-changed`, {
1654
1654
  element: e,
1655
1655
  value: s
1656
1656
  });
@@ -1665,14 +1665,14 @@ class tt {
1665
1665
  */
1666
1666
  scaleMontageAreaToImage({ object: e, preserveAspectRatio: t, withoutSave: s } = {}) {
1667
1667
  const {
1668
- canvas: i,
1669
- montageArea: n,
1668
+ canvas: n,
1669
+ montageArea: i,
1670
1670
  transformManager: a,
1671
1671
  options: {
1672
1672
  montageAreaWidth: o,
1673
- montageAreaHeight: c
1673
+ montageAreaHeight: d
1674
1674
  }
1675
- } = this.editor, r = e || i.getActiveObject();
1675
+ } = this.editor, r = e || n.getActiveObject();
1676
1676
  if (!r || r.type !== "image" && r.format !== "svg") return;
1677
1677
  const { width: l, height: h } = r;
1678
1678
  let g = Math.min(l, O), u = Math.min(h, T);
@@ -1680,10 +1680,10 @@ class tt {
1680
1680
  const {
1681
1681
  width: m,
1682
1682
  height: M
1683
- } = n, f = l / m, j = h / M, A = Math.max(f, j);
1683
+ } = i, f = l / m, j = h / M, A = Math.max(f, j);
1684
1684
  g = m * A, u = M * A;
1685
1685
  }
1686
- this.setResolutionWidth(g, { withoutSave: !0 }), this.setResolutionHeight(u, { withoutSave: !0 }), (l > o || h > c) && a.calculateAndApplyDefaultZoom(), a.resetObject(r, { withoutSave: !0 }), i.centerObject(r), i.renderAll(), s || this.editor.historyManager.saveState(), i.fire("editor:montage-area-scaled-to-image", {
1686
+ this.setResolutionWidth(g, { withoutSave: !0 }), this.setResolutionHeight(u, { withoutSave: !0 }), (l > o || h > d) && a.calculateAndApplyDefaultZoom(), a.resetObject(r, { withoutSave: !0 }), n.centerObject(r), n.renderAll(), s || this.editor.historyManager.saveState(), n.fire("editor:montage-area-scaled-to-image", {
1687
1687
  object: r,
1688
1688
  width: g,
1689
1689
  height: u,
@@ -1709,13 +1709,13 @@ class tt {
1709
1709
  const {
1710
1710
  canvas: t,
1711
1711
  transformManager: s,
1712
- historyManager: i,
1712
+ historyManager: n,
1713
1713
  options: {
1714
- montageAreaWidth: n,
1714
+ montageAreaWidth: i,
1715
1715
  montageAreaHeight: a
1716
1716
  }
1717
1717
  } = this.editor;
1718
- s.resetZoom(), this.setResolutionWidth(n, { withoutSave: !0 }), this.setResolutionHeight(a, { withoutSave: !0 }), t.renderAll(), s.resetObjects(), e || i.saveState(), t.fire("editor:default-scale-set");
1718
+ s.resetZoom(), this.setResolutionWidth(i, { withoutSave: !0 }), this.setResolutionHeight(a, { withoutSave: !0 }), t.renderAll(), s.resetObjects(), e || n.saveState(), t.fire("editor:default-scale-set");
1719
1719
  }
1720
1720
  /**
1721
1721
  * Получение всех объектов внутри монтажной области редактора
@@ -1723,7 +1723,7 @@ class tt {
1723
1723
  */
1724
1724
  getObjects() {
1725
1725
  const { canvas: e, montageArea: t, interactionBlocker: { overlayMask: s } } = this.editor;
1726
- return e.getObjects().filter((n) => n.id !== t.id && n.id !== (s == null ? void 0 : s.id));
1726
+ return e.getObjects().filter((i) => i.id !== t.id && i.id !== (s == null ? void 0 : s.id));
1727
1727
  }
1728
1728
  }
1729
1729
  class st {
@@ -1738,8 +1738,8 @@ class st {
1738
1738
  * @param scale - Желаемый масштаб относительно размеров контейнера редактора.
1739
1739
  */
1740
1740
  calculateAndApplyDefaultZoom(e = this.options.defaultScale) {
1741
- const { canvas: t } = this.editor, s = t.editorContainer, i = s.clientWidth, n = s.clientHeight, { width: a, height: o } = this.editor.montageArea, c = i / a * e, r = n / o * e;
1742
- this.defaultZoom = Math.min(c, r);
1741
+ const { canvas: t } = this.editor, s = t.editorContainer, n = s.clientWidth, i = s.clientHeight, { width: a, height: o } = this.editor.montageArea, d = n / a * e, r = i / o * e;
1742
+ this.defaultZoom = Math.min(d, r);
1743
1743
  const { defaultZoom: l, maxZoomFactor: h, minZoom: g, maxZoom: u } = this;
1744
1744
  this.minZoom = Math.min(l / h, g), this.maxZoom = Math.max(l * h, u), this.setZoom();
1745
1745
  }
@@ -1755,14 +1755,14 @@ class st {
1755
1755
  zoom(e = qe, t = {}) {
1756
1756
  var g, u;
1757
1757
  if (!e) return;
1758
- const { minZoom: s, maxZoom: i } = this, { canvas: n } = this.editor, a = n.getZoom(), o = n.getCenterPoint(), c = (g = t.pointX) != null ? g : o.x, r = (u = t.pointY) != null ? u : o.y, l = new _(c, r);
1758
+ const { minZoom: s, maxZoom: n } = this, { canvas: i } = this.editor, a = i.getZoom(), o = i.getCenterPoint(), d = (g = t.pointX) != null ? g : o.x, r = (u = t.pointY) != null ? u : o.y, l = new _(d, r);
1759
1759
  let h = Number((a + Number(e)).toFixed(2));
1760
- h > i && (h = i), h < s && (h = s), n.zoomToPoint(l, h), console.log({
1760
+ h > n && (h = n), h < s && (h = s), i.zoomToPoint(l, h), console.log({
1761
1761
  currentZoom: a,
1762
1762
  zoom: h,
1763
1763
  point: l
1764
- }), n.fire("editor:zoom-changed", {
1765
- currentZoom: n.getZoom(),
1764
+ }), i.fire("editor:zoom-changed", {
1765
+ currentZoom: i.getZoom(),
1766
1766
  zoom: h,
1767
1767
  point: l
1768
1768
  });
@@ -1773,12 +1773,12 @@ class st {
1773
1773
  * @fires editor:zoom-changed
1774
1774
  */
1775
1775
  setZoom(e = this.defaultZoom) {
1776
- const { minZoom: t, maxZoom: s } = this, { canvas: i } = this.editor, n = new _(i.getCenterPoint());
1776
+ const { minZoom: t, maxZoom: s } = this, { canvas: n } = this.editor, i = new _(n.getCenterPoint());
1777
1777
  let a = e;
1778
- e > s && (a = s), e < t && (a = t), i.zoomToPoint(n, a), i.fire("editor:zoom-changed", {
1779
- currentZoom: i.getZoom(),
1778
+ e > s && (a = s), e < t && (a = t), n.zoomToPoint(i, a), n.fire("editor:zoom-changed", {
1779
+ currentZoom: n.getZoom(),
1780
1780
  zoom: a,
1781
- point: n
1781
+ point: i
1782
1782
  });
1783
1783
  }
1784
1784
  /**
@@ -1800,11 +1800,11 @@ class st {
1800
1800
  * @fires editor:object-rotated
1801
1801
  */
1802
1802
  rotate(e = et, { withoutSave: t } = {}) {
1803
- const { canvas: s, historyManager: i } = this.editor, n = s.getActiveObject();
1804
- if (!n) return;
1805
- const a = n.angle + e;
1806
- n.rotate(a), n.setCoords(), s.renderAll(), t || i.saveState(), s.fire("editor:object-rotated", {
1807
- object: n,
1803
+ const { canvas: s, historyManager: n } = this.editor, i = s.getActiveObject();
1804
+ if (!i) return;
1805
+ const a = i.angle + e;
1806
+ i.rotate(a), i.setCoords(), s.renderAll(), t || n.saveState(), s.fire("editor:object-rotated", {
1807
+ object: i,
1808
1808
  withoutSave: t,
1809
1809
  angle: a
1810
1810
  });
@@ -1816,9 +1816,9 @@ class st {
1816
1816
  * @fires editor:object-flipped-x
1817
1817
  */
1818
1818
  flipX({ withoutSave: e } = {}) {
1819
- const { canvas: t, historyManager: s } = this.editor, i = t.getActiveObject();
1820
- i && (i.flipX = !i.flipX, t.renderAll(), e || s.saveState(), t.fire("editor:object-flipped-x", {
1821
- object: i,
1819
+ const { canvas: t, historyManager: s } = this.editor, n = t.getActiveObject();
1820
+ n && (n.flipX = !n.flipX, t.renderAll(), e || s.saveState(), t.fire("editor:object-flipped-x", {
1821
+ object: n,
1822
1822
  withoutSave: e
1823
1823
  }));
1824
1824
  }
@@ -1829,9 +1829,9 @@ class st {
1829
1829
  * @fires editor:object-flipped-y
1830
1830
  */
1831
1831
  flipY({ withoutSave: e } = {}) {
1832
- const { canvas: t, historyManager: s } = this.editor, i = t.getActiveObject();
1833
- i && (i.flipY = !i.flipY, t.renderAll(), e || s.saveState(), t.fire("editor:object-flipped-y", {
1834
- object: i,
1832
+ const { canvas: t, historyManager: s } = this.editor, n = t.getActiveObject();
1833
+ n && (n.flipY = !n.flipY, t.renderAll(), e || s.saveState(), t.fire("editor:object-flipped-y", {
1834
+ object: n,
1835
1835
  withoutSave: e
1836
1836
  }));
1837
1837
  }
@@ -1848,10 +1848,10 @@ class st {
1848
1848
  opacity: t = 1,
1849
1849
  withoutSave: s
1850
1850
  } = {}) {
1851
- const { canvas: i, historyManager: n } = this.editor, a = e || i.getActiveObject();
1851
+ const { canvas: n, historyManager: i } = this.editor, a = e || n.getActiveObject();
1852
1852
  a && (a instanceof v ? a.getObjects().forEach((o) => {
1853
1853
  o.set("opacity", t);
1854
- }) : a.set("opacity", t), i.renderAll(), s || n.saveState(), i.fire("editor:object-opacity-changed", {
1854
+ }) : a.set("opacity", t), n.renderAll(), s || i.saveState(), n.fire("editor:object-opacity-changed", {
1855
1855
  object: a,
1856
1856
  opacity: t,
1857
1857
  withoutSave: s
@@ -1872,24 +1872,24 @@ class st {
1872
1872
  object: e,
1873
1873
  type: t = this.options.scaleType,
1874
1874
  withoutSave: s,
1875
- fitAsOneObject: i
1875
+ fitAsOneObject: n
1876
1876
  } = {}) {
1877
- const { canvas: n, historyManager: a } = this.editor, o = e || n.getActiveObject();
1877
+ const { canvas: i, historyManager: a } = this.editor, o = e || i.getActiveObject();
1878
1878
  if (o) {
1879
- if (o instanceof v && !i) {
1880
- const c = o.getObjects();
1881
- n.discardActiveObject(), c.forEach((l) => {
1879
+ if (o instanceof v && !n) {
1880
+ const d = o.getObjects();
1881
+ i.discardActiveObject(), d.forEach((l) => {
1882
1882
  this._fitSingleObject(l, t);
1883
1883
  });
1884
- const r = new v(c, { canvas: n });
1885
- n.setActiveObject(r);
1884
+ const r = new v(d, { canvas: i });
1885
+ i.setActiveObject(r);
1886
1886
  } else
1887
1887
  this._fitSingleObject(o, t);
1888
- n.renderAll(), s || a.saveState(), n.fire("editor:object-fitted", {
1888
+ i.renderAll(), s || a.saveState(), i.fire("editor:object-fitted", {
1889
1889
  object: o,
1890
1890
  type: t,
1891
1891
  withoutSave: s,
1892
- fitAsOneObject: i
1892
+ fitAsOneObject: n
1893
1893
  });
1894
1894
  }
1895
1895
  }
@@ -1900,11 +1900,11 @@ class st {
1900
1900
  * @private
1901
1901
  */
1902
1902
  _fitSingleObject(e, t) {
1903
- const { canvas: s, montageArea: i } = this.editor, { width: n, height: a, scaleX: o = 1, scaleY: c = 1, angle: r = 0 } = e, l = n * Math.abs(o), h = a * Math.abs(c), g = r * Math.PI / 180, u = Math.abs(Math.cos(g)), m = Math.abs(Math.sin(g)), M = l * u + h * m, f = l * m + h * u, j = i.width, A = i.height;
1903
+ const { canvas: s, montageArea: n } = this.editor, { width: i, height: a, scaleX: o = 1, scaleY: d = 1, angle: r = 0 } = e, l = i * Math.abs(o), h = a * Math.abs(d), g = r * Math.PI / 180, u = Math.abs(Math.cos(g)), m = Math.abs(Math.sin(g)), M = l * u + h * m, f = l * m + h * u, j = n.width, A = n.height;
1904
1904
  let b;
1905
1905
  t === "contain" ? b = Math.min(j / M, A / f) : b = Math.max(j / M, A / f), e.set({
1906
1906
  scaleX: o * b,
1907
- scaleY: c * b
1907
+ scaleY: d * b
1908
1908
  }), s.centerObject(e);
1909
1909
  }
1910
1910
  /**
@@ -1925,12 +1925,12 @@ class st {
1925
1925
  */
1926
1926
  resetObject(e, { alwaysFitObject: t = !1, withoutSave: s = !1 } = {}) {
1927
1927
  const {
1928
- canvas: i,
1929
- montageArea: n,
1928
+ canvas: n,
1929
+ montageArea: i,
1930
1930
  imageManager: a,
1931
1931
  historyManager: o,
1932
- options: { scaleType: c }
1933
- } = this.editor, r = e || i.getActiveObject();
1932
+ options: { scaleType: d }
1933
+ } = this.editor, r = e || n.getActiveObject();
1934
1934
  if (!r || r.locked) return;
1935
1935
  if (o.suspendHistory(), r.type === "image" || r.format === "svg" || r.set({
1936
1936
  scaleX: 1,
@@ -1941,20 +1941,20 @@ class st {
1941
1941
  }), t)
1942
1942
  this.fitObject({ object: r, withoutSave: !0, fitAsOneObject: !0 });
1943
1943
  else {
1944
- const { width: h, height: g } = n, { width: u, height: m } = r, M = a.calculateScaleFactor({
1944
+ const { width: h, height: g } = i, { width: u, height: m } = r, M = a.calculateScaleFactor({
1945
1945
  imageObject: r,
1946
- scaleType: c
1946
+ scaleType: d
1947
1947
  });
1948
- c === "contain" && M < 1 || c === "cover" && (u > h || m > g) ? this.fitObject({ object: r, withoutSave: !0, fitAsOneObject: !0 }) : r.set({ scaleX: 1, scaleY: 1 });
1948
+ d === "contain" && M < 1 || d === "cover" && (u > h || m > g) ? this.fitObject({ object: r, withoutSave: !0, fitAsOneObject: !0 }) : r.set({ scaleX: 1, scaleY: 1 });
1949
1949
  }
1950
- r.set({ flipX: !1, flipY: !1, angle: 0 }), i.centerObject(r), i.renderAll(), o.resumeHistory(), s || o.saveState(), i.fire("editor:object-reset", {
1950
+ r.set({ flipX: !1, flipY: !1, angle: 0 }), n.centerObject(r), n.renderAll(), o.resumeHistory(), s || o.saveState(), n.fire("editor:object-reset", {
1951
1951
  object: r,
1952
1952
  withoutSave: s,
1953
1953
  alwaysFitObject: t
1954
1954
  });
1955
1955
  }
1956
1956
  }
1957
- class it {
1957
+ class nt {
1958
1958
  constructor({ editor: e }) {
1959
1959
  this.editor = e, this.isBlocked = !1, this.overlayMask = null, this._createOverlay();
1960
1960
  }
@@ -1984,8 +1984,8 @@ class it {
1984
1984
  const { canvas: e, montageArea: t, historyManager: s } = this.editor;
1985
1985
  if (!t || !this.overlayMask) return;
1986
1986
  s.suspendHistory(), t.setCoords();
1987
- const { left: i, top: n, width: a, height: o } = t.getBoundingRect();
1988
- this.overlayMask.set({ left: i, top: n, width: a, height: o }), e.discardActiveObject(), this.editor.layerManager.bringToFront(this.overlayMask, { withoutSave: !0 }), s.resumeHistory();
1987
+ const { left: n, top: i, width: a, height: o } = t.getBoundingRect();
1988
+ this.overlayMask.set({ left: n, top: i, width: a, height: o }), e.discardActiveObject(), this.editor.layerManager.bringToFront(this.overlayMask, { withoutSave: !0 }), s.resumeHistory();
1989
1989
  }
1990
1990
  /**
1991
1991
  * Выключает редактор:
@@ -1996,8 +1996,8 @@ class it {
1996
1996
  block() {
1997
1997
  if (this.isBlocked || !this.overlayMask) return;
1998
1998
  const { canvas: e, canvasManager: t, historyManager: s } = this.editor;
1999
- s.suspendHistory(), this.isBlocked = !0, e.discardActiveObject(), e.selection = !1, e.skipTargetFind = !0, t.getObjects().forEach((i) => {
2000
- i.evented = !1, i.selectable = !1;
1999
+ s.suspendHistory(), this.isBlocked = !0, e.discardActiveObject(), e.selection = !1, e.skipTargetFind = !0, t.getObjects().forEach((n) => {
2000
+ n.evented = !1, n.selectable = !1;
2001
2001
  }), e.upperCanvasEl.style.pointerEvents = "none", e.lowerCanvasEl.style.pointerEvents = "none", this.overlayMask.visible = !0, this.refresh(), e.fire("editor:disabled"), s.resumeHistory();
2002
2002
  }
2003
2003
  /**
@@ -2006,8 +2006,8 @@ class it {
2006
2006
  unblock() {
2007
2007
  if (!this.isBlocked || !this.overlayMask) return;
2008
2008
  const { canvas: e, canvasManager: t, historyManager: s } = this.editor;
2009
- s.suspendHistory(), this.isBlocked = !1, e.selection = !0, e.skipTargetFind = !1, t.getObjects().forEach((i) => {
2010
- i.evented = !0, i.selectable = !0;
2009
+ s.suspendHistory(), this.isBlocked = !1, e.selection = !0, e.skipTargetFind = !1, t.getObjects().forEach((n) => {
2010
+ n.evented = !0, n.selectable = !0;
2011
2011
  }), e.upperCanvasEl.style.pointerEvents = "", e.lowerCanvasEl.style.pointerEvents = "", this.overlayMask.visible = !1, e.requestRenderAll(), e.fire("editor:enabled"), s.resumeHistory();
2012
2012
  }
2013
2013
  }
@@ -2023,13 +2023,13 @@ class P {
2023
2023
  * @fires editor:object-bring-to-front
2024
2024
  */
2025
2025
  bringToFront(e, { withoutSave: t } = {}) {
2026
- const { canvas: s, historyManager: i } = this.editor;
2027
- i.suspendHistory();
2028
- const n = e || s.getActiveObject();
2029
- n && (n instanceof v ? n.getObjects().forEach((a) => {
2026
+ const { canvas: s, historyManager: n } = this.editor;
2027
+ n.suspendHistory();
2028
+ const i = e || s.getActiveObject();
2029
+ i && (i instanceof v ? i.getObjects().forEach((a) => {
2030
2030
  s.bringObjectToFront(a);
2031
- }) : s.bringObjectToFront(n), s.renderAll(), i.resumeHistory(), t || i.saveState(), s.fire("editor:object-bring-to-front", {
2032
- object: n,
2031
+ }) : s.bringObjectToFront(i), s.renderAll(), n.resumeHistory(), t || n.saveState(), s.fire("editor:object-bring-to-front", {
2032
+ object: i,
2033
2033
  withoutSave: t
2034
2034
  }));
2035
2035
  }
@@ -2041,11 +2041,11 @@ class P {
2041
2041
  * @fires editor:object-bring-forward
2042
2042
  */
2043
2043
  bringForward(e, { withoutSave: t } = {}) {
2044
- const { canvas: s, historyManager: i } = this.editor;
2045
- i.suspendHistory();
2046
- const n = e || s.getActiveObject();
2047
- n && (n instanceof v ? P._moveSelectionForward(s, n) : s.bringObjectForward(n), s.renderAll(), i.resumeHistory(), t || i.saveState(), s.fire("editor:object-bring-forward", {
2048
- object: n,
2044
+ const { canvas: s, historyManager: n } = this.editor;
2045
+ n.suspendHistory();
2046
+ const i = e || s.getActiveObject();
2047
+ i && (i instanceof v ? P._moveSelectionForward(s, i) : s.bringObjectForward(i), s.renderAll(), n.resumeHistory(), t || n.saveState(), s.fire("editor:object-bring-forward", {
2048
+ object: i,
2049
2049
  withoutSave: t
2050
2050
  }));
2051
2051
  }
@@ -2059,20 +2059,20 @@ class P {
2059
2059
  sendToBack(e, { withoutSave: t } = {}) {
2060
2060
  const {
2061
2061
  canvas: s,
2062
- montageArea: i,
2063
- historyManager: n,
2062
+ montageArea: n,
2063
+ historyManager: i,
2064
2064
  interactionBlocker: { overlayMask: a }
2065
2065
  } = this.editor;
2066
- n.suspendHistory();
2066
+ i.suspendHistory();
2067
2067
  const o = e || s.getActiveObject();
2068
2068
  if (o) {
2069
2069
  if (o instanceof v) {
2070
- const c = o.getObjects();
2071
- for (let r = c.length - 1; r >= 0; r -= 1)
2072
- s.sendObjectToBack(c[r]);
2070
+ const d = o.getObjects();
2071
+ for (let r = d.length - 1; r >= 0; r -= 1)
2072
+ s.sendObjectToBack(d[r]);
2073
2073
  } else
2074
2074
  s.sendObjectToBack(o);
2075
- s.sendObjectToBack(i), a && s.sendObjectToBack(a), s.renderAll(), n.resumeHistory(), t || n.saveState(), s.fire("editor:object-send-to-back", {
2075
+ s.sendObjectToBack(n), a && s.sendObjectToBack(a), s.renderAll(), i.resumeHistory(), t || i.saveState(), s.fire("editor:object-send-to-back", {
2076
2076
  object: o,
2077
2077
  withoutSave: t
2078
2078
  });
@@ -2087,59 +2087,57 @@ class P {
2087
2087
  sendBackwards(e, { withoutSave: t } = {}) {
2088
2088
  const {
2089
2089
  canvas: s,
2090
- montageArea: i,
2091
- historyManager: n,
2090
+ montageArea: n,
2091
+ historyManager: i,
2092
2092
  interactionBlocker: { overlayMask: a }
2093
2093
  } = this.editor;
2094
- n.suspendHistory();
2094
+ i.suspendHistory();
2095
2095
  const o = e || s.getActiveObject();
2096
- o && (o instanceof v ? P._moveSelectionBackwards(s, o) : s.sendObjectBackwards(o), s.sendObjectToBack(i), a && s.sendObjectToBack(a), s.renderAll(), n.resumeHistory(), t || n.saveState(), s.fire("editor:object-send-backwards", {
2096
+ o && (o instanceof v ? P._moveSelectionBackwards(s, o) : s.sendObjectBackwards(o), s.sendObjectToBack(n), a && s.sendObjectToBack(a), s.renderAll(), i.resumeHistory(), t || i.saveState(), s.fire("editor:object-send-backwards", {
2097
2097
  object: o,
2098
2098
  withoutSave: t
2099
2099
  }));
2100
2100
  }
2101
2101
  /**
2102
- * Сдвигает выделенные объекты на один уровень вверх относительно ближайшего верхнего объекта
2102
+ * Сдвигает выделенные объекты на один уровень вверх - каждый объект поднимается
2103
+ * на одну позицию выше относительно своей текущей позиции
2103
2104
  * @param canvas - экземпляр холста
2104
2105
  * @param activeSelection - активное выделение
2105
2106
  */
2106
2107
  static _moveSelectionForward(e, t) {
2107
- const s = e.getObjects(), i = t.getObjects(), n = i.map((o) => s.indexOf(o));
2108
- let a = -1;
2109
- for (let o = 0; o < s.length; o += 1) {
2110
- const c = s[o];
2111
- if (!i.includes(c) && n.some((r) => o > r)) {
2112
- a = o;
2113
- break;
2114
- }
2115
- }
2116
- a !== -1 && i.map((c) => ({ obj: c, index: s.indexOf(c) })).sort((c, r) => r.index - c.index).forEach((c) => {
2117
- const r = s.indexOf(c.obj);
2118
- r < a && (e.moveObjectTo(c.obj, a), a = r);
2108
+ const s = e.getObjects(), n = t.getObjects();
2109
+ if (!n.some((o) => {
2110
+ const d = s.indexOf(o);
2111
+ for (let r = d + 1; r < s.length; r += 1)
2112
+ if (!n.includes(s[r]))
2113
+ return !0;
2114
+ return !1;
2115
+ })) return;
2116
+ n.map((o) => ({ obj: o, index: s.indexOf(o) })).sort((o, d) => d.index - o.index).forEach((o) => {
2117
+ e.bringObjectForward(o.obj);
2119
2118
  });
2120
2119
  }
2121
2120
  /**
2122
- * Сдвигает выделенные объекты на один уровень вниз относительно ближайшего нижнего объекта
2121
+ * Сдвигает выделенные объекты на один уровень вниз - каждый объект опускается
2122
+ * на одну позицию ниже относительно своей текущей позиции
2123
2123
  * @param canvas - экземпляр холста
2124
2124
  * @param activeSelection - активное выделение
2125
2125
  */
2126
2126
  static _moveSelectionBackwards(e, t) {
2127
- const s = e.getObjects(), i = t.getObjects(), n = i.map((o) => s.indexOf(o));
2128
- let a = -1;
2129
- for (let o = s.length - 1; o >= 0; o -= 1) {
2130
- const c = s[o];
2131
- if (!i.includes(c) && n.some((r) => o < r)) {
2132
- a = o;
2133
- break;
2134
- }
2135
- }
2136
- a !== -1 && i.map((c) => ({ obj: c, index: s.indexOf(c) })).sort((c, r) => c.index - r.index).forEach((c) => {
2137
- const r = s.indexOf(c.obj);
2138
- r > a && (e.moveObjectTo(c.obj, a), a = r);
2127
+ const s = e.getObjects(), n = t.getObjects();
2128
+ if (!n.some((o) => {
2129
+ const d = s.indexOf(o);
2130
+ for (let r = d - 1; r >= 0; r -= 1)
2131
+ if (!n.includes(s[r]))
2132
+ return !0;
2133
+ return !1;
2134
+ })) return;
2135
+ n.map((o) => ({ obj: o, index: s.indexOf(o) })).sort((o, d) => o.index - d.index).forEach((o) => {
2136
+ e.sendObjectBackwards(o.obj);
2139
2137
  });
2140
2138
  }
2141
2139
  }
2142
- class nt {
2140
+ class it {
2143
2141
  /**
2144
2142
  * Менеджер фигур для редактора.
2145
2143
  * @param options - Опции и настройки менеджера фигур.
@@ -2163,13 +2161,13 @@ class nt {
2163
2161
  * @param flags.withoutSelection - Не выделять объект
2164
2162
  * @param flags.withoutAdding - Не добавлять объект в canvas
2165
2163
  */
2166
- addRectangle(l = {}, { withoutSelection: c, withoutAdding: r } = {}) {
2164
+ addRectangle(l = {}, { withoutSelection: d, withoutAdding: r } = {}) {
2167
2165
  var h = l, {
2168
2166
  id: e = `rect-${L()}`,
2169
2167
  left: t,
2170
2168
  top: s,
2171
- width: i = 100,
2172
- height: n = 100,
2169
+ width: n = 100,
2170
+ height: i = 100,
2173
2171
  fill: a = "blue"
2174
2172
  } = h, o = Y(h, [
2175
2173
  "id",
@@ -2179,15 +2177,15 @@ class nt {
2179
2177
  "height",
2180
2178
  "fill"
2181
2179
  ]);
2182
- const { canvas: g } = this.editor, u = new ve(p({
2180
+ const { canvas: g } = this.editor, u = new ve(y({
2183
2181
  id: e,
2184
2182
  left: t,
2185
2183
  top: s,
2186
- width: i,
2187
- height: n,
2184
+ width: n,
2185
+ height: i,
2188
2186
  fill: a
2189
2187
  }, o));
2190
- return !t && !s && g.centerObject(u), r || (g.add(u), c || g.setActiveObject(u), g.renderAll()), u;
2188
+ return !t && !s && g.centerObject(u), r || (g.add(u), d || g.setActiveObject(u), g.renderAll()), u;
2191
2189
  }
2192
2190
  /**
2193
2191
  * Добавление круга
@@ -2205,13 +2203,13 @@ class nt {
2205
2203
  * @param flags.withoutSelection - Не выделять объект
2206
2204
  * @param flags.withoutAdding - Не добавлять объект в canvas
2207
2205
  */
2208
- addCircle(r = {}, { withoutSelection: o, withoutAdding: c } = {}) {
2206
+ addCircle(r = {}, { withoutSelection: o, withoutAdding: d } = {}) {
2209
2207
  var l = r, {
2210
2208
  id: e = `circle-${L()}`,
2211
2209
  left: t,
2212
2210
  top: s,
2213
- radius: i = 50,
2214
- fill: n = "green"
2211
+ radius: n = 50,
2212
+ fill: i = "green"
2215
2213
  } = l, a = Y(l, [
2216
2214
  "id",
2217
2215
  "left",
@@ -2219,14 +2217,14 @@ class nt {
2219
2217
  "radius",
2220
2218
  "fill"
2221
2219
  ]);
2222
- const { canvas: h } = this.editor, g = new Ae(p({
2220
+ const { canvas: h } = this.editor, g = new Ae(y({
2223
2221
  id: e,
2224
2222
  left: t,
2225
2223
  top: s,
2226
- fill: n,
2227
- radius: i
2224
+ fill: i,
2225
+ radius: n
2228
2226
  }, a));
2229
- return !t && !s && h.centerObject(g), c || (h.add(g), o || h.setActiveObject(g), h.renderAll()), g;
2227
+ return !t && !s && h.centerObject(g), d || (h.add(g), o || h.setActiveObject(g), h.renderAll()), g;
2230
2228
  }
2231
2229
  /**
2232
2230
  * Добавление треугольника
@@ -2245,13 +2243,13 @@ class nt {
2245
2243
  * @param flags.withoutSelection - Не выделять объект
2246
2244
  * @param flags.withoutAdding - Не добавлять объект в canvas
2247
2245
  */
2248
- addTriangle(l = {}, { withoutSelection: c, withoutAdding: r } = {}) {
2246
+ addTriangle(l = {}, { withoutSelection: d, withoutAdding: r } = {}) {
2249
2247
  var h = l, {
2250
2248
  id: e = `triangle-${L()}`,
2251
2249
  left: t,
2252
2250
  top: s,
2253
- width: i = 100,
2254
- height: n = 100,
2251
+ width: n = 100,
2252
+ height: i = 100,
2255
2253
  fill: a = "yellow"
2256
2254
  } = h, o = Y(h, [
2257
2255
  "id",
@@ -2261,15 +2259,15 @@ class nt {
2261
2259
  "height",
2262
2260
  "fill"
2263
2261
  ]);
2264
- const { canvas: g } = this.editor, u = new Se(p({
2262
+ const { canvas: g } = this.editor, u = new Se(y({
2265
2263
  id: e,
2266
2264
  left: t,
2267
2265
  top: s,
2268
2266
  fill: a,
2269
- width: i,
2270
- height: n
2267
+ width: n,
2268
+ height: i
2271
2269
  }, o));
2272
- return !t && !s && g.centerObject(u), r || (g.add(u), c || g.setActiveObject(u), g.renderAll()), u;
2270
+ return !t && !s && g.centerObject(u), r || (g.add(u), d || g.setActiveObject(u), g.renderAll()), u;
2273
2271
  }
2274
2272
  }
2275
2273
  class at {
@@ -2310,9 +2308,9 @@ class at {
2310
2308
  }), this._cloneAndFire(e, s);
2311
2309
  return;
2312
2310
  }
2313
- const n = s.toCanvasElement().toDataURL(), a = n.slice(5).split(";")[0], o = n.split(",")[1], c = atob(o), r = new Uint8Array(c.length);
2314
- for (let g = 0; g < c.length; g += 1)
2315
- r[g] = c.charCodeAt(g);
2311
+ const i = s.toCanvasElement().toDataURL(), a = i.slice(5).split(";")[0], o = i.split(",")[1], d = atob(o), r = new Uint8Array(d.length);
2312
+ for (let g = 0; g < d.length; g += 1)
2313
+ r[g] = d.charCodeAt(g);
2316
2314
  const l = new Blob([r.buffer], { type: a }), h = new ClipboardItem({ [a]: l });
2317
2315
  navigator.clipboard.write([h]).catch((g) => {
2318
2316
  t.emitWarning({
@@ -2350,19 +2348,19 @@ class at {
2350
2348
  handlePasteEvent({ clipboardData: e }) {
2351
2349
  var a;
2352
2350
  if (!((a = e == null ? void 0 : e.items) != null && a.length)) return;
2353
- const { imageManager: t } = this.editor, { items: s } = e, i = s[s.length - 1];
2354
- if (i.type !== "text/html") {
2355
- const o = i.getAsFile();
2351
+ const { imageManager: t } = this.editor, { items: s } = e, n = s[s.length - 1];
2352
+ if (n.type !== "text/html") {
2353
+ const o = n.getAsFile();
2356
2354
  if (!o) return;
2357
- const c = new FileReader();
2358
- c.onload = (r) => {
2355
+ const d = new FileReader();
2356
+ d.onload = (r) => {
2359
2357
  r.target && this.editor.imageManager.importImage({ source: r.target.result });
2360
- }, c.readAsDataURL(o);
2358
+ }, d.readAsDataURL(o);
2361
2359
  return;
2362
2360
  }
2363
- const n = e.getData("text/html");
2364
- if (n) {
2365
- const r = new DOMParser().parseFromString(n, "text/html").querySelector("img");
2361
+ const i = e.getData("text/html");
2362
+ if (i) {
2363
+ const r = new DOMParser().parseFromString(i, "text/html").querySelector("img");
2366
2364
  if (r != null && r.src) {
2367
2365
  t.importImage({ source: r.src });
2368
2366
  return;
@@ -2403,7 +2401,7 @@ class F {
2403
2401
  * @fires editor:object-locked
2404
2402
  */
2405
2403
  lockObject({ object: e, skipInnerObjects: t, withoutSave: s } = {}) {
2406
- const { canvas: i, historyManager: n } = this.editor, a = e || i.getActiveObject();
2404
+ const { canvas: n, historyManager: i } = this.editor, a = e || n.getActiveObject();
2407
2405
  if (!a || a.locked) return;
2408
2406
  const o = {
2409
2407
  lockMovementX: !0,
@@ -2417,7 +2415,7 @@ class F {
2417
2415
  };
2418
2416
  a.set(o), !t && F._isGroupOrSelection(a) && a.getObjects().forEach((r) => {
2419
2417
  r.set(o);
2420
- }), i.renderAll(), s || n.saveState(), i.fire("editor:object-locked", {
2418
+ }), n.renderAll(), s || i.saveState(), n.fire("editor:object-locked", {
2421
2419
  object: a,
2422
2420
  skipInnerObjects: t,
2423
2421
  withoutSave: s
@@ -2431,8 +2429,8 @@ class F {
2431
2429
  * @fires editor:object-unlocked
2432
2430
  */
2433
2431
  unlockObject({ object: e, withoutSave: t } = {}) {
2434
- const { canvas: s, historyManager: i } = this.editor, n = e || s.getActiveObject();
2435
- if (!n) return;
2432
+ const { canvas: s, historyManager: n } = this.editor, i = e || s.getActiveObject();
2433
+ if (!i) return;
2436
2434
  const a = {
2437
2435
  lockMovementX: !1,
2438
2436
  lockMovementY: !1,
@@ -2443,10 +2441,10 @@ class F {
2443
2441
  lockSkewingY: !1,
2444
2442
  locked: !1
2445
2443
  };
2446
- n.set(a), F._isGroupOrSelection(n) && n.getObjects().forEach((o) => {
2444
+ i.set(a), F._isGroupOrSelection(i) && i.getObjects().forEach((o) => {
2447
2445
  o.set(a);
2448
- }), s.renderAll(), t || i.saveState(), s.fire("editor:object-unlocked", {
2449
- object: n,
2446
+ }), s.renderAll(), t || n.saveState(), s.fire("editor:object-unlocked", {
2447
+ object: i,
2450
2448
  withoutSave: t
2451
2449
  });
2452
2450
  }
@@ -2469,13 +2467,13 @@ class ot {
2469
2467
  object: e,
2470
2468
  withoutSave: t
2471
2469
  } = {}) {
2472
- const { canvas: s, historyManager: i } = this.editor;
2473
- i.suspendHistory();
2474
- const n = e || s.getActiveObject();
2475
- if (!n || !(n instanceof v)) return;
2476
- const a = n.getObjects(), o = new X(a);
2477
- a.forEach((c) => s.remove(c)), o.set("id", `${o.type}-${L()}`), s.add(o), s.setActiveObject(o), s.renderAll(), i.resumeHistory(), t || i.saveState(), s.fire("editor:objects-grouped", {
2478
- object: n,
2470
+ const { canvas: s, historyManager: n } = this.editor;
2471
+ n.suspendHistory();
2472
+ const i = e || s.getActiveObject();
2473
+ if (!i || !(i instanceof v)) return;
2474
+ const a = i.getObjects(), o = new X(a);
2475
+ a.forEach((d) => s.remove(d)), o.set("id", `${o.type}-${L()}`), s.add(o), s.setActiveObject(o), s.renderAll(), n.resumeHistory(), t || n.saveState(), s.fire("editor:objects-grouped", {
2476
+ object: i,
2479
2477
  group: o,
2480
2478
  withoutSave: t
2481
2479
  });
@@ -2491,17 +2489,17 @@ class ot {
2491
2489
  object: e,
2492
2490
  withoutSave: t
2493
2491
  } = {}) {
2494
- const { canvas: s, historyManager: i } = this.editor;
2495
- i.suspendHistory();
2496
- const n = e || s.getActiveObject();
2497
- if (!(n instanceof X)) return;
2498
- const a = n.removeAll();
2499
- s.remove(n), a.forEach((c) => s.add(c));
2492
+ const { canvas: s, historyManager: n } = this.editor;
2493
+ n.suspendHistory();
2494
+ const i = e || s.getActiveObject();
2495
+ if (!(i instanceof X)) return;
2496
+ const a = i.removeAll();
2497
+ s.remove(i), a.forEach((d) => s.add(d));
2500
2498
  const o = new v(a, {
2501
2499
  canvas: s
2502
2500
  });
2503
- s.setActiveObject(o), s.renderAll(), i.resumeHistory(), t || i.saveState(), s.fire("editor:objects-ungrouped", {
2504
- object: n,
2501
+ s.setActiveObject(o), s.renderAll(), n.resumeHistory(), t || n.saveState(), s.fire("editor:objects-ungrouped", {
2502
+ object: i,
2505
2503
  selection: o,
2506
2504
  withoutSave: t
2507
2505
  });
@@ -2518,8 +2516,8 @@ class rt {
2518
2516
  selectAll() {
2519
2517
  const { canvas: e, canvasManager: t, objectLockManager: s } = this.editor;
2520
2518
  e.discardActiveObject();
2521
- const i = t.getObjects(), n = i.some((o) => o.locked), a = i.length > 1 ? new v(t.getObjects(), { canvas: e }) : i[0];
2522
- n && s.lockObject({ object: a, skipInnerObjects: !0, withoutSave: !0 }), e.setActiveObject(a), e.requestRenderAll(), e.fire("editor:all-objects-selected", { selected: a });
2519
+ const n = t.getObjects(), i = n.some((o) => o.locked), a = n.length > 1 ? new v(t.getObjects(), { canvas: e }) : n[0];
2520
+ i && s.lockObject({ object: a, skipInnerObjects: !0, withoutSave: !0 }), e.setActiveObject(a), e.requestRenderAll(), e.fire("editor:all-objects-selected", { selected: a });
2523
2521
  }
2524
2522
  }
2525
2523
  class ct {
@@ -2537,14 +2535,14 @@ class ct {
2537
2535
  objects: e,
2538
2536
  withoutSave: t
2539
2537
  } = {}) {
2540
- const { canvas: s, historyManager: i, groupingManager: n } = this.editor, a = (e || s.getActiveObjects()).filter((o) => !o.locked);
2541
- a != null && a.length && (i.suspendHistory(), a.forEach((o) => {
2538
+ const { canvas: s, historyManager: n, groupingManager: i } = this.editor, a = (e || s.getActiveObjects()).filter((o) => !o.locked);
2539
+ a != null && a.length && (n.suspendHistory(), a.forEach((o) => {
2542
2540
  if (o.type === "group" && o.format !== "svg") {
2543
- n.ungroup({ object: o, withoutSave: t }), this.deleteSelectedObjects();
2541
+ i.ungroup({ object: o, withoutSave: t }), this.deleteSelectedObjects();
2544
2542
  return;
2545
2543
  }
2546
2544
  s.remove(o);
2547
- }), s.discardActiveObject(), s.renderAll(), i.resumeHistory(), t || i.saveState(), s.fire("editor:objects-deleted", {
2545
+ }), s.discardActiveObject(), s.renderAll(), n.resumeHistory(), t || n.saveState(), s.fire("editor:objects-deleted", {
2548
2546
  objects: a,
2549
2547
  withoutSave: t
2550
2548
  }));
@@ -2638,22 +2636,22 @@ class V {
2638
2636
  * @param options.message — текст ошибки (опционально, если не передан, то используется код ошибки)
2639
2637
  * @fires editor:error
2640
2638
  */
2641
- emitError({ origin: e = "ImageEditor", method: t = "Unknown Method", code: s, data: i, message: n }) {
2639
+ emitError({ origin: e = "ImageEditor", method: t = "Unknown Method", code: s, data: n, message: i }) {
2642
2640
  if (!V.isValidErrorCode(s)) {
2643
2641
  console.warn("Неизвестный код ошибки: ", { code: s, origin: e, method: t });
2644
2642
  return;
2645
2643
  }
2646
2644
  if (!s) return;
2647
- const a = n || s;
2648
- console.error(`${e}. ${t}. ${s}. ${a}`, i);
2645
+ const a = i || s;
2646
+ console.error(`${e}. ${t}. ${s}. ${a}`, n);
2649
2647
  const o = {
2650
2648
  code: s,
2651
2649
  origin: e,
2652
2650
  method: t,
2653
2651
  message: a,
2654
- data: i
2652
+ data: n
2655
2653
  };
2656
- this._buffer.push(p({
2654
+ this._buffer.push(y({
2657
2655
  type: "editor:error"
2658
2656
  }, o)), this.editor.canvas.fire("editor:error", o);
2659
2657
  }
@@ -2667,21 +2665,21 @@ class V {
2667
2665
  * @param options.message — текст предупреждения (опционально, если не передан, то используется код предупреждения)
2668
2666
  * @fires editor:warning
2669
2667
  */
2670
- emitWarning({ origin: e = "ImageEditor", method: t = "Unknown Method", code: s, message: i, data: n }) {
2668
+ emitWarning({ origin: e = "ImageEditor", method: t = "Unknown Method", code: s, message: n, data: i }) {
2671
2669
  if (!V.isValidErrorCode(s)) {
2672
2670
  console.warn("Неизвестный код предупреждения: ", { code: s, origin: e, method: t });
2673
2671
  return;
2674
2672
  }
2675
- const a = i || s;
2676
- console.warn(`${e}. ${t}. ${s}. ${a}`, n);
2673
+ const a = n || s;
2674
+ console.warn(`${e}. ${t}. ${s}. ${a}`, i);
2677
2675
  const o = {
2678
2676
  code: s,
2679
2677
  origin: e,
2680
2678
  method: t,
2681
2679
  message: a,
2682
- data: n
2680
+ data: i
2683
2681
  };
2684
- this._buffer.push(p({
2682
+ this._buffer.push(y({
2685
2683
  type: "editor:warning"
2686
2684
  }, o)), this.editor.canvas.fire("editor:warning", o);
2687
2685
  }
@@ -2694,7 +2692,7 @@ class V {
2694
2692
  return e ? Object.values(dt).some((t) => Object.values(t).includes(e)) : !1;
2695
2693
  }
2696
2694
  }
2697
- class ie {
2695
+ class ne {
2698
2696
  /**
2699
2697
  * Конструктор класса ImageEditor.
2700
2698
  * @param canvasId - идентификатор канваса, в котором будет создан редактор
@@ -2714,15 +2712,15 @@ class ie {
2714
2712
  editorContainerWidth: e,
2715
2713
  editorContainerHeight: t,
2716
2714
  canvasWrapperWidth: s,
2717
- canvasWrapperHeight: i,
2718
- canvasCSSWidth: n,
2715
+ canvasWrapperHeight: n,
2716
+ canvasCSSWidth: i,
2719
2717
  canvasCSSHeight: a,
2720
2718
  initialImage: o,
2721
- initialStateJSON: c,
2719
+ initialStateJSON: d,
2722
2720
  scaleType: r,
2723
2721
  _onReadyCallback: l
2724
2722
  } = this.options;
2725
- if (He.apply(), this.canvas = new Ce(this.containerId, this.options), this.moduleLoader = new Ee(), this.workerManager = new Te(), this.errorManager = new V({ editor: this }), this.historyManager = new Je({ editor: this }), this.toolbar = new Qe({ editor: this }), this.transformManager = new st({ editor: this }), this.canvasManager = new tt({ editor: this }), this.imageManager = new D({ editor: this }), this.layerManager = new P({ editor: this }), this.shapeManager = new nt({ editor: this }), this.interactionBlocker = new it({ editor: this }), this.clipboardManager = new at({ editor: this }), this.objectLockManager = new F({ editor: this }), this.groupingManager = new ot({ editor: this }), this.selectionManager = new rt({ editor: this }), this.deletionManager = new ct({ editor: this }), this._createMontageArea(), this._createClippingArea(), this.listeners = new z({ editor: this, options: this.options }), this.canvasManager.setEditorContainerWidth(e), this.canvasManager.setEditorContainerHeight(t), this.canvasManager.setCanvasWrapperWidth(s), this.canvasManager.setCanvasWrapperHeight(i), this.canvasManager.setCanvasCSSWidth(n), this.canvasManager.setCanvasCSSHeight(a), o != null && o.source) {
2723
+ if (He.apply(), this.canvas = new Ce(this.containerId, this.options), this.moduleLoader = new Ee(), this.workerManager = new Te(), this.errorManager = new V({ editor: this }), this.historyManager = new Je({ editor: this }), this.toolbar = new Qe({ editor: this }), this.transformManager = new st({ editor: this }), this.canvasManager = new tt({ editor: this }), this.imageManager = new D({ editor: this }), this.layerManager = new P({ editor: this }), this.shapeManager = new it({ editor: this }), this.interactionBlocker = new nt({ editor: this }), this.clipboardManager = new at({ editor: this }), this.objectLockManager = new F({ editor: this }), this.groupingManager = new ot({ editor: this }), this.selectionManager = new rt({ editor: this }), this.deletionManager = new ct({ editor: this }), this._createMontageArea(), this._createClippingArea(), this.listeners = new z({ editor: this, options: this.options }), this.canvasManager.setEditorContainerWidth(e), this.canvasManager.setEditorContainerHeight(t), this.canvasManager.setCanvasWrapperWidth(s), this.canvasManager.setCanvasWrapperHeight(n), this.canvasManager.setCanvasCSSWidth(i), this.canvasManager.setCanvasCSSHeight(a), o != null && o.source) {
2726
2724
  const {
2727
2725
  source: h,
2728
2726
  scale: g = `image-${r}`,
@@ -2731,7 +2729,7 @@ class ie {
2731
2729
  yield this.imageManager.importImage({ source: h, scale: g, withoutSave: u });
2732
2730
  } else
2733
2731
  this.canvasManager.setDefaultScale({ withoutSave: !0 });
2734
- c && this.historyManager.loadStateFromFullState(c), this.historyManager.saveState(), console.log("editor:ready"), this.canvas.fire("editor:ready", this), typeof l == "function" && l(this);
2732
+ d && this.historyManager.loadStateFromFullState(d), this.historyManager.saveState(), console.log("editor:ready"), this.canvas.fire("editor:ready", this), typeof l == "function" && l(this);
2735
2733
  });
2736
2734
  }
2737
2735
  /**
@@ -2745,7 +2743,7 @@ class ie {
2745
2743
  this.montageArea = this.shapeManager.addRectangle({
2746
2744
  width: e,
2747
2745
  height: t,
2748
- fill: ie._createMosaicPattern(),
2746
+ fill: ne._createMosaicPattern(),
2749
2747
  stroke: null,
2750
2748
  strokeWidth: 0,
2751
2749
  selectable: !1,
@@ -2889,15 +2887,15 @@ const lt = {
2889
2887
  deleteObjectsByHotkey: !0,
2890
2888
  resetObjectFitByDoubleClick: !0
2891
2889
  };
2892
- function bt(d, e = {}) {
2893
- const t = p(p({}, lt), e), s = document.getElementById(d);
2890
+ function bt(c, e = {}) {
2891
+ const t = y(y({}, lt), e), s = document.getElementById(c);
2894
2892
  if (!s)
2895
- return Promise.reject(new Error(`Контейнер с ID "${d}" не найден.`));
2896
- const i = document.createElement("canvas");
2897
- return i.id = `${d}-canvas`, s.appendChild(i), t.editorContainer = s, new Promise((n) => {
2898
- t._onReadyCallback = n;
2899
- const a = new ie(i.id, t);
2900
- window[d] = a;
2893
+ return Promise.reject(new Error(`Контейнер с ID "${c}" не найден.`));
2894
+ const n = document.createElement("canvas");
2895
+ return n.id = `${c}-canvas`, s.appendChild(n), t.editorContainer = s, new Promise((i) => {
2896
+ t._onReadyCallback = i;
2897
+ const a = new ne(n.id, t);
2898
+ window[c] = a;
2901
2899
  });
2902
2900
  }
2903
2901
  export {