@docmentis/udoc-viewer 0.5.2 → 0.5.3
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/package.json +1 -1
- package/dist/package.json +0 -56
- package/dist/src/UDocClient.d.ts +0 -383
- package/dist/src/UDocClient.d.ts.map +0 -1
- package/dist/src/UDocClient.js +0 -428
- package/dist/src/UDocClient.js.map +0 -1
- package/dist/src/UDocViewer.d.ts +0 -271
- package/dist/src/UDocViewer.d.ts.map +0 -1
- package/dist/src/UDocViewer.js +0 -769
- package/dist/src/UDocViewer.js.map +0 -1
- package/dist/src/fonts.d.ts +0 -29
- package/dist/src/fonts.d.ts.map +0 -1
- package/dist/src/fonts.js +0 -30
- package/dist/src/fonts.js.map +0 -1
- package/dist/src/index.d.ts +0 -9
- package/dist/src/index.d.ts.map +0 -1
- package/dist/src/index.js +0 -8
- package/dist/src/index.js.map +0 -1
- package/dist/src/performance/PerformanceCounter.d.ts +0 -132
- package/dist/src/performance/PerformanceCounter.d.ts.map +0 -1
- package/dist/src/performance/PerformanceCounter.js +0 -129
- package/dist/src/performance/PerformanceCounter.js.map +0 -1
- package/dist/src/performance/index.d.ts +0 -2
- package/dist/src/performance/index.d.ts.map +0 -1
- package/dist/src/performance/index.js +0 -2
- package/dist/src/performance/index.js.map +0 -1
- package/dist/src/ui/framework/component.d.ts +0 -68
- package/dist/src/ui/framework/component.d.ts.map +0 -1
- package/dist/src/ui/framework/component.js +0 -87
- package/dist/src/ui/framework/component.js.map +0 -1
- package/dist/src/ui/framework/dom.d.ts +0 -19
- package/dist/src/ui/framework/dom.d.ts.map +0 -1
- package/dist/src/ui/framework/dom.js +0 -29
- package/dist/src/ui/framework/dom.js.map +0 -1
- package/dist/src/ui/framework/events.d.ts +0 -18
- package/dist/src/ui/framework/events.d.ts.map +0 -1
- package/dist/src/ui/framework/events.js +0 -23
- package/dist/src/ui/framework/events.js.map +0 -1
- package/dist/src/ui/framework/index.d.ts +0 -15
- package/dist/src/ui/framework/index.d.ts.map +0 -1
- package/dist/src/ui/framework/index.js +0 -15
- package/dist/src/ui/framework/index.js.map +0 -1
- package/dist/src/ui/framework/selectors.d.ts +0 -51
- package/dist/src/ui/framework/selectors.d.ts.map +0 -1
- package/dist/src/ui/framework/selectors.js +0 -30
- package/dist/src/ui/framework/selectors.js.map +0 -1
- package/dist/src/ui/framework/store.d.ts +0 -37
- package/dist/src/ui/framework/store.d.ts.map +0 -1
- package/dist/src/ui/framework/store.js +0 -54
- package/dist/src/ui/framework/store.js.map +0 -1
- package/dist/src/ui/viewer/actions.d.ts +0 -131
- package/dist/src/ui/viewer/actions.d.ts.map +0 -1
- package/dist/src/ui/viewer/actions.js +0 -2
- package/dist/src/ui/viewer/actions.js.map +0 -1
- package/dist/src/ui/viewer/annotation/LinkRenderer.d.ts +0 -9
- package/dist/src/ui/viewer/annotation/LinkRenderer.d.ts.map +0 -1
- package/dist/src/ui/viewer/annotation/LinkRenderer.js +0 -17
- package/dist/src/ui/viewer/annotation/LinkRenderer.js.map +0 -1
- package/dist/src/ui/viewer/annotation/MarkupRenderer.d.ts +0 -21
- package/dist/src/ui/viewer/annotation/MarkupRenderer.d.ts.map +0 -1
- package/dist/src/ui/viewer/annotation/MarkupRenderer.js +0 -138
- package/dist/src/ui/viewer/annotation/MarkupRenderer.js.map +0 -1
- package/dist/src/ui/viewer/annotation/ShapeRenderer.d.ts +0 -33
- package/dist/src/ui/viewer/annotation/ShapeRenderer.d.ts.map +0 -1
- package/dist/src/ui/viewer/annotation/ShapeRenderer.js +0 -378
- package/dist/src/ui/viewer/annotation/ShapeRenderer.js.map +0 -1
- package/dist/src/ui/viewer/annotation/TextRenderer.d.ts +0 -23
- package/dist/src/ui/viewer/annotation/TextRenderer.d.ts.map +0 -1
- package/dist/src/ui/viewer/annotation/TextRenderer.js +0 -196
- package/dist/src/ui/viewer/annotation/TextRenderer.js.map +0 -1
- package/dist/src/ui/viewer/annotation/index.d.ts +0 -8
- package/dist/src/ui/viewer/annotation/index.d.ts.map +0 -1
- package/dist/src/ui/viewer/annotation/index.js +0 -8
- package/dist/src/ui/viewer/annotation/index.js.map +0 -1
- package/dist/src/ui/viewer/annotation/render.d.ts +0 -24
- package/dist/src/ui/viewer/annotation/render.d.ts.map +0 -1
- package/dist/src/ui/viewer/annotation/render.js +0 -184
- package/dist/src/ui/viewer/annotation/render.js.map +0 -1
- package/dist/src/ui/viewer/annotation/types.d.ts +0 -239
- package/dist/src/ui/viewer/annotation/types.d.ts.map +0 -1
- package/dist/src/ui/viewer/annotation/types.js +0 -7
- package/dist/src/ui/viewer/annotation/types.js.map +0 -1
- package/dist/src/ui/viewer/annotation/utils.d.ts +0 -37
- package/dist/src/ui/viewer/annotation/utils.d.ts.map +0 -1
- package/dist/src/ui/viewer/annotation/utils.js +0 -82
- package/dist/src/ui/viewer/annotation/utils.js.map +0 -1
- package/dist/src/ui/viewer/components/AnnotationPanel.d.ts +0 -19
- package/dist/src/ui/viewer/components/AnnotationPanel.d.ts.map +0 -1
- package/dist/src/ui/viewer/components/AnnotationPanel.js +0 -284
- package/dist/src/ui/viewer/components/AnnotationPanel.js.map +0 -1
- package/dist/src/ui/viewer/components/FloatingToolbar.d.ts +0 -9
- package/dist/src/ui/viewer/components/FloatingToolbar.d.ts.map +0 -1
- package/dist/src/ui/viewer/components/FloatingToolbar.js +0 -305
- package/dist/src/ui/viewer/components/FloatingToolbar.js.map +0 -1
- package/dist/src/ui/viewer/components/LeftPanel.d.ts +0 -10
- package/dist/src/ui/viewer/components/LeftPanel.d.ts.map +0 -1
- package/dist/src/ui/viewer/components/LeftPanel.js +0 -165
- package/dist/src/ui/viewer/components/LeftPanel.js.map +0 -1
- package/dist/src/ui/viewer/components/LoadingOverlay.d.ts +0 -12
- package/dist/src/ui/viewer/components/LoadingOverlay.d.ts.map +0 -1
- package/dist/src/ui/viewer/components/LoadingOverlay.js +0 -88
- package/dist/src/ui/viewer/components/LoadingOverlay.js.map +0 -1
- package/dist/src/ui/viewer/components/OutlinePanel.d.ts +0 -10
- package/dist/src/ui/viewer/components/OutlinePanel.d.ts.map +0 -1
- package/dist/src/ui/viewer/components/OutlinePanel.js +0 -169
- package/dist/src/ui/viewer/components/OutlinePanel.js.map +0 -1
- package/dist/src/ui/viewer/components/PasswordDialog.d.ts +0 -15
- package/dist/src/ui/viewer/components/PasswordDialog.d.ts.map +0 -1
- package/dist/src/ui/viewer/components/PasswordDialog.js +0 -143
- package/dist/src/ui/viewer/components/PasswordDialog.js.map +0 -1
- package/dist/src/ui/viewer/components/RightPanel.d.ts +0 -9
- package/dist/src/ui/viewer/components/RightPanel.d.ts.map +0 -1
- package/dist/src/ui/viewer/components/RightPanel.js +0 -102
- package/dist/src/ui/viewer/components/RightPanel.js.map +0 -1
- package/dist/src/ui/viewer/components/Spread.d.ts +0 -43
- package/dist/src/ui/viewer/components/Spread.d.ts.map +0 -1
- package/dist/src/ui/viewer/components/Spread.js +0 -345
- package/dist/src/ui/viewer/components/Spread.js.map +0 -1
- package/dist/src/ui/viewer/components/ThumbnailPanel.d.ts +0 -11
- package/dist/src/ui/viewer/components/ThumbnailPanel.d.ts.map +0 -1
- package/dist/src/ui/viewer/components/ThumbnailPanel.js +0 -240
- package/dist/src/ui/viewer/components/ThumbnailPanel.js.map +0 -1
- package/dist/src/ui/viewer/components/Toolbar.d.ts +0 -9
- package/dist/src/ui/viewer/components/Toolbar.d.ts.map +0 -1
- package/dist/src/ui/viewer/components/Toolbar.js +0 -93
- package/dist/src/ui/viewer/components/Toolbar.js.map +0 -1
- package/dist/src/ui/viewer/components/ViewModeMenu.d.ts +0 -9
- package/dist/src/ui/viewer/components/ViewModeMenu.d.ts.map +0 -1
- package/dist/src/ui/viewer/components/ViewModeMenu.js +0 -169
- package/dist/src/ui/viewer/components/ViewModeMenu.js.map +0 -1
- package/dist/src/ui/viewer/components/Viewport.d.ts +0 -10
- package/dist/src/ui/viewer/components/Viewport.d.ts.map +0 -1
- package/dist/src/ui/viewer/components/Viewport.js +0 -1076
- package/dist/src/ui/viewer/components/Viewport.js.map +0 -1
- package/dist/src/ui/viewer/effects.d.ts +0 -8
- package/dist/src/ui/viewer/effects.d.ts.map +0 -1
- package/dist/src/ui/viewer/effects.js +0 -207
- package/dist/src/ui/viewer/effects.js.map +0 -1
- package/dist/src/ui/viewer/icons.d.ts +0 -32
- package/dist/src/ui/viewer/icons.d.ts.map +0 -1
- package/dist/src/ui/viewer/icons.js +0 -44
- package/dist/src/ui/viewer/icons.js.map +0 -1
- package/dist/src/ui/viewer/index.d.ts +0 -6
- package/dist/src/ui/viewer/index.d.ts.map +0 -1
- package/dist/src/ui/viewer/index.js +0 -6
- package/dist/src/ui/viewer/index.js.map +0 -1
- package/dist/src/ui/viewer/layout/index.d.ts +0 -3
- package/dist/src/ui/viewer/layout/index.d.ts.map +0 -1
- package/dist/src/ui/viewer/layout/index.js +0 -3
- package/dist/src/ui/viewer/layout/index.js.map +0 -1
- package/dist/src/ui/viewer/layout/pixelAlign.d.ts +0 -7
- package/dist/src/ui/viewer/layout/pixelAlign.d.ts.map +0 -1
- package/dist/src/ui/viewer/layout/pixelAlign.js +0 -22
- package/dist/src/ui/viewer/layout/pixelAlign.js.map +0 -1
- package/dist/src/ui/viewer/layout/spreadLayout.d.ts +0 -93
- package/dist/src/ui/viewer/layout/spreadLayout.d.ts.map +0 -1
- package/dist/src/ui/viewer/layout/spreadLayout.js +0 -315
- package/dist/src/ui/viewer/layout/spreadLayout.js.map +0 -1
- package/dist/src/ui/viewer/navigation.d.ts +0 -80
- package/dist/src/ui/viewer/navigation.d.ts.map +0 -1
- package/dist/src/ui/viewer/navigation.js +0 -59
- package/dist/src/ui/viewer/navigation.js.map +0 -1
- package/dist/src/ui/viewer/reducer.d.ts +0 -4
- package/dist/src/ui/viewer/reducer.d.ts.map +0 -1
- package/dist/src/ui/viewer/reducer.js +0 -305
- package/dist/src/ui/viewer/reducer.js.map +0 -1
- package/dist/src/ui/viewer/shell.d.ts +0 -34
- package/dist/src/ui/viewer/shell.d.ts.map +0 -1
- package/dist/src/ui/viewer/shell.js +0 -93
- package/dist/src/ui/viewer/shell.js.map +0 -1
- package/dist/src/ui/viewer/state.d.ts +0 -89
- package/dist/src/ui/viewer/state.d.ts.map +0 -1
- package/dist/src/ui/viewer/state.js +0 -55
- package/dist/src/ui/viewer/state.js.map +0 -1
- package/dist/src/ui/viewer/styles-inline.d.ts +0 -2
- package/dist/src/ui/viewer/styles-inline.d.ts.map +0 -1
- package/dist/src/ui/viewer/styles-inline.js +0 -1584
- package/dist/src/ui/viewer/styles-inline.js.map +0 -1
- package/dist/src/ui/viewer/text/index.d.ts +0 -7
- package/dist/src/ui/viewer/text/index.d.ts.map +0 -1
- package/dist/src/ui/viewer/text/index.js +0 -3
- package/dist/src/ui/viewer/text/index.js.map +0 -1
- package/dist/src/ui/viewer/text/render.d.ts +0 -19
- package/dist/src/ui/viewer/text/render.d.ts.map +0 -1
- package/dist/src/ui/viewer/text/render.js +0 -228
- package/dist/src/ui/viewer/text/render.js.map +0 -1
- package/dist/src/ui/viewer/text/selection.d.ts +0 -12
- package/dist/src/ui/viewer/text/selection.d.ts.map +0 -1
- package/dist/src/ui/viewer/text/selection.js +0 -70
- package/dist/src/ui/viewer/text/selection.js.map +0 -1
- package/dist/src/ui/viewer/text/types.d.ts +0 -37
- package/dist/src/ui/viewer/text/types.d.ts.map +0 -1
- package/dist/src/ui/viewer/text/types.js +0 -7
- package/dist/src/ui/viewer/text/types.js.map +0 -1
- package/dist/src/wasm/LICENSE +0 -104
- package/dist/src/wasm/udoc.d.ts +0 -480
- package/dist/src/wasm/udoc.js +0 -1738
- package/dist/src/wasm/udoc_bg.wasm +0 -0
- package/dist/src/wasm/udoc_bg.wasm.d.ts +0 -45
- package/dist/src/worker/WorkerClient.d.ts +0 -335
- package/dist/src/worker/WorkerClient.d.ts.map +0 -1
- package/dist/src/worker/WorkerClient.js +0 -903
- package/dist/src/worker/WorkerClient.js.map +0 -1
- package/dist/src/worker/index.d.ts +0 -4
- package/dist/src/worker/index.d.ts.map +0 -1
- package/dist/src/worker/index.js +0 -2
- package/dist/src/worker/index.js.map +0 -1
- package/dist/src/worker/worker.d.ts +0 -437
- package/dist/src/worker/worker.d.ts.map +0 -1
- package/dist/src/worker/worker.js +0 -237
- package/dist/src/worker/worker.js.map +0 -1
|
@@ -1,240 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ThumbnailPanel.js","sourceRoot":"","sources":["../../../../../src/ui/viewer/components/ThumbnailPanel.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,9 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,93 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Toolbar.js","sourceRoot":"","sources":["../../../../../src/ui/viewer/components/Toolbar.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,9 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,169 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ViewModeMenu.js","sourceRoot":"","sources":["../../../../../src/ui/viewer/components/ViewModeMenu.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,10 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|