@anu3ev/fabric-image-editor 0.1.0 → 0.1.2
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 → bundle.js} +460 -461
- package/dist/worker.js +68 -0
- package/package.json +2 -2
|
@@ -1,34 +1,34 @@
|
|
|
1
|
-
import { ActiveSelection as
|
|
2
|
-
import { create as
|
|
3
|
-
var He = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict",
|
|
1
|
+
import { ActiveSelection as Z, util as z, controlsUtils as Oe, InteractiveFabricObject as Te, Pattern as Ee, loadSVGFromURL as ke, FabricImage as de, Point as xe, Rect as Be, Circle as Ze, Triangle as ze, Group as Ue, Canvas as Pe } from "fabric";
|
|
2
|
+
import { create as Ye } from "jsondiffpatch";
|
|
3
|
+
var He = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict", I = function() {
|
|
4
4
|
for (var e = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : 21, t = "", a = crypto.getRandomValues(new Uint8Array(e |= 0)); e--; )
|
|
5
5
|
t += He[a[e] & 63];
|
|
6
6
|
return t;
|
|
7
7
|
};
|
|
8
|
-
function
|
|
8
|
+
function le(i, e, t, a, r, n, o) {
|
|
9
9
|
try {
|
|
10
|
-
var s = n
|
|
10
|
+
var s = i[n](o), c = s.value;
|
|
11
11
|
} catch (d) {
|
|
12
12
|
return void t(d);
|
|
13
13
|
}
|
|
14
14
|
s.done ? e(c) : Promise.resolve(c).then(a, r);
|
|
15
15
|
}
|
|
16
|
-
function
|
|
16
|
+
function We(i) {
|
|
17
17
|
return function() {
|
|
18
18
|
var e = this, t = arguments;
|
|
19
19
|
return new Promise(function(a, r) {
|
|
20
|
-
var
|
|
20
|
+
var n = i.apply(e, t);
|
|
21
21
|
function o(c) {
|
|
22
|
-
|
|
22
|
+
le(n, a, r, o, s, "next", c);
|
|
23
23
|
}
|
|
24
24
|
function s(c) {
|
|
25
|
-
|
|
25
|
+
le(n, a, r, o, s, "throw", c);
|
|
26
26
|
}
|
|
27
27
|
o(void 0);
|
|
28
28
|
});
|
|
29
29
|
};
|
|
30
30
|
}
|
|
31
|
-
class
|
|
31
|
+
class B {
|
|
32
32
|
/**
|
|
33
33
|
* Конструктор принимает редактор и опции.
|
|
34
34
|
* @param {Object} params
|
|
@@ -49,7 +49,7 @@ class Ve {
|
|
|
49
49
|
editor: t,
|
|
50
50
|
options: a = {}
|
|
51
51
|
} = e;
|
|
52
|
-
this.editor = t, this.canvas = t.canvas, this.options = a, this.isUndoRedoKeyPressed = !1, this.handleAdaptCanvasToContainerBound =
|
|
52
|
+
this.editor = t, this.canvas = t.canvas, this.options = a, this.isUndoRedoKeyPressed = !1, this.handleAdaptCanvasToContainerBound = B.debounce(this.handleAdaptCanvasToContainer.bind(this), 500), this.handleCopyEventBound = this.handleCopyEvent.bind(this), this.handlePasteEventBound = this.handlePasteEvent.bind(this), this.handleUndoRedoEventBound = this.handleUndoRedoEvent.bind(this), this.handleUndoRedoKeyUpBound = this.handleUndoRedoKeyUp.bind(this), this.handleSelectAllEventBound = this.handleSelectAllEvent.bind(this), this.handleDeleteObjectsEventBound = this.handleDeleteObjectsEvent.bind(this), this.handleObjectModifiedHistoryBound = B.debounce(this.handleObjectModifiedHistory.bind(this), 300), this.handleObjectRotatingHistoryBound = B.debounce(this.handleObjectRotatingHistory.bind(this), 300), this.handleObjectAddedHistoryBound = this.handleObjectAddedHistory.bind(this), this.handleObjectRemovedHistoryBound = this.handleObjectRemovedHistory.bind(this), this.handleOverlayUpdateBound = this.handleOverlayUpdate.bind(this), this.handleCanvasDragStartBound = this.handleCanvasDragStart.bind(this), this.handleCanvasDraggingBound = this.handleCanvasDragging.bind(this), this.handleCanvasDragEndBound = this.handleCanvasDragEnd.bind(this), this.handleMouseWheelZoomBound = this.handleMouseWheelZoom.bind(this), this.handleBringToFrontBound = this.handleBringToFront.bind(this), this.handleResetObjectFitBound = this.handleResetObjectFit.bind(this), this.handleLockedSelectionBound = this._filterLockedSelection.bind(this), this.init();
|
|
53
53
|
}
|
|
54
54
|
/**
|
|
55
55
|
* Инициализация всех обработчиков согласно опциям.
|
|
@@ -60,7 +60,7 @@ class Ve {
|
|
|
60
60
|
canvasDragging: t,
|
|
61
61
|
mouseWheelZooming: a,
|
|
62
62
|
bringToFrontOnSelection: r,
|
|
63
|
-
copyObjectsByHotkey:
|
|
63
|
+
copyObjectsByHotkey: n,
|
|
64
64
|
pasteImageFromClipboard: o,
|
|
65
65
|
undoRedoByHotKeys: s,
|
|
66
66
|
selectAllByHotkey: c,
|
|
@@ -69,7 +69,7 @@ class Ve {
|
|
|
69
69
|
} = this.options;
|
|
70
70
|
t && (this.canvas.on("mouse:down", this.handleCanvasDragStartBound), this.canvas.on("mouse:move", this.handleCanvasDraggingBound), this.canvas.on("mouse:up", this.handleCanvasDragEndBound)), a && this.canvas.on("mouse:wheel", this.handleMouseWheelZoomBound), r && (this.canvas.on("selection:created", this.handleBringToFrontBound), this.canvas.on("selection:updated", this.handleBringToFrontBound)), l && this.canvas.on("mouse:dblclick", this.handleResetObjectFitBound), e && window.addEventListener("resize", this.handleAdaptCanvasToContainerBound, {
|
|
71
71
|
capture: !0
|
|
72
|
-
}),
|
|
72
|
+
}), n && document.addEventListener("keydown", this.handleCopyEventBound, {
|
|
73
73
|
capture: !0
|
|
74
74
|
}), o && document.addEventListener("paste", this.handlePasteEventBound, {
|
|
75
75
|
capture: !0
|
|
@@ -102,10 +102,10 @@ class Ve {
|
|
|
102
102
|
this.canvas.setActiveObject(r[0]);
|
|
103
103
|
return;
|
|
104
104
|
}
|
|
105
|
-
var
|
|
105
|
+
var n = new Z(r, {
|
|
106
106
|
canvas: this.canvas
|
|
107
107
|
});
|
|
108
|
-
this.canvas.setActiveObject(
|
|
108
|
+
this.canvas.setActiveObject(n), this.canvas.requestRenderAll();
|
|
109
109
|
}
|
|
110
110
|
}
|
|
111
111
|
}
|
|
@@ -180,14 +180,14 @@ class Ve {
|
|
|
180
180
|
if (a != null && (t = a.items) !== null && t !== void 0 && t.length) {
|
|
181
181
|
var {
|
|
182
182
|
items: r
|
|
183
|
-
} = a,
|
|
184
|
-
if (
|
|
185
|
-
var o =
|
|
183
|
+
} = a, n = r[r.length - 1];
|
|
184
|
+
if (n.type.indexOf("image") !== -1) {
|
|
185
|
+
var o = n.getAsFile();
|
|
186
186
|
if (!o) return;
|
|
187
187
|
var s = new FileReader();
|
|
188
|
-
s.onload = (
|
|
188
|
+
s.onload = (h) => {
|
|
189
189
|
this.editor.imageManager.importImage({
|
|
190
|
-
source:
|
|
190
|
+
source: h.target.result
|
|
191
191
|
});
|
|
192
192
|
}, s.readAsDataURL(o);
|
|
193
193
|
return;
|
|
@@ -214,14 +214,14 @@ class Ve {
|
|
|
214
214
|
*/
|
|
215
215
|
handleUndoRedoEvent(e) {
|
|
216
216
|
var t = this;
|
|
217
|
-
return
|
|
217
|
+
return We(function* () {
|
|
218
218
|
var {
|
|
219
219
|
ctrlKey: a,
|
|
220
220
|
metaKey: r,
|
|
221
|
-
code:
|
|
221
|
+
code: n,
|
|
222
222
|
repeat: o
|
|
223
223
|
} = e;
|
|
224
|
-
!a && !r || o || t.isUndoRedoKeyPressed || (
|
|
224
|
+
!a && !r || o || t.isUndoRedoKeyPressed || (n === "KeyZ" ? (e.preventDefault(), t.isUndoRedoKeyPressed = !0, yield t.editor.historyManager.undo()) : n === "KeyY" && (e.preventDefault(), t.isUndoRedoKeyPressed = !0, yield t.editor.historyManager.redo()));
|
|
225
225
|
})();
|
|
226
226
|
}
|
|
227
227
|
/**
|
|
@@ -347,19 +347,19 @@ class Ve {
|
|
|
347
347
|
}), this.options.canvasDragging && (this.canvas.off("mouse:down", this.handleCanvasDragStartBound), this.canvas.off("mouse:move", this.handleCanvasDraggingBound), this.canvas.off("mouse:up", this.handleCanvasDragEndBound)), this.options.mouseWheelZooming && this.canvas.off("mouse:wheel", this.handleMouseWheelZoomBound), this.options.bringToFrontOnSelection && (this.canvas.off("selection:created", this.handleBringToFrontBound), this.canvas.off("selection:updated", this.handleBringToFrontBound)), this.options.resetObjectFitByDoubleClick && this.canvas.off("mouse:dblclick", this.handleResetObjectFitBound), this.canvas.off("object:modified", this.handleObjectModifiedHistoryBound), this.canvas.off("object:rotating", this.handleObjectRotatingHistoryBound), this.canvas.off("object:added", this.handleObjectAddedHistoryBound), this.canvas.off("object:removed", this.handleObjectRemovedHistoryBound), this.canvas.off("object:added", this.handleOverlayUpdateBound), this.canvas.off("selection:created", this.handleOverlayUpdateBound), this.canvas.off("selection:created", this.handleLockedSelectionBound.bind(this)), this.canvas.off("selection:updated", this.handleLockedSelectionBound.bind(this));
|
|
348
348
|
}
|
|
349
349
|
// Дебаунс для снижения частоты сохранения состояния
|
|
350
|
-
debounce(e, t) {
|
|
350
|
+
static debounce(e, t) {
|
|
351
351
|
var a = null;
|
|
352
352
|
return function() {
|
|
353
|
-
for (var r = arguments.length,
|
|
354
|
-
|
|
353
|
+
for (var r = arguments.length, n = new Array(r), o = 0; o < r; o++)
|
|
354
|
+
n[o] = arguments[o];
|
|
355
355
|
var s = this;
|
|
356
356
|
clearTimeout(a), a = setTimeout(() => {
|
|
357
|
-
e.apply(s,
|
|
357
|
+
e.apply(s, n);
|
|
358
358
|
}, t);
|
|
359
359
|
};
|
|
360
360
|
}
|
|
361
361
|
}
|
|
362
|
-
class
|
|
362
|
+
class _e {
|
|
363
363
|
/**
|
|
364
364
|
* @description Класс для динамической загрузки внешних модулей.
|
|
365
365
|
*/
|
|
@@ -383,7 +383,7 @@ class Re {
|
|
|
383
383
|
* По-умолчанию использует файл рядом с этим модулем
|
|
384
384
|
*/
|
|
385
385
|
constructor() {
|
|
386
|
-
var e = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : new URL("
|
|
386
|
+
var e = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : new URL("" + new URL("worker.js", import.meta.url).href, import.meta.url);
|
|
387
387
|
this.worker = new Worker(e, {
|
|
388
388
|
type: "module"
|
|
389
389
|
}), this._callbacks = /* @__PURE__ */ new Map(), this.worker.onmessage = this._handleMessage.bind(this);
|
|
@@ -404,10 +404,10 @@ class Re {
|
|
|
404
404
|
} = e, {
|
|
405
405
|
requestId: a,
|
|
406
406
|
success: r,
|
|
407
|
-
data:
|
|
407
|
+
data: n,
|
|
408
408
|
error: o
|
|
409
409
|
} = t, s = this._callbacks.get(a);
|
|
410
|
-
s && (r ? s.resolve(
|
|
410
|
+
s && (r ? s.resolve(n) : s.reject(new Error(o)), this._callbacks.delete(a));
|
|
411
411
|
}
|
|
412
412
|
/**
|
|
413
413
|
* Универсальный метод отправки команды в воркер
|
|
@@ -417,10 +417,10 @@ class Re {
|
|
|
417
417
|
* @returns {Promise<any>}
|
|
418
418
|
*/
|
|
419
419
|
post(e, t) {
|
|
420
|
-
var a = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : [], r = "".concat(e, ":").concat(
|
|
421
|
-
return new Promise((
|
|
420
|
+
var a = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : [], r = "".concat(e, ":").concat(I(8));
|
|
421
|
+
return new Promise((n, o) => {
|
|
422
422
|
this._callbacks.set(r, {
|
|
423
|
-
resolve:
|
|
423
|
+
resolve: n,
|
|
424
424
|
reject: o
|
|
425
425
|
}), this.worker.postMessage({
|
|
426
426
|
action: e,
|
|
@@ -436,98 +436,98 @@ class Re {
|
|
|
436
436
|
this.worker.terminate();
|
|
437
437
|
}
|
|
438
438
|
}
|
|
439
|
-
var
|
|
440
|
-
function
|
|
441
|
-
var
|
|
442
|
-
|
|
439
|
+
var p = 12, Ve = 2, X = 8, Q = 20, Fe = 100, J = 20, K = 8, Ge = 100, $ = 32, q = 1, Xe = "#2B2D33", ee = "#3D8BF4", te = "#FFFFFF";
|
|
440
|
+
function U(i, e, t, a, r) {
|
|
441
|
+
var n = p, o = Ve;
|
|
442
|
+
i.save(), i.translate(e, t), i.rotate(z.degreesToRadians(r.angle)), i.fillStyle = te, i.strokeStyle = ee, i.lineWidth = q, i.beginPath(), i.roundRect(-12 / 2, -12 / 2, n, n, o), i.fill(), i.stroke(), i.restore();
|
|
443
443
|
}
|
|
444
|
-
function
|
|
445
|
-
var
|
|
446
|
-
|
|
444
|
+
function he(i, e, t, a, r) {
|
|
445
|
+
var n = X, o = Q, s = Fe;
|
|
446
|
+
i.save(), i.translate(e, t), i.rotate(z.degreesToRadians(r.angle)), i.fillStyle = te, i.strokeStyle = ee, i.lineWidth = q, i.beginPath(), i.roundRect(-8 / 2, -20 / 2, n, o, s), i.fill(), i.stroke(), i.restore();
|
|
447
447
|
}
|
|
448
|
-
function ge(
|
|
449
|
-
var
|
|
450
|
-
|
|
448
|
+
function ge(i, e, t, a, r) {
|
|
449
|
+
var n = J, o = K, s = Ge;
|
|
450
|
+
i.save(), i.translate(e, t), i.rotate(z.degreesToRadians(r.angle)), i.fillStyle = te, i.strokeStyle = ee, i.lineWidth = q, i.beginPath(), i.roundRect(-20 / 2, -8 / 2, n, o, s), i.fill(), i.stroke(), i.restore();
|
|
451
451
|
}
|
|
452
|
-
var Qe = "data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgZmlsbD0ibm9uZSI+PHBhdGggZmlsbD0iI2ZmZiIgZD0iTTE4Ljc1IDQuMzc1djMuNzVhLjYyNS42MjUgMCAwIDEtLjYyNS42MjVoLTMuNzVhLjYyNS42MjUgMCAwIDEgMC0xLjI1aDIuMTRsLTIuMDc3LTEuOTAzLS4wMi0uMDE5YTYuMjUgNi4yNSAwIDEgMC0uMTMgOC45NjcuNjI2LjYyNiAwIDAgMSAuODYuOTA5QTcuNDU2IDcuNDU2IDAgMCAxIDEwIDE3LjVoLS4xMDNhNy41IDcuNSAwIDEgMSA1LjM5Ni0xMi44MTJMMTcuNSA2LjcwM1Y0LjM3NWEuNjI1LjYyNSAwIDAgMSAxLjI1IDBaIi8+PC9zdmc+",
|
|
453
|
-
|
|
454
|
-
function
|
|
455
|
-
var
|
|
456
|
-
|
|
452
|
+
var Qe = "data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgZmlsbD0ibm9uZSI+PHBhdGggZmlsbD0iI2ZmZiIgZD0iTTE4Ljc1IDQuMzc1djMuNzVhLjYyNS42MjUgMCAwIDEtLjYyNS42MjVoLTMuNzVhLjYyNS42MjUgMCAwIDEgMC0xLjI1aDIuMTRsLTIuMDc3LTEuOTAzLS4wMi0uMDE5YTYuMjUgNi4yNSAwIDEgMC0uMTMgOC45NjcuNjI2LjYyNiAwIDAgMSAuODYuOTA5QTcuNDU2IDcuNDU2IDAgMCAxIDEwIDE3LjVoLS4xMDNhNy41IDcuNSAwIDEgMSA1LjM5Ni0xMi44MTJMMTcuNSA2LjcwM1Y0LjM3NWEuNjI1LjYyNSAwIDAgMSAxLjI1IDBaIi8+PC9zdmc+", Ae = new Image();
|
|
453
|
+
Ae.src = Qe;
|
|
454
|
+
function Je(i, e, t, a, r) {
|
|
455
|
+
var n = $, o = n / 2;
|
|
456
|
+
i.save(), i.translate(e, t), i.rotate(z.degreesToRadians(r.angle)), i.fillStyle = Xe, i.beginPath(), i.arc(0, 0, o, 0, 2 * Math.PI), i.fill(), i.drawImage(Ae, -16 / 2, -16 / 2, o, o), i.restore();
|
|
457
457
|
}
|
|
458
|
-
var
|
|
458
|
+
var Ke = {
|
|
459
459
|
// Угловые точки
|
|
460
460
|
tl: {
|
|
461
|
-
render:
|
|
462
|
-
sizeX:
|
|
463
|
-
sizeY:
|
|
461
|
+
render: U,
|
|
462
|
+
sizeX: p,
|
|
463
|
+
sizeY: p,
|
|
464
464
|
offsetX: 0,
|
|
465
465
|
offsetY: 0
|
|
466
466
|
},
|
|
467
467
|
tr: {
|
|
468
|
-
render:
|
|
469
|
-
sizeX:
|
|
470
|
-
sizeY:
|
|
468
|
+
render: U,
|
|
469
|
+
sizeX: p,
|
|
470
|
+
sizeY: p,
|
|
471
471
|
offsetX: 0,
|
|
472
472
|
offsetY: 0
|
|
473
473
|
},
|
|
474
474
|
bl: {
|
|
475
|
-
render:
|
|
476
|
-
sizeX:
|
|
477
|
-
sizeY:
|
|
475
|
+
render: U,
|
|
476
|
+
sizeX: p,
|
|
477
|
+
sizeY: p,
|
|
478
478
|
offsetX: 0,
|
|
479
479
|
offsetY: 0
|
|
480
480
|
},
|
|
481
481
|
br: {
|
|
482
|
-
render:
|
|
483
|
-
sizeX:
|
|
484
|
-
sizeY:
|
|
482
|
+
render: U,
|
|
483
|
+
sizeX: p,
|
|
484
|
+
sizeY: p,
|
|
485
485
|
offsetX: 0,
|
|
486
486
|
offsetY: 0
|
|
487
487
|
},
|
|
488
488
|
// Середина вертикалей
|
|
489
489
|
ml: {
|
|
490
|
-
render:
|
|
491
|
-
sizeX:
|
|
492
|
-
sizeY:
|
|
490
|
+
render: he,
|
|
491
|
+
sizeX: X,
|
|
492
|
+
sizeY: Q,
|
|
493
493
|
offsetX: 0,
|
|
494
494
|
offsetY: 0
|
|
495
495
|
},
|
|
496
496
|
mr: {
|
|
497
|
-
render:
|
|
498
|
-
sizeX:
|
|
499
|
-
sizeY:
|
|
497
|
+
render: he,
|
|
498
|
+
sizeX: X,
|
|
499
|
+
sizeY: Q,
|
|
500
500
|
offsetX: 0,
|
|
501
501
|
offsetY: 0
|
|
502
502
|
},
|
|
503
503
|
// Середина горизонталей
|
|
504
504
|
mt: {
|
|
505
505
|
render: ge,
|
|
506
|
-
sizeX:
|
|
506
|
+
sizeX: J,
|
|
507
507
|
sizeY: K,
|
|
508
508
|
offsetX: 0,
|
|
509
509
|
offsetY: 0
|
|
510
510
|
},
|
|
511
511
|
mb: {
|
|
512
512
|
render: ge,
|
|
513
|
-
sizeX:
|
|
513
|
+
sizeX: J,
|
|
514
514
|
sizeY: K,
|
|
515
515
|
offsetX: 0,
|
|
516
516
|
offsetY: 0
|
|
517
517
|
},
|
|
518
518
|
// Специальный «rotate» контрол
|
|
519
519
|
mtr: {
|
|
520
|
-
render:
|
|
521
|
-
sizeX:
|
|
522
|
-
sizeY:
|
|
520
|
+
render: Je,
|
|
521
|
+
sizeX: $,
|
|
522
|
+
sizeY: $,
|
|
523
523
|
offsetX: 0,
|
|
524
524
|
offsetY: -32
|
|
525
525
|
}
|
|
526
526
|
};
|
|
527
527
|
class $e {
|
|
528
528
|
static apply() {
|
|
529
|
-
var e =
|
|
530
|
-
Object.entries(
|
|
529
|
+
var e = Oe.createObjectDefaultControls();
|
|
530
|
+
Object.entries(Ke).forEach((t) => {
|
|
531
531
|
var [a, r] = t;
|
|
532
532
|
Object.assign(e[a], {
|
|
533
533
|
render: r.render,
|
|
@@ -536,28 +536,28 @@ class $e {
|
|
|
536
536
|
offsetX: r.offsetX,
|
|
537
537
|
offsetY: r.offsetY
|
|
538
538
|
});
|
|
539
|
-
}),
|
|
539
|
+
}), Te.ownDefaults.controls = e;
|
|
540
540
|
}
|
|
541
541
|
}
|
|
542
|
-
var qe = "data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgZmlsbD0ibm9uZSI+PHBhdGggZmlsbD0iI2ZmZiIgZmlsbC1ydWxlPSJldmVub2RkIiBkPSJNNi44NzUgMi41YS42MjUuNjI1IDAgMCAwLS42MjUuNjI0VjYuMjVIMy4xMjVhLjYyNS42MjUgMCAwIDAtLjYyNS42MjV2MTBjMCAuMzQ1LjI4LjYyNS42MjUuNjI1aDEwYy4zNDUgMCAuNjI1LS4yOC42MjUtLjYyNXYtMy4xMjZoMy4xMjVjLjM0NSAwIC42MjUtLjI4LjYyNS0uNjI1di0xMGEuNjI1LjYyNSAwIDAgMC0uNjI1LS42MjVoLTEwWm02Ljg3NSAxMGgyLjVWMy43NUg3LjV2Mi41aDUuNjI1Yy4zNDUgMCAuNjI1LjI4LjYyNS42MjV2NS42MjRabS0xMCAzLjc1VjcuNWg4Ljc1djguNzVIMy43NVoiIGNsaXAtcnVsZT0iZXZlbm9kZCIvPjwvc3ZnPg==", et = "data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgZmlsbD0ibm9uZSI+PHBhdGggZmlsbD0iI2ZmZiIgZmlsbC1ydWxlPSJldmVub2RkIiBkPSJNMi41IDcuNWMwLS42OS41Ni0xLjI1IDEuMjUtMS4yNWgxMi41Yy42OSAwIDEuMjUuNTYgMS4yNSAxLjI1djguNzVjMCAuNjktLjU2IDEuMjUtMS4yNSAxLjI1SDMuNzVjLS42OSAwLTEuMjUtLjU2LTEuMjUtMS4yNVY3LjVabTEzLjc1IDBIMy43NXY4Ljc1aDEyLjVWNy41WiIgY2xpcC1ydWxlPSJldmVub2RkIi8+PHBhdGggZmlsbD0iI2ZmZiIgZmlsbC1ydWxlPSJldmVub2RkIiBkPSJNMTAgMS44NzVhMi4xODggMi4xODggMCAwIDAtMi4xODggMi4xODh2Mi44MTJhLjYyNS42MjUgMCAxIDEtMS4yNSAwVjQuMDYyYTMuNDM3IDMuNDM3IDAgMSAxIDYuODc1IDB2Mi44MTNhLjYyNS42MjUgMCAxIDEtMS4yNSAwVjQuMDYyQTIuMTg4IDIuMTg4IDAgMCAwIDEwIDEuODc2WiIgY2xpcC1ydWxlPSJldmVub2RkIi8+PHBhdGggZmlsbD0iI2ZmZiIgZD0iTTEwIDEyLjgxM2EuOTM3LjkzNyAwIDEgMCAwLTEuODc1LjkzNy45MzcgMCAwIDAgMCAxLjg3NFoiLz48L3N2Zz4=", tt = "data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgZmlsbD0ibm9uZSI+PHBhdGggZmlsbD0iI2ZmZiIgZD0iTTE2LjI1IDYuMjVINy41VjQuMzc1YTIuNSAyLjUgMCAwIDEgMi41LTIuNWMxLjIgMCAyLjI4MS44NiAyLjUxMiAyYS42MjUuNjI1IDAgMCAwIDEuMjI2LS4yNWMtLjM1NC0xLjczOC0xLjkyNS0zLTMuNzM4LTNhMy43NTQgMy43NTQgMCAwIDAtMy43NSAzLjc1VjYuMjVoLTIuNUExLjI1IDEuMjUgMCAwIDAgMi41IDcuNXY4Ljc1YTEuMjUgMS4yNSAwIDAgMCAxLjI1IDEuMjVoMTIuNWExLjI1IDEuMjUgMCAwIDAgMS4yNS0xLjI1VjcuNWExLjI1IDEuMjUgMCAwIDAtMS4yNS0xLjI1Wm0wIDEwSDMuNzVWNy41aDEyLjV2OC43NVptLTUuMzEzLTQuMzc1YS45MzcuOTM3IDAgMSAxLTEuODc0IDAgLjkzNy45MzcgMCAwIDEgMS44NzQgMFoiLz48L3N2Zz4K", at = "data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgZmlsbD0ibm9uZSI+PHBhdGggZmlsbD0iI2ZmZiIgZD0iTTIuNSA4LjEyNSAxMCAxMi41bDcuNS00LjM3NUwxMCAzLjc1IDIuNSA4LjEyNVoiLz48cGF0aCBmaWxsPSIjZmZmIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik05LjY4NSAzLjIxYS42MjUuNjI1IDAgMCAxIC42MyAwbDcuNSA0LjM3NWEuNjI1LjYyNSAwIDAgMSAwIDEuMDhsLTcuNSA0LjM3NWEuNjI1LjYyNSAwIDAgMS0uNjMgMGwtNy41LTQuMzc1YS42MjUuNjI1IDAgMCAxIDAtMS4wOGw3LjUtNC4zNzVaTTMuNzQgOC4xMjUgMTAgMTEuNzc2bDYuMjYtMy42NTFMMTAgNC40NzQgMy43NCA4LjEyNVoiIGNsaXAtcnVsZT0iZXZlbm9kZCIvPjxwYXRoIGZpbGw9IiNmZmYiIGZpbGwtcnVsZT0iZXZlbm9kZCIgZD0iTTUuNCA5LjQ2YS42MjUuNjI1IDAgMCAxIC42MyAwTDEwIDExLjc3NmwzLjk3LTIuMzE2YS42MjUuNjI1IDAgMCAxIC42MyAwbDMuMjE1IDEuODc1YS42MjUuNjI1IDAgMCAxIDAgMS4wOGwtNy41IDQuMzc1YS42MjUuNjI1IDAgMCAxLS42MyAwbC03LjUtNC4zNzVhLjYyNS42MjUgMCAwIDEgMC0xLjA4TDUuNCA5LjQ2Wm0tMS42NiAyLjQxNUwxMCAxNS41MjZsNi4yNi0zLjY1MS0xLjk3NC0xLjE1MS0zLjk3MSAyLjMxNmEuNjI1LjYyNSAwIDAgMS0uNjMgMGwtMy45Ny0yLjMxNi0xLjk3NSAxLjE1MVoiIGNsaXAtcnVsZT0iZXZlbm9kZCIvPjwvc3ZnPg==", rt = "data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgZmlsbD0ibm9uZSI+PHBhdGggZmlsbD0iI2ZmZiIgZmlsbC1ydWxlPSJldmVub2RkIiBkPSJNOS42ODUgMy4yMWEuNjI1LjYyNSAwIDAgMSAuNjMgMGw3LjUgNC4zNzVhLjYyNS42MjUgMCAwIDEgMCAxLjA4bC03LjUgNC4zNzVhLjYyNS42MjUgMCAwIDEtLjYzIDBsLTcuNS00LjM3NWEuNjI1LjYyNSAwIDAgMSAwLTEuMDhsNy41LTQuMzc1Wk0zLjc0IDguMTI1IDEwIDExLjc3Nmw2LjI2LTMuNjUxTDEwIDQuNDc0IDMuNzQgOC4xMjVaIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiLz48cGF0aCBmaWxsPSIjZmZmIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik01LjcxNCAxMCAxMCAxMi41bDQuMjg2LTIuNSAzLjIxNCAxLjg3NUwxMCAxNi4yNWwtNy41LTQuMzc1TDUuNzE0IDEwWiIgY2xpcC1ydWxlPSJldmVub2RkIi8+PHBhdGggZmlsbD0iI2ZmZiIgZmlsbC1ydWxlPSJldmVub2RkIiBkPSJNNS40IDkuNDZhLjYyNS42MjUgMCAwIDEgLjYzIDBMMTAgMTEuNzc2bDMuOTctMi4zMTZhLjYyNS42MjUgMCAwIDEgLjYzIDBsMy4yMTUgMS44NzVhLjYyNS42MjUgMCAwIDEgMCAxLjA4bC03LjUgNC4zNzVhLjYyNS42MjUgMCAwIDEtLjYzIDBsLTcuNS00LjM3NWEuNjI1LjYyNSAwIDAgMSAwLTEuMDhMNS40IDkuNDZabS0xLjY2IDIuNDE1TDEwIDE1LjUyNmw2LjI2LTMuNjUxLTEuOTc0LTEuMTUxLTMuOTcxIDIuMzE2YS42MjUuNjI1IDAgMCAxLS42MyAwbC0zLjk3LTIuMzE2LTEuOTc1IDEuMTUxWiIgY2xpcC1ydWxlPSJldmVub2RkIi8+PC9zdmc+",
|
|
543
|
-
function
|
|
542
|
+
var qe = "data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgZmlsbD0ibm9uZSI+PHBhdGggZmlsbD0iI2ZmZiIgZmlsbC1ydWxlPSJldmVub2RkIiBkPSJNNi44NzUgMi41YS42MjUuNjI1IDAgMCAwLS42MjUuNjI0VjYuMjVIMy4xMjVhLjYyNS42MjUgMCAwIDAtLjYyNS42MjV2MTBjMCAuMzQ1LjI4LjYyNS42MjUuNjI1aDEwYy4zNDUgMCAuNjI1LS4yOC42MjUtLjYyNXYtMy4xMjZoMy4xMjVjLjM0NSAwIC42MjUtLjI4LjYyNS0uNjI1di0xMGEuNjI1LjYyNSAwIDAgMC0uNjI1LS42MjVoLTEwWm02Ljg3NSAxMGgyLjVWMy43NUg3LjV2Mi41aDUuNjI1Yy4zNDUgMCAuNjI1LjI4LjYyNS42MjV2NS42MjRabS0xMCAzLjc1VjcuNWg4Ljc1djguNzVIMy43NVoiIGNsaXAtcnVsZT0iZXZlbm9kZCIvPjwvc3ZnPg==", et = "data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgZmlsbD0ibm9uZSI+PHBhdGggZmlsbD0iI2ZmZiIgZmlsbC1ydWxlPSJldmVub2RkIiBkPSJNMi41IDcuNWMwLS42OS41Ni0xLjI1IDEuMjUtMS4yNWgxMi41Yy42OSAwIDEuMjUuNTYgMS4yNSAxLjI1djguNzVjMCAuNjktLjU2IDEuMjUtMS4yNSAxLjI1SDMuNzVjLS42OSAwLTEuMjUtLjU2LTEuMjUtMS4yNVY3LjVabTEzLjc1IDBIMy43NXY4Ljc1aDEyLjVWNy41WiIgY2xpcC1ydWxlPSJldmVub2RkIi8+PHBhdGggZmlsbD0iI2ZmZiIgZmlsbC1ydWxlPSJldmVub2RkIiBkPSJNMTAgMS44NzVhMi4xODggMi4xODggMCAwIDAtMi4xODggMi4xODh2Mi44MTJhLjYyNS42MjUgMCAxIDEtMS4yNSAwVjQuMDYyYTMuNDM3IDMuNDM3IDAgMSAxIDYuODc1IDB2Mi44MTNhLjYyNS42MjUgMCAxIDEtMS4yNSAwVjQuMDYyQTIuMTg4IDIuMTg4IDAgMCAwIDEwIDEuODc2WiIgY2xpcC1ydWxlPSJldmVub2RkIi8+PHBhdGggZmlsbD0iI2ZmZiIgZD0iTTEwIDEyLjgxM2EuOTM3LjkzNyAwIDEgMCAwLTEuODc1LjkzNy45MzcgMCAwIDAgMCAxLjg3NFoiLz48L3N2Zz4=", tt = "data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgZmlsbD0ibm9uZSI+PHBhdGggZmlsbD0iI2ZmZiIgZD0iTTE2LjI1IDYuMjVINy41VjQuMzc1YTIuNSAyLjUgMCAwIDEgMi41LTIuNWMxLjIgMCAyLjI4MS44NiAyLjUxMiAyYS42MjUuNjI1IDAgMCAwIDEuMjI2LS4yNWMtLjM1NC0xLjczOC0xLjkyNS0zLTMuNzM4LTNhMy43NTQgMy43NTQgMCAwIDAtMy43NSAzLjc1VjYuMjVoLTIuNUExLjI1IDEuMjUgMCAwIDAgMi41IDcuNXY4Ljc1YTEuMjUgMS4yNSAwIDAgMCAxLjI1IDEuMjVoMTIuNWExLjI1IDEuMjUgMCAwIDAgMS4yNS0xLjI1VjcuNWExLjI1IDEuMjUgMCAwIDAtMS4yNS0xLjI1Wm0wIDEwSDMuNzVWNy41aDEyLjV2OC43NVptLTUuMzEzLTQuMzc1YS45MzcuOTM3IDAgMSAxLTEuODc0IDAgLjkzNy45MzcgMCAwIDEgMS44NzQgMFoiLz48L3N2Zz4K", at = "data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgZmlsbD0ibm9uZSI+PHBhdGggZmlsbD0iI2ZmZiIgZD0iTTIuNSA4LjEyNSAxMCAxMi41bDcuNS00LjM3NUwxMCAzLjc1IDIuNSA4LjEyNVoiLz48cGF0aCBmaWxsPSIjZmZmIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik05LjY4NSAzLjIxYS42MjUuNjI1IDAgMCAxIC42MyAwbDcuNSA0LjM3NWEuNjI1LjYyNSAwIDAgMSAwIDEuMDhsLTcuNSA0LjM3NWEuNjI1LjYyNSAwIDAgMS0uNjMgMGwtNy41LTQuMzc1YS42MjUuNjI1IDAgMCAxIDAtMS4wOGw3LjUtNC4zNzVaTTMuNzQgOC4xMjUgMTAgMTEuNzc2bDYuMjYtMy42NTFMMTAgNC40NzQgMy43NCA4LjEyNVoiIGNsaXAtcnVsZT0iZXZlbm9kZCIvPjxwYXRoIGZpbGw9IiNmZmYiIGZpbGwtcnVsZT0iZXZlbm9kZCIgZD0iTTUuNCA5LjQ2YS42MjUuNjI1IDAgMCAxIC42MyAwTDEwIDExLjc3NmwzLjk3LTIuMzE2YS42MjUuNjI1IDAgMCAxIC42MyAwbDMuMjE1IDEuODc1YS42MjUuNjI1IDAgMCAxIDAgMS4wOGwtNy41IDQuMzc1YS42MjUuNjI1IDAgMCAxLS42MyAwbC03LjUtNC4zNzVhLjYyNS42MjUgMCAwIDEgMC0xLjA4TDUuNCA5LjQ2Wm0tMS42NiAyLjQxNUwxMCAxNS41MjZsNi4yNi0zLjY1MS0xLjk3NC0xLjE1MS0zLjk3MSAyLjMxNmEuNjI1LjYyNSAwIDAgMS0uNjMgMGwtMy45Ny0yLjMxNi0xLjk3NSAxLjE1MVoiIGNsaXAtcnVsZT0iZXZlbm9kZCIvPjwvc3ZnPg==", rt = "data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgZmlsbD0ibm9uZSI+PHBhdGggZmlsbD0iI2ZmZiIgZmlsbC1ydWxlPSJldmVub2RkIiBkPSJNOS42ODUgMy4yMWEuNjI1LjYyNSAwIDAgMSAuNjMgMGw3LjUgNC4zNzVhLjYyNS42MjUgMCAwIDEgMCAxLjA4bC03LjUgNC4zNzVhLjYyNS42MjUgMCAwIDEtLjYzIDBsLTcuNS00LjM3NWEuNjI1LjYyNSAwIDAgMSAwLTEuMDhsNy41LTQuMzc1Wk0zLjc0IDguMTI1IDEwIDExLjc3Nmw2LjI2LTMuNjUxTDEwIDQuNDc0IDMuNzQgOC4xMjVaIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiLz48cGF0aCBmaWxsPSIjZmZmIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik01LjcxNCAxMCAxMCAxMi41bDQuMjg2LTIuNSAzLjIxNCAxLjg3NUwxMCAxNi4yNWwtNy41LTQuMzc1TDUuNzE0IDEwWiIgY2xpcC1ydWxlPSJldmVub2RkIi8+PHBhdGggZmlsbD0iI2ZmZiIgZmlsbC1ydWxlPSJldmVub2RkIiBkPSJNNS40IDkuNDZhLjYyNS42MjUgMCAwIDEgLjYzIDBMMTAgMTEuNzc2bDMuOTctMi4zMTZhLjYyNS42MjUgMCAwIDEgLjYzIDBsMy4yMTUgMS44NzVhLjYyNS42MjUgMCAwIDEgMCAxLjA4bC03LjUgNC4zNzVhLjYyNS42MjUgMCAwIDEtLjYzIDBsLTcuNS00LjM3NWEuNjI1LjYyNSAwIDAgMSAwLTEuMDhMNS40IDkuNDZabS0xLjY2IDIuNDE1TDEwIDE1LjUyNmw2LjI2LTMuNjUxLTEuOTc0LTEuMTUxLTMuOTcxIDIuMzE2YS42MjUuNjI1IDAgMCAxLS42MyAwbC0zLjk3LTIuMzE2LTEuOTc1IDEuMTUxWiIgY2xpcC1ydWxlPSJldmVub2RkIi8+PC9zdmc+", nt = "data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgZmlsbD0ibm9uZSI+PHBhdGggZmlsbD0iI2ZmZiIgZD0ibTIuNSA2LjI1IDcuNSA0LjM3NSA3LjUtNC4zNzVMMTAgMS44NzUgMi41IDYuMjVaIi8+PHBhdGggZmlsbD0iI2ZmZiIgZmlsbC1ydWxlPSJldmVub2RkIiBkPSJNOS42ODUgMS4zMzVhLjYyNS42MjUgMCAwIDEgLjYzIDBsNy41IDQuMzc1YS42MjUuNjI1IDAgMCAxIDAgMS4wOGwtNy41IDQuMzc1YS42MjUuNjI1IDAgMCAxLS42MyAwbC03LjUtNC4zNzVhLjYyNS42MjUgMCAwIDEgMC0xLjA4bDcuNS00LjM3NVpNMy43NCA2LjI1IDEwIDkuOTAxbDYuMjYtMy42NTFMMTAgMi41OTkgMy43NCA2LjI1WiIgY2xpcC1ydWxlPSJldmVub2RkIi8+PHBhdGggZmlsbD0iI2ZmZiIgZmlsbC1ydWxlPSJldmVub2RkIiBkPSJNNS40IDExLjMzNWEuNjI1LjYyNSAwIDAgMSAuNjMgMEwxMCAxMy42NTFsMy45Ny0yLjMxNmEuNjI1LjYyNSAwIDAgMSAuNjMgMGwzLjIxNSAxLjg3NWEuNjI1LjYyNSAwIDAgMSAwIDEuMDhsLTcuNSA0LjM3NWEuNjI1LjYyNSAwIDAgMS0uNjMgMGwtNy41LTQuMzc1YS42MjUuNjI1IDAgMCAxIDAtMS4wOEw1LjQgMTEuMzM1Wk0zLjc0IDEzLjc1IDEwIDE3LjQwMWw2LjI2LTMuNjUxLTEuOTc0LTEuMTUxLTMuOTcxIDIuMzE2YS42MjUuNjI1IDAgMCAxLS42MyAwbC0zLjk3LTIuMzE2TDMuNzQgMTMuNzVaIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiLz48cGF0aCBmaWxsPSIjZmZmIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik01LjQgNy41ODVhLjYyNS42MjUgMCAwIDEgLjYzIDBMMTAgOS45MDFsMy45Ny0yLjMxNmEuNjI1LjYyNSAwIDAgMSAuNjMgMGwzLjIxNSAxLjg3NWEuNjI1LjYyNSAwIDAgMSAwIDEuMDhsLTcuNSA0LjM3NWEuNjI1LjYyNSAwIDAgMS0uNjMgMGwtNy41LTQuMzc1YS42MjUuNjI1IDAgMCAxIDAtMS4wOEw1LjQgNy41ODVaTTMuNzQgMTAgMTAgMTMuNjUxIDE2LjI2IDEwbC0xLjk3NC0xLjE1MS0zLjk3MSAyLjMxNmEuNjI1LjYyNSAwIDAgMS0uNjMgMGwtMy45Ny0yLjMxNkwzLjc0IDEwWiIgY2xpcC1ydWxlPSJldmVub2RkIi8+PC9zdmc+", it = "data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgZmlsbD0ibm9uZSI+PHBhdGggZmlsbD0iI2ZmZiIgZmlsbC1ydWxlPSJldmVub2RkIiBkPSJNMS45NiAxMy40MzVhLjYyNS42MjUgMCAwIDEgLjg1NS0uMjI1TDEwIDE3LjQwMWw3LjE4NS00LjE5YS42MjUuNjI1IDAgMCAxIC42MyAxLjA3OWwtNy41IDQuMzc1YS42MjUuNjI1IDAgMCAxLS42MyAwbC03LjUtNC4zNzVhLjYyNS42MjUgMCAwIDEtLjIyNS0uODU1Wk05LjY4NSAxLjMzNWEuNjI1LjYyNSAwIDAgMSAuNjMgMGw3LjUgNC4zNzVhLjYyNS42MjUgMCAwIDEgMCAxLjA4bC03LjUgNC4zNzVhLjYyNS42MjUgMCAwIDEtLjYzIDBsLTcuNS00LjM3NWEuNjI1LjYyNSAwIDAgMSAwLTEuMDhsNy41LTQuMzc1Wk0zLjc0IDYuMjUgMTAgOS45MDFsNi4yNi0zLjY1MUwxMCAyLjU5OSAzLjc0IDYuMjVaIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiLz48cGF0aCBmaWxsPSIjZmZmIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIGQ9Im01LjcxNCAxMS44NzUgNC4yODYgMi41IDQuMjg2LTIuNUwxNy41IDEzLjc1IDEwIDE4LjEyNSAyLjUgMTMuNzVsMy4yMTQtMS44NzVaIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiLz48cGF0aCBmaWxsPSIjZmZmIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik01LjQgMTEuMzM1YS42MjUuNjI1IDAgMCAxIC42MyAwTDEwIDEzLjY1MWwzLjk3LTIuMzE2YS42MjUuNjI1IDAgMCAxIC42MyAwbDMuMjE1IDEuODc1YS42MjUuNjI1IDAgMCAxIDAgMS4wOGwtNy41IDQuMzc1YS42MjUuNjI1IDAgMCAxLS42MyAwbC03LjUtNC4zNzVhLjYyNS42MjUgMCAwIDEgMC0xLjA4TDUuNCAxMS4zMzVaTTMuNzQgMTMuNzUgMTAgMTcuNDAxbDYuMjYtMy42NTEtMS45NzQtMS4xNTEtMy45NzEgMi4zMTZhLjYyNS42MjUgMCAwIDEtLjYzIDBsLTMuOTctMi4zMTZMMy43NCAxMy43NVoiIGNsaXAtcnVsZT0iZXZlbm9kZCIvPjxwYXRoIGZpbGw9IiNmZmYiIGZpbGwtcnVsZT0iZXZlbm9kZCIgZD0iTTUuNCA3LjU4NWEuNjI1LjYyNSAwIDAgMSAuNjMgMEwxMCA5LjkwMWwzLjk3LTIuMzE2YS42MjUuNjI1IDAgMCAxIC42MyAwbDMuMjE1IDEuODc1YS42MjUuNjI1IDAgMCAxIDAgMS4wOGwtNy41IDQuMzc1YS42MjUuNjI1IDAgMCAxLS42MyAwbC03LjUtNC4zNzVhLjYyNS42MjUgMCAwIDEgMC0xLjA4TDUuNCA3LjU4NVpNMy43NCAxMCAxMCAxMy42NTEgMTYuMjYgMTBsLTEuOTc0LTEuMTUxLTMuOTcxIDIuMzE2YS42MjUuNjI1IDAgMCAxLS42MyAwbC0zLjk3LTIuMzE2TDMuNzQgMTBaIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiLz48L3N2Zz4=", ot = "data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgZmlsbD0ibm9uZSI+PHBhdGggZmlsbD0iI0VDNEU0MCIgZmlsbC1ydWxlPSJldmVub2RkIiBkPSJNOC4xMjUgMS4yNUExLjg3NSAxLjg3NSAwIDAgMCA2LjI1IDMuMTI1di42MjVIMy4xMjVhLjYyNS42MjUgMCAwIDAgMCAxLjI1aC42MjV2MTEuMjVBMS4yNSAxLjI1IDAgMCAwIDUgMTcuNWgxMGExLjI1IDEuMjUgMCAwIDAgMS4yNS0xLjI1VjVoLjYyNWEuNjI1LjYyNSAwIDAgMCAwLTEuMjVIMTMuNzV2LS42MjVhMS44NzUgMS44NzUgMCAwIDAtMS44NzUtMS44NzVoLTMuNzVabTQuMzc1IDIuNXYtLjYyNWEuNjI1LjYyNSAwIDAgMC0uNjI1LS42MjVoLTMuNzVhLjYyNS42MjUgMCAwIDAtLjYyNS42MjV2LjYyNWg1Wk01IDE2LjI1VjVoMTB2MTEuMjVINVpNOC4xMjUgNy41Yy4zNDUgMCAuNjI1LjI4LjYyNS42MjV2NWEuNjI1LjYyNSAwIDEgMS0xLjI1IDB2LTVjMC0uMzQ1LjI4LS42MjUuNjI1LS42MjVabTQuMzc1IDUuNjI1di01YS42MjUuNjI1IDAgMCAwLTEuMjUgMHY1YS42MjUuNjI1IDAgMSAwIDEuMjUgMFoiIGNsaXAtcnVsZT0iZXZlbm9kZCIvPjwvc3ZnPg==";
|
|
543
|
+
function ve(i, e, t, a, r, n, o) {
|
|
544
544
|
try {
|
|
545
|
-
var s = n
|
|
545
|
+
var s = i[n](o), c = s.value;
|
|
546
546
|
} catch (d) {
|
|
547
547
|
return void t(d);
|
|
548
548
|
}
|
|
549
549
|
s.done ? e(c) : Promise.resolve(c).then(a, r);
|
|
550
550
|
}
|
|
551
|
-
function st(
|
|
551
|
+
function st(i) {
|
|
552
552
|
return function() {
|
|
553
553
|
var e = this, t = arguments;
|
|
554
554
|
return new Promise(function(a, r) {
|
|
555
|
-
var
|
|
555
|
+
var n = i.apply(e, t);
|
|
556
556
|
function o(c) {
|
|
557
|
-
|
|
557
|
+
ve(n, a, r, o, s, "next", c);
|
|
558
558
|
}
|
|
559
559
|
function s(c) {
|
|
560
|
-
|
|
560
|
+
ve(n, a, r, o, s, "throw", c);
|
|
561
561
|
}
|
|
562
562
|
o(void 0);
|
|
563
563
|
});
|
|
@@ -626,81 +626,81 @@ const E = {
|
|
|
626
626
|
delete: ot,
|
|
627
627
|
lock: et,
|
|
628
628
|
unlock: tt,
|
|
629
|
-
bringToFront:
|
|
630
|
-
sendToBack:
|
|
629
|
+
bringToFront: nt,
|
|
630
|
+
sendToBack: it,
|
|
631
631
|
bringForward: at,
|
|
632
632
|
sendBackwards: rt
|
|
633
633
|
},
|
|
634
634
|
handlers: {
|
|
635
635
|
copyPaste: function() {
|
|
636
|
-
var
|
|
636
|
+
var i = st(function* (t) {
|
|
637
637
|
yield t.clipboardManager.copy(), yield t.clipboardManager.paste();
|
|
638
638
|
});
|
|
639
639
|
function e(t) {
|
|
640
|
-
return
|
|
640
|
+
return i.apply(this, arguments);
|
|
641
641
|
}
|
|
642
642
|
return e;
|
|
643
643
|
}(),
|
|
644
|
-
delete: (
|
|
645
|
-
|
|
644
|
+
delete: (i) => {
|
|
645
|
+
i.deletionManager.deleteSelectedObjects();
|
|
646
646
|
},
|
|
647
|
-
lock: (
|
|
648
|
-
|
|
647
|
+
lock: (i) => {
|
|
648
|
+
i.objectLockManager.lockObject();
|
|
649
649
|
},
|
|
650
|
-
unlock: (
|
|
651
|
-
|
|
650
|
+
unlock: (i) => {
|
|
651
|
+
i.objectLockManager.unlockObject();
|
|
652
652
|
},
|
|
653
|
-
bringForward: (
|
|
654
|
-
|
|
653
|
+
bringForward: (i) => {
|
|
654
|
+
i.layerManager.bringForward();
|
|
655
655
|
},
|
|
656
|
-
bringToFront: (
|
|
657
|
-
|
|
656
|
+
bringToFront: (i) => {
|
|
657
|
+
i.layerManager.bringToFront();
|
|
658
658
|
},
|
|
659
|
-
sendToBack: (
|
|
660
|
-
|
|
659
|
+
sendToBack: (i) => {
|
|
660
|
+
i.layerManager.sendToBack();
|
|
661
661
|
},
|
|
662
|
-
sendBackwards: (
|
|
663
|
-
|
|
662
|
+
sendBackwards: (i) => {
|
|
663
|
+
i.layerManager.sendBackwards();
|
|
664
664
|
}
|
|
665
665
|
}
|
|
666
666
|
};
|
|
667
|
-
function
|
|
668
|
-
var t = Object.keys(
|
|
667
|
+
function me(i, e) {
|
|
668
|
+
var t = Object.keys(i);
|
|
669
669
|
if (Object.getOwnPropertySymbols) {
|
|
670
|
-
var a = Object.getOwnPropertySymbols(
|
|
670
|
+
var a = Object.getOwnPropertySymbols(i);
|
|
671
671
|
e && (a = a.filter(function(r) {
|
|
672
|
-
return Object.getOwnPropertyDescriptor(
|
|
672
|
+
return Object.getOwnPropertyDescriptor(i, r).enumerable;
|
|
673
673
|
})), t.push.apply(t, a);
|
|
674
674
|
}
|
|
675
675
|
return t;
|
|
676
676
|
}
|
|
677
|
-
function M(
|
|
677
|
+
function M(i) {
|
|
678
678
|
for (var e = 1; e < arguments.length; e++) {
|
|
679
679
|
var t = arguments[e] != null ? arguments[e] : {};
|
|
680
|
-
e % 2 ?
|
|
681
|
-
ct(
|
|
682
|
-
}) : Object.getOwnPropertyDescriptors ? Object.defineProperties(
|
|
683
|
-
Object.defineProperty(
|
|
680
|
+
e % 2 ? me(Object(t), !0).forEach(function(a) {
|
|
681
|
+
ct(i, a, t[a]);
|
|
682
|
+
}) : Object.getOwnPropertyDescriptors ? Object.defineProperties(i, Object.getOwnPropertyDescriptors(t)) : me(Object(t)).forEach(function(a) {
|
|
683
|
+
Object.defineProperty(i, a, Object.getOwnPropertyDescriptor(t, a));
|
|
684
684
|
});
|
|
685
685
|
}
|
|
686
|
-
return
|
|
686
|
+
return i;
|
|
687
687
|
}
|
|
688
|
-
function ct(
|
|
689
|
-
return (e = ut(e)) in
|
|
688
|
+
function ct(i, e, t) {
|
|
689
|
+
return (e = ut(e)) in i ? Object.defineProperty(i, e, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : i[e] = t, i;
|
|
690
690
|
}
|
|
691
|
-
function ut(
|
|
692
|
-
var e = dt(
|
|
691
|
+
function ut(i) {
|
|
692
|
+
var e = dt(i, "string");
|
|
693
693
|
return typeof e == "symbol" ? e : e + "";
|
|
694
694
|
}
|
|
695
|
-
function dt(
|
|
696
|
-
if (typeof
|
|
697
|
-
var t =
|
|
695
|
+
function dt(i, e) {
|
|
696
|
+
if (typeof i != "object" || !i) return i;
|
|
697
|
+
var t = i[Symbol.toPrimitive];
|
|
698
698
|
if (t !== void 0) {
|
|
699
|
-
var a = t.call(
|
|
699
|
+
var a = t.call(i, e);
|
|
700
700
|
if (typeof a != "object") return a;
|
|
701
701
|
throw new TypeError("@@toPrimitive must return a primitive value.");
|
|
702
702
|
}
|
|
703
|
-
return (e === "string" ? String : Number)(
|
|
703
|
+
return (e === "string" ? String : Number)(i);
|
|
704
704
|
}
|
|
705
705
|
class lt {
|
|
706
706
|
/**
|
|
@@ -760,8 +760,8 @@ class lt {
|
|
|
760
760
|
handlers: l
|
|
761
761
|
} = t.config, u = document.createElement("button");
|
|
762
762
|
u.innerHTML = c[s] ? '<img src="'.concat(c[s], '" title="').concat(o, '" />') : o, Object.assign(u.style, d), u.onclick = () => {
|
|
763
|
-
var
|
|
764
|
-
return (
|
|
763
|
+
var h;
|
|
764
|
+
return (h = l[s]) === null || h === void 0 ? void 0 : h.call(l, t.editor);
|
|
765
765
|
}, t.el.appendChild(u);
|
|
766
766
|
};
|
|
767
767
|
for (var r of e)
|
|
@@ -834,15 +834,15 @@ class lt {
|
|
|
834
834
|
canvas: r
|
|
835
835
|
} = this;
|
|
836
836
|
e.setCoords();
|
|
837
|
-
var
|
|
837
|
+
var n = r.getZoom(), [, , , , o, s] = r.viewportTransform, {
|
|
838
838
|
x: c
|
|
839
839
|
} = e.getCenterPoint(), {
|
|
840
840
|
top: d,
|
|
841
841
|
height: l
|
|
842
|
-
} = e.getBoundingRect(!1, !0), u = c *
|
|
842
|
+
} = e.getBoundingRect(!1, !0), u = c * n + o, h = u - t.offsetWidth / 2, g = (d + l) * n + s + a.offsetTop;
|
|
843
843
|
Object.assign(t.style, {
|
|
844
|
-
left: "".concat(
|
|
845
|
-
top: "".concat(
|
|
844
|
+
left: "".concat(h, "px"),
|
|
845
|
+
top: "".concat(g, "px"),
|
|
846
846
|
display: "flex"
|
|
847
847
|
});
|
|
848
848
|
}
|
|
@@ -854,30 +854,30 @@ class lt {
|
|
|
854
854
|
this.el.removeEventListener("mouseover", this._onBtnOver), this.el.removeEventListener("mouseout", this._onBtnOut), this.canvas.off("mouse:down", this._onMouseDown), this.canvas.off("object:moving", this._onObjectMoving), this.canvas.off("object:scaling", this._onObjectScaling), this.canvas.off("object:rotating", this._onObjectRotating), this.canvas.off("mouse:up", this._onMouseUp), this.canvas.off("object:modified", this._onObjectModified), this.canvas.off("selection:created", this._onSelectionChange), this.canvas.off("selection:updated", this._onSelectionChange), this.canvas.off("selection:changed", this._onSelectionChange), this.canvas.off("after:render", this._onSelectionChange), this.canvas.off("selection:cleared", this._onSelectionClear), this.el.remove();
|
|
855
855
|
}
|
|
856
856
|
}
|
|
857
|
-
function
|
|
857
|
+
function fe(i, e, t, a, r, n, o) {
|
|
858
858
|
try {
|
|
859
|
-
var s = n
|
|
859
|
+
var s = i[n](o), c = s.value;
|
|
860
860
|
} catch (d) {
|
|
861
861
|
return void t(d);
|
|
862
862
|
}
|
|
863
863
|
s.done ? e(c) : Promise.resolve(c).then(a, r);
|
|
864
864
|
}
|
|
865
|
-
function
|
|
865
|
+
function V(i) {
|
|
866
866
|
return function() {
|
|
867
867
|
var e = this, t = arguments;
|
|
868
868
|
return new Promise(function(a, r) {
|
|
869
|
-
var
|
|
869
|
+
var n = i.apply(e, t);
|
|
870
870
|
function o(c) {
|
|
871
|
-
|
|
871
|
+
fe(n, a, r, o, s, "next", c);
|
|
872
872
|
}
|
|
873
873
|
function s(c) {
|
|
874
|
-
|
|
874
|
+
fe(n, a, r, o, s, "throw", c);
|
|
875
875
|
}
|
|
876
876
|
o(void 0);
|
|
877
877
|
});
|
|
878
878
|
};
|
|
879
879
|
}
|
|
880
|
-
class
|
|
880
|
+
class ht {
|
|
881
881
|
/**
|
|
882
882
|
* @param {object} options
|
|
883
883
|
* @param {ImageEditor} options.editor - экземпляр редактора с доступом к canvas
|
|
@@ -893,7 +893,7 @@ class gt {
|
|
|
893
893
|
return this._historySuspendCount > 0;
|
|
894
894
|
}
|
|
895
895
|
_createDiffPatcher() {
|
|
896
|
-
this.diffPatcher =
|
|
896
|
+
this.diffPatcher = Ye({
|
|
897
897
|
objectHash(e) {
|
|
898
898
|
return [e.id, e.format, e.locked, e.left, e.top, e.width, e.height, e.flipX, e.flipY, e.scaleX, e.scaleY, e.angle, e.opacity].join("-");
|
|
899
899
|
},
|
|
@@ -922,8 +922,8 @@ class gt {
|
|
|
922
922
|
baseState: e,
|
|
923
923
|
currentIndex: t,
|
|
924
924
|
patches: a
|
|
925
|
-
} = this, r = JSON.parse(JSON.stringify(e)),
|
|
926
|
-
r = this.diffPatcher.patch(r, a[
|
|
925
|
+
} = this, r = JSON.parse(JSON.stringify(e)), n = 0; n < t; n += 1)
|
|
926
|
+
r = this.diffPatcher.patch(r, a[n]);
|
|
927
927
|
return console.log("getFullState state", r), r;
|
|
928
928
|
}
|
|
929
929
|
/**
|
|
@@ -952,12 +952,12 @@ class gt {
|
|
|
952
952
|
*/
|
|
953
953
|
loadStateFromFullState(e) {
|
|
954
954
|
var t = this;
|
|
955
|
-
return
|
|
955
|
+
return V(function* () {
|
|
956
956
|
if (e) {
|
|
957
957
|
console.log("loadStateFromFullState fullState", e), yield t.canvas.loadFromJSON(e);
|
|
958
|
-
var a = t.canvas.getObjects().find((
|
|
958
|
+
var a = t.canvas.getObjects().find((n) => n.id === "montage-area");
|
|
959
959
|
a && (t.editor.montageArea = a);
|
|
960
|
-
var r = t.canvas.getObjects().find((
|
|
960
|
+
var r = t.canvas.getObjects().find((n) => n.id === "overlay-mask");
|
|
961
961
|
r && (t.editor.interactionBlocker.overlayMask = r, t.editor.interactionBlocker.overlayMask.visible = !1), t.canvas.renderAll(), t.canvas.fire("editor:history-state-loaded");
|
|
962
962
|
}
|
|
963
963
|
})();
|
|
@@ -968,7 +968,7 @@ class gt {
|
|
|
968
968
|
*/
|
|
969
969
|
undo() {
|
|
970
970
|
var e = this;
|
|
971
|
-
return
|
|
971
|
+
return V(function* () {
|
|
972
972
|
if (!e.skipHistory) {
|
|
973
973
|
if (e.currentIndex <= 0) {
|
|
974
974
|
console.log("Нет предыдущих состояний для отмены.");
|
|
@@ -995,7 +995,7 @@ class gt {
|
|
|
995
995
|
*/
|
|
996
996
|
redo() {
|
|
997
997
|
var e = this;
|
|
998
|
-
return
|
|
998
|
+
return V(function* () {
|
|
999
999
|
if (!e.skipHistory) {
|
|
1000
1000
|
if (e.currentIndex >= e.patches.length) {
|
|
1001
1001
|
console.log("Нет состояний для повтора.");
|
|
@@ -1017,47 +1017,47 @@ class gt {
|
|
|
1017
1017
|
})();
|
|
1018
1018
|
}
|
|
1019
1019
|
}
|
|
1020
|
-
function
|
|
1020
|
+
function Y(i) {
|
|
1021
1021
|
var {
|
|
1022
1022
|
montageArea: e,
|
|
1023
1023
|
imageObject: t,
|
|
1024
1024
|
scaleType: a = "contain"
|
|
1025
|
-
} =
|
|
1025
|
+
} = i;
|
|
1026
1026
|
if (!e || !t) return 1;
|
|
1027
|
-
var r = e.width,
|
|
1027
|
+
var r = e.width, n = e.height, {
|
|
1028
1028
|
width: o,
|
|
1029
1029
|
height: s
|
|
1030
1030
|
} = t;
|
|
1031
|
-
return a === "contain" || a === "image-contain" ? Math.min(r / o,
|
|
1031
|
+
return a === "contain" || a === "image-contain" ? Math.min(r / o, n / s) : a === "cover" || a === "image-cover" ? Math.max(r / o, n / s) : 1;
|
|
1032
1032
|
}
|
|
1033
|
-
function
|
|
1034
|
-
var
|
|
1035
|
-
|
|
1036
|
-
var e =
|
|
1037
|
-
return e.fillStyle = "#ddd", e.fillRect(0, 0, 40, 40), e.fillStyle = "#ccc", e.fillRect(0, 0, 10, 10), e.fillRect(10, 10, 10, 10), new
|
|
1038
|
-
source:
|
|
1033
|
+
function gt() {
|
|
1034
|
+
var i = document.createElement("canvas");
|
|
1035
|
+
i.width = 20, i.height = 20;
|
|
1036
|
+
var e = i.getContext("2d");
|
|
1037
|
+
return e.fillStyle = "#ddd", e.fillRect(0, 0, 40, 40), e.fillStyle = "#ccc", e.fillRect(0, 0, 10, 10), e.fillRect(10, 10, 10, 10), new Ee({
|
|
1038
|
+
source: i,
|
|
1039
1039
|
repeat: "repeat"
|
|
1040
1040
|
});
|
|
1041
1041
|
}
|
|
1042
|
-
var vt = 0.1, mt = 2, ft = 0.1, Mt = 90,
|
|
1043
|
-
function
|
|
1042
|
+
var vt = 0.1, mt = 2, ft = 0.1, Mt = 90, k = 16, x = 16, D = 4096, C = 4096;
|
|
1043
|
+
function Me(i, e, t, a, r, n, o) {
|
|
1044
1044
|
try {
|
|
1045
|
-
var s = n
|
|
1045
|
+
var s = i[n](o), c = s.value;
|
|
1046
1046
|
} catch (d) {
|
|
1047
1047
|
return void t(d);
|
|
1048
1048
|
}
|
|
1049
1049
|
s.done ? e(c) : Promise.resolve(c).then(a, r);
|
|
1050
1050
|
}
|
|
1051
|
-
function
|
|
1051
|
+
function P(i) {
|
|
1052
1052
|
return function() {
|
|
1053
1053
|
var e = this, t = arguments;
|
|
1054
1054
|
return new Promise(function(a, r) {
|
|
1055
|
-
var
|
|
1055
|
+
var n = i.apply(e, t);
|
|
1056
1056
|
function o(c) {
|
|
1057
|
-
|
|
1057
|
+
Me(n, a, r, o, s, "next", c);
|
|
1058
1058
|
}
|
|
1059
1059
|
function s(c) {
|
|
1060
|
-
|
|
1060
|
+
Me(n, a, r, o, s, "throw", c);
|
|
1061
1061
|
}
|
|
1062
1062
|
o(void 0);
|
|
1063
1063
|
});
|
|
@@ -1087,11 +1087,11 @@ class L {
|
|
|
1087
1087
|
*/
|
|
1088
1088
|
importImage(e) {
|
|
1089
1089
|
var t = this;
|
|
1090
|
-
return
|
|
1090
|
+
return P(function* () {
|
|
1091
1091
|
var {
|
|
1092
1092
|
source: a,
|
|
1093
1093
|
scale: r = "image-".concat(t.options.scaleType),
|
|
1094
|
-
withoutSave:
|
|
1094
|
+
withoutSave: n = !1,
|
|
1095
1095
|
contentType: o = "image/png"
|
|
1096
1096
|
} = e;
|
|
1097
1097
|
if (a) {
|
|
@@ -1103,13 +1103,13 @@ class L {
|
|
|
1103
1103
|
} = t.editor;
|
|
1104
1104
|
l.suspendHistory();
|
|
1105
1105
|
try {
|
|
1106
|
-
var u,
|
|
1106
|
+
var u, h;
|
|
1107
1107
|
if (a instanceof File)
|
|
1108
1108
|
u = URL.createObjectURL(a);
|
|
1109
1109
|
else if (typeof a == "string") {
|
|
1110
|
-
var
|
|
1110
|
+
var g = yield fetch(a, {
|
|
1111
1111
|
mode: "cors"
|
|
1112
|
-
}), f = yield
|
|
1112
|
+
}), f = yield g.blob({
|
|
1113
1113
|
type: o,
|
|
1114
1114
|
quality: 1
|
|
1115
1115
|
});
|
|
@@ -1119,48 +1119,47 @@ class L {
|
|
|
1119
1119
|
t._createdBlobUrls.push(u);
|
|
1120
1120
|
var v = L.getFormatFromContentType(o);
|
|
1121
1121
|
if (v === "svg") {
|
|
1122
|
-
var j = yield
|
|
1123
|
-
|
|
1122
|
+
var j = yield ke(u);
|
|
1123
|
+
h = z.groupSVGElements(j.objects, j.options);
|
|
1124
1124
|
} else
|
|
1125
|
-
|
|
1125
|
+
h = yield de.fromURL(u, {
|
|
1126
1126
|
crossOrigin: "anonymous"
|
|
1127
1127
|
});
|
|
1128
|
-
g.set("id", "".concat(g.type, "-").concat(p())), g.set("format", v);
|
|
1129
1128
|
var {
|
|
1130
1129
|
width: m,
|
|
1131
|
-
height:
|
|
1132
|
-
} =
|
|
1133
|
-
if (
|
|
1134
|
-
var y = yield t.resizeImageToBoundaries(
|
|
1135
|
-
t._createdBlobUrls.push(
|
|
1130
|
+
height: b
|
|
1131
|
+
} = h;
|
|
1132
|
+
if (b > C || m > D) {
|
|
1133
|
+
var y = yield t.resizeImageToBoundaries(h._element.src, "max"), S = URL.createObjectURL(y);
|
|
1134
|
+
t._createdBlobUrls.push(S), h = yield de.fromURL(S, {
|
|
1136
1135
|
crossOrigin: "anonymous"
|
|
1137
1136
|
});
|
|
1138
1137
|
}
|
|
1139
|
-
if (r === "scale-montage")
|
|
1138
|
+
if (h.set("id", "".concat(h.type, "-").concat(I())), h.set("format", v), r === "scale-montage")
|
|
1140
1139
|
t.editor.canvasManager.scaleMontageAreaToImage({
|
|
1141
|
-
object:
|
|
1140
|
+
object: h,
|
|
1142
1141
|
withoutSave: !0
|
|
1143
1142
|
});
|
|
1144
1143
|
else {
|
|
1145
1144
|
var {
|
|
1146
1145
|
width: O,
|
|
1147
1146
|
height: A
|
|
1148
|
-
} = c,
|
|
1147
|
+
} = c, w = Y({
|
|
1149
1148
|
montageArea: c,
|
|
1150
|
-
imageObject:
|
|
1149
|
+
imageObject: h,
|
|
1151
1150
|
scaleType: r
|
|
1152
1151
|
});
|
|
1153
|
-
r === "image-contain" &&
|
|
1154
|
-
object:
|
|
1152
|
+
r === "image-contain" && w < 1 ? d.fitObject({
|
|
1153
|
+
object: h,
|
|
1155
1154
|
type: "contain",
|
|
1156
1155
|
withoutSave: !0
|
|
1157
|
-
}) : r === "image-cover" && (m > O ||
|
|
1158
|
-
object:
|
|
1156
|
+
}) : r === "image-cover" && (m > O || b > A) && d.fitObject({
|
|
1157
|
+
object: h,
|
|
1159
1158
|
type: "cover",
|
|
1160
1159
|
withoutSave: !0
|
|
1161
1160
|
});
|
|
1162
1161
|
}
|
|
1163
|
-
s.add(
|
|
1162
|
+
s.add(h), s.centerObject(h), s.setActiveObject(h), s.renderAll(), l.resumeHistory(), n || l.saveState();
|
|
1164
1163
|
} catch (T) {
|
|
1165
1164
|
console.error("importImage. Ошибка импорта изображения: ", T), s.fire("editor:error", {
|
|
1166
1165
|
message: "Ошибка импорта изображения: ".concat(T.message)
|
|
@@ -1179,15 +1178,15 @@ class L {
|
|
|
1179
1178
|
*/
|
|
1180
1179
|
resizeImageToBoundaries(e) {
|
|
1181
1180
|
var t = arguments, a = this;
|
|
1182
|
-
return
|
|
1183
|
-
var r = t.length > 1 && t[1] !== void 0 ? t[1] : "max",
|
|
1184
|
-
console.warn("importImage. ".concat(
|
|
1185
|
-
message:
|
|
1181
|
+
return P(function* () {
|
|
1182
|
+
var r = t.length > 1 && t[1] !== void 0 ? t[1] : "max", n = "Размер изображения больше максимального размера канваса, поэтому оно будет уменьшено до максимальных размеров: ".concat(D, "x").concat(C);
|
|
1183
|
+
console.warn("importImage. ".concat(n)), a.editor.canvas.fire("editor:warning", {
|
|
1184
|
+
message: n
|
|
1186
1185
|
});
|
|
1187
1186
|
var o = yield a.editor.workerManager.post("resizeImage", {
|
|
1188
1187
|
dataURL: e,
|
|
1189
|
-
maxWidth:
|
|
1190
|
-
maxHeight:
|
|
1188
|
+
maxWidth: D,
|
|
1189
|
+
maxHeight: C,
|
|
1191
1190
|
sizeType: r
|
|
1192
1191
|
});
|
|
1193
1192
|
return o;
|
|
@@ -1206,38 +1205,38 @@ class L {
|
|
|
1206
1205
|
*/
|
|
1207
1206
|
exportCanvasAsImageFile() {
|
|
1208
1207
|
var e = arguments, t = this;
|
|
1209
|
-
return
|
|
1208
|
+
return P(function* () {
|
|
1210
1209
|
var {
|
|
1211
1210
|
fileName: a = "image.png",
|
|
1212
1211
|
contentType: r = "image/png",
|
|
1213
|
-
exportAsBase64:
|
|
1212
|
+
exportAsBase64: n = !1,
|
|
1214
1213
|
exportAsBlob: o = !1
|
|
1215
1214
|
} = e.length > 0 && e[0] !== void 0 ? e[0] : {}, {
|
|
1216
1215
|
canvas: s,
|
|
1217
1216
|
montageArea: c,
|
|
1218
1217
|
workerManager: d
|
|
1219
|
-
} = t.editor, l = r === "application/pdf", u = l ? "image/jpg" : r,
|
|
1218
|
+
} = t.editor, l = r === "application/pdf", u = l ? "image/jpg" : r, h = L.getFormatFromContentType(u);
|
|
1220
1219
|
c.setCoords();
|
|
1221
1220
|
var {
|
|
1222
|
-
left:
|
|
1221
|
+
left: g,
|
|
1223
1222
|
top: f,
|
|
1224
1223
|
width: v,
|
|
1225
1224
|
height: j
|
|
1226
1225
|
} = c.getBoundingRect(), m = yield s.clone(["id", "format", "locked"]);
|
|
1227
1226
|
["image/jpg", "image/jpeg"].includes(u) && (m.backgroundColor = "#ffffff");
|
|
1228
|
-
var
|
|
1229
|
-
|
|
1227
|
+
var b = m.getObjects().find((N) => N.id === c.id);
|
|
1228
|
+
b.visible = !1, m.viewportTransform = [1, 0, 0, 1, -g, -f], m.setDimensions({
|
|
1230
1229
|
width: v,
|
|
1231
1230
|
height: j
|
|
1232
1231
|
}, {
|
|
1233
1232
|
backstoreOnly: !0
|
|
1234
1233
|
}), m.renderAll();
|
|
1235
|
-
var y = m.getObjects().filter((
|
|
1236
|
-
if (
|
|
1237
|
-
var
|
|
1234
|
+
var y = m.getObjects().filter((N) => N.format).every((N) => N.format === "svg");
|
|
1235
|
+
if (h === "svg" && y) {
|
|
1236
|
+
var S = m.toSVG();
|
|
1238
1237
|
m.dispose();
|
|
1239
|
-
var O = L._exportSVGStringAsFile(
|
|
1240
|
-
exportAsBase64:
|
|
1238
|
+
var O = L._exportSVGStringAsFile(S, {
|
|
1239
|
+
exportAsBase64: n,
|
|
1241
1240
|
exportAsBlob: o,
|
|
1242
1241
|
fileName: a
|
|
1243
1242
|
}), A = {
|
|
@@ -1248,66 +1247,66 @@ class L {
|
|
|
1248
1247
|
};
|
|
1249
1248
|
return s.fire("editor:canvas-exported", A), A;
|
|
1250
1249
|
}
|
|
1251
|
-
var
|
|
1252
|
-
m.getElement().toBlob(
|
|
1250
|
+
var w = yield new Promise((N) => {
|
|
1251
|
+
m.getElement().toBlob(N);
|
|
1253
1252
|
});
|
|
1254
1253
|
if (m.dispose(), o) {
|
|
1255
1254
|
var T = {
|
|
1256
|
-
image:
|
|
1257
|
-
format:
|
|
1255
|
+
image: w,
|
|
1256
|
+
format: h,
|
|
1258
1257
|
contentType: u,
|
|
1259
1258
|
fileName: a
|
|
1260
1259
|
};
|
|
1261
1260
|
return s.fire("editor:canvas-exported", T), T;
|
|
1262
1261
|
}
|
|
1263
|
-
var
|
|
1264
|
-
format:
|
|
1262
|
+
var ae = yield createImageBitmap(w), re = yield d.post("toDataURL", {
|
|
1263
|
+
format: h,
|
|
1265
1264
|
quality: 1,
|
|
1266
|
-
bitmap:
|
|
1267
|
-
}, [
|
|
1265
|
+
bitmap: ae
|
|
1266
|
+
}, [ae]);
|
|
1268
1267
|
if (l) {
|
|
1269
|
-
var
|
|
1270
|
-
orientation:
|
|
1268
|
+
var ne = 0.264583, W = v * ne, _ = j * ne, we = (yield t.editor.moduleLoader.loadModule("jspdf")).jsPDF, R = new we({
|
|
1269
|
+
orientation: W > _ ? "landscape" : "portrait",
|
|
1271
1270
|
unit: "mm",
|
|
1272
|
-
format: [
|
|
1271
|
+
format: [W, _]
|
|
1273
1272
|
});
|
|
1274
|
-
if (
|
|
1275
|
-
var
|
|
1276
|
-
image:
|
|
1273
|
+
if (R.addImage(re, "JPG", 0, 0, W, _), n) {
|
|
1274
|
+
var Ne = R.output("datauristring"), ie = {
|
|
1275
|
+
image: Ne,
|
|
1277
1276
|
format: "pdf",
|
|
1278
1277
|
contentType: "application/pdf",
|
|
1279
1278
|
fileName: a
|
|
1280
1279
|
};
|
|
1281
1280
|
return s.fire("editor:canvas-exported", ie), ie;
|
|
1282
1281
|
}
|
|
1283
|
-
var
|
|
1282
|
+
var De = R.output("blob"), Ce = new File([De], a, {
|
|
1284
1283
|
type: "application/pdf"
|
|
1285
|
-
}),
|
|
1286
|
-
image:
|
|
1284
|
+
}), oe = {
|
|
1285
|
+
image: Ce,
|
|
1287
1286
|
format: "pdf",
|
|
1288
1287
|
contentType: "application/pdf",
|
|
1289
1288
|
fileName: a
|
|
1290
1289
|
};
|
|
1291
|
-
return s.fire("editor:canvas-exported",
|
|
1290
|
+
return s.fire("editor:canvas-exported", oe), oe;
|
|
1292
1291
|
}
|
|
1293
|
-
if (
|
|
1294
|
-
var
|
|
1295
|
-
image:
|
|
1296
|
-
format:
|
|
1292
|
+
if (n) {
|
|
1293
|
+
var se = {
|
|
1294
|
+
image: re,
|
|
1295
|
+
format: h,
|
|
1297
1296
|
contentType: u,
|
|
1298
1297
|
fileName: a
|
|
1299
1298
|
};
|
|
1300
|
-
return s.fire("editor:canvas-exported",
|
|
1299
|
+
return s.fire("editor:canvas-exported", se), se;
|
|
1301
1300
|
}
|
|
1302
|
-
var
|
|
1301
|
+
var ce = h === "svg" && !y ? a.replace(/\.[^/.]+$/, ".png") : a, Le = new File([w], ce, {
|
|
1303
1302
|
type: u
|
|
1304
|
-
}),
|
|
1305
|
-
image:
|
|
1306
|
-
format:
|
|
1303
|
+
}), ue = {
|
|
1304
|
+
image: Le,
|
|
1305
|
+
format: h,
|
|
1307
1306
|
contentType: u,
|
|
1308
|
-
fileName:
|
|
1307
|
+
fileName: ce
|
|
1309
1308
|
};
|
|
1310
|
-
return s.fire("editor:canvas-exported",
|
|
1309
|
+
return s.fire("editor:canvas-exported", ue), ue;
|
|
1311
1310
|
})();
|
|
1312
1311
|
}
|
|
1313
1312
|
/**
|
|
@@ -1323,11 +1322,11 @@ class L {
|
|
|
1323
1322
|
*/
|
|
1324
1323
|
exportObjectAsImageFile() {
|
|
1325
1324
|
var e = arguments, t = this;
|
|
1326
|
-
return
|
|
1325
|
+
return P(function* () {
|
|
1327
1326
|
var {
|
|
1328
1327
|
object: a,
|
|
1329
1328
|
fileName: r = "image.png",
|
|
1330
|
-
contentType:
|
|
1329
|
+
contentType: n = "image/png",
|
|
1331
1330
|
exportAsBase64: o = !1,
|
|
1332
1331
|
exportAsBlob: s = !1
|
|
1333
1332
|
} = e.length > 0 && e[0] !== void 0 ? e[0] : {}, {
|
|
@@ -1338,14 +1337,14 @@ class L {
|
|
|
1338
1337
|
return console.error("exportObjectAsDataURL. Не выбран объект"), c.fire("editor:error", {
|
|
1339
1338
|
message: "Не выбран объект для экспорта"
|
|
1340
1339
|
}), "";
|
|
1341
|
-
var u = L.getFormatFromContentType(
|
|
1340
|
+
var u = L.getFormatFromContentType(n);
|
|
1342
1341
|
if (u === "svg") {
|
|
1343
|
-
var
|
|
1342
|
+
var h = l.toSVG(), g = t._exportSVGStringAsFile(h, {
|
|
1344
1343
|
exportAsBase64: o,
|
|
1345
1344
|
exportAsBlob: s,
|
|
1346
1345
|
fileName: r
|
|
1347
1346
|
}), f = {
|
|
1348
|
-
image:
|
|
1347
|
+
image: g,
|
|
1349
1348
|
format: u,
|
|
1350
1349
|
contentType: "image/svg+xml",
|
|
1351
1350
|
fileName: r.replace(/\.[^/.]+$/, ".svg")
|
|
@@ -1360,29 +1359,29 @@ class L {
|
|
|
1360
1359
|
}, [v]), m = {
|
|
1361
1360
|
image: j,
|
|
1362
1361
|
format: u,
|
|
1363
|
-
contentType:
|
|
1362
|
+
contentType: n,
|
|
1364
1363
|
fileName: r
|
|
1365
1364
|
};
|
|
1366
1365
|
return c.fire("editor:object-exported", m), m;
|
|
1367
1366
|
}
|
|
1368
|
-
var
|
|
1369
|
-
|
|
1367
|
+
var b = l.toCanvasElement(), y = yield new Promise((w) => {
|
|
1368
|
+
b.toBlob(w);
|
|
1370
1369
|
});
|
|
1371
1370
|
if (s) {
|
|
1372
|
-
var
|
|
1371
|
+
var S = {
|
|
1373
1372
|
image: y,
|
|
1374
1373
|
format: u,
|
|
1375
|
-
contentType:
|
|
1374
|
+
contentType: n,
|
|
1376
1375
|
fileName: r
|
|
1377
1376
|
};
|
|
1378
|
-
return c.fire("editor:object-exported",
|
|
1377
|
+
return c.fire("editor:object-exported", S), S;
|
|
1379
1378
|
}
|
|
1380
1379
|
var O = new File([y], r, {
|
|
1381
|
-
type:
|
|
1380
|
+
type: n
|
|
1382
1381
|
}), A = {
|
|
1383
1382
|
image: O,
|
|
1384
1383
|
format: u,
|
|
1385
|
-
contentType:
|
|
1384
|
+
contentType: n,
|
|
1386
1385
|
fileName: r
|
|
1387
1386
|
};
|
|
1388
1387
|
return c.fire("editor:object-exported", A), A;
|
|
@@ -1457,7 +1456,7 @@ class jt {
|
|
|
1457
1456
|
} = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};
|
|
1458
1457
|
if (e) {
|
|
1459
1458
|
var {
|
|
1460
|
-
canvas:
|
|
1459
|
+
canvas: n,
|
|
1461
1460
|
montageArea: o,
|
|
1462
1461
|
options: {
|
|
1463
1462
|
canvasBackstoreWidth: s
|
|
@@ -1465,21 +1464,21 @@ class jt {
|
|
|
1465
1464
|
} = this.editor, {
|
|
1466
1465
|
width: c,
|
|
1467
1466
|
height: d
|
|
1468
|
-
} = o, l = Number(Math.max(Math.min(e,
|
|
1467
|
+
} = o, l = Number(Math.max(Math.min(e, D), k));
|
|
1469
1468
|
if (!s || s === "auto" || r ? this.adaptCanvasToContainer() : s ? this.setCanvasBackstoreWidth(s) : this.setCanvasBackstoreWidth(l), o.set({
|
|
1470
1469
|
width: l
|
|
1471
|
-
}),
|
|
1470
|
+
}), n.clipPath.set({
|
|
1472
1471
|
width: l
|
|
1473
1472
|
}), t) {
|
|
1474
|
-
var u = l / c,
|
|
1475
|
-
this.setResolutionHeight(
|
|
1473
|
+
var u = l / c, h = d * u;
|
|
1474
|
+
this.setResolutionHeight(h);
|
|
1476
1475
|
return;
|
|
1477
1476
|
}
|
|
1478
1477
|
var {
|
|
1479
|
-
left:
|
|
1478
|
+
left: g,
|
|
1480
1479
|
top: f
|
|
1481
|
-
} = this.getObjectDefaultCoords(o), v =
|
|
1482
|
-
|
|
1480
|
+
} = this.getObjectDefaultCoords(o), v = n.getZoom();
|
|
1481
|
+
n.setViewportTransform([v, 0, 0, v, g, f]), this.centerMontageArea(), a || this.editor.historyManager.saveState(), n == null || n.fire("editor:resolution-width-changed", {
|
|
1483
1482
|
width: e
|
|
1484
1483
|
});
|
|
1485
1484
|
}
|
|
@@ -1500,7 +1499,7 @@ class jt {
|
|
|
1500
1499
|
} = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};
|
|
1501
1500
|
if (e) {
|
|
1502
1501
|
var {
|
|
1503
|
-
canvas:
|
|
1502
|
+
canvas: n,
|
|
1504
1503
|
montageArea: o,
|
|
1505
1504
|
options: {
|
|
1506
1505
|
canvasBackstoreHeight: s
|
|
@@ -1508,21 +1507,21 @@ class jt {
|
|
|
1508
1507
|
} = this.editor, {
|
|
1509
1508
|
width: c,
|
|
1510
1509
|
height: d
|
|
1511
|
-
} = o, l = Number(Math.max(Math.min(e,
|
|
1510
|
+
} = o, l = Number(Math.max(Math.min(e, C), x));
|
|
1512
1511
|
if (!s || s === "auto" || r ? this.adaptCanvasToContainer() : s ? this.setCanvasBackstoreHeight(s) : this.setCanvasBackstoreHeight(l), o.set({
|
|
1513
1512
|
height: l
|
|
1514
|
-
}),
|
|
1513
|
+
}), n.clipPath.set({
|
|
1515
1514
|
height: l
|
|
1516
1515
|
}), t) {
|
|
1517
|
-
var u = l / d,
|
|
1518
|
-
this.setResolutionWidth(
|
|
1516
|
+
var u = l / d, h = c * u;
|
|
1517
|
+
this.setResolutionWidth(h);
|
|
1519
1518
|
return;
|
|
1520
1519
|
}
|
|
1521
1520
|
var {
|
|
1522
|
-
left:
|
|
1521
|
+
left: g,
|
|
1523
1522
|
top: f
|
|
1524
|
-
} = this.getObjectDefaultCoords(o), v =
|
|
1525
|
-
|
|
1523
|
+
} = this.getObjectDefaultCoords(o), v = n.getZoom();
|
|
1524
|
+
n.setViewportTransform([v, 0, 0, v, g, f]), this.centerMontageArea(), a || this.editor.historyManager.saveState(), n == null || n.fire("editor:resolution-height-changed", {
|
|
1526
1525
|
height: e
|
|
1527
1526
|
});
|
|
1528
1527
|
}
|
|
@@ -1535,7 +1534,7 @@ class jt {
|
|
|
1535
1534
|
var {
|
|
1536
1535
|
canvas: e,
|
|
1537
1536
|
montageArea: t
|
|
1538
|
-
} = this.editor, a = e.getWidth(), r = e.getHeight(),
|
|
1537
|
+
} = this.editor, a = e.getWidth(), r = e.getHeight(), n = e.getZoom(), o = new xe(a / 2, r / 2);
|
|
1539
1538
|
t.set({
|
|
1540
1539
|
left: a / 2,
|
|
1541
1540
|
top: r / 2
|
|
@@ -1544,7 +1543,7 @@ class jt {
|
|
|
1544
1543
|
top: r / 2
|
|
1545
1544
|
}), e.renderAll();
|
|
1546
1545
|
var s = e.viewportTransform;
|
|
1547
|
-
s[4] = a / 2 - o.x *
|
|
1546
|
+
s[4] = a / 2 - o.x * n, s[5] = r / 2 - o.y * n, e.setViewportTransform(s), e.renderAll();
|
|
1548
1547
|
}
|
|
1549
1548
|
/**
|
|
1550
1549
|
* Метод для получения координат объекта с учетом текущего зума
|
|
@@ -1561,8 +1560,8 @@ class jt {
|
|
|
1561
1560
|
}), {};
|
|
1562
1561
|
var {
|
|
1563
1562
|
width: r,
|
|
1564
|
-
height:
|
|
1565
|
-
} = a, o = t.getZoom(), s = (r - r * o) / 2, c = (
|
|
1563
|
+
height: n
|
|
1564
|
+
} = a, o = t.getZoom(), s = (r - r * o) / 2, c = (n - n * o) / 2;
|
|
1566
1565
|
return {
|
|
1567
1566
|
left: s,
|
|
1568
1567
|
top: c
|
|
@@ -1570,7 +1569,7 @@ class jt {
|
|
|
1570
1569
|
}
|
|
1571
1570
|
setCanvasBackstoreWidth(e) {
|
|
1572
1571
|
if (!(!e || typeof e != "number")) {
|
|
1573
|
-
var t = Math.max(Math.min(e,
|
|
1572
|
+
var t = Math.max(Math.min(e, D), k);
|
|
1574
1573
|
this.editor.canvas.setDimensions({
|
|
1575
1574
|
width: t
|
|
1576
1575
|
}, {
|
|
@@ -1580,7 +1579,7 @@ class jt {
|
|
|
1580
1579
|
}
|
|
1581
1580
|
setCanvasBackstoreHeight(e) {
|
|
1582
1581
|
if (!(!e || typeof e != "number")) {
|
|
1583
|
-
var t = Math.max(Math.min(e,
|
|
1582
|
+
var t = Math.max(Math.min(e, C), x);
|
|
1584
1583
|
this.editor.canvas.setDimensions({
|
|
1585
1584
|
height: t
|
|
1586
1585
|
}, {
|
|
@@ -1591,9 +1590,9 @@ class jt {
|
|
|
1591
1590
|
adaptCanvasToContainer() {
|
|
1592
1591
|
var {
|
|
1593
1592
|
canvas: e
|
|
1594
|
-
} = this.editor, t = e.editorContainer, a = t.clientWidth, r = t.clientHeight,
|
|
1595
|
-
console.log("adaptCanvasToContainer newWidth",
|
|
1596
|
-
width:
|
|
1593
|
+
} = this.editor, t = e.editorContainer, a = t.clientWidth, r = t.clientHeight, n = Math.max(Math.min(a, D), k), o = Math.max(Math.min(r, C), x);
|
|
1594
|
+
console.log("adaptCanvasToContainer newWidth", n), console.log("adaptCanvasToContainer newHeight", o), e.setDimensions({
|
|
1595
|
+
width: n,
|
|
1597
1596
|
height: o
|
|
1598
1597
|
}, {
|
|
1599
1598
|
backstoreOnly: !0
|
|
@@ -1690,7 +1689,7 @@ class jt {
|
|
|
1690
1689
|
var {
|
|
1691
1690
|
canvas: r,
|
|
1692
1691
|
options: {
|
|
1693
|
-
editorContainer:
|
|
1692
|
+
editorContainer: n
|
|
1694
1693
|
}
|
|
1695
1694
|
} = this.editor, o = [];
|
|
1696
1695
|
switch (e) {
|
|
@@ -1701,7 +1700,7 @@ class jt {
|
|
|
1701
1700
|
o.push(r.wrapperEl);
|
|
1702
1701
|
break;
|
|
1703
1702
|
case "container":
|
|
1704
|
-
o.push(
|
|
1703
|
+
o.push(n);
|
|
1705
1704
|
break;
|
|
1706
1705
|
default:
|
|
1707
1706
|
o.push(r.lowerCanvasEl, r.upperCanvasEl);
|
|
@@ -1740,7 +1739,7 @@ class jt {
|
|
|
1740
1739
|
withoutSave: a
|
|
1741
1740
|
} = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, {
|
|
1742
1741
|
canvas: r,
|
|
1743
|
-
montageArea:
|
|
1742
|
+
montageArea: n,
|
|
1744
1743
|
transformManager: o,
|
|
1745
1744
|
options: {
|
|
1746
1745
|
montageAreaWidth: s,
|
|
@@ -1752,28 +1751,28 @@ class jt {
|
|
|
1752
1751
|
width: l,
|
|
1753
1752
|
height: u
|
|
1754
1753
|
} = d;
|
|
1755
|
-
if (l <
|
|
1756
|
-
var
|
|
1757
|
-
console.warn("scaleMontageAreaToImage. ".concat(
|
|
1758
|
-
message:
|
|
1754
|
+
if (l < k || u < x) {
|
|
1755
|
+
var h = "Размер изображения меньше минимального размера канваса, поэтому оно будет растянуто до минимальных размеров: ".concat(k, "x").concat(x);
|
|
1756
|
+
console.warn("scaleMontageAreaToImage. ".concat(h)), r.fire("editor:warning", {
|
|
1757
|
+
message: h
|
|
1759
1758
|
});
|
|
1760
1759
|
}
|
|
1761
|
-
var
|
|
1760
|
+
var g = Math.min(l, D), f = Math.min(u, C);
|
|
1762
1761
|
if (t) {
|
|
1763
1762
|
var {
|
|
1764
1763
|
width: v,
|
|
1765
1764
|
height: j
|
|
1766
|
-
} =
|
|
1767
|
-
|
|
1765
|
+
} = n, m = l / v, b = u / j, y = Math.max(m, b);
|
|
1766
|
+
g = v * y, f = j * y;
|
|
1768
1767
|
}
|
|
1769
|
-
this.setResolutionWidth(
|
|
1768
|
+
this.setResolutionWidth(g, {
|
|
1770
1769
|
withoutSave: !0
|
|
1771
1770
|
}), this.setResolutionHeight(f, {
|
|
1772
1771
|
withoutSave: !0
|
|
1773
1772
|
}), (l > s || u > c) && o.calculateAndApplyDefaultZoom(s, c), o.resetObject(d, {
|
|
1774
1773
|
withoutSave: !0
|
|
1775
1774
|
}), r.centerObject(d), r.renderAll(), a || this.editor.historyManager.saveState(), r.fire("editor:canvas-scaled", {
|
|
1776
|
-
width:
|
|
1775
|
+
width: g,
|
|
1777
1776
|
height: f
|
|
1778
1777
|
});
|
|
1779
1778
|
}
|
|
@@ -1804,11 +1803,11 @@ class jt {
|
|
|
1804
1803
|
transformManager: a,
|
|
1805
1804
|
historyManager: r,
|
|
1806
1805
|
options: {
|
|
1807
|
-
montageAreaWidth:
|
|
1806
|
+
montageAreaWidth: n,
|
|
1808
1807
|
montageAreaHeight: o
|
|
1809
1808
|
}
|
|
1810
1809
|
} = this.editor;
|
|
1811
|
-
a.resetZoom(), this.setResolutionWidth(
|
|
1810
|
+
a.resetZoom(), this.setResolutionWidth(n, {
|
|
1812
1811
|
withoutSave: !0
|
|
1813
1812
|
}), this.setResolutionHeight(o, {
|
|
1814
1813
|
withoutSave: !0
|
|
@@ -1826,7 +1825,7 @@ class jt {
|
|
|
1826
1825
|
overlayMask: a
|
|
1827
1826
|
}
|
|
1828
1827
|
} = this.editor, r = e.getObjects();
|
|
1829
|
-
return r.filter((
|
|
1828
|
+
return r.filter((n) => n.id !== t.id && n.id !== a.id);
|
|
1830
1829
|
}
|
|
1831
1830
|
}
|
|
1832
1831
|
class yt {
|
|
@@ -1851,7 +1850,7 @@ class yt {
|
|
|
1851
1850
|
var e = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : this.options.montageAreaWidth, t = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : this.options.montageAreaHeight, {
|
|
1852
1851
|
width: a,
|
|
1853
1852
|
height: r
|
|
1854
|
-
} = this.editor.montageArea,
|
|
1853
|
+
} = this.editor.montageArea, n = e / a, o = t / r, s = Math.min(n, o), {
|
|
1855
1854
|
minZoom: c,
|
|
1856
1855
|
maxZoom: d,
|
|
1857
1856
|
maxZoomFactor: l
|
|
@@ -1871,15 +1870,15 @@ class yt {
|
|
|
1871
1870
|
var e, t, a = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : ft, r = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};
|
|
1872
1871
|
if (a) {
|
|
1873
1872
|
var {
|
|
1874
|
-
canvas:
|
|
1873
|
+
canvas: n,
|
|
1875
1874
|
minZoom: o,
|
|
1876
1875
|
maxZoom: s
|
|
1877
|
-
} = this.editor, c =
|
|
1878
|
-
u > s && (u = s), u < o && (u = o), console.log("currentZoom", c),
|
|
1876
|
+
} = this.editor, c = n.getZoom(), d = (e = r.pointX) !== null && e !== void 0 ? e : n.getWidth() / 2, l = (t = r.pointY) !== null && t !== void 0 ? t : n.getHeight() / 2, u = Number((c + Number(a)).toFixed(2));
|
|
1877
|
+
u > s && (u = s), u < o && (u = o), console.log("currentZoom", c), n.zoomToPoint({
|
|
1879
1878
|
x: Number(d),
|
|
1880
1879
|
y: Number(l)
|
|
1881
|
-
}, u),
|
|
1882
|
-
currentZoom:
|
|
1880
|
+
}, u), n.fire("editor:zoom-changed", {
|
|
1881
|
+
currentZoom: n.getZoom(),
|
|
1883
1882
|
zoom: u,
|
|
1884
1883
|
pointX: d,
|
|
1885
1884
|
pointY: l
|
|
@@ -1896,14 +1895,14 @@ class yt {
|
|
|
1896
1895
|
canvas: t,
|
|
1897
1896
|
minZoom: a,
|
|
1898
1897
|
maxZoom: r
|
|
1899
|
-
} = this.editor,
|
|
1898
|
+
} = this.editor, n = t.getWidth() / 2, o = t.getHeight() / 2, s = e;
|
|
1900
1899
|
e > r && (s = r), e < a && (s = a), t.zoomToPoint({
|
|
1901
|
-
x: Number(
|
|
1900
|
+
x: Number(n),
|
|
1902
1901
|
y: Number(o)
|
|
1903
1902
|
}, s), t.fire("editor:zoom-changed", {
|
|
1904
1903
|
currentZoom: t.getZoom(),
|
|
1905
1904
|
zoom: s,
|
|
1906
|
-
pointX:
|
|
1905
|
+
pointX: n,
|
|
1907
1906
|
pointY: o
|
|
1908
1907
|
});
|
|
1909
1908
|
}
|
|
@@ -1936,10 +1935,10 @@ class yt {
|
|
|
1936
1935
|
} = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}, {
|
|
1937
1936
|
canvas: a,
|
|
1938
1937
|
historyManager: r
|
|
1939
|
-
} = this.editor,
|
|
1940
|
-
if (
|
|
1941
|
-
var o =
|
|
1942
|
-
|
|
1938
|
+
} = this.editor, n = a.getActiveObject();
|
|
1939
|
+
if (n) {
|
|
1940
|
+
var o = n.angle + e;
|
|
1941
|
+
n.rotate(o), n.setCoords(), a.renderAll(), t || r.saveState(), a.fire("editor:object-rotated", {
|
|
1943
1942
|
angle: o
|
|
1944
1943
|
});
|
|
1945
1944
|
}
|
|
@@ -1986,11 +1985,11 @@ class yt {
|
|
|
1986
1985
|
withoutSave: a
|
|
1987
1986
|
} = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, {
|
|
1988
1987
|
canvas: r,
|
|
1989
|
-
historyManager:
|
|
1988
|
+
historyManager: n
|
|
1990
1989
|
} = this.editor, o = e || r.getActiveObject();
|
|
1991
1990
|
o && (o.type === "activeselection" ? o.getObjects().forEach((s) => {
|
|
1992
1991
|
s.set("opacity", t);
|
|
1993
|
-
}) : o.set("opacity", t), r.renderAll(), a ||
|
|
1992
|
+
}) : o.set("opacity", t), r.renderAll(), a || n.saveState(), r.fire("editor:object-opacity-changed", t));
|
|
1994
1993
|
}
|
|
1995
1994
|
/**
|
|
1996
1995
|
* Масштабирование изображения
|
|
@@ -2010,34 +2009,34 @@ class yt {
|
|
|
2010
2009
|
withoutSave: a,
|
|
2011
2010
|
fitAsOneObject: r
|
|
2012
2011
|
} = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, {
|
|
2013
|
-
canvas:
|
|
2012
|
+
canvas: n,
|
|
2014
2013
|
montageArea: o,
|
|
2015
2014
|
historyManager: s
|
|
2016
|
-
} = this.editor, c = e ||
|
|
2015
|
+
} = this.editor, c = e || n.getActiveObject();
|
|
2017
2016
|
if (c) {
|
|
2018
2017
|
if (["activeselection"].includes(c.type) && !r) {
|
|
2019
2018
|
var d = c.getObjects();
|
|
2020
|
-
|
|
2021
|
-
var
|
|
2019
|
+
n.discardActiveObject(), d.forEach((h) => {
|
|
2020
|
+
var g = Y({
|
|
2022
2021
|
montageArea: o,
|
|
2023
|
-
imageObject:
|
|
2022
|
+
imageObject: h,
|
|
2024
2023
|
scaleType: t
|
|
2025
2024
|
});
|
|
2026
|
-
|
|
2025
|
+
h.scale(g), n.centerObject(h);
|
|
2027
2026
|
});
|
|
2028
|
-
var l = new
|
|
2029
|
-
canvas:
|
|
2027
|
+
var l = new Z(d, {
|
|
2028
|
+
canvas: n
|
|
2030
2029
|
});
|
|
2031
|
-
|
|
2030
|
+
n.setActiveObject(l);
|
|
2032
2031
|
} else {
|
|
2033
|
-
var u =
|
|
2032
|
+
var u = Y({
|
|
2034
2033
|
montageArea: o,
|
|
2035
2034
|
imageObject: c,
|
|
2036
2035
|
scaleType: t
|
|
2037
2036
|
});
|
|
2038
|
-
c.scale(u),
|
|
2037
|
+
c.scale(u), n.centerObject(c);
|
|
2039
2038
|
}
|
|
2040
|
-
|
|
2039
|
+
n.renderAll(), a || s.saveState(), n.fire("editor:image-fitted", {
|
|
2041
2040
|
type: t
|
|
2042
2041
|
});
|
|
2043
2042
|
}
|
|
@@ -2063,7 +2062,7 @@ class yt {
|
|
|
2063
2062
|
withoutSave: a = !1
|
|
2064
2063
|
} = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}, {
|
|
2065
2064
|
canvas: r,
|
|
2066
|
-
montageArea:
|
|
2065
|
+
montageArea: n,
|
|
2067
2066
|
historyManager: o,
|
|
2068
2067
|
options: {
|
|
2069
2068
|
scaleType: s
|
|
@@ -2085,15 +2084,15 @@ class yt {
|
|
|
2085
2084
|
var {
|
|
2086
2085
|
width: d,
|
|
2087
2086
|
height: l
|
|
2088
|
-
} =
|
|
2087
|
+
} = n, {
|
|
2089
2088
|
width: u,
|
|
2090
|
-
height:
|
|
2091
|
-
} = c,
|
|
2092
|
-
montageArea:
|
|
2089
|
+
height: h
|
|
2090
|
+
} = c, g = Y({
|
|
2091
|
+
montageArea: n,
|
|
2093
2092
|
imageObject: c,
|
|
2094
2093
|
scaleType: s
|
|
2095
2094
|
});
|
|
2096
|
-
s === "contain" &&
|
|
2095
|
+
s === "contain" && g < 1 || s === "cover" && (u > d || h > l) ? this.fitObject({
|
|
2097
2096
|
object: c,
|
|
2098
2097
|
withoutSave: !0
|
|
2099
2098
|
}) : c.set({
|
|
@@ -2109,7 +2108,7 @@ class yt {
|
|
|
2109
2108
|
}
|
|
2110
2109
|
}
|
|
2111
2110
|
}
|
|
2112
|
-
class
|
|
2111
|
+
class pt {
|
|
2113
2112
|
/**
|
|
2114
2113
|
* @param {object} options
|
|
2115
2114
|
* @param {ImageEditor} options.editor – экземпляр редактора
|
|
@@ -2159,13 +2158,13 @@ class bt {
|
|
|
2159
2158
|
a.suspendHistory(), t.setCoords();
|
|
2160
2159
|
var {
|
|
2161
2160
|
left: r,
|
|
2162
|
-
top:
|
|
2161
|
+
top: n,
|
|
2163
2162
|
width: o,
|
|
2164
2163
|
height: s
|
|
2165
2164
|
} = t.getBoundingRect();
|
|
2166
2165
|
this.overlayMask.set({
|
|
2167
2166
|
left: r,
|
|
2168
|
-
top:
|
|
2167
|
+
top: n,
|
|
2169
2168
|
width: o,
|
|
2170
2169
|
height: s
|
|
2171
2170
|
}), e.discardActiveObject(), this.editor.layerManager.bringToFront(this.overlayMask, {
|
|
@@ -2235,10 +2234,10 @@ class H {
|
|
|
2235
2234
|
historyManager: r
|
|
2236
2235
|
} = this.editor;
|
|
2237
2236
|
r.suspendHistory();
|
|
2238
|
-
var
|
|
2239
|
-
|
|
2237
|
+
var n = e || a.getActiveObject();
|
|
2238
|
+
n && (n.type === "activeselection" ? n.getObjects().forEach((o) => {
|
|
2240
2239
|
a.bringObjectToFront(o);
|
|
2241
|
-
}) : a.bringObjectToFront(
|
|
2240
|
+
}) : a.bringObjectToFront(n), a.renderAll(), r.resumeHistory(), t || r.saveState(), a.fire("editor:object-bring-to-front"));
|
|
2242
2241
|
}
|
|
2243
2242
|
/**
|
|
2244
2243
|
* Поднять объект на один уровень вверх по оси Z
|
|
@@ -2255,8 +2254,8 @@ class H {
|
|
|
2255
2254
|
historyManager: r
|
|
2256
2255
|
} = this.editor;
|
|
2257
2256
|
r.suspendHistory();
|
|
2258
|
-
var
|
|
2259
|
-
|
|
2257
|
+
var n = e || a.getActiveObject();
|
|
2258
|
+
n && (n.type === "activeselection" ? H._moveSelectionForward(a, n) : a.bringObjectForward(n), a.renderAll(), r.resumeHistory(), t || r.saveState(), a.fire("editor:object-bring-forward"));
|
|
2260
2259
|
}
|
|
2261
2260
|
/**
|
|
2262
2261
|
* Отправить объект на задний план по оси Z
|
|
@@ -2271,12 +2270,12 @@ class H {
|
|
|
2271
2270
|
} = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}, {
|
|
2272
2271
|
canvas: a,
|
|
2273
2272
|
montageArea: r,
|
|
2274
|
-
historyManager:
|
|
2273
|
+
historyManager: n,
|
|
2275
2274
|
interactionBlocker: {
|
|
2276
2275
|
overlayMask: o
|
|
2277
2276
|
}
|
|
2278
2277
|
} = this.editor;
|
|
2279
|
-
|
|
2278
|
+
n.suspendHistory();
|
|
2280
2279
|
var s = e || a.getActiveObject();
|
|
2281
2280
|
if (s) {
|
|
2282
2281
|
if (s.type === "activeselection")
|
|
@@ -2284,7 +2283,7 @@ class H {
|
|
|
2284
2283
|
a.sendObjectToBack(c[d]);
|
|
2285
2284
|
else
|
|
2286
2285
|
a.sendObjectToBack(s);
|
|
2287
|
-
a.sendObjectToBack(r), a.sendObjectToBack(o), a.renderAll(),
|
|
2286
|
+
a.sendObjectToBack(r), a.sendObjectToBack(o), a.renderAll(), n.resumeHistory(), t || n.saveState(), a.fire("editor:object-send-to-back");
|
|
2288
2287
|
}
|
|
2289
2288
|
}
|
|
2290
2289
|
/**
|
|
@@ -2299,14 +2298,14 @@ class H {
|
|
|
2299
2298
|
} = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}, {
|
|
2300
2299
|
canvas: a,
|
|
2301
2300
|
montageArea: r,
|
|
2302
|
-
historyManager:
|
|
2301
|
+
historyManager: n,
|
|
2303
2302
|
interactionBlocker: {
|
|
2304
2303
|
overlayMask: o
|
|
2305
2304
|
}
|
|
2306
2305
|
} = this.editor;
|
|
2307
|
-
|
|
2306
|
+
n.suspendHistory();
|
|
2308
2307
|
var s = e || a.getActiveObject();
|
|
2309
|
-
s && (s.type === "activeselection" ? H._moveSelectionBackwards(a, s) : a.sendObjectBackwards(s), a.sendObjectToBack(r), a.sendObjectToBack(o), a.renderAll(),
|
|
2308
|
+
s && (s.type === "activeselection" ? H._moveSelectionBackwards(a, s) : a.sendObjectBackwards(s), a.sendObjectToBack(r), a.sendObjectToBack(o), a.renderAll(), n.resumeHistory(), t || n.saveState(), a.fire("editor:object-send-backwards"));
|
|
2310
2309
|
}
|
|
2311
2310
|
/**
|
|
2312
2311
|
* Сдвигает выделенные объекты на один уровень вверх относительно ближайшего верхнего объекта
|
|
@@ -2316,8 +2315,8 @@ class H {
|
|
|
2316
2315
|
* @private
|
|
2317
2316
|
*/
|
|
2318
2317
|
static _moveSelectionForward(e, t) {
|
|
2319
|
-
for (var a = e.getObjects(), r = t.getObjects(),
|
|
2320
|
-
for (var o = r[
|
|
2318
|
+
for (var a = e.getObjects(), r = t.getObjects(), n = r.length - 1; n >= 0; n -= 1) {
|
|
2319
|
+
for (var o = r[n], s = a.indexOf(o), c = s + 1; c < a.length && r.includes(a[c]); )
|
|
2321
2320
|
c += 1;
|
|
2322
2321
|
c < a.length && e.moveObjectTo(o, c);
|
|
2323
2322
|
}
|
|
@@ -2330,68 +2329,68 @@ class H {
|
|
|
2330
2329
|
* @private
|
|
2331
2330
|
*/
|
|
2332
2331
|
static _moveSelectionBackwards(e, t) {
|
|
2333
|
-
for (var a = e.getObjects(), r = t.getObjects(),
|
|
2334
|
-
e.moveObjectTo(r[o],
|
|
2332
|
+
for (var a = e.getObjects(), r = t.getObjects(), n = Math.min(...r.map((s) => a.indexOf(s))), o = r.length - 1; o >= 0; o -= 1)
|
|
2333
|
+
e.moveObjectTo(r[o], n - 1);
|
|
2335
2334
|
}
|
|
2336
2335
|
}
|
|
2337
|
-
var
|
|
2338
|
-
function
|
|
2339
|
-
var t = Object.keys(
|
|
2336
|
+
var bt = ["id", "left", "top", "width", "height", "fill"], It = ["id", "left", "top", "radius", "fill"], St = ["id", "left", "top", "width", "height", "fill"];
|
|
2337
|
+
function je(i, e) {
|
|
2338
|
+
var t = Object.keys(i);
|
|
2340
2339
|
if (Object.getOwnPropertySymbols) {
|
|
2341
|
-
var a = Object.getOwnPropertySymbols(
|
|
2340
|
+
var a = Object.getOwnPropertySymbols(i);
|
|
2342
2341
|
e && (a = a.filter(function(r) {
|
|
2343
|
-
return Object.getOwnPropertyDescriptor(
|
|
2342
|
+
return Object.getOwnPropertyDescriptor(i, r).enumerable;
|
|
2344
2343
|
})), t.push.apply(t, a);
|
|
2345
2344
|
}
|
|
2346
2345
|
return t;
|
|
2347
2346
|
}
|
|
2348
|
-
function
|
|
2347
|
+
function F(i) {
|
|
2349
2348
|
for (var e = 1; e < arguments.length; e++) {
|
|
2350
2349
|
var t = arguments[e] != null ? arguments[e] : {};
|
|
2351
|
-
e % 2 ?
|
|
2352
|
-
At(
|
|
2353
|
-
}) : Object.getOwnPropertyDescriptors ? Object.defineProperties(
|
|
2354
|
-
Object.defineProperty(
|
|
2350
|
+
e % 2 ? je(Object(t), !0).forEach(function(a) {
|
|
2351
|
+
At(i, a, t[a]);
|
|
2352
|
+
}) : Object.getOwnPropertyDescriptors ? Object.defineProperties(i, Object.getOwnPropertyDescriptors(t)) : je(Object(t)).forEach(function(a) {
|
|
2353
|
+
Object.defineProperty(i, a, Object.getOwnPropertyDescriptor(t, a));
|
|
2355
2354
|
});
|
|
2356
2355
|
}
|
|
2357
|
-
return
|
|
2356
|
+
return i;
|
|
2358
2357
|
}
|
|
2359
|
-
function At(
|
|
2360
|
-
return (e =
|
|
2358
|
+
function At(i, e, t) {
|
|
2359
|
+
return (e = wt(e)) in i ? Object.defineProperty(i, e, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : i[e] = t, i;
|
|
2361
2360
|
}
|
|
2362
|
-
function
|
|
2363
|
-
var e =
|
|
2361
|
+
function wt(i) {
|
|
2362
|
+
var e = Nt(i, "string");
|
|
2364
2363
|
return typeof e == "symbol" ? e : e + "";
|
|
2365
2364
|
}
|
|
2366
|
-
function
|
|
2367
|
-
if (typeof
|
|
2368
|
-
var t =
|
|
2365
|
+
function Nt(i, e) {
|
|
2366
|
+
if (typeof i != "object" || !i) return i;
|
|
2367
|
+
var t = i[Symbol.toPrimitive];
|
|
2369
2368
|
if (t !== void 0) {
|
|
2370
|
-
var a = t.call(
|
|
2369
|
+
var a = t.call(i, e);
|
|
2371
2370
|
if (typeof a != "object") return a;
|
|
2372
2371
|
throw new TypeError("@@toPrimitive must return a primitive value.");
|
|
2373
2372
|
}
|
|
2374
|
-
return (e === "string" ? String : Number)(
|
|
2373
|
+
return (e === "string" ? String : Number)(i);
|
|
2375
2374
|
}
|
|
2376
|
-
function
|
|
2377
|
-
if (
|
|
2378
|
-
var t, a, r =
|
|
2375
|
+
function G(i, e) {
|
|
2376
|
+
if (i == null) return {};
|
|
2377
|
+
var t, a, r = Dt(i, e);
|
|
2379
2378
|
if (Object.getOwnPropertySymbols) {
|
|
2380
|
-
var
|
|
2381
|
-
for (a = 0; a <
|
|
2379
|
+
var n = Object.getOwnPropertySymbols(i);
|
|
2380
|
+
for (a = 0; a < n.length; a++) t = n[a], e.indexOf(t) === -1 && {}.propertyIsEnumerable.call(i, t) && (r[t] = i[t]);
|
|
2382
2381
|
}
|
|
2383
2382
|
return r;
|
|
2384
2383
|
}
|
|
2385
|
-
function
|
|
2386
|
-
if (
|
|
2384
|
+
function Dt(i, e) {
|
|
2385
|
+
if (i == null) return {};
|
|
2387
2386
|
var t = {};
|
|
2388
|
-
for (var a in
|
|
2387
|
+
for (var a in i) if ({}.hasOwnProperty.call(i, a)) {
|
|
2389
2388
|
if (e.indexOf(a) !== -1) continue;
|
|
2390
|
-
t[a] =
|
|
2389
|
+
t[a] = i[a];
|
|
2391
2390
|
}
|
|
2392
2391
|
return t;
|
|
2393
2392
|
}
|
|
2394
|
-
class
|
|
2393
|
+
class Ct {
|
|
2395
2394
|
/**
|
|
2396
2395
|
* @param {object} options
|
|
2397
2396
|
* @param {ImageEditor} options.editor - экземпляр редактора с доступом к canvas
|
|
@@ -2419,26 +2418,26 @@ class Dt {
|
|
|
2419
2418
|
*/
|
|
2420
2419
|
addRectangle() {
|
|
2421
2420
|
var e = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, {
|
|
2422
|
-
id: t = "rect-".concat(
|
|
2421
|
+
id: t = "rect-".concat(I()),
|
|
2423
2422
|
left: a,
|
|
2424
2423
|
top: r,
|
|
2425
|
-
width:
|
|
2424
|
+
width: n = 100,
|
|
2426
2425
|
height: o = 100,
|
|
2427
2426
|
fill: s = "blue"
|
|
2428
|
-
} = e, c =
|
|
2427
|
+
} = e, c = G(e, bt), {
|
|
2429
2428
|
withoutSelection: d,
|
|
2430
2429
|
withoutAdding: l
|
|
2431
2430
|
} = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}, {
|
|
2432
2431
|
canvas: u
|
|
2433
|
-
} = this.editor,
|
|
2432
|
+
} = this.editor, h = new Be(F({
|
|
2434
2433
|
id: t,
|
|
2435
2434
|
left: a,
|
|
2436
2435
|
top: r,
|
|
2437
|
-
width:
|
|
2436
|
+
width: n,
|
|
2438
2437
|
height: o,
|
|
2439
2438
|
fill: s
|
|
2440
2439
|
}, c));
|
|
2441
|
-
return !a && !r && u.centerObject(
|
|
2440
|
+
return !a && !r && u.centerObject(h), l || (u.add(h), d || u.setActiveObject(h), u.renderAll()), h;
|
|
2442
2441
|
}
|
|
2443
2442
|
/**
|
|
2444
2443
|
* Добавление круга
|
|
@@ -2456,22 +2455,22 @@ class Dt {
|
|
|
2456
2455
|
*/
|
|
2457
2456
|
addCircle() {
|
|
2458
2457
|
var e = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, {
|
|
2459
|
-
id: t = "circle-".concat(
|
|
2458
|
+
id: t = "circle-".concat(I()),
|
|
2460
2459
|
left: a,
|
|
2461
2460
|
top: r,
|
|
2462
|
-
radius:
|
|
2461
|
+
radius: n = 50,
|
|
2463
2462
|
fill: o = "green"
|
|
2464
|
-
} = e, s =
|
|
2463
|
+
} = e, s = G(e, It), {
|
|
2465
2464
|
withoutSelection: c,
|
|
2466
2465
|
withoutAdding: d
|
|
2467
2466
|
} = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}, {
|
|
2468
2467
|
canvas: l
|
|
2469
|
-
} = this.editor, u = new
|
|
2468
|
+
} = this.editor, u = new Ze(F({
|
|
2470
2469
|
id: t,
|
|
2471
2470
|
left: a,
|
|
2472
2471
|
top: r,
|
|
2473
2472
|
fill: o,
|
|
2474
|
-
radius:
|
|
2473
|
+
radius: n
|
|
2475
2474
|
}, s));
|
|
2476
2475
|
return !a && !r && l.centerObject(u), d || (l.add(u), c || l.setActiveObject(u), l.renderAll()), u;
|
|
2477
2476
|
}
|
|
@@ -2492,46 +2491,46 @@ class Dt {
|
|
|
2492
2491
|
*/
|
|
2493
2492
|
addTriangle() {
|
|
2494
2493
|
var e = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, {
|
|
2495
|
-
id: t = "triangle-".concat(
|
|
2494
|
+
id: t = "triangle-".concat(I()),
|
|
2496
2495
|
left: a,
|
|
2497
2496
|
top: r,
|
|
2498
|
-
width:
|
|
2497
|
+
width: n = 100,
|
|
2499
2498
|
height: o = 100,
|
|
2500
2499
|
fill: s = "yellow"
|
|
2501
|
-
} = e, c =
|
|
2500
|
+
} = e, c = G(e, St), {
|
|
2502
2501
|
withoutSelection: d,
|
|
2503
2502
|
withoutAdding: l
|
|
2504
2503
|
} = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}, {
|
|
2505
2504
|
canvas: u
|
|
2506
|
-
} = this.editor,
|
|
2505
|
+
} = this.editor, h = new ze(F({
|
|
2507
2506
|
id: t,
|
|
2508
2507
|
left: a,
|
|
2509
2508
|
top: r,
|
|
2510
2509
|
fill: s,
|
|
2511
|
-
width:
|
|
2510
|
+
width: n,
|
|
2512
2511
|
height: o
|
|
2513
2512
|
}, c));
|
|
2514
|
-
return !a && !r && u.centerObject(
|
|
2513
|
+
return !a && !r && u.centerObject(h), l || (u.add(h), d || u.setActiveObject(h), u.renderAll()), h;
|
|
2515
2514
|
}
|
|
2516
2515
|
}
|
|
2517
|
-
function
|
|
2516
|
+
function ye(i, e, t, a, r, n, o) {
|
|
2518
2517
|
try {
|
|
2519
|
-
var s = n
|
|
2518
|
+
var s = i[n](o), c = s.value;
|
|
2520
2519
|
} catch (d) {
|
|
2521
2520
|
return void t(d);
|
|
2522
2521
|
}
|
|
2523
2522
|
s.done ? e(c) : Promise.resolve(c).then(a, r);
|
|
2524
2523
|
}
|
|
2525
|
-
function
|
|
2524
|
+
function pe(i) {
|
|
2526
2525
|
return function() {
|
|
2527
2526
|
var e = this, t = arguments;
|
|
2528
2527
|
return new Promise(function(a, r) {
|
|
2529
|
-
var
|
|
2528
|
+
var n = i.apply(e, t);
|
|
2530
2529
|
function o(c) {
|
|
2531
|
-
|
|
2530
|
+
ye(n, a, r, o, s, "next", c);
|
|
2532
2531
|
}
|
|
2533
2532
|
function s(c) {
|
|
2534
|
-
|
|
2533
|
+
ye(n, a, r, o, s, "throw", c);
|
|
2535
2534
|
}
|
|
2536
2535
|
o(void 0);
|
|
2537
2536
|
});
|
|
@@ -2554,7 +2553,7 @@ class Lt {
|
|
|
2554
2553
|
*/
|
|
2555
2554
|
copy() {
|
|
2556
2555
|
var e = this;
|
|
2557
|
-
return
|
|
2556
|
+
return pe(function* () {
|
|
2558
2557
|
var {
|
|
2559
2558
|
canvas: t
|
|
2560
2559
|
} = e.editor, a = t.getActiveObject();
|
|
@@ -2576,8 +2575,8 @@ class Lt {
|
|
|
2576
2575
|
});
|
|
2577
2576
|
return;
|
|
2578
2577
|
}
|
|
2579
|
-
var
|
|
2580
|
-
|
|
2578
|
+
var n = r.toCanvasElement(), o = yield new Promise((d) => {
|
|
2579
|
+
n.toBlob(d);
|
|
2581
2580
|
}), s = new ClipboardItem({
|
|
2582
2581
|
[o.type]: o
|
|
2583
2582
|
});
|
|
@@ -2598,18 +2597,18 @@ class Lt {
|
|
|
2598
2597
|
*/
|
|
2599
2598
|
paste() {
|
|
2600
2599
|
var e = this;
|
|
2601
|
-
return
|
|
2600
|
+
return pe(function* () {
|
|
2602
2601
|
var {
|
|
2603
2602
|
canvas: t
|
|
2604
2603
|
} = e.editor;
|
|
2605
2604
|
if (e.clipboard) {
|
|
2606
2605
|
var a = yield e.clipboard.clone();
|
|
2607
2606
|
t.discardActiveObject(), a.set({
|
|
2608
|
-
id: "".concat(a.type, "-").concat(
|
|
2607
|
+
id: "".concat(a.type, "-").concat(I()),
|
|
2609
2608
|
left: a.left + 10,
|
|
2610
2609
|
top: a.top + 10,
|
|
2611
2610
|
evented: !0
|
|
2612
|
-
}), a instanceof
|
|
2611
|
+
}), a instanceof Z ? (a.canvas = t, a.forEachObject((r) => {
|
|
2613
2612
|
t.add(r);
|
|
2614
2613
|
})) : t.add(a), t.setActiveObject(a), t.requestRenderAll(), t.fire("editor:object-pasted", {
|
|
2615
2614
|
object: a
|
|
@@ -2644,8 +2643,8 @@ class Ot {
|
|
|
2644
2643
|
} = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, {
|
|
2645
2644
|
canvas: a,
|
|
2646
2645
|
historyManager: r
|
|
2647
|
-
} = this.editor,
|
|
2648
|
-
if (
|
|
2646
|
+
} = this.editor, n = e || a.getActiveObject();
|
|
2647
|
+
if (n) {
|
|
2649
2648
|
var o = {
|
|
2650
2649
|
lockMovementX: !0,
|
|
2651
2650
|
lockMovementY: !0,
|
|
@@ -2656,10 +2655,10 @@ class Ot {
|
|
|
2656
2655
|
lockSkewingY: !0,
|
|
2657
2656
|
locked: !0
|
|
2658
2657
|
};
|
|
2659
|
-
|
|
2658
|
+
n.set(o), ["activeselection", "group"].includes(n.type) && n.getObjects().forEach((s) => {
|
|
2660
2659
|
s.set(o);
|
|
2661
2660
|
}), a.renderAll(), t || r.saveState(), a.fire("editor:object-locked", {
|
|
2662
|
-
object:
|
|
2661
|
+
object: n
|
|
2663
2662
|
});
|
|
2664
2663
|
}
|
|
2665
2664
|
}
|
|
@@ -2678,8 +2677,8 @@ class Ot {
|
|
|
2678
2677
|
} = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, {
|
|
2679
2678
|
canvas: a,
|
|
2680
2679
|
historyManager: r
|
|
2681
|
-
} = this.editor,
|
|
2682
|
-
if (
|
|
2680
|
+
} = this.editor, n = e || a.getActiveObject();
|
|
2681
|
+
if (n) {
|
|
2683
2682
|
var o = {
|
|
2684
2683
|
lockMovementX: !1,
|
|
2685
2684
|
lockMovementY: !1,
|
|
@@ -2690,10 +2689,10 @@ class Ot {
|
|
|
2690
2689
|
lockSkewingY: !1,
|
|
2691
2690
|
locked: !1
|
|
2692
2691
|
};
|
|
2693
|
-
|
|
2692
|
+
n.set(o), ["activeselection", "group"].includes(n.type) && n.getObjects().forEach((s) => {
|
|
2694
2693
|
s.set(o);
|
|
2695
2694
|
}), a.renderAll(), t || r.saveState(), a.fire("editor:object-unlocked", {
|
|
2696
|
-
object:
|
|
2695
|
+
object: n
|
|
2697
2696
|
});
|
|
2698
2697
|
}
|
|
2699
2698
|
}
|
|
@@ -2725,10 +2724,10 @@ class Tt {
|
|
|
2725
2724
|
historyManager: r
|
|
2726
2725
|
} = this.editor;
|
|
2727
2726
|
r.suspendHistory();
|
|
2728
|
-
var
|
|
2729
|
-
if (
|
|
2730
|
-
var o =
|
|
2731
|
-
o.forEach((c) => a.remove(c)), s.set("id", "".concat(s.type, "-").concat(
|
|
2727
|
+
var n = e || a.getActiveObject();
|
|
2728
|
+
if (n && n.type === "activeselection") {
|
|
2729
|
+
var o = n.getObjects(), s = new Ue(o);
|
|
2730
|
+
o.forEach((c) => a.remove(c)), s.set("id", "".concat(s.type, "-").concat(I())), a.add(s), a.setActiveObject(s), a.renderAll(), r.resumeHistory(), t || r.saveState(), a.fire("editor:objects-grouped");
|
|
2732
2731
|
}
|
|
2733
2732
|
}
|
|
2734
2733
|
/**
|
|
@@ -2747,11 +2746,11 @@ class Tt {
|
|
|
2747
2746
|
historyManager: r
|
|
2748
2747
|
} = this.editor;
|
|
2749
2748
|
r.suspendHistory();
|
|
2750
|
-
var
|
|
2751
|
-
if (!(!
|
|
2752
|
-
var o =
|
|
2753
|
-
a.remove(
|
|
2754
|
-
var s = new
|
|
2749
|
+
var n = e || a.getActiveObject();
|
|
2750
|
+
if (!(!n || n.type !== "group")) {
|
|
2751
|
+
var o = n.removeAll();
|
|
2752
|
+
a.remove(n), o.forEach((c) => a.add(c));
|
|
2753
|
+
var s = new Z(o, {
|
|
2755
2754
|
canvas: a
|
|
2756
2755
|
});
|
|
2757
2756
|
a.setActiveObject(s), a.renderAll(), r.resumeHistory(), t || r.saveState(), a.fire("editor:objects-ungrouped");
|
|
@@ -2779,7 +2778,7 @@ class Et {
|
|
|
2779
2778
|
canvasManager: t
|
|
2780
2779
|
} = this.editor;
|
|
2781
2780
|
e.discardActiveObject();
|
|
2782
|
-
var a = new
|
|
2781
|
+
var a = new Z(t.getObjects(), {
|
|
2783
2782
|
canvas: e
|
|
2784
2783
|
});
|
|
2785
2784
|
e.setActiveObject(a), e.requestRenderAll(), e.fire("editor:all-objects-selected", {
|
|
@@ -2787,7 +2786,7 @@ class Et {
|
|
|
2787
2786
|
});
|
|
2788
2787
|
}
|
|
2789
2788
|
}
|
|
2790
|
-
class
|
|
2789
|
+
class kt {
|
|
2791
2790
|
/**
|
|
2792
2791
|
* @param {object} options
|
|
2793
2792
|
* @param {ImageEditor} options.editor - экземпляр редактора с доступом к canvas
|
|
@@ -2814,8 +2813,8 @@ class Zt {
|
|
|
2814
2813
|
historyManager: r
|
|
2815
2814
|
} = this.editor;
|
|
2816
2815
|
r.suspendHistory();
|
|
2817
|
-
var
|
|
2818
|
-
|
|
2816
|
+
var n = e || a.getActiveObjects();
|
|
2817
|
+
n != null && n.length && (n.forEach((o) => {
|
|
2819
2818
|
if (o.type === "group" && o.format !== "svg") {
|
|
2820
2819
|
this.ungroup(o), this.deleteSelectedObjects();
|
|
2821
2820
|
return;
|
|
@@ -2824,48 +2823,48 @@ class Zt {
|
|
|
2824
2823
|
}), a.discardActiveObject(), a.renderAll(), r.resumeHistory(), t || r.saveState(), a.fire("editor:objects-deleted"));
|
|
2825
2824
|
}
|
|
2826
2825
|
}
|
|
2827
|
-
function be(
|
|
2826
|
+
function be(i, e, t, a, r, n, o) {
|
|
2828
2827
|
try {
|
|
2829
|
-
var s = n
|
|
2828
|
+
var s = i[n](o), c = s.value;
|
|
2830
2829
|
} catch (d) {
|
|
2831
2830
|
return void t(d);
|
|
2832
2831
|
}
|
|
2833
2832
|
s.done ? e(c) : Promise.resolve(c).then(a, r);
|
|
2834
2833
|
}
|
|
2835
|
-
function
|
|
2834
|
+
function xt(i) {
|
|
2836
2835
|
return function() {
|
|
2837
2836
|
var e = this, t = arguments;
|
|
2838
2837
|
return new Promise(function(a, r) {
|
|
2839
|
-
var
|
|
2838
|
+
var n = i.apply(e, t);
|
|
2840
2839
|
function o(c) {
|
|
2841
|
-
be(
|
|
2840
|
+
be(n, a, r, o, s, "next", c);
|
|
2842
2841
|
}
|
|
2843
2842
|
function s(c) {
|
|
2844
|
-
be(
|
|
2843
|
+
be(n, a, r, o, s, "throw", c);
|
|
2845
2844
|
}
|
|
2846
2845
|
o(void 0);
|
|
2847
2846
|
});
|
|
2848
2847
|
};
|
|
2849
2848
|
}
|
|
2850
|
-
class
|
|
2849
|
+
class Bt {
|
|
2851
2850
|
constructor(e) {
|
|
2852
2851
|
var t = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};
|
|
2853
2852
|
this.options = t;
|
|
2854
2853
|
var {
|
|
2855
2854
|
defaultScale: a,
|
|
2856
2855
|
minZoom: r,
|
|
2857
|
-
maxZoom:
|
|
2856
|
+
maxZoom: n
|
|
2858
2857
|
} = t;
|
|
2859
|
-
this.containerId = e, this.editorId = "".concat(e, "-").concat(
|
|
2858
|
+
this.containerId = e, this.editorId = "".concat(e, "-").concat(I()), this.clipboard = null, this.defaultZoom = a, this.minZoom = r || vt, this.maxZoom = n || mt, this.init();
|
|
2860
2859
|
}
|
|
2861
2860
|
init() {
|
|
2862
2861
|
var e = this;
|
|
2863
|
-
return
|
|
2862
|
+
return xt(function* () {
|
|
2864
2863
|
var {
|
|
2865
2864
|
editorContainerWidth: t,
|
|
2866
2865
|
editorContainerHeight: a,
|
|
2867
2866
|
canvasWrapperWidth: r,
|
|
2868
|
-
canvasWrapperHeight:
|
|
2867
|
+
canvasWrapperHeight: n,
|
|
2869
2868
|
canvasCSSWidth: o,
|
|
2870
2869
|
canvasCSSHeight: s,
|
|
2871
2870
|
initialImage: c,
|
|
@@ -2873,7 +2872,7 @@ class kt {
|
|
|
2873
2872
|
scaleType: l,
|
|
2874
2873
|
_onReadyCallback: u
|
|
2875
2874
|
} = e.options;
|
|
2876
|
-
if ($e.apply(), e.canvas = new
|
|
2875
|
+
if ($e.apply(), e.canvas = new Pe(e.containerId, e.options), e.moduleLoader = new _e(), e.workerManager = new Re(), e.historyManager = new ht({
|
|
2877
2876
|
editor: e
|
|
2878
2877
|
}), e.toolbar = new lt({
|
|
2879
2878
|
editor: e
|
|
@@ -2885,9 +2884,9 @@ class kt {
|
|
|
2885
2884
|
editor: e
|
|
2886
2885
|
}), e.layerManager = new H({
|
|
2887
2886
|
editor: e
|
|
2888
|
-
}), e.shapeManager = new
|
|
2887
|
+
}), e.shapeManager = new Ct({
|
|
2889
2888
|
editor: e
|
|
2890
|
-
}), e.interactionBlocker = new
|
|
2889
|
+
}), e.interactionBlocker = new pt({
|
|
2891
2890
|
editor: e
|
|
2892
2891
|
}), e.clipboardManager = new Lt({
|
|
2893
2892
|
editor: e
|
|
@@ -2897,21 +2896,21 @@ class kt {
|
|
|
2897
2896
|
editor: e
|
|
2898
2897
|
}), e.selectionManager = new Et({
|
|
2899
2898
|
editor: e
|
|
2900
|
-
}), e.deletionManager = new
|
|
2899
|
+
}), e.deletionManager = new kt({
|
|
2901
2900
|
editor: e
|
|
2902
|
-
}), e._createMonageArea(), e._createClippingArea(), e.listeners = new
|
|
2901
|
+
}), e._createMonageArea(), e._createClippingArea(), e.listeners = new B({
|
|
2903
2902
|
editor: e,
|
|
2904
2903
|
options: e.options
|
|
2905
|
-
}), e.canvasManager.setEditorContainerWidth(t), e.canvasManager.setEditorContainerHeight(a), e.canvasManager.setCanvasWrapperWidth(r), e.canvasManager.setCanvasWrapperHeight(
|
|
2904
|
+
}), e.canvasManager.setEditorContainerWidth(t), e.canvasManager.setEditorContainerHeight(a), e.canvasManager.setCanvasWrapperWidth(r), e.canvasManager.setCanvasWrapperHeight(n), e.canvasManager.setCanvasCSSWidth(o), e.canvasManager.setCanvasCSSHeight(s), c != null && c.source) {
|
|
2906
2905
|
var {
|
|
2907
|
-
source:
|
|
2908
|
-
scale:
|
|
2906
|
+
source: h,
|
|
2907
|
+
scale: g = "image-".concat(l),
|
|
2909
2908
|
withoutSave: f = !0,
|
|
2910
2909
|
contentType: v
|
|
2911
2910
|
} = c;
|
|
2912
2911
|
yield e.imageManager.importImage({
|
|
2913
|
-
source:
|
|
2914
|
-
scale:
|
|
2912
|
+
source: h,
|
|
2913
|
+
scale: g,
|
|
2915
2914
|
withoutSave: f,
|
|
2916
2915
|
contentType: v
|
|
2917
2916
|
});
|
|
@@ -2935,7 +2934,7 @@ class kt {
|
|
|
2935
2934
|
this.montageArea = this.shapeManager.addRectangle({
|
|
2936
2935
|
width: e,
|
|
2937
2936
|
height: t,
|
|
2938
|
-
fill:
|
|
2937
|
+
fill: gt(),
|
|
2939
2938
|
stroke: null,
|
|
2940
2939
|
strokeWidth: 0,
|
|
2941
2940
|
selectable: !1,
|
|
@@ -2986,7 +2985,7 @@ class kt {
|
|
|
2986
2985
|
this.listeners.destroy(), this.toolbar.destroy(), this.canvas.dispose(), this.workerManager.worker.terminate(), this.imageManager.revokeBlobUrls();
|
|
2987
2986
|
}
|
|
2988
2987
|
}
|
|
2989
|
-
const
|
|
2988
|
+
const Zt = {
|
|
2990
2989
|
// Cохраняют ли объекты свой текущий порядок (z-index) при выделении
|
|
2991
2990
|
preserveObjectStacking: !0,
|
|
2992
2991
|
// Возможность взаимодействия с объектом за пределами монтажной области
|
|
@@ -3091,56 +3090,56 @@ const xt = {
|
|
|
3091
3090
|
// Сброс параметров объекта по двойному клику
|
|
3092
3091
|
resetObjectFitByDoubleClick: !0
|
|
3093
3092
|
};
|
|
3094
|
-
function Ie(
|
|
3095
|
-
var t = Object.keys(
|
|
3093
|
+
function Ie(i, e) {
|
|
3094
|
+
var t = Object.keys(i);
|
|
3096
3095
|
if (Object.getOwnPropertySymbols) {
|
|
3097
|
-
var a = Object.getOwnPropertySymbols(
|
|
3096
|
+
var a = Object.getOwnPropertySymbols(i);
|
|
3098
3097
|
e && (a = a.filter(function(r) {
|
|
3099
|
-
return Object.getOwnPropertyDescriptor(
|
|
3098
|
+
return Object.getOwnPropertyDescriptor(i, r).enumerable;
|
|
3100
3099
|
})), t.push.apply(t, a);
|
|
3101
3100
|
}
|
|
3102
3101
|
return t;
|
|
3103
3102
|
}
|
|
3104
|
-
function
|
|
3103
|
+
function Se(i) {
|
|
3105
3104
|
for (var e = 1; e < arguments.length; e++) {
|
|
3106
3105
|
var t = arguments[e] != null ? arguments[e] : {};
|
|
3107
3106
|
e % 2 ? Ie(Object(t), !0).forEach(function(a) {
|
|
3108
|
-
zt(
|
|
3109
|
-
}) : Object.getOwnPropertyDescriptors ? Object.defineProperties(
|
|
3110
|
-
Object.defineProperty(
|
|
3107
|
+
zt(i, a, t[a]);
|
|
3108
|
+
}) : Object.getOwnPropertyDescriptors ? Object.defineProperties(i, Object.getOwnPropertyDescriptors(t)) : Ie(Object(t)).forEach(function(a) {
|
|
3109
|
+
Object.defineProperty(i, a, Object.getOwnPropertyDescriptor(t, a));
|
|
3111
3110
|
});
|
|
3112
3111
|
}
|
|
3113
|
-
return
|
|
3112
|
+
return i;
|
|
3114
3113
|
}
|
|
3115
|
-
function zt(
|
|
3116
|
-
return (e =
|
|
3114
|
+
function zt(i, e, t) {
|
|
3115
|
+
return (e = Ut(e)) in i ? Object.defineProperty(i, e, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : i[e] = t, i;
|
|
3117
3116
|
}
|
|
3118
|
-
function
|
|
3119
|
-
var e =
|
|
3117
|
+
function Ut(i) {
|
|
3118
|
+
var e = Pt(i, "string");
|
|
3120
3119
|
return typeof e == "symbol" ? e : e + "";
|
|
3121
3120
|
}
|
|
3122
|
-
function
|
|
3123
|
-
if (typeof
|
|
3124
|
-
var t =
|
|
3121
|
+
function Pt(i, e) {
|
|
3122
|
+
if (typeof i != "object" || !i) return i;
|
|
3123
|
+
var t = i[Symbol.toPrimitive];
|
|
3125
3124
|
if (t !== void 0) {
|
|
3126
|
-
var a = t.call(
|
|
3125
|
+
var a = t.call(i, e);
|
|
3127
3126
|
if (typeof a != "object") return a;
|
|
3128
3127
|
throw new TypeError("@@toPrimitive must return a primitive value.");
|
|
3129
3128
|
}
|
|
3130
|
-
return (e === "string" ? String : Number)(
|
|
3129
|
+
return (e === "string" ? String : Number)(i);
|
|
3131
3130
|
}
|
|
3132
|
-
function
|
|
3133
|
-
var e = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}, t =
|
|
3131
|
+
function Wt(i) {
|
|
3132
|
+
var e = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}, t = Se(Se({}, Zt), e), a = document.getElementById(i);
|
|
3134
3133
|
if (!a)
|
|
3135
|
-
return Promise.reject(new Error('Контейнер с ID "'.concat(
|
|
3134
|
+
return Promise.reject(new Error('Контейнер с ID "'.concat(i, '" не найден.')));
|
|
3136
3135
|
var r = document.createElement("canvas");
|
|
3137
|
-
return r.id = "".concat(
|
|
3138
|
-
t._onReadyCallback =
|
|
3139
|
-
var o = new
|
|
3140
|
-
window[
|
|
3136
|
+
return r.id = "".concat(i, "-canvas"), a.appendChild(r), t.editorContainer = a, new Promise((n) => {
|
|
3137
|
+
t._onReadyCallback = n;
|
|
3138
|
+
var o = new Bt(r.id, t);
|
|
3139
|
+
window[i] = o;
|
|
3141
3140
|
});
|
|
3142
3141
|
}
|
|
3143
3142
|
export {
|
|
3144
|
-
|
|
3143
|
+
Wt as default
|
|
3145
3144
|
};
|
|
3146
|
-
//# sourceMappingURL=
|
|
3145
|
+
//# sourceMappingURL=bundle.js.map
|