@bensitu/image-editor 1.5.2 → 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 +367 -518
- 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 -4407
- package/dist/image-editor.cjs.map +0 -7
- package/dist/image-editor.esm.js +0 -4376
- 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 -4376
- package/dist/image-editor.esm.mjs.map +0 -7
- package/dist/image-editor.js +0 -4373
- 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 -271
- package/src/browser.js +0 -11
- package/src/esm.js +0 -9
- package/src/image-editor.js +0 -5013
|
@@ -0,0 +1,224 @@
|
|
|
1
|
+
import { forceReflow } from '../utils/dom.js';
|
|
2
|
+
export function selectLayoutStrategy(options) {
|
|
3
|
+
if (options.fitImageToCanvas)
|
|
4
|
+
return 'fit';
|
|
5
|
+
if (options.coverImageToCanvas)
|
|
6
|
+
return 'cover';
|
|
7
|
+
return 'expand';
|
|
8
|
+
}
|
|
9
|
+
export function detectLayoutConflict(options) {
|
|
10
|
+
if (!options.fitImageToCanvas || !options.coverImageToCanvas)
|
|
11
|
+
return null;
|
|
12
|
+
const enabled = ['fit', 'cover'];
|
|
13
|
+
if (options.expandCanvasToImage)
|
|
14
|
+
enabled.push('expand');
|
|
15
|
+
const selected = selectLayoutStrategy(options);
|
|
16
|
+
return {
|
|
17
|
+
enabled,
|
|
18
|
+
selected,
|
|
19
|
+
message: `Layout flags ${enabled.map((s) => `\`${s}\``).join(', ')} are enabled simultaneously. ` +
|
|
20
|
+
`Using precedence \`fit > cover > expand\`; selected \`${selected}\`.`,
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
export class ViewportCache {
|
|
24
|
+
constructor() {
|
|
25
|
+
Object.defineProperty(this, "lastVisible", {
|
|
26
|
+
enumerable: true,
|
|
27
|
+
configurable: true,
|
|
28
|
+
writable: true,
|
|
29
|
+
value: null
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
measure(container, fallback, scrollbarSize) {
|
|
33
|
+
var _a;
|
|
34
|
+
if (!container)
|
|
35
|
+
return fallback;
|
|
36
|
+
const containerWidth = Math.floor(container.clientWidth);
|
|
37
|
+
const containerHeight = Math.floor(container.clientHeight);
|
|
38
|
+
if (containerWidth > 0 && containerHeight > 0) {
|
|
39
|
+
this.lastVisible = measureContainerViewport(container, fallback, scrollbarSize);
|
|
40
|
+
return this.lastVisible;
|
|
41
|
+
}
|
|
42
|
+
return (_a = this.lastVisible) !== null && _a !== void 0 ? _a : fallback;
|
|
43
|
+
}
|
|
44
|
+
peek() {
|
|
45
|
+
return this.lastVisible;
|
|
46
|
+
}
|
|
47
|
+
clear() {
|
|
48
|
+
this.lastVisible = null;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
const OVERFLOW_EPSILON = 0.5;
|
|
52
|
+
function normalizeOverflowValue(value) {
|
|
53
|
+
return String(value !== null && value !== void 0 ? value : '')
|
|
54
|
+
.trim()
|
|
55
|
+
.toLowerCase();
|
|
56
|
+
}
|
|
57
|
+
function getContainerOverflowValues(container) {
|
|
58
|
+
var _a, _b;
|
|
59
|
+
const style = container.style;
|
|
60
|
+
let computedOverflow = '';
|
|
61
|
+
let computedOverflowX = '';
|
|
62
|
+
let computedOverflowY = '';
|
|
63
|
+
const view = (_b = (_a = container.ownerDocument) === null || _a === void 0 ? void 0 : _a.defaultView) !== null && _b !== void 0 ? _b : (typeof window === 'undefined' ? null : window);
|
|
64
|
+
if (typeof (view === null || view === void 0 ? void 0 : view.getComputedStyle) === 'function') {
|
|
65
|
+
const computed = view.getComputedStyle(container);
|
|
66
|
+
computedOverflow = computed.overflow;
|
|
67
|
+
computedOverflowX = computed.overflowX;
|
|
68
|
+
computedOverflowY = computed.overflowY;
|
|
69
|
+
}
|
|
70
|
+
const x = [
|
|
71
|
+
normalizeOverflowValue(style === null || style === void 0 ? void 0 : style.overflow),
|
|
72
|
+
normalizeOverflowValue(style === null || style === void 0 ? void 0 : style.overflowX),
|
|
73
|
+
normalizeOverflowValue(computedOverflow),
|
|
74
|
+
normalizeOverflowValue(computedOverflowX),
|
|
75
|
+
];
|
|
76
|
+
const y = [
|
|
77
|
+
normalizeOverflowValue(style === null || style === void 0 ? void 0 : style.overflow),
|
|
78
|
+
normalizeOverflowValue(style === null || style === void 0 ? void 0 : style.overflowY),
|
|
79
|
+
normalizeOverflowValue(computedOverflow),
|
|
80
|
+
normalizeOverflowValue(computedOverflowY),
|
|
81
|
+
];
|
|
82
|
+
return { x, y, all: [...x, ...y] };
|
|
83
|
+
}
|
|
84
|
+
function isAutoScrollableOverflow(value) {
|
|
85
|
+
return value === 'auto' || value === 'overlay';
|
|
86
|
+
}
|
|
87
|
+
export function measureScrollbarSize(ownerDocument) {
|
|
88
|
+
const doc = ownerDocument !== null && ownerDocument !== void 0 ? ownerDocument : (typeof document === 'undefined' ? null : document);
|
|
89
|
+
if (!(doc === null || doc === void 0 ? void 0 : doc.body))
|
|
90
|
+
return { width: 0, height: 0 };
|
|
91
|
+
const probe = doc.createElement('div');
|
|
92
|
+
probe.style.position = 'absolute';
|
|
93
|
+
probe.style.left = '-9999px';
|
|
94
|
+
probe.style.top = '-9999px';
|
|
95
|
+
probe.style.width = '100px';
|
|
96
|
+
probe.style.height = '100px';
|
|
97
|
+
probe.style.overflow = 'scroll';
|
|
98
|
+
probe.style.visibility = 'hidden';
|
|
99
|
+
probe.style.pointerEvents = 'none';
|
|
100
|
+
doc.body.appendChild(probe);
|
|
101
|
+
const width = Math.max(0, probe.offsetWidth - probe.clientWidth);
|
|
102
|
+
const height = Math.max(0, probe.offsetHeight - probe.clientHeight);
|
|
103
|
+
probe.remove();
|
|
104
|
+
return { width, height };
|
|
105
|
+
}
|
|
106
|
+
function normalizeScrollbarSize(scrollbarSize) {
|
|
107
|
+
return {
|
|
108
|
+
width: Math.max(0, Number(scrollbarSize === null || scrollbarSize === void 0 ? void 0 : scrollbarSize.width) || 0),
|
|
109
|
+
height: Math.max(0, Number(scrollbarSize === null || scrollbarSize === void 0 ? void 0 : scrollbarSize.height) || 0),
|
|
110
|
+
};
|
|
111
|
+
}
|
|
112
|
+
export function measureContainerViewport(container, fallback, scrollbarSize) {
|
|
113
|
+
if (!container)
|
|
114
|
+
return fallback;
|
|
115
|
+
const clientWidth = Math.floor(container.clientWidth || 0);
|
|
116
|
+
const clientHeight = Math.floor(container.clientHeight || 0);
|
|
117
|
+
if (clientWidth <= 0 || clientHeight <= 0)
|
|
118
|
+
return fallback;
|
|
119
|
+
const overflow = getContainerOverflowValues(container);
|
|
120
|
+
if (overflow.all.includes('scroll')) {
|
|
121
|
+
return { width: clientWidth, height: clientHeight };
|
|
122
|
+
}
|
|
123
|
+
const scrollbar = normalizeScrollbarSize(scrollbarSize);
|
|
124
|
+
const canAutoScrollX = overflow.x.some(isAutoScrollableOverflow);
|
|
125
|
+
const canAutoScrollY = overflow.y.some(isAutoScrollableOverflow);
|
|
126
|
+
const scrollWidth = Math.ceil(container.scrollWidth || 0);
|
|
127
|
+
const scrollHeight = Math.ceil(container.scrollHeight || 0);
|
|
128
|
+
const hasHorizontalScrollbar = canAutoScrollX && scrollWidth > clientWidth + OVERFLOW_EPSILON;
|
|
129
|
+
const hasVerticalScrollbar = canAutoScrollY && scrollHeight > clientHeight + OVERFLOW_EPSILON;
|
|
130
|
+
return {
|
|
131
|
+
width: clientWidth + (hasVerticalScrollbar ? scrollbar.width : 0),
|
|
132
|
+
height: clientHeight + (hasHorizontalScrollbar ? scrollbar.height : 0),
|
|
133
|
+
};
|
|
134
|
+
}
|
|
135
|
+
export function computeScrollableCanvasSize(contentWidth, contentHeight, viewport, scrollbarSize) {
|
|
136
|
+
const viewportW = Math.max(1, viewport.width || 1);
|
|
137
|
+
const viewportH = Math.max(1, viewport.height || 1);
|
|
138
|
+
const scrollbar = normalizeScrollbarSize(scrollbarSize);
|
|
139
|
+
let hasHorizontal = false;
|
|
140
|
+
let hasVertical = false;
|
|
141
|
+
for (let i = 0; i < 4; i += 1) {
|
|
142
|
+
const effectiveW = Math.max(1, viewportW - (hasVertical ? scrollbar.width : 0));
|
|
143
|
+
const effectiveH = Math.max(1, viewportH - (hasHorizontal ? scrollbar.height : 0));
|
|
144
|
+
const nextHorizontal = contentWidth > effectiveW + OVERFLOW_EPSILON;
|
|
145
|
+
const nextVertical = contentHeight > effectiveH + OVERFLOW_EPSILON;
|
|
146
|
+
if (nextHorizontal === hasHorizontal && nextVertical === hasVertical)
|
|
147
|
+
break;
|
|
148
|
+
hasHorizontal = nextHorizontal;
|
|
149
|
+
hasVertical = nextVertical;
|
|
150
|
+
}
|
|
151
|
+
const effectiveW = Math.max(1, viewportW - (hasVertical ? scrollbar.width : 0));
|
|
152
|
+
const effectiveH = Math.max(1, viewportH - (hasHorizontal ? scrollbar.height : 0));
|
|
153
|
+
return {
|
|
154
|
+
width: hasHorizontal ? Math.ceil(contentWidth) : effectiveW,
|
|
155
|
+
height: hasVertical ? Math.ceil(contentHeight) : effectiveH,
|
|
156
|
+
};
|
|
157
|
+
}
|
|
158
|
+
export function computeFitLayout(imageWidth, imageHeight, optionsCanvasWidth, optionsCanvasHeight, containerSize) {
|
|
159
|
+
const canvasWidth = Math.max(1, (containerSize.width || optionsCanvasWidth) - 1);
|
|
160
|
+
const canvasHeight = Math.max(1, (containerSize.height || optionsCanvasHeight) - 1);
|
|
161
|
+
const fitScale = Math.min(canvasWidth / imageWidth, canvasHeight / imageHeight, 1);
|
|
162
|
+
return {
|
|
163
|
+
canvasWidth,
|
|
164
|
+
canvasHeight,
|
|
165
|
+
imageScale: fitScale,
|
|
166
|
+
imageLeft: 0,
|
|
167
|
+
imageTop: 0,
|
|
168
|
+
baseImageScale: fitScale,
|
|
169
|
+
};
|
|
170
|
+
}
|
|
171
|
+
export function computeCoverLayout(imageWidth, imageHeight, optionsCanvasWidth, optionsCanvasHeight, containerSize, scrollbarSize) {
|
|
172
|
+
const viewportW = containerSize.width || optionsCanvasWidth;
|
|
173
|
+
const viewportH = containerSize.height || optionsCanvasHeight;
|
|
174
|
+
const scrollbar = normalizeScrollbarSize(scrollbarSize);
|
|
175
|
+
let hasHorizontal = false;
|
|
176
|
+
let hasVertical = false;
|
|
177
|
+
let coverScale = 1;
|
|
178
|
+
let scaledW = imageWidth;
|
|
179
|
+
let scaledH = imageHeight;
|
|
180
|
+
for (let i = 0; i < 4; i += 1) {
|
|
181
|
+
const effectiveW = Math.max(1, viewportW - (hasVertical ? scrollbar.width : 0));
|
|
182
|
+
const effectiveH = Math.max(1, viewportH - (hasHorizontal ? scrollbar.height : 0));
|
|
183
|
+
coverScale = Math.min(1, Math.max(effectiveW / imageWidth, effectiveH / imageHeight));
|
|
184
|
+
scaledW = imageWidth * coverScale;
|
|
185
|
+
scaledH = imageHeight * coverScale;
|
|
186
|
+
const nextHasHorizontal = scaledW > effectiveW + OVERFLOW_EPSILON;
|
|
187
|
+
const nextHasVertical = scaledH > effectiveH + OVERFLOW_EPSILON;
|
|
188
|
+
if (nextHasHorizontal === hasHorizontal && nextHasVertical === hasVertical)
|
|
189
|
+
break;
|
|
190
|
+
hasHorizontal = nextHasHorizontal;
|
|
191
|
+
hasVertical = nextHasVertical;
|
|
192
|
+
}
|
|
193
|
+
const canvasSize = computeScrollableCanvasSize(scaledW, scaledH, {
|
|
194
|
+
width: viewportW,
|
|
195
|
+
height: viewportH,
|
|
196
|
+
}, scrollbar);
|
|
197
|
+
return {
|
|
198
|
+
canvasWidth: canvasSize.width,
|
|
199
|
+
canvasHeight: canvasSize.height,
|
|
200
|
+
imageScale: coverScale,
|
|
201
|
+
imageLeft: 0,
|
|
202
|
+
imageTop: 0,
|
|
203
|
+
baseImageScale: coverScale,
|
|
204
|
+
};
|
|
205
|
+
}
|
|
206
|
+
export function computeExpandLayout(imageWidth, imageHeight, optionsCanvasWidth, optionsCanvasHeight, containerSize) {
|
|
207
|
+
const canvasWidth = Math.max(containerSize.width, Math.floor(imageWidth));
|
|
208
|
+
const canvasHeight = Math.max(containerSize.height, Math.floor(imageHeight));
|
|
209
|
+
return {
|
|
210
|
+
canvasWidth,
|
|
211
|
+
canvasHeight,
|
|
212
|
+
imageScale: 1,
|
|
213
|
+
imageLeft: 0,
|
|
214
|
+
imageTop: 0,
|
|
215
|
+
baseImageScale: 1,
|
|
216
|
+
};
|
|
217
|
+
}
|
|
218
|
+
export function applyCanvasDimensions(canvas, width, height, containerElement) {
|
|
219
|
+
const integerWidth = Math.max(1, Math.round(Number(width) || 1));
|
|
220
|
+
const integerHeight = Math.max(1, Math.round(Number(height) || 1));
|
|
221
|
+
canvas.setDimensions({ width: integerWidth, height: integerHeight });
|
|
222
|
+
forceReflow(containerElement);
|
|
223
|
+
}
|
|
224
|
+
//# sourceMappingURL=layout-manager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"layout-manager.js","sourceRoot":"","sources":["../../../src/image/layout-manager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
import { animateProps, restoreOrigin } from '../fabric/fabric-animation.js';
|
|
2
|
+
export class TransformController {
|
|
3
|
+
constructor(context) {
|
|
4
|
+
Object.defineProperty(this, "context", {
|
|
5
|
+
enumerable: true,
|
|
6
|
+
configurable: true,
|
|
7
|
+
writable: true,
|
|
8
|
+
value: void 0
|
|
9
|
+
});
|
|
10
|
+
this.context = context;
|
|
11
|
+
}
|
|
12
|
+
async scaleImage(factor) {
|
|
13
|
+
if (!Number.isFinite(factor))
|
|
14
|
+
return;
|
|
15
|
+
const imageObject = this.context.getOriginalImage();
|
|
16
|
+
if (!imageObject)
|
|
17
|
+
return;
|
|
18
|
+
if (this.context.guard.isAnimating())
|
|
19
|
+
return;
|
|
20
|
+
if (this.context.guard.isDisposed())
|
|
21
|
+
return;
|
|
22
|
+
const clamped = Math.max(this.context.options.minScale, Math.min(this.context.options.maxScale, factor));
|
|
23
|
+
this.context.setCurrentScale(clamped);
|
|
24
|
+
const targetAbs = this.context.getBaseImageScale() * clamped;
|
|
25
|
+
try {
|
|
26
|
+
const topLeft = computeTopLeftPoint(imageObject);
|
|
27
|
+
imageObject.set({ originX: 'left', originY: 'top' });
|
|
28
|
+
imageObject.setPositionByOrigin(topLeft, 'left', 'top');
|
|
29
|
+
imageObject.setCoords();
|
|
30
|
+
}
|
|
31
|
+
catch (error) {
|
|
32
|
+
console.warn('[ImageEditor] scaleImage: origin pre-anchor failed', error);
|
|
33
|
+
}
|
|
34
|
+
try {
|
|
35
|
+
await this.context.guard.runAnimation(() => animateProps(imageObject, { scaleX: targetAbs, scaleY: targetAbs }, {
|
|
36
|
+
duration: this.context.options.animationDuration,
|
|
37
|
+
onChange: () => this.context.canvas.requestRenderAll(),
|
|
38
|
+
}, this.context.guard));
|
|
39
|
+
}
|
|
40
|
+
catch (error) {
|
|
41
|
+
console.warn('[ImageEditor] scaleImage animation error', error);
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
if (this.context.guard.isDisposed())
|
|
45
|
+
return;
|
|
46
|
+
imageObject.set({ scaleX: targetAbs, scaleY: targetAbs });
|
|
47
|
+
imageObject.setCoords();
|
|
48
|
+
if (this.context.afterTransformSnap)
|
|
49
|
+
this.context.afterTransformSnap();
|
|
50
|
+
this.context.saveCanvasState();
|
|
51
|
+
}
|
|
52
|
+
async rotateImage(degrees) {
|
|
53
|
+
if (!Number.isFinite(degrees))
|
|
54
|
+
return;
|
|
55
|
+
const imageObject = this.context.getOriginalImage();
|
|
56
|
+
if (!imageObject)
|
|
57
|
+
return;
|
|
58
|
+
if (this.context.guard.isAnimating())
|
|
59
|
+
return;
|
|
60
|
+
if (this.context.guard.isDisposed())
|
|
61
|
+
return;
|
|
62
|
+
this.context.setCurrentRotation(degrees);
|
|
63
|
+
try {
|
|
64
|
+
const centre = imageObject.getCenterPoint();
|
|
65
|
+
imageObject.set({ originX: 'center', originY: 'center' });
|
|
66
|
+
imageObject.setPositionByOrigin(centre, 'center', 'center');
|
|
67
|
+
imageObject.setCoords();
|
|
68
|
+
}
|
|
69
|
+
catch (error) {
|
|
70
|
+
console.warn('[ImageEditor] rotateImage: origin pre-anchor failed', error);
|
|
71
|
+
}
|
|
72
|
+
let animationFailed = false;
|
|
73
|
+
try {
|
|
74
|
+
await this.context.guard.runAnimation(() => animateProps(imageObject, { angle: degrees }, {
|
|
75
|
+
duration: this.context.options.animationDuration,
|
|
76
|
+
onChange: () => this.context.canvas.requestRenderAll(),
|
|
77
|
+
}, this.context.guard));
|
|
78
|
+
}
|
|
79
|
+
catch (error) {
|
|
80
|
+
animationFailed = true;
|
|
81
|
+
console.warn('[ImageEditor] rotateImage animation error', error);
|
|
82
|
+
}
|
|
83
|
+
finally {
|
|
84
|
+
if (this.context.guard.isDisposed()) {
|
|
85
|
+
restoreOrigin(imageObject, 'left', 'top');
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
if (animationFailed)
|
|
89
|
+
return;
|
|
90
|
+
if (this.context.guard.isDisposed())
|
|
91
|
+
return;
|
|
92
|
+
imageObject.set('angle', degrees);
|
|
93
|
+
imageObject.setCoords();
|
|
94
|
+
if (this.context.afterTransformSnap)
|
|
95
|
+
this.context.afterTransformSnap();
|
|
96
|
+
try {
|
|
97
|
+
const newTopLeft = computeTopLeftPoint(imageObject);
|
|
98
|
+
imageObject.set({ originX: 'left', originY: 'top' });
|
|
99
|
+
imageObject.setPositionByOrigin(newTopLeft, 'left', 'top');
|
|
100
|
+
imageObject.setCoords();
|
|
101
|
+
}
|
|
102
|
+
catch (error) {
|
|
103
|
+
console.warn('[ImageEditor] rotateImage: origin post-restore failed', error);
|
|
104
|
+
}
|
|
105
|
+
this.context.saveCanvasState();
|
|
106
|
+
}
|
|
107
|
+
async resetImageTransform() {
|
|
108
|
+
if (!this.context.getOriginalImage())
|
|
109
|
+
return;
|
|
110
|
+
this.context.setSuppressSaveState(true);
|
|
111
|
+
try {
|
|
112
|
+
await this.scaleImage(1);
|
|
113
|
+
await this.rotateImage(0);
|
|
114
|
+
}
|
|
115
|
+
finally {
|
|
116
|
+
this.context.setSuppressSaveState(false);
|
|
117
|
+
}
|
|
118
|
+
if (this.context.guard.isDisposed())
|
|
119
|
+
return;
|
|
120
|
+
this.context.saveCanvasState();
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
function computeTopLeftPoint(object) {
|
|
124
|
+
object.setCoords();
|
|
125
|
+
const coords = object.getCoords();
|
|
126
|
+
const first = coords[0];
|
|
127
|
+
if (first)
|
|
128
|
+
return first;
|
|
129
|
+
const boundingRect = object.getBoundingRect();
|
|
130
|
+
return { x: boundingRect.left, y: boundingRect.top };
|
|
131
|
+
}
|
|
132
|
+
//# sourceMappingURL=transform-controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transform-controller.js","sourceRoot":"","sources":["../../../src/image/transform-controller.ts"],"names":[],"mappings":"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"}
|