@printwithsynergy/lens-pdf 0.3.0-beta.81
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/LICENSE +661 -0
- package/README.md +344 -0
- package/dist/browser/codexOverlay.d.ts +109 -0
- package/dist/browser/codexOverlay.d.ts.map +1 -0
- package/dist/browser/codexOverlay.js +256 -0
- package/dist/browser/codexOverlay.js.map +1 -0
- package/dist/browser/constants.d.ts +13 -0
- package/dist/browser/constants.d.ts.map +1 -0
- package/dist/browser/constants.js +13 -0
- package/dist/browser/constants.js.map +1 -0
- package/dist/browser/index.d.ts +211 -0
- package/dist/browser/index.d.ts.map +1 -0
- package/dist/browser/index.js +1190 -0
- package/dist/browser/index.js.map +1 -0
- package/dist/browser/pantone-gold.d.ts +59 -0
- package/dist/browser/pantone-gold.d.ts.map +1 -0
- package/dist/browser/pantone-gold.js +237 -0
- package/dist/browser/pantone-gold.js.map +1 -0
- package/dist/components/AnnotationCanvas.d.ts +27 -0
- package/dist/components/AnnotationCanvas.d.ts.map +1 -0
- package/dist/components/AnnotationCanvas.js +401 -0
- package/dist/components/AnnotationCanvas.js.map +1 -0
- package/dist/components/AnnotationNotesPanel.d.ts +15 -0
- package/dist/components/AnnotationNotesPanel.d.ts.map +1 -0
- package/dist/components/AnnotationNotesPanel.js +235 -0
- package/dist/components/AnnotationNotesPanel.js.map +1 -0
- package/dist/components/AnnotationThread.d.ts +18 -0
- package/dist/components/AnnotationThread.d.ts.map +1 -0
- package/dist/components/AnnotationThread.js +163 -0
- package/dist/components/AnnotationThread.js.map +1 -0
- package/dist/components/AnnotationToolbar.d.ts +39 -0
- package/dist/components/AnnotationToolbar.d.ts.map +1 -0
- package/dist/components/AnnotationToolbar.js +258 -0
- package/dist/components/AnnotationToolbar.js.map +1 -0
- package/dist/components/BoxOverlay.d.ts +20 -0
- package/dist/components/BoxOverlay.d.ts.map +1 -0
- package/dist/components/BoxOverlay.js +107 -0
- package/dist/components/BoxOverlay.js.map +1 -0
- package/dist/components/ColorPickerTool.d.ts +11 -0
- package/dist/components/ColorPickerTool.d.ts.map +1 -0
- package/dist/components/ColorPickerTool.js +220 -0
- package/dist/components/ColorPickerTool.js.map +1 -0
- package/dist/components/DensitometerTool.d.ts +25 -0
- package/dist/components/DensitometerTool.d.ts.map +1 -0
- package/dist/components/DensitometerTool.js +246 -0
- package/dist/components/DensitometerTool.js.map +1 -0
- package/dist/components/DielineInfoPanel.d.ts +27 -0
- package/dist/components/DielineInfoPanel.d.ts.map +1 -0
- package/dist/components/DielineInfoPanel.js +23 -0
- package/dist/components/DielineInfoPanel.js.map +1 -0
- package/dist/components/DielineOverlay.d.ts +10 -0
- package/dist/components/DielineOverlay.d.ts.map +1 -0
- package/dist/components/DielineOverlay.js +57 -0
- package/dist/components/DielineOverlay.js.map +1 -0
- package/dist/components/FindingsSidebar.d.ts +50 -0
- package/dist/components/FindingsSidebar.d.ts.map +1 -0
- package/dist/components/FindingsSidebar.js +78 -0
- package/dist/components/FindingsSidebar.js.map +1 -0
- package/dist/components/LayerCanvas.d.ts +30 -0
- package/dist/components/LayerCanvas.d.ts.map +1 -0
- package/dist/components/LayerCanvas.js +84 -0
- package/dist/components/LayerCanvas.js.map +1 -0
- package/dist/components/LayerPanel.d.ts +9 -0
- package/dist/components/LayerPanel.d.ts.map +1 -0
- package/dist/components/LayerPanel.js +144 -0
- package/dist/components/LayerPanel.js.map +1 -0
- package/dist/components/LensPDF.d.ts +61 -0
- package/dist/components/LensPDF.d.ts.map +1 -0
- package/dist/components/LensPDF.js +49 -0
- package/dist/components/LensPDF.js.map +1 -0
- package/dist/components/LensPDFDemo.d.ts +160 -0
- package/dist/components/LensPDFDemo.d.ts.map +1 -0
- package/dist/components/LensPDFDemo.js +1060 -0
- package/dist/components/LensPDFDemo.js.map +1 -0
- package/dist/components/LensPDFDemo.styles.d.ts +38 -0
- package/dist/components/LensPDFDemo.styles.d.ts.map +1 -0
- package/dist/components/LensPDFDemo.styles.js +282 -0
- package/dist/components/LensPDFDemo.styles.js.map +1 -0
- package/dist/components/LensPDFViewer.d.ts +79 -0
- package/dist/components/LensPDFViewer.d.ts.map +1 -0
- package/dist/components/LensPDFViewer.js +254 -0
- package/dist/components/LensPDFViewer.js.map +1 -0
- package/dist/components/MeasureTool.d.ts +16 -0
- package/dist/components/MeasureTool.d.ts.map +1 -0
- package/dist/components/MeasureTool.js +137 -0
- package/dist/components/MeasureTool.js.map +1 -0
- package/dist/components/MobileBottomSheet.d.ts +12 -0
- package/dist/components/MobileBottomSheet.d.ts.map +1 -0
- package/dist/components/MobileBottomSheet.js +113 -0
- package/dist/components/MobileBottomSheet.js.map +1 -0
- package/dist/components/MobileDrawer.d.ts +31 -0
- package/dist/components/MobileDrawer.d.ts.map +1 -0
- package/dist/components/MobileDrawer.js +67 -0
- package/dist/components/MobileDrawer.js.map +1 -0
- package/dist/components/PageCanvas.d.ts +33 -0
- package/dist/components/PageCanvas.d.ts.map +1 -0
- package/dist/components/PageCanvas.js +385 -0
- package/dist/components/PageCanvas.js.map +1 -0
- package/dist/components/PageNavigator.d.ts +18 -0
- package/dist/components/PageNavigator.d.ts.map +1 -0
- package/dist/components/PageNavigator.js +44 -0
- package/dist/components/PageNavigator.js.map +1 -0
- package/dist/components/SeparationCanvas.d.ts +12 -0
- package/dist/components/SeparationCanvas.d.ts.map +1 -0
- package/dist/components/SeparationCanvas.js +174 -0
- package/dist/components/SeparationCanvas.js.map +1 -0
- package/dist/components/TACHeatmapOverlay.d.ts +17 -0
- package/dist/components/TACHeatmapOverlay.d.ts.map +1 -0
- package/dist/components/TACHeatmapOverlay.js +119 -0
- package/dist/components/TACHeatmapOverlay.js.map +1 -0
- package/dist/components/ZoomControls.d.ts +11 -0
- package/dist/components/ZoomControls.d.ts.map +1 -0
- package/dist/components/ZoomControls.js +26 -0
- package/dist/components/ZoomControls.js.map +1 -0
- package/dist/components/defaultShellPlugins.d.ts +3 -0
- package/dist/components/defaultShellPlugins.d.ts.map +1 -0
- package/dist/components/defaultShellPlugins.js +273 -0
- package/dist/components/defaultShellPlugins.js.map +1 -0
- package/dist/components/index.d.ts +32 -0
- package/dist/components/index.d.ts.map +1 -0
- package/dist/components/index.js +32 -0
- package/dist/components/index.js.map +1 -0
- package/dist/components/presets.d.ts +8 -0
- package/dist/components/presets.d.ts.map +1 -0
- package/dist/components/presets.js +14 -0
- package/dist/components/presets.js.map +1 -0
- package/dist/components/shellPlugins.d.ts +105 -0
- package/dist/components/shellPlugins.d.ts.map +1 -0
- package/dist/components/shellPlugins.js +52 -0
- package/dist/components/shellPlugins.js.map +1 -0
- package/dist/components/useIsMobile.d.ts +16 -0
- package/dist/components/useIsMobile.d.ts.map +1 -0
- package/dist/components/useIsMobile.js +30 -0
- package/dist/components/useIsMobile.js.map +1 -0
- package/dist/fallback-pdfjs/index.d.ts +60 -0
- package/dist/fallback-pdfjs/index.d.ts.map +1 -0
- package/dist/fallback-pdfjs/index.js +163 -0
- package/dist/fallback-pdfjs/index.js.map +1 -0
- package/dist/host/LensPDFProvider.d.ts +36 -0
- package/dist/host/LensPDFProvider.d.ts.map +1 -0
- package/dist/host/LensPDFProvider.js +12 -0
- package/dist/host/LensPDFProvider.js.map +1 -0
- package/dist/host/index.d.ts +167 -0
- package/dist/host/index.d.ts.map +1 -0
- package/dist/host/index.js +173 -0
- package/dist/host/index.js.map +1 -0
- package/dist/host/pdfFallback.d.ts +50 -0
- package/dist/host/pdfFallback.d.ts.map +1 -0
- package/dist/host/pdfFallback.js +171 -0
- package/dist/host/pdfFallback.js.map +1 -0
- package/dist/host/pdfValidation.d.ts +45 -0
- package/dist/host/pdfValidation.d.ts.map +1 -0
- package/dist/host/pdfValidation.js +78 -0
- package/dist/host/pdfValidation.js.map +1 -0
- package/dist/host/shareLink.d.ts +80 -0
- package/dist/host/shareLink.d.ts.map +1 -0
- package/dist/host/shareLink.js +114 -0
- package/dist/host/shareLink.js.map +1 -0
- package/dist/host/useLensPDF.d.ts +73 -0
- package/dist/host/useLensPDF.d.ts.map +1 -0
- package/dist/host/useLensPDF.js +213 -0
- package/dist/host/useLensPDF.js.map +1 -0
- package/dist/index.d.ts +68 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +62 -0
- package/dist/index.js.map +1 -0
- package/dist/plugin/context.d.ts +70 -0
- package/dist/plugin/context.d.ts.map +1 -0
- package/dist/plugin/context.js +16 -0
- package/dist/plugin/context.js.map +1 -0
- package/dist/plugin/findings-location.d.ts +53 -0
- package/dist/plugin/findings-location.d.ts.map +1 -0
- package/dist/plugin/findings-location.js +72 -0
- package/dist/plugin/findings-location.js.map +1 -0
- package/dist/plugin/index.d.ts +19 -0
- package/dist/plugin/index.d.ts.map +1 -0
- package/dist/plugin/index.js +16 -0
- package/dist/plugin/index.js.map +1 -0
- package/dist/plugin/registry.d.ts +61 -0
- package/dist/plugin/registry.d.ts.map +1 -0
- package/dist/plugin/registry.js +102 -0
- package/dist/plugin/registry.js.map +1 -0
- package/dist/plugin/services.d.ts +380 -0
- package/dist/plugin/services.d.ts.map +1 -0
- package/dist/plugin/services.js +104 -0
- package/dist/plugin/services.js.map +1 -0
- package/dist/plugin/types.d.ts +198 -0
- package/dist/plugin/types.d.ts.map +1 -0
- package/dist/plugin/types.js +24 -0
- package/dist/plugin/types.js.map +1 -0
- package/dist/types/index.d.ts +191 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +95 -0
- package/dist/types/index.js.map +1 -0
- package/dist/units/index.d.ts +64 -0
- package/dist/units/index.d.ts.map +1 -0
- package/dist/units/index.js +98 -0
- package/dist/units/index.js.map +1 -0
- package/docs/architecture.md +90 -0
- package/docs/components.md +569 -0
- package/docs/contributing.md +78 -0
- package/docs/fallback.md +174 -0
- package/docs/lens-pdf-viewer.md +128 -0
- package/docs/licensing.md +78 -0
- package/docs/measurement-units.md +87 -0
- package/docs/plugins.md +256 -0
- package/docs/security.md +69 -0
- package/docs/server.md +212 -0
- package/docs/services.md +210 -0
- package/docs/share-links.md +111 -0
- package/docs/theming.md +164 -0
- package/docs/validation.md +83 -0
- package/package.json +139 -0
|
@@ -0,0 +1,401 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import { useCallback, useEffect, useRef, useState } from "react";
|
|
4
|
+
import { isUnwired, logUnwiredHide, useViewerHost, useViewerServices } from "../host/index.js";
|
|
5
|
+
const ANNOTATION_NUMBER_KEY = "__loupeAnnotationNumber";
|
|
6
|
+
export function AnnotationCanvas({ jobId: _jobId, pageNum, width, height, activeTool, strokeColor, onSavingChange, onHistoryChange, onIndexedAnnotationsChange, selectedAnnotationNumber, onSelectedAnnotationNumberChange, }) {
|
|
7
|
+
const { readOnly, debug } = useViewerHost();
|
|
8
|
+
const { annotations } = useViewerServices();
|
|
9
|
+
const hidden = isUnwired(annotations);
|
|
10
|
+
const canvasElRef = useRef(null);
|
|
11
|
+
useEffect(() => {
|
|
12
|
+
if (hidden && debug)
|
|
13
|
+
logUnwiredHide("AnnotationCanvas", "annotations");
|
|
14
|
+
}, [hidden, debug]);
|
|
15
|
+
const fabricRef = useRef(null);
|
|
16
|
+
const historyRef = useRef({ stack: [], index: -1 });
|
|
17
|
+
const debounceRef = useRef(null);
|
|
18
|
+
const [loaded, setLoaded] = useState(false);
|
|
19
|
+
// ── Helpers ──────────────────────────────────────────────────
|
|
20
|
+
const saveToApi = useCallback(async (canvas) => {
|
|
21
|
+
if (readOnly)
|
|
22
|
+
return;
|
|
23
|
+
onSavingChange?.(true);
|
|
24
|
+
try {
|
|
25
|
+
await annotations.saveForPage(pageNum, canvas.toJSON());
|
|
26
|
+
}
|
|
27
|
+
finally {
|
|
28
|
+
onSavingChange?.(false);
|
|
29
|
+
}
|
|
30
|
+
}, [annotations, pageNum, readOnly, onSavingChange]);
|
|
31
|
+
const debouncedSave = useCallback((canvas) => {
|
|
32
|
+
if (debounceRef.current)
|
|
33
|
+
clearTimeout(debounceRef.current);
|
|
34
|
+
debounceRef.current = setTimeout(() => saveToApi(canvas), 2000);
|
|
35
|
+
}, [saveToApi]);
|
|
36
|
+
const syncAnnotationIndex = useCallback((canvas) => {
|
|
37
|
+
const objects = canvas
|
|
38
|
+
.getObjects()
|
|
39
|
+
.filter((obj) => obj.excludeFromExport !== true);
|
|
40
|
+
let maxNumber = 0;
|
|
41
|
+
for (const obj of objects) {
|
|
42
|
+
const n = Number(obj[ANNOTATION_NUMBER_KEY]);
|
|
43
|
+
if (Number.isFinite(n) && n > maxNumber)
|
|
44
|
+
maxNumber = n;
|
|
45
|
+
}
|
|
46
|
+
let next = maxNumber + 1;
|
|
47
|
+
let touched = false;
|
|
48
|
+
for (const obj of objects) {
|
|
49
|
+
const n = Number(obj[ANNOTATION_NUMBER_KEY]);
|
|
50
|
+
if (!Number.isFinite(n) || n <= 0) {
|
|
51
|
+
obj[ANNOTATION_NUMBER_KEY] = next++;
|
|
52
|
+
touched = true;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
const rows = objects
|
|
56
|
+
.map((obj) => {
|
|
57
|
+
const rect = obj.getBoundingRect();
|
|
58
|
+
return {
|
|
59
|
+
number: Number(obj[ANNOTATION_NUMBER_KEY] ?? 0),
|
|
60
|
+
pageNum,
|
|
61
|
+
objectType: String(obj.type ?? "object"),
|
|
62
|
+
centerX: rect.left + rect.width / 2,
|
|
63
|
+
centerY: rect.top + rect.height / 2,
|
|
64
|
+
};
|
|
65
|
+
})
|
|
66
|
+
.filter((r) => Number.isFinite(r.number) && r.number > 0)
|
|
67
|
+
.sort((a, b) => a.number - b.number);
|
|
68
|
+
onIndexedAnnotationsChange?.(rows);
|
|
69
|
+
if (touched)
|
|
70
|
+
canvas.requestRenderAll();
|
|
71
|
+
}, [onIndexedAnnotationsChange, pageNum]);
|
|
72
|
+
const pushHistory = useCallback((canvas) => {
|
|
73
|
+
const json = JSON.stringify(canvas.toJSON());
|
|
74
|
+
const h = historyRef.current;
|
|
75
|
+
// Truncate any redo entries
|
|
76
|
+
h.stack = h.stack.slice(0, h.index + 1);
|
|
77
|
+
h.stack.push(json);
|
|
78
|
+
h.index = h.stack.length - 1;
|
|
79
|
+
onHistoryChange?.(h.index > 0, false);
|
|
80
|
+
}, [onHistoryChange]);
|
|
81
|
+
// ── Undo / Redo (exposed via ref-style callbacks) ───────────
|
|
82
|
+
const undo = useCallback(() => {
|
|
83
|
+
const canvas = fabricRef.current;
|
|
84
|
+
const h = historyRef.current;
|
|
85
|
+
if (!canvas || h.index <= 0)
|
|
86
|
+
return;
|
|
87
|
+
h.index -= 1;
|
|
88
|
+
canvas.loadFromJSON(JSON.parse(h.stack[h.index]), () => {
|
|
89
|
+
canvas.renderAll();
|
|
90
|
+
debouncedSave(canvas);
|
|
91
|
+
onHistoryChange?.(h.index > 0, h.index < h.stack.length - 1);
|
|
92
|
+
});
|
|
93
|
+
}, [debouncedSave, onHistoryChange]);
|
|
94
|
+
const redo = useCallback(() => {
|
|
95
|
+
const canvas = fabricRef.current;
|
|
96
|
+
const h = historyRef.current;
|
|
97
|
+
if (!canvas || h.index >= h.stack.length - 1)
|
|
98
|
+
return;
|
|
99
|
+
h.index += 1;
|
|
100
|
+
canvas.loadFromJSON(JSON.parse(h.stack[h.index]), () => {
|
|
101
|
+
canvas.renderAll();
|
|
102
|
+
debouncedSave(canvas);
|
|
103
|
+
onHistoryChange?.(h.index > 0, h.index < h.stack.length - 1);
|
|
104
|
+
});
|
|
105
|
+
}, [debouncedSave, onHistoryChange]);
|
|
106
|
+
// Expose undo/redo on the canvas element as data attributes for parent access
|
|
107
|
+
useEffect(() => {
|
|
108
|
+
const el = canvasElRef.current;
|
|
109
|
+
if (!el)
|
|
110
|
+
return;
|
|
111
|
+
el.__annotationUndo = undo;
|
|
112
|
+
el.__annotationRedo = redo;
|
|
113
|
+
}, [undo, redo]);
|
|
114
|
+
// ── Fabric initialisation ────────────────────────────────────
|
|
115
|
+
useEffect(() => {
|
|
116
|
+
let cancelled = false;
|
|
117
|
+
async function init() {
|
|
118
|
+
const fabric = await import("fabric");
|
|
119
|
+
if (cancelled || !canvasElRef.current)
|
|
120
|
+
return;
|
|
121
|
+
const canvas = new fabric.Canvas(canvasElRef.current, {
|
|
122
|
+
width,
|
|
123
|
+
height,
|
|
124
|
+
selection: true,
|
|
125
|
+
});
|
|
126
|
+
fabricRef.current = canvas;
|
|
127
|
+
// fabric v6 no longer auto-instantiates freeDrawingBrush. Without
|
|
128
|
+
// this, switching to the pen tool sets isDrawingMode=true but the
|
|
129
|
+
// brush is undefined so nothing renders. Instantiate a PencilBrush
|
|
130
|
+
// up-front and the tool effect below configures colour / width.
|
|
131
|
+
try {
|
|
132
|
+
const PencilBrush = fabric.PencilBrush;
|
|
133
|
+
if (PencilBrush && !canvas.freeDrawingBrush) {
|
|
134
|
+
canvas.freeDrawingBrush = new PencilBrush(canvas);
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
catch {
|
|
138
|
+
// Fall through — older fabric builds will already have a brush.
|
|
139
|
+
}
|
|
140
|
+
// Load existing annotations through the AnnotationService.
|
|
141
|
+
// getForPage returns null on no-saved-drawing or any error,
|
|
142
|
+
// so the canvas falls back to a blank slate.
|
|
143
|
+
const saved = await annotations.getForPage(pageNum);
|
|
144
|
+
if (saved?.fabricJson) {
|
|
145
|
+
await new Promise((resolve) => {
|
|
146
|
+
// fabricJson is opaque to `core/`; the canvas component
|
|
147
|
+
// is the only place that knows it's a Fabric.js JSON.
|
|
148
|
+
canvas.loadFromJSON(saved.fabricJson, () => {
|
|
149
|
+
canvas.renderAll();
|
|
150
|
+
resolve();
|
|
151
|
+
});
|
|
152
|
+
});
|
|
153
|
+
}
|
|
154
|
+
syncAnnotationIndex(canvas);
|
|
155
|
+
// Seed history
|
|
156
|
+
pushHistory(canvas);
|
|
157
|
+
// Listen for object changes
|
|
158
|
+
const onChange = () => {
|
|
159
|
+
syncAnnotationIndex(canvas);
|
|
160
|
+
pushHistory(canvas);
|
|
161
|
+
debouncedSave(canvas);
|
|
162
|
+
};
|
|
163
|
+
const getSelectedNumber = () => {
|
|
164
|
+
const active = canvas.getActiveObject();
|
|
165
|
+
if (!active)
|
|
166
|
+
return null;
|
|
167
|
+
const n = Number((active[ANNOTATION_NUMBER_KEY]));
|
|
168
|
+
return Number.isFinite(n) && n > 0 ? n : null;
|
|
169
|
+
};
|
|
170
|
+
const onSelection = () => {
|
|
171
|
+
onSelectedAnnotationNumberChange?.(getSelectedNumber());
|
|
172
|
+
};
|
|
173
|
+
canvas.on("object:added", onChange);
|
|
174
|
+
canvas.on("object:modified", onChange);
|
|
175
|
+
canvas.on("object:removed", onChange);
|
|
176
|
+
canvas.on("selection:created", onSelection);
|
|
177
|
+
canvas.on("selection:updated", onSelection);
|
|
178
|
+
canvas.on("selection:cleared", onSelection);
|
|
179
|
+
setLoaded(true);
|
|
180
|
+
}
|
|
181
|
+
init();
|
|
182
|
+
return () => {
|
|
183
|
+
cancelled = true;
|
|
184
|
+
if (debounceRef.current)
|
|
185
|
+
clearTimeout(debounceRef.current);
|
|
186
|
+
if (fabricRef.current) {
|
|
187
|
+
fabricRef.current.dispose();
|
|
188
|
+
fabricRef.current = null;
|
|
189
|
+
}
|
|
190
|
+
};
|
|
191
|
+
// Intentionally only per-page init: re-initialising Fabric on every
|
|
192
|
+
// parent state update (tool toggles, side-panel changes) can tear
|
|
193
|
+
// down the canvas mid-interaction and crash the viewer.
|
|
194
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
195
|
+
}, [pageNum]);
|
|
196
|
+
// Keep canvas selection in sync when the panel picks an annotation by number.
|
|
197
|
+
useEffect(() => {
|
|
198
|
+
const canvas = fabricRef.current;
|
|
199
|
+
if (!canvas || selectedAnnotationNumber == null)
|
|
200
|
+
return;
|
|
201
|
+
const match = canvas.getObjects().find((obj) => {
|
|
202
|
+
const n = Number((obj[ANNOTATION_NUMBER_KEY]));
|
|
203
|
+
return Number.isFinite(n) && n === selectedAnnotationNumber;
|
|
204
|
+
});
|
|
205
|
+
if (!match)
|
|
206
|
+
return;
|
|
207
|
+
canvas.setActiveObject(match);
|
|
208
|
+
canvas.requestRenderAll();
|
|
209
|
+
}, [selectedAnnotationNumber]);
|
|
210
|
+
// ── Resize canvas when dimensions change ─────────────────────
|
|
211
|
+
useEffect(() => {
|
|
212
|
+
const canvas = fabricRef.current;
|
|
213
|
+
if (!canvas)
|
|
214
|
+
return;
|
|
215
|
+
canvas.setDimensions({ width, height });
|
|
216
|
+
canvas.renderAll();
|
|
217
|
+
}, [width, height]);
|
|
218
|
+
// ── Tool switching ───────────────────────────────────────────
|
|
219
|
+
useEffect(() => {
|
|
220
|
+
const canvas = fabricRef.current;
|
|
221
|
+
if (!canvas || !loaded)
|
|
222
|
+
return;
|
|
223
|
+
// Reset drawing mode
|
|
224
|
+
canvas.isDrawingMode = false;
|
|
225
|
+
canvas.selection = true;
|
|
226
|
+
canvas.defaultCursor = "default";
|
|
227
|
+
if (activeTool === "pen") {
|
|
228
|
+
canvas.isDrawingMode = true;
|
|
229
|
+
if (canvas.freeDrawingBrush) {
|
|
230
|
+
canvas.freeDrawingBrush.color = strokeColor;
|
|
231
|
+
canvas.freeDrawingBrush.width = 2;
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
else if (activeTool === "pointer") {
|
|
235
|
+
canvas.selection = true;
|
|
236
|
+
}
|
|
237
|
+
else {
|
|
238
|
+
// For shape tools, disable selection so mousedown creates shapes
|
|
239
|
+
canvas.selection = false;
|
|
240
|
+
canvas.defaultCursor = "crosshair";
|
|
241
|
+
}
|
|
242
|
+
}, [activeTool, strokeColor, loaded]);
|
|
243
|
+
// ── Shape drawing (arrow, rect, ellipse, text, highlight) ────
|
|
244
|
+
useEffect(() => {
|
|
245
|
+
const canvas = fabricRef.current;
|
|
246
|
+
if (!canvas || !loaded)
|
|
247
|
+
return;
|
|
248
|
+
if (activeTool === "pointer" ||
|
|
249
|
+
activeTool === "pen")
|
|
250
|
+
return;
|
|
251
|
+
let isDrawing = false;
|
|
252
|
+
let startX = 0;
|
|
253
|
+
let startY = 0;
|
|
254
|
+
let activeShape = null;
|
|
255
|
+
const onMouseDown = async (opt) => {
|
|
256
|
+
const pointer = canvas.getPointer(opt.e);
|
|
257
|
+
startX = pointer.x;
|
|
258
|
+
startY = pointer.y;
|
|
259
|
+
isDrawing = true;
|
|
260
|
+
const fabric = await import("fabric");
|
|
261
|
+
if (activeTool === "text") {
|
|
262
|
+
const text = new fabric.IText("Text", {
|
|
263
|
+
left: startX,
|
|
264
|
+
top: startY,
|
|
265
|
+
fontSize: 16,
|
|
266
|
+
fill: strokeColor,
|
|
267
|
+
fontFamily: "sans-serif",
|
|
268
|
+
});
|
|
269
|
+
canvas.add(text);
|
|
270
|
+
canvas.setActiveObject(text);
|
|
271
|
+
text.enterEditing();
|
|
272
|
+
isDrawing = false;
|
|
273
|
+
return;
|
|
274
|
+
}
|
|
275
|
+
if (activeTool === "rectangle") {
|
|
276
|
+
activeShape = new fabric.Rect({
|
|
277
|
+
left: startX,
|
|
278
|
+
top: startY,
|
|
279
|
+
width: 0,
|
|
280
|
+
height: 0,
|
|
281
|
+
fill: "transparent",
|
|
282
|
+
stroke: strokeColor,
|
|
283
|
+
strokeWidth: 2,
|
|
284
|
+
});
|
|
285
|
+
}
|
|
286
|
+
else if (activeTool === "ellipse") {
|
|
287
|
+
activeShape = new fabric.Ellipse({
|
|
288
|
+
left: startX,
|
|
289
|
+
top: startY,
|
|
290
|
+
rx: 0,
|
|
291
|
+
ry: 0,
|
|
292
|
+
fill: "transparent",
|
|
293
|
+
stroke: strokeColor,
|
|
294
|
+
strokeWidth: 2,
|
|
295
|
+
});
|
|
296
|
+
}
|
|
297
|
+
else if (activeTool === "highlight") {
|
|
298
|
+
activeShape = new fabric.Rect({
|
|
299
|
+
left: startX,
|
|
300
|
+
top: startY,
|
|
301
|
+
width: 0,
|
|
302
|
+
height: 0,
|
|
303
|
+
fill: strokeColor + "40", // semi-transparent
|
|
304
|
+
stroke: "transparent",
|
|
305
|
+
strokeWidth: 0,
|
|
306
|
+
});
|
|
307
|
+
}
|
|
308
|
+
else if (activeTool === "arrow") {
|
|
309
|
+
activeShape = new fabric.Line([startX, startY, startX, startY], {
|
|
310
|
+
stroke: strokeColor,
|
|
311
|
+
strokeWidth: 2,
|
|
312
|
+
});
|
|
313
|
+
}
|
|
314
|
+
if (activeShape) {
|
|
315
|
+
canvas.add(activeShape);
|
|
316
|
+
}
|
|
317
|
+
};
|
|
318
|
+
const onMouseMove = (opt) => {
|
|
319
|
+
if (!isDrawing || !activeShape)
|
|
320
|
+
return;
|
|
321
|
+
const pointer = canvas.getPointer(opt.e);
|
|
322
|
+
if (activeTool === "rectangle" || activeTool === "highlight") {
|
|
323
|
+
const left = Math.min(startX, pointer.x);
|
|
324
|
+
const top = Math.min(startY, pointer.y);
|
|
325
|
+
activeShape.set({
|
|
326
|
+
left,
|
|
327
|
+
top,
|
|
328
|
+
width: Math.abs(pointer.x - startX),
|
|
329
|
+
height: Math.abs(pointer.y - startY),
|
|
330
|
+
});
|
|
331
|
+
}
|
|
332
|
+
else if (activeTool === "ellipse") {
|
|
333
|
+
activeShape.set({
|
|
334
|
+
rx: Math.abs(pointer.x - startX) / 2,
|
|
335
|
+
ry: Math.abs(pointer.y - startY) / 2,
|
|
336
|
+
left: Math.min(startX, pointer.x),
|
|
337
|
+
top: Math.min(startY, pointer.y),
|
|
338
|
+
});
|
|
339
|
+
}
|
|
340
|
+
else if (activeTool === "arrow") {
|
|
341
|
+
activeShape.set({ x2: pointer.x, y2: pointer.y });
|
|
342
|
+
}
|
|
343
|
+
canvas.renderAll();
|
|
344
|
+
};
|
|
345
|
+
const onMouseUp = async () => {
|
|
346
|
+
if (!isDrawing)
|
|
347
|
+
return;
|
|
348
|
+
isDrawing = false;
|
|
349
|
+
// For arrow tool, add an arrowhead triangle
|
|
350
|
+
if (activeTool === "arrow" && activeShape) {
|
|
351
|
+
const fabric = await import("fabric");
|
|
352
|
+
const x1 = activeShape.x1;
|
|
353
|
+
const y1 = activeShape.y1;
|
|
354
|
+
const x2 = activeShape.x2;
|
|
355
|
+
const y2 = activeShape.y2;
|
|
356
|
+
const angle = Math.atan2(y2 - y1, x2 - x1) * (180 / Math.PI);
|
|
357
|
+
const headLen = 12;
|
|
358
|
+
const head = new fabric.Triangle({
|
|
359
|
+
left: x2,
|
|
360
|
+
top: y2,
|
|
361
|
+
width: headLen,
|
|
362
|
+
height: headLen,
|
|
363
|
+
fill: strokeColor,
|
|
364
|
+
angle: angle + 90,
|
|
365
|
+
originX: "center",
|
|
366
|
+
originY: "center",
|
|
367
|
+
});
|
|
368
|
+
// Group line + head
|
|
369
|
+
const group = new fabric.Group([activeShape, head]);
|
|
370
|
+
canvas.remove(activeShape);
|
|
371
|
+
canvas.add(group);
|
|
372
|
+
}
|
|
373
|
+
activeShape = null;
|
|
374
|
+
canvas.renderAll();
|
|
375
|
+
};
|
|
376
|
+
canvas.on("mouse:down", onMouseDown);
|
|
377
|
+
canvas.on("mouse:move", onMouseMove);
|
|
378
|
+
canvas.on("mouse:up", onMouseUp);
|
|
379
|
+
return () => {
|
|
380
|
+
canvas.off("mouse:down", onMouseDown);
|
|
381
|
+
canvas.off("mouse:move", onMouseMove);
|
|
382
|
+
canvas.off("mouse:up", onMouseUp);
|
|
383
|
+
};
|
|
384
|
+
}, [activeTool, strokeColor, loaded]);
|
|
385
|
+
if (hidden)
|
|
386
|
+
return null;
|
|
387
|
+
// Inline positioning styles — don't depend on the host's Tailwind
|
|
388
|
+
// config providing `absolute` / `inset-0`, so the annotation canvas
|
|
389
|
+
// overlays correctly in any embed (Astro, Next, plain CRA, etc.).
|
|
390
|
+
return (_jsx("div", { style: {
|
|
391
|
+
position: "absolute",
|
|
392
|
+
inset: 0,
|
|
393
|
+
// Inherit so the LensPDFDemo wrapper's pointer-events:none
|
|
394
|
+
// (active when activeTool !== "annotate") actually takes effect.
|
|
395
|
+
// "auto" here would override it and let the canvas intercept
|
|
396
|
+
// events in Move/Pan mode, causing accidental draws.
|
|
397
|
+
pointerEvents: "inherit",
|
|
398
|
+
zIndex: 20,
|
|
399
|
+
}, children: _jsx("canvas", { ref: canvasElRef, width: width, height: height }) }));
|
|
400
|
+
}
|
|
401
|
+
//# sourceMappingURL=AnnotationCanvas.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AnnotationCanvas.js","sourceRoot":"","sources":["../../components/AnnotationCanvas.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
interface AnnotationNotesPanelProps {
|
|
2
|
+
refreshKey?: number;
|
|
3
|
+
storageScopeKey?: string;
|
|
4
|
+
onJumpToPage?: (pageNum: number) => void;
|
|
5
|
+
indexedAnnotations?: Array<{
|
|
6
|
+
number: number;
|
|
7
|
+
pageNum: number;
|
|
8
|
+
objectType: string;
|
|
9
|
+
}>;
|
|
10
|
+
selectedAnnotationId?: string | null;
|
|
11
|
+
onSelectedAnnotationIdChange?: (id: string) => void;
|
|
12
|
+
}
|
|
13
|
+
export declare function AnnotationNotesPanel({ refreshKey, storageScopeKey, onJumpToPage, indexedAnnotations, selectedAnnotationId: selectedAnnotationIdProp, onSelectedAnnotationIdChange, }: AnnotationNotesPanelProps): import("react/jsx-runtime").JSX.Element | null;
|
|
14
|
+
export {};
|
|
15
|
+
//# sourceMappingURL=AnnotationNotesPanel.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AnnotationNotesPanel.d.ts","sourceRoot":"","sources":["../../components/AnnotationNotesPanel.tsx"],"names":[],"mappings":"AAOA,UAAU,yBAAyB;IACjC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,YAAY,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,CAAC;IACzC,kBAAkB,CAAC,EAAE,KAAK,CAAC;QACzB,MAAM,EAAE,MAAM,CAAC;QACf,OAAO,EAAE,MAAM,CAAC;QAChB,UAAU,EAAE,MAAM,CAAC;KACpB,CAAC,CAAC;IACH,oBAAoB,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACrC,4BAA4B,CAAC,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,IAAI,CAAC;CACrD;AA+CD,wBAAgB,oBAAoB,CAAC,EACnC,UAAU,EACV,eAAe,EACf,YAAY,EACZ,kBAAuB,EACvB,oBAAoB,EAAE,wBAAwB,EAC9C,4BAA4B,GAC7B,EAAE,yBAAyB,kDAoS3B"}
|