@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,4CAoQvC"}
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
- const cx = (canvas.getWidth() / 2 - vpt[4]) / canvasZoom;
169
- const cy = (canvas.getHeight() / 2 - vpt[5]) / canvasZoom;
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 cx = (canvas.getWidth() / 2 - vpt[4]) / canvasZoom;
188
- const cy = (canvas.getHeight() / 2 - vpt[5]) / canvasZoom;
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 - 150,
198
+ x: cx - 160, // 320px wide → center offset
195
199
  y: cy - 80,
196
200
  },
197
201
  ]);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@mhamz.01/easyflow-whiteboard",
3
- "version": "2.31.0",
3
+ "version": "2.34.0",
4
4
  "description": "A feature-rich whiteboard component built with Fabric.js and React",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",