@anu3ev/fabric-image-editor 0.1.74 → 0.1.76
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 +474 -437
- package/package.json +1 -1
package/dist/main.js
CHANGED
|
@@ -1,46 +1,46 @@
|
|
|
1
|
-
var
|
|
2
|
-
var
|
|
1
|
+
var Ae = Object.defineProperty, Ce = Object.defineProperties;
|
|
2
|
+
var Se = Object.getOwnPropertyDescriptors;
|
|
3
3
|
var W = Object.getOwnPropertySymbols;
|
|
4
|
-
var
|
|
5
|
-
var
|
|
4
|
+
var ge = Object.prototype.hasOwnProperty, ue = Object.prototype.propertyIsEnumerable;
|
|
5
|
+
var he = (r, e, t) => e in r ? Ae(r, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : r[e] = t, I = (r, e) => {
|
|
6
6
|
for (var t in e || (e = {}))
|
|
7
|
-
|
|
7
|
+
ge.call(e, t) && he(r, t, e[t]);
|
|
8
8
|
if (W)
|
|
9
9
|
for (var t of W(e))
|
|
10
|
-
|
|
10
|
+
ue.call(e, t) && he(r, t, e[t]);
|
|
11
11
|
return r;
|
|
12
|
-
},
|
|
12
|
+
}, fe = (r, e) => Ce(r, Se(e));
|
|
13
13
|
var F = (r, e) => {
|
|
14
14
|
var t = {};
|
|
15
15
|
for (var s in r)
|
|
16
|
-
|
|
16
|
+
ge.call(r, s) && e.indexOf(s) < 0 && (t[s] = r[s]);
|
|
17
17
|
if (r != null && W)
|
|
18
18
|
for (var s of W(r))
|
|
19
|
-
e.indexOf(s) < 0 &&
|
|
19
|
+
e.indexOf(s) < 0 && ue.call(r, s) && (t[s] = r[s]);
|
|
20
20
|
return t;
|
|
21
21
|
};
|
|
22
22
|
var y = (r, e, t) => new Promise((s, a) => {
|
|
23
|
-
var
|
|
23
|
+
var o = (c) => {
|
|
24
24
|
try {
|
|
25
25
|
i(t.next(c));
|
|
26
26
|
} catch (d) {
|
|
27
27
|
a(d);
|
|
28
28
|
}
|
|
29
|
-
},
|
|
29
|
+
}, n = (c) => {
|
|
30
30
|
try {
|
|
31
31
|
i(t.throw(c));
|
|
32
32
|
} catch (d) {
|
|
33
33
|
a(d);
|
|
34
34
|
}
|
|
35
|
-
}, i = (c) => c.done ? s(c.value) : Promise.resolve(c.value).then(
|
|
35
|
+
}, i = (c) => c.done ? s(c.value) : Promise.resolve(c.value).then(o, n);
|
|
36
36
|
i((t = t.apply(r, e)).next());
|
|
37
37
|
});
|
|
38
|
-
import { ActiveSelection as v, util as P, controlsUtils as
|
|
39
|
-
import { create as
|
|
40
|
-
import
|
|
41
|
-
var
|
|
38
|
+
import { ActiveSelection as v, util as P, controlsUtils as De, InteractiveFabricObject as Ee, loadSVGFromURL as Ne, FabricImage as H, Point as G, Gradient as Me, Rect as Oe, Circle as Le, Triangle as we, Group as ee, Canvas as Te, Pattern as ke } from "fabric";
|
|
39
|
+
import { create as Be } from "jsondiffpatch";
|
|
40
|
+
import _e from "diff-match-patch";
|
|
41
|
+
var xe = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict", A = function() {
|
|
42
42
|
for (var e = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : 21, t = "", s = crypto.getRandomValues(new Uint8Array(e |= 0)); e--; )
|
|
43
|
-
t +=
|
|
43
|
+
t += xe[s[e] & 63];
|
|
44
44
|
return t;
|
|
45
45
|
};
|
|
46
46
|
class Y {
|
|
@@ -72,14 +72,14 @@ class Y {
|
|
|
72
72
|
canvasDragging: t,
|
|
73
73
|
mouseWheelZooming: s,
|
|
74
74
|
bringToFrontOnSelection: a,
|
|
75
|
-
copyObjectsByHotkey:
|
|
76
|
-
pasteImageFromClipboard:
|
|
75
|
+
copyObjectsByHotkey: o,
|
|
76
|
+
pasteImageFromClipboard: n,
|
|
77
77
|
undoRedoByHotKeys: i,
|
|
78
78
|
selectAllByHotkey: c,
|
|
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 }),
|
|
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 })), c && document.addEventListener("keydown", this.handleSelectAllEventBound, { capture: !0 }), d && document.addEventListener("keydown", this.handleDeleteObjectsEventBound, { capture: !0 }), this.canvas.on("object:modified", this.handleObjectModifiedHistoryBound), this.canvas.on("object:rotating", this.handleObjectRotatingHistoryBound), this.canvas.on("object:added", this.handleObjectAddedHistoryBound), this.canvas.on("object:removed", this.handleObjectRemovedHistoryBound), this.canvas.on("object:added", this.handleOverlayUpdateBound), this.canvas.on("selection:created", this.handleOverlayUpdateBound), this.canvas.on("selection:created", this.handleLockedSelectionBound), this.canvas.on("selection:updated", this.handleLockedSelectionBound), this.canvas.on("object:added", this.handleBackgroundUpdateBound), this.canvas.on("selection:created", this.handleBackgroundUpdateBound);
|
|
83
83
|
}
|
|
84
84
|
/**
|
|
85
85
|
* При массовом выделении объектов удаляем из него залоченные.
|
|
@@ -90,7 +90,7 @@ class Y {
|
|
|
90
90
|
_filterLockedSelection({ selected: e, e: t }) {
|
|
91
91
|
if (!(e != null && e.length) || !(t instanceof MouseEvent) || e.length === 1) return;
|
|
92
92
|
const { lockedObjects: s, unlockedObjects: a } = e.reduce(
|
|
93
|
-
(
|
|
93
|
+
(n, i) => i.locked ? (n.lockedObjects.push(i), n) : (n.unlockedObjects.push(i), n),
|
|
94
94
|
{ lockedObjects: [], unlockedObjects: [] }
|
|
95
95
|
);
|
|
96
96
|
if (s.length === 0) return;
|
|
@@ -98,22 +98,22 @@ class Y {
|
|
|
98
98
|
if (a.length === 1)
|
|
99
99
|
this.canvas.setActiveObject(a[0]);
|
|
100
100
|
else {
|
|
101
|
-
const
|
|
101
|
+
const n = new v(a, {
|
|
102
102
|
canvas: this.canvas
|
|
103
103
|
});
|
|
104
|
-
this.canvas.setActiveObject(
|
|
104
|
+
this.canvas.setActiveObject(n);
|
|
105
105
|
}
|
|
106
106
|
this.canvas.requestRenderAll();
|
|
107
107
|
return;
|
|
108
108
|
}
|
|
109
|
-
const
|
|
109
|
+
const o = new v(e, {
|
|
110
110
|
canvas: this.canvas
|
|
111
111
|
});
|
|
112
112
|
this.editor.objectLockManager.lockObject({
|
|
113
|
-
object:
|
|
113
|
+
object: o,
|
|
114
114
|
skipInnerObjects: !0,
|
|
115
115
|
withoutSave: !0
|
|
116
|
-
}), this.canvas.setActiveObject(
|
|
116
|
+
}), this.canvas.setActiveObject(o), this.canvas.requestRenderAll();
|
|
117
117
|
}
|
|
118
118
|
/**
|
|
119
119
|
* Обработчики для сохранения состояния редактора в истории.
|
|
@@ -176,8 +176,8 @@ class Y {
|
|
|
176
176
|
*/
|
|
177
177
|
handleUndoRedoEvent(e) {
|
|
178
178
|
return y(this, null, function* () {
|
|
179
|
-
const { ctrlKey: t, metaKey: s, code: a, repeat:
|
|
180
|
-
this._shouldIgnoreKeyboardEvent(e) || !t && !s ||
|
|
179
|
+
const { ctrlKey: t, metaKey: s, code: a, repeat: o } = e;
|
|
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
|
});
|
|
182
182
|
}
|
|
183
183
|
/**
|
|
@@ -216,11 +216,11 @@ class Y {
|
|
|
216
216
|
*/
|
|
217
217
|
handleSpaceKeyDown(e) {
|
|
218
218
|
if (e.code !== "Space" || this._shouldIgnoreKeyboardEvent(e)) return;
|
|
219
|
-
const { canvas: t, editor: s, isSpacePressed: a, isDragging:
|
|
220
|
-
if (a ||
|
|
219
|
+
const { canvas: t, editor: s, isSpacePressed: a, isDragging: o } = this;
|
|
220
|
+
if (a || o) return;
|
|
221
221
|
this.isSpacePressed = !0, e.preventDefault();
|
|
222
|
-
const
|
|
223
|
-
|
|
222
|
+
const n = t.getActiveObject() || null;
|
|
223
|
+
n instanceof v ? this.savedSelection = n.getObjects().slice() : n && (this.savedSelection = [n]), t.discardActiveObject(), t.set({
|
|
224
224
|
selection: !1,
|
|
225
225
|
defaultCursor: "grab"
|
|
226
226
|
}), t.setCursor("grab"), s.canvasManager.getObjects().forEach((i) => {
|
|
@@ -259,8 +259,8 @@ class Y {
|
|
|
259
259
|
t.setActiveObject(e[0]);
|
|
260
260
|
return;
|
|
261
261
|
}
|
|
262
|
-
const a = e.filter((
|
|
263
|
-
t.setActiveObject(
|
|
262
|
+
const a = e.filter((n) => s.canvasManager.getObjects().includes(n)), o = new v(a, { canvas: t });
|
|
263
|
+
t.setActiveObject(o);
|
|
264
264
|
}
|
|
265
265
|
// --- Обработчики для событий canvas (Fabric) ---
|
|
266
266
|
/**
|
|
@@ -327,16 +327,16 @@ class Y {
|
|
|
327
327
|
_shouldIgnoreKeyboardEvent(e) {
|
|
328
328
|
const t = document.activeElement, s = e.target, a = ["input", "textarea", "select"];
|
|
329
329
|
if (s) {
|
|
330
|
-
const
|
|
331
|
-
if (a.includes(
|
|
330
|
+
const n = s.tagName.toLowerCase();
|
|
331
|
+
if (a.includes(n) || s.contentEditable === "true") return !0;
|
|
332
332
|
}
|
|
333
333
|
if (t && t !== s) {
|
|
334
|
-
const
|
|
335
|
-
if (a.includes(
|
|
334
|
+
const n = t.tagName.toLowerCase();
|
|
335
|
+
if (a.includes(n) || t.contentEditable === "true") return !0;
|
|
336
336
|
}
|
|
337
|
-
const
|
|
338
|
-
if (
|
|
339
|
-
let c =
|
|
337
|
+
const o = window.getSelection();
|
|
338
|
+
if (o && !o.isCollapsed && o.rangeCount > 0) {
|
|
339
|
+
let c = o.getRangeAt(0).commonAncestorContainer;
|
|
340
340
|
c.nodeType === Node.TEXT_NODE && (c = c.parentElement);
|
|
341
341
|
const { keyboardIgnoreSelectors: d } = this.options;
|
|
342
342
|
if (d != null && d.length && c)
|
|
@@ -372,7 +372,7 @@ class Y {
|
|
|
372
372
|
};
|
|
373
373
|
}
|
|
374
374
|
}
|
|
375
|
-
class
|
|
375
|
+
class Re {
|
|
376
376
|
/**
|
|
377
377
|
* Класс для динамической загрузки внешних модулей.
|
|
378
378
|
*/
|
|
@@ -390,7 +390,7 @@ class xe {
|
|
|
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 Ue(r) {
|
|
394
394
|
return new Worker(
|
|
395
395
|
"" + new URL("assets/worker-CN39s7P7.js", import.meta.url).href,
|
|
396
396
|
{
|
|
@@ -398,13 +398,13 @@ function Re(r) {
|
|
|
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 Ue(), this._callbacks = /* @__PURE__ */ new Map(), this.worker.onmessage = this._handleMessage.bind(this);
|
|
408
408
|
}
|
|
409
409
|
/**
|
|
410
410
|
* Обработчик сообщений от воркера
|
|
@@ -417,12 +417,12 @@ class Ue {
|
|
|
417
417
|
* @returns
|
|
418
418
|
*/
|
|
419
419
|
_handleMessage({ data: e }) {
|
|
420
|
-
const { requestId: t, success: s, data: a, error:
|
|
421
|
-
if (!
|
|
420
|
+
const { requestId: t, success: s, data: a, error: o } = e, n = this._callbacks.get(t);
|
|
421
|
+
if (!n) {
|
|
422
422
|
console.warn(`No callback found for requestId: ${t}`);
|
|
423
423
|
return;
|
|
424
424
|
}
|
|
425
|
-
s ?
|
|
425
|
+
s ? n.resolve(a) : n.reject(new Error(o)), this._callbacks.delete(t);
|
|
426
426
|
}
|
|
427
427
|
/**
|
|
428
428
|
* Универсальный метод отправки команды в воркер
|
|
@@ -433,8 +433,8 @@ class Ue {
|
|
|
433
433
|
*/
|
|
434
434
|
post(e, t, s = []) {
|
|
435
435
|
const a = `${e}:${A(8)}`;
|
|
436
|
-
return new Promise((
|
|
437
|
-
this._callbacks.set(a, { resolve:
|
|
436
|
+
return new Promise((o, n) => {
|
|
437
|
+
this._callbacks.set(a, { resolve: o, reject: n }), this.worker.postMessage({ action: e, payload: t, requestId: a }, s);
|
|
438
438
|
});
|
|
439
439
|
}
|
|
440
440
|
/**
|
|
@@ -444,26 +444,26 @@ class Ue {
|
|
|
444
444
|
this.worker.terminate();
|
|
445
445
|
}
|
|
446
446
|
}
|
|
447
|
-
const N = 12, He = 2,
|
|
447
|
+
const N = 12, He = 2, te = 8, se = 20, Ze = 100, ae = 20, oe = 8, Ye = 100, X = 32, ne = 1, Pe = "#2B2D33", ie = "#3D8BF4", re = "#FFFFFF";
|
|
448
448
|
function V(r, e, t, s, a) {
|
|
449
|
-
const
|
|
450
|
-
r.save(), r.translate(e, t), r.rotate(P.degreesToRadians(a.angle)), r.fillStyle =
|
|
451
|
-
}
|
|
452
|
-
function fe(r, e, t, s, a) {
|
|
453
|
-
const n = ee, o = te, i = ze;
|
|
454
|
-
r.save(), r.translate(e, t), r.rotate(P.degreesToRadians(a.angle)), r.fillStyle = ie, r.strokeStyle = oe, r.lineWidth = ne, r.beginPath(), r.roundRect(-n / 2, -o / 2, n, o, i), r.fill(), r.stroke(), r.restore();
|
|
449
|
+
const o = N, n = He;
|
|
450
|
+
r.save(), r.translate(e, t), r.rotate(P.degreesToRadians(a.angle)), r.fillStyle = re, r.strokeStyle = ie, r.lineWidth = ne, r.beginPath(), r.roundRect(-o / 2, -o / 2, o, o, n), r.fill(), r.stroke(), r.restore();
|
|
455
451
|
}
|
|
456
452
|
function me(r, e, t, s, a) {
|
|
457
|
-
const
|
|
458
|
-
r.save(), r.translate(e, t), r.rotate(P.degreesToRadians(a.angle)), r.fillStyle =
|
|
453
|
+
const o = te, n = se, i = Ze;
|
|
454
|
+
r.save(), r.translate(e, t), r.rotate(P.degreesToRadians(a.angle)), r.fillStyle = re, r.strokeStyle = ie, r.lineWidth = ne, r.beginPath(), r.roundRect(-o / 2, -n / 2, o, n, i), r.fill(), r.stroke(), r.restore();
|
|
459
455
|
}
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
const o = X / 2;
|
|
464
|
-
r.save(), r.translate(e, t), r.rotate(P.degreesToRadians(a.angle)), r.fillStyle = Ye, r.beginPath(), r.arc(0, 0, o, 0, 2 * Math.PI), r.fill(), r.drawImage(ye, -o / 2, -o / 2, o, o), r.restore();
|
|
456
|
+
function be(r, e, t, s, a) {
|
|
457
|
+
const o = ae, n = oe, i = Ye;
|
|
458
|
+
r.save(), r.translate(e, t), r.rotate(P.degreesToRadians(a.angle)), r.fillStyle = re, r.strokeStyle = ie, r.lineWidth = ne, r.beginPath(), r.roundRect(-o / 2, -n / 2, o, n, i), r.fill(), r.stroke(), r.restore();
|
|
465
459
|
}
|
|
466
|
-
const
|
|
460
|
+
const We = "", pe = new Image();
|
|
461
|
+
pe.src = We;
|
|
462
|
+
function Fe(r, e, t, s, a) {
|
|
463
|
+
const n = X / 2;
|
|
464
|
+
r.save(), r.translate(e, t), r.rotate(P.degreesToRadians(a.angle)), r.fillStyle = Pe, r.beginPath(), r.arc(0, 0, n, 0, 2 * Math.PI), r.fill(), r.drawImage(pe, -n / 2, -n / 2, n, n), r.restore();
|
|
465
|
+
}
|
|
466
|
+
const Ve = {
|
|
467
467
|
// Угловые точки
|
|
468
468
|
tl: {
|
|
469
469
|
render: V,
|
|
@@ -495,61 +495,61 @@ const Fe = {
|
|
|
495
495
|
},
|
|
496
496
|
// Середина вертикалей
|
|
497
497
|
ml: {
|
|
498
|
-
render:
|
|
499
|
-
sizeX:
|
|
500
|
-
sizeY:
|
|
498
|
+
render: me,
|
|
499
|
+
sizeX: te,
|
|
500
|
+
sizeY: se,
|
|
501
501
|
offsetX: 0,
|
|
502
502
|
offsetY: 0
|
|
503
503
|
},
|
|
504
504
|
mr: {
|
|
505
|
-
render:
|
|
506
|
-
sizeX:
|
|
507
|
-
sizeY:
|
|
505
|
+
render: me,
|
|
506
|
+
sizeX: te,
|
|
507
|
+
sizeY: se,
|
|
508
508
|
offsetX: 0,
|
|
509
509
|
offsetY: 0
|
|
510
510
|
},
|
|
511
511
|
// Середина горизонталей
|
|
512
512
|
mt: {
|
|
513
|
-
render:
|
|
514
|
-
sizeX:
|
|
515
|
-
sizeY:
|
|
513
|
+
render: be,
|
|
514
|
+
sizeX: ae,
|
|
515
|
+
sizeY: oe,
|
|
516
516
|
offsetX: 0,
|
|
517
517
|
offsetY: 0
|
|
518
518
|
},
|
|
519
519
|
mb: {
|
|
520
|
-
render:
|
|
521
|
-
sizeX:
|
|
522
|
-
sizeY:
|
|
520
|
+
render: be,
|
|
521
|
+
sizeX: ae,
|
|
522
|
+
sizeY: oe,
|
|
523
523
|
offsetX: 0,
|
|
524
524
|
offsetY: 0
|
|
525
525
|
},
|
|
526
526
|
// Специальный «rotate» контрол
|
|
527
527
|
mtr: {
|
|
528
|
-
render:
|
|
528
|
+
render: Fe,
|
|
529
529
|
sizeX: X,
|
|
530
530
|
sizeY: X,
|
|
531
531
|
offsetX: 0,
|
|
532
532
|
offsetY: -X
|
|
533
533
|
}
|
|
534
534
|
};
|
|
535
|
-
class
|
|
535
|
+
class Ge {
|
|
536
536
|
static apply() {
|
|
537
|
-
const e =
|
|
538
|
-
Object.entries(
|
|
537
|
+
const e = De.createObjectDefaultControls();
|
|
538
|
+
Object.entries(Ve).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 = (
|
|
545
|
+
}), t === "mtr" && (e[t].cursorStyle = "grab", e[t].mouseDownHandler = (o, n, i, c) => {
|
|
546
546
|
var h;
|
|
547
|
-
(h =
|
|
547
|
+
(h = n.target.canvas) == null || h.setCursor("grabbing");
|
|
548
548
|
});
|
|
549
549
|
}), Ee.ownDefaults.controls = e;
|
|
550
550
|
}
|
|
551
551
|
}
|
|
552
|
-
const
|
|
552
|
+
const Xe = "", Qe = "", Ke = "", $e = "", Je = "", qe = "", et = "", tt = "", Z = {
|
|
553
553
|
style: {
|
|
554
554
|
position: "absolute",
|
|
555
555
|
display: "none",
|
|
@@ -616,14 +616,14 @@ const Ge = "
|
|
|
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: Xe,
|
|
620
|
+
delete: tt,
|
|
621
|
+
lock: Qe,
|
|
622
|
+
unlock: Ke,
|
|
623
|
+
bringToFront: qe,
|
|
624
|
+
sendToBack: et,
|
|
625
|
+
bringForward: $e,
|
|
626
|
+
sendBackwards: Je
|
|
627
627
|
},
|
|
628
628
|
handlers: {
|
|
629
629
|
copyPaste: (r) => y(null, null, function* () {
|
|
@@ -652,14 +652,14 @@ const Ge = "
|
|
|
652
652
|
}
|
|
653
653
|
}
|
|
654
654
|
};
|
|
655
|
-
class
|
|
655
|
+
class st {
|
|
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 =
|
|
662
|
+
this.config = fe(I(I({}, Z), e), {
|
|
663
663
|
style: I(I({}, Z.style), e.style || {}),
|
|
664
664
|
btnStyle: I(I({}, Z.btnStyle), e.btnStyle || {}),
|
|
665
665
|
icons: I(I({}, Z.icons), e.icons || {}),
|
|
@@ -690,8 +690,8 @@ class tt {
|
|
|
690
690
|
_renderButtons(e) {
|
|
691
691
|
this.el.innerHTML = "";
|
|
692
692
|
for (const t of e) {
|
|
693
|
-
const { name: s, handle: a } = t, { icons:
|
|
694
|
-
c.innerHTML =
|
|
693
|
+
const { name: s, handle: a } = t, { icons: o = {}, btnStyle: n, handlers: i = {} } = this.config, c = document.createElement("button");
|
|
694
|
+
c.innerHTML = o[a] ? `<img src="${o[a]}" title="${s}" />` : s, Object.assign(c.style, n), c.onclick = () => {
|
|
695
695
|
var d;
|
|
696
696
|
return (d = i[a]) == null ? void 0 : d.call(i, this.editor);
|
|
697
697
|
}, c.onmousedown = (d) => {
|
|
@@ -754,10 +754,10 @@ class tt {
|
|
|
754
754
|
}
|
|
755
755
|
const { el: t, config: s, canvas: a } = this;
|
|
756
756
|
e.setCoords();
|
|
757
|
-
const
|
|
757
|
+
const o = a.getZoom(), [, , , , n, i] = a.viewportTransform, { x: c } = e.getCenterPoint(), { top: d, height: h } = e.getBoundingRect(), g = c * 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
|
-
top: `${
|
|
760
|
+
top: `${M}px`,
|
|
761
761
|
display: "flex"
|
|
762
762
|
});
|
|
763
763
|
}
|
|
@@ -768,7 +768,7 @@ class tt {
|
|
|
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 Q {
|
|
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,12 +780,13 @@ class st {
|
|
|
780
780
|
return this.patches[this.currentIndex - 1] || null;
|
|
781
781
|
}
|
|
782
782
|
_createDiffPatcher() {
|
|
783
|
-
this.diffPatcher =
|
|
783
|
+
this.diffPatcher = Be({
|
|
784
784
|
objectHash(e) {
|
|
785
785
|
const t = e;
|
|
786
786
|
return [
|
|
787
787
|
t.id,
|
|
788
788
|
t.backgroundId,
|
|
789
|
+
t.customData,
|
|
789
790
|
t.format,
|
|
790
791
|
t.locked,
|
|
791
792
|
t.left,
|
|
@@ -805,7 +806,7 @@ class st {
|
|
|
805
806
|
includeValueOnMove: !1
|
|
806
807
|
},
|
|
807
808
|
textDiff: {
|
|
808
|
-
diffMatchPatch:
|
|
809
|
+
diffMatchPatch: _e,
|
|
809
810
|
minLength: 60
|
|
810
811
|
}
|
|
811
812
|
});
|
|
@@ -836,8 +837,8 @@ class st {
|
|
|
836
837
|
getFullState() {
|
|
837
838
|
const { baseState: e, currentIndex: t, patches: s } = this;
|
|
838
839
|
let a = JSON.parse(JSON.stringify(e));
|
|
839
|
-
for (let
|
|
840
|
-
a = this.diffPatcher.patch(a, s[
|
|
840
|
+
for (let o = 0; o < t; o += 1)
|
|
841
|
+
a = this.diffPatcher.patch(a, s[o].diff);
|
|
841
842
|
return console.log("getFullState state", a), a;
|
|
842
843
|
}
|
|
843
844
|
/**
|
|
@@ -851,6 +852,7 @@ class st {
|
|
|
851
852
|
"evented",
|
|
852
853
|
"id",
|
|
853
854
|
"backgroundId",
|
|
855
|
+
"customData",
|
|
854
856
|
"backgroundType",
|
|
855
857
|
"format",
|
|
856
858
|
"width",
|
|
@@ -875,6 +877,31 @@ class st {
|
|
|
875
877
|
}
|
|
876
878
|
console.log("baseState", this.baseState), this.currentIndex < this.patches.length && this.patches.splice(this.currentIndex), console.log("diff", s), this.totalChangesCount += 1, this.patches.push({ id: A(), diff: s }), this.currentIndex += 1, this.patches.length > this.maxHistoryLength && (this.baseState = this.diffPatcher.patch(this.baseState, this.patches[0].diff), this.patches.shift(), this.currentIndex -= 1, this.baseStateChangesCount += 1), console.log("Состояние сохранено. Текущий индекс истории:", this.currentIndex);
|
|
877
879
|
}
|
|
880
|
+
/**
|
|
881
|
+
* Сериализует customData объектов в строку. Это необходимо чтобы при вызове loadFromJSON fabricjs не пытался обрабатывать свойства внутри customData, как свойства FabricObject, если их названия совпадают с зарезервированными.
|
|
882
|
+
*
|
|
883
|
+
* @param state - состояние канваса для сериализации
|
|
884
|
+
*/
|
|
885
|
+
static _serializeCustomData(e) {
|
|
886
|
+
e.objects && e.objects.forEach((t) => {
|
|
887
|
+
t.customData && typeof t.customData == "object" && (t._serializedCustomData = JSON.stringify(t.customData), delete t.customData);
|
|
888
|
+
});
|
|
889
|
+
}
|
|
890
|
+
/**
|
|
891
|
+
* Десериализует customData из строки обратно в объект
|
|
892
|
+
* @param serializedObj - сериализованный объект из JSON
|
|
893
|
+
* @param fabricObject - объект Fabric, в который нужно записать customData
|
|
894
|
+
*/
|
|
895
|
+
static _deserializeCustomData(e, t) {
|
|
896
|
+
if (!(!e._serializedCustomData || !t))
|
|
897
|
+
try {
|
|
898
|
+
t.customData = JSON.parse(
|
|
899
|
+
e._serializedCustomData
|
|
900
|
+
);
|
|
901
|
+
} catch (s) {
|
|
902
|
+
console.warn("Не удалось десериализовать customData:", s), t.customData = {};
|
|
903
|
+
}
|
|
904
|
+
}
|
|
878
905
|
/**
|
|
879
906
|
* Функция загрузки состояния в канвас.
|
|
880
907
|
* @param fullState - полное состояние канваса
|
|
@@ -884,14 +911,16 @@ class st {
|
|
|
884
911
|
return y(this, null, function* () {
|
|
885
912
|
if (!e) return;
|
|
886
913
|
console.log("loadStateFromFullState fullState", e);
|
|
887
|
-
const { canvas: t, canvasManager: s, interactionBlocker: a, backgroundManager:
|
|
888
|
-
yield t.loadFromJSON(e)
|
|
914
|
+
const { canvas: t, canvasManager: s, interactionBlocker: a, backgroundManager: o } = this.editor, { width: n, height: i } = t;
|
|
915
|
+
a.overlayMask = null, Q._serializeCustomData(e), yield t.loadFromJSON(e, (l, g) => {
|
|
916
|
+
Q._deserializeCustomData(l, g);
|
|
917
|
+
});
|
|
889
918
|
const c = t.getObjects().find((l) => l.id === "montage-area");
|
|
890
|
-
c && (this.editor.montageArea = c, (
|
|
919
|
+
c && (this.editor.montageArea = c, (n !== t.getWidth() || i !== t.getHeight()) && s.updateCanvas());
|
|
891
920
|
const d = t.getObjects().find((l) => l.id === "overlay-mask");
|
|
892
921
|
d && (a.overlayMask = d, a.overlayMask.visible = !1);
|
|
893
922
|
const h = t.getObjects().find((l) => l.id === "background");
|
|
894
|
-
h ?
|
|
923
|
+
h ? o.backgroundObject = h : o.removeBackground({ withoutSave: !0 }), t.renderAll(), t.fire("editor:history-state-loaded", {
|
|
895
924
|
fullState: e,
|
|
896
925
|
currentIndex: this.currentIndex,
|
|
897
926
|
totalChangesCount: this.totalChangesCount,
|
|
@@ -976,7 +1005,7 @@ class st {
|
|
|
976
1005
|
});
|
|
977
1006
|
}
|
|
978
1007
|
}
|
|
979
|
-
const at = 0.1,
|
|
1008
|
+
const at = 0.1, ot = 2, nt = 0.1, it = 90, R = 16, U = 16, w = 4096, T = 4096, je = "application/image-editor:";
|
|
980
1009
|
class O {
|
|
981
1010
|
constructor({ editor: e }) {
|
|
982
1011
|
this.editor = e, this.options = e.options, this._createdBlobUrls = [], this.acceptContentTypes = this.editor.options.acceptContentTypes, this.acceptFormats = this.getAllowedFormatsFromContentTypes();
|
|
@@ -999,12 +1028,12 @@ class O {
|
|
|
999
1028
|
source: t,
|
|
1000
1029
|
scale: s = `image-${this.options.scaleType}`,
|
|
1001
1030
|
withoutSave: a = !1,
|
|
1002
|
-
fromClipboard:
|
|
1003
|
-
isBackground:
|
|
1031
|
+
fromClipboard: o = !1,
|
|
1032
|
+
isBackground: n = !1,
|
|
1004
1033
|
withoutSelection: i = !1
|
|
1005
1034
|
} = e;
|
|
1006
1035
|
if (!t) return null;
|
|
1007
|
-
const { canvas: c, montageArea: d, transformManager: h, historyManager: l, errorManager: g } = this.editor, u = yield this.getContentType(t),
|
|
1036
|
+
const { canvas: c, montageArea: d, transformManager: h, historyManager: l, errorManager: g } = this.editor, u = yield this.getContentType(t), M = O.getFormatFromContentType(u), { acceptContentTypes: m, acceptFormats: f } = this;
|
|
1008
1037
|
if (!this.isAllowedContentType(u)) {
|
|
1009
1038
|
const j = `Неверный contentType для изображения: ${u}. Ожидается один из: ${this.acceptContentTypes.join(", ")}.`;
|
|
1010
1039
|
return g.emitError({
|
|
@@ -1014,12 +1043,12 @@ class O {
|
|
|
1014
1043
|
message: j,
|
|
1015
1044
|
data: {
|
|
1016
1045
|
source: t,
|
|
1017
|
-
format:
|
|
1046
|
+
format: M,
|
|
1018
1047
|
contentType: u,
|
|
1019
1048
|
acceptContentTypes: m,
|
|
1020
|
-
acceptFormats:
|
|
1021
|
-
fromClipboard:
|
|
1022
|
-
isBackground:
|
|
1049
|
+
acceptFormats: f,
|
|
1050
|
+
fromClipboard: o,
|
|
1051
|
+
isBackground: n,
|
|
1023
1052
|
withoutSelection: i
|
|
1024
1053
|
}
|
|
1025
1054
|
}), null;
|
|
@@ -1030,8 +1059,8 @@ class O {
|
|
|
1030
1059
|
if (t instanceof File)
|
|
1031
1060
|
j = URL.createObjectURL(t);
|
|
1032
1061
|
else if (typeof t == "string") {
|
|
1033
|
-
const
|
|
1034
|
-
j = URL.createObjectURL(
|
|
1062
|
+
const D = yield (yield fetch(t, { mode: "cors" })).blob();
|
|
1063
|
+
j = URL.createObjectURL(D);
|
|
1035
1064
|
} else
|
|
1036
1065
|
return g.emitError({
|
|
1037
1066
|
origin: "ImageManager",
|
|
@@ -1040,51 +1069,51 @@ class O {
|
|
|
1040
1069
|
message: "Неверный тип источника изображения. Ожидается URL или объект File.",
|
|
1041
1070
|
data: {
|
|
1042
1071
|
source: t,
|
|
1043
|
-
format:
|
|
1072
|
+
format: M,
|
|
1044
1073
|
contentType: u,
|
|
1045
1074
|
acceptContentTypes: m,
|
|
1046
|
-
acceptFormats:
|
|
1047
|
-
fromClipboard:
|
|
1048
|
-
isBackground:
|
|
1075
|
+
acceptFormats: f,
|
|
1076
|
+
fromClipboard: o,
|
|
1077
|
+
isBackground: n,
|
|
1049
1078
|
withoutSelection: i
|
|
1050
1079
|
}
|
|
1051
1080
|
}), null;
|
|
1052
|
-
if (this._createdBlobUrls.push(j),
|
|
1053
|
-
const C = yield
|
|
1081
|
+
if (this._createdBlobUrls.push(j), M === "svg") {
|
|
1082
|
+
const C = yield Ne(j);
|
|
1054
1083
|
b = P.groupSVGElements(C.objects, C.options);
|
|
1055
1084
|
} else
|
|
1056
|
-
b = yield
|
|
1085
|
+
b = yield H.fromURL(j, { crossOrigin: "anonymous" });
|
|
1057
1086
|
const { width: S, height: k } = b;
|
|
1058
|
-
if (b instanceof
|
|
1087
|
+
if (b instanceof H) {
|
|
1059
1088
|
const C = b.getElement();
|
|
1060
|
-
let
|
|
1061
|
-
if (C instanceof HTMLImageElement ?
|
|
1062
|
-
const L = yield this.resizeImageToBoundaries(
|
|
1063
|
-
this._createdBlobUrls.push(p), b = yield
|
|
1089
|
+
let D = "";
|
|
1090
|
+
if (C instanceof HTMLImageElement ? D = C.src : C instanceof HTMLCanvasElement && (D = C.toDataURL()), k > T || S > w) {
|
|
1091
|
+
const L = yield this.resizeImageToBoundaries(D, "max"), p = URL.createObjectURL(L);
|
|
1092
|
+
this._createdBlobUrls.push(p), b = yield H.fromURL(p, { crossOrigin: "anonymous" });
|
|
1064
1093
|
} else if (k < U || S < R) {
|
|
1065
|
-
const L = yield this.resizeImageToBoundaries(
|
|
1066
|
-
this._createdBlobUrls.push(p), b = yield
|
|
1094
|
+
const L = yield this.resizeImageToBoundaries(D, "min"), p = URL.createObjectURL(L);
|
|
1095
|
+
this._createdBlobUrls.push(p), b = yield H.fromURL(p, { crossOrigin: "anonymous" });
|
|
1067
1096
|
}
|
|
1068
1097
|
}
|
|
1069
|
-
if (b.set("id", `${b.type}-${A()}`), b.set("format",
|
|
1098
|
+
if (b.set("id", `${b.type}-${A()}`), b.set("format", M), s === "scale-montage")
|
|
1070
1099
|
this.editor.canvasManager.scaleMontageAreaToImage({ object: b, withoutSave: !0 });
|
|
1071
1100
|
else {
|
|
1072
|
-
const { width: C, height:
|
|
1073
|
-
s === "image-contain" && L < 1 ? h.fitObject({ object: b, type: "contain", withoutSave: !0 }) : s === "image-cover" && (S > C || k >
|
|
1101
|
+
const { width: C, height: D } = d, L = this.calculateScaleFactor({ imageObject: b, scaleType: s });
|
|
1102
|
+
s === "image-contain" && L < 1 ? h.fitObject({ object: b, type: "contain", withoutSave: !0 }) : s === "image-cover" && (S > C || k > D) && h.fitObject({ object: b, type: "cover", withoutSave: !0 });
|
|
1074
1103
|
}
|
|
1075
1104
|
c.add(b), c.centerObject(b), i || c.setActiveObject(b), c.renderAll(), l.resumeHistory(), a || l.saveState();
|
|
1076
|
-
const
|
|
1105
|
+
const z = {
|
|
1077
1106
|
image: b,
|
|
1078
|
-
format:
|
|
1107
|
+
format: M,
|
|
1079
1108
|
contentType: u,
|
|
1080
1109
|
scale: s,
|
|
1081
1110
|
withoutSave: a,
|
|
1082
1111
|
source: t,
|
|
1083
|
-
fromClipboard:
|
|
1084
|
-
isBackground:
|
|
1112
|
+
fromClipboard: o,
|
|
1113
|
+
isBackground: n,
|
|
1085
1114
|
withoutSelection: i
|
|
1086
1115
|
};
|
|
1087
|
-
return c.fire("editor:image-imported",
|
|
1116
|
+
return c.fire("editor:image-imported", z), z;
|
|
1088
1117
|
} catch (j) {
|
|
1089
1118
|
return g.emitError({
|
|
1090
1119
|
origin: "ImageManager",
|
|
@@ -1093,12 +1122,12 @@ class O {
|
|
|
1093
1122
|
message: `Ошибка импорта изображения: ${j.message}`,
|
|
1094
1123
|
data: {
|
|
1095
1124
|
source: t,
|
|
1096
|
-
format:
|
|
1125
|
+
format: M,
|
|
1097
1126
|
contentType: u,
|
|
1098
1127
|
scale: s,
|
|
1099
1128
|
withoutSave: a,
|
|
1100
|
-
fromClipboard:
|
|
1101
|
-
isBackground:
|
|
1129
|
+
fromClipboard: o,
|
|
1130
|
+
isBackground: n,
|
|
1102
1131
|
withoutSelection: i
|
|
1103
1132
|
}
|
|
1104
1133
|
}), l.resumeHistory(), null;
|
|
@@ -1151,81 +1180,81 @@ class O {
|
|
|
1151
1180
|
fileName: t = "image.png",
|
|
1152
1181
|
contentType: s = "image/png",
|
|
1153
1182
|
exportAsBase64: a = !1,
|
|
1154
|
-
exportAsBlob:
|
|
1155
|
-
} = e, { canvas:
|
|
1183
|
+
exportAsBlob: o = !1
|
|
1184
|
+
} = e, { canvas: n, montageArea: i, workerManager: c } = this.editor;
|
|
1156
1185
|
try {
|
|
1157
1186
|
const d = s === "application/pdf", h = d ? "image/jpg" : s, l = O.getFormatFromContentType(h);
|
|
1158
1187
|
i.setCoords();
|
|
1159
|
-
const { left: g, top: u, width:
|
|
1160
|
-
|
|
1161
|
-
const j =
|
|
1162
|
-
j && (j.visible = !1),
|
|
1163
|
-
const b =
|
|
1188
|
+
const { left: g, top: u, width: M, height: m } = i.getBoundingRect(), f = yield n.clone(["id", "format", "locked"]);
|
|
1189
|
+
f.enableRetinaScaling = !1, ["image/jpg", "image/jpeg"].includes(h) && (f.backgroundColor = "#ffffff");
|
|
1190
|
+
const j = f.getObjects().find((p) => p.id === i.id);
|
|
1191
|
+
j && (j.visible = !1), f.viewportTransform = [1, 0, 0, 1, -g, -u], f.setDimensions({ width: M, height: m }, { backstoreOnly: !0 }), f.renderAll();
|
|
1192
|
+
const b = f.getObjects().filter((p) => p.format).every((p) => p.format === "svg");
|
|
1164
1193
|
if (l === "svg" && b) {
|
|
1165
|
-
const p =
|
|
1166
|
-
|
|
1167
|
-
const
|
|
1194
|
+
const p = f.toSVG();
|
|
1195
|
+
f.dispose();
|
|
1196
|
+
const E = {
|
|
1168
1197
|
image: O._exportSVGStringAsFile(p, {
|
|
1169
1198
|
exportAsBase64: a,
|
|
1170
|
-
exportAsBlob:
|
|
1199
|
+
exportAsBlob: o,
|
|
1171
1200
|
fileName: t
|
|
1172
1201
|
}),
|
|
1173
1202
|
format: "svg",
|
|
1174
1203
|
contentType: "image/svg+xml",
|
|
1175
1204
|
fileName: t.replace(/\.[^/.]+$/, ".svg")
|
|
1176
1205
|
};
|
|
1177
|
-
return
|
|
1206
|
+
return n.fire("editor:canvas-exported", E), E;
|
|
1178
1207
|
}
|
|
1179
1208
|
const S = yield new Promise((p, B) => {
|
|
1180
|
-
|
|
1181
|
-
|
|
1209
|
+
f.getElement().toBlob((E) => {
|
|
1210
|
+
E ? p(E) : B(new Error("Failed to create Blob from canvas"));
|
|
1182
1211
|
});
|
|
1183
1212
|
});
|
|
1184
|
-
if (
|
|
1213
|
+
if (f.dispose(), o) {
|
|
1185
1214
|
const p = {
|
|
1186
1215
|
image: S,
|
|
1187
1216
|
format: l,
|
|
1188
1217
|
contentType: h,
|
|
1189
1218
|
fileName: t
|
|
1190
1219
|
};
|
|
1191
|
-
return
|
|
1220
|
+
return n.fire("editor:canvas-exported", p), p;
|
|
1192
1221
|
}
|
|
1193
|
-
const k = yield createImageBitmap(S),
|
|
1222
|
+
const k = yield createImageBitmap(S), z = yield c.post(
|
|
1194
1223
|
"toDataURL",
|
|
1195
1224
|
{ format: l, quality: 1, bitmap: k },
|
|
1196
1225
|
[k]
|
|
1197
1226
|
);
|
|
1198
1227
|
if (d) {
|
|
1199
|
-
const B =
|
|
1200
|
-
orientation: B >
|
|
1228
|
+
const B = M * 0.264583, E = m * 0.264583, Ie = (yield this.editor.moduleLoader.loadModule("jspdf")).jsPDF, q = new Ie({
|
|
1229
|
+
orientation: B > E ? "landscape" : "portrait",
|
|
1201
1230
|
unit: "mm",
|
|
1202
|
-
format: [B,
|
|
1231
|
+
format: [B, E]
|
|
1203
1232
|
});
|
|
1204
|
-
if (
|
|
1205
|
-
const
|
|
1206
|
-
image:
|
|
1233
|
+
if (q.addImage(String(z), "JPG", 0, 0, B, E), a) {
|
|
1234
|
+
const le = {
|
|
1235
|
+
image: q.output("datauristring"),
|
|
1207
1236
|
format: "pdf",
|
|
1208
1237
|
contentType: "application/pdf",
|
|
1209
1238
|
fileName: t
|
|
1210
1239
|
};
|
|
1211
|
-
return
|
|
1240
|
+
return n.fire("editor:canvas-exported", le), le;
|
|
1212
1241
|
}
|
|
1213
|
-
const
|
|
1214
|
-
image: new File([
|
|
1242
|
+
const ve = q.output("blob"), de = {
|
|
1243
|
+
image: new File([ve], t, { type: "application/pdf" }),
|
|
1215
1244
|
format: "pdf",
|
|
1216
1245
|
contentType: "application/pdf",
|
|
1217
1246
|
fileName: t
|
|
1218
1247
|
};
|
|
1219
|
-
return
|
|
1248
|
+
return n.fire("editor:canvas-exported", de), de;
|
|
1220
1249
|
}
|
|
1221
1250
|
if (a) {
|
|
1222
1251
|
const p = {
|
|
1223
|
-
image:
|
|
1252
|
+
image: z,
|
|
1224
1253
|
format: l,
|
|
1225
1254
|
contentType: h,
|
|
1226
1255
|
fileName: t
|
|
1227
1256
|
};
|
|
1228
|
-
return
|
|
1257
|
+
return n.fire("editor:canvas-exported", p), p;
|
|
1229
1258
|
}
|
|
1230
1259
|
const C = l === "svg" && !b ? t.replace(/\.[^/.]+$/, ".png") : t, L = {
|
|
1231
1260
|
image: new File([S], C, { type: h }),
|
|
@@ -1233,14 +1262,14 @@ class O {
|
|
|
1233
1262
|
contentType: h,
|
|
1234
1263
|
fileName: C
|
|
1235
1264
|
};
|
|
1236
|
-
return
|
|
1265
|
+
return n.fire("editor:canvas-exported", L), L;
|
|
1237
1266
|
} catch (d) {
|
|
1238
1267
|
return this.editor.errorManager.emitError({
|
|
1239
1268
|
origin: "ImageManager",
|
|
1240
1269
|
method: "exportCanvasAsImageFile",
|
|
1241
1270
|
code: "IMAGE_EXPORT_FAILED",
|
|
1242
1271
|
message: `Ошибка экспорта изображения: ${d.message}`,
|
|
1243
|
-
data: { contentType: s, fileName: t, exportAsBase64: a, exportAsBlob:
|
|
1272
|
+
data: { contentType: s, fileName: t, exportAsBase64: a, exportAsBlob: o }
|
|
1244
1273
|
}), null;
|
|
1245
1274
|
}
|
|
1246
1275
|
});
|
|
@@ -1262,8 +1291,8 @@ class O {
|
|
|
1262
1291
|
object: t,
|
|
1263
1292
|
fileName: s = "image.png",
|
|
1264
1293
|
contentType: a = "image/png",
|
|
1265
|
-
exportAsBase64:
|
|
1266
|
-
exportAsBlob:
|
|
1294
|
+
exportAsBase64: o = !1,
|
|
1295
|
+
exportAsBlob: n = !1
|
|
1267
1296
|
} = e, { canvas: i, workerManager: c } = this.editor, d = t || i.getActiveObject();
|
|
1268
1297
|
if (!d)
|
|
1269
1298
|
return this.editor.errorManager.emitError({
|
|
@@ -1271,26 +1300,26 @@ class O {
|
|
|
1271
1300
|
method: "exportObjectAsImageFile",
|
|
1272
1301
|
code: "NO_OBJECT_SELECTED",
|
|
1273
1302
|
message: "Не выбран объект для экспорта",
|
|
1274
|
-
data: { contentType: a, fileName: s, exportAsBase64:
|
|
1303
|
+
data: { contentType: a, fileName: s, exportAsBase64: o, exportAsBlob: n }
|
|
1275
1304
|
}), null;
|
|
1276
1305
|
try {
|
|
1277
1306
|
const h = O.getFormatFromContentType(a);
|
|
1278
1307
|
if (h === "svg") {
|
|
1279
|
-
const m = d.toSVG(),
|
|
1280
|
-
exportAsBase64:
|
|
1281
|
-
exportAsBlob:
|
|
1308
|
+
const m = d.toSVG(), f = O._exportSVGStringAsFile(m, {
|
|
1309
|
+
exportAsBase64: o,
|
|
1310
|
+
exportAsBlob: n,
|
|
1282
1311
|
fileName: s
|
|
1283
1312
|
}), j = {
|
|
1284
1313
|
object: d,
|
|
1285
|
-
image:
|
|
1314
|
+
image: f,
|
|
1286
1315
|
format: h,
|
|
1287
1316
|
contentType: "image/svg+xml",
|
|
1288
1317
|
fileName: s.replace(/\.[^/.]+$/, ".svg")
|
|
1289
1318
|
};
|
|
1290
1319
|
return i.fire("editor:object-exported", j), j;
|
|
1291
1320
|
}
|
|
1292
|
-
if (
|
|
1293
|
-
const m = yield createImageBitmap(d.getElement()),
|
|
1321
|
+
if (o && d instanceof H) {
|
|
1322
|
+
const m = yield createImageBitmap(d.getElement()), f = yield c.post(
|
|
1294
1323
|
"toDataURL",
|
|
1295
1324
|
{
|
|
1296
1325
|
format: h,
|
|
@@ -1300,7 +1329,7 @@ class O {
|
|
|
1300
1329
|
[m]
|
|
1301
1330
|
), j = {
|
|
1302
1331
|
object: d,
|
|
1303
|
-
image:
|
|
1332
|
+
image: f,
|
|
1304
1333
|
format: h,
|
|
1305
1334
|
contentType: a,
|
|
1306
1335
|
fileName: s
|
|
@@ -1309,12 +1338,12 @@ class O {
|
|
|
1309
1338
|
}
|
|
1310
1339
|
const l = d.toCanvasElement({
|
|
1311
1340
|
enableRetinaScaling: !1
|
|
1312
|
-
}), g = yield new Promise((m,
|
|
1341
|
+
}), g = yield new Promise((m, f) => {
|
|
1313
1342
|
l.toBlob((j) => {
|
|
1314
|
-
j ? m(j) :
|
|
1343
|
+
j ? m(j) : f(new Error("Failed to create Blob from canvas"));
|
|
1315
1344
|
});
|
|
1316
1345
|
});
|
|
1317
|
-
if (
|
|
1346
|
+
if (n) {
|
|
1318
1347
|
const m = {
|
|
1319
1348
|
object: d,
|
|
1320
1349
|
image: g,
|
|
@@ -1324,21 +1353,21 @@ class O {
|
|
|
1324
1353
|
};
|
|
1325
1354
|
return i.fire("editor:object-exported", m), m;
|
|
1326
1355
|
}
|
|
1327
|
-
const u = new File([g], s, { type: a }),
|
|
1356
|
+
const u = new File([g], s, { type: a }), M = {
|
|
1328
1357
|
object: d,
|
|
1329
1358
|
image: u,
|
|
1330
1359
|
format: h,
|
|
1331
1360
|
contentType: a,
|
|
1332
1361
|
fileName: s
|
|
1333
1362
|
};
|
|
1334
|
-
return i.fire("editor:object-exported",
|
|
1363
|
+
return i.fire("editor:object-exported", M), M;
|
|
1335
1364
|
} catch (h) {
|
|
1336
1365
|
return this.editor.errorManager.emitError({
|
|
1337
1366
|
origin: "ImageManager",
|
|
1338
1367
|
method: "exportObjectAsImageFile",
|
|
1339
1368
|
code: "IMAGE_EXPORT_FAILED",
|
|
1340
1369
|
message: `Ошибка экспорта объекта: ${h.message}`,
|
|
1341
|
-
data: { contentType: a, fileName: s, exportAsBase64:
|
|
1370
|
+
data: { contentType: a, fileName: s, exportAsBase64: o, exportAsBlob: n }
|
|
1342
1371
|
}), null;
|
|
1343
1372
|
}
|
|
1344
1373
|
});
|
|
@@ -1405,11 +1434,11 @@ class O {
|
|
|
1405
1434
|
getContentTypeFromExtension(e) {
|
|
1406
1435
|
var t;
|
|
1407
1436
|
try {
|
|
1408
|
-
const a = (t = new URL(e).pathname.split(".").pop()) == null ? void 0 : t.toLowerCase(),
|
|
1409
|
-
return this.acceptContentTypes.forEach((
|
|
1410
|
-
const i = O.getFormatFromContentType(
|
|
1411
|
-
i && (
|
|
1412
|
-
}), a &&
|
|
1437
|
+
const a = (t = new URL(e).pathname.split(".").pop()) == null ? void 0 : t.toLowerCase(), o = {};
|
|
1438
|
+
return this.acceptContentTypes.forEach((n) => {
|
|
1439
|
+
const i = O.getFormatFromContentType(n);
|
|
1440
|
+
i && (o[i] = n);
|
|
1441
|
+
}), a && o[a] || "application/octet-stream";
|
|
1413
1442
|
} catch (s) {
|
|
1414
1443
|
return console.warn("Не удалось определить расширение из URL:", e, s), "application/octet-stream";
|
|
1415
1444
|
}
|
|
@@ -1427,8 +1456,8 @@ class O {
|
|
|
1427
1456
|
}) {
|
|
1428
1457
|
const { montageArea: s } = this.editor;
|
|
1429
1458
|
if (!s || !e) return 1;
|
|
1430
|
-
const a = s.width,
|
|
1431
|
-
return t === "contain" || t === "image-contain" ? Math.min(a /
|
|
1459
|
+
const a = s.width, o = s.height, { width: n, height: i } = e;
|
|
1460
|
+
return t === "contain" || t === "image-contain" ? Math.min(a / n, o / i) : t === "cover" || t === "image-cover" ? Math.max(a / n, o / i) : 1;
|
|
1432
1461
|
}
|
|
1433
1462
|
/**
|
|
1434
1463
|
* Преобразует SVG-строку в Blob, файл, или base64
|
|
@@ -1460,7 +1489,7 @@ class O {
|
|
|
1460
1489
|
return t ? t[1] : "";
|
|
1461
1490
|
}
|
|
1462
1491
|
}
|
|
1463
|
-
const _ = (r, e, t) => Math.max(Math.min(r, t), e),
|
|
1492
|
+
const _ = (r, e, t) => Math.max(Math.min(r, t), e), ye = (r, e) => r * e, rt = (r, e) => new G(r / 2, e / 2);
|
|
1464
1493
|
function ct(r) {
|
|
1465
1494
|
return ((r == null ? void 0 : r.type) === "image" || (r == null ? void 0 : r.format) === "svg") && typeof (r == null ? void 0 : r.width) == "number" && typeof (r == null ? void 0 : r.height) == "number";
|
|
1466
1495
|
}
|
|
@@ -1489,20 +1518,20 @@ class dt {
|
|
|
1489
1518
|
* @fires editor:resolution-width-changed
|
|
1490
1519
|
*/
|
|
1491
1520
|
setResolutionWidth(e, { preserveProportional: t, withoutSave: s, adaptCanvasToContainer: a } = {}) {
|
|
1492
|
-
var
|
|
1521
|
+
var M;
|
|
1493
1522
|
if (!e) return;
|
|
1494
1523
|
const {
|
|
1495
|
-
canvas:
|
|
1496
|
-
montageArea:
|
|
1524
|
+
canvas: o,
|
|
1525
|
+
montageArea: n,
|
|
1497
1526
|
options: { canvasBackstoreWidth: i }
|
|
1498
|
-
} = this.editor, { width: c, height: d } =
|
|
1499
|
-
if (!i || i === "auto" || a ? this.adaptCanvasToContainer() : i ? this.setCanvasBackstoreWidth(Number(i)) : this.setCanvasBackstoreWidth(h),
|
|
1500
|
-
const m = h / c,
|
|
1501
|
-
this.setResolutionHeight(
|
|
1527
|
+
} = this.editor, { width: c, height: d } = n, h = _(Number(e), R, w);
|
|
1528
|
+
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 / c, f = ye(d, m);
|
|
1530
|
+
this.setResolutionHeight(f);
|
|
1502
1531
|
return;
|
|
1503
1532
|
}
|
|
1504
|
-
const { left: l, top: g } = this.getObjectDefaultCoords(
|
|
1505
|
-
|
|
1533
|
+
const { left: l, top: g } = this.getObjectDefaultCoords(n), u = o.getZoom();
|
|
1534
|
+
o.setViewportTransform([u, 0, 0, u, l, g]), this.centerMontageArea(), s || this.editor.historyManager.saveState(), o.fire("editor:resolution-width-changed", {
|
|
1506
1535
|
width: h,
|
|
1507
1536
|
preserveProportional: t,
|
|
1508
1537
|
withoutSave: s,
|
|
@@ -1519,20 +1548,20 @@ class dt {
|
|
|
1519
1548
|
* @fires editor:resolution-height-changed
|
|
1520
1549
|
*/
|
|
1521
1550
|
setResolutionHeight(e, { preserveProportional: t, withoutSave: s, adaptCanvasToContainer: a } = {}) {
|
|
1522
|
-
var
|
|
1551
|
+
var M;
|
|
1523
1552
|
if (!e) return;
|
|
1524
1553
|
const {
|
|
1525
|
-
canvas:
|
|
1526
|
-
montageArea:
|
|
1554
|
+
canvas: o,
|
|
1555
|
+
montageArea: n,
|
|
1527
1556
|
options: { canvasBackstoreHeight: i }
|
|
1528
|
-
} = this.editor, { width: c, height: d } =
|
|
1529
|
-
if (!i || i === "auto" || a ? this.adaptCanvasToContainer() : i ? this.setCanvasBackstoreHeight(Number(i)) : this.setCanvasBackstoreHeight(h),
|
|
1530
|
-
const m = h / d,
|
|
1531
|
-
this.setResolutionWidth(
|
|
1557
|
+
} = this.editor, { width: c, height: d } = n, h = _(Number(e), U, T);
|
|
1558
|
+
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, f = ye(c, m);
|
|
1560
|
+
this.setResolutionWidth(f);
|
|
1532
1561
|
return;
|
|
1533
1562
|
}
|
|
1534
|
-
const { left: l, top: g } = this.getObjectDefaultCoords(
|
|
1535
|
-
|
|
1563
|
+
const { left: l, top: g } = this.getObjectDefaultCoords(n), u = o.getZoom();
|
|
1564
|
+
o.setViewportTransform([u, 0, 0, u, l, g]), this.centerMontageArea(), s || this.editor.historyManager.saveState(), o.fire("editor:resolution-height-changed", {
|
|
1536
1565
|
height: h,
|
|
1537
1566
|
preserveProportional: t,
|
|
1538
1567
|
withoutSave: s,
|
|
@@ -1545,7 +1574,7 @@ class dt {
|
|
|
1545
1574
|
*/
|
|
1546
1575
|
centerMontageArea() {
|
|
1547
1576
|
var c;
|
|
1548
|
-
const { canvas: e, montageArea: t } = this.editor, s = e.getWidth(), a = e.getHeight(),
|
|
1577
|
+
const { canvas: e, montageArea: t } = this.editor, s = e.getWidth(), a = e.getHeight(), o = e.getZoom(), n = rt(s, a);
|
|
1549
1578
|
t.set({
|
|
1550
1579
|
left: s / 2,
|
|
1551
1580
|
top: a / 2
|
|
@@ -1554,7 +1583,7 @@ class dt {
|
|
|
1554
1583
|
top: a / 2
|
|
1555
1584
|
}), e.renderAll();
|
|
1556
1585
|
const i = e.viewportTransform;
|
|
1557
|
-
i[4] = s / 2 -
|
|
1586
|
+
i[4] = s / 2 - n.x * o, i[5] = a / 2 - n.y * o, e.setViewportTransform(i), e.renderAll();
|
|
1558
1587
|
}
|
|
1559
1588
|
/**
|
|
1560
1589
|
* Метод для получения координат объекта с учетом текущего зума
|
|
@@ -1570,7 +1599,7 @@ class dt {
|
|
|
1570
1599
|
code: "NO_ACTIVE_OBJECT",
|
|
1571
1600
|
message: "Не выбран объект для получения координат"
|
|
1572
1601
|
}), { left: 0, top: 0 };
|
|
1573
|
-
const { width: a, height:
|
|
1602
|
+
const { width: a, height: o } = s, n = t.getZoom(), i = (a - a * n) / 2, c = (o - o * n) / 2;
|
|
1574
1603
|
return { left: i, top: c };
|
|
1575
1604
|
}
|
|
1576
1605
|
/**
|
|
@@ -1596,8 +1625,8 @@ class dt {
|
|
|
1596
1625
|
* с учётом минимальных и максимальных значений.
|
|
1597
1626
|
*/
|
|
1598
1627
|
adaptCanvasToContainer() {
|
|
1599
|
-
const { canvas: e } = this.editor, t = this.getEditorContainer(), s = t.clientWidth, a = t.clientHeight,
|
|
1600
|
-
e.setDimensions({ width:
|
|
1628
|
+
const { canvas: e } = this.editor, t = this.getEditorContainer(), s = t.clientWidth, a = t.clientHeight, o = _(s, R, w), n = _(a, U, T);
|
|
1629
|
+
e.setDimensions({ width: o, height: n }, { backstoreOnly: !0 });
|
|
1601
1630
|
}
|
|
1602
1631
|
/**
|
|
1603
1632
|
* Обновляет размеры канваса без изменения позиций объектов.
|
|
@@ -1612,9 +1641,9 @@ class dt {
|
|
|
1612
1641
|
width: s,
|
|
1613
1642
|
height: a
|
|
1614
1643
|
}
|
|
1615
|
-
} = this.editor,
|
|
1644
|
+
} = this.editor, o = t.left, n = t.top;
|
|
1616
1645
|
this.setResolutionWidth(s, { adaptCanvasToContainer: !0, withoutSave: !0 }), this.setResolutionHeight(a, { adaptCanvasToContainer: !0, withoutSave: !0 }), this.centerMontageArea();
|
|
1617
|
-
const i = t.left -
|
|
1646
|
+
const i = t.left - o, c = t.top - n;
|
|
1618
1647
|
if (i !== 0 || c !== 0) {
|
|
1619
1648
|
const d = e.getActiveObject(), h = [];
|
|
1620
1649
|
if ((d == null ? void 0 : d.type) === "activeselection") {
|
|
@@ -1748,32 +1777,32 @@ class dt {
|
|
|
1748
1777
|
*/
|
|
1749
1778
|
setDisplayDimension({ element: e = "canvas", dimension: t, value: s } = {}) {
|
|
1750
1779
|
if (!s) return;
|
|
1751
|
-
const { canvas: a } = this.editor,
|
|
1780
|
+
const { canvas: a } = this.editor, o = [];
|
|
1752
1781
|
switch (e) {
|
|
1753
1782
|
case "canvas":
|
|
1754
|
-
|
|
1783
|
+
o.push(a.lowerCanvasEl, a.upperCanvasEl);
|
|
1755
1784
|
break;
|
|
1756
1785
|
case "wrapper":
|
|
1757
|
-
|
|
1786
|
+
o.push(a.wrapperEl);
|
|
1758
1787
|
break;
|
|
1759
1788
|
case "container":
|
|
1760
|
-
|
|
1789
|
+
o.push(this.getEditorContainer());
|
|
1761
1790
|
break;
|
|
1762
1791
|
default:
|
|
1763
|
-
|
|
1792
|
+
o.push(a.lowerCanvasEl, a.upperCanvasEl);
|
|
1764
1793
|
}
|
|
1765
|
-
const
|
|
1794
|
+
const n = t === "width" ? "width" : "height";
|
|
1766
1795
|
if (typeof s == "string") {
|
|
1767
|
-
|
|
1768
|
-
c.style[
|
|
1796
|
+
o.forEach((c) => {
|
|
1797
|
+
c.style[n] = s;
|
|
1769
1798
|
});
|
|
1770
1799
|
return;
|
|
1771
1800
|
}
|
|
1772
1801
|
if (isNaN(s)) return;
|
|
1773
1802
|
const i = `${s}px`;
|
|
1774
|
-
|
|
1775
|
-
c.style[
|
|
1776
|
-
}), a.fire(`editor:display-${e}-${
|
|
1803
|
+
o.forEach((c) => {
|
|
1804
|
+
c.style[n] = i;
|
|
1805
|
+
}), a.fire(`editor:display-${e}-${n}-changed`, {
|
|
1777
1806
|
element: e,
|
|
1778
1807
|
value: s
|
|
1779
1808
|
});
|
|
@@ -1789,8 +1818,8 @@ class dt {
|
|
|
1789
1818
|
scaleMontageAreaToImage({ object: e, preserveAspectRatio: t, withoutSave: s } = {}) {
|
|
1790
1819
|
const {
|
|
1791
1820
|
canvas: a,
|
|
1792
|
-
montageArea:
|
|
1793
|
-
transformManager:
|
|
1821
|
+
montageArea: o,
|
|
1822
|
+
transformManager: n,
|
|
1794
1823
|
options: {
|
|
1795
1824
|
montageAreaWidth: i,
|
|
1796
1825
|
montageAreaHeight: c
|
|
@@ -1801,12 +1830,12 @@ class dt {
|
|
|
1801
1830
|
let g = Math.min(h, w), u = Math.min(l, T);
|
|
1802
1831
|
if (t) {
|
|
1803
1832
|
const {
|
|
1804
|
-
width:
|
|
1833
|
+
width: M,
|
|
1805
1834
|
height: m
|
|
1806
|
-
} =
|
|
1807
|
-
g =
|
|
1835
|
+
} = o, f = h / M, j = l / m, b = Math.max(f, j);
|
|
1836
|
+
g = M * b, u = m * b;
|
|
1808
1837
|
}
|
|
1809
|
-
this.setResolutionWidth(g, { withoutSave: !0 }), this.setResolutionHeight(u, { withoutSave: !0 }), this.editor.backgroundManager.backgroundObject && this.editor.backgroundManager.refresh(), (h > i || l > c) &&
|
|
1838
|
+
this.setResolutionWidth(g, { withoutSave: !0 }), this.setResolutionHeight(u, { withoutSave: !0 }), this.editor.backgroundManager.backgroundObject && this.editor.backgroundManager.refresh(), (h > i || l > c) && 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", {
|
|
1810
1839
|
object: d,
|
|
1811
1840
|
width: g,
|
|
1812
1841
|
height: u,
|
|
@@ -1834,11 +1863,11 @@ class dt {
|
|
|
1834
1863
|
transformManager: s,
|
|
1835
1864
|
historyManager: a,
|
|
1836
1865
|
options: {
|
|
1837
|
-
montageAreaWidth:
|
|
1838
|
-
montageAreaHeight:
|
|
1866
|
+
montageAreaWidth: o,
|
|
1867
|
+
montageAreaHeight: n
|
|
1839
1868
|
}
|
|
1840
1869
|
} = this.editor;
|
|
1841
|
-
s.resetZoom(), this.setResolutionWidth(
|
|
1870
|
+
s.resetZoom(), this.setResolutionWidth(o, { withoutSave: !0 }), this.setResolutionHeight(n, { withoutSave: !0 }), t.renderAll(), s.resetObjects(), e || a.saveState(), t.fire("editor:default-scale-set");
|
|
1842
1871
|
}
|
|
1843
1872
|
/**
|
|
1844
1873
|
* Получение всех объектов внутри монтажной области редактора
|
|
@@ -1852,13 +1881,13 @@ class dt {
|
|
|
1852
1881
|
backgroundManager: { backgroundObject: a }
|
|
1853
1882
|
} = this.editor;
|
|
1854
1883
|
return e.getObjects().filter(
|
|
1855
|
-
(
|
|
1884
|
+
(n) => n.id !== t.id && n.id !== (s == null ? void 0 : s.id) && n.id !== (a == null ? void 0 : a.id)
|
|
1856
1885
|
);
|
|
1857
1886
|
}
|
|
1858
1887
|
}
|
|
1859
1888
|
class lt {
|
|
1860
1889
|
constructor({ editor: e }) {
|
|
1861
|
-
this.editor = e, this.options = e.options, this.minZoom = this.options.minZoom || at, this.maxZoom = this.options.maxZoom ||
|
|
1890
|
+
this.editor = e, this.options = e.options, this.minZoom = this.options.minZoom || at, this.maxZoom = this.options.maxZoom || ot, this.defaultZoom = this.options.defaultScale;
|
|
1862
1891
|
}
|
|
1863
1892
|
/**
|
|
1864
1893
|
* Метод рассчитывает и применяет зум по умолчанию для монтажной области редактора.
|
|
@@ -1868,7 +1897,7 @@ class lt {
|
|
|
1868
1897
|
* @param scale - Желаемый масштаб относительно размеров контейнера редактора.
|
|
1869
1898
|
*/
|
|
1870
1899
|
calculateAndApplyDefaultZoom(e = this.options.defaultScale) {
|
|
1871
|
-
const { canvas: t } = this.editor, s = t.editorContainer, a = s.clientWidth,
|
|
1900
|
+
const { canvas: t } = this.editor, s = t.editorContainer, a = s.clientWidth, o = s.clientHeight, { width: n, height: i } = this.editor.montageArea, c = a / n * e, d = o / i * e;
|
|
1872
1901
|
this.defaultZoom = Math.min(c, d), this.setZoom();
|
|
1873
1902
|
}
|
|
1874
1903
|
/**
|
|
@@ -1880,13 +1909,13 @@ class lt {
|
|
|
1880
1909
|
* @fires editor:zoom-changed
|
|
1881
1910
|
* Если передавать координаты курсора, то нужно быть аккуратнее, так как юзер может выйти за пределы рабочей области
|
|
1882
1911
|
*/
|
|
1883
|
-
zoom(e =
|
|
1912
|
+
zoom(e = nt, t = {}) {
|
|
1884
1913
|
var g, u;
|
|
1885
1914
|
if (!e) return;
|
|
1886
|
-
const { minZoom: s, maxZoom: a } = this, { canvas:
|
|
1887
|
-
let l = Number((
|
|
1888
|
-
l > a && (l = a), l < s && (l = s),
|
|
1889
|
-
currentZoom:
|
|
1915
|
+
const { minZoom: s, maxZoom: a } = this, { canvas: o } = this.editor, n = o.getZoom(), i = o.getCenterPoint(), c = (g = t.pointX) != null ? g : i.x, d = (u = t.pointY) != null ? u : i.y, h = new G(c, d);
|
|
1916
|
+
let l = Number((n + Number(e)).toFixed(2));
|
|
1917
|
+
l > a && (l = a), l < s && (l = s), o.zoomToPoint(h, l), o.fire("editor:zoom-changed", {
|
|
1918
|
+
currentZoom: o.getZoom(),
|
|
1890
1919
|
zoom: l,
|
|
1891
1920
|
point: h
|
|
1892
1921
|
});
|
|
@@ -1897,12 +1926,12 @@ class lt {
|
|
|
1897
1926
|
* @fires editor:zoom-changed
|
|
1898
1927
|
*/
|
|
1899
1928
|
setZoom(e = this.defaultZoom) {
|
|
1900
|
-
const { minZoom: t, maxZoom: s } = this, { canvas: a } = this.editor,
|
|
1901
|
-
let
|
|
1902
|
-
e > s && (
|
|
1929
|
+
const { minZoom: t, maxZoom: s } = this, { canvas: a } = this.editor, o = new G(a.getCenterPoint());
|
|
1930
|
+
let n = e;
|
|
1931
|
+
e > s && (n = s), e < t && (n = t), a.zoomToPoint(o, n), a.fire("editor:zoom-changed", {
|
|
1903
1932
|
currentZoom: a.getZoom(),
|
|
1904
|
-
zoom:
|
|
1905
|
-
point:
|
|
1933
|
+
zoom: n,
|
|
1934
|
+
point: o
|
|
1906
1935
|
});
|
|
1907
1936
|
}
|
|
1908
1937
|
/**
|
|
@@ -1924,13 +1953,13 @@ class lt {
|
|
|
1924
1953
|
* @fires editor:object-rotated
|
|
1925
1954
|
*/
|
|
1926
1955
|
rotate(e = it, { withoutSave: t } = {}) {
|
|
1927
|
-
const { canvas: s, historyManager: a } = this.editor,
|
|
1928
|
-
if (!
|
|
1929
|
-
const
|
|
1930
|
-
|
|
1931
|
-
object:
|
|
1956
|
+
const { canvas: s, historyManager: a } = this.editor, o = s.getActiveObject();
|
|
1957
|
+
if (!o) return;
|
|
1958
|
+
const n = o.angle + e;
|
|
1959
|
+
o.rotate(n), o.setCoords(), s.renderAll(), t || a.saveState(), s.fire("editor:object-rotated", {
|
|
1960
|
+
object: o,
|
|
1932
1961
|
withoutSave: t,
|
|
1933
|
-
angle:
|
|
1962
|
+
angle: n
|
|
1934
1963
|
});
|
|
1935
1964
|
}
|
|
1936
1965
|
/**
|
|
@@ -1972,11 +2001,11 @@ class lt {
|
|
|
1972
2001
|
opacity: t = 1,
|
|
1973
2002
|
withoutSave: s
|
|
1974
2003
|
} = {}) {
|
|
1975
|
-
const { canvas: a, historyManager:
|
|
1976
|
-
|
|
2004
|
+
const { canvas: a, historyManager: o } = this.editor, n = e || a.getActiveObject();
|
|
2005
|
+
n && (n instanceof v ? n.getObjects().forEach((i) => {
|
|
1977
2006
|
i.set("opacity", t);
|
|
1978
|
-
}) :
|
|
1979
|
-
object:
|
|
2007
|
+
}) : n.set("opacity", t), a.renderAll(), s || o.saveState(), a.fire("editor:object-opacity-changed", {
|
|
2008
|
+
object: n,
|
|
1980
2009
|
opacity: t,
|
|
1981
2010
|
withoutSave: s
|
|
1982
2011
|
}));
|
|
@@ -1998,18 +2027,18 @@ class lt {
|
|
|
1998
2027
|
withoutSave: s,
|
|
1999
2028
|
fitAsOneObject: a
|
|
2000
2029
|
} = {}) {
|
|
2001
|
-
const { canvas:
|
|
2030
|
+
const { canvas: o, historyManager: n } = this.editor, i = e || o.getActiveObject();
|
|
2002
2031
|
if (i) {
|
|
2003
2032
|
if (i instanceof v && !a) {
|
|
2004
2033
|
const c = i.getObjects();
|
|
2005
|
-
|
|
2034
|
+
o.discardActiveObject(), c.forEach((h) => {
|
|
2006
2035
|
this._fitSingleObject(h, t);
|
|
2007
2036
|
});
|
|
2008
|
-
const d = new v(c, { canvas:
|
|
2009
|
-
|
|
2037
|
+
const d = new v(c, { canvas: o });
|
|
2038
|
+
o.setActiveObject(d);
|
|
2010
2039
|
} else
|
|
2011
2040
|
this._fitSingleObject(i, t);
|
|
2012
|
-
|
|
2041
|
+
o.renderAll(), s || n.saveState(), o.fire("editor:object-fitted", {
|
|
2013
2042
|
object: i,
|
|
2014
2043
|
type: t,
|
|
2015
2044
|
withoutSave: s,
|
|
@@ -2024,9 +2053,9 @@ class lt {
|
|
|
2024
2053
|
* @private
|
|
2025
2054
|
*/
|
|
2026
2055
|
_fitSingleObject(e, t) {
|
|
2027
|
-
const { canvas: s, montageArea: a } = this.editor, { width:
|
|
2056
|
+
const { canvas: s, montageArea: a } = this.editor, { width: o, height: n, scaleX: i = 1, scaleY: c = 1, angle: d = 0 } = e, h = o * Math.abs(i), l = n * Math.abs(c), g = d * Math.PI / 180, u = Math.abs(Math.cos(g)), M = Math.abs(Math.sin(g)), m = h * u + l * M, f = h * M + l * u, j = a.width, b = a.height;
|
|
2028
2057
|
let S;
|
|
2029
|
-
t === "contain" ? S = Math.min(j / m, b /
|
|
2058
|
+
t === "contain" ? S = Math.min(j / m, b / f) : S = Math.max(j / m, b / f), e.set({
|
|
2030
2059
|
scaleX: i * S,
|
|
2031
2060
|
scaleY: c * S
|
|
2032
2061
|
}), s.centerObject(e);
|
|
@@ -2050,8 +2079,8 @@ class lt {
|
|
|
2050
2079
|
resetObject({ object: e, alwaysFitObject: t = !1, withoutSave: s = !1 } = {}) {
|
|
2051
2080
|
const {
|
|
2052
2081
|
canvas: a,
|
|
2053
|
-
montageArea:
|
|
2054
|
-
imageManager:
|
|
2082
|
+
montageArea: o,
|
|
2083
|
+
imageManager: n,
|
|
2055
2084
|
historyManager: i,
|
|
2056
2085
|
options: { scaleType: c }
|
|
2057
2086
|
} = this.editor, d = e || a.getActiveObject();
|
|
@@ -2065,11 +2094,11 @@ class lt {
|
|
|
2065
2094
|
}), t)
|
|
2066
2095
|
this.fitObject({ object: d, withoutSave: !0, fitAsOneObject: !0 });
|
|
2067
2096
|
else {
|
|
2068
|
-
const { width: l, height: g } =
|
|
2097
|
+
const { width: l, height: g } = o, { width: u, height: M } = d, m = n.calculateScaleFactor({
|
|
2069
2098
|
imageObject: d,
|
|
2070
2099
|
scaleType: c
|
|
2071
2100
|
});
|
|
2072
|
-
c === "contain" && m < 1 || c === "cover" && (u > l ||
|
|
2101
|
+
c === "contain" && m < 1 || c === "cover" && (u > l || M > g) ? this.fitObject({ object: d, withoutSave: !0, fitAsOneObject: !0 }) : d.set({ scaleX: 1, scaleY: 1 });
|
|
2073
2102
|
}
|
|
2074
2103
|
d.set({ flipX: !1, flipY: !1, angle: 0 }), a.centerObject(d), a.renderAll(), i.resumeHistory(), s || i.saveState(), a.fire("editor:object-reset", {
|
|
2075
2104
|
object: d,
|
|
@@ -2108,8 +2137,8 @@ class ht {
|
|
|
2108
2137
|
const { canvas: e, montageArea: t, historyManager: s } = this.editor;
|
|
2109
2138
|
if (!t || !this.overlayMask) return;
|
|
2110
2139
|
s.suspendHistory(), t.setCoords();
|
|
2111
|
-
const { left: a, top:
|
|
2112
|
-
this.overlayMask.set({ left: a, top:
|
|
2140
|
+
const { left: a, top: o, width: n, height: i } = t.getBoundingRect();
|
|
2141
|
+
this.overlayMask.set({ left: a, top: o, width: n, height: i }), e.discardActiveObject(), this.editor.layerManager.bringToFront(this.overlayMask, { withoutSave: !0 }), s.resumeHistory();
|
|
2113
2142
|
}
|
|
2114
2143
|
/**
|
|
2115
2144
|
* Выключает редактор:
|
|
@@ -2147,26 +2176,31 @@ class x {
|
|
|
2147
2176
|
*/
|
|
2148
2177
|
setColorBackground({
|
|
2149
2178
|
color: e,
|
|
2150
|
-
|
|
2179
|
+
customData: t = {},
|
|
2180
|
+
withoutSave: s = !1
|
|
2151
2181
|
}) {
|
|
2182
|
+
var a;
|
|
2152
2183
|
try {
|
|
2153
|
-
const { historyManager:
|
|
2154
|
-
if (
|
|
2155
|
-
if (
|
|
2156
|
-
|
|
2184
|
+
const { historyManager: o } = this.editor, { backgroundObject: n } = this;
|
|
2185
|
+
if (o.suspendHistory(), n && n.backgroundType === "color") {
|
|
2186
|
+
if (n.fill === e) {
|
|
2187
|
+
o.resumeHistory();
|
|
2157
2188
|
return;
|
|
2158
2189
|
}
|
|
2159
|
-
|
|
2190
|
+
n.set({
|
|
2191
|
+
fill: e,
|
|
2192
|
+
backgroundId: `background-${A()}`
|
|
2193
|
+
}), this.editor.canvas.requestRenderAll();
|
|
2160
2194
|
} else
|
|
2161
2195
|
this._removeCurrentBackground(), this._createColorBackground(e);
|
|
2162
|
-
this.editor.canvas.fire("background:changed", { type: "color", color: e }),
|
|
2163
|
-
} catch (
|
|
2196
|
+
(a = this.backgroundObject) == null || a.set({ customData: t }), this.editor.canvas.fire("editor:background:changed", { type: "color", color: e }), o.resumeHistory(), s || o.saveState();
|
|
2197
|
+
} catch (o) {
|
|
2164
2198
|
this.editor.errorManager.emitError({
|
|
2165
2199
|
code: "BACKGROUND_CREATION_FAILED",
|
|
2166
2200
|
origin: "BackgroundManager",
|
|
2167
2201
|
method: "setColorBackground",
|
|
2168
2202
|
message: "Не удалось установить цветовой фон",
|
|
2169
|
-
data: { error:
|
|
2203
|
+
data: { error: o }
|
|
2170
2204
|
});
|
|
2171
2205
|
}
|
|
2172
2206
|
}
|
|
@@ -2178,30 +2212,35 @@ class x {
|
|
|
2178
2212
|
*/
|
|
2179
2213
|
setGradientBackground({
|
|
2180
2214
|
gradient: e,
|
|
2181
|
-
|
|
2215
|
+
customData: t = {},
|
|
2216
|
+
withoutSave: s = !1
|
|
2182
2217
|
}) {
|
|
2218
|
+
var a;
|
|
2183
2219
|
try {
|
|
2184
|
-
const { historyManager:
|
|
2185
|
-
if (
|
|
2186
|
-
const
|
|
2187
|
-
if (x._isGradientEqual(
|
|
2188
|
-
|
|
2220
|
+
const { historyManager: o } = this.editor, { backgroundObject: n } = this;
|
|
2221
|
+
if (o.suspendHistory(), n && n.backgroundType === "gradient") {
|
|
2222
|
+
const i = x._createFabricGradient(e);
|
|
2223
|
+
if (x._isGradientEqual(n.fill, i)) {
|
|
2224
|
+
o.resumeHistory();
|
|
2189
2225
|
return;
|
|
2190
2226
|
}
|
|
2191
|
-
|
|
2227
|
+
n.set({
|
|
2228
|
+
fill: i,
|
|
2229
|
+
backgroundId: `background-${A()}`
|
|
2230
|
+
}), this.editor.canvas.requestRenderAll();
|
|
2192
2231
|
} else
|
|
2193
2232
|
this._removeCurrentBackground(), this._createGradientBackground(e);
|
|
2194
|
-
this.editor.canvas.fire("background:changed", {
|
|
2233
|
+
(a = this.backgroundObject) == null || a.set({ customData: t }), this.editor.canvas.fire("editor:background:changed", {
|
|
2195
2234
|
type: "gradient",
|
|
2196
2235
|
gradientParams: e
|
|
2197
|
-
}),
|
|
2198
|
-
} catch (
|
|
2236
|
+
}), o.resumeHistory(), s || o.saveState();
|
|
2237
|
+
} catch (o) {
|
|
2199
2238
|
this.editor.errorManager.emitError({
|
|
2200
2239
|
code: "BACKGROUND_CREATION_FAILED",
|
|
2201
2240
|
origin: "BackgroundManager",
|
|
2202
2241
|
method: "setGradientBackground",
|
|
2203
2242
|
message: "Не удалось установить градиентный фон",
|
|
2204
|
-
data: { error:
|
|
2243
|
+
data: { error: o }
|
|
2205
2244
|
});
|
|
2206
2245
|
}
|
|
2207
2246
|
}
|
|
@@ -2214,8 +2253,9 @@ class x {
|
|
|
2214
2253
|
startColor: t,
|
|
2215
2254
|
endColor: s,
|
|
2216
2255
|
startPosition: a,
|
|
2217
|
-
endPosition:
|
|
2218
|
-
|
|
2256
|
+
endPosition: o,
|
|
2257
|
+
customData: n = {},
|
|
2258
|
+
withoutSave: i = !1
|
|
2219
2259
|
}) {
|
|
2220
2260
|
this.setGradientBackground({
|
|
2221
2261
|
gradient: {
|
|
@@ -2224,9 +2264,10 @@ class x {
|
|
|
2224
2264
|
startColor: t,
|
|
2225
2265
|
endColor: s,
|
|
2226
2266
|
startPosition: a,
|
|
2227
|
-
endPosition:
|
|
2267
|
+
endPosition: o
|
|
2228
2268
|
},
|
|
2229
|
-
|
|
2269
|
+
customData: n,
|
|
2270
|
+
withoutSave: i
|
|
2230
2271
|
});
|
|
2231
2272
|
}
|
|
2232
2273
|
/**
|
|
@@ -2238,10 +2279,11 @@ class x {
|
|
|
2238
2279
|
centerY: t,
|
|
2239
2280
|
radius: s,
|
|
2240
2281
|
startColor: a,
|
|
2241
|
-
endColor:
|
|
2242
|
-
startPosition:
|
|
2282
|
+
endColor: o,
|
|
2283
|
+
startPosition: n,
|
|
2243
2284
|
endPosition: i,
|
|
2244
|
-
|
|
2285
|
+
customData: c = {},
|
|
2286
|
+
withoutSave: d = !1
|
|
2245
2287
|
}) {
|
|
2246
2288
|
this.setGradientBackground({
|
|
2247
2289
|
gradient: {
|
|
@@ -2250,11 +2292,12 @@ class x {
|
|
|
2250
2292
|
centerY: t,
|
|
2251
2293
|
radius: s,
|
|
2252
2294
|
startColor: a,
|
|
2253
|
-
endColor:
|
|
2254
|
-
startPosition:
|
|
2295
|
+
endColor: o,
|
|
2296
|
+
startPosition: n,
|
|
2255
2297
|
endPosition: i
|
|
2256
2298
|
},
|
|
2257
|
-
|
|
2299
|
+
customData: c,
|
|
2300
|
+
withoutSave: d
|
|
2258
2301
|
});
|
|
2259
2302
|
}
|
|
2260
2303
|
/**
|
|
@@ -2263,25 +2306,26 @@ class x {
|
|
|
2263
2306
|
* @param options.imageUrl - URL изображения
|
|
2264
2307
|
* @param options.withoutSave - Если true, не сохранять состояние в историю
|
|
2265
2308
|
*/
|
|
2266
|
-
setImageBackground(
|
|
2309
|
+
setImageBackground(a) {
|
|
2267
2310
|
return y(this, arguments, function* ({
|
|
2268
2311
|
imageSource: e,
|
|
2269
|
-
|
|
2312
|
+
customData: t = {},
|
|
2313
|
+
withoutSave: s = !1
|
|
2270
2314
|
}) {
|
|
2271
2315
|
try {
|
|
2272
|
-
const { historyManager:
|
|
2273
|
-
|
|
2316
|
+
const { historyManager: o } = this.editor;
|
|
2317
|
+
o.suspendHistory(), yield this._createImageBackground(e, t), this.editor.canvas.fire("editor:background:changed", {
|
|
2274
2318
|
type: "image",
|
|
2275
2319
|
imageSource: e,
|
|
2276
2320
|
backgroundObject: this.backgroundObject
|
|
2277
|
-
}),
|
|
2278
|
-
} catch (
|
|
2321
|
+
}), o.resumeHistory(), s || o.saveState();
|
|
2322
|
+
} catch (o) {
|
|
2279
2323
|
this.editor.errorManager.emitError({
|
|
2280
2324
|
code: "BACKGROUND_CREATION_FAILED",
|
|
2281
2325
|
origin: "BackgroundManager",
|
|
2282
2326
|
method: "setImageBackground",
|
|
2283
2327
|
message: "Не удалось установить изображение в качестве фона",
|
|
2284
|
-
data: { error:
|
|
2328
|
+
data: { error: o }
|
|
2285
2329
|
});
|
|
2286
2330
|
}
|
|
2287
2331
|
});
|
|
@@ -2294,16 +2338,8 @@ class x {
|
|
|
2294
2338
|
removeBackground({ withoutSave: e = !1 } = {}) {
|
|
2295
2339
|
try {
|
|
2296
2340
|
const { historyManager: t } = this.editor;
|
|
2297
|
-
if (!this.backgroundObject)
|
|
2298
|
-
|
|
2299
|
-
code: "NO_BACKGROUND_TO_REMOVE",
|
|
2300
|
-
origin: "BackgroundManager",
|
|
2301
|
-
method: "removeBackground",
|
|
2302
|
-
message: "Нет фона для удаления"
|
|
2303
|
-
});
|
|
2304
|
-
return;
|
|
2305
|
-
}
|
|
2306
|
-
t.suspendHistory(), this._removeCurrentBackground(), this.editor.canvas.fire("background:removed"), t.resumeHistory(), e || t.saveState();
|
|
2341
|
+
if (!this.backgroundObject) return;
|
|
2342
|
+
t.suspendHistory(), this._removeCurrentBackground(), this.editor.canvas.fire("editor:background:removed"), t.resumeHistory(), e || t.saveState();
|
|
2307
2343
|
} catch (t) {
|
|
2308
2344
|
this.editor.errorManager.emitError({
|
|
2309
2345
|
code: "BACKGROUND_REMOVAL_FAILED",
|
|
@@ -2321,8 +2357,8 @@ class x {
|
|
|
2321
2357
|
const { canvas: e, montageArea: t, historyManager: s } = this.editor;
|
|
2322
2358
|
if (!t || !this.backgroundObject) return;
|
|
2323
2359
|
s.suspendHistory(), this.editor.transformManager.fitObject({ object: this.backgroundObject, withoutSave: !0, type: "cover" });
|
|
2324
|
-
const a = e.getObjects(),
|
|
2325
|
-
this.backgroundObject &&
|
|
2360
|
+
const a = e.getObjects(), o = a.indexOf(t), n = a.indexOf(this.backgroundObject);
|
|
2361
|
+
this.backgroundObject && n !== o + 1 && e.moveObjectTo(this.backgroundObject, o + 1), e.requestRenderAll(), s.resumeHistory();
|
|
2326
2362
|
}
|
|
2327
2363
|
/**
|
|
2328
2364
|
* Создает цветовой фон.
|
|
@@ -2363,27 +2399,28 @@ class x {
|
|
|
2363
2399
|
* Создает фон из изображения.
|
|
2364
2400
|
* @param source - источник изображения (URL или File)
|
|
2365
2401
|
*/
|
|
2366
|
-
_createImageBackground(e) {
|
|
2402
|
+
_createImageBackground(e, t) {
|
|
2367
2403
|
return y(this, null, function* () {
|
|
2368
|
-
var
|
|
2369
|
-
const { image:
|
|
2404
|
+
var a;
|
|
2405
|
+
const { image: s } = (a = yield this.editor.imageManager.importImage({
|
|
2370
2406
|
source: e,
|
|
2371
2407
|
withoutSave: !0,
|
|
2372
2408
|
isBackground: !0,
|
|
2373
2409
|
withoutSelection: !0,
|
|
2374
2410
|
scale: "image-cover"
|
|
2375
|
-
})) != null ?
|
|
2376
|
-
if (!
|
|
2411
|
+
})) != null ? a : {};
|
|
2412
|
+
if (!s)
|
|
2377
2413
|
throw new Error("Не удалось загрузить изображение");
|
|
2378
|
-
|
|
2414
|
+
s.set({
|
|
2379
2415
|
selectable: !1,
|
|
2380
2416
|
evented: !1,
|
|
2381
2417
|
hasBorders: !1,
|
|
2382
2418
|
hasControls: !1,
|
|
2383
2419
|
id: "background",
|
|
2384
2420
|
backgroundType: "image",
|
|
2385
|
-
backgroundId: `background-${A()}
|
|
2386
|
-
|
|
2421
|
+
backgroundId: `background-${A()}`,
|
|
2422
|
+
customData: t
|
|
2423
|
+
}), this._removeCurrentBackground(), this.backgroundObject = s, this.refresh();
|
|
2387
2424
|
});
|
|
2388
2425
|
}
|
|
2389
2426
|
/**
|
|
@@ -2401,10 +2438,10 @@ class x {
|
|
|
2401
2438
|
startColor: t,
|
|
2402
2439
|
endColor: s,
|
|
2403
2440
|
startPosition: a = 0,
|
|
2404
|
-
endPosition:
|
|
2405
|
-
} = e,
|
|
2441
|
+
endPosition: o = 100
|
|
2442
|
+
} = e, n = [
|
|
2406
2443
|
{ offset: a / 100, color: t },
|
|
2407
|
-
{ offset:
|
|
2444
|
+
{ offset: o / 100, color: s }
|
|
2408
2445
|
];
|
|
2409
2446
|
if (e.type === "linear") {
|
|
2410
2447
|
const l = e.angle * Math.PI / 180, g = x._angleToCoords(l);
|
|
@@ -2412,7 +2449,7 @@ class x {
|
|
|
2412
2449
|
type: "linear",
|
|
2413
2450
|
gradientUnits: "percentage",
|
|
2414
2451
|
coords: g,
|
|
2415
|
-
colorStops:
|
|
2452
|
+
colorStops: n
|
|
2416
2453
|
});
|
|
2417
2454
|
}
|
|
2418
2455
|
const {
|
|
@@ -2431,7 +2468,7 @@ class x {
|
|
|
2431
2468
|
type: "radial",
|
|
2432
2469
|
gradientUnits: "percentage",
|
|
2433
2470
|
coords: h,
|
|
2434
|
-
colorStops:
|
|
2471
|
+
colorStops: n
|
|
2435
2472
|
});
|
|
2436
2473
|
}
|
|
2437
2474
|
/**
|
|
@@ -2456,13 +2493,13 @@ class x {
|
|
|
2456
2493
|
static _isGradientEqual(e, t) {
|
|
2457
2494
|
if (!e || !t || e.type !== t.type) return !1;
|
|
2458
2495
|
const s = e.colorStops || [], a = t.colorStops || [];
|
|
2459
|
-
return s.length !== a.length || !s.every((
|
|
2496
|
+
return s.length !== a.length || !s.every((n, i) => {
|
|
2460
2497
|
const c = a[i];
|
|
2461
|
-
return
|
|
2498
|
+
return n.color === c.color && Math.abs(n.offset - c.offset) < 1e-4;
|
|
2462
2499
|
}) ? !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;
|
|
2463
2500
|
}
|
|
2464
2501
|
}
|
|
2465
|
-
class
|
|
2502
|
+
class K {
|
|
2466
2503
|
constructor({ editor: e }) {
|
|
2467
2504
|
this.editor = e;
|
|
2468
2505
|
}
|
|
@@ -2476,11 +2513,11 @@ class Q {
|
|
|
2476
2513
|
bringToFront(e, { withoutSave: t } = {}) {
|
|
2477
2514
|
const { canvas: s, historyManager: a } = this.editor;
|
|
2478
2515
|
a.suspendHistory();
|
|
2479
|
-
const
|
|
2480
|
-
|
|
2481
|
-
s.bringObjectToFront(
|
|
2482
|
-
}) : s.bringObjectToFront(
|
|
2483
|
-
object:
|
|
2516
|
+
const o = e || s.getActiveObject();
|
|
2517
|
+
o && (o instanceof v ? o.getObjects().forEach((n) => {
|
|
2518
|
+
s.bringObjectToFront(n);
|
|
2519
|
+
}) : s.bringObjectToFront(o), s.renderAll(), a.resumeHistory(), t || a.saveState(), s.fire("editor:object-bring-to-front", {
|
|
2520
|
+
object: o,
|
|
2484
2521
|
withoutSave: t
|
|
2485
2522
|
}));
|
|
2486
2523
|
}
|
|
@@ -2494,9 +2531,9 @@ class Q {
|
|
|
2494
2531
|
bringForward(e, { withoutSave: t } = {}) {
|
|
2495
2532
|
const { canvas: s, historyManager: a } = this.editor;
|
|
2496
2533
|
a.suspendHistory();
|
|
2497
|
-
const
|
|
2498
|
-
|
|
2499
|
-
object:
|
|
2534
|
+
const o = e || s.getActiveObject();
|
|
2535
|
+
o && (o instanceof v ? K._moveSelectionForward(s, o) : s.bringObjectForward(o), s.renderAll(), a.resumeHistory(), t || a.saveState(), s.fire("editor:object-bring-forward", {
|
|
2536
|
+
object: o,
|
|
2500
2537
|
withoutSave: t
|
|
2501
2538
|
}));
|
|
2502
2539
|
}
|
|
@@ -2511,11 +2548,11 @@ class Q {
|
|
|
2511
2548
|
const {
|
|
2512
2549
|
canvas: s,
|
|
2513
2550
|
montageArea: a,
|
|
2514
|
-
historyManager:
|
|
2515
|
-
interactionBlocker: { overlayMask:
|
|
2551
|
+
historyManager: o,
|
|
2552
|
+
interactionBlocker: { overlayMask: n },
|
|
2516
2553
|
backgroundManager: { backgroundObject: i }
|
|
2517
2554
|
} = this.editor;
|
|
2518
|
-
|
|
2555
|
+
o.suspendHistory();
|
|
2519
2556
|
const c = e || s.getActiveObject();
|
|
2520
2557
|
if (c) {
|
|
2521
2558
|
if (c instanceof v) {
|
|
@@ -2524,7 +2561,7 @@ class Q {
|
|
|
2524
2561
|
s.sendObjectToBack(d[h]);
|
|
2525
2562
|
} else
|
|
2526
2563
|
s.sendObjectToBack(c);
|
|
2527
|
-
i && s.sendObjectToBack(i), s.sendObjectToBack(a),
|
|
2564
|
+
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", {
|
|
2528
2565
|
object: c,
|
|
2529
2566
|
withoutSave: t
|
|
2530
2567
|
});
|
|
@@ -2540,13 +2577,13 @@ class Q {
|
|
|
2540
2577
|
const {
|
|
2541
2578
|
canvas: s,
|
|
2542
2579
|
montageArea: a,
|
|
2543
|
-
historyManager:
|
|
2544
|
-
interactionBlocker: { overlayMask:
|
|
2580
|
+
historyManager: o,
|
|
2581
|
+
interactionBlocker: { overlayMask: n },
|
|
2545
2582
|
backgroundManager: { backgroundObject: i }
|
|
2546
2583
|
} = this.editor;
|
|
2547
|
-
|
|
2584
|
+
o.suspendHistory();
|
|
2548
2585
|
const c = e || s.getActiveObject();
|
|
2549
|
-
c && (c instanceof v ?
|
|
2586
|
+
c && (c instanceof v ? K._moveSelectionBackwards(s, c) : s.sendObjectBackwards(c), i && s.sendObjectToBack(i), s.sendObjectToBack(a), n && s.sendObjectToBack(n), s.renderAll(), o.resumeHistory(), t || o.saveState(), s.fire("editor:object-send-backwards", {
|
|
2550
2587
|
object: c,
|
|
2551
2588
|
withoutSave: t
|
|
2552
2589
|
}));
|
|
@@ -2620,8 +2657,8 @@ class gt {
|
|
|
2620
2657
|
left: t,
|
|
2621
2658
|
top: s,
|
|
2622
2659
|
width: a = 100,
|
|
2623
|
-
height:
|
|
2624
|
-
fill:
|
|
2660
|
+
height: o = 100,
|
|
2661
|
+
fill: n = "blue"
|
|
2625
2662
|
} = l, i = F(l, [
|
|
2626
2663
|
"id",
|
|
2627
2664
|
"left",
|
|
@@ -2630,13 +2667,13 @@ class gt {
|
|
|
2630
2667
|
"height",
|
|
2631
2668
|
"fill"
|
|
2632
2669
|
]);
|
|
2633
|
-
const { canvas: g } = this.editor, u = new
|
|
2670
|
+
const { canvas: g } = this.editor, u = new Oe(I({
|
|
2634
2671
|
id: e,
|
|
2635
2672
|
left: t,
|
|
2636
2673
|
top: s,
|
|
2637
2674
|
width: a,
|
|
2638
|
-
height:
|
|
2639
|
-
fill:
|
|
2675
|
+
height: o,
|
|
2676
|
+
fill: n
|
|
2640
2677
|
}, i));
|
|
2641
2678
|
return !t && !s && g.centerObject(u), d || (g.add(u), c || g.setActiveObject(u), g.renderAll()), u;
|
|
2642
2679
|
}
|
|
@@ -2662,21 +2699,21 @@ class gt {
|
|
|
2662
2699
|
left: t,
|
|
2663
2700
|
top: s,
|
|
2664
2701
|
radius: a = 50,
|
|
2665
|
-
fill:
|
|
2666
|
-
} = h,
|
|
2702
|
+
fill: o = "green"
|
|
2703
|
+
} = h, n = F(h, [
|
|
2667
2704
|
"id",
|
|
2668
2705
|
"left",
|
|
2669
2706
|
"top",
|
|
2670
2707
|
"radius",
|
|
2671
2708
|
"fill"
|
|
2672
2709
|
]);
|
|
2673
|
-
const { canvas: l } = this.editor, g = new
|
|
2710
|
+
const { canvas: l } = this.editor, g = new Le(I({
|
|
2674
2711
|
id: e,
|
|
2675
2712
|
left: t,
|
|
2676
2713
|
top: s,
|
|
2677
|
-
fill:
|
|
2714
|
+
fill: o,
|
|
2678
2715
|
radius: a
|
|
2679
|
-
},
|
|
2716
|
+
}, n));
|
|
2680
2717
|
return !t && !s && l.centerObject(g), c || (l.add(g), i || l.setActiveObject(g), l.renderAll()), g;
|
|
2681
2718
|
}
|
|
2682
2719
|
/**
|
|
@@ -2702,8 +2739,8 @@ class gt {
|
|
|
2702
2739
|
left: t,
|
|
2703
2740
|
top: s,
|
|
2704
2741
|
width: a = 100,
|
|
2705
|
-
height:
|
|
2706
|
-
fill:
|
|
2742
|
+
height: o = 100,
|
|
2743
|
+
fill: n = "yellow"
|
|
2707
2744
|
} = l, i = F(l, [
|
|
2708
2745
|
"id",
|
|
2709
2746
|
"left",
|
|
@@ -2712,13 +2749,13 @@ class gt {
|
|
|
2712
2749
|
"height",
|
|
2713
2750
|
"fill"
|
|
2714
2751
|
]);
|
|
2715
|
-
const { canvas: g } = this.editor, u = new
|
|
2752
|
+
const { canvas: g } = this.editor, u = new we(I({
|
|
2716
2753
|
id: e,
|
|
2717
2754
|
left: t,
|
|
2718
2755
|
top: s,
|
|
2719
|
-
fill:
|
|
2756
|
+
fill: n,
|
|
2720
2757
|
width: a,
|
|
2721
|
-
height:
|
|
2758
|
+
height: o
|
|
2722
2759
|
}, i));
|
|
2723
2760
|
return !t && !s && g.centerObject(u), d || (g.add(u), c || g.setActiveObject(u), g.renderAll()), u;
|
|
2724
2761
|
}
|
|
@@ -2800,10 +2837,10 @@ class ut {
|
|
|
2800
2837
|
_copyImageToClipboard(e, t) {
|
|
2801
2838
|
return y(this, null, function* () {
|
|
2802
2839
|
try {
|
|
2803
|
-
const a = e.toCanvasElement({ enableRetinaScaling: !1 }).toDataURL(),
|
|
2840
|
+
const a = e.toCanvasElement({ enableRetinaScaling: !1 }).toDataURL(), o = a.slice(5).split(";")[0], n = a.split(",")[1], i = atob(n), c = new Uint8Array(i.length);
|
|
2804
2841
|
for (let l = 0; l < i.length; l += 1)
|
|
2805
2842
|
c[l] = i.charCodeAt(l);
|
|
2806
|
-
const d = new Blob([c.buffer], { type:
|
|
2843
|
+
const d = new Blob([c.buffer], { type: o }), h = new ClipboardItem({ [o]: d });
|
|
2807
2844
|
return yield navigator.clipboard.write([h]), console.info("Image copied to clipboard successfully"), !0;
|
|
2808
2845
|
} catch (s) {
|
|
2809
2846
|
return this.editor.errorManager.emitWarning({
|
|
@@ -2822,7 +2859,7 @@ class ut {
|
|
|
2822
2859
|
_copyTextToClipboard(e) {
|
|
2823
2860
|
return y(this, null, function* () {
|
|
2824
2861
|
try {
|
|
2825
|
-
const t = `${
|
|
2862
|
+
const t = `${je}${e}`;
|
|
2826
2863
|
return yield navigator.clipboard.writeText(t), console.info("Text copied to clipboard successfully"), !0;
|
|
2827
2864
|
} catch (t) {
|
|
2828
2865
|
const { errorManager: s } = this.editor;
|
|
@@ -2883,8 +2920,8 @@ class ut {
|
|
|
2883
2920
|
evented: !0
|
|
2884
2921
|
}), this._addClonedObjectToCanvas(a), t.fire("editor:object-duplicated", { object: a }), !0;
|
|
2885
2922
|
} catch (a) {
|
|
2886
|
-
const { errorManager:
|
|
2887
|
-
return
|
|
2923
|
+
const { errorManager: o } = this.editor;
|
|
2924
|
+
return o.emitError({
|
|
2888
2925
|
origin: "ClipboardManager",
|
|
2889
2926
|
method: "copyPaste",
|
|
2890
2927
|
code: "COPY_PASTE_FAILED",
|
|
@@ -2908,12 +2945,12 @@ class ut {
|
|
|
2908
2945
|
return;
|
|
2909
2946
|
}
|
|
2910
2947
|
const s = e.getData("text/plain");
|
|
2911
|
-
if (s && s.startsWith(
|
|
2948
|
+
if (s && s.startsWith(je)) {
|
|
2912
2949
|
this.paste();
|
|
2913
2950
|
return;
|
|
2914
2951
|
}
|
|
2915
|
-
const { items: a } = e,
|
|
2916
|
-
if (
|
|
2952
|
+
const { items: a } = e, o = a[a.length - 1], n = o.getAsFile();
|
|
2953
|
+
if (o.type !== "text/html" && n) {
|
|
2917
2954
|
const d = new FileReader();
|
|
2918
2955
|
d.onload = (h) => {
|
|
2919
2956
|
h.target && this._handleImageImport(h.target.result).catch((l) => {
|
|
@@ -2925,7 +2962,7 @@ class ut {
|
|
|
2925
2962
|
data: l
|
|
2926
2963
|
});
|
|
2927
2964
|
});
|
|
2928
|
-
}, d.readAsDataURL(
|
|
2965
|
+
}, d.readAsDataURL(n);
|
|
2929
2966
|
return;
|
|
2930
2967
|
}
|
|
2931
2968
|
const i = e.getData("text/html");
|
|
@@ -2976,7 +3013,7 @@ class ut {
|
|
|
2976
3013
|
});
|
|
2977
3014
|
}
|
|
2978
3015
|
}
|
|
2979
|
-
class
|
|
3016
|
+
class $ {
|
|
2980
3017
|
constructor({ editor: e }) {
|
|
2981
3018
|
this.editor = e;
|
|
2982
3019
|
}
|
|
@@ -2989,8 +3026,8 @@ class K {
|
|
|
2989
3026
|
* @fires editor:object-locked
|
|
2990
3027
|
*/
|
|
2991
3028
|
lockObject({ object: e, skipInnerObjects: t, withoutSave: s } = {}) {
|
|
2992
|
-
const { canvas: a, historyManager:
|
|
2993
|
-
if (!
|
|
3029
|
+
const { canvas: a, historyManager: o } = this.editor, n = e || a.getActiveObject();
|
|
3030
|
+
if (!n || n.locked) return;
|
|
2994
3031
|
const i = {
|
|
2995
3032
|
lockMovementX: !0,
|
|
2996
3033
|
lockMovementY: !0,
|
|
@@ -3001,10 +3038,10 @@ class K {
|
|
|
3001
3038
|
lockSkewingY: !0,
|
|
3002
3039
|
locked: !0
|
|
3003
3040
|
};
|
|
3004
|
-
|
|
3041
|
+
n.set(i), !t && $._isGroupOrSelection(n) && n.getObjects().forEach((d) => {
|
|
3005
3042
|
d.set(i);
|
|
3006
|
-
}), a.renderAll(), s ||
|
|
3007
|
-
object:
|
|
3043
|
+
}), a.renderAll(), s || o.saveState(), a.fire("editor:object-locked", {
|
|
3044
|
+
object: n,
|
|
3008
3045
|
skipInnerObjects: t,
|
|
3009
3046
|
withoutSave: s
|
|
3010
3047
|
});
|
|
@@ -3017,9 +3054,9 @@ class K {
|
|
|
3017
3054
|
* @fires editor:object-unlocked
|
|
3018
3055
|
*/
|
|
3019
3056
|
unlockObject({ object: e, withoutSave: t } = {}) {
|
|
3020
|
-
const { canvas: s, historyManager: a } = this.editor,
|
|
3021
|
-
if (!
|
|
3022
|
-
const
|
|
3057
|
+
const { canvas: s, historyManager: a } = this.editor, o = e || s.getActiveObject();
|
|
3058
|
+
if (!o) return;
|
|
3059
|
+
const n = {
|
|
3023
3060
|
lockMovementX: !1,
|
|
3024
3061
|
lockMovementY: !1,
|
|
3025
3062
|
lockRotation: !1,
|
|
@@ -3029,18 +3066,18 @@ class K {
|
|
|
3029
3066
|
lockSkewingY: !1,
|
|
3030
3067
|
locked: !1
|
|
3031
3068
|
};
|
|
3032
|
-
|
|
3033
|
-
i.set(
|
|
3069
|
+
o.set(n), $._isGroupOrSelection(o) && o.getObjects().forEach((i) => {
|
|
3070
|
+
i.set(n);
|
|
3034
3071
|
}), s.renderAll(), t || a.saveState(), s.fire("editor:object-unlocked", {
|
|
3035
|
-
object:
|
|
3072
|
+
object: o,
|
|
3036
3073
|
withoutSave: t
|
|
3037
3074
|
});
|
|
3038
3075
|
}
|
|
3039
3076
|
static _isGroupOrSelection(e) {
|
|
3040
|
-
return e instanceof v || e instanceof
|
|
3077
|
+
return e instanceof v || e instanceof ee;
|
|
3041
3078
|
}
|
|
3042
3079
|
}
|
|
3043
|
-
class
|
|
3080
|
+
class ft {
|
|
3044
3081
|
constructor({ editor: e }) {
|
|
3045
3082
|
this.editor = e;
|
|
3046
3083
|
}
|
|
@@ -3057,11 +3094,11 @@ class Mt {
|
|
|
3057
3094
|
} = {}) {
|
|
3058
3095
|
const { canvas: s, historyManager: a } = this.editor;
|
|
3059
3096
|
a.suspendHistory();
|
|
3060
|
-
const
|
|
3061
|
-
if (!
|
|
3062
|
-
const
|
|
3063
|
-
|
|
3064
|
-
object:
|
|
3097
|
+
const o = e || s.getActiveObject();
|
|
3098
|
+
if (!o || !(o instanceof v)) return;
|
|
3099
|
+
const n = o.getObjects(), i = new ee(n);
|
|
3100
|
+
n.forEach((c) => s.remove(c)), i.set("id", `${i.type}-${A()}`), s.add(i), s.setActiveObject(i), s.renderAll(), a.resumeHistory(), t || a.saveState(), s.fire("editor:objects-grouped", {
|
|
3101
|
+
object: o,
|
|
3065
3102
|
group: i,
|
|
3066
3103
|
withoutSave: t
|
|
3067
3104
|
});
|
|
@@ -3079,21 +3116,21 @@ class Mt {
|
|
|
3079
3116
|
} = {}) {
|
|
3080
3117
|
const { canvas: s, historyManager: a } = this.editor;
|
|
3081
3118
|
a.suspendHistory();
|
|
3082
|
-
const
|
|
3083
|
-
if (!(
|
|
3084
|
-
const
|
|
3085
|
-
s.remove(
|
|
3086
|
-
const i = new v(
|
|
3119
|
+
const o = e || s.getActiveObject();
|
|
3120
|
+
if (!(o instanceof ee)) return;
|
|
3121
|
+
const n = o.removeAll();
|
|
3122
|
+
s.remove(o), n.forEach((c) => s.add(c));
|
|
3123
|
+
const i = new v(n, {
|
|
3087
3124
|
canvas: s
|
|
3088
3125
|
});
|
|
3089
3126
|
s.setActiveObject(i), s.renderAll(), a.resumeHistory(), t || a.saveState(), s.fire("editor:objects-ungrouped", {
|
|
3090
|
-
object:
|
|
3127
|
+
object: o,
|
|
3091
3128
|
selection: i,
|
|
3092
3129
|
withoutSave: t
|
|
3093
3130
|
});
|
|
3094
3131
|
}
|
|
3095
3132
|
}
|
|
3096
|
-
class
|
|
3133
|
+
class Mt {
|
|
3097
3134
|
constructor({ editor: e }) {
|
|
3098
3135
|
this.editor = e;
|
|
3099
3136
|
}
|
|
@@ -3104,8 +3141,8 @@ class ft {
|
|
|
3104
3141
|
selectAll() {
|
|
3105
3142
|
const { canvas: e, canvasManager: t, objectLockManager: s } = this.editor;
|
|
3106
3143
|
e.discardActiveObject();
|
|
3107
|
-
const a = t.getObjects(),
|
|
3108
|
-
|
|
3144
|
+
const a = t.getObjects(), o = a.some((i) => i.locked), n = a.length > 1 ? new v(t.getObjects(), { canvas: e }) : a[0];
|
|
3145
|
+
o && s.lockObject({ object: n, skipInnerObjects: !0, withoutSave: !0 }), e.setActiveObject(n), e.requestRenderAll(), e.fire("editor:all-objects-selected", { selected: n });
|
|
3109
3146
|
}
|
|
3110
3147
|
}
|
|
3111
3148
|
class mt {
|
|
@@ -3123,15 +3160,15 @@ class mt {
|
|
|
3123
3160
|
objects: e,
|
|
3124
3161
|
withoutSave: t
|
|
3125
3162
|
} = {}) {
|
|
3126
|
-
const { canvas: s, historyManager: a, groupingManager:
|
|
3127
|
-
|
|
3163
|
+
const { canvas: s, historyManager: a, groupingManager: o } = this.editor, n = (e || s.getActiveObjects()).filter((i) => !i.locked);
|
|
3164
|
+
n != null && n.length && (a.suspendHistory(), n.forEach((i) => {
|
|
3128
3165
|
if (i.type === "group" && i.format !== "svg") {
|
|
3129
|
-
|
|
3166
|
+
o.ungroup({ object: i, withoutSave: t }), this.deleteSelectedObjects();
|
|
3130
3167
|
return;
|
|
3131
3168
|
}
|
|
3132
3169
|
s.remove(i);
|
|
3133
3170
|
}), s.discardActiveObject(), s.renderAll(), a.resumeHistory(), t || a.saveState(), s.fire("editor:objects-deleted", {
|
|
3134
|
-
objects:
|
|
3171
|
+
objects: n,
|
|
3135
3172
|
withoutSave: t
|
|
3136
3173
|
}));
|
|
3137
3174
|
}
|
|
@@ -3235,7 +3272,7 @@ const bt = {
|
|
|
3235
3272
|
INVALID_GRADIENT_FORMAT: "INVALID_GRADIENT_FORMAT"
|
|
3236
3273
|
}
|
|
3237
3274
|
};
|
|
3238
|
-
class
|
|
3275
|
+
class J {
|
|
3239
3276
|
constructor({ editor: e }) {
|
|
3240
3277
|
this._buffer = [], this.editor = e;
|
|
3241
3278
|
}
|
|
@@ -3261,19 +3298,19 @@ class $ {
|
|
|
3261
3298
|
* @param options.message — текст ошибки (опционально, если не передан, то используется код ошибки)
|
|
3262
3299
|
* @fires editor:error
|
|
3263
3300
|
*/
|
|
3264
|
-
emitError({ origin: e = "ImageEditor", method: t = "Unknown Method", code: s, data: a, message:
|
|
3265
|
-
if (
|
|
3301
|
+
emitError({ origin: e = "ImageEditor", method: t = "Unknown Method", code: s, data: a, message: o }) {
|
|
3302
|
+
if (!J.isValidErrorCode(s)) {
|
|
3266
3303
|
console.warn("Неизвестный код ошибки: ", { code: s, origin: e, method: t });
|
|
3267
3304
|
return;
|
|
3268
3305
|
}
|
|
3269
3306
|
if (!s) return;
|
|
3270
|
-
const
|
|
3271
|
-
console.error(`${e}. ${t}. ${s}. ${
|
|
3307
|
+
const n = o || s;
|
|
3308
|
+
console.error(`${e}. ${t}. ${s}. ${n}`, a);
|
|
3272
3309
|
const i = {
|
|
3273
3310
|
code: s,
|
|
3274
3311
|
origin: e,
|
|
3275
3312
|
method: t,
|
|
3276
|
-
message:
|
|
3313
|
+
message: n,
|
|
3277
3314
|
data: a
|
|
3278
3315
|
};
|
|
3279
3316
|
this._buffer.push(I({
|
|
@@ -3290,19 +3327,19 @@ class $ {
|
|
|
3290
3327
|
* @param options.message — текст предупреждения (опционально, если не передан, то используется код предупреждения)
|
|
3291
3328
|
* @fires editor:warning
|
|
3292
3329
|
*/
|
|
3293
|
-
emitWarning({ origin: e = "ImageEditor", method: t = "Unknown Method", code: s, message: a, data:
|
|
3294
|
-
if (
|
|
3330
|
+
emitWarning({ origin: e = "ImageEditor", method: t = "Unknown Method", code: s, message: a, data: o }) {
|
|
3331
|
+
if (!J.isValidErrorCode(s)) {
|
|
3295
3332
|
console.warn("Неизвестный код предупреждения: ", { code: s, origin: e, method: t });
|
|
3296
3333
|
return;
|
|
3297
3334
|
}
|
|
3298
|
-
const
|
|
3299
|
-
console.warn(`${e}. ${t}. ${s}. ${
|
|
3335
|
+
const n = a || s;
|
|
3336
|
+
console.warn(`${e}. ${t}. ${s}. ${n}`, o);
|
|
3300
3337
|
const i = {
|
|
3301
3338
|
code: s,
|
|
3302
3339
|
origin: e,
|
|
3303
3340
|
method: t,
|
|
3304
|
-
message:
|
|
3305
|
-
data:
|
|
3341
|
+
message: n,
|
|
3342
|
+
data: o
|
|
3306
3343
|
};
|
|
3307
3344
|
this._buffer.push(I({
|
|
3308
3345
|
type: "editor:warning"
|
|
@@ -3317,7 +3354,7 @@ class $ {
|
|
|
3317
3354
|
return e ? Object.values(bt).some((t) => Object.values(t).includes(e)) : !1;
|
|
3318
3355
|
}
|
|
3319
3356
|
}
|
|
3320
|
-
class
|
|
3357
|
+
class ce {
|
|
3321
3358
|
/**
|
|
3322
3359
|
* Конструктор класса ImageEditor.
|
|
3323
3360
|
* @param canvasId - идентификатор канваса, в котором будет создан редактор
|
|
@@ -3338,14 +3375,14 @@ class re {
|
|
|
3338
3375
|
editorContainerHeight: t,
|
|
3339
3376
|
canvasWrapperWidth: s,
|
|
3340
3377
|
canvasWrapperHeight: a,
|
|
3341
|
-
canvasCSSWidth:
|
|
3342
|
-
canvasCSSHeight:
|
|
3378
|
+
canvasCSSWidth: o,
|
|
3379
|
+
canvasCSSHeight: n,
|
|
3343
3380
|
initialImage: i,
|
|
3344
3381
|
initialStateJSON: c,
|
|
3345
3382
|
scaleType: d,
|
|
3346
3383
|
_onReadyCallback: h
|
|
3347
3384
|
} = this.options;
|
|
3348
|
-
if (
|
|
3385
|
+
if (Ge.apply(), this.canvas = new Te(this.containerId, this.options), this.moduleLoader = new Re(), this.workerManager = new ze(), this.errorManager = new J({ editor: this }), this.historyManager = new Q({ editor: this }), this.toolbar = new st({ editor: this }), this.transformManager = new lt({ editor: this }), this.canvasManager = new dt({ editor: this }), this.imageManager = new O({ editor: this }), this.layerManager = new K({ editor: this }), this.shapeManager = new gt({ editor: this }), this.interactionBlocker = new ht({ editor: this }), this.backgroundManager = new x({ editor: this }), this.clipboardManager = new ut({ editor: this }), this.objectLockManager = new $({ editor: this }), this.groupingManager = new ft({ editor: this }), this.selectionManager = new Mt({ editor: this }), this.deletionManager = new mt({ editor: this }), this._createMontageArea(), this._createClippingArea(), this.listeners = new Y({ editor: this, options: this.options }), this.canvasManager.setEditorContainerWidth(e), this.canvasManager.setEditorContainerHeight(t), this.canvasManager.setCanvasWrapperWidth(s), this.canvasManager.setCanvasWrapperHeight(a), this.canvasManager.setCanvasCSSWidth(o), this.canvasManager.setCanvasCSSHeight(n), i != null && i.source) {
|
|
3349
3386
|
const {
|
|
3350
3387
|
source: l,
|
|
3351
3388
|
scale: g = `image-${d}`,
|
|
@@ -3368,7 +3405,7 @@ class re {
|
|
|
3368
3405
|
this.montageArea = this.shapeManager.addRectangle({
|
|
3369
3406
|
width: e,
|
|
3370
3407
|
height: t,
|
|
3371
|
-
fill:
|
|
3408
|
+
fill: ce._createMosaicPattern(),
|
|
3372
3409
|
stroke: null,
|
|
3373
3410
|
strokeWidth: 0,
|
|
3374
3411
|
selectable: !1,
|
|
@@ -3418,7 +3455,7 @@ class re {
|
|
|
3418
3455
|
const e = document.createElement("canvas");
|
|
3419
3456
|
e.width = 20, e.height = 20;
|
|
3420
3457
|
const t = e.getContext("2d");
|
|
3421
|
-
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
|
|
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 ke({
|
|
3422
3459
|
source: e,
|
|
3423
3460
|
repeat: "repeat"
|
|
3424
3461
|
});
|
|
@@ -3518,10 +3555,10 @@ function St(r, e = {}) {
|
|
|
3518
3555
|
if (!s)
|
|
3519
3556
|
return Promise.reject(new Error(`Контейнер с ID "${r}" не найден.`));
|
|
3520
3557
|
const a = document.createElement("canvas");
|
|
3521
|
-
return a.id = `${r}-canvas`, s.appendChild(a), t.editorContainer = s, new Promise((
|
|
3522
|
-
t._onReadyCallback =
|
|
3523
|
-
const
|
|
3524
|
-
window[r] =
|
|
3558
|
+
return a.id = `${r}-canvas`, s.appendChild(a), t.editorContainer = s, new Promise((o) => {
|
|
3559
|
+
t._onReadyCallback = o;
|
|
3560
|
+
const n = new ce(a.id, t);
|
|
3561
|
+
window[r] = n;
|
|
3525
3562
|
});
|
|
3526
3563
|
}
|
|
3527
3564
|
export {
|