@docmentis/udoc-viewer 0.5.3 → 0.5.4
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/dist/package.json +56 -0
- package/dist/src/UDocClient.d.ts +383 -0
- package/dist/src/UDocClient.d.ts.map +1 -0
- package/dist/src/UDocClient.js +428 -0
- package/dist/src/UDocClient.js.map +1 -0
- package/dist/src/UDocViewer.d.ts +275 -0
- package/dist/src/UDocViewer.d.ts.map +1 -0
- package/dist/src/UDocViewer.js +796 -0
- package/dist/src/UDocViewer.js.map +1 -0
- package/dist/src/fonts.d.ts +29 -0
- package/dist/src/fonts.d.ts.map +1 -0
- package/dist/src/fonts.js +30 -0
- package/dist/src/fonts.js.map +1 -0
- package/dist/src/index.d.ts +9 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +8 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/performance/PerformanceCounter.d.ts +132 -0
- package/dist/src/performance/PerformanceCounter.d.ts.map +1 -0
- package/dist/src/performance/PerformanceCounter.js +129 -0
- package/dist/src/performance/PerformanceCounter.js.map +1 -0
- package/dist/src/performance/index.d.ts +2 -0
- package/dist/src/performance/index.d.ts.map +1 -0
- package/dist/src/performance/index.js +2 -0
- package/dist/src/performance/index.js.map +1 -0
- package/dist/src/ui/framework/component.d.ts +68 -0
- package/dist/src/ui/framework/component.d.ts.map +1 -0
- package/dist/src/ui/framework/component.js +87 -0
- package/dist/src/ui/framework/component.js.map +1 -0
- package/dist/src/ui/framework/dom.d.ts +19 -0
- package/dist/src/ui/framework/dom.d.ts.map +1 -0
- package/dist/src/ui/framework/dom.js +29 -0
- package/dist/src/ui/framework/dom.js.map +1 -0
- package/dist/src/ui/framework/events.d.ts +18 -0
- package/dist/src/ui/framework/events.d.ts.map +1 -0
- package/dist/src/ui/framework/events.js +23 -0
- package/dist/src/ui/framework/events.js.map +1 -0
- package/dist/src/ui/framework/index.d.ts +15 -0
- package/dist/src/ui/framework/index.d.ts.map +1 -0
- package/dist/src/ui/framework/index.js +15 -0
- package/dist/src/ui/framework/index.js.map +1 -0
- package/dist/src/ui/framework/selectors.d.ts +51 -0
- package/dist/src/ui/framework/selectors.d.ts.map +1 -0
- package/dist/src/ui/framework/selectors.js +30 -0
- package/dist/src/ui/framework/selectors.js.map +1 -0
- package/dist/src/ui/framework/store.d.ts +37 -0
- package/dist/src/ui/framework/store.d.ts.map +1 -0
- package/dist/src/ui/framework/store.js +54 -0
- package/dist/src/ui/framework/store.js.map +1 -0
- package/dist/src/ui/viewer/actions.d.ts +132 -0
- package/dist/src/ui/viewer/actions.d.ts.map +1 -0
- package/dist/src/ui/viewer/actions.js +2 -0
- package/dist/src/ui/viewer/actions.js.map +1 -0
- package/dist/src/ui/viewer/annotation/LinkRenderer.d.ts +9 -0
- package/dist/src/ui/viewer/annotation/LinkRenderer.d.ts.map +1 -0
- package/dist/src/ui/viewer/annotation/LinkRenderer.js +17 -0
- package/dist/src/ui/viewer/annotation/LinkRenderer.js.map +1 -0
- package/dist/src/ui/viewer/annotation/MarkupRenderer.d.ts +21 -0
- package/dist/src/ui/viewer/annotation/MarkupRenderer.d.ts.map +1 -0
- package/dist/src/ui/viewer/annotation/MarkupRenderer.js +138 -0
- package/dist/src/ui/viewer/annotation/MarkupRenderer.js.map +1 -0
- package/dist/src/ui/viewer/annotation/ShapeRenderer.d.ts +33 -0
- package/dist/src/ui/viewer/annotation/ShapeRenderer.d.ts.map +1 -0
- package/dist/src/ui/viewer/annotation/ShapeRenderer.js +378 -0
- package/dist/src/ui/viewer/annotation/ShapeRenderer.js.map +1 -0
- package/dist/src/ui/viewer/annotation/TextRenderer.d.ts +23 -0
- package/dist/src/ui/viewer/annotation/TextRenderer.d.ts.map +1 -0
- package/dist/src/ui/viewer/annotation/TextRenderer.js +196 -0
- package/dist/src/ui/viewer/annotation/TextRenderer.js.map +1 -0
- package/dist/src/ui/viewer/annotation/index.d.ts +8 -0
- package/dist/src/ui/viewer/annotation/index.d.ts.map +1 -0
- package/dist/src/ui/viewer/annotation/index.js +8 -0
- package/dist/src/ui/viewer/annotation/index.js.map +1 -0
- package/dist/src/ui/viewer/annotation/render.d.ts +24 -0
- package/dist/src/ui/viewer/annotation/render.d.ts.map +1 -0
- package/dist/src/ui/viewer/annotation/render.js +184 -0
- package/dist/src/ui/viewer/annotation/render.js.map +1 -0
- package/dist/src/ui/viewer/annotation/types.d.ts +239 -0
- package/dist/src/ui/viewer/annotation/types.d.ts.map +1 -0
- package/dist/src/ui/viewer/annotation/types.js +7 -0
- package/dist/src/ui/viewer/annotation/types.js.map +1 -0
- package/dist/src/ui/viewer/annotation/utils.d.ts +37 -0
- package/dist/src/ui/viewer/annotation/utils.d.ts.map +1 -0
- package/dist/src/ui/viewer/annotation/utils.js +82 -0
- package/dist/src/ui/viewer/annotation/utils.js.map +1 -0
- package/dist/src/ui/viewer/components/AnnotationPanel.d.ts +19 -0
- package/dist/src/ui/viewer/components/AnnotationPanel.d.ts.map +1 -0
- package/dist/src/ui/viewer/components/AnnotationPanel.js +284 -0
- package/dist/src/ui/viewer/components/AnnotationPanel.js.map +1 -0
- package/dist/src/ui/viewer/components/FloatingToolbar.d.ts +9 -0
- package/dist/src/ui/viewer/components/FloatingToolbar.d.ts.map +1 -0
- package/dist/src/ui/viewer/components/FloatingToolbar.js +305 -0
- package/dist/src/ui/viewer/components/FloatingToolbar.js.map +1 -0
- package/dist/src/ui/viewer/components/LeftPanel.d.ts +10 -0
- package/dist/src/ui/viewer/components/LeftPanel.d.ts.map +1 -0
- package/dist/src/ui/viewer/components/LeftPanel.js +165 -0
- package/dist/src/ui/viewer/components/LeftPanel.js.map +1 -0
- package/dist/src/ui/viewer/components/LoadingOverlay.d.ts +12 -0
- package/dist/src/ui/viewer/components/LoadingOverlay.d.ts.map +1 -0
- package/dist/src/ui/viewer/components/LoadingOverlay.js +88 -0
- package/dist/src/ui/viewer/components/LoadingOverlay.js.map +1 -0
- package/dist/src/ui/viewer/components/OutlinePanel.d.ts +10 -0
- package/dist/src/ui/viewer/components/OutlinePanel.d.ts.map +1 -0
- package/dist/src/ui/viewer/components/OutlinePanel.js +169 -0
- package/dist/src/ui/viewer/components/OutlinePanel.js.map +1 -0
- package/dist/src/ui/viewer/components/PasswordDialog.d.ts +15 -0
- package/dist/src/ui/viewer/components/PasswordDialog.d.ts.map +1 -0
- package/dist/src/ui/viewer/components/PasswordDialog.js +143 -0
- package/dist/src/ui/viewer/components/PasswordDialog.js.map +1 -0
- package/dist/src/ui/viewer/components/RightPanel.d.ts +9 -0
- package/dist/src/ui/viewer/components/RightPanel.d.ts.map +1 -0
- package/dist/src/ui/viewer/components/RightPanel.js +102 -0
- package/dist/src/ui/viewer/components/RightPanel.js.map +1 -0
- package/dist/src/ui/viewer/components/Spread.d.ts +43 -0
- package/dist/src/ui/viewer/components/Spread.d.ts.map +1 -0
- package/dist/src/ui/viewer/components/Spread.js +345 -0
- package/dist/src/ui/viewer/components/Spread.js.map +1 -0
- package/dist/src/ui/viewer/components/ThumbnailPanel.d.ts +11 -0
- package/dist/src/ui/viewer/components/ThumbnailPanel.d.ts.map +1 -0
- package/dist/src/ui/viewer/components/ThumbnailPanel.js +240 -0
- package/dist/src/ui/viewer/components/ThumbnailPanel.js.map +1 -0
- package/dist/src/ui/viewer/components/Toolbar.d.ts +9 -0
- package/dist/src/ui/viewer/components/Toolbar.d.ts.map +1 -0
- package/dist/src/ui/viewer/components/Toolbar.js +93 -0
- package/dist/src/ui/viewer/components/Toolbar.js.map +1 -0
- package/dist/src/ui/viewer/components/ViewModeMenu.d.ts +9 -0
- package/dist/src/ui/viewer/components/ViewModeMenu.d.ts.map +1 -0
- package/dist/src/ui/viewer/components/ViewModeMenu.js +169 -0
- package/dist/src/ui/viewer/components/ViewModeMenu.js.map +1 -0
- package/dist/src/ui/viewer/components/Viewport.d.ts +10 -0
- package/dist/src/ui/viewer/components/Viewport.d.ts.map +1 -0
- package/dist/src/ui/viewer/components/Viewport.js +1076 -0
- package/dist/src/ui/viewer/components/Viewport.js.map +1 -0
- package/dist/src/ui/viewer/effects.d.ts +8 -0
- package/dist/src/ui/viewer/effects.d.ts.map +1 -0
- package/dist/src/ui/viewer/effects.js +207 -0
- package/dist/src/ui/viewer/effects.js.map +1 -0
- package/dist/src/ui/viewer/icons.d.ts +32 -0
- package/dist/src/ui/viewer/icons.d.ts.map +1 -0
- package/dist/src/ui/viewer/icons.js +44 -0
- package/dist/src/ui/viewer/icons.js.map +1 -0
- package/dist/src/ui/viewer/index.d.ts +6 -0
- package/dist/src/ui/viewer/index.d.ts.map +1 -0
- package/dist/src/ui/viewer/index.js +6 -0
- package/dist/src/ui/viewer/index.js.map +1 -0
- package/dist/src/ui/viewer/layout/index.d.ts +3 -0
- package/dist/src/ui/viewer/layout/index.d.ts.map +1 -0
- package/dist/src/ui/viewer/layout/index.js +3 -0
- package/dist/src/ui/viewer/layout/index.js.map +1 -0
- package/dist/src/ui/viewer/layout/pixelAlign.d.ts +7 -0
- package/dist/src/ui/viewer/layout/pixelAlign.d.ts.map +1 -0
- package/dist/src/ui/viewer/layout/pixelAlign.js +22 -0
- package/dist/src/ui/viewer/layout/pixelAlign.js.map +1 -0
- package/dist/src/ui/viewer/layout/spreadLayout.d.ts +93 -0
- package/dist/src/ui/viewer/layout/spreadLayout.d.ts.map +1 -0
- package/dist/src/ui/viewer/layout/spreadLayout.js +315 -0
- package/dist/src/ui/viewer/layout/spreadLayout.js.map +1 -0
- package/dist/src/ui/viewer/navigation.d.ts +80 -0
- package/dist/src/ui/viewer/navigation.d.ts.map +1 -0
- package/dist/src/ui/viewer/navigation.js +59 -0
- package/dist/src/ui/viewer/navigation.js.map +1 -0
- package/dist/src/ui/viewer/reducer.d.ts +4 -0
- package/dist/src/ui/viewer/reducer.d.ts.map +1 -0
- package/dist/src/ui/viewer/reducer.js +317 -0
- package/dist/src/ui/viewer/reducer.js.map +1 -0
- package/dist/src/ui/viewer/shell.d.ts +34 -0
- package/dist/src/ui/viewer/shell.d.ts.map +1 -0
- package/dist/src/ui/viewer/shell.js +93 -0
- package/dist/src/ui/viewer/shell.js.map +1 -0
- package/dist/src/ui/viewer/state.d.ts +105 -0
- package/dist/src/ui/viewer/state.d.ts.map +1 -0
- package/dist/src/ui/viewer/state.js +65 -0
- package/dist/src/ui/viewer/state.js.map +1 -0
- package/dist/src/ui/viewer/styles-inline.d.ts +2 -0
- package/dist/src/ui/viewer/styles-inline.d.ts.map +1 -0
- package/dist/src/ui/viewer/styles-inline.js +1584 -0
- package/dist/src/ui/viewer/styles-inline.js.map +1 -0
- package/dist/src/ui/viewer/text/index.d.ts +7 -0
- package/dist/src/ui/viewer/text/index.d.ts.map +1 -0
- package/dist/src/ui/viewer/text/index.js +3 -0
- package/dist/src/ui/viewer/text/index.js.map +1 -0
- package/dist/src/ui/viewer/text/render.d.ts +19 -0
- package/dist/src/ui/viewer/text/render.d.ts.map +1 -0
- package/dist/src/ui/viewer/text/render.js +228 -0
- package/dist/src/ui/viewer/text/render.js.map +1 -0
- package/dist/src/ui/viewer/text/selection.d.ts +12 -0
- package/dist/src/ui/viewer/text/selection.d.ts.map +1 -0
- package/dist/src/ui/viewer/text/selection.js +70 -0
- package/dist/src/ui/viewer/text/selection.js.map +1 -0
- package/dist/src/ui/viewer/text/types.d.ts +37 -0
- package/dist/src/ui/viewer/text/types.d.ts.map +1 -0
- package/dist/src/ui/viewer/text/types.js +7 -0
- package/dist/src/ui/viewer/text/types.js.map +1 -0
- package/dist/src/wasm/LICENSE +104 -0
- package/dist/src/wasm/udoc.d.ts +480 -0
- package/dist/src/wasm/udoc.js +1738 -0
- package/dist/src/wasm/udoc_bg.wasm +0 -0
- package/dist/src/wasm/udoc_bg.wasm.d.ts +45 -0
- package/dist/src/worker/WorkerClient.d.ts +335 -0
- package/dist/src/worker/WorkerClient.d.ts.map +1 -0
- package/dist/src/worker/WorkerClient.js +903 -0
- package/dist/src/worker/WorkerClient.js.map +1 -0
- package/dist/src/worker/index.d.ts +4 -0
- package/dist/src/worker/index.d.ts.map +1 -0
- package/dist/src/worker/index.js +2 -0
- package/dist/src/worker/index.js.map +1 -0
- package/dist/src/worker/worker.d.ts +437 -0
- package/dist/src/worker/worker.d.ts.map +1 -0
- package/dist/src/worker/worker.js +237 -0
- package/dist/src/worker/worker.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,240 @@
|
|
|
1
|
+
import { subscribeSelector, shallowEqual } from "../../framework/selectors";
|
|
2
|
+
import { getPointsToPixels } from "../state";
|
|
3
|
+
import { getDevicePixelRatio } from "../layout";
|
|
4
|
+
const THUMBNAIL_WIDTH = 150; // Fixed width in CSS pixels
|
|
5
|
+
function selectThumbnailSlice(state) {
|
|
6
|
+
return {
|
|
7
|
+
docId: state.doc?.id ?? null,
|
|
8
|
+
pageCount: state.pageCount,
|
|
9
|
+
pageInfos: state.pageInfos,
|
|
10
|
+
currentPage: state.page,
|
|
11
|
+
dpi: state.dpi
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
export function createThumbnailPanel() {
|
|
15
|
+
const el = document.createElement("div");
|
|
16
|
+
el.className = "udoc-thumbnail-panel";
|
|
17
|
+
let mounted = false;
|
|
18
|
+
let storeRef = null;
|
|
19
|
+
let workerClient = null;
|
|
20
|
+
let thumbnailItems = [];
|
|
21
|
+
let intersectionObserver = null;
|
|
22
|
+
let currentSlice = null;
|
|
23
|
+
let unsubRender = null;
|
|
24
|
+
const unsubEvents = [];
|
|
25
|
+
function createThumbnailItem(pageNumber, pageInfo) {
|
|
26
|
+
const container = document.createElement("div");
|
|
27
|
+
container.className = "udoc-thumbnail-item";
|
|
28
|
+
container.dataset.page = String(pageNumber);
|
|
29
|
+
const canvas = document.createElement("canvas");
|
|
30
|
+
canvas.className = "udoc-thumbnail-item__canvas";
|
|
31
|
+
// Set aspect ratio for responsive scaling
|
|
32
|
+
const aspectRatio = pageInfo.width / pageInfo.height;
|
|
33
|
+
canvas.style.aspectRatio = String(aspectRatio);
|
|
34
|
+
canvas.style.width = `${THUMBNAIL_WIDTH}px`;
|
|
35
|
+
container.appendChild(canvas);
|
|
36
|
+
const label = document.createElement("div");
|
|
37
|
+
label.className = "udoc-thumbnail-item__label";
|
|
38
|
+
label.textContent = String(pageNumber);
|
|
39
|
+
container.appendChild(label);
|
|
40
|
+
// Click handler for navigation
|
|
41
|
+
const onClick = () => {
|
|
42
|
+
if (storeRef) {
|
|
43
|
+
storeRef.dispatch({ type: "NAVIGATE_TO_PAGE", page: pageNumber });
|
|
44
|
+
}
|
|
45
|
+
};
|
|
46
|
+
container.addEventListener("click", onClick);
|
|
47
|
+
unsubEvents.push(() => container.removeEventListener("click", onClick));
|
|
48
|
+
return {
|
|
49
|
+
container,
|
|
50
|
+
canvas,
|
|
51
|
+
pageNumber,
|
|
52
|
+
renderKey: "",
|
|
53
|
+
pendingKey: null,
|
|
54
|
+
renderToken: 0
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
function buildThumbnailList(slice) {
|
|
58
|
+
// Clear existing
|
|
59
|
+
for (const item of thumbnailItems) {
|
|
60
|
+
item.container.remove();
|
|
61
|
+
}
|
|
62
|
+
thumbnailItems = [];
|
|
63
|
+
if (!slice.docId || slice.pageCount === 0)
|
|
64
|
+
return;
|
|
65
|
+
// Default page size if not available
|
|
66
|
+
const defaultPageInfo = { width: 612, height: 792, rotation: 0 };
|
|
67
|
+
// Create thumbnail items for each page
|
|
68
|
+
for (let i = 1; i <= slice.pageCount; i++) {
|
|
69
|
+
const pageInfo = slice.pageInfos[i - 1] || defaultPageInfo;
|
|
70
|
+
const item = createThumbnailItem(i, pageInfo);
|
|
71
|
+
thumbnailItems.push(item);
|
|
72
|
+
el.appendChild(item.container);
|
|
73
|
+
}
|
|
74
|
+
// Setup intersection observer for lazy loading
|
|
75
|
+
setupIntersectionObserver();
|
|
76
|
+
// Highlight current page
|
|
77
|
+
updateCurrentPageHighlight(slice.currentPage);
|
|
78
|
+
}
|
|
79
|
+
function setupIntersectionObserver() {
|
|
80
|
+
if (intersectionObserver) {
|
|
81
|
+
intersectionObserver.disconnect();
|
|
82
|
+
}
|
|
83
|
+
intersectionObserver = new IntersectionObserver((entries) => {
|
|
84
|
+
for (const entry of entries) {
|
|
85
|
+
if (entry.isIntersecting) {
|
|
86
|
+
const pageNumber = parseInt(entry.target.dataset.page || "0", 10);
|
|
87
|
+
if (pageNumber > 0) {
|
|
88
|
+
requestThumbnailRender(pageNumber);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
}, {
|
|
93
|
+
root: el,
|
|
94
|
+
rootMargin: "100px 0px",
|
|
95
|
+
threshold: 0
|
|
96
|
+
});
|
|
97
|
+
for (const item of thumbnailItems) {
|
|
98
|
+
intersectionObserver.observe(item.container);
|
|
99
|
+
}
|
|
100
|
+
// Setup scroll handler for boost priority
|
|
101
|
+
setupScrollHandler();
|
|
102
|
+
}
|
|
103
|
+
function setupScrollHandler() {
|
|
104
|
+
const onScroll = () => {
|
|
105
|
+
if (!workerClient || !currentSlice?.docId)
|
|
106
|
+
return;
|
|
107
|
+
const focusPage = findFocusThumbnail();
|
|
108
|
+
if (focusPage !== null) {
|
|
109
|
+
workerClient.boostThumbnailRenderPriority(currentSlice.docId, focusPage);
|
|
110
|
+
}
|
|
111
|
+
};
|
|
112
|
+
el.addEventListener("scroll", onScroll, { passive: true });
|
|
113
|
+
unsubEvents.push(() => el.removeEventListener("scroll", onScroll));
|
|
114
|
+
}
|
|
115
|
+
function findFocusThumbnail() {
|
|
116
|
+
if (thumbnailItems.length === 0)
|
|
117
|
+
return null;
|
|
118
|
+
const panelRect = el.getBoundingClientRect();
|
|
119
|
+
const panelCenter = panelRect.top + panelRect.height / 2;
|
|
120
|
+
let closestPage = null;
|
|
121
|
+
let closestDistance = Infinity;
|
|
122
|
+
for (const item of thumbnailItems) {
|
|
123
|
+
const itemRect = item.container.getBoundingClientRect();
|
|
124
|
+
const itemCenter = itemRect.top + itemRect.height / 2;
|
|
125
|
+
const distance = Math.abs(itemCenter - panelCenter);
|
|
126
|
+
if (distance < closestDistance) {
|
|
127
|
+
closestDistance = distance;
|
|
128
|
+
closestPage = item.pageNumber;
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
return closestPage;
|
|
132
|
+
}
|
|
133
|
+
async function requestThumbnailRender(pageNumber) {
|
|
134
|
+
const item = thumbnailItems[pageNumber - 1];
|
|
135
|
+
if (!item || !workerClient || !currentSlice || !currentSlice.docId)
|
|
136
|
+
return;
|
|
137
|
+
const pageInfo = currentSlice.pageInfos[pageNumber - 1];
|
|
138
|
+
if (!pageInfo)
|
|
139
|
+
return;
|
|
140
|
+
const dpr = getDevicePixelRatio();
|
|
141
|
+
const pointsToPixels = getPointsToPixels(currentSlice.dpi);
|
|
142
|
+
const scale = THUMBNAIL_WIDTH / (pageInfo.width * pointsToPixels);
|
|
143
|
+
const renderScale = scale * pointsToPixels * dpr;
|
|
144
|
+
const key = `${currentSlice.docId}:${pageNumber}:${renderScale.toFixed(4)}`;
|
|
145
|
+
if (item.renderKey === key || item.pendingKey === key)
|
|
146
|
+
return;
|
|
147
|
+
const token = ++item.renderToken;
|
|
148
|
+
item.pendingKey = key;
|
|
149
|
+
try {
|
|
150
|
+
const result = await workerClient.requestRender({
|
|
151
|
+
docId: currentSlice.docId,
|
|
152
|
+
page: pageNumber,
|
|
153
|
+
type: "thumbnail",
|
|
154
|
+
scale: renderScale
|
|
155
|
+
});
|
|
156
|
+
if (!mounted || item.renderToken !== token) {
|
|
157
|
+
if (item.pendingKey === key)
|
|
158
|
+
item.pendingKey = null;
|
|
159
|
+
return;
|
|
160
|
+
}
|
|
161
|
+
const canvas = item.canvas;
|
|
162
|
+
if (canvas.width !== result.width)
|
|
163
|
+
canvas.width = result.width;
|
|
164
|
+
if (canvas.height !== result.height)
|
|
165
|
+
canvas.height = result.height;
|
|
166
|
+
const ctx = canvas.getContext("2d");
|
|
167
|
+
if (ctx) {
|
|
168
|
+
ctx.drawImage(result.bitmap, 0, 0);
|
|
169
|
+
}
|
|
170
|
+
item.renderKey = key;
|
|
171
|
+
}
|
|
172
|
+
catch (error) {
|
|
173
|
+
if (error.message !== "Request cancelled") {
|
|
174
|
+
console.error(`Thumbnail render failed for page ${pageNumber}:`, error);
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
finally {
|
|
178
|
+
if (item.pendingKey === key)
|
|
179
|
+
item.pendingKey = null;
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
function updateCurrentPageHighlight(currentPage) {
|
|
183
|
+
for (const item of thumbnailItems) {
|
|
184
|
+
const isActive = item.pageNumber === currentPage;
|
|
185
|
+
item.container.classList.toggle("udoc-thumbnail-item--active", isActive);
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
function scrollActiveIntoView(currentPage) {
|
|
189
|
+
const item = thumbnailItems[currentPage - 1];
|
|
190
|
+
if (!item)
|
|
191
|
+
return;
|
|
192
|
+
// Use instant scroll to avoid triggering renders for all intermediate thumbnails
|
|
193
|
+
item.container.scrollIntoView({
|
|
194
|
+
behavior: "instant",
|
|
195
|
+
block: "nearest"
|
|
196
|
+
});
|
|
197
|
+
}
|
|
198
|
+
function applyState(slice) {
|
|
199
|
+
const docChanged = !currentSlice ||
|
|
200
|
+
slice.docId !== currentSlice.docId ||
|
|
201
|
+
slice.pageCount !== currentSlice.pageCount ||
|
|
202
|
+
slice.pageInfos !== currentSlice.pageInfos;
|
|
203
|
+
if (docChanged) {
|
|
204
|
+
buildThumbnailList(slice);
|
|
205
|
+
}
|
|
206
|
+
else if (slice.currentPage !== currentSlice?.currentPage) {
|
|
207
|
+
updateCurrentPageHighlight(slice.currentPage);
|
|
208
|
+
scrollActiveIntoView(slice.currentPage);
|
|
209
|
+
}
|
|
210
|
+
currentSlice = slice;
|
|
211
|
+
}
|
|
212
|
+
function mount(container, store, rm) {
|
|
213
|
+
container.appendChild(el);
|
|
214
|
+
mounted = true;
|
|
215
|
+
storeRef = store;
|
|
216
|
+
workerClient = rm;
|
|
217
|
+
// Apply initial state (currentSlice is null, so docChanged will be true)
|
|
218
|
+
applyState(selectThumbnailSlice(store.getState()));
|
|
219
|
+
unsubRender = subscribeSelector(store, selectThumbnailSlice, applyState, { equality: shallowEqual });
|
|
220
|
+
}
|
|
221
|
+
function destroy() {
|
|
222
|
+
mounted = false;
|
|
223
|
+
if (unsubRender)
|
|
224
|
+
unsubRender();
|
|
225
|
+
for (const off of unsubEvents)
|
|
226
|
+
off();
|
|
227
|
+
unsubEvents.length = 0;
|
|
228
|
+
if (intersectionObserver) {
|
|
229
|
+
intersectionObserver.disconnect();
|
|
230
|
+
intersectionObserver = null;
|
|
231
|
+
}
|
|
232
|
+
thumbnailItems = [];
|
|
233
|
+
storeRef = null;
|
|
234
|
+
workerClient = null;
|
|
235
|
+
currentSlice = null;
|
|
236
|
+
el.remove();
|
|
237
|
+
}
|
|
238
|
+
return { el, mount, destroy };
|
|
239
|
+
}
|
|
240
|
+
//# sourceMappingURL=ThumbnailPanel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ThumbnailPanel.js","sourceRoot":"","sources":["../../../../../src/ui/viewer/components/ThumbnailPanel.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { Store } from "../../framework/store";
|
|
2
|
+
import type { ViewerState } from "../state";
|
|
3
|
+
import type { Action } from "../actions";
|
|
4
|
+
export declare function createToolbar(): {
|
|
5
|
+
el: HTMLDivElement;
|
|
6
|
+
mount: (container: HTMLElement, store: Store<ViewerState, Action>) => void;
|
|
7
|
+
destroy: () => void;
|
|
8
|
+
};
|
|
9
|
+
//# sourceMappingURL=Toolbar.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Toolbar.d.ts","sourceRoot":"","sources":["../../../../../src/ui/viewer/components/Toolbar.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AACnD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAC5C,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AAWzC,wBAAgB,aAAa;;uBA2BC,WAAW,SAAS,KAAK,CAAC,WAAW,EAAE,MAAM,CAAC,KAAG,IAAI;mBA4D3D,IAAI;EAO3B"}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import { ICON_MENU, ICON_SEARCH, ICON_COMMENTS, ICON_FULLSCREEN, ICON_FULLSCREEN_EXIT } from "../icons";
|
|
2
|
+
function createButton(className, label, iconSvg) {
|
|
3
|
+
const btn = document.createElement("button");
|
|
4
|
+
btn.className = `udoc-toolbar__btn ${className}`;
|
|
5
|
+
btn.setAttribute("aria-label", label);
|
|
6
|
+
btn.innerHTML = iconSvg;
|
|
7
|
+
return btn;
|
|
8
|
+
}
|
|
9
|
+
export function createToolbar() {
|
|
10
|
+
const el = document.createElement("div");
|
|
11
|
+
el.className = "udoc-toolbar";
|
|
12
|
+
// Left section
|
|
13
|
+
const leftSection = document.createElement("div");
|
|
14
|
+
leftSection.className = "udoc-toolbar__left";
|
|
15
|
+
const menuBtn = createButton("udoc-toolbar__btn--menu", "Menu", ICON_MENU);
|
|
16
|
+
leftSection.appendChild(menuBtn);
|
|
17
|
+
// Spacer
|
|
18
|
+
const spacer = document.createElement("div");
|
|
19
|
+
spacer.className = "udoc-toolbar__spacer";
|
|
20
|
+
// Right section
|
|
21
|
+
const rightSection = document.createElement("div");
|
|
22
|
+
rightSection.className = "udoc-toolbar__right";
|
|
23
|
+
const searchBtn = createButton("udoc-toolbar__btn--search", "Search", ICON_SEARCH);
|
|
24
|
+
const commentsBtn = createButton("udoc-toolbar__btn--comments", "Comments", ICON_COMMENTS);
|
|
25
|
+
const fullscreenBtn = createButton("udoc-toolbar__btn--fullscreen", "Fullscreen", ICON_FULLSCREEN);
|
|
26
|
+
rightSection.append(searchBtn, commentsBtn, fullscreenBtn);
|
|
27
|
+
el.append(leftSection, spacer, rightSection);
|
|
28
|
+
const unsubEvents = [];
|
|
29
|
+
let unsubRender = null;
|
|
30
|
+
function mount(container, store) {
|
|
31
|
+
container.appendChild(el);
|
|
32
|
+
// Wire menu button to toggle thumbnails panel
|
|
33
|
+
const onMenuClick = () => {
|
|
34
|
+
store.dispatch({ type: "TOGGLE_PANEL", panel: "thumbnail" });
|
|
35
|
+
};
|
|
36
|
+
menuBtn.addEventListener("click", onMenuClick);
|
|
37
|
+
unsubEvents.push(() => menuBtn.removeEventListener("click", onMenuClick));
|
|
38
|
+
// Wire search button to toggle search panel
|
|
39
|
+
const onSearchClick = () => {
|
|
40
|
+
store.dispatch({ type: "TOGGLE_PANEL", panel: "search" });
|
|
41
|
+
};
|
|
42
|
+
searchBtn.addEventListener("click", onSearchClick);
|
|
43
|
+
unsubEvents.push(() => searchBtn.removeEventListener("click", onSearchClick));
|
|
44
|
+
// Wire comments button to toggle comments panel
|
|
45
|
+
const onCommentsClick = () => {
|
|
46
|
+
store.dispatch({ type: "TOGGLE_PANEL", panel: "comments" });
|
|
47
|
+
};
|
|
48
|
+
commentsBtn.addEventListener("click", onCommentsClick);
|
|
49
|
+
unsubEvents.push(() => commentsBtn.removeEventListener("click", onCommentsClick));
|
|
50
|
+
// Wire fullscreen button
|
|
51
|
+
const onFullscreenClick = () => {
|
|
52
|
+
const root = el.closest(".udoc-viewer-root");
|
|
53
|
+
if (!root)
|
|
54
|
+
return;
|
|
55
|
+
if (!document.fullscreenElement) {
|
|
56
|
+
root.requestFullscreen().catch(() => {
|
|
57
|
+
// Fullscreen request failed (e.g., not allowed by browser)
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
document.exitFullscreen().catch(() => {
|
|
62
|
+
// Exit fullscreen failed
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
};
|
|
66
|
+
fullscreenBtn.addEventListener("click", onFullscreenClick);
|
|
67
|
+
unsubEvents.push(() => fullscreenBtn.removeEventListener("click", onFullscreenClick));
|
|
68
|
+
// Listen for fullscreen change events to sync state
|
|
69
|
+
const onFullscreenChange = () => {
|
|
70
|
+
const root = el.closest(".udoc-viewer-root");
|
|
71
|
+
const isFullscreen = document.fullscreenElement === root;
|
|
72
|
+
store.dispatch({ type: "SET_FULLSCREEN", isFullscreen });
|
|
73
|
+
};
|
|
74
|
+
document.addEventListener("fullscreenchange", onFullscreenChange);
|
|
75
|
+
unsubEvents.push(() => document.removeEventListener("fullscreenchange", onFullscreenChange));
|
|
76
|
+
// Subscribe to state to update fullscreen button icon
|
|
77
|
+
unsubRender = store.subscribeRender((prev, next) => {
|
|
78
|
+
if (prev.isFullscreen !== next.isFullscreen) {
|
|
79
|
+
fullscreenBtn.innerHTML = next.isFullscreen ? ICON_FULLSCREEN_EXIT : ICON_FULLSCREEN;
|
|
80
|
+
fullscreenBtn.setAttribute("aria-label", next.isFullscreen ? "Exit fullscreen" : "Fullscreen");
|
|
81
|
+
}
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
function destroy() {
|
|
85
|
+
if (unsubRender)
|
|
86
|
+
unsubRender();
|
|
87
|
+
for (const off of unsubEvents)
|
|
88
|
+
off();
|
|
89
|
+
el.remove();
|
|
90
|
+
}
|
|
91
|
+
return { el, mount, destroy };
|
|
92
|
+
}
|
|
93
|
+
//# sourceMappingURL=Toolbar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Toolbar.js","sourceRoot":"","sources":["../../../../../src/ui/viewer/components/Toolbar.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { Store } from "../../framework/store";
|
|
2
|
+
import type { ViewerState } from "../state";
|
|
3
|
+
import type { Action } from "../actions";
|
|
4
|
+
export declare function createViewModeMenu(): {
|
|
5
|
+
el: HTMLDivElement;
|
|
6
|
+
mount: (store: Store<ViewerState, Action>) => void;
|
|
7
|
+
destroy: () => void;
|
|
8
|
+
};
|
|
9
|
+
//# sourceMappingURL=ViewModeMenu.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ViewModeMenu.d.ts","sourceRoot":"","sources":["../../../../../src/ui/viewer/components/ViewModeMenu.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAGnD,OAAO,KAAK,EAAE,WAAW,EAAqD,MAAM,UAAU,CAAC;AAC/F,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AAmEzC,wBAAgB,kBAAkB;;mBAmIR,KAAK,CAAC,WAAW,EAAE,MAAM,CAAC,KAAG,IAAI;mBAwCnC,IAAI;EAO3B"}
|
|
@@ -0,0 +1,169 @@
|
|
|
1
|
+
import { subscribeSelector } from "../../framework/selectors";
|
|
2
|
+
import { on } from "../../framework/events";
|
|
3
|
+
import { ICON_VIEW_MODE, ICON_SCROLL_SPREAD, ICON_SCROLL_CONTINUOUS, ICON_LAYOUT_SINGLE, ICON_LAYOUT_DOUBLE, ICON_LAYOUT_DOUBLE_ODD_RIGHT, ICON_LAYOUT_DOUBLE_ODD_LEFT, ICON_ROTATE_0, ICON_ROTATE_90, ICON_ROTATE_180, ICON_ROTATE_270, ICON_SPACING_ALL, ICON_SPACING_NONE, ICON_SPACING_SPREAD, ICON_SPACING_PAGE } from "../icons";
|
|
4
|
+
function sliceEqual(a, b) {
|
|
5
|
+
return (a.scrollMode === b.scrollMode &&
|
|
6
|
+
a.layoutMode === b.layoutMode &&
|
|
7
|
+
a.pageRotation === b.pageRotation &&
|
|
8
|
+
a.spacingMode === b.spacingMode);
|
|
9
|
+
}
|
|
10
|
+
const SCROLL_OPTIONS = [
|
|
11
|
+
{ value: "spread", icon: ICON_SCROLL_SPREAD, label: "Spread" },
|
|
12
|
+
{ value: "continuous", icon: ICON_SCROLL_CONTINUOUS, label: "Continuous" }
|
|
13
|
+
];
|
|
14
|
+
const LAYOUT_OPTIONS = [
|
|
15
|
+
{ value: "single-page", icon: ICON_LAYOUT_SINGLE, label: "Single" },
|
|
16
|
+
{ value: "double-page", icon: ICON_LAYOUT_DOUBLE, label: "Double" },
|
|
17
|
+
{ value: "double-page-odd-right", icon: ICON_LAYOUT_DOUBLE_ODD_RIGHT, label: "Cover Right" },
|
|
18
|
+
{ value: "double-page-odd-left", icon: ICON_LAYOUT_DOUBLE_ODD_LEFT, label: "Cover Left" }
|
|
19
|
+
];
|
|
20
|
+
const ROTATION_OPTIONS = [
|
|
21
|
+
{ value: 0, icon: ICON_ROTATE_0, label: "0°" },
|
|
22
|
+
{ value: 90, icon: ICON_ROTATE_90, label: "90°" },
|
|
23
|
+
{ value: 180, icon: ICON_ROTATE_180, label: "180°" },
|
|
24
|
+
{ value: 270, icon: ICON_ROTATE_270, label: "270°" }
|
|
25
|
+
];
|
|
26
|
+
const SPACING_OPTIONS = [
|
|
27
|
+
{ value: "all", icon: ICON_SPACING_ALL, label: "All" },
|
|
28
|
+
{ value: "none", icon: ICON_SPACING_NONE, label: "None" },
|
|
29
|
+
{ value: "spread-only", icon: ICON_SPACING_SPREAD, label: "Spread" },
|
|
30
|
+
{ value: "page-only", icon: ICON_SPACING_PAGE, label: "Page" }
|
|
31
|
+
];
|
|
32
|
+
export function createViewModeMenu() {
|
|
33
|
+
const el = document.createElement("div");
|
|
34
|
+
el.className = "udoc-view-mode-menu";
|
|
35
|
+
// Toggle button
|
|
36
|
+
const toggleBtn = document.createElement("button");
|
|
37
|
+
toggleBtn.className = "udoc-floating-toolbar__btn";
|
|
38
|
+
toggleBtn.innerHTML = ICON_VIEW_MODE;
|
|
39
|
+
toggleBtn.title = "View settings";
|
|
40
|
+
el.appendChild(toggleBtn);
|
|
41
|
+
// Dropdown panel
|
|
42
|
+
const dropdown = document.createElement("div");
|
|
43
|
+
dropdown.className = "udoc-view-mode-menu__dropdown";
|
|
44
|
+
dropdown.style.display = "none";
|
|
45
|
+
el.appendChild(dropdown);
|
|
46
|
+
let unsub = null;
|
|
47
|
+
const unsubEvents = [];
|
|
48
|
+
let storeRef = null;
|
|
49
|
+
let isOpen = false;
|
|
50
|
+
function createSection(title, options, currentValue, onSelect, sectionOptions = {}) {
|
|
51
|
+
const section = document.createElement("div");
|
|
52
|
+
section.className = "udoc-view-mode-menu__section";
|
|
53
|
+
const titleEl = document.createElement("div");
|
|
54
|
+
titleEl.className = "udoc-view-mode-menu__title";
|
|
55
|
+
titleEl.textContent = title;
|
|
56
|
+
section.appendChild(titleEl);
|
|
57
|
+
const optionsContainer = document.createElement("div");
|
|
58
|
+
optionsContainer.className = "udoc-view-mode-menu__options";
|
|
59
|
+
for (const opt of options) {
|
|
60
|
+
const btn = document.createElement("button");
|
|
61
|
+
btn.className = "udoc-view-mode-menu__option";
|
|
62
|
+
// Only mark active if value matches and not in "no selection" state
|
|
63
|
+
const isActive = opt.value === currentValue && !sectionOptions.allowNoSelection;
|
|
64
|
+
if (isActive) {
|
|
65
|
+
btn.classList.add("udoc-view-mode-menu__option--active");
|
|
66
|
+
}
|
|
67
|
+
if (sectionOptions.disabled) {
|
|
68
|
+
btn.disabled = true;
|
|
69
|
+
btn.classList.add("udoc-view-mode-menu__option--disabled");
|
|
70
|
+
}
|
|
71
|
+
btn.title = opt.label;
|
|
72
|
+
const iconSpan = document.createElement("span");
|
|
73
|
+
iconSpan.className = "udoc-view-mode-menu__option-icon";
|
|
74
|
+
iconSpan.innerHTML = opt.icon;
|
|
75
|
+
btn.appendChild(iconSpan);
|
|
76
|
+
if (!sectionOptions.disabled) {
|
|
77
|
+
unsubEvents.push(on(btn, "click", (e) => {
|
|
78
|
+
e.stopPropagation();
|
|
79
|
+
onSelect(opt.value);
|
|
80
|
+
}));
|
|
81
|
+
}
|
|
82
|
+
optionsContainer.appendChild(btn);
|
|
83
|
+
}
|
|
84
|
+
section.appendChild(optionsContainer);
|
|
85
|
+
return section;
|
|
86
|
+
}
|
|
87
|
+
function buildDropdown(slice) {
|
|
88
|
+
// Clear existing content
|
|
89
|
+
dropdown.innerHTML = "";
|
|
90
|
+
// Scroll mode section
|
|
91
|
+
dropdown.appendChild(createSection("Scroll", SCROLL_OPTIONS, slice.scrollMode, (mode) => {
|
|
92
|
+
storeRef?.dispatch({ type: "SET_SCROLL_MODE", mode });
|
|
93
|
+
}));
|
|
94
|
+
// Layout mode section
|
|
95
|
+
dropdown.appendChild(createSection("Layout", LAYOUT_OPTIONS, slice.layoutMode, (mode) => {
|
|
96
|
+
storeRef?.dispatch({ type: "SET_LAYOUT_MODE", mode });
|
|
97
|
+
}));
|
|
98
|
+
// Page rotation section
|
|
99
|
+
dropdown.appendChild(createSection("Rotation", ROTATION_OPTIONS, slice.pageRotation, (rotation) => {
|
|
100
|
+
storeRef?.dispatch({ type: "SET_PAGE_ROTATION", rotation });
|
|
101
|
+
}));
|
|
102
|
+
// Spacing section
|
|
103
|
+
dropdown.appendChild(createSection("Spacing", SPACING_OPTIONS, slice.spacingMode, (mode) => {
|
|
104
|
+
storeRef?.dispatch({ type: "SET_SPACING_MODE", mode });
|
|
105
|
+
}));
|
|
106
|
+
}
|
|
107
|
+
function toggleDropdown() {
|
|
108
|
+
isOpen = !isOpen;
|
|
109
|
+
dropdown.style.display = isOpen ? "block" : "none";
|
|
110
|
+
toggleBtn.classList.toggle("udoc-floating-toolbar__btn--active", isOpen);
|
|
111
|
+
}
|
|
112
|
+
function closeDropdown() {
|
|
113
|
+
if (isOpen) {
|
|
114
|
+
isOpen = false;
|
|
115
|
+
dropdown.style.display = "none";
|
|
116
|
+
toggleBtn.classList.remove("udoc-floating-toolbar__btn--active");
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
function mount(store) {
|
|
120
|
+
storeRef = store;
|
|
121
|
+
// Toggle button click
|
|
122
|
+
unsubEvents.push(on(toggleBtn, "click", (e) => {
|
|
123
|
+
e.stopPropagation();
|
|
124
|
+
toggleDropdown();
|
|
125
|
+
}));
|
|
126
|
+
// Close on outside click
|
|
127
|
+
const handleOutsideClick = (e) => {
|
|
128
|
+
if (!el.contains(e.target)) {
|
|
129
|
+
closeDropdown();
|
|
130
|
+
}
|
|
131
|
+
};
|
|
132
|
+
document.addEventListener("click", handleOutsideClick);
|
|
133
|
+
unsubEvents.push(() => document.removeEventListener("click", handleOutsideClick));
|
|
134
|
+
// Close on escape
|
|
135
|
+
const handleEscape = (e) => {
|
|
136
|
+
if (e.key === "Escape") {
|
|
137
|
+
closeDropdown();
|
|
138
|
+
}
|
|
139
|
+
};
|
|
140
|
+
document.addEventListener("keydown", handleEscape);
|
|
141
|
+
unsubEvents.push(() => document.removeEventListener("keydown", handleEscape));
|
|
142
|
+
const applyState = (slice) => {
|
|
143
|
+
buildDropdown(slice);
|
|
144
|
+
};
|
|
145
|
+
// Initial build
|
|
146
|
+
applyState(selectSlice(store.getState()));
|
|
147
|
+
// Subscribe to changes
|
|
148
|
+
unsub = subscribeSelector(store, selectSlice, applyState, {
|
|
149
|
+
equality: sliceEqual
|
|
150
|
+
});
|
|
151
|
+
}
|
|
152
|
+
function destroy() {
|
|
153
|
+
if (unsub)
|
|
154
|
+
unsub();
|
|
155
|
+
for (const off of unsubEvents)
|
|
156
|
+
off();
|
|
157
|
+
el.remove();
|
|
158
|
+
}
|
|
159
|
+
return { el, mount, destroy };
|
|
160
|
+
}
|
|
161
|
+
function selectSlice(state) {
|
|
162
|
+
return {
|
|
163
|
+
scrollMode: state.scrollMode,
|
|
164
|
+
layoutMode: state.layoutMode,
|
|
165
|
+
pageRotation: state.pageRotation,
|
|
166
|
+
spacingMode: state.spacingMode
|
|
167
|
+
};
|
|
168
|
+
}
|
|
169
|
+
//# sourceMappingURL=ViewModeMenu.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ViewModeMenu.js","sourceRoot":"","sources":["../../../../../src/ui/viewer/components/ViewModeMenu.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { Store } from "../../framework/store";
|
|
2
|
+
import { type ViewerState } from "../state";
|
|
3
|
+
import type { Action } from "../actions";
|
|
4
|
+
import type { WorkerClient } from "../../../worker/index.js";
|
|
5
|
+
export declare function createViewport(): {
|
|
6
|
+
el: HTMLDivElement;
|
|
7
|
+
mount: (parent: HTMLElement, store: Store<ViewerState, Action>, wc: WorkerClient) => void;
|
|
8
|
+
destroy: () => void;
|
|
9
|
+
};
|
|
10
|
+
//# sourceMappingURL=Viewport.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Viewport.d.ts","sourceRoot":"","sources":["../../../../../src/ui/viewer/components/Viewport.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAEnD,OAAO,EAEH,KAAK,WAAW,EAOnB,MAAM,UAAU,CAAC;AAClB,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AAIzC,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAmZ7D,wBAAgB,cAAc;;oBAoKH,WAAW,SAAS,KAAK,CAAC,WAAW,EAAE,MAAM,CAAC,MAAM,YAAY,KAAG,IAAI;mBAwsB1E,IAAI;EAsB3B"}
|