@anu3ev/fabric-image-editor 0.3.0 → 0.3.1

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 (3) hide show
  1. package/dist/main.js +529 -483
  2. package/package.json +1 -1
  3. package/readme.md +64 -1
package/dist/main.js CHANGED
@@ -1,25 +1,25 @@
1
- var we = Object.defineProperty, De = Object.defineProperties;
2
- var Oe = Object.getOwnPropertyDescriptors;
1
+ var De = Object.defineProperty, Oe = Object.defineProperties;
2
+ var Te = Object.getOwnPropertyDescriptors;
3
3
  var pt = Object.getOwnPropertySymbols;
4
- var he = Object.prototype.hasOwnProperty, ue = Object.prototype.propertyIsEnumerable;
5
- var le = (l, t, e) => t in l ? we(l, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : l[t] = e, D = (l, t) => {
4
+ var ge = Object.prototype.hasOwnProperty, fe = Object.prototype.propertyIsEnumerable;
5
+ var ue = (h, t, e) => t in h ? De(h, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : h[t] = e, E = (h, t) => {
6
6
  for (var e in t || (t = {}))
7
- he.call(t, e) && le(l, e, t[e]);
7
+ ge.call(t, e) && ue(h, e, t[e]);
8
8
  if (pt)
9
9
  for (var e of pt(t))
10
- ue.call(t, e) && le(l, e, t[e]);
11
- return l;
12
- }, ge = (l, t) => De(l, Oe(t));
13
- var X = (l, t) => {
10
+ fe.call(t, e) && ue(h, e, t[e]);
11
+ return h;
12
+ }, me = (h, t) => Oe(h, Te(t));
13
+ var X = (h, t) => {
14
14
  var e = {};
15
- for (var s in l)
16
- he.call(l, s) && t.indexOf(s) < 0 && (e[s] = l[s]);
17
- if (l != null && pt)
18
- for (var s of pt(l))
19
- t.indexOf(s) < 0 && ue.call(l, s) && (e[s] = l[s]);
15
+ for (var s in h)
16
+ ge.call(h, s) && t.indexOf(s) < 0 && (e[s] = h[s]);
17
+ if (h != null && pt)
18
+ for (var s of pt(h))
19
+ t.indexOf(s) < 0 && fe.call(h, s) && (e[s] = h[s]);
20
20
  return e;
21
21
  };
22
- var C = (l, t, e) => new Promise((s, n) => {
22
+ var C = (h, t, e) => new Promise((s, n) => {
23
23
  var o = (r) => {
24
24
  try {
25
25
  i(e.next(r));
@@ -33,14 +33,14 @@ var C = (l, t, e) => new Promise((s, n) => {
33
33
  n(c);
34
34
  }
35
35
  }, i = (r) => r.done ? s(r.value) : Promise.resolve(r.value).then(o, a);
36
- i((e = e.apply(l, t)).next());
36
+ i((e = e.apply(h, t)).next());
37
37
  });
38
- import { ActiveSelection as O, Textbox as gt, util as mt, controlsUtils as fe, InteractiveFabricObject as me, loadSVGFromURL as Ee, FabricImage as ht, Point as yt, Gradient as pe, Rect as Ne, Circle as Le, Triangle as Te, Group as $, Canvas as ke, Pattern as xe } from "fabric";
39
- import { create as Be } from "jsondiffpatch";
40
- import _e from "diff-match-patch";
41
- var Re = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict", N = function() {
38
+ import { ActiveSelection as D, Textbox as gt, util as mt, controlsUtils as pe, InteractiveFabricObject as Me, loadSVGFromURL as Ne, FabricImage as ht, Point as bt, Gradient as ye, Rect as Le, Circle as xe, Triangle as ke, Group as $, Canvas as Be, Pattern as _e } from "fabric";
39
+ import { create as Re } from "jsondiffpatch";
40
+ import Ue from "diff-match-patch";
41
+ var ze = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict", x = 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 += Re[s[t] & 63];
43
+ e += ze[s[t] & 63];
44
44
  return e;
45
45
  };
46
46
  class ft {
@@ -98,7 +98,7 @@ class ft {
98
98
  if (n.length === 1)
99
99
  this.canvas.setActiveObject(n[0]);
100
100
  else {
101
- const a = new O(n, {
101
+ const a = new D(n, {
102
102
  canvas: this.canvas
103
103
  });
104
104
  this.canvas.setActiveObject(a);
@@ -106,7 +106,7 @@ class ft {
106
106
  this.canvas.requestRenderAll();
107
107
  return;
108
108
  }
109
- const o = new O(t, {
109
+ const o = new D(t, {
110
110
  canvas: this.canvas
111
111
  });
112
112
  this.editor.objectLockManager.lockObject({
@@ -120,16 +120,16 @@ class ft {
120
120
  * Срабатывают при изменении объектов (перемещение, изменение размера и т.д.).
121
121
  */
122
122
  handleObjectModifiedHistory() {
123
- this.editor.historyManager.skipHistory || this.editor.historyManager.saveState();
123
+ this.editor.historyManager.skipHistory || this.editor.textManager.isTextEditingActive || this.editor.historyManager.saveState();
124
124
  }
125
125
  handleObjectRotatingHistory() {
126
- this.editor.historyManager.skipHistory || this.editor.historyManager.saveState();
126
+ this.editor.historyManager.skipHistory || this.editor.textManager.isTextEditingActive || this.editor.historyManager.saveState();
127
127
  }
128
128
  handleObjectAddedHistory() {
129
- this.editor.historyManager.skipHistory || this.editor.historyManager.saveState();
129
+ this.editor.historyManager.skipHistory || this.editor.textManager.isTextEditingActive || this.editor.historyManager.saveState();
130
130
  }
131
131
  handleObjectRemovedHistory() {
132
- this.editor.historyManager.skipHistory || this.editor.historyManager.saveState();
132
+ this.editor.historyManager.skipHistory || this.editor.textManager.isTextEditingActive || this.editor.historyManager.saveState();
133
133
  }
134
134
  /**
135
135
  * Обновление overlayMask при добавлении объектов или выделении.
@@ -220,7 +220,7 @@ class ft {
220
220
  if (n || o) return;
221
221
  this.isSpacePressed = !0, t.preventDefault();
222
222
  const a = e.getActiveObject() || null;
223
- a instanceof O ? this.savedSelection = a.getObjects().slice() : a && (this.savedSelection = [a]), e.discardActiveObject(), e.set({
223
+ a instanceof D ? this.savedSelection = a.getObjects().slice() : a && (this.savedSelection = [a]), e.discardActiveObject(), e.set({
224
224
  selection: !1,
225
225
  defaultCursor: "grab"
226
226
  }), e.setCursor("grab"), s.canvasManager.getObjects().forEach((i) => {
@@ -259,7 +259,7 @@ class ft {
259
259
  e.setActiveObject(t[0]);
260
260
  return;
261
261
  }
262
- const n = t.filter((a) => s.canvasManager.getObjects().includes(a)), o = new O(n, { canvas: e });
262
+ const n = t.filter((a) => s.canvasManager.getObjects().includes(a)), o = new D(n, { canvas: e });
263
263
  e.setActiveObject(o);
264
264
  }
265
265
  // --- Обработчики для событий canvas (Fabric) ---
@@ -342,7 +342,12 @@ class ft {
342
342
  const e = document.activeElement, s = t.target, n = ["input", "textarea", "select"];
343
343
  if (s) {
344
344
  const a = s.tagName.toLowerCase();
345
- if (n.includes(a) || s.contentEditable === "true") return !0;
345
+ if (t.type === "paste" && n.includes(a)) {
346
+ const i = e == null ? void 0 : e.tagName.toLowerCase();
347
+ return !!(i && n.includes(i));
348
+ }
349
+ if (n.includes(a) || s.contentEditable === "true")
350
+ return !0;
346
351
  }
347
352
  if (e && e !== s) {
348
353
  const a = e.tagName.toLowerCase();
@@ -356,11 +361,11 @@ class ft {
356
361
  if (c != null && c.length && r)
357
362
  for (const d of c)
358
363
  try {
359
- const h = r;
360
- if (h.matches && h.matches(d) || h.closest && h.closest(d))
364
+ const l = r;
365
+ if (l.matches && l.matches(d) || l.closest && l.closest(d))
361
366
  return !0;
362
- } catch (h) {
363
- console.warn(`Error checking selection container with selector "${d}":`, h);
367
+ } catch (l) {
368
+ console.warn(`Error checking selection container with selector "${d}":`, l);
364
369
  }
365
370
  }
366
371
  return !1;
@@ -386,7 +391,7 @@ class ft {
386
391
  };
387
392
  }
388
393
  }
389
- class Ue {
394
+ class Ye {
390
395
  /**
391
396
  * Класс для динамической загрузки внешних модулей.
392
397
  */
@@ -404,21 +409,21 @@ class Ue {
404
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}"`));
405
410
  }
406
411
  }
407
- function ze(l) {
412
+ function Fe(h) {
408
413
  return new Worker(
409
414
  "" + new URL("assets/worker-CN39s7P7.js", import.meta.url).href,
410
415
  {
411
- name: l == null ? void 0 : l.name
416
+ name: h == null ? void 0 : h.name
412
417
  }
413
418
  );
414
419
  }
415
- class Ye {
420
+ class He {
416
421
  /**
417
422
  * @param scriptUrl — URL скрипта воркера.
418
423
  * По-умолчанию использует DefaultWorker из соседнего файла
419
424
  */
420
425
  constructor(t) {
421
- t ? this.worker = new Worker(t, { type: "module" }) : this.worker = new ze(), this._callbacks = /* @__PURE__ */ new Map(), this.worker.onmessage = this._handleMessage.bind(this);
426
+ t ? this.worker = new Worker(t, { type: "module" }) : this.worker = new Fe(), this._callbacks = /* @__PURE__ */ new Map(), this.worker.onmessage = this._handleMessage.bind(this);
422
427
  }
423
428
  /**
424
429
  * Обработчик сообщений от воркера
@@ -446,7 +451,7 @@ class Ye {
446
451
  * @returns Promise, который будет выполнен, когда воркер вернет ответ
447
452
  */
448
453
  post(t, e, s = []) {
449
- const n = `${t}:${N(8)}`;
454
+ const n = `${t}:${x(8)}`;
450
455
  return new Promise((o, a) => {
451
456
  this._callbacks.set(n, { resolve: o, reject: a }), this.worker.postMessage({ action: t, payload: e, requestId: n }, s);
452
457
  });
@@ -458,26 +463,26 @@ class Ye {
458
463
  this.worker.terminate();
459
464
  }
460
465
  }
461
- const F = 12, Fe = 2, Dt = 8, Ot = 20, He = 100, Et = 20, Nt = 8, Ze = 100, bt = 32, Tt = 1, We = "#2B2D33", kt = "#3D8BF4", xt = "#FFFFFF";
462
- function Mt(l, t, e, s, n) {
463
- const o = F, a = Fe;
464
- l.save(), l.translate(t, e), l.rotate(mt.degreesToRadians(n.angle)), l.fillStyle = xt, l.strokeStyle = kt, l.lineWidth = Tt, l.beginPath(), l.roundRect(-o / 2, -o / 2, o, o, a), l.fill(), l.stroke(), l.restore();
466
+ const F = 12, Ze = 2, Dt = 8, Ot = 20, We = 100, Tt = 20, Nt = 8, Pe = 100, vt = 32, xt = 1, Ve = "#2B2D33", kt = "#3D8BF4", Bt = "#FFFFFF";
467
+ function Mt(h, t, e, s, n) {
468
+ const o = F, a = Ze;
469
+ h.save(), h.translate(t, e), h.rotate(mt.degreesToRadians(n.angle)), h.fillStyle = Bt, h.strokeStyle = kt, h.lineWidth = xt, h.beginPath(), h.roundRect(-o / 2, -o / 2, o, o, a), h.fill(), h.stroke(), h.restore();
465
470
  }
466
- function Me(l, t, e, s, n) {
467
- const o = Dt, a = Ot, i = He;
468
- l.save(), l.translate(t, e), l.rotate(mt.degreesToRadians(n.angle)), l.fillStyle = xt, l.strokeStyle = kt, l.lineWidth = Tt, l.beginPath(), l.roundRect(-o / 2, -a / 2, o, a, i), l.fill(), l.stroke(), l.restore();
471
+ function be(h, t, e, s, n) {
472
+ const o = Dt, a = Ot, i = We;
473
+ h.save(), h.translate(t, e), h.rotate(mt.degreesToRadians(n.angle)), h.fillStyle = Bt, h.strokeStyle = kt, h.lineWidth = xt, h.beginPath(), h.roundRect(-o / 2, -a / 2, o, a, i), h.fill(), h.stroke(), h.restore();
469
474
  }
470
- function ye(l, t, e, s, n) {
471
- const o = Et, a = Nt, i = Ze;
472
- l.save(), l.translate(t, e), l.rotate(mt.degreesToRadians(n.angle)), l.fillStyle = xt, l.strokeStyle = kt, l.lineWidth = Tt, l.beginPath(), l.roundRect(-o / 2, -a / 2, o, a, i), l.fill(), l.stroke(), l.restore();
475
+ function ve(h, t, e, s, n) {
476
+ const o = Tt, a = Nt, i = Pe;
477
+ h.save(), h.translate(t, e), h.rotate(mt.degreesToRadians(n.angle)), h.fillStyle = Bt, h.strokeStyle = kt, h.lineWidth = xt, h.beginPath(), h.roundRect(-o / 2, -a / 2, o, a, i), h.fill(), h.stroke(), h.restore();
473
478
  }
474
- const Pe = "", Ce = new Image();
475
- Ce.src = Pe;
476
- function Ve(l, t, e, s, n) {
477
- const a = bt / 2;
478
- l.save(), l.translate(t, e), l.rotate(mt.degreesToRadians(n.angle)), l.fillStyle = We, l.beginPath(), l.arc(0, 0, a, 0, 2 * Math.PI), l.fill(), l.drawImage(Ce, -a / 2, -a / 2, a, a), l.restore();
479
+ const Ge = "", we = new Image();
480
+ we.src = Ge;
481
+ function Xe(h, t, e, s, n) {
482
+ const a = vt / 2;
483
+ h.save(), h.translate(t, e), h.rotate(mt.degreesToRadians(n.angle)), h.fillStyle = Ve, h.beginPath(), h.arc(0, 0, a, 0, 2 * Math.PI), h.fill(), h.drawImage(we, -a / 2, -a / 2, a, a), h.restore();
479
484
  }
480
- const Ge = {
485
+ const Ke = {
481
486
  // Угловые точки
482
487
  tl: {
483
488
  render: Mt,
@@ -509,14 +514,14 @@ const Ge = {
509
514
  },
510
515
  // Середина вертикалей
511
516
  ml: {
512
- render: Me,
517
+ render: be,
513
518
  sizeX: Dt,
514
519
  sizeY: Ot,
515
520
  offsetX: 0,
516
521
  offsetY: 0
517
522
  },
518
523
  mr: {
519
- render: Me,
524
+ render: be,
520
525
  sizeX: Dt,
521
526
  sizeY: Ot,
522
527
  offsetX: 0,
@@ -524,31 +529,31 @@ const Ge = {
524
529
  },
525
530
  // Середина горизонталей
526
531
  mt: {
527
- render: ye,
528
- sizeX: Et,
532
+ render: ve,
533
+ sizeX: Tt,
529
534
  sizeY: Nt,
530
535
  offsetX: 0,
531
536
  offsetY: 0
532
537
  },
533
538
  mb: {
534
- render: ye,
535
- sizeX: Et,
539
+ render: ve,
540
+ sizeX: Tt,
536
541
  sizeY: Nt,
537
542
  offsetX: 0,
538
543
  offsetY: 0
539
544
  },
540
545
  // Специальный «rotate» контрол
541
546
  mtr: {
542
- render: Ve,
543
- sizeX: bt,
544
- sizeY: bt,
547
+ render: Xe,
548
+ sizeX: vt,
549
+ sizeY: vt,
545
550
  offsetX: 0,
546
- offsetY: -bt
551
+ offsetY: -vt
547
552
  }
548
553
  };
549
- class vt {
554
+ class jt {
550
555
  static applyControlOverrides(t) {
551
- Object.entries(Ge).forEach(([e, s]) => {
556
+ Object.entries(Ke).forEach(([e, s]) => {
552
557
  const n = t[e];
553
558
  n && (Object.assign(n, s), e === "mtr" && (n.cursorStyle = "grab", n.mouseDownHandler = (o, a, i, r) => {
554
559
  var d;
@@ -558,13 +563,13 @@ class vt {
558
563
  });
559
564
  }
560
565
  static apply() {
561
- const t = fe.createObjectDefaultControls();
562
- vt.applyControlOverrides(t), me.ownDefaults.controls = t;
563
- const e = fe.createTextboxDefaultControls();
564
- vt.applyControlOverrides(e), e.mt && (e.mt.visible = !1), e.mb && (e.mb.visible = !1), gt.ownDefaults.controls = e, me.ownDefaults.snapAngle = 1;
566
+ const t = pe.createObjectDefaultControls();
567
+ jt.applyControlOverrides(t), Me.ownDefaults.controls = t;
568
+ const e = pe.createTextboxDefaultControls();
569
+ jt.applyControlOverrides(e), e.mt && (e.mt.visible = !1), e.mb && (e.mb.visible = !1), gt.ownDefaults.controls = e, Me.ownDefaults.snapAngle = 1;
565
570
  }
566
571
  }
567
- const I = class I {
572
+ const j = class j {
568
573
  constructor(t = []) {
569
574
  this.fonts = t;
570
575
  }
@@ -578,7 +583,7 @@ const I = class I {
578
583
  if (!t.length) return;
579
584
  const e = typeof document != "undefined" ? document : void 0;
580
585
  if (!e) return;
581
- const s = t.map((o) => I.loadFont(o, e));
586
+ const s = t.map((o) => j.loadFont(o, e));
582
587
  yield Promise.allSettled(s);
583
588
  });
584
589
  }
@@ -587,21 +592,21 @@ const I = class I {
587
592
  var c, d;
588
593
  const s = typeof FontFace != "undefined", n = (c = t.family) == null ? void 0 : c.trim(), o = (d = t.source) == null ? void 0 : d.trim();
589
594
  if (!n || !o) return;
590
- const a = I.normalizeFontSource(o), i = I.getDescriptorSnapshot(t.descriptors), r = I.getFontRegistrationKey(n, a, i);
591
- if (!I.registeredFontKeys.has(r)) {
592
- if (I.isFontFaceAlreadyApplied(e, n, i)) {
593
- I.registeredFontKeys.add(r);
595
+ const a = j.normalizeFontSource(o), i = j.getDescriptorSnapshot(t.descriptors), r = j.getFontRegistrationKey(n, a, i);
596
+ if (!j.registeredFontKeys.has(r)) {
597
+ if (j.isFontFaceAlreadyApplied(e, n, i)) {
598
+ j.registeredFontKeys.add(r);
594
599
  return;
595
600
  }
596
601
  if (s && e.fonts && typeof e.fonts.add == "function")
597
602
  try {
598
603
  const u = yield new FontFace(n, a, t.descriptors).load();
599
- e.fonts.add(u), I.registeredFontKeys.add(r);
604
+ e.fonts.add(u), j.registeredFontKeys.add(r);
600
605
  return;
601
- } catch (h) {
602
- console.warn(`Не удалось загрузить шрифт "${n}" через FontFace API`, h);
606
+ } catch (l) {
607
+ console.warn(`Не удалось загрузить шрифт "${n}" через FontFace API`, l);
603
608
  }
604
- I.injectFontFace({
609
+ j.injectFontFace({
605
610
  font: t,
606
611
  source: a,
607
612
  doc: e,
@@ -621,15 +626,15 @@ const I = class I {
621
626
  if (!a) return;
622
627
  const i = s.createElement("style");
623
628
  i.setAttribute("data-editor-font", a), i.setAttribute("data-editor-font-key", n);
624
- const r = I.descriptorsToCss(o), c = [
629
+ const r = j.descriptorsToCss(o), c = [
625
630
  "@font-face {",
626
- ` font-family: ${I.formatFontFamilyForCss(a)};`,
631
+ ` font-family: ${j.formatFontFamilyForCss(a)};`,
627
632
  ` src: ${e};`,
628
- ...r.map((h) => ` ${h}`),
633
+ ...r.map((l) => ` ${l}`),
629
634
  "}"
630
635
  ];
631
636
  i.textContent = c.join(`
632
- `), s.head.appendChild(i), I.registeredFontKeys.add(n);
637
+ `), s.head.appendChild(i), j.registeredFontKeys.add(n);
633
638
  }
634
639
  static normalizeFontSource(t) {
635
640
  const e = t.trim();
@@ -652,15 +657,15 @@ const I = class I {
652
657
  return t ? t.trim().replace(/^['"]+|['"]+$/g, "").toLowerCase() : "";
653
658
  }
654
659
  static getDescriptorSnapshot(t) {
655
- const e = I.descriptorDefaults;
660
+ const e = j.descriptorDefaults;
656
661
  return {
657
- style: I.normalizeDescriptorValue(t == null ? void 0 : t.style, e.style),
658
- weight: I.normalizeDescriptorValue(t == null ? void 0 : t.weight, e.weight),
659
- stretch: I.normalizeDescriptorValue(t == null ? void 0 : t.stretch, e.stretch),
660
- unicodeRange: I.normalizeDescriptorValue(t == null ? void 0 : t.unicodeRange, e.unicodeRange),
661
- variant: I.normalizeDescriptorValue(t == null ? void 0 : t.variant, e.variant),
662
- featureSettings: I.normalizeDescriptorValue(t == null ? void 0 : t.featureSettings, e.featureSettings),
663
- display: I.normalizeDescriptorValue(t == null ? void 0 : t.display, e.display)
662
+ style: j.normalizeDescriptorValue(t == null ? void 0 : t.style, e.style),
663
+ weight: j.normalizeDescriptorValue(t == null ? void 0 : t.weight, e.weight),
664
+ stretch: j.normalizeDescriptorValue(t == null ? void 0 : t.stretch, e.stretch),
665
+ unicodeRange: j.normalizeDescriptorValue(t == null ? void 0 : t.unicodeRange, e.unicodeRange),
666
+ variant: j.normalizeDescriptorValue(t == null ? void 0 : t.variant, e.variant),
667
+ featureSettings: j.normalizeDescriptorValue(t == null ? void 0 : t.featureSettings, e.featureSettings),
668
+ display: j.normalizeDescriptorValue(t == null ? void 0 : t.display, e.display)
664
669
  };
665
670
  }
666
671
  static areDescriptorSnapshotsEqual(t, e) {
@@ -668,7 +673,7 @@ const I = class I {
668
673
  }
669
674
  static getFontRegistrationKey(t, e, s) {
670
675
  return [
671
- I.normalizeFamilyName(t),
676
+ j.normalizeFamilyName(t),
672
677
  e,
673
678
  s.style,
674
679
  s.weight,
@@ -682,12 +687,12 @@ const I = class I {
682
687
  static isFontFaceAlreadyApplied(t, e, s) {
683
688
  const n = t.fonts;
684
689
  if (!n || typeof n.forEach != "function") return !1;
685
- const o = I.normalizeFamilyName(e);
690
+ const o = j.normalizeFamilyName(e);
686
691
  let a = !1;
687
692
  try {
688
693
  n.forEach((i) => {
689
- if (a || I.normalizeFamilyName(i.family) !== o) return;
690
- const c = I.getDescriptorSnapshot({
694
+ if (a || j.normalizeFamilyName(i.family) !== o) return;
695
+ const c = j.getDescriptorSnapshot({
691
696
  style: i.style,
692
697
  weight: i.weight,
693
698
  stretch: i.stretch,
@@ -696,7 +701,7 @@ const I = class I {
696
701
  featureSettings: i.featureSettings,
697
702
  display: i.display
698
703
  });
699
- I.areDescriptorSnapshotsEqual(s, c) && (a = !0);
704
+ j.areDescriptorSnapshotsEqual(s, c) && (a = !0);
700
705
  });
701
706
  } catch (i) {
702
707
  return console.warn("Не удалось проверить, загружен ли шрифт ранее через FontFaceSet", i), !1;
@@ -723,7 +728,7 @@ const I = class I {
723
728
  });
724
729
  }
725
730
  };
726
- I.registeredFontKeys = /* @__PURE__ */ new Set(), I.descriptorDefaults = {
731
+ j.registeredFontKeys = /* @__PURE__ */ new Set(), j.descriptorDefaults = {
727
732
  style: "normal",
728
733
  weight: "normal",
729
734
  stretch: "normal",
@@ -732,8 +737,8 @@ I.registeredFontKeys = /* @__PURE__ */ new Set(), I.descriptorDefaults = {
732
737
  featureSettings: "normal",
733
738
  display: "auto"
734
739
  };
735
- let Lt = I;
736
- const Xe = "", Ke = "", $e = "", Qe = "", Je = "", qe = "", ts = "", es = "", ut = {
740
+ let Lt = j;
741
+ const $e = "", Qe = "", Je = "", qe = "", ts = "", es = "", ss = "", ns = "", ut = {
737
742
  style: {
738
743
  position: "absolute",
739
744
  display: "none",
@@ -800,54 +805,54 @@ const Xe = "
800
805
  ],
801
806
  offsetTop: 50,
802
807
  icons: {
803
- copyPaste: Xe,
804
- delete: es,
805
- lock: Ke,
806
- unlock: $e,
807
- bringToFront: qe,
808
- sendToBack: ts,
809
- bringForward: Qe,
810
- sendBackwards: Je
808
+ copyPaste: $e,
809
+ delete: ns,
810
+ lock: Qe,
811
+ unlock: Je,
812
+ bringToFront: es,
813
+ sendToBack: ss,
814
+ bringForward: qe,
815
+ sendBackwards: ts
811
816
  },
812
817
  handlers: {
813
- copyPaste: (l) => C(null, null, function* () {
814
- l.clipboardManager.copyPaste();
818
+ copyPaste: (h) => C(null, null, function* () {
819
+ h.clipboardManager.copyPaste();
815
820
  }),
816
- delete: (l) => {
817
- l.deletionManager.deleteSelectedObjects();
821
+ delete: (h) => {
822
+ h.deletionManager.deleteSelectedObjects();
818
823
  },
819
- lock: (l) => {
820
- l.objectLockManager.lockObject();
824
+ lock: (h) => {
825
+ h.objectLockManager.lockObject();
821
826
  },
822
- unlock: (l) => {
823
- l.objectLockManager.unlockObject();
827
+ unlock: (h) => {
828
+ h.objectLockManager.unlockObject();
824
829
  },
825
- bringForward: (l) => {
826
- l.layerManager.bringForward();
830
+ bringForward: (h) => {
831
+ h.layerManager.bringForward();
827
832
  },
828
- bringToFront: (l) => {
829
- l.layerManager.bringToFront();
833
+ bringToFront: (h) => {
834
+ h.layerManager.bringToFront();
830
835
  },
831
- sendToBack: (l) => {
832
- l.layerManager.sendToBack();
836
+ sendToBack: (h) => {
837
+ h.layerManager.sendToBack();
833
838
  },
834
- sendBackwards: (l) => {
835
- l.layerManager.sendBackwards();
839
+ sendBackwards: (h) => {
840
+ h.layerManager.sendBackwards();
836
841
  }
837
842
  }
838
843
  };
839
- class ss {
844
+ class os {
840
845
  constructor({ editor: t }) {
841
846
  this.currentTarget = null, this.currentLocked = !1, this.isTransforming = !1, this.editor = t, this.canvas = t.canvas, this.options = t.options, this._initToolbar();
842
847
  }
843
848
  _initToolbar() {
844
849
  if (!this.options.showToolbar) return;
845
850
  const t = this.options.toolbar || {};
846
- this.config = ge(D(D({}, ut), t), {
847
- style: D(D({}, ut.style), t.style || {}),
848
- btnStyle: D(D({}, ut.btnStyle), t.btnStyle || {}),
849
- icons: D(D({}, ut.icons), t.icons || {}),
850
- handlers: D(D({}, ut.handlers), t.handlers || {})
851
+ this.config = me(E(E({}, ut), t), {
852
+ style: E(E({}, ut.style), t.style || {}),
853
+ btnStyle: E(E({}, ut.btnStyle), t.btnStyle || {}),
854
+ icons: E(E({}, ut.icons), t.icons || {}),
855
+ handlers: E(E({}, ut.handlers), t.handlers || {})
851
856
  }), this.currentTarget = null, this.currentLocked = !1, this.isTransforming = !1, this._onMouseDown = this._handleMouseDown.bind(this), this._onObjectMoving = this._startTransform.bind(this), this._onObjectScaling = this._startTransform.bind(this), this._onObjectRotating = this._startTransform.bind(this), this._onMouseUp = this._endTransform.bind(this), this._onObjectModified = this._endTransform.bind(this), this._onSelectionChange = this._updateToolbar.bind(this), this._onSelectionClear = () => {
852
857
  this.el.style.display = "none";
853
858
  }, this._createDOM(), this._bindEvents();
@@ -952,7 +957,7 @@ class ss {
952
957
  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();
953
958
  }
954
959
  }
955
- const ns = {
960
+ const as = {
956
961
  position: "absolute",
957
962
  display: "none",
958
963
  background: "#2B2D33",
@@ -966,8 +971,8 @@ const ns = {
966
971
  "pointer-events": "none",
967
972
  "white-space": "nowrap",
968
973
  "box-shadow": "0 2px 8px rgba(0, 0, 0, 0.2)"
969
- }, be = 16, ve = 16, os = "fabric-editor-angle-indicator";
970
- class Bt {
974
+ }, je = 16, Ie = 16, is = "fabric-editor-angle-indicator";
975
+ class _t {
971
976
  constructor({ editor: t }) {
972
977
  this.isActive = !1, this.currentAngle = 0, this.editor = t, this.canvas = t.canvas, this.options = t.options, this._createDOM(), this._bindEvents();
973
978
  }
@@ -975,7 +980,7 @@ class Bt {
975
980
  * Создание DOM-элемента индикатора
976
981
  */
977
982
  _createDOM() {
978
- this.el = document.createElement("div"), this.el.className = os, Object.entries(ns).forEach(([t, e]) => {
983
+ this.el = document.createElement("div"), this.el.className = is, Object.entries(as).forEach(([t, e]) => {
979
984
  this.el.style.setProperty(t, e);
980
985
  }), this.canvas.wrapperEl.appendChild(this.el);
981
986
  }
@@ -995,7 +1000,7 @@ class Bt {
995
1000
  return;
996
1001
  }
997
1002
  const s = e.angle || 0;
998
- this.currentAngle = Bt._normalizeAngle(s), this.el.textContent = `${this.currentAngle}°`, this._positionIndicator(t.e), this.isActive || this._showIndicator();
1003
+ this.currentAngle = _t._normalizeAngle(s), this.el.textContent = `${this.currentAngle}°`, this._positionIndicator(t.e), this.isActive || this._showIndicator();
999
1004
  }
1000
1005
  /**
1001
1006
  * Обработчик отпускания кнопки мыши
@@ -1026,9 +1031,9 @@ class Bt {
1026
1031
  */
1027
1032
  _positionIndicator(t) {
1028
1033
  const e = this.canvas.wrapperEl.getBoundingClientRect();
1029
- let s = t.clientX - e.left + be, n = t.clientY - e.top + ve;
1034
+ let s = t.clientX - e.left + je, n = t.clientY - e.top + Ie;
1030
1035
  const o = this.el.getBoundingClientRect(), a = o.width, i = o.height;
1031
- s + a > e.width && (s = t.clientX - e.left - a - be), n + i > e.height && (n = t.clientY - e.top - i - ve), this.el.style.left = `${s}px`, this.el.style.top = `${n}px`;
1036
+ s + a > e.width && (s = t.clientX - e.left - a - je), n + i > e.height && (n = t.clientY - e.top - i - Ie), this.el.style.left = `${s}px`, this.el.style.top = `${n}px`;
1032
1037
  }
1033
1038
  /**
1034
1039
  * Показать индикатор
@@ -1059,7 +1064,7 @@ class Bt {
1059
1064
  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;
1060
1065
  }
1061
1066
  }
1062
- const as = [
1067
+ const rs = [
1063
1068
  "selectable",
1064
1069
  "evented",
1065
1070
  "id",
@@ -1076,9 +1081,11 @@ const as = [
1076
1081
  "lockScalingX",
1077
1082
  "lockScalingY",
1078
1083
  "lockSkewingX",
1079
- "lockSkewingY"
1084
+ "lockSkewingY",
1085
+ "textCaseRaw",
1086
+ "uppercase"
1080
1087
  ];
1081
- class jt {
1088
+ class It {
1082
1089
  constructor({ editor: t }) {
1083
1090
  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();
1084
1091
  }
@@ -1090,7 +1097,7 @@ class jt {
1090
1097
  return this.patches[this.currentIndex - 1] || null;
1091
1098
  }
1092
1099
  _createDiffPatcher() {
1093
- this.diffPatcher = Be({
1100
+ this.diffPatcher = Re({
1094
1101
  objectHash(t) {
1095
1102
  const e = t, s = t;
1096
1103
  return [
@@ -1109,6 +1116,7 @@ class jt {
1109
1116
  e.scaleY,
1110
1117
  e.angle,
1111
1118
  e.opacity,
1119
+ s.text,
1112
1120
  s.textCaseRaw,
1113
1121
  s.uppercase,
1114
1122
  s.underline,
@@ -1125,7 +1133,7 @@ class jt {
1125
1133
  includeValueOnMove: !1
1126
1134
  },
1127
1135
  textDiff: {
1128
- diffMatchPatch: _e,
1136
+ diffMatchPatch: Ue,
1129
1137
  minLength: 60
1130
1138
  }
1131
1139
  });
@@ -1166,7 +1174,7 @@ class jt {
1166
1174
  saveState() {
1167
1175
  if (console.log("saveState"), this.skipHistory) return;
1168
1176
  console.time("saveState");
1169
- const t = this.canvas.toDatalessObject([...as]);
1177
+ const t = this.canvas.toDatalessObject([...rs]);
1170
1178
  if (console.timeEnd("saveState"), !this.baseState) {
1171
1179
  this.baseState = t, this.patches = [], this.currentIndex = 0, console.log("Базовое состояние сохранено.");
1172
1180
  return;
@@ -1176,7 +1184,7 @@ class jt {
1176
1184
  console.log("Нет изменений для сохранения.");
1177
1185
  return;
1178
1186
  }
1179
- 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: N(), 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);
1187
+ 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: x(), 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);
1180
1188
  }
1181
1189
  /**
1182
1190
  * Сериализует customData объектов в строку. Это необходимо чтобы при вызове loadFromJSON fabricjs не пытался обрабатывать свойства внутри customData, как свойства FabricObject, если их названия совпадают с зарезервированными.
@@ -1213,14 +1221,14 @@ class jt {
1213
1221
  if (!t) return;
1214
1222
  console.log("loadStateFromFullState fullState", t);
1215
1223
  const { canvas: e, canvasManager: s, interactionBlocker: n, backgroundManager: o } = this.editor, { width: a, height: i } = e;
1216
- n.overlayMask = null, jt._serializeCustomData(t), yield e.loadFromJSON(t, (h, u) => {
1217
- jt._deserializeCustomData(h, u);
1224
+ n.overlayMask = null, It._serializeCustomData(t), yield e.loadFromJSON(t, (l, u) => {
1225
+ It._deserializeCustomData(l, u);
1218
1226
  });
1219
- const r = e.getObjects().find((h) => h.id === "montage-area");
1227
+ const r = e.getObjects().find((l) => l.id === "montage-area");
1220
1228
  r && (this.editor.montageArea = r, (a !== e.getWidth() || i !== e.getHeight()) && s.updateCanvas());
1221
- const c = e.getObjects().find((h) => h.id === "overlay-mask");
1229
+ const c = e.getObjects().find((l) => l.id === "overlay-mask");
1222
1230
  c && (n.overlayMask = c, n.overlayMask.visible = !1);
1223
- const d = e.getObjects().find((h) => h.id === "background");
1231
+ const d = e.getObjects().find((l) => l.id === "background");
1224
1232
  d ? (o.backgroundObject = d, o.refresh()) : o.removeBackground({ withoutSave: !0 }), e.renderAll(), e.fire("editor:history-state-loaded", {
1225
1233
  fullState: t,
1226
1234
  currentIndex: this.currentIndex,
@@ -1306,7 +1314,7 @@ class jt {
1306
1314
  });
1307
1315
  }
1308
1316
  }
1309
- const is = 0.1, rs = 2, je = 0.1, cs = 90, J = 16, q = 16, P = 4096, V = 4096, Ie = "application/image-editor:";
1317
+ const cs = 0.1, ds = 2, Ae = 0.1, ls = 90, J = 16, q = 16, P = 4096, V = 4096, Ce = "application/image-editor:", yt = ["format", "uppercase", "textCaseRaw"], hs = 50;
1310
1318
  class H {
1311
1319
  constructor({ editor: t }) {
1312
1320
  this.editor = t, this.options = t.options, this._createdBlobUrls = [], this.acceptContentTypes = this.editor.options.acceptContentTypes, this.acceptFormats = this.getAllowedFormatsFromContentTypes();
@@ -1334,7 +1342,7 @@ class H {
1334
1342
  withoutSelection: i = !1
1335
1343
  } = t;
1336
1344
  if (!e) return null;
1337
- const { canvas: r, montageArea: c, transformManager: d, historyManager: h, errorManager: u } = this.editor, g = yield this.getContentType(e), f = H.getFormatFromContentType(g), { acceptContentTypes: m, acceptFormats: y } = this;
1345
+ const { canvas: r, montageArea: c, transformManager: d, historyManager: l, errorManager: u } = this.editor, g = yield this.getContentType(e), f = H.getFormatFromContentType(g), { acceptContentTypes: m, acceptFormats: b } = this;
1338
1346
  if (!this.isAllowedContentType(g)) {
1339
1347
  const p = `Неверный contentType для изображения: ${g}. Ожидается один из: ${this.acceptContentTypes.join(", ")}.`;
1340
1348
  return u.emitError({
@@ -1347,21 +1355,21 @@ class H {
1347
1355
  format: f,
1348
1356
  contentType: g,
1349
1357
  acceptContentTypes: m,
1350
- acceptFormats: y,
1358
+ acceptFormats: b,
1351
1359
  fromClipboard: o,
1352
1360
  isBackground: a,
1353
1361
  withoutSelection: i
1354
1362
  }
1355
1363
  }), null;
1356
1364
  }
1357
- h.suspendHistory();
1365
+ l.suspendHistory();
1358
1366
  try {
1359
1367
  let p, M;
1360
1368
  if (e instanceof File)
1361
1369
  p = URL.createObjectURL(e);
1362
1370
  else if (typeof e == "string") {
1363
- const j = yield (yield fetch(e, { mode: "cors" })).blob();
1364
- p = URL.createObjectURL(j);
1371
+ const A = yield (yield fetch(e, { mode: "cors" })).blob();
1372
+ p = URL.createObjectURL(A);
1365
1373
  } else
1366
1374
  return u.emitError({
1367
1375
  origin: "ImageManager",
@@ -1373,37 +1381,37 @@ class H {
1373
1381
  format: f,
1374
1382
  contentType: g,
1375
1383
  acceptContentTypes: m,
1376
- acceptFormats: y,
1384
+ acceptFormats: b,
1377
1385
  fromClipboard: o,
1378
1386
  isBackground: a,
1379
1387
  withoutSelection: i
1380
1388
  }
1381
1389
  }), null;
1382
1390
  if (this._createdBlobUrls.push(p), f === "svg") {
1383
- const A = yield Ee(p);
1384
- M = mt.groupSVGElements(A.objects, A.options);
1391
+ const y = yield Ne(p);
1392
+ M = mt.groupSVGElements(y.objects, y.options);
1385
1393
  } else
1386
1394
  M = yield ht.fromURL(p, { crossOrigin: "anonymous" });
1387
- const { width: S, height: E } = M;
1395
+ const { width: S, height: O } = M;
1388
1396
  if (M instanceof ht) {
1389
- const A = M.getElement();
1390
- let j = "";
1391
- if (A instanceof HTMLImageElement ? j = A.src : A instanceof HTMLCanvasElement && (j = A.toDataURL()), E > V || S > P) {
1392
- const L = yield this.resizeImageToBoundaries(j, "max"), w = URL.createObjectURL(L);
1393
- this._createdBlobUrls.push(w), M = yield ht.fromURL(w, { crossOrigin: "anonymous" });
1394
- } else if (E < q || S < J) {
1395
- const L = yield this.resizeImageToBoundaries(j, "min"), w = URL.createObjectURL(L);
1396
- this._createdBlobUrls.push(w), M = yield ht.fromURL(w, { crossOrigin: "anonymous" });
1397
+ const y = M.getElement();
1398
+ let A = "";
1399
+ if (y instanceof HTMLImageElement ? A = y.src : y instanceof HTMLCanvasElement && (A = y.toDataURL()), O > V || S > P) {
1400
+ const N = yield this.resizeImageToBoundaries(A, "max"), I = URL.createObjectURL(N);
1401
+ this._createdBlobUrls.push(I), M = yield ht.fromURL(I, { crossOrigin: "anonymous" });
1402
+ } else if (O < q || S < J) {
1403
+ const N = yield this.resizeImageToBoundaries(A, "min"), I = URL.createObjectURL(N);
1404
+ this._createdBlobUrls.push(I), M = yield ht.fromURL(I, { crossOrigin: "anonymous" });
1397
1405
  }
1398
1406
  }
1399
- if (M.set("id", `${M.type}-${N()}`), M.set("format", f), s === "scale-montage")
1407
+ if (M.set("id", `${M.type}-${x()}`), M.set("format", f), s === "scale-montage")
1400
1408
  this.editor.canvasManager.scaleMontageAreaToImage({ object: M, withoutSave: !0 });
1401
1409
  else {
1402
- const { width: A, height: j } = c, L = this.calculateScaleFactor({ imageObject: M, scaleType: s });
1403
- s === "image-contain" && L < 1 ? d.fitObject({ object: M, type: "contain", withoutSave: !0 }) : s === "image-cover" && (S > A || E > j) && d.fitObject({ object: M, type: "cover", withoutSave: !0 });
1410
+ const { width: y, height: A } = c, N = this.calculateScaleFactor({ imageObject: M, scaleType: s });
1411
+ s === "image-contain" && N < 1 ? d.fitObject({ object: M, type: "contain", withoutSave: !0 }) : s === "image-cover" && (S > y || O > A) && d.fitObject({ object: M, type: "cover", withoutSave: !0 });
1404
1412
  }
1405
- r.add(M), r.centerObject(M), i || r.setActiveObject(M), r.renderAll(), h.resumeHistory(), n || h.saveState();
1406
- const v = {
1413
+ r.add(M), r.centerObject(M), i || r.setActiveObject(M), r.renderAll(), l.resumeHistory(), n || l.saveState();
1414
+ const T = {
1407
1415
  image: M,
1408
1416
  format: f,
1409
1417
  contentType: g,
@@ -1414,7 +1422,7 @@ class H {
1414
1422
  isBackground: a,
1415
1423
  withoutSelection: i
1416
1424
  };
1417
- return r.fire("editor:image-imported", v), v;
1425
+ return r.fire("editor:image-imported", T), T;
1418
1426
  } catch (p) {
1419
1427
  return u.emitError({
1420
1428
  origin: "ImageManager",
@@ -1431,7 +1439,7 @@ class H {
1431
1439
  isBackground: a,
1432
1440
  withoutSelection: i
1433
1441
  }
1434
- }), h.resumeHistory(), null;
1442
+ }), l.resumeHistory(), null;
1435
1443
  }
1436
1444
  });
1437
1445
  }
@@ -1484,22 +1492,22 @@ class H {
1484
1492
  exportAsBlob: o = !1
1485
1493
  } = t, { canvas: a, montageArea: i, workerManager: r, interactionBlocker: c } = this.editor;
1486
1494
  try {
1487
- const d = s === "application/pdf", h = d ? "image/jpg" : s, u = H.getFormatFromContentType(h);
1495
+ const d = s === "application/pdf", l = d ? "image/jpg" : s, u = H.getFormatFromContentType(l);
1488
1496
  i.setCoords();
1489
- const { left: g, top: f, width: m, height: y } = i.getBoundingRect(), p = yield a.clone(["id", "format", "locked"]);
1490
- p.enableRetinaScaling = !1, ["image/jpg", "image/jpeg"].includes(h) && (p.backgroundColor = "#ffffff");
1491
- const M = p.getObjects().find((b) => b.id === i.id);
1497
+ const { left: g, top: f, width: m, height: b } = i.getBoundingRect(), p = yield a.clone(["id", "format", "locked"]);
1498
+ p.enableRetinaScaling = !1, ["image/jpg", "image/jpeg"].includes(l) && (p.backgroundColor = "#ffffff");
1499
+ const M = p.getObjects().find((v) => v.id === i.id);
1492
1500
  if (M && (M.visible = !1), c != null && c.isBlocked) {
1493
- const b = p.getObjects().find((T) => T.id === c.overlayMask.id);
1494
- b && (b.visible = !1);
1501
+ const v = p.getObjects().find((w) => w.id === c.overlayMask.id);
1502
+ v && (v.visible = !1);
1495
1503
  }
1496
- p.viewportTransform = [1, 0, 0, 1, -g, -f], p.setDimensions({ width: m, height: y }, { backstoreOnly: !0 }), p.renderAll();
1497
- const S = p.getObjects().filter((b) => b.format).every((b) => b.format === "svg");
1504
+ p.viewportTransform = [1, 0, 0, 1, -g, -f], p.setDimensions({ width: m, height: b }, { backstoreOnly: !0 }), p.renderAll();
1505
+ const S = p.getObjects().filter((v) => v.format).every((v) => v.format === "svg");
1498
1506
  if (u === "svg" && S) {
1499
- const b = p.toSVG();
1507
+ const v = p.toSVG();
1500
1508
  p.dispose();
1501
- const k = {
1502
- image: H._exportSVGStringAsFile(b, {
1509
+ const L = {
1510
+ image: H._exportSVGStringAsFile(v, {
1503
1511
  exportAsBase64: n,
1504
1512
  exportAsBlob: o,
1505
1513
  fileName: e
@@ -1508,34 +1516,34 @@ class H {
1508
1516
  contentType: "image/svg+xml",
1509
1517
  fileName: e.replace(/\.[^/.]+$/, ".svg")
1510
1518
  };
1511
- return a.fire("editor:canvas-exported", k), k;
1519
+ return a.fire("editor:canvas-exported", L), L;
1512
1520
  }
1513
- const E = yield new Promise((b, T) => {
1514
- p.getElement().toBlob((k) => {
1515
- k ? b(k) : T(new Error("Failed to create Blob from canvas"));
1521
+ const O = yield new Promise((v, w) => {
1522
+ p.getElement().toBlob((L) => {
1523
+ L ? v(L) : w(new Error("Failed to create Blob from canvas"));
1516
1524
  });
1517
1525
  });
1518
1526
  if (p.dispose(), o) {
1519
- const b = {
1520
- image: E,
1527
+ const v = {
1528
+ image: O,
1521
1529
  format: u,
1522
- contentType: h,
1530
+ contentType: l,
1523
1531
  fileName: e
1524
1532
  };
1525
- return a.fire("editor:canvas-exported", b), b;
1533
+ return a.fire("editor:canvas-exported", v), v;
1526
1534
  }
1527
- const v = yield createImageBitmap(E), A = yield r.post(
1535
+ const T = yield createImageBitmap(O), y = yield r.post(
1528
1536
  "toDataURL",
1529
- { format: u, quality: 1, bitmap: v },
1530
- [v]
1537
+ { format: u, quality: 1, bitmap: T },
1538
+ [T]
1531
1539
  );
1532
1540
  if (d) {
1533
- const T = m * 0.264583, k = y * 0.264583, x = (yield this.editor.moduleLoader.loadModule("jspdf")).jsPDF, Y = new x({
1534
- orientation: T > k ? "landscape" : "portrait",
1541
+ const w = m * 0.264583, L = b * 0.264583, B = (yield this.editor.moduleLoader.loadModule("jspdf")).jsPDF, Y = new B({
1542
+ orientation: w > L ? "landscape" : "portrait",
1535
1543
  unit: "mm",
1536
- format: [T, k]
1544
+ format: [w, L]
1537
1545
  });
1538
- if (Y.addImage(String(A), "JPG", 0, 0, T, k), n) {
1546
+ if (Y.addImage(String(y), "JPG", 0, 0, w, L), n) {
1539
1547
  const W = {
1540
1548
  image: Y.output("datauristring"),
1541
1549
  format: "pdf",
@@ -1553,21 +1561,21 @@ class H {
1553
1561
  return a.fire("editor:canvas-exported", Z), Z;
1554
1562
  }
1555
1563
  if (n) {
1556
- const b = {
1557
- image: A,
1564
+ const v = {
1565
+ image: y,
1558
1566
  format: u,
1559
- contentType: h,
1567
+ contentType: l,
1560
1568
  fileName: e
1561
1569
  };
1562
- return a.fire("editor:canvas-exported", b), b;
1570
+ return a.fire("editor:canvas-exported", v), v;
1563
1571
  }
1564
- const j = u === "svg" && !S ? e.replace(/\.[^/.]+$/, ".png") : e, w = {
1565
- image: new File([E], j, { type: h }),
1572
+ const A = u === "svg" && !S ? e.replace(/\.[^/.]+$/, ".png") : e, I = {
1573
+ image: new File([O], A, { type: l }),
1566
1574
  format: u,
1567
- contentType: h,
1568
- fileName: j
1575
+ contentType: l,
1576
+ fileName: A
1569
1577
  };
1570
- return a.fire("editor:canvas-exported", w), w;
1578
+ return a.fire("editor:canvas-exported", I), I;
1571
1579
  } catch (d) {
1572
1580
  return this.editor.errorManager.emitError({
1573
1581
  origin: "ImageManager",
@@ -1610,13 +1618,13 @@ class H {
1610
1618
  try {
1611
1619
  const d = H.getFormatFromContentType(n);
1612
1620
  if (d === "svg") {
1613
- const m = c.toSVG(), y = H._exportSVGStringAsFile(m, {
1621
+ const m = c.toSVG(), b = H._exportSVGStringAsFile(m, {
1614
1622
  exportAsBase64: o,
1615
1623
  exportAsBlob: a,
1616
1624
  fileName: s
1617
1625
  }), p = {
1618
1626
  object: c,
1619
- image: y,
1627
+ image: b,
1620
1628
  format: d,
1621
1629
  contentType: "image/svg+xml",
1622
1630
  fileName: s.replace(/\.[^/.]+$/, ".svg")
@@ -1624,7 +1632,7 @@ class H {
1624
1632
  return i.fire("editor:object-exported", p), p;
1625
1633
  }
1626
1634
  if (o && c instanceof ht) {
1627
- const m = yield createImageBitmap(c.getElement()), y = yield r.post(
1635
+ const m = yield createImageBitmap(c.getElement()), b = yield r.post(
1628
1636
  "toDataURL",
1629
1637
  {
1630
1638
  format: d,
@@ -1634,18 +1642,18 @@ class H {
1634
1642
  [m]
1635
1643
  ), p = {
1636
1644
  object: c,
1637
- image: y,
1645
+ image: b,
1638
1646
  format: d,
1639
1647
  contentType: n,
1640
1648
  fileName: s
1641
1649
  };
1642
1650
  return i.fire("editor:object-exported", p), p;
1643
1651
  }
1644
- const h = c.toCanvasElement({
1652
+ const l = c.toCanvasElement({
1645
1653
  enableRetinaScaling: !1
1646
- }), u = yield new Promise((m, y) => {
1647
- h.toBlob((p) => {
1648
- p ? m(p) : y(new Error("Failed to create Blob from canvas"));
1654
+ }), u = yield new Promise((m, b) => {
1655
+ l.toBlob((p) => {
1656
+ p ? m(p) : b(new Error("Failed to create Blob from canvas"));
1649
1657
  });
1650
1658
  });
1651
1659
  if (a) {
@@ -1794,11 +1802,11 @@ class H {
1794
1802
  return e ? e[1] : "";
1795
1803
  }
1796
1804
  }
1797
- const K = (l, t, e) => Math.max(Math.min(l, e), t), Ae = (l, t) => l * t, ds = (l, t) => new yt(l / 2, t / 2);
1798
- function ls(l) {
1799
- return ((l == null ? void 0 : l.type) === "image" || (l == null ? void 0 : l.format) === "svg") && typeof (l == null ? void 0 : l.width) == "number" && typeof (l == null ? void 0 : l.height) == "number";
1805
+ const K = (h, t, e) => Math.max(Math.min(h, e), t), Se = (h, t) => h * t, us = (h, t) => new bt(h / 2, t / 2);
1806
+ function gs(h) {
1807
+ 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";
1800
1808
  }
1801
- class hs {
1809
+ class fs {
1802
1810
  /**
1803
1811
  * @param options
1804
1812
  * @param options.editor – экземпляр редактора
@@ -1831,12 +1839,12 @@ class hs {
1831
1839
  options: { canvasBackstoreWidth: i }
1832
1840
  } = this.editor, { width: r, height: c } = a, d = K(Number(t), J, P);
1833
1841
  if (!i || i === "auto" || n ? this.adaptCanvasToContainer() : i ? this.setCanvasBackstoreWidth(Number(i)) : this.setCanvasBackstoreWidth(d), a.set({ width: d }), (f = o.clipPath) == null || f.set({ width: d }), e) {
1834
- const m = d / r, y = Ae(c, m);
1835
- this.setResolutionHeight(y);
1842
+ const m = d / r, b = Se(c, m);
1843
+ this.setResolutionHeight(b);
1836
1844
  return;
1837
1845
  }
1838
- const { left: h, top: u } = this.getObjectDefaultCoords(a), g = o.getZoom();
1839
- o.setViewportTransform([g, 0, 0, g, h, u]), this.centerMontageArea(), s || this.editor.historyManager.saveState(), o.fire("editor:resolution-width-changed", {
1846
+ const { left: l, top: u } = this.getObjectDefaultCoords(a), g = o.getZoom();
1847
+ o.setViewportTransform([g, 0, 0, g, l, u]), this.centerMontageArea(), s || this.editor.historyManager.saveState(), o.fire("editor:resolution-width-changed", {
1840
1848
  width: d,
1841
1849
  preserveProportional: e,
1842
1850
  withoutSave: s,
@@ -1861,12 +1869,12 @@ class hs {
1861
1869
  options: { canvasBackstoreHeight: i }
1862
1870
  } = this.editor, { width: r, height: c } = a, d = K(Number(t), q, V);
1863
1871
  if (!i || i === "auto" || n ? this.adaptCanvasToContainer() : i ? this.setCanvasBackstoreHeight(Number(i)) : this.setCanvasBackstoreHeight(d), a.set({ height: d }), (f = o.clipPath) == null || f.set({ height: d }), e) {
1864
- const m = d / c, y = Ae(r, m);
1865
- this.setResolutionWidth(y);
1872
+ const m = d / c, b = Se(r, m);
1873
+ this.setResolutionWidth(b);
1866
1874
  return;
1867
1875
  }
1868
- const { left: h, top: u } = this.getObjectDefaultCoords(a), g = o.getZoom();
1869
- o.setViewportTransform([g, 0, 0, g, h, u]), this.centerMontageArea(), s || this.editor.historyManager.saveState(), o.fire("editor:resolution-height-changed", {
1876
+ const { left: l, top: u } = this.getObjectDefaultCoords(a), g = o.getZoom();
1877
+ o.setViewportTransform([g, 0, 0, g, l, u]), this.centerMontageArea(), s || this.editor.historyManager.saveState(), o.fire("editor:resolution-height-changed", {
1870
1878
  height: d,
1871
1879
  preserveProportional: e,
1872
1880
  withoutSave: s,
@@ -1879,7 +1887,7 @@ class hs {
1879
1887
  */
1880
1888
  centerMontageArea() {
1881
1889
  var r;
1882
- const { canvas: t, montageArea: e } = this.editor, s = t.getWidth(), n = t.getHeight(), o = t.getZoom(), a = ds(s, n);
1890
+ const { canvas: t, montageArea: e } = this.editor, s = t.getWidth(), n = t.getHeight(), o = t.getZoom(), a = us(s, n);
1883
1891
  e.set({
1884
1892
  left: s / 2,
1885
1893
  top: n / 2
@@ -1952,22 +1960,22 @@ class hs {
1952
1960
  if (i !== 0 || r !== 0) {
1953
1961
  const c = t.getActiveObject(), d = [];
1954
1962
  if ((c == null ? void 0 : c.type) === "activeselection") {
1955
- const h = c;
1956
- d.push(...h.getObjects()), t.discardActiveObject();
1963
+ const l = c;
1964
+ d.push(...l.getObjects()), t.discardActiveObject();
1957
1965
  }
1958
- if (t.getObjects().forEach((h) => {
1959
- h.id === "montage-area" || h.id === "overlay-mask" || h.id === "background" || (h.set({
1960
- left: h.left + i,
1961
- top: h.top + r
1962
- }), h.setCoords());
1966
+ if (t.getObjects().forEach((l) => {
1967
+ l.id === "montage-area" || l.id === "overlay-mask" || l.id === "background" || (l.set({
1968
+ left: l.left + i,
1969
+ top: l.top + r
1970
+ }), l.setCoords());
1963
1971
  }), d.length > 0)
1964
1972
  if (d.length === 1)
1965
1973
  t.setActiveObject(d[0]);
1966
1974
  else {
1967
- const h = new O(d, {
1975
+ const l = new D(d, {
1968
1976
  canvas: t
1969
1977
  });
1970
- t.setActiveObject(h);
1978
+ t.setActiveObject(l);
1971
1979
  }
1972
1980
  }
1973
1981
  t.renderAll(), t.fire("editor:canvas-updated", {
@@ -2130,17 +2138,17 @@ class hs {
2130
2138
  montageAreaHeight: r
2131
2139
  }
2132
2140
  } = this.editor, c = t || n.getActiveObject();
2133
- if (!ls(c)) return;
2134
- const { width: d, height: h } = c;
2135
- let u = Math.min(d, P), g = Math.min(h, V);
2141
+ if (!gs(c)) return;
2142
+ const { width: d, height: l } = c;
2143
+ let u = Math.min(d, P), g = Math.min(l, V);
2136
2144
  if (e) {
2137
2145
  const {
2138
2146
  width: f,
2139
2147
  height: m
2140
- } = o, y = d / f, p = h / m, M = Math.max(y, p);
2148
+ } = o, b = d / f, p = l / m, M = Math.max(b, p);
2141
2149
  u = f * M, g = m * M;
2142
2150
  }
2143
- this.setResolutionWidth(u, { withoutSave: !0 }), this.setResolutionHeight(g, { withoutSave: !0 }), this.editor.backgroundManager.backgroundObject && this.editor.backgroundManager.refresh(), (d > i || h > r) && this.editor.zoomManager.calculateAndApplyDefaultZoom(), a.resetObject({ object: c, withoutSave: !0 }), n.centerObject(c), n.renderAll(), s || this.editor.historyManager.saveState(), n.fire("editor:montage-area-scaled-to-image", {
2151
+ this.setResolutionWidth(u, { withoutSave: !0 }), this.setResolutionHeight(g, { withoutSave: !0 }), this.editor.backgroundManager.backgroundObject && this.editor.backgroundManager.refresh(), (d > i || l > r) && this.editor.zoomManager.calculateAndApplyDefaultZoom(), a.resetObject({ object: c, withoutSave: !0 }), n.centerObject(c), n.renderAll(), s || this.editor.historyManager.saveState(), n.fire("editor:montage-area-scaled-to-image", {
2144
2152
  object: c,
2145
2153
  width: u,
2146
2154
  height: g,
@@ -2190,7 +2198,7 @@ class hs {
2190
2198
  );
2191
2199
  }
2192
2200
  }
2193
- class us {
2201
+ class ms {
2194
2202
  constructor({ editor: t }) {
2195
2203
  this.editor = t, this.options = t.options;
2196
2204
  }
@@ -2201,7 +2209,7 @@ class us {
2201
2209
  * @param options.withoutSave - Не сохранять состояние
2202
2210
  * @fires editor:object-rotated
2203
2211
  */
2204
- rotate(t = cs, { withoutSave: e } = {}) {
2212
+ rotate(t = ls, { withoutSave: e } = {}) {
2205
2213
  const { canvas: s, historyManager: n } = this.editor, o = s.getActiveObject();
2206
2214
  if (!o) return;
2207
2215
  const a = o.angle + t;
@@ -2251,7 +2259,7 @@ class us {
2251
2259
  withoutSave: s
2252
2260
  } = {}) {
2253
2261
  const { canvas: n, historyManager: o } = this.editor, a = t || n.getActiveObject();
2254
- a && (a instanceof O ? a.getObjects().forEach((i) => {
2262
+ a && (a instanceof D ? a.getObjects().forEach((i) => {
2255
2263
  i.set("opacity", e);
2256
2264
  }) : a.set("opacity", e), n.renderAll(), s || o.saveState(), n.fire("editor:object-opacity-changed", {
2257
2265
  object: a,
@@ -2278,12 +2286,12 @@ class us {
2278
2286
  } = {}) {
2279
2287
  const { canvas: o, historyManager: a } = this.editor, i = t || o.getActiveObject();
2280
2288
  if (i) {
2281
- if (i instanceof O && !n) {
2289
+ if (i instanceof D && !n) {
2282
2290
  const r = i.getObjects();
2283
2291
  o.discardActiveObject(), r.forEach((d) => {
2284
2292
  this._fitSingleObject(d, e);
2285
2293
  });
2286
- const c = new O(r, { canvas: o });
2294
+ const c = new D(r, { canvas: o });
2287
2295
  o.setActiveObject(c);
2288
2296
  } else
2289
2297
  this._fitSingleObject(i, e);
@@ -2302,9 +2310,9 @@ class us {
2302
2310
  * @private
2303
2311
  */
2304
2312
  _fitSingleObject(t, e) {
2305
- const { canvas: s, montageArea: n } = this.editor, { width: o, height: a, scaleX: i = 1, scaleY: r = 1, angle: c = 0 } = t, d = o * Math.abs(i), h = a * Math.abs(r), u = c * Math.PI / 180, g = Math.abs(Math.cos(u)), f = Math.abs(Math.sin(u)), m = d * g + h * f, y = d * f + h * g, p = n.width, M = n.height;
2313
+ const { canvas: s, montageArea: n } = this.editor, { width: o, height: a, scaleX: i = 1, scaleY: r = 1, angle: c = 0 } = t, d = o * Math.abs(i), l = a * Math.abs(r), u = c * Math.PI / 180, g = Math.abs(Math.cos(u)), f = Math.abs(Math.sin(u)), m = d * g + l * f, b = d * f + l * g, p = n.width, M = n.height;
2306
2314
  let S;
2307
- e === "contain" ? S = Math.min(p / m, M / y) : S = Math.max(p / m, M / y), t.set({
2315
+ e === "contain" ? S = Math.min(p / m, M / b) : S = Math.max(p / m, M / b), t.set({
2308
2316
  scaleX: i * S,
2309
2317
  scaleY: r * S
2310
2318
  }), s.centerObject(t);
@@ -2343,11 +2351,11 @@ class us {
2343
2351
  }), e)
2344
2352
  this.fitObject({ object: c, withoutSave: !0, fitAsOneObject: !0 });
2345
2353
  else {
2346
- const { width: h, height: u } = o, { width: g, height: f } = c, m = a.calculateScaleFactor({
2354
+ const { width: l, height: u } = o, { width: g, height: f } = c, m = a.calculateScaleFactor({
2347
2355
  imageObject: c,
2348
2356
  scaleType: r
2349
2357
  });
2350
- r === "contain" && m < 1 || r === "cover" && (g > h || f > u) ? this.fitObject({ object: c, withoutSave: !0, fitAsOneObject: !0 }) : c.set({ scaleX: 1, scaleY: 1 });
2358
+ r === "contain" && m < 1 || r === "cover" && (g > l || f > u) ? this.fitObject({ object: c, withoutSave: !0, fitAsOneObject: !0 }) : c.set({ scaleX: 1, scaleY: 1 });
2351
2359
  }
2352
2360
  c.set({ flipX: !1, flipY: !1, angle: 0 }), n.centerObject(c), n.renderAll(), i.resumeHistory(), s || i.saveState(), n.fire("editor:object-reset", {
2353
2361
  object: c,
@@ -2356,9 +2364,9 @@ class us {
2356
2364
  });
2357
2365
  }
2358
2366
  }
2359
- class gs {
2367
+ class ps {
2360
2368
  constructor({ editor: t }) {
2361
- this.editor = t, this.options = t.options, this.minZoom = this.options.minZoom || is, this.maxZoom = this.options.maxZoom || rs, this.defaultZoom = this.options.defaultScale;
2369
+ this.editor = t, this.options = t.options, this.minZoom = this.options.minZoom || cs, this.maxZoom = this.options.maxZoom || ds, this.defaultZoom = this.options.defaultScale;
2362
2370
  }
2363
2371
  /**
2364
2372
  * Вспомогательный метод для вычисления размеров масштабированной монтажной области
@@ -2380,10 +2388,10 @@ class gs {
2380
2388
  * @private
2381
2389
  */
2382
2390
  _getClampedPointerCoordinates(t) {
2383
- const { canvas: e, montageArea: s } = this.editor, n = e.getPointer(t, !0), o = e.viewportTransform, a = e.getZoom(), i = s.left - s.width / 2, r = s.left + s.width / 2, c = s.top - s.height / 2, d = s.top + s.height / 2, h = i * a + o[4], u = r * a + o[4], g = c * a + o[5], f = d * a + o[5], m = Math.max(h, Math.min(u, n.x)), y = Math.max(g, Math.min(f, n.y));
2391
+ const { canvas: e, montageArea: s } = this.editor, n = e.getPointer(t, !0), o = e.viewportTransform, a = e.getZoom(), i = s.left - s.width / 2, r = s.left + s.width / 2, c = s.top - s.height / 2, d = s.top + s.height / 2, l = i * a + o[4], u = r * a + o[4], g = c * a + o[5], f = d * a + o[5], m = Math.max(l, Math.min(u, n.x)), b = Math.max(g, Math.min(f, n.y));
2384
2392
  return {
2385
2393
  x: m,
2386
- y
2394
+ y: b
2387
2395
  };
2388
2396
  }
2389
2397
  /**
@@ -2415,10 +2423,10 @@ class gs {
2415
2423
  * @private
2416
2424
  */
2417
2425
  _calculateEmptySpaceRatio(t) {
2418
- const { canvas: e, montageArea: s } = this.editor, n = e.viewportTransform, o = e.getWidth(), a = e.getHeight(), i = s.left - s.width / 2, r = s.left + s.width / 2, c = s.top - s.height / 2, d = s.top + s.height / 2, h = -n[4] / t, u = (-n[4] + o) / t, g = -n[5] / t, f = (-n[5] + a) / t, m = h < i, y = u > r, p = g < c, M = f > d;
2419
- if (!(m || y || p || M)) return 0;
2420
- const E = Math.max(0, i - h), v = Math.max(0, u - r), A = Math.max(0, c - g), j = Math.max(0, f - d), L = Math.max(E, v), w = Math.max(A, j), b = L / o, T = w / a;
2421
- return Math.max(b, T);
2426
+ const { canvas: e, montageArea: s } = this.editor, n = e.viewportTransform, o = e.getWidth(), a = e.getHeight(), i = s.left - s.width / 2, r = s.left + s.width / 2, c = s.top - s.height / 2, d = s.top + s.height / 2, l = -n[4] / t, u = (-n[4] + o) / t, g = -n[5] / t, f = (-n[5] + a) / t, m = l < i, b = u > r, p = g < c, M = f > d;
2427
+ if (!(m || b || p || M)) return 0;
2428
+ const O = Math.max(0, i - l), T = Math.max(0, u - r), y = Math.max(0, c - g), A = Math.max(0, f - d), N = Math.max(O, T), I = Math.max(y, A), v = N / o, w = I / a;
2429
+ return Math.max(v, w);
2422
2430
  }
2423
2431
  /**
2424
2432
  * Вычисляет плавный шаг перемещения viewport к центру с ускорением
@@ -2431,11 +2439,11 @@ class gs {
2431
2439
  * @private
2432
2440
  */
2433
2441
  _calculateSmoothCenteringStep(t, e, s, n, o) {
2434
- const { canvas: a, montageArea: i } = this.editor, r = a.viewportTransform, c = a.getWidth(), d = a.getHeight(), h = t.x - r[4], u = t.y - r[5], g = Math.abs(n), f = e - s;
2442
+ const { canvas: a, montageArea: i } = this.editor, r = a.viewportTransform, c = a.getWidth(), d = a.getHeight(), l = t.x - r[4], u = t.y - r[5], g = Math.abs(n), f = e - s;
2435
2443
  if (Math.abs(f) / g <= 0.1)
2436
- return { x: h, y: u };
2437
- const y = c / 2, p = d / 2, M = i.left, S = i.top, E = y - M * s, v = p - S * s, A = (E - r[4]) / (e - s), j = (v - r[5]) / (e - s), L = A * g, w = j * g, b = L * o, T = w * o, k = Math.abs(b) > Math.abs(h) ? h : b, x = Math.abs(T) > Math.abs(u) ? u : T;
2438
- return { x: k, y: x };
2444
+ return { x: l, y: u };
2445
+ const b = c / 2, p = d / 2, M = i.left, S = i.top, O = b - M * s, T = p - S * s, y = (O - r[4]) / (e - s), A = (T - r[5]) / (e - s), N = y * g, I = A * g, v = N * o, w = I * o, L = Math.abs(v) > Math.abs(l) ? l : v, B = Math.abs(w) > Math.abs(u) ? u : w;
2446
+ return { x: L, y: B };
2439
2447
  }
2440
2448
  /**
2441
2449
  * Применяет плавное центрирование viewport при приближении к defaultZoom.
@@ -2447,7 +2455,7 @@ class gs {
2447
2455
  * @returns true если центрирование было применено
2448
2456
  * @private
2449
2457
  */
2450
- _applyViewportCentering(t, e = !1, s = je) {
2458
+ _applyViewportCentering(t, e = !1, s = Ae) {
2451
2459
  const { canvas: n } = this.editor, o = this._getScaledMontageDimensions(t), a = n.getWidth(), i = n.getHeight(), r = o.width > a || o.height > i, c = this._calculateFitZoom(), d = t - c;
2452
2460
  if (!(!r || d) && !e)
2453
2461
  return !1;
@@ -2508,10 +2516,10 @@ class gs {
2508
2516
  });
2509
2517
  return;
2510
2518
  }
2511
- const h = this._getClampedPointerCoordinates(e);
2519
+ const l = this._getClampedPointerCoordinates(e);
2512
2520
  this.zoom(t, {
2513
- pointX: h.x,
2514
- pointY: h.y
2521
+ pointX: l.x,
2522
+ pointY: l.y
2515
2523
  });
2516
2524
  }
2517
2525
  /**
@@ -2522,16 +2530,16 @@ class gs {
2522
2530
  * @param options.pointY - Координата Y точки зума
2523
2531
  * @fires editor:zoom-changed
2524
2532
  */
2525
- zoom(t = je, e = {}) {
2533
+ zoom(t = Ae, e = {}) {
2526
2534
  var g, f;
2527
2535
  if (!t) return;
2528
- const { minZoom: s, maxZoom: n } = this, { canvas: o } = this.editor, a = t < 0, i = o.getZoom(), r = o.getCenterPoint(), c = (g = e.pointX) != null ? g : r.x, d = (f = e.pointY) != null ? f : r.y, h = new yt(c, d);
2536
+ const { minZoom: s, maxZoom: n } = this, { canvas: o } = this.editor, a = t < 0, i = o.getZoom(), r = o.getCenterPoint(), c = (g = e.pointX) != null ? g : r.x, d = (f = e.pointY) != null ? f : r.y, l = new bt(c, d);
2529
2537
  this.editor.montageArea.setCoords(), this.editor.canvas.requestRenderAll();
2530
2538
  let u = Number((i + Number(t)).toFixed(3));
2531
- u > n && (u = n), u < s && (u = s), o.zoomToPoint(h, u), this.editor.panConstraintManager.updateBounds(), this._applyViewportCentering(u, a, t), o.fire("editor:zoom-changed", {
2539
+ u > n && (u = n), u < s && (u = s), o.zoomToPoint(l, u), this.editor.panConstraintManager.updateBounds(), this._applyViewportCentering(u, a, t), o.fire("editor:zoom-changed", {
2532
2540
  currentZoom: o.getZoom(),
2533
2541
  zoom: u,
2534
- point: h
2542
+ point: l
2535
2543
  });
2536
2544
  }
2537
2545
  /**
@@ -2540,7 +2548,7 @@ class gs {
2540
2548
  * @fires editor:zoom-changed
2541
2549
  */
2542
2550
  setZoom(t = this.defaultZoom) {
2543
- const { minZoom: e, maxZoom: s } = this, { canvas: n } = this.editor, o = new yt(n.getCenterPoint());
2551
+ const { minZoom: e, maxZoom: s } = this, { canvas: n } = this.editor, o = new bt(n.getCenterPoint());
2544
2552
  let a = t;
2545
2553
  t > s && (a = s), t < e && (a = e), n.zoomToPoint(o, a), n.fire("editor:zoom-changed", {
2546
2554
  currentZoom: n.getZoom(),
@@ -2553,14 +2561,14 @@ class gs {
2553
2561
  * @fires editor:zoom-changed
2554
2562
  */
2555
2563
  resetZoom() {
2556
- const { canvas: t } = this.editor, e = new yt(t.getCenterPoint());
2564
+ const { canvas: t } = this.editor, e = new bt(t.getCenterPoint());
2557
2565
  t.zoomToPoint(e, this.defaultZoom), this.editor.canvas.fire("editor:zoom-changed", {
2558
2566
  currentZoom: t.getZoom(),
2559
2567
  point: e
2560
2568
  }), this.editor.panConstraintManager.updateBounds();
2561
2569
  }
2562
2570
  }
2563
- class fs {
2571
+ class Ms {
2564
2572
  constructor({ editor: t }) {
2565
2573
  this.editor = t, this.isBlocked = !1, this.overlayMask = null, this._createOverlay();
2566
2574
  }
@@ -2642,7 +2650,7 @@ class Q {
2642
2650
  }
2643
2651
  a.set({
2644
2652
  fill: t,
2645
- backgroundId: `background-${N()}`
2653
+ backgroundId: `background-${x()}`
2646
2654
  }), this.editor.canvas.requestRenderAll();
2647
2655
  } else
2648
2656
  this._removeCurrentBackground(), this._createColorBackground(t);
@@ -2679,7 +2687,7 @@ class Q {
2679
2687
  }
2680
2688
  a.set({
2681
2689
  fill: i,
2682
- backgroundId: `background-${N()}`
2690
+ backgroundId: `background-${x()}`
2683
2691
  }), this.editor.canvas.requestRenderAll();
2684
2692
  } else
2685
2693
  this._removeCurrentBackground(), this._createGradientBackground(t);
@@ -2826,7 +2834,7 @@ class Q {
2826
2834
  hasControls: !1,
2827
2835
  id: "background",
2828
2836
  backgroundType: "color",
2829
- backgroundId: `background-${N()}`
2837
+ backgroundId: `background-${x()}`
2830
2838
  }, { withoutSelection: !0 }), this.refresh();
2831
2839
  }
2832
2840
  /**
@@ -2843,7 +2851,7 @@ class Q {
2843
2851
  hasControls: !1,
2844
2852
  id: "background",
2845
2853
  backgroundType: "gradient",
2846
- backgroundId: `background-${N()}`
2854
+ backgroundId: `background-${x()}`
2847
2855
  }, { withoutSelection: !0 }), this.refresh();
2848
2856
  const e = Q._createFabricGradient(t);
2849
2857
  this.backgroundObject.set("fill", e), this.editor.canvas.requestRenderAll();
@@ -2871,7 +2879,7 @@ class Q {
2871
2879
  hasControls: !1,
2872
2880
  id: "background",
2873
2881
  backgroundType: "image",
2874
- backgroundId: `background-${N()}`,
2882
+ backgroundId: `background-${x()}`,
2875
2883
  customData: e
2876
2884
  }), this._removeCurrentBackground(), this.backgroundObject = s, this.refresh();
2877
2885
  });
@@ -2897,8 +2905,8 @@ class Q {
2897
2905
  { offset: o / 100, color: s }
2898
2906
  ];
2899
2907
  if (t.type === "linear") {
2900
- const h = t.angle * Math.PI / 180, u = Q._angleToCoords(h);
2901
- return new pe({
2908
+ const l = t.angle * Math.PI / 180, u = Q._angleToCoords(l);
2909
+ return new ye({
2902
2910
  type: "linear",
2903
2911
  gradientUnits: "percentage",
2904
2912
  coords: u,
@@ -2917,7 +2925,7 @@ class Q {
2917
2925
  r1: 0,
2918
2926
  r2: c / 100
2919
2927
  };
2920
- return new pe({
2928
+ return new ye({
2921
2929
  type: "radial",
2922
2930
  gradientUnits: "percentage",
2923
2931
  coords: d,
@@ -2952,7 +2960,7 @@ class Q {
2952
2960
  }) ? !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;
2953
2961
  }
2954
2962
  }
2955
- class It {
2963
+ class At {
2956
2964
  constructor({ editor: t }) {
2957
2965
  this.editor = t;
2958
2966
  }
@@ -2967,7 +2975,7 @@ class It {
2967
2975
  const { canvas: s, historyManager: n } = this.editor;
2968
2976
  n.suspendHistory();
2969
2977
  const o = t || s.getActiveObject();
2970
- o && (o instanceof O ? o.getObjects().forEach((a) => {
2978
+ o && (o instanceof D ? o.getObjects().forEach((a) => {
2971
2979
  s.bringObjectToFront(a);
2972
2980
  }) : s.bringObjectToFront(o), s.renderAll(), n.resumeHistory(), e || n.saveState(), s.fire("editor:object-bring-to-front", {
2973
2981
  object: o,
@@ -2985,7 +2993,7 @@ class It {
2985
2993
  const { canvas: s, historyManager: n } = this.editor;
2986
2994
  n.suspendHistory();
2987
2995
  const o = t || s.getActiveObject();
2988
- o && (o instanceof O ? It._moveSelectionForward(s, o) : s.bringObjectForward(o), s.renderAll(), n.resumeHistory(), e || n.saveState(), s.fire("editor:object-bring-forward", {
2996
+ o && (o instanceof D ? At._moveSelectionForward(s, o) : s.bringObjectForward(o), s.renderAll(), n.resumeHistory(), e || n.saveState(), s.fire("editor:object-bring-forward", {
2989
2997
  object: o,
2990
2998
  withoutSave: e
2991
2999
  }));
@@ -3008,7 +3016,7 @@ class It {
3008
3016
  o.suspendHistory();
3009
3017
  const r = t || s.getActiveObject();
3010
3018
  if (r) {
3011
- if (r instanceof O) {
3019
+ if (r instanceof D) {
3012
3020
  const c = r.getObjects();
3013
3021
  for (let d = c.length - 1; d >= 0; d -= 1)
3014
3022
  s.sendObjectToBack(c[d]);
@@ -3036,7 +3044,7 @@ class It {
3036
3044
  } = this.editor;
3037
3045
  o.suspendHistory();
3038
3046
  const r = t || s.getActiveObject();
3039
- r && (r instanceof O ? It._moveSelectionBackwards(s, r) : s.sendObjectBackwards(r), i && s.sendObjectToBack(i), s.sendObjectToBack(n), a && s.sendObjectToBack(a), s.renderAll(), o.resumeHistory(), e || o.saveState(), s.fire("editor:object-send-backwards", {
3047
+ r && (r instanceof D ? At._moveSelectionBackwards(s, r) : s.sendObjectBackwards(r), i && s.sendObjectToBack(i), s.sendObjectToBack(n), a && s.sendObjectToBack(a), s.renderAll(), o.resumeHistory(), e || o.saveState(), s.fire("editor:object-send-backwards", {
3040
3048
  object: r,
3041
3049
  withoutSave: e
3042
3050
  }));
@@ -3080,7 +3088,7 @@ class It {
3080
3088
  });
3081
3089
  }
3082
3090
  }
3083
- class ms {
3091
+ class ys {
3084
3092
  /**
3085
3093
  * Менеджер фигур для редактора.
3086
3094
  * @param options - Опции и настройки менеджера фигур.
@@ -3105,14 +3113,14 @@ class ms {
3105
3113
  * @param flags.withoutAdding - Не добавлять объект в canvas
3106
3114
  */
3107
3115
  addRectangle(d = {}, { withoutSelection: r, withoutAdding: c } = {}) {
3108
- var h = d, {
3109
- id: t = `rect-${N()}`,
3116
+ var l = d, {
3117
+ id: t = `rect-${x()}`,
3110
3118
  left: e,
3111
3119
  top: s,
3112
3120
  width: n = 100,
3113
3121
  height: o = 100,
3114
3122
  fill: a = "blue"
3115
- } = h, i = X(h, [
3123
+ } = l, i = X(l, [
3116
3124
  "id",
3117
3125
  "left",
3118
3126
  "top",
@@ -3120,7 +3128,7 @@ class ms {
3120
3128
  "height",
3121
3129
  "fill"
3122
3130
  ]);
3123
- const { canvas: u } = this.editor, g = new Ne(D({
3131
+ const { canvas: u } = this.editor, g = new Le(E({
3124
3132
  id: t,
3125
3133
  left: e,
3126
3134
  top: s,
@@ -3148,7 +3156,7 @@ class ms {
3148
3156
  */
3149
3157
  addCircle(c = {}, { withoutSelection: i, withoutAdding: r } = {}) {
3150
3158
  var d = c, {
3151
- id: t = `circle-${N()}`,
3159
+ id: t = `circle-${x()}`,
3152
3160
  left: e,
3153
3161
  top: s,
3154
3162
  radius: n = 50,
@@ -3160,14 +3168,14 @@ class ms {
3160
3168
  "radius",
3161
3169
  "fill"
3162
3170
  ]);
3163
- const { canvas: h } = this.editor, u = new Le(D({
3171
+ const { canvas: l } = this.editor, u = new xe(E({
3164
3172
  id: t,
3165
3173
  left: e,
3166
3174
  top: s,
3167
3175
  fill: o,
3168
3176
  radius: n
3169
3177
  }, a));
3170
- return !e && !s && h.centerObject(u), r || (h.add(u), i || h.setActiveObject(u), h.renderAll()), u;
3178
+ return !e && !s && l.centerObject(u), r || (l.add(u), i || l.setActiveObject(u), l.renderAll()), u;
3171
3179
  }
3172
3180
  /**
3173
3181
  * Добавление треугольника
@@ -3187,14 +3195,14 @@ class ms {
3187
3195
  * @param flags.withoutAdding - Не добавлять объект в canvas
3188
3196
  */
3189
3197
  addTriangle(d = {}, { withoutSelection: r, withoutAdding: c } = {}) {
3190
- var h = d, {
3191
- id: t = `triangle-${N()}`,
3198
+ var l = d, {
3199
+ id: t = `triangle-${x()}`,
3192
3200
  left: e,
3193
3201
  top: s,
3194
3202
  width: n = 100,
3195
3203
  height: o = 100,
3196
3204
  fill: a = "yellow"
3197
- } = h, i = X(h, [
3205
+ } = l, i = X(l, [
3198
3206
  "id",
3199
3207
  "left",
3200
3208
  "top",
@@ -3202,7 +3210,7 @@ class ms {
3202
3210
  "height",
3203
3211
  "fill"
3204
3212
  ]);
3205
- const { canvas: u } = this.editor, g = new Te(D({
3213
+ const { canvas: u } = this.editor, g = new ke(E({
3206
3214
  id: t,
3207
3215
  left: e,
3208
3216
  top: s,
@@ -3213,7 +3221,7 @@ class ms {
3213
3221
  return !e && !s && u.centerObject(g), c || (u.add(g), r || u.setActiveObject(g), u.renderAll()), g;
3214
3222
  }
3215
3223
  }
3216
- class ps {
3224
+ class bs {
3217
3225
  /**
3218
3226
  * @param options
3219
3227
  * @param options.editor - экземпляр редактора с доступом к canvas
@@ -3244,7 +3252,7 @@ class ps {
3244
3252
  return C(this, null, function* () {
3245
3253
  const { canvas: e, errorManager: s } = this.editor;
3246
3254
  try {
3247
- const n = yield t.clone(["format"]);
3255
+ const n = yield t.clone(yt);
3248
3256
  this.clipboard = n, e.fire("editor:object-copied", { object: n });
3249
3257
  } catch (n) {
3250
3258
  s.emitError({
@@ -3271,7 +3279,7 @@ class ps {
3271
3279
  message: "navigator.clipboard не поддерживается в этом браузере или отсутствует HTTPS-соединение."
3272
3280
  }), !1;
3273
3281
  try {
3274
- const s = t.toObject(["format"]), n = JSON.stringify(s);
3282
+ const s = t.toObject(yt), n = JSON.stringify(s);
3275
3283
  return t.type === "image" ? this._copyImageToClipboard(t, n) : this._copyTextToClipboard(n);
3276
3284
  } catch (s) {
3277
3285
  return e.emitError({
@@ -3291,8 +3299,8 @@ class ps {
3291
3299
  return C(this, null, function* () {
3292
3300
  try {
3293
3301
  const n = t.toCanvasElement({ enableRetinaScaling: !1 }).toDataURL(), o = n.slice(5).split(";")[0], a = n.split(",")[1], i = atob(a), r = new Uint8Array(i.length);
3294
- for (let h = 0; h < i.length; h += 1)
3295
- r[h] = i.charCodeAt(h);
3302
+ for (let l = 0; l < i.length; l += 1)
3303
+ r[l] = i.charCodeAt(l);
3296
3304
  const c = new Blob([r.buffer], { type: o }), d = new ClipboardItem({ [o]: c });
3297
3305
  return yield navigator.clipboard.write([d]), console.info("Image copied to clipboard successfully"), !0;
3298
3306
  } catch (s) {
@@ -3312,7 +3320,7 @@ class ps {
3312
3320
  _copyTextToClipboard(t) {
3313
3321
  return C(this, null, function* () {
3314
3322
  try {
3315
- const e = `${Ie}${t}`;
3323
+ const e = `${Ce}${t}`;
3316
3324
  return yield navigator.clipboard.writeText(e), console.info("Text copied to clipboard successfully"), !0;
3317
3325
  } catch (e) {
3318
3326
  const { errorManager: s } = this.editor;
@@ -3332,7 +3340,7 @@ class ps {
3332
3340
  */
3333
3341
  _addClonedObjectToCanvas(t) {
3334
3342
  const { canvas: e, historyManager: s } = this.editor;
3335
- if (e.discardActiveObject(), t instanceof O) {
3343
+ if (e.discardActiveObject(), t instanceof D) {
3336
3344
  s.suspendHistory(), t.canvas = e, t.forEachObject((n) => {
3337
3345
  e.add(n);
3338
3346
  }), e.setActiveObject(t), e.requestRenderAll(), s.resumeHistory(), s.saveState();
@@ -3365,14 +3373,14 @@ class ps {
3365
3373
  const { canvas: e } = this.editor, s = t || e.getActiveObject();
3366
3374
  if (!s || s.locked) return !1;
3367
3375
  try {
3368
- const n = yield s.clone(["format"]);
3369
- return n instanceof O && n.forEachObject((o) => {
3376
+ const n = yield s.clone(yt);
3377
+ return n instanceof D && n.forEachObject((o) => {
3370
3378
  o.set({
3371
- id: `${o.type}-${N()}`,
3379
+ id: `${o.type}-${x()}`,
3372
3380
  evented: !0
3373
3381
  });
3374
3382
  }), n.set({
3375
- id: `${n.type}-${N()}`,
3383
+ id: `${n.type}-${x()}`,
3376
3384
  left: n.left + 10,
3377
3385
  top: n.top + 10,
3378
3386
  evented: !0
@@ -3403,7 +3411,7 @@ class ps {
3403
3411
  return;
3404
3412
  }
3405
3413
  const s = t.getData("text/plain");
3406
- if (s && s.startsWith(Ie)) {
3414
+ if (s && s.startsWith(Ce)) {
3407
3415
  this.paste();
3408
3416
  return;
3409
3417
  }
@@ -3411,13 +3419,13 @@ class ps {
3411
3419
  if (o.type !== "text/html" && a) {
3412
3420
  const c = new FileReader();
3413
3421
  c.onload = (d) => {
3414
- d.target && this._handleImageImport(d.target.result).catch((h) => {
3422
+ d.target && this._handleImageImport(d.target.result).catch((l) => {
3415
3423
  this.editor.errorManager.emitError({
3416
3424
  origin: "ClipboardManager",
3417
3425
  method: "handlePasteEvent",
3418
3426
  code: "PASTE_IMAGE_FAILED",
3419
3427
  message: "Ошибка вставки изображения из буфера обмена",
3420
- data: h
3428
+ data: l
3421
3429
  });
3422
3430
  });
3423
3431
  }, c.readAsDataURL(a);
@@ -3425,9 +3433,9 @@ class ps {
3425
3433
  }
3426
3434
  const i = t.getData("text/html");
3427
3435
  if (i) {
3428
- const h = new DOMParser().parseFromString(i, "text/html").querySelector("img");
3429
- if (h != null && h.src) {
3430
- this._handleImageImport(h.src).catch((u) => {
3436
+ const l = new DOMParser().parseFromString(i, "text/html").querySelector("img");
3437
+ if (l != null && l.src) {
3438
+ this._handleImageImport(l.src).catch((u) => {
3431
3439
  this.editor.errorManager.emitError({
3432
3440
  origin: "ClipboardManager",
3433
3441
  method: "handlePasteEvent",
@@ -3451,14 +3459,14 @@ class ps {
3451
3459
  const { canvas: t } = this.editor;
3452
3460
  if (!this.clipboard) return !1;
3453
3461
  try {
3454
- const e = yield this.clipboard.clone(["format"]);
3455
- return t.discardActiveObject(), e instanceof O && e.forEachObject((s) => {
3462
+ const e = yield this.clipboard.clone(yt);
3463
+ return t.discardActiveObject(), e instanceof D && e.forEachObject((s) => {
3456
3464
  s.set({
3457
- id: `${s.type}-${N()}`,
3465
+ id: `${s.type}-${x()}`,
3458
3466
  evented: !0
3459
3467
  });
3460
3468
  }), e.set({
3461
- id: `${e.type}-${N()}`,
3469
+ id: `${e.type}-${x()}`,
3462
3470
  left: e.left + 10,
3463
3471
  top: e.top + 10,
3464
3472
  evented: !0
@@ -3476,7 +3484,7 @@ class ps {
3476
3484
  });
3477
3485
  }
3478
3486
  }
3479
- class At {
3487
+ class Ct {
3480
3488
  constructor({ editor: t }) {
3481
3489
  this.editor = t;
3482
3490
  }
@@ -3501,7 +3509,7 @@ class At {
3501
3509
  lockSkewingY: !0,
3502
3510
  locked: !0
3503
3511
  };
3504
- a.set(i), !e && At._isGroupOrSelection(a) && a.getObjects().forEach((c) => {
3512
+ a.set(i), !e && Ct._isGroupOrSelection(a) && a.getObjects().forEach((c) => {
3505
3513
  c.set(i);
3506
3514
  }), n.renderAll(), s || o.saveState(), n.fire("editor:object-locked", {
3507
3515
  object: a,
@@ -3529,7 +3537,7 @@ class At {
3529
3537
  lockSkewingY: !1,
3530
3538
  locked: !1
3531
3539
  };
3532
- o.set(a), At._isGroupOrSelection(o) && o.getObjects().forEach((i) => {
3540
+ o.set(a), Ct._isGroupOrSelection(o) && o.getObjects().forEach((i) => {
3533
3541
  i.set(a);
3534
3542
  }), s.renderAll(), e || n.saveState(), s.fire("editor:object-unlocked", {
3535
3543
  object: o,
@@ -3537,10 +3545,10 @@ class At {
3537
3545
  });
3538
3546
  }
3539
3547
  static _isGroupOrSelection(t) {
3540
- return t instanceof O || t instanceof $;
3548
+ return t instanceof D || t instanceof $;
3541
3549
  }
3542
3550
  }
3543
- class Ms {
3551
+ class vs {
3544
3552
  constructor({ editor: t }) {
3545
3553
  this.editor = t;
3546
3554
  }
@@ -3552,7 +3560,7 @@ class Ms {
3552
3560
  if (Array.isArray(t))
3553
3561
  return t.length > 0 ? t : null;
3554
3562
  const e = t || this.editor.canvas.getActiveObject();
3555
- return !e || !(e instanceof O) ? null : e.getObjects();
3563
+ return !e || !(e instanceof D) ? null : e.getObjects();
3556
3564
  }
3557
3565
  /**
3558
3566
  * Получить группы для разгруппировки
@@ -3563,13 +3571,13 @@ class Ms {
3563
3571
  const s = t.filter((n) => n instanceof $);
3564
3572
  return s.length > 0 ? s : null;
3565
3573
  }
3566
- if (t instanceof O) {
3574
+ if (t instanceof D) {
3567
3575
  const s = t.getObjects().filter((n) => n instanceof $);
3568
3576
  return s.length > 0 ? s : null;
3569
3577
  }
3570
3578
  const e = t || this.editor.canvas.getActiveObject();
3571
3579
  if (!e) return null;
3572
- if (e instanceof O) {
3580
+ if (e instanceof D) {
3573
3581
  const s = e.getObjects().filter((n) => n instanceof $);
3574
3582
  return s.length > 0 ? s : null;
3575
3583
  }
@@ -3591,7 +3599,7 @@ class Ms {
3591
3599
  try {
3592
3600
  n.suspendHistory();
3593
3601
  const a = new $(o, {
3594
- id: `group-${N()}`
3602
+ id: `group-${x()}`
3595
3603
  });
3596
3604
  o.forEach((r) => s.remove(r)), s.add(a), s.setActiveObject(a), s.requestRenderAll();
3597
3605
  const i = {
@@ -3622,11 +3630,11 @@ class Ms {
3622
3630
  const a = [];
3623
3631
  o.forEach((c) => {
3624
3632
  const d = c.removeAll();
3625
- s.remove(c), d.forEach((h) => {
3626
- s.add(h), a.push(h);
3633
+ s.remove(c), d.forEach((l) => {
3634
+ s.add(l), a.push(l);
3627
3635
  });
3628
3636
  });
3629
- const i = new O(a, {
3637
+ const i = new D(a, {
3630
3638
  canvas: s
3631
3639
  });
3632
3640
  s.setActiveObject(i), s.requestRenderAll();
@@ -3641,7 +3649,7 @@ class Ms {
3641
3649
  }
3642
3650
  }
3643
3651
  }
3644
- class ys {
3652
+ class js {
3645
3653
  constructor({ editor: t }) {
3646
3654
  this.editor = t;
3647
3655
  }
@@ -3652,11 +3660,11 @@ class ys {
3652
3660
  selectAll() {
3653
3661
  const { canvas: t, canvasManager: e, objectLockManager: s } = this.editor;
3654
3662
  t.discardActiveObject();
3655
- const n = e.getObjects(), o = n.some((i) => i.locked), a = n.length > 1 ? new O(e.getObjects(), { canvas: t }) : n[0];
3663
+ const n = e.getObjects(), o = n.some((i) => i.locked), a = n.length > 1 ? new D(e.getObjects(), { canvas: t }) : n[0];
3656
3664
  o && s.lockObject({ object: a, skipInnerObjects: !0, withoutSave: !0 }), t.setActiveObject(a), t.requestRenderAll(), t.fire("editor:all-objects-selected", { selected: a });
3657
3665
  }
3658
3666
  }
3659
- class _t {
3667
+ class Rt {
3660
3668
  constructor({ editor: t }) {
3661
3669
  this.editor = t;
3662
3670
  }
@@ -3703,9 +3711,9 @@ class _t {
3703
3711
  s || o.suspendHistory();
3704
3712
  const r = [];
3705
3713
  if (i.forEach((d) => {
3706
- if (_t._isUngroupableGroup(d)) {
3707
- const h = this._handleGroupDeletion(d);
3708
- r.push(...h);
3714
+ if (Rt._isUngroupableGroup(d)) {
3715
+ const l = this._handleGroupDeletion(d);
3716
+ r.push(...l);
3709
3717
  return;
3710
3718
  }
3711
3719
  n.remove(d), r.push(d);
@@ -3718,7 +3726,7 @@ class _t {
3718
3726
  return n.fire("editor:objects-deleted", c), c;
3719
3727
  }
3720
3728
  }
3721
- const bs = {
3729
+ const Is = {
3722
3730
  IMAGE_MANAGER: {
3723
3731
  /**
3724
3732
  * Некорректный Content-Type изображения
@@ -3817,7 +3825,7 @@ const bs = {
3817
3825
  INVALID_GRADIENT_FORMAT: "INVALID_GRADIENT_FORMAT"
3818
3826
  }
3819
3827
  };
3820
- class Ct {
3828
+ class St {
3821
3829
  constructor({ editor: t }) {
3822
3830
  this._buffer = [], this.editor = t;
3823
3831
  }
@@ -3844,7 +3852,7 @@ class Ct {
3844
3852
  * @fires editor:error
3845
3853
  */
3846
3854
  emitError({ origin: t = "ImageEditor", method: e = "Unknown Method", code: s, data: n, message: o }) {
3847
- if (!Ct.isValidErrorCode(s)) {
3855
+ if (!St.isValidErrorCode(s)) {
3848
3856
  console.warn("Неизвестный код ошибки: ", { code: s, origin: t, method: e });
3849
3857
  return;
3850
3858
  }
@@ -3858,7 +3866,7 @@ class Ct {
3858
3866
  message: a,
3859
3867
  data: n
3860
3868
  };
3861
- this._buffer.push(D({
3869
+ this._buffer.push(E({
3862
3870
  type: "editor:error"
3863
3871
  }, i)), this.editor.canvas.fire("editor:error", i);
3864
3872
  }
@@ -3873,7 +3881,7 @@ class Ct {
3873
3881
  * @fires editor:warning
3874
3882
  */
3875
3883
  emitWarning({ origin: t = "ImageEditor", method: e = "Unknown Method", code: s, message: n, data: o }) {
3876
- if (!Ct.isValidErrorCode(s)) {
3884
+ if (!St.isValidErrorCode(s)) {
3877
3885
  console.warn("Неизвестный код предупреждения: ", { code: s, origin: t, method: e });
3878
3886
  return;
3879
3887
  }
@@ -3886,7 +3894,7 @@ class Ct {
3886
3894
  message: a,
3887
3895
  data: o
3888
3896
  };
3889
- this._buffer.push(D({
3897
+ this._buffer.push(E({
3890
3898
  type: "editor:warning"
3891
3899
  }, i)), this.editor.canvas.fire("editor:warning", i);
3892
3900
  }
@@ -3896,10 +3904,10 @@ class Ct {
3896
3904
  * @returns true, если код допустим, иначе false
3897
3905
  */
3898
3906
  static isValidErrorCode(t) {
3899
- return t ? Object.values(bs).some((e) => Object.values(e).includes(t)) : !1;
3907
+ return t ? Object.values(Is).some((e) => Object.values(e).includes(t)) : !1;
3900
3908
  }
3901
3909
  }
3902
- class vs {
3910
+ class As {
3903
3911
  constructor({ editor: t }) {
3904
3912
  this.currentBounds = null, this.editor = t;
3905
3913
  }
@@ -3949,12 +3957,12 @@ class vs {
3949
3957
  constrainPan(t, e) {
3950
3958
  if (!this.currentBounds || !this.currentBounds.canPan)
3951
3959
  return { x: 0, y: 0 };
3952
- const { canvas: s, montageArea: n } = this.editor, o = s.getZoom(), a = n.left, i = n.top, r = s.getWidth() / 2, c = s.getHeight() / 2, d = a * o + t - r, h = i * o + e - c, u = Math.max(
3960
+ const { canvas: s, montageArea: n } = this.editor, o = s.getZoom(), a = n.left, i = n.top, r = s.getWidth() / 2, c = s.getHeight() / 2, d = a * o + t - r, l = i * o + e - c, u = Math.max(
3953
3961
  this.currentBounds.minX,
3954
3962
  Math.min(this.currentBounds.maxX, d)
3955
3963
  ), g = Math.max(
3956
3964
  this.currentBounds.minY,
3957
- Math.min(this.currentBounds.maxY, h)
3965
+ Math.min(this.currentBounds.maxY, l)
3958
3966
  ), f = u + r - a * o, m = g + c - i * o;
3959
3967
  return {
3960
3968
  x: f,
@@ -3984,56 +3992,89 @@ class vs {
3984
3992
  this.currentBounds = this.calculatePanBounds();
3985
3993
  }
3986
3994
  }
3987
- const wt = 0.01;
3988
- class B {
3995
+ const Et = 0.01;
3996
+ class k {
3989
3997
  constructor({ editor: t }) {
3990
3998
  var e;
3991
- this.handleObjectScaling = (s) => {
3999
+ this.handleTextEditingEntered = () => {
4000
+ this.isTextEditingActive = !0;
4001
+ }, this.handleTextChanged = (s) => {
4002
+ var r, c;
4003
+ const { target: n } = s;
4004
+ if (!k._isTextbox(n)) return;
4005
+ const o = (r = n.text) != null ? r : "", a = !!n.uppercase, i = (c = n.textCaseRaw) != null ? c : "";
4006
+ if (a) {
4007
+ const d = k._toUpperCase(o);
4008
+ d !== o && (n.set({ text: d }), this.canvas.requestRenderAll());
4009
+ const l = i.length, u = o.length;
4010
+ if (u > l) {
4011
+ const g = o.slice(l).toLocaleLowerCase();
4012
+ n.textCaseRaw = i + g;
4013
+ } else u < l ? n.textCaseRaw = i.slice(0, u) : n.textCaseRaw = o.toLocaleLowerCase();
4014
+ } else
4015
+ n.textCaseRaw = o;
4016
+ }, this.handleTextEditingExited = (s) => {
4017
+ var i, r;
4018
+ const { target: n } = s;
4019
+ if (!k._isTextbox(n)) return;
4020
+ const o = (i = n.text) != null ? i : "";
4021
+ if (!!n.uppercase) {
4022
+ const c = (r = n.textCaseRaw) != null ? r : o.toLocaleLowerCase();
4023
+ n.textCaseRaw = c;
4024
+ } else
4025
+ n.textCaseRaw = o;
4026
+ n.locked || n.set({
4027
+ lockMovementX: !1,
4028
+ lockMovementY: !1
4029
+ }), setTimeout(() => {
4030
+ this.isTextEditingActive = !1, this.editor.historyManager.saveState();
4031
+ }, hs);
4032
+ }, this.handleObjectScaling = (s) => {
3992
4033
  var Z, G, W, tt, et, st, nt, ot, at, it, rt, ct, dt, lt;
3993
4034
  const { target: n, transform: o } = s;
3994
- if (!B._isTextbox(n) || !o) return;
3995
- const a = this._ensureScalingState(n), { baseWidth: i, baseLeft: r, baseFontSize: c } = a, d = typeof ((Z = o.original) == null ? void 0 : Z.width) == "number" ? o.original.width : void 0, h = typeof ((G = o.original) == null ? void 0 : G.left) == "number" ? o.original.left : void 0, u = d != null ? d : i, g = h != null ? h : r, f = (W = o.corner) != null ? W : "", m = (tt = o.action) != null ? tt : "", y = ["ml", "mr"].includes(f) || m === "scaleX", p = ["mt", "mb"].includes(f) || m === "scaleY", M = ["tl", "tr", "bl", "br"].includes(f) || m === "scale";
3996
- if (!y && !p && !M) return;
3997
- const S = Math.abs((st = (et = n.scaleX) != null ? et : o.scaleX) != null ? st : 1) || 1, E = Math.abs((ot = (nt = n.scaleY) != null ? nt : o.scaleY) != null ? ot : 1) || 1, v = Math.max(1, u * S), A = Math.max(1, c * E), j = (it = (at = o.originX) != null ? at : n.originX) != null ? it : "left", L = g + u, w = g + u / 2, b = (rt = n.width) != null ? rt : u, T = Math.abs(v - b) > wt, k = Math.abs(A - ((ct = n.fontSize) != null ? ct : c)) > wt;
3998
- if (!T && !k) {
4035
+ if (!k._isTextbox(n) || !o) return;
4036
+ const a = this._ensureScalingState(n), { baseWidth: i, baseLeft: r, baseFontSize: c } = a, d = typeof ((Z = o.original) == null ? void 0 : Z.width) == "number" ? o.original.width : void 0, l = typeof ((G = o.original) == null ? void 0 : G.left) == "number" ? o.original.left : void 0, u = d != null ? d : i, g = l != null ? l : r, f = (W = o.corner) != null ? W : "", m = (tt = o.action) != null ? tt : "", b = ["ml", "mr"].includes(f) || m === "scaleX", p = ["mt", "mb"].includes(f) || m === "scaleY", M = ["tl", "tr", "bl", "br"].includes(f) || m === "scale";
4037
+ if (!b && !p && !M) return;
4038
+ const S = Math.abs((st = (et = n.scaleX) != null ? et : o.scaleX) != null ? st : 1) || 1, O = Math.abs((ot = (nt = n.scaleY) != null ? nt : o.scaleY) != null ? ot : 1) || 1, T = Math.max(1, u * S), y = Math.max(1, c * O), A = (it = (at = o.originX) != null ? at : n.originX) != null ? it : "left", N = g + u, I = g + u / 2, v = (rt = n.width) != null ? rt : u, w = Math.abs(T - v) > Et, L = Math.abs(y - ((ct = n.fontSize) != null ? ct : c)) > Et;
4039
+ if (!w && !L) {
3999
4040
  n.set({ scaleX: 1, scaleY: 1 }), o.scaleX = 1, o.scaleY = 1;
4000
4041
  return;
4001
4042
  }
4002
4043
  n.set({
4003
- width: v,
4004
- fontSize: M || p ? A : c,
4044
+ width: T,
4045
+ fontSize: M || p ? y : c,
4005
4046
  scaleX: 1,
4006
4047
  scaleY: 1
4007
4048
  });
4008
- const x = (dt = n.width) != null ? dt : v, Y = Math.abs(x - b) > wt;
4049
+ const B = (dt = n.width) != null ? dt : T, Y = Math.abs(B - v) > Et;
4009
4050
  let _ = g;
4010
- Y && (y || M) && (j === "right" ? _ = L - x : j === "center" && (_ = w - x / 2)), n.set({ left: _ }), a.baseLeft = _, o.scaleX = 1, o.scaleY = 1;
4051
+ Y && (b || M) && (A === "right" ? _ = N - B : A === "center" && (_ = I - B / 2)), n.set({ left: _ }), a.baseLeft = _, o.scaleX = 1, o.scaleY = 1;
4011
4052
  const { original: R } = o;
4012
- R && (R.scaleX = 1, R.scaleY = 1, R.width = x, R.height = n.height, R.left = _), n.setCoords(), this.canvas.requestRenderAll(), a.baseWidth = x, a.baseFontSize = (lt = n.fontSize) != null ? lt : A, a.hasWidthChange = Y || k;
4053
+ R && (R.scaleX = 1, R.scaleY = 1, R.width = B, R.height = n.height, R.left = _), n.setCoords(), this.canvas.requestRenderAll(), a.baseWidth = B, a.baseFontSize = (lt = n.fontSize) != null ? lt : y, a.hasWidthChange = Y || L;
4013
4054
  }, this.handleObjectModified = (s) => {
4014
4055
  var r, c, d;
4015
4056
  const { target: n } = s;
4016
- if (!B._isTextbox(n)) return;
4057
+ if (!k._isTextbox(n)) return;
4017
4058
  const o = this.scalingState.get(n);
4018
4059
  if (this.scalingState.delete(n), !(o != null && o.hasWidthChange)) return;
4019
4060
  const a = (r = n.width) != null ? r : n.calcTextWidth(), i = (d = (c = n.fontSize) != null ? c : o == null ? void 0 : o.baseFontSize) != null ? d : 16;
4020
4061
  this.updateText(n, { width: a, fontSize: i }), n.set({ scaleX: 1, scaleY: 1 }), n.setCoords();
4021
- }, this.editor = t, this.canvas = t.canvas, this.fonts = (e = t.options.fonts) != null ? e : [], this.scalingState = /* @__PURE__ */ new WeakMap(), this._bindEvents();
4062
+ }, 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();
4022
4063
  }
4023
4064
  /**
4024
4065
  * Уничтожает менеджер и снимает слушатели.
4025
4066
  */
4026
4067
  destroy() {
4027
- this.canvas.off("object:scaling", this.handleObjectScaling), this.canvas.off("object:modified", this.handleObjectModified);
4068
+ this.canvas.off("object:scaling", this.handleObjectScaling), this.canvas.off("object:modified", this.handleObjectModified), this.canvas.off("text:editing:exited", this.handleTextEditingExited), this.canvas.off("text:editing:entered", this.handleTextEditingEntered), this.canvas.off("text:changed", this.handleTextChanged);
4028
4069
  }
4029
4070
  /**
4030
4071
  * Добавляет новый текстовый объект на канвас.
4031
4072
  * @param options — настройки текста
4032
4073
  * @param flags — флаги поведения
4033
4074
  */
4034
- addText(M = {}, { withoutSelection: y, withoutAdding: p } = {}) {
4035
- var S = M, {
4036
- id: t = `text-${N()}`,
4075
+ addText(S = {}, { withoutSelection: b = !1, withoutSave: p = !1, withoutAdding: M = !1 } = {}) {
4076
+ var O = S, {
4077
+ id: t = `text-${x()}`,
4037
4078
  text: e = "Новый текст",
4038
4079
  fontFamily: s,
4039
4080
  fontSize: n = 48,
@@ -4043,11 +4084,11 @@ class B {
4043
4084
  uppercase: r = !1,
4044
4085
  strikethrough: c = !1,
4045
4086
  align: d = "left",
4046
- color: h = "#000000",
4087
+ color: l = "#000000",
4047
4088
  strokeColor: u,
4048
4089
  strokeWidth: g = 0,
4049
4090
  opacity: f = 1
4050
- } = S, m = X(S, [
4091
+ } = O, m = X(O, [
4051
4092
  "id",
4052
4093
  "text",
4053
4094
  "fontFamily",
@@ -4064,12 +4105,14 @@ class B {
4064
4105
  "opacity"
4065
4106
  ]);
4066
4107
  var w;
4067
- const E = s != null ? s : this._getDefaultFontFamily(), v = B._resolveStrokeWidth(g), A = B._resolveStrokeColor(
4108
+ const { historyManager: T } = this.editor;
4109
+ T.suspendHistory();
4110
+ const y = s != null ? s : this._getDefaultFontFamily(), A = k._resolveStrokeWidth(g), N = k._resolveStrokeColor(
4068
4111
  u,
4069
- v
4070
- ), j = new gt(e, D({
4112
+ A
4113
+ ), I = new gt(e, E({
4071
4114
  id: t,
4072
- fontFamily: E,
4115
+ fontFamily: y,
4073
4116
  fontSize: n,
4074
4117
  fontWeight: o ? "bold" : "normal",
4075
4118
  fontStyle: a ? "italic" : "normal",
@@ -4077,21 +4120,21 @@ class B {
4077
4120
  uppercase: r,
4078
4121
  linethrough: c,
4079
4122
  textAlign: d,
4080
- fill: h,
4081
- stroke: A,
4082
- strokeWidth: v,
4123
+ fill: l,
4124
+ stroke: N,
4125
+ strokeWidth: A,
4083
4126
  strokeUniform: !0,
4084
4127
  opacity: f
4085
4128
  }, m));
4086
- if (j.textCaseRaw = (w = j.text) != null ? w : "", r) {
4087
- const b = B._toUpperCase(j.textCaseRaw);
4088
- b !== j.text && j.set({ text: b });
4129
+ if (I.textCaseRaw = (w = I.text) != null ? w : "", r) {
4130
+ const L = k._toUpperCase(I.textCaseRaw);
4131
+ L !== I.text && I.set({ text: L });
4089
4132
  }
4090
- m.left === void 0 && m.top === void 0 && this.canvas.centerObject(j), p || this.canvas.add(j), y || this.canvas.setActiveObject(j), this.canvas.requestRenderAll();
4091
- const L = D({
4133
+ m.left === void 0 && m.top === void 0 && this.canvas.centerObject(I), M || this.canvas.add(I), b || this.canvas.setActiveObject(I), this.canvas.requestRenderAll(), T.resumeHistory(), p || T.saveState();
4134
+ const v = E({
4092
4135
  id: t,
4093
4136
  text: e,
4094
- fontFamily: E,
4137
+ fontFamily: y,
4095
4138
  fontSize: n,
4096
4139
  bold: o,
4097
4140
  italic: a,
@@ -4099,19 +4142,20 @@ class B {
4099
4142
  uppercase: r,
4100
4143
  strikethrough: c,
4101
4144
  align: d,
4102
- color: h,
4103
- strokeColor: A,
4104
- strokeWidth: v,
4145
+ color: l,
4146
+ strokeColor: N,
4147
+ strokeWidth: A,
4105
4148
  opacity: f
4106
4149
  }, m);
4107
4150
  return this.canvas.fire("editor:text-added", {
4108
- textbox: j,
4109
- options: L,
4151
+ textbox: I,
4152
+ options: v,
4110
4153
  flags: {
4111
- withoutSelection: !!y,
4112
- withoutAdding: !!p
4154
+ withoutSelection: !!b,
4155
+ withoutSave: !!p,
4156
+ withoutAdding: !!M
4113
4157
  }
4114
- }), j;
4158
+ }), I;
4115
4159
  }
4116
4160
  /**
4117
4161
  * Обновляет текстовый объект.
@@ -4120,47 +4164,49 @@ class B {
4120
4164
  * @param options — настройки обновления
4121
4165
  */
4122
4166
  updateText(t, e = {}, { withoutSave: s, skipRender: n } = {}) {
4123
- var x, Y, _, R, Z, G, W, tt, et, st, nt, ot, at, it, rt, ct, dt, lt, Ut, Yt, Ft, Ht, Zt, Wt, Pt, Vt, Gt, Xt, Kt, $t, Qt, Jt, qt, te, ee, se, ne, oe, ae, ie, re, ce;
4167
+ var Y, _, R, Z, G, W, tt, et, st, nt, ot, at, it, rt, ct, dt, lt, zt, Yt, Ht, Zt, Wt, Pt, Vt, Gt, Xt, Kt, $t, Qt, Jt, qt, te, ee, se, ne, oe, ae, ie, re, ce, de, le;
4124
4168
  const o = this._resolveTextObject(t);
4125
4169
  if (!o) return null;
4126
- const a = {
4170
+ const { historyManager: a } = this.editor;
4171
+ a.suspendHistory();
4172
+ const i = {
4127
4173
  id: o.id,
4128
- text: (x = o.text) != null ? x : void 0,
4129
- textCaseRaw: (Y = o.textCaseRaw) != null ? Y : void 0,
4174
+ text: (Y = o.text) != null ? Y : void 0,
4175
+ textCaseRaw: (_ = o.textCaseRaw) != null ? _ : void 0,
4130
4176
  uppercase: !!o.uppercase,
4131
- fontFamily: (_ = o.fontFamily) != null ? _ : void 0,
4132
- fontSize: (R = o.fontSize) != null ? R : void 0,
4133
- fontWeight: (Z = o.fontWeight) != null ? Z : void 0,
4134
- fontStyle: (G = o.fontStyle) != null ? G : void 0,
4135
- underline: (W = o.underline) != null ? W : void 0,
4136
- linethrough: (tt = o.linethrough) != null ? tt : void 0,
4177
+ fontFamily: (R = o.fontFamily) != null ? R : void 0,
4178
+ fontSize: (Z = o.fontSize) != null ? Z : void 0,
4179
+ fontWeight: (G = o.fontWeight) != null ? G : void 0,
4180
+ fontStyle: (W = o.fontStyle) != null ? W : void 0,
4181
+ underline: (tt = o.underline) != null ? tt : void 0,
4182
+ linethrough: (et = o.linethrough) != null ? et : void 0,
4137
4183
  textAlign: o.textAlign,
4138
- fill: (et = o.fill) != null ? et : void 0,
4139
- stroke: (st = o.stroke) != null ? st : void 0,
4140
- strokeWidth: (nt = o.strokeWidth) != null ? nt : void 0,
4141
- opacity: (ot = o.opacity) != null ? ot : void 0,
4142
- left: (at = o.left) != null ? at : void 0,
4143
- top: (it = o.top) != null ? it : void 0,
4144
- width: (rt = o.width) != null ? rt : void 0,
4145
- height: (ct = o.height) != null ? ct : void 0,
4146
- angle: (dt = o.angle) != null ? dt : void 0,
4147
- scaleX: (lt = o.scaleX) != null ? lt : void 0,
4148
- scaleY: (Ut = o.scaleY) != null ? Ut : void 0
4149
- }, zt = e, {
4150
- text: i,
4151
- fontFamily: r,
4152
- fontSize: c,
4153
- bold: d,
4154
- italic: h,
4155
- underline: u,
4156
- uppercase: g,
4157
- strikethrough: f,
4158
- align: m,
4159
- color: y,
4160
- strokeColor: p,
4161
- strokeWidth: M,
4162
- opacity: S
4163
- } = zt, E = X(zt, [
4184
+ fill: (st = o.fill) != null ? st : void 0,
4185
+ stroke: (nt = o.stroke) != null ? nt : void 0,
4186
+ strokeWidth: (ot = o.strokeWidth) != null ? ot : void 0,
4187
+ opacity: (at = o.opacity) != null ? at : void 0,
4188
+ left: (it = o.left) != null ? it : void 0,
4189
+ top: (rt = o.top) != null ? rt : void 0,
4190
+ width: (ct = o.width) != null ? ct : void 0,
4191
+ height: (dt = o.height) != null ? dt : void 0,
4192
+ angle: (lt = o.angle) != null ? lt : void 0,
4193
+ scaleX: (zt = o.scaleX) != null ? zt : void 0,
4194
+ scaleY: (Yt = o.scaleY) != null ? Yt : void 0
4195
+ }, Ft = e, {
4196
+ text: r,
4197
+ fontFamily: c,
4198
+ fontSize: d,
4199
+ bold: l,
4200
+ italic: u,
4201
+ underline: g,
4202
+ uppercase: f,
4203
+ strikethrough: m,
4204
+ align: b,
4205
+ color: p,
4206
+ strokeColor: M,
4207
+ strokeWidth: S,
4208
+ opacity: O
4209
+ } = Ft, T = X(Ft, [
4164
4210
  "text",
4165
4211
  "fontFamily",
4166
4212
  "fontSize",
@@ -4174,41 +4220,41 @@ class B {
4174
4220
  "strokeColor",
4175
4221
  "strokeWidth",
4176
4222
  "opacity"
4177
- ]), v = D({}, E);
4178
- if (r !== void 0 && (v.fontFamily = r), c !== void 0 && (v.fontSize = c), d !== void 0 && (v.fontWeight = d ? "bold" : "normal"), h !== void 0 && (v.fontStyle = h ? "italic" : "normal"), u !== void 0 && (v.underline = u), f !== void 0 && (v.linethrough = f), m !== void 0 && (v.textAlign = m), y !== void 0 && (v.fill = y), p !== void 0 || M !== void 0) {
4179
- const St = (Yt = M != null ? M : o.strokeWidth) != null ? Yt : 0, de = B._resolveStrokeWidth(St), Se = (Ft = p != null ? p : o.stroke) != null ? Ft : void 0;
4180
- v.stroke = B._resolveStrokeColor(Se, de), v.strokeWidth = de;
4223
+ ]), y = E({}, T);
4224
+ if (c !== void 0 && (y.fontFamily = c), d !== void 0 && (y.fontSize = d), l !== void 0 && (y.fontWeight = l ? "bold" : "normal"), u !== void 0 && (y.fontStyle = u ? "italic" : "normal"), g !== void 0 && (y.underline = g), m !== void 0 && (y.linethrough = m), b !== void 0 && (y.textAlign = b), p !== void 0 && (y.fill = p), M !== void 0 || S !== void 0) {
4225
+ const wt = (Ht = S != null ? S : o.strokeWidth) != null ? Ht : 0, he = k._resolveStrokeWidth(wt), Ee = (Zt = M != null ? M : o.stroke) != null ? Zt : void 0;
4226
+ y.stroke = k._resolveStrokeColor(Ee, he), y.strokeWidth = he;
4181
4227
  }
4182
- S !== void 0 && (v.opacity = S);
4183
- const A = (Zt = o.textCaseRaw) != null ? Zt : (Ht = o.text) != null ? Ht : "", j = !!o.uppercase, L = i !== void 0, w = L ? i != null ? i : "" : A, b = g != null ? g : j;
4184
- if (L || b !== j) {
4185
- const St = b ? B._toUpperCase(w) : w;
4186
- v.text = St, o.textCaseRaw = w;
4228
+ O !== void 0 && (y.opacity = O);
4229
+ const A = (Pt = o.textCaseRaw) != null ? Pt : (Wt = o.text) != null ? Wt : "", N = !!o.uppercase, I = r !== void 0, v = I ? r != null ? r : "" : A, w = f != null ? f : N;
4230
+ if (I || w !== N) {
4231
+ const wt = w ? k._toUpperCase(v) : v;
4232
+ y.text = wt, o.textCaseRaw = v;
4187
4233
  } else o.textCaseRaw === void 0 && (o.textCaseRaw = A);
4188
- o.uppercase = b, o.set(v), o.setCoords(), n || this.canvas.requestRenderAll(), s || this.editor.historyManager.saveState();
4189
- const k = {
4234
+ o.uppercase = w, o.set(y), o.setCoords(), n || this.canvas.requestRenderAll(), a.resumeHistory(), s || a.saveState();
4235
+ const B = {
4190
4236
  id: o.id,
4191
- text: (Wt = o.text) != null ? Wt : void 0,
4192
- textCaseRaw: (Pt = o.textCaseRaw) != null ? Pt : void 0,
4237
+ text: (Vt = o.text) != null ? Vt : void 0,
4238
+ textCaseRaw: (Gt = o.textCaseRaw) != null ? Gt : void 0,
4193
4239
  uppercase: !!o.uppercase,
4194
- fontFamily: (Vt = o.fontFamily) != null ? Vt : void 0,
4195
- fontSize: (Gt = o.fontSize) != null ? Gt : void 0,
4196
- fontWeight: (Xt = o.fontWeight) != null ? Xt : void 0,
4197
- fontStyle: (Kt = o.fontStyle) != null ? Kt : void 0,
4198
- underline: ($t = o.underline) != null ? $t : void 0,
4199
- linethrough: (Qt = o.linethrough) != null ? Qt : void 0,
4240
+ fontFamily: (Xt = o.fontFamily) != null ? Xt : void 0,
4241
+ fontSize: (Kt = o.fontSize) != null ? Kt : void 0,
4242
+ fontWeight: ($t = o.fontWeight) != null ? $t : void 0,
4243
+ fontStyle: (Qt = o.fontStyle) != null ? Qt : void 0,
4244
+ underline: (Jt = o.underline) != null ? Jt : void 0,
4245
+ linethrough: (qt = o.linethrough) != null ? qt : void 0,
4200
4246
  textAlign: o.textAlign,
4201
- fill: (Jt = o.fill) != null ? Jt : void 0,
4202
- stroke: (qt = o.stroke) != null ? qt : void 0,
4203
- strokeWidth: (te = o.strokeWidth) != null ? te : void 0,
4204
- opacity: (ee = o.opacity) != null ? ee : void 0,
4205
- left: (se = o.left) != null ? se : void 0,
4206
- top: (ne = o.top) != null ? ne : void 0,
4207
- width: (oe = o.width) != null ? oe : void 0,
4208
- height: (ae = o.height) != null ? ae : void 0,
4209
- angle: (ie = o.angle) != null ? ie : void 0,
4210
- scaleX: (re = o.scaleX) != null ? re : void 0,
4211
- scaleY: (ce = o.scaleY) != null ? ce : void 0
4247
+ fill: (te = o.fill) != null ? te : void 0,
4248
+ stroke: (ee = o.stroke) != null ? ee : void 0,
4249
+ strokeWidth: (se = o.strokeWidth) != null ? se : void 0,
4250
+ opacity: (ne = o.opacity) != null ? ne : void 0,
4251
+ left: (oe = o.left) != null ? oe : void 0,
4252
+ top: (ae = o.top) != null ? ae : void 0,
4253
+ width: (ie = o.width) != null ? ie : void 0,
4254
+ height: (re = o.height) != null ? re : void 0,
4255
+ angle: (ce = o.angle) != null ? ce : void 0,
4256
+ scaleX: (de = o.scaleX) != null ? de : void 0,
4257
+ scaleY: (le = o.scaleY) != null ? le : void 0
4212
4258
  };
4213
4259
  return this.canvas.fire("editor:text-updated", {
4214
4260
  textbox: o,
@@ -4218,9 +4264,9 @@ class B {
4218
4264
  withoutSave: !!s,
4219
4265
  skipRender: !!n
4220
4266
  },
4221
- updates: v,
4222
- before: a,
4223
- after: k
4267
+ updates: y,
4268
+ before: i,
4269
+ after: B
4224
4270
  }), o;
4225
4271
  }
4226
4272
  /**
@@ -4230,10 +4276,10 @@ class B {
4230
4276
  if (t instanceof gt) return t;
4231
4277
  if (!t) {
4232
4278
  const e = this.canvas.getActiveObject();
4233
- return B._isTextbox(e) ? e : null;
4279
+ return k._isTextbox(e) ? e : null;
4234
4280
  }
4235
4281
  if (typeof t == "string") {
4236
- const e = this.canvas.getObjects().find((s) => B._isTextbox(s) && s.id === t);
4282
+ const e = this.canvas.getObjects().find((s) => k._isTextbox(s) && s.id === t);
4237
4283
  return e != null ? e : null;
4238
4284
  }
4239
4285
  return null;
@@ -4242,7 +4288,7 @@ class B {
4242
4288
  return !!t && t instanceof gt;
4243
4289
  }
4244
4290
  _bindEvents() {
4245
- this.canvas.on("object:scaling", this.handleObjectScaling), this.canvas.on("object:modified", this.handleObjectModified);
4291
+ this.canvas.on("object:scaling", this.handleObjectScaling), this.canvas.on("object:modified", this.handleObjectModified), this.canvas.on("text:editing:entered", this.handleTextEditingEntered), this.canvas.on("text:editing:exited", this.handleTextEditingExited), this.canvas.on("text:changed", this.handleTextChanged);
4246
4292
  }
4247
4293
  _ensureScalingState(t) {
4248
4294
  var s, n, o;
@@ -4273,14 +4319,14 @@ class B {
4273
4319
  return (e = (t = this.fonts[0]) == null ? void 0 : t.family) != null ? e : "Arial";
4274
4320
  }
4275
4321
  }
4276
- class Rt {
4322
+ class Ut {
4277
4323
  /**
4278
4324
  * Конструктор класса ImageEditor.
4279
4325
  * @param canvasId - идентификатор канваса, в котором будет создан редактор
4280
4326
  * @param options - опции и настройки редактора
4281
4327
  */
4282
4328
  constructor(t, e) {
4283
- this.options = e, this.containerId = t, this.editorId = `${t}-${N()}`, this.clipboard = null, this.init();
4329
+ this.options = e, this.containerId = t, this.editorId = `${t}-${x()}`, this.clipboard = null, this.init();
4284
4330
  }
4285
4331
  /**
4286
4332
  * Инициализация редактора.
@@ -4301,9 +4347,9 @@ class Rt {
4301
4347
  initialStateJSON: r,
4302
4348
  scaleType: c,
4303
4349
  showRotationAngle: d,
4304
- _onReadyCallback: h
4350
+ _onReadyCallback: l
4305
4351
  } = this.options;
4306
- if (vt.apply(), this.canvas = new ke(this.containerId, this.options), this.moduleLoader = new Ue(), this.workerManager = new Ye(), this.errorManager = new Ct({ editor: this }), this.historyManager = new jt({ editor: this }), this.toolbar = new ss({ editor: this }), this.transformManager = new us({ editor: this }), this.zoomManager = new gs({ editor: this }), this.canvasManager = new hs({ editor: this }), this.imageManager = new H({ editor: this }), this.layerManager = new It({ editor: this }), this.shapeManager = new ms({ editor: this }), this.interactionBlocker = new fs({ editor: this }), this.backgroundManager = new Q({ editor: this }), this.clipboardManager = new ps({ editor: this }), this.objectLockManager = new At({ editor: this }), this.groupingManager = new Ms({ editor: this }), this.selectionManager = new ys({ editor: this }), this.deletionManager = new _t({ editor: this }), this.panConstraintManager = new vs({ editor: this }), this.fontManager = new Lt((u = this.options.fonts) != null ? u : []), yield this.fontManager.loadFonts(), this.textManager = new B({ editor: this }), d && (this.angleIndicator = new Bt({ editor: this })), this._createMontageArea(), this._createClippingArea(), this.listeners = new ft({ editor: this, options: this.options }), this.canvasManager.setEditorContainerWidth(t), this.canvasManager.setEditorContainerHeight(e), this.canvasManager.setCanvasWrapperWidth(s), this.canvasManager.setCanvasWrapperHeight(n), this.canvasManager.setCanvasCSSWidth(o), this.canvasManager.setCanvasCSSHeight(a), this.canvasManager.updateCanvas(), this.zoomManager.calculateAndApplyDefaultZoom(), i != null && i.source) {
4352
+ if (jt.apply(), this.canvas = new Be(this.containerId, this.options), this.moduleLoader = new Ye(), this.workerManager = new He(), this.errorManager = new St({ editor: this }), this.historyManager = new It({ editor: this }), this.toolbar = new os({ editor: this }), this.transformManager = new ms({ editor: this }), this.zoomManager = new ps({ editor: this }), this.canvasManager = new fs({ editor: this }), this.imageManager = new H({ editor: this }), this.layerManager = new At({ editor: this }), this.shapeManager = new ys({ editor: this }), this.interactionBlocker = new Ms({ editor: this }), this.backgroundManager = new Q({ editor: this }), this.clipboardManager = new bs({ editor: this }), this.objectLockManager = new Ct({ editor: this }), this.groupingManager = new vs({ editor: this }), this.selectionManager = new js({ editor: this }), this.deletionManager = new Rt({ editor: this }), this.panConstraintManager = new As({ editor: this }), this.fontManager = new Lt((u = this.options.fonts) != null ? u : []), this.textManager = new k({ editor: this }), d && (this.angleIndicator = new _t({ editor: this })), this._createMontageArea(), this._createClippingArea(), this.listeners = new ft({ editor: this, options: this.options }), this.canvasManager.setEditorContainerWidth(t), this.canvasManager.setEditorContainerHeight(e), this.canvasManager.setCanvasWrapperWidth(s), this.canvasManager.setCanvasWrapperHeight(n), this.canvasManager.setCanvasCSSWidth(o), this.canvasManager.setCanvasCSSHeight(a), this.canvasManager.updateCanvas(), this.zoomManager.calculateAndApplyDefaultZoom(), yield this.fontManager.loadFonts(), i != null && i.source) {
4307
4353
  const {
4308
4354
  source: g,
4309
4355
  scale: f = `image-${c}`,
@@ -4311,7 +4357,7 @@ class Rt {
4311
4357
  } = i;
4312
4358
  yield this.imageManager.importImage({ source: g, scale: f, withoutSave: m });
4313
4359
  }
4314
- r && this.historyManager.loadStateFromFullState(r), this.historyManager.saveState(), console.log("editor:ready"), this.canvas.fire("editor:ready", this), typeof h == "function" && h(this);
4360
+ r && this.historyManager.loadStateFromFullState(r), this.historyManager.saveState(), console.log("editor:ready"), this.canvas.fire("editor:ready", this), typeof l == "function" && l(this);
4315
4361
  });
4316
4362
  }
4317
4363
  /**
@@ -4325,7 +4371,7 @@ class Rt {
4325
4371
  this.montageArea = this.shapeManager.addRectangle({
4326
4372
  width: t,
4327
4373
  height: e,
4328
- fill: Rt._createMosaicPattern(),
4374
+ fill: Ut._createMosaicPattern(),
4329
4375
  stroke: null,
4330
4376
  strokeWidth: 0,
4331
4377
  selectable: !1,
@@ -4376,7 +4422,7 @@ class Rt {
4376
4422
  const t = document.createElement("canvas");
4377
4423
  t.width = 20, t.height = 20;
4378
4424
  const e = t.getContext("2d");
4379
- 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 xe({
4425
+ 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 _e({
4380
4426
  source: t,
4381
4427
  repeat: "repeat"
4382
4428
  });
@@ -4408,7 +4454,7 @@ const U = [
4408
4454
  "U+0490-0491",
4409
4455
  "U+04B0-04B1",
4410
4456
  "U+2116"
4411
- ].join(", "), js = [
4457
+ ].join(", "), Cs = [
4412
4458
  {
4413
4459
  family: "Arial",
4414
4460
  source: 'local("Arial"), local("Liberation Sans"), local("DejaVu Sans")',
@@ -4618,7 +4664,7 @@ const U = [
4618
4664
  unicodeRange: U
4619
4665
  }
4620
4666
  }
4621
- ], Is = {
4667
+ ], Ss = {
4622
4668
  /**
4623
4669
  * Опции редактора
4624
4670
  */
@@ -4710,20 +4756,20 @@ const U = [
4710
4756
  /**
4711
4757
  * Список шрифтов, которые будут доступны в редакторе по умолчанию.
4712
4758
  */
4713
- fonts: js
4759
+ fonts: Cs
4714
4760
  };
4715
- function Ds(l, t = {}) {
4716
- const e = D(D({}, Is), t), s = document.getElementById(l);
4761
+ function Ts(h, t = {}) {
4762
+ const e = E(E({}, Ss), t), s = document.getElementById(h);
4717
4763
  if (!s)
4718
- return Promise.reject(new Error(`Контейнер с ID "${l}" не найден.`));
4764
+ return Promise.reject(new Error(`Контейнер с ID "${h}" не найден.`));
4719
4765
  const n = document.createElement("canvas");
4720
- return n.id = `${l}-canvas`, s.appendChild(n), e.editorContainer = s, new Promise((o) => {
4766
+ return n.id = `${h}-canvas`, s.appendChild(n), e.editorContainer = s, new Promise((o) => {
4721
4767
  e._onReadyCallback = o;
4722
- const a = new Rt(n.id, e);
4723
- window[l] = a;
4768
+ const a = new Ut(n.id, e);
4769
+ window[h] = a;
4724
4770
  });
4725
4771
  }
4726
4772
  export {
4727
- Ds as default
4773
+ Ts as default
4728
4774
  };
4729
4775
  //# sourceMappingURL=main.js.map