@anu3ev/fabric-image-editor 0.1.73 → 0.1.75

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 (4) hide show
  1. package/LICENSE +21 -0
  2. package/dist/main.js +425 -334
  3. package/package.json +1 -1
  4. package/readme.md +338 -30
package/dist/main.js CHANGED
@@ -1,25 +1,25 @@
1
- var Ie = Object.defineProperty, ve = Object.defineProperties;
2
- var Ae = Object.getOwnPropertyDescriptors;
3
- var Y = Object.getOwnPropertySymbols;
1
+ var ve = Object.defineProperty, Ae = Object.defineProperties;
2
+ var Ce = Object.getOwnPropertyDescriptors;
3
+ var W = Object.getOwnPropertySymbols;
4
4
  var he = Object.prototype.hasOwnProperty, ge = Object.prototype.propertyIsEnumerable;
5
- var le = (r, e, t) => e in r ? Ie(r, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : r[e] = t, p = (r, e) => {
5
+ var le = (r, e, t) => e in r ? ve(r, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : r[e] = t, I = (r, e) => {
6
6
  for (var t in e || (e = {}))
7
7
  he.call(e, t) && le(r, t, e[t]);
8
- if (Y)
9
- for (var t of Y(e))
8
+ if (W)
9
+ for (var t of W(e))
10
10
  ge.call(e, t) && le(r, t, e[t]);
11
11
  return r;
12
- }, ue = (r, e) => ve(r, Ae(e));
13
- var W = (r, e) => {
12
+ }, ue = (r, e) => Ae(r, Ce(e));
13
+ var F = (r, e) => {
14
14
  var t = {};
15
15
  for (var s in r)
16
16
  he.call(r, s) && e.indexOf(s) < 0 && (t[s] = r[s]);
17
- if (r != null && Y)
18
- for (var s of Y(r))
17
+ if (r != null && W)
18
+ for (var s of W(r))
19
19
  e.indexOf(s) < 0 && ge.call(r, s) && (t[s] = r[s]);
20
20
  return t;
21
21
  };
22
- var b = (r, e, t) => new Promise((s, a) => {
22
+ var y = (r, e, t) => new Promise((s, a) => {
23
23
  var n = (c) => {
24
24
  try {
25
25
  i(t.next(c));
@@ -35,15 +35,15 @@ var b = (r, e, t) => new Promise((s, a) => {
35
35
  }, i = (c) => c.done ? s(c.value) : Promise.resolve(c.value).then(n, o);
36
36
  i((t = t.apply(r, e)).next());
37
37
  });
38
- import { ActiveSelection as y, util as P, controlsUtils as Ce, InteractiveFabricObject as Se, loadSVGFromURL as Ee, FabricImage as x, Point as V, Gradient as De, Rect as Ne, Circle as Oe, Triangle as Le, Group as J, Canvas as Te, Pattern as we } from "fabric";
38
+ import { ActiveSelection as v, util as P, controlsUtils as Se, InteractiveFabricObject as Ee, loadSVGFromURL as De, FabricImage as z, Point as G, Gradient as Me, Rect as Ne, Circle as Oe, Triangle as Le, Group as q, Canvas as we, Pattern as Te } from "fabric";
39
39
  import { create as ke } from "jsondiffpatch";
40
40
  import Be from "diff-match-patch";
41
- var _e = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict", v = function() {
41
+ var xe = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict", A = function() {
42
42
  for (var e = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : 21, t = "", s = crypto.getRandomValues(new Uint8Array(e |= 0)); e--; )
43
- t += _e[s[e] & 63];
43
+ t += xe[s[e] & 63];
44
44
  return t;
45
45
  };
46
- class Z {
46
+ class Y {
47
47
  /**
48
48
  * Конструктор принимает редактор и опции.
49
49
  * @param params
@@ -61,7 +61,7 @@ class Z {
61
61
  * @param params.options.adaptCanvasToContainerOnResize — адаптировать канвас к размерам контейнера при изменении размеров окна
62
62
  */
63
63
  constructor({ editor: e, options: t = {} }) {
64
- this.isDragging = !1, this.lastMouseX = 0, this.lastMouseY = 0, this.isUndoRedoKeyPressed = !1, this.isSpacePressed = !1, this.savedSelection = [], this.canvasDragging = !1, this.mouseWheelZooming = !1, this.bringToFrontOnSelection = !1, this.resetObjectFitByDoubleClick = !1, this.copyObjectsByHotkey = !1, this.pasteImageFromClipboard = !1, this.undoRedoByHotKeys = !1, this.selectAllByHotkey = !1, this.deleteObjectsByHotkey = !1, this.adaptCanvasToContainerOnResize = !1, this.editor = e, this.canvas = e.canvas, this.options = t, this.handleContainerResizeBound = Z.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 = Z.debounce(this.handleObjectModifiedHistory.bind(this), 300), this.handleObjectRotatingHistoryBound = Z.debounce(this.handleObjectRotatingHistory.bind(this), 300), this.handleObjectAddedHistoryBound = this.handleObjectAddedHistory.bind(this), this.handleObjectRemovedHistoryBound = this.handleObjectRemovedHistory.bind(this), this.handleOverlayUpdateBound = this.handleOverlayUpdate.bind(this), this.handleBackgroundUpdateBound = this.handleBackgroundUpdate.bind(this), this.handleCanvasDragStartBound = this.handleCanvasDragStart.bind(this), this.handleCanvasDraggingBound = this.handleCanvasDragging.bind(this), this.handleCanvasDragEndBound = this.handleCanvasDragEnd.bind(this), this.handleMouseWheelZoomBound = this.handleMouseWheelZoom.bind(this), this.handleBringToFrontBound = this.handleBringToFront.bind(this), this.handleResetObjectFitBound = this.handleResetObjectFit.bind(this), this.handleLockedSelectionBound = this._filterLockedSelection.bind(this), this.init();
64
+ this.isDragging = !1, this.lastMouseX = 0, this.lastMouseY = 0, this.isUndoRedoKeyPressed = !1, this.isSpacePressed = !1, this.savedSelection = [], this.canvasDragging = !1, this.mouseWheelZooming = !1, this.bringToFrontOnSelection = !1, this.resetObjectFitByDoubleClick = !1, this.copyObjectsByHotkey = !1, this.pasteImageFromClipboard = !1, this.undoRedoByHotKeys = !1, this.selectAllByHotkey = !1, this.deleteObjectsByHotkey = !1, this.adaptCanvasToContainerOnResize = !1, this.editor = e, this.canvas = e.canvas, this.options = t, this.handleContainerResizeBound = Y.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 = Y.debounce(this.handleObjectModifiedHistory.bind(this), 300), this.handleObjectRotatingHistoryBound = Y.debounce(this.handleObjectRotatingHistory.bind(this), 300), this.handleObjectAddedHistoryBound = this.handleObjectAddedHistory.bind(this), this.handleObjectRemovedHistoryBound = this.handleObjectRemovedHistory.bind(this), this.handleOverlayUpdateBound = this.handleOverlayUpdate.bind(this), this.handleBackgroundUpdateBound = this.handleBackgroundUpdate.bind(this), this.handleCanvasDragStartBound = this.handleCanvasDragStart.bind(this), this.handleCanvasDraggingBound = this.handleCanvasDragging.bind(this), this.handleCanvasDragEndBound = this.handleCanvasDragEnd.bind(this), this.handleMouseWheelZoomBound = this.handleMouseWheelZoom.bind(this), this.handleBringToFrontBound = this.handleBringToFront.bind(this), this.handleResetObjectFitBound = this.handleResetObjectFit.bind(this), this.handleLockedSelectionBound = this._filterLockedSelection.bind(this), this.init();
65
65
  }
66
66
  /**
67
67
  * Инициализация всех обработчиков согласно опциям.
@@ -98,7 +98,7 @@ class Z {
98
98
  if (a.length === 1)
99
99
  this.canvas.setActiveObject(a[0]);
100
100
  else {
101
- const o = new y(a, {
101
+ const o = new v(a, {
102
102
  canvas: this.canvas
103
103
  });
104
104
  this.canvas.setActiveObject(o);
@@ -106,7 +106,7 @@ class Z {
106
106
  this.canvas.requestRenderAll();
107
107
  return;
108
108
  }
109
- const n = new y(e, {
109
+ const n = new v(e, {
110
110
  canvas: this.canvas
111
111
  });
112
112
  this.editor.objectLockManager.lockObject({
@@ -175,7 +175,7 @@ class Z {
175
175
  * @param event.code — код клавиши
176
176
  */
177
177
  handleUndoRedoEvent(e) {
178
- return b(this, null, function* () {
178
+ return y(this, null, function* () {
179
179
  const { ctrlKey: t, metaKey: s, code: a, repeat: n } = e;
180
180
  this._shouldIgnoreKeyboardEvent(e) || !t && !s || n || !/Mac/i.test(navigator.userAgent) && this.isUndoRedoKeyPressed || (a === "KeyZ" ? (e.preventDefault(), this.isUndoRedoKeyPressed = !0, yield this.editor.historyManager.undo()) : a === "KeyY" && (e.preventDefault(), this.isUndoRedoKeyPressed = !0, yield this.editor.historyManager.redo()));
181
181
  });
@@ -220,7 +220,7 @@ class Z {
220
220
  if (a || n) return;
221
221
  this.isSpacePressed = !0, e.preventDefault();
222
222
  const o = t.getActiveObject() || null;
223
- o instanceof y ? this.savedSelection = o.getObjects().slice() : o && (this.savedSelection = [o]), t.discardActiveObject(), t.set({
223
+ o instanceof v ? this.savedSelection = o.getObjects().slice() : o && (this.savedSelection = [o]), t.discardActiveObject(), t.set({
224
224
  selection: !1,
225
225
  defaultCursor: "grab"
226
226
  }), t.setCursor("grab"), s.canvasManager.getObjects().forEach((i) => {
@@ -259,7 +259,7 @@ class Z {
259
259
  t.setActiveObject(e[0]);
260
260
  return;
261
261
  }
262
- const a = e.filter((o) => s.canvasManager.getObjects().includes(o)), n = new y(a, { canvas: t });
262
+ const a = e.filter((o) => s.canvasManager.getObjects().includes(o)), n = new v(a, { canvas: t });
263
263
  t.setActiveObject(n);
264
264
  }
265
265
  // --- Обработчики для событий canvas (Fabric) ---
@@ -372,7 +372,7 @@ class Z {
372
372
  };
373
373
  }
374
374
  }
375
- class xe {
375
+ class _e {
376
376
  /**
377
377
  * Класс для динамической загрузки внешних модулей.
378
378
  */
@@ -432,7 +432,7 @@ class Ue {
432
432
  * @returns Promise, который будет выполнен, когда воркер вернет ответ
433
433
  */
434
434
  post(e, t, s = []) {
435
- const a = `${e}:${v(8)}`;
435
+ const a = `${e}:${A(8)}`;
436
436
  return new Promise((n, o) => {
437
437
  this._callbacks.set(a, { resolve: n, reject: o }), this.worker.postMessage({ action: e, payload: t, requestId: a }, s);
438
438
  });
@@ -444,50 +444,50 @@ class Ue {
444
444
  this.worker.terminate();
445
445
  }
446
446
  }
447
- const N = 12, He = 2, q = 8, ee = 20, ze = 100, te = 20, se = 8, Ze = 100, G = 32, ae = 1, Pe = "#2B2D33", ne = "#3D8BF4", oe = "#FFFFFF";
448
- function F(r, e, t, s, a) {
447
+ const N = 12, He = 2, ee = 8, te = 20, ze = 100, se = 20, ae = 8, Ze = 100, X = 32, ne = 1, Ye = "#2B2D33", oe = "#3D8BF4", ie = "#FFFFFF";
448
+ function V(r, e, t, s, a) {
449
449
  const n = N, o = He;
450
- r.save(), r.translate(e, t), r.rotate(P.degreesToRadians(a.angle)), r.fillStyle = oe, r.strokeStyle = ne, r.lineWidth = ae, r.beginPath(), r.roundRect(-n / 2, -n / 2, n, n, o), r.fill(), r.stroke(), r.restore();
451
- }
452
- function Me(r, e, t, s, a) {
453
- const n = q, o = ee, i = ze;
454
- r.save(), r.translate(e, t), r.rotate(P.degreesToRadians(a.angle)), r.fillStyle = oe, r.strokeStyle = ne, r.lineWidth = ae, r.beginPath(), r.roundRect(-n / 2, -o / 2, n, o, i), r.fill(), r.stroke(), r.restore();
450
+ r.save(), r.translate(e, t), r.rotate(P.degreesToRadians(a.angle)), r.fillStyle = ie, r.strokeStyle = oe, r.lineWidth = ne, r.beginPath(), r.roundRect(-n / 2, -n / 2, n, n, o), r.fill(), r.stroke(), r.restore();
455
451
  }
456
452
  function fe(r, e, t, s, a) {
457
- const n = te, o = se, i = Ze;
458
- r.save(), r.translate(e, t), r.rotate(P.degreesToRadians(a.angle)), r.fillStyle = oe, r.strokeStyle = ne, r.lineWidth = ae, r.beginPath(), r.roundRect(-n / 2, -o / 2, n, o, i), r.fill(), r.stroke(), r.restore();
453
+ const n = ee, o = te, i = ze;
454
+ r.save(), r.translate(e, t), r.rotate(P.degreesToRadians(a.angle)), r.fillStyle = ie, r.strokeStyle = oe, r.lineWidth = ne, r.beginPath(), r.roundRect(-n / 2, -o / 2, n, o, i), r.fill(), r.stroke(), r.restore();
455
+ }
456
+ function me(r, e, t, s, a) {
457
+ const n = se, o = ae, i = Ze;
458
+ r.save(), r.translate(e, t), r.rotate(P.degreesToRadians(a.angle)), r.fillStyle = ie, r.strokeStyle = oe, r.lineWidth = ne, r.beginPath(), r.roundRect(-n / 2, -o / 2, n, o, i), r.fill(), r.stroke(), r.restore();
459
459
  }
460
- const Ye = "", je = new Image();
461
- je.src = Ye;
460
+ const Pe = "", ye = new Image();
461
+ ye.src = Pe;
462
462
  function We(r, e, t, s, a) {
463
- const o = G / 2;
464
- r.save(), r.translate(e, t), r.rotate(P.degreesToRadians(a.angle)), r.fillStyle = Pe, r.beginPath(), r.arc(0, 0, o, 0, 2 * Math.PI), r.fill(), r.drawImage(je, -o / 2, -o / 2, o, o), r.restore();
463
+ const o = X / 2;
464
+ r.save(), r.translate(e, t), r.rotate(P.degreesToRadians(a.angle)), r.fillStyle = Ye, r.beginPath(), r.arc(0, 0, o, 0, 2 * Math.PI), r.fill(), r.drawImage(ye, -o / 2, -o / 2, o, o), r.restore();
465
465
  }
466
466
  const Fe = {
467
467
  // Угловые точки
468
468
  tl: {
469
- render: F,
469
+ render: V,
470
470
  sizeX: N,
471
471
  sizeY: N,
472
472
  offsetX: 0,
473
473
  offsetY: 0
474
474
  },
475
475
  tr: {
476
- render: F,
476
+ render: V,
477
477
  sizeX: N,
478
478
  sizeY: N,
479
479
  offsetX: 0,
480
480
  offsetY: 0
481
481
  },
482
482
  bl: {
483
- render: F,
483
+ render: V,
484
484
  sizeX: N,
485
485
  sizeY: N,
486
486
  offsetX: 0,
487
487
  offsetY: 0
488
488
  },
489
489
  br: {
490
- render: F,
490
+ render: V,
491
491
  sizeX: N,
492
492
  sizeY: N,
493
493
  offsetX: 0,
@@ -495,46 +495,46 @@ const Fe = {
495
495
  },
496
496
  // Середина вертикалей
497
497
  ml: {
498
- render: Me,
499
- sizeX: q,
500
- sizeY: ee,
498
+ render: fe,
499
+ sizeX: ee,
500
+ sizeY: te,
501
501
  offsetX: 0,
502
502
  offsetY: 0
503
503
  },
504
504
  mr: {
505
- render: Me,
506
- sizeX: q,
507
- sizeY: ee,
505
+ render: fe,
506
+ sizeX: ee,
507
+ sizeY: te,
508
508
  offsetX: 0,
509
509
  offsetY: 0
510
510
  },
511
511
  // Середина горизонталей
512
512
  mt: {
513
- render: fe,
514
- sizeX: te,
515
- sizeY: se,
513
+ render: me,
514
+ sizeX: se,
515
+ sizeY: ae,
516
516
  offsetX: 0,
517
517
  offsetY: 0
518
518
  },
519
519
  mb: {
520
- render: fe,
521
- sizeX: te,
522
- sizeY: se,
520
+ render: me,
521
+ sizeX: se,
522
+ sizeY: ae,
523
523
  offsetX: 0,
524
524
  offsetY: 0
525
525
  },
526
526
  // Специальный «rotate» контрол
527
527
  mtr: {
528
528
  render: We,
529
- sizeX: G,
530
- sizeY: G,
529
+ sizeX: X,
530
+ sizeY: X,
531
531
  offsetX: 0,
532
- offsetY: -G
532
+ offsetY: -X
533
533
  }
534
534
  };
535
535
  class Ve {
536
536
  static apply() {
537
- const e = Ce.createObjectDefaultControls();
537
+ const e = Se.createObjectDefaultControls();
538
538
  Object.entries(Fe).forEach(([t, s]) => {
539
539
  Object.assign(e[t], {
540
540
  render: s.render,
@@ -546,10 +546,10 @@ class Ve {
546
546
  var h;
547
547
  (h = o.target.canvas) == null || h.setCursor("grabbing");
548
548
  });
549
- }), Se.ownDefaults.controls = e;
549
+ }), Ee.ownDefaults.controls = e;
550
550
  }
551
551
  }
552
- const Ge = "", Xe = "", Qe = "", Ke = "", $e = "", Je = "", qe = "", et = "", z = {
552
+ const Ge = "", Xe = "", Qe = "", Ke = "", $e = "", Je = "", qe = "", et = "", Z = {
553
553
  style: {
554
554
  position: "absolute",
555
555
  display: "none",
@@ -626,7 +626,7 @@ const Ge = "
626
626
  sendBackwards: $e
627
627
  },
628
628
  handlers: {
629
- copyPaste: (r) => b(null, null, function* () {
629
+ copyPaste: (r) => y(null, null, function* () {
630
630
  r.clipboardManager.copyPaste();
631
631
  }),
632
632
  delete: (r) => {
@@ -659,11 +659,11 @@ class tt {
659
659
  _initToolbar() {
660
660
  if (!this.options.showToolbar) return;
661
661
  const e = this.options.toolbar || {};
662
- this.config = ue(p(p({}, z), e), {
663
- style: p(p({}, z.style), e.style || {}),
664
- btnStyle: p(p({}, z.btnStyle), e.btnStyle || {}),
665
- icons: p(p({}, z.icons), e.icons || {}),
666
- handlers: p(p({}, z.handlers), e.handlers || {})
662
+ this.config = ue(I(I({}, Z), e), {
663
+ style: I(I({}, Z.style), e.style || {}),
664
+ btnStyle: I(I({}, Z.btnStyle), e.btnStyle || {}),
665
+ icons: I(I({}, Z.icons), e.icons || {}),
666
+ handlers: I(I({}, Z.handlers), e.handlers || {})
667
667
  }), 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 = () => {
668
668
  this.el.style.display = "none";
669
669
  }, this._createDOM(), this._bindEvents();
@@ -754,10 +754,10 @@ class tt {
754
754
  }
755
755
  const { el: t, config: s, canvas: a } = this;
756
756
  e.setCoords();
757
- const n = a.getZoom(), [, , , , o, i] = a.viewportTransform, { x: c } = e.getCenterPoint(), { top: d, height: h } = e.getBoundingRect(), g = c * n + o - t.offsetWidth / 2, M = s.offsetTop || 0, m = (d + h) * n + i + M;
757
+ const n = a.getZoom(), [, , , , o, i] = a.viewportTransform, { x: c } = e.getCenterPoint(), { top: d, height: h } = e.getBoundingRect(), g = c * n + o - t.offsetWidth / 2, u = s.offsetTop || 0, f = (d + h) * n + i + u;
758
758
  Object.assign(t.style, {
759
759
  left: `${g}px`,
760
- top: `${m}px`,
760
+ top: `${f}px`,
761
761
  display: "flex"
762
762
  });
763
763
  }
@@ -873,7 +873,7 @@ class st {
873
873
  console.log("Нет изменений для сохранения.");
874
874
  return;
875
875
  }
876
- console.log("baseState", this.baseState), this.currentIndex < this.patches.length && this.patches.splice(this.currentIndex), console.log("diff", s), this.totalChangesCount += 1, this.patches.push({ id: v(), diff: s }), this.currentIndex += 1, this.patches.length > this.maxHistoryLength && (this.baseState = this.diffPatcher.patch(this.baseState, this.patches[0].diff), this.patches.shift(), this.currentIndex -= 1, this.baseStateChangesCount += 1), console.log("Состояние сохранено. Текущий индекс истории:", this.currentIndex);
876
+ console.log("baseState", this.baseState), this.currentIndex < this.patches.length && this.patches.splice(this.currentIndex), console.log("diff", s), this.totalChangesCount += 1, this.patches.push({ id: A(), diff: s }), this.currentIndex += 1, this.patches.length > this.maxHistoryLength && (this.baseState = this.diffPatcher.patch(this.baseState, this.patches[0].diff), this.patches.shift(), this.currentIndex -= 1, this.baseStateChangesCount += 1), console.log("Состояние сохранено. Текущий индекс истории:", this.currentIndex);
877
877
  }
878
878
  /**
879
879
  * Функция загрузки состояния в канвас.
@@ -881,7 +881,7 @@ class st {
881
881
  * @fires editor:history-state-loaded
882
882
  */
883
883
  loadStateFromFullState(e) {
884
- return b(this, null, function* () {
884
+ return y(this, null, function* () {
885
885
  if (!e) return;
886
886
  console.log("loadStateFromFullState fullState", e);
887
887
  const { canvas: t, canvasManager: s, interactionBlocker: a, backgroundManager: n } = this.editor, { width: o, height: i } = t;
@@ -906,7 +906,7 @@ class st {
906
906
  * @fires editor:undo
907
907
  */
908
908
  undo() {
909
- return b(this, null, function* () {
909
+ return y(this, null, function* () {
910
910
  if (!this.skipHistory) {
911
911
  if (this.currentIndex <= 0) {
912
912
  console.log("Нет предыдущих состояний для отмены.");
@@ -943,7 +943,7 @@ class st {
943
943
  * @fires editor:redo
944
944
  */
945
945
  redo() {
946
- return b(this, null, function* () {
946
+ return y(this, null, function* () {
947
947
  if (!this.skipHistory) {
948
948
  if (this.currentIndex >= this.patches.length) {
949
949
  console.log("Нет состояний для повтора.");
@@ -976,7 +976,7 @@ class st {
976
976
  });
977
977
  }
978
978
  }
979
- const at = 0.1, nt = 2, ot = 0.1, it = 90, U = 16, H = 16, T = 4096, w = 4096, me = "application/image-editor:";
979
+ const at = 0.1, nt = 2, ot = 0.1, it = 90, R = 16, U = 16, w = 4096, T = 4096, be = "application/image-editor:";
980
980
  class O {
981
981
  constructor({ editor: e }) {
982
982
  this.editor = e, this.options = e.options, this._createdBlobUrls = [], this.acceptContentTypes = this.editor.options.acceptContentTypes, this.acceptFormats = this.getAllowedFormatsFromContentTypes();
@@ -994,83 +994,114 @@ class O {
994
994
  * @returns возвращает Promise с объектом изображения или null в случае ошибки
995
995
  */
996
996
  importImage(e) {
997
- return b(this, null, function* () {
997
+ return y(this, null, function* () {
998
998
  const {
999
999
  source: t,
1000
1000
  scale: s = `image-${this.options.scaleType}`,
1001
1001
  withoutSave: a = !1,
1002
- fromClipboard: n = !1
1002
+ fromClipboard: n = !1,
1003
+ isBackground: o = !1,
1004
+ withoutSelection: i = !1
1003
1005
  } = e;
1004
1006
  if (!t) return null;
1005
- const { canvas: o, montageArea: i, transformManager: c, historyManager: d, errorManager: h } = this.editor, l = yield this.getContentType(t), g = O.getFormatFromContentType(l), { acceptContentTypes: M, acceptFormats: m } = this;
1006
- if (!this.isAllowedContentType(l)) {
1007
- const f = `Неверный contentType для изображения: ${l}. Ожидается один из: ${this.acceptContentTypes.join(", ")}.`;
1008
- return h.emitError({
1007
+ const { canvas: c, montageArea: d, transformManager: h, historyManager: l, errorManager: g } = this.editor, u = yield this.getContentType(t), f = O.getFormatFromContentType(u), { acceptContentTypes: m, acceptFormats: M } = this;
1008
+ if (!this.isAllowedContentType(u)) {
1009
+ const j = `Неверный contentType для изображения: ${u}. Ожидается один из: ${this.acceptContentTypes.join(", ")}.`;
1010
+ return g.emitError({
1009
1011
  origin: "ImageManager",
1010
1012
  method: "importImage",
1011
1013
  code: "INVALID_CONTENT_TYPE",
1012
- message: f,
1013
- data: { source: t, format: g, contentType: l, acceptContentTypes: M, acceptFormats: m, fromClipboard: n }
1014
+ message: j,
1015
+ data: {
1016
+ source: t,
1017
+ format: f,
1018
+ contentType: u,
1019
+ acceptContentTypes: m,
1020
+ acceptFormats: M,
1021
+ fromClipboard: n,
1022
+ isBackground: o,
1023
+ withoutSelection: i
1024
+ }
1014
1025
  }), null;
1015
1026
  }
1016
- d.suspendHistory();
1027
+ l.suspendHistory();
1017
1028
  try {
1018
- let f, u;
1029
+ let j, b;
1019
1030
  if (t instanceof File)
1020
- f = URL.createObjectURL(t);
1031
+ j = URL.createObjectURL(t);
1021
1032
  else if (typeof t == "string") {
1022
1033
  const E = yield (yield fetch(t, { mode: "cors" })).blob();
1023
- f = URL.createObjectURL(E);
1034
+ j = URL.createObjectURL(E);
1024
1035
  } else
1025
- return h.emitError({
1036
+ return g.emitError({
1026
1037
  origin: "ImageManager",
1027
1038
  method: "importImage",
1028
1039
  code: "INVALID_SOURCE_TYPE",
1029
1040
  message: "Неверный тип источника изображения. Ожидается URL или объект File.",
1030
- data: { source: t, format: g, contentType: l, acceptContentTypes: M, acceptFormats: m, fromClipboard: n }
1041
+ data: {
1042
+ source: t,
1043
+ format: f,
1044
+ contentType: u,
1045
+ acceptContentTypes: m,
1046
+ acceptFormats: M,
1047
+ fromClipboard: n,
1048
+ isBackground: o,
1049
+ withoutSelection: i
1050
+ }
1031
1051
  }), null;
1032
- if (this._createdBlobUrls.push(f), g === "svg") {
1033
- const A = yield Ee(f);
1034
- u = P.groupSVGElements(A.objects, A.options);
1052
+ if (this._createdBlobUrls.push(j), f === "svg") {
1053
+ const C = yield De(j);
1054
+ b = P.groupSVGElements(C.objects, C.options);
1035
1055
  } else
1036
- u = yield x.fromURL(f, { crossOrigin: "anonymous" });
1037
- const { width: j, height: C } = u;
1038
- if (u instanceof x) {
1039
- const A = u.getElement();
1056
+ b = yield z.fromURL(j, { crossOrigin: "anonymous" });
1057
+ const { width: S, height: k } = b;
1058
+ if (b instanceof z) {
1059
+ const C = b.getElement();
1040
1060
  let E = "";
1041
- if (A instanceof HTMLImageElement ? E = A.src : A instanceof HTMLCanvasElement && (E = A.toDataURL()), C > w || j > T) {
1042
- const L = yield this.resizeImageToBoundaries(E, "max"), k = URL.createObjectURL(L);
1043
- this._createdBlobUrls.push(k), u = yield x.fromURL(k, { crossOrigin: "anonymous" });
1044
- } else if (C < H || j < U) {
1045
- const L = yield this.resizeImageToBoundaries(E, "min"), k = URL.createObjectURL(L);
1046
- this._createdBlobUrls.push(k), u = yield x.fromURL(k, { crossOrigin: "anonymous" });
1061
+ if (C instanceof HTMLImageElement ? E = C.src : C instanceof HTMLCanvasElement && (E = C.toDataURL()), k > T || S > w) {
1062
+ const L = yield this.resizeImageToBoundaries(E, "max"), p = URL.createObjectURL(L);
1063
+ this._createdBlobUrls.push(p), b = yield z.fromURL(p, { crossOrigin: "anonymous" });
1064
+ } else if (k < U || S < R) {
1065
+ const L = yield this.resizeImageToBoundaries(E, "min"), p = URL.createObjectURL(L);
1066
+ this._createdBlobUrls.push(p), b = yield z.fromURL(p, { crossOrigin: "anonymous" });
1047
1067
  }
1048
1068
  }
1049
- if (u.set("id", `${u.type}-${v()}`), u.set("format", g), s === "scale-montage")
1050
- this.editor.canvasManager.scaleMontageAreaToImage({ object: u, withoutSave: !0 });
1069
+ if (b.set("id", `${b.type}-${A()}`), b.set("format", f), s === "scale-montage")
1070
+ this.editor.canvasManager.scaleMontageAreaToImage({ object: b, withoutSave: !0 });
1051
1071
  else {
1052
- const { width: A, height: E } = i, L = this.calculateScaleFactor({ imageObject: u, scaleType: s });
1053
- s === "image-contain" && L < 1 ? c.fitObject({ object: u, type: "contain", withoutSave: !0 }) : s === "image-cover" && (j > A || C > E) && c.fitObject({ object: u, type: "cover", withoutSave: !0 });
1072
+ const { width: C, height: E } = d, L = this.calculateScaleFactor({ imageObject: b, scaleType: s });
1073
+ s === "image-contain" && L < 1 ? h.fitObject({ object: b, type: "contain", withoutSave: !0 }) : s === "image-cover" && (S > C || k > E) && h.fitObject({ object: b, type: "cover", withoutSave: !0 });
1054
1074
  }
1055
- o.add(u), o.centerObject(u), o.setActiveObject(u), o.renderAll(), d.resumeHistory(), a || d.saveState();
1056
- const S = {
1057
- image: u,
1058
- format: g,
1059
- contentType: l,
1075
+ c.add(b), c.centerObject(b), i || c.setActiveObject(b), c.renderAll(), l.resumeHistory(), a || l.saveState();
1076
+ const H = {
1077
+ image: b,
1078
+ format: f,
1079
+ contentType: u,
1060
1080
  scale: s,
1061
1081
  withoutSave: a,
1062
1082
  source: t,
1063
- fromClipboard: n
1083
+ fromClipboard: n,
1084
+ isBackground: o,
1085
+ withoutSelection: i
1064
1086
  };
1065
- return o.fire("editor:image-imported", S), S;
1066
- } catch (f) {
1067
- return h.emitError({
1087
+ return c.fire("editor:image-imported", H), H;
1088
+ } catch (j) {
1089
+ return g.emitError({
1068
1090
  origin: "ImageManager",
1069
1091
  method: "importImage",
1070
1092
  code: "IMPORT_FAILED",
1071
- message: `Ошибка импорта изображения: ${f.message}`,
1072
- data: { source: t, format: g, contentType: l, scale: s, withoutSave: a, fromClipboard: n }
1073
- }), d.resumeHistory(), null;
1093
+ message: `Ошибка импорта изображения: ${j.message}`,
1094
+ data: {
1095
+ source: t,
1096
+ format: f,
1097
+ contentType: u,
1098
+ scale: s,
1099
+ withoutSave: a,
1100
+ fromClipboard: n,
1101
+ isBackground: o,
1102
+ withoutSelection: i
1103
+ }
1104
+ }), l.resumeHistory(), null;
1074
1105
  }
1075
1106
  });
1076
1107
  }
@@ -1083,16 +1114,16 @@ class O {
1083
1114
  * @returns возвращает Promise с Blob-объектом уменьшенного изображения
1084
1115
  */
1085
1116
  resizeImageToBoundaries(e, t = "max") {
1086
- return b(this, null, function* () {
1087
- let s = `Размер изображения больше максимального размера канваса, поэтому оно будет уменьшено до максимальных размеров c сохранением пропорций: ${T}x${w}`;
1088
- t === "min" && (s = `Размер изображения меньше минимального размера канваса, поэтому оно будет увеличено до минимальных размеров c сохранением пропорций: ${U}x${H}`);
1117
+ return y(this, null, function* () {
1118
+ let s = `Размер изображения больше максимального размера канваса, поэтому оно будет уменьшено до максимальных размеров c сохранением пропорций: ${w}x${T}`;
1119
+ t === "min" && (s = `Размер изображения меньше минимального размера канваса, поэтому оно будет увеличено до минимальных размеров c сохранением пропорций: ${R}x${U}`);
1089
1120
  const a = {
1090
1121
  dataURL: e,
1091
1122
  sizeType: t,
1092
- maxWidth: T,
1093
- maxHeight: w,
1094
- minWidth: U,
1095
- minHeight: H
1123
+ maxWidth: w,
1124
+ maxHeight: T,
1125
+ minWidth: R,
1126
+ minHeight: U
1096
1127
  };
1097
1128
  return this.editor.errorManager.emitWarning({
1098
1129
  origin: "ImageManager",
@@ -1115,7 +1146,7 @@ class O {
1115
1146
  * @fires editor:canvas-exported
1116
1147
  */
1117
1148
  exportCanvasAsImageFile() {
1118
- return b(this, arguments, function* (e = {}) {
1149
+ return y(this, arguments, function* (e = {}) {
1119
1150
  const {
1120
1151
  fileName: t = "image.png",
1121
1152
  contentType: s = "image/png",
@@ -1125,16 +1156,16 @@ class O {
1125
1156
  try {
1126
1157
  const d = s === "application/pdf", h = d ? "image/jpg" : s, l = O.getFormatFromContentType(h);
1127
1158
  i.setCoords();
1128
- const { left: g, top: M, width: m, height: f } = i.getBoundingRect(), u = yield o.clone(["id", "format", "locked"]);
1129
- u.enableRetinaScaling = !1, ["image/jpg", "image/jpeg"].includes(h) && (u.backgroundColor = "#ffffff");
1130
- const j = u.getObjects().find((I) => I.id === i.id);
1131
- j && (j.visible = !1), u.viewportTransform = [1, 0, 0, 1, -g, -M], u.setDimensions({ width: m, height: f }, { backstoreOnly: !0 }), u.renderAll();
1132
- const C = u.getObjects().filter((I) => I.format).every((I) => I.format === "svg");
1133
- if (l === "svg" && C) {
1134
- const I = u.toSVG();
1135
- u.dispose();
1159
+ const { left: g, top: u, width: f, height: m } = i.getBoundingRect(), M = yield o.clone(["id", "format", "locked"]);
1160
+ M.enableRetinaScaling = !1, ["image/jpg", "image/jpeg"].includes(h) && (M.backgroundColor = "#ffffff");
1161
+ const j = M.getObjects().find((p) => p.id === i.id);
1162
+ j && (j.visible = !1), M.viewportTransform = [1, 0, 0, 1, -g, -u], M.setDimensions({ width: f, height: m }, { backstoreOnly: !0 }), M.renderAll();
1163
+ const b = M.getObjects().filter((p) => p.format).every((p) => p.format === "svg");
1164
+ if (l === "svg" && b) {
1165
+ const p = M.toSVG();
1166
+ M.dispose();
1136
1167
  const D = {
1137
- image: O._exportSVGStringAsFile(I, {
1168
+ image: O._exportSVGStringAsFile(p, {
1138
1169
  exportAsBase64: a,
1139
1170
  exportAsBlob: n,
1140
1171
  fileName: t
@@ -1145,42 +1176,42 @@ class O {
1145
1176
  };
1146
1177
  return o.fire("editor:canvas-exported", D), D;
1147
1178
  }
1148
- const S = yield new Promise((I, B) => {
1149
- u.getElement().toBlob((D) => {
1150
- D ? I(D) : B(new Error("Failed to create Blob from canvas"));
1179
+ const S = yield new Promise((p, B) => {
1180
+ M.getElement().toBlob((D) => {
1181
+ D ? p(D) : B(new Error("Failed to create Blob from canvas"));
1151
1182
  });
1152
1183
  });
1153
- if (u.dispose(), n) {
1154
- const I = {
1184
+ if (M.dispose(), n) {
1185
+ const p = {
1155
1186
  image: S,
1156
1187
  format: l,
1157
1188
  contentType: h,
1158
1189
  fileName: t
1159
1190
  };
1160
- return o.fire("editor:canvas-exported", I), I;
1191
+ return o.fire("editor:canvas-exported", p), p;
1161
1192
  }
1162
- const A = yield createImageBitmap(S), E = yield c.post(
1193
+ const k = yield createImageBitmap(S), H = yield c.post(
1163
1194
  "toDataURL",
1164
- { format: l, quality: 1, bitmap: A },
1165
- [A]
1195
+ { format: l, quality: 1, bitmap: k },
1196
+ [k]
1166
1197
  );
1167
1198
  if (d) {
1168
- const B = m * 0.264583, D = f * 0.264583, pe = (yield this.editor.moduleLoader.loadModule("jspdf")).jsPDF, $ = new pe({
1199
+ const B = f * 0.264583, D = m * 0.264583, pe = (yield this.editor.moduleLoader.loadModule("jspdf")).jsPDF, J = new pe({
1169
1200
  orientation: B > D ? "landscape" : "portrait",
1170
1201
  unit: "mm",
1171
1202
  format: [B, D]
1172
1203
  });
1173
- if ($.addImage(String(E), "JPG", 0, 0, B, D), a) {
1204
+ if (J.addImage(String(H), "JPG", 0, 0, B, D), a) {
1174
1205
  const de = {
1175
- image: $.output("datauristring"),
1206
+ image: J.output("datauristring"),
1176
1207
  format: "pdf",
1177
1208
  contentType: "application/pdf",
1178
1209
  fileName: t
1179
1210
  };
1180
1211
  return o.fire("editor:canvas-exported", de), de;
1181
1212
  }
1182
- const ye = $.output("blob"), ce = {
1183
- image: new File([ye], t, { type: "application/pdf" }),
1213
+ const Ie = J.output("blob"), ce = {
1214
+ image: new File([Ie], t, { type: "application/pdf" }),
1184
1215
  format: "pdf",
1185
1216
  contentType: "application/pdf",
1186
1217
  fileName: t
@@ -1188,21 +1219,21 @@ class O {
1188
1219
  return o.fire("editor:canvas-exported", ce), ce;
1189
1220
  }
1190
1221
  if (a) {
1191
- const I = {
1192
- image: E,
1222
+ const p = {
1223
+ image: H,
1193
1224
  format: l,
1194
1225
  contentType: h,
1195
1226
  fileName: t
1196
1227
  };
1197
- return o.fire("editor:canvas-exported", I), I;
1228
+ return o.fire("editor:canvas-exported", p), p;
1198
1229
  }
1199
- const L = l === "svg" && !C ? t.replace(/\.[^/.]+$/, ".png") : t, re = {
1200
- image: new File([S], L, { type: h }),
1230
+ const C = l === "svg" && !b ? t.replace(/\.[^/.]+$/, ".png") : t, L = {
1231
+ image: new File([S], C, { type: h }),
1201
1232
  format: l,
1202
1233
  contentType: h,
1203
- fileName: L
1234
+ fileName: C
1204
1235
  };
1205
- return o.fire("editor:canvas-exported", re), re;
1236
+ return o.fire("editor:canvas-exported", L), L;
1206
1237
  } catch (d) {
1207
1238
  return this.editor.errorManager.emitError({
1208
1239
  origin: "ImageManager",
@@ -1226,7 +1257,7 @@ class O {
1226
1257
  * @fires editor:object-exported
1227
1258
  */
1228
1259
  exportObjectAsImageFile() {
1229
- return b(this, arguments, function* (e = {}) {
1260
+ return y(this, arguments, function* (e = {}) {
1230
1261
  const {
1231
1262
  object: t,
1232
1263
  fileName: s = "image.png",
@@ -1245,31 +1276,31 @@ class O {
1245
1276
  try {
1246
1277
  const h = O.getFormatFromContentType(a);
1247
1278
  if (h === "svg") {
1248
- const f = d.toSVG(), u = O._exportSVGStringAsFile(f, {
1279
+ const m = d.toSVG(), M = O._exportSVGStringAsFile(m, {
1249
1280
  exportAsBase64: n,
1250
1281
  exportAsBlob: o,
1251
1282
  fileName: s
1252
1283
  }), j = {
1253
1284
  object: d,
1254
- image: u,
1285
+ image: M,
1255
1286
  format: h,
1256
1287
  contentType: "image/svg+xml",
1257
1288
  fileName: s.replace(/\.[^/.]+$/, ".svg")
1258
1289
  };
1259
1290
  return i.fire("editor:object-exported", j), j;
1260
1291
  }
1261
- if (n && d instanceof x) {
1262
- const f = yield createImageBitmap(d.getElement()), u = yield c.post(
1292
+ if (n && d instanceof z) {
1293
+ const m = yield createImageBitmap(d.getElement()), M = yield c.post(
1263
1294
  "toDataURL",
1264
1295
  {
1265
1296
  format: h,
1266
1297
  quality: 1,
1267
- bitmap: f
1298
+ bitmap: m
1268
1299
  },
1269
- [f]
1300
+ [m]
1270
1301
  ), j = {
1271
1302
  object: d,
1272
- image: u,
1303
+ image: M,
1273
1304
  format: h,
1274
1305
  contentType: a,
1275
1306
  fileName: s
@@ -1278,29 +1309,29 @@ class O {
1278
1309
  }
1279
1310
  const l = d.toCanvasElement({
1280
1311
  enableRetinaScaling: !1
1281
- }), g = yield new Promise((f, u) => {
1312
+ }), g = yield new Promise((m, M) => {
1282
1313
  l.toBlob((j) => {
1283
- j ? f(j) : u(new Error("Failed to create Blob from canvas"));
1314
+ j ? m(j) : M(new Error("Failed to create Blob from canvas"));
1284
1315
  });
1285
1316
  });
1286
1317
  if (o) {
1287
- const f = {
1318
+ const m = {
1288
1319
  object: d,
1289
1320
  image: g,
1290
1321
  format: h,
1291
1322
  contentType: a,
1292
1323
  fileName: s
1293
1324
  };
1294
- return i.fire("editor:object-exported", f), f;
1325
+ return i.fire("editor:object-exported", m), m;
1295
1326
  }
1296
- const M = new File([g], s, { type: a }), m = {
1327
+ const u = new File([g], s, { type: a }), f = {
1297
1328
  object: d,
1298
- image: M,
1329
+ image: u,
1299
1330
  format: h,
1300
1331
  contentType: a,
1301
1332
  fileName: s
1302
1333
  };
1303
- return i.fire("editor:object-exported", m), m;
1334
+ return i.fire("editor:object-exported", f), f;
1304
1335
  } catch (h) {
1305
1336
  return this.editor.errorManager.emitError({
1306
1337
  origin: "ImageManager",
@@ -1339,7 +1370,7 @@ class O {
1339
1370
  * @public
1340
1371
  */
1341
1372
  getContentType(e) {
1342
- return b(this, null, function* () {
1373
+ return y(this, null, function* () {
1343
1374
  return typeof e == "string" ? this.getContentTypeFromUrl(e) : e.type || "application/octet-stream";
1344
1375
  });
1345
1376
  }
@@ -1350,7 +1381,7 @@ class O {
1350
1381
  * @public
1351
1382
  */
1352
1383
  getContentTypeFromUrl(e) {
1353
- return b(this, null, function* () {
1384
+ return y(this, null, function* () {
1354
1385
  if (e.startsWith("data:")) {
1355
1386
  const t = e.match(/^data:([^;]+)/);
1356
1387
  return t ? t[1] : "application/octet-stream";
@@ -1429,7 +1460,7 @@ class O {
1429
1460
  return t ? t[1] : "";
1430
1461
  }
1431
1462
  }
1432
- const _ = (r, e, t) => Math.max(Math.min(r, t), e), be = (r, e) => r * e, rt = (r, e) => new V(r / 2, e / 2);
1463
+ const x = (r, e, t) => Math.max(Math.min(r, t), e), je = (r, e) => r * e, rt = (r, e) => new G(r / 2, e / 2);
1433
1464
  function ct(r) {
1434
1465
  return ((r == null ? void 0 : r.type) === "image" || (r == null ? void 0 : r.format) === "svg") && typeof (r == null ? void 0 : r.width) == "number" && typeof (r == null ? void 0 : r.height) == "number";
1435
1466
  }
@@ -1458,20 +1489,20 @@ class dt {
1458
1489
  * @fires editor:resolution-width-changed
1459
1490
  */
1460
1491
  setResolutionWidth(e, { preserveProportional: t, withoutSave: s, adaptCanvasToContainer: a } = {}) {
1461
- var m;
1492
+ var f;
1462
1493
  if (!e) return;
1463
1494
  const {
1464
1495
  canvas: n,
1465
1496
  montageArea: o,
1466
1497
  options: { canvasBackstoreWidth: i }
1467
- } = this.editor, { width: c, height: d } = o, h = _(Number(e), U, T);
1468
- if (!i || i === "auto" || a ? this.adaptCanvasToContainer() : i ? this.setCanvasBackstoreWidth(Number(i)) : this.setCanvasBackstoreWidth(h), o.set({ width: h }), (m = n.clipPath) == null || m.set({ width: h }), t) {
1469
- const f = h / c, u = be(d, f);
1470
- this.setResolutionHeight(u);
1498
+ } = this.editor, { width: c, height: d } = o, h = x(Number(e), R, w);
1499
+ if (!i || i === "auto" || a ? this.adaptCanvasToContainer() : i ? this.setCanvasBackstoreWidth(Number(i)) : this.setCanvasBackstoreWidth(h), o.set({ width: h }), (f = n.clipPath) == null || f.set({ width: h }), t) {
1500
+ const m = h / c, M = je(d, m);
1501
+ this.setResolutionHeight(M);
1471
1502
  return;
1472
1503
  }
1473
- const { left: l, top: g } = this.getObjectDefaultCoords(o), M = n.getZoom();
1474
- n.setViewportTransform([M, 0, 0, M, l, g]), this.centerMontageArea(), s || this.editor.historyManager.saveState(), n.fire("editor:resolution-width-changed", {
1504
+ const { left: l, top: g } = this.getObjectDefaultCoords(o), u = n.getZoom();
1505
+ n.setViewportTransform([u, 0, 0, u, l, g]), this.centerMontageArea(), s || this.editor.historyManager.saveState(), n.fire("editor:resolution-width-changed", {
1475
1506
  width: h,
1476
1507
  preserveProportional: t,
1477
1508
  withoutSave: s,
@@ -1488,20 +1519,20 @@ class dt {
1488
1519
  * @fires editor:resolution-height-changed
1489
1520
  */
1490
1521
  setResolutionHeight(e, { preserveProportional: t, withoutSave: s, adaptCanvasToContainer: a } = {}) {
1491
- var m;
1522
+ var f;
1492
1523
  if (!e) return;
1493
1524
  const {
1494
1525
  canvas: n,
1495
1526
  montageArea: o,
1496
1527
  options: { canvasBackstoreHeight: i }
1497
- } = this.editor, { width: c, height: d } = o, h = _(Number(e), H, w);
1498
- if (!i || i === "auto" || a ? this.adaptCanvasToContainer() : i ? this.setCanvasBackstoreHeight(Number(i)) : this.setCanvasBackstoreHeight(h), o.set({ height: h }), (m = n.clipPath) == null || m.set({ height: h }), t) {
1499
- const f = h / d, u = be(c, f);
1500
- this.setResolutionWidth(u);
1528
+ } = this.editor, { width: c, height: d } = o, h = x(Number(e), U, T);
1529
+ if (!i || i === "auto" || a ? this.adaptCanvasToContainer() : i ? this.setCanvasBackstoreHeight(Number(i)) : this.setCanvasBackstoreHeight(h), o.set({ height: h }), (f = n.clipPath) == null || f.set({ height: h }), t) {
1530
+ const m = h / d, M = je(c, m);
1531
+ this.setResolutionWidth(M);
1501
1532
  return;
1502
1533
  }
1503
- const { left: l, top: g } = this.getObjectDefaultCoords(o), M = n.getZoom();
1504
- n.setViewportTransform([M, 0, 0, M, l, g]), this.centerMontageArea(), s || this.editor.historyManager.saveState(), n.fire("editor:resolution-height-changed", {
1534
+ const { left: l, top: g } = this.getObjectDefaultCoords(o), u = n.getZoom();
1535
+ n.setViewportTransform([u, 0, 0, u, l, g]), this.centerMontageArea(), s || this.editor.historyManager.saveState(), n.fire("editor:resolution-height-changed", {
1505
1536
  height: h,
1506
1537
  preserveProportional: t,
1507
1538
  withoutSave: s,
@@ -1547,7 +1578,7 @@ class dt {
1547
1578
  */
1548
1579
  setCanvasBackstoreWidth(e) {
1549
1580
  if (!e || typeof e != "number") return;
1550
- const t = _(e, U, T);
1581
+ const t = x(e, R, w);
1551
1582
  this.editor.canvas.setDimensions({ width: t }, { backstoreOnly: !0 });
1552
1583
  }
1553
1584
  /**
@@ -1556,7 +1587,7 @@ class dt {
1556
1587
  */
1557
1588
  setCanvasBackstoreHeight(e) {
1558
1589
  if (!e || typeof e != "number") return;
1559
- const t = _(e, H, w);
1590
+ const t = x(e, U, T);
1560
1591
  this.editor.canvas.setDimensions({ height: t }, { backstoreOnly: !0 });
1561
1592
  }
1562
1593
  /**
@@ -1565,7 +1596,7 @@ class dt {
1565
1596
  * с учётом минимальных и максимальных значений.
1566
1597
  */
1567
1598
  adaptCanvasToContainer() {
1568
- const { canvas: e } = this.editor, t = this.getEditorContainer(), s = t.clientWidth, a = t.clientHeight, n = _(s, U, T), o = _(a, H, w);
1599
+ const { canvas: e } = this.editor, t = this.getEditorContainer(), s = t.clientWidth, a = t.clientHeight, n = x(s, R, w), o = x(a, U, T);
1569
1600
  e.setDimensions({ width: n, height: o }, { backstoreOnly: !0 });
1570
1601
  }
1571
1602
  /**
@@ -1599,7 +1630,7 @@ class dt {
1599
1630
  if (h.length === 1)
1600
1631
  e.setActiveObject(h[0]);
1601
1632
  else {
1602
- const l = new y(h, {
1633
+ const l = new v(h, {
1603
1634
  canvas: e
1604
1635
  });
1605
1636
  e.setActiveObject(l);
@@ -1767,18 +1798,18 @@ class dt {
1767
1798
  } = this.editor, d = e || a.getActiveObject();
1768
1799
  if (!ct(d)) return;
1769
1800
  const { width: h, height: l } = d;
1770
- let g = Math.min(h, T), M = Math.min(l, w);
1801
+ let g = Math.min(h, w), u = Math.min(l, T);
1771
1802
  if (t) {
1772
1803
  const {
1773
- width: m,
1774
- height: f
1775
- } = n, u = h / m, j = l / f, C = Math.max(u, j);
1776
- g = m * C, M = f * C;
1804
+ width: f,
1805
+ height: m
1806
+ } = n, M = h / f, j = l / m, b = Math.max(M, j);
1807
+ g = f * b, u = m * b;
1777
1808
  }
1778
- this.setResolutionWidth(g, { withoutSave: !0 }), this.setResolutionHeight(M, { withoutSave: !0 }), this.editor.backgroundManager.backgroundObject && this.editor.backgroundManager.refresh(), (h > i || l > c) && o.calculateAndApplyDefaultZoom(), o.resetObject({ object: d, withoutSave: !0 }), a.centerObject(d), a.renderAll(), s || this.editor.historyManager.saveState(), a.fire("editor:montage-area-scaled-to-image", {
1809
+ this.setResolutionWidth(g, { withoutSave: !0 }), this.setResolutionHeight(u, { withoutSave: !0 }), this.editor.backgroundManager.backgroundObject && this.editor.backgroundManager.refresh(), (h > i || l > c) && o.calculateAndApplyDefaultZoom(), o.resetObject({ object: d, withoutSave: !0 }), a.centerObject(d), a.renderAll(), s || this.editor.historyManager.saveState(), a.fire("editor:montage-area-scaled-to-image", {
1779
1810
  object: d,
1780
1811
  width: g,
1781
- height: M,
1812
+ height: u,
1782
1813
  preserveAspectRatio: t,
1783
1814
  withoutSave: s
1784
1815
  });
@@ -1850,9 +1881,9 @@ class lt {
1850
1881
  * Если передавать координаты курсора, то нужно быть аккуратнее, так как юзер может выйти за пределы рабочей области
1851
1882
  */
1852
1883
  zoom(e = ot, t = {}) {
1853
- var g, M;
1884
+ var g, u;
1854
1885
  if (!e) return;
1855
- const { minZoom: s, maxZoom: a } = this, { canvas: n } = this.editor, o = n.getZoom(), i = n.getCenterPoint(), c = (g = t.pointX) != null ? g : i.x, d = (M = t.pointY) != null ? M : i.y, h = new V(c, d);
1886
+ const { minZoom: s, maxZoom: a } = this, { canvas: n } = this.editor, o = n.getZoom(), i = n.getCenterPoint(), c = (g = t.pointX) != null ? g : i.x, d = (u = t.pointY) != null ? u : i.y, h = new G(c, d);
1856
1887
  let l = Number((o + Number(e)).toFixed(2));
1857
1888
  l > a && (l = a), l < s && (l = s), n.zoomToPoint(h, l), n.fire("editor:zoom-changed", {
1858
1889
  currentZoom: n.getZoom(),
@@ -1866,7 +1897,7 @@ class lt {
1866
1897
  * @fires editor:zoom-changed
1867
1898
  */
1868
1899
  setZoom(e = this.defaultZoom) {
1869
- const { minZoom: t, maxZoom: s } = this, { canvas: a } = this.editor, n = new V(a.getCenterPoint());
1900
+ const { minZoom: t, maxZoom: s } = this, { canvas: a } = this.editor, n = new G(a.getCenterPoint());
1870
1901
  let o = e;
1871
1902
  e > s && (o = s), e < t && (o = t), a.zoomToPoint(n, o), a.fire("editor:zoom-changed", {
1872
1903
  currentZoom: a.getZoom(),
@@ -1879,7 +1910,7 @@ class lt {
1879
1910
  * @fires editor:zoom-changed
1880
1911
  */
1881
1912
  resetZoom() {
1882
- const { canvas: e } = this.editor, t = new V(e.getCenterPoint());
1913
+ const { canvas: e } = this.editor, t = new G(e.getCenterPoint());
1883
1914
  e.zoomToPoint(t, this.defaultZoom), this.editor.canvas.fire("editor:zoom-changed", {
1884
1915
  currentZoom: e.getZoom(),
1885
1916
  point: t
@@ -1942,7 +1973,7 @@ class lt {
1942
1973
  withoutSave: s
1943
1974
  } = {}) {
1944
1975
  const { canvas: a, historyManager: n } = this.editor, o = e || a.getActiveObject();
1945
- o && (o instanceof y ? o.getObjects().forEach((i) => {
1976
+ o && (o instanceof v ? o.getObjects().forEach((i) => {
1946
1977
  i.set("opacity", t);
1947
1978
  }) : o.set("opacity", t), a.renderAll(), s || n.saveState(), a.fire("editor:object-opacity-changed", {
1948
1979
  object: o,
@@ -1969,12 +2000,12 @@ class lt {
1969
2000
  } = {}) {
1970
2001
  const { canvas: n, historyManager: o } = this.editor, i = e || n.getActiveObject();
1971
2002
  if (i) {
1972
- if (i instanceof y && !a) {
2003
+ if (i instanceof v && !a) {
1973
2004
  const c = i.getObjects();
1974
2005
  n.discardActiveObject(), c.forEach((h) => {
1975
2006
  this._fitSingleObject(h, t);
1976
2007
  });
1977
- const d = new y(c, { canvas: n });
2008
+ const d = new v(c, { canvas: n });
1978
2009
  n.setActiveObject(d);
1979
2010
  } else
1980
2011
  this._fitSingleObject(i, t);
@@ -1993,9 +2024,9 @@ class lt {
1993
2024
  * @private
1994
2025
  */
1995
2026
  _fitSingleObject(e, t) {
1996
- const { canvas: s, montageArea: a } = this.editor, { width: n, height: o, scaleX: i = 1, scaleY: c = 1, angle: d = 0 } = e, h = n * Math.abs(i), l = o * Math.abs(c), g = d * Math.PI / 180, M = Math.abs(Math.cos(g)), m = Math.abs(Math.sin(g)), f = h * M + l * m, u = h * m + l * M, j = a.width, C = a.height;
2027
+ const { canvas: s, montageArea: a } = this.editor, { width: n, height: o, scaleX: i = 1, scaleY: c = 1, angle: d = 0 } = e, h = n * Math.abs(i), l = o * Math.abs(c), g = d * Math.PI / 180, u = Math.abs(Math.cos(g)), f = Math.abs(Math.sin(g)), m = h * u + l * f, M = h * f + l * u, j = a.width, b = a.height;
1997
2028
  let S;
1998
- t === "contain" ? S = Math.min(j / f, C / u) : S = Math.max(j / f, C / u), e.set({
2029
+ t === "contain" ? S = Math.min(j / m, b / M) : S = Math.max(j / m, b / M), e.set({
1999
2030
  scaleX: i * S,
2000
2031
  scaleY: c * S
2001
2032
  }), s.centerObject(e);
@@ -2034,11 +2065,11 @@ class lt {
2034
2065
  }), t)
2035
2066
  this.fitObject({ object: d, withoutSave: !0, fitAsOneObject: !0 });
2036
2067
  else {
2037
- const { width: l, height: g } = n, { width: M, height: m } = d, f = o.calculateScaleFactor({
2068
+ const { width: l, height: g } = n, { width: u, height: f } = d, m = o.calculateScaleFactor({
2038
2069
  imageObject: d,
2039
2070
  scaleType: c
2040
2071
  });
2041
- c === "contain" && f < 1 || c === "cover" && (M > l || m > g) ? this.fitObject({ object: d, withoutSave: !0, fitAsOneObject: !0 }) : d.set({ scaleX: 1, scaleY: 1 });
2072
+ c === "contain" && m < 1 || c === "cover" && (u > l || f > g) ? this.fitObject({ object: d, withoutSave: !0, fitAsOneObject: !0 }) : d.set({ scaleX: 1, scaleY: 1 });
2042
2073
  }
2043
2074
  d.set({ flipX: !1, flipY: !1, angle: 0 }), a.centerObject(d), a.renderAll(), i.resumeHistory(), s || i.saveState(), a.fire("editor:object-reset", {
2044
2075
  object: d,
@@ -2104,7 +2135,7 @@ class ht {
2104
2135
  }), e.upperCanvasEl.style.pointerEvents = "", e.lowerCanvasEl.style.pointerEvents = "", this.overlayMask.visible = !1, e.requestRenderAll(), e.fire("editor:enabled"), s.resumeHistory();
2105
2136
  }
2106
2137
  }
2107
- class R {
2138
+ class _ {
2108
2139
  constructor({ editor: e }) {
2109
2140
  this.editor = e, this.backgroundObject = null;
2110
2141
  }
@@ -2125,10 +2156,10 @@ class R {
2125
2156
  s.resumeHistory();
2126
2157
  return;
2127
2158
  }
2128
- a.set({ fill: e }), a.set("backgroundId", `background-${v()}`), this.editor.canvas.requestRenderAll();
2159
+ a.set({ fill: e }), a.set("backgroundId", `background-${A()}`), this.editor.canvas.requestRenderAll();
2129
2160
  } else
2130
2161
  this._removeCurrentBackground(), this._createColorBackground(e);
2131
- this.editor.canvas.fire("background:changed", { type: "color", color: e }), s.resumeHistory(), t || s.saveState();
2162
+ this.editor.canvas.fire("editor:background:changed", { type: "color", color: e }), s.resumeHistory(), t || s.saveState();
2132
2163
  } catch (s) {
2133
2164
  this.editor.errorManager.emitError({
2134
2165
  code: "BACKGROUND_CREATION_FAILED",
@@ -2152,15 +2183,15 @@ class R {
2152
2183
  try {
2153
2184
  const { historyManager: s } = this.editor, { backgroundObject: a } = this;
2154
2185
  if (s.suspendHistory(), a && a.backgroundType === "gradient") {
2155
- const n = R._createFabricGradient(e);
2156
- if (R._isGradientEqual(a.fill, n)) {
2186
+ const n = _._createFabricGradient(e);
2187
+ if (_._isGradientEqual(a.fill, n)) {
2157
2188
  s.resumeHistory();
2158
2189
  return;
2159
2190
  }
2160
- a.set({ fill: n }), a.set("backgroundId", `background-${v()}`), this.editor.canvas.requestRenderAll();
2191
+ a.set({ fill: n }), a.set("backgroundId", `background-${A()}`), this.editor.canvas.requestRenderAll();
2161
2192
  } else
2162
2193
  this._removeCurrentBackground(), this._createGradientBackground(e);
2163
- this.editor.canvas.fire("background:changed", {
2194
+ this.editor.canvas.fire("editor:background:changed", {
2164
2195
  type: "gradient",
2165
2196
  gradientParams: e
2166
2197
  }), s.resumeHistory(), t || s.saveState();
@@ -2174,6 +2205,58 @@ class R {
2174
2205
  });
2175
2206
  }
2176
2207
  }
2208
+ /**
2209
+ * Устанавливает линейный градиентный фон.
2210
+ * @param options - Опции для установки линейного градиента
2211
+ */
2212
+ setLinearGradientBackground({
2213
+ angle: e,
2214
+ startColor: t,
2215
+ endColor: s,
2216
+ startPosition: a,
2217
+ endPosition: n,
2218
+ withoutSave: o = !1
2219
+ }) {
2220
+ this.setGradientBackground({
2221
+ gradient: {
2222
+ type: "linear",
2223
+ angle: e,
2224
+ startColor: t,
2225
+ endColor: s,
2226
+ startPosition: a,
2227
+ endPosition: n
2228
+ },
2229
+ withoutSave: o
2230
+ });
2231
+ }
2232
+ /**
2233
+ * Устанавливает радиальный градиентный фон.
2234
+ * @param options - Опции для установки радиального градиента
2235
+ */
2236
+ setRadialGradientBackground({
2237
+ centerX: e,
2238
+ centerY: t,
2239
+ radius: s,
2240
+ startColor: a,
2241
+ endColor: n,
2242
+ startPosition: o,
2243
+ endPosition: i,
2244
+ withoutSave: c = !1
2245
+ }) {
2246
+ this.setGradientBackground({
2247
+ gradient: {
2248
+ type: "radial",
2249
+ centerX: e,
2250
+ centerY: t,
2251
+ radius: s,
2252
+ startColor: a,
2253
+ endColor: n,
2254
+ startPosition: o,
2255
+ endPosition: i
2256
+ },
2257
+ withoutSave: c
2258
+ });
2259
+ }
2177
2260
  /**
2178
2261
  * Устанавливает фон из изображения.
2179
2262
  * @param options - Опции для установки фонового изображения
@@ -2181,13 +2264,17 @@ class R {
2181
2264
  * @param options.withoutSave - Если true, не сохранять состояние в историю
2182
2265
  */
2183
2266
  setImageBackground(s) {
2184
- return b(this, arguments, function* ({
2185
- imageUrl: e,
2267
+ return y(this, arguments, function* ({
2268
+ imageSource: e,
2186
2269
  withoutSave: t = !1
2187
2270
  }) {
2188
2271
  try {
2189
2272
  const { historyManager: a } = this.editor;
2190
- a.suspendHistory(), this._removeCurrentBackground(), yield this._createImageBackground(e), this.editor.canvas.fire("background:changed", { type: "image", imageUrl: e }), a.resumeHistory(), t || a.saveState();
2273
+ a.suspendHistory(), yield this._createImageBackground(e), this.editor.canvas.fire("editor:background:changed", {
2274
+ type: "image",
2275
+ imageSource: e,
2276
+ backgroundObject: this.backgroundObject
2277
+ }), a.resumeHistory(), t || a.saveState();
2191
2278
  } catch (a) {
2192
2279
  this.editor.errorManager.emitError({
2193
2280
  code: "BACKGROUND_CREATION_FAILED",
@@ -2207,16 +2294,8 @@ class R {
2207
2294
  removeBackground({ withoutSave: e = !1 } = {}) {
2208
2295
  try {
2209
2296
  const { historyManager: t } = this.editor;
2210
- if (!this.backgroundObject) {
2211
- this.editor.errorManager.emitWarning({
2212
- code: "NO_BACKGROUND_TO_REMOVE",
2213
- origin: "BackgroundManager",
2214
- method: "removeBackground",
2215
- message: "Нет фона для удаления"
2216
- });
2217
- return;
2218
- }
2219
- t.suspendHistory(), this._removeCurrentBackground(), this.editor.canvas.fire("background:removed"), t.resumeHistory(), e || t.saveState();
2297
+ if (!this.backgroundObject) return;
2298
+ t.suspendHistory(), this._removeCurrentBackground(), this.editor.canvas.fire("editor:background:removed"), t.resumeHistory(), e || t.saveState();
2220
2299
  } catch (t) {
2221
2300
  this.editor.errorManager.emitError({
2222
2301
  code: "BACKGROUND_REMOVAL_FAILED",
@@ -2233,11 +2312,9 @@ class R {
2233
2312
  refresh() {
2234
2313
  const { canvas: e, montageArea: t, historyManager: s } = this.editor;
2235
2314
  if (!t || !this.backgroundObject) return;
2236
- s.suspendHistory(), t.setCoords();
2237
- const { left: a, top: n, width: o, height: i } = t.getBoundingRect();
2238
- this.backgroundObject.set({ left: a, top: n, width: o, height: i });
2239
- const c = e.getObjects(), d = c.indexOf(t), h = c.indexOf(this.backgroundObject);
2240
- this.backgroundObject && h !== d + 1 && e.moveObjectTo(this.backgroundObject, d + 1), e.requestRenderAll(), s.resumeHistory();
2315
+ s.suspendHistory(), this.editor.transformManager.fitObject({ object: this.backgroundObject, withoutSave: !0, type: "cover" });
2316
+ const a = e.getObjects(), n = a.indexOf(t), o = a.indexOf(this.backgroundObject);
2317
+ this.backgroundObject && o !== n + 1 && e.moveObjectTo(this.backgroundObject, n + 1), e.requestRenderAll(), s.resumeHistory();
2241
2318
  }
2242
2319
  /**
2243
2320
  * Создает цветовой фон.
@@ -2252,8 +2329,8 @@ class R {
2252
2329
  hasControls: !1,
2253
2330
  id: "background",
2254
2331
  backgroundType: "color",
2255
- backgroundId: `background-${v()}`
2256
- }, { withoutSelection: !0 }), this._setupBackgroundPosition();
2332
+ backgroundId: `background-${A()}`
2333
+ }, { withoutSelection: !0 }), this.refresh();
2257
2334
  }
2258
2335
  /**
2259
2336
  * Создает градиентный фон.
@@ -2269,44 +2346,38 @@ class R {
2269
2346
  hasControls: !1,
2270
2347
  id: "background",
2271
2348
  backgroundType: "gradient",
2272
- backgroundId: `background-${v()}`
2273
- }, { withoutSelection: !0 }), this._setupBackgroundPosition();
2274
- const t = R._createFabricGradient(e);
2349
+ backgroundId: `background-${A()}`
2350
+ }, { withoutSelection: !0 }), this.refresh();
2351
+ const t = _._createFabricGradient(e);
2275
2352
  this.backgroundObject.set("fill", t), this.editor.canvas.requestRenderAll();
2276
2353
  }
2277
2354
  /**
2278
2355
  * Создает фон из изображения.
2279
- * @param imageUrl - URL изображения
2356
+ * @param source - источник изображения (URL или File)
2280
2357
  */
2281
2358
  _createImageBackground(e) {
2282
- return b(this, null, function* () {
2283
- return new Promise((t, s) => {
2284
- x.fromURL(e, {
2285
- crossOrigin: "anonymous"
2286
- }).then((a) => {
2287
- if (!a) {
2288
- s(new Error("Не удалось загрузить изображение"));
2289
- return;
2290
- }
2291
- a.set({
2292
- selectable: !1,
2293
- evented: !1,
2294
- hasBorders: !1,
2295
- hasControls: !1,
2296
- id: "background",
2297
- backgroundType: "image",
2298
- backgroundId: `background-${v()}`
2299
- }), this.editor.canvas.add(a), this.backgroundObject = a, this._setupBackgroundPosition(), t();
2300
- }).catch(s);
2301
- });
2359
+ return y(this, null, function* () {
2360
+ var s;
2361
+ const { image: t } = (s = yield this.editor.imageManager.importImage({
2362
+ source: e,
2363
+ withoutSave: !0,
2364
+ isBackground: !0,
2365
+ withoutSelection: !0,
2366
+ scale: "image-cover"
2367
+ })) != null ? s : {};
2368
+ if (!t)
2369
+ throw new Error("Не удалось загрузить изображение");
2370
+ t.set({
2371
+ selectable: !1,
2372
+ evented: !1,
2373
+ hasBorders: !1,
2374
+ hasControls: !1,
2375
+ id: "background",
2376
+ backgroundType: "image",
2377
+ backgroundId: `background-${A()}`
2378
+ }), this._removeCurrentBackground(), this.backgroundObject = t, this.refresh();
2302
2379
  });
2303
2380
  }
2304
- /**
2305
- * Настраивает позицию и размеры фона.
2306
- */
2307
- _setupBackgroundPosition() {
2308
- this.backgroundObject && this.refresh();
2309
- }
2310
2381
  /**
2311
2382
  * Удаляет текущий фон.
2312
2383
  */
@@ -2319,20 +2390,40 @@ class R {
2319
2390
  */
2320
2391
  static _createFabricGradient(e) {
2321
2392
  const {
2322
- angle: t,
2323
- startColor: s,
2324
- endColor: a,
2325
- startPosition: n = 0,
2326
- endPosition: o = 100
2327
- } = e, i = t * Math.PI / 180, c = R._angleToCoords(i), d = [
2328
- { offset: n / 100, color: s },
2329
- { offset: o / 100, color: a }
2393
+ startColor: t,
2394
+ endColor: s,
2395
+ startPosition: a = 0,
2396
+ endPosition: n = 100
2397
+ } = e, o = [
2398
+ { offset: a / 100, color: t },
2399
+ { offset: n / 100, color: s }
2330
2400
  ];
2331
- return new De({
2332
- type: "linear",
2401
+ if (e.type === "linear") {
2402
+ const l = e.angle * Math.PI / 180, g = _._angleToCoords(l);
2403
+ return new Me({
2404
+ type: "linear",
2405
+ gradientUnits: "percentage",
2406
+ coords: g,
2407
+ colorStops: o
2408
+ });
2409
+ }
2410
+ const {
2411
+ centerX: i = 50,
2412
+ centerY: c = 50,
2413
+ radius: d = 50
2414
+ } = e, h = {
2415
+ x1: i / 100,
2416
+ y1: c / 100,
2417
+ x2: i / 100,
2418
+ y2: c / 100,
2419
+ r1: 0,
2420
+ r2: d / 100
2421
+ };
2422
+ return new Me({
2423
+ type: "radial",
2333
2424
  gradientUnits: "percentage",
2334
- coords: c,
2335
- colorStops: d
2425
+ coords: h,
2426
+ colorStops: o
2336
2427
  });
2337
2428
  }
2338
2429
  /**
@@ -2355,15 +2446,15 @@ class R {
2355
2446
  * @returns true если градиенты одинаковые
2356
2447
  */
2357
2448
  static _isGradientEqual(e, t) {
2358
- if (!e || !t || e.type !== "linear" || t.type !== "linear" || !(Math.abs(e.coords.x1 - t.coords.x1) < 1e-4 && Math.abs(e.coords.y1 - t.coords.y1) < 1e-4 && Math.abs(e.coords.x2 - t.coords.x2) < 1e-4 && Math.abs(e.coords.y2 - t.coords.y2) < 1e-4)) return !1;
2359
- const a = e.colorStops || [], n = t.colorStops || [];
2360
- return a.length !== n.length ? !1 : a.every((o, i) => {
2361
- const c = n[i];
2449
+ if (!e || !t || e.type !== t.type) return !1;
2450
+ const s = e.colorStops || [], a = t.colorStops || [];
2451
+ return s.length !== a.length || !s.every((o, i) => {
2452
+ const c = a[i];
2362
2453
  return o.color === c.color && Math.abs(o.offset - c.offset) < 1e-4;
2363
- });
2454
+ }) ? !1 : e.type === "linear" && t.type === "linear" ? Math.abs(e.coords.x1 - t.coords.x1) < 1e-4 && Math.abs(e.coords.y1 - t.coords.y1) < 1e-4 && Math.abs(e.coords.x2 - t.coords.x2) < 1e-4 && Math.abs(e.coords.y2 - t.coords.y2) < 1e-4 : e.type === "radial" && t.type === "radial" ? Math.abs(e.coords.x1 - t.coords.x1) < 1e-4 && Math.abs(e.coords.y1 - t.coords.y1) < 1e-4 && Math.abs(e.coords.x2 - t.coords.x2) < 1e-4 && Math.abs(e.coords.y2 - t.coords.y2) < 1e-4 && Math.abs(e.coords.r1 - t.coords.r1) < 1e-4 && Math.abs(e.coords.r2 - t.coords.r2) < 1e-4 : !1;
2364
2455
  }
2365
2456
  }
2366
- class X {
2457
+ class Q {
2367
2458
  constructor({ editor: e }) {
2368
2459
  this.editor = e;
2369
2460
  }
@@ -2378,7 +2469,7 @@ class X {
2378
2469
  const { canvas: s, historyManager: a } = this.editor;
2379
2470
  a.suspendHistory();
2380
2471
  const n = e || s.getActiveObject();
2381
- n && (n instanceof y ? n.getObjects().forEach((o) => {
2472
+ n && (n instanceof v ? n.getObjects().forEach((o) => {
2382
2473
  s.bringObjectToFront(o);
2383
2474
  }) : s.bringObjectToFront(n), s.renderAll(), a.resumeHistory(), t || a.saveState(), s.fire("editor:object-bring-to-front", {
2384
2475
  object: n,
@@ -2396,7 +2487,7 @@ class X {
2396
2487
  const { canvas: s, historyManager: a } = this.editor;
2397
2488
  a.suspendHistory();
2398
2489
  const n = e || s.getActiveObject();
2399
- n && (n instanceof y ? X._moveSelectionForward(s, n) : s.bringObjectForward(n), s.renderAll(), a.resumeHistory(), t || a.saveState(), s.fire("editor:object-bring-forward", {
2490
+ n && (n instanceof v ? Q._moveSelectionForward(s, n) : s.bringObjectForward(n), s.renderAll(), a.resumeHistory(), t || a.saveState(), s.fire("editor:object-bring-forward", {
2400
2491
  object: n,
2401
2492
  withoutSave: t
2402
2493
  }));
@@ -2419,7 +2510,7 @@ class X {
2419
2510
  n.suspendHistory();
2420
2511
  const c = e || s.getActiveObject();
2421
2512
  if (c) {
2422
- if (c instanceof y) {
2513
+ if (c instanceof v) {
2423
2514
  const d = c.getObjects();
2424
2515
  for (let h = d.length - 1; h >= 0; h -= 1)
2425
2516
  s.sendObjectToBack(d[h]);
@@ -2447,7 +2538,7 @@ class X {
2447
2538
  } = this.editor;
2448
2539
  n.suspendHistory();
2449
2540
  const c = e || s.getActiveObject();
2450
- c && (c instanceof y ? X._moveSelectionBackwards(s, c) : s.sendObjectBackwards(c), i && s.sendObjectToBack(i), s.sendObjectToBack(a), o && s.sendObjectToBack(o), s.renderAll(), n.resumeHistory(), t || n.saveState(), s.fire("editor:object-send-backwards", {
2541
+ c && (c instanceof v ? Q._moveSelectionBackwards(s, c) : s.sendObjectBackwards(c), i && s.sendObjectToBack(i), s.sendObjectToBack(a), o && s.sendObjectToBack(o), s.renderAll(), n.resumeHistory(), t || n.saveState(), s.fire("editor:object-send-backwards", {
2451
2542
  object: c,
2452
2543
  withoutSave: t
2453
2544
  }));
@@ -2517,13 +2608,13 @@ class gt {
2517
2608
  */
2518
2609
  addRectangle(h = {}, { withoutSelection: c, withoutAdding: d } = {}) {
2519
2610
  var l = h, {
2520
- id: e = `rect-${v()}`,
2611
+ id: e = `rect-${A()}`,
2521
2612
  left: t,
2522
2613
  top: s,
2523
2614
  width: a = 100,
2524
2615
  height: n = 100,
2525
2616
  fill: o = "blue"
2526
- } = l, i = W(l, [
2617
+ } = l, i = F(l, [
2527
2618
  "id",
2528
2619
  "left",
2529
2620
  "top",
@@ -2531,7 +2622,7 @@ class gt {
2531
2622
  "height",
2532
2623
  "fill"
2533
2624
  ]);
2534
- const { canvas: g } = this.editor, M = new Ne(p({
2625
+ const { canvas: g } = this.editor, u = new Ne(I({
2535
2626
  id: e,
2536
2627
  left: t,
2537
2628
  top: s,
@@ -2539,7 +2630,7 @@ class gt {
2539
2630
  height: n,
2540
2631
  fill: o
2541
2632
  }, i));
2542
- return !t && !s && g.centerObject(M), d || (g.add(M), c || g.setActiveObject(M), g.renderAll()), M;
2633
+ return !t && !s && g.centerObject(u), d || (g.add(u), c || g.setActiveObject(u), g.renderAll()), u;
2543
2634
  }
2544
2635
  /**
2545
2636
  * Добавление круга
@@ -2559,19 +2650,19 @@ class gt {
2559
2650
  */
2560
2651
  addCircle(d = {}, { withoutSelection: i, withoutAdding: c } = {}) {
2561
2652
  var h = d, {
2562
- id: e = `circle-${v()}`,
2653
+ id: e = `circle-${A()}`,
2563
2654
  left: t,
2564
2655
  top: s,
2565
2656
  radius: a = 50,
2566
2657
  fill: n = "green"
2567
- } = h, o = W(h, [
2658
+ } = h, o = F(h, [
2568
2659
  "id",
2569
2660
  "left",
2570
2661
  "top",
2571
2662
  "radius",
2572
2663
  "fill"
2573
2664
  ]);
2574
- const { canvas: l } = this.editor, g = new Oe(p({
2665
+ const { canvas: l } = this.editor, g = new Oe(I({
2575
2666
  id: e,
2576
2667
  left: t,
2577
2668
  top: s,
@@ -2599,13 +2690,13 @@ class gt {
2599
2690
  */
2600
2691
  addTriangle(h = {}, { withoutSelection: c, withoutAdding: d } = {}) {
2601
2692
  var l = h, {
2602
- id: e = `triangle-${v()}`,
2693
+ id: e = `triangle-${A()}`,
2603
2694
  left: t,
2604
2695
  top: s,
2605
2696
  width: a = 100,
2606
2697
  height: n = 100,
2607
2698
  fill: o = "yellow"
2608
- } = l, i = W(l, [
2699
+ } = l, i = F(l, [
2609
2700
  "id",
2610
2701
  "left",
2611
2702
  "top",
@@ -2613,7 +2704,7 @@ class gt {
2613
2704
  "height",
2614
2705
  "fill"
2615
2706
  ]);
2616
- const { canvas: g } = this.editor, M = new Le(p({
2707
+ const { canvas: g } = this.editor, u = new Le(I({
2617
2708
  id: e,
2618
2709
  left: t,
2619
2710
  top: s,
@@ -2621,7 +2712,7 @@ class gt {
2621
2712
  width: a,
2622
2713
  height: n
2623
2714
  }, i));
2624
- return !t && !s && g.centerObject(M), d || (g.add(M), c || g.setActiveObject(M), g.renderAll()), M;
2715
+ return !t && !s && g.centerObject(u), d || (g.add(u), c || g.setActiveObject(u), g.renderAll()), u;
2625
2716
  }
2626
2717
  }
2627
2718
  class ut {
@@ -2652,7 +2743,7 @@ class ut {
2652
2743
  * Асинхронное клонирование для внутреннего буфера
2653
2744
  */
2654
2745
  _cloneToInternalClipboard(e) {
2655
- return b(this, null, function* () {
2746
+ return y(this, null, function* () {
2656
2747
  const { canvas: t, errorManager: s } = this.editor;
2657
2748
  try {
2658
2749
  const a = yield e.clone(["format"]);
@@ -2672,7 +2763,7 @@ class ut {
2672
2763
  * Копирование в системный буфер обмена
2673
2764
  */
2674
2765
  _copyToSystemClipboard(e) {
2675
- return b(this, null, function* () {
2766
+ return y(this, null, function* () {
2676
2767
  const { errorManager: t } = this.editor;
2677
2768
  if (typeof ClipboardItem == "undefined" || !navigator.clipboard)
2678
2769
  return t.emitWarning({
@@ -2699,7 +2790,7 @@ class ut {
2699
2790
  * Копирование изображения в буфер обмена
2700
2791
  */
2701
2792
  _copyImageToClipboard(e, t) {
2702
- return b(this, null, function* () {
2793
+ return y(this, null, function* () {
2703
2794
  try {
2704
2795
  const a = e.toCanvasElement({ enableRetinaScaling: !1 }).toDataURL(), n = a.slice(5).split(";")[0], o = a.split(",")[1], i = atob(o), c = new Uint8Array(i.length);
2705
2796
  for (let l = 0; l < i.length; l += 1)
@@ -2721,9 +2812,9 @@ class ut {
2721
2812
  * Копирование текста в буфер обмена
2722
2813
  */
2723
2814
  _copyTextToClipboard(e) {
2724
- return b(this, null, function* () {
2815
+ return y(this, null, function* () {
2725
2816
  try {
2726
- const t = `${me}${e}`;
2817
+ const t = `${be}${e}`;
2727
2818
  return yield navigator.clipboard.writeText(t), console.info("Text copied to clipboard successfully"), !0;
2728
2819
  } catch (t) {
2729
2820
  const { errorManager: s } = this.editor;
@@ -2743,7 +2834,7 @@ class ut {
2743
2834
  */
2744
2835
  _addClonedObjectToCanvas(e) {
2745
2836
  const { canvas: t, historyManager: s } = this.editor;
2746
- if (t.discardActiveObject(), e instanceof y) {
2837
+ if (t.discardActiveObject(), e instanceof v) {
2747
2838
  s.suspendHistory(), e.canvas = t, e.forEachObject((a) => {
2748
2839
  t.add(a);
2749
2840
  }), t.setActiveObject(e), t.requestRenderAll(), s.resumeHistory(), s.saveState();
@@ -2756,7 +2847,7 @@ class ut {
2756
2847
  * @param source - источник изображения (data URL или URL)
2757
2848
  */
2758
2849
  _handleImageImport(e) {
2759
- return b(this, null, function* () {
2850
+ return y(this, null, function* () {
2760
2851
  var s;
2761
2852
  const { image: t } = (s = yield this.editor.imageManager.importImage({
2762
2853
  source: e,
@@ -2772,13 +2863,13 @@ class ut {
2772
2863
  * @fires editor:object-pasted
2773
2864
  */
2774
2865
  copyPaste(e) {
2775
- return b(this, null, function* () {
2866
+ return y(this, null, function* () {
2776
2867
  const { canvas: t } = this.editor, s = e || t.getActiveObject();
2777
2868
  if (!s || s.locked) return !1;
2778
2869
  try {
2779
2870
  const a = yield s.clone(["format"]);
2780
2871
  return a.set({
2781
- id: `${a.type}-${v()}`,
2872
+ id: `${a.type}-${A()}`,
2782
2873
  left: a.left + 10,
2783
2874
  top: a.top + 10,
2784
2875
  evented: !0
@@ -2802,14 +2893,14 @@ class ut {
2802
2893
  * @param event.clipboardData.items — элементы буфера обмена
2803
2894
  */
2804
2895
  handlePasteEvent(t) {
2805
- return b(this, arguments, function* ({ clipboardData: e }) {
2896
+ return y(this, arguments, function* ({ clipboardData: e }) {
2806
2897
  var c;
2807
2898
  if (!((c = e == null ? void 0 : e.items) != null && c.length)) {
2808
2899
  this.paste();
2809
2900
  return;
2810
2901
  }
2811
2902
  const s = e.getData("text/plain");
2812
- if (s && s.startsWith(me)) {
2903
+ if (s && s.startsWith(be)) {
2813
2904
  this.paste();
2814
2905
  return;
2815
2906
  }
@@ -2853,13 +2944,13 @@ class ut {
2853
2944
  * @fires editor:object-pasted
2854
2945
  */
2855
2946
  paste() {
2856
- return b(this, null, function* () {
2947
+ return y(this, null, function* () {
2857
2948
  const { canvas: e } = this.editor;
2858
2949
  if (!this.clipboard) return !1;
2859
2950
  try {
2860
2951
  const t = yield this.clipboard.clone(["format"]);
2861
2952
  return e.discardActiveObject(), t.set({
2862
- id: `${t.type}-${v()}`,
2953
+ id: `${t.type}-${A()}`,
2863
2954
  left: t.left + 10,
2864
2955
  top: t.top + 10,
2865
2956
  evented: !0
@@ -2877,7 +2968,7 @@ class ut {
2877
2968
  });
2878
2969
  }
2879
2970
  }
2880
- class Q {
2971
+ class K {
2881
2972
  constructor({ editor: e }) {
2882
2973
  this.editor = e;
2883
2974
  }
@@ -2902,7 +2993,7 @@ class Q {
2902
2993
  lockSkewingY: !0,
2903
2994
  locked: !0
2904
2995
  };
2905
- o.set(i), !t && Q._isGroupOrSelection(o) && o.getObjects().forEach((d) => {
2996
+ o.set(i), !t && K._isGroupOrSelection(o) && o.getObjects().forEach((d) => {
2906
2997
  d.set(i);
2907
2998
  }), a.renderAll(), s || n.saveState(), a.fire("editor:object-locked", {
2908
2999
  object: o,
@@ -2930,7 +3021,7 @@ class Q {
2930
3021
  lockSkewingY: !1,
2931
3022
  locked: !1
2932
3023
  };
2933
- n.set(o), Q._isGroupOrSelection(n) && n.getObjects().forEach((i) => {
3024
+ n.set(o), K._isGroupOrSelection(n) && n.getObjects().forEach((i) => {
2934
3025
  i.set(o);
2935
3026
  }), s.renderAll(), t || a.saveState(), s.fire("editor:object-unlocked", {
2936
3027
  object: n,
@@ -2938,7 +3029,7 @@ class Q {
2938
3029
  });
2939
3030
  }
2940
3031
  static _isGroupOrSelection(e) {
2941
- return e instanceof y || e instanceof J;
3032
+ return e instanceof v || e instanceof q;
2942
3033
  }
2943
3034
  }
2944
3035
  class Mt {
@@ -2959,9 +3050,9 @@ class Mt {
2959
3050
  const { canvas: s, historyManager: a } = this.editor;
2960
3051
  a.suspendHistory();
2961
3052
  const n = e || s.getActiveObject();
2962
- if (!n || !(n instanceof y)) return;
2963
- const o = n.getObjects(), i = new J(o);
2964
- o.forEach((c) => s.remove(c)), i.set("id", `${i.type}-${v()}`), s.add(i), s.setActiveObject(i), s.renderAll(), a.resumeHistory(), t || a.saveState(), s.fire("editor:objects-grouped", {
3053
+ if (!n || !(n instanceof v)) return;
3054
+ const o = n.getObjects(), i = new q(o);
3055
+ o.forEach((c) => s.remove(c)), i.set("id", `${i.type}-${A()}`), s.add(i), s.setActiveObject(i), s.renderAll(), a.resumeHistory(), t || a.saveState(), s.fire("editor:objects-grouped", {
2965
3056
  object: n,
2966
3057
  group: i,
2967
3058
  withoutSave: t
@@ -2981,10 +3072,10 @@ class Mt {
2981
3072
  const { canvas: s, historyManager: a } = this.editor;
2982
3073
  a.suspendHistory();
2983
3074
  const n = e || s.getActiveObject();
2984
- if (!(n instanceof J)) return;
3075
+ if (!(n instanceof q)) return;
2985
3076
  const o = n.removeAll();
2986
3077
  s.remove(n), o.forEach((c) => s.add(c));
2987
- const i = new y(o, {
3078
+ const i = new v(o, {
2988
3079
  canvas: s
2989
3080
  });
2990
3081
  s.setActiveObject(i), s.renderAll(), a.resumeHistory(), t || a.saveState(), s.fire("editor:objects-ungrouped", {
@@ -3005,7 +3096,7 @@ class ft {
3005
3096
  selectAll() {
3006
3097
  const { canvas: e, canvasManager: t, objectLockManager: s } = this.editor;
3007
3098
  e.discardActiveObject();
3008
- const a = t.getObjects(), n = a.some((i) => i.locked), o = a.length > 1 ? new y(t.getObjects(), { canvas: e }) : a[0];
3099
+ const a = t.getObjects(), n = a.some((i) => i.locked), o = a.length > 1 ? new v(t.getObjects(), { canvas: e }) : a[0];
3009
3100
  n && s.lockObject({ object: o, skipInnerObjects: !0, withoutSave: !0 }), e.setActiveObject(o), e.requestRenderAll(), e.fire("editor:all-objects-selected", { selected: o });
3010
3101
  }
3011
3102
  }
@@ -3136,7 +3227,7 @@ const bt = {
3136
3227
  INVALID_GRADIENT_FORMAT: "INVALID_GRADIENT_FORMAT"
3137
3228
  }
3138
3229
  };
3139
- class K {
3230
+ class $ {
3140
3231
  constructor({ editor: e }) {
3141
3232
  this._buffer = [], this.editor = e;
3142
3233
  }
@@ -3163,7 +3254,7 @@ class K {
3163
3254
  * @fires editor:error
3164
3255
  */
3165
3256
  emitError({ origin: e = "ImageEditor", method: t = "Unknown Method", code: s, data: a, message: n }) {
3166
- if (!K.isValidErrorCode(s)) {
3257
+ if (!$.isValidErrorCode(s)) {
3167
3258
  console.warn("Неизвестный код ошибки: ", { code: s, origin: e, method: t });
3168
3259
  return;
3169
3260
  }
@@ -3177,7 +3268,7 @@ class K {
3177
3268
  message: o,
3178
3269
  data: a
3179
3270
  };
3180
- this._buffer.push(p({
3271
+ this._buffer.push(I({
3181
3272
  type: "editor:error"
3182
3273
  }, i)), this.editor.canvas.fire("editor:error", i);
3183
3274
  }
@@ -3192,7 +3283,7 @@ class K {
3192
3283
  * @fires editor:warning
3193
3284
  */
3194
3285
  emitWarning({ origin: e = "ImageEditor", method: t = "Unknown Method", code: s, message: a, data: n }) {
3195
- if (!K.isValidErrorCode(s)) {
3286
+ if (!$.isValidErrorCode(s)) {
3196
3287
  console.warn("Неизвестный код предупреждения: ", { code: s, origin: e, method: t });
3197
3288
  return;
3198
3289
  }
@@ -3205,7 +3296,7 @@ class K {
3205
3296
  message: o,
3206
3297
  data: n
3207
3298
  };
3208
- this._buffer.push(p({
3299
+ this._buffer.push(I({
3209
3300
  type: "editor:warning"
3210
3301
  }, i)), this.editor.canvas.fire("editor:warning", i);
3211
3302
  }
@@ -3218,14 +3309,14 @@ class K {
3218
3309
  return e ? Object.values(bt).some((t) => Object.values(t).includes(e)) : !1;
3219
3310
  }
3220
3311
  }
3221
- class ie {
3312
+ class re {
3222
3313
  /**
3223
3314
  * Конструктор класса ImageEditor.
3224
3315
  * @param canvasId - идентификатор канваса, в котором будет создан редактор
3225
3316
  * @param options - опции и настройки редактора
3226
3317
  */
3227
3318
  constructor(e, t) {
3228
- this.options = t, this.containerId = e, this.editorId = `${e}-${v()}`, this.clipboard = null, this.init();
3319
+ this.options = t, this.containerId = e, this.editorId = `${e}-${A()}`, this.clipboard = null, this.init();
3229
3320
  }
3230
3321
  /**
3231
3322
  * Инициализация редактора.
@@ -3233,7 +3324,7 @@ class ie {
3233
3324
  * @fires editor:ready
3234
3325
  */
3235
3326
  init() {
3236
- return b(this, null, function* () {
3327
+ return y(this, null, function* () {
3237
3328
  const {
3238
3329
  editorContainerWidth: e,
3239
3330
  editorContainerHeight: t,
@@ -3246,13 +3337,13 @@ class ie {
3246
3337
  scaleType: d,
3247
3338
  _onReadyCallback: h
3248
3339
  } = this.options;
3249
- if (Ve.apply(), this.canvas = new Te(this.containerId, this.options), this.moduleLoader = new xe(), this.workerManager = new Ue(), this.errorManager = new K({ editor: this }), this.historyManager = new st({ editor: this }), this.toolbar = new tt({ editor: this }), this.transformManager = new lt({ editor: this }), this.canvasManager = new dt({ editor: this }), this.imageManager = new O({ editor: this }), this.layerManager = new X({ editor: this }), this.shapeManager = new gt({ editor: this }), this.interactionBlocker = new ht({ editor: this }), this.backgroundManager = new R({ editor: this }), this.clipboardManager = new ut({ editor: this }), this.objectLockManager = new Q({ editor: this }), this.groupingManager = new Mt({ editor: this }), this.selectionManager = new ft({ editor: this }), this.deletionManager = new mt({ 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(a), this.canvasManager.setCanvasCSSWidth(n), this.canvasManager.setCanvasCSSHeight(o), i != null && i.source) {
3340
+ if (Ve.apply(), this.canvas = new we(this.containerId, this.options), this.moduleLoader = new _e(), this.workerManager = new Ue(), this.errorManager = new $({ editor: this }), this.historyManager = new st({ editor: this }), this.toolbar = new tt({ editor: this }), this.transformManager = new lt({ editor: this }), this.canvasManager = new dt({ editor: this }), this.imageManager = new O({ editor: this }), this.layerManager = new Q({ editor: this }), this.shapeManager = new gt({ editor: this }), this.interactionBlocker = new ht({ editor: this }), this.backgroundManager = new _({ editor: this }), this.clipboardManager = new ut({ editor: this }), this.objectLockManager = new K({ editor: this }), this.groupingManager = new Mt({ editor: this }), this.selectionManager = new ft({ editor: this }), this.deletionManager = new mt({ editor: this }), this._createMontageArea(), this._createClippingArea(), this.listeners = new Y({ editor: this, options: this.options }), this.canvasManager.setEditorContainerWidth(e), this.canvasManager.setEditorContainerHeight(t), this.canvasManager.setCanvasWrapperWidth(s), this.canvasManager.setCanvasWrapperHeight(a), this.canvasManager.setCanvasCSSWidth(n), this.canvasManager.setCanvasCSSHeight(o), i != null && i.source) {
3250
3341
  const {
3251
3342
  source: l,
3252
3343
  scale: g = `image-${d}`,
3253
- withoutSave: M = !0
3344
+ withoutSave: u = !0
3254
3345
  } = i;
3255
- yield this.imageManager.importImage({ source: l, scale: g, withoutSave: M });
3346
+ yield this.imageManager.importImage({ source: l, scale: g, withoutSave: u });
3256
3347
  } else
3257
3348
  this.canvasManager.setDefaultScale({ withoutSave: !0 });
3258
3349
  c && this.historyManager.loadStateFromFullState(c), this.historyManager.saveState(), console.log("editor:ready"), this.canvas.fire("editor:ready", this), typeof h == "function" && h(this);
@@ -3269,7 +3360,7 @@ class ie {
3269
3360
  this.montageArea = this.shapeManager.addRectangle({
3270
3361
  width: e,
3271
3362
  height: t,
3272
- fill: ie._createMosaicPattern(),
3363
+ fill: re._createMosaicPattern(),
3273
3364
  stroke: null,
3274
3365
  strokeWidth: 0,
3275
3366
  selectable: !1,
@@ -3319,7 +3410,7 @@ class ie {
3319
3410
  const e = document.createElement("canvas");
3320
3411
  e.width = 20, e.height = 20;
3321
3412
  const t = e.getContext("2d");
3322
- return t.fillStyle = "#ddd", t.fillRect(0, 0, 40, 40), t.fillStyle = "#ccc", t.fillRect(0, 0, 10, 10), t.fillRect(10, 10, 10, 10), new we({
3413
+ return t.fillStyle = "#ddd", t.fillRect(0, 0, 40, 40), t.fillStyle = "#ccc", t.fillRect(0, 0, 10, 10), t.fillRect(10, 10, 10, 10), new Te({
3323
3414
  source: e,
3324
3415
  repeat: "repeat"
3325
3416
  });
@@ -3415,13 +3506,13 @@ const jt = {
3415
3506
  keyboardIgnoreSelectors: []
3416
3507
  };
3417
3508
  function St(r, e = {}) {
3418
- const t = p(p({}, jt), e), s = document.getElementById(r);
3509
+ const t = I(I({}, jt), e), s = document.getElementById(r);
3419
3510
  if (!s)
3420
3511
  return Promise.reject(new Error(`Контейнер с ID "${r}" не найден.`));
3421
3512
  const a = document.createElement("canvas");
3422
3513
  return a.id = `${r}-canvas`, s.appendChild(a), t.editorContainer = s, new Promise((n) => {
3423
3514
  t._onReadyCallback = n;
3424
- const o = new ie(a.id, t);
3515
+ const o = new re(a.id, t);
3425
3516
  window[r] = o;
3426
3517
  });
3427
3518
  }