@docmentis/udoc-viewer 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +180 -0
- package/dist/UDocClient.d.ts +197 -0
- package/dist/UDocClient.d.ts.map +1 -0
- package/dist/UDocClient.js +170 -0
- package/dist/UDocClient.js.map +1 -0
- package/dist/UDocViewer.d.ts +196 -0
- package/dist/UDocViewer.d.ts.map +1 -0
- package/dist/UDocViewer.js +427 -0
- package/dist/UDocViewer.js.map +1 -0
- package/dist/WorkerClient.d.ts +36 -0
- package/dist/WorkerClient.d.ts.map +1 -0
- package/dist/WorkerClient.js +121 -0
- package/dist/WorkerClient.js.map +1 -0
- package/dist/annotation/AnnotationLayer.d.ts +166 -0
- package/dist/annotation/AnnotationLayer.d.ts.map +1 -0
- package/dist/annotation/AnnotationLayer.js +1090 -0
- package/dist/annotation/AnnotationLayer.js.map +1 -0
- package/dist/annotation/index.d.ts +6 -0
- package/dist/annotation/index.d.ts.map +1 -0
- package/dist/annotation/index.js +6 -0
- package/dist/annotation/index.js.map +1 -0
- package/dist/components/FloatingBar.d.ts +102 -0
- package/dist/components/FloatingBar.d.ts.map +1 -0
- package/dist/components/FloatingBar.js +513 -0
- package/dist/components/FloatingBar.js.map +1 -0
- package/dist/components/Header.d.ts +46 -0
- package/dist/components/Header.d.ts.map +1 -0
- package/dist/components/Header.js +93 -0
- package/dist/components/Header.js.map +1 -0
- package/dist/components/index.d.ts +6 -0
- package/dist/components/index.d.ts.map +1 -0
- package/dist/components/index.js +4 -0
- package/dist/components/index.js.map +1 -0
- package/dist/components/panels/CommentsPanel.d.ts +33 -0
- package/dist/components/panels/CommentsPanel.d.ts.map +1 -0
- package/dist/components/panels/CommentsPanel.js +176 -0
- package/dist/components/panels/CommentsPanel.js.map +1 -0
- package/dist/components/panels/OutlinePanel.d.ts +30 -0
- package/dist/components/panels/OutlinePanel.d.ts.map +1 -0
- package/dist/components/panels/OutlinePanel.js +144 -0
- package/dist/components/panels/OutlinePanel.js.map +1 -0
- package/dist/components/panels/ThumbnailsPanel.d.ts +51 -0
- package/dist/components/panels/ThumbnailsPanel.d.ts.map +1 -0
- package/dist/components/panels/ThumbnailsPanel.js +160 -0
- package/dist/components/panels/ThumbnailsPanel.js.map +1 -0
- package/dist/components/panels/index.d.ts +7 -0
- package/dist/components/panels/index.d.ts.map +1 -0
- package/dist/components/panels/index.js +4 -0
- package/dist/components/panels/index.js.map +1 -0
- package/dist/constants.d.ts +25 -0
- package/dist/constants.d.ts.map +1 -0
- package/dist/constants.js +46 -0
- package/dist/constants.js.map +1 -0
- package/dist/core/NavigationController.d.ts +54 -0
- package/dist/core/NavigationController.d.ts.map +1 -0
- package/dist/core/NavigationController.js +145 -0
- package/dist/core/NavigationController.js.map +1 -0
- package/dist/core/PerfTimer.d.ts +12 -0
- package/dist/core/PerfTimer.d.ts.map +1 -0
- package/dist/core/PerfTimer.js +32 -0
- package/dist/core/PerfTimer.js.map +1 -0
- package/dist/core/ViewerState.d.ts +108 -0
- package/dist/core/ViewerState.d.ts.map +1 -0
- package/dist/core/ViewerState.js +179 -0
- package/dist/core/ViewerState.js.map +1 -0
- package/dist/core/constants.d.ts +24 -0
- package/dist/core/constants.d.ts.map +1 -0
- package/dist/core/constants.js +42 -0
- package/dist/core/constants.js.map +1 -0
- package/dist/core/index.d.ts +8 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +11 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/types.d.ts +573 -0
- package/dist/core/types.d.ts.map +1 -0
- package/dist/core/types.js +5 -0
- package/dist/core/types.js.map +1 -0
- package/dist/icons/icons.d.ts +41 -0
- package/dist/icons/icons.d.ts.map +1 -0
- package/dist/icons/icons.js +51 -0
- package/dist/icons/icons.js.map +1 -0
- package/dist/icons/index.d.ts +3 -0
- package/dist/icons/index.d.ts.map +1 -0
- package/dist/icons/index.js +2 -0
- package/dist/icons/index.js.map +1 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +6 -0
- package/dist/index.js.map +1 -0
- package/dist/layout/BandManager.d.ts +87 -0
- package/dist/layout/BandManager.d.ts.map +1 -0
- package/dist/layout/BandManager.js +185 -0
- package/dist/layout/BandManager.js.map +1 -0
- package/dist/layout/LayoutCalculator.d.ts +42 -0
- package/dist/layout/LayoutCalculator.d.ts.map +1 -0
- package/dist/layout/LayoutCalculator.js +180 -0
- package/dist/layout/LayoutCalculator.js.map +1 -0
- package/dist/layout/LayoutState.d.ts +46 -0
- package/dist/layout/LayoutState.d.ts.map +1 -0
- package/dist/layout/LayoutState.js +109 -0
- package/dist/layout/LayoutState.js.map +1 -0
- package/dist/layout/TransitionCoordinator.d.ts +11 -0
- package/dist/layout/TransitionCoordinator.d.ts.map +1 -0
- package/dist/layout/TransitionCoordinator.js +22 -0
- package/dist/layout/TransitionCoordinator.js.map +1 -0
- package/dist/layout/index.d.ts +7 -0
- package/dist/layout/index.d.ts.map +1 -0
- package/dist/layout/index.js +4 -0
- package/dist/layout/index.js.map +1 -0
- package/dist/rendering/BandManager.d.ts +87 -0
- package/dist/rendering/BandManager.d.ts.map +1 -0
- package/dist/rendering/BandManager.js +185 -0
- package/dist/rendering/BandManager.js.map +1 -0
- package/dist/rendering/PageCache.d.ts +75 -0
- package/dist/rendering/PageCache.d.ts.map +1 -0
- package/dist/rendering/PageCache.js +122 -0
- package/dist/rendering/PageCache.js.map +1 -0
- package/dist/rendering/RenderQueue.d.ts +75 -0
- package/dist/rendering/RenderQueue.d.ts.map +1 -0
- package/dist/rendering/RenderQueue.js +105 -0
- package/dist/rendering/RenderQueue.js.map +1 -0
- package/dist/rendering/ThumbnailQueue.d.ts +57 -0
- package/dist/rendering/ThumbnailQueue.d.ts.map +1 -0
- package/dist/rendering/ThumbnailQueue.js +85 -0
- package/dist/rendering/ThumbnailQueue.js.map +1 -0
- package/dist/rendering/index.d.ts +13 -0
- package/dist/rendering/index.d.ts.map +1 -0
- package/dist/rendering/index.js +10 -0
- package/dist/rendering/index.js.map +1 -0
- package/dist/rendering/types.d.ts +72 -0
- package/dist/rendering/types.d.ts.map +1 -0
- package/dist/rendering/types.js +5 -0
- package/dist/rendering/types.js.map +1 -0
- package/dist/styles/index.d.ts +6 -0
- package/dist/styles/index.d.ts.map +1 -0
- package/dist/styles/index.js +1221 -0
- package/dist/styles/index.js.map +1 -0
- package/dist/types.d.ts +6 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +6 -0
- package/dist/types.js.map +1 -0
- package/dist/ui/Component.d.ts +127 -0
- package/dist/ui/Component.d.ts.map +1 -0
- package/dist/ui/Component.js +201 -0
- package/dist/ui/Component.js.map +1 -0
- package/dist/ui/annotation/AnnotationLayer.d.ts +90 -0
- package/dist/ui/annotation/AnnotationLayer.d.ts.map +1 -0
- package/dist/ui/annotation/AnnotationLayer.js +322 -0
- package/dist/ui/annotation/AnnotationLayer.js.map +1 -0
- package/dist/ui/annotation/LinkRenderer.d.ts +32 -0
- package/dist/ui/annotation/LinkRenderer.d.ts.map +1 -0
- package/dist/ui/annotation/LinkRenderer.js +74 -0
- package/dist/ui/annotation/LinkRenderer.js.map +1 -0
- package/dist/ui/annotation/MarkupRenderer.d.ts +40 -0
- package/dist/ui/annotation/MarkupRenderer.d.ts.map +1 -0
- package/dist/ui/annotation/MarkupRenderer.js +154 -0
- package/dist/ui/annotation/MarkupRenderer.js.map +1 -0
- package/dist/ui/annotation/ShapeRenderer.d.ts +46 -0
- package/dist/ui/annotation/ShapeRenderer.d.ts.map +1 -0
- package/dist/ui/annotation/ShapeRenderer.js +376 -0
- package/dist/ui/annotation/ShapeRenderer.js.map +1 -0
- package/dist/ui/annotation/TextRenderer.d.ts +36 -0
- package/dist/ui/annotation/TextRenderer.d.ts.map +1 -0
- package/dist/ui/annotation/TextRenderer.js +199 -0
- package/dist/ui/annotation/TextRenderer.js.map +1 -0
- package/dist/ui/annotation/index.d.ts +17 -0
- package/dist/ui/annotation/index.d.ts.map +1 -0
- package/dist/ui/annotation/index.js +13 -0
- package/dist/ui/annotation/index.js.map +1 -0
- package/dist/ui/annotation/utils.d.ts +40 -0
- package/dist/ui/annotation/utils.d.ts.map +1 -0
- package/dist/ui/annotation/utils.js +62 -0
- package/dist/ui/annotation/utils.js.map +1 -0
- package/dist/ui/components/CommentsContent.d.ts +35 -0
- package/dist/ui/components/CommentsContent.d.ts.map +1 -0
- package/dist/ui/components/CommentsContent.js +203 -0
- package/dist/ui/components/CommentsContent.js.map +1 -0
- package/dist/ui/components/FloatingBar.d.ts +55 -0
- package/dist/ui/components/FloatingBar.d.ts.map +1 -0
- package/dist/ui/components/FloatingBar.js +585 -0
- package/dist/ui/components/FloatingBar.js.map +1 -0
- package/dist/ui/components/Header.d.ts +29 -0
- package/dist/ui/components/Header.d.ts.map +1 -0
- package/dist/ui/components/Header.js +127 -0
- package/dist/ui/components/Header.js.map +1 -0
- package/dist/ui/components/LeftPanel.d.ts +54 -0
- package/dist/ui/components/LeftPanel.d.ts.map +1 -0
- package/dist/ui/components/LeftPanel.js +202 -0
- package/dist/ui/components/LeftPanel.js.map +1 -0
- package/dist/ui/components/OutlineContent.d.ts +34 -0
- package/dist/ui/components/OutlineContent.d.ts.map +1 -0
- package/dist/ui/components/OutlineContent.js +147 -0
- package/dist/ui/components/OutlineContent.js.map +1 -0
- package/dist/ui/components/RightPanel.d.ts +52 -0
- package/dist/ui/components/RightPanel.d.ts.map +1 -0
- package/dist/ui/components/RightPanel.js +142 -0
- package/dist/ui/components/RightPanel.js.map +1 -0
- package/dist/ui/components/Viewport.d.ts +70 -0
- package/dist/ui/components/Viewport.d.ts.map +1 -0
- package/dist/ui/components/Viewport.js +173 -0
- package/dist/ui/components/Viewport.js.map +1 -0
- package/dist/ui/components/index.d.ts +11 -0
- package/dist/ui/components/index.d.ts.map +1 -0
- package/dist/ui/components/index.js +10 -0
- package/dist/ui/components/index.js.map +1 -0
- package/dist/ui/framework/component.d.ts +68 -0
- package/dist/ui/framework/component.d.ts.map +1 -0
- package/dist/ui/framework/component.js +87 -0
- package/dist/ui/framework/component.js.map +1 -0
- package/dist/ui/framework/dom.d.ts +19 -0
- package/dist/ui/framework/dom.d.ts.map +1 -0
- package/dist/ui/framework/dom.js +29 -0
- package/dist/ui/framework/dom.js.map +1 -0
- package/dist/ui/framework/events.d.ts +18 -0
- package/dist/ui/framework/events.d.ts.map +1 -0
- package/dist/ui/framework/events.js +23 -0
- package/dist/ui/framework/events.js.map +1 -0
- package/dist/ui/framework/index.d.ts +15 -0
- package/dist/ui/framework/index.d.ts.map +1 -0
- package/dist/ui/framework/index.js +15 -0
- package/dist/ui/framework/index.js.map +1 -0
- package/dist/ui/framework/selectors.d.ts +51 -0
- package/dist/ui/framework/selectors.d.ts.map +1 -0
- package/dist/ui/framework/selectors.js +30 -0
- package/dist/ui/framework/selectors.js.map +1 -0
- package/dist/ui/framework/store.d.ts +37 -0
- package/dist/ui/framework/store.d.ts.map +1 -0
- package/dist/ui/framework/store.js +54 -0
- package/dist/ui/framework/store.js.map +1 -0
- package/dist/ui/icons/icons.d.ts +43 -0
- package/dist/ui/icons/icons.d.ts.map +1 -0
- package/dist/ui/icons/icons.js +46 -0
- package/dist/ui/icons/icons.js.map +1 -0
- package/dist/ui/icons/index.d.ts +11 -0
- package/dist/ui/icons/index.d.ts.map +1 -0
- package/dist/ui/icons/index.js +18 -0
- package/dist/ui/icons/index.js.map +1 -0
- package/dist/ui/index.d.ts +7 -0
- package/dist/ui/index.d.ts.map +1 -0
- package/dist/ui/index.js +9 -0
- package/dist/ui/index.js.map +1 -0
- package/dist/ui/styles/base.css.d.ts +5 -0
- package/dist/ui/styles/base.css.d.ts.map +1 -0
- package/dist/ui/styles/base.css.js +49 -0
- package/dist/ui/styles/base.css.js.map +1 -0
- package/dist/ui/styles/floating-bar.css.d.ts +5 -0
- package/dist/ui/styles/floating-bar.css.d.ts.map +1 -0
- package/dist/ui/styles/floating-bar.css.js +417 -0
- package/dist/ui/styles/floating-bar.css.js.map +1 -0
- package/dist/ui/styles/header.css.d.ts +5 -0
- package/dist/ui/styles/header.css.d.ts.map +1 -0
- package/dist/ui/styles/header.css.js +49 -0
- package/dist/ui/styles/header.css.js.map +1 -0
- package/dist/ui/styles/index.d.ts +21 -0
- package/dist/ui/styles/index.d.ts.map +1 -0
- package/dist/ui/styles/index.js +48 -0
- package/dist/ui/styles/index.js.map +1 -0
- package/dist/ui/styles/panels.css.d.ts +5 -0
- package/dist/ui/styles/panels.css.d.ts.map +1 -0
- package/dist/ui/styles/panels.css.js +446 -0
- package/dist/ui/styles/panels.css.js.map +1 -0
- package/dist/ui/styles/responsive.css.d.ts +5 -0
- package/dist/ui/styles/responsive.css.d.ts.map +1 -0
- package/dist/ui/styles/responsive.css.js +201 -0
- package/dist/ui/styles/responsive.css.js.map +1 -0
- package/dist/ui/styles/variables.css.d.ts +6 -0
- package/dist/ui/styles/variables.css.d.ts.map +1 -0
- package/dist/ui/styles/variables.css.js +75 -0
- package/dist/ui/styles/variables.css.js.map +1 -0
- package/dist/ui/styles/viewport.css.d.ts +5 -0
- package/dist/ui/styles/viewport.css.d.ts.map +1 -0
- package/dist/ui/styles/viewport.css.js +87 -0
- package/dist/ui/styles/viewport.css.js.map +1 -0
- package/dist/ui/viewer/actions.d.ts +103 -0
- package/dist/ui/viewer/actions.d.ts.map +1 -0
- package/dist/ui/viewer/actions.js +2 -0
- package/dist/ui/viewer/actions.js.map +1 -0
- package/dist/ui/viewer/annotation/LinkRenderer.d.ts +9 -0
- package/dist/ui/viewer/annotation/LinkRenderer.d.ts.map +1 -0
- package/dist/ui/viewer/annotation/LinkRenderer.js +17 -0
- package/dist/ui/viewer/annotation/LinkRenderer.js.map +1 -0
- package/dist/ui/viewer/annotation/MarkupRenderer.d.ts +21 -0
- package/dist/ui/viewer/annotation/MarkupRenderer.d.ts.map +1 -0
- package/dist/ui/viewer/annotation/MarkupRenderer.js +138 -0
- package/dist/ui/viewer/annotation/MarkupRenderer.js.map +1 -0
- package/dist/ui/viewer/annotation/ShapeRenderer.d.ts +33 -0
- package/dist/ui/viewer/annotation/ShapeRenderer.d.ts.map +1 -0
- package/dist/ui/viewer/annotation/ShapeRenderer.js +378 -0
- package/dist/ui/viewer/annotation/ShapeRenderer.js.map +1 -0
- package/dist/ui/viewer/annotation/TextRenderer.d.ts +23 -0
- package/dist/ui/viewer/annotation/TextRenderer.d.ts.map +1 -0
- package/dist/ui/viewer/annotation/TextRenderer.js +196 -0
- package/dist/ui/viewer/annotation/TextRenderer.js.map +1 -0
- package/dist/ui/viewer/annotation/index.d.ts +8 -0
- package/dist/ui/viewer/annotation/index.d.ts.map +1 -0
- package/dist/ui/viewer/annotation/index.js +8 -0
- package/dist/ui/viewer/annotation/index.js.map +1 -0
- package/dist/ui/viewer/annotation/render.d.ts +24 -0
- package/dist/ui/viewer/annotation/render.d.ts.map +1 -0
- package/dist/ui/viewer/annotation/render.js +184 -0
- package/dist/ui/viewer/annotation/render.js.map +1 -0
- package/dist/ui/viewer/annotation/types.d.ts +239 -0
- package/dist/ui/viewer/annotation/types.d.ts.map +1 -0
- package/dist/ui/viewer/annotation/types.js +7 -0
- package/dist/ui/viewer/annotation/types.js.map +1 -0
- package/dist/ui/viewer/annotation/utils.d.ts +37 -0
- package/dist/ui/viewer/annotation/utils.d.ts.map +1 -0
- package/dist/ui/viewer/annotation/utils.js +82 -0
- package/dist/ui/viewer/annotation/utils.js.map +1 -0
- package/dist/ui/viewer/components/AnnotationPanel.d.ts +19 -0
- package/dist/ui/viewer/components/AnnotationPanel.d.ts.map +1 -0
- package/dist/ui/viewer/components/AnnotationPanel.js +284 -0
- package/dist/ui/viewer/components/AnnotationPanel.js.map +1 -0
- package/dist/ui/viewer/components/FloatingToolbar.d.ts +9 -0
- package/dist/ui/viewer/components/FloatingToolbar.d.ts.map +1 -0
- package/dist/ui/viewer/components/FloatingToolbar.js +305 -0
- package/dist/ui/viewer/components/FloatingToolbar.js.map +1 -0
- package/dist/ui/viewer/components/LeftPanel.d.ts +10 -0
- package/dist/ui/viewer/components/LeftPanel.d.ts.map +1 -0
- package/dist/ui/viewer/components/LeftPanel.js +165 -0
- package/dist/ui/viewer/components/LeftPanel.js.map +1 -0
- package/dist/ui/viewer/components/OutlinePanel.d.ts +10 -0
- package/dist/ui/viewer/components/OutlinePanel.d.ts.map +1 -0
- package/dist/ui/viewer/components/OutlinePanel.js +169 -0
- package/dist/ui/viewer/components/OutlinePanel.js.map +1 -0
- package/dist/ui/viewer/components/RightPanel.d.ts +9 -0
- package/dist/ui/viewer/components/RightPanel.d.ts.map +1 -0
- package/dist/ui/viewer/components/RightPanel.js +102 -0
- package/dist/ui/viewer/components/RightPanel.js.map +1 -0
- package/dist/ui/viewer/components/Spread.d.ts +41 -0
- package/dist/ui/viewer/components/Spread.d.ts.map +1 -0
- package/dist/ui/viewer/components/Spread.js +278 -0
- package/dist/ui/viewer/components/Spread.js.map +1 -0
- package/dist/ui/viewer/components/ThumbnailPanel.d.ts +11 -0
- package/dist/ui/viewer/components/ThumbnailPanel.d.ts.map +1 -0
- package/dist/ui/viewer/components/ThumbnailPanel.js +206 -0
- package/dist/ui/viewer/components/ThumbnailPanel.js.map +1 -0
- package/dist/ui/viewer/components/Toolbar.d.ts +9 -0
- package/dist/ui/viewer/components/Toolbar.d.ts.map +1 -0
- package/dist/ui/viewer/components/Toolbar.js +93 -0
- package/dist/ui/viewer/components/Toolbar.js.map +1 -0
- package/dist/ui/viewer/components/ViewModeMenu.d.ts +9 -0
- package/dist/ui/viewer/components/ViewModeMenu.d.ts.map +1 -0
- package/dist/ui/viewer/components/ViewModeMenu.js +169 -0
- package/dist/ui/viewer/components/ViewModeMenu.js.map +1 -0
- package/dist/ui/viewer/components/Viewport.d.ts +10 -0
- package/dist/ui/viewer/components/Viewport.d.ts.map +1 -0
- package/dist/ui/viewer/components/Viewport.js +793 -0
- package/dist/ui/viewer/components/Viewport.js.map +1 -0
- package/dist/ui/viewer/effects.d.ts +9 -0
- package/dist/ui/viewer/effects.d.ts.map +1 -0
- package/dist/ui/viewer/effects.js +179 -0
- package/dist/ui/viewer/effects.js.map +1 -0
- package/dist/ui/viewer/icons.d.ts +32 -0
- package/dist/ui/viewer/icons.d.ts.map +1 -0
- package/dist/ui/viewer/icons.js +44 -0
- package/dist/ui/viewer/icons.js.map +1 -0
- package/dist/ui/viewer/index.d.ts +6 -0
- package/dist/ui/viewer/index.d.ts.map +1 -0
- package/dist/ui/viewer/index.js +6 -0
- package/dist/ui/viewer/index.js.map +1 -0
- package/dist/ui/viewer/layout/index.d.ts +3 -0
- package/dist/ui/viewer/layout/index.d.ts.map +1 -0
- package/dist/ui/viewer/layout/index.js +3 -0
- package/dist/ui/viewer/layout/index.js.map +1 -0
- package/dist/ui/viewer/layout/pixelAlign.d.ts +7 -0
- package/dist/ui/viewer/layout/pixelAlign.d.ts.map +1 -0
- package/dist/ui/viewer/layout/pixelAlign.js +22 -0
- package/dist/ui/viewer/layout/pixelAlign.js.map +1 -0
- package/dist/ui/viewer/layout/spreadLayout.d.ts +93 -0
- package/dist/ui/viewer/layout/spreadLayout.d.ts.map +1 -0
- package/dist/ui/viewer/layout/spreadLayout.js +303 -0
- package/dist/ui/viewer/layout/spreadLayout.js.map +1 -0
- package/dist/ui/viewer/navigation.d.ts +80 -0
- package/dist/ui/viewer/navigation.d.ts.map +1 -0
- package/dist/ui/viewer/navigation.js +59 -0
- package/dist/ui/viewer/navigation.js.map +1 -0
- package/dist/ui/viewer/reducer.d.ts +4 -0
- package/dist/ui/viewer/reducer.d.ts.map +1 -0
- package/dist/ui/viewer/reducer.js +229 -0
- package/dist/ui/viewer/reducer.js.map +1 -0
- package/dist/ui/viewer/rendering/RenderManager.d.ts +76 -0
- package/dist/ui/viewer/rendering/RenderManager.d.ts.map +1 -0
- package/dist/ui/viewer/rendering/RenderManager.js +236 -0
- package/dist/ui/viewer/rendering/RenderManager.js.map +1 -0
- package/dist/ui/viewer/shell.d.ts +29 -0
- package/dist/ui/viewer/shell.d.ts.map +1 -0
- package/dist/ui/viewer/shell.js +70 -0
- package/dist/ui/viewer/shell.js.map +1 -0
- package/dist/ui/viewer/state.d.ts +72 -0
- package/dist/ui/viewer/state.d.ts.map +1 -0
- package/dist/ui/viewer/state.js +47 -0
- package/dist/ui/viewer/state.js.map +1 -0
- package/dist/view/LayoutCalculator.d.ts +42 -0
- package/dist/view/LayoutCalculator.d.ts.map +1 -0
- package/dist/view/LayoutCalculator.js +180 -0
- package/dist/view/LayoutCalculator.js.map +1 -0
- package/dist/view/TransitionCoordinator.d.ts +11 -0
- package/dist/view/TransitionCoordinator.d.ts.map +1 -0
- package/dist/view/TransitionCoordinator.js +22 -0
- package/dist/view/TransitionCoordinator.js.map +1 -0
- package/dist/view/ViewState.d.ts +46 -0
- package/dist/view/ViewState.d.ts.map +1 -0
- package/dist/view/ViewState.js +109 -0
- package/dist/view/ViewState.js.map +1 -0
- package/dist/view/index.d.ts +7 -0
- package/dist/view/index.d.ts.map +1 -0
- package/dist/view/index.js +4 -0
- package/dist/view/index.js.map +1 -0
- package/dist/wasm/udoc.d.ts +202 -0
- package/dist/wasm/udoc.js +929 -0
- package/dist/wasm/udoc_bg.wasm +0 -0
- package/dist/wasm/udoc_bg.wasm.d.ts +28 -0
- package/dist/worker/WorkerClient.d.ts +103 -0
- package/dist/worker/WorkerClient.d.ts.map +1 -0
- package/dist/worker/WorkerClient.js +182 -0
- package/dist/worker/WorkerClient.js.map +1 -0
- package/dist/worker/index.d.ts +4 -0
- package/dist/worker/index.d.ts.map +1 -0
- package/dist/worker/index.js +2 -0
- package/dist/worker/index.js.map +1 -0
- package/dist/worker/types.d.ts +81 -0
- package/dist/worker/types.d.ts.map +1 -0
- package/dist/worker/types.js +6 -0
- package/dist/worker/types.js.map +1 -0
- package/dist/worker/worker.d.ts +191 -0
- package/dist/worker/worker.d.ts.map +1 -0
- package/dist/worker/worker.js +127 -0
- package/dist/worker/worker.js.map +1 -0
- package/dist/worker.d.ts +2 -0
- package/dist/worker.d.ts.map +1 -0
- package/dist/worker.js +205 -0
- package/dist/worker.js.map +1 -0
- package/package.json +32 -0
|
@@ -0,0 +1,278 @@
|
|
|
1
|
+
import { getPointsToPixels } from "../state";
|
|
2
|
+
import { getDevicePixelRatio, toCssPixels, toDevicePixels } from "../layout";
|
|
3
|
+
import { renderAnnotationsToLayer } from "../annotation";
|
|
4
|
+
function normalizeRotation(rotation) {
|
|
5
|
+
switch (rotation) {
|
|
6
|
+
case 90:
|
|
7
|
+
case 180:
|
|
8
|
+
case 270:
|
|
9
|
+
return rotation;
|
|
10
|
+
default:
|
|
11
|
+
return 0;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
function rotateSize(size, rotation) {
|
|
15
|
+
const normalized = normalizeRotation(rotation);
|
|
16
|
+
if (normalized === 90 || normalized === 270) {
|
|
17
|
+
return { width: size.height, height: size.width };
|
|
18
|
+
}
|
|
19
|
+
return size;
|
|
20
|
+
}
|
|
21
|
+
function formatScaleKey(value) {
|
|
22
|
+
return value.toFixed(4);
|
|
23
|
+
}
|
|
24
|
+
function formatCssSize(value) {
|
|
25
|
+
return `${value.toFixed(3)}px`;
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Spread component - renders one or two pages side by side.
|
|
29
|
+
* Empty slots render as blank placeholders that preserve layout.
|
|
30
|
+
*/
|
|
31
|
+
export function createSpread(data) {
|
|
32
|
+
const el = document.createElement("div");
|
|
33
|
+
el.className = "udoc-spread";
|
|
34
|
+
el.dataset.spreadIndex = String(data.index);
|
|
35
|
+
const slotElements = [];
|
|
36
|
+
let mounted = false;
|
|
37
|
+
for (const slot of data.slots) {
|
|
38
|
+
const slotEl = createSlotElement(slot);
|
|
39
|
+
slotElements.push(slotEl);
|
|
40
|
+
el.appendChild(slotEl.container);
|
|
41
|
+
}
|
|
42
|
+
function createSlotElement(pageNumber) {
|
|
43
|
+
const container = document.createElement("div");
|
|
44
|
+
container.className = "udoc-spread__slot";
|
|
45
|
+
container.style.position = "relative";
|
|
46
|
+
container.style.overflow = "hidden";
|
|
47
|
+
if (pageNumber !== null) {
|
|
48
|
+
container.dataset.page = String(pageNumber);
|
|
49
|
+
const canvas = document.createElement("canvas");
|
|
50
|
+
canvas.className = "udoc-spread__canvas";
|
|
51
|
+
canvas.style.position = "absolute";
|
|
52
|
+
canvas.style.left = "0px";
|
|
53
|
+
canvas.style.top = "0px";
|
|
54
|
+
canvas.style.transformOrigin = "top left";
|
|
55
|
+
container.appendChild(canvas);
|
|
56
|
+
// Annotation layer (above canvas)
|
|
57
|
+
const annotationLayer = document.createElement("div");
|
|
58
|
+
annotationLayer.className = "udoc-spread__annotation-layer";
|
|
59
|
+
annotationLayer.style.position = "absolute";
|
|
60
|
+
annotationLayer.style.left = "0px";
|
|
61
|
+
annotationLayer.style.top = "0px";
|
|
62
|
+
annotationLayer.style.transformOrigin = "top left";
|
|
63
|
+
annotationLayer.style.pointerEvents = "none";
|
|
64
|
+
container.appendChild(annotationLayer);
|
|
65
|
+
return {
|
|
66
|
+
container,
|
|
67
|
+
canvas,
|
|
68
|
+
annotationLayer,
|
|
69
|
+
pageNumber,
|
|
70
|
+
renderKey: "",
|
|
71
|
+
pendingKey: null,
|
|
72
|
+
renderToken: 0,
|
|
73
|
+
cssWidth: 0,
|
|
74
|
+
cssHeight: 0,
|
|
75
|
+
lastAnnotations: null,
|
|
76
|
+
lastAnnotationScale: 0,
|
|
77
|
+
lastHighlightedBounds: null
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
container.classList.add("udoc-spread__slot--empty");
|
|
81
|
+
return {
|
|
82
|
+
container,
|
|
83
|
+
canvas: null,
|
|
84
|
+
annotationLayer: null,
|
|
85
|
+
pageNumber: null,
|
|
86
|
+
renderKey: "",
|
|
87
|
+
pendingKey: null,
|
|
88
|
+
renderToken: 0,
|
|
89
|
+
cssWidth: 0,
|
|
90
|
+
cssHeight: 0,
|
|
91
|
+
lastAnnotations: null,
|
|
92
|
+
lastAnnotationScale: 0,
|
|
93
|
+
lastHighlightedBounds: null
|
|
94
|
+
};
|
|
95
|
+
}
|
|
96
|
+
function updateLayout(options) {
|
|
97
|
+
const dpr = getDevicePixelRatio();
|
|
98
|
+
const pointsToPixels = getPointsToPixels(options.dpi);
|
|
99
|
+
const rotation = normalizeRotation(options.rotation);
|
|
100
|
+
const gapCss = toCssPixels(toDevicePixels(options.pageSpacing, dpr), dpr);
|
|
101
|
+
el.style.gap = `${gapCss}px`;
|
|
102
|
+
let referenceSize = null;
|
|
103
|
+
for (const slotEl of slotElements) {
|
|
104
|
+
if (slotEl.pageNumber === null)
|
|
105
|
+
continue;
|
|
106
|
+
const pageSize = options.pageInfos[slotEl.pageNumber - 1];
|
|
107
|
+
if (pageSize) {
|
|
108
|
+
referenceSize = {
|
|
109
|
+
width: pageSize.width * pointsToPixels * options.scale,
|
|
110
|
+
height: pageSize.height * pointsToPixels * options.scale
|
|
111
|
+
};
|
|
112
|
+
break;
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
for (const slotEl of slotElements) {
|
|
116
|
+
const pageSize = slotEl.pageNumber === null
|
|
117
|
+
? null
|
|
118
|
+
: options.pageInfos[slotEl.pageNumber - 1];
|
|
119
|
+
const baseSize = pageSize
|
|
120
|
+
? {
|
|
121
|
+
width: pageSize.width * pointsToPixels * options.scale,
|
|
122
|
+
height: pageSize.height * pointsToPixels * options.scale
|
|
123
|
+
}
|
|
124
|
+
: referenceSize;
|
|
125
|
+
if (!baseSize) {
|
|
126
|
+
slotEl.container.style.width = "0px";
|
|
127
|
+
slotEl.container.style.height = "0px";
|
|
128
|
+
continue;
|
|
129
|
+
}
|
|
130
|
+
const baseWidthDevice = toDevicePixels(baseSize.width, dpr);
|
|
131
|
+
const baseHeightDevice = toDevicePixels(baseSize.height, dpr);
|
|
132
|
+
const rotatedSize = rotateSize({ width: baseWidthDevice, height: baseHeightDevice }, rotation);
|
|
133
|
+
slotEl.container.style.width = formatCssSize(toCssPixels(rotatedSize.width, dpr));
|
|
134
|
+
slotEl.container.style.height = formatCssSize(toCssPixels(rotatedSize.height, dpr));
|
|
135
|
+
slotEl.cssWidth = toCssPixels(baseWidthDevice, dpr);
|
|
136
|
+
slotEl.cssHeight = toCssPixels(baseHeightDevice, dpr);
|
|
137
|
+
if (slotEl.canvas) {
|
|
138
|
+
slotEl.canvas.style.width = formatCssSize(slotEl.cssWidth);
|
|
139
|
+
slotEl.canvas.style.height = formatCssSize(slotEl.cssHeight);
|
|
140
|
+
const canvasLeft = rotation === 180 ? slotEl.cssWidth : rotation === 270 ? slotEl.cssHeight : 0;
|
|
141
|
+
const canvasTop = rotation === 90 ? slotEl.cssWidth : rotation === 180 ? slotEl.cssHeight : 0;
|
|
142
|
+
slotEl.canvas.style.left = formatCssSize(canvasLeft);
|
|
143
|
+
slotEl.canvas.style.top = formatCssSize(canvasTop);
|
|
144
|
+
slotEl.canvas.style.transform = rotation === 0 ? "none" : `rotate(${rotation}deg)`;
|
|
145
|
+
}
|
|
146
|
+
// Update annotation layer to match canvas position/transform
|
|
147
|
+
if (slotEl.annotationLayer) {
|
|
148
|
+
slotEl.annotationLayer.style.width = formatCssSize(slotEl.cssWidth);
|
|
149
|
+
slotEl.annotationLayer.style.height = formatCssSize(slotEl.cssHeight);
|
|
150
|
+
const layerLeft = rotation === 180 ? slotEl.cssWidth : rotation === 270 ? slotEl.cssHeight : 0;
|
|
151
|
+
const layerTop = rotation === 90 ? slotEl.cssWidth : rotation === 180 ? slotEl.cssHeight : 0;
|
|
152
|
+
slotEl.annotationLayer.style.left = formatCssSize(layerLeft);
|
|
153
|
+
slotEl.annotationLayer.style.top = formatCssSize(layerTop);
|
|
154
|
+
slotEl.annotationLayer.style.transform = rotation === 0 ? "none" : `rotate(${rotation}deg)`;
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
async function render(renderManager, options) {
|
|
159
|
+
const dpr = getDevicePixelRatio();
|
|
160
|
+
const pointsToPixels = getPointsToPixels(options.dpi);
|
|
161
|
+
const renderScale = pointsToPixels * options.scale * dpr;
|
|
162
|
+
const scaleKey = formatScaleKey(renderScale);
|
|
163
|
+
for (const slotEl of slotElements) {
|
|
164
|
+
if (slotEl.pageNumber === null || slotEl.canvas === null) {
|
|
165
|
+
slotEl.renderKey = "";
|
|
166
|
+
slotEl.pendingKey = null;
|
|
167
|
+
continue;
|
|
168
|
+
}
|
|
169
|
+
const key = `${options.docId}:${slotEl.pageNumber}:${scaleKey}`;
|
|
170
|
+
if (slotEl.renderKey === key || slotEl.pendingKey === key)
|
|
171
|
+
continue;
|
|
172
|
+
const token = ++slotEl.renderToken;
|
|
173
|
+
slotEl.pendingKey = key;
|
|
174
|
+
try {
|
|
175
|
+
const result = await renderManager.request({
|
|
176
|
+
docId: options.docId,
|
|
177
|
+
page: slotEl.pageNumber,
|
|
178
|
+
type: "page",
|
|
179
|
+
scale: renderScale
|
|
180
|
+
});
|
|
181
|
+
if (!mounted || slotEl.renderToken !== token) {
|
|
182
|
+
if (slotEl.pendingKey === key)
|
|
183
|
+
slotEl.pendingKey = null;
|
|
184
|
+
continue;
|
|
185
|
+
}
|
|
186
|
+
const canvas = slotEl.canvas;
|
|
187
|
+
if (slotEl.cssWidth > 0 && slotEl.cssHeight > 0) {
|
|
188
|
+
canvas.width = Math.max(1, Math.round(slotEl.cssWidth * dpr));
|
|
189
|
+
canvas.height = Math.max(1, Math.round(slotEl.cssHeight * dpr));
|
|
190
|
+
canvas.style.width = formatCssSize(slotEl.cssWidth);
|
|
191
|
+
canvas.style.height = formatCssSize(slotEl.cssHeight);
|
|
192
|
+
}
|
|
193
|
+
else {
|
|
194
|
+
canvas.width = result.width;
|
|
195
|
+
canvas.height = result.height;
|
|
196
|
+
}
|
|
197
|
+
const ctx = canvas.getContext("2d");
|
|
198
|
+
if (ctx) {
|
|
199
|
+
ctx.clearRect(0, 0, canvas.width, canvas.height);
|
|
200
|
+
if (canvas.width === result.width && canvas.height === result.height) {
|
|
201
|
+
ctx.drawImage(result.bitmap, 0, 0);
|
|
202
|
+
}
|
|
203
|
+
else {
|
|
204
|
+
ctx.drawImage(result.bitmap, 0, 0, canvas.width, canvas.height);
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
slotEl.renderKey = key;
|
|
208
|
+
}
|
|
209
|
+
catch (error) {
|
|
210
|
+
if (error.message !== "Request cancelled") {
|
|
211
|
+
console.error(`Spread render failed for page ${slotEl.pageNumber}:`, error);
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
finally {
|
|
215
|
+
if (slotEl.pendingKey === key)
|
|
216
|
+
slotEl.pendingKey = null;
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
}
|
|
220
|
+
function mount(container) {
|
|
221
|
+
container.appendChild(el);
|
|
222
|
+
mounted = true;
|
|
223
|
+
}
|
|
224
|
+
function destroy() {
|
|
225
|
+
mounted = false;
|
|
226
|
+
for (const slotEl of slotElements) {
|
|
227
|
+
slotEl.renderKey = "";
|
|
228
|
+
slotEl.pendingKey = null;
|
|
229
|
+
slotEl.renderToken = 0;
|
|
230
|
+
}
|
|
231
|
+
el.remove();
|
|
232
|
+
}
|
|
233
|
+
function getElement() {
|
|
234
|
+
return el;
|
|
235
|
+
}
|
|
236
|
+
function getData() {
|
|
237
|
+
return data;
|
|
238
|
+
}
|
|
239
|
+
function updateAnnotations(annotations, options, highlightedAnnotation) {
|
|
240
|
+
const pointsToPixels = getPointsToPixels(options.dpi);
|
|
241
|
+
const scale = pointsToPixels * options.scale;
|
|
242
|
+
for (const slotEl of slotElements) {
|
|
243
|
+
if (!slotEl.annotationLayer || slotEl.pageNumber === null)
|
|
244
|
+
continue;
|
|
245
|
+
// pageNumber is 1-based, annotations map is 0-based
|
|
246
|
+
const pageIndex = slotEl.pageNumber - 1;
|
|
247
|
+
const pageAnnotations = annotations.get(pageIndex);
|
|
248
|
+
// Check if this page has a highlighted annotation
|
|
249
|
+
const highlightBounds = highlightedAnnotation?.pageIndex === pageIndex
|
|
250
|
+
? highlightedAnnotation.bounds
|
|
251
|
+
: null;
|
|
252
|
+
// Skip if annotations, scale, and highlight haven't changed
|
|
253
|
+
// Use epsilon comparison for scale to prevent oscillation from floating-point drift
|
|
254
|
+
const scaleUnchanged = Math.abs(scale - slotEl.lastAnnotationScale) < 0.0001;
|
|
255
|
+
if (pageAnnotations === slotEl.lastAnnotations &&
|
|
256
|
+
scaleUnchanged &&
|
|
257
|
+
highlightBounds === slotEl.lastHighlightedBounds) {
|
|
258
|
+
continue;
|
|
259
|
+
}
|
|
260
|
+
// Render and cache
|
|
261
|
+
renderAnnotationsToLayer(slotEl.annotationLayer, pageAnnotations || [], scale, highlightBounds);
|
|
262
|
+
slotEl.lastAnnotations = pageAnnotations ?? null;
|
|
263
|
+
slotEl.lastAnnotationScale = scale;
|
|
264
|
+
slotEl.lastHighlightedBounds = highlightBounds;
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
return {
|
|
268
|
+
el,
|
|
269
|
+
mount,
|
|
270
|
+
destroy,
|
|
271
|
+
render,
|
|
272
|
+
updateLayout,
|
|
273
|
+
updateAnnotations,
|
|
274
|
+
getElement,
|
|
275
|
+
getData
|
|
276
|
+
};
|
|
277
|
+
}
|
|
278
|
+
//# sourceMappingURL=Spread.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Spread.js","sourceRoot":"","sources":["../../../../src/ui/viewer/components/Spread.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { Store } from "../../framework/store";
|
|
2
|
+
import type { ViewerState } from "../state";
|
|
3
|
+
import type { Action } from "../actions";
|
|
4
|
+
import type { RenderManager } from "../rendering/RenderManager";
|
|
5
|
+
export declare function createThumbnailPanel(): {
|
|
6
|
+
el: HTMLDivElement;
|
|
7
|
+
mount: (container: HTMLElement, store: Store<ViewerState, Action>, rm: RenderManager) => void;
|
|
8
|
+
destroy: () => void;
|
|
9
|
+
};
|
|
10
|
+
export type ThumbnailPanelComponent = ReturnType<typeof createThumbnailPanel>;
|
|
11
|
+
//# sourceMappingURL=ThumbnailPanel.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ThumbnailPanel.d.ts","sourceRoot":"","sources":["../../../../src/ui/viewer/components/ThumbnailPanel.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAEnD,OAAO,KAAK,EAAE,WAAW,EAAY,MAAM,UAAU,CAAC;AAEtD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAgChE,wBAAgB,oBAAoB;;uBAoMjB,WAAW,SACf,KAAK,CAAC,WAAW,EAAE,MAAM,CAAC,MAC7B,aAAa,KAClB,IAAI;mBAiBa,IAAI;EAqB3B;AAED,MAAM,MAAM,uBAAuB,GAAG,UAAU,CAAC,OAAO,oBAAoB,CAAC,CAAC"}
|
|
@@ -0,0 +1,206 @@
|
|
|
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 renderManager = 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 };
|
|
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
|
+
}
|
|
101
|
+
async function requestThumbnailRender(pageNumber) {
|
|
102
|
+
const item = thumbnailItems[pageNumber - 1];
|
|
103
|
+
if (!item || !renderManager || !currentSlice || !currentSlice.docId)
|
|
104
|
+
return;
|
|
105
|
+
const pageInfo = currentSlice.pageInfos[pageNumber - 1];
|
|
106
|
+
if (!pageInfo)
|
|
107
|
+
return;
|
|
108
|
+
const dpr = getDevicePixelRatio();
|
|
109
|
+
const pointsToPixels = getPointsToPixels(currentSlice.dpi);
|
|
110
|
+
const scale = THUMBNAIL_WIDTH / (pageInfo.width * pointsToPixels);
|
|
111
|
+
const renderScale = scale * pointsToPixels * dpr;
|
|
112
|
+
const key = `${currentSlice.docId}:${pageNumber}:${renderScale.toFixed(4)}`;
|
|
113
|
+
if (item.renderKey === key || item.pendingKey === key)
|
|
114
|
+
return;
|
|
115
|
+
const token = ++item.renderToken;
|
|
116
|
+
item.pendingKey = key;
|
|
117
|
+
try {
|
|
118
|
+
const result = await renderManager.request({
|
|
119
|
+
docId: currentSlice.docId,
|
|
120
|
+
page: pageNumber,
|
|
121
|
+
type: "thumbnail",
|
|
122
|
+
scale: renderScale
|
|
123
|
+
});
|
|
124
|
+
if (!mounted || item.renderToken !== token) {
|
|
125
|
+
if (item.pendingKey === key)
|
|
126
|
+
item.pendingKey = null;
|
|
127
|
+
return;
|
|
128
|
+
}
|
|
129
|
+
const canvas = item.canvas;
|
|
130
|
+
canvas.width = result.width;
|
|
131
|
+
canvas.height = result.height;
|
|
132
|
+
const ctx = canvas.getContext("2d");
|
|
133
|
+
if (ctx) {
|
|
134
|
+
ctx.drawImage(result.bitmap, 0, 0);
|
|
135
|
+
}
|
|
136
|
+
item.renderKey = key;
|
|
137
|
+
}
|
|
138
|
+
catch (error) {
|
|
139
|
+
if (error.message !== "Request cancelled") {
|
|
140
|
+
console.error(`Thumbnail render failed for page ${pageNumber}:`, error);
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
finally {
|
|
144
|
+
if (item.pendingKey === key)
|
|
145
|
+
item.pendingKey = null;
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
function updateCurrentPageHighlight(currentPage) {
|
|
149
|
+
for (const item of thumbnailItems) {
|
|
150
|
+
const isActive = item.pageNumber === currentPage;
|
|
151
|
+
item.container.classList.toggle("udoc-thumbnail-item--active", isActive);
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
function scrollActiveIntoView(currentPage) {
|
|
155
|
+
const item = thumbnailItems[currentPage - 1];
|
|
156
|
+
if (!item)
|
|
157
|
+
return;
|
|
158
|
+
// Use instant scroll to avoid triggering renders for all intermediate thumbnails
|
|
159
|
+
item.container.scrollIntoView({
|
|
160
|
+
behavior: "instant",
|
|
161
|
+
block: "nearest"
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
function applyState(slice) {
|
|
165
|
+
const docChanged = !currentSlice ||
|
|
166
|
+
slice.docId !== currentSlice.docId ||
|
|
167
|
+
slice.pageCount !== currentSlice.pageCount ||
|
|
168
|
+
slice.pageInfos !== currentSlice.pageInfos;
|
|
169
|
+
if (docChanged) {
|
|
170
|
+
buildThumbnailList(slice);
|
|
171
|
+
}
|
|
172
|
+
else if (slice.currentPage !== currentSlice?.currentPage) {
|
|
173
|
+
updateCurrentPageHighlight(slice.currentPage);
|
|
174
|
+
scrollActiveIntoView(slice.currentPage);
|
|
175
|
+
}
|
|
176
|
+
currentSlice = slice;
|
|
177
|
+
}
|
|
178
|
+
function mount(container, store, rm) {
|
|
179
|
+
container.appendChild(el);
|
|
180
|
+
mounted = true;
|
|
181
|
+
storeRef = store;
|
|
182
|
+
renderManager = rm;
|
|
183
|
+
// Apply initial state (currentSlice is null, so docChanged will be true)
|
|
184
|
+
applyState(selectThumbnailSlice(store.getState()));
|
|
185
|
+
unsubRender = subscribeSelector(store, selectThumbnailSlice, applyState, { equality: shallowEqual });
|
|
186
|
+
}
|
|
187
|
+
function destroy() {
|
|
188
|
+
mounted = false;
|
|
189
|
+
if (unsubRender)
|
|
190
|
+
unsubRender();
|
|
191
|
+
for (const off of unsubEvents)
|
|
192
|
+
off();
|
|
193
|
+
unsubEvents.length = 0;
|
|
194
|
+
if (intersectionObserver) {
|
|
195
|
+
intersectionObserver.disconnect();
|
|
196
|
+
intersectionObserver = null;
|
|
197
|
+
}
|
|
198
|
+
thumbnailItems = [];
|
|
199
|
+
storeRef = null;
|
|
200
|
+
renderManager = null;
|
|
201
|
+
currentSlice = null;
|
|
202
|
+
el.remove();
|
|
203
|
+
}
|
|
204
|
+
return { el, mount, destroy };
|
|
205
|
+
}
|
|
206
|
+
//# 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":"AAGA,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,aAAa,EAAE,eAAe,EAAE,oBAAoB,EAAE,MAAM,UAAU,CAAC;AAExG,SAAS,YAAY,CAAC,SAAiB,EAAE,KAAa,EAAE,OAAe;IACnE,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;IAC7C,GAAG,CAAC,SAAS,GAAG,qBAAqB,SAAS,EAAE,CAAC;IACjD,GAAG,CAAC,YAAY,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC;IACtC,GAAG,CAAC,SAAS,GAAG,OAAO,CAAC;IACxB,OAAO,GAAG,CAAC;AACf,CAAC;AAED,MAAM,UAAU,aAAa;IACzB,MAAM,EAAE,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IACzC,EAAE,CAAC,SAAS,GAAG,cAAc,CAAC;IAE9B,eAAe;IACf,MAAM,WAAW,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAClD,WAAW,CAAC,SAAS,GAAG,oBAAoB,CAAC;IAC7C,MAAM,OAAO,GAAG,YAAY,CAAC,yBAAyB,EAAE,MAAM,EAAE,SAAS,CAAC,CAAC;IAC3E,WAAW,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;IAEjC,SAAS;IACT,MAAM,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAC7C,MAAM,CAAC,SAAS,GAAG,sBAAsB,CAAC;IAE1C,gBAAgB;IAChB,MAAM,YAAY,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IACnD,YAAY,CAAC,SAAS,GAAG,qBAAqB,CAAC;IAC/C,MAAM,SAAS,GAAG,YAAY,CAAC,2BAA2B,EAAE,QAAQ,EAAE,WAAW,CAAC,CAAC;IACnF,MAAM,WAAW,GAAG,YAAY,CAAC,6BAA6B,EAAE,UAAU,EAAE,aAAa,CAAC,CAAC;IAC3F,MAAM,aAAa,GAAG,YAAY,CAAC,+BAA+B,EAAE,YAAY,EAAE,eAAe,CAAC,CAAC;IACnG,YAAY,CAAC,MAAM,CAAC,SAAS,EAAE,WAAW,EAAE,aAAa,CAAC,CAAC;IAE3D,EAAE,CAAC,MAAM,CAAC,WAAW,EAAE,MAAM,EAAE,YAAY,CAAC,CAAC;IAE7C,MAAM,WAAW,GAAsB,EAAE,CAAC;IAC1C,IAAI,WAAW,GAAwB,IAAI,CAAC;IAE5C,SAAS,KAAK,CAAC,SAAsB,EAAE,KAAiC;QACpE,SAAS,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;QAE1B,8CAA8C;QAC9C,MAAM,WAAW,GAAG,GAAG,EAAE;YACrB,KAAK,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE,WAAW,EAAE,CAAC,CAAC;QACjE,CAAC,CAAC;QACF,OAAO,CAAC,gBAAgB,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;QAC/C,WAAW,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,mBAAmB,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC,CAAC;QAE1E,4CAA4C;QAC5C,MAAM,aAAa,GAAG,GAAG,EAAE;YACvB,KAAK,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAC;QAC9D,CAAC,CAAC;QACF,SAAS,CAAC,gBAAgB,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;QACnD,WAAW,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC,mBAAmB,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC,CAAC;QAE9E,gDAAgD;QAChD,MAAM,eAAe,GAAG,GAAG,EAAE;YACzB,KAAK,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE,UAAU,EAAE,CAAC,CAAC;QAChE,CAAC,CAAC;QACF,WAAW,CAAC,gBAAgB,CAAC,OAAO,EAAE,eAAe,CAAC,CAAC;QACvD,WAAW,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,WAAW,CAAC,mBAAmB,CAAC,OAAO,EAAE,eAAe,CAAC,CAAC,CAAC;QAElF,yBAAyB;QACzB,MAAM,iBAAiB,GAAG,GAAG,EAAE;YAC3B,MAAM,IAAI,GAAG,EAAE,CAAC,OAAO,CAAC,mBAAmB,CAAuB,CAAC;YACnE,IAAI,CAAC,IAAI;gBAAE,OAAO;YAElB,IAAI,CAAC,QAAQ,CAAC,iBAAiB,EAAE,CAAC;gBAC9B,IAAI,CAAC,iBAAiB,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE;oBAChC,2DAA2D;gBAC/D,CAAC,CAAC,CAAC;YACP,CAAC;iBAAM,CAAC;gBACJ,QAAQ,CAAC,cAAc,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE;oBACjC,yBAAyB;gBAC7B,CAAC,CAAC,CAAC;YACP,CAAC;QACL,CAAC,CAAC;QACF,aAAa,CAAC,gBAAgB,CAAC,OAAO,EAAE,iBAAiB,CAAC,CAAC;QAC3D,WAAW,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,aAAa,CAAC,mBAAmB,CAAC,OAAO,EAAE,iBAAiB,CAAC,CAAC,CAAC;QAEtF,oDAAoD;QACpD,MAAM,kBAAkB,GAAG,GAAG,EAAE;YAC5B,MAAM,IAAI,GAAG,EAAE,CAAC,OAAO,CAAC,mBAAmB,CAAC,CAAC;YAC7C,MAAM,YAAY,GAAG,QAAQ,CAAC,iBAAiB,KAAK,IAAI,CAAC;YACzD,KAAK,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,gBAAgB,EAAE,YAAY,EAAE,CAAC,CAAC;QAC7D,CAAC,CAAC;QACF,QAAQ,CAAC,gBAAgB,CAAC,kBAAkB,EAAE,kBAAkB,CAAC,CAAC;QAClE,WAAW,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,mBAAmB,CAAC,kBAAkB,EAAE,kBAAkB,CAAC,CAAC,CAAC;QAE7F,sDAAsD;QACtD,WAAW,GAAG,KAAK,CAAC,eAAe,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE;YAC/C,IAAI,IAAI,CAAC,YAAY,KAAK,IAAI,CAAC,YAAY,EAAE,CAAC;gBAC1C,aAAa,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,eAAe,CAAC;gBACrF,aAAa,CAAC,YAAY,CAAC,YAAY,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC;YACnG,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED,SAAS,OAAO;QACZ,IAAI,WAAW;YAAE,WAAW,EAAE,CAAC;QAC/B,KAAK,MAAM,GAAG,IAAI,WAAW;YAAE,GAAG,EAAE,CAAC;QACrC,EAAE,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;IAED,OAAO,EAAE,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC;AAClC,CAAC"}
|
|
@@ -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
|