@bensitu/image-editor 1.5.1 → 2.0.0
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/README.md +370 -466
- package/dist/cjs/index.cjs +5422 -0
- package/dist/cjs/index.cjs.map +1 -0
- package/dist/esm/animation/animation-queue.js +67 -0
- package/dist/esm/animation/animation-queue.js.map +1 -0
- package/dist/esm/core/callback-reporter.js +23 -0
- package/dist/esm/core/callback-reporter.js.map +1 -0
- package/dist/esm/core/default-options.js +322 -0
- package/dist/esm/core/default-options.js.map +1 -0
- package/dist/esm/core/errors.js +156 -0
- package/dist/esm/core/errors.js.map +1 -0
- package/dist/esm/core/operation-guard.js +129 -0
- package/dist/esm/core/operation-guard.js.map +1 -0
- package/dist/esm/core/public-types.js +4 -0
- package/dist/esm/core/public-types.js.map +1 -0
- package/dist/esm/core/state-serializer.js +251 -0
- package/dist/esm/core/state-serializer.js.map +1 -0
- package/dist/esm/crop/crop-controller.js +403 -0
- package/dist/esm/crop/crop-controller.js.map +1 -0
- package/dist/esm/export/export-format.js +53 -0
- package/dist/esm/export/export-format.js.map +1 -0
- package/dist/esm/export/export-service.js +596 -0
- package/dist/esm/export/export-service.js.map +1 -0
- package/dist/esm/fabric/fabric-adapter.js +37 -0
- package/dist/esm/fabric/fabric-adapter.js.map +1 -0
- package/dist/esm/fabric/fabric-animation.js +37 -0
- package/dist/esm/fabric/fabric-animation.js.map +1 -0
- package/dist/esm/history/command.js +2 -0
- package/dist/esm/history/command.js.map +1 -0
- package/dist/esm/history/history-manager.js +103 -0
- package/dist/esm/history/history-manager.js.map +1 -0
- package/dist/esm/image/image-loader.js +245 -0
- package/dist/esm/image/image-loader.js.map +1 -0
- package/dist/esm/image/image-resampler.js +55 -0
- package/dist/esm/image/image-resampler.js.map +1 -0
- package/dist/esm/image/layout-manager.js +224 -0
- package/dist/esm/image/layout-manager.js.map +1 -0
- package/dist/esm/image/transform-controller.js +132 -0
- package/dist/esm/image/transform-controller.js.map +1 -0
- package/dist/esm/image-editor.js +1740 -0
- package/dist/esm/image-editor.js.map +1 -0
- package/dist/esm/index.js +5 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/mask/mask-factory.js +332 -0
- package/dist/esm/mask/mask-factory.js.map +1 -0
- package/dist/esm/mask/mask-label-manager.js +120 -0
- package/dist/esm/mask/mask-label-manager.js.map +1 -0
- package/dist/esm/mask/mask-list.js +47 -0
- package/dist/esm/mask/mask-list.js.map +1 -0
- package/dist/esm/mask/mask-style.js +182 -0
- package/dist/esm/mask/mask-style.js.map +1 -0
- package/dist/esm/ui/dom-bindings.js +60 -0
- package/dist/esm/ui/dom-bindings.js.map +1 -0
- package/dist/esm/ui/ui-state.js +25 -0
- package/dist/esm/ui/ui-state.js.map +1 -0
- package/dist/esm/ui/visibility-state.js +11 -0
- package/dist/esm/ui/visibility-state.js.map +1 -0
- package/dist/esm/utils/canvas-region.js +100 -0
- package/dist/esm/utils/canvas-region.js.map +1 -0
- package/dist/esm/utils/dom.js +6 -0
- package/dist/esm/utils/dom.js.map +1 -0
- package/dist/esm/utils/file.js +53 -0
- package/dist/esm/utils/file.js.map +1 -0
- package/dist/esm/utils/number.js +24 -0
- package/dist/esm/utils/number.js.map +1 -0
- package/dist/esm/utils/timeout.js +17 -0
- package/dist/esm/utils/timeout.js.map +1 -0
- package/dist/types/animation/animation-queue.d.ts +111 -0
- package/dist/types/animation/animation-queue.d.ts.map +1 -0
- package/dist/types/core/callback-reporter.d.ts +125 -0
- package/dist/types/core/callback-reporter.d.ts.map +1 -0
- package/dist/types/core/default-options.d.ts +56 -0
- package/dist/types/core/default-options.d.ts.map +1 -0
- package/dist/types/core/errors.d.ts +142 -0
- package/dist/types/core/errors.d.ts.map +1 -0
- package/dist/types/core/operation-guard.d.ts +192 -0
- package/dist/types/core/operation-guard.d.ts.map +1 -0
- package/dist/types/core/public-types.d.ts +678 -0
- package/dist/types/core/public-types.d.ts.map +1 -0
- package/dist/types/core/state-serializer.d.ts +301 -0
- package/dist/types/core/state-serializer.d.ts.map +1 -0
- package/dist/types/crop/crop-controller.d.ts +407 -0
- package/dist/types/crop/crop-controller.d.ts.map +1 -0
- package/dist/types/export/export-format.d.ts +136 -0
- package/dist/types/export/export-format.d.ts.map +1 -0
- package/dist/types/export/export-service.d.ts +333 -0
- package/dist/types/export/export-service.d.ts.map +1 -0
- package/dist/types/fabric/fabric-adapter.d.ts +74 -0
- package/dist/types/fabric/fabric-adapter.d.ts.map +1 -0
- package/dist/types/fabric/fabric-animation.d.ts +141 -0
- package/dist/types/fabric/fabric-animation.d.ts.map +1 -0
- package/dist/types/history/command.d.ts +16 -0
- package/dist/types/history/command.d.ts.map +1 -0
- package/dist/types/history/history-manager.d.ts +129 -0
- package/dist/types/history/history-manager.d.ts.map +1 -0
- package/dist/types/image/image-loader.d.ts +265 -0
- package/dist/types/image/image-loader.d.ts.map +1 -0
- package/dist/types/image/image-resampler.d.ts +139 -0
- package/dist/types/image/image-resampler.d.ts.map +1 -0
- package/dist/types/image/layout-manager.d.ts +255 -0
- package/dist/types/image/layout-manager.d.ts.map +1 -0
- package/dist/types/image/transform-controller.d.ts +287 -0
- package/dist/types/image/transform-controller.d.ts.map +1 -0
- package/dist/types/image-editor.d.ts +650 -0
- package/dist/types/image-editor.d.ts.map +1 -0
- package/dist/types/index.d.cts +31 -0
- package/dist/types/index.d.cts.map +1 -0
- package/dist/types/index.d.ts +31 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/mask/mask-factory.d.ts +209 -0
- package/dist/types/mask/mask-factory.d.ts.map +1 -0
- package/dist/types/mask/mask-label-manager.d.ts +171 -0
- package/dist/types/mask/mask-label-manager.d.ts.map +1 -0
- package/dist/types/mask/mask-list.d.ts +144 -0
- package/dist/types/mask/mask-list.d.ts.map +1 -0
- package/dist/types/mask/mask-style.d.ts +338 -0
- package/dist/types/mask/mask-style.d.ts.map +1 -0
- package/dist/types/ui/dom-bindings.d.ts +103 -0
- package/dist/types/ui/dom-bindings.d.ts.map +1 -0
- package/dist/types/ui/ui-state.d.ts +112 -0
- package/dist/types/ui/ui-state.d.ts.map +1 -0
- package/dist/types/ui/visibility-state.d.ts +77 -0
- package/dist/types/ui/visibility-state.d.ts.map +1 -0
- package/dist/types/utils/canvas-region.d.ts +177 -0
- package/dist/types/utils/canvas-region.d.ts.map +1 -0
- package/dist/types/utils/dom.d.ts +26 -0
- package/dist/types/utils/dom.d.ts.map +1 -0
- package/dist/types/utils/file.d.ts +80 -0
- package/dist/types/utils/file.d.ts.map +1 -0
- package/dist/types/utils/number.d.ts +132 -0
- package/dist/types/utils/number.d.ts.map +1 -0
- package/dist/types/utils/timeout.d.ts +84 -0
- package/dist/types/utils/timeout.d.ts.map +1 -0
- package/dist/umd/image-editor.umd.js +2 -0
- package/dist/umd/image-editor.umd.js.map +1 -0
- package/package.json +72 -66
- package/dist/image-editor.cjs +0 -4185
- package/dist/image-editor.cjs.map +0 -7
- package/dist/image-editor.esm.js +0 -4154
- package/dist/image-editor.esm.js.map +0 -7
- package/dist/image-editor.esm.min.js +0 -9
- package/dist/image-editor.esm.min.js.map +0 -7
- package/dist/image-editor.esm.min.mjs +0 -9
- package/dist/image-editor.esm.min.mjs.map +0 -7
- package/dist/image-editor.esm.mjs +0 -4154
- package/dist/image-editor.esm.mjs.map +0 -7
- package/dist/image-editor.js +0 -4151
- package/dist/image-editor.js.map +0 -7
- package/dist/image-editor.min.js +0 -9
- package/dist/image-editor.min.js.map +0 -7
- package/image-editor.d.ts +0 -269
- package/src/browser.js +0 -11
- package/src/esm.js +0 -9
- package/src/image-editor.js +0 -4775
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { isMaskObject } from '../core/public-types.js';
|
|
2
|
+
export function renderMaskList(context) {
|
|
3
|
+
const listId = context.getListElementId();
|
|
4
|
+
if (!listId)
|
|
5
|
+
return;
|
|
6
|
+
const listEl = document.getElementById(listId);
|
|
7
|
+
if (!listEl || !context.canvas)
|
|
8
|
+
return;
|
|
9
|
+
listEl.innerHTML = '';
|
|
10
|
+
const canvas = context.canvas;
|
|
11
|
+
canvas
|
|
12
|
+
.getObjects()
|
|
13
|
+
.filter(isMaskObject)
|
|
14
|
+
.forEach((mask) => {
|
|
15
|
+
const listItemElement = document.createElement('li');
|
|
16
|
+
listItemElement.className = 'list-group-item mask-item';
|
|
17
|
+
listItemElement.textContent = mask.maskName;
|
|
18
|
+
listItemElement.dataset.maskId = String(mask.maskId);
|
|
19
|
+
listItemElement.onclick = () => {
|
|
20
|
+
const id = Number(listItemElement.dataset.maskId);
|
|
21
|
+
if (!Number.isFinite(id))
|
|
22
|
+
return;
|
|
23
|
+
const target = canvas
|
|
24
|
+
.getObjects()
|
|
25
|
+
.find((o) => isMaskObject(o) && o.maskId === id);
|
|
26
|
+
if (!target)
|
|
27
|
+
return;
|
|
28
|
+
canvas.setActiveObject(target);
|
|
29
|
+
context.onMaskSelected(target);
|
|
30
|
+
};
|
|
31
|
+
listEl.appendChild(listItemElement);
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
export function updateMaskListSelection(context, selectedMask) {
|
|
35
|
+
const listId = context.getListElementId();
|
|
36
|
+
if (!listId)
|
|
37
|
+
return;
|
|
38
|
+
const listEl = document.getElementById(listId);
|
|
39
|
+
if (!listEl)
|
|
40
|
+
return;
|
|
41
|
+
const selectedId = selectedMask ? String(selectedMask.maskId) : null;
|
|
42
|
+
listEl.querySelectorAll('.mask-item').forEach((item) => {
|
|
43
|
+
const isSelected = selectedId !== null && item.dataset.maskId === selectedId;
|
|
44
|
+
item.classList.toggle('active', isSelected);
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=mask-list.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mask-list.js","sourceRoot":"","sources":["../../../src/mask/mask-list.ts"],"names":[],"mappings":"AA4DA,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAkEvD,MAAM,UAAU,cAAc,CAAC,OAAwB;IACnD,MAAM,MAAM,GAAG,OAAO,CAAC,gBAAgB,EAAE,CAAC;IAC1C,IAAI,CAAC,MAAM;QAAE,OAAO;IACpB,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;IAC/C,IAAI,CAAC,MAAM,IAAI,CAAC,OAAO,CAAC,MAAM;QAAE,OAAO;IAKvC,MAAM,CAAC,SAAS,GAAG,EAAE,CAAC;IAEtB,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAE9B,MAAM;SACD,UAAU,EAAE;SACZ,MAAM,CAAC,YAAY,CAAC;SACpB,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;QACd,MAAM,eAAe,GAAG,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QAGrD,eAAe,CAAC,SAAS,GAAG,2BAA2B,CAAC;QACxD,eAAe,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC;QAE5C,eAAe,CAAC,OAAO,CAAC,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAErD,eAAe,CAAC,OAAO,GAAG,GAAG,EAAE;YAK3B,MAAM,EAAE,GAAG,MAAM,CAAC,eAAe,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;YAClD,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAAE,OAAO;YACjC,MAAM,MAAM,GAAG,MAAM;iBAChB,UAAU,EAAE;iBACZ,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,MAAM,KAAK,EAAE,CAA2B,CAAC;YAC/E,IAAI,CAAC,MAAM;gBAAE,OAAO;YACpB,MAAM,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;YAC/B,OAAO,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;QACnC,CAAC,CAAC;QAEF,MAAM,CAAC,WAAW,CAAC,eAAe,CAAC,CAAC;IACxC,CAAC,CAAC,CAAC;AACX,CAAC;AAqBD,MAAM,UAAU,uBAAuB,CACnC,OAAwB,EACxB,YAA+B;IAE/B,MAAM,MAAM,GAAG,OAAO,CAAC,gBAAgB,EAAE,CAAC;IAC1C,IAAI,CAAC,MAAM;QAAE,OAAO;IACpB,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;IAC/C,IAAI,CAAC,MAAM;QAAE,OAAO;IAEpB,MAAM,UAAU,GAAG,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACrE,MAAM,CAAC,gBAAgB,CAAc,YAAY,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;QAChE,MAAM,UAAU,GAAG,UAAU,KAAK,IAAI,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,KAAK,UAAU,CAAC;QAC7E,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;IAChD,CAAC,CAAC,CAAC;AACP,CAAC"}
|
|
@@ -0,0 +1,182 @@
|
|
|
1
|
+
import { isMaskObject } from '../core/public-types.js';
|
|
2
|
+
const SELECTED_STROKE = '#ff0000';
|
|
3
|
+
const SELECTED_STROKE_WIDTH = 1;
|
|
4
|
+
const HOVER_STROKE = '#ff5500';
|
|
5
|
+
const HOVER_STROKE_WIDTH = 2;
|
|
6
|
+
const HOVER_OPACITY_BUMP = 0.2;
|
|
7
|
+
const DEFAULT_STROKE_FALLBACK = '#ccc';
|
|
8
|
+
const DEFAULT_STROKE_WIDTH_FALLBACK = 1;
|
|
9
|
+
const DEFAULT_ALPHA_FALLBACK = 0.5;
|
|
10
|
+
export function getMaskNormalStyle(mask) {
|
|
11
|
+
var _a;
|
|
12
|
+
const strokeWidth = Number(mask.originalStrokeWidth);
|
|
13
|
+
const opacity = Number(mask.originalAlpha);
|
|
14
|
+
return {
|
|
15
|
+
stroke: (_a = mask.originalStroke) !== null && _a !== void 0 ? _a : DEFAULT_STROKE_FALLBACK,
|
|
16
|
+
strokeWidth: Number.isFinite(strokeWidth) ? strokeWidth : DEFAULT_STROKE_WIDTH_FALLBACK,
|
|
17
|
+
opacity: Number.isFinite(opacity) ? opacity : DEFAULT_ALPHA_FALLBACK,
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
export function getMaskHoverStyle(mask) {
|
|
21
|
+
const opacity = Number(mask.originalAlpha);
|
|
22
|
+
const baseAlpha = Number.isFinite(opacity) ? opacity : DEFAULT_ALPHA_FALLBACK;
|
|
23
|
+
return {
|
|
24
|
+
stroke: HOVER_STROKE,
|
|
25
|
+
strokeWidth: HOVER_STROKE_WIDTH,
|
|
26
|
+
opacity: Math.min(baseAlpha + HOVER_OPACITY_BUMP, 1),
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
export function applyMaskSelectedStyle(mask) {
|
|
30
|
+
mask.set({ stroke: SELECTED_STROKE, strokeWidth: SELECTED_STROKE_WIDTH });
|
|
31
|
+
}
|
|
32
|
+
export function applyMaskUnselectedStyle(mask) {
|
|
33
|
+
var _a;
|
|
34
|
+
const strokeWidth = Number(mask.originalStrokeWidth);
|
|
35
|
+
mask.set({
|
|
36
|
+
stroke: (_a = mask.originalStroke) !== null && _a !== void 0 ? _a : DEFAULT_STROKE_FALLBACK,
|
|
37
|
+
strokeWidth: Number.isFinite(strokeWidth) ? strokeWidth : DEFAULT_STROKE_WIDTH_FALLBACK,
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
export function attachMaskHoverHandlers(mask) {
|
|
41
|
+
const tagged = mask;
|
|
42
|
+
const mouseover = () => {
|
|
43
|
+
var _a;
|
|
44
|
+
tagged.set(getMaskHoverStyle(tagged));
|
|
45
|
+
(_a = tagged.canvas) === null || _a === void 0 ? void 0 : _a.requestRenderAll();
|
|
46
|
+
};
|
|
47
|
+
const mouseout = () => {
|
|
48
|
+
var _a;
|
|
49
|
+
tagged.set(getMaskNormalStyle(tagged));
|
|
50
|
+
(_a = tagged.canvas) === null || _a === void 0 ? void 0 : _a.requestRenderAll();
|
|
51
|
+
};
|
|
52
|
+
tagged.on('mouseover', mouseover);
|
|
53
|
+
tagged.on('mouseout', mouseout);
|
|
54
|
+
tagged.imageEditorMaskHandlers = { mouseover, mouseout };
|
|
55
|
+
}
|
|
56
|
+
export function reattachMaskHoverHandlers(mask) {
|
|
57
|
+
var _a;
|
|
58
|
+
const tagged = mask;
|
|
59
|
+
if (tagged.imageEditorMaskHandlers) {
|
|
60
|
+
try {
|
|
61
|
+
tagged.off('mouseover', tagged.imageEditorMaskHandlers.mouseover);
|
|
62
|
+
tagged.off('mouseout', tagged.imageEditorMaskHandlers.mouseout);
|
|
63
|
+
}
|
|
64
|
+
catch {
|
|
65
|
+
}
|
|
66
|
+
delete tagged.imageEditorMaskHandlers;
|
|
67
|
+
}
|
|
68
|
+
const patch = {};
|
|
69
|
+
if (!Number.isFinite(Number(tagged.originalAlpha))) {
|
|
70
|
+
const opacity = Number(tagged.opacity);
|
|
71
|
+
patch.originalAlpha = Number.isFinite(opacity) ? opacity : DEFAULT_ALPHA_FALLBACK;
|
|
72
|
+
}
|
|
73
|
+
if (tagged.originalStroke == null) {
|
|
74
|
+
patch.originalStroke = (_a = tagged.stroke) !== null && _a !== void 0 ? _a : DEFAULT_STROKE_FALLBACK;
|
|
75
|
+
}
|
|
76
|
+
if (!Number.isFinite(Number(tagged.originalStrokeWidth))) {
|
|
77
|
+
const sw = Number(tagged.strokeWidth);
|
|
78
|
+
patch.originalStrokeWidth = Number.isFinite(sw) ? sw : DEFAULT_STROKE_WIDTH_FALLBACK;
|
|
79
|
+
}
|
|
80
|
+
if (Object.keys(patch).length > 0)
|
|
81
|
+
tagged.set(patch);
|
|
82
|
+
attachMaskHoverHandlers(tagged);
|
|
83
|
+
}
|
|
84
|
+
export function detachMaskHoverHandlers(mask) {
|
|
85
|
+
const tagged = mask;
|
|
86
|
+
if (!tagged.imageEditorMaskHandlers)
|
|
87
|
+
return;
|
|
88
|
+
try {
|
|
89
|
+
tagged.off('mouseover', tagged.imageEditorMaskHandlers.mouseover);
|
|
90
|
+
tagged.off('mouseout', tagged.imageEditorMaskHandlers.mouseout);
|
|
91
|
+
}
|
|
92
|
+
catch {
|
|
93
|
+
}
|
|
94
|
+
delete tagged.imageEditorMaskHandlers;
|
|
95
|
+
}
|
|
96
|
+
export function captureMaskStyleBackup(mask) {
|
|
97
|
+
var _a, _b, _c, _d, _e, _f, _g;
|
|
98
|
+
return {
|
|
99
|
+
object: mask,
|
|
100
|
+
opacity: (_a = mask.opacity) !== null && _a !== void 0 ? _a : 1,
|
|
101
|
+
fill: ((_b = mask.fill) !== null && _b !== void 0 ? _b : null),
|
|
102
|
+
strokeWidth: (_c = mask.strokeWidth) !== null && _c !== void 0 ? _c : 0,
|
|
103
|
+
stroke: ((_d = mask.stroke) !== null && _d !== void 0 ? _d : null),
|
|
104
|
+
selectable: (_e = mask.selectable) !== null && _e !== void 0 ? _e : true,
|
|
105
|
+
evented: (_f = mask.evented) !== null && _f !== void 0 ? _f : true,
|
|
106
|
+
lockRotation: (_g = mask.lockRotation) !== null && _g !== void 0 ? _g : false,
|
|
107
|
+
};
|
|
108
|
+
}
|
|
109
|
+
export function restoreMaskStyleBackup(backup) {
|
|
110
|
+
try {
|
|
111
|
+
backup.object.set({
|
|
112
|
+
opacity: backup.opacity,
|
|
113
|
+
fill: backup.fill,
|
|
114
|
+
strokeWidth: backup.strokeWidth,
|
|
115
|
+
stroke: backup.stroke,
|
|
116
|
+
selectable: backup.selectable,
|
|
117
|
+
evented: backup.evented,
|
|
118
|
+
lockRotation: backup.lockRotation,
|
|
119
|
+
});
|
|
120
|
+
if (typeof backup.object.setCoords === 'function') {
|
|
121
|
+
backup.object.setCoords();
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
catch {
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
export function withNormalizedMaskStyles(context, callback) {
|
|
128
|
+
if (!context.canvas)
|
|
129
|
+
return callback();
|
|
130
|
+
const masks = context.canvas.getObjects().filter(isMaskObject);
|
|
131
|
+
const patches = [];
|
|
132
|
+
try {
|
|
133
|
+
for (const mask of masks) {
|
|
134
|
+
const normal = getMaskNormalStyle(mask);
|
|
135
|
+
const snapshot = {};
|
|
136
|
+
const stylePatch = {};
|
|
137
|
+
Object.keys(normal).forEach((key) => {
|
|
138
|
+
const live = mask[key];
|
|
139
|
+
if (live !== normal[key]) {
|
|
140
|
+
snapshot[key] = live;
|
|
141
|
+
stylePatch[key] = normal[key];
|
|
142
|
+
}
|
|
143
|
+
});
|
|
144
|
+
if (Object.keys(stylePatch).length === 0)
|
|
145
|
+
continue;
|
|
146
|
+
patches.push({ object: mask, snapshot });
|
|
147
|
+
mask.set(stylePatch);
|
|
148
|
+
}
|
|
149
|
+
return callback();
|
|
150
|
+
}
|
|
151
|
+
finally {
|
|
152
|
+
for (const patch of patches) {
|
|
153
|
+
try {
|
|
154
|
+
patch.object.set(patch.snapshot);
|
|
155
|
+
}
|
|
156
|
+
catch {
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
export async function withMaskStyleBackup(context, mutator, callback) {
|
|
162
|
+
if (!context.canvas)
|
|
163
|
+
return await callback();
|
|
164
|
+
const masks = context.canvas.getObjects().filter(isMaskObject);
|
|
165
|
+
const backups = masks.map(captureMaskStyleBackup);
|
|
166
|
+
try {
|
|
167
|
+
masks.forEach((mask, index) => mutator(mask, index));
|
|
168
|
+
return await callback();
|
|
169
|
+
}
|
|
170
|
+
finally {
|
|
171
|
+
for (const backup of backups)
|
|
172
|
+
restoreMaskStyleBackup(backup);
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
export function applyCropHideMaskStyle(mask) {
|
|
176
|
+
try {
|
|
177
|
+
mask.set({ opacity: 0, evented: false, selectable: false });
|
|
178
|
+
}
|
|
179
|
+
catch {
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
//# sourceMappingURL=mask-style.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mask-style.js","sourceRoot":"","sources":["../../../src/mask/mask-style.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
export class DomBindings {
|
|
2
|
+
constructor(resolveElementId, isDisposed) {
|
|
3
|
+
Object.defineProperty(this, "registry", {
|
|
4
|
+
enumerable: true,
|
|
5
|
+
configurable: true,
|
|
6
|
+
writable: true,
|
|
7
|
+
value: []
|
|
8
|
+
});
|
|
9
|
+
Object.defineProperty(this, "resolveElementId", {
|
|
10
|
+
enumerable: true,
|
|
11
|
+
configurable: true,
|
|
12
|
+
writable: true,
|
|
13
|
+
value: void 0
|
|
14
|
+
});
|
|
15
|
+
Object.defineProperty(this, "isDisposed", {
|
|
16
|
+
enumerable: true,
|
|
17
|
+
configurable: true,
|
|
18
|
+
writable: true,
|
|
19
|
+
value: void 0
|
|
20
|
+
});
|
|
21
|
+
this.resolveElementId = resolveElementId;
|
|
22
|
+
this.isDisposed = isDisposed;
|
|
23
|
+
}
|
|
24
|
+
bindIfExists(key, eventType, handler) {
|
|
25
|
+
const id = this.resolveElementId(key);
|
|
26
|
+
if (!id)
|
|
27
|
+
return false;
|
|
28
|
+
const element = document.getElementById(id);
|
|
29
|
+
if (!element)
|
|
30
|
+
return false;
|
|
31
|
+
const wrapped = (event) => {
|
|
32
|
+
if (this.isDisposed())
|
|
33
|
+
return;
|
|
34
|
+
handler(event);
|
|
35
|
+
};
|
|
36
|
+
element.addEventListener(eventType, wrapped);
|
|
37
|
+
this.registry.push({ elementKey: key, eventType, handler: wrapped });
|
|
38
|
+
return true;
|
|
39
|
+
}
|
|
40
|
+
removeAll() {
|
|
41
|
+
for (const entry of this.registry) {
|
|
42
|
+
const id = this.resolveElementId(entry.elementKey);
|
|
43
|
+
if (!id)
|
|
44
|
+
continue;
|
|
45
|
+
const element = document.getElementById(id);
|
|
46
|
+
if (!element)
|
|
47
|
+
continue;
|
|
48
|
+
try {
|
|
49
|
+
element.removeEventListener(entry.eventType, entry.handler);
|
|
50
|
+
}
|
|
51
|
+
catch {
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
this.registry = [];
|
|
55
|
+
}
|
|
56
|
+
size() {
|
|
57
|
+
return this.registry.length;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=dom-bindings.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dom-bindings.js","sourceRoot":"","sources":["../../../src/ui/dom-bindings.ts"],"names":[],"mappings":"AA6EA,MAAM,OAAO,WAAW;IAapB,YACI,gBAAgE,EAChE,UAAyB;QAdrB;;;;mBAA2B,EAAE;WAAC;QACrB;;;;;WAAiE;QACjE;;;;;WAA0B;QAcvC,IAAI,CAAC,gBAAgB,GAAG,gBAAgB,CAAC;QACzC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;IACjC,CAAC;IAcD,YAAY,CAAC,GAAe,EAAE,SAAiB,EAAE,OAAsB;QACnE,MAAM,EAAE,GAAG,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC;QACtC,IAAI,CAAC,EAAE;YAAE,OAAO,KAAK,CAAC;QACtB,MAAM,OAAO,GAAG,QAAQ,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;QAC5C,IAAI,CAAC,OAAO;YAAE,OAAO,KAAK,CAAC;QAK3B,MAAM,OAAO,GAAkB,CAAC,KAAK,EAAE,EAAE;YACrC,IAAI,IAAI,CAAC,UAAU,EAAE;gBAAE,OAAO;YAC9B,OAAO,CAAC,KAAK,CAAC,CAAC;QACnB,CAAC,CAAC;QAEF,OAAO,CAAC,gBAAgB,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QAC7C,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,UAAU,EAAE,GAAG,EAAE,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC,CAAC;QACrE,OAAO,IAAI,CAAC;IAChB,CAAC;IASD,SAAS;QACL,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAChC,MAAM,EAAE,GAAG,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;YACnD,IAAI,CAAC,EAAE;gBAAE,SAAS;YAClB,MAAM,OAAO,GAAG,QAAQ,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;YAC5C,IAAI,CAAC,OAAO;gBAAE,SAAS;YACvB,IAAI,CAAC;gBACD,OAAO,CAAC,mBAAmB,CAAC,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;YAChE,CAAC;YAAC,MAAM,CAAC;YAGT,CAAC;QACL,CAAC;QACD,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACvB,CAAC;IAMD,IAAI;QACA,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC;IAChC,CAAC;CACJ"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
export function setDisabled(resolveElementId, key, disabled) {
|
|
2
|
+
const id = resolveElementId(key);
|
|
3
|
+
if (!id)
|
|
4
|
+
return;
|
|
5
|
+
const element = document.getElementById(id);
|
|
6
|
+
if (element)
|
|
7
|
+
element.disabled = disabled;
|
|
8
|
+
}
|
|
9
|
+
export function setAriaDisabled(resolveElementId, key, disabled) {
|
|
10
|
+
const id = resolveElementId(key);
|
|
11
|
+
if (!id)
|
|
12
|
+
return;
|
|
13
|
+
const element = document.getElementById(id);
|
|
14
|
+
if (element)
|
|
15
|
+
element.setAttribute('aria-disabled', disabled ? 'true' : 'false');
|
|
16
|
+
}
|
|
17
|
+
export function setClass(resolveElementId, key, className, enabled) {
|
|
18
|
+
const id = resolveElementId(key);
|
|
19
|
+
if (!id)
|
|
20
|
+
return;
|
|
21
|
+
const element = document.getElementById(id);
|
|
22
|
+
if (element)
|
|
23
|
+
element.classList.toggle(className, enabled);
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=ui-state.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ui-state.js","sourceRoot":"","sources":["../../../src/ui/ui-state.ts"],"names":[],"mappings":"AAgFA,MAAM,UAAU,WAAW,CACvB,gBAAmC,EACnC,GAAe,EACf,QAAiB;IAEjB,MAAM,EAAE,GAAG,gBAAgB,CAAC,GAAG,CAAC,CAAC;IACjC,IAAI,CAAC,EAAE;QAAE,OAAO;IAChB,MAAM,OAAO,GAAG,QAAQ,CAAC,cAAc,CAAC,EAAE,CAA6B,CAAC;IACxE,IAAI,OAAO;QAAE,OAAO,CAAC,QAAQ,GAAG,QAAQ,CAAC;AAC7C,CAAC;AAkBD,MAAM,UAAU,eAAe,CAC3B,gBAAmC,EACnC,GAAe,EACf,QAAiB;IAEjB,MAAM,EAAE,GAAG,gBAAgB,CAAC,GAAG,CAAC,CAAC;IACjC,IAAI,CAAC,EAAE;QAAE,OAAO;IAChB,MAAM,OAAO,GAAG,QAAQ,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;IAC5C,IAAI,OAAO;QAAE,OAAO,CAAC,YAAY,CAAC,eAAe,EAAE,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;AACpF,CAAC;AAkBD,MAAM,UAAU,QAAQ,CACpB,gBAAmC,EACnC,GAAe,EACf,SAAiB,EACjB,OAAgB;IAEhB,MAAM,EAAE,GAAG,gBAAgB,CAAC,GAAG,CAAC,CAAC;IACjC,IAAI,CAAC,EAAE;QAAE,OAAO;IAChB,MAAM,OAAO,GAAG,QAAQ,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;IAC5C,IAAI,OAAO;QAAE,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;AAC9D,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export function setPlaceholderVisible(placeholderElement, containerElement, show) {
|
|
2
|
+
if (placeholderElement) {
|
|
3
|
+
placeholderElement.hidden = !show;
|
|
4
|
+
placeholderElement.setAttribute('aria-hidden', show ? 'false' : 'true');
|
|
5
|
+
}
|
|
6
|
+
if (containerElement) {
|
|
7
|
+
containerElement.hidden = show;
|
|
8
|
+
containerElement.setAttribute('aria-hidden', show ? 'true' : 'false');
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=visibility-state.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"visibility-state.js","sourceRoot":"","sources":["../../../src/ui/visibility-state.ts"],"names":[],"mappings":"AA4EA,MAAM,UAAU,qBAAqB,CACjC,kBAAsC,EACtC,gBAAoC,EACpC,IAAa;IAIb,IAAI,kBAAkB,EAAE,CAAC;QACrB,kBAAkB,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC;QAClC,kBAAkB,CAAC,YAAY,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;IAC5E,CAAC;IAMD,IAAI,gBAAgB,EAAE,CAAC;QACnB,gBAAgB,CAAC,MAAM,GAAG,IAAI,CAAC;QAC/B,gBAAgB,CAAC,YAAY,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;IAC1E,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
export function hasMeaningfulCanvasRegion(rect, canvasWidth, canvasHeight) {
|
|
2
|
+
const left = Number(rect.left);
|
|
3
|
+
const top = Number(rect.top);
|
|
4
|
+
const width = Number(rect.width);
|
|
5
|
+
const height = Number(rect.height);
|
|
6
|
+
if (!Number.isFinite(left) ||
|
|
7
|
+
!Number.isFinite(top) ||
|
|
8
|
+
!Number.isFinite(width) ||
|
|
9
|
+
!Number.isFinite(height) ||
|
|
10
|
+
width <= 0 ||
|
|
11
|
+
height <= 0) {
|
|
12
|
+
return false;
|
|
13
|
+
}
|
|
14
|
+
const right = left + width;
|
|
15
|
+
const bottom = top + height;
|
|
16
|
+
if (!Number.isFinite(right) || !Number.isFinite(bottom))
|
|
17
|
+
return false;
|
|
18
|
+
const safeCanvasWidth = Number(canvasWidth);
|
|
19
|
+
const safeCanvasHeight = Number(canvasHeight);
|
|
20
|
+
if (!Number.isFinite(safeCanvasWidth) ||
|
|
21
|
+
!Number.isFinite(safeCanvasHeight) ||
|
|
22
|
+
safeCanvasWidth <= 0 ||
|
|
23
|
+
safeCanvasHeight <= 0) {
|
|
24
|
+
return true;
|
|
25
|
+
}
|
|
26
|
+
const overlapWidth = Math.min(right, safeCanvasWidth) - Math.max(left, 0);
|
|
27
|
+
const overlapHeight = Math.min(bottom, safeCanvasHeight) - Math.max(top, 0);
|
|
28
|
+
return overlapWidth > 0 && overlapHeight > 0;
|
|
29
|
+
}
|
|
30
|
+
export function getClampedCanvasRegion(rect, canvasWidth, canvasHeight, options = {}) {
|
|
31
|
+
const safeLeft = Number.isFinite(rect.left) ? rect.left : 0;
|
|
32
|
+
const safeTop = Number.isFinite(rect.top) ? rect.top : 0;
|
|
33
|
+
const safeWidth = Math.max(0, Number.isFinite(rect.width) ? rect.width : 0);
|
|
34
|
+
const safeHeight = Math.max(0, Number.isFinite(rect.height) ? rect.height : 0);
|
|
35
|
+
const includePartialPixels = options.includePartialPixels !== false;
|
|
36
|
+
const roundEnd = includePartialPixels ? Math.ceil : Math.floor;
|
|
37
|
+
const hasCanvasWidth = Number.isFinite(canvasWidth);
|
|
38
|
+
const hasCanvasHeight = Number.isFinite(canvasHeight);
|
|
39
|
+
const safeCanvasWidth = hasCanvasWidth
|
|
40
|
+
? Math.max(1, Math.round(Number(canvasWidth)))
|
|
41
|
+
: Number.POSITIVE_INFINITY;
|
|
42
|
+
const safeCanvasHeight = hasCanvasHeight
|
|
43
|
+
? Math.max(1, Math.round(Number(canvasHeight)))
|
|
44
|
+
: Number.POSITIVE_INFINITY;
|
|
45
|
+
const left = Math.min(safeCanvasWidth - 1, Math.max(0, Math.floor(safeLeft)));
|
|
46
|
+
const top = Math.min(safeCanvasHeight - 1, Math.max(0, Math.floor(safeTop)));
|
|
47
|
+
const right = Math.min(safeCanvasWidth, Math.max(left + 1, roundEnd(safeLeft + safeWidth)));
|
|
48
|
+
const bottom = Math.min(safeCanvasHeight, Math.max(top + 1, roundEnd(safeTop + safeHeight)));
|
|
49
|
+
return {
|
|
50
|
+
left,
|
|
51
|
+
top,
|
|
52
|
+
width: Math.max(1, right - left),
|
|
53
|
+
height: Math.max(1, bottom - top),
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
export function floorRegion(rect) {
|
|
57
|
+
return getClampedCanvasRegion(rect, undefined, undefined, { includePartialPixels: false });
|
|
58
|
+
}
|
|
59
|
+
export function hasFractionalCanvasEdge(value) {
|
|
60
|
+
const numericValue = Number(value);
|
|
61
|
+
if (!Number.isFinite(numericValue))
|
|
62
|
+
return false;
|
|
63
|
+
return Math.abs(numericValue - Math.round(numericValue)) > 0.01;
|
|
64
|
+
}
|
|
65
|
+
export function getPartialExportEdges(bounds, angle = 0) {
|
|
66
|
+
if (!bounds)
|
|
67
|
+
return null;
|
|
68
|
+
const normalizedAngle = Math.abs((Number(angle) || 0) % 90);
|
|
69
|
+
const isAxisAligned = normalizedAngle < 0.01 || Math.abs(normalizedAngle - 90) < 0.01;
|
|
70
|
+
if (!isAxisAligned)
|
|
71
|
+
return null;
|
|
72
|
+
const left = Number(bounds.left) || 0;
|
|
73
|
+
const top = Number(bounds.top) || 0;
|
|
74
|
+
return {
|
|
75
|
+
left: hasFractionalCanvasEdge(left),
|
|
76
|
+
top: hasFractionalCanvasEdge(top),
|
|
77
|
+
right: hasFractionalCanvasEdge(left + (Number(bounds.width) || 0)),
|
|
78
|
+
bottom: hasFractionalCanvasEdge(top + (Number(bounds.height) || 0)),
|
|
79
|
+
};
|
|
80
|
+
}
|
|
81
|
+
export function getObjectBBox(object) {
|
|
82
|
+
object.setCoords();
|
|
83
|
+
const boundingRect = object.getBoundingRect();
|
|
84
|
+
return {
|
|
85
|
+
left: boundingRect.left,
|
|
86
|
+
top: boundingRect.top,
|
|
87
|
+
width: boundingRect.width,
|
|
88
|
+
height: boundingRect.height,
|
|
89
|
+
};
|
|
90
|
+
}
|
|
91
|
+
export function clampRegionToCanvas(region, canvasWidth, canvasHeight) {
|
|
92
|
+
const safeCw = Math.max(1, Math.floor(Number.isFinite(canvasWidth) ? canvasWidth : 1));
|
|
93
|
+
const safeCh = Math.max(1, Math.floor(Number.isFinite(canvasHeight) ? canvasHeight : 1));
|
|
94
|
+
const left = Math.max(0, Math.min(region.left, safeCw - 1));
|
|
95
|
+
const top = Math.max(0, Math.min(region.top, safeCh - 1));
|
|
96
|
+
const width = Math.max(1, Math.min(region.width, safeCw - left));
|
|
97
|
+
const height = Math.max(1, Math.min(region.height, safeCh - top));
|
|
98
|
+
return { left, top, width, height };
|
|
99
|
+
}
|
|
100
|
+
//# sourceMappingURL=canvas-region.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"canvas-region.js","sourceRoot":"","sources":["../../../src/utils/canvas-region.ts"],"names":[],"mappings":"AA8FA,MAAM,UAAU,yBAAyB,CACrC,IAKC,EACD,WAAoB,EACpB,YAAqB;IAErB,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC/B,MAAM,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC7B,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACnC,IACI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC;QACtB,CAAC,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC;QACrB,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC;QACvB,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC;QACxB,KAAK,IAAI,CAAC;QACV,MAAM,IAAI,CAAC,EACb,CAAC;QACC,OAAO,KAAK,CAAC;IACjB,CAAC;IAED,MAAM,KAAK,GAAG,IAAI,GAAG,KAAK,CAAC;IAC3B,MAAM,MAAM,GAAG,GAAG,GAAG,MAAM,CAAC;IAC5B,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC;QAAE,OAAO,KAAK,CAAC;IAEtE,MAAM,eAAe,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;IAC5C,MAAM,gBAAgB,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC;IAC9C,IACI,CAAC,MAAM,CAAC,QAAQ,CAAC,eAAe,CAAC;QACjC,CAAC,MAAM,CAAC,QAAQ,CAAC,gBAAgB,CAAC;QAClC,eAAe,IAAI,CAAC;QACpB,gBAAgB,IAAI,CAAC,EACvB,CAAC;QACC,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,MAAM,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,eAAe,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;IAC1E,MAAM,aAAa,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,gBAAgB,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;IAC5E,OAAO,YAAY,GAAG,CAAC,IAAI,aAAa,GAAG,CAAC,CAAC;AACjD,CAAC;AAmBD,MAAM,UAAU,sBAAsB,CAClC,IAKC,EACD,WAAoB,EACpB,YAAqB,EACrB,UAAiC,EAAE;IAEnC,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5D,MAAM,OAAO,GAAG,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACzD,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5E,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/E,MAAM,oBAAoB,GAAG,OAAO,CAAC,oBAAoB,KAAK,KAAK,CAAC;IACpE,MAAM,QAAQ,GAAG,oBAAoB,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC;IAE/D,MAAM,cAAc,GAAG,MAAM,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;IACpD,MAAM,eAAe,GAAG,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;IACtD,MAAM,eAAe,GAAG,cAAc;QAClC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC;QAC9C,CAAC,CAAC,MAAM,CAAC,iBAAiB,CAAC;IAC/B,MAAM,gBAAgB,GAAG,eAAe;QACpC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC;QAC/C,CAAC,CAAC,MAAM,CAAC,iBAAiB,CAAC;IAE/B,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,eAAe,GAAG,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;IAC9E,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,gBAAgB,GAAG,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IAC7E,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,eAAe,EAAE,IAAI,CAAC,GAAG,CAAC,IAAI,GAAG,CAAC,EAAE,QAAQ,CAAC,QAAQ,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;IAC5F,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,gBAAgB,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,EAAE,QAAQ,CAAC,OAAO,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;IAE7F,OAAO;QACH,IAAI;QACJ,GAAG;QACH,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,GAAG,IAAI,CAAC;QAChC,MAAM,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,GAAG,GAAG,CAAC;KACpC,CAAC;AACN,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,IAK3B;IACG,OAAO,sBAAsB,CAAC,IAAI,EAAE,SAAS,EAAE,SAAS,EAAE,EAAE,oBAAoB,EAAE,KAAK,EAAE,CAAC,CAAC;AAC/F,CAAC;AAED,MAAM,UAAU,uBAAuB,CAAC,KAAa;IACjD,MAAM,YAAY,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IACnC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC;QAAE,OAAO,KAAK,CAAC;IACjD,OAAO,IAAI,CAAC,GAAG,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,GAAG,IAAI,CAAC;AACpE,CAAC;AAED,MAAM,UAAU,qBAAqB,CACjC,MAA2E,EAC3E,KAAK,GAAG,CAAC;IAET,IAAI,CAAC,MAAM;QAAE,OAAO,IAAI,CAAC;IACzB,MAAM,eAAe,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC;IAC5D,MAAM,aAAa,GAAG,eAAe,GAAG,IAAI,IAAI,IAAI,CAAC,GAAG,CAAC,eAAe,GAAG,EAAE,CAAC,GAAG,IAAI,CAAC;IACtF,IAAI,CAAC,aAAa;QAAE,OAAO,IAAI,CAAC;IAEhC,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACtC,MAAM,GAAG,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IACpC,OAAO;QACH,IAAI,EAAE,uBAAuB,CAAC,IAAI,CAAC;QACnC,GAAG,EAAE,uBAAuB,CAAC,GAAG,CAAC;QACjC,KAAK,EAAE,uBAAuB,CAAC,IAAI,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC;QAClE,MAAM,EAAE,uBAAuB,CAAC,GAAG,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;KACtE,CAAC;AACN,CAAC;AAmBD,MAAM,UAAU,aAAa,CAAC,MAA6B;IAMvD,MAAM,CAAC,SAAS,EAAE,CAAC;IACnB,MAAM,YAAY,GAAG,MAAM,CAAC,eAAe,EAAE,CAAC;IAC9C,OAAO;QACH,IAAI,EAAE,YAAY,CAAC,IAAI;QACvB,GAAG,EAAE,YAAY,CAAC,GAAG;QACrB,KAAK,EAAE,YAAY,CAAC,KAAK;QACzB,MAAM,EAAE,YAAY,CAAC,MAAM;KAC9B,CAAC;AACN,CAAC;AAuBD,MAAM,UAAU,mBAAmB,CAC/B,MAAqB,EACrB,WAAmB,EACnB,YAAoB;IAEpB,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACvF,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAEzF,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;IAC5D,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;IAC1D,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC,CAAC,CAAC;IACjE,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,GAAG,CAAC,CAAC,CAAC;IAClE,OAAO,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC;AACxC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dom.js","sourceRoot":"","sources":["../../../src/utils/dom.ts"],"names":[],"mappings":"AAyBA,MAAM,UAAU,WAAW,CAAC,OAAuC;IAC/D,IAAI,CAAC,OAAO;QAAE,OAAO;IAIrB,KAAK,OAAO,CAAC,WAAW,CAAC;AAC7B,CAAC"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
export const SUPPORTED_IMAGE_EXTENSIONS = {
|
|
2
|
+
png: 'image/png',
|
|
3
|
+
jpg: 'image/jpeg',
|
|
4
|
+
jpeg: 'image/jpeg',
|
|
5
|
+
webp: 'image/webp',
|
|
6
|
+
gif: 'image/gif',
|
|
7
|
+
bmp: 'image/bmp',
|
|
8
|
+
};
|
|
9
|
+
export const SUPPORTED_IMAGE_MIME_TYPES = new Set(Object.values(SUPPORTED_IMAGE_EXTENSIONS));
|
|
10
|
+
export function inferImageMimeType(file) {
|
|
11
|
+
var _a, _b;
|
|
12
|
+
if (file.type && SUPPORTED_IMAGE_MIME_TYPES.has(file.type))
|
|
13
|
+
return file.type;
|
|
14
|
+
if (file.type)
|
|
15
|
+
return null;
|
|
16
|
+
const match = /\.([a-z0-9]+)$/i.exec(file.name);
|
|
17
|
+
const ext = (_a = match === null || match === void 0 ? void 0 : match[1]) === null || _a === void 0 ? void 0 : _a.toLowerCase();
|
|
18
|
+
if (!ext)
|
|
19
|
+
return null;
|
|
20
|
+
return (_b = SUPPORTED_IMAGE_EXTENSIONS[ext]) !== null && _b !== void 0 ? _b : null;
|
|
21
|
+
}
|
|
22
|
+
export function readFileAsDataUrl(file) {
|
|
23
|
+
return new Promise((resolve, reject) => {
|
|
24
|
+
const reader = new FileReader();
|
|
25
|
+
reader.onload = () => {
|
|
26
|
+
const fileReaderResult = reader.result;
|
|
27
|
+
if (typeof fileReaderResult === 'string') {
|
|
28
|
+
resolve(fileReaderResult);
|
|
29
|
+
}
|
|
30
|
+
else {
|
|
31
|
+
reject(new Error('FileReader returned a non-string result'));
|
|
32
|
+
}
|
|
33
|
+
};
|
|
34
|
+
reader.onerror = () => {
|
|
35
|
+
var _a;
|
|
36
|
+
reject((_a = reader.error) !== null && _a !== void 0 ? _a : new Error('FileReader error'));
|
|
37
|
+
};
|
|
38
|
+
reader.onabort = () => {
|
|
39
|
+
reject(new Error('FileReader read aborted'));
|
|
40
|
+
};
|
|
41
|
+
reader.readAsDataURL(file);
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
export function resetFileInput(input) {
|
|
45
|
+
if (!input)
|
|
46
|
+
return;
|
|
47
|
+
try {
|
|
48
|
+
input.value = '';
|
|
49
|
+
}
|
|
50
|
+
catch {
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
//# sourceMappingURL=file.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"file.js","sourceRoot":"","sources":["../../../src/utils/file.ts"],"names":[],"mappings":"AA8BA,MAAM,CAAC,MAAM,0BAA0B,GAA2B;IAC9D,GAAG,EAAE,WAAW;IAChB,GAAG,EAAE,YAAY;IACjB,IAAI,EAAE,YAAY;IAClB,IAAI,EAAE,YAAY;IAClB,GAAG,EAAE,WAAW;IAChB,GAAG,EAAE,WAAW;CACnB,CAAC;AAEF,MAAM,CAAC,MAAM,0BAA0B,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,0BAA0B,CAAC,CAAC,CAAC;AAqB7F,MAAM,UAAU,kBAAkB,CAAC,IAAU;;IACzC,IAAI,IAAI,CAAC,IAAI,IAAI,0BAA0B,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC;QAAE,OAAO,IAAI,CAAC,IAAI,CAAC;IAC7E,IAAI,IAAI,CAAC,IAAI;QAAE,OAAO,IAAI,CAAC;IAC3B,MAAM,KAAK,GAAG,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAChD,MAAM,GAAG,GAAG,MAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAG,CAAC,CAAC,0CAAE,WAAW,EAAE,CAAC;IACtC,IAAI,CAAC,GAAG;QAAE,OAAO,IAAI,CAAC;IACtB,OAAO,MAAA,0BAA0B,CAAC,GAAG,CAAC,mCAAI,IAAI,CAAC;AACnD,CAAC;AAeD,MAAM,UAAU,iBAAiB,CAAC,IAAU;IACxC,OAAO,IAAI,OAAO,CAAS,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QAC3C,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;QAChC,MAAM,CAAC,MAAM,GAAG,GAAG,EAAE;YACjB,MAAM,gBAAgB,GAAG,MAAM,CAAC,MAAM,CAAC;YACvC,IAAI,OAAO,gBAAgB,KAAK,QAAQ,EAAE,CAAC;gBACvC,OAAO,CAAC,gBAAgB,CAAC,CAAC;YAC9B,CAAC;iBAAM,CAAC;gBACJ,MAAM,CAAC,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAC,CAAC;YACjE,CAAC;QACL,CAAC,CAAC;QACF,MAAM,CAAC,OAAO,GAAG,GAAG,EAAE;;YAClB,MAAM,CAAC,MAAA,MAAM,CAAC,KAAK,mCAAI,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAAC,CAAC;QAC1D,CAAC,CAAC;QACF,MAAM,CAAC,OAAO,GAAG,GAAG,EAAE;YAClB,MAAM,CAAC,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC,CAAC;QACjD,CAAC,CAAC;QACF,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;AACP,CAAC;AAeD,MAAM,UAAU,cAAc,CAAC,KAA8B;IACzD,IAAI,CAAC,KAAK;QAAE,OAAO;IACnB,IAAI,CAAC;QACD,KAAK,CAAC,KAAK,GAAG,EAAE,CAAC;IACrB,CAAC;IAAC,MAAM,CAAC;IAET,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
export function resolveNumeric(val, axis, fallback, canvas, options) {
|
|
2
|
+
if (typeof val === 'number') {
|
|
3
|
+
return val;
|
|
4
|
+
}
|
|
5
|
+
if (typeof val === 'function') {
|
|
6
|
+
return val(canvas, options);
|
|
7
|
+
}
|
|
8
|
+
if (typeof val === 'string' && val.endsWith('%')) {
|
|
9
|
+
const pct = parseFloat(val);
|
|
10
|
+
if (!Number.isFinite(pct)) {
|
|
11
|
+
return fallback;
|
|
12
|
+
}
|
|
13
|
+
const dim = axis === 'x' ? canvas.getWidth() : canvas.getHeight();
|
|
14
|
+
return Math.floor(dim * (pct / 100));
|
|
15
|
+
}
|
|
16
|
+
return fallback;
|
|
17
|
+
}
|
|
18
|
+
export function coercePoint(pt) {
|
|
19
|
+
if (Array.isArray(pt)) {
|
|
20
|
+
return { x: Number(pt[0]), y: Number(pt[1]) };
|
|
21
|
+
}
|
|
22
|
+
return { x: Number(pt.x), y: Number(pt.y) };
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=number.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"number.js","sourceRoot":"","sources":["../../../src/utils/number.ts"],"names":[],"mappings":"AA4GA,MAAM,UAAU,cAAc,CAC1B,GAAgC,EAChC,IAAU,EACV,QAAgB,EAChB,MAAuB,EACvB,OAAwB;IAExB,IAAI,OAAO,GAAG,KAAK,QAAQ,EAAE,CAAC;QAC1B,OAAO,GAAG,CAAC;IACf,CAAC;IACD,IAAI,OAAO,GAAG,KAAK,UAAU,EAAE,CAAC;QAC5B,OAAO,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAChC,CAAC;IACD,IAAI,OAAO,GAAG,KAAK,QAAQ,IAAI,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;QAC/C,MAAM,GAAG,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC;QAC5B,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;YACxB,OAAO,QAAQ,CAAC;QACpB,CAAC;QACD,MAAM,GAAG,GAAG,IAAI,KAAK,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC;QAClE,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IACzC,CAAC;IACD,OAAO,QAAQ,CAAC;AACpB,CAAC;AAuBD,MAAM,UAAU,WAAW,CAAC,EAAgB;IACxC,IAAI,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC;QACpB,OAAO,EAAE,CAAC,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IAClD,CAAC;IACD,OAAO,EAAE,CAAC,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;AAChD,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { ImageLoadTimeoutError } from '../core/errors.js';
|
|
2
|
+
export function withTimeout(promise, ms, label) {
|
|
3
|
+
return new Promise((resolve, reject) => {
|
|
4
|
+
const start = Date.now();
|
|
5
|
+
const timeoutId = setTimeout(() => {
|
|
6
|
+
reject(new ImageLoadTimeoutError(label, Date.now() - start));
|
|
7
|
+
}, ms);
|
|
8
|
+
promise.then((value) => {
|
|
9
|
+
clearTimeout(timeoutId);
|
|
10
|
+
resolve(value);
|
|
11
|
+
}, (err) => {
|
|
12
|
+
clearTimeout(timeoutId);
|
|
13
|
+
reject(err);
|
|
14
|
+
});
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=timeout.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"timeout.js","sourceRoot":"","sources":["../../../src/utils/timeout.ts"],"names":[],"mappings":"AAkDA,OAAO,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAC;AAmC1D,MAAM,UAAU,WAAW,CAAI,OAAmB,EAAE,EAAU,EAAE,KAAa;IACzE,OAAO,IAAI,OAAO,CAAI,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACtC,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACzB,MAAM,SAAS,GAAG,UAAU,CAAC,GAAG,EAAE;YAC9B,MAAM,CAAC,IAAI,qBAAqB,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,CAAC,CAAC,CAAC;QACjE,CAAC,EAAE,EAAE,CAAC,CAAC;QAEP,OAAO,CAAC,IAAI,CACR,CAAC,KAAK,EAAE,EAAE;YACN,YAAY,CAAC,SAAS,CAAC,CAAC;YACxB,OAAO,CAAC,KAAK,CAAC,CAAC;QACnB,CAAC,EACD,CAAC,GAAY,EAAE,EAAE;YACb,YAAY,CAAC,SAAS,CAAC,CAAC;YACxB,MAAM,CAAC,GAAG,CAAC,CAAC;QAChB,CAAC,CACJ,CAAC;IACN,CAAC,CAAC,CAAC;AACP,CAAC"}
|