@anu3ev/fabric-image-editor 0.5.2 → 0.5.4

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 +619 -572
  2. package/package.json +1 -1
package/dist/main.js CHANGED
@@ -1,22 +1,22 @@
1
- var as = Object.defineProperty, rs = Object.defineProperties;
2
- var cs = Object.getOwnPropertyDescriptors;
1
+ var ds = Object.defineProperty, ls = Object.defineProperties;
2
+ var hs = Object.getOwnPropertyDescriptors;
3
3
  var Wt = Object.getOwnPropertySymbols;
4
- var Le = Object.prototype.hasOwnProperty, De = Object.prototype.propertyIsEnumerable;
5
- var Oe = (h, t, e) => t in h ? as(h, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : h[t] = e, k = (h, t) => {
4
+ var _e = Object.prototype.hasOwnProperty, Ne = Object.prototype.propertyIsEnumerable;
5
+ var Re = (h, t, e) => t in h ? ds(h, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : h[t] = e, x = (h, t) => {
6
6
  for (var e in t || (t = {}))
7
- Le.call(t, e) && Oe(h, e, t[e]);
7
+ _e.call(t, e) && Re(h, e, t[e]);
8
8
  if (Wt)
9
9
  for (var e of Wt(t))
10
- De.call(t, e) && Oe(h, e, t[e]);
10
+ Ne.call(t, e) && Re(h, e, t[e]);
11
11
  return h;
12
- }, bt = (h, t) => rs(h, cs(t));
13
- var ut = (h, t) => {
12
+ }, St = (h, t) => ls(h, hs(t));
13
+ var gt = (h, t) => {
14
14
  var e = {};
15
15
  for (var s in h)
16
- Le.call(h, s) && t.indexOf(s) < 0 && (e[s] = h[s]);
16
+ _e.call(h, s) && t.indexOf(s) < 0 && (e[s] = h[s]);
17
17
  if (h != null && Wt)
18
18
  for (var s of Wt(h))
19
- t.indexOf(s) < 0 && De.call(h, s) && (e[s] = h[s]);
19
+ t.indexOf(s) < 0 && Ne.call(h, s) && (e[s] = h[s]);
20
20
  return e;
21
21
  };
22
22
  var _ = (h, t, e) => new Promise((s, o) => {
@@ -35,15 +35,15 @@ var _ = (h, t, e) => new Promise((s, o) => {
35
35
  }, a = (r) => r.done ? s(r.value) : Promise.resolve(r.value).then(n, i);
36
36
  a((e = e.apply(h, t)).next());
37
37
  });
38
- import { ActiveSelection as B, Textbox as st, util as rt, controlsUtils as Re, InteractiveFabricObject as _e, Point as $, FitContentLayout as Ne, loadSVGFromURL as ds, FabricImage as kt, Gradient as ke, Rect as ls, Circle as hs, Triangle as us, Group as wt, Color as gs, classRegistry as Be, loadSVGFromString as fs, Canvas as ps, Pattern as ms } from "fabric";
39
- import { create as ys } from "jsondiffpatch";
40
- import vs from "diff-match-patch";
41
- var bs = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict", Y = function() {
38
+ import { ActiveSelection as k, Textbox as st, util as ct, controlsUtils as xe, InteractiveFabricObject as ke, Point as J, FitContentLayout as Be, loadSVGFromURL as us, FabricImage as xt, Gradient as ze, Rect as gs, Circle as fs, Triangle as ps, Group as jt, Color as ms, classRegistry as Pe, loadSVGFromString as ys, Canvas as vs, Pattern as bs } from "fabric";
39
+ import { create as Ms } from "jsondiffpatch";
40
+ import ws from "diff-match-patch";
41
+ var Ss = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict", F = function() {
42
42
  for (var t = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : 21, e = "", s = crypto.getRandomValues(new Uint8Array(t |= 0)); t--; )
43
- e += bs[s[t] & 63];
43
+ e += Ss[s[t] & 63];
44
44
  return e;
45
45
  };
46
- class xt {
46
+ class Bt {
47
47
  /**
48
48
  * Конструктор принимает редактор и опции.
49
49
  * @param params
@@ -61,7 +61,7 @@ class xt {
61
61
  * @param params.options.adaptCanvasToContainerOnResize — адаптировать канвас к размерам контейнера при изменении размеров окна
62
62
  */
63
63
  constructor({ editor: t, options: e = {} }) {
64
- this.isDragging = !1, this.lastMouseX = 0, this.lastMouseY = 0, this.isUndoRedoKeyPressed = !1, this.isSpacePressed = !1, this.savedSelection = [], this.canvasDragging = !1, this.mouseWheelZooming = !1, this.bringToFrontOnSelection = !1, this.resetObjectFitByDoubleClick = !1, this.copyObjectsByHotkey = !1, this.pasteImageFromClipboard = !1, this.undoRedoByHotKeys = !1, this.selectAllByHotkey = !1, this.deleteObjectsByHotkey = !1, this.adaptCanvasToContainerOnResize = !1, this.editor = t, this.canvas = t.canvas, this.options = e, this.handleContainerResizeBound = xt.debounce(this.handleContainerResize.bind(this), 500), this.handleCopyEventBound = this.handleCopyEvent.bind(this), this.handlePasteEventBound = this.handlePasteEvent.bind(this), this.handleUndoRedoEventBound = this.handleUndoRedoEvent.bind(this), this.handleUndoRedoKeyUpBound = this.handleUndoRedoKeyUp.bind(this), this.handleSelectAllEventBound = this.handleSelectAllEvent.bind(this), this.handleDeleteObjectsEventBound = this.handleDeleteObjectsEvent.bind(this), this.handleSpaceKeyDownBound = this.handleSpaceKeyDown.bind(this), this.handleSpaceKeyUpBound = this.handleSpaceKeyUp.bind(this), this.handleObjectModifiedHistoryBound = xt.debounce(this.handleObjectModifiedHistory.bind(this), 300), this.handleObjectRotatingHistoryBound = xt.debounce(this.handleObjectRotatingHistory.bind(this), 300), this.handleObjectAddedHistoryBound = this.handleObjectAddedHistory.bind(this), this.handleObjectRemovedHistoryBound = this.handleObjectRemovedHistory.bind(this), this.handleOverlayUpdateBound = this.handleOverlayUpdate.bind(this), this.handleBackgroundUpdateBound = this.handleBackgroundUpdate.bind(this), this.handleCanvasDragStartBound = this.handleCanvasDragStart.bind(this), this.handleCanvasDraggingBound = this.handleCanvasDragging.bind(this), this.handleCanvasDragEndBound = this.handleCanvasDragEnd.bind(this), this.handleMouseWheelZoomBound = this.handleMouseWheelZoom.bind(this), this.handleBringToFrontBound = this.handleBringToFront.bind(this), this.handleResetObjectFitBound = this.handleResetObjectFit.bind(this), this.handleLockedSelectionBound = this._filterLockedSelection.bind(this), this.init();
64
+ this.isDragging = !1, this.lastMouseX = 0, this.lastMouseY = 0, this.isUndoRedoKeyPressed = !1, this.isSpacePressed = !1, this.savedSelection = [], this.canvasDragging = !1, this.mouseWheelZooming = !1, this.bringToFrontOnSelection = !1, this.resetObjectFitByDoubleClick = !1, this.copyObjectsByHotkey = !1, this.pasteImageFromClipboard = !1, this.undoRedoByHotKeys = !1, this.selectAllByHotkey = !1, this.deleteObjectsByHotkey = !1, this.adaptCanvasToContainerOnResize = !1, this.editor = t, this.canvas = t.canvas, this.options = e, this.handleContainerResizeBound = Bt.debounce(this.handleContainerResize.bind(this), 500), this.handleCopyEventBound = this.handleCopyEvent.bind(this), this.handlePasteEventBound = this.handlePasteEvent.bind(this), this.handleUndoRedoEventBound = this.handleUndoRedoEvent.bind(this), this.handleUndoRedoKeyUpBound = this.handleUndoRedoKeyUp.bind(this), this.handleSelectAllEventBound = this.handleSelectAllEvent.bind(this), this.handleDeleteObjectsEventBound = this.handleDeleteObjectsEvent.bind(this), this.handleSpaceKeyDownBound = this.handleSpaceKeyDown.bind(this), this.handleSpaceKeyUpBound = this.handleSpaceKeyUp.bind(this), this.handleObjectModifiedHistoryBound = Bt.debounce(this.handleObjectModifiedHistory.bind(this), 300), this.handleObjectRotatingHistoryBound = Bt.debounce(this.handleObjectRotatingHistory.bind(this), 300), this.handleObjectAddedHistoryBound = this.handleObjectAddedHistory.bind(this), this.handleObjectRemovedHistoryBound = this.handleObjectRemovedHistory.bind(this), this.handleOverlayUpdateBound = this.handleOverlayUpdate.bind(this), this.handleBackgroundUpdateBound = this.handleBackgroundUpdate.bind(this), this.handleCanvasDragStartBound = this.handleCanvasDragStart.bind(this), this.handleCanvasDraggingBound = this.handleCanvasDragging.bind(this), this.handleCanvasDragEndBound = this.handleCanvasDragEnd.bind(this), this.handleMouseWheelZoomBound = this.handleMouseWheelZoom.bind(this), this.handleBringToFrontBound = this.handleBringToFront.bind(this), this.handleResetObjectFitBound = this.handleResetObjectFit.bind(this), this.handleLockedSelectionBound = this._filterLockedSelection.bind(this), this.init();
65
65
  }
66
66
  /**
67
67
  * Инициализация всех обработчиков согласно опциям.
@@ -98,7 +98,7 @@ class xt {
98
98
  if (o.length === 1)
99
99
  this.canvas.setActiveObject(o[0]);
100
100
  else {
101
- const i = new B(o, {
101
+ const i = new k(o, {
102
102
  canvas: this.canvas
103
103
  });
104
104
  this.canvas.setActiveObject(i);
@@ -106,7 +106,7 @@ class xt {
106
106
  this.canvas.requestRenderAll();
107
107
  return;
108
108
  }
109
- const n = new B(t, {
109
+ const n = new k(t, {
110
110
  canvas: this.canvas
111
111
  });
112
112
  this.editor.objectLockManager.lockObject({
@@ -220,7 +220,7 @@ class xt {
220
220
  if (o || n) return;
221
221
  this.isSpacePressed = !0, t.preventDefault();
222
222
  const i = e.getActiveObject() || null;
223
- i instanceof B ? this.savedSelection = i.getObjects().slice() : i && (this.savedSelection = [i]), e.discardActiveObject(), e.set({
223
+ i instanceof k ? this.savedSelection = i.getObjects().slice() : i && (this.savedSelection = [i]), e.discardActiveObject(), e.set({
224
224
  selection: !1,
225
225
  defaultCursor: "grab"
226
226
  }), e.setCursor("grab"), s.canvasManager.getObjects().forEach((a) => {
@@ -259,7 +259,7 @@ class xt {
259
259
  e.setActiveObject(t[0]);
260
260
  return;
261
261
  }
262
- const o = t.filter((i) => s.canvasManager.getObjects().includes(i)), n = new B(o, { canvas: e });
262
+ const o = t.filter((i) => s.canvasManager.getObjects().includes(i)), n = new k(o, { canvas: e });
263
263
  e.setActiveObject(n);
264
264
  }
265
265
  // --- Обработчики для событий canvas (Fabric) ---
@@ -391,7 +391,7 @@ class xt {
391
391
  };
392
392
  }
393
393
  }
394
- class Ms {
394
+ class As {
395
395
  /**
396
396
  * Класс для динамической загрузки внешних модулей.
397
397
  */
@@ -409,7 +409,7 @@ class Ms {
409
409
  return this.loaders[t] ? (this.cache.has(t) || this.cache.set(t, this.loaders[t]()), this.cache.get(t)) : Promise.reject(new Error(`Unknown module "${t}"`));
410
410
  }
411
411
  }
412
- function ws(h) {
412
+ function js(h) {
413
413
  return new Worker(
414
414
  "" + new URL("assets/worker-CN39s7P7.js", import.meta.url).href,
415
415
  {
@@ -417,13 +417,13 @@ function ws(h) {
417
417
  }
418
418
  );
419
419
  }
420
- class Ss {
420
+ class Is {
421
421
  /**
422
422
  * @param scriptUrl — URL скрипта воркера.
423
423
  * По-умолчанию использует DefaultWorker из соседнего файла
424
424
  */
425
425
  constructor(t) {
426
- t ? this.worker = new Worker(t, { type: "module" }) : this.worker = new ws(), this._callbacks = /* @__PURE__ */ new Map(), this.worker.onmessage = this._handleMessage.bind(this);
426
+ t ? this.worker = new Worker(t, { type: "module" }) : this.worker = new js(), this._callbacks = /* @__PURE__ */ new Map(), this.worker.onmessage = this._handleMessage.bind(this);
427
427
  }
428
428
  /**
429
429
  * Обработчик сообщений от воркера
@@ -451,7 +451,7 @@ class Ss {
451
451
  * @returns Promise, который будет выполнен, когда воркер вернет ответ
452
452
  */
453
453
  post(t, e, s = []) {
454
- const o = `${t}:${Y(8)}`;
454
+ const o = `${t}:${F(8)}`;
455
455
  return new Promise((n, i) => {
456
456
  this._callbacks.set(o, { resolve: n, reject: i }), this.worker.postMessage({ action: t, payload: e, requestId: o }, s);
457
457
  });
@@ -463,65 +463,65 @@ class Ss {
463
463
  this.worker.terminate();
464
464
  }
465
465
  }
466
- const it = 12, As = 2, ce = 8, de = 20, js = 100, le = 20, he = 8, Is = 100, Xt = 32, pe = 1, Cs = "#2B2D33", me = "#3D8BF4", ye = "#FFFFFF";
466
+ const at = 12, Cs = 2, ce = 8, de = 20, Ts = 100, le = 20, he = 8, Es = 100, Kt = 32, pe = 1, Os = "#2B2D33", me = "#3D8BF4", ye = "#FFFFFF";
467
467
  function Zt(h, t, e, s, o) {
468
- const n = it, i = As;
469
- h.save(), h.translate(t, e), h.rotate(rt.degreesToRadians(o.angle)), h.fillStyle = ye, h.strokeStyle = me, h.lineWidth = pe, h.beginPath(), h.roundRect(-n / 2, -n / 2, n, n, i), h.fill(), h.stroke(), h.restore();
468
+ const n = at, i = Cs;
469
+ h.save(), h.translate(t, e), h.rotate(ct.degreesToRadians(o.angle)), h.fillStyle = ye, h.strokeStyle = me, h.lineWidth = pe, h.beginPath(), h.roundRect(-n / 2, -n / 2, n, n, i), h.fill(), h.stroke(), h.restore();
470
470
  }
471
- function xe(h, t, e, s, o) {
472
- const n = ce, i = de, a = js;
473
- h.save(), h.translate(t, e), h.rotate(rt.degreesToRadians(o.angle)), h.fillStyle = ye, h.strokeStyle = me, h.lineWidth = pe, h.beginPath(), h.roundRect(-n / 2, -i / 2, n, i, a), h.fill(), h.stroke(), h.restore();
471
+ function Ue(h, t, e, s, o) {
472
+ const n = ce, i = de, a = Ts;
473
+ h.save(), h.translate(t, e), h.rotate(ct.degreesToRadians(o.angle)), h.fillStyle = ye, h.strokeStyle = me, h.lineWidth = pe, h.beginPath(), h.roundRect(-n / 2, -i / 2, n, i, a), h.fill(), h.stroke(), h.restore();
474
474
  }
475
- function ze(h, t, e, s, o) {
476
- const n = le, i = he, a = Is;
477
- h.save(), h.translate(t, e), h.rotate(rt.degreesToRadians(o.angle)), h.fillStyle = ye, h.strokeStyle = me, h.lineWidth = pe, h.beginPath(), h.roundRect(-n / 2, -i / 2, n, i, a), h.fill(), h.stroke(), h.restore();
475
+ function Ye(h, t, e, s, o) {
476
+ const n = le, i = he, a = Es;
477
+ h.save(), h.translate(t, e), h.rotate(ct.degreesToRadians(o.angle)), h.fillStyle = ye, h.strokeStyle = me, h.lineWidth = pe, h.beginPath(), h.roundRect(-n / 2, -i / 2, n, i, a), h.fill(), h.stroke(), h.restore();
478
478
  }
479
- const Ts = "", $e = new Image();
480
- $e.src = Ts;
481
- function Es(h, t, e, s, o) {
482
- const i = Xt / 2;
483
- h.save(), h.translate(t, e), h.rotate(rt.degreesToRadians(o.angle)), h.fillStyle = Cs, h.beginPath(), h.arc(0, 0, i, 0, 2 * Math.PI), h.fill(), h.drawImage($e, -i / 2, -i / 2, i, i), h.restore();
479
+ const Ds = "", es = new Image();
480
+ es.src = Ds;
481
+ function Ls(h, t, e, s, o) {
482
+ const i = Kt / 2;
483
+ h.save(), h.translate(t, e), h.rotate(ct.degreesToRadians(o.angle)), h.fillStyle = Os, h.beginPath(), h.arc(0, 0, i, 0, 2 * Math.PI), h.fill(), h.drawImage(es, -i / 2, -i / 2, i, i), h.restore();
484
484
  }
485
- const Os = {
485
+ const Rs = {
486
486
  // Угловые точки
487
487
  tl: {
488
488
  render: Zt,
489
- sizeX: it,
490
- sizeY: it,
489
+ sizeX: at,
490
+ sizeY: at,
491
491
  offsetX: 0,
492
492
  offsetY: 0
493
493
  },
494
494
  tr: {
495
495
  render: Zt,
496
- sizeX: it,
497
- sizeY: it,
496
+ sizeX: at,
497
+ sizeY: at,
498
498
  offsetX: 0,
499
499
  offsetY: 0
500
500
  },
501
501
  bl: {
502
502
  render: Zt,
503
- sizeX: it,
504
- sizeY: it,
503
+ sizeX: at,
504
+ sizeY: at,
505
505
  offsetX: 0,
506
506
  offsetY: 0
507
507
  },
508
508
  br: {
509
509
  render: Zt,
510
- sizeX: it,
511
- sizeY: it,
510
+ sizeX: at,
511
+ sizeY: at,
512
512
  offsetX: 0,
513
513
  offsetY: 0
514
514
  },
515
515
  // Середина вертикалей
516
516
  ml: {
517
- render: xe,
517
+ render: Ue,
518
518
  sizeX: ce,
519
519
  sizeY: de,
520
520
  offsetX: 0,
521
521
  offsetY: 0
522
522
  },
523
523
  mr: {
524
- render: xe,
524
+ render: Ue,
525
525
  sizeX: ce,
526
526
  sizeY: de,
527
527
  offsetX: 0,
@@ -529,14 +529,14 @@ const Os = {
529
529
  },
530
530
  // Середина горизонталей
531
531
  mt: {
532
- render: ze,
532
+ render: Ye,
533
533
  sizeX: le,
534
534
  sizeY: he,
535
535
  offsetX: 0,
536
536
  offsetY: 0
537
537
  },
538
538
  mb: {
539
- render: ze,
539
+ render: Ye,
540
540
  sizeX: le,
541
541
  sizeY: he,
542
542
  offsetX: 0,
@@ -544,14 +544,14 @@ const Os = {
544
544
  },
545
545
  // Специальный «rotate» контрол
546
546
  mtr: {
547
- render: Es,
548
- sizeX: Xt,
549
- sizeY: Xt,
547
+ render: Ls,
548
+ sizeX: Kt,
549
+ sizeY: Kt,
550
550
  offsetX: 0,
551
- offsetY: -Xt
551
+ offsetY: -Kt
552
552
  }
553
553
  };
554
- class Q {
554
+ class $ {
555
555
  /**
556
556
  * Отключает изменение ширины по оси X для заблокированных объектов, сохраняя поведение остального хэндлера.
557
557
  */
@@ -567,7 +567,7 @@ class Q {
567
567
  * Применяет конфигурацию контролов к набору по ключам из DEFAULT_CONTROLS.
568
568
  */
569
569
  static applyControlOverrides(t) {
570
- Object.entries(Os).forEach(([e, s]) => {
570
+ Object.entries(Rs).forEach(([e, s]) => {
571
571
  const o = t[e];
572
572
  o && (Object.assign(o, s), e === "mtr" && (o.cursorStyle = "grab", o.mouseDownHandler = (n, i, a, r) => {
573
573
  var d;
@@ -580,24 +580,24 @@ class Q {
580
580
  * Регистрирует контролы и настройки поведения выделений.
581
581
  */
582
582
  static apply() {
583
- const t = Re.createObjectDefaultControls();
584
- Q.applyControlOverrides(t), _e.ownDefaults.controls = t;
585
- const e = Re.createTextboxDefaultControls();
586
- Q.applyControlOverrides(e), e.mt && (e.mt.visible = !1), e.mb && (e.mb.visible = !1), Q.wrapWidthControl(e.ml), Q.wrapWidthControl(e.mr), st.ownDefaults.controls = e, Q.patchActiveSelectionBounds(), _e.ownDefaults.snapAngle = 1;
583
+ const t = xe.createObjectDefaultControls();
584
+ $.applyControlOverrides(t), ke.ownDefaults.controls = t;
585
+ const e = xe.createTextboxDefaultControls();
586
+ $.applyControlOverrides(e), e.mt && (e.mt.visible = !1), e.mb && (e.mb.visible = !1), $.wrapWidthControl(e.ml), $.wrapWidthControl(e.mr), st.ownDefaults.controls = e, $.patchActiveSelectionBounds(), ke.ownDefaults.snapAngle = 1;
587
587
  }
588
588
  /**
589
589
  * Обновляет алгоритм расчёта границ ActiveSelection, чтобы учитывать фон и отступы текстовых объектов.
590
590
  */
591
591
  static patchActiveSelectionBounds() {
592
- const t = B.prototype, e = t._calcBoundsFromObjects;
592
+ const t = k.prototype, e = t._calcBoundsFromObjects;
593
593
  t._calcBoundsFromObjects = function(...n) {
594
594
  var g, f;
595
595
  const i = (f = (g = this.getObjects) == null ? void 0 : g.call(this)) != null ? f : [];
596
- Q.applyTextSelectionScalingLock({
596
+ $.applyTextSelectionScalingLock({
597
597
  selection: this,
598
598
  objects: i
599
599
  });
600
- const a = Q.calculateActiveSelectionBounds({
600
+ const a = $.calculateActiveSelectionBounds({
601
601
  objects: i
602
602
  });
603
603
  if (!a)
@@ -609,45 +609,45 @@ class Q {
609
609
  width: d,
610
610
  height: l
611
611
  });
612
- const u = new $(r + d / 2, c + l / 2);
612
+ const u = new J(r + d / 2, c + l / 2);
613
613
  return this.setPositionByOrigin(u, "center", "center"), a;
614
614
  };
615
615
  const s = t._onAfterObjectsChange;
616
616
  t._onAfterObjectsChange = function(n, i) {
617
617
  var p, m;
618
618
  const a = s ? s.call(this, n, i) : void 0, r = (m = (p = this.getObjects) == null ? void 0 : p.call(this)) != null ? m : [];
619
- Q.applyTextSelectionScalingLock({
619
+ $.applyTextSelectionScalingLock({
620
620
  selection: this,
621
621
  objects: r
622
622
  });
623
- const c = Q.calculateActiveSelectionBounds({
623
+ const c = $.calculateActiveSelectionBounds({
624
624
  objects: r
625
625
  });
626
626
  if (!c) return a;
627
- const { left: d, top: l, width: u, height: g } = c, f = new $(d + u / 2, l + g / 2);
627
+ const { left: d, top: l, width: u, height: g } = c, f = new J(d + u / 2, l + g / 2);
628
628
  return this.set({
629
629
  width: u,
630
630
  height: g
631
631
  }), this.setPositionByOrigin(f, "center", "center"), this.setCoords(), a;
632
632
  };
633
- const o = Ne.prototype.calcBoundingBox;
634
- Ne.prototype.calcBoundingBox = function(n, i) {
633
+ const o = Be.prototype.calcBoundingBox;
634
+ Be.prototype.calcBoundingBox = function(n, i) {
635
635
  const { target: a, type: r, overrides: c } = i;
636
636
  if (r === "imperative" && c)
637
637
  return c;
638
- if (!(a instanceof B))
638
+ if (!(a instanceof k))
639
639
  return o.call(this, n, i);
640
- Q.applyTextSelectionScalingLock({
640
+ $.applyTextSelectionScalingLock({
641
641
  selection: a,
642
642
  objects: n
643
643
  });
644
- const d = Q.calculateActiveSelectionBounds({ objects: n });
644
+ const d = $.calculateActiveSelectionBounds({ objects: n });
645
645
  if (!d)
646
646
  return o.call(this, n, i);
647
- const { left: l, top: u, width: g, height: f } = d, p = new $(g, f), m = new $(l + g / 2, u + f / 2);
647
+ const { left: l, top: u, width: g, height: f } = d, p = new J(g, f), m = new J(l + g / 2, u + f / 2);
648
648
  return r === "initialization" ? {
649
649
  center: m,
650
- relativeCorrection: new $(0, 0),
650
+ relativeCorrection: new J(0, 0),
651
651
  size: p
652
652
  } : {
653
653
  center: m,
@@ -855,7 +855,7 @@ N.registeredFontKeys = /* @__PURE__ */ new Set(), N.descriptorDefaults = {
855
855
  display: "auto"
856
856
  };
857
857
  let ue = N;
858
- const Ls = "", Ds = "", Rs = "", _s = "", Ns = "", ks = "", Bs = "", xs = "", Bt = {
858
+ const _s = "", Ns = "", xs = "", ks = "", Bs = "", zs = "", Ps = "", Us = "", kt = {
859
859
  style: {
860
860
  position: "absolute",
861
861
  display: "none",
@@ -922,14 +922,14 @@ const Ls = "
922
922
  ],
923
923
  offsetTop: 50,
924
924
  icons: {
925
- copyPaste: Ls,
926
- delete: xs,
927
- lock: Ds,
928
- unlock: Rs,
929
- bringToFront: ks,
930
- sendToBack: Bs,
931
- bringForward: _s,
932
- sendBackwards: Ns
925
+ copyPaste: _s,
926
+ delete: Us,
927
+ lock: Ns,
928
+ unlock: xs,
929
+ bringToFront: zs,
930
+ sendToBack: Ps,
931
+ bringForward: ks,
932
+ sendBackwards: Bs
933
933
  },
934
934
  handlers: {
935
935
  copyPaste: (h) => _(null, null, function* () {
@@ -958,18 +958,18 @@ const Ls = "
958
958
  }
959
959
  }
960
960
  };
961
- class zs {
961
+ class Ys {
962
962
  constructor({ editor: t }) {
963
963
  this.currentTarget = null, this.currentLocked = !1, this.isTransforming = !1, this.isTemporarilyHidden = !1, this.editor = t, this.canvas = t.canvas, this.options = t.options, this._initToolbar();
964
964
  }
965
965
  _initToolbar() {
966
966
  if (!this.options.showToolbar) return;
967
967
  const t = this.options.toolbar || {};
968
- this.config = bt(k(k({}, Bt), t), {
969
- style: k(k({}, Bt.style), t.style || {}),
970
- btnStyle: k(k({}, Bt.btnStyle), t.btnStyle || {}),
971
- icons: k(k({}, Bt.icons), t.icons || {}),
972
- handlers: k(k({}, Bt.handlers), t.handlers || {})
968
+ this.config = St(x(x({}, kt), t), {
969
+ style: x(x({}, kt.style), t.style || {}),
970
+ btnStyle: x(x({}, kt.btnStyle), t.btnStyle || {}),
971
+ icons: x(x({}, kt.icons), t.icons || {}),
972
+ handlers: x(x({}, kt.handlers), t.handlers || {})
973
973
  }), this.currentTarget = null, this.currentLocked = !1, this.isTransforming = !1, this.isTemporarilyHidden = !1, this._onMouseDown = this._handleMouseDown.bind(this), this._onObjectMoving = this._startTransform.bind(this), this._onObjectScaling = this._startTransform.bind(this), this._onObjectRotating = this._startTransform.bind(this), this._onMouseUp = this._endTransform.bind(this), this._onObjectModified = this._endTransform.bind(this), this._onSelectionChange = this._updateToolbar.bind(this), this._onSelectionClear = () => {
974
974
  this.el.style.display = "none";
975
975
  }, this._createDOM(), this._bindEvents();
@@ -1086,7 +1086,7 @@ class zs {
1086
1086
  this.el.removeEventListener("mouseover", this._onBtnOver), this.el.removeEventListener("mouseout", this._onBtnOut), this.canvas.off("mouse:down", this._onMouseDown), this.canvas.off("object:moving", this._onObjectMoving), this.canvas.off("object:scaling", this._onObjectScaling), this.canvas.off("object:rotating", this._onObjectRotating), this.canvas.off("mouse:up", this._onMouseUp), this.canvas.off("object:modified", this._onObjectModified), this.canvas.off("selection:created", this._onSelectionChange), this.canvas.off("selection:updated", this._onSelectionChange), this.canvas.off("after:render", this._onSelectionChange), this.canvas.off("selection:cleared", this._onSelectionClear), this.el.remove();
1087
1087
  }
1088
1088
  }
1089
- const Us = {
1089
+ const Fs = {
1090
1090
  position: "absolute",
1091
1091
  display: "none",
1092
1092
  background: "#2B2D33",
@@ -1100,7 +1100,7 @@ const Us = {
1100
1100
  "pointer-events": "none",
1101
1101
  "white-space": "nowrap",
1102
1102
  "box-shadow": "0 2px 8px rgba(0, 0, 0, 0.2)"
1103
- }, Ue = 16, Pe = 16, Ps = "fabric-editor-angle-indicator";
1103
+ }, Fe = 16, He = 16, Hs = "fabric-editor-angle-indicator";
1104
1104
  class ve {
1105
1105
  constructor({ editor: t }) {
1106
1106
  this.isActive = !1, this.currentAngle = 0, this.editor = t, this.canvas = t.canvas, this.options = t.options, this._createDOM(), this._bindEvents();
@@ -1109,7 +1109,7 @@ class ve {
1109
1109
  * Создание DOM-элемента индикатора
1110
1110
  */
1111
1111
  _createDOM() {
1112
- this.el = document.createElement("div"), this.el.className = Ps, Object.entries(Us).forEach(([t, e]) => {
1112
+ this.el = document.createElement("div"), this.el.className = Hs, Object.entries(Fs).forEach(([t, e]) => {
1113
1113
  this.el.style.setProperty(t, e);
1114
1114
  }), this.canvas.wrapperEl.appendChild(this.el);
1115
1115
  }
@@ -1160,9 +1160,9 @@ class ve {
1160
1160
  */
1161
1161
  _positionIndicator(t) {
1162
1162
  const e = this.canvas.wrapperEl.getBoundingClientRect();
1163
- let s = t.clientX - e.left + Ue, o = t.clientY - e.top + Pe;
1163
+ let s = t.clientX - e.left + Fe, o = t.clientY - e.top + He;
1164
1164
  const n = this.el.getBoundingClientRect(), i = n.width, a = n.height;
1165
- s + i > e.width && (s = t.clientX - e.left - i - Ue), o + a > e.height && (o = t.clientY - e.top - a - Pe), this.el.style.left = `${s}px`, this.el.style.top = `${o}px`;
1165
+ s + i > e.width && (s = t.clientX - e.left - i - Fe), o + a > e.height && (o = t.clientY - e.top - a - He), this.el.style.left = `${s}px`, this.el.style.top = `${o}px`;
1166
1166
  }
1167
1167
  /**
1168
1168
  * Показать индикатор
@@ -1193,7 +1193,7 @@ class ve {
1193
1193
  this.canvas && (this.canvas.off("object:rotating", this._onObjectRotating), this.canvas.off("mouse:up", this._onMouseUp), this.canvas.off("object:modified", this._onObjectModified), this.canvas.off("selection:cleared", this._onSelectionCleared)), (t = this.el) != null && t.parentNode && this.el.parentNode.removeChild(this.el), this.el = null, this.editor = null, this.canvas = null, this.options = null;
1194
1194
  }
1195
1195
  }
1196
- const Je = [
1196
+ const ss = [
1197
1197
  "selectable",
1198
1198
  "evented",
1199
1199
  "id",
@@ -1229,7 +1229,7 @@ const Je = [
1229
1229
  "radiusBottomRight",
1230
1230
  "radiusBottomLeft"
1231
1231
  ];
1232
- class Kt {
1232
+ class Qt {
1233
1233
  constructor({ editor: t }) {
1234
1234
  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();
1235
1235
  }
@@ -1241,7 +1241,7 @@ class Kt {
1241
1241
  return this.patches[this.currentIndex - 1] || null;
1242
1242
  }
1243
1243
  _createDiffPatcher() {
1244
- this.diffPatcher = ys({
1244
+ this.diffPatcher = Ms({
1245
1245
  objectHash(t) {
1246
1246
  const e = t, s = t, o = s.styles ? JSON.stringify(s.styles) : "";
1247
1247
  return [
@@ -1291,7 +1291,7 @@ class Kt {
1291
1291
  includeValueOnMove: !1
1292
1292
  },
1293
1293
  textDiff: {
1294
- diffMatchPatch: vs,
1294
+ diffMatchPatch: ws,
1295
1295
  minLength: 60
1296
1296
  }
1297
1297
  });
@@ -1333,7 +1333,7 @@ class Kt {
1333
1333
  if (console.log("saveState"), this.skipHistory) return;
1334
1334
  console.time("saveState");
1335
1335
  const t = this._withTemporaryUnlock(
1336
- () => this.canvas.toDatalessObject([...Je])
1336
+ () => this.canvas.toDatalessObject([...ss])
1337
1337
  );
1338
1338
  if (console.timeEnd("saveState"), !this.baseState) {
1339
1339
  this.baseState = t, this.patches = [], this.currentIndex = 0, console.log("Базовое состояние сохранено.");
@@ -1344,7 +1344,7 @@ class Kt {
1344
1344
  console.log("Нет изменений для сохранения.");
1345
1345
  return;
1346
1346
  }
1347
- console.log("baseState", this.baseState), this.currentIndex < this.patches.length && this.patches.splice(this.currentIndex), console.log("diff", s), this.totalChangesCount += 1, this.patches.push({ id: Y(), diff: s }), this.currentIndex += 1, this.patches.length > this.maxHistoryLength && (this.baseState = this.diffPatcher.patch(this.baseState, this.patches[0].diff), this.patches.shift(), this.currentIndex -= 1, this.baseStateChangesCount += 1), console.log("Состояние сохранено. Текущий индекс истории:", this.currentIndex);
1347
+ console.log("baseState", this.baseState), this.currentIndex < this.patches.length && this.patches.splice(this.currentIndex), console.log("diff", s), this.totalChangesCount += 1, this.patches.push({ id: F(), diff: s }), this.currentIndex += 1, this.patches.length > this.maxHistoryLength && (this.baseState = this.diffPatcher.patch(this.baseState, this.patches[0].diff), this.patches.shift(), this.currentIndex -= 1, this.baseStateChangesCount += 1), console.log("Состояние сохранено. Текущий индекс истории:", this.currentIndex);
1348
1348
  }
1349
1349
  /**
1350
1350
  * Сериализует customData объектов в строку. Это необходимо чтобы при вызове loadFromJSON fabricjs не пытался обрабатывать свойства внутри customData, как свойства FabricObject, если их названия совпадают с зарезервированными.
@@ -1381,8 +1381,8 @@ class Kt {
1381
1381
  if (!t) return;
1382
1382
  console.log("loadStateFromFullState fullState", t);
1383
1383
  const { canvas: e, canvasManager: s, interactionBlocker: o, backgroundManager: n } = this.editor, { width: i, height: a } = e;
1384
- o.overlayMask = null, Kt._serializeCustomData(t), yield e.loadFromJSON(t, (l, u) => {
1385
- Kt._deserializeCustomData(l, u);
1384
+ o.overlayMask = null, Qt._serializeCustomData(t), yield e.loadFromJSON(t, (l, u) => {
1385
+ Qt._deserializeCustomData(l, u);
1386
1386
  });
1387
1387
  const r = e.getObjects().find((l) => l.id === "montage-area");
1388
1388
  r && (this.editor.montageArea = r, (i !== e.getWidth() || a !== e.getHeight()) && s.updateCanvas());
@@ -1496,7 +1496,7 @@ class Kt {
1496
1496
  }
1497
1497
  }
1498
1498
  }
1499
- const Ys = 0.1, Fs = 2, Ye = 0.1, Hs = 90, It = 16, Ct = 16, ft = 4096, pt = 4096, Fe = "application/image-editor:", Gt = [
1499
+ const Ws = 0.1, Zs = 2, We = 0.1, Gs = 90, Et = 16, Ot = 16, pt = 4096, mt = 4096, Ze = "application/image-editor:", Gt = [
1500
1500
  "format",
1501
1501
  "uppercase",
1502
1502
  "textCaseRaw",
@@ -1510,8 +1510,8 @@ const Ys = 0.1, Fs = 2, Ye = 0.1, Hs = 90, It = 16, Ct = 16, ft = 4096, pt = 409
1510
1510
  "radiusTopRight",
1511
1511
  "radiusBottomRight",
1512
1512
  "radiusBottomLeft"
1513
- ], Ws = 50;
1514
- class at {
1513
+ ], Vs = 50;
1514
+ class rt {
1515
1515
  constructor({ editor: t }) {
1516
1516
  this.editor = t, this.options = t.options, this._createdBlobUrls = [], this.acceptContentTypes = this.editor.options.acceptContentTypes, this.acceptFormats = this.getAllowedFormatsFromContentTypes();
1517
1517
  }
@@ -1538,7 +1538,7 @@ class at {
1538
1538
  withoutSelection: a = !1
1539
1539
  } = t;
1540
1540
  if (!e) return null;
1541
- const { canvas: r, montageArea: c, transformManager: d, historyManager: l, errorManager: u } = this.editor, g = yield this.getContentType(e), f = at.getFormatFromContentType(g), { acceptContentTypes: p, acceptFormats: m } = this;
1541
+ const { canvas: r, montageArea: c, transformManager: d, historyManager: l, errorManager: u } = this.editor, g = yield this.getContentType(e), f = rt.getFormatFromContentType(g), { acceptContentTypes: p, acceptFormats: m } = this;
1542
1542
  if (!this.isAllowedContentType(g)) {
1543
1543
  const v = `Неверный contentType для изображения: ${g}. Ожидается один из: ${this.acceptContentTypes.join(", ")}.`;
1544
1544
  return u.emitError({
@@ -1584,23 +1584,23 @@ class at {
1584
1584
  }
1585
1585
  }), null;
1586
1586
  if (this._createdBlobUrls.push(v), f === "svg") {
1587
- const S = yield ds(v);
1588
- b = rt.groupSVGElements(S.objects, S.options);
1587
+ const S = yield us(v);
1588
+ b = ct.groupSVGElements(S.objects, S.options);
1589
1589
  } else
1590
- b = yield kt.fromURL(v, { crossOrigin: "anonymous" });
1590
+ b = yield xt.fromURL(v, { crossOrigin: "anonymous" });
1591
1591
  const { width: I, height: y } = b;
1592
- if (b instanceof kt) {
1592
+ if (b instanceof xt) {
1593
1593
  const S = b.getElement();
1594
1594
  let A = "";
1595
- if (S instanceof HTMLImageElement ? A = S.src : S instanceof HTMLCanvasElement && (A = S.toDataURL()), y > pt || I > ft) {
1595
+ if (S instanceof HTMLImageElement ? A = S.src : S instanceof HTMLCanvasElement && (A = S.toDataURL()), y > mt || I > pt) {
1596
1596
  const M = yield this.resizeImageToBoundaries(A, "max"), C = URL.createObjectURL(M);
1597
- this._createdBlobUrls.push(C), b = yield kt.fromURL(C, { crossOrigin: "anonymous" });
1598
- } else if (y < Ct || I < It) {
1597
+ this._createdBlobUrls.push(C), b = yield xt.fromURL(C, { crossOrigin: "anonymous" });
1598
+ } else if (y < Ot || I < Et) {
1599
1599
  const M = yield this.resizeImageToBoundaries(A, "min"), C = URL.createObjectURL(M);
1600
- this._createdBlobUrls.push(C), b = yield kt.fromURL(C, { crossOrigin: "anonymous" });
1600
+ this._createdBlobUrls.push(C), b = yield xt.fromURL(C, { crossOrigin: "anonymous" });
1601
1601
  }
1602
1602
  }
1603
- if (b.set("id", `${b.type}-${Y()}`), b.set("format", f), s === "scale-montage")
1603
+ if (b.set("id", `${b.type}-${F()}`), b.set("format", f), s === "scale-montage")
1604
1604
  this.editor.canvasManager.scaleMontageAreaToImage({ object: b, withoutSave: !0 });
1605
1605
  else {
1606
1606
  const { width: S, height: A } = c, M = this.calculateScaleFactor({ imageObject: b, scaleType: s });
@@ -1649,15 +1649,15 @@ class at {
1649
1649
  */
1650
1650
  resizeImageToBoundaries(t, e = "max") {
1651
1651
  return _(this, null, function* () {
1652
- let s = `Размер изображения больше максимального размера канваса, поэтому оно будет уменьшено до максимальных размеров c сохранением пропорций: ${ft}x${pt}`;
1653
- e === "min" && (s = `Размер изображения меньше минимального размера канваса, поэтому оно будет увеличено до минимальных размеров c сохранением пропорций: ${It}x${Ct}`);
1652
+ let s = `Размер изображения больше максимального размера канваса, поэтому оно будет уменьшено до максимальных размеров c сохранением пропорций: ${pt}x${mt}`;
1653
+ e === "min" && (s = `Размер изображения меньше минимального размера канваса, поэтому оно будет увеличено до минимальных размеров c сохранением пропорций: ${Et}x${Ot}`);
1654
1654
  const o = {
1655
1655
  dataURL: t,
1656
1656
  sizeType: e,
1657
- maxWidth: ft,
1658
- maxHeight: pt,
1659
- minWidth: It,
1660
- minHeight: Ct
1657
+ maxWidth: pt,
1658
+ maxHeight: mt,
1659
+ minWidth: Et,
1660
+ minHeight: Ot
1661
1661
  };
1662
1662
  return this.editor.errorManager.emitWarning({
1663
1663
  origin: "ImageManager",
@@ -1688,7 +1688,7 @@ class at {
1688
1688
  exportAsBlob: n = !1
1689
1689
  } = t, { canvas: i, montageArea: a, workerManager: r, interactionBlocker: c } = this.editor;
1690
1690
  try {
1691
- const d = s === "application/pdf", l = d ? "image/jpg" : s, u = at.getFormatFromContentType(l);
1691
+ const d = s === "application/pdf", l = d ? "image/jpg" : s, u = rt.getFormatFromContentType(l);
1692
1692
  a.setCoords();
1693
1693
  const { left: g, top: f, width: p, height: m } = a.getBoundingRect(), v = yield i.clone(["id", "format", "locked"]);
1694
1694
  v.enableRetinaScaling = !1, ["image/jpg", "image/jpeg"].includes(l) && (v.backgroundColor = "#ffffff");
@@ -1702,8 +1702,8 @@ class at {
1702
1702
  if (u === "svg" && I) {
1703
1703
  const j = v.toSVG();
1704
1704
  v.dispose();
1705
- const x = {
1706
- image: at._exportSVGStringAsFile(j, {
1705
+ const B = {
1706
+ image: rt._exportSVGStringAsFile(j, {
1707
1707
  exportAsBase64: o,
1708
1708
  exportAsBlob: n,
1709
1709
  fileName: e
@@ -1712,11 +1712,11 @@ class at {
1712
1712
  contentType: "image/svg+xml",
1713
1713
  fileName: e.replace(/\.[^/.]+$/, ".svg")
1714
1714
  };
1715
- return i.fire("editor:canvas-exported", x), x;
1715
+ return i.fire("editor:canvas-exported", B), B;
1716
1716
  }
1717
1717
  const y = yield new Promise((j, T) => {
1718
- v.getElement().toBlob((x) => {
1719
- x ? j(x) : T(new Error("Failed to create Blob from canvas"));
1718
+ v.getElement().toBlob((B) => {
1719
+ B ? j(B) : T(new Error("Failed to create Blob from canvas"));
1720
1720
  });
1721
1721
  });
1722
1722
  if (v.dispose(), n) {
@@ -1734,27 +1734,27 @@ class at {
1734
1734
  [w]
1735
1735
  );
1736
1736
  if (d) {
1737
- const T = p * 0.264583, x = m * 0.264583, Z = (yield this.editor.moduleLoader.loadModule("jspdf")).jsPDF, P = new Z({
1738
- orientation: T > x ? "landscape" : "portrait",
1737
+ const T = p * 0.264583, B = m * 0.264583, G = (yield this.editor.moduleLoader.loadModule("jspdf")).jsPDF, Y = new G({
1738
+ orientation: T > B ? "landscape" : "portrait",
1739
1739
  unit: "mm",
1740
- format: [T, x]
1740
+ format: [T, B]
1741
1741
  });
1742
- if (P.addImage(String(S), "JPG", 0, 0, T, x), o) {
1743
- const X = {
1744
- image: P.output("datauristring"),
1742
+ if (Y.addImage(String(S), "JPG", 0, 0, T, B), o) {
1743
+ const K = {
1744
+ image: Y.output("datauristring"),
1745
1745
  format: "pdf",
1746
1746
  contentType: "application/pdf",
1747
1747
  fileName: e
1748
1748
  };
1749
- return i.fire("editor:canvas-exported", X), X;
1749
+ return i.fire("editor:canvas-exported", K), K;
1750
1750
  }
1751
- const F = P.output("blob"), L = {
1752
- image: new File([F], e, { type: "application/pdf" }),
1751
+ const H = Y.output("blob"), D = {
1752
+ image: new File([H], e, { type: "application/pdf" }),
1753
1753
  format: "pdf",
1754
1754
  contentType: "application/pdf",
1755
1755
  fileName: e
1756
1756
  };
1757
- return i.fire("editor:canvas-exported", L), L;
1757
+ return i.fire("editor:canvas-exported", D), D;
1758
1758
  }
1759
1759
  if (o) {
1760
1760
  const j = {
@@ -1812,9 +1812,9 @@ class at {
1812
1812
  data: { contentType: o, fileName: s, exportAsBase64: n, exportAsBlob: i }
1813
1813
  }), null;
1814
1814
  try {
1815
- const d = at.getFormatFromContentType(o);
1815
+ const d = rt.getFormatFromContentType(o);
1816
1816
  if (d === "svg") {
1817
- const p = c.toSVG(), m = at._exportSVGStringAsFile(p, {
1817
+ const p = c.toSVG(), m = rt._exportSVGStringAsFile(p, {
1818
1818
  exportAsBase64: n,
1819
1819
  exportAsBlob: i,
1820
1820
  fileName: s
@@ -1827,7 +1827,7 @@ class at {
1827
1827
  };
1828
1828
  return a.fire("editor:object-exported", v), v;
1829
1829
  }
1830
- if (n && c instanceof kt) {
1830
+ if (n && c instanceof xt) {
1831
1831
  const p = yield createImageBitmap(c.getElement()), m = yield r.post(
1832
1832
  "toDataURL",
1833
1833
  {
@@ -1892,7 +1892,7 @@ class at {
1892
1892
  * @returns массив допустимых форматов изображений
1893
1893
  */
1894
1894
  getAllowedFormatsFromContentTypes() {
1895
- return this.acceptContentTypes.map((t) => at.getFormatFromContentType(t)).filter((t) => t);
1895
+ return this.acceptContentTypes.map((t) => rt.getFormatFromContentType(t)).filter((t) => t);
1896
1896
  }
1897
1897
  /**
1898
1898
  * Проверяет, является ли contentType допустимым типом изображения.
@@ -1945,7 +1945,7 @@ class at {
1945
1945
  try {
1946
1946
  const o = (e = new URL(t).pathname.split(".").pop()) == null ? void 0 : e.toLowerCase(), n = {};
1947
1947
  return this.acceptContentTypes.forEach((i) => {
1948
- const a = at.getFormatFromContentType(i);
1948
+ const a = rt.getFormatFromContentType(i);
1949
1949
  a && (n[a] = i);
1950
1950
  }), o && n[o] || "application/octet-stream";
1951
1951
  } catch (s) {
@@ -1998,11 +1998,11 @@ class at {
1998
1998
  return e ? e[1] : "";
1999
1999
  }
2000
2000
  }
2001
- const Mt = (h, t, e) => Math.max(Math.min(h, e), t), He = (h, t) => h * t, Zs = (h, t) => new $(h / 2, t / 2);
2002
- function Gs(h) {
2001
+ const At = (h, t, e) => Math.max(Math.min(h, e), t), Ge = (h, t) => h * t, Xs = (h, t) => new J(h / 2, t / 2);
2002
+ function Ks(h) {
2003
2003
  return ((h == null ? void 0 : h.type) === "image" || (h == null ? void 0 : h.format) === "svg") && typeof (h == null ? void 0 : h.width) == "number" && typeof (h == null ? void 0 : h.height) == "number";
2004
2004
  }
2005
- class Vs {
2005
+ class Qs {
2006
2006
  /**
2007
2007
  * @param options
2008
2008
  * @param options.editor – экземпляр редактора
@@ -2033,9 +2033,9 @@ class Vs {
2033
2033
  canvas: n,
2034
2034
  montageArea: i,
2035
2035
  options: { canvasBackstoreWidth: a }
2036
- } = this.editor, { width: r, height: c } = i, d = Mt(Number(t), It, ft);
2036
+ } = this.editor, { width: r, height: c } = i, d = At(Number(t), Et, pt);
2037
2037
  if (!a || a === "auto" || o ? this.adaptCanvasToContainer() : a ? this.setCanvasBackstoreWidth(Number(a)) : this.setCanvasBackstoreWidth(d), i.set({ width: d }), (f = n.clipPath) == null || f.set({ width: d }), e) {
2038
- const p = d / r, m = He(c, p);
2038
+ const p = d / r, m = Ge(c, p);
2039
2039
  this.setResolutionHeight(m);
2040
2040
  return;
2041
2041
  }
@@ -2063,9 +2063,9 @@ class Vs {
2063
2063
  canvas: n,
2064
2064
  montageArea: i,
2065
2065
  options: { canvasBackstoreHeight: a }
2066
- } = this.editor, { width: r, height: c } = i, d = Mt(Number(t), Ct, pt);
2066
+ } = this.editor, { width: r, height: c } = i, d = At(Number(t), Ot, mt);
2067
2067
  if (!a || a === "auto" || o ? this.adaptCanvasToContainer() : a ? this.setCanvasBackstoreHeight(Number(a)) : this.setCanvasBackstoreHeight(d), i.set({ height: d }), (f = n.clipPath) == null || f.set({ height: d }), e) {
2068
- const p = d / c, m = He(r, p);
2068
+ const p = d / c, m = Ge(r, p);
2069
2069
  this.setResolutionWidth(m);
2070
2070
  return;
2071
2071
  }
@@ -2083,7 +2083,7 @@ class Vs {
2083
2083
  */
2084
2084
  centerMontageArea() {
2085
2085
  var r;
2086
- const { canvas: t, montageArea: e } = this.editor, s = t.getWidth(), o = t.getHeight(), n = t.getZoom(), i = Zs(s, o);
2086
+ const { canvas: t, montageArea: e } = this.editor, s = t.getWidth(), o = t.getHeight(), n = t.getZoom(), i = Xs(s, o);
2087
2087
  e.set({
2088
2088
  left: s / 2,
2089
2089
  top: o / 2
@@ -2116,7 +2116,7 @@ class Vs {
2116
2116
  */
2117
2117
  setCanvasBackstoreWidth(t) {
2118
2118
  if (!t || typeof t != "number") return;
2119
- const e = Mt(t, It, ft);
2119
+ const e = At(t, Et, pt);
2120
2120
  this.editor.canvas.setDimensions({ width: e }, { backstoreOnly: !0 });
2121
2121
  }
2122
2122
  /**
@@ -2125,7 +2125,7 @@ class Vs {
2125
2125
  */
2126
2126
  setCanvasBackstoreHeight(t) {
2127
2127
  if (!t || typeof t != "number") return;
2128
- const e = Mt(t, Ct, pt);
2128
+ const e = At(t, Ot, mt);
2129
2129
  this.editor.canvas.setDimensions({ height: e }, { backstoreOnly: !0 });
2130
2130
  }
2131
2131
  /**
@@ -2134,7 +2134,7 @@ class Vs {
2134
2134
  * с учётом минимальных и максимальных значений.
2135
2135
  */
2136
2136
  adaptCanvasToContainer() {
2137
- const { canvas: t } = this.editor, e = this.getEditorContainer(), s = e.clientWidth, o = e.clientHeight, n = Mt(s, It, ft), i = Mt(o, Ct, pt);
2137
+ const { canvas: t } = this.editor, e = this.getEditorContainer(), s = e.clientWidth, o = e.clientHeight, n = At(s, Et, pt), i = At(o, Ot, mt);
2138
2138
  t.setDimensions({ width: n, height: i }, { backstoreOnly: !0 });
2139
2139
  }
2140
2140
  /**
@@ -2168,7 +2168,7 @@ class Vs {
2168
2168
  if (d.length === 1)
2169
2169
  t.setActiveObject(d[0]);
2170
2170
  else {
2171
- const l = new B(d, {
2171
+ const l = new k(d, {
2172
2172
  canvas: t
2173
2173
  });
2174
2174
  t.setActiveObject(l);
@@ -2334,9 +2334,9 @@ class Vs {
2334
2334
  montageAreaHeight: r
2335
2335
  }
2336
2336
  } = this.editor, c = t || o.getActiveObject();
2337
- if (!Gs(c)) return;
2337
+ if (!Ks(c)) return;
2338
2338
  const { width: d, height: l } = c;
2339
- let u = Math.min(d, ft), g = Math.min(l, pt);
2339
+ let u = Math.min(d, pt), g = Math.min(l, mt);
2340
2340
  if (e) {
2341
2341
  const {
2342
2342
  width: f,
@@ -2394,7 +2394,7 @@ class Vs {
2394
2394
  );
2395
2395
  }
2396
2396
  }
2397
- class Xs {
2397
+ class qs {
2398
2398
  constructor({ editor: t }) {
2399
2399
  this.editor = t, this.options = t.options;
2400
2400
  }
@@ -2405,7 +2405,7 @@ class Xs {
2405
2405
  * @param options.withoutSave - Не сохранять состояние
2406
2406
  * @fires editor:object-rotated
2407
2407
  */
2408
- rotate(t = Hs, { withoutSave: e } = {}) {
2408
+ rotate(t = Gs, { withoutSave: e } = {}) {
2409
2409
  const { canvas: s, historyManager: o } = this.editor, n = s.getActiveObject();
2410
2410
  if (!n) return;
2411
2411
  const i = n.angle + t;
@@ -2455,7 +2455,7 @@ class Xs {
2455
2455
  withoutSave: s
2456
2456
  } = {}) {
2457
2457
  const { canvas: o, historyManager: n } = this.editor, i = t || o.getActiveObject();
2458
- i && (i instanceof B ? i.getObjects().forEach((a) => {
2458
+ i && (i instanceof k ? i.getObjects().forEach((a) => {
2459
2459
  a.set("opacity", e);
2460
2460
  }) : i.set("opacity", e), o.renderAll(), s || n.saveState(), o.fire("editor:object-opacity-changed", {
2461
2461
  object: i,
@@ -2482,12 +2482,12 @@ class Xs {
2482
2482
  } = {}) {
2483
2483
  const { canvas: n, historyManager: i } = this.editor, a = t || n.getActiveObject();
2484
2484
  if (a) {
2485
- if (a instanceof B && !o) {
2485
+ if (a instanceof k && !o) {
2486
2486
  const r = a.getObjects();
2487
2487
  n.discardActiveObject(), r.forEach((d) => {
2488
2488
  this._fitSingleObject(d, e);
2489
2489
  });
2490
- const c = new B(r, { canvas: n });
2490
+ const c = new k(r, { canvas: n });
2491
2491
  n.setActiveObject(c);
2492
2492
  } else
2493
2493
  this._fitSingleObject(a, e);
@@ -2560,9 +2560,9 @@ class Xs {
2560
2560
  });
2561
2561
  }
2562
2562
  }
2563
- class Ks {
2563
+ class $s {
2564
2564
  constructor({ editor: t }) {
2565
- this.editor = t, this.options = t.options, this.minZoom = this.options.minZoom || Ys, this.maxZoom = this.options.maxZoom || Fs, this.defaultZoom = this.options.defaultScale;
2565
+ this.editor = t, this.options = t.options, this.minZoom = this.options.minZoom || Ws, this.maxZoom = this.options.maxZoom || Zs, this.defaultZoom = this.options.defaultScale;
2566
2566
  }
2567
2567
  /**
2568
2568
  * Вспомогательный метод для вычисления размеров масштабированной монтажной области
@@ -2638,8 +2638,8 @@ class Ks {
2638
2638
  const { canvas: i, montageArea: a } = this.editor, r = i.viewportTransform, c = i.getWidth(), d = i.getHeight(), l = t.x - r[4], u = t.y - r[5], g = Math.abs(o), f = e - s;
2639
2639
  if (Math.abs(f) / g <= 0.1)
2640
2640
  return { x: l, y: u };
2641
- const m = c / 2, v = d / 2, b = a.left, I = a.top, y = m - b * s, w = v - I * s, S = (y - r[4]) / (e - s), A = (w - r[5]) / (e - s), M = S * g, C = A * g, j = M * n, T = C * n, x = Math.abs(j) > Math.abs(l) ? l : j, Z = Math.abs(T) > Math.abs(u) ? u : T;
2642
- return { x, y: Z };
2641
+ const m = c / 2, v = d / 2, b = a.left, I = a.top, y = m - b * s, w = v - I * s, S = (y - r[4]) / (e - s), A = (w - r[5]) / (e - s), M = S * g, C = A * g, j = M * n, T = C * n, B = Math.abs(j) > Math.abs(l) ? l : j, G = Math.abs(T) > Math.abs(u) ? u : T;
2642
+ return { x: B, y: G };
2643
2643
  }
2644
2644
  /**
2645
2645
  * Применяет плавное центрирование viewport при приближении к defaultZoom.
@@ -2651,7 +2651,7 @@ class Ks {
2651
2651
  * @returns true если центрирование было применено
2652
2652
  * @private
2653
2653
  */
2654
- _applyViewportCentering(t, e = !1, s = Ye) {
2654
+ _applyViewportCentering(t, e = !1, s = We) {
2655
2655
  const { canvas: o } = this.editor, n = this._getScaledMontageDimensions(t), i = o.getWidth(), a = o.getHeight(), r = n.width > i || n.height > a, c = this._calculateFitZoom(), d = t - c;
2656
2656
  if (!(!r || d) && !e)
2657
2657
  return !1;
@@ -2726,10 +2726,10 @@ class Ks {
2726
2726
  * @param options.pointY - Координата Y точки зума
2727
2727
  * @fires editor:zoom-changed
2728
2728
  */
2729
- zoom(t = Ye, e = {}) {
2729
+ zoom(t = We, e = {}) {
2730
2730
  var g, f;
2731
2731
  if (!t) return;
2732
- const { minZoom: s, maxZoom: o } = this, { canvas: n } = this.editor, i = t < 0, a = n.getZoom(), r = n.getCenterPoint(), c = (g = e.pointX) != null ? g : r.x, d = (f = e.pointY) != null ? f : r.y, l = new $(c, d);
2732
+ const { minZoom: s, maxZoom: o } = this, { canvas: n } = this.editor, i = t < 0, a = n.getZoom(), r = n.getCenterPoint(), c = (g = e.pointX) != null ? g : r.x, d = (f = e.pointY) != null ? f : r.y, l = new J(c, d);
2733
2733
  this.editor.montageArea.setCoords(), this.editor.canvas.requestRenderAll();
2734
2734
  let u = Number((a + Number(t)).toFixed(3));
2735
2735
  u > o && (u = o), u < s && (u = s), n.zoomToPoint(l, u), this.editor.panConstraintManager.updateBounds(), this._applyViewportCentering(u, i, t), n.fire("editor:zoom-changed", {
@@ -2744,7 +2744,7 @@ class Ks {
2744
2744
  * @fires editor:zoom-changed
2745
2745
  */
2746
2746
  setZoom(t = this.defaultZoom) {
2747
- const { minZoom: e, maxZoom: s } = this, { canvas: o } = this.editor, n = new $(o.getCenterPoint());
2747
+ const { minZoom: e, maxZoom: s } = this, { canvas: o } = this.editor, n = new J(o.getCenterPoint());
2748
2748
  let i = t;
2749
2749
  t > s && (i = s), t < e && (i = e), o.zoomToPoint(n, i), o.fire("editor:zoom-changed", {
2750
2750
  currentZoom: o.getZoom(),
@@ -2757,14 +2757,14 @@ class Ks {
2757
2757
  * @fires editor:zoom-changed
2758
2758
  */
2759
2759
  resetZoom() {
2760
- const { canvas: t } = this.editor, e = new $(t.getCenterPoint());
2760
+ const { canvas: t } = this.editor, e = new J(t.getCenterPoint());
2761
2761
  t.zoomToPoint(e, this.defaultZoom), this.editor.canvas.fire("editor:zoom-changed", {
2762
2762
  currentZoom: t.getZoom(),
2763
2763
  point: e
2764
2764
  }), this.editor.panConstraintManager.updateBounds();
2765
2765
  }
2766
2766
  }
2767
- class Qs {
2767
+ class Js {
2768
2768
  constructor({ editor: t }) {
2769
2769
  this.editor = t, this.isBlocked = !1, this.overlayMask = null, this._createOverlay();
2770
2770
  }
@@ -2821,7 +2821,7 @@ class Qs {
2821
2821
  }), t.upperCanvasEl.style.pointerEvents = "", t.lowerCanvasEl.style.pointerEvents = "", this.overlayMask.visible = !1, t.requestRenderAll(), t.fire("editor:enabled"), s.resumeHistory();
2822
2822
  }
2823
2823
  }
2824
- class St {
2824
+ class It {
2825
2825
  constructor({ editor: t }) {
2826
2826
  this.editor = t, this.backgroundObject = null;
2827
2827
  }
@@ -2846,7 +2846,7 @@ class St {
2846
2846
  }
2847
2847
  i.set({
2848
2848
  fill: t,
2849
- backgroundId: `background-${Y()}`
2849
+ backgroundId: `background-${F()}`
2850
2850
  }), this.editor.canvas.requestRenderAll();
2851
2851
  } else
2852
2852
  this._removeCurrentBackground(), this._createColorBackground(t);
@@ -2876,14 +2876,14 @@ class St {
2876
2876
  try {
2877
2877
  const { historyManager: n } = this.editor, { backgroundObject: i } = this;
2878
2878
  if (n.suspendHistory(), i && i.backgroundType === "gradient") {
2879
- const a = St._createFabricGradient(t);
2880
- if (St._isGradientEqual(i.fill, a)) {
2879
+ const a = It._createFabricGradient(t);
2880
+ if (It._isGradientEqual(i.fill, a)) {
2881
2881
  n.resumeHistory();
2882
2882
  return;
2883
2883
  }
2884
2884
  i.set({
2885
2885
  fill: a,
2886
- backgroundId: `background-${Y()}`
2886
+ backgroundId: `background-${F()}`
2887
2887
  }), this.editor.canvas.requestRenderAll();
2888
2888
  } else
2889
2889
  this._removeCurrentBackground(), this._createGradientBackground(t);
@@ -3030,7 +3030,7 @@ class St {
3030
3030
  hasControls: !1,
3031
3031
  id: "background",
3032
3032
  backgroundType: "color",
3033
- backgroundId: `background-${Y()}`
3033
+ backgroundId: `background-${F()}`
3034
3034
  }, { withoutSelection: !0 }), this.refresh();
3035
3035
  }
3036
3036
  /**
@@ -3047,9 +3047,9 @@ class St {
3047
3047
  hasControls: !1,
3048
3048
  id: "background",
3049
3049
  backgroundType: "gradient",
3050
- backgroundId: `background-${Y()}`
3050
+ backgroundId: `background-${F()}`
3051
3051
  }, { withoutSelection: !0 }), this.refresh();
3052
- const e = St._createFabricGradient(t);
3052
+ const e = It._createFabricGradient(t);
3053
3053
  this.backgroundObject.set("fill", e), this.editor.canvas.requestRenderAll();
3054
3054
  }
3055
3055
  /**
@@ -3075,7 +3075,7 @@ class St {
3075
3075
  hasControls: !1,
3076
3076
  id: "background",
3077
3077
  backgroundType: "image",
3078
- backgroundId: `background-${Y()}`,
3078
+ backgroundId: `background-${F()}`,
3079
3079
  customData: e
3080
3080
  }), this._removeCurrentBackground(), this.backgroundObject = s, this.refresh();
3081
3081
  });
@@ -3101,8 +3101,8 @@ class St {
3101
3101
  { offset: n / 100, color: s }
3102
3102
  ];
3103
3103
  if (t.type === "linear") {
3104
- const l = t.angle * Math.PI / 180, u = St._angleToCoords(l);
3105
- return new ke({
3104
+ const l = t.angle * Math.PI / 180, u = It._angleToCoords(l);
3105
+ return new ze({
3106
3106
  type: "linear",
3107
3107
  gradientUnits: "percentage",
3108
3108
  coords: u,
@@ -3121,7 +3121,7 @@ class St {
3121
3121
  r1: 0,
3122
3122
  r2: c / 100
3123
3123
  };
3124
- return new ke({
3124
+ return new ze({
3125
3125
  type: "radial",
3126
3126
  gradientUnits: "percentage",
3127
3127
  coords: d,
@@ -3156,7 +3156,7 @@ class St {
3156
3156
  }) ? !1 : t.type === "linear" && e.type === "linear" ? Math.abs(t.coords.x1 - e.coords.x1) < 1e-4 && Math.abs(t.coords.y1 - e.coords.y1) < 1e-4 && Math.abs(t.coords.x2 - e.coords.x2) < 1e-4 && Math.abs(t.coords.y2 - e.coords.y2) < 1e-4 : t.type === "radial" && e.type === "radial" ? Math.abs(t.coords.x1 - e.coords.x1) < 1e-4 && Math.abs(t.coords.y1 - e.coords.y1) < 1e-4 && Math.abs(t.coords.x2 - e.coords.x2) < 1e-4 && Math.abs(t.coords.y2 - e.coords.y2) < 1e-4 && Math.abs(t.coords.r1 - e.coords.r1) < 1e-4 && Math.abs(t.coords.r2 - e.coords.r2) < 1e-4 : !1;
3157
3157
  }
3158
3158
  }
3159
- class Qt {
3159
+ class qt {
3160
3160
  constructor({ editor: t }) {
3161
3161
  this.editor = t;
3162
3162
  }
@@ -3171,7 +3171,7 @@ class Qt {
3171
3171
  const { canvas: s, historyManager: o } = this.editor;
3172
3172
  o.suspendHistory();
3173
3173
  const n = t || s.getActiveObject();
3174
- n && (n instanceof B ? n.getObjects().forEach((i) => {
3174
+ n && (n instanceof k ? n.getObjects().forEach((i) => {
3175
3175
  s.bringObjectToFront(i);
3176
3176
  }) : s.bringObjectToFront(n), s.renderAll(), o.resumeHistory(), e || o.saveState(), s.fire("editor:object-bring-to-front", {
3177
3177
  object: n,
@@ -3189,7 +3189,7 @@ class Qt {
3189
3189
  const { canvas: s, historyManager: o } = this.editor;
3190
3190
  o.suspendHistory();
3191
3191
  const n = t || s.getActiveObject();
3192
- n && (n instanceof B ? Qt._moveSelectionForward(s, n) : s.bringObjectForward(n), s.renderAll(), o.resumeHistory(), e || o.saveState(), s.fire("editor:object-bring-forward", {
3192
+ n && (n instanceof k ? qt._moveSelectionForward(s, n) : s.bringObjectForward(n), s.renderAll(), o.resumeHistory(), e || o.saveState(), s.fire("editor:object-bring-forward", {
3193
3193
  object: n,
3194
3194
  withoutSave: e
3195
3195
  }));
@@ -3212,7 +3212,7 @@ class Qt {
3212
3212
  n.suspendHistory();
3213
3213
  const r = t || s.getActiveObject();
3214
3214
  if (r) {
3215
- if (r instanceof B) {
3215
+ if (r instanceof k) {
3216
3216
  const c = r.getObjects();
3217
3217
  for (let d = c.length - 1; d >= 0; d -= 1)
3218
3218
  s.sendObjectToBack(c[d]);
@@ -3240,7 +3240,7 @@ class Qt {
3240
3240
  } = this.editor;
3241
3241
  n.suspendHistory();
3242
3242
  const r = t || s.getActiveObject();
3243
- r && (r instanceof B ? Qt._moveSelectionBackwards(s, r) : s.sendObjectBackwards(r), a && s.sendObjectToBack(a), s.sendObjectToBack(o), i && s.sendObjectToBack(i), s.renderAll(), n.resumeHistory(), e || n.saveState(), s.fire("editor:object-send-backwards", {
3243
+ r && (r instanceof k ? qt._moveSelectionBackwards(s, r) : s.sendObjectBackwards(r), a && s.sendObjectToBack(a), s.sendObjectToBack(o), i && s.sendObjectToBack(i), s.renderAll(), n.resumeHistory(), e || n.saveState(), s.fire("editor:object-send-backwards", {
3244
3244
  object: r,
3245
3245
  withoutSave: e
3246
3246
  }));
@@ -3284,7 +3284,7 @@ class Qt {
3284
3284
  });
3285
3285
  }
3286
3286
  }
3287
- class qs {
3287
+ class to {
3288
3288
  /**
3289
3289
  * Менеджер фигур для редактора.
3290
3290
  * @param options - Опции и настройки менеджера фигур.
@@ -3310,13 +3310,13 @@ class qs {
3310
3310
  */
3311
3311
  addRectangle(d = {}, { withoutSelection: r, withoutAdding: c } = {}) {
3312
3312
  var l = d, {
3313
- id: t = `rect-${Y()}`,
3313
+ id: t = `rect-${F()}`,
3314
3314
  left: e,
3315
3315
  top: s,
3316
3316
  width: o = 100,
3317
3317
  height: n = 100,
3318
3318
  fill: i = "blue"
3319
- } = l, a = ut(l, [
3319
+ } = l, a = gt(l, [
3320
3320
  "id",
3321
3321
  "left",
3322
3322
  "top",
@@ -3324,7 +3324,7 @@ class qs {
3324
3324
  "height",
3325
3325
  "fill"
3326
3326
  ]);
3327
- const { canvas: u } = this.editor, g = new ls(k({
3327
+ const { canvas: u } = this.editor, g = new gs(x({
3328
3328
  id: t,
3329
3329
  left: e,
3330
3330
  top: s,
@@ -3352,19 +3352,19 @@ class qs {
3352
3352
  */
3353
3353
  addCircle(c = {}, { withoutSelection: a, withoutAdding: r } = {}) {
3354
3354
  var d = c, {
3355
- id: t = `circle-${Y()}`,
3355
+ id: t = `circle-${F()}`,
3356
3356
  left: e,
3357
3357
  top: s,
3358
3358
  radius: o = 50,
3359
3359
  fill: n = "green"
3360
- } = d, i = ut(d, [
3360
+ } = d, i = gt(d, [
3361
3361
  "id",
3362
3362
  "left",
3363
3363
  "top",
3364
3364
  "radius",
3365
3365
  "fill"
3366
3366
  ]);
3367
- const { canvas: l } = this.editor, u = new hs(k({
3367
+ const { canvas: l } = this.editor, u = new fs(x({
3368
3368
  id: t,
3369
3369
  left: e,
3370
3370
  top: s,
@@ -3392,13 +3392,13 @@ class qs {
3392
3392
  */
3393
3393
  addTriangle(d = {}, { withoutSelection: r, withoutAdding: c } = {}) {
3394
3394
  var l = d, {
3395
- id: t = `triangle-${Y()}`,
3395
+ id: t = `triangle-${F()}`,
3396
3396
  left: e,
3397
3397
  top: s,
3398
3398
  width: o = 100,
3399
3399
  height: n = 100,
3400
3400
  fill: i = "yellow"
3401
- } = l, a = ut(l, [
3401
+ } = l, a = gt(l, [
3402
3402
  "id",
3403
3403
  "left",
3404
3404
  "top",
@@ -3406,7 +3406,7 @@ class qs {
3406
3406
  "height",
3407
3407
  "fill"
3408
3408
  ]);
3409
- const { canvas: u } = this.editor, g = new us(k({
3409
+ const { canvas: u } = this.editor, g = new ps(x({
3410
3410
  id: t,
3411
3411
  left: e,
3412
3412
  top: s,
@@ -3417,7 +3417,7 @@ class qs {
3417
3417
  return !e && !s && u.centerObject(g), c || (u.add(g), r || u.setActiveObject(g), u.renderAll()), g;
3418
3418
  }
3419
3419
  }
3420
- class $s {
3420
+ class eo {
3421
3421
  /**
3422
3422
  * @param options
3423
3423
  * @param options.editor - экземпляр редактора с доступом к canvas
@@ -3516,7 +3516,7 @@ class $s {
3516
3516
  _copyTextToClipboard(t) {
3517
3517
  return _(this, null, function* () {
3518
3518
  try {
3519
- const e = `${Fe}${t}`;
3519
+ const e = `${Ze}${t}`;
3520
3520
  return yield navigator.clipboard.writeText(e), console.info("Text copied to clipboard successfully"), !0;
3521
3521
  } catch (e) {
3522
3522
  const { errorManager: s } = this.editor;
@@ -3536,7 +3536,7 @@ class $s {
3536
3536
  */
3537
3537
  _addClonedObjectToCanvas(t) {
3538
3538
  const { canvas: e, historyManager: s } = this.editor;
3539
- if (e.discardActiveObject(), t instanceof B) {
3539
+ if (e.discardActiveObject(), t instanceof k) {
3540
3540
  s.suspendHistory(), t.canvas = e, t.forEachObject((o) => {
3541
3541
  e.add(o);
3542
3542
  }), e.setActiveObject(t), e.requestRenderAll(), s.resumeHistory(), s.saveState();
@@ -3570,13 +3570,13 @@ class $s {
3570
3570
  if (!s || s.locked) return !1;
3571
3571
  try {
3572
3572
  const o = yield s.clone(Gt);
3573
- return o instanceof B && o.forEachObject((n) => {
3573
+ return o instanceof k && o.forEachObject((n) => {
3574
3574
  n.set({
3575
- id: `${n.type}-${Y()}`,
3575
+ id: `${n.type}-${F()}`,
3576
3576
  evented: !0
3577
3577
  });
3578
3578
  }), o.set({
3579
- id: `${o.type}-${Y()}`,
3579
+ id: `${o.type}-${F()}`,
3580
3580
  left: o.left + 10,
3581
3581
  top: o.top + 10,
3582
3582
  evented: !0
@@ -3607,7 +3607,7 @@ class $s {
3607
3607
  return;
3608
3608
  }
3609
3609
  const s = t.getData("text/plain");
3610
- if (s && s.startsWith(Fe)) {
3610
+ if (s && s.startsWith(Ze)) {
3611
3611
  this.paste();
3612
3612
  return;
3613
3613
  }
@@ -3656,13 +3656,13 @@ class $s {
3656
3656
  if (!this.clipboard) return !1;
3657
3657
  try {
3658
3658
  const e = yield this.clipboard.clone(Gt);
3659
- return t.discardActiveObject(), e instanceof B && e.forEachObject((s) => {
3659
+ return t.discardActiveObject(), e instanceof k && e.forEachObject((s) => {
3660
3660
  s.set({
3661
- id: `${s.type}-${Y()}`,
3661
+ id: `${s.type}-${F()}`,
3662
3662
  evented: !0
3663
3663
  });
3664
3664
  }), e.set({
3665
- id: `${e.type}-${Y()}`,
3665
+ id: `${e.type}-${F()}`,
3666
3666
  left: e.left + 10,
3667
3667
  top: e.top + 10,
3668
3668
  evented: !0
@@ -3680,7 +3680,7 @@ class $s {
3680
3680
  });
3681
3681
  }
3682
3682
  }
3683
- class qt {
3683
+ class $t {
3684
3684
  constructor({ editor: t }) {
3685
3685
  this.editor = t;
3686
3686
  }
@@ -3706,7 +3706,7 @@ class qt {
3706
3706
  editable: !1,
3707
3707
  locked: !0
3708
3708
  };
3709
- i.set(a), !e && qt._isGroupOrSelection(i) && i.getObjects().forEach((c) => {
3709
+ i.set(a), !e && $t._isGroupOrSelection(i) && i.getObjects().forEach((c) => {
3710
3710
  c.set(a);
3711
3711
  }), o.renderAll(), s || n.saveState(), o.fire("editor:object-locked", {
3712
3712
  object: i,
@@ -3735,7 +3735,7 @@ class qt {
3735
3735
  editable: !0,
3736
3736
  locked: !1
3737
3737
  };
3738
- n.set(i), qt._isGroupOrSelection(n) && n.getObjects().forEach((a) => {
3738
+ n.set(i), $t._isGroupOrSelection(n) && n.getObjects().forEach((a) => {
3739
3739
  a.set(i);
3740
3740
  }), s.renderAll(), e || o.saveState(), s.fire("editor:object-unlocked", {
3741
3741
  object: n,
@@ -3743,10 +3743,10 @@ class qt {
3743
3743
  });
3744
3744
  }
3745
3745
  static _isGroupOrSelection(t) {
3746
- return t instanceof B || t instanceof wt;
3746
+ return t instanceof k || t instanceof jt;
3747
3747
  }
3748
3748
  }
3749
- class Js {
3749
+ class so {
3750
3750
  constructor({ editor: t }) {
3751
3751
  this.editor = t;
3752
3752
  }
@@ -3758,7 +3758,7 @@ class Js {
3758
3758
  if (Array.isArray(t))
3759
3759
  return t.length > 0 ? t : null;
3760
3760
  const e = t || this.editor.canvas.getActiveObject();
3761
- return !e || !(e instanceof B) ? null : e.getObjects();
3761
+ return !e || !(e instanceof k) ? null : e.getObjects();
3762
3762
  }
3763
3763
  /**
3764
3764
  * Получить группы для разгруппировки
@@ -3766,20 +3766,20 @@ class Js {
3766
3766
  */
3767
3767
  _getGroupsToUngroup(t) {
3768
3768
  if (Array.isArray(t)) {
3769
- const s = t.filter((o) => o instanceof wt);
3769
+ const s = t.filter((o) => o instanceof jt);
3770
3770
  return s.length > 0 ? s : null;
3771
3771
  }
3772
- if (t instanceof B) {
3773
- const s = t.getObjects().filter((o) => o instanceof wt);
3772
+ if (t instanceof k) {
3773
+ const s = t.getObjects().filter((o) => o instanceof jt);
3774
3774
  return s.length > 0 ? s : null;
3775
3775
  }
3776
3776
  const e = t || this.editor.canvas.getActiveObject();
3777
3777
  if (!e) return null;
3778
- if (e instanceof B) {
3779
- const s = e.getObjects().filter((o) => o instanceof wt);
3778
+ if (e instanceof k) {
3779
+ const s = e.getObjects().filter((o) => o instanceof jt);
3780
3780
  return s.length > 0 ? s : null;
3781
3781
  }
3782
- return e instanceof wt ? [e] : null;
3782
+ return e instanceof jt ? [e] : null;
3783
3783
  }
3784
3784
  /**
3785
3785
  * Группировка объектов
@@ -3796,8 +3796,8 @@ class Js {
3796
3796
  if (!n) return null;
3797
3797
  try {
3798
3798
  o.suspendHistory();
3799
- const i = new wt(n, {
3800
- id: `group-${Y()}`
3799
+ const i = new jt(n, {
3800
+ id: `group-${F()}`
3801
3801
  });
3802
3802
  n.forEach((r) => s.remove(r)), s.add(i), s.setActiveObject(i), s.requestRenderAll();
3803
3803
  const a = {
@@ -3832,7 +3832,7 @@ class Js {
3832
3832
  s.add(l), i.push(l);
3833
3833
  });
3834
3834
  });
3835
- const a = new B(i, {
3835
+ const a = new k(i, {
3836
3836
  canvas: s
3837
3837
  });
3838
3838
  s.setActiveObject(a), s.requestRenderAll();
@@ -3847,7 +3847,7 @@ class Js {
3847
3847
  }
3848
3848
  }
3849
3849
  }
3850
- class to {
3850
+ class oo {
3851
3851
  constructor({ editor: t }) {
3852
3852
  this.editor = t;
3853
3853
  }
@@ -3858,7 +3858,7 @@ class to {
3858
3858
  selectAll() {
3859
3859
  const { canvas: t, canvasManager: e, objectLockManager: s } = this.editor;
3860
3860
  t.discardActiveObject();
3861
- const o = e.getObjects(), n = o.some((a) => a.locked), i = o.length > 1 ? new B(e.getObjects(), { canvas: t }) : o[0];
3861
+ const o = e.getObjects(), n = o.some((a) => a.locked), i = o.length > 1 ? new k(e.getObjects(), { canvas: t }) : o[0];
3862
3862
  n && s.lockObject({ object: i, skipInnerObjects: !0, withoutSave: !0 }), t.setActiveObject(i), t.requestRenderAll(), t.fire("editor:all-objects-selected", { selected: i });
3863
3863
  }
3864
3864
  }
@@ -3924,7 +3924,7 @@ class be {
3924
3924
  return o.fire("editor:objects-deleted", c), c;
3925
3925
  }
3926
3926
  }
3927
- const gt = {
3927
+ const ft = {
3928
3928
  IMAGE_MANAGER: {
3929
3929
  /**
3930
3930
  * Некорректный Content-Type изображения
@@ -4070,7 +4070,7 @@ class zt {
4070
4070
  message: i,
4071
4071
  data: o
4072
4072
  };
4073
- this._buffer.push(k({
4073
+ this._buffer.push(x({
4074
4074
  type: "editor:error"
4075
4075
  }, a)), this.editor.canvas.fire("editor:error", a);
4076
4076
  }
@@ -4098,7 +4098,7 @@ class zt {
4098
4098
  message: i,
4099
4099
  data: n
4100
4100
  };
4101
- this._buffer.push(k({
4101
+ this._buffer.push(x({
4102
4102
  type: "editor:warning"
4103
4103
  }, a)), this.editor.canvas.fire("editor:warning", a);
4104
4104
  }
@@ -4108,10 +4108,10 @@ class zt {
4108
4108
  * @returns true, если код допустим, иначе false
4109
4109
  */
4110
4110
  static isValidErrorCode(t) {
4111
- return t ? Object.values(gt).some((e) => Object.values(e).includes(t)) : !1;
4111
+ return t ? Object.values(ft).some((e) => Object.values(e).includes(t)) : !1;
4112
4112
  }
4113
4113
  }
4114
- class eo {
4114
+ class no {
4115
4115
  constructor({ editor: t }) {
4116
4116
  this.currentBounds = null, this.editor = t;
4117
4117
  }
@@ -4200,10 +4200,16 @@ const nt = ({
4200
4200
  value: h,
4201
4201
  min: t,
4202
4202
  max: e
4203
- }) => Math.min(Math.max(h, t), e), jt = class jt extends st {
4203
+ }) => Math.min(Math.max(h, t), e), Tt = class Tt extends st {
4204
4204
  constructor(t, e = {}) {
4205
4205
  var s, o, n, i, a, r, c, d, l;
4206
- super(t, e), this.backgroundOpacity = (s = e.backgroundOpacity) != null ? s : 1, this.paddingTop = (o = e.paddingTop) != null ? o : 0, this.paddingRight = (n = e.paddingRight) != null ? n : 0, this.paddingBottom = (i = e.paddingBottom) != null ? i : 0, this.paddingLeft = (a = e.paddingLeft) != null ? a : 0, this.radiusTopLeft = (r = e.radiusTopLeft) != null ? r : 0, this.radiusTopRight = (c = e.radiusTopRight) != null ? c : 0, this.radiusBottomRight = (d = e.radiusBottomRight) != null ? d : 0, this.radiusBottomLeft = (l = e.radiusBottomLeft) != null ? l : 0;
4206
+ super(t, e), this.backgroundOpacity = (s = e.backgroundOpacity) != null ? s : 1, this.paddingTop = (o = e.paddingTop) != null ? o : 0, this.paddingRight = (n = e.paddingRight) != null ? n : 0, this.paddingBottom = (i = e.paddingBottom) != null ? i : 0, this.paddingLeft = (a = e.paddingLeft) != null ? a : 0, this.radiusTopLeft = (r = e.radiusTopLeft) != null ? r : 0, this.radiusTopRight = (c = e.radiusTopRight) != null ? c : 0, this.radiusBottomRight = (d = e.radiusBottomRight) != null ? d : 0, this.radiusBottomLeft = (l = e.radiusBottomLeft) != null ? l : 0, this._roundDimensions();
4207
+ }
4208
+ /**
4209
+ * Пересчитывает размеры текста и округляет их до целых значений.
4210
+ */
4211
+ initDimensions() {
4212
+ super.initDimensions(), this._roundDimensions();
4207
4213
  }
4208
4214
  _getLeftOffset() {
4209
4215
  const { width: t } = this._getBackgroundDimensions(), { left: e } = this._getPadding();
@@ -4215,11 +4221,11 @@ const nt = ({
4215
4221
  }
4216
4222
  _getNonTransformedDimensions() {
4217
4223
  const { width: t, height: e } = this._getBackgroundDimensions();
4218
- return new $(t, e).scalarAdd(this.strokeWidth);
4224
+ return new J(t, e).scalarAdd(this.strokeWidth);
4219
4225
  }
4220
4226
  _getTransformedDimensions(t = {}) {
4221
4227
  const { width: e, height: s } = this._getBackgroundDimensions();
4222
- return super._getTransformedDimensions(bt(k({}, t), {
4228
+ return super._getTransformedDimensions(St(x({}, t), {
4223
4229
  width: e,
4224
4230
  height: s
4225
4231
  }));
@@ -4229,7 +4235,7 @@ const nt = ({
4229
4235
  */
4230
4236
  toObject(t = []) {
4231
4237
  const e = super.toObject(t);
4232
- return bt(k({}, e), {
4238
+ return St(x({}, e), {
4233
4239
  backgroundOpacity: this.backgroundOpacity,
4234
4240
  paddingTop: this.paddingTop,
4235
4241
  paddingRight: this.paddingRight,
@@ -4246,7 +4252,7 @@ const nt = ({
4246
4252
  const e = this._getEffectiveBackgroundFill();
4247
4253
  if (e && e) {
4248
4254
  const n = this._getPadding(), i = (s = this.width) != null ? s : 0, a = (o = this.height) != null ? o : 0, r = i + n.left + n.right, c = a + n.top + n.bottom, d = this._getCornerRadii({ width: r, height: c }), l = this._getLeftOffset() - n.left, u = this._getTopOffset() - n.top;
4249
- t.save(), jt._renderRoundedRect({
4255
+ t.save(), Tt._renderRoundedRect({
4250
4256
  ctx: t,
4251
4257
  height: c,
4252
4258
  left: l,
@@ -4290,7 +4296,7 @@ const nt = ({
4290
4296
  const e = nt({ value: (o = this.backgroundOpacity) != null ? o : 1, min: 0, max: 1 });
4291
4297
  let s;
4292
4298
  try {
4293
- s = new gs(t);
4299
+ s = new ms(t);
4294
4300
  } catch (n) {
4295
4301
  return zt.emitError({
4296
4302
  origin: "BackgroundTextbox",
@@ -4318,8 +4324,18 @@ const nt = ({
4318
4324
  } = o, g = nt({ value: c, min: 0, max: i }), f = nt({ value: d, min: 0, max: i }), p = nt({ value: l, min: 0, max: i }), m = nt({ value: u, min: 0, max: i });
4319
4325
  t.beginPath(), t.moveTo(s + g, n), t.lineTo(a - f, n), t.quadraticCurveTo(a, n, a, n + f), t.lineTo(a, r - p), t.quadraticCurveTo(a, r, a - p, r), t.lineTo(s + m, r), t.quadraticCurveTo(s, r, s, r - m), t.lineTo(s, n + g), t.quadraticCurveTo(s, n, s + g, n), t.closePath();
4320
4326
  }
4327
+ /**
4328
+ * Округляет текущие значения ширины и высоты до ближайших целых.
4329
+ */
4330
+ _roundDimensions() {
4331
+ const {
4332
+ width: t = 0,
4333
+ height: e = 0
4334
+ } = this, s = Math.round(t), o = Math.round(e);
4335
+ s !== t && (this.width = Math.max(0, s)), o !== e && (this.height = Math.max(0, o));
4336
+ }
4321
4337
  };
4322
- jt.type = "background-textbox", jt.cacheProperties = [
4338
+ Tt.type = "background-textbox", Tt.cacheProperties = [
4323
4339
  ...Array.isArray(st.cacheProperties) ? st.cacheProperties : [],
4324
4340
  "backgroundColor",
4325
4341
  "backgroundOpacity",
@@ -4331,7 +4347,7 @@ jt.type = "background-textbox", jt.cacheProperties = [
4331
4347
  "radiusTopRight",
4332
4348
  "radiusBottomRight",
4333
4349
  "radiusBottomLeft"
4334
- ], jt.stateProperties = [
4350
+ ], Tt.stateProperties = [
4335
4351
  ...Array.isArray(st.stateProperties) ? st.stateProperties : [],
4336
4352
  "backgroundColor",
4337
4353
  "backgroundOpacity",
@@ -4344,11 +4360,11 @@ jt.type = "background-textbox", jt.cacheProperties = [
4344
4360
  "radiusBottomRight",
4345
4361
  "radiusBottomLeft"
4346
4362
  ];
4347
- let $t = jt;
4348
- const so = () => {
4363
+ let Jt = Tt;
4364
+ const io = () => {
4349
4365
  var h;
4350
- (h = Be) != null && h.setClass && Be.setClass($t, "background-textbox");
4351
- }, oo = ({ textbox: h }) => {
4366
+ (h = Pe) != null && h.setClass && Pe.setClass(Jt, "background-textbox");
4367
+ }, ao = ({ textbox: h }) => {
4352
4368
  var s, o;
4353
4369
  if (!h.isEditing) return null;
4354
4370
  const t = (s = h.selectionStart) != null ? s : 0, e = (o = h.selectionEnd) != null ? o : t;
@@ -4356,11 +4372,11 @@ const so = () => {
4356
4372
  start: Math.min(t, e),
4357
4373
  end: Math.max(t, e)
4358
4374
  };
4359
- }, no = ({ textbox: h }) => {
4375
+ }, ro = ({ textbox: h }) => {
4360
4376
  var e, s;
4361
4377
  const t = (s = (e = h.text) == null ? void 0 : e.length) != null ? s : 0;
4362
4378
  return t <= 0 ? null : { start: 0, end: t };
4363
- }, io = ({ textbox: h, range: t }) => {
4379
+ }, co = ({ textbox: h, range: t }) => {
4364
4380
  var s, o;
4365
4381
  if (!t) return !1;
4366
4382
  const e = (o = (s = h.text) == null ? void 0 : s.length) != null ? o : 0;
@@ -4373,7 +4389,7 @@ const so = () => {
4373
4389
  if (!t || !Object.keys(t).length) return !1;
4374
4390
  const { start: s, end: o } = e;
4375
4391
  return o <= s ? !1 : (h.setSelectionStyles(t, s, o), !0);
4376
- }, We = ({
4392
+ }, Ve = ({
4377
4393
  textbox: h,
4378
4394
  range: t,
4379
4395
  property: e
@@ -4387,42 +4403,52 @@ const so = () => {
4387
4403
  );
4388
4404
  if (s.length)
4389
4405
  return (o = s[0]) == null ? void 0 : o[e];
4390
- }, Ze = ({ strokeColor: h, width: t }) => {
4406
+ }, Xe = ({ strokeColor: h, width: t }) => {
4391
4407
  if (!(t <= 0))
4392
4408
  return h != null ? h : "#000000";
4393
- }, Ge = ({ width: h = 0 }) => h ? Math.max(0, h) : 0, oe = ({ value: h }) => typeof h == "string" ? h.toLocaleUpperCase() : "", J = 0.01;
4394
- class q {
4409
+ }, Ke = ({ width: h = 0 }) => h ? Math.max(0, h) : 0, oe = ({ value: h }) => typeof h == "string" ? h.toLocaleUpperCase() : "", it = 0.01;
4410
+ class U {
4395
4411
  constructor({ editor: t }) {
4396
4412
  var e;
4397
4413
  this._handleTextEditingEntered = () => {
4398
4414
  this.isTextEditingActive = !0;
4415
+ }, this._handleTextChanged = (s) => {
4416
+ const { target: o } = s;
4417
+ if (!U._isTextbox(o)) return;
4418
+ const { text: n = "", uppercase: i } = o, a = !!i, r = n.toLocaleLowerCase();
4419
+ if (a) {
4420
+ const d = oe({ value: r });
4421
+ d !== n && o.set({ text: d }), o.textCaseRaw = r;
4422
+ } else
4423
+ o.textCaseRaw = n;
4424
+ U._roundTextboxDimensions({ textbox: o }) && (o.setCoords(), o.dirty = !0);
4399
4425
  }, this._handleTextEditingExited = (s) => {
4400
- var a, r;
4426
+ var r, c;
4401
4427
  const { target: o } = s;
4402
- if (!q._isTextbox(o)) return;
4403
- const n = (a = o.text) != null ? a : "";
4428
+ if (!U._isTextbox(o)) return;
4429
+ const n = (r = o.text) != null ? r : "";
4404
4430
  if (!!o.uppercase) {
4405
- const c = (r = o.textCaseRaw) != null ? r : n.toLocaleLowerCase();
4406
- o.textCaseRaw = c;
4431
+ const d = (c = o.textCaseRaw) != null ? c : n.toLocaleLowerCase();
4432
+ o.textCaseRaw = d;
4407
4433
  } else
4408
4434
  o.textCaseRaw = n;
4409
- o.locked || o.set({
4435
+ U._roundTextboxDimensions({ textbox: o }) && (o.setCoords(), o.dirty = !0, this.canvas.requestRenderAll()), o.locked || o.set({
4410
4436
  lockMovementX: !1,
4411
4437
  lockMovementY: !1
4412
4438
  }), setTimeout(() => {
4413
4439
  this.isTextEditingActive = !1, this.editor.historyManager.saveState();
4414
- }, Ws);
4440
+ }, Vs);
4415
4441
  }, this._handleObjectScaling = (s) => {
4416
- var Nt, W, yt, Yt, ht, Ft, vt, we, Se, Ae, je, Ie, Ce;
4442
+ var Z, Mt, Yt, ut, Ft, wt, Ae, je, Ie, Ce, Te, Ee, Oe;
4417
4443
  const { target: o, transform: n } = s;
4418
- if (o instanceof B) {
4444
+ if (o instanceof k) {
4419
4445
  this._handleActiveSelectionScaling({
4420
4446
  selection: o,
4421
4447
  transform: n
4422
4448
  });
4423
4449
  return;
4424
4450
  }
4425
- if (!q._isTextbox(o) || !n) return;
4451
+ if (!U._isTextbox(o) || !n) return;
4426
4452
  o.isScaling = !0;
4427
4453
  const i = this._ensureScalingState(o), {
4428
4454
  baseWidth: a,
@@ -4431,88 +4457,90 @@ class q {
4431
4457
  basePadding: d,
4432
4458
  baseRadii: l,
4433
4459
  baseStyles: u
4434
- } = i, g = typeof ((Nt = n.original) == null ? void 0 : Nt.width) == "number" ? n.original.width : void 0, f = typeof ((W = n.original) == null ? void 0 : W.left) == "number" ? n.original.left : void 0, p = g != null ? g : a, m = f != null ? f : r, v = (yt = n.corner) != null ? yt : "", b = (Yt = n.action) != null ? Yt : "", I = ["ml", "mr"].includes(v) || b === "scaleX", y = ["mt", "mb"].includes(v) || b === "scaleY", w = ["tl", "tr", "bl", "br"].includes(v) || b === "scale", S = w || y;
4460
+ } = i, g = typeof ((Z = n.original) == null ? void 0 : Z.width) == "number" ? n.original.width : void 0, f = typeof ((Mt = n.original) == null ? void 0 : Mt.left) == "number" ? n.original.left : void 0, p = g != null ? g : a, m = f != null ? f : r, v = (Yt = n.corner) != null ? Yt : "", b = (ut = n.action) != null ? ut : "", I = ["ml", "mr"].includes(v) || b === "scaleX", y = ["mt", "mb"].includes(v) || b === "scaleY", w = ["tl", "tr", "bl", "br"].includes(v) || b === "scale", S = w || y;
4435
4461
  if (!I && !y && !w) return;
4436
- const A = Math.abs((Ft = (ht = o.scaleX) != null ? ht : n.scaleX) != null ? Ft : 1) || 1, M = Math.abs((we = (vt = o.scaleY) != null ? vt : n.scaleY) != null ? we : 1) || 1, C = Math.max(1, p * A), j = Math.max(1, c * M), {
4437
- paddingTop: T = 0,
4438
- paddingRight: x = 0,
4439
- paddingBottom: Z = 0,
4440
- paddingLeft: P = 0,
4441
- radiusTopLeft: F = 0,
4442
- radiusTopRight: K = 0,
4443
- radiusBottomRight: L = 0,
4444
- radiusBottomLeft: R = 0,
4445
- fontSize: X,
4446
- width: H,
4447
- originX: G = "left"
4448
- } = o, V = w || y, et = w || y, z = V ? {
4462
+ const A = Math.abs((wt = (Ft = o.scaleX) != null ? Ft : n.scaleX) != null ? wt : 1) || 1, M = Math.abs((je = (Ae = o.scaleY) != null ? Ae : n.scaleY) != null ? je : 1) || 1, C = Math.max(1, p * A), j = Math.max(1, Math.round(C)), T = Math.max(1, c * M), {
4463
+ paddingTop: B = 0,
4464
+ paddingRight: G = 0,
4465
+ paddingBottom: Y = 0,
4466
+ paddingLeft: H = 0,
4467
+ radiusTopLeft: V = 0,
4468
+ radiusTopRight: D = 0,
4469
+ radiusBottomRight: R = 0,
4470
+ radiusBottomLeft: K = 0,
4471
+ fontSize: W,
4472
+ width: z,
4473
+ originX: X = "left"
4474
+ } = o, et = w || y, q = w || y, P = et ? {
4449
4475
  top: Math.max(0, d.top * M),
4450
4476
  right: Math.max(0, d.right * M),
4451
4477
  bottom: Math.max(0, d.bottom * M),
4452
4478
  left: Math.max(0, d.left * M)
4453
- } : d, U = et ? {
4479
+ } : d, Q = q ? {
4454
4480
  topLeft: Math.max(0, l.topLeft * M),
4455
4481
  topRight: Math.max(0, l.topRight * M),
4456
4482
  bottomRight: Math.max(0, l.bottomRight * M),
4457
4483
  bottomLeft: Math.max(0, l.bottomLeft * M)
4458
- } : l, Ut = Object.keys(u).length > 0;
4459
- let mt;
4460
- if (S && Ut) {
4484
+ } : l, Pt = Object.keys(u).length > 0;
4485
+ let yt;
4486
+ if (S && Pt) {
4461
4487
  const te = {};
4462
- Object.entries(u).forEach(([ns, Te]) => {
4463
- if (!Te) return;
4488
+ Object.entries(u).forEach(([rs, De]) => {
4489
+ if (!De) return;
4464
4490
  const ee = {};
4465
- Object.entries(Te).forEach(([is, Ht]) => {
4491
+ Object.entries(De).forEach(([cs, Ht]) => {
4466
4492
  if (!Ht) return;
4467
- const Ee = k({}, Ht);
4468
- typeof Ht.fontSize == "number" && (Ee.fontSize = Math.max(1, Ht.fontSize * M)), ee[is] = Ee;
4469
- }), Object.keys(ee).length && (te[ns] = ee);
4470
- }), Object.keys(te).length && (mt = te);
4493
+ const Le = x({}, Ht);
4494
+ typeof Ht.fontSize == "number" && (Le.fontSize = Math.max(1, Ht.fontSize * M)), ee[cs] = Le;
4495
+ }), Object.keys(ee).length && (te[rs] = ee);
4496
+ }), Object.keys(te).length && (yt = te);
4471
4497
  }
4472
- const Tt = (Ae = (Se = n.originX) != null ? Se : G) != null ? Ae : "left", Et = m + p, Ot = m + p / 2, Jt = H != null ? H : p, Lt = Math.abs(C - Jt) > J, Pt = Math.abs(j - (X != null ? X : c)) > J, Dt = Math.abs(z.top - T) > J || Math.abs(z.right - x) > J || Math.abs(z.bottom - Z) > J || Math.abs(z.left - P) > J, Rt = Math.abs(U.topLeft - F) > J || Math.abs(U.topRight - K) > J || Math.abs(U.bottomRight - L) > J || Math.abs(U.bottomLeft - R) > J;
4473
- if (!Lt && !Pt && !Dt && !Rt) {
4498
+ const vt = (Ce = (Ie = n.originX) != null ? Ie : X) != null ? Ce : "left", Dt = m + p, we = m + p / 2, bt = z != null ? z : p, Se = j !== bt, Ut = Math.abs(T - (W != null ? W : c)) > it, Lt = Math.abs(P.top - B) > it || Math.abs(P.right - G) > it || Math.abs(P.bottom - Y) > it || Math.abs(P.left - H) > it, Rt = Math.abs(Q.topLeft - V) > it || Math.abs(Q.topRight - D) > it || Math.abs(Q.bottomRight - R) > it || Math.abs(Q.bottomLeft - K) > it;
4499
+ if (!Se && !Ut && !Lt && !Rt) {
4474
4500
  o.set({ scaleX: 1, scaleY: 1 }), n.scaleX = 1, n.scaleY = 1;
4475
4501
  return;
4476
4502
  }
4477
- mt && (o.styles = mt), o.set({
4478
- width: C,
4479
- fontSize: S ? j : c,
4480
- paddingTop: z.top,
4481
- paddingRight: z.right,
4482
- paddingBottom: z.bottom,
4483
- paddingLeft: z.left,
4484
- radiusTopLeft: U.topLeft,
4485
- radiusTopRight: U.topRight,
4486
- radiusBottomRight: U.bottomRight,
4487
- radiusBottomLeft: U.bottomLeft,
4503
+ yt && (o.styles = yt), o.set({
4504
+ width: j,
4505
+ fontSize: S ? T : c,
4506
+ paddingTop: P.top,
4507
+ paddingRight: P.right,
4508
+ paddingBottom: P.bottom,
4509
+ paddingLeft: P.left,
4510
+ radiusTopLeft: Q.topLeft,
4511
+ radiusTopRight: Q.topRight,
4512
+ radiusBottomRight: Q.bottomRight,
4513
+ radiusBottomLeft: Q.bottomLeft,
4488
4514
  scaleX: 1,
4489
4515
  scaleY: 1
4490
4516
  });
4491
- const ct = (je = o.width) != null ? je : C, _t = Math.abs(ct - Jt) > J;
4492
- let dt = m;
4493
- _t && (I || w) && (Tt === "right" ? dt = Et - ct : Tt === "center" && (dt = Ot - ct / 2)), o.set({ left: dt }), i.baseLeft = dt, n.scaleX = 1, n.scaleY = 1;
4517
+ const _t = U._roundTextboxDimensions({ textbox: o });
4518
+ _t && (o.dirty = !0);
4519
+ const dt = (Te = o.width) != null ? Te : j, Nt = dt !== bt;
4520
+ let lt = m;
4521
+ Nt && (I || w) && (vt === "right" ? lt = Dt - dt : vt === "center" && (lt = we - dt / 2)), o.set({ left: lt }), i.baseLeft = lt, n.scaleX = 1, n.scaleY = 1;
4494
4522
  const { original: ot } = n;
4495
- ot && (ot.scaleX = 1, ot.scaleY = 1, ot.width = ct, ot.height = o.height, ot.left = dt), o.setCoords(), this.canvas.requestRenderAll(), i.baseWidth = ct, i.baseFontSize = (Ie = o.fontSize) != null ? Ie : j, i.baseStyles = JSON.parse(JSON.stringify((Ce = o.styles) != null ? Ce : {})), i.basePadding = {
4496
- top: z.top,
4497
- right: z.right,
4498
- bottom: z.bottom,
4499
- left: z.left
4523
+ ot && (ot.scaleX = 1, ot.scaleY = 1, ot.width = dt, ot.height = o.height, ot.left = lt), o.setCoords(), this.canvas.requestRenderAll(), i.baseWidth = dt, i.baseFontSize = (Ee = o.fontSize) != null ? Ee : T, i.baseStyles = JSON.parse(JSON.stringify((Oe = o.styles) != null ? Oe : {})), i.basePadding = {
4524
+ top: P.top,
4525
+ right: P.right,
4526
+ bottom: P.bottom,
4527
+ left: P.left
4500
4528
  }, i.baseRadii = {
4501
- topLeft: U.topLeft,
4502
- topRight: U.topRight,
4503
- bottomRight: U.bottomRight,
4504
- bottomLeft: U.bottomLeft
4505
- }, i.hasWidthChange = _t || Pt || Dt || Rt;
4529
+ topLeft: Q.topLeft,
4530
+ topRight: Q.topRight,
4531
+ bottomRight: Q.bottomRight,
4532
+ bottomLeft: Q.bottomLeft
4533
+ }, i.hasWidthChange = Nt || Ut || Lt || Rt || _t;
4506
4534
  }, this._handleObjectModified = (s) => {
4507
4535
  var b, I, y;
4508
4536
  const { target: o } = s;
4509
- if (o instanceof B) {
4537
+ if (o instanceof k) {
4510
4538
  this._finalizeActiveSelectionScaling({
4511
4539
  selection: o
4512
4540
  });
4513
4541
  return;
4514
4542
  }
4515
- if (!q._isTextbox(o)) return;
4543
+ if (!U._isTextbox(o)) return;
4516
4544
  o.isScaling = !1;
4517
4545
  const n = this.scalingState.get(o);
4518
4546
  if (this.scalingState.delete(o), !(n != null && n.hasWidthChange)) return;
@@ -4540,16 +4568,16 @@ class q {
4540
4568
  target: o,
4541
4569
  style: v
4542
4570
  }), o.set({ scaleX: 1, scaleY: 1 }), o.setCoords();
4543
- }, this.editor = t, this.canvas = t.canvas, this.fonts = (e = t.options.fonts) != null ? e : [], this.scalingState = /* @__PURE__ */ new WeakMap(), this.isTextEditingActive = !1, this._bindEvents(), so();
4571
+ }, this.editor = t, this.canvas = t.canvas, this.fonts = (e = t.options.fonts) != null ? e : [], this.scalingState = /* @__PURE__ */ new WeakMap(), this.isTextEditingActive = !1, this._bindEvents(), io();
4544
4572
  }
4545
4573
  /**
4546
4574
  * Добавляет новый текстовый объект на канвас.
4547
4575
  * @param options — настройки текста
4548
4576
  * @param flags — флаги поведения
4549
4577
  */
4550
- addText(Z = {}, { withoutSelection: j = !1, withoutSave: T = !1, withoutAdding: x = !1 } = {}) {
4551
- var P = Z, {
4552
- id: t = `text-${Y()}`,
4578
+ addText(G = {}, { withoutSelection: j = !1, withoutSave: T = !1, withoutAdding: B = !1 } = {}) {
4579
+ var Y = G, {
4580
+ id: t = `text-${F()}`,
4553
4581
  text: e = "Новый текст",
4554
4582
  fontFamily: s,
4555
4583
  fontSize: o = 48,
@@ -4573,7 +4601,7 @@ class q {
4573
4601
  radiusTopRight: S = 0,
4574
4602
  radiusBottomRight: A = 0,
4575
4603
  radiusBottomLeft: M = 0
4576
- } = P, C = ut(P, [
4604
+ } = Y, C = gt(Y, [
4577
4605
  "id",
4578
4606
  "text",
4579
4607
  "fontFamily",
@@ -4599,15 +4627,15 @@ class q {
4599
4627
  "radiusBottomRight",
4600
4628
  "radiusBottomLeft"
4601
4629
  ]);
4602
- var V;
4603
- const { historyManager: F } = this.editor, { canvas: K } = this;
4604
- F.suspendHistory();
4605
- const L = s != null ? s : this._getDefaultFontFamily(), R = Ge({ width: g }), X = Ze({
4630
+ var et;
4631
+ const { historyManager: H } = this.editor, { canvas: V } = this;
4632
+ H.suspendHistory();
4633
+ const D = s != null ? s : this._getDefaultFontFamily(), R = Ke({ width: g }), K = Xe({
4606
4634
  strokeColor: u,
4607
4635
  width: R
4608
- }), H = k({
4636
+ }), W = x({
4609
4637
  id: t,
4610
- fontFamily: L,
4638
+ fontFamily: D,
4611
4639
  fontSize: o,
4612
4640
  fontWeight: n ? "bold" : "normal",
4613
4641
  fontStyle: i ? "italic" : "normal",
@@ -4616,7 +4644,7 @@ class q {
4616
4644
  linethrough: c,
4617
4645
  textAlign: d,
4618
4646
  fill: l,
4619
- stroke: X,
4647
+ stroke: K,
4620
4648
  strokeWidth: R,
4621
4649
  strokeUniform: !0,
4622
4650
  opacity: f,
@@ -4630,29 +4658,29 @@ class q {
4630
4658
  radiusTopRight: S,
4631
4659
  radiusBottomRight: A,
4632
4660
  radiusBottomLeft: M
4633
- }, C), G = new $t(e, H);
4634
- if (G.textCaseRaw = (V = G.text) != null ? V : "", r) {
4635
- const et = oe({ value: G.textCaseRaw });
4636
- et !== G.text && G.set({ text: et });
4637
- }
4638
- return C.left === void 0 && C.top === void 0 && K.centerObject(G), x || K.add(G), j || K.setActiveObject(G), K.requestRenderAll(), F.resumeHistory(), T || F.saveState(), K.fire("editor:text-added", {
4639
- textbox: G,
4640
- options: bt(k({}, H), {
4661
+ }, C), z = new Jt(e, W);
4662
+ if (z.textCaseRaw = (et = z.text) != null ? et : "", r) {
4663
+ const q = oe({ value: z.textCaseRaw });
4664
+ q !== z.text && z.set({ text: q });
4665
+ }
4666
+ return U._roundTextboxDimensions({ textbox: z }) && (z.dirty = !0), C.left === void 0 && C.top === void 0 && V.centerObject(z), B || V.add(z), j || V.setActiveObject(z), V.requestRenderAll(), H.resumeHistory(), T || H.saveState(), V.fire("editor:text-added", {
4667
+ textbox: z,
4668
+ options: St(x({}, W), {
4641
4669
  text: e,
4642
4670
  bold: n,
4643
4671
  italic: i,
4644
4672
  strikethrough: c,
4645
4673
  align: d,
4646
4674
  color: l,
4647
- strokeColor: X,
4675
+ strokeColor: K,
4648
4676
  strokeWidth: R
4649
4677
  }),
4650
4678
  flags: {
4651
4679
  withoutSelection: !!j,
4652
4680
  withoutSave: !!T,
4653
- withoutAdding: !!x
4681
+ withoutAdding: !!B
4654
4682
  }
4655
- }), G;
4683
+ }), z;
4656
4684
  }
4657
4685
  /**
4658
4686
  * Обновляет текстовый объект.
@@ -4663,12 +4691,12 @@ class q {
4663
4691
  * @param options.skipRender — не вызывать перерисовку канваса
4664
4692
  */
4665
4693
  updateText({ target: t, style: e = {}, withoutSave: s, skipRender: o } = {}) {
4666
- var Rt, ct, _t, dt, ot, Nt;
4694
+ var Rt, _t, dt, Nt, lt, ot;
4667
4695
  const n = this._resolveTextObject(t);
4668
4696
  if (!n) return null;
4669
4697
  const { historyManager: i } = this.editor, { canvas: a } = this;
4670
4698
  i.suspendHistory();
4671
- const r = q._getSnapshot(n), Dt = e, {
4699
+ const r = U._getSnapshot(n), Lt = e, {
4672
4700
  text: c,
4673
4701
  fontFamily: d,
4674
4702
  fontSize: l,
@@ -4688,11 +4716,11 @@ class q {
4688
4716
  paddingRight: C,
4689
4717
  paddingBottom: j,
4690
4718
  paddingLeft: T,
4691
- radiusTopLeft: x,
4692
- radiusTopRight: Z,
4693
- radiusBottomRight: P,
4694
- radiusBottomLeft: F
4695
- } = Dt, K = ut(Dt, [
4719
+ radiusTopLeft: B,
4720
+ radiusTopRight: G,
4721
+ radiusBottomRight: Y,
4722
+ radiusBottomLeft: H
4723
+ } = Lt, V = gt(Lt, [
4696
4724
  "text",
4697
4725
  "fontFamily",
4698
4726
  "fontSize",
@@ -4716,39 +4744,39 @@ class q {
4716
4744
  "radiusTopRight",
4717
4745
  "radiusBottomRight",
4718
4746
  "radiusBottomLeft"
4719
- ]), L = k({}, K), R = oo({ textbox: n }), X = R ? this._expandRangeToFullLines({ textbox: n, range: R }) : null, H = {}, G = {}, V = {}, et = io({ textbox: n, range: R }), z = !R || et, U = !R;
4720
- if (d !== void 0 && (X && (G.fontFamily = d), z && (L.fontFamily = d, U && (V.fontFamily = d))), l !== void 0 && (X && (G.fontSize = l), z && (L.fontSize = l, U && (V.fontSize = l))), u !== void 0) {
4721
- const W = u ? "bold" : "normal";
4722
- R && (H.fontWeight = W), z && (L.fontWeight = W, U && (V.fontWeight = W));
4747
+ ]), D = x({}, V), R = ao({ textbox: n }), K = R ? this._expandRangeToFullLines({ textbox: n, range: R }) : null, W = {}, z = {}, X = {}, et = co({ textbox: n, range: R }), q = !R || et, P = !R;
4748
+ if (d !== void 0 && (K && (z.fontFamily = d), q && (D.fontFamily = d, P && (X.fontFamily = d))), l !== void 0 && (K && (z.fontSize = l), q && (D.fontSize = l, P && (X.fontSize = l))), u !== void 0) {
4749
+ const Z = u ? "bold" : "normal";
4750
+ R && (W.fontWeight = Z), q && (D.fontWeight = Z, P && (X.fontWeight = Z));
4723
4751
  }
4724
4752
  if (g !== void 0) {
4725
- const W = g ? "italic" : "normal";
4726
- R && (H.fontStyle = W), z && (L.fontStyle = W, U && (V.fontStyle = W));
4753
+ const Z = g ? "italic" : "normal";
4754
+ R && (W.fontStyle = Z), q && (D.fontStyle = Z, P && (X.fontStyle = Z));
4727
4755
  }
4728
- if (f !== void 0 && (R && (H.underline = f), z && (L.underline = f, U && (V.underline = f))), m !== void 0 && (R && (H.linethrough = m), z && (L.linethrough = m, U && (V.linethrough = m))), v !== void 0 && (L.textAlign = v), b !== void 0 && (R && (H.fill = b), z && (L.fill = b, U && (V.fill = b))), I !== void 0 || y !== void 0) {
4729
- const W = R ? We({ textbox: n, range: R, property: "strokeWidth" }) : void 0, yt = R ? We({ textbox: n, range: R, property: "stroke" }) : void 0, Yt = (ct = (Rt = y != null ? y : W) != null ? Rt : n.strokeWidth) != null ? ct : 0, ht = Ge({ width: Yt }), Ft = (dt = (_t = I != null ? I : yt) != null ? _t : n.stroke) != null ? dt : void 0, vt = Ze({
4756
+ if (f !== void 0 && (R && (W.underline = f), q && (D.underline = f, P && (X.underline = f))), m !== void 0 && (R && (W.linethrough = m), q && (D.linethrough = m, P && (X.linethrough = m))), v !== void 0 && (D.textAlign = v), b !== void 0 && (R && (W.fill = b), q && (D.fill = b, P && (X.fill = b))), I !== void 0 || y !== void 0) {
4757
+ const Z = R ? Ve({ textbox: n, range: R, property: "strokeWidth" }) : void 0, Mt = R ? Ve({ textbox: n, range: R, property: "stroke" }) : void 0, Yt = (_t = (Rt = y != null ? y : Z) != null ? Rt : n.strokeWidth) != null ? _t : 0, ut = Ke({ width: Yt }), Ft = (Nt = (dt = I != null ? I : Mt) != null ? dt : n.stroke) != null ? Nt : void 0, wt = Xe({
4730
4758
  strokeColor: Ft,
4731
- width: ht
4759
+ width: ut
4732
4760
  });
4733
- R && (H.stroke = vt, H.strokeWidth = ht), z && (L.stroke = vt, L.strokeWidth = ht, U && (V.stroke = vt, V.strokeWidth = ht));
4734
- }
4735
- w !== void 0 && (L.opacity = w), S !== void 0 && (L.backgroundColor = S), A !== void 0 && (L.backgroundOpacity = A), M !== void 0 && (L.paddingTop = M), C !== void 0 && (L.paddingRight = C), j !== void 0 && (L.paddingBottom = j), T !== void 0 && (L.paddingLeft = T), x !== void 0 && (L.radiusTopLeft = x), Z !== void 0 && (L.radiusTopRight = Z), P !== void 0 && (L.radiusBottomRight = P), F !== void 0 && (L.radiusBottomLeft = F);
4736
- const Ut = (Nt = n.textCaseRaw) != null ? Nt : (ot = n.text) != null ? ot : "", mt = !!n.uppercase, Tt = c !== void 0, Et = Tt ? c != null ? c : "" : Ut, Ot = p != null ? p : mt;
4737
- if (Tt || Ot !== mt) {
4738
- const W = Ot ? oe({ value: Et }) : Et;
4739
- L.text = W, n.textCaseRaw = Et;
4740
- } else n.textCaseRaw === void 0 && (n.textCaseRaw = Ut);
4741
- n.uppercase = Ot, n.set(L);
4742
- let Lt = !1;
4761
+ R && (W.stroke = wt, W.strokeWidth = ut), q && (D.stroke = wt, D.strokeWidth = ut, P && (X.stroke = wt, X.strokeWidth = ut));
4762
+ }
4763
+ w !== void 0 && (D.opacity = w), S !== void 0 && (D.backgroundColor = S), A !== void 0 && (D.backgroundOpacity = A), M !== void 0 && (D.paddingTop = M), C !== void 0 && (D.paddingRight = C), j !== void 0 && (D.paddingBottom = j), T !== void 0 && (D.paddingLeft = T), B !== void 0 && (D.radiusTopLeft = B), G !== void 0 && (D.radiusTopRight = G), Y !== void 0 && (D.radiusBottomRight = Y), H !== void 0 && (D.radiusBottomLeft = H);
4764
+ const Q = (ot = n.textCaseRaw) != null ? ot : (lt = n.text) != null ? lt : "", Pt = !!n.uppercase, yt = c !== void 0, vt = yt ? c != null ? c : "" : Q, Dt = p != null ? p : Pt;
4765
+ if (yt || Dt !== Pt) {
4766
+ const Z = Dt ? oe({ value: vt }) : vt;
4767
+ D.text = Z, n.textCaseRaw = vt;
4768
+ } else n.textCaseRaw === void 0 && (n.textCaseRaw = Q);
4769
+ n.uppercase = Dt, n.set(D);
4770
+ let bt = !1;
4743
4771
  if (R) {
4744
- const W = se({ textbox: n, styles: H, range: R }), yt = X ? se({ textbox: n, styles: G, range: X }) : !1;
4745
- Lt = W || yt;
4746
- } else if (Object.keys(V).length) {
4747
- const W = no({ textbox: n });
4748
- W && (Lt = se({ textbox: n, styles: V, range: W }));
4749
- }
4750
- Lt && (n.dirty = !0), (S !== void 0 || A !== void 0 || M !== void 0 || C !== void 0 || j !== void 0 || T !== void 0 || x !== void 0 || Z !== void 0 || P !== void 0 || F !== void 0) && (n.dirty = !0), n.setCoords(), o || a.requestRenderAll(), i.resumeHistory(), s || i.saveState();
4751
- const Pt = q._getSnapshot(n);
4772
+ const Z = se({ textbox: n, styles: W, range: R }), Mt = K ? se({ textbox: n, styles: z, range: K }) : !1;
4773
+ bt = Z || Mt;
4774
+ } else if (Object.keys(X).length) {
4775
+ const Z = ro({ textbox: n });
4776
+ Z && (bt = se({ textbox: n, styles: X, range: Z }));
4777
+ }
4778
+ bt && (n.dirty = !0), (S !== void 0 || A !== void 0 || M !== void 0 || C !== void 0 || j !== void 0 || T !== void 0 || B !== void 0 || G !== void 0 || Y !== void 0 || H !== void 0) && (n.dirty = !0), U._roundTextboxDimensions({ textbox: n }) && (n.dirty = !0), n.setCoords(), o || a.requestRenderAll(), i.resumeHistory(), s || i.saveState();
4779
+ const Ut = U._getSnapshot(n);
4752
4780
  return a.fire("editor:text-updated", {
4753
4781
  textbox: n,
4754
4782
  target: t,
@@ -4757,11 +4785,11 @@ class q {
4757
4785
  withoutSave: !!s,
4758
4786
  skipRender: !!o
4759
4787
  },
4760
- updates: L,
4788
+ updates: D,
4761
4789
  before: r,
4762
- after: Pt,
4790
+ after: Ut,
4763
4791
  selectionRange: R != null ? R : void 0,
4764
- selectionStyles: R && Object.keys(H).length ? H : void 0
4792
+ selectionStyles: R && Object.keys(W).length ? W : void 0
4765
4793
  }), n;
4766
4794
  }
4767
4795
  /**
@@ -4779,10 +4807,10 @@ class q {
4779
4807
  const { canvas: e } = this;
4780
4808
  if (!t) {
4781
4809
  const s = e.getActiveObject();
4782
- return q._isTextbox(s) ? s : null;
4810
+ return U._isTextbox(s) ? s : null;
4783
4811
  }
4784
4812
  if (typeof t == "string") {
4785
- const s = e.getObjects().find((o) => q._isTextbox(o) && o.id === t);
4813
+ const s = e.getObjects().find((o) => U._isTextbox(o) && o.id === t);
4786
4814
  return s != null ? s : null;
4787
4815
  }
4788
4816
  return null;
@@ -4798,22 +4826,7 @@ class q {
4798
4826
  */
4799
4827
  _bindEvents() {
4800
4828
  const { canvas: t } = this;
4801
- t.on("object:scaling", this._handleObjectScaling), t.on("object:modified", this._handleObjectModified), t.on("text:editing:entered", this._handleTextEditingEntered), t.on("text:editing:exited", this._handleTextEditingExited), t.on("text:changed", q._handleTextChanged);
4802
- }
4803
- /**
4804
- * Реагирует на изменение текста в режиме редактирования: синхронизирует textCaseRaw и uppercase.
4805
- */
4806
- static _handleTextChanged(t) {
4807
- var i;
4808
- const { target: e } = t;
4809
- if (!q._isTextbox(e)) return;
4810
- const s = (i = e.text) != null ? i : "", o = !!e.uppercase, n = s.toLocaleLowerCase();
4811
- if (o) {
4812
- const a = oe({ value: n });
4813
- a !== s && e.set({ text: a }), e.textCaseRaw = n;
4814
- return;
4815
- }
4816
- e.textCaseRaw = s;
4829
+ t.on("object:scaling", this._handleObjectScaling), t.on("object:modified", this._handleObjectModified), t.on("text:editing:entered", this._handleTextEditingEntered), t.on("text:editing:exited", this._handleTextEditingExited), t.on("text:changed", this._handleTextChanged);
4817
4830
  }
4818
4831
  /**
4819
4832
  * Обрабатывает горизонтальное масштабирование ActiveSelection: расширяет текстовые блоки по ширине без растяжения шрифта.
@@ -4827,13 +4840,13 @@ class q {
4827
4840
  if (!(["ml", "mr", "tl", "tr", "bl", "br"].includes(s) || o === "scaleX" || o === "scale")) return;
4828
4841
  const i = Math.abs((l = (d = t.scaleX) != null ? d : e == null ? void 0 : e.scaleX) != null ? l : 1) || 1, a = i === 0 ? 1 : 1 / i;
4829
4842
  t.getObjects().forEach((u) => {
4830
- if (!q._isTextbox(u)) return;
4831
- const g = this._ensureScalingState(u), f = Math.max(1, g.baseWidth * i);
4843
+ if (!U._isTextbox(u)) return;
4844
+ const g = this._ensureScalingState(u), f = Math.max(1, Math.round(g.baseWidth * i));
4832
4845
  u.set({
4833
4846
  width: f,
4834
4847
  scaleX: a,
4835
4848
  scaleY: 1
4836
- }), u.setCoords(), u.dirty = !0;
4849
+ }), U._roundTextboxDimensions({ textbox: u }), u.setCoords(), u.dirty = !0;
4837
4850
  }), t.setCoords(), this.canvas.requestRenderAll();
4838
4851
  }
4839
4852
  /**
@@ -4843,14 +4856,14 @@ class q {
4843
4856
  selection: t
4844
4857
  }) {
4845
4858
  var o;
4846
- const e = Math.abs((o = t.scaleX) != null ? o : 1) || 1, s = t.getObjects().filter((n) => q._isTextbox(n));
4859
+ const e = Math.abs((o = t.scaleX) != null ? o : 1) || 1, s = t.getObjects().filter((n) => U._isTextbox(n));
4847
4860
  s.length && (s.forEach((n) => {
4848
- const i = this._ensureScalingState(n), a = Math.max(1, i.baseWidth * e);
4861
+ const i = this._ensureScalingState(n), a = Math.max(1, Math.round(i.baseWidth * e));
4849
4862
  n.set({
4850
4863
  width: a,
4851
4864
  scaleX: 1,
4852
4865
  scaleY: 1
4853
- }), n.setCoords(), n.dirty = !0, this.scalingState.delete(n);
4866
+ }), U._roundTextboxDimensions({ textbox: n }), n.setCoords(), n.dirty = !0, this.scalingState.delete(n);
4854
4867
  }), t.set({
4855
4868
  scaleX: 1
4856
4869
  }), t.setCoords(), this.canvas.requestRenderAll());
@@ -4879,7 +4892,7 @@ class q {
4879
4892
  }) {
4880
4893
  const s = this._getLineRanges({ textbox: t });
4881
4894
  if (!s.length) return e;
4882
- let o = e.start, n = e.end;
4895
+ let { start: o } = e, { end: n } = e;
4883
4896
  return s.forEach(({ start: i, end: a }) => {
4884
4897
  e.end > i && e.start < a && (o = Math.min(o, i), n = Math.max(n, a));
4885
4898
  }), { start: o, end: n };
@@ -4924,16 +4937,40 @@ class q {
4924
4937
  }
4925
4938
  return e;
4926
4939
  }
4940
+ /**
4941
+ * Возвращает числовое значение размера, используя исходное значение или заранее вычисленное.
4942
+ */
4943
+ static _resolveDimension({
4944
+ rawValue: t,
4945
+ calculatedValue: e
4946
+ }) {
4947
+ return typeof t == "number" ? t : typeof e == "number" ? e : 0;
4948
+ }
4949
+ /**
4950
+ * Округляет ширину и высоту текстового блока до ближайших целых значений.
4951
+ */
4952
+ static _roundTextboxDimensions({
4953
+ textbox: t
4954
+ }) {
4955
+ const { width: e, height: s, calcTextWidth: o, calcTextHeight: n } = t, i = typeof o == "function" ? o.call(t) : void 0, a = typeof n == "function" ? n.call(t) : void 0, r = U._resolveDimension({
4956
+ rawValue: e,
4957
+ calculatedValue: i
4958
+ }), c = U._resolveDimension({
4959
+ rawValue: s,
4960
+ calculatedValue: a
4961
+ }), d = Number.isFinite(r) ? Math.round(r) : null, l = Number.isFinite(c) ? Math.round(c) : null, u = {};
4962
+ return d !== null && d !== r && (u.width = Math.max(0, d)), l !== null && l !== c && (u.height = Math.max(0, l)), Object.keys(u).length ? (t.set(u), !0) : !1;
4963
+ }
4927
4964
  /**
4928
4965
  * Формирует снимок текущих свойств текстового объекта для истории и событий.
4929
4966
  */
4930
4967
  static _getSnapshot(t) {
4931
4968
  const e = ({
4932
- snapshot: H,
4933
- entries: G
4969
+ snapshot: W,
4970
+ entries: z
4934
4971
  }) => {
4935
- Object.entries(G).forEach(([V, et]) => {
4936
- et != null && (H[V] = et);
4972
+ Object.entries(z).forEach(([X, et]) => {
4973
+ et != null && (W[X] = et);
4937
4974
  });
4938
4975
  }, {
4939
4976
  id: s,
@@ -4961,20 +4998,20 @@ class q {
4961
4998
  radiusTopRight: C,
4962
4999
  radiusBottomRight: j,
4963
5000
  radiusBottomLeft: T,
4964
- left: x,
4965
- top: Z,
4966
- width: P,
4967
- height: F,
4968
- angle: K,
4969
- scaleX: L,
5001
+ left: B,
5002
+ top: G,
5003
+ width: Y,
5004
+ height: H,
5005
+ angle: V,
5006
+ scaleX: D,
4970
5007
  scaleY: R
4971
- } = t, X = {
5008
+ } = t, K = {
4972
5009
  id: s,
4973
5010
  uppercase: !!i,
4974
5011
  textAlign: g
4975
5012
  };
4976
5013
  return e({
4977
- snapshot: X,
5014
+ snapshot: K,
4978
5015
  entries: {
4979
5016
  text: o,
4980
5017
  textCaseRaw: n,
@@ -4998,15 +5035,15 @@ class q {
4998
5035
  radiusTopRight: C,
4999
5036
  radiusBottomRight: j,
5000
5037
  radiusBottomLeft: T,
5001
- left: x,
5002
- top: Z,
5003
- width: P,
5004
- height: F,
5005
- angle: K,
5006
- scaleX: L,
5038
+ left: B,
5039
+ top: G,
5040
+ width: Y,
5041
+ height: H,
5042
+ angle: V,
5043
+ scaleX: D,
5007
5044
  scaleY: R
5008
5045
  }
5009
- }), X;
5046
+ }), K;
5010
5047
  }
5011
5048
  /**
5012
5049
  * Возвращает первый доступный шрифт или дефолтный Arial.
@@ -5026,7 +5063,7 @@ const tt = ({
5026
5063
  }) => {
5027
5064
  const s = tt({ value: h });
5028
5065
  return e ? s : s / (t || 1);
5029
- }, ao = ({
5066
+ }, lo = ({
5030
5067
  object: h,
5031
5068
  baseWidth: t,
5032
5069
  baseHeight: e,
@@ -5060,7 +5097,7 @@ const tt = ({
5060
5097
  x: l + g / 2,
5061
5098
  y: u + f / 2
5062
5099
  };
5063
- }, ro = ({
5100
+ }, ho = ({
5064
5101
  normalizedX: h,
5065
5102
  normalizedY: t,
5066
5103
  bounds: e,
@@ -5070,11 +5107,11 @@ const tt = ({
5070
5107
  const { left: n, top: i, width: a, height: r } = e;
5071
5108
  if (!o) {
5072
5109
  const { width: l, height: u } = s, g = n + h * (l || a), f = i + t * (u || r);
5073
- return new $(g, f);
5110
+ return new J(g, f);
5074
5111
  }
5075
5112
  const c = n + h * a, d = i + t * r;
5076
- return new $(c, d);
5077
- }, co = ({
5113
+ return new J(c, d);
5114
+ }, uo = ({
5078
5115
  object: h,
5079
5116
  montageArea: t,
5080
5117
  bounds: e
@@ -5089,7 +5126,7 @@ const tt = ({
5089
5126
  } catch (s) {
5090
5127
  return null;
5091
5128
  }
5092
- }, lt = ({
5129
+ }, ht = ({
5093
5130
  object: h
5094
5131
  }) => {
5095
5132
  if (!h) return null;
@@ -5112,12 +5149,12 @@ const tt = ({
5112
5149
  } catch (t) {
5113
5150
  return null;
5114
5151
  }
5115
- }, lo = ({
5152
+ }, go = ({
5116
5153
  x1: h,
5117
5154
  y1: t,
5118
5155
  x2: e,
5119
5156
  y2: s
5120
- }) => (Math.atan2(s - t, e - h) * 180 / Math.PI + 360) % 360, ho = (h) => {
5157
+ }) => (Math.atan2(s - t, e - h) * 180 / Math.PI + 360) % 360, fo = (h) => {
5121
5158
  if (!h || typeof h != "object") return null;
5122
5159
  const { type: t, coords: e, colorStops: s } = h, o = Array.isArray(s) ? s : [], n = o[0], i = o[o.length - 1], a = typeof (n == null ? void 0 : n.color) == "string" ? n.color : void 0, r = typeof (i == null ? void 0 : i.color) == "string" ? i.color : a, c = typeof (n == null ? void 0 : n.offset) == "number" ? n.offset * 100 : void 0, d = typeof (i == null ? void 0 : i.offset) == "number" ? i.offset * 100 : void 0;
5123
5160
  if (!a || !r || !e) return null;
@@ -5126,7 +5163,7 @@ const tt = ({
5126
5163
  if (typeof l == "number" && typeof u == "number" && typeof g == "number" && typeof f == "number")
5127
5164
  return {
5128
5165
  type: "linear",
5129
- angle: lo({ x1: l, y1: u, x2: g, y2: f }),
5166
+ angle: go({ x1: l, y1: u, x2: g, y2: f }),
5130
5167
  startColor: a,
5131
5168
  endColor: r,
5132
5169
  startPosition: c,
@@ -5149,7 +5186,7 @@ const tt = ({
5149
5186
  }
5150
5187
  return null;
5151
5188
  }, ne = "_templateCenterX", ie = "_templateCenterY", ae = "_templateAnchorX", re = "_templateAnchorY";
5152
- class D {
5189
+ class L {
5153
5190
  constructor({ editor: t }) {
5154
5191
  this.editor = t;
5155
5192
  }
@@ -5168,28 +5205,28 @@ class D {
5168
5205
  montageArea: i,
5169
5206
  errorManager: a,
5170
5207
  backgroundManager: r
5171
- } = this.editor, c = n.getActiveObject(), d = D._collectObjects(c), { backgroundObject: l } = r != null ? r : {}, u = o && l ? [l] : [], g = [...d, ...u];
5208
+ } = this.editor, c = n.getActiveObject(), d = L._collectObjects(c), { backgroundObject: l } = r != null ? r : {}, u = o && l ? [l] : [], g = [...d, ...u];
5172
5209
  if (!g.length)
5173
5210
  return a.emitWarning({
5174
5211
  origin: "TemplateManager",
5175
5212
  method: "serializeSelection",
5176
- code: gt.TEMPLATE_MANAGER.NO_OBJECTS_SELECTED,
5213
+ code: ft.TEMPLATE_MANAGER.NO_OBJECTS_SELECTED,
5177
5214
  message: "Нет объектов для сериализации шаблона"
5178
5215
  }), null;
5179
- const f = D._getBounds(i), p = D._getMontageSize({ montageArea: i, bounds: f }), m = p.width, v = p.height, b = g.map((w) => D._serializeObject({
5216
+ const f = L._getBounds(i), p = L._getMontageSize({ montageArea: i, bounds: f }), m = p.width, v = p.height, b = g.map((w) => L._serializeObject({
5180
5217
  object: w,
5181
5218
  bounds: f,
5182
5219
  baseWidth: m,
5183
5220
  baseHeight: v,
5184
5221
  montageArea: i != null ? i : null
5185
- })), I = bt(k({}, s), {
5222
+ })), I = St(x({}, s), {
5186
5223
  baseWidth: m,
5187
5224
  baseHeight: v,
5188
5225
  positionsNormalized: !0,
5189
5226
  previewId: e != null ? e : s.previewId
5190
5227
  });
5191
5228
  return {
5192
- id: t != null ? t : `template-${Y()}`,
5229
+ id: t != null ? t : `template-${F()}`,
5193
5230
  meta: I,
5194
5231
  objects: b
5195
5232
  };
@@ -5216,36 +5253,36 @@ class D {
5216
5253
  return a.emitWarning({
5217
5254
  origin: "TemplateManager",
5218
5255
  method: "applyTemplate",
5219
- code: gt.TEMPLATE_MANAGER.INVALID_TEMPLATE,
5256
+ code: ft.TEMPLATE_MANAGER.INVALID_TEMPLATE,
5220
5257
  message: "Шаблон не содержит объектов"
5221
5258
  }), null;
5222
- const u = D._getBounds(n);
5259
+ const u = L._getBounds(n);
5223
5260
  if (!u)
5224
5261
  return a.emitWarning({
5225
5262
  origin: "TemplateManager",
5226
5263
  method: "applyTemplate",
5227
- code: gt.TEMPLATE_MANAGER.INVALID_TARGET,
5264
+ code: ft.TEMPLATE_MANAGER.INVALID_TARGET,
5228
5265
  message: "Не удалось определить границы монтажной области"
5229
5266
  }), null;
5230
- const g = D._getMontageSize({ montageArea: n, bounds: u }), f = D._normalizeMeta({ meta: d, fallback: g }), p = D._calculateScale({ meta: f, target: g }), m = !!f.positionsNormalized;
5267
+ const g = L._getMontageSize({ montageArea: n, bounds: u }), f = L._normalizeMeta({ meta: d, fallback: g }), p = L._calculateScale({ meta: f, target: g }), m = !!f.positionsNormalized;
5231
5268
  let v = !1, b = !1;
5232
5269
  i.suspendHistory();
5233
5270
  try {
5234
- const I = yield D._enlivenObjects(c);
5271
+ const I = yield L._enlivenObjects(c);
5235
5272
  if (!I.length)
5236
5273
  return a.emitWarning({
5237
5274
  origin: "TemplateManager",
5238
5275
  method: "applyTemplate",
5239
- code: gt.TEMPLATE_MANAGER.INVALID_TEMPLATE,
5276
+ code: ft.TEMPLATE_MANAGER.INVALID_TEMPLATE,
5240
5277
  message: "Не удалось создать объекты шаблона"
5241
5278
  }), null;
5242
- const { backgroundObject: y, contentObjects: w } = D._extractBackgroundObject(I);
5243
- y && (b = yield D._applyBackgroundFromObject({
5279
+ const { backgroundObject: y, contentObjects: w } = L._extractBackgroundObject(I);
5280
+ y && (b = yield L._applyBackgroundFromObject({
5244
5281
  backgroundObject: y,
5245
5282
  backgroundManager: r,
5246
5283
  errorManager: a
5247
5284
  }));
5248
- const S = w.map((A) => (D._applyTextOverrides({ object: A, data: e }), D._transformObject({
5285
+ const S = w.map((A) => (L._applyTextOverrides({ object: A, data: e }), L._transformObject({
5249
5286
  object: A,
5250
5287
  scale: p,
5251
5288
  bounds: u,
@@ -5255,10 +5292,10 @@ class D {
5255
5292
  montageArea: n,
5256
5293
  useRelativePositions: m
5257
5294
  }), A.set({
5258
- id: `${A.type}-${Y()}`,
5295
+ id: `${A.type}-${F()}`,
5259
5296
  evented: !0
5260
5297
  }), o.add(A), A));
5261
- return !S.length && !b ? null : (v = S.length > 0 || b, S.length && D._activateObjects({ canvas: o, objects: S }), o.requestRenderAll(), o.fire("editor:template-applied", {
5298
+ return !S.length && !b ? null : (v = S.length > 0 || b, S.length && L._activateObjects({ canvas: o, objects: S }), o.requestRenderAll(), o.fire("editor:template-applied", {
5262
5299
  template: t,
5263
5300
  objects: S,
5264
5301
  bounds: u
@@ -5267,7 +5304,7 @@ class D {
5267
5304
  return a.emitError({
5268
5305
  origin: "TemplateManager",
5269
5306
  method: "applyTemplate",
5270
- code: gt.TEMPLATE_MANAGER.APPLY_FAILED,
5307
+ code: ft.TEMPLATE_MANAGER.APPLY_FAILED,
5271
5308
  message: "Ошибка применения шаблона",
5272
5309
  data: {
5273
5310
  templateId: l,
@@ -5283,7 +5320,7 @@ class D {
5283
5320
  * Подготавливает объекты для сериализации.
5284
5321
  */
5285
5322
  static _collectObjects(t) {
5286
- return t ? t instanceof B ? t.getObjects() : [t] : [];
5323
+ return t ? t instanceof k ? t.getObjects() : [t] : [];
5287
5324
  }
5288
5325
  /**
5289
5326
  * Возвращает габариты объекта.
@@ -5309,13 +5346,13 @@ class D {
5309
5346
  static _enlivenObjects(t) {
5310
5347
  return _(this, null, function* () {
5311
5348
  return (yield Promise.all(t.map((s) => _(null, null, function* () {
5312
- if (D._hasSerializedSvgMarkup(s)) {
5313
- const i = yield D._reviveSvgObject(s);
5349
+ if (L._hasSerializedSvgMarkup(s)) {
5350
+ const i = yield L._reviveSvgObject(s);
5314
5351
  if (i)
5315
- return D._restoreImageScale({ revived: i, serialized: s }), i;
5352
+ return L._restoreImageScale({ revived: i, serialized: s }), i;
5316
5353
  }
5317
- const o = yield rt.enlivenObjects([s]), n = o == null ? void 0 : o[0];
5318
- return n ? (D._restoreImageScale({ revived: n, serialized: s }), n) : null;
5354
+ const o = yield ct.enlivenObjects([s]), n = o == null ? void 0 : o[0];
5355
+ return n ? (L._restoreImageScale({ revived: n, serialized: s }), n) : null;
5319
5356
  })))).filter((s) => !!s);
5320
5357
  });
5321
5358
  }
@@ -5359,8 +5396,8 @@ class D {
5359
5396
  const e = typeof t.svgMarkup == "string" ? t.svgMarkup : null;
5360
5397
  if (!e) return null;
5361
5398
  try {
5362
- const s = yield fs(e), o = rt.groupSVGElements(s.objects, s.options), n = yield rt.enlivenObjectEnlivables(
5363
- D._prepareSerializableProps(t)
5399
+ const s = yield ys(e), o = ct.groupSVGElements(s.objects, s.options), n = yield ct.enlivenObjectEnlivables(
5400
+ L._prepareSerializableProps(t)
5364
5401
  );
5365
5402
  return o.set(n), o.setCoords(), o;
5366
5403
  } catch (s) {
@@ -5372,7 +5409,7 @@ class D {
5372
5409
  * Убирает технические поля сериализации, оставляя только применимые свойства.
5373
5410
  */
5374
5411
  static _prepareSerializableProps(t) {
5375
- const e = k({}, t);
5412
+ const e = x({}, t);
5376
5413
  return delete e.svgMarkup, delete e.objects, delete e.path, delete e.paths, delete e.type, delete e.version, e;
5377
5414
  }
5378
5415
  /**
@@ -5418,7 +5455,7 @@ class D {
5418
5455
  montageArea: a,
5419
5456
  useRelativePositions: r
5420
5457
  }) {
5421
- const c = t, { x: d, y: l } = ao({
5458
+ const c = t, { x: d, y: l } = lo({
5422
5459
  object: t,
5423
5460
  baseWidth: n,
5424
5461
  baseHeight: i,
@@ -5427,15 +5464,15 @@ class D {
5427
5464
  x: ne,
5428
5465
  y: ie
5429
5466
  }
5430
- }), { scaleX: u, scaleY: g } = t, f = tt({ value: u, fallback: 1 }), p = tt({ value: g, fallback: 1 }), m = D._getPositioningBounds({
5467
+ }), { scaleX: u, scaleY: g } = t, f = tt({ value: u, fallback: 1 }), p = tt({ value: g, fallback: 1 }), m = L._getPositioningBounds({
5431
5468
  bounds: s,
5432
5469
  baseWidth: n,
5433
5470
  baseHeight: i,
5434
5471
  scale: e,
5435
5472
  useRelativePositions: r,
5436
- anchorX: D._resolveAnchor(c, ae),
5437
- anchorY: D._resolveAnchor(c, re)
5438
- }), v = ro({
5473
+ anchorX: L._resolveAnchor(c, ae),
5474
+ anchorY: L._resolveAnchor(c, re)
5475
+ }), v = ho({
5439
5476
  normalizedX: d,
5440
5477
  normalizedY: l,
5441
5478
  bounds: m,
@@ -5461,7 +5498,7 @@ class D {
5461
5498
  anchorY: a
5462
5499
  }) {
5463
5500
  if (!n) return t;
5464
- const r = (e || t.width) * o, c = (s || t.height) * o, d = t.width - r, l = t.height - c, u = t.left + D._calculateAnchorOffset(i, d), g = t.top + D._calculateAnchorOffset(a, l);
5501
+ const r = (e || t.width) * o, c = (s || t.height) * o, d = t.width - r, l = t.height - c, u = t.left + L._calculateAnchorOffset(i, d), g = t.top + L._calculateAnchorOffset(a, l);
5465
5502
  return {
5466
5503
  left: u,
5467
5504
  top: g,
@@ -5495,8 +5532,8 @@ class D {
5495
5532
  meta: t,
5496
5533
  fallback: e
5497
5534
  }) {
5498
- const { width: s, height: o } = e, r = t || {}, { baseWidth: n = s, baseHeight: i = o } = r, a = ut(r, ["baseWidth", "baseHeight"]);
5499
- return k({
5535
+ const { width: s, height: o } = e, r = t || {}, { baseWidth: n = s, baseHeight: i = o } = r, a = gt(r, ["baseWidth", "baseHeight"]);
5536
+ return x({
5500
5537
  baseWidth: n,
5501
5538
  baseHeight: i
5502
5539
  }, a);
@@ -5523,7 +5560,7 @@ class D {
5523
5560
  t.setActiveObject(e[0]);
5524
5561
  return;
5525
5562
  }
5526
- const s = new B(e, { canvas: t });
5563
+ const s = new k(e, { canvas: t });
5527
5564
  t.setActiveObject(s);
5528
5565
  }
5529
5566
  /**
@@ -5547,9 +5584,9 @@ class D {
5547
5584
  baseHeight: o,
5548
5585
  montageArea: n
5549
5586
  }) {
5550
- const i = t.toDatalessObject([...Je]);
5551
- if (D._isSvgObject(t)) {
5552
- const y = D._extractSvgMarkup(t);
5587
+ const i = t.toDatalessObject([...ss]);
5588
+ if (L._isSvgObject(t)) {
5589
+ const y = L._extractSvgMarkup(t);
5553
5590
  y && (i.svgMarkup = y, delete i.objects, delete i.path);
5554
5591
  }
5555
5592
  if (!e) return i;
@@ -5558,7 +5595,7 @@ class D {
5558
5595
  top: r,
5559
5596
  width: c,
5560
5597
  height: d
5561
- } = e, l = t.getBoundingRect(!1, !0), u = s || c || 1, g = o || d || 1, f = co({
5598
+ } = e, l = t.getBoundingRect(!1, !0), u = s || c || 1, g = o || d || 1, f = uo({
5562
5599
  object: t,
5563
5600
  montageArea: n,
5564
5601
  bounds: e
@@ -5569,11 +5606,11 @@ class D {
5569
5606
  y: (y.y - r) / g
5570
5607
  };
5571
5608
  })(), m = (l.left - a) / u, v = (l.top - r) / g, b = m + l.width / u, I = v + l.height / g;
5572
- return i[ne] = p.x, i[ie] = p.y, i[ae] = D._detectAnchor({
5609
+ return i[ne] = p.x, i[ie] = p.y, i[ae] = L._detectAnchor({
5573
5610
  center: p.x,
5574
5611
  start: m,
5575
5612
  end: b
5576
- }), i[re] = D._detectAnchor({
5613
+ }), i[re] = L._detectAnchor({
5577
5614
  center: p.y,
5578
5615
  start: v,
5579
5616
  end: I
@@ -5599,7 +5636,7 @@ class D {
5599
5636
  errorManager: s
5600
5637
  }) {
5601
5638
  try {
5602
- const { fill: n, customData: i } = t, { backgroundType: a } = t, r = D._cloneCustomData(i);
5639
+ const { fill: n, customData: i } = t, { backgroundType: a } = t, r = L._cloneCustomData(i);
5603
5640
  if (a === "color" && typeof n == "string")
5604
5641
  return e.setColorBackground({
5605
5642
  color: n,
@@ -5607,7 +5644,7 @@ class D {
5607
5644
  withoutSave: !0
5608
5645
  }), !0;
5609
5646
  if (a === "gradient") {
5610
- const c = ho(n);
5647
+ const c = fo(n);
5611
5648
  if (c)
5612
5649
  return e.setGradientBackground({
5613
5650
  gradient: c,
@@ -5616,7 +5653,7 @@ class D {
5616
5653
  }), !0;
5617
5654
  }
5618
5655
  if (a === "image") {
5619
- const c = D._getImageSource(t);
5656
+ const c = L._getImageSource(t);
5620
5657
  if (c)
5621
5658
  return yield e.setImageBackground({
5622
5659
  imageSource: c,
@@ -5628,7 +5665,7 @@ class D {
5628
5665
  s.emitWarning({
5629
5666
  origin: "TemplateManager",
5630
5667
  method: "applyTemplate",
5631
- code: gt.TEMPLATE_MANAGER.APPLY_FAILED,
5668
+ code: ft.TEMPLATE_MANAGER.APPLY_FAILED,
5632
5669
  message: "Не удалось применить фон из шаблона",
5633
5670
  data: n
5634
5671
  });
@@ -5658,7 +5695,7 @@ class D {
5658
5695
  */
5659
5696
  static _cloneCustomData(t) {
5660
5697
  if (!(!t || typeof t != "object"))
5661
- return k({}, t);
5698
+ return x({}, t);
5662
5699
  }
5663
5700
  /**
5664
5701
  * Извлекает src изображения из FabricImage или его исходного элемента.
@@ -5684,10 +5721,10 @@ class D {
5684
5721
  */
5685
5722
  // eslint-disable-next-line class-methods-use-this
5686
5723
  enlivenObjectEnlivables(t) {
5687
- return rt.enlivenObjectEnlivables(t);
5724
+ return ct.enlivenObjectEnlivables(t);
5688
5725
  }
5689
5726
  }
5690
- const uo = 5, ts = "#3D8BF4", ge = 1, Ve = ({
5727
+ const po = 5, os = "#3D8BF4", ge = 1, Xt = 1, Qe = ({
5691
5728
  anchors: h,
5692
5729
  positions: t,
5693
5730
  threshold: e
@@ -5702,16 +5739,16 @@ const uo = 5, ts = "#3D8BF4", ge = 1, Ve = ({
5702
5739
  delta: s,
5703
5740
  guidePosition: n
5704
5741
  };
5705
- }, go = ({
5742
+ }, mo = ({
5706
5743
  activeBounds: h,
5707
5744
  threshold: t,
5708
5745
  anchors: e
5709
5746
  }) => {
5710
- const { left: s, right: o, centerX: n, top: i, bottom: a, centerY: r } = h, c = Ve({
5747
+ const { left: s, right: o, centerX: n, top: i, bottom: a, centerY: r } = h, c = Qe({
5711
5748
  anchors: e.vertical,
5712
5749
  positions: [s, n, o],
5713
5750
  threshold: t
5714
- }), d = Ve({
5751
+ }), d = Qe({
5715
5752
  anchors: e.horizontal,
5716
5753
  positions: [i, r, a],
5717
5754
  threshold: t
@@ -5727,7 +5764,7 @@ const uo = 5, ts = "#3D8BF4", ge = 1, Ve = ({
5727
5764
  deltaY: d.delta,
5728
5765
  guides: l
5729
5766
  };
5730
- }, es = ({
5767
+ }, ns = ({
5731
5768
  activeBounds: h,
5732
5769
  aligned: t,
5733
5770
  threshold: e,
@@ -5799,7 +5836,7 @@ const uo = 5, ts = "#3D8BF4", ge = 1, Ve = ({
5799
5836
  }
5800
5837
  }
5801
5838
  return c;
5802
- }, fo = ({
5839
+ }, yo = ({
5803
5840
  activeBounds: h,
5804
5841
  candidates: t,
5805
5842
  threshold: e,
@@ -5856,22 +5893,22 @@ const uo = 5, ts = "#3D8BF4", ge = 1, Ve = ({
5856
5893
  if (u && f) {
5857
5894
  const { bounds: y } = u, { bounds: w } = f, A = w.top - y.bottom - v;
5858
5895
  if (A >= 0) {
5859
- const M = A / 2, C = n - y.bottom, j = w.top - i, T = Math.abs(C - M), x = Math.abs(j - M), Z = Math.max(T, x);
5860
- if (Z <= e) {
5861
- const P = M - C, F = i + P, K = {
5896
+ const M = A / 2, C = n - y.bottom, j = w.top - i, T = Math.abs(C - M), B = Math.abs(j - M), G = Math.max(T, B);
5897
+ if (G <= e) {
5898
+ const Y = M - C, H = i + Y, V = {
5862
5899
  type: "vertical",
5863
5900
  axis: o,
5864
5901
  refStart: y.bottom,
5865
5902
  refEnd: y.bottom + M,
5866
- activeStart: F,
5867
- activeEnd: F + M,
5903
+ activeStart: H,
5904
+ activeEnd: H + M,
5868
5905
  distance: M
5869
5906
  };
5870
- m.push({ delta: P, guide: K, diff: Z });
5907
+ m.push({ delta: Y, guide: V, diff: G });
5871
5908
  }
5872
5909
  }
5873
5910
  }
5874
- const b = es({
5911
+ const b = ns({
5875
5912
  activeBounds: h,
5876
5913
  aligned: c,
5877
5914
  threshold: e,
@@ -5885,7 +5922,7 @@ const uo = 5, ts = "#3D8BF4", ge = 1, Ve = ({
5885
5922
  delta: I.delta,
5886
5923
  guide: I.guide
5887
5924
  };
5888
- }, po = ({
5925
+ }, vo = ({
5889
5926
  activeBounds: h,
5890
5927
  candidates: t,
5891
5928
  threshold: e,
@@ -5942,22 +5979,22 @@ const uo = 5, ts = "#3D8BF4", ge = 1, Ve = ({
5942
5979
  if (u && f) {
5943
5980
  const { bounds: y } = u, { bounds: w } = f, A = w.left - y.right - v;
5944
5981
  if (A >= 0) {
5945
- const M = A / 2, C = n - y.right, j = w.left - i, T = Math.abs(C - M), x = Math.abs(j - M), Z = Math.max(T, x);
5946
- if (Z <= e) {
5947
- const P = M - C, F = i + P, K = {
5982
+ const M = A / 2, C = n - y.right, j = w.left - i, T = Math.abs(C - M), B = Math.abs(j - M), G = Math.max(T, B);
5983
+ if (G <= e) {
5984
+ const Y = M - C, H = i + Y, V = {
5948
5985
  type: "horizontal",
5949
5986
  axis: o,
5950
5987
  refStart: y.right,
5951
5988
  refEnd: y.right + M,
5952
- activeStart: F,
5953
- activeEnd: F + M,
5989
+ activeStart: H,
5990
+ activeEnd: H + M,
5954
5991
  distance: M
5955
5992
  };
5956
- m.push({ delta: P, guide: K, diff: Z });
5993
+ m.push({ delta: Y, guide: V, diff: G });
5957
5994
  }
5958
5995
  }
5959
5996
  }
5960
- const b = es({
5997
+ const b = ns({
5961
5998
  activeBounds: h,
5962
5999
  aligned: c,
5963
6000
  threshold: e,
@@ -5971,18 +6008,18 @@ const uo = 5, ts = "#3D8BF4", ge = 1, Ve = ({
5971
6008
  delta: I.delta,
5972
6009
  guide: I.guide
5973
6010
  };
5974
- }, mo = ({
6011
+ }, bo = ({
5975
6012
  activeBounds: h,
5976
6013
  candidates: t,
5977
6014
  threshold: e,
5978
6015
  spacingPatterns: s
5979
6016
  }) => {
5980
- const o = fo({
6017
+ const o = yo({
5981
6018
  activeBounds: h,
5982
6019
  candidates: t,
5983
6020
  threshold: e,
5984
6021
  patterns: s.vertical
5985
- }), n = po({
6022
+ }), n = vo({
5986
6023
  activeBounds: h,
5987
6024
  candidates: t,
5988
6025
  threshold: e,
@@ -5993,7 +6030,7 @@ const uo = 5, ts = "#3D8BF4", ge = 1, Ve = ({
5993
6030
  deltaY: o.delta,
5994
6031
  guides: i
5995
6032
  };
5996
- }, yo = ({
6033
+ }, Mo = ({
5997
6034
  context: h,
5998
6035
  x: t,
5999
6036
  y: e,
@@ -6023,7 +6060,7 @@ const uo = 5, ts = "#3D8BF4", ge = 1, Ve = ({
6023
6060
  const p = i || 1, m = 12 / p, v = l / p, b = u / p, I = (s + o) / 2 + g, y = t === "vertical" ? e + f : I, w = t === "vertical" ? I : e + f;
6024
6061
  h.save(), h.setLineDash([]), h.fillStyle = a, h.strokeStyle = a, h.lineWidth = d / p, h.font = `${m}px ${c}`, h.textAlign = "center", h.textBaseline = "middle";
6025
6062
  const A = h.measureText(n).width + v * 2, M = m + v * 2, C = y - A / 2, j = w - M / 2;
6026
- h.beginPath(), yo({
6063
+ h.beginPath(), Mo({
6027
6064
  context: h,
6028
6065
  x: C,
6029
6066
  y: j,
@@ -6031,7 +6068,7 @@ const uo = 5, ts = "#3D8BF4", ge = 1, Ve = ({
6031
6068
  height: M,
6032
6069
  radius: b
6033
6070
  }), h.fill(), h.fillStyle = r, h.fillText(n, y, w), h.restore();
6034
- }, vo = ({
6071
+ }, wo = ({
6035
6072
  context: h,
6036
6073
  guide: t,
6037
6074
  zoom: e
@@ -6046,7 +6083,7 @@ const uo = 5, ts = "#3D8BF4", ge = 1, Ve = ({
6046
6083
  distance: c
6047
6084
  } = t, d = Math.round(c).toString();
6048
6085
  h.beginPath(), s === "vertical" ? (h.moveTo(o, n), h.lineTo(o, i), h.moveTo(o, a), h.lineTo(o, r)) : (h.moveTo(n, o), h.lineTo(i, o), h.moveTo(a, o), h.lineTo(r, o)), h.stroke();
6049
- const l = ts;
6086
+ const l = os;
6050
6087
  fe({
6051
6088
  context: h,
6052
6089
  type: s,
@@ -6068,7 +6105,7 @@ const uo = 5, ts = "#3D8BF4", ge = 1, Ve = ({
6068
6105
  color: l,
6069
6106
  lineWidth: ge
6070
6107
  });
6071
- }, Xe = ({
6108
+ }, qe = ({
6072
6109
  anchors: h,
6073
6110
  bounds: t
6074
6111
  }) => {
@@ -6081,7 +6118,7 @@ const uo = 5, ts = "#3D8BF4", ge = 1, Ve = ({
6081
6118
  centerY: a
6082
6119
  } = t;
6083
6120
  h.vertical.push(e, o, s), h.horizontal.push(n, a, i);
6084
- }, Ke = ({
6121
+ }, $e = ({
6085
6122
  bounds: h,
6086
6123
  type: t,
6087
6124
  primaryStart: e,
@@ -6108,30 +6145,30 @@ const uo = 5, ts = "#3D8BF4", ge = 1, Ve = ({
6108
6145
  });
6109
6146
  }
6110
6147
  return o;
6111
- }, bo = ({
6148
+ }, So = ({
6112
6149
  bounds: h
6113
6150
  }) => {
6114
- const t = Ke({
6151
+ const t = $e({
6115
6152
  bounds: h,
6116
6153
  type: "vertical",
6117
6154
  primaryStart: "top",
6118
6155
  primaryEnd: "bottom"
6119
- }), e = Ke({
6156
+ }), e = $e({
6120
6157
  bounds: h,
6121
6158
  type: "horizontal",
6122
6159
  primaryStart: "left",
6123
6160
  primaryEnd: "right"
6124
6161
  });
6125
6162
  return { vertical: t, horizontal: e };
6126
- }, Mo = ["montage-area", "background", "interaction-blocker"], ss = ({
6163
+ }, Ao = ["montage-area", "background", "interaction-blocker"], is = ({
6127
6164
  activeObject: h
6128
6165
  }) => {
6129
6166
  const t = /* @__PURE__ */ new Set();
6130
- return h && (t.add(h), h instanceof B && h.getObjects().forEach((e) => t.add(e))), t;
6131
- }, os = ({
6167
+ return h && (t.add(h), h instanceof k && h.getObjects().forEach((e) => t.add(e))), t;
6168
+ }, as = ({
6132
6169
  object: h,
6133
6170
  excluded: t,
6134
- ignoredIds: e = Mo
6171
+ ignoredIds: e = Ao
6135
6172
  }) => {
6136
6173
  if (t.has(h)) return !0;
6137
6174
  const { visible: s = !0 } = h;
@@ -6139,7 +6176,7 @@ const uo = 5, ts = "#3D8BF4", ge = 1, Ve = ({
6139
6176
  const { id: o } = h;
6140
6177
  return !!(o && e.includes(o));
6141
6178
  };
6142
- class wo {
6179
+ class jo {
6143
6180
  /**
6144
6181
  * Создаёт менеджер прилипания и инициализирует слушатели событий.
6145
6182
  */
@@ -6186,51 +6223,51 @@ class wo {
6186
6223
  * Выполняет привязку объекта к ближайшим линиям при его перемещении.
6187
6224
  */
6188
6225
  _handleObjectMoving(t) {
6189
- var f, p;
6226
+ var p, m;
6190
6227
  const { target: e, e: s } = t;
6191
6228
  if (!e) {
6192
6229
  this._clearGuides();
6193
6230
  return;
6194
6231
  }
6195
- if (s != null && s.ctrlKey) {
6196
- this._clearGuides();
6232
+ if (!!(s != null && s.ctrlKey)) {
6233
+ this._clearGuides(), this._applyMovementStep({ target: e });
6197
6234
  return;
6198
6235
  }
6199
6236
  !this.anchors.vertical.length && !this.anchors.horizontal.length && this._cacheAnchors({ activeObject: e });
6200
- let o = lt({ object: e });
6201
- if (!o) {
6237
+ let n = ht({ object: e });
6238
+ if (!n) {
6202
6239
  this._clearGuides();
6203
6240
  return;
6204
6241
  }
6205
- const { canvas: n } = this, i = n.getZoom() || 1, a = uo / i, r = go({
6206
- activeBounds: o,
6207
- threshold: a,
6242
+ const { canvas: i } = this, a = i.getZoom() || 1, r = po / a, c = mo({
6243
+ activeBounds: n,
6244
+ threshold: r,
6208
6245
  anchors: this.anchors
6209
- }), { deltaX: c, deltaY: d, guides: l } = r;
6210
- if (c !== 0 || d !== 0) {
6211
- const { left: m = 0, top: v = 0 } = e;
6246
+ }), { deltaX: d, deltaY: l, guides: u } = c;
6247
+ if (d !== 0 || l !== 0) {
6248
+ const { left: v = 0, top: b = 0 } = e;
6212
6249
  e.set({
6213
- left: m + c,
6214
- top: v + d
6215
- }), e.setCoords(), o = (f = lt({ object: e })) != null ? f : o;
6216
- }
6217
- const u = this.cachedTargetBounds.length ? this.cachedTargetBounds : this._collectTargets({ activeObject: e }).map((m) => lt({ object: m })).filter((m) => !!m), g = mo({
6218
- activeBounds: o,
6219
- candidates: u,
6220
- threshold: a,
6250
+ left: v + d,
6251
+ top: b + l
6252
+ }), e.setCoords(), n = (p = ht({ object: e })) != null ? p : n;
6253
+ }
6254
+ const g = this.cachedTargetBounds.length ? this.cachedTargetBounds : this._collectTargets({ activeObject: e }).map((v) => ht({ object: v })).filter((v) => !!v), f = bo({
6255
+ activeBounds: n,
6256
+ candidates: g,
6257
+ threshold: r,
6221
6258
  spacingPatterns: this.spacingPatterns
6222
6259
  });
6223
- if (g.deltaX !== 0 || g.deltaY !== 0) {
6224
- const { left: m = 0, top: v = 0 } = e;
6260
+ if (f.deltaX !== 0 || f.deltaY !== 0) {
6261
+ const { left: v = 0, top: b = 0 } = e;
6225
6262
  e.set({
6226
- left: m + g.deltaX,
6227
- top: v + g.deltaY
6228
- }), e.setCoords(), o = (p = lt({ object: e })) != null ? p : o;
6263
+ left: v + f.deltaX,
6264
+ top: b + f.deltaY
6265
+ }), e.setCoords(), n = (m = ht({ object: e })) != null ? m : n;
6229
6266
  }
6230
6267
  this._applyGuides({
6231
- guides: l,
6232
- spacingGuides: g.guides
6233
- });
6268
+ guides: u,
6269
+ spacingGuides: f.guides
6270
+ }), this._applyMovementStep({ target: e });
6234
6271
  }
6235
6272
  /**
6236
6273
  * Очищает направляющие и кеш после окончания перетаскивания.
@@ -6253,11 +6290,11 @@ class wo {
6253
6290
  const { canvas: t, guideBounds: e } = this, s = t.getSelectionContext();
6254
6291
  if (!s) return;
6255
6292
  const o = e != null ? e : this._calculateViewportBounds(), { left: n, right: i, top: a, bottom: r } = o, { viewportTransform: c } = t, d = t.getZoom() || 1;
6256
- s.save(), Array.isArray(c) && s.transform(...c), s.lineWidth = ge / d, s.strokeStyle = ts, s.setLineDash([4, 4]);
6293
+ s.save(), Array.isArray(c) && s.transform(...c), s.lineWidth = ge / d, s.strokeStyle = os, s.setLineDash([4, 4]);
6257
6294
  for (const l of this.activeGuides)
6258
6295
  s.beginPath(), l.type === "vertical" ? (s.moveTo(l.position, a), s.lineTo(l.position, r)) : (s.moveTo(n, l.position), s.lineTo(i, l.position)), s.stroke();
6259
6296
  for (const l of this.activeSpacingGuides)
6260
- vo({
6297
+ wo({
6261
6298
  context: s,
6262
6299
  guide: l,
6263
6300
  zoom: d
@@ -6289,18 +6326,28 @@ class wo {
6289
6326
  _clearAnchors() {
6290
6327
  this.anchors = { vertical: [], horizontal: [] }, this.spacingPatterns = { vertical: [], horizontal: [] }, this.cachedTargetBounds = [];
6291
6328
  }
6329
+ /**
6330
+ * Применяет шаг перемещения, округляя координаты объекта к сетке MOVE_SNAP_STEP.
6331
+ */
6332
+ _applyMovementStep({ target: t }) {
6333
+ const { left: e = 0, top: s = 0 } = t, o = Math.round(e / Xt) * Xt, n = Math.round(s / Xt) * Xt;
6334
+ o === e && n === s || (t.set({
6335
+ left: o,
6336
+ top: n
6337
+ }), t.setCoords());
6338
+ }
6292
6339
  /**
6293
6340
  * Сохраняет линии для прилипания от всех доступных объектов и монтажной области.
6294
6341
  */
6295
6342
  _cacheAnchors({ activeObject: t }) {
6296
6343
  const e = this._collectTargets({ activeObject: t }), s = { vertical: [], horizontal: [] }, o = [];
6297
6344
  for (const a of e) {
6298
- const r = lt({ object: a });
6299
- r && (Xe({ anchors: s, bounds: r }), o.push(r));
6345
+ const r = ht({ object: a });
6346
+ r && (qe({ anchors: s, bounds: r }), o.push(r));
6300
6347
  }
6301
- const { montageArea: n } = this.editor, i = lt({ object: n });
6348
+ const { montageArea: n } = this.editor, i = ht({ object: n });
6302
6349
  if (i) {
6303
- Xe({ anchors: s, bounds: i });
6350
+ qe({ anchors: s, bounds: i });
6304
6351
  const { left: a, right: r, top: c, bottom: d } = i;
6305
6352
  this.guideBounds = {
6306
6353
  left: a,
@@ -6310,15 +6357,15 @@ class wo {
6310
6357
  };
6311
6358
  } else
6312
6359
  this.guideBounds = this._calculateViewportBounds();
6313
- this.anchors = s, this.spacingPatterns = bo({ bounds: o }), this.cachedTargetBounds = o;
6360
+ this.anchors = s, this.spacingPatterns = So({ bounds: o }), this.cachedTargetBounds = o;
6314
6361
  }
6315
6362
  /**
6316
6363
  * Собирает объекты, подходящие для прилипания, исключая активный объект и запрещённые id.
6317
6364
  */
6318
6365
  _collectTargets({ activeObject: t }) {
6319
- const e = ss({ activeObject: t }), s = [];
6366
+ const e = is({ activeObject: t }), s = [];
6320
6367
  return this.canvas.forEachObject((o) => {
6321
- os({ object: o, excluded: e }) || s.push(o);
6368
+ as({ object: o, excluded: e }) || s.push(o);
6322
6369
  }), s;
6323
6370
  }
6324
6371
  /**
@@ -6341,8 +6388,8 @@ class wo {
6341
6388
  };
6342
6389
  }
6343
6390
  }
6344
- const Qe = "#3D8BF4", qe = 1;
6345
- class At {
6391
+ const Je = "#3D8BF4", ts = 1;
6392
+ class Ct {
6346
6393
  /**
6347
6394
  * Создаёт менеджер измерений и инициализирует события.
6348
6395
  */
@@ -6447,15 +6494,15 @@ class At {
6447
6494
  this._clearGuides();
6448
6495
  return;
6449
6496
  }
6450
- const n = lt({ object: o });
6497
+ const n = ht({ object: o });
6451
6498
  if (!n) {
6452
6499
  this._clearGuides();
6453
6500
  return;
6454
6501
  }
6455
- const i = At._resolveTarget({
6502
+ const i = Ct._resolveTarget({
6456
6503
  event: t,
6457
6504
  activeObject: o
6458
- }), { montageArea: a } = s, r = i != null ? i : a, c = r === a, d = lt({ object: r });
6505
+ }), { montageArea: a } = s, r = i != null ? i : a, c = r === a, d = ht({ object: r });
6459
6506
  if (!d) {
6460
6507
  this._clearGuides();
6461
6508
  return;
@@ -6464,7 +6511,7 @@ class At {
6464
6511
  this._clearGuides();
6465
6512
  return;
6466
6513
  }
6467
- const u = At._buildGuides({
6514
+ const u = Ct._buildGuides({
6468
6515
  activeBounds: n,
6469
6516
  targetBounds: d,
6470
6517
  targetIsMontageArea: c
@@ -6482,8 +6529,8 @@ class At {
6482
6529
  event: t,
6483
6530
  activeObject: e
6484
6531
  }) {
6485
- const { target: s } = t, o = ss({ activeObject: e });
6486
- return s && !os({ object: s, excluded: o }) ? s : null;
6532
+ const { target: s } = t, o = is({ activeObject: e });
6533
+ return s && !as({ object: s, excluded: o }) ? s : null;
6487
6534
  }
6488
6535
  /**
6489
6536
  * Собирает вертикальные и горизонтальные направляющие расстояний.
@@ -6493,11 +6540,11 @@ class At {
6493
6540
  targetBounds: e,
6494
6541
  targetIsMontageArea: s
6495
6542
  }) {
6496
- const o = At._buildHorizontalGuides({
6543
+ const o = Ct._buildHorizontalGuides({
6497
6544
  activeBounds: t,
6498
6545
  targetBounds: e,
6499
6546
  targetIsMontageArea: s
6500
- }), n = At._buildVerticalGuides({
6547
+ }), n = Ct._buildVerticalGuides({
6501
6548
  activeBounds: t,
6502
6549
  targetBounds: e,
6503
6550
  targetIsMontageArea: s
@@ -6651,7 +6698,7 @@ class At {
6651
6698
  const { canvas: t } = this, e = t.getSelectionContext();
6652
6699
  if (!e) return;
6653
6700
  const { viewportTransform: s } = t, o = t.getZoom() || 1, n = this.activeGuides.some((c) => c.type === "vertical"), i = this.activeGuides.some((c) => c.type === "horizontal"), a = n && i && !this.isTargetMontageArea, r = a ? 12 / o : 0;
6654
- e.save(), Array.isArray(s) && e.transform(...s), e.lineWidth = qe / o, e.strokeStyle = Qe, e.setLineDash([]);
6701
+ e.save(), Array.isArray(s) && e.transform(...s), e.lineWidth = ts / o, e.strokeStyle = Je, e.setLineDash([]);
6655
6702
  for (const c of this.activeGuides) {
6656
6703
  const { type: d, axis: l, start: u, end: g, distance: f } = c, p = Math.abs(g - u), m = u <= g ? -1 : 1, v = a ? m * (p / 2 + r) : 0, b = 0;
6657
6704
  e.beginPath(), d === "vertical" ? (e.moveTo(l, u), e.lineTo(l, g)) : (e.moveTo(u, l), e.lineTo(g, l)), e.stroke(), fe({
@@ -6662,8 +6709,8 @@ class At {
6662
6709
  end: g,
6663
6710
  text: Math.round(f).toString(),
6664
6711
  zoom: o,
6665
- color: Qe,
6666
- lineWidth: qe,
6712
+ color: Je,
6713
+ lineWidth: ts,
6667
6714
  offsetAlongAxis: v,
6668
6715
  offsetPerpendicular: b
6669
6716
  });
@@ -6696,7 +6743,7 @@ class Me {
6696
6743
  * @param options - опции и настройки редактора
6697
6744
  */
6698
6745
  constructor(t, e) {
6699
- this.options = e, this.containerId = t, this.editorId = `${t}-${Y()}`, this.clipboard = null, this.init();
6746
+ this.options = e, this.containerId = t, this.editorId = `${t}-${F()}`, this.clipboard = null, this.init();
6700
6747
  }
6701
6748
  /**
6702
6749
  * Инициализация редактора.
@@ -6719,7 +6766,7 @@ class Me {
6719
6766
  showRotationAngle: d,
6720
6767
  _onReadyCallback: l
6721
6768
  } = this.options;
6722
- if (Q.apply(), this.canvas = new ps(this.containerId, this.options), this.moduleLoader = new Ms(), this.workerManager = new Ss(), this.errorManager = new zt({ editor: this }), this.historyManager = new Kt({ editor: this }), this.toolbar = new zs({ editor: this }), this.transformManager = new Xs({ editor: this }), this.zoomManager = new Ks({ editor: this }), this.canvasManager = new Vs({ editor: this }), this.imageManager = new at({ editor: this }), this.layerManager = new Qt({ editor: this }), this.shapeManager = new qs({ editor: this }), this.interactionBlocker = new Qs({ editor: this }), this.backgroundManager = new St({ editor: this }), this.clipboardManager = new $s({ editor: this }), this.objectLockManager = new qt({ editor: this }), this.groupingManager = new Js({ editor: this }), this.selectionManager = new to({ editor: this }), this.deletionManager = new be({ editor: this }), this.panConstraintManager = new eo({ editor: this }), this.snappingManager = new wo({ editor: this }), this.measurementManager = new At({ editor: this }), this.fontManager = new ue((u = this.options.fonts) != null ? u : []), this.textManager = new q({ editor: this }), this.templateManager = new D({ editor: this }), d && (this.angleIndicator = new ve({ editor: this })), this._createMontageArea(), this._createClippingArea(), this.listeners = new xt({ editor: this, options: this.options }), this.canvasManager.setEditorContainerWidth(t), this.canvasManager.setEditorContainerHeight(e), this.canvasManager.setCanvasWrapperWidth(s), this.canvasManager.setCanvasWrapperHeight(o), this.canvasManager.setCanvasCSSWidth(n), this.canvasManager.setCanvasCSSHeight(i), this.canvasManager.updateCanvas(), this.zoomManager.calculateAndApplyDefaultZoom(), yield this.fontManager.loadFonts(), a != null && a.source) {
6769
+ if ($.apply(), this.canvas = new vs(this.containerId, this.options), this.moduleLoader = new As(), this.workerManager = new Is(), this.errorManager = new zt({ editor: this }), this.historyManager = new Qt({ editor: this }), this.toolbar = new Ys({ editor: this }), this.transformManager = new qs({ editor: this }), this.zoomManager = new $s({ editor: this }), this.canvasManager = new Qs({ editor: this }), this.imageManager = new rt({ editor: this }), this.layerManager = new qt({ editor: this }), this.shapeManager = new to({ editor: this }), this.interactionBlocker = new Js({ editor: this }), this.backgroundManager = new It({ editor: this }), this.clipboardManager = new eo({ editor: this }), this.objectLockManager = new $t({ editor: this }), this.groupingManager = new so({ editor: this }), this.selectionManager = new oo({ editor: this }), this.deletionManager = new be({ editor: this }), this.panConstraintManager = new no({ editor: this }), this.snappingManager = new jo({ editor: this }), this.measurementManager = new Ct({ editor: this }), this.fontManager = new ue((u = this.options.fonts) != null ? u : []), this.textManager = new U({ editor: this }), this.templateManager = new L({ editor: this }), d && (this.angleIndicator = new ve({ editor: this })), this._createMontageArea(), this._createClippingArea(), this.listeners = new Bt({ editor: this, options: this.options }), this.canvasManager.setEditorContainerWidth(t), this.canvasManager.setEditorContainerHeight(e), this.canvasManager.setCanvasWrapperWidth(s), this.canvasManager.setCanvasWrapperHeight(o), this.canvasManager.setCanvasCSSWidth(n), this.canvasManager.setCanvasCSSHeight(i), this.canvasManager.updateCanvas(), this.zoomManager.calculateAndApplyDefaultZoom(), yield this.fontManager.loadFonts(), a != null && a.source) {
6723
6770
  const {
6724
6771
  source: g,
6725
6772
  scale: f = `image-${c}`,
@@ -6792,7 +6839,7 @@ class Me {
6792
6839
  const t = document.createElement("canvas");
6793
6840
  t.width = 20, t.height = 20;
6794
6841
  const e = t.getContext("2d");
6795
- return e.fillStyle = "#ddd", e.fillRect(0, 0, 40, 40), e.fillStyle = "#ccc", e.fillRect(0, 0, 10, 10), e.fillRect(10, 10, 10, 10), new ms({
6842
+ return e.fillStyle = "#ddd", e.fillRect(0, 0, 40, 40), e.fillStyle = "#ccc", e.fillRect(0, 0, 10, 10), e.fillRect(10, 10, 10, 10), new bs({
6796
6843
  source: t,
6797
6844
  repeat: "repeat"
6798
6845
  });
@@ -6824,7 +6871,7 @@ const E = [
6824
6871
  "U+0490-0491",
6825
6872
  "U+04B0-04B1",
6826
6873
  "U+2116"
6827
- ].join(", "), So = [
6874
+ ].join(", "), Io = [
6828
6875
  {
6829
6876
  family: "Arial",
6830
6877
  source: 'local("Arial"), local("Liberation Sans"), local("DejaVu Sans")',
@@ -7614,7 +7661,7 @@ const E = [
7614
7661
  unicodeRange: E
7615
7662
  }
7616
7663
  }
7617
- ], Ao = {
7664
+ ], Co = {
7618
7665
  /**
7619
7666
  * Опции редактора
7620
7667
  */
@@ -7706,10 +7753,10 @@ const E = [
7706
7753
  /**
7707
7754
  * Список шрифтов, которые будут доступны в редакторе по умолчанию.
7708
7755
  */
7709
- fonts: So
7756
+ fonts: Io
7710
7757
  };
7711
- function Eo(h, t = {}) {
7712
- const e = k(k({}, Ao), t), s = document.getElementById(h);
7758
+ function Lo(h, t = {}) {
7759
+ const e = x(x({}, Co), t), s = document.getElementById(h);
7713
7760
  if (!s)
7714
7761
  return Promise.reject(new Error(`Контейнер с ID "${h}" не найден.`));
7715
7762
  const o = document.createElement("canvas");
@@ -7720,6 +7767,6 @@ function Eo(h, t = {}) {
7720
7767
  });
7721
7768
  }
7722
7769
  export {
7723
- Eo as default
7770
+ Lo as default
7724
7771
  };
7725
7772
  //# sourceMappingURL=main.js.map