@mhamz.01/easyflow-whiteboard 2.31.0 → 2.34.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.
|
@@ -300,7 +300,7 @@ export default function CanvasOverlayLayer({ tasks, documents, onTasksUpdate, on
|
|
|
300
300
|
setLocalDocuments((prev) => prev.map((d) => itemIds.includes(d.id) ? {
|
|
301
301
|
...d,
|
|
302
302
|
x: (startPositions.get(d.id)?.x ?? d.x) + deltaX,
|
|
303
|
-
y: (startPositions.get(d.id)?.y ?? d.y),
|
|
303
|
+
y: (startPositions.get(d.id)?.y ?? d.y) + deltaY,
|
|
304
304
|
} : d));
|
|
305
305
|
// 7. Sync Fabric Objects (Imperative update for performance)
|
|
306
306
|
canvasObjectsStartPos.forEach((startPos, obj) => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"whiteboard-test.d.ts","sourceRoot":"","sources":["../../../src/components/whiteboard/whiteboard-test.tsx"],"names":[],"mappings":"AA4CA,MAAM,CAAC,OAAO,UAAU,gBAAgB,
|
|
1
|
+
{"version":3,"file":"whiteboard-test.d.ts","sourceRoot":"","sources":["../../../src/components/whiteboard/whiteboard-test.tsx"],"names":[],"mappings":"AA4CA,MAAM,CAAC,OAAO,UAAU,gBAAgB,4CA0QvC"}
|
|
@@ -165,8 +165,11 @@ export default function FabricWhiteboard() {
|
|
|
165
165
|
const vpt = canvas.viewportTransform;
|
|
166
166
|
if (!vpt)
|
|
167
167
|
return;
|
|
168
|
-
|
|
169
|
-
|
|
168
|
+
// vpt[0] = live zoom, vpt[4]/vpt[5] = live pan
|
|
169
|
+
// Never use canvasZoom state here — it can be 1 render behind
|
|
170
|
+
const liveZoom = vpt[0];
|
|
171
|
+
const cx = (canvas.getWidth() / 2 - vpt[4]) / liveZoom;
|
|
172
|
+
const cy = (canvas.getHeight() / 2 - vpt[5]) / liveZoom;
|
|
170
173
|
setTasks((prev) => [
|
|
171
174
|
...prev,
|
|
172
175
|
{
|
|
@@ -184,14 +187,15 @@ export default function FabricWhiteboard() {
|
|
|
184
187
|
const vpt = canvas.viewportTransform;
|
|
185
188
|
if (!vpt)
|
|
186
189
|
return;
|
|
187
|
-
const
|
|
188
|
-
const
|
|
190
|
+
const liveZoom = vpt[0];
|
|
191
|
+
const cx = (canvas.getWidth() / 2 - vpt[4]) / liveZoom;
|
|
192
|
+
const cy = (canvas.getHeight() / 2 - vpt[5]) / liveZoom;
|
|
189
193
|
setDocuments((prev) => [
|
|
190
194
|
...prev,
|
|
191
195
|
{
|
|
192
196
|
...docTemplate,
|
|
193
197
|
id: `${docTemplate.id}-${Date.now()}`,
|
|
194
|
-
x: cx -
|
|
198
|
+
x: cx - 160, // 320px wide → center offset
|
|
195
199
|
y: cy - 80,
|
|
196
200
|
},
|
|
197
201
|
]);
|