@anu3ev/fabric-image-editor 0.1.44 → 0.1.46

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 +956 -1115
  2. package/package.json +2 -1
package/dist/main.js CHANGED
@@ -1,44 +1,45 @@
1
- var we = Object.defineProperty;
2
- var G = Object.getOwnPropertySymbols;
3
- var fe = Object.prototype.hasOwnProperty, je = Object.prototype.propertyIsEnumerable;
4
- var me = (o, e, t) => e in o ? we(o, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : o[e] = t, C = (o, e) => {
1
+ var fe = Object.defineProperty;
2
+ var _ = Object.getOwnPropertySymbols;
3
+ var re = Object.prototype.hasOwnProperty, ce = Object.prototype.propertyIsEnumerable;
4
+ var oe = (r, e, t) => e in r ? fe(r, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : r[e] = t, N = (r, e) => {
5
5
  for (var t in e || (e = {}))
6
- fe.call(e, t) && me(o, t, e[t]);
7
- if (G)
8
- for (var t of G(e))
9
- je.call(e, t) && me(o, t, e[t]);
10
- return o;
6
+ re.call(e, t) && oe(r, t, e[t]);
7
+ if (_)
8
+ for (var t of _(e))
9
+ ce.call(e, t) && oe(r, t, e[t]);
10
+ return r;
11
11
  };
12
- var X = (o, e) => {
12
+ var Y = (r, e) => {
13
13
  var t = {};
14
- for (var a in o)
15
- fe.call(o, a) && e.indexOf(a) < 0 && (t[a] = o[a]);
16
- if (o != null && G)
17
- for (var a of G(o))
18
- e.indexOf(a) < 0 && je.call(o, a) && (t[a] = o[a]);
14
+ for (var a in r)
15
+ re.call(r, a) && e.indexOf(a) < 0 && (t[a] = r[a]);
16
+ if (r != null && _)
17
+ for (var a of _(r))
18
+ e.indexOf(a) < 0 && ce.call(r, a) && (t[a] = r[a]);
19
19
  return t;
20
20
  };
21
- var Q = (o, e, t) => new Promise((a, n) => {
21
+ var b = (r, e, t) => new Promise((a, s) => {
22
22
  var i = (c) => {
23
23
  try {
24
- r(t.next(c));
25
- } catch (u) {
26
- n(u);
24
+ o(t.next(c));
25
+ } catch (d) {
26
+ s(d);
27
27
  }
28
- }, s = (c) => {
28
+ }, n = (c) => {
29
29
  try {
30
- r(t.throw(c));
31
- } catch (u) {
32
- n(u);
30
+ o(t.throw(c));
31
+ } catch (d) {
32
+ s(d);
33
33
  }
34
- }, r = (c) => c.done ? a(c.value) : Promise.resolve(c.value).then(i, s);
35
- r((t = t.apply(o, e)).next());
34
+ }, o = (c) => c.done ? a(c.value) : Promise.resolve(c.value).then(i, n);
35
+ o((t = t.apply(r, e)).next());
36
36
  });
37
- import { ActiveSelection as T, util as P, controlsUtils as Oe, InteractiveFabricObject as Te, loadSVGFromURL as ke, FabricImage as ee, Point as K, Rect as xe, Circle as Be, Triangle as Ze, Group as ze, Canvas as Ue, Pattern as _e } from "fabric";
38
- import { create as He } from "jsondiffpatch";
39
- var Ye = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict", A = function() {
37
+ import { ActiveSelection as E, util as H, controlsUtils as ve, InteractiveFabricObject as be, loadSVGFromURL as ye, FabricImage as Z, Point as W, Rect as pe, Circle as Ie, Triangle as Ae, Group as de, Canvas as Se, Pattern as Ce } from "fabric";
38
+ import { create as De } from "jsondiffpatch";
39
+ import we from "diff-match-patch";
40
+ var Le = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict", D = function() {
40
41
  for (var e = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : 21, t = "", a = crypto.getRandomValues(new Uint8Array(e |= 0)); e--; )
41
- t += Ye[a[e] & 63];
42
+ t += Le[a[e] & 63];
42
43
  return t;
43
44
  };
44
45
  class R {
@@ -68,15 +69,15 @@ class R {
68
69
  adaptCanvasToContainerOnResize: e,
69
70
  canvasDragging: t,
70
71
  mouseWheelZooming: a,
71
- bringToFrontOnSelection: n,
72
+ bringToFrontOnSelection: s,
72
73
  copyObjectsByHotkey: i,
73
- pasteImageFromClipboard: s,
74
- undoRedoByHotKeys: r,
74
+ pasteImageFromClipboard: n,
75
+ undoRedoByHotKeys: o,
75
76
  selectAllByHotkey: c,
76
- deleteObjectsByHotkey: u,
77
+ deleteObjectsByHotkey: d,
77
78
  resetObjectFitByDoubleClick: l
78
79
  } = this.options;
79
- 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 })), a && 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 }), s && document.addEventListener("paste", this.handlePasteEventBound, { capture: !0 }), r && (document.addEventListener("keydown", this.handleUndoRedoEventBound, { capture: !0 }), document.addEventListener("keyup", this.handleUndoRedoKeyUpBound, { capture: !0 })), c && document.addEventListener("keydown", this.handleSelectAllEventBound, { capture: !0 }), u && 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);
80
+ 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 })), a && this.canvas.on("mouse:wheel", this.handleMouseWheelZoomBound), s && (this.canvas.on("selection:created", this.handleBringToFrontBound), this.canvas.on("selection:updated", this.handleBringToFrontBound)), l && this.canvas.on("mouse:dblclick", this.handleResetObjectFitBound), e && window.addEventListener("resize", this.handleContainerResizeBound, { capture: !0 }), i && document.addEventListener("keydown", this.handleCopyEventBound, { capture: !0 }), n && 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 }), d && 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);
80
81
  }
81
82
  /**
82
83
  * При массовом выделении объектов удаляем из него залоченные.
@@ -85,17 +86,17 @@ class R {
85
86
  * @param {TPointerEvent} [params.e] - событие указателя (опционально)
86
87
  */
