@anu3ev/fabric-image-editor 0.1.77 → 0.1.79
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.
- package/dist/main.js +422 -381
- package/package.json +1 -1
package/dist/main.js
CHANGED
|
@@ -1,49 +1,49 @@
|
|
|
1
|
-
var
|
|
2
|
-
var
|
|
3
|
-
var
|
|
4
|
-
var
|
|
5
|
-
var
|
|
1
|
+
var Se = Object.defineProperty, De = Object.defineProperties;
|
|
2
|
+
var Ee = Object.getOwnPropertyDescriptors;
|
|
3
|
+
var F = Object.getOwnPropertySymbols;
|
|
4
|
+
var fe = Object.prototype.hasOwnProperty, Me = Object.prototype.propertyIsEnumerable;
|
|
5
|
+
var ue = (c, e, t) => e in c ? Se(c, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : c[e] = t, I = (c, e) => {
|
|
6
6
|
for (var t in e || (e = {}))
|
|
7
|
-
|
|
8
|
-
if (
|
|
9
|
-
for (var t of
|
|
10
|
-
|
|
11
|
-
return
|
|
12
|
-
},
|
|
13
|
-
var
|
|
7
|
+
fe.call(e, t) && ue(c, t, e[t]);
|
|
8
|
+
if (F)
|
|
9
|
+
for (var t of F(e))
|
|
10
|
+
Me.call(e, t) && ue(c, t, e[t]);
|
|
11
|
+
return c;
|
|
12
|
+
}, me = (c, e) => De(c, Ee(e));
|
|
13
|
+
var V = (c, e) => {
|
|
14
14
|
var t = {};
|
|
15
|
-
for (var s in
|
|
16
|
-
|
|
17
|
-
if (
|
|
18
|
-
for (var s of
|
|
19
|
-
e.indexOf(s) < 0 &&
|
|
15
|
+
for (var s in c)
|
|
16
|
+
fe.call(c, s) && e.indexOf(s) < 0 && (t[s] = c[s]);
|
|
17
|
+
if (c != null && F)
|
|
18
|
+
for (var s of F(c))
|
|
19
|
+
e.indexOf(s) < 0 && Me.call(c, s) && (t[s] = c[s]);
|
|
20
20
|
return t;
|
|
21
21
|
};
|
|
22
|
-
var
|
|
23
|
-
var o = (
|
|
22
|
+
var j = (c, e, t) => new Promise((s, a) => {
|
|
23
|
+
var o = (r) => {
|
|
24
24
|
try {
|
|
25
|
-
i(t.next(
|
|
25
|
+
i(t.next(r));
|
|
26
26
|
} catch (d) {
|
|
27
27
|
a(d);
|
|
28
28
|
}
|
|
29
|
-
}, n = (
|
|
29
|
+
}, n = (r) => {
|
|
30
30
|
try {
|
|
31
|
-
i(t.throw(
|
|
31
|
+
i(t.throw(r));
|
|
32
32
|
} catch (d) {
|
|
33
33
|
a(d);
|
|
34
34
|
}
|
|
35
|
-
}, i = (
|
|
36
|
-
i((t = t.apply(
|
|
35
|
+
}, i = (r) => r.done ? s(r.value) : Promise.resolve(r.value).then(o, n);
|
|
36
|
+
i((t = t.apply(c, e)).next());
|
|
37
37
|
});
|
|
38
|
-
import { ActiveSelection as v, util as
|
|
39
|
-
import { create as
|
|
40
|
-
import
|
|
41
|
-
var
|
|
38
|
+
import { ActiveSelection as v, util as W, controlsUtils as Ne, InteractiveFabricObject as Oe, loadSVGFromURL as Le, FabricImage as Z, Point as X, Gradient as be, Rect as we, Circle as Te, Triangle as ke, Group as te, Canvas as Be, Pattern as _e } from "fabric";
|
|
39
|
+
import { create as xe } from "jsondiffpatch";
|
|
40
|
+
import Re from "diff-match-patch";
|
|
41
|
+
var Ue = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict", A = function() {
|
|
42
42
|
for (var e = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : 21, t = "", s = crypto.getRandomValues(new Uint8Array(e |= 0)); e--; )
|
|
43
|
-
t +=
|
|
43
|
+
t += Ue[s[e] & 63];
|
|
44
44
|
return t;
|
|
45
45
|
};
|
|
46
|
-
class
|
|
46
|
+
class P {
|
|
47
47
|
/**
|
|
48
48
|
* Конструктор принимает редактор и опции.
|
|
49
49
|
* @param params
|
|
@@ -61,7 +61,7 @@ class Y {
|
|
|
61
61
|
* @param params.options.adaptCanvasToContainerOnResize — адаптировать канвас к размерам контейнера при изменении размеров окна
|
|
62
62
|
*/
|
|
63
63
|
constructor({ editor: e, options: t = {} }) {
|
|
64
|
-
this.isDragging = !1, this.lastMouseX = 0, this.lastMouseY = 0, this.isUndoRedoKeyPressed = !1, this.isSpacePressed = !1, this.savedSelection = [], this.canvasDragging = !1, this.mouseWheelZooming = !1, this.bringToFrontOnSelection = !1, this.resetObjectFitByDoubleClick = !1, this.copyObjectsByHotkey = !1, this.pasteImageFromClipboard = !1, this.undoRedoByHotKeys = !1, this.selectAllByHotkey = !1, this.deleteObjectsByHotkey = !1, this.adaptCanvasToContainerOnResize = !1, this.editor = e, this.canvas = e.canvas, this.options = t, this.handleContainerResizeBound =
|
|
64
|
+
this.isDragging = !1, this.lastMouseX = 0, this.lastMouseY = 0, this.isUndoRedoKeyPressed = !1, this.isSpacePressed = !1, this.savedSelection = [], this.canvasDragging = !1, this.mouseWheelZooming = !1, this.bringToFrontOnSelection = !1, this.resetObjectFitByDoubleClick = !1, this.copyObjectsByHotkey = !1, this.pasteImageFromClipboard = !1, this.undoRedoByHotKeys = !1, this.selectAllByHotkey = !1, this.deleteObjectsByHotkey = !1, this.adaptCanvasToContainerOnResize = !1, this.editor = e, this.canvas = e.canvas, this.options = t, this.handleContainerResizeBound = P.debounce(this.handleContainerResize.bind(this), 500), this.handleCopyEventBound = this.handleCopyEvent.bind(this), this.handlePasteEventBound = this.handlePasteEvent.bind(this), this.handleUndoRedoEventBound = this.handleUndoRedoEvent.bind(this), this.handleUndoRedoKeyUpBound = this.handleUndoRedoKeyUp.bind(this), this.handleSelectAllEventBound = this.handleSelectAllEvent.bind(this), this.handleDeleteObjectsEventBound = this.handleDeleteObjectsEvent.bind(this), this.handleSpaceKeyDownBound = this.handleSpaceKeyDown.bind(this), this.handleSpaceKeyUpBound = this.handleSpaceKeyUp.bind(this), this.handleObjectModifiedHistoryBound = P.debounce(this.handleObjectModifiedHistory.bind(this), 300), this.handleObjectRotatingHistoryBound = P.debounce(this.handleObjectRotatingHistory.bind(this), 300), this.handleObjectAddedHistoryBound = this.handleObjectAddedHistory.bind(this), this.handleObjectRemovedHistoryBound = this.handleObjectRemovedHistory.bind(this), this.handleOverlayUpdateBound = this.handleOverlayUpdate.bind(this), this.handleBackgroundUpdateBound = this.handleBackgroundUpdate.bind(this), this.handleCanvasDragStartBound = this.handleCanvasDragStart.bind(this), this.handleCanvasDraggingBound = this.handleCanvasDragging.bind(this), this.handleCanvasDragEndBound = this.handleCanvasDragEnd.bind(this), this.handleMouseWheelZoomBound = this.handleMouseWheelZoom.bind(this), this.handleBringToFrontBound = this.handleBringToFront.bind(this), this.handleResetObjectFitBound = this.handleResetObjectFit.bind(this), this.handleLockedSelectionBound = this._filterLockedSelection.bind(this), this.init();
|
|
65
65
|
}
|
|
66
66
|
/**
|
|
67
67
|
* Инициализация всех обработчиков согласно опциям.
|
|
@@ -75,11 +75,11 @@ class Y {
|
|
|
75
75
|
copyObjectsByHotkey: o,
|
|
76
76
|
pasteImageFromClipboard: n,
|
|
77
77
|
undoRedoByHotKeys: i,
|
|
78
|
-
selectAllByHotkey:
|
|
78
|
+
selectAllByHotkey: r,
|
|
79
79
|
deleteObjectsByHotkey: d,
|
|
80
80
|
resetObjectFitByDoubleClick: h
|
|
81
81
|
} = this.options;
|
|
82
|
-
t && (this.canvas.on("mouse:down", this.handleCanvasDragStartBound), this.canvas.on("mouse:move", this.handleCanvasDraggingBound), this.canvas.on("mouse:up", this.handleCanvasDragEndBound), document.addEventListener("keydown", this.handleSpaceKeyDownBound, { capture: !0 }), document.addEventListener("keyup", this.handleSpaceKeyUpBound, { capture: !0 })), s && this.canvas.on("mouse:wheel", this.handleMouseWheelZoomBound), a && (this.canvas.on("selection:created", this.handleBringToFrontBound), this.canvas.on("selection:updated", this.handleBringToFrontBound)), h && this.canvas.on("mouse:dblclick", this.handleResetObjectFitBound), e && window.addEventListener("resize", this.handleContainerResizeBound, { capture: !0 }), o && document.addEventListener("keydown", this.handleCopyEventBound, { capture: !0 }), n && document.addEventListener("paste", this.handlePasteEventBound, { capture: !0 }), i && (document.addEventListener("keydown", this.handleUndoRedoEventBound, { capture: !0 }), document.addEventListener("keyup", this.handleUndoRedoKeyUpBound, { capture: !0 })),
|
|
82
|
+
t && (this.canvas.on("mouse:down", this.handleCanvasDragStartBound), this.canvas.on("mouse:move", this.handleCanvasDraggingBound), this.canvas.on("mouse:up", this.handleCanvasDragEndBound), document.addEventListener("keydown", this.handleSpaceKeyDownBound, { capture: !0 }), document.addEventListener("keyup", this.handleSpaceKeyUpBound, { capture: !0 })), s && this.canvas.on("mouse:wheel", this.handleMouseWheelZoomBound), a && (this.canvas.on("selection:created", this.handleBringToFrontBound), this.canvas.on("selection:updated", this.handleBringToFrontBound)), h && this.canvas.on("mouse:dblclick", this.handleResetObjectFitBound), e && window.addEventListener("resize", this.handleContainerResizeBound, { capture: !0 }), o && document.addEventListener("keydown", this.handleCopyEventBound, { capture: !0 }), n && document.addEventListener("paste", this.handlePasteEventBound, { capture: !0 }), i && (document.addEventListener("keydown", this.handleUndoRedoEventBound, { capture: !0 }), document.addEventListener("keyup", this.handleUndoRedoKeyUpBound, { capture: !0 })), r && document.addEventListener("keydown", this.handleSelectAllEventBound, { capture: !0 }), d && document.addEventListener("keydown", this.handleDeleteObjectsEventBound, { capture: !0 }), this.canvas.on("object:modified", this.handleObjectModifiedHistoryBound), this.canvas.on("object:rotating", this.handleObjectRotatingHistoryBound), this.canvas.on("object:added", this.handleObjectAddedHistoryBound), this.canvas.on("object:removed", this.handleObjectRemovedHistoryBound), this.canvas.on("object:added", this.handleOverlayUpdateBound), this.canvas.on("selection:created", this.handleOverlayUpdateBound), this.canvas.on("selection:created", this.handleLockedSelectionBound), this.canvas.on("selection:updated", this.handleLockedSelectionBound), this.canvas.on("object:added", this.handleBackgroundUpdateBound), this.canvas.on("selection:created", this.handleBackgroundUpdateBound);
|
|
83
83
|
}
|
|
84
84
|
/**
|
|
85
85
|
* При массовом выделении объектов удаляем из него залоченные.
|
|
@@ -175,7 +175,7 @@ class Y {
|
|
|
175
175
|
* @param event.code — код клавиши
|
|
176
176
|
*/
|
|
177
177
|
handleUndoRedoEvent(e) {
|
|
178
|
-
return
|
|
178
|
+
return j(this, null, function* () {
|
|
179
179
|
const { ctrlKey: t, metaKey: s, code: a, repeat: o } = e;
|
|
180
180
|
this._shouldIgnoreKeyboardEvent(e) || !t && !s || o || !/Mac/i.test(navigator.userAgent) && this.isUndoRedoKeyPressed || (a === "KeyZ" ? (e.preventDefault(), this.isUndoRedoKeyPressed = !0, yield this.editor.historyManager.undo()) : a === "KeyY" && (e.preventDefault(), this.isUndoRedoKeyPressed = !0, yield this.editor.historyManager.redo()));
|
|
181
181
|
});
|
|
@@ -336,13 +336,13 @@ class Y {
|
|
|
336
336
|
}
|
|
337
337
|
const o = window.getSelection();
|
|
338
338
|
if (o && !o.isCollapsed && o.rangeCount > 0) {
|
|
339
|
-
let
|
|
340
|
-
|
|
339
|
+
let r = o.getRangeAt(0).commonAncestorContainer;
|
|
340
|
+
r.nodeType === Node.TEXT_NODE && (r = r.parentElement);
|
|
341
341
|
const { keyboardIgnoreSelectors: d } = this.options;
|
|
342
|
-
if (d != null && d.length &&
|
|
342
|
+
if (d != null && d.length && r)
|
|
343
343
|
for (const h of d)
|
|
344
344
|
try {
|
|
345
|
-
const l =
|
|
345
|
+
const l = r;
|
|
346
346
|
if (l.matches && l.matches(h) || l.closest && l.closest(h))
|
|
347
347
|
return !0;
|
|
348
348
|
} catch (l) {
|
|
@@ -372,7 +372,7 @@ class Y {
|
|
|
372
372
|
};
|
|
373
373
|
}
|
|
374
374
|
}
|
|
375
|
-
class
|
|
375
|
+
class ze {
|
|
376
376
|
/**
|
|
377
377
|
* Класс для динамической загрузки внешних модулей.
|
|
378
378
|
*/
|
|
@@ -390,21 +390,21 @@ class Re {
|
|
|
390
390
|
return this.loaders[e] ? (this.cache.has(e) || this.cache.set(e, this.loaders[e]()), this.cache.get(e)) : Promise.reject(new Error(`Unknown module "${e}"`));
|
|
391
391
|
}
|
|
392
392
|
}
|
|
393
|
-
function
|
|
393
|
+
function He(c) {
|
|
394
394
|
return new Worker(
|
|
395
395
|
"" + new URL("assets/worker-CN39s7P7.js", import.meta.url).href,
|
|
396
396
|
{
|
|
397
|
-
name:
|
|
397
|
+
name: c == null ? void 0 : c.name
|
|
398
398
|
}
|
|
399
399
|
);
|
|
400
400
|
}
|
|
401
|
-
class
|
|
401
|
+
class Ze {
|
|
402
402
|
/**
|
|
403
403
|
* @param scriptUrl — URL скрипта воркера.
|
|
404
404
|
* По-умолчанию использует DefaultWorker из соседнего файла
|
|
405
405
|
*/
|
|
406
406
|
constructor(e) {
|
|
407
|
-
e ? this.worker = new Worker(e, { type: "module" }) : this.worker = new
|
|
407
|
+
e ? this.worker = new Worker(e, { type: "module" }) : this.worker = new He(), this._callbacks = /* @__PURE__ */ new Map(), this.worker.onmessage = this._handleMessage.bind(this);
|
|
408
408
|
}
|
|
409
409
|
/**
|
|
410
410
|
* Обработчик сообщений от воркера
|
|
@@ -444,50 +444,50 @@ class ze {
|
|
|
444
444
|
this.worker.terminate();
|
|
445
445
|
}
|
|
446
446
|
}
|
|
447
|
-
const N = 12,
|
|
448
|
-
function
|
|
449
|
-
const o = N, n =
|
|
450
|
-
|
|
447
|
+
const N = 12, Ye = 2, se = 8, ae = 20, Pe = 100, oe = 20, ne = 8, We = 100, Q = 32, ie = 1, Fe = "#2B2D33", re = "#3D8BF4", ce = "#FFFFFF";
|
|
448
|
+
function G(c, e, t, s, a) {
|
|
449
|
+
const o = N, n = Ye;
|
|
450
|
+
c.save(), c.translate(e, t), c.rotate(W.degreesToRadians(a.angle)), c.fillStyle = ce, c.strokeStyle = re, c.lineWidth = ie, c.beginPath(), c.roundRect(-o / 2, -o / 2, o, o, n), c.fill(), c.stroke(), c.restore();
|
|
451
451
|
}
|
|
452
|
-
function
|
|
453
|
-
const o =
|
|
454
|
-
|
|
452
|
+
function je(c, e, t, s, a) {
|
|
453
|
+
const o = se, n = ae, i = Pe;
|
|
454
|
+
c.save(), c.translate(e, t), c.rotate(W.degreesToRadians(a.angle)), c.fillStyle = ce, c.strokeStyle = re, c.lineWidth = ie, c.beginPath(), c.roundRect(-o / 2, -n / 2, o, n, i), c.fill(), c.stroke(), c.restore();
|
|
455
455
|
}
|
|
456
|
-
function
|
|
457
|
-
const o =
|
|
458
|
-
|
|
456
|
+
function pe(c, e, t, s, a) {
|
|
457
|
+
const o = oe, n = ne, i = We;
|
|
458
|
+
c.save(), c.translate(e, t), c.rotate(W.degreesToRadians(a.angle)), c.fillStyle = ce, c.strokeStyle = re, c.lineWidth = ie, c.beginPath(), c.roundRect(-o / 2, -n / 2, o, n, i), c.fill(), c.stroke(), c.restore();
|
|
459
459
|
}
|
|
460
|
-
const
|
|
461
|
-
|
|
462
|
-
function
|
|
463
|
-
const n =
|
|
464
|
-
|
|
460
|
+
const Ve = "", ve = new Image();
|
|
461
|
+
ve.src = Ve;
|
|
462
|
+
function Ge(c, e, t, s, a) {
|
|
463
|
+
const n = Q / 2;
|
|
464
|
+
c.save(), c.translate(e, t), c.rotate(W.degreesToRadians(a.angle)), c.fillStyle = Fe, c.beginPath(), c.arc(0, 0, n, 0, 2 * Math.PI), c.fill(), c.drawImage(ve, -n / 2, -n / 2, n, n), c.restore();
|
|
465
465
|
}
|
|
466
|
-
const
|
|
466
|
+
const Xe = {
|
|
467
467
|
// Угловые точки
|
|
468
468
|
tl: {
|
|
469
|
-
render:
|
|
469
|
+
render: G,
|
|
470
470
|
sizeX: N,
|
|
471
471
|
sizeY: N,
|
|
472
472
|
offsetX: 0,
|
|
473
473
|
offsetY: 0
|
|
474
474
|
},
|
|
475
475
|
tr: {
|
|
476
|
-
render:
|
|
476
|
+
render: G,
|
|
477
477
|
sizeX: N,
|
|
478
478
|
sizeY: N,
|
|
479
479
|
offsetX: 0,
|
|
480
480
|
offsetY: 0
|
|
481
481
|
},
|
|
482
482
|
bl: {
|
|
483
|
-
render:
|
|
483
|
+
render: G,
|
|
484
484
|
sizeX: N,
|
|
485
485
|
sizeY: N,
|
|
486
486
|
offsetX: 0,
|
|
487
487
|
offsetY: 0
|
|
488
488
|
},
|
|
489
489
|
br: {
|
|
490
|
-
render:
|
|
490
|
+
render: G,
|
|
491
491
|
sizeX: N,
|
|
492
492
|
sizeY: N,
|
|
493
493
|
offsetX: 0,
|
|
@@ -495,61 +495,61 @@ const Ve = {
|
|
|
495
495
|
},
|
|
496
496
|
// Середина вертикалей
|
|
497
497
|
ml: {
|
|
498
|
-
render:
|
|
499
|
-
sizeX:
|
|
500
|
-
sizeY:
|
|
498
|
+
render: je,
|
|
499
|
+
sizeX: se,
|
|
500
|
+
sizeY: ae,
|
|
501
501
|
offsetX: 0,
|
|
502
502
|
offsetY: 0
|
|
503
503
|
},
|
|
504
504
|
mr: {
|
|
505
|
-
render:
|
|
506
|
-
sizeX:
|
|
507
|
-
sizeY:
|
|
505
|
+
render: je,
|
|
506
|
+
sizeX: se,
|
|
507
|
+
sizeY: ae,
|
|
508
508
|
offsetX: 0,
|
|
509
509
|
offsetY: 0
|
|
510
510
|
},
|
|
511
511
|
// Середина горизонталей
|
|
512
512
|
mt: {
|
|
513
|
-
render:
|
|
514
|
-
sizeX:
|
|
515
|
-
sizeY:
|
|
513
|
+
render: pe,
|
|
514
|
+
sizeX: oe,
|
|
515
|
+
sizeY: ne,
|
|
516
516
|
offsetX: 0,
|
|
517
517
|
offsetY: 0
|
|
518
518
|
},
|
|
519
519
|
mb: {
|
|
520
|
-
render:
|
|
521
|
-
sizeX:
|
|
522
|
-
sizeY:
|
|
520
|
+
render: pe,
|
|
521
|
+
sizeX: oe,
|
|
522
|
+
sizeY: ne,
|
|
523
523
|
offsetX: 0,
|
|
524
524
|
offsetY: 0
|
|
525
525
|
},
|
|
526
526
|
// Специальный «rotate» контрол
|
|
527
527
|
mtr: {
|
|
528
|
-
render:
|
|
529
|
-
sizeX:
|
|
530
|
-
sizeY:
|
|
528
|
+
render: Ge,
|
|
529
|
+
sizeX: Q,
|
|
530
|
+
sizeY: Q,
|
|
531
531
|
offsetX: 0,
|
|
532
|
-
offsetY: -
|
|
532
|
+
offsetY: -Q
|
|
533
533
|
}
|
|
534
534
|
};
|
|
535
|
-
class
|
|
535
|
+
class Qe {
|
|
536
536
|
static apply() {
|
|
537
|
-
const e =
|
|
538
|
-
Object.entries(
|
|
537
|
+
const e = Ne.createObjectDefaultControls();
|
|
538
|
+
Object.entries(Xe).forEach(([t, s]) => {
|
|
539
539
|
Object.assign(e[t], {
|
|
540
540
|
render: s.render,
|
|
541
541
|
sizeX: s.sizeX,
|
|
542
542
|
sizeY: s.sizeY,
|
|
543
543
|
offsetX: s.offsetX,
|
|
544
544
|
offsetY: s.offsetY
|
|
545
|
-
}), t === "mtr" && (e[t].cursorStyle = "grab", e[t].mouseDownHandler = (o, n, i,
|
|
545
|
+
}), t === "mtr" && (e[t].cursorStyle = "grab", e[t].mouseDownHandler = (o, n, i, r) => {
|
|
546
546
|
var h;
|
|
547
547
|
(h = n.target.canvas) == null || h.setCursor("grabbing");
|
|
548
548
|
});
|
|
549
|
-
}),
|
|
549
|
+
}), Oe.ownDefaults.controls = e;
|
|
550
550
|
}
|
|
551
551
|
}
|
|
552
|
-
const
|
|
552
|
+
const Ke = "", $e = "", Je = "", qe = "", et = "", tt = "", st = "", at = "", Y = {
|
|
553
553
|
style: {
|
|
554
554
|
position: "absolute",
|
|
555
555
|
display: "none",
|
|
@@ -616,54 +616,54 @@ const Xe = "
|
|
|
616
616
|
],
|
|
617
617
|
offsetTop: 50,
|
|
618
618
|
icons: {
|
|
619
|
-
copyPaste:
|
|
620
|
-
delete:
|
|
621
|
-
lock:
|
|
622
|
-
unlock:
|
|
623
|
-
bringToFront:
|
|
624
|
-
sendToBack:
|
|
625
|
-
bringForward:
|
|
626
|
-
sendBackwards:
|
|
619
|
+
copyPaste: Ke,
|
|
620
|
+
delete: at,
|
|
621
|
+
lock: $e,
|
|
622
|
+
unlock: Je,
|
|
623
|
+
bringToFront: tt,
|
|
624
|
+
sendToBack: st,
|
|
625
|
+
bringForward: qe,
|
|
626
|
+
sendBackwards: et
|
|
627
627
|
},
|
|
628
628
|
handlers: {
|
|
629
|
-
copyPaste: (
|
|
630
|
-
|
|
629
|
+
copyPaste: (c) => j(null, null, function* () {
|
|
630
|
+
c.clipboardManager.copyPaste();
|
|
631
631
|
}),
|
|
632
|
-
delete: (
|
|
633
|
-
|
|
632
|
+
delete: (c) => {
|
|
633
|
+
c.deletionManager.deleteSelectedObjects();
|
|
634
634
|
},
|
|
635
|
-
lock: (
|
|
636
|
-
|
|
635
|
+
lock: (c) => {
|
|
636
|
+
c.objectLockManager.lockObject();
|
|
637
637
|
},
|
|
638
|
-
unlock: (
|
|
639
|
-
|
|
638
|
+
unlock: (c) => {
|
|
639
|
+
c.objectLockManager.unlockObject();
|
|
640
640
|
},
|
|
641
|
-
bringForward: (
|
|
642
|
-
|
|
641
|
+
bringForward: (c) => {
|
|
642
|
+
c.layerManager.bringForward();
|
|
643
643
|
},
|
|
644
|
-
bringToFront: (
|
|
645
|
-
|
|
644
|
+
bringToFront: (c) => {
|
|
645
|
+
c.layerManager.bringToFront();
|
|
646
646
|
},
|
|
647
|
-
sendToBack: (
|
|
648
|
-
|
|
647
|
+
sendToBack: (c) => {
|
|
648
|
+
c.layerManager.sendToBack();
|
|
649
649
|
},
|
|
650
|
-
sendBackwards: (
|
|
651
|
-
|
|
650
|
+
sendBackwards: (c) => {
|
|
651
|
+
c.layerManager.sendBackwards();
|
|
652
652
|
}
|
|
653
653
|
}
|
|
654
654
|
};
|
|
655
|
-
class
|
|
655
|
+
class ot {
|
|
656
656
|
constructor({ editor: e }) {
|
|
657
657
|
this.currentTarget = null, this.currentLocked = !1, this.isTransforming = !1, this.editor = e, this.canvas = e.canvas, this.options = e.options, this._initToolbar();
|
|
658
658
|
}
|
|
659
659
|
_initToolbar() {
|
|
660
660
|
if (!this.options.showToolbar) return;
|
|
661
661
|
const e = this.options.toolbar || {};
|
|
662
|
-
this.config =
|
|
663
|
-
style: I(I({},
|
|
664
|
-
btnStyle: I(I({},
|
|
665
|
-
icons: I(I({},
|
|
666
|
-
handlers: I(I({},
|
|
662
|
+
this.config = me(I(I({}, Y), e), {
|
|
663
|
+
style: I(I({}, Y.style), e.style || {}),
|
|
664
|
+
btnStyle: I(I({}, Y.btnStyle), e.btnStyle || {}),
|
|
665
|
+
icons: I(I({}, Y.icons), e.icons || {}),
|
|
666
|
+
handlers: I(I({}, Y.handlers), e.handlers || {})
|
|
667
667
|
}), this.currentTarget = null, this.currentLocked = !1, this.isTransforming = !1, this._onMouseDown = this._handleMouseDown.bind(this), this._onObjectMoving = this._startTransform.bind(this), this._onObjectScaling = this._startTransform.bind(this), this._onObjectRotating = this._startTransform.bind(this), this._onMouseUp = this._endTransform.bind(this), this._onObjectModified = this._endTransform.bind(this), this._onSelectionChange = this._updateToolbar.bind(this), this._onSelectionClear = () => {
|
|
668
668
|
this.el.style.display = "none";
|
|
669
669
|
}, this._createDOM(), this._bindEvents();
|
|
@@ -690,13 +690,13 @@ class st {
|
|
|
690
690
|
_renderButtons(e) {
|
|
691
691
|
this.el.innerHTML = "";
|
|
692
692
|
for (const t of e) {
|
|
693
|
-
const { name: s, handle: a } = t, { icons: o = {}, btnStyle: n, handlers: i = {} } = this.config,
|
|
694
|
-
|
|
693
|
+
const { name: s, handle: a } = t, { icons: o = {}, btnStyle: n, handlers: i = {} } = this.config, r = document.createElement("button");
|
|
694
|
+
r.innerHTML = o[a] ? `<img src="${o[a]}" title="${s}" />` : s, Object.assign(r.style, n), r.onclick = () => {
|
|
695
695
|
var d;
|
|
696
696
|
return (d = i[a]) == null ? void 0 : d.call(i, this.editor);
|
|
697
|
-
},
|
|
697
|
+
}, r.onmousedown = (d) => {
|
|
698
698
|
d.stopPropagation(), d.preventDefault();
|
|
699
|
-
},
|
|
699
|
+
}, r.ondragstart = (d) => d.preventDefault(), this.el.appendChild(r);
|
|
700
700
|
}
|
|
701
701
|
}
|
|
702
702
|
/**
|
|
@@ -754,7 +754,7 @@ class st {
|
|
|
754
754
|
}
|
|
755
755
|
const { el: t, config: s, canvas: a } = this;
|
|
756
756
|
e.setCoords();
|
|
757
|
-
const o = a.getZoom(), [, , , , n, i] = a.viewportTransform, { x:
|
|
757
|
+
const o = a.getZoom(), [, , , , n, i] = a.viewportTransform, { x: r } = e.getCenterPoint(), { top: d, height: h } = e.getBoundingRect(), g = r * o + n - t.offsetWidth / 2, u = s.offsetTop || 0, M = (d + h) * o + i + u;
|
|
758
758
|
Object.assign(t.style, {
|
|
759
759
|
left: `${g}px`,
|
|
760
760
|
top: `${M}px`,
|
|
@@ -768,7 +768,7 @@ class st {
|
|
|
768
768
|
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();
|
|
769
769
|
}
|
|
770
770
|
}
|
|
771
|
-
class
|
|
771
|
+
class K {
|
|
772
772
|
constructor({ editor: e }) {
|
|
773
773
|
this.editor = e, this.canvas = e.canvas, this._historySuspendCount = 0, this.baseState = null, this.patches = [], this.currentIndex = 0, this.maxHistoryLength = e.options.maxHistoryLength, this.totalChangesCount = 0, this.baseStateChangesCount = 0, this._createDiffPatcher();
|
|
774
774
|
}
|
|
@@ -780,7 +780,7 @@ class Q {
|
|
|
780
780
|
return this.patches[this.currentIndex - 1] || null;
|
|
781
781
|
}
|
|
782
782
|
_createDiffPatcher() {
|
|
783
|
-
this.diffPatcher =
|
|
783
|
+
this.diffPatcher = xe({
|
|
784
784
|
objectHash(e) {
|
|
785
785
|
const t = e;
|
|
786
786
|
return [
|
|
@@ -806,7 +806,7 @@ class Q {
|
|
|
806
806
|
includeValueOnMove: !1
|
|
807
807
|
},
|
|
808
808
|
textDiff: {
|
|
809
|
-
diffMatchPatch:
|
|
809
|
+
diffMatchPatch: Re,
|
|
810
810
|
minLength: 60
|
|
811
811
|
}
|
|
812
812
|
});
|
|
@@ -908,15 +908,15 @@ class Q {
|
|
|
908
908
|
* @fires editor:history-state-loaded
|
|
909
909
|
*/
|
|
910
910
|
loadStateFromFullState(e) {
|
|
911
|
-
return
|
|
911
|
+
return j(this, null, function* () {
|
|
912
912
|
if (!e) return;
|
|
913
913
|
console.log("loadStateFromFullState fullState", e);
|
|
914
914
|
const { canvas: t, canvasManager: s, interactionBlocker: a, backgroundManager: o } = this.editor, { width: n, height: i } = t;
|
|
915
|
-
a.overlayMask = null,
|
|
916
|
-
|
|
915
|
+
a.overlayMask = null, K._serializeCustomData(e), yield t.loadFromJSON(e, (l, g) => {
|
|
916
|
+
K._deserializeCustomData(l, g);
|
|
917
917
|
});
|
|
918
|
-
const
|
|
919
|
-
|
|
918
|
+
const r = t.getObjects().find((l) => l.id === "montage-area");
|
|
919
|
+
r && (this.editor.montageArea = r, (n !== t.getWidth() || i !== t.getHeight()) && s.updateCanvas());
|
|
920
920
|
const d = t.getObjects().find((l) => l.id === "overlay-mask");
|
|
921
921
|
d && (a.overlayMask = d, a.overlayMask.visible = !1);
|
|
922
922
|
const h = t.getObjects().find((l) => l.id === "background");
|
|
@@ -935,7 +935,7 @@ class Q {
|
|
|
935
935
|
* @fires editor:undo
|
|
936
936
|
*/
|
|
937
937
|
undo() {
|
|
938
|
-
return
|
|
938
|
+
return j(this, null, function* () {
|
|
939
939
|
if (!this.skipHistory) {
|
|
940
940
|
if (this.currentIndex <= 0) {
|
|
941
941
|
console.log("Нет предыдущих состояний для отмены.");
|
|
@@ -972,7 +972,7 @@ class Q {
|
|
|
972
972
|
* @fires editor:redo
|
|
973
973
|
*/
|
|
974
974
|
redo() {
|
|
975
|
-
return
|
|
975
|
+
return j(this, null, function* () {
|
|
976
976
|
if (!this.skipHistory) {
|
|
977
977
|
if (this.currentIndex >= this.patches.length) {
|
|
978
978
|
console.log("Нет состояний для повтора.");
|
|
@@ -1005,7 +1005,7 @@ class Q {
|
|
|
1005
1005
|
});
|
|
1006
1006
|
}
|
|
1007
1007
|
}
|
|
1008
|
-
const
|
|
1008
|
+
const nt = 0.1, it = 2, rt = 0.1, ct = 90, U = 16, z = 16, k = 4096, B = 4096, ye = "application/image-editor:";
|
|
1009
1009
|
class O {
|
|
1010
1010
|
constructor({ editor: e }) {
|
|
1011
1011
|
this.editor = e, this.options = e.options, this._createdBlobUrls = [], this.acceptContentTypes = this.editor.options.acceptContentTypes, this.acceptFormats = this.getAllowedFormatsFromContentTypes();
|
|
@@ -1023,7 +1023,7 @@ class O {
|
|
|
1023
1023
|
* @returns возвращает Promise с объектом изображения или null в случае ошибки
|
|
1024
1024
|
*/
|
|
1025
1025
|
importImage(e) {
|
|
1026
|
-
return
|
|
1026
|
+
return j(this, null, function* () {
|
|
1027
1027
|
const {
|
|
1028
1028
|
source: t,
|
|
1029
1029
|
scale: s = `image-${this.options.scaleType}`,
|
|
@@ -1033,20 +1033,20 @@ class O {
|
|
|
1033
1033
|
withoutSelection: i = !1
|
|
1034
1034
|
} = e;
|
|
1035
1035
|
if (!t) return null;
|
|
1036
|
-
const { canvas:
|
|
1036
|
+
const { canvas: r, montageArea: d, transformManager: h, historyManager: l, errorManager: g } = this.editor, u = yield this.getContentType(t), M = O.getFormatFromContentType(u), { acceptContentTypes: m, acceptFormats: p } = this;
|
|
1037
1037
|
if (!this.isAllowedContentType(u)) {
|
|
1038
|
-
const
|
|
1038
|
+
const f = `Неверный contentType для изображения: ${u}. Ожидается один из: ${this.acceptContentTypes.join(", ")}.`;
|
|
1039
1039
|
return g.emitError({
|
|
1040
1040
|
origin: "ImageManager",
|
|
1041
1041
|
method: "importImage",
|
|
1042
1042
|
code: "INVALID_CONTENT_TYPE",
|
|
1043
|
-
message:
|
|
1043
|
+
message: f,
|
|
1044
1044
|
data: {
|
|
1045
1045
|
source: t,
|
|
1046
1046
|
format: M,
|
|
1047
1047
|
contentType: u,
|
|
1048
1048
|
acceptContentTypes: m,
|
|
1049
|
-
acceptFormats:
|
|
1049
|
+
acceptFormats: p,
|
|
1050
1050
|
fromClipboard: o,
|
|
1051
1051
|
isBackground: n,
|
|
1052
1052
|
withoutSelection: i
|
|
@@ -1055,12 +1055,12 @@ class O {
|
|
|
1055
1055
|
}
|
|
1056
1056
|
l.suspendHistory();
|
|
1057
1057
|
try {
|
|
1058
|
-
let
|
|
1058
|
+
let f, b;
|
|
1059
1059
|
if (t instanceof File)
|
|
1060
|
-
|
|
1060
|
+
f = URL.createObjectURL(t);
|
|
1061
1061
|
else if (typeof t == "string") {
|
|
1062
1062
|
const D = yield (yield fetch(t, { mode: "cors" })).blob();
|
|
1063
|
-
|
|
1063
|
+
f = URL.createObjectURL(D);
|
|
1064
1064
|
} else
|
|
1065
1065
|
return g.emitError({
|
|
1066
1066
|
origin: "ImageManager",
|
|
@@ -1072,37 +1072,37 @@ class O {
|
|
|
1072
1072
|
format: M,
|
|
1073
1073
|
contentType: u,
|
|
1074
1074
|
acceptContentTypes: m,
|
|
1075
|
-
acceptFormats:
|
|
1075
|
+
acceptFormats: p,
|
|
1076
1076
|
fromClipboard: o,
|
|
1077
1077
|
isBackground: n,
|
|
1078
1078
|
withoutSelection: i
|
|
1079
1079
|
}
|
|
1080
1080
|
}), null;
|
|
1081
|
-
if (this._createdBlobUrls.push(
|
|
1082
|
-
const C = yield
|
|
1083
|
-
b =
|
|
1081
|
+
if (this._createdBlobUrls.push(f), M === "svg") {
|
|
1082
|
+
const C = yield Le(f);
|
|
1083
|
+
b = W.groupSVGElements(C.objects, C.options);
|
|
1084
1084
|
} else
|
|
1085
|
-
b = yield
|
|
1086
|
-
const { width: S, height:
|
|
1087
|
-
if (b instanceof
|
|
1085
|
+
b = yield Z.fromURL(f, { crossOrigin: "anonymous" });
|
|
1086
|
+
const { width: S, height: T } = b;
|
|
1087
|
+
if (b instanceof Z) {
|
|
1088
1088
|
const C = b.getElement();
|
|
1089
1089
|
let D = "";
|
|
1090
|
-
if (C instanceof HTMLImageElement ? D = C.src : C instanceof HTMLCanvasElement && (D = C.toDataURL()),
|
|
1091
|
-
const
|
|
1092
|
-
this._createdBlobUrls.push(
|
|
1093
|
-
} else if (
|
|
1094
|
-
const
|
|
1095
|
-
this._createdBlobUrls.push(
|
|
1090
|
+
if (C instanceof HTMLImageElement ? D = C.src : C instanceof HTMLCanvasElement && (D = C.toDataURL()), T > B || S > k) {
|
|
1091
|
+
const _ = yield this.resizeImageToBoundaries(D, "max"), L = URL.createObjectURL(_);
|
|
1092
|
+
this._createdBlobUrls.push(L), b = yield Z.fromURL(L, { crossOrigin: "anonymous" });
|
|
1093
|
+
} else if (T < z || S < U) {
|
|
1094
|
+
const _ = yield this.resizeImageToBoundaries(D, "min"), L = URL.createObjectURL(_);
|
|
1095
|
+
this._createdBlobUrls.push(L), b = yield Z.fromURL(L, { crossOrigin: "anonymous" });
|
|
1096
1096
|
}
|
|
1097
1097
|
}
|
|
1098
1098
|
if (b.set("id", `${b.type}-${A()}`), b.set("format", M), s === "scale-montage")
|
|
1099
1099
|
this.editor.canvasManager.scaleMontageAreaToImage({ object: b, withoutSave: !0 });
|
|
1100
1100
|
else {
|
|
1101
|
-
const { width: C, height: D } = d,
|
|
1102
|
-
s === "image-contain" &&
|
|
1101
|
+
const { width: C, height: D } = d, _ = this.calculateScaleFactor({ imageObject: b, scaleType: s });
|
|
1102
|
+
s === "image-contain" && _ < 1 ? h.fitObject({ object: b, type: "contain", withoutSave: !0 }) : s === "image-cover" && (S > C || T > D) && h.fitObject({ object: b, type: "cover", withoutSave: !0 });
|
|
1103
1103
|
}
|
|
1104
|
-
|
|
1105
|
-
const
|
|
1104
|
+
r.add(b), r.centerObject(b), i || r.setActiveObject(b), r.renderAll(), l.resumeHistory(), a || l.saveState();
|
|
1105
|
+
const H = {
|
|
1106
1106
|
image: b,
|
|
1107
1107
|
format: M,
|
|
1108
1108
|
contentType: u,
|
|
@@ -1113,13 +1113,13 @@ class O {
|
|
|
1113
1113
|
isBackground: n,
|
|
1114
1114
|
withoutSelection: i
|
|
1115
1115
|
};
|
|
1116
|
-
return
|
|
1117
|
-
} catch (
|
|
1116
|
+
return r.fire("editor:image-imported", H), H;
|
|
1117
|
+
} catch (f) {
|
|
1118
1118
|
return g.emitError({
|
|
1119
1119
|
origin: "ImageManager",
|
|
1120
1120
|
method: "importImage",
|
|
1121
1121
|
code: "IMPORT_FAILED",
|
|
1122
|
-
message: `Ошибка импорта изображения: ${
|
|
1122
|
+
message: `Ошибка импорта изображения: ${f.message}`,
|
|
1123
1123
|
data: {
|
|
1124
1124
|
source: t,
|
|
1125
1125
|
format: M,
|
|
@@ -1143,16 +1143,16 @@ class O {
|
|
|
1143
1143
|
* @returns возвращает Promise с Blob-объектом уменьшенного изображения
|
|
1144
1144
|
*/
|
|
1145
1145
|
resizeImageToBoundaries(e, t = "max") {
|
|
1146
|
-
return
|
|
1147
|
-
let s = `Размер изображения больше максимального размера канваса, поэтому оно будет уменьшено до максимальных размеров c сохранением пропорций: ${
|
|
1148
|
-
t === "min" && (s = `Размер изображения меньше минимального размера канваса, поэтому оно будет увеличено до минимальных размеров c сохранением пропорций: ${
|
|
1146
|
+
return j(this, null, function* () {
|
|
1147
|
+
let s = `Размер изображения больше максимального размера канваса, поэтому оно будет уменьшено до максимальных размеров c сохранением пропорций: ${k}x${B}`;
|
|
1148
|
+
t === "min" && (s = `Размер изображения меньше минимального размера канваса, поэтому оно будет увеличено до минимальных размеров c сохранением пропорций: ${U}x${z}`);
|
|
1149
1149
|
const a = {
|
|
1150
1150
|
dataURL: e,
|
|
1151
1151
|
sizeType: t,
|
|
1152
|
-
maxWidth:
|
|
1153
|
-
maxHeight:
|
|
1154
|
-
minWidth:
|
|
1155
|
-
minHeight:
|
|
1152
|
+
maxWidth: k,
|
|
1153
|
+
maxHeight: B,
|
|
1154
|
+
minWidth: U,
|
|
1155
|
+
minHeight: z
|
|
1156
1156
|
};
|
|
1157
1157
|
return this.editor.errorManager.emitWarning({
|
|
1158
1158
|
origin: "ImageManager",
|
|
@@ -1175,26 +1175,30 @@ class O {
|
|
|
1175
1175
|
* @fires editor:canvas-exported
|
|
1176
1176
|
*/
|
|
1177
1177
|
exportCanvasAsImageFile() {
|
|
1178
|
-
return
|
|
1178
|
+
return j(this, arguments, function* (e = {}) {
|
|
1179
1179
|
const {
|
|
1180
1180
|
fileName: t = "image.png",
|
|
1181
1181
|
contentType: s = "image/png",
|
|
1182
1182
|
exportAsBase64: a = !1,
|
|
1183
1183
|
exportAsBlob: o = !1
|
|
1184
|
-
} = e, { canvas: n, montageArea: i, workerManager:
|
|
1184
|
+
} = e, { canvas: n, montageArea: i, workerManager: r, interactionBlocker: d } = this.editor;
|
|
1185
1185
|
try {
|
|
1186
|
-
const
|
|
1186
|
+
const h = s === "application/pdf", l = h ? "image/jpg" : s, g = O.getFormatFromContentType(l);
|
|
1187
1187
|
i.setCoords();
|
|
1188
|
-
const { left:
|
|
1189
|
-
f.enableRetinaScaling = !1, ["image/jpg", "image/jpeg"].includes(
|
|
1190
|
-
const
|
|
1191
|
-
|
|
1192
|
-
|
|
1193
|
-
|
|
1194
|
-
|
|
1188
|
+
const { left: u, top: M, width: m, height: p } = i.getBoundingRect(), f = yield n.clone(["id", "format", "locked"]);
|
|
1189
|
+
f.enableRetinaScaling = !1, ["image/jpg", "image/jpeg"].includes(l) && (f.backgroundColor = "#ffffff");
|
|
1190
|
+
const b = f.getObjects().find((y) => y.id === i.id);
|
|
1191
|
+
if (b && (b.visible = !1), d != null && d.isBlocked) {
|
|
1192
|
+
const y = f.getObjects().find((w) => w.id === d.overlayMask.id);
|
|
1193
|
+
y && (y.visible = !1);
|
|
1194
|
+
}
|
|
1195
|
+
f.viewportTransform = [1, 0, 0, 1, -u, -M], f.setDimensions({ width: m, height: p }, { backstoreOnly: !0 }), f.renderAll();
|
|
1196
|
+
const S = f.getObjects().filter((y) => y.format).every((y) => y.format === "svg");
|
|
1197
|
+
if (g === "svg" && S) {
|
|
1198
|
+
const y = f.toSVG();
|
|
1195
1199
|
f.dispose();
|
|
1196
1200
|
const E = {
|
|
1197
|
-
image: O._exportSVGStringAsFile(
|
|
1201
|
+
image: O._exportSVGStringAsFile(y, {
|
|
1198
1202
|
exportAsBase64: a,
|
|
1199
1203
|
exportAsBlob: o,
|
|
1200
1204
|
fileName: t
|
|
@@ -1205,70 +1209,70 @@ class O {
|
|
|
1205
1209
|
};
|
|
1206
1210
|
return n.fire("editor:canvas-exported", E), E;
|
|
1207
1211
|
}
|
|
1208
|
-
const
|
|
1212
|
+
const T = yield new Promise((y, w) => {
|
|
1209
1213
|
f.getElement().toBlob((E) => {
|
|
1210
|
-
E ?
|
|
1214
|
+
E ? y(E) : w(new Error("Failed to create Blob from canvas"));
|
|
1211
1215
|
});
|
|
1212
1216
|
});
|
|
1213
1217
|
if (f.dispose(), o) {
|
|
1214
|
-
const
|
|
1215
|
-
image:
|
|
1216
|
-
format:
|
|
1217
|
-
contentType:
|
|
1218
|
+
const y = {
|
|
1219
|
+
image: T,
|
|
1220
|
+
format: g,
|
|
1221
|
+
contentType: l,
|
|
1218
1222
|
fileName: t
|
|
1219
1223
|
};
|
|
1220
|
-
return n.fire("editor:canvas-exported",
|
|
1224
|
+
return n.fire("editor:canvas-exported", y), y;
|
|
1221
1225
|
}
|
|
1222
|
-
const
|
|
1226
|
+
const H = yield createImageBitmap(T), C = yield r.post(
|
|
1223
1227
|
"toDataURL",
|
|
1224
|
-
{ format:
|
|
1225
|
-
[
|
|
1228
|
+
{ format: g, quality: 1, bitmap: H },
|
|
1229
|
+
[H]
|
|
1226
1230
|
);
|
|
1227
|
-
if (
|
|
1228
|
-
const
|
|
1229
|
-
orientation:
|
|
1231
|
+
if (h) {
|
|
1232
|
+
const w = m * 0.264583, E = p * 0.264583, Ae = (yield this.editor.moduleLoader.loadModule("jspdf")).jsPDF, ee = new Ae({
|
|
1233
|
+
orientation: w > E ? "landscape" : "portrait",
|
|
1230
1234
|
unit: "mm",
|
|
1231
|
-
format: [
|
|
1235
|
+
format: [w, E]
|
|
1232
1236
|
});
|
|
1233
|
-
if (
|
|
1234
|
-
const
|
|
1235
|
-
image:
|
|
1237
|
+
if (ee.addImage(String(C), "JPG", 0, 0, w, E), a) {
|
|
1238
|
+
const ge = {
|
|
1239
|
+
image: ee.output("datauristring"),
|
|
1236
1240
|
format: "pdf",
|
|
1237
1241
|
contentType: "application/pdf",
|
|
1238
1242
|
fileName: t
|
|
1239
1243
|
};
|
|
1240
|
-
return n.fire("editor:canvas-exported",
|
|
1244
|
+
return n.fire("editor:canvas-exported", ge), ge;
|
|
1241
1245
|
}
|
|
1242
|
-
const
|
|
1243
|
-
image: new File([
|
|
1246
|
+
const Ce = ee.output("blob"), he = {
|
|
1247
|
+
image: new File([Ce], t, { type: "application/pdf" }),
|
|
1244
1248
|
format: "pdf",
|
|
1245
1249
|
contentType: "application/pdf",
|
|
1246
1250
|
fileName: t
|
|
1247
1251
|
};
|
|
1248
|
-
return n.fire("editor:canvas-exported",
|
|
1252
|
+
return n.fire("editor:canvas-exported", he), he;
|
|
1249
1253
|
}
|
|
1250
1254
|
if (a) {
|
|
1251
|
-
const
|
|
1252
|
-
image:
|
|
1253
|
-
format:
|
|
1254
|
-
contentType:
|
|
1255
|
+
const y = {
|
|
1256
|
+
image: C,
|
|
1257
|
+
format: g,
|
|
1258
|
+
contentType: l,
|
|
1255
1259
|
fileName: t
|
|
1256
1260
|
};
|
|
1257
|
-
return n.fire("editor:canvas-exported",
|
|
1261
|
+
return n.fire("editor:canvas-exported", y), y;
|
|
1258
1262
|
}
|
|
1259
|
-
const
|
|
1260
|
-
image: new File([
|
|
1261
|
-
format:
|
|
1262
|
-
contentType:
|
|
1263
|
-
fileName:
|
|
1263
|
+
const D = g === "svg" && !S ? t.replace(/\.[^/.]+$/, ".png") : t, L = {
|
|
1264
|
+
image: new File([T], D, { type: l }),
|
|
1265
|
+
format: g,
|
|
1266
|
+
contentType: l,
|
|
1267
|
+
fileName: D
|
|
1264
1268
|
};
|
|
1265
1269
|
return n.fire("editor:canvas-exported", L), L;
|
|
1266
|
-
} catch (
|
|
1270
|
+
} catch (h) {
|
|
1267
1271
|
return this.editor.errorManager.emitError({
|
|
1268
1272
|
origin: "ImageManager",
|
|
1269
1273
|
method: "exportCanvasAsImageFile",
|
|
1270
1274
|
code: "IMAGE_EXPORT_FAILED",
|
|
1271
|
-
message: `Ошибка экспорта изображения: ${
|
|
1275
|
+
message: `Ошибка экспорта изображения: ${h.message}`,
|
|
1272
1276
|
data: { contentType: s, fileName: t, exportAsBase64: a, exportAsBlob: o }
|
|
1273
1277
|
}), null;
|
|
1274
1278
|
}
|
|
@@ -1286,14 +1290,14 @@ class O {
|
|
|
1286
1290
|
* @fires editor:object-exported
|
|
1287
1291
|
*/
|
|
1288
1292
|
exportObjectAsImageFile() {
|
|
1289
|
-
return
|
|
1293
|
+
return j(this, arguments, function* (e = {}) {
|
|
1290
1294
|
const {
|
|
1291
1295
|
object: t,
|
|
1292
1296
|
fileName: s = "image.png",
|
|
1293
1297
|
contentType: a = "image/png",
|
|
1294
1298
|
exportAsBase64: o = !1,
|
|
1295
1299
|
exportAsBlob: n = !1
|
|
1296
|
-
} = e, { canvas: i, workerManager:
|
|
1300
|
+
} = e, { canvas: i, workerManager: r } = this.editor, d = t || i.getActiveObject();
|
|
1297
1301
|
if (!d)
|
|
1298
1302
|
return this.editor.errorManager.emitError({
|
|
1299
1303
|
origin: "ImageManager",
|
|
@@ -1305,21 +1309,21 @@ class O {
|
|
|
1305
1309
|
try {
|
|
1306
1310
|
const h = O.getFormatFromContentType(a);
|
|
1307
1311
|
if (h === "svg") {
|
|
1308
|
-
const m = d.toSVG(),
|
|
1312
|
+
const m = d.toSVG(), p = O._exportSVGStringAsFile(m, {
|
|
1309
1313
|
exportAsBase64: o,
|
|
1310
1314
|
exportAsBlob: n,
|
|
1311
1315
|
fileName: s
|
|
1312
|
-
}),
|
|
1316
|
+
}), f = {
|
|
1313
1317
|
object: d,
|
|
1314
|
-
image:
|
|
1318
|
+
image: p,
|
|
1315
1319
|
format: h,
|
|
1316
1320
|
contentType: "image/svg+xml",
|
|
1317
1321
|
fileName: s.replace(/\.[^/.]+$/, ".svg")
|
|
1318
1322
|
};
|
|
1319
|
-
return i.fire("editor:object-exported",
|
|
1323
|
+
return i.fire("editor:object-exported", f), f;
|
|
1320
1324
|
}
|
|
1321
|
-
if (o && d instanceof
|
|
1322
|
-
const m = yield createImageBitmap(d.getElement()),
|
|
1325
|
+
if (o && d instanceof Z) {
|
|
1326
|
+
const m = yield createImageBitmap(d.getElement()), p = yield r.post(
|
|
1323
1327
|
"toDataURL",
|
|
1324
1328
|
{
|
|
1325
1329
|
format: h,
|
|
@@ -1327,20 +1331,20 @@ class O {
|
|
|
1327
1331
|
bitmap: m
|
|
1328
1332
|
},
|
|
1329
1333
|
[m]
|
|
1330
|
-
),
|
|
1334
|
+
), f = {
|
|
1331
1335
|
object: d,
|
|
1332
|
-
image:
|
|
1336
|
+
image: p,
|
|
1333
1337
|
format: h,
|
|
1334
1338
|
contentType: a,
|
|
1335
1339
|
fileName: s
|
|
1336
1340
|
};
|
|
1337
|
-
return i.fire("editor:object-exported",
|
|
1341
|
+
return i.fire("editor:object-exported", f), f;
|
|
1338
1342
|
}
|
|
1339
1343
|
const l = d.toCanvasElement({
|
|
1340
1344
|
enableRetinaScaling: !1
|
|
1341
|
-
}), g = yield new Promise((m,
|
|
1342
|
-
l.toBlob((
|
|
1343
|
-
|
|
1345
|
+
}), g = yield new Promise((m, p) => {
|
|
1346
|
+
l.toBlob((f) => {
|
|
1347
|
+
f ? m(f) : p(new Error("Failed to create Blob from canvas"));
|
|
1344
1348
|
});
|
|
1345
1349
|
});
|
|
1346
1350
|
if (n) {
|
|
@@ -1399,7 +1403,7 @@ class O {
|
|
|
1399
1403
|
* @public
|
|
1400
1404
|
*/
|
|
1401
1405
|
getContentType(e) {
|
|
1402
|
-
return
|
|
1406
|
+
return j(this, null, function* () {
|
|
1403
1407
|
return typeof e == "string" ? this.getContentTypeFromUrl(e) : e.type || "application/octet-stream";
|
|
1404
1408
|
});
|
|
1405
1409
|
}
|
|
@@ -1410,7 +1414,7 @@ class O {
|
|
|
1410
1414
|
* @public
|
|
1411
1415
|
*/
|
|
1412
1416
|
getContentTypeFromUrl(e) {
|
|
1413
|
-
return
|
|
1417
|
+
return j(this, null, function* () {
|
|
1414
1418
|
if (e.startsWith("data:")) {
|
|
1415
1419
|
const t = e.match(/^data:([^;]+)/);
|
|
1416
1420
|
return t ? t[1] : "application/octet-stream";
|
|
@@ -1489,11 +1493,11 @@ class O {
|
|
|
1489
1493
|
return t ? t[1] : "";
|
|
1490
1494
|
}
|
|
1491
1495
|
}
|
|
1492
|
-
const
|
|
1493
|
-
function
|
|
1494
|
-
return ((
|
|
1496
|
+
const x = (c, e, t) => Math.max(Math.min(c, t), e), Ie = (c, e) => c * e, dt = (c, e) => new X(c / 2, e / 2);
|
|
1497
|
+
function lt(c) {
|
|
1498
|
+
return ((c == null ? void 0 : c.type) === "image" || (c == null ? void 0 : c.format) === "svg") && typeof (c == null ? void 0 : c.width) == "number" && typeof (c == null ? void 0 : c.height) == "number";
|
|
1495
1499
|
}
|
|
1496
|
-
class
|
|
1500
|
+
class ht {
|
|
1497
1501
|
/**
|
|
1498
1502
|
* @param options
|
|
1499
1503
|
* @param options.editor – экземпляр редактора
|
|
@@ -1524,10 +1528,10 @@ class dt {
|
|
|
1524
1528
|
canvas: o,
|
|
1525
1529
|
montageArea: n,
|
|
1526
1530
|
options: { canvasBackstoreWidth: i }
|
|
1527
|
-
} = this.editor, { width:
|
|
1531
|
+
} = this.editor, { width: r, height: d } = n, h = x(Number(e), U, k);
|
|
1528
1532
|
if (!i || i === "auto" || a ? this.adaptCanvasToContainer() : i ? this.setCanvasBackstoreWidth(Number(i)) : this.setCanvasBackstoreWidth(h), n.set({ width: h }), (M = o.clipPath) == null || M.set({ width: h }), t) {
|
|
1529
|
-
const m = h /
|
|
1530
|
-
this.setResolutionHeight(
|
|
1533
|
+
const m = h / r, p = Ie(d, m);
|
|
1534
|
+
this.setResolutionHeight(p);
|
|
1531
1535
|
return;
|
|
1532
1536
|
}
|
|
1533
1537
|
const { left: l, top: g } = this.getObjectDefaultCoords(n), u = o.getZoom();
|
|
@@ -1554,10 +1558,10 @@ class dt {
|
|
|
1554
1558
|
canvas: o,
|
|
1555
1559
|
montageArea: n,
|
|
1556
1560
|
options: { canvasBackstoreHeight: i }
|
|
1557
|
-
} = this.editor, { width:
|
|
1561
|
+
} = this.editor, { width: r, height: d } = n, h = x(Number(e), z, B);
|
|
1558
1562
|
if (!i || i === "auto" || a ? this.adaptCanvasToContainer() : i ? this.setCanvasBackstoreHeight(Number(i)) : this.setCanvasBackstoreHeight(h), n.set({ height: h }), (M = o.clipPath) == null || M.set({ height: h }), t) {
|
|
1559
|
-
const m = h / d,
|
|
1560
|
-
this.setResolutionWidth(
|
|
1563
|
+
const m = h / d, p = Ie(r, m);
|
|
1564
|
+
this.setResolutionWidth(p);
|
|
1561
1565
|
return;
|
|
1562
1566
|
}
|
|
1563
1567
|
const { left: l, top: g } = this.getObjectDefaultCoords(n), u = o.getZoom();
|
|
@@ -1573,12 +1577,12 @@ class dt {
|
|
|
1573
1577
|
* и устанавливает правильный viewportTransform.
|
|
1574
1578
|
*/
|
|
1575
1579
|
centerMontageArea() {
|
|
1576
|
-
var
|
|
1577
|
-
const { canvas: e, montageArea: t } = this.editor, s = e.getWidth(), a = e.getHeight(), o = e.getZoom(), n =
|
|
1580
|
+
var r;
|
|
1581
|
+
const { canvas: e, montageArea: t } = this.editor, s = e.getWidth(), a = e.getHeight(), o = e.getZoom(), n = dt(s, a);
|
|
1578
1582
|
t.set({
|
|
1579
1583
|
left: s / 2,
|
|
1580
1584
|
top: a / 2
|
|
1581
|
-
}), (
|
|
1585
|
+
}), (r = e.clipPath) == null || r.set({
|
|
1582
1586
|
left: s / 2,
|
|
1583
1587
|
top: a / 2
|
|
1584
1588
|
}), e.renderAll();
|
|
@@ -1599,15 +1603,15 @@ class dt {
|
|
|
1599
1603
|
code: "NO_ACTIVE_OBJECT",
|
|
1600
1604
|
message: "Не выбран объект для получения координат"
|
|
1601
1605
|
}), { left: 0, top: 0 };
|
|
1602
|
-
const { width: a, height: o } = s, n = t.getZoom(), i = (a - a * n) / 2,
|
|
1603
|
-
return { left: i, top:
|
|
1606
|
+
const { width: a, height: o } = s, n = t.getZoom(), i = (a - a * n) / 2, r = (o - o * n) / 2;
|
|
1607
|
+
return { left: i, top: r };
|
|
1604
1608
|
}
|
|
1605
1609
|
/**
|
|
1606
1610
|
* Устанавливаем ширину канваса в backstore (для экспорта)
|
|
1607
1611
|
*/
|
|
1608
1612
|
setCanvasBackstoreWidth(e) {
|
|
1609
1613
|
if (!e || typeof e != "number") return;
|
|
1610
|
-
const t =
|
|
1614
|
+
const t = x(e, U, k);
|
|
1611
1615
|
this.editor.canvas.setDimensions({ width: t }, { backstoreOnly: !0 });
|
|
1612
1616
|
}
|
|
1613
1617
|
/**
|
|
@@ -1616,7 +1620,7 @@ class dt {
|
|
|
1616
1620
|
*/
|
|
1617
1621
|
setCanvasBackstoreHeight(e) {
|
|
1618
1622
|
if (!e || typeof e != "number") return;
|
|
1619
|
-
const t =
|
|
1623
|
+
const t = x(e, z, B);
|
|
1620
1624
|
this.editor.canvas.setDimensions({ height: t }, { backstoreOnly: !0 });
|
|
1621
1625
|
}
|
|
1622
1626
|
/**
|
|
@@ -1625,7 +1629,7 @@ class dt {
|
|
|
1625
1629
|
* с учётом минимальных и максимальных значений.
|
|
1626
1630
|
*/
|
|
1627
1631
|
adaptCanvasToContainer() {
|
|
1628
|
-
const { canvas: e } = this.editor, t = this.getEditorContainer(), s = t.clientWidth, a = t.clientHeight, o =
|
|
1632
|
+
const { canvas: e } = this.editor, t = this.getEditorContainer(), s = t.clientWidth, a = t.clientHeight, o = x(s, U, k), n = x(a, z, B);
|
|
1629
1633
|
e.setDimensions({ width: o, height: n }, { backstoreOnly: !0 });
|
|
1630
1634
|
}
|
|
1631
1635
|
/**
|
|
@@ -1643,8 +1647,8 @@ class dt {
|
|
|
1643
1647
|
}
|
|
1644
1648
|
} = this.editor, o = t.left, n = t.top;
|
|
1645
1649
|
this.setResolutionWidth(s, { adaptCanvasToContainer: !0, withoutSave: !0 }), this.setResolutionHeight(a, { adaptCanvasToContainer: !0, withoutSave: !0 }), this.centerMontageArea();
|
|
1646
|
-
const i = t.left - o,
|
|
1647
|
-
if (i !== 0 ||
|
|
1650
|
+
const i = t.left - o, r = t.top - n;
|
|
1651
|
+
if (i !== 0 || r !== 0) {
|
|
1648
1652
|
const d = e.getActiveObject(), h = [];
|
|
1649
1653
|
if ((d == null ? void 0 : d.type) === "activeselection") {
|
|
1650
1654
|
const l = d;
|
|
@@ -1653,7 +1657,7 @@ class dt {
|
|
|
1653
1657
|
if (e.getObjects().forEach((l) => {
|
|
1654
1658
|
l.id === "montage-area" || l.id === "overlay-mask" || l.id === "background" || (l.set({
|
|
1655
1659
|
left: l.left + i,
|
|
1656
|
-
top: l.top +
|
|
1660
|
+
top: l.top + r
|
|
1657
1661
|
}), l.setCoords());
|
|
1658
1662
|
}), h.length > 0)
|
|
1659
1663
|
if (h.length === 1)
|
|
@@ -1793,15 +1797,15 @@ class dt {
|
|
|
1793
1797
|
}
|
|
1794
1798
|
const n = t === "width" ? "width" : "height";
|
|
1795
1799
|
if (typeof s == "string") {
|
|
1796
|
-
o.forEach((
|
|
1797
|
-
|
|
1800
|
+
o.forEach((r) => {
|
|
1801
|
+
r.style[n] = s;
|
|
1798
1802
|
});
|
|
1799
1803
|
return;
|
|
1800
1804
|
}
|
|
1801
1805
|
if (isNaN(s)) return;
|
|
1802
1806
|
const i = `${s}px`;
|
|
1803
|
-
o.forEach((
|
|
1804
|
-
|
|
1807
|
+
o.forEach((r) => {
|
|
1808
|
+
r.style[n] = i;
|
|
1805
1809
|
}), a.fire(`editor:display-${e}-${n}-changed`, {
|
|
1806
1810
|
element: e,
|
|
1807
1811
|
value: s
|
|
@@ -1822,20 +1826,20 @@ class dt {
|
|
|
1822
1826
|
transformManager: n,
|
|
1823
1827
|
options: {
|
|
1824
1828
|
montageAreaWidth: i,
|
|
1825
|
-
montageAreaHeight:
|
|
1829
|
+
montageAreaHeight: r
|
|
1826
1830
|
}
|
|
1827
1831
|
} = this.editor, d = e || a.getActiveObject();
|
|
1828
|
-
if (!
|
|
1832
|
+
if (!lt(d)) return;
|
|
1829
1833
|
const { width: h, height: l } = d;
|
|
1830
|
-
let g = Math.min(h,
|
|
1834
|
+
let g = Math.min(h, k), u = Math.min(l, B);
|
|
1831
1835
|
if (t) {
|
|
1832
1836
|
const {
|
|
1833
1837
|
width: M,
|
|
1834
1838
|
height: m
|
|
1835
|
-
} = o,
|
|
1839
|
+
} = o, p = h / M, f = l / m, b = Math.max(p, f);
|
|
1836
1840
|
g = M * b, u = m * b;
|
|
1837
1841
|
}
|
|
1838
|
-
this.setResolutionWidth(g, { withoutSave: !0 }), this.setResolutionHeight(u, { withoutSave: !0 }), this.editor.backgroundManager.backgroundObject && this.editor.backgroundManager.refresh(), (h > i || l >
|
|
1842
|
+
this.setResolutionWidth(g, { withoutSave: !0 }), this.setResolutionHeight(u, { withoutSave: !0 }), this.editor.backgroundManager.backgroundObject && this.editor.backgroundManager.refresh(), (h > i || l > r) && n.calculateAndApplyDefaultZoom(), n.resetObject({ object: d, withoutSave: !0 }), a.centerObject(d), a.renderAll(), s || this.editor.historyManager.saveState(), a.fire("editor:montage-area-scaled-to-image", {
|
|
1839
1843
|
object: d,
|
|
1840
1844
|
width: g,
|
|
1841
1845
|
height: u,
|
|
@@ -1885,9 +1889,9 @@ class dt {
|
|
|
1885
1889
|
);
|
|
1886
1890
|
}
|
|
1887
1891
|
}
|
|
1888
|
-
class
|
|
1892
|
+
class gt {
|
|
1889
1893
|
constructor({ editor: e }) {
|
|
1890
|
-
this.editor = e, this.options = e.options, this.minZoom = this.options.minZoom ||
|
|
1894
|
+
this.editor = e, this.options = e.options, this.minZoom = this.options.minZoom || nt, this.maxZoom = this.options.maxZoom || it, this.defaultZoom = this.options.defaultScale;
|
|
1891
1895
|
}
|
|
1892
1896
|
/**
|
|
1893
1897
|
* Метод рассчитывает и применяет зум по умолчанию для монтажной области редактора.
|
|
@@ -1897,8 +1901,8 @@ class lt {
|
|
|
1897
1901
|
* @param scale - Желаемый масштаб относительно размеров контейнера редактора.
|
|
1898
1902
|
*/
|
|
1899
1903
|
calculateAndApplyDefaultZoom(e = this.options.defaultScale) {
|
|
1900
|
-
const { canvas: t } = this.editor, s = t.editorContainer, a = s.clientWidth, o = s.clientHeight, { width: n, height: i } = this.editor.montageArea,
|
|
1901
|
-
this.defaultZoom = Math.min(
|
|
1904
|
+
const { canvas: t } = this.editor, s = t.editorContainer, a = s.clientWidth, o = s.clientHeight, { width: n, height: i } = this.editor.montageArea, r = a / n * e, d = o / i * e;
|
|
1905
|
+
this.defaultZoom = Math.min(r, d), this.setZoom();
|
|
1902
1906
|
}
|
|
1903
1907
|
/**
|
|
1904
1908
|
* Увеличение/уменьшение масштаба
|
|
@@ -1909,10 +1913,10 @@ class lt {
|
|
|
1909
1913
|
* @fires editor:zoom-changed
|
|
1910
1914
|
* Если передавать координаты курсора, то нужно быть аккуратнее, так как юзер может выйти за пределы рабочей области
|
|
1911
1915
|
*/
|
|
1912
|
-
zoom(e =
|
|
1916
|
+
zoom(e = rt, t = {}) {
|
|
1913
1917
|
var g, u;
|
|
1914
1918
|
if (!e) return;
|
|
1915
|
-
const { minZoom: s, maxZoom: a } = this, { canvas: o } = this.editor, n = o.getZoom(), i = o.getCenterPoint(),
|
|
1919
|
+
const { minZoom: s, maxZoom: a } = this, { canvas: o } = this.editor, n = o.getZoom(), i = o.getCenterPoint(), r = (g = t.pointX) != null ? g : i.x, d = (u = t.pointY) != null ? u : i.y, h = new X(r, d);
|
|
1916
1920
|
let l = Number((n + Number(e)).toFixed(2));
|
|
1917
1921
|
l > a && (l = a), l < s && (l = s), o.zoomToPoint(h, l), o.fire("editor:zoom-changed", {
|
|
1918
1922
|
currentZoom: o.getZoom(),
|
|
@@ -1926,7 +1930,7 @@ class lt {
|
|
|
1926
1930
|
* @fires editor:zoom-changed
|
|
1927
1931
|
*/
|
|
1928
1932
|
setZoom(e = this.defaultZoom) {
|
|
1929
|
-
const { minZoom: t, maxZoom: s } = this, { canvas: a } = this.editor, o = new
|
|
1933
|
+
const { minZoom: t, maxZoom: s } = this, { canvas: a } = this.editor, o = new X(a.getCenterPoint());
|
|
1930
1934
|
let n = e;
|
|
1931
1935
|
e > s && (n = s), e < t && (n = t), a.zoomToPoint(o, n), a.fire("editor:zoom-changed", {
|
|
1932
1936
|
currentZoom: a.getZoom(),
|
|
@@ -1939,7 +1943,7 @@ class lt {
|
|
|
1939
1943
|
* @fires editor:zoom-changed
|
|
1940
1944
|
*/
|
|
1941
1945
|
resetZoom() {
|
|
1942
|
-
const { canvas: e } = this.editor, t = new
|
|
1946
|
+
const { canvas: e } = this.editor, t = new X(e.getCenterPoint());
|
|
1943
1947
|
e.zoomToPoint(t, this.defaultZoom), this.editor.canvas.fire("editor:zoom-changed", {
|
|
1944
1948
|
currentZoom: e.getZoom(),
|
|
1945
1949
|
point: t
|
|
@@ -1952,7 +1956,7 @@ class lt {
|
|
|
1952
1956
|
* @param options.withoutSave - Не сохранять состояние
|
|
1953
1957
|
* @fires editor:object-rotated
|
|
1954
1958
|
*/
|
|
1955
|
-
rotate(e =
|
|
1959
|
+
rotate(e = ct, { withoutSave: t } = {}) {
|
|
1956
1960
|
const { canvas: s, historyManager: a } = this.editor, o = s.getActiveObject();
|
|
1957
1961
|
if (!o) return;
|
|
1958
1962
|
const n = o.angle + e;
|
|
@@ -2030,11 +2034,11 @@ class lt {
|
|
|
2030
2034
|
const { canvas: o, historyManager: n } = this.editor, i = e || o.getActiveObject();
|
|
2031
2035
|
if (i) {
|
|
2032
2036
|
if (i instanceof v && !a) {
|
|
2033
|
-
const
|
|
2034
|
-
o.discardActiveObject(),
|
|
2037
|
+
const r = i.getObjects();
|
|
2038
|
+
o.discardActiveObject(), r.forEach((h) => {
|
|
2035
2039
|
this._fitSingleObject(h, t);
|
|
2036
2040
|
});
|
|
2037
|
-
const d = new v(
|
|
2041
|
+
const d = new v(r, { canvas: o });
|
|
2038
2042
|
o.setActiveObject(d);
|
|
2039
2043
|
} else
|
|
2040
2044
|
this._fitSingleObject(i, t);
|
|
@@ -2053,11 +2057,11 @@ class lt {
|
|
|
2053
2057
|
* @private
|
|
2054
2058
|
*/
|
|
2055
2059
|
_fitSingleObject(e, t) {
|
|
2056
|
-
const { canvas: s, montageArea: a } = this.editor, { width: o, height: n, scaleX: i = 1, scaleY:
|
|
2060
|
+
const { canvas: s, montageArea: a } = this.editor, { width: o, height: n, scaleX: i = 1, scaleY: r = 1, angle: d = 0 } = e, h = o * Math.abs(i), l = n * Math.abs(r), g = d * Math.PI / 180, u = Math.abs(Math.cos(g)), M = Math.abs(Math.sin(g)), m = h * u + l * M, p = h * M + l * u, f = a.width, b = a.height;
|
|
2057
2061
|
let S;
|
|
2058
|
-
t === "contain" ? S = Math.min(
|
|
2062
|
+
t === "contain" ? S = Math.min(f / m, b / p) : S = Math.max(f / m, b / p), e.set({
|
|
2059
2063
|
scaleX: i * S,
|
|
2060
|
-
scaleY:
|
|
2064
|
+
scaleY: r * S
|
|
2061
2065
|
}), s.centerObject(e);
|
|
2062
2066
|
}
|
|
2063
2067
|
/**
|
|
@@ -2082,7 +2086,7 @@ class lt {
|
|
|
2082
2086
|
montageArea: o,
|
|
2083
2087
|
imageManager: n,
|
|
2084
2088
|
historyManager: i,
|
|
2085
|
-
options: { scaleType:
|
|
2089
|
+
options: { scaleType: r }
|
|
2086
2090
|
} = this.editor, d = e || a.getActiveObject();
|
|
2087
2091
|
if (!d || d.locked) return;
|
|
2088
2092
|
if (i.suspendHistory(), d.type === "image" || d.format === "svg" || d.set({
|
|
@@ -2096,9 +2100,9 @@ class lt {
|
|
|
2096
2100
|
else {
|
|
2097
2101
|
const { width: l, height: g } = o, { width: u, height: M } = d, m = n.calculateScaleFactor({
|
|
2098
2102
|
imageObject: d,
|
|
2099
|
-
scaleType:
|
|
2103
|
+
scaleType: r
|
|
2100
2104
|
});
|
|
2101
|
-
|
|
2105
|
+
r === "contain" && m < 1 || r === "cover" && (u > l || M > g) ? this.fitObject({ object: d, withoutSave: !0, fitAsOneObject: !0 }) : d.set({ scaleX: 1, scaleY: 1 });
|
|
2102
2106
|
}
|
|
2103
2107
|
d.set({ flipX: !1, flipY: !1, angle: 0 }), a.centerObject(d), a.renderAll(), i.resumeHistory(), s || i.saveState(), a.fire("editor:object-reset", {
|
|
2104
2108
|
object: d,
|
|
@@ -2107,7 +2111,7 @@ class lt {
|
|
|
2107
2111
|
});
|
|
2108
2112
|
}
|
|
2109
2113
|
}
|
|
2110
|
-
class
|
|
2114
|
+
class ut {
|
|
2111
2115
|
constructor({ editor: e }) {
|
|
2112
2116
|
this.editor = e, this.isBlocked = !1, this.overlayMask = null, this._createOverlay();
|
|
2113
2117
|
}
|
|
@@ -2164,7 +2168,7 @@ class ht {
|
|
|
2164
2168
|
}), e.upperCanvasEl.style.pointerEvents = "", e.lowerCanvasEl.style.pointerEvents = "", this.overlayMask.visible = !1, e.requestRenderAll(), e.fire("editor:enabled"), s.resumeHistory();
|
|
2165
2169
|
}
|
|
2166
2170
|
}
|
|
2167
|
-
class
|
|
2171
|
+
class R {
|
|
2168
2172
|
constructor({ editor: e }) {
|
|
2169
2173
|
this.editor = e, this.backgroundObject = null;
|
|
2170
2174
|
}
|
|
@@ -2219,8 +2223,8 @@ class x {
|
|
|
2219
2223
|
try {
|
|
2220
2224
|
const { historyManager: o } = this.editor, { backgroundObject: n } = this;
|
|
2221
2225
|
if (o.suspendHistory(), n && n.backgroundType === "gradient") {
|
|
2222
|
-
const i =
|
|
2223
|
-
if (
|
|
2226
|
+
const i = R._createFabricGradient(e);
|
|
2227
|
+
if (R._isGradientEqual(n.fill, i)) {
|
|
2224
2228
|
o.resumeHistory();
|
|
2225
2229
|
return;
|
|
2226
2230
|
}
|
|
@@ -2282,7 +2286,7 @@ class x {
|
|
|
2282
2286
|
endColor: o,
|
|
2283
2287
|
startPosition: n,
|
|
2284
2288
|
endPosition: i,
|
|
2285
|
-
customData:
|
|
2289
|
+
customData: r = {},
|
|
2286
2290
|
withoutSave: d = !1
|
|
2287
2291
|
}) {
|
|
2288
2292
|
this.setGradientBackground({
|
|
@@ -2296,7 +2300,7 @@ class x {
|
|
|
2296
2300
|
startPosition: n,
|
|
2297
2301
|
endPosition: i
|
|
2298
2302
|
},
|
|
2299
|
-
customData:
|
|
2303
|
+
customData: r,
|
|
2300
2304
|
withoutSave: d
|
|
2301
2305
|
});
|
|
2302
2306
|
}
|
|
@@ -2307,7 +2311,7 @@ class x {
|
|
|
2307
2311
|
* @param options.withoutSave - Если true, не сохранять состояние в историю
|
|
2308
2312
|
*/
|
|
2309
2313
|
setImageBackground(a) {
|
|
2310
|
-
return
|
|
2314
|
+
return j(this, arguments, function* ({
|
|
2311
2315
|
imageSource: e,
|
|
2312
2316
|
customData: t = {},
|
|
2313
2317
|
withoutSave: s = !1
|
|
@@ -2392,7 +2396,7 @@ class x {
|
|
|
2392
2396
|
backgroundType: "gradient",
|
|
2393
2397
|
backgroundId: `background-${A()}`
|
|
2394
2398
|
}, { withoutSelection: !0 }), this.refresh();
|
|
2395
|
-
const t =
|
|
2399
|
+
const t = R._createFabricGradient(e);
|
|
2396
2400
|
this.backgroundObject.set("fill", t), this.editor.canvas.requestRenderAll();
|
|
2397
2401
|
}
|
|
2398
2402
|
/**
|
|
@@ -2400,7 +2404,7 @@ class x {
|
|
|
2400
2404
|
* @param source - источник изображения (URL или File)
|
|
2401
2405
|
*/
|
|
2402
2406
|
_createImageBackground(e, t) {
|
|
2403
|
-
return
|
|
2407
|
+
return j(this, null, function* () {
|
|
2404
2408
|
var a;
|
|
2405
2409
|
const { image: s } = (a = yield this.editor.imageManager.importImage({
|
|
2406
2410
|
source: e,
|
|
@@ -2444,8 +2448,8 @@ class x {
|
|
|
2444
2448
|
{ offset: o / 100, color: s }
|
|
2445
2449
|
];
|
|
2446
2450
|
if (e.type === "linear") {
|
|
2447
|
-
const l = e.angle * Math.PI / 180, g =
|
|
2448
|
-
return new
|
|
2451
|
+
const l = e.angle * Math.PI / 180, g = R._angleToCoords(l);
|
|
2452
|
+
return new be({
|
|
2449
2453
|
type: "linear",
|
|
2450
2454
|
gradientUnits: "percentage",
|
|
2451
2455
|
coords: g,
|
|
@@ -2454,17 +2458,17 @@ class x {
|
|
|
2454
2458
|
}
|
|
2455
2459
|
const {
|
|
2456
2460
|
centerX: i = 50,
|
|
2457
|
-
centerY:
|
|
2461
|
+
centerY: r = 50,
|
|
2458
2462
|
radius: d = 50
|
|
2459
2463
|
} = e, h = {
|
|
2460
2464
|
x1: i / 100,
|
|
2461
|
-
y1:
|
|
2465
|
+
y1: r / 100,
|
|
2462
2466
|
x2: i / 100,
|
|
2463
|
-
y2:
|
|
2467
|
+
y2: r / 100,
|
|
2464
2468
|
r1: 0,
|
|
2465
2469
|
r2: d / 100
|
|
2466
2470
|
};
|
|
2467
|
-
return new
|
|
2471
|
+
return new be({
|
|
2468
2472
|
type: "radial",
|
|
2469
2473
|
gradientUnits: "percentage",
|
|
2470
2474
|
coords: h,
|
|
@@ -2494,12 +2498,12 @@ class x {
|
|
|
2494
2498
|
if (!e || !t || e.type !== t.type) return !1;
|
|
2495
2499
|
const s = e.colorStops || [], a = t.colorStops || [];
|
|
2496
2500
|
return s.length !== a.length || !s.every((n, i) => {
|
|
2497
|
-
const
|
|
2498
|
-
return n.color ===
|
|
2501
|
+
const r = a[i];
|
|
2502
|
+
return n.color === r.color && Math.abs(n.offset - r.offset) < 1e-4;
|
|
2499
2503
|
}) ? !1 : e.type === "linear" && t.type === "linear" ? Math.abs(e.coords.x1 - t.coords.x1) < 1e-4 && Math.abs(e.coords.y1 - t.coords.y1) < 1e-4 && Math.abs(e.coords.x2 - t.coords.x2) < 1e-4 && Math.abs(e.coords.y2 - t.coords.y2) < 1e-4 : e.type === "radial" && t.type === "radial" ? Math.abs(e.coords.x1 - t.coords.x1) < 1e-4 && Math.abs(e.coords.y1 - t.coords.y1) < 1e-4 && Math.abs(e.coords.x2 - t.coords.x2) < 1e-4 && Math.abs(e.coords.y2 - t.coords.y2) < 1e-4 && Math.abs(e.coords.r1 - t.coords.r1) < 1e-4 && Math.abs(e.coords.r2 - t.coords.r2) < 1e-4 : !1;
|
|
2500
2504
|
}
|
|
2501
2505
|
}
|
|
2502
|
-
class
|
|
2506
|
+
class $ {
|
|
2503
2507
|
constructor({ editor: e }) {
|
|
2504
2508
|
this.editor = e;
|
|
2505
2509
|
}
|
|
@@ -2532,7 +2536,7 @@ class K {
|
|
|
2532
2536
|
const { canvas: s, historyManager: a } = this.editor;
|
|
2533
2537
|
a.suspendHistory();
|
|
2534
2538
|
const o = e || s.getActiveObject();
|
|
2535
|
-
o && (o instanceof v ?
|
|
2539
|
+
o && (o instanceof v ? $._moveSelectionForward(s, o) : s.bringObjectForward(o), s.renderAll(), a.resumeHistory(), t || a.saveState(), s.fire("editor:object-bring-forward", {
|
|
2536
2540
|
object: o,
|
|
2537
2541
|
withoutSave: t
|
|
2538
2542
|
}));
|
|
@@ -2553,16 +2557,16 @@ class K {
|
|
|
2553
2557
|
backgroundManager: { backgroundObject: i }
|
|
2554
2558
|
} = this.editor;
|
|
2555
2559
|
o.suspendHistory();
|
|
2556
|
-
const
|
|
2557
|
-
if (
|
|
2558
|
-
if (
|
|
2559
|
-
const d =
|
|
2560
|
+
const r = e || s.getActiveObject();
|
|
2561
|
+
if (r) {
|
|
2562
|
+
if (r instanceof v) {
|
|
2563
|
+
const d = r.getObjects();
|
|
2560
2564
|
for (let h = d.length - 1; h >= 0; h -= 1)
|
|
2561
2565
|
s.sendObjectToBack(d[h]);
|
|
2562
2566
|
} else
|
|
2563
|
-
s.sendObjectToBack(
|
|
2567
|
+
s.sendObjectToBack(r);
|
|
2564
2568
|
i && s.sendObjectToBack(i), s.sendObjectToBack(a), n && s.sendObjectToBack(n), s.renderAll(), o.resumeHistory(), t || o.saveState(), s.fire("editor:object-send-to-back", {
|
|
2565
|
-
object:
|
|
2569
|
+
object: r,
|
|
2566
2570
|
withoutSave: t
|
|
2567
2571
|
});
|
|
2568
2572
|
}
|
|
@@ -2582,9 +2586,9 @@ class K {
|
|
|
2582
2586
|
backgroundManager: { backgroundObject: i }
|
|
2583
2587
|
} = this.editor;
|
|
2584
2588
|
o.suspendHistory();
|
|
2585
|
-
const
|
|
2586
|
-
|
|
2587
|
-
object:
|
|
2589
|
+
const r = e || s.getActiveObject();
|
|
2590
|
+
r && (r instanceof v ? $._moveSelectionBackwards(s, r) : s.sendObjectBackwards(r), i && s.sendObjectToBack(i), s.sendObjectToBack(a), n && s.sendObjectToBack(n), s.renderAll(), o.resumeHistory(), t || o.saveState(), s.fire("editor:object-send-backwards", {
|
|
2591
|
+
object: r,
|
|
2588
2592
|
withoutSave: t
|
|
2589
2593
|
}));
|
|
2590
2594
|
}
|
|
@@ -2597,13 +2601,13 @@ class K {
|
|
|
2597
2601
|
static _moveSelectionForward(e, t) {
|
|
2598
2602
|
const s = e.getObjects(), a = t.getObjects();
|
|
2599
2603
|
if (!a.some((i) => {
|
|
2600
|
-
const
|
|
2601
|
-
for (let d =
|
|
2604
|
+
const r = s.indexOf(i);
|
|
2605
|
+
for (let d = r + 1; d < s.length; d += 1)
|
|
2602
2606
|
if (!a.includes(s[d]))
|
|
2603
2607
|
return !0;
|
|
2604
2608
|
return !1;
|
|
2605
2609
|
})) return;
|
|
2606
|
-
a.map((i) => ({ obj: i, index: s.indexOf(i) })).sort((i,
|
|
2610
|
+
a.map((i) => ({ obj: i, index: s.indexOf(i) })).sort((i, r) => r.index - i.index).forEach((i) => {
|
|
2607
2611
|
e.bringObjectForward(i.obj);
|
|
2608
2612
|
});
|
|
2609
2613
|
}
|
|
@@ -2616,18 +2620,18 @@ class K {
|
|
|
2616
2620
|
static _moveSelectionBackwards(e, t) {
|
|
2617
2621
|
const s = e.getObjects(), a = t.getObjects();
|
|
2618
2622
|
if (!a.some((i) => {
|
|
2619
|
-
const
|
|
2620
|
-
for (let d =
|
|
2623
|
+
const r = s.indexOf(i);
|
|
2624
|
+
for (let d = r - 1; d >= 0; d -= 1)
|
|
2621
2625
|
if (!a.includes(s[d]))
|
|
2622
2626
|
return !0;
|
|
2623
2627
|
return !1;
|
|
2624
2628
|
})) return;
|
|
2625
|
-
a.map((i) => ({ obj: i, index: s.indexOf(i) })).sort((i,
|
|
2629
|
+
a.map((i) => ({ obj: i, index: s.indexOf(i) })).sort((i, r) => i.index - r.index).forEach((i) => {
|
|
2626
2630
|
e.sendObjectBackwards(i.obj);
|
|
2627
2631
|
});
|
|
2628
2632
|
}
|
|
2629
2633
|
}
|
|
2630
|
-
class
|
|
2634
|
+
class ft {
|
|
2631
2635
|
/**
|
|
2632
2636
|
* Менеджер фигур для редактора.
|
|
2633
2637
|
* @param options - Опции и настройки менеджера фигур.
|
|
@@ -2651,7 +2655,7 @@ class gt {
|
|
|
2651
2655
|
* @param flags.withoutSelection - Не выделять объект
|
|
2652
2656
|
* @param flags.withoutAdding - Не добавлять объект в canvas
|
|
2653
2657
|
*/
|
|
2654
|
-
addRectangle(h = {}, { withoutSelection:
|
|
2658
|
+
addRectangle(h = {}, { withoutSelection: r, withoutAdding: d } = {}) {
|
|
2655
2659
|
var l = h, {
|
|
2656
2660
|
id: e = `rect-${A()}`,
|
|
2657
2661
|
left: t,
|
|
@@ -2659,7 +2663,7 @@ class gt {
|
|
|
2659
2663
|
width: a = 100,
|
|
2660
2664
|
height: o = 100,
|
|
2661
2665
|
fill: n = "blue"
|
|
2662
|
-
} = l, i =
|
|
2666
|
+
} = l, i = V(l, [
|
|
2663
2667
|
"id",
|
|
2664
2668
|
"left",
|
|
2665
2669
|
"top",
|
|
@@ -2667,7 +2671,7 @@ class gt {
|
|
|
2667
2671
|
"height",
|
|
2668
2672
|
"fill"
|
|
2669
2673
|
]);
|
|
2670
|
-
const { canvas: g } = this.editor, u = new
|
|
2674
|
+
const { canvas: g } = this.editor, u = new we(I({
|
|
2671
2675
|
id: e,
|
|
2672
2676
|
left: t,
|
|
2673
2677
|
top: s,
|
|
@@ -2675,7 +2679,7 @@ class gt {
|
|
|
2675
2679
|
height: o,
|
|
2676
2680
|
fill: n
|
|
2677
2681
|
}, i));
|
|
2678
|
-
return !t && !s && g.centerObject(u), d || (g.add(u),
|
|
2682
|
+
return !t && !s && g.centerObject(u), d || (g.add(u), r || g.setActiveObject(u), g.renderAll()), u;
|
|
2679
2683
|
}
|
|
2680
2684
|
/**
|
|
2681
2685
|
* Добавление круга
|
|
@@ -2693,28 +2697,28 @@ class gt {
|
|
|
2693
2697
|
* @param flags.withoutSelection - Не выделять объект
|
|
2694
2698
|
* @param flags.withoutAdding - Не добавлять объект в canvas
|
|
2695
2699
|
*/
|
|
2696
|
-
addCircle(d = {}, { withoutSelection: i, withoutAdding:
|
|
2700
|
+
addCircle(d = {}, { withoutSelection: i, withoutAdding: r } = {}) {
|
|
2697
2701
|
var h = d, {
|
|
2698
2702
|
id: e = `circle-${A()}`,
|
|
2699
2703
|
left: t,
|
|
2700
2704
|
top: s,
|
|
2701
2705
|
radius: a = 50,
|
|
2702
2706
|
fill: o = "green"
|
|
2703
|
-
} = h, n =
|
|
2707
|
+
} = h, n = V(h, [
|
|
2704
2708
|
"id",
|
|
2705
2709
|
"left",
|
|
2706
2710
|
"top",
|
|
2707
2711
|
"radius",
|
|
2708
2712
|
"fill"
|
|
2709
2713
|
]);
|
|
2710
|
-
const { canvas: l } = this.editor, g = new
|
|
2714
|
+
const { canvas: l } = this.editor, g = new Te(I({
|
|
2711
2715
|
id: e,
|
|
2712
2716
|
left: t,
|
|
2713
2717
|
top: s,
|
|
2714
2718
|
fill: o,
|
|
2715
2719
|
radius: a
|
|
2716
2720
|
}, n));
|
|
2717
|
-
return !t && !s && l.centerObject(g),
|
|
2721
|
+
return !t && !s && l.centerObject(g), r || (l.add(g), i || l.setActiveObject(g), l.renderAll()), g;
|
|
2718
2722
|
}
|
|
2719
2723
|
/**
|
|
2720
2724
|
* Добавление треугольника
|
|
@@ -2733,7 +2737,7 @@ class gt {
|
|
|
2733
2737
|
* @param flags.withoutSelection - Не выделять объект
|
|
2734
2738
|
* @param flags.withoutAdding - Не добавлять объект в canvas
|
|
2735
2739
|
*/
|
|
2736
|
-
addTriangle(h = {}, { withoutSelection:
|
|
2740
|
+
addTriangle(h = {}, { withoutSelection: r, withoutAdding: d } = {}) {
|
|
2737
2741
|
var l = h, {
|
|
2738
2742
|
id: e = `triangle-${A()}`,
|
|
2739
2743
|
left: t,
|
|
@@ -2741,7 +2745,7 @@ class gt {
|
|
|
2741
2745
|
width: a = 100,
|
|
2742
2746
|
height: o = 100,
|
|
2743
2747
|
fill: n = "yellow"
|
|
2744
|
-
} = l, i =
|
|
2748
|
+
} = l, i = V(l, [
|
|
2745
2749
|
"id",
|
|
2746
2750
|
"left",
|
|
2747
2751
|
"top",
|
|
@@ -2749,7 +2753,7 @@ class gt {
|
|
|
2749
2753
|
"height",
|
|
2750
2754
|
"fill"
|
|
2751
2755
|
]);
|
|
2752
|
-
const { canvas: g } = this.editor, u = new
|
|
2756
|
+
const { canvas: g } = this.editor, u = new ke(I({
|
|
2753
2757
|
id: e,
|
|
2754
2758
|
left: t,
|
|
2755
2759
|
top: s,
|
|
@@ -2757,10 +2761,10 @@ class gt {
|
|
|
2757
2761
|
width: a,
|
|
2758
2762
|
height: o
|
|
2759
2763
|
}, i));
|
|
2760
|
-
return !t && !s && g.centerObject(u), d || (g.add(u),
|
|
2764
|
+
return !t && !s && g.centerObject(u), d || (g.add(u), r || g.setActiveObject(u), g.renderAll()), u;
|
|
2761
2765
|
}
|
|
2762
2766
|
}
|
|
2763
|
-
class
|
|
2767
|
+
class Mt {
|
|
2764
2768
|
/**
|
|
2765
2769
|
* @param options
|
|
2766
2770
|
* @param options.editor - экземпляр редактора с доступом к canvas
|
|
@@ -2788,7 +2792,7 @@ class ut {
|
|
|
2788
2792
|
* Асинхронное клонирование для внутреннего буфера
|
|
2789
2793
|
*/
|
|
2790
2794
|
_cloneToInternalClipboard(e) {
|
|
2791
|
-
return
|
|
2795
|
+
return j(this, null, function* () {
|
|
2792
2796
|
const { canvas: t, errorManager: s } = this.editor;
|
|
2793
2797
|
try {
|
|
2794
2798
|
const a = yield e.clone(["format"]);
|
|
@@ -2808,7 +2812,7 @@ class ut {
|
|
|
2808
2812
|
* Копирование в системный буфер обмена
|
|
2809
2813
|
*/
|
|
2810
2814
|
_copyToSystemClipboard(e) {
|
|
2811
|
-
return
|
|
2815
|
+
return j(this, null, function* () {
|
|
2812
2816
|
const { errorManager: t } = this.editor;
|
|
2813
2817
|
if (typeof ClipboardItem == "undefined" || !navigator.clipboard)
|
|
2814
2818
|
return t.emitWarning({
|
|
@@ -2835,12 +2839,12 @@ class ut {
|
|
|
2835
2839
|
* Копирование изображения в буфер обмена
|
|
2836
2840
|
*/
|
|
2837
2841
|
_copyImageToClipboard(e, t) {
|
|
2838
|
-
return
|
|
2842
|
+
return j(this, null, function* () {
|
|
2839
2843
|
try {
|
|
2840
|
-
const a = e.toCanvasElement({ enableRetinaScaling: !1 }).toDataURL(), o = a.slice(5).split(";")[0], n = a.split(",")[1], i = atob(n),
|
|
2844
|
+
const a = e.toCanvasElement({ enableRetinaScaling: !1 }).toDataURL(), o = a.slice(5).split(";")[0], n = a.split(",")[1], i = atob(n), r = new Uint8Array(i.length);
|
|
2841
2845
|
for (let l = 0; l < i.length; l += 1)
|
|
2842
|
-
|
|
2843
|
-
const d = new Blob([
|
|
2846
|
+
r[l] = i.charCodeAt(l);
|
|
2847
|
+
const d = new Blob([r.buffer], { type: o }), h = new ClipboardItem({ [o]: d });
|
|
2844
2848
|
return yield navigator.clipboard.write([h]), console.info("Image copied to clipboard successfully"), !0;
|
|
2845
2849
|
} catch (s) {
|
|
2846
2850
|
return this.editor.errorManager.emitWarning({
|
|
@@ -2857,9 +2861,9 @@ class ut {
|
|
|
2857
2861
|
* Копирование текста в буфер обмена
|
|
2858
2862
|
*/
|
|
2859
2863
|
_copyTextToClipboard(e) {
|
|
2860
|
-
return
|
|
2864
|
+
return j(this, null, function* () {
|
|
2861
2865
|
try {
|
|
2862
|
-
const t = `${
|
|
2866
|
+
const t = `${ye}${e}`;
|
|
2863
2867
|
return yield navigator.clipboard.writeText(t), console.info("Text copied to clipboard successfully"), !0;
|
|
2864
2868
|
} catch (t) {
|
|
2865
2869
|
const { errorManager: s } = this.editor;
|
|
@@ -2892,7 +2896,7 @@ class ut {
|
|
|
2892
2896
|
* @param source - источник изображения (data URL или URL)
|
|
2893
2897
|
*/
|
|
2894
2898
|
_handleImageImport(e) {
|
|
2895
|
-
return
|
|
2899
|
+
return j(this, null, function* () {
|
|
2896
2900
|
var s;
|
|
2897
2901
|
const { image: t } = (s = yield this.editor.imageManager.importImage({
|
|
2898
2902
|
source: e,
|
|
@@ -2908,7 +2912,7 @@ class ut {
|
|
|
2908
2912
|
* @fires editor:object-pasted
|
|
2909
2913
|
*/
|
|
2910
2914
|
copyPaste(e) {
|
|
2911
|
-
return
|
|
2915
|
+
return j(this, null, function* () {
|
|
2912
2916
|
const { canvas: t } = this.editor, s = e || t.getActiveObject();
|
|
2913
2917
|
if (!s || s.locked) return !1;
|
|
2914
2918
|
try {
|
|
@@ -2938,14 +2942,14 @@ class ut {
|
|
|
2938
2942
|
* @param event.clipboardData.items — элементы буфера обмена
|
|
2939
2943
|
*/
|
|
2940
2944
|
handlePasteEvent(t) {
|
|
2941
|
-
return
|
|
2942
|
-
var
|
|
2943
|
-
if (!((
|
|
2945
|
+
return j(this, arguments, function* ({ clipboardData: e }) {
|
|
2946
|
+
var r;
|
|
2947
|
+
if (!((r = e == null ? void 0 : e.items) != null && r.length)) {
|
|
2944
2948
|
this.paste();
|
|
2945
2949
|
return;
|
|
2946
2950
|
}
|
|
2947
2951
|
const s = e.getData("text/plain");
|
|
2948
|
-
if (s && s.startsWith(
|
|
2952
|
+
if (s && s.startsWith(ye)) {
|
|
2949
2953
|
this.paste();
|
|
2950
2954
|
return;
|
|
2951
2955
|
}
|
|
@@ -2989,7 +2993,7 @@ class ut {
|
|
|
2989
2993
|
* @fires editor:object-pasted
|
|
2990
2994
|
*/
|
|
2991
2995
|
paste() {
|
|
2992
|
-
return
|
|
2996
|
+
return j(this, null, function* () {
|
|
2993
2997
|
const { canvas: e } = this.editor;
|
|
2994
2998
|
if (!this.clipboard) return !1;
|
|
2995
2999
|
try {
|
|
@@ -3013,7 +3017,7 @@ class ut {
|
|
|
3013
3017
|
});
|
|
3014
3018
|
}
|
|
3015
3019
|
}
|
|
3016
|
-
class
|
|
3020
|
+
class J {
|
|
3017
3021
|
constructor({ editor: e }) {
|
|
3018
3022
|
this.editor = e;
|
|
3019
3023
|
}
|
|
@@ -3038,7 +3042,7 @@ class $ {
|
|
|
3038
3042
|
lockSkewingY: !0,
|
|
3039
3043
|
locked: !0
|
|
3040
3044
|
};
|
|
3041
|
-
n.set(i), !t &&
|
|
3045
|
+
n.set(i), !t && J._isGroupOrSelection(n) && n.getObjects().forEach((d) => {
|
|
3042
3046
|
d.set(i);
|
|
3043
3047
|
}), a.renderAll(), s || o.saveState(), a.fire("editor:object-locked", {
|
|
3044
3048
|
object: n,
|
|
@@ -3066,7 +3070,7 @@ class $ {
|
|
|
3066
3070
|
lockSkewingY: !1,
|
|
3067
3071
|
locked: !1
|
|
3068
3072
|
};
|
|
3069
|
-
o.set(n),
|
|
3073
|
+
o.set(n), J._isGroupOrSelection(o) && o.getObjects().forEach((i) => {
|
|
3070
3074
|
i.set(n);
|
|
3071
3075
|
}), s.renderAll(), t || a.saveState(), s.fire("editor:object-unlocked", {
|
|
3072
3076
|
object: o,
|
|
@@ -3074,10 +3078,10 @@ class $ {
|
|
|
3074
3078
|
});
|
|
3075
3079
|
}
|
|
3076
3080
|
static _isGroupOrSelection(e) {
|
|
3077
|
-
return e instanceof v || e instanceof
|
|
3081
|
+
return e instanceof v || e instanceof te;
|
|
3078
3082
|
}
|
|
3079
3083
|
}
|
|
3080
|
-
class
|
|
3084
|
+
class mt {
|
|
3081
3085
|
constructor({ editor: e }) {
|
|
3082
3086
|
this.editor = e;
|
|
3083
3087
|
}
|
|
@@ -3096,8 +3100,8 @@ class ft {
|
|
|
3096
3100
|
a.suspendHistory();
|
|
3097
3101
|
const o = e || s.getActiveObject();
|
|
3098
3102
|
if (!o || !(o instanceof v)) return;
|
|
3099
|
-
const n = o.getObjects(), i = new
|
|
3100
|
-
n.forEach((
|
|
3103
|
+
const n = o.getObjects(), i = new te(n);
|
|
3104
|
+
n.forEach((r) => s.remove(r)), i.set("id", `${i.type}-${A()}`), s.add(i), s.setActiveObject(i), s.renderAll(), a.resumeHistory(), t || a.saveState(), s.fire("editor:objects-grouped", {
|
|
3101
3105
|
object: o,
|
|
3102
3106
|
group: i,
|
|
3103
3107
|
withoutSave: t
|
|
@@ -3108,29 +3112,32 @@ class ft {
|
|
|
3108
3112
|
* @param options
|
|
3109
3113
|
* @param options.object - объект для разгруппировки
|
|
3110
3114
|
* @param options.withoutSave - Не сохранять состояние
|
|
3115
|
+
* @returns данные о разгруппировке или null, если объект не является группой
|
|
3111
3116
|
* @fires editor:objects-ungrouped
|
|
3112
3117
|
*/
|
|
3113
3118
|
ungroup({
|
|
3114
3119
|
object: e,
|
|
3115
3120
|
withoutSave: t
|
|
3116
3121
|
} = {}) {
|
|
3117
|
-
const { canvas: s, historyManager: a } = this.editor;
|
|
3122
|
+
const { canvas: s, historyManager: a } = this.editor, o = e || s.getActiveObject();
|
|
3123
|
+
if (!(o instanceof te)) return null;
|
|
3118
3124
|
a.suspendHistory();
|
|
3119
|
-
const o = e || s.getActiveObject();
|
|
3120
|
-
if (!(o instanceof ee)) return;
|
|
3121
3125
|
const n = o.removeAll();
|
|
3122
|
-
s.remove(o), n.forEach((
|
|
3126
|
+
s.remove(o), n.forEach((d) => s.add(d));
|
|
3123
3127
|
const i = new v(n, {
|
|
3124
3128
|
canvas: s
|
|
3125
3129
|
});
|
|
3126
|
-
s.setActiveObject(i), s.renderAll(), a.resumeHistory(), t || a.saveState()
|
|
3130
|
+
s.setActiveObject(i), s.renderAll(), a.resumeHistory(), t || a.saveState();
|
|
3131
|
+
const r = {
|
|
3127
3132
|
object: o,
|
|
3128
3133
|
selection: i,
|
|
3134
|
+
ungroupedObjects: n,
|
|
3129
3135
|
withoutSave: t
|
|
3130
|
-
}
|
|
3136
|
+
};
|
|
3137
|
+
return s.fire("editor:objects-ungrouped", r), r;
|
|
3131
3138
|
}
|
|
3132
3139
|
}
|
|
3133
|
-
class
|
|
3140
|
+
class bt {
|
|
3134
3141
|
constructor({ editor: e }) {
|
|
3135
3142
|
this.editor = e;
|
|
3136
3143
|
}
|
|
@@ -3145,35 +3152,69 @@ class Mt {
|
|
|
3145
3152
|
o && s.lockObject({ object: n, skipInnerObjects: !0, withoutSave: !0 }), e.setActiveObject(n), e.requestRenderAll(), e.fire("editor:all-objects-selected", { selected: n });
|
|
3146
3153
|
}
|
|
3147
3154
|
}
|
|
3148
|
-
class
|
|
3155
|
+
class de {
|
|
3149
3156
|
constructor({ editor: e }) {
|
|
3150
3157
|
this.editor = e;
|
|
3151
3158
|
}
|
|
3159
|
+
/**
|
|
3160
|
+
* Проверяет, является ли объект разгруппируемой группой
|
|
3161
|
+
* @param obj - объект для проверки
|
|
3162
|
+
* @returns true, если объект является группой и не является SVG
|
|
3163
|
+
*/
|
|
3164
|
+
static _isUngroupableGroup(e) {
|
|
3165
|
+
return e.type === "group" && e.format !== "svg";
|
|
3166
|
+
}
|
|
3167
|
+
/**
|
|
3168
|
+
* Обрабатывает удаление группы: разгруппировывает и рекурсивно удаляет объекты
|
|
3169
|
+
* @param group - группа для обработки
|
|
3170
|
+
* @returns массив всех удаленных объектов (включая саму группу)
|
|
3171
|
+
*/
|
|
3172
|
+
_handleGroupDeletion(e) {
|
|
3173
|
+
var a;
|
|
3174
|
+
const { groupingManager: t } = this.editor, { ungroupedObjects: s = [] } = (a = t.ungroup({
|
|
3175
|
+
object: e,
|
|
3176
|
+
withoutSave: !0
|
|
3177
|
+
})) != null ? a : {};
|
|
3178
|
+
return this.deleteSelectedObjects({
|
|
3179
|
+
objects: s,
|
|
3180
|
+
withoutSave: !0,
|
|
3181
|
+
_isRecursiveCall: !0
|
|
3182
|
+
}), [e, ...s];
|
|
3183
|
+
}
|
|
3152
3184
|
/**
|
|
3153
3185
|
* Удалить выбранные объекты
|
|
3154
3186
|
* @param options
|
|
3155
3187
|
* @param options.objects - массив объектов для удаления
|
|
3156
3188
|
* @param options.withoutSave - Не сохранять состояние
|
|
3189
|
+
* @param options._isRecursiveCall - Внутренний параметр для рекурсивных вызовов
|
|
3157
3190
|
* @fires editor:objects-deleted
|
|
3158
3191
|
*/
|
|
3159
3192
|
deleteSelectedObjects({
|
|
3160
3193
|
objects: e,
|
|
3161
|
-
withoutSave: t
|
|
3194
|
+
withoutSave: t = !1,
|
|
3195
|
+
_isRecursiveCall: s = !1
|
|
3162
3196
|
} = {}) {
|
|
3163
|
-
const { canvas:
|
|
3164
|
-
|
|
3165
|
-
|
|
3166
|
-
|
|
3197
|
+
const { canvas: a, historyManager: o } = this.editor, i = (e || a.getActiveObjects()).filter((h) => !h.locked);
|
|
3198
|
+
if (!(i != null && i.length)) return null;
|
|
3199
|
+
s || o.suspendHistory();
|
|
3200
|
+
const r = [];
|
|
3201
|
+
if (i.forEach((h) => {
|
|
3202
|
+
if (de._isUngroupableGroup(h)) {
|
|
3203
|
+
const l = this._handleGroupDeletion(h);
|
|
3204
|
+
r.push(...l);
|
|
3167
3205
|
return;
|
|
3168
3206
|
}
|
|
3169
|
-
|
|
3170
|
-
}), s
|
|
3171
|
-
|
|
3207
|
+
a.remove(h), r.push(h);
|
|
3208
|
+
}), s) return null;
|
|
3209
|
+
a.discardActiveObject(), a.renderAll(), o.resumeHistory(), t || o.saveState();
|
|
3210
|
+
const d = {
|
|
3211
|
+
objects: r,
|
|
3172
3212
|
withoutSave: t
|
|
3173
|
-
}
|
|
3213
|
+
};
|
|
3214
|
+
return a.fire("editor:objects-deleted", d), d;
|
|
3174
3215
|
}
|
|
3175
3216
|
}
|
|
3176
|
-
const
|
|
3217
|
+
const jt = {
|
|
3177
3218
|
IMAGE_MANAGER: {
|
|
3178
3219
|
/**
|
|
3179
3220
|
* Некорректный Content-Type изображения
|
|
@@ -3272,7 +3313,7 @@ const bt = {
|
|
|
3272
3313
|
INVALID_GRADIENT_FORMAT: "INVALID_GRADIENT_FORMAT"
|
|
3273
3314
|
}
|
|
3274
3315
|
};
|
|
3275
|
-
class
|
|
3316
|
+
class q {
|
|
3276
3317
|
constructor({ editor: e }) {
|
|
3277
3318
|
this._buffer = [], this.editor = e;
|
|
3278
3319
|
}
|
|
@@ -3299,7 +3340,7 @@ class J {
|
|
|
3299
3340
|
* @fires editor:error
|
|
3300
3341
|
*/
|
|
3301
3342
|
emitError({ origin: e = "ImageEditor", method: t = "Unknown Method", code: s, data: a, message: o }) {
|
|
3302
|
-
if (!
|
|
3343
|
+
if (!q.isValidErrorCode(s)) {
|
|
3303
3344
|
console.warn("Неизвестный код ошибки: ", { code: s, origin: e, method: t });
|
|
3304
3345
|
return;
|
|
3305
3346
|
}
|
|
@@ -3328,7 +3369,7 @@ class J {
|
|
|
3328
3369
|
* @fires editor:warning
|
|
3329
3370
|
*/
|
|
3330
3371
|
emitWarning({ origin: e = "ImageEditor", method: t = "Unknown Method", code: s, message: a, data: o }) {
|
|
3331
|
-
if (!
|
|
3372
|
+
if (!q.isValidErrorCode(s)) {
|
|
3332
3373
|
console.warn("Неизвестный код предупреждения: ", { code: s, origin: e, method: t });
|
|
3333
3374
|
return;
|
|
3334
3375
|
}
|
|
@@ -3351,10 +3392,10 @@ class J {
|
|
|
3351
3392
|
* @returns true, если код допустим, иначе false
|
|
3352
3393
|
*/
|
|
3353
3394
|
static isValidErrorCode(e) {
|
|
3354
|
-
return e ? Object.values(
|
|
3395
|
+
return e ? Object.values(jt).some((t) => Object.values(t).includes(e)) : !1;
|
|
3355
3396
|
}
|
|
3356
3397
|
}
|
|
3357
|
-
class
|
|
3398
|
+
class le {
|
|
3358
3399
|
/**
|
|
3359
3400
|
* Конструктор класса ImageEditor.
|
|
3360
3401
|
* @param canvasId - идентификатор канваса, в котором будет создан редактор
|
|
@@ -3369,7 +3410,7 @@ class ce {
|
|
|
3369
3410
|
* @fires editor:ready
|
|
3370
3411
|
*/
|
|
3371
3412
|
init() {
|
|
3372
|
-
return
|
|
3413
|
+
return j(this, null, function* () {
|
|
3373
3414
|
const {
|
|
3374
3415
|
editorContainerWidth: e,
|
|
3375
3416
|
editorContainerHeight: t,
|
|
@@ -3378,11 +3419,11 @@ class ce {
|
|
|
3378
3419
|
canvasCSSWidth: o,
|
|
3379
3420
|
canvasCSSHeight: n,
|
|
3380
3421
|
initialImage: i,
|
|
3381
|
-
initialStateJSON:
|
|
3422
|
+
initialStateJSON: r,
|
|
3382
3423
|
scaleType: d,
|
|
3383
3424
|
_onReadyCallback: h
|
|
3384
3425
|
} = this.options;
|
|
3385
|
-
if (
|
|
3426
|
+
if (Qe.apply(), this.canvas = new Be(this.containerId, this.options), this.moduleLoader = new ze(), this.workerManager = new Ze(), this.errorManager = new q({ editor: this }), this.historyManager = new K({ editor: this }), this.toolbar = new ot({ editor: this }), this.transformManager = new gt({ editor: this }), this.canvasManager = new ht({ editor: this }), this.imageManager = new O({ editor: this }), this.layerManager = new $({ editor: this }), this.shapeManager = new ft({ editor: this }), this.interactionBlocker = new ut({ editor: this }), this.backgroundManager = new R({ editor: this }), this.clipboardManager = new Mt({ editor: this }), this.objectLockManager = new J({ editor: this }), this.groupingManager = new mt({ editor: this }), this.selectionManager = new bt({ editor: this }), this.deletionManager = new de({ editor: this }), this._createMontageArea(), this._createClippingArea(), this.listeners = new P({ editor: this, options: this.options }), this.canvasManager.setEditorContainerWidth(e), this.canvasManager.setEditorContainerHeight(t), this.canvasManager.setCanvasWrapperWidth(s), this.canvasManager.setCanvasWrapperHeight(a), this.canvasManager.setCanvasCSSWidth(o), this.canvasManager.setCanvasCSSHeight(n), i != null && i.source) {
|
|
3386
3427
|
const {
|
|
3387
3428
|
source: l,
|
|
3388
3429
|
scale: g = `image-${d}`,
|
|
@@ -3391,7 +3432,7 @@ class ce {
|
|
|
3391
3432
|
yield this.imageManager.importImage({ source: l, scale: g, withoutSave: u });
|
|
3392
3433
|
} else
|
|
3393
3434
|
this.canvasManager.setDefaultScale({ withoutSave: !0 });
|
|
3394
|
-
|
|
3435
|
+
r && this.historyManager.loadStateFromFullState(r), this.historyManager.saveState(), console.log("editor:ready"), this.canvas.fire("editor:ready", this), typeof h == "function" && h(this);
|
|
3395
3436
|
});
|
|
3396
3437
|
}
|
|
3397
3438
|
/**
|
|
@@ -3405,7 +3446,7 @@ class ce {
|
|
|
3405
3446
|
this.montageArea = this.shapeManager.addRectangle({
|
|
3406
3447
|
width: e,
|
|
3407
3448
|
height: t,
|
|
3408
|
-
fill:
|
|
3449
|
+
fill: le._createMosaicPattern(),
|
|
3409
3450
|
stroke: null,
|
|
3410
3451
|
strokeWidth: 0,
|
|
3411
3452
|
selectable: !1,
|
|
@@ -3455,13 +3496,13 @@ class ce {
|
|
|
3455
3496
|
const e = document.createElement("canvas");
|
|
3456
3497
|
e.width = 20, e.height = 20;
|
|
3457
3498
|
const t = e.getContext("2d");
|
|
3458
|
-
return t.fillStyle = "#ddd", t.fillRect(0, 0, 40, 40), t.fillStyle = "#ccc", t.fillRect(0, 0, 10, 10), t.fillRect(10, 10, 10, 10), new
|
|
3499
|
+
return t.fillStyle = "#ddd", t.fillRect(0, 0, 40, 40), t.fillStyle = "#ccc", t.fillRect(0, 0, 10, 10), t.fillRect(10, 10, 10, 10), new _e({
|
|
3459
3500
|
source: e,
|
|
3460
3501
|
repeat: "repeat"
|
|
3461
3502
|
});
|
|
3462
3503
|
}
|
|
3463
3504
|
}
|
|
3464
|
-
const
|
|
3505
|
+
const pt = {
|
|
3465
3506
|
/**
|
|
3466
3507
|
* Опции редактора
|
|
3467
3508
|
*/
|
|
@@ -3550,18 +3591,18 @@ const jt = {
|
|
|
3550
3591
|
resetObjectFitByDoubleClick: !0,
|
|
3551
3592
|
keyboardIgnoreSelectors: []
|
|
3552
3593
|
};
|
|
3553
|
-
function
|
|
3554
|
-
const t = I(I({},
|
|
3594
|
+
function Dt(c, e = {}) {
|
|
3595
|
+
const t = I(I({}, pt), e), s = document.getElementById(c);
|
|
3555
3596
|
if (!s)
|
|
3556
|
-
return Promise.reject(new Error(`Контейнер с ID "${
|
|
3597
|
+
return Promise.reject(new Error(`Контейнер с ID "${c}" не найден.`));
|
|
3557
3598
|
const a = document.createElement("canvas");
|
|
3558
|
-
return a.id = `${
|
|
3599
|
+
return a.id = `${c}-canvas`, s.appendChild(a), t.editorContainer = s, new Promise((o) => {
|
|
3559
3600
|
t._onReadyCallback = o;
|
|
3560
|
-
const n = new
|
|
3561
|
-
window[
|
|
3601
|
+
const n = new le(a.id, t);
|
|
3602
|
+
window[c] = n;
|
|
3562
3603
|
});
|
|
3563
3604
|
}
|
|
3564
3605
|
export {
|
|
3565
|
-
|
|
3606
|
+
Dt as default
|
|
3566
3607
|
};
|
|
3567
3608
|
//# sourceMappingURL=main.js.map
|