87
88
  _filterLockedSelection({ selected: e, e: t }) {
88
- if (!(e != null && e.length) || !(t instanceof MouseEvent) || e.length === 1 || !e.some((s) => s.locked)) return;
89
- const n = e.filter((s) => !s.locked);
90
- if (n.length === 0) {
89
+ if (!(e != null && e.length) || !(t instanceof MouseEvent) || e.length === 1 || !e.some((n) => n.locked)) return;
90
+ const s = e.filter((n) => !n.locked);
91
+ if (s.length === 0) {
91
92
  this.canvas.discardActiveObject();
92
93
  return;
93
94
  }
94
- if (n.length === 1) {
95
- this.canvas.setActiveObject(n[0]);
95
+ if (s.length === 1) {
96
+ this.canvas.setActiveObject(s[0]);
96
97
  return;
97
98
  }
98
- const i = new T(n, {
99
+ const i = new E(s, {
99
100
  canvas: this.canvas
100
101
  });
101
102
  this.canvas.setActiveObject(i), this.canvas.requestRenderAll();
@@ -139,8 +140,8 @@ class R {
139
140
  * @param {String} event.code — код клавиши
140
141
  */
141
142
  handleCopyEvent(e) {
142
- const { ctrlKey: t, metaKey: a, code: n } = e;
143
- !t && !a || n !== "KeyC" || (e.preventDefault(), this.editor.clipboardManager.copy());
143
+ const { ctrlKey: t, metaKey: a, code: s } = e;
144
+ !t && !a || s !== "KeyC" || (e.preventDefault(), this.editor.clipboardManager.copy());
144
145
  }
145
146
  /**
146
147
  * Обработчик вставки объекта или изображения из буфера обмена.
@@ -157,9 +158,9 @@ class R {
157
158
  * @param {String} event.code — код клавиши
158
159
  */
159
160
  handleUndoRedoEvent(e) {
160
- return Q(this, null, function* () {
161
- const { ctrlKey: t, metaKey: a, code: n, repeat: i } = e;
162
- !t && !a || 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()));
161
+ return b(this, null, function* () {
162
+ const { ctrlKey: t, metaKey: a, code: s, repeat: i } = e;
163
+ !t && !a || i || !/Mac/i.test(navigator.userAgent) && this.isUndoRedoKeyPressed || (s === "KeyZ" ? (e.preventDefault(), this.isUndoRedoKeyPressed = !0, yield this.editor.historyManager.undo()) : s === "KeyY" && (e.preventDefault(), this.isUndoRedoKeyPressed = !0, yield this.editor.historyManager.redo()));
163
164
  });
164
165
  }
165
166
  /**
@@ -178,8 +179,8 @@ class R {
178
179
  * @param {String} event.code — код клавиши
179
180
  */
180
181
  handleSelectAllEvent(e) {
181
- const { ctrlKey: t, metaKey: a, code: n } = e;
182
- !t && !a || n !== "KeyA" || (e.preventDefault(), this.editor.selectionManager.selectAll());
182
+ const { ctrlKey: t, metaKey: a, code: s } = e;
183
+ !t && !a || s !== "KeyA" || (e.preventDefault(), this.editor.selectionManager.selectAll());
183
184
  }
184
185
  /**
185
186
  * Обработчик для удаления объектов (Delete).
@@ -197,12 +198,12 @@ class R {
197
198
  */
198
199
  handleSpaceKeyDown(e) {
199
200
  if (e.code !== "Space") return;
200
- const { canvas: t, editor: a, isSpacePressed: n, isDragging: i } = this;
201
- n || i || (this.isSpacePressed = !0, e.preventDefault(), t.set({
201
+ const { canvas: t, editor: a, isSpacePressed: s, isDragging: i } = this;
202
+ s || i || (this.isSpacePressed = !0, e.preventDefault(), t.set({
202
203
  selection: !1,
203
204
  defaultCursor: "grab"
204
- }), t.setCursor("grab"), a.canvasManager.getObjects().forEach((s) => {
205
- s.set({
205
+ }), t.setCursor("grab"), a.canvasManager.getObjects().forEach((n) => {
206
+ n.set({
206
207
  selectable: !1,
207
208
  evented: !1
208
209
  });
@@ -296,14 +297,14 @@ class R {
296
297
  */
297
298
  static debounce(e, t) {
298
299
  let a = null;
299
- return function(...n) {
300
+ return function(...s) {
300
301
  a !== null && clearTimeout(a), a = setTimeout(() => {
301
- e.apply(this, n);
302
+ e.apply(this, s);
302
303
  }, t);
303
304
  };
304
305
  }
305
306
  }
306
- class Re {
307
+ class Ne {
307
308
  /**
308
309
  * @description Класс для динамической загрузки внешних модулей.
309
310
  */
@@ -321,7 +322,7 @@ class Re {
321
322
  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 "'.concat(e, '"')));
322
323
  }
323
324
  }
324
- class Pe {
325
+ class Ee {
325
326
  /**
326
327
  * @param {string|URL} [scriptUrl] — URL скрипта воркера.
327
328
  * По-умолчанию использует файл рядом с этим модулем
@@ -347,11 +348,11 @@ class Pe {
347
348
  data: t
348
349
  } = e, {
349
350
  requestId: a,
350
- success: n,
351
+ success: s,
351
352
  data: i,
352
- error: s
353
- } = t, r = this._callbacks.get(a);
354
- r && (n ? r.resolve(i) : r.reject(new Error(s)), this._callbacks.delete(a));
353
+ error: n
354
+ } = t, o = this._callbacks.get(a);
355
+ o && (s ? o.resolve(i) : o.reject(new Error(n)), this._callbacks.delete(a));
355
356
  }
356
357
  /**
357
358
  * Универсальный метод отправки команды в воркер
@@ -361,15 +362,15 @@ class Pe {
361
362
  * @returns {Promise<any>}
362
363
  */
363
364
  post(e, t) {
364
- var a = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : [], n = "".concat(e, ":").concat(A(8));
365
- return new Promise((i, s) => {
366
- this._callbacks.set(n, {
365
+ var a = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : [], s = "".concat(e, ":").concat(D(8));
366
+ return new Promise((i, n) => {
367
+ this._callbacks.set(s, {
367
368
  resolve: i,
368
- reject: s
369
+ reject: n
369
370
  }), this.worker.postMessage({
370
371
  action: e,
371
372
  payload: t,
372
- requestId: n
373
+ requestId: s
373
374
  }, a);
374
375
  });
375
376
  }
@@ -380,136 +381,136 @@ class Pe {
380
381
  this.worker.terminate();
381
382
  }
382
383
  }
383
- const I = 12, We = 2, ae = 8, ne = 20, Fe = 100, ie = 20, se = 8, Ve = 100, re = 32, oe = 1, Ge = "#2B2D33", ce = "#3D8BF4", ue = "#FFFFFF";
384
- function J(o, e, t, a, n) {
385
- const i = I, s = We;
386
- o.save(), o.translate(e, t), o.rotate(P.degreesToRadians(n.angle)), o.fillStyle = ue, o.strokeStyle = ce, o.lineWidth = oe, o.beginPath(), o.roundRect(-12 / 2, -12 / 2, i, i, s), o.fill(), o.stroke(), o.restore();
384
+ const S = 12, Oe = 2, X = 8, Q = 20, Te = 100, J = 20, $ = 8, ke = 100, K = 32, q = 1, xe = "#2B2D33", ee = "#3D8BF4", te = "#FFFFFF";
385
+ function P(r, e, t, a, s) {
386
+ const i = S, n = Oe;
387
+ r.save(), r.translate(e, t), r.rotate(H.degreesToRadians(s.angle)), r.fillStyle = te, r.strokeStyle = ee, r.lineWidth = q, r.beginPath(), r.roundRect(-12 / 2, -12 / 2, i, i, n), r.fill(), r.stroke(), r.restore();
387
388
  }
388
- function ye(o, e, t, a, n) {
389
- const i = ae, s = ne, r = Fe;
390
- o.save(), o.translate(e, t), o.rotate(P.degreesToRadians(n.angle)), o.fillStyle = ue, o.strokeStyle = ce, o.lineWidth = oe, o.beginPath(), o.roundRect(-8 / 2, -20 / 2, i, s, r), o.fill(), o.stroke(), o.restore();
389
+ function le(r, e, t, a, s) {
390
+ const i = X, n = Q, o = Te;
391
+ r.save(), r.translate(e, t), r.rotate(H.degreesToRadians(s.angle)), r.fillStyle = te, r.strokeStyle = ee, r.lineWidth = q, r.beginPath(), r.roundRect(-8 / 2, -20 / 2, i, n, o), r.fill(), r.stroke(), r.restore();
391
392
  }
392
- function be(o, e, t, a, n) {
393
- const i = ie, s = se, r = Ve;
394
- o.save(), o.translate(e, t), o.rotate(P.degreesToRadians(n.angle)), o.fillStyle = ue, o.strokeStyle = ce, o.lineWidth = oe, o.beginPath(), o.roundRect(-20 / 2, -8 / 2, i, s, r), o.fill(), o.stroke(), o.restore();
393
+ function he(r, e, t, a, s) {
394
+ const i = J, n = $, o = ke;
395
+ r.save(), r.translate(e, t), r.rotate(H.degreesToRadians(s.angle)), r.fillStyle = te, r.strokeStyle = ee, r.lineWidth = q, r.beginPath(), r.roundRect(-20 / 2, -8 / 2, i, n, o), r.fill(), r.stroke(), r.restore();
395
396
  }
396
- const Xe = "", Ce = new Image();
397
- Ce.src = Xe;
398
- function Qe(o, e, t, a, n) {
399
- const s = re / 2;
400
- o.save(), o.translate(e, t), o.rotate(P.degreesToRadians(n.angle)), o.fillStyle = Ge, o.beginPath(), o.arc(0, 0, s, 0, 2 * Math.PI), o.fill(), o.drawImage(Ce, -16 / 2, -16 / 2, s, s), o.restore();
397
+ const Be = "", Me = new Image();
398
+ Me.src = Be;
399
+ function Ue(r, e, t, a, s) {
400
+ const n = K / 2;
401
+ r.save(), r.translate(e, t), r.rotate(H.degreesToRadians(s.angle)), r.fillStyle = xe, r.beginPath(), r.arc(0, 0, n, 0, 2 * Math.PI), r.fill(), r.drawImage(Me, -16 / 2, -16 / 2, n, n), r.restore();
401
402
  }
402
- const Je = {
403
+ const Ze = {
403
404
  // Угловые точки
404
405
  tl: {
405
- render: J,
406
- sizeX: I,
407
- sizeY: I,
406
+ render: P,
407
+ sizeX: S,
408
+ sizeY: S,
408
409
  offsetX: 0,
409
410
  offsetY: 0
410
411
  },
411
412
  tr: {
412
- render: J,
413
- sizeX: I,
414
- sizeY: I,
413
+ render: P,
414
+ sizeX: S,
415
+ sizeY: S,
415
416
  offsetX: 0,
416
417
  offsetY: 0
417
418
  },
418
419
  bl: {
419
- render: J,
420
- sizeX: I,
421
- sizeY: I,
420
+ render: P,
421
+ sizeX: S,
422
+ sizeY: S,
422
423
  offsetX: 0,
423
424
  offsetY: 0
424
425
  },
425
426
  br: {
426
- render: J,
427
- sizeX: I,
428
- sizeY: I,
427
+ render: P,
428
+ sizeX: S,
429
+ sizeY: S,
429
430
  offsetX: 0,
430
431
  offsetY: 0
431
432
  },
432
433
  // Середина вертикалей
433
434
  ml: {
434
- render: ye,
435
- sizeX: ae,
436
- sizeY: ne,
435
+ render: le,
436
+ sizeX: X,
437
+ sizeY: Q,
437
438
  offsetX: 0,
438
439
  offsetY: 0
439
440
  },
440
441
  mr: {
441
- render: ye,
442
- sizeX: ae,
443
- sizeY: ne,
442
+ render: le,
443
+ sizeX: X,
444
+ sizeY: Q,
444
445
  offsetX: 0,
445
446
  offsetY: 0
446
447
  },
447
448
  // Середина горизонталей
448
449
  mt: {
449
- render: be,
450
- sizeX: ie,
451
- sizeY: se,
450
+ render: he,
451
+ sizeX: J,
452
+ sizeY: $,
452
453
  offsetX: 0,
453
454
  offsetY: 0
454
455
  },
455
456
  mb: {
456
- render: be,
457
- sizeX: ie,
458
- sizeY: se,
457
+ render: he,
458
+ sizeX: J,
459
+ sizeY: $,
459
460
  offsetX: 0,
460
461
  offsetY: 0
461
462
  },
462
463
  // Специальный «rotate» контрол
463
464
  mtr: {
464
- render: Qe,
465
- sizeX: re,
466
- sizeY: re,
465
+ render: Ue,
466
+ sizeX: K,
467
+ sizeY: K,
467
468
  offsetX: 0,
468
469
  offsetY: -32
469
470
  }
470
471
  };
471
- class Ke {
472
+ class ze {
472
473
  static apply() {
473
- const e = Oe.createObjectDefaultControls();
474
- Object.entries(Je).forEach(([t, a]) => {
474
+ const e = ve.createObjectDefaultControls();
475
+ Object.entries(Ze).forEach(([t, a]) => {
475
476
  Object.assign(e[t], {
476
477
  render: a.render,
477
478
  sizeX: a.sizeX,
478
479
  sizeY: a.sizeY,
479
480
  offsetX: a.offsetX,
480
481
  offsetY: a.offsetY
481
- }), t === "mtr" && (e[t].cursorStyle = "grab", e[t].mouseDownHandler = (i, s, r, c) => {
482
+ }), t === "mtr" && (e[t].cursorStyle = "grab", e[t].mouseDownHandler = (i, n, o, c) => {
482
483
  var l;
483
- (l = s.target.canvas) == null || l.setCursor("grabbing");
484
+ (l = n.target.canvas) == null || l.setCursor("grabbing");
484
485
  });
485
- }), Te.ownDefaults.controls = e;
486
+ }), be.ownDefaults.controls = e;
486
487
  }
487
488
  }
488
- var $e = "", qe = "", et = "", tt = "", at = "", nt = "", it = "", st = "";
489
- function pe(o, e, t, a, n, i, s) {
489
+ var Re = "", He = "", _e = "", Ye = "", Pe = "", We = "", Fe = "", Ve = "";
490
+ function ge(r, e, t, a, s, i, n) {
490
491
  try {
491
- var r = o[i](s), c = r.value;
492
- } catch (u) {
493
- return void t(u);
492
+ var o = r[i](n), c = o.value;
493
+ } catch (d) {
494
+ return void t(d);
494
495
  }
495
- r.done ? e(c) : Promise.resolve(c).then(a, n);
496
+ o.done ? e(c) : Promise.resolve(c).then(a, s);
496
497
  }
497
- function rt(o) {
498
+ function Ge(r) {
498
499
  return function() {
499
500
  var e = this, t = arguments;
500
- return new Promise(function(a, n) {
501
- var i = o.apply(e, t);
502
- function s(c) {
503
- pe(i, a, n, s, r, "next", c);
501
+ return new Promise(function(a, s) {
502
+ var i = r.apply(e, t);
503
+ function n(c) {
504
+ ge(i, a, s, n, o, "next", c);
504
505
  }
505
- function r(c) {
506
- pe(i, a, n, s, r, "throw", c);
506
+ function o(c) {
507
+ ge(i, a, s, n, o, "throw", c);
507
508
  }
508
- s(void 0);
509
+ n(void 0);
509
510
  });
510
511
  };
511
512
  }
512
- const Y = {
513
+ const z = {
513
514
  style: {
514
515
  position: "absolute",
515
516
  display: "none",
@@ -568,87 +569,87 @@ const Y = {
568
569
  }],
569
570
  offsetTop: 50,
570
571
  icons: {
571
- copyPaste: $e,
572
- delete: st,
573
- lock: qe,
574
- unlock: et,
575
- bringToFront: nt,
576
- sendToBack: it,
577
- bringForward: tt,
578
- sendBackwards: at
572
+ copyPaste: Re,
573
+ delete: Ve,
574
+ lock: He,
575
+ unlock: _e,
576
+ bringToFront: We,
577
+ sendToBack: Fe,
578
+ bringForward: Ye,
579
+ sendBackwards: Pe
579
580
  },
580
581
  handlers: {
581
582
  copyPaste: function() {
582
- var o = rt(function* (t) {
583
+ var r = Ge(function* (t) {
583
584
  yield t.clipboardManager.copy(), yield t.clipboardManager.paste();
584
585
  });
585
586
  function e(t) {
586
- return o.apply(this, arguments);
587
+ return r.apply(this, arguments);
587
588
  }
588
589
  return e;
589
590
  }(),
590
- delete: (o) => {
591
- o.deletionManager.deleteSelectedObjects();
591
+ delete: (r) => {
592
+ r.deletionManager.deleteSelectedObjects();
592
593
  },
593
- lock: (o) => {
594
- o.objectLockManager.lockObject();
594
+ lock: (r) => {
595
+ r.objectLockManager.lockObject();
595
596
  },
596
- unlock: (o) => {
597
- o.objectLockManager.unlockObject();
597
+ unlock: (r) => {
598
+ r.objectLockManager.unlockObject();
598
599
  },
599
- bringForward: (o) => {
600
- o.layerManager.bringForward();
600
+ bringForward: (r) => {
601
+ r.layerManager.bringForward();
601
602
  },
602
- bringToFront: (o) => {
603
- o.layerManager.bringToFront();
603
+ bringToFront: (r) => {
604
+ r.layerManager.bringToFront();
604
605
  },
605
- sendToBack: (o) => {
606
- o.layerManager.sendToBack();
606
+ sendToBack: (r) => {
607
+ r.layerManager.sendToBack();
607
608
  },
608
- sendBackwards: (o) => {
609
- o.layerManager.sendBackwards();
609
+ sendBackwards: (r) => {
610
+ r.layerManager.sendBackwards();
610
611
  }
611
612
  }
612
613
  };
613
- function Ie(o, e) {
614
- var t = Object.keys(o);
614
+ function ue(r, e) {
615
+ var t = Object.keys(r);
615
616
  if (Object.getOwnPropertySymbols) {
616
- var a = Object.getOwnPropertySymbols(o);
617
- e && (a = a.filter(function(n) {
618
- return Object.getOwnPropertyDescriptor(o, n).enumerable;
617
+ var a = Object.getOwnPropertySymbols(r);
618
+ e && (a = a.filter(function(s) {
619
+ return Object.getOwnPropertyDescriptor(r, s).enumerable;
619
620
  })), t.push.apply(t, a);
620
621
  }
621
622
  return t;
622
623
  }
623
- function j(o) {
624
+ function p(r) {
624
625
  for (var e = 1; e < arguments.length; e++) {
625
626
  var t = arguments[e] != null ? arguments[e] : {};
626
- e % 2 ? Ie(Object(t), !0).forEach(function(a) {
627
- ot(o, a, t[a]);
628
- }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(o, Object.getOwnPropertyDescriptors(t)) : Ie(Object(t)).forEach(function(a) {
629
- Object.defineProperty(o, a, Object.getOwnPropertyDescriptor(t, a));
627
+ e % 2 ? ue(Object(t), !0).forEach(function(a) {
628
+ Xe(r, a, t[a]);
629
+ }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(r, Object.getOwnPropertyDescriptors(t)) : ue(Object(t)).forEach(function(a) {
630
+ Object.defineProperty(r, a, Object.getOwnPropertyDescriptor(t, a));
630
631
  });
631
632
  }
632
- return o;
633
+ return r;
633
634
  }
634
- function ot(o, e, t) {
635
- return (e = ct(e)) in o ? Object.defineProperty(o, e, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : o[e] = t, o;
635
+ function Xe(r, e, t) {
636
+ return (e = Qe(e)) in r ? Object.defineProperty(r, e, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : r[e] = t, r;
636
637
  }
637
- function ct(o) {
638
- var e = ut(o, "string");
638
+ function Qe(r) {
639
+ var e = Je(r, "string");
639
640
  return typeof e == "symbol" ? e : e + "";
640
641
  }
641
- function ut(o, e) {
642
- if (typeof o != "object" || !o) return o;
643
- var t = o[Symbol.toPrimitive];
642
+ function Je(r, e) {
643
+ if (typeof r != "object" || !r) return r;
644
+ var t = r[Symbol.toPrimitive];
644
645
  if (t !== void 0) {
645
- var a = t.call(o, e);
646
+ var a = t.call(r, e);
646
647
  if (typeof a != "object") return a;
647
648
  throw new TypeError("@@toPrimitive must return a primitive value.");
648
649
  }
649
- return (e === "string" ? String : Number)(o);
650
+ return (e === "string" ? String : Number)(r);
650
651
  }
651
- class dt {
652
+ class $e {
652
653
  /**
653
654
  * @param {object} options
654
655
  * @param {ImageEditor} options.editor - экземпляр редактора с доступом к canvas
@@ -660,11 +661,11 @@ class dt {
660
661
  if (this.options = t.options, !!this.options.showToolbar) {
661
662
  this.editor = t, this.canvas = t.canvas;
662
663
  var a = this.options.toolbar || {};
663
- this.config = j(j(j({}, Y), a), {}, {
664
- style: j(j({}, Y.style), a.style || {}),
665
- btnStyle: j(j({}, Y.btnStyle), a.btnStyle || {}),
666
- icons: j(j({}, Y.icons), a.icons || {}),
667
- handlers: j(j({}, Y.handlers), a.handlers || {})
664
+ this.config = p(p(p({}, z), a), {}, {
665
+ style: p(p({}, z.style), a.style || {}),
666
+ btnStyle: p(p({}, z.btnStyle), a.btnStyle || {}),
667
+ icons: p(p({}, z.icons), a.icons || {}),
668
+ handlers: p(p({}, z.handlers), a.handlers || {})
668
669
  }), this.currentTarget = null, this.currentLocked = null, 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 = () => {
669
670
  this.el.style.display = "none";
670
671
  }, this._createDOM(), this._bindEvents();
@@ -698,19 +699,19 @@ class dt {
698
699
  this.el.innerHTML = "";
699
700
  var a = function() {
700
701
  var {
701
- name: s,
702
- handle: r
703
- } = n, {
702
+ name: n,
703
+ handle: o
704
+ } = s, {
704
705
  icons: c,
705
- btnStyle: u,
706
+ btnStyle: d,
706
707
  handlers: l
707
- } = t.config, d = document.createElement("button");
708
- d.innerHTML = c[r] ? '<img src="'.concat(c[r], '" title="').concat(s, '" />') : s, Object.assign(d.style, u), d.onclick = () => {
709
- var h;
710
- return (h = l[r]) === null || h === void 0 ? void 0 : h.call(l, t.editor);
711
- }, t.el.appendChild(d);
708
+ } = t.config, h = document.createElement("button");
709
+ h.innerHTML = c[o] ? '<img src="'.concat(c[o], '" title="').concat(n, '" />') : n, Object.assign(h.style, d), h.onclick = () => {
710
+ var g;
711
+ return (g = l[o]) === null || g === void 0 ? void 0 : g.call(l, t.editor);
712
+ }, t.el.appendChild(h);
712
713
  };
713
- for (var n of e)
714
+ for (var s of e)
714
715
  a();
715
716
  }
716
717
  /**
@@ -777,18 +778,18 @@ class dt {
777
778
  var {
778
779
  el: t,
779
780
  config: a,
780
- canvas: n
781
+ canvas: s
781
782
  } = this;
782
783
  e.setCoords();
783
- var i = n.getZoom(), [, , , , s, r] = n.viewportTransform, {
784
+ var i = s.getZoom(), [, , , , n, o] = s.viewportTransform, {
784
785
  x: c
785
786
  } = e.getCenterPoint(), {
786
- top: u,
787
+ top: d,
787
788
  height: l
788
- } = e.getBoundingRect(!1, !0), d = c * i + s, h = d - t.offsetWidth / 2, g = (u + l) * i + r + a.offsetTop;
789
+ } = e.getBoundingRect(!1, !0), h = c * i + n, g = h - t.offsetWidth / 2, u = (d + l) * i + o + a.offsetTop;
789
790
  Object.assign(t.style, {
790
- left: "".concat(h, "px"),
791
- top: "".concat(g, "px"),
791
+ left: "".concat(g, "px"),
792
+ top: "".concat(u, "px"),
792
793
  display: "flex"
793
794
  });
794
795
  }
@@ -800,39 +801,9 @@ class dt {
800
801
  this.el.removeEventListener("mouseover", this._onBtnOver), this.el.removeEventListener("mouseout", this._onBtnOut), this.canvas.off("mouse:down", this._onMouseDown), this.canvas.off("object:moving", this._onObjectMoving), this.canvas.off("object:scaling", this._onObjectScaling), this.canvas.off("object:rotating", this._onObjectRotating), this.canvas.off("mouse:up", this._onMouseUp), this.canvas.off("object:modified", this._onObjectModified), this.canvas.off("selection:created", this._onSelectionChange), this.canvas.off("selection:updated", this._onSelectionChange), this.canvas.off("selection:changed", this._onSelectionChange), this.canvas.off("after:render", this._onSelectionChange), this.canvas.off("selection:cleared", this._onSelectionClear), this.el.remove();
801
802
  }
802
803
  }
803
- function Ae(o, e, t, a, n, i, s) {
804
- try {
805
- var r = o[i](s), c = r.value;
806
- } catch (u) {
807
- return void t(u);
808
- }
809
- r.done ? e(c) : Promise.resolve(c).then(a, n);
810
- }
811
- function te(o) {
812
- return function() {
813
- var e = this, t = arguments;
814
- return new Promise(function(a, n) {
815
- var i = o.apply(e, t);
816
- function s(c) {
817
- Ae(i, a, n, s, r, "next", c);
818
- }
819
- function r(c) {
820
- Ae(i, a, n, s, r, "throw", c);
821
- }
822
- s(void 0);
823
- });
824
- };
825
- }
826
- class lt {
827
- /**
828
- * @param {object} options
829
- * @param {ImageEditor} options.editor - экземпляр редактора с доступом к canvas
830
- */
831
- constructor(e) {
832
- var {
833
- editor: t
834
- } = e;
835
- this.editor = t, this.canvas = t.canvas, this._historySuspendCount = 0, this.baseState = null, this.patches = [], this.currentIndex = 0, this.maxHistoryLength = t.options.maxHistoryLength, this.totalChangesCount = 0, this.baseStateChangesCount = 0, this._createDiffPatcher();
804
+ class Ke {
805
+ constructor({ editor: e }) {
806
+ this.editor = e, this.canvas = e.canvas, this._historySuspendCount = 0, this.baseState = null, this.patches = [], this.currentIndex = 0, this.maxHistoryLength = e.options.maxHistoryLength, this.totalChangesCount = 0, this.baseStateChangesCount = 0, this._createDiffPatcher();
836
807
  }
837
808
  /** Проверка, нужно ли пропускать сохранение истории */
838
809
  get skipHistory() {
@@ -842,15 +813,31 @@ class lt {
842
813
  return this.patches[this.currentIndex - 1] || null;
843
814
  }
844
815
  _createDiffPatcher() {
845
- this.diffPatcher = He({
816
+ this.diffPatcher = De({
846
817
  objectHash(e) {
847
- return [e.id, e.format, e.locked, e.left, e.top, e.width, e.height, e.flipX, e.flipY, e.scaleX, e.scaleY, e.angle, e.opacity].join("-");
818
+ const t = e;
819
+ return [
820
+ t.id,
821
+ t.format,
822
+ t.locked,
823
+ t.left,
824
+ t.top,
825
+ t.width,
826
+ t.height,
827
+ t.flipX,
828
+ t.flipY,
829
+ t.scaleX,
830
+ t.scaleY,
831
+ t.angle,
832
+ t.opacity
833
+ ].join("-");
848
834
  },
849
835
  arrays: {
850
836
  detectMove: !0,
851
837
  includeValueOnMove: !1
852
838
  },
853
839
  textDiff: {
840
+ diffMatchPatch: we,
854
841
  minLength: 60
855
842
  }
856
843
  });
@@ -881,717 +868,593 @@ class lt {
881
868
  * Получаем полное состояние, применяя все диффы к базовому состоянию.
882
869
  */
883
870
  getFullState() {
884
- for (var {
885
- baseState: e,
886
- currentIndex: t,
887
- patches: a
888
- } = this, n = JSON.parse(JSON.stringify(e)), i = 0; i < t; i += 1)
889
- n = this.diffPatcher.patch(n, a[i].diff);
890
- return console.log("getFullState state", n), n;
871
+ const { baseState: e, currentIndex: t, patches: a } = this;
872
+ let s = JSON.parse(JSON.stringify(e));
873
+ for (let i = 0; i < t; i += 1)
874
+ s = this.diffPatcher.patch(s, a[i].diff);
875
+ return console.log("getFullState state", s), s;
891
876
  }
892
877
  /**
893
878
  * Сохраняем текущее состояние в виде диффа от последнего сохранённого полного состояния.
894
879
  */
895
880
  saveState() {
896
- if (console.log("saveState"), !this.skipHistory) {
897
- console.time("saveState");
898
- var e = this.canvas.toDatalessObject(["selectable", "evented", "id", "format", "width", "height", "locked", "lockMovementX", "lockMovementY", "lockRotation", "lockScalingX", "lockScalingY", "lockSkewingX", "lockSkewingY"]);
899
- if (console.timeEnd("saveState"), !this.baseState) {
900
- this.baseState = e, this.patches = [], this.currentIndex = 0, console.log("Базовое состояние сохранено.");
901
- return;
902
- }
903
- var t = this.getFullState(), a = this.diffPatcher.diff(t, e);
904
- if (!a) {
905
- console.log("Нет изменений для сохранения.");
906
- return;
907
- }
908
- console.log("baseState", this.baseState), this.currentIndex < this.patches.length && this.patches.splice(this.currentIndex), console.log("diff", a), this.totalChangesCount += 1, this.patches.push({
909
- id: A(),
910
- diff: a
911
- }), 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);
881
+ if (console.log("saveState"), this.skipHistory) return;
882
+ console.time("saveState");
883
+ const e = this.canvas.toDatalessObject([
884
+ "selectable",
885
+ "evented",
886
+ "id",
887
+ "format",
888
+ "width",
889
+ "height",
890
+ "locked",
891
+ "lockMovementX",
892
+ "lockMovementY",
893
+ "lockRotation",
894
+ "lockScalingX",
895
+ "lockScalingY",
896
+ "lockSkewingX",
897
+ "lockSkewingY"
898
+ ]);
899
+ if (console.timeEnd("saveState"), !this.baseState) {
900
+ this.baseState = e, this.patches = [], this.currentIndex = 0, console.log("Базовое состояние сохранено.");
901
+ return;
912
902
  }
903
+ const t = this.getFullState(), a = this.diffPatcher.diff(t, e);
904
+ if (!a) {
905
+ console.log("Нет изменений для сохранения.");
906
+ return;
907
+ }
908
+ console.log("baseState", this.baseState), this.currentIndex < this.patches.length && this.patches.splice(this.currentIndex), console.log("diff", a), this.totalChangesCount += 1, this.patches.push({ id: D(), diff: a }), 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);
913
909
  }
914
910
  /**
915
911
  * Функция загрузки состояния в канвас.
916
- * @param {object} fullState - полное состояние канваса
912
+ * @param {Partial<Canvas>} fullState - полное состояние канваса
917
913
  * @fires editor:history-state-loaded
918
914
  */
919
915
  loadStateFromFullState(e) {
920
- var t = this;
921
- return te(function* () {
922
- if (e) {
923
- console.log("loadStateFromFullState fullState", e);
924
- var {
925
- canvas: a,
926
- canvasManager: n,
927
- interactionBlocker: i
928
- } = t.editor, {
929
- width: s,
930
- height: r
931
- } = a;
932
- yield a.loadFromJSON(e);
933
- var c = a.getObjects().find((l) => l.id === "montage-area");
934
- c && (t.editor.montageArea = c, (s !== e.width || r !== e.height) && n.updateCanvasAndFitObjects());
935
- var u = a.getObjects().find((l) => l.id === "overlay-mask");
936
- u && (i.overlayMask = u, i.overlayMask.visible = !1), a.renderAll(), a.fire("editor:history-state-loaded", {
937
- fullState: e,
938
- currentIndex: t.currentIndex,
939
- totalChangesCount: t.totalChangesCount,
940
- baseStateChangesCount: t.baseStateChangesCount,
941
- patchesCount: t.patches.length,
942
- patches: t.patches
943
- });
944
- }
945
- })();
916
+ return b(this, null, function* () {
917
+ if (!e) return;
918
+ console.log("loadStateFromFullState fullState", e);
919
+ const { canvas: t, canvasManager: a, interactionBlocker: s } = this.editor, { width: i, height: n } = t;
920
+ yield t.loadFromJSON(e);
921
+ const o = t.getObjects().find((d) => d.id === "montage-area");
922
+ o && (this.editor.montageArea = o, (i !== e.width || n !== e.height) && a.updateCanvasAndFitObjects());
923
+ const c = t.getObjects().find((d) => d.id === "overlay-mask");
924
+ c && (s.overlayMask = c, s.overlayMask.visible = !1), t.renderAll(), t.fire("editor:history-state-loaded", {
925
+ fullState: e,
926
+ currentIndex: this.currentIndex,
927
+ totalChangesCount: this.totalChangesCount,
928
+ baseStateChangesCount: this.baseStateChangesCount,
929
+ patchesCount: this.patches.length,
930
+ patches: this.patches
931
+ });
932
+ });
946
933
  }
947
934
  /**
948
935
  * Undo – отмена последнего действия, восстанавливая состояние по накопленным диффам.
949
936
  * @fires editor:undo
950
937
  */
951
938
  undo() {
952
- var e = this;
953
- return te(function* () {
954
- if (!e.skipHistory) {
955
- if (e.currentIndex <= 0) {
939
+ return b(this, null, function* () {
940
+ if (!this.skipHistory) {
941
+ if (this.currentIndex <= 0) {
956
942
  console.log("Нет предыдущих состояний для отмены.");
957
943
  return;
958
944
  }
959
- e.suspendHistory();
945
+ this.suspendHistory();
960
946
  try {
961
- e.currentIndex -= 1, e.totalChangesCount -= 1;
962
- var t = e.getFullState();
963
- yield e.loadStateFromFullState(t), console.log("Undo выполнен. Текущий индекс истории:", e.currentIndex), e.canvas.fire("editor:undo", {
964
- fullState: t,
965
- currentIndex: e.currentIndex,
966
- totalChangesCount: e.totalChangesCount,
967
- baseStateChangesCount: e.baseStateChangesCount,
968
- patchesCount: e.patches.length,
969
- patches: e.patches
947
+ this.currentIndex -= 1, this.totalChangesCount -= 1;
948
+ const e = this.getFullState();
949
+ yield this.loadStateFromFullState(e), console.log("Undo выполнен. Текущий индекс истории:", this.currentIndex), this.canvas.fire("editor:undo", {
950
+ fullState: e,
951
+ currentIndex: this.currentIndex,
952
+ totalChangesCount: this.totalChangesCount,
953
+ baseStateChangesCount: this.baseStateChangesCount,
954
+ patchesCount: this.patches.length,
955
+ patches: this.patches
970
956
  });
971
- } catch (a) {
972
- console.error("undo. Ошибка отмены действия: ", a), e.canvas.fire("editor:error", {
973
- message: "Ошибка отмены действия: ".concat(a.message)
957
+ } catch (e) {
958
+ this.editor.errorManager.emitError({
959
+ origin: "HistoryManager",
960
+ method: "undo",
961
+ code: "UNDO_ERROR",
962
+ message: "Ошибка отмены действия",
963
+ data: e
974
964
  });
975
965
  } finally {
976
- e.resumeHistory();
966
+ this.resumeHistory();
977
967
  }
978
968
  }
979
- })();
969
+ });
980
970
  }
981
971
  /**
982
972
  * Redo – повтор ранее отменённого действия.
983
973
  * @fires editor:redo
984
974
  */
985
975
  redo() {
986
- var e = this;
987
- return te(function* () {
988
- if (!e.skipHistory) {
989
- if (e.currentIndex >= e.patches.length) {
976
+ return b(this, null, function* () {
977
+ if (!this.skipHistory) {
978
+ if (this.currentIndex >= this.patches.length) {
990
979
  console.log("Нет состояний для повтора.");
991
980
  return;
992
981
  }
993
- e.suspendHistory();
982
+ this.suspendHistory();
994
983
  try {
995
- e.currentIndex += 1, e.totalChangesCount += 1;
996
- var t = e.getFullState();
997
- console.log("fullState", t), yield e.loadStateFromFullState(t), console.log("Redo выполнен. Текущий индекс истории:", e.currentIndex), e.canvas.fire("editor:redo", {
998
- fullState: t,
999
- currentIndex: e.currentIndex,
1000
- totalChangesCount: e.totalChangesCount,
1001
- baseStateChangesCount: e.baseStateChangesCount,
1002
- patchesCount: e.patches.length,
1003
- patches: e.patches
984
+ this.currentIndex += 1, this.totalChangesCount += 1;
985
+ const e = this.getFullState();
986
+ console.log("fullState", e), yield this.loadStateFromFullState(e), console.log("Redo выполнен. Текущий индекс истории:", this.currentIndex), this.canvas.fire("editor:redo", {
987
+ fullState: e,
988
+ currentIndex: this.currentIndex,
989
+ totalChangesCount: this.totalChangesCount,
990
+ baseStateChangesCount: this.baseStateChangesCount,
991
+ patchesCount: this.patches.length,
992
+ patches: this.patches
1004
993
  });
1005
- } catch (a) {
1006
- console.error("redo. Ошибка повтора действия: ", a), e.canvas.fire("editor:error", {
1007
- message: "Ошибка повтора действия: ".concat(a.message)
994
+ } catch (e) {
995
+ this.editor.errorManager.emitError({
996
+ origin: "HistoryManager",
997
+ method: "redo",
998
+ code: "REDO_ERROR",
999
+ message: "Ошибка повтора действия",
1000
+ data: e
1008
1001
  });
1009
1002
  } finally {
1010
- e.resumeHistory();
1003
+ this.resumeHistory();
1011
1004
  }
1012
1005
  }
1013
- })();
1014
- }
1015
- }
1016
- const ht = 0.1, gt = 2, Mt = 0.1, vt = 90, x = 16, B = 16, w = 4096, O = 4096;
1017
- function Se(o, e, t, a, n, i, s) {
1018
- try {
1019
- var r = o[i](s), c = r.value;
1020
- } catch (u) {
1021
- return void t(u);
1022
- }
1023
- r.done ? e(c) : Promise.resolve(c).then(a, n);
1024
- }
1025
- function k(o) {
1026
- return function() {
1027
- var e = this, t = arguments;
1028
- return new Promise(function(a, n) {
1029
- var i = o.apply(e, t);
1030
- function s(c) {
1031
- Se(i, a, n, s, r, "next", c);
1032
- }
1033
- function r(c) {
1034
- Se(i, a, n, s, r, "throw", c);
1035
- }
1036
- s(void 0);
1037
1006
  });
1038
- };
1007
+ }
1039
1008
  }
1040
- class D {
1041
- /**
1042
- * @param {object} options
1043
- * @param {ImageEditor} options.editor - экземпляр редактора с доступом к canvas
1044
- */
1045
- constructor(e) {
1046
- var {
1047
- editor: t
1048
- } = e;
1049
- this.editor = t, this.options = t.options, this._createdBlobUrls = [], this.acceptContentTypes = this.editor.options.acceptContentTypes, this.acceptFormats = this.getAllowedFormatsFromContentTypes();
1009
+ const qe = 0.1, et = 2, tt = 0.1, at = 90, B = 16, U = 16, O = 4096, T = 4096;
1010
+ class C {
1011
+ constructor({ editor: e }) {
1012
+ this.editor = e, this.options = e.options, this._createdBlobUrls = [], this.acceptContentTypes = this.editor.options.acceptContentTypes, this.acceptFormats = this.getAllowedFormatsFromContentTypes();
1050
1013
  }
1051
1014
  /**
1052
1015
  * Импорт изображения
1053
- * @param {Object} options
1054
- * @param {File|string} [options.source] - URL изображения или объект File
1055
- * @param {String} [options.scale] - Если изображение не вписывается в допустимые размеры, то как масштабировать:
1016
+ * @param options
1017
+ * @param options.source - URL изображения или объект File
1018
+ * @param options.scale - Если изображение не вписывается в допустимые размеры, то как масштабировать:
1056
1019
  * 'image-contain' - скейлит картинку, чтобы она вписалась в монтажную область
1057
1020
  * 'image-cover' - скейлит картинку, чтобы она вписалась в монтажную область
1058
1021
  * 'scale-montage' - Обновляет backstore-резолюцию монтажной области (масштабирует
1059
1022
  * экспортный размер канваса под размер изображения)
1060
- * @param {Boolean} [options.withoutSave] - Не сохранять в историю изменений
1061
- * @returns {Promise<Object|null>} - возвращает Promise с объектом изображения или null в случае ошибки
1023
+ * @param options.withoutSave - Не сохранять в историю изменений
1024
+ * @returns возвращает Promise с объектом изображения или null в случае ошибки
1062
1025
  */
1063
- importImage(e) {
1064
- var t = this;
1065
- return k(function* () {
1066
- var {
1067
- source: a,
1068
- scale: n = "image-".concat(t.options.scaleType),
1069
- withoutSave: i = !1
1070
- } = e;
1071
- if (!a) return null;
1072
- var {
1073
- canvas: s,
1074
- montageArea: r,
1075
- transformManager: c,
1076
- historyManager: u,
1077
- errorManager: l
1078
- } = t.editor, d = yield t.getContentType(a), h = D.getFormatFromContentType(d), {
1079
- acceptContentTypes: g,
1080
- acceptFormats: v
1081
- } = t;
1082
- if (!t.isAllowedContentType(d)) {
1083
- var f = "Неверный contentType для изображения: ".concat(d, ". Ожидается один из: ").concat(t.acceptContentTypes.join(", "), ".");
1084
- return l.emitError({
1026
+ importImage(s) {
1027
+ return b(this, arguments, function* ({
1028
+ source: e,
1029
+ scale: t = `image-${this.options.scaleType}`,
1030
+ withoutSave: a = !1
1031
+ }) {
1032
+ if (!e) return null;
1033
+ const { canvas: i, montageArea: n, transformManager: o, historyManager: c, errorManager: d } = this.editor, l = yield this.getContentType(e), h = C.getFormatFromContentType(l), { acceptContentTypes: g, acceptFormats: u } = this;
1034
+ if (!this.isAllowedContentType(l)) {
1035
+ const m = `Неверный contentType для изображения: ${l}. Ожидается один из: ${this.acceptContentTypes.join(", ")}.`;
1036
+ return d.emitError({
1085
1037
  origin: "ImageManager",
1086
1038
  method: "importImage",
1087
1039
  code: "INVALID_CONTENT_TYPE",
1088
- message: f,
1089
- data: {
1090
- source: a,
1091
- format: h,
1092
- contentType: d,
1093
- acceptContentTypes: g,
1094
- acceptFormats: v
1095
- }
1040
+ message: m,
1041
+ data: { source: e, format: h, contentType: l, acceptContentTypes: g, acceptFormats: u }
1096
1042
  }), null;
1097
1043
  }
1098
- u.suspendHistory();
1044
+ c.suspendHistory();
1099
1045
  try {
1100
- var m, M;
1101
- if (a instanceof File)
1102
- m = URL.createObjectURL(a);
1103
- else if (typeof a == "string") {
1104
- var S = yield fetch(a, {
1105
- mode: "cors"
1106
- }), N = yield S.blob({
1107
- type: d,
1108
- quality: 1
1109
- });
1110
- m = URL.createObjectURL(N);
1046
+ let m, M;
1047
+ if (e instanceof File)
1048
+ m = URL.createObjectURL(e);
1049
+ else if (typeof e == "string") {
1050
+ const y = yield (yield fetch(e, { mode: "cors" })).blob();
1051
+ m = URL.createObjectURL(y);
1111
1052
  } else
1112
- return l.emitError({
1053
+ return d.emitError({
1113
1054
  origin: "ImageManager",
1114
1055
  method: "importImage",
1115
1056
  code: "INVALID_SOURCE_TYPE",
1116
1057
  message: "Неверный тип источника изображения. Ожидается URL или объект File.",
1117
- data: {
1118
- source: a,
1119
- format: h,
1120
- contentType: d,
1121
- acceptContentTypes: g,
1122
- acceptFormats: v
1123
- }
1058
+ data: { source: e, format: h, contentType: l, acceptContentTypes: g, acceptFormats: u }
1124
1059
  }), null;
1125
- if (t._createdBlobUrls.push(m), h === "svg") {
1126
- var E = yield ke(m);
1127
- M = P.groupSVGElements(E.objects, E.options);
1060
+ if (this._createdBlobUrls.push(m), h === "svg") {
1061
+ const v = yield ye(m);
1062
+ M = H.groupSVGElements(v.objects, v.options);
1128
1063
  } else
1129
- M = yield ee.fromURL(m, {
1130
- crossOrigin: "anonymous"
1131
- });
1132
- var {
1133
- width: L,
1134
- height: y
1135
- } = M;
1136
- if (y > O || L > w) {
1137
- var b = yield t.resizeImageToBoundaries(M._element.src, "max"), Z = URL.createObjectURL(b);
1138
- t._createdBlobUrls.push(Z), M = yield ee.fromURL(Z, {
1139
- crossOrigin: "anonymous"
1140
- });
1141
- } else if (y < B || L < x) {
1142
- var W = yield t.resizeImageToBoundaries(M._element.src, "min"), z = URL.createObjectURL(W);
1143
- t._createdBlobUrls.push(z), M = yield ee.fromURL(z, {
1144
- crossOrigin: "anonymous"
1145
- });
1064
+ M = yield Z.fromURL(m, { crossOrigin: "anonymous" });
1065
+ const { width: j, height: w } = M;
1066
+ if (M instanceof Z) {
1067
+ const v = M.getElement();
1068
+ let y = "";
1069
+ if (v instanceof HTMLImageElement ? y = v.src : v instanceof HTMLCanvasElement && (y = v.toDataURL()), w > T || j > O) {
1070
+ const L = yield this.resizeImageToBoundaries(y, "max"), k = URL.createObjectURL(L);
1071
+ this._createdBlobUrls.push(k), M = yield Z.fromURL(k, { crossOrigin: "anonymous" });
1072
+ } else if (w < U || j < B) {
1073
+ const L = yield this.resizeImageToBoundaries(y, "min"), k = URL.createObjectURL(L);
1074
+ this._createdBlobUrls.push(k), M = yield Z.fromURL(k, { crossOrigin: "anonymous" });
1075
+ }
1146
1076
  }
1147
- if (M.set("id", "".concat(M.type, "-").concat(A())), M.set("format", h), n === "scale-montage")
1148
- t.editor.canvasManager.scaleMontageAreaToImage({
1149
- object: M,
1150
- withoutSave: !0
1151
- });
1077
+ if (M.set("id", `${M.type}-${D()}`), M.set("format", h), t === "scale-montage")
1078
+ this.editor.canvasManager.scaleMontageAreaToImage({ object: M, withoutSave: !0 });
1152
1079
  else {
1153
- var {
1154
- width: F,
1155
- height: U
1156
- } = r, _ = t.calculateScaleFactor({
1157
- imageObject: M,
1158
- scaleType: n
1159
- });
1160
- n === "image-contain" && _ < 1 ? c.fitObject({
1161
- object: M,
1162
- type: "contain",
1163
- withoutSave: !0
1164
- }) : n === "image-cover" && (L > F || y > U) && c.fitObject({
1165
- object: M,
1166
- type: "cover",
1167
- withoutSave: !0
1168
- });
1080
+ const { width: v, height: y } = n, L = this.calculateScaleFactor({ imageObject: M, scaleType: t });
1081
+ t === "image-contain" && L < 1 ? o.fitObject({ object: M, type: "contain", withoutSave: !0 }) : t === "image-cover" && (j > v || w > y) && o.fitObject({ object: M, type: "cover", withoutSave: !0 });
1169
1082
  }
1170
- s.add(M), s.centerObject(M), s.setActiveObject(M), s.renderAll(), u.resumeHistory(), i || u.saveState();
1171
- var V = {
1083
+ i.add(M), i.centerObject(M), i.setActiveObject(M), i.renderAll(), c.resumeHistory(), a || c.saveState();
1084
+ const I = {
1172
1085
  image: M,
1173
1086
  format: h,
1174
- contentType: d,
1175
- scale: n,
1176
- withoutSave: i,
1177
- source: a
1087
+ contentType: l,
1088
+ scale: t,
1089
+ withoutSave: a,
1090
+ source: e
1178
1091
  };
1179
- return s.fire("editor:image-imported", V), V;
1180
- } catch (H) {
1181
- return l.emitError({
1092
+ return i.fire("editor:image-imported", I), I;
1093
+ } catch (m) {
1094
+ return d.emitError({
1182
1095
  origin: "ImageManager",
1183
1096
  method: "importImage",
1184
1097
  code: "IMPORT_FAILED",
1185
- message: "Ошибка импорта изображения: ".concat(H.message),
1186
- data: {
1187
- source: a,
1188
- format: h,
1189
- contentType: d,
1190
- scale: n,
1191
- withoutSave: i
1192
- }
1193
- }), u.resumeHistory(), null;
1098
+ message: `Ошибка импорта изображения: ${m.message}`,
1099
+ data: { source: e, format: h, contentType: l, scale: t, withoutSave: a }
1100
+ }), c.resumeHistory(), null;
1194
1101
  }
1195
- })();
1102
+ });
1196
1103
  }
1197
1104
  /**
1198
1105
  * Функция для ресайза изображения до максимальных размеров,
1199
1106
  * если оно их превышает. Сохраняет пропорции.
1200
1107
  *
1201
- * @param {HTMLImageElement} imageEl - HTML элемент изображения
1108
+ * @param {string} dataURL - dataURL изображения
1202
1109
  * @param {string} [size='max | min'] - максимальный или минимальный размер
1203
- * @returns {Promise<string>} - возвращает Promise с новым dataURL
1204
- */
1205
- resizeImageToBoundaries(e) {
1206
- var t = arguments, a = this;
1207
- return k(function* () {
1208
- var n = t.length > 1 && t[1] !== void 0 ? t[1] : "max", i = "Размер изображения больше максимального размера канваса, поэтому оно будет уменьшено до максимальных размеров c сохранением пропорций: ".concat(w, "x").concat(O);
1209
- n === "min" && (i = "Размер изображения меньше минимального размера канваса, поэтому оно будет увеличено до минимальных размеров c сохранением пропорций: ".concat(x, "x").concat(B));
1210
- var s = {
1110
+ * @returns {Promise<Blob>} - возвращает Promise с Blob-объектом уменьшенного изображения
1111
+ */
1112
+ resizeImageToBoundaries(e, t = "max") {
1113
+ return b(this, null, function* () {
1114
+ let a = `Размер изображения больше максимального размера канваса, поэтому оно будет уменьшено до максимальных размеров c сохранением пропорций: ${O}x${T}`;
1115
+ t === "min" && (a = `Размер изображения меньше минимального размера канваса, поэтому оно будет увеличено до минимальных размеров c сохранением пропорций: ${B}x${U}`);
1116
+ const s = {
1211
1117
  dataURL: e,
1212
- sizeType: n,
1213
- maxWidth: w,
1214
- maxHeight: O,
1215
- minWidth: x,
1216
- minHeight: B
1118
+ sizeType: t,
1119
+ maxWidth: O,
1120
+ maxHeight: T,
1121
+ minWidth: B,
1122
+ minHeight: U
1217
1123
  };
1218
- return a.editor.errorManager.emitWarning({
1124
+ return this.editor.errorManager.emitWarning({
1219
1125
  origin: "ImageManager",
1220
1126
  method: "resizeImageToBoundaries",
1221
1127
  code: "IMAGE_RESIZE_WARNING",
1222
- message: i,
1128
+ message: a,
1223
1129
  data: s
1224
- }), a.editor.workerManager.post("resizeImage", s);
1225
- })();
1130
+ }), this.editor.workerManager.post("resizeImage", s);
1131
+ });
1226
1132
  }
1227
1133
  /**
1228
1134
  * Экспорт изображения в файл – экспортируется содержимое монтажной области.
1229
1135
  * Независимо от текущего зума, экспортируется монтажная область в исходном масштабе. Можно экспортировать как base64.
1230
- * @param {Object} options - опции
1231
- * @param {string} options.fileName - имя файла
1232
- * @param {string} options.contentType - тип контента
1233
- * @param {Boolean} options.exportAsBase64 - экспортировать как base64
1234
- * @param {Boolean} options.exportAsBlob - экспортировать как blob
1235
- * @returns {Promise<File> | String} - файл или base64
1136
+ * @param options - опции
1137
+ * @param options.fileName - имя файла
1138
+ * @param options.contentType - тип контента
1139
+ * @param options.exportAsBase64 - экспортировать как base64
1140
+ * @param options.exportAsBlob - экспортировать как blob
1141
+ * @returns возвращает Promise с объектом файла или null в случае ошибки
1236
1142
  * @fires editor:canvas-exported
1237
1143
  */
1238
1144
  exportCanvasAsImageFile() {
1239
- var e = arguments, t = this;
1240
- return k(function* () {
1241
- var {
1242
- fileName: a = "image.png",
1243
- contentType: n = "image/png",
1244
- exportAsBase64: i = !1,
1245
- exportAsBlob: s = !1
1246
- } = e.length > 0 && e[0] !== void 0 ? e[0] : {}, {
1247
- canvas: r,
1248
- montageArea: c,
1249
- workerManager: u
1250
- } = t.editor;
1145
+ return b(this, arguments, function* ({
1146
+ fileName: e = "image.png",
1147
+ contentType: t = "image/png",
1148
+ exportAsBase64: a = !1,
1149
+ exportAsBlob: s = !1
1150
+ } = {}) {
1151
+ const { canvas: i, montageArea: n, workerManager: o } = this.editor;
1251
1152
  try {
1252
- var l = n === "application/pdf", d = l ? "image/jpg" : n, h = D.getFormatFromContentType(d);
1253
- c.setCoords();
1254
- var {
1255
- left: g,
1256
- top: v,
1257
- width: f,
1258
- height: m
1259
- } = c.getBoundingRect(), M = yield r.clone(["id", "format", "locked"]);
1153
+ const c = t === "application/pdf", d = c ? "image/jpg" : t, l = C.getFormatFromContentType(d);
1154
+ n.setCoords();
1155
+ const { left: h, top: g, width: u, height: m } = n.getBoundingRect(), M = yield i.clone(["id", "format", "locked"]);
1260
1156
  ["image/jpg", "image/jpeg"].includes(d) && (M.backgroundColor = "#ffffff");
1261
- var S = M.getObjects().find((p) => p.id === c.id);
1262
- S.visible = !1, M.viewportTransform = [1, 0, 0, 1, -g, -v], M.setDimensions({
1263
- width: f,
1264
- height: m
1265
- }, {
1266
- backstoreOnly: !0
1267
- }), M.renderAll();
1268
- var N = M.getObjects().filter((p) => p.format).every((p) => p.format === "svg");
1269
- if (h === "svg" && N) {
1270
- var E = M.toSVG();
1157
+ const j = M.getObjects().find((f) => f.id === n.id);
1158
+ j && (j.visible = !1), M.viewportTransform = [1, 0, 0, 1, -h, -g], M.setDimensions({ width: u, height: m }, { backstoreOnly: !0 }), M.renderAll();
1159
+ const w = M.getObjects().filter((f) => f.format).every((f) => f.format === "svg");
1160
+ if (l === "svg" && w) {
1161
+ const f = M.toSVG();
1271
1162
  M.dispose();
1272
- var L = D._exportSVGStringAsFile(E, {
1273
- exportAsBase64: i,
1274
- exportAsBlob: s,
1275
- fileName: a
1276
- }), y = {
1277
- image: L,
1163
+ const A = {
1164
+ image: C._exportSVGStringAsFile(f, {
1165
+ exportAsBase64: a,
1166
+ exportAsBlob: s,
1167
+ fileName: e
1168
+ }),
1278
1169
  format: "svg",
1279
1170
  contentType: "image/svg+xml",
1280
- fileName: a.replace(/\.[^/.]+$/, ".svg")
1171
+ fileName: e.replace(/\.[^/.]+$/, ".svg")
1281
1172
  };
1282
- return r.fire("editor:canvas-exported", y), y;
1173
+ return i.fire("editor:canvas-exported", A), A;
1283
1174
  }
1284
- var b = yield new Promise((p) => {
1285
- M.getElement().toBlob(p);
1175
+ const I = yield new Promise((f, x) => {
1176
+ M.getElement().toBlob((A) => {
1177
+ A ? f(A) : x(new Error("Failed to create Blob from canvas"));
1178
+ });
1286
1179
  });
1287
1180
  if (M.dispose(), s) {
1288
- var Z = {
1289
- image: b,
1290
- format: h,
1181
+ const f = {
1182
+ image: I,
1183
+ format: l,
1291
1184
  contentType: d,
1292
- fileName: a
1185
+ fileName: e
1293
1186
  };
1294
- return r.fire("editor:canvas-exported", Z), Z;
1187
+ return i.fire("editor:canvas-exported", f), f;
1295
1188
  }
1296
- var W = yield createImageBitmap(b), z = yield u.post("toDataURL", {
1297
- format: h,
1298
- quality: 1,
1299
- bitmap: W
1300
- }, [W]);
1301
- if (l) {
1302
- var F = 0.264583, U = f * F, _ = m * F, V = (yield t.editor.moduleLoader.loadModule("jspdf")).jsPDF, H = new V({
1303
- orientation: U > _ ? "landscape" : "portrait",
1189
+ const v = yield createImageBitmap(I), y = yield o.post(
1190
+ "toDataURL",
1191
+ { format: l, quality: 1, bitmap: v },
1192
+ [v]
1193
+ );
1194
+ if (c) {
1195
+ const x = u * 0.264583, A = m * 0.264583, me = (yield this.editor.moduleLoader.loadModule("jspdf")).jsPDF, G = new me({
1196
+ orientation: x > A ? "landscape" : "portrait",
1304
1197
  unit: "mm",
1305
- format: [U, _]
1198
+ format: [x, A]
1306
1199
  });
1307
- if (H.addImage(z, "JPG", 0, 0, U, _), i) {
1308
- var De = H.output("datauristring"), le = {
1309
- image: De,
1200
+ if (G.addImage(y, "JPG", 0, 0, x, A), a) {
1201
+ const ne = {
1202
+ image: G.output("datauristring"),
1310
1203
  format: "pdf",
1311
1204
  contentType: "application/pdf",
1312
- fileName: a
1205
+ fileName: e
1313
1206
  };
1314
- return r.fire("editor:canvas-exported", le), le;
1207
+ return i.fire("editor:canvas-exported", ne), ne;
1315
1208
  }
1316
- var Ne = H.output("blob"), Ee = new File([Ne], a, {
1317
- type: "application/pdf"
1318
- }), he = {
1319
- image: Ee,
1209
+ const je = G.output("blob"), ie = {
1210
+ image: new File([je], e, { type: "application/pdf" }),
1320
1211
  format: "pdf",
1321
1212
  contentType: "application/pdf",
1322
- fileName: a
1213
+ fileName: e
1323
1214
  };
1324
- return r.fire("editor:canvas-exported", he), he;
1215
+ return i.fire("editor:canvas-exported", ie), ie;
1325
1216
  }
1326
- if (i) {
1327
- var ge = {
1328
- image: z,
1329
- format: h,
1217
+ if (a) {
1218
+ const f = {
1219
+ image: y,
1220
+ format: l,
1330
1221
  contentType: d,
1331
- fileName: a
1222
+ fileName: e
1332
1223
  };
1333
- return r.fire("editor:canvas-exported", ge), ge;
1224
+ return i.fire("editor:canvas-exported", f), f;
1334
1225
  }
1335
- var Me = h === "svg" && !N ? a.replace(/\.[^/.]+$/, ".png") : a, Le = new File([b], Me, {
1336
- type: d
1337
- }), ve = {
1338
- image: Le,
1339
- format: h,
1226
+ const L = l === "svg" && !w ? e.replace(/\.[^/.]+$/, ".png") : e, se = {
1227
+ image: new File([I], L, { type: d }),
1228
+ format: l,
1340
1229
  contentType: d,
1341
- fileName: Me
1230
+ fileName: L
1342
1231
  };
1343
- return r.fire("editor:canvas-exported", ve), ve;
1344
- } catch (p) {
1345
- return t.editor.errorManager.emitError({
1232
+ return i.fire("editor:canvas-exported", se), se;
1233
+ } catch (c) {
1234
+ return this.editor.errorManager.emitError({
1346
1235
  origin: "ImageManager",
1347
1236
  method: "exportCanvasAsImageFile",
1348
1237
  code: "IMAGE_EXPORT_FAILED",
1349
- message: "Ошибка экспорта изображения: ".concat(p.message),
1350
- data: {
1351
- contentType: n,
1352
- fileName: a,
1353
- exportAsBase64: i,
1354
- exportAsBlob: s
1355
- }
1356
- }), "";
1238
+ message: `Ошибка экспорта изображения: ${c.message}`,
1239
+ data: { contentType: t, fileName: e, exportAsBase64: a, exportAsBlob: s }
1240
+ }), null;
1357
1241
  }
1358
- })();
1242
+ });
1359
1243
  }
1360
1244
  /**
1361
1245
  * Экспорт выбранного объекта в виде изображения или base64
1362
- * @param {Object} options - опции
1363
- * @param {fabric.Object} options.object - объект для экспорта
1364
- * @param {String} options.fileName - имя файла
1365
- * @param {String} options.contentType - тип контента
1366
- * @param {Boolean} options.exportAsBase64 - экспортировать как base64
1367
- * @param {Boolean} options.exportAsBlob - экспортировать как blob
1368
- * @returns {String} base64
1246
+ * @param options - опции
1247
+ * @param options.object - объект для экспорта
1248
+ * @param options.fileName - имя файла
1249
+ * @param options.contentType - тип контента
1250
+ * @param options.exportAsBase64 - экспортировать как base64
1251
+ * @param options.exportAsBlob - экспортировать как blob
1252
+ * @returns - возвращает Promise с объектом файла или null в случае ошибки
1369
1253
  * @fires editor:object-exported
1370
1254
  */
1371
1255
  exportObjectAsImageFile() {
1372
- var e = arguments, t = this;
1373
- return k(function* () {
1374
- var {
1375
- object: a,
1376
- fileName: n = "image.png",
1377
- contentType: i = "image/png",
1378
- exportAsBase64: s = !1,
1379
- exportAsBlob: r = !1
1380
- } = e.length > 0 && e[0] !== void 0 ? e[0] : {}, {
1381
- canvas: c,
1382
- workerManager: u
1383
- } = t.editor, l = a || c.getActiveObject();
1384
- if (!l)
1385
- return t.editor.errorManager.emitError({
1256
+ return b(this, arguments, function* ({
1257
+ object: e,
1258
+ fileName: t = "image.png",
1259
+ contentType: a = "image/png",
1260
+ exportAsBase64: s = !1,
1261
+ exportAsBlob: i = !1
1262
+ } = {}) {
1263
+ const { canvas: n, workerManager: o } = this.editor, c = e || n.getActiveObject();
1264
+ if (!c)
1265
+ return this.editor.errorManager.emitError({
1386
1266
  origin: "ImageManager",
1387
1267
  method: "exportObjectAsImageFile",
1388
1268
  code: "NO_OBJECT_SELECTED",
1389
1269
  message: "Не выбран объект для экспорта",
1390
- data: {
1391
- contentType: i,
1392
- fileName: n,
1393
- exportAsBase64: s,
1394
- exportAsBlob: r
1395
- }
1396
- }), "";
1270
+ data: { contentType: a, fileName: t, exportAsBase64: s, exportAsBlob: i }
1271
+ }), null;
1397
1272
  try {
1398
- var d = D.getFormatFromContentType(i);
1273
+ const d = C.getFormatFromContentType(a);
1399
1274
  if (d === "svg") {
1400
- var h = l.toSVG(), g = t._exportSVGStringAsFile(h, {
1275
+ const m = c.toSVG(), M = C._exportSVGStringAsFile(m, {
1401
1276
  exportAsBase64: s,
1402
- exportAsBlob: r,
1403
- fileName: n
1404
- }), v = {
1405
- image: g,
1277
+ exportAsBlob: i,
1278
+ fileName: t
1279
+ }), j = {
1280
+ object: c,
1281
+ image: M,
1406
1282
  format: d,
1407
1283
  contentType: "image/svg+xml",
1408
- fileName: n.replace(/\.[^/.]+$/, ".svg")
1284
+ fileName: t.replace(/\.[^/.]+$/, ".svg")
1409
1285
  };
1410
- return c.fire("editor:object-exported", v), v;
1286
+ return n.fire("editor:object-exported", j), j;
1411
1287
  }
1412
- if (s) {
1413
- var f = yield createImageBitmap(l._element), m = yield u.post("toDataURL", {
1414
- format: d,
1415
- quality: 1,
1416
- bitmap: f
1417
- }, [f]), M = {
1418
- image: m,
1288
+ if (s && c instanceof Z) {
1289
+ const m = yield createImageBitmap(c.getElement()), M = yield o.post(
1290
+ "toDataURL",
1291
+ {
1292
+ format: d,
1293
+ quality: 1,
1294
+ bitmap: m
1295
+ },
1296
+ [m]
1297
+ ), j = {
1298
+ object: c,
1299
+ image: M,
1419
1300
  format: d,
1420
- contentType: i,
1421
- fileName: n
1301
+ contentType: a,
1302
+ fileName: t
1422
1303
  };
1423
- return c.fire("editor:object-exported", M), M;
1304
+ return n.fire("editor:object-exported", j), j;
1424
1305
  }
1425
- var S = l.toCanvasElement(), N = yield new Promise((b) => {
1426
- S.toBlob(b);
1306
+ const l = c.toCanvasElement(), h = yield new Promise((m, M) => {
1307
+ l.toBlob((j) => {
1308
+ j ? m(j) : M(new Error("Failed to create Blob from canvas"));
1309
+ });
1427
1310
  });
1428
- if (r) {
1429
- var E = {
1430
- image: N,
1311
+ if (i) {
1312
+ const m = {
1313
+ object: c,
1314
+ image: h,
1431
1315
  format: d,
1432
- contentType: i,
1433
- fileName: n
1316
+ contentType: a,
1317
+ fileName: t
1434
1318
  };
1435
- return c.fire("editor:object-exported", E), E;
1319
+ return n.fire("editor:object-exported", m), m;
1436
1320
  }
1437
- var L = new File([N], n, {
1438
- type: i
1439
- }), y = {
1440
- image: L,
1321
+ const g = new File([h], t, { type: a }), u = {
1322
+ object: c,
1323
+ image: g,
1441
1324
  format: d,
1442
- contentType: i,
1443
- fileName: n
1325
+ contentType: a,
1326
+ fileName: t
1444
1327
  };
1445
- return c.fire("editor:object-exported", y), y;
1446
- } catch (b) {
1447
- return t.editor.errorManager.emitError({
1328
+ return n.fire("editor:object-exported", u), u;
1329
+ } catch (d) {
1330
+ return this.editor.errorManager.emitError({
1448
1331
  origin: "ImageManager",
1449
1332
  method: "exportObjectAsImageFile",
1450
1333
  code: "IMAGE_EXPORT_FAILED",
1451
- message: "Ошибка экспорта объекта: ".concat(b.message),
1452
- data: {
1453
- contentType: i,
1454
- fileName: n,
1455
- exportAsBase64: s,
1456
- exportAsBlob: r
1457
- }
1458
- }), "";
1334
+ message: `Ошибка экспорта объекта: ${d.message}`,
1335
+ data: { contentType: a, fileName: t, exportAsBase64: s, exportAsBlob: i }
1336
+ }), null;
1459
1337
  }
1460
- })();
1338
+ });
1461
1339
  }
1462
1340
  /**
1463
1341
  * Удаляет все созданные blobURL
1464
- * @returns {void}
1465
1342
  */
1466
1343
  revokeBlobUrls() {
1467
1344
  this._createdBlobUrls.forEach(URL.revokeObjectURL), this._createdBlobUrls = [];
1468
1345
  }
1469
- /**
1470
- * Преобразует SVG-строку в Blob, файл, или base64
1471
- * @param {string} svgString - SVG-строка
1472
- * @param {Object} options - опции
1473
- * @param {Boolean} options.exportAsBase64 - экспортировать как base64
1474
- * @param {Boolean} options.exportAsBlob - экспортировать как blob
1475
- * @param {String} options.fileName - имя файла
1476
- * @returns {Blob|String|File} - Blob, base64 или файл
1477
- * @private
1478
- * @static
1479
- */
1480
- static _exportSVGStringAsFile(e) {
1481
- var {
1482
- exportAsBase64: t,
1483
- exportAsBlob: a,
1484
- fileName: n
1485
- } = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};
1486
- return a ? new Blob([e], {
1487
- type: "image/svg+xml"
1488
- }) : t ? "data:image/svg+xml;base64,".concat(btoa(e)) : new File([e], n.replace(/\.[^/.]+$/, ".svg"), {
1489
- type: "image/svg+xml"
1490
- });
1491
- }
1492
1346
  /**
1493
1347
  * Получает список допустимых форматов изображений
1494
- * @returns {string[]} - массив допустимых форматов изображений
1348
+ * @returns массив допустимых форматов изображений
1495
1349
  */
1496
1350
  getAllowedFormatsFromContentTypes() {
1497
- return this.acceptContentTypes.map((e) => D.getFormatFromContentType(e)).filter((e) => e);
1498
- }
1499
- /**
1500
- * Извлекает чистый формат (subtype) из contentType,
1501
- * отбросив любую часть после «+» или «;»
1502
- * @param {string} contentType
1503
- * @returns {string} формат, например 'png', 'jpeg', 'svg'
1504
- * @static
1505
- */
1506
- static getFormatFromContentType() {
1507
- var e = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : "", t = e.match(/^[^/]+\/([^+;]+)/);
1508
- return t ? t[1] : "";
1351
+ return this.acceptContentTypes.map((e) => C.getFormatFromContentType(e)).filter((e) => e);
1509
1352
  }
1510
1353
  /**
1511
1354
  * Проверяет, является ли contentType допустимым типом изображения.
1512
- * @param {string} contentType - тип контента
1513
- * @returns {boolean} true, если contentType допустим, иначе false
1355
+ * @returns true, если contentType допустим, иначе false
1514
1356
  */
1515
- isAllowedContentType() {
1516
- var e = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : "";
1357
+ isAllowedContentType(e = "") {
1517
1358
  return this.acceptContentTypes.includes(e);
1518
1359
  }
1519
1360
  /**
1520
1361
  * Получает contentType изображения из источника
1521
- * @param {File|string} source - URL изображения или объект File
1522
- * @returns {Promise<string>|string} - MIME-тип изображения
1362
+ * @param source - URL изображения или объект File
1363
+ * @returns MIME-тип изображения
1523
1364
  * @public
1524
1365
  */
1525
1366
  getContentType(e) {
1526
- var t = this;
1527
- return k(function* () {
1528
- return typeof e == "string" ? t.getContentTypeFromUrl(e) : e.type || "application/octet-stream";
1529
- })();
1367
+ return b(this, null, function* () {
1368
+ return typeof e == "string" ? this.getContentTypeFromUrl(e) : e.type || "application/octet-stream";
1369
+ });
1530
1370
  }
1531
1371
  /**
1532
1372
  * Получает contentType изображения через HTTP HEAD запрос или анализ URL
1533
- * @param {string} src - URL изображения
1534
- * @returns {Promise<string>} - MIME-тип изображения
1373
+ * @param src - URL изображения
1374
+ * @returns MIME-тип изображения
1535
1375
  * @public
1536
1376
  */
1537
1377
  getContentTypeFromUrl(e) {
1538
- var t = this;
1539
- return k(function* () {
1378
+ return b(this, null, function* () {
1540
1379
  if (e.startsWith("data:")) {
1541
- var a = e.match(/^data:([^;]+)/);
1542
- return a ? a[1] : "application/octet-stream";
1380
+ const t = e.match(/^data:([^;]+)/);
1381
+ return t ? t[1] : "application/octet-stream";
1543
1382
  }
1544
1383
  try {
1545
- var n = yield fetch(e, {
1546
- method: "HEAD"
1547
- }), i = n.headers.get("content-type");
1548
- if (i && i.startsWith("image/"))
1549
- return i.split(";")[0];
1550
- } catch (s) {
1551
- console.warn("HEAD запрос неудачен, определяем тип по расширению:", s);
1384
+ const a = (yield fetch(e, { method: "HEAD" })).headers.get("content-type");
1385
+ if (a && a.startsWith("image/"))
1386
+ return a.split(";")[0];
1387
+ } catch (t) {
1388
+ console.warn("HEAD запрос неудачен, определяем тип по расширению:", t);
1552
1389
  }
1553
- return t.getContentTypeFromExtension(e);
1554
- })();
1390
+ return this.getContentTypeFromExtension(e);
1391
+ });
1555
1392
  }
1556
1393
  /**
1557
1394
  * Определяет contentType по расширению файла в URL
1558
- * @param {string} url - URL файла
1559
- * @returns {string} - MIME-тип
1395
+ * @param url - URL файла
1396
+ * @returns - MIME-тип
1560
1397
  * @public
1561
1398
  */
1562
1399
  getContentTypeFromExtension(e) {
1400
+ var t;
1563
1401
  try {
1564
- var t, a = new URL(e), n = (t = a.pathname.split(".").pop()) === null || t === void 0 ? void 0 : t.toLowerCase(), i = {};
1565
- return this.acceptContentTypes.forEach((s) => {
1566
- var r = D.getFormatFromContentType(s);
1567
- r && (i[r] = s);
1568
- }), i[n] || "application/octet-stream";
1569
- } catch (s) {
1570
- return console.warn("Не удалось определить расширение из URL:", e, s), "application/octet-stream";
1402
+ const s = (t = new URL(e).pathname.split(".").pop()) == null ? void 0 : t.toLowerCase(), i = {};
1403
+ return this.acceptContentTypes.forEach((n) => {
1404
+ const o = C.getFormatFromContentType(n);
1405
+ o && (i[o] = n);
1406
+ }), s && i[s] || "application/octet-stream";
1407
+ } catch (a) {
1408
+ return console.warn("Не удалось определить расширение из URL:", e, a), "application/octet-stream";
1571
1409
  }
1572
1410
  }
1573
1411
  /**
1574
1412
  * Рассчитывает коэффициент масштабирования изображения.
1575
- * @param {object} imageObject - объект изображения
1576
- * @param {string} scaleType - тип масштабирования ('contain' или 'cover')
1577
- * @returns {number} коэффициент масштабирования
1413
+ * @param options - опции
1414
+ * @param options.imageObject - объект изображения
1415
+ * @param options.scaleType - тип масштабирования ('contain' или 'cover')
1416
+ * @returns коэффициент масштабирования
1578
1417
  */
1579
- calculateScaleFactor(e) {
1580
- var {
1581
- imageObject: t,
1582
- scaleType: a = "contain"
1583
- } = e, {
1584
- montageArea: n
1585
- } = this.editor;
1586
- if (!n || !t) return 1;
1587
- var i = n.width, s = n.height, {
1588
- width: r,
1589
- height: c
1590
- } = t;
1591
- return a === "contain" || a === "image-contain" ? Math.min(i / r, s / c) : a === "cover" || a === "image-cover" ? Math.max(i / r, s / c) : 1;
1418
+ calculateScaleFactor({
1419
+ imageObject: e,
1420
+ scaleType: t = "contain"
1421
+ }) {
1422
+ const { montageArea: a } = this.editor;
1423
+ if (!a || !e) return 1;
1424
+ const s = a.width, i = a.height, { width: n, height: o } = e;
1425
+ return t === "contain" || t === "image-contain" ? Math.min(s / n, i / o) : t === "cover" || t === "image-cover" ? Math.max(s / n, i / o) : 1;
1426
+ }
1427
+ /**
1428
+ * Преобразует SVG-строку в Blob, файл, или base64
1429
+ * @param svgString - SVG-строка
1430
+ * @param options - опции
1431
+ * @param options.exportAsBase64 - экспортировать как base64
1432
+ * @param options.exportAsBlob - экспортировать как blob
1433
+ * @param options.fileName - имя файла
1434
+ * @returns Blob, base64 или файл
1435
+ * @private
1436
+ * @static
1437
+ */
1438
+ static _exportSVGStringAsFile(e, {
1439
+ exportAsBase64: t,
1440
+ exportAsBlob: a,
1441
+ fileName: s = "image.svg"
1442
+ } = {}) {
1443
+ return a ? new Blob([e], { type: "image/svg+xml" }) : t ? `data:image/svg+xml;base64,${window.btoa(encodeURIComponent(e))}` : new File([e], s.replace(/\.[^/.]+$/, ".svg"), { type: "image/svg+xml" });
1444
+ }
1445
+ /**
1446
+ * Извлекает чистый формат (subtype) из contentType,
1447
+ * отбросив любую часть после «+» или «;»
1448
+ * @param contentType
1449
+ * @returns формат, например 'png', 'jpeg', 'svg'
1450
+ * @static
1451
+ */
1452
+ static getFormatFromContentType(e = "") {
1453
+ const t = e.match(/^[^/]+\/([^+;]+)/);
1454
+ return t ? t[1] : "";
1592
1455
  }
1593
1456
  }
1594
- class mt {
1457
+ class st {
1595
1458
  /**
1596
1459
  * @param {object} options
1597
1460
  * @param {ImageEditor} options.editor – экземпляр редактора
@@ -1608,25 +1471,25 @@ class mt {
1608
1471
  * @param {Boolean} [options.adaptCanvasToContainer] - Адаптировать канвас к контейнеру
1609
1472
  * @fires editor:resolution-width-changed
1610
1473
  */
1611
- setResolutionWidth(e, { preserveProportional: t, withoutSave: a, adaptCanvasToContainer: n } = {}) {
1612
- var v;
1474
+ setResolutionWidth(e, { preserveProportional: t, withoutSave: a, adaptCanvasToContainer: s } = {}) {
1475
+ var m;
1613
1476
  if (!e) return;
1614
1477
  const {
1615
1478
  canvas: i,
1616
- montageArea: s,
1617
- options: { canvasBackstoreWidth: r }
1618
- } = this.editor, { width: c, height: u } = s, l = Math.max(Math.min(Number(e), w), x);
1619
- if (!r || r === "auto" || n ? this.adaptCanvasToContainer() : r ? this.setCanvasBackstoreWidth(Number(r)) : this.setCanvasBackstoreWidth(l), s.set({ width: l }), (v = i.clipPath) == null || v.set({ width: l }), t) {
1620
- const f = l / c, m = u * f;
1621
- this.setResolutionHeight(m);
1479
+ montageArea: n,
1480
+ options: { canvasBackstoreWidth: o }
1481
+ } = this.editor, { width: c, height: d } = n, l = Math.max(Math.min(Number(e), O), B);
1482
+ if (!o || o === "auto" || s ? this.adaptCanvasToContainer() : o ? this.setCanvasBackstoreWidth(Number(o)) : this.setCanvasBackstoreWidth(l), n.set({ width: l }), (m = i.clipPath) == null || m.set({ width: l }), t) {
1483
+ const M = l / c, j = d * M;
1484
+ this.setResolutionHeight(j);
1622
1485
  return;
1623
1486
  }
1624
- const { left: d, top: h } = this.getObjectDefaultCoords(s), g = i.getZoom();
1625
- i.setViewportTransform([g, 0, 0, g, d, h]), this.centerMontageArea(), a || this.editor.historyManager.saveState(), i.fire("editor:resolution-width-changed", {
1487
+ const { left: h, top: g } = this.getObjectDefaultCoords(n), u = i.getZoom();
1488
+ i.setViewportTransform([u, 0, 0, u, h, g]), this.centerMontageArea(), a || this.editor.historyManager.saveState(), i.fire("editor:resolution-width-changed", {
1626
1489
  width: l,
1627
1490
  preserveProportional: t,
1628
1491
  withoutSave: a,
1629
- adaptCanvasToContainer: n
1492
+ adaptCanvasToContainer: s
1630
1493
  });
1631
1494
  }
1632
1495
  /**
@@ -1638,25 +1501,25 @@ class mt {
1638
1501
  * @param {Boolean} [options.adaptCanvasToContainer] - Адаптировать канвас к контейнеру
1639
1502
  * @fires editor:resolution-height-changed
1640
1503
  */
1641
- setResolutionHeight(e, { preserveProportional: t, withoutSave: a, adaptCanvasToContainer: n } = {}) {
1642
- var v;
1504
+ setResolutionHeight(e, { preserveProportional: t, withoutSave: a, adaptCanvasToContainer: s } = {}) {
1505
+ var m;
1643
1506
  if (!e) return;
1644
1507
  const {
1645
1508
  canvas: i,
1646
- montageArea: s,
1647
- options: { canvasBackstoreHeight: r }
1648
- } = this.editor, { width: c, height: u } = s, l = Math.max(Math.min(Number(e), O), B);
1649
- if (!r || r === "auto" || n ? this.adaptCanvasToContainer() : r ? this.setCanvasBackstoreHeight(Number(r)) : this.setCanvasBackstoreHeight(l), s.set({ height: l }), (v = i.clipPath) == null || v.set({ height: l }), t) {
1650
- const f = l / u, m = c * f;
1651
- this.setResolutionWidth(m);
1509
+ montageArea: n,
1510
+ options: { canvasBackstoreHeight: o }
1511
+ } = this.editor, { width: c, height: d } = n, l = Math.max(Math.min(Number(e), T), U);
1512
+ if (!o || o === "auto" || s ? this.adaptCanvasToContainer() : o ? this.setCanvasBackstoreHeight(Number(o)) : this.setCanvasBackstoreHeight(l), n.set({ height: l }), (m = i.clipPath) == null || m.set({ height: l }), t) {
1513
+ const M = l / d, j = c * M;
1514
+ this.setResolutionWidth(j);
1652
1515
  return;
1653
1516
  }
1654
- const { left: d, top: h } = this.getObjectDefaultCoords(s), g = i.getZoom();
1655
- i.setViewportTransform([g, 0, 0, g, d, h]), this.centerMontageArea(), a || this.editor.historyManager.saveState(), i.fire("editor:resolution-height-changed", {
1517
+ const { left: h, top: g } = this.getObjectDefaultCoords(n), u = i.getZoom();
1518
+ i.setViewportTransform([u, 0, 0, u, h, g]), this.centerMontageArea(), a || this.editor.historyManager.saveState(), i.fire("editor:resolution-height-changed", {
1656
1519
  height: l,
1657
1520
  preserveProportional: t,
1658
1521
  withoutSave: a,
1659
- adaptCanvasToContainer: n
1522
+ adaptCanvasToContainer: s
1660
1523
  });
1661
1524
  }
1662
1525
  /**
@@ -1665,16 +1528,16 @@ class mt {
1665
1528
  */
1666
1529
  centerMontageArea() {
1667
1530
  var c;
1668
- const { canvas: e, montageArea: t } = this.editor, a = e.getWidth(), n = e.getHeight(), i = e.getZoom(), s = new K(a / 2, n / 2);
1531
+ const { canvas: e, montageArea: t } = this.editor, a = e.getWidth(), s = e.getHeight(), i = e.getZoom(), n = new W(a / 2, s / 2);
1669
1532
  t.set({
1670
1533
  left: a / 2,
1671
- top: n / 2
1534
+ top: s / 2
1672
1535
  }), (c = e.clipPath) == null || c.set({
1673
1536
  left: a / 2,
1674
- top: n / 2
1537
+ top: s / 2
1675
1538
  }), e.renderAll();
1676
- const r = e.viewportTransform;
1677
- r[4] = a / 2 - s.x * i, r[5] = n / 2 - s.y * i, e.setViewportTransform(r), e.renderAll();
1539
+ const o = e.viewportTransform;
1540
+ o[4] = a / 2 - n.x * i, o[5] = s / 2 - n.y * i, e.setViewportTransform(o), e.renderAll();
1678
1541
  }
1679
1542
  /**
1680
1543
  * Метод для получения координат объекта с учетом текущего зума
@@ -1690,8 +1553,8 @@ class mt {
1690
1553
  code: "NO_ACTIVE_OBJECT",
1691
1554
  message: "Не выбран объект для получения координат"
1692
1555
  }), { left: 0, top: 0 };
1693
- const { width: n, height: i } = a, s = t.getZoom(), r = (n - n * s) / 2, c = (i - i * s) / 2;
1694
- return { left: r, top: c };
1556
+ const { width: s, height: i } = a, n = t.getZoom(), o = (s - s * n) / 2, c = (i - i * n) / 2;
1557
+ return { left: o, top: c };
1695
1558
  }
1696
1559
  /**
1697
1560
  * Устанавливаем ширину канваса в backstore (для экспорта)
@@ -1699,7 +1562,7 @@ class mt {
1699
1562
  */
1700
1563
  setCanvasBackstoreWidth(e) {
1701
1564
  if (!e || typeof e != "number") return;
1702
- const t = Math.max(Math.min(e, w), x);
1565
+ const t = Math.max(Math.min(e, O), B);
1703
1566
  this.editor.canvas.setDimensions({ width: t }, { backstoreOnly: !0 });
1704
1567
  }
1705
1568
  /**
@@ -1708,7 +1571,7 @@ class mt {
1708
1571
  */
1709
1572
  setCanvasBackstoreHeight(e) {
1710
1573
  if (!e || typeof e != "number") return;
1711
- const t = Math.max(Math.min(e, O), B);
1574
+ const t = Math.max(Math.min(e, T), U);
1712
1575
  this.editor.canvas.setDimensions({ height: t }, { backstoreOnly: !0 });
1713
1576
  }
1714
1577
  /**
@@ -1717,8 +1580,8 @@ class mt {
1717
1580
  * с учётом минимальных и максимальных значений.
1718
1581
  */
1719
1582
  adaptCanvasToContainer() {
1720
- const { canvas: e } = this.editor, t = e.editorContainer, a = t.clientWidth, n = t.clientHeight, i = Math.max(Math.min(a, w), x), s = Math.max(Math.min(n, O), B);
1721
- console.log("adaptCanvasToContainer newWidth", i), console.log("adaptCanvasToContainer newHeight", s), e.setDimensions({ width: i, height: s }, { backstoreOnly: !0 });
1583
+ const { canvas: e } = this.editor, t = e.editorContainer, a = t.clientWidth, s = t.clientHeight, i = Math.max(Math.min(a, O), B), n = Math.max(Math.min(s, T), U);
1584
+ console.log("adaptCanvasToContainer newWidth", i), console.log("adaptCanvasToContainer newHeight", n), e.setDimensions({ width: i, height: n }, { backstoreOnly: !0 });
1722
1585
  }
1723
1586
  /**
1724
1587
  * Обновляет размеры канваса и вписывает объекты в монтажную область.
@@ -1731,12 +1594,12 @@ class mt {
1731
1594
  selectionManager: t,
1732
1595
  transformManager: a,
1733
1596
  montageArea: {
1734
- width: n,
1597
+ width: s,
1735
1598
  height: i
1736
1599
  }
1737
1600
  } = this.editor;
1738
- this.setResolutionWidth(n, { adaptCanvasToContainer: !0, withoutSave: !0 }), this.setResolutionHeight(i, { adaptCanvasToContainer: !0, withoutSave: !0 }), this.centerMontageArea(), t.selectAll(), a.fitObject({ fitAsOneObject: !0, withoutSave: !0 }), e.fire("editor:canvas-updated", {
1739
- width: n,
1601
+ this.setResolutionWidth(s, { adaptCanvasToContainer: !0, withoutSave: !0 }), this.setResolutionHeight(i, { adaptCanvasToContainer: !0, withoutSave: !0 }), this.centerMontageArea(), t.selectAll(), a.fitObject({ fitAsOneObject: !0, withoutSave: !0 }), e.fire("editor:canvas-updated", {
1602
+ width: s,
1740
1603
  height: i
1741
1604
  });
1742
1605
  }
@@ -1752,11 +1615,11 @@ class mt {
1752
1615
  * @param {Number} zoom — текущее значение zoom (например, 1, 1.2, 2 и т.д.)
1753
1616
  */
1754
1617
  updateCssDimensionsForZoom(e) {
1755
- const { canvas: t, montageArea: a } = this.editor, n = a.width * e, i = a.height * e, s = t.wrapperEl.parentNode;
1756
- if (!(s instanceof HTMLElement)) return;
1757
- const r = n <= s.clientWidth ? "100%" : n, c = i <= s.clientHeight ? "100%" : i;
1618
+ const { canvas: t, montageArea: a } = this.editor, s = a.width * e, i = a.height * e, n = t.wrapperEl.parentNode;
1619
+ if (!(n instanceof HTMLElement)) return;
1620
+ const o = s <= n.clientWidth ? "100%" : s, c = i <= n.clientHeight ? "100%" : i;
1758
1621
  t.setDimensions(
1759
- { width: r, height: c },
1622
+ { width: o, height: c },
1760
1623
  { cssOnly: !0 }
1761
1624
  );
1762
1625
  }
@@ -1843,32 +1706,32 @@ class mt {
1843
1706
  */
1844
1707
  setDisplayDimension({ element: e = "canvas", dimension: t, value: a } = {}) {
1845
1708
  if (!a) return;
1846
- const { canvas: n, options: { editorContainer: i } } = this.editor, s = [];
1709
+ const { canvas: s, options: { editorContainer: i } } = this.editor, n = [];
1847
1710
  switch (e) {
1848
1711
  case "canvas":
1849
- s.push(n.lowerCanvasEl, n.upperCanvasEl);
1712
+ n.push(s.lowerCanvasEl, s.upperCanvasEl);
1850
1713
  break;
1851
1714
  case "wrapper":
1852
- s.push(n.wrapperEl);
1715
+ n.push(s.wrapperEl);
1853
1716
  break;
1854
1717
  case "container":
1855
- s.push(i);
1718
+ n.push(i);
1856
1719
  break;
1857
1720
  default:
1858
- s.push(n.lowerCanvasEl, n.upperCanvasEl);
1721
+ n.push(s.lowerCanvasEl, s.upperCanvasEl);
1859
1722
  }
1860
- const r = t === "width" ? "width" : "height";
1723
+ const o = t === "width" ? "width" : "height";
1861
1724
  if (typeof a == "string") {
1862
- s.forEach((u) => {
1863
- u.style[r] = a;
1725
+ n.forEach((d) => {
1726
+ d.style[o] = a;
1864
1727
  });
1865
1728
  return;
1866
1729
  }
1867
1730
  if (isNaN(a)) return;
1868
1731
  const c = `${a}px`;
1869
- s.forEach((u) => {
1870
- u.style[r] = c;
1871
- }), n.fire(`editor:display-${e}-${r}-changed`, {
1732
+ n.forEach((d) => {
1733
+ d.style[o] = c;
1734
+ }), s.fire(`editor:display-${e}-${o}-changed`, {
1872
1735
  element: e,
1873
1736
  value: a
1874
1737
  });
@@ -1883,28 +1746,28 @@ class mt {
1883
1746
  */
1884
1747
  scaleMontageAreaToImage({ object: e, preserveAspectRatio: t, withoutSave: a } = {}) {
1885
1748
  const {
1886
- canvas: n,
1749
+ canvas: s,
1887
1750
  montageArea: i,
1888
- transformManager: s,
1751
+ transformManager: n,
1889
1752
  options: {
1890
- montageAreaWidth: r,
1753
+ montageAreaWidth: o,
1891
1754
  montageAreaHeight: c
1892
1755
  }
1893
- } = this.editor, u = e || n.getActiveObject();
1894
- if (!u || u.type !== "image" && u.format !== "svg") return;
1895
- const { width: l, height: d } = u;
1896
- let h = Math.min(l, w), g = Math.min(d, O);
1756
+ } = this.editor, d = e || s.getActiveObject();
1757
+ if (!d || d.type !== "image" && d.format !== "svg") return;
1758
+ const { width: l, height: h } = d;
1759
+ let g = Math.min(l, O), u = Math.min(h, T);
1897
1760
  if (t) {
1898
1761
  const {
1899
- width: v,
1900
- height: f
1901
- } = i, m = l / v, M = d / f, S = Math.max(m, M);
1902
- h = v * S, g = f * S;
1762
+ width: m,
1763
+ height: M
1764
+ } = i, j = l / m, w = h / M, I = Math.max(j, w);
1765
+ g = m * I, u = M * I;
1903
1766
  }
1904
- this.setResolutionWidth(h, { withoutSave: !0 }), this.setResolutionHeight(g, { withoutSave: !0 }), (l > r || d > c) && s.calculateAndApplyDefaultZoom(), s.resetObject(u, { withoutSave: !0 }), n.centerObject(u), n.renderAll(), a || this.editor.historyManager.saveState(), n.fire("editor:montage-area-scaled-to-image", {
1905
- object: u,
1906
- width: h,
1907
- height: g,
1767
+ this.setResolutionWidth(g, { withoutSave: !0 }), this.setResolutionHeight(u, { withoutSave: !0 }), (l > o || h > c) && n.calculateAndApplyDefaultZoom(), n.resetObject(d, { withoutSave: !0 }), s.centerObject(d), s.renderAll(), a || this.editor.historyManager.saveState(), s.fire("editor:montage-area-scaled-to-image", {
1768
+ object: d,
1769
+ width: g,
1770
+ height: u,
1908
1771
  preserveAspectRatio: t,
1909
1772
  withoutSave: a
1910
1773
  });
@@ -1927,13 +1790,13 @@ class mt {
1927
1790
  const {
1928
1791
  canvas: t,
1929
1792
  transformManager: a,
1930
- historyManager: n,
1793
+ historyManager: s,
1931
1794
  options: {
1932
1795
  montageAreaWidth: i,
1933
- montageAreaHeight: s
1796
+ montageAreaHeight: n
1934
1797
  }
1935
1798
  } = this.editor;
1936
- a.resetZoom(), this.setResolutionWidth(i, { withoutSave: !0 }), this.setResolutionHeight(s, { withoutSave: !0 }), t.renderAll(), a.resetObjects(), e || n.saveState(), t.fire("editor:default-scale-set");
1799
+ a.resetZoom(), this.setResolutionWidth(i, { withoutSave: !0 }), this.setResolutionHeight(n, { withoutSave: !0 }), t.renderAll(), a.resetObjects(), e || s.saveState(), t.fire("editor:default-scale-set");
1937
1800
  }
1938
1801
  /**
1939
1802
  * Получение всех объектов внутри монтажной области редактора
@@ -1944,9 +1807,9 @@ class mt {
1944
1807
  return e.getObjects().filter((i) => i.id !== t.id && i.id !== a.id);
1945
1808
  }
1946
1809
  }
1947
- class ft {
1810
+ class it {
1948
1811
  constructor({ editor: e }) {
1949
- this.editor = e, this.options = e.options, this.minZoom = this.options.minZoom || ht, this.maxZoom = this.options.maxZoom || gt, this.defaultZoom = this.options.defaultScale, this.maxZoomFactor = this.options.maxZoomFactor;
1812
+ this.editor = e, this.options = e.options, this.minZoom = this.options.minZoom || qe, this.maxZoom = this.options.maxZoom || et, this.defaultZoom = this.options.defaultScale, this.maxZoomFactor = this.options.maxZoomFactor;
1950
1813
  }
1951
1814
  /**
1952
1815
  * Метод рассчитывает и применяет зум по умолчанию для монтажной области редактора.
@@ -1956,10 +1819,10 @@ class ft {
1956
1819
  * @param {Number} [scale] - Желаемый масштаб относительно размеров контейнера редактора.
1957
1820
  */
1958
1821
  calculateAndApplyDefaultZoom(e = this.options.defaultScale) {
1959
- const { canvas: t } = this.editor, a = t.editorContainer, n = a.clientWidth, i = a.clientHeight, { width: s, height: r } = this.editor.montageArea, c = n / s * e, u = i / r * e;
1960
- this.defaultZoom = Math.min(c, u);
1961
- const { defaultZoom: l, maxZoomFactor: d, minZoom: h, maxZoom: g } = this;
1962
- this.minZoom = Math.min(l / d, h), this.maxZoom = Math.max(l * d, g), this.setZoom();
1822
+ const { canvas: t } = this.editor, a = t.editorContainer, s = a.clientWidth, i = a.clientHeight, { width: n, height: o } = this.editor.montageArea, c = s / n * e, d = i / o * e;
1823
+ this.defaultZoom = Math.min(c, d);
1824
+ const { defaultZoom: l, maxZoomFactor: h, minZoom: g, maxZoom: u } = this;
1825
+ this.minZoom = Math.min(l / h, g), this.maxZoom = Math.max(l * h, u), this.setZoom();
1963
1826
  }
1964
1827
  /**
1965
1828
  * Увеличение/уменьшение масштаба
@@ -1970,18 +1833,18 @@ class ft {
1970
1833
  * @fires editor:zoom-changed
1971
1834
  * Если передавать координаты курсора, то нужно быть аккуратнее, так как юзер может выйти за пределы рабочей области
1972
1835
  */
1973
- zoom(e = Mt, t = {}) {
1974
- var h, g;
1836
+ zoom(e = tt, t = {}) {
1837
+ var g, u;
1975
1838
  if (!e) return;
1976
- const { minZoom: a, maxZoom: n } = this, { canvas: i } = this.editor, s = i.getZoom(), r = i.getCenterPoint(), c = (h = t.pointX) != null ? h : r.x, u = (g = t.pointY) != null ? g : r.y, l = new K(c, u);
1977
- let d = Number((s + Number(e)).toFixed(2));
1978
- d > n && (d = n), d < a && (d = a), i.zoomToPoint(l, d), console.log({
1979
- currentZoom: s,
1980
- zoom: d,
1839
+ const { minZoom: a, maxZoom: s } = this, { canvas: i } = this.editor, n = i.getZoom(), o = i.getCenterPoint(), c = (g = t.pointX) != null ? g : o.x, d = (u = t.pointY) != null ? u : o.y, l = new W(c, d);
1840
+ let h = Number((n + Number(e)).toFixed(2));
1841
+ h > s && (h = s), h < a && (h = a), i.zoomToPoint(l, h), console.log({
1842
+ currentZoom: n,
1843
+ zoom: h,
1981
1844
  point: l
1982
1845
  }), i.fire("editor:zoom-changed", {
1983
1846
  currentZoom: i.getZoom(),
1984
- zoom: d,
1847
+ zoom: h,
1985
1848
  point: l
1986
1849
  });
1987
1850
  }
@@ -1991,11 +1854,11 @@ class ft {
1991
1854
  * @fires editor:zoom-changed
1992
1855
  */
1993
1856
  setZoom(e = this.defaultZoom) {
1994
- const { minZoom: t, maxZoom: a } = this, { canvas: n } = this.editor, i = new K(n.getCenterPoint());
1995
- let s = e;
1996
- e > a && (s = a), e < t && (s = t), n.zoomToPoint(i, s), n.fire("editor:zoom-changed", {
1997
- currentZoom: n.getZoom(),
1998
- zoom: s,
1857
+ const { minZoom: t, maxZoom: a } = this, { canvas: s } = this.editor, i = new W(s.getCenterPoint());
1858
+ let n = e;
1859
+ e > a && (n = a), e < t && (n = t), s.zoomToPoint(i, n), s.fire("editor:zoom-changed", {
1860
+ currentZoom: s.getZoom(),
1861
+ zoom: n,
1999
1862
  point: i
2000
1863
  });
2001
1864
  }
@@ -2004,7 +1867,7 @@ class ft {
2004
1867
  * @fires editor:zoom-changed
2005
1868
  */
2006
1869
  resetZoom() {
2007
- const { canvas: e } = this.editor, t = new K(e.getCenterPoint());
1870
+ const { canvas: e } = this.editor, t = new W(e.getCenterPoint());
2008
1871
  e.zoomToPoint(t, this.defaultZoom), this.editor.canvas.fire("editor:zoom-changed", {
2009
1872
  currentZoom: e.getZoom(),
2010
1873
  point: t
@@ -2017,14 +1880,14 @@ class ft {
2017
1880
  * @param {Boolean} options.withoutSave - Не сохранять состояние
2018
1881
  * @fires editor:object-rotated
2019
1882
  */
2020
- rotate(e = vt, { withoutSave: t } = {}) {
2021
- const { canvas: a, historyManager: n } = this.editor, i = a.getActiveObject();
1883
+ rotate(e = at, { withoutSave: t } = {}) {
1884
+ const { canvas: a, historyManager: s } = this.editor, i = a.getActiveObject();
2022
1885
  if (!i) return;
2023
- const s = i.angle + e;
2024
- i.rotate(s), i.setCoords(), a.renderAll(), t || n.saveState(), a.fire("editor:object-rotated", {
1886
+ const n = i.angle + e;
1887
+ i.rotate(n), i.setCoords(), a.renderAll(), t || s.saveState(), a.fire("editor:object-rotated", {
2025
1888
  object: i,
2026
1889
  withoutSave: t,
2027
- angle: s
1890
+ angle: n
2028
1891
  });
2029
1892
  }
2030
1893
  /**
@@ -2034,9 +1897,9 @@ class ft {
2034
1897
  * @fires editor:object-flipped-x
2035
1898
  */
2036
1899
  flipX({ withoutSave: e } = {}) {
2037
- const { canvas: t, historyManager: a } = this.editor, n = t.getActiveObject();
2038
- n && (n.flipX = !n.flipX, t.renderAll(), e || a.saveState(), t.fire("editor:object-flipped-x", {
2039
- object: n,
1900
+ const { canvas: t, historyManager: a } = this.editor, s = t.getActiveObject();
1901
+ s && (s.flipX = !s.flipX, t.renderAll(), e || a.saveState(), t.fire("editor:object-flipped-x", {
1902
+ object: s,
2040
1903
  withoutSave: e
2041
1904
  }));
2042
1905
  }
@@ -2047,9 +1910,9 @@ class ft {
2047
1910
  * @fires editor:object-flipped-y
2048
1911
  */
2049
1912
  flipY({ withoutSave: e } = {}) {
2050
- const { canvas: t, historyManager: a } = this.editor, n = t.getActiveObject();
2051
- n && (n.flipY = !n.flipY, t.renderAll(), e || a.saveState(), t.fire("editor:object-flipped-y", {
2052
- object: n,
1913
+ const { canvas: t, historyManager: a } = this.editor, s = t.getActiveObject();
1914
+ s && (s.flipY = !s.flipY, t.renderAll(), e || a.saveState(), t.fire("editor:object-flipped-y", {
1915
+ object: s,
2053
1916
  withoutSave: e
2054
1917
  }));
2055
1918
  }
@@ -2063,11 +1926,11 @@ class ft {
2063
1926
  opacity: t = 1,
2064
1927
  withoutSave: a
2065
1928
  } = {}) {
2066
- const { canvas: n, historyManager: i } = this.editor, s = e || n.getActiveObject();
2067
- s && (s instanceof T ? s.getObjects().forEach((r) => {
2068
- r.set("opacity", t);
2069
- }) : s.set("opacity", t), n.renderAll(), a || i.saveState(), n.fire("editor:object-opacity-changed", {
2070
- object: s,
1929
+ const { canvas: s, historyManager: i } = this.editor, n = e || s.getActiveObject();
1930
+ n && (n instanceof E ? n.getObjects().forEach((o) => {
1931
+ o.set("opacity", t);
1932
+ }) : n.set("opacity", t), s.renderAll(), a || i.saveState(), s.fire("editor:object-opacity-changed", {
1933
+ object: n,
2071
1934
  opacity: t,
2072
1935
  withoutSave: a
2073
1936
  }));
@@ -2087,30 +1950,30 @@ class ft {
2087
1950
  object: e,
2088
1951
  type: t = this.options.scaleType,
2089
1952
  withoutSave: a,
2090
- fitAsOneObject: n
1953
+ fitAsOneObject: s
2091
1954
  } = {}) {
2092
- const { canvas: i, imageManager: s, historyManager: r } = this.editor, c = e || i.getActiveObject();
1955
+ const { canvas: i, imageManager: n, historyManager: o } = this.editor, c = e || i.getActiveObject();
2093
1956
  if (c) {
2094
- if (c.set("angle", 0), c instanceof T && !n) {
2095
- const u = c.getObjects();
2096
- i.discardActiveObject(), u.forEach((d) => {
2097
- const h = s.calculateScaleFactor({ imageObject: d, scaleType: t });
2098
- d.scale(h), i.centerObject(d);
1957
+ if (c.set("angle", 0), c instanceof E && !s) {
1958
+ const d = c.getObjects();
1959
+ i.discardActiveObject(), d.forEach((h) => {
1960
+ const g = n.calculateScaleFactor({ imageObject: h, scaleType: t });
1961
+ h.scale(g), i.centerObject(h);
2099
1962
  });
2100
- const l = new T(u, { canvas: i });
1963
+ const l = new E(d, { canvas: i });
2101
1964
  i.setActiveObject(l);
2102
1965
  } else {
2103
- const u = s.calculateScaleFactor({
1966
+ const d = n.calculateScaleFactor({
2104
1967
  imageObject: c,
2105
1968
  scaleType: t
2106
1969
  });
2107
- c.scale(u), i.centerObject(c);
1970
+ c.scale(d), i.centerObject(c);
2108
1971
  }
2109
- i.renderAll(), a || r.saveState(), i.fire("editor:object-fitted", {
1972
+ i.renderAll(), a || o.saveState(), i.fire("editor:object-fitted", {
2110
1973
  object: c,
2111
1974
  type: t,
2112
1975
  withoutSave: a,
2113
- fitAsOneObject: n
1976
+ fitAsOneObject: s
2114
1977
  });
2115
1978
  }
2116
1979
  }
@@ -2133,36 +1996,36 @@ class ft {
2133
1996
  */
2134
1997
  resetObject(e, { alwaysFitObject: t = !1, withoutSave: a = !1 } = {}) {
2135
1998
  const {
2136
- canvas: n,
1999
+ canvas: s,
2137
2000
  montageArea: i,
2138
- imageManager: s,
2139
- historyManager: r,
2001
+ imageManager: n,
2002
+ historyManager: o,
2140
2003
  options: { scaleType: c }
2141
- } = this.editor, u = e || n.getActiveObject();
2142
- if (!u || u.locked) return;
2143
- if (r.suspendHistory(), u.type === "image" || u.format === "svg" || u.set({
2004
+ } = this.editor, d = e || s.getActiveObject();
2005
+ if (!d || d.locked) return;
2006
+ if (o.suspendHistory(), d.type === "image" || d.format === "svg" || d.set({
2144
2007
  scaleX: 1,
2145
2008
  scaleY: 1,
2146
2009
  flipX: !1,
2147
2010
  flipY: !1,
2148
2011
  angle: 0
2149
2012
  }), t)
2150
- this.fitObject({ object: u, withoutSave: !0, fitAsOneObject: !0 });
2013
+ this.fitObject({ object: d, withoutSave: !0, fitAsOneObject: !0 });
2151
2014
  else {
2152
- const { width: d, height: h } = i, { width: g, height: v } = u, f = s.calculateScaleFactor({
2153
- imageObject: u,
2015
+ const { width: h, height: g } = i, { width: u, height: m } = d, M = n.calculateScaleFactor({
2016
+ imageObject: d,
2154
2017
  scaleType: c
2155
2018
  });
2156
- c === "contain" && f < 1 || c === "cover" && (g > d || v > h) ? this.fitObject({ object: u, withoutSave: !0, fitAsOneObject: !0 }) : u.set({ scaleX: 1, scaleY: 1 });
2019
+ c === "contain" && M < 1 || c === "cover" && (u > h || m > g) ? this.fitObject({ object: d, withoutSave: !0, fitAsOneObject: !0 }) : d.set({ scaleX: 1, scaleY: 1 });
2157
2020
  }
2158
- u.set({ flipX: !1, flipY: !1, angle: 0 }), n.centerObject(u), n.renderAll(), r.resumeHistory(), a || r.saveState(), n.fire("editor:object-reset", {
2159
- object: u,
2021
+ d.set({ flipX: !1, flipY: !1, angle: 0 }), s.centerObject(d), s.renderAll(), o.resumeHistory(), a || o.saveState(), s.fire("editor:object-reset", {
2022
+ object: d,
2160
2023
  withoutSave: a,
2161
2024
  alwaysFitObject: t
2162
2025
  });
2163
2026
  }
2164
2027
  }
2165
- class jt {
2028
+ class nt {
2166
2029
  /**
2167
2030
  * @param {object} options
2168
2031
  * @param {ImageEditor} options.editor – экземпляр редактора
@@ -2211,16 +2074,16 @@ class jt {
2211
2074
  if (!(!t || !this.overlayMask)) {
2212
2075
  a.suspendHistory(), t.setCoords();
2213
2076
  var {
2214
- left: n,
2077
+ left: s,
2215
2078
  top: i,
2216
- width: s,
2217
- height: r
2079
+ width: n,
2080
+ height: o
2218
2081
  } = t.getBoundingRect();
2219
2082
  this.overlayMask.set({
2220
- left: n,
2083
+ left: s,
2221
2084
  top: i,
2222
- width: s,
2223
- height: r
2085
+ width: n,
2086
+ height: o
2224
2087
  }), e.discardActiveObject(), this.editor.layerManager.bringToFront(this.overlayMask, {
2225
2088
  withoutSave: !0
2226
2089
  }), a.resumeHistory();
@@ -2240,8 +2103,8 @@ class jt {
2240
2103
  canvasManager: t,
2241
2104
  historyManager: a
2242
2105
  } = this.editor;
2243
- a.suspendHistory(), this.isBlocked = !0, e.discardActiveObject(), e.selection = !1, e.skipTargetFind = !0, t.getObjects().forEach((n) => {
2244
- n.evented = !1, n.selectable = !1;
2106
+ a.suspendHistory(), this.isBlocked = !0, e.discardActiveObject(), e.selection = !1, e.skipTargetFind = !0, t.getObjects().forEach((s) => {
2107
+ s.evented = !1, s.selectable = !1;
2245
2108
  }), e.upperCanvasEl.style.pointerEvents = "none", e.lowerCanvasEl.style.pointerEvents = "none", this.overlayMask.visible = !0, this.refresh(), e.fire("editor:disabled"), a.resumeHistory();
2246
2109
  }
2247
2110
  }
@@ -2256,13 +2119,13 @@ class jt {
2256
2119
  canvasManager: t,
2257
2120
  historyManager: a
2258
2121
  } = this.editor;
2259
- a.suspendHistory(), this.isBlocked = !1, e.selection = !0, e.skipTargetFind = !1, t.getObjects().forEach((n) => {
2260
- n.evented = !0, n.selectable = !0;
2122
+ a.suspendHistory(), this.isBlocked = !1, e.selection = !0, e.skipTargetFind = !1, t.getObjects().forEach((s) => {
2123
+ s.evented = !0, s.selectable = !0;
2261
2124
  }), e.upperCanvasEl.style.pointerEvents = "", e.lowerCanvasEl.style.pointerEvents = "", this.overlayMask.visible = !1, e.requestRenderAll(), e.fire("editor:enabled"), a.resumeHistory();
2262
2125
  }
2263
2126
  }
2264
2127
  }
2265
- class $ {
2128
+ class F {
2266
2129
  /**
2267
2130
  * @param {object} options
2268
2131
  * @param {ImageEditor} options.editor - экземпляр редактора с доступом к canvas
@@ -2285,13 +2148,13 @@ class $ {
2285
2148
  withoutSave: t
2286
2149
  } = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}, {
2287
2150
  canvas: a,
2288
- historyManager: n
2151
+ historyManager: s
2289
2152
  } = this.editor;
2290
- n.suspendHistory();
2153
+ s.suspendHistory();
2291
2154
  var i = e || a.getActiveObject();
2292
- i && (i.type === "activeselection" ? i.getObjects().forEach((s) => {
2293
- a.bringObjectToFront(s);
2294
- }) : a.bringObjectToFront(i), a.renderAll(), n.resumeHistory(), t || n.saveState(), a.fire("editor:object-bring-to-front", {
2155
+ i && (i.type === "activeselection" ? i.getObjects().forEach((n) => {
2156
+ a.bringObjectToFront(n);
2157
+ }) : a.bringObjectToFront(i), a.renderAll(), s.resumeHistory(), t || s.saveState(), a.fire("editor:object-bring-to-front", {
2295
2158
  object: i,
2296
2159
  withoutSave: t
2297
2160
  }));
@@ -2308,11 +2171,11 @@ class $ {
2308
2171
  withoutSave: t
2309
2172
  } = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}, {
2310
2173
  canvas: a,
2311
- historyManager: n
2174
+ historyManager: s
2312
2175
  } = this.editor;
2313
- n.suspendHistory();
2176
+ s.suspendHistory();
2314
2177
  var i = e || a.getActiveObject();
2315
- i && (i.type === "activeselection" ? $._moveSelectionForward(a, i) : a.bringObjectForward(i), a.renderAll(), n.resumeHistory(), t || n.saveState(), a.fire("editor:object-bring-forward", {
2178
+ i && (i.type === "activeselection" ? F._moveSelectionForward(a, i) : a.bringObjectForward(i), a.renderAll(), s.resumeHistory(), t || s.saveState(), a.fire("editor:object-bring-forward", {
2316
2179
  object: i,
2317
2180
  withoutSave: t
2318
2181
  }));
@@ -2329,22 +2192,22 @@ class $ {
2329
2192
  withoutSave: t
2330
2193
  } = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}, {
2331
2194
  canvas: a,
2332
- montageArea: n,
2195
+ montageArea: s,
2333
2196
  historyManager: i,
2334
2197
  interactionBlocker: {
2335
- overlayMask: s
2198
+ overlayMask: n
2336
2199
  }
2337
2200
  } = this.editor;
2338
2201
  i.suspendHistory();
2339
- var r = e || a.getActiveObject();
2340
- if (r) {
2341
- if (r.type === "activeselection")
2342
- for (var c = r.getObjects(), u = c.length - 1; u >= 0; u -= 1)
2343
- a.sendObjectToBack(c[u]);
2202
+ var o = e || a.getActiveObject();
2203
+ if (o) {
2204
+ if (o.type === "activeselection")
2205
+ for (var c = o.getObjects(), d = c.length - 1; d >= 0; d -= 1)
2206
+ a.sendObjectToBack(c[d]);
2344
2207
  else
2345
- a.sendObjectToBack(r);
2346
- a.sendObjectToBack(n), a.sendObjectToBack(s), a.renderAll(), i.resumeHistory(), t || i.saveState(), a.fire("editor:object-send-to-back", {
2347
- object: r,
2208
+ a.sendObjectToBack(o);
2209
+ a.sendObjectToBack(s), a.sendObjectToBack(n), a.renderAll(), i.resumeHistory(), t || i.saveState(), a.fire("editor:object-send-to-back", {
2210
+ object: o,
2348
2211
  withoutSave: t
2349
2212
  });
2350
2213
  }
@@ -2360,16 +2223,16 @@ class $ {
2360
2223
  withoutSave: t
2361
2224
  } = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}, {
2362
2225
  canvas: a,
2363
- montageArea: n,
2226
+ montageArea: s,
2364
2227
  historyManager: i,
2365
2228
  interactionBlocker: {
2366
- overlayMask: s
2229
+ overlayMask: n
2367
2230
  }
2368
2231
  } = this.editor;
2369
2232
  i.suspendHistory();
2370
- var r = e || a.getActiveObject();
2371
- r && (r.type === "activeselection" ? $._moveSelectionBackwards(a, r) : a.sendObjectBackwards(r), a.sendObjectToBack(n), a.sendObjectToBack(s), a.renderAll(), i.resumeHistory(), t || i.saveState(), a.fire("editor:object-send-backwards", {
2372
- object: r,
2233
+ var o = e || a.getActiveObject();
2234
+ o && (o.type === "activeselection" ? F._moveSelectionBackwards(a, o) : a.sendObjectBackwards(o), a.sendObjectToBack(s), a.sendObjectToBack(n), a.renderAll(), i.resumeHistory(), t || i.saveState(), a.fire("editor:object-send-backwards", {
2235
+ object: o,
2373
2236
  withoutSave: t
2374
2237
  }));
2375
2238
  }
@@ -2381,20 +2244,20 @@ class $ {
2381
2244
  * @private
2382
2245
  */
2383
2246
  static _moveSelectionForward(e, t) {
2384
- for (var a = e.getObjects(), n = t.getObjects(), i = n.map((l) => a.indexOf(l)), s = -1, r = function(d) {
2385
- var h = a[d];
2386
- if (!n.includes(h) && i.some((g) => d > g))
2387
- return s = d, 1;
2388
- }, c = 0; c < a.length && !r(c); c += 1)
2247
+ for (var a = e.getObjects(), s = t.getObjects(), i = s.map((l) => a.indexOf(l)), n = -1, o = function(h) {
2248
+ var g = a[h];
2249
+ if (!s.includes(g) && i.some((u) => h > u))
2250
+ return n = h, 1;
2251
+ }, c = 0; c < a.length && !o(c); c += 1)
2389
2252
  ;
2390
- if (s !== -1) {
2391
- var u = n.map((l) => ({
2253
+ if (n !== -1) {
2254
+ var d = s.map((l) => ({
2392
2255
  obj: l,
2393
2256
  index: a.indexOf(l)
2394
- })).sort((l, d) => d.index - l.index);
2395
- u.forEach((l) => {
2396
- var d = a.indexOf(l.obj);
2397
- d < s && (e.moveObjectTo(l.obj, s), s = d);
2257
+ })).sort((l, h) => h.index - l.index);
2258
+ d.forEach((l) => {
2259
+ var h = a.indexOf(l.obj);
2260
+ h < n && (e.moveObjectTo(l.obj, n), n = h);
2398
2261
  });
2399
2262
  }
2400
2263
  }
@@ -2406,11 +2269,11 @@ class $ {
2406
2269
  * @private
2407
2270
  */
2408
2271
  static _moveSelectionBackwards(e, t) {
2409
- for (var a = e.getObjects(), n = t.getObjects(), i = Math.min(...n.map((r) => a.indexOf(r))), s = n.length - 1; s >= 0; s -= 1)
2410
- e.moveObjectTo(n[s], i - 1);
2272
+ for (var a = e.getObjects(), s = t.getObjects(), i = Math.min(...s.map((o) => a.indexOf(o))), n = s.length - 1; n >= 0; n -= 1)
2273
+ e.moveObjectTo(s[n], i - 1);
2411
2274
  }
2412
2275
  }
2413
- class yt {
2276
+ class ot {
2414
2277
  /**
2415
2278
  * Менеджер фигур для редактора.
2416
2279
  * @param {Object} options - Опции и настройки менеджера фигур.
@@ -2434,15 +2297,15 @@ class yt {
2434
2297
  * @param {Object} flags.withoutSelection - Не выделять объект
2435
2298
  * @param {Object} flags.withoutAdding - Не добавлять объект в canvas
2436
2299
  */
2437
- addRectangle(l = {}, { withoutSelection: c, withoutAdding: u } = {}) {
2438
- var d = l, {
2439
- id: e = `rect-${A()}`,
2300
+ addRectangle(l = {}, { withoutSelection: c, withoutAdding: d } = {}) {
2301
+ var h = l, {
2302
+ id: e = `rect-${D()}`,
2440
2303
  left: t,
2441
2304
  top: a,
2442
- width: n = 100,
2305
+ width: s = 100,
2443
2306
  height: i = 100,
2444
- fill: s = "blue"
2445
- } = d, r = X(d, [
2307
+ fill: n = "blue"
2308
+ } = h, o = Y(h, [
2446
2309
  "id",
2447
2310
  "left",
2448
2311
  "top",
@@ -2450,15 +2313,15 @@ class yt {
2450
2313
  "height",
2451
2314
  "fill"
2452
2315
  ]);
2453
- const { canvas: h } = this.editor, g = new xe(C({
2316
+ const { canvas: g } = this.editor, u = new pe(N({
2454
2317
  id: e,
2455
2318
  left: t,
2456
2319
  top: a,
2457
- width: n,
2320
+ width: s,
2458
2321
  height: i,
2459
- fill: s
2460
- }, r));
2461
- return !t && !a && h.centerObject(g), u || (h.add(g), c || h.setActiveObject(g), h.renderAll()), g;
2322
+ fill: n
2323
+ }, o));
2324
+ return !t && !a && g.centerObject(u), d || (g.add(u), c || g.setActiveObject(u), g.renderAll()), u;
2462
2325
  }
2463
2326
  /**
2464
2327
  * Добавление круга
@@ -2476,28 +2339,28 @@ class yt {
2476
2339
  * @param {Object} flags.withoutSelection - Не выделять объект
2477
2340
  * @param {Object} flags.withoutAdding - Не добавлять объект в canvas
2478
2341
  */
2479
- addCircle(u = {}, { withoutSelection: r, withoutAdding: c } = {}) {
2480
- var l = u, {
2481
- id: e = `circle-${A()}`,
2342
+ addCircle(d = {}, { withoutSelection: o, withoutAdding: c } = {}) {
2343
+ var l = d, {
2344
+ id: e = `circle-${D()}`,
2482
2345
  left: t,
2483
2346
  top: a,
2484
- radius: n = 50,
2347
+ radius: s = 50,
2485
2348
  fill: i = "green"
2486
- } = l, s = X(l, [
2349
+ } = l, n = Y(l, [
2487
2350
  "id",
2488
2351
  "left",
2489
2352
  "top",
2490
2353
  "radius",
2491
2354
  "fill"
2492
2355
  ]);
2493
- const { canvas: d } = this.editor, h = new Be(C({
2356
+ const { canvas: h } = this.editor, g = new Ie(N({
2494
2357
  id: e,
2495
2358
  left: t,
2496
2359
  top: a,
2497
2360
  fill: i,
2498
- radius: n
2499
- }, s));
2500
- return !t && !a && d.centerObject(h), c || (d.add(h), r || d.setActiveObject(h), d.renderAll()), h;
2361
+ radius: s
2362
+ }, n));
2363
+ return !t && !a && h.centerObject(g), c || (h.add(g), o || h.setActiveObject(g), h.renderAll()), g;
2501
2364
  }
2502
2365
  /**
2503
2366
  * Добавление треугольника
@@ -2516,15 +2379,15 @@ class yt {
2516
2379
  * @param {Object} flags.withoutSelection - Не выделять объект
2517
2380
  * @param {Object} flags.withoutAdding - Не добавлять объект в canvas
2518
2381
  */
2519
- addTriangle(l = {}, { withoutSelection: c, withoutAdding: u } = {}) {
2520
- var d = l, {
2521
- id: e = `triangle-${A()}`,
2382
+ addTriangle(l = {}, { withoutSelection: c, withoutAdding: d } = {}) {
2383
+ var h = l, {
2384
+ id: e = `triangle-${D()}`,
2522
2385
  left: t,
2523
2386
  top: a,
2524
- width: n = 100,
2387
+ width: s = 100,
2525
2388
  height: i = 100,
2526
- fill: s = "yellow"
2527
- } = d, r = X(d, [
2389
+ fill: n = "yellow"
2390
+ } = h, o = Y(h, [
2528
2391
  "id",
2529
2392
  "left",
2530
2393
  "top",
@@ -2532,18 +2395,18 @@ class yt {
2532
2395
  "height",
2533
2396
  "fill"
2534
2397
  ]);
2535
- const { canvas: h } = this.editor, g = new Ze(C({
2398
+ const { canvas: g } = this.editor, u = new Ae(N({
2536
2399
  id: e,
2537
2400
  left: t,
2538
2401
  top: a,
2539
- fill: s,
2540
- width: n,
2402
+ fill: n,
2403
+ width: s,
2541
2404
  height: i
2542
- }, r));
2543
- return !t && !a && h.centerObject(g), u || (h.add(g), c || h.setActiveObject(g), h.renderAll()), g;
2405
+ }, o));
2406
+ return !t && !a && g.centerObject(u), d || (g.add(u), c || g.setActiveObject(u), g.renderAll()), u;
2544
2407
  }
2545
2408
  }
2546
- class bt {
2409
+ class rt {
2547
2410
  /**
2548
2411
  * @param {object} options
2549
2412
  * @param {ImageEditor} options.editor - экземпляр редактора с доступом к canvas
@@ -2569,28 +2432,28 @@ class bt {
2569
2432
  return;
2570
2433
  }
2571
2434
  if (a.type !== "image") {
2572
- const h = `application/image-editor:${JSON.stringify(a.toObject(["format"]))}`;
2573
- navigator.clipboard.writeText(h).catch((g) => {
2435
+ const g = `application/image-editor:${JSON.stringify(a.toObject(["format"]))}`;
2436
+ navigator.clipboard.writeText(g).catch((u) => {
2574
2437
  t.emitWarning({
2575
2438
  origin: "ClipboardManager",
2576
2439
  method: "copy",
2577
2440
  code: "CLIPBOARD_WRITE_TEXT_FAILED",
2578
- message: `Ошибка записи текстового объекта в буфер обмена: ${g.message}`,
2579
- data: g
2441
+ message: `Ошибка записи текстового объекта в буфер обмена: ${u.message}`,
2442
+ data: u
2580
2443
  });
2581
2444
  }), this._cloneAndFire(e, a);
2582
2445
  return;
2583
2446
  }
2584
- const i = a.toCanvasElement().toDataURL(), s = i.slice(5).split(";")[0], r = i.split(",")[1], c = atob(r), u = new Uint8Array(c.length);
2585
- for (let h = 0; h < c.length; h += 1)
2586
- u[h] = c.charCodeAt(h);
2587
- const l = new Blob([u.buffer], { type: s }), d = new ClipboardItem({ [s]: l });
2588
- navigator.clipboard.write([d]).catch((h) => {
2447
+ const i = a.toCanvasElement().toDataURL(), n = i.slice(5).split(";")[0], o = i.split(",")[1], c = atob(o), d = new Uint8Array(c.length);
2448
+ for (let g = 0; g < c.length; g += 1)
2449
+ d[g] = c.charCodeAt(g);
2450
+ const l = new Blob([d.buffer], { type: n }), h = new ClipboardItem({ [n]: l });
2451
+ navigator.clipboard.write([h]).catch((g) => {
2589
2452
  t.emitWarning({
2590
2453
  origin: "ClipboardManager",
2591
2454
  method: "copy",
2592
2455
  code: "CLIPBOARD_WRITE_IMAGE_FAILED",
2593
- message: `Ошибка записи изображения в буфер обмена: ${h.message}`
2456
+ message: `Ошибка записи изображения в буфер обмена: ${g.message}`
2594
2457
  });
2595
2458
  }), this._cloneAndFire(e, a);
2596
2459
  }
@@ -2607,7 +2470,7 @@ class bt {
2607
2470
  origin: "ClipboardManager",
2608
2471
  method: "_cloneAndFire",
2609
2472
  code: "CLONE_FAILED",
2610
- message: "ClipboardManager. Ошибка клонирования объекта",
2473
+ message: "Ошибка клонирования объекта",
2611
2474
  data: a
2612
2475
  });
2613
2476
  });
@@ -2619,23 +2482,23 @@ class bt {
2619
2482
  * @param {Array} event.clipboardData.items — элементы буфера обмена
2620
2483
  */
2621
2484
  handlePasteEvent({ clipboardData: e }) {
2622
- var s;
2623
- if (!((s = e == null ? void 0 : e.items) != null && s.length)) return;
2624
- const { imageManager: t } = this.editor, { items: a } = e, n = a[a.length - 1];
2625
- if (n.type !== "text/html") {
2626
- const r = n.getAsFile();
2627
- if (!r) return;
2485
+ var n;
2486
+ if (!((n = e == null ? void 0 : e.items) != null && n.length)) return;
2487
+ const { imageManager: t } = this.editor, { items: a } = e, s = a[a.length - 1];
2488
+ if (s.type !== "text/html") {
2489
+ const o = s.getAsFile();
2490
+ if (!o) return;
2628
2491
  const c = new FileReader();
2629
- c.onload = (u) => {
2630
- u.target && this.editor.imageManager.importImage({ source: u.target.result });
2631
- }, c.readAsDataURL(r);
2492
+ c.onload = (d) => {
2493
+ d.target && this.editor.imageManager.importImage({ source: d.target.result });
2494
+ }, c.readAsDataURL(o);
2632
2495
  return;
2633
2496
  }
2634
2497
  const i = e.getData("text/html");
2635
2498
  if (i) {
2636
- const u = new DOMParser().parseFromString(i, "text/html").querySelector("img");
2637
- if (u != null && u.src) {
2638
- t.importImage({ source: u.src });
2499
+ const d = new DOMParser().parseFromString(i, "text/html").querySelector("img");
2500
+ if (d != null && d.src) {
2501
+ t.importImage({ source: d.src });
2639
2502
  return;
2640
2503
  }
2641
2504
  }
@@ -2646,22 +2509,22 @@ class bt {
2646
2509
  * @fires editor:object-pasted
2647
2510
  */
2648
2511
  paste() {
2649
- return Q(this, null, function* () {
2512
+ return b(this, null, function* () {
2650
2513
  const { canvas: e } = this.editor;
2651
2514
  if (!this.clipboard) return;
2652
2515
  const t = yield this.clipboard.clone(["format"]);
2653
2516
  e.discardActiveObject(), t.set({
2654
- id: `${t.type}-${A()}`,
2517
+ id: `${t.type}-${D()}`,
2655
2518
  left: t.left + 10,
2656
2519
  top: t.top + 10,
2657
2520
  evented: !0
2658
- }), t instanceof T ? (t.canvas = e, t.forEachObject((a) => {
2521
+ }), t instanceof E ? (t.canvas = e, t.forEachObject((a) => {
2659
2522
  e.add(a);
2660
2523
  })) : e.add(t), e.setActiveObject(t), e.requestRenderAll(), e.fire("editor:object-pasted", { object: t });
2661
2524
  });
2662
2525
  }
2663
2526
  }
2664
- class pt {
2527
+ class ct {
2665
2528
  /**
2666
2529
  * @param {object} options
2667
2530
  * @param {ImageEditor} options.editor - экземпляр редактора с доступом к canvas
@@ -2686,11 +2549,11 @@ class pt {
2686
2549
  skipInnerObjects: t,
2687
2550
  withoutSave: a
2688
2551
  } = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, {
2689
- canvas: n,
2552
+ canvas: s,
2690
2553
  historyManager: i
2691
- } = this.editor, s = e || n.getActiveObject();
2692
- if (!(!s || s.locked)) {
2693
- var r = {
2554
+ } = this.editor, n = e || s.getActiveObject();
2555
+ if (!(!n || n.locked)) {
2556
+ var o = {
2694
2557
  lockMovementX: !0,
2695
2558
  lockMovementY: !0,
2696
2559
  lockRotation: !0,
@@ -2700,12 +2563,12 @@ class pt {
2700
2563
  lockSkewingY: !0,
2701
2564
  locked: !0
2702
2565
  };
2703
- s.set(r);
2704
- var c = !t && ["activeselection", "group"].includes(s.type);
2705
- c && s.getObjects().forEach((u) => {
2706
- u.set(r);
2707
- }), n.renderAll(), a || i.saveState(), n.fire("editor:object-locked", {
2708
- object: s,
2566
+ n.set(o);
2567
+ var c = !t && ["activeselection", "group"].includes(n.type);
2568
+ c && n.getObjects().forEach((d) => {
2569
+ d.set(o);
2570
+ }), s.renderAll(), a || i.saveState(), s.fire("editor:object-locked", {
2571
+ object: n,
2709
2572
  skipInnerObjects: t,
2710
2573
  withoutSave: a
2711
2574
  });
@@ -2725,10 +2588,10 @@ class pt {
2725
2588
  withoutSave: t
2726
2589
  } = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, {
2727
2590
  canvas: a,
2728
- historyManager: n
2591
+ historyManager: s
2729
2592
  } = this.editor, i = e || a.getActiveObject();
2730
2593
  if (i) {
2731
- var s = {
2594
+ var n = {
2732
2595
  lockMovementX: !1,
2733
2596
  lockMovementY: !1,
2734
2597
  lockRotation: !1,
@@ -2738,25 +2601,18 @@ class pt {
2738
2601
  lockSkewingY: !1,
2739
2602
  locked: !1
2740
2603
  };
2741
- i.set(s), ["activeselection", "group"].includes(i.type) && i.getObjects().forEach((r) => {
2742
- r.set(s);
2743
- }), a.renderAll(), t || n.saveState(), a.fire("editor:object-unlocked", {
2604
+ i.set(n), ["activeselection", "group"].includes(i.type) && i.getObjects().forEach((o) => {
2605
+ o.set(n);
2606
+ }), a.renderAll(), t || s.saveState(), a.fire("editor:object-unlocked", {
2744
2607
  object: i,
2745
2608
  withoutSave: t
2746
2609
  });
2747
2610
  }
2748
2611
  }
2749
2612
  }
2750
- class It {
2751
- /**
2752
- * @param {object} options
2753
- * @param {ImageEditor} options.editor - экземпляр редактора с доступом к canvas
2754
- */
2755
- constructor(e) {
2756
- var {
2757
- editor: t
2758
- } = e;
2759
- this.editor = t;
2613
+ class dt {
2614
+ constructor({ editor: e }) {
2615
+ this.editor = e;
2760
2616
  }
2761
2617
  /**
2762
2618
  * Группировка объектов
@@ -2765,24 +2621,20 @@ class It {
2765
2621
  * @param {fabric.Object} options.object - массив объектов для группировки
2766
2622
  * @fires editor:objects-grouped
2767
2623
  */
2768
- group() {
2769
- var {
2770
- object: e,
2624
+ group({
2625
+ object: e,
2626
+ withoutSave: t
2627
+ } = {}) {
2628
+ const { canvas: a, historyManager: s } = this.editor;
2629
+ s.suspendHistory();
2630
+ const i = e || a.getActiveObject();
2631
+ if (!i || !(i instanceof E)) return;
2632
+ const n = i.getObjects(), o = new de(n);
2633
+ n.forEach((c) => a.remove(c)), o.set("id", `${o.type}-${D()}`), a.add(o), a.setActiveObject(o), a.renderAll(), s.resumeHistory(), t || s.saveState(), a.fire("editor:objects-grouped", {
2634
+ object: i,
2635
+ group: o,
2771
2636
  withoutSave: t
2772
- } = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, {
2773
- canvas: a,
2774
- historyManager: n
2775
- } = this.editor;
2776
- n.suspendHistory();
2777
- var i = e || a.getActiveObject();
2778
- if (i && i.type === "activeselection") {
2779
- var s = i.getObjects(), r = new ze(s);
2780
- s.forEach((c) => a.remove(c)), r.set("id", "".concat(r.type, "-").concat(A())), a.add(r), a.setActiveObject(r), a.renderAll(), n.resumeHistory(), t || n.saveState(), a.fire("editor:objects-grouped", {
2781
- object: i,
2782
- group: r,
2783
- withoutSave: t
2784
- });
2785
- }
2637
+ });
2786
2638
  }
2787
2639
  /**
2788
2640
  * Разгруппировка объектов
@@ -2791,31 +2643,27 @@ class It {
2791
2643
  * @param {Boolean} options.withoutSave - Не сохранять состояние
2792
2644
  * @fires editor:objects-ungrouped
2793
2645
  */
2794
- ungroup() {
2795
- var {
2796
- object: e,
2646
+ ungroup({
2647
+ object: e,
2648
+ withoutSave: t
2649
+ } = {}) {
2650
+ const { canvas: a, historyManager: s } = this.editor;
2651
+ s.suspendHistory();
2652
+ const i = e || a.getActiveObject();
2653
+ if (!(i instanceof de)) return;
2654
+ const n = i.removeAll();
2655
+ a.remove(i), n.forEach((c) => a.add(c));
2656
+ const o = new E(n, {
2657
+ canvas: a
2658
+ });
2659
+ a.setActiveObject(o), a.renderAll(), s.resumeHistory(), t || s.saveState(), a.fire("editor:objects-ungrouped", {
2660
+ object: i,
2661
+ selection: o,
2797
2662
  withoutSave: t
2798
- } = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, {
2799
- canvas: a,
2800
- historyManager: n
2801
- } = this.editor;
2802
- n.suspendHistory();
2803
- var i = e || a.getActiveObject();
2804
- if (!(!i || i.type !== "group")) {
2805
- var s = i.removeAll();
2806
- a.remove(i), s.forEach((c) => a.add(c));
2807
- var r = new T(s, {
2808
- canvas: a
2809
- });
2810
- a.setActiveObject(r), a.renderAll(), n.resumeHistory(), t || n.saveState(), a.fire("editor:objects-ungrouped", {
2811
- object: i,
2812
- selection: r,
2813
- withoutSave: t
2814
- });
2815
- }
2663
+ });
2816
2664
  }
2817
2665
  }
2818
- class At {
2666
+ class lt {
2819
2667
  /**
2820
2668
  * @param {object} options
2821
2669
  * @param {ImageEditor} options.editor - экземпляр редактора с доступом к canvas
@@ -2837,58 +2685,47 @@ class At {
2837
2685
  objectLockManager: a
2838
2686
  } = this.editor;
2839
2687
  e.discardActiveObject();
2840
- var n = t.getObjects(), i = n.some((r) => r.locked), s = n.length > 1 ? new T(t.getObjects(), {
2688
+ var s = t.getObjects(), i = s.some((o) => o.locked), n = s.length > 1 ? new E(t.getObjects(), {
2841
2689
  canvas: e
2842
- }) : n[0];
2690
+ }) : s[0];
2843
2691
  i && a.lockObject({
2844
- object: s,
2692
+ object: n,
2845
2693
  skipInnerObjects: !0,
2846
2694
  withoutSave: !0
2847
- }), e.setActiveObject(s), e.requestRenderAll(), e.fire("editor:all-objects-selected", {
2848
- selected: s
2695
+ }), e.setActiveObject(n), e.requestRenderAll(), e.fire("editor:all-objects-selected", {
2696
+ selected: n
2849
2697
  });
2850
2698
  }
2851
2699
  }
2852
- class St {
2853
- /**
2854
- * @param {object} options
2855
- * @param {ImageEditor} options.editor - экземпляр редактора с доступом к canvas
2856
- */
2857
- constructor(e) {
2858
- var {
2859
- editor: t
2860
- } = e;
2861
- this.editor = t;
2700
+ class ht {
2701
+ constructor({ editor: e }) {
2702
+ this.editor = e;
2862
2703
  }
2863
2704
  /**
2864
2705
  * Удалить выбранные объекты
2865
2706
  * @param {Object} options
2866
- * @param {fabric.Object[]} options.objects - массив объектов для удаления
2707
+ * @param {FabricObject[]} options.objects - массив объектов для удаления
2867
2708
  * @param {Boolean} options.withoutSave - Не сохранять состояние
2868
2709
  * @fires editor:objects-deleted
2869
2710
  */
2870
- deleteSelectedObjects() {
2871
- var {
2872
- objects: e,
2873
- withoutSave: t
2874
- } = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, {
2875
- canvas: a,
2876
- historyManager: n,
2877
- groupingManager: i
2878
- } = this.editor, s = (e || a.getActiveObjects()).filter((r) => !r.locked);
2879
- s != null && s.length && (n.suspendHistory(), s.forEach((r) => {
2880
- if (r.type === "group" && r.format !== "svg") {
2881
- i.ungroup(r), this.deleteSelectedObjects();
2711
+ deleteSelectedObjects({
2712
+ objects: e,
2713
+ withoutSave: t
2714
+ } = {}) {
2715
+ const { canvas: a, historyManager: s, groupingManager: i } = this.editor, n = (e || a.getActiveObjects()).filter((o) => !o.locked);
2716
+ n != null && n.length && (s.suspendHistory(), n.forEach((o) => {
2717
+ if (o.type === "group" && o.format !== "svg") {
2718
+ i.ungroup({ object: o, withoutSave: t }), this.deleteSelectedObjects();
2882
2719
  return;
2883
2720
  }
2884
- a.remove(r);
2885
- }), a.discardActiveObject(), a.renderAll(), n.resumeHistory(), t || n.saveState(), a.fire("editor:objects-deleted", {
2886
- objects: s,
2721
+ a.remove(o);
2722
+ }), a.discardActiveObject(), a.renderAll(), s.resumeHistory(), t || s.saveState(), a.fire("editor:objects-deleted", {
2723
+ objects: n,
2887
2724
  withoutSave: t
2888
2725
  }));
2889
2726
  }
2890
2727
  }
2891
- const Ct = {
2728
+ const gt = {
2892
2729
  IMAGE_MANAGER: {
2893
2730
  /**
2894
2731
  * Некорректный Content-Type изображения
@@ -2944,9 +2781,13 @@ const Ct = {
2944
2781
  * Ошибка при получении активного объекта.
2945
2782
  */
2946
2783
  NO_ACTIVE_OBJECT: "NO_ACTIVE_OBJECT"
2784
+ },
2785
+ HISTORY_MANAGER: {
2786
+ UNDO_ERROR: "UNDO_ERROR",
2787
+ REDO_ERROR: "REDO_ERROR"
2947
2788
  }
2948
2789
  };
2949
- class q {
2790
+ class V {
2950
2791
  constructor({ editor: e }) {
2951
2792
  this._buffer = [], this.editor = e;
2952
2793
  }
@@ -2966,24 +2807,24 @@ class q {
2966
2807
  * @param {string} [options.message] — текст ошибки (опционально, если не передан, то используется код ошибки)
2967
2808
  * @fires editor:error
2968
2809
  */
2969
- emitError({ origin: e = "ImageEditor", method: t = "Unknown Method", code: a, data: n, message: i }) {
2970
- if (!q.isValidErrorCode(a)) {
2810
+ emitError({ origin: e = "ImageEditor", method: t = "Unknown Method", code: a, data: s, message: i }) {
2811
+ if (!V.isValidErrorCode(a)) {
2971
2812
  console.warn("Неизвестный код ошибки: ", { code: a, origin: e, method: t });
2972
2813
  return;
2973
2814
  }
2974
2815
  if (!a) return;
2975
- const s = i || a;
2976
- console.error(`${e}. ${t}. ${a}. ${s}`, n);
2977
- const r = {
2816
+ const n = i || a;
2817
+ console.error(`${e}. ${t}. ${a}. ${n}`, s);
2818
+ const o = {
2978
2819
  code: a,
2979
2820
  origin: e,
2980
2821
  method: t,
2981
- message: s,
2982
- data: n
2822
+ message: n,
2823
+ data: s
2983
2824
  };
2984
- this._buffer.push(C({
2825
+ this._buffer.push(N({
2985
2826
  type: "editor:error"
2986
- }, r)), this.editor.canvas.fire("editor:error", r);
2827
+ }, o)), this.editor.canvas.fire("editor:error", o);
2987
2828
  }
2988
2829
  /**
2989
2830
  * Эмитит предупреждение через fabricjs
@@ -2995,58 +2836,58 @@ class q {
2995
2836
  * @param {string} [options.message] — текст предупреждения (опционально, если не передан, то используется код предупреждения)
2996
2837
  * @fires editor:warning
2997
2838
  */
2998
- emitWarning({ origin: e = "ImageEditor", method: t = "Unknown Method", code: a, message: n, data: i }) {
2999
- if (!q.isValidErrorCode(a)) {
2839
+ emitWarning({ origin: e = "ImageEditor", method: t = "Unknown Method", code: a, message: s, data: i }) {
2840
+ if (!V.isValidErrorCode(a)) {
3000
2841
  console.warn("Неизвестный код предупреждения: ", { code: a, origin: e, method: t });
3001
2842
  return;
3002
2843
  }
3003
- const s = n || a;
3004
- console.warn(`${e}. ${t}. ${a}. ${s}`, i);
3005
- const r = {
2844
+ const n = s || a;
2845
+ console.warn(`${e}. ${t}. ${a}. ${n}`, i);
2846
+ const o = {
3006
2847
  code: a,
3007
2848
  origin: e,
3008
2849
  method: t,
3009
- message: s,
2850
+ message: n,
3010
2851
  data: i
3011
2852
  };
3012
- this._buffer.push(C({
2853
+ this._buffer.push(N({
3013
2854
  type: "editor:warning"
3014
- }, r)), this.editor.canvas.fire("editor:warning", r);
2855
+ }, o)), this.editor.canvas.fire("editor:warning", o);
3015
2856
  }
3016
2857
  static isValidErrorCode(e) {
3017
- return e ? Object.values(Ct).some((t) => Object.values(t).includes(e)) : !1;
2858
+ return e ? Object.values(gt).some((t) => Object.values(t).includes(e)) : !1;
3018
2859
  }
3019
2860
  }
3020
- class de {
2861
+ class ae {
3021
2862
  /**
3022
2863
  * Конструктор класса ImageEditor.
3023
2864
  * @param {string} canvasId - идентификатор канваса, в котором будет создан редактор
3024
2865
  * @param {CanvasOptions} options - опции и настройки редактора
3025
2866
  */
3026
2867
  constructor(e, t) {
3027
- this.options = t, this.containerId = e, this.editorId = `${e}-${A()}`, this.clipboard = null, this.init();
2868
+ this.options = t, this.containerId = e, this.editorId = `${e}-${D()}`, this.clipboard = null, this.init();
3028
2869
  }
3029
2870
  init() {
3030
- return Q(this, null, function* () {
2871
+ return b(this, null, function* () {
3031
2872
  const {
3032
2873
  editorContainerWidth: e,
3033
2874
  editorContainerHeight: t,
3034
2875
  canvasWrapperWidth: a,
3035
- canvasWrapperHeight: n,
2876
+ canvasWrapperHeight: s,
3036
2877
  canvasCSSWidth: i,
3037
- canvasCSSHeight: s,
3038
- initialImage: r,
2878
+ canvasCSSHeight: n,
2879
+ initialImage: o,
3039
2880
  initialStateJSON: c,
3040
- scaleType: u,
2881
+ scaleType: d,
3041
2882
  _onReadyCallback: l
3042
2883
  } = this.options;
3043
- if (Ke.apply(), this.canvas = new Ue(this.containerId, this.options), this.moduleLoader = new Re(), this.workerManager = new Pe(), this.errorManager = new q({ editor: this }), this.historyManager = new lt({ editor: this }), this.toolbar = new dt({ editor: this }), this.transformManager = new ft({ editor: this }), this.canvasManager = new mt({ editor: this }), this.imageManager = new D({ editor: this }), this.layerManager = new $({ editor: this }), this.shapeManager = new yt({ editor: this }), this.interactionBlocker = new jt({ editor: this }), this.clipboardManager = new bt({ editor: this }), this.objectLockManager = new pt({ editor: this }), this.groupingManager = new It({ editor: this }), this.selectionManager = new At({ editor: this }), this.deletionManager = new St({ editor: this }), this._createMontageArea(), this._createClippingArea(), this.listeners = new R({ editor: this, options: this.options }), this.canvasManager.setEditorContainerWidth(e), this.canvasManager.setEditorContainerHeight(t), this.canvasManager.setCanvasWrapperWidth(a), this.canvasManager.setCanvasWrapperHeight(n), this.canvasManager.setCanvasCSSWidth(i), this.canvasManager.setCanvasCSSHeight(s), r != null && r.source) {
2884
+ if (ze.apply(), this.canvas = new Se(this.containerId, this.options), this.moduleLoader = new Ne(), this.workerManager = new Ee(), this.errorManager = new V({ editor: this }), this.historyManager = new Ke({ editor: this }), this.toolbar = new $e({ editor: this }), this.transformManager = new it({ editor: this }), this.canvasManager = new st({ editor: this }), this.imageManager = new C({ editor: this }), this.layerManager = new F({ editor: this }), this.shapeManager = new ot({ editor: this }), this.interactionBlocker = new nt({ editor: this }), this.clipboardManager = new rt({ editor: this }), this.objectLockManager = new ct({ editor: this }), this.groupingManager = new dt({ editor: this }), this.selectionManager = new lt({ editor: this }), this.deletionManager = new ht({ editor: this }), this._createMontageArea(), this._createClippingArea(), this.listeners = new R({ editor: this, options: this.options }), this.canvasManager.setEditorContainerWidth(e), this.canvasManager.setEditorContainerHeight(t), this.canvasManager.setCanvasWrapperWidth(a), this.canvasManager.setCanvasWrapperHeight(s), this.canvasManager.setCanvasCSSWidth(i), this.canvasManager.setCanvasCSSHeight(n), o != null && o.source) {
3044
2885
  const {
3045
- source: d,
3046
- scale: h = `image-${u}`,
3047
- withoutSave: g = !0
3048
- } = r;
3049
- yield this.imageManager.importImage({ source: d, scale: h, withoutSave: g });
2886
+ source: h,
2887
+ scale: g = `image-${d}`,
2888
+ withoutSave: u = !0
2889
+ } = o;
2890
+ yield this.imageManager.importImage({ source: h, scale: g, withoutSave: u });
3050
2891
  } else
3051
2892
  this.canvasManager.setDefaultScale({ withoutSave: !0 });
3052
2893
  c && this.historyManager.loadStateFromFullState(c), this.historyManager.saveState(), console.log("editor:ready"), this.canvas.fire("editor:ready", this), typeof l == "function" && l(this);
@@ -3060,7 +2901,7 @@ class de {
3060
2901
  this.montageArea = this.shapeManager.addRectangle({
3061
2902
  width: e,
3062
2903
  height: t,
3063
- fill: de._createMosaicPattern(),
2904
+ fill: ae._createMosaicPattern(),
3064
2905
  stroke: null,
3065
2906
  strokeWidth: 0,
3066
2907
  selectable: !1,
@@ -3104,13 +2945,13 @@ class de {
3104
2945
  const e = document.createElement("canvas");
3105
2946
  e.width = 20, e.height = 20;
3106
2947
  const t = e.getContext("2d");
3107
- 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 _e({
2948
+ 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 Ce({
3108
2949
  source: e,
3109
2950
  repeat: "repeat"
3110
2951
  });
3111
2952
  }
3112
2953
  }
3113
- const Dt = {
2954
+ const ut = {
3114
2955
  /**
3115
2956
  * Опции редактора
3116
2957
  */
@@ -3198,18 +3039,18 @@ const Dt = {
3198
3039
  deleteObjectsByHotkey: !0,
3199
3040
  resetObjectFitByDoubleClick: !0
3200
3041
  };
3201
- function wt(o, e = {}) {
3202
- const t = C(C({}, Dt), e), a = document.getElementById(o);
3042
+ function yt(r, e = {}) {
3043
+ const t = N(N({}, ut), e), a = document.getElementById(r);
3203
3044
  if (!a)
3204
- return Promise.reject(new Error(`Контейнер с ID "${o}" не найден.`));
3205
- const n = document.createElement("canvas");
3206
- return n.id = `${o}-canvas`, a.appendChild(n), t.editorContainer = a, new Promise((i) => {
3045
+ return Promise.reject(new Error(`Контейнер с ID "${r}" не найден.`));
3046
+ const s = document.createElement("canvas");
3047
+ return s.id = `${r}-canvas`, a.appendChild(s), t.editorContainer = a, new Promise((i) => {
3207
3048
  t._onReadyCallback = i;
3208
- const s = new de(n.id, t);
3209
- window[o] = s;
3049
+ const n = new ae(s.id, t);
3050
+ window[r] = n;
3210
3051
  });
3211
3052
  }
3212
3053
  export {
3213
- wt as default
3054
+ yt as default
3214
3055
  };
3215
3056
  //# sourceMappingURL=main.js.map