@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,284 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* AnnotationPanel - Displays annotations grouped by page in the right panel.
|
|
3
|
+
*
|
|
4
|
+
* Features:
|
|
5
|
+
* - Groups annotations by page
|
|
6
|
+
* - Collapsible page sections
|
|
7
|
+
* - Shows author, status, and content
|
|
8
|
+
* - Collapsible reply threads
|
|
9
|
+
* - Click to navigate to page
|
|
10
|
+
*/
|
|
11
|
+
import { subscribeSelector } from "../../framework/selectors";
|
|
12
|
+
import { ICON_CHEVRON_DOWN, ICON_CHEVRON_RIGHT, ICON_COMMENTS } from "../icons";
|
|
13
|
+
// Icons for annotation types
|
|
14
|
+
const ICON_STICKY_NOTE = `<svg viewBox="0 0 24 24" width="16" height="16" fill="currentColor"><path d="M20 2H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h4l4 4 4-4h4c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2z"/></svg>`;
|
|
15
|
+
const ICON_HIGHLIGHT = `<svg viewBox="0 0 24 24" width="16" height="16" fill="currentColor"><path d="M15.5 14h-.79l-.28-.27A6.471 6.471 0 0016 9.5 6.5 6.5 0 109.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z"/></svg>`;
|
|
16
|
+
const ICON_UNDERLINE = `<svg viewBox="0 0 24 24" width="16" height="16" fill="currentColor"><path d="M12 17c3.31 0 6-2.69 6-6V3h-2.5v8c0 1.93-1.57 3.5-3.5 3.5S8.5 12.93 8.5 11V3H6v8c0 3.31 2.69 6 6 6zm-7 2v2h14v-2H5z"/></svg>`;
|
|
17
|
+
const ICON_STRIKEOUT = `<svg viewBox="0 0 24 24" width="16" height="16" fill="currentColor"><path d="M10 19h4v-3h-4v3zM5 4v3h5v3h4V7h5V4H5zM3 14h18v-2H3v2z"/></svg>`;
|
|
18
|
+
const ICON_SQUIGGLY = `<svg viewBox="0 0 24 24" width="16" height="16" fill="currentColor"><path d="M3 18h18v-2H3v2zm0-5h18v-2H3v2zm0-7v2h18V6H3z"/></svg>`;
|
|
19
|
+
const ICON_FREETEXT = `<svg viewBox="0 0 24 24" width="16" height="16" fill="currentColor"><path d="M2.5 4v3h5v12h3V7h5V4h-13zm19 5h-9v3h3v7h3v-7h3V9z"/></svg>`;
|
|
20
|
+
const ICON_SHAPE = `<svg viewBox="0 0 24 24" width="16" height="16" fill="currentColor"><path d="M2 6v6h6V6H2zm16 0v6h6V6h-6zM7 17l5-5 5 5H7z"/></svg>`;
|
|
21
|
+
const ICON_INK = `<svg viewBox="0 0 24 24" width="16" height="16" fill="currentColor"><path d="M3 17.25V21h3.75L17.81 9.94l-3.75-3.75L3 17.25zM20.71 7.04a.996.996 0 000-1.41l-2.34-2.34a.996.996 0 00-1.41 0l-1.83 1.83 3.75 3.75 1.83-1.83z"/></svg>`;
|
|
22
|
+
const ICON_STAMP = `<svg viewBox="0 0 24 24" width="16" height="16" fill="currentColor"><path d="M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-5 14H7v-2h7v2zm3-4H7v-2h10v2zm0-4H7V7h10v2z"/></svg>`;
|
|
23
|
+
const ICON_CARET = `<svg viewBox="0 0 24 24" width="16" height="16" fill="currentColor"><path d="M7 14l5-5 5 5H7z"/></svg>`;
|
|
24
|
+
const ICON_REDACT = `<svg viewBox="0 0 24 24" width="16" height="16" fill="currentColor"><path d="M3 3h18v18H3V3zm2 2v14h14V5H5zm2 2h10v10H7V7z"/></svg>`;
|
|
25
|
+
/**
|
|
26
|
+
* Filter annotations to only those with metadata (comments).
|
|
27
|
+
*/
|
|
28
|
+
function filterAnnotationsWithMetadata(annotations) {
|
|
29
|
+
return annotations.filter(annotation => {
|
|
30
|
+
const meta = annotation.metadata;
|
|
31
|
+
return meta && (meta.author || meta.contents || meta.subject);
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Get icon SVG for annotation type.
|
|
36
|
+
*/
|
|
37
|
+
function getAnnotationTypeIcon(type) {
|
|
38
|
+
switch (type) {
|
|
39
|
+
case "text":
|
|
40
|
+
return ICON_STICKY_NOTE;
|
|
41
|
+
case "highlight":
|
|
42
|
+
return ICON_HIGHLIGHT;
|
|
43
|
+
case "underline":
|
|
44
|
+
return ICON_UNDERLINE;
|
|
45
|
+
case "strikeOut":
|
|
46
|
+
return ICON_STRIKEOUT;
|
|
47
|
+
case "squiggly":
|
|
48
|
+
return ICON_SQUIGGLY;
|
|
49
|
+
case "freeText":
|
|
50
|
+
return ICON_FREETEXT;
|
|
51
|
+
case "line":
|
|
52
|
+
case "square":
|
|
53
|
+
case "circle":
|
|
54
|
+
case "polygon":
|
|
55
|
+
case "polyLine":
|
|
56
|
+
return ICON_SHAPE;
|
|
57
|
+
case "ink":
|
|
58
|
+
return ICON_INK;
|
|
59
|
+
case "stamp":
|
|
60
|
+
return ICON_STAMP;
|
|
61
|
+
case "caret":
|
|
62
|
+
return ICON_CARET;
|
|
63
|
+
case "redact":
|
|
64
|
+
return ICON_REDACT;
|
|
65
|
+
default:
|
|
66
|
+
return ICON_COMMENTS;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
export function createAnnotationPanel() {
|
|
70
|
+
const el = document.createElement("div");
|
|
71
|
+
el.className = "udoc-annotation-panel";
|
|
72
|
+
let unsubRender = null;
|
|
73
|
+
let storeRef = null;
|
|
74
|
+
let cachedSlice = null;
|
|
75
|
+
function renderPlaceholder() {
|
|
76
|
+
el.innerHTML = `
|
|
77
|
+
<div class="udoc-annotation-panel__placeholder">
|
|
78
|
+
<div class="udoc-annotation-panel__placeholder-icon">${ICON_COMMENTS}</div>
|
|
79
|
+
<div class="udoc-annotation-panel__placeholder-title">Comments</div>
|
|
80
|
+
<div class="udoc-annotation-panel__placeholder-message">No comments in this document</div>
|
|
81
|
+
</div>
|
|
82
|
+
`;
|
|
83
|
+
}
|
|
84
|
+
function renderLoading() {
|
|
85
|
+
el.innerHTML = `
|
|
86
|
+
<div class="udoc-annotation-panel__loading">
|
|
87
|
+
Loading comments...
|
|
88
|
+
</div>
|
|
89
|
+
`;
|
|
90
|
+
}
|
|
91
|
+
function renderCommentItem(container, annotation, pageIndex, depth) {
|
|
92
|
+
const item = document.createElement("div");
|
|
93
|
+
item.className = depth > 0
|
|
94
|
+
? `udoc-comment-item udoc-comment-reply udoc-comment-depth-${Math.min(depth, 3)}`
|
|
95
|
+
: "udoc-comment-item";
|
|
96
|
+
// Icon
|
|
97
|
+
const icon = document.createElement("div");
|
|
98
|
+
icon.className = "udoc-comment-icon";
|
|
99
|
+
icon.innerHTML = getAnnotationTypeIcon(annotation.type);
|
|
100
|
+
item.appendChild(icon);
|
|
101
|
+
// Body
|
|
102
|
+
const body = document.createElement("div");
|
|
103
|
+
body.className = "udoc-comment-body";
|
|
104
|
+
// Header with author and status
|
|
105
|
+
const header = document.createElement("div");
|
|
106
|
+
header.className = "udoc-comment-header";
|
|
107
|
+
const meta = annotation.metadata;
|
|
108
|
+
const title = meta?.author || meta?.subject;
|
|
109
|
+
if (title) {
|
|
110
|
+
const titleEl = document.createElement("span");
|
|
111
|
+
titleEl.className = "udoc-comment-author";
|
|
112
|
+
titleEl.textContent = title;
|
|
113
|
+
header.appendChild(titleEl);
|
|
114
|
+
}
|
|
115
|
+
// Status badge
|
|
116
|
+
if (meta?.state) {
|
|
117
|
+
const badge = document.createElement("span");
|
|
118
|
+
badge.className = `udoc-comment-status udoc-comment-status--${meta.state.toLowerCase()}`;
|
|
119
|
+
badge.textContent = meta.state;
|
|
120
|
+
header.appendChild(badge);
|
|
121
|
+
}
|
|
122
|
+
body.appendChild(header);
|
|
123
|
+
// Contents
|
|
124
|
+
if (meta?.contents) {
|
|
125
|
+
const contents = document.createElement("div");
|
|
126
|
+
contents.className = "udoc-comment-contents";
|
|
127
|
+
contents.textContent = meta.contents;
|
|
128
|
+
body.appendChild(contents);
|
|
129
|
+
}
|
|
130
|
+
// Reply toggle button
|
|
131
|
+
if (annotation.replies && annotation.replies.length > 0) {
|
|
132
|
+
const toggleBtn = document.createElement("button");
|
|
133
|
+
toggleBtn.className = "udoc-comment-toggle";
|
|
134
|
+
toggleBtn.innerHTML = `${ICON_CHEVRON_RIGHT}<span>${annotation.replies.length} ${annotation.replies.length === 1 ? "reply" : "replies"}</span>`;
|
|
135
|
+
toggleBtn.title = "Show replies";
|
|
136
|
+
body.appendChild(toggleBtn);
|
|
137
|
+
}
|
|
138
|
+
item.appendChild(body);
|
|
139
|
+
// Click to navigate and highlight
|
|
140
|
+
item.addEventListener("click", (e) => {
|
|
141
|
+
e.stopPropagation();
|
|
142
|
+
if (storeRef) {
|
|
143
|
+
// Navigate to the page
|
|
144
|
+
storeRef.dispatch({ type: "NAVIGATE_TO_PAGE", page: pageIndex + 1 });
|
|
145
|
+
// Highlight the annotation on the page
|
|
146
|
+
storeRef.dispatch({
|
|
147
|
+
type: "HIGHLIGHT_ANNOTATION",
|
|
148
|
+
pageIndex,
|
|
149
|
+
bounds: annotation.bounds
|
|
150
|
+
});
|
|
151
|
+
}
|
|
152
|
+
});
|
|
153
|
+
container.appendChild(item);
|
|
154
|
+
// Render replies (collapsed by default)
|
|
155
|
+
if (annotation.replies && annotation.replies.length > 0) {
|
|
156
|
+
const toggleBtn = body.querySelector(".udoc-comment-toggle");
|
|
157
|
+
const repliesContainer = document.createElement("div");
|
|
158
|
+
repliesContainer.className = "udoc-comment-replies udoc-comment-replies--collapsed";
|
|
159
|
+
for (const reply of annotation.replies) {
|
|
160
|
+
renderCommentItem(repliesContainer, reply, pageIndex, depth + 1);
|
|
161
|
+
}
|
|
162
|
+
container.appendChild(repliesContainer);
|
|
163
|
+
toggleBtn.addEventListener("click", (e) => {
|
|
164
|
+
e.stopPropagation();
|
|
165
|
+
const isCollapsed = repliesContainer.classList.contains("udoc-comment-replies--collapsed");
|
|
166
|
+
if (isCollapsed) {
|
|
167
|
+
repliesContainer.classList.remove("udoc-comment-replies--collapsed");
|
|
168
|
+
toggleBtn.classList.add("udoc-comment-toggle--expanded");
|
|
169
|
+
toggleBtn.title = "Hide replies";
|
|
170
|
+
}
|
|
171
|
+
else {
|
|
172
|
+
repliesContainer.classList.add("udoc-comment-replies--collapsed");
|
|
173
|
+
toggleBtn.classList.remove("udoc-comment-toggle--expanded");
|
|
174
|
+
toggleBtn.title = "Show replies";
|
|
175
|
+
}
|
|
176
|
+
});
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
function render(slice) {
|
|
180
|
+
if (!slice.isOpen || !slice.isCommentsTab) {
|
|
181
|
+
el.style.display = "none";
|
|
182
|
+
return;
|
|
183
|
+
}
|
|
184
|
+
el.style.display = "";
|
|
185
|
+
// Check if still loading
|
|
186
|
+
if (!slice.allAnnotationsLoaded) {
|
|
187
|
+
renderLoading();
|
|
188
|
+
return;
|
|
189
|
+
}
|
|
190
|
+
// Collect annotations with metadata across all pages
|
|
191
|
+
const annotationsByPage = new Map();
|
|
192
|
+
for (const [pageIndex, annotations] of slice.annotationsByPage) {
|
|
193
|
+
const filtered = filterAnnotationsWithMetadata(annotations);
|
|
194
|
+
if (filtered.length > 0) {
|
|
195
|
+
annotationsByPage.set(pageIndex, filtered);
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
if (annotationsByPage.size === 0) {
|
|
199
|
+
renderPlaceholder();
|
|
200
|
+
return;
|
|
201
|
+
}
|
|
202
|
+
el.innerHTML = "";
|
|
203
|
+
const list = document.createElement("div");
|
|
204
|
+
list.className = "udoc-comments-list";
|
|
205
|
+
// Sort pages by index
|
|
206
|
+
const sortedPages = Array.from(annotationsByPage.keys()).sort((a, b) => a - b);
|
|
207
|
+
for (const pageIndex of sortedPages) {
|
|
208
|
+
const annotations = annotationsByPage.get(pageIndex);
|
|
209
|
+
// Page group
|
|
210
|
+
const pageGroup = document.createElement("div");
|
|
211
|
+
pageGroup.className = "udoc-comments-page-group";
|
|
212
|
+
// Page header
|
|
213
|
+
const pageHeader = document.createElement("div");
|
|
214
|
+
pageHeader.className = "udoc-comments-page-header";
|
|
215
|
+
pageHeader.innerHTML = `${ICON_CHEVRON_DOWN}<span>Page ${pageIndex + 1}</span><span class="udoc-comments-page-count">${annotations.length}</span>`;
|
|
216
|
+
pageGroup.appendChild(pageHeader);
|
|
217
|
+
// Page content
|
|
218
|
+
const pageContent = document.createElement("div");
|
|
219
|
+
pageContent.className = "udoc-comments-page-content";
|
|
220
|
+
for (const annotation of annotations) {
|
|
221
|
+
renderCommentItem(pageContent, annotation, pageIndex, 0);
|
|
222
|
+
}
|
|
223
|
+
pageGroup.appendChild(pageContent);
|
|
224
|
+
// Toggle click handler
|
|
225
|
+
pageHeader.addEventListener("click", () => {
|
|
226
|
+
const isCollapsed = pageGroup.classList.contains("udoc-comments-page-group--collapsed");
|
|
227
|
+
if (isCollapsed) {
|
|
228
|
+
pageGroup.classList.remove("udoc-comments-page-group--collapsed");
|
|
229
|
+
}
|
|
230
|
+
else {
|
|
231
|
+
pageGroup.classList.add("udoc-comments-page-group--collapsed");
|
|
232
|
+
}
|
|
233
|
+
});
|
|
234
|
+
list.appendChild(pageGroup);
|
|
235
|
+
}
|
|
236
|
+
el.appendChild(list);
|
|
237
|
+
}
|
|
238
|
+
function applyState(slice) {
|
|
239
|
+
// Skip if unchanged (deep comparison for Map is expensive, so rely on selector memoization)
|
|
240
|
+
cachedSlice = slice;
|
|
241
|
+
render(slice);
|
|
242
|
+
}
|
|
243
|
+
function mount(container, store) {
|
|
244
|
+
container.appendChild(el);
|
|
245
|
+
storeRef = store;
|
|
246
|
+
applyState(selectAnnotationPanel(store.getState()));
|
|
247
|
+
unsubRender = subscribeSelector(store, selectAnnotationPanel, applyState, {
|
|
248
|
+
equality: annotationPanelEqual
|
|
249
|
+
});
|
|
250
|
+
}
|
|
251
|
+
function destroy() {
|
|
252
|
+
if (unsubRender)
|
|
253
|
+
unsubRender();
|
|
254
|
+
storeRef = null;
|
|
255
|
+
el.remove();
|
|
256
|
+
}
|
|
257
|
+
return { el, mount, destroy };
|
|
258
|
+
}
|
|
259
|
+
function selectAnnotationPanel(state) {
|
|
260
|
+
const isCommentsTab = state.activePanel === "comments";
|
|
261
|
+
const isOpen = isCommentsTab;
|
|
262
|
+
// Check if we have annotations for all pages
|
|
263
|
+
const allAnnotationsLoaded = state.doc !== null &&
|
|
264
|
+
state.pageCount > 0 &&
|
|
265
|
+
state.pageAnnotations.size >= state.pageCount;
|
|
266
|
+
return {
|
|
267
|
+
isOpen,
|
|
268
|
+
isCommentsTab,
|
|
269
|
+
annotationsByPage: state.pageAnnotations,
|
|
270
|
+
allAnnotationsLoaded
|
|
271
|
+
};
|
|
272
|
+
}
|
|
273
|
+
function annotationPanelEqual(a, b) {
|
|
274
|
+
if (a.isOpen !== b.isOpen)
|
|
275
|
+
return false;
|
|
276
|
+
if (a.isCommentsTab !== b.isCommentsTab)
|
|
277
|
+
return false;
|
|
278
|
+
if (a.allAnnotationsLoaded !== b.allAnnotationsLoaded)
|
|
279
|
+
return false;
|
|
280
|
+
if (a.annotationsByPage !== b.annotationsByPage)
|
|
281
|
+
return false;
|
|
282
|
+
return true;
|
|
283
|
+
}
|
|
284
|
+
//# sourceMappingURL=AnnotationPanel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AnnotationPanel.js","sourceRoot":"","sources":["../../../../src/ui/viewer/components/AnnotationPanel.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 createFloatingToolbar(): {
|
|
5
|
+
el: HTMLDivElement;
|
|
6
|
+
mount: (container: HTMLElement, store: Store<ViewerState, Action>) => void;
|
|
7
|
+
destroy: () => void;
|
|
8
|
+
};
|
|
9
|
+
//# sourceMappingURL=FloatingToolbar.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FloatingToolbar.d.ts","sourceRoot":"","sources":["../../../../src/ui/viewer/components/FloatingToolbar.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAGnD,OAAO,KAAK,EAAE,WAAW,EAAY,MAAM,UAAU,CAAC;AACtD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AAyCzC,wBAAgB,qBAAqB;;uBAsGP,WAAW,SAAS,KAAK,CAAC,WAAW,EAAE,MAAM,CAAC,KAAG,IAAI;mBA2N3D,IAAI;EAQ3B"}
|
|
@@ -0,0 +1,305 @@
|
|
|
1
|
+
import { subscribeSelector } from "../../framework/selectors";
|
|
2
|
+
import { on } from "../../framework/events";
|
|
3
|
+
import { ICON_CHEVRON_LEFT, ICON_CHEVRON_RIGHT, ICON_CHEVRON_DOWN, ICON_ZOOM_IN, ICON_ZOOM_OUT } from "../icons";
|
|
4
|
+
import { createViewModeMenu } from "./ViewModeMenu";
|
|
5
|
+
function sliceEqual(a, b) {
|
|
6
|
+
return (a.page === b.page &&
|
|
7
|
+
a.pageCount === b.pageCount &&
|
|
8
|
+
a.zoom === b.zoom &&
|
|
9
|
+
a.zoomMode === b.zoomMode &&
|
|
10
|
+
a.effectiveZoom === b.effectiveZoom &&
|
|
11
|
+
a.zoomSteps === b.zoomSteps);
|
|
12
|
+
}
|
|
13
|
+
/** Format zoom as percentage string, preserving 1 decimal when present */
|
|
14
|
+
function formatZoomPercent(zoom) {
|
|
15
|
+
const percent = Math.round(zoom * 1000) / 10; // Round to 1 decimal
|
|
16
|
+
return percent % 1 === 0 ? `${percent}%` : `${percent.toFixed(1)}%`;
|
|
17
|
+
}
|
|
18
|
+
function getDisplayZoom(slice) {
|
|
19
|
+
if (slice.zoomMode === "custom")
|
|
20
|
+
return slice.zoom;
|
|
21
|
+
return slice.effectiveZoom ?? slice.zoom;
|
|
22
|
+
}
|
|
23
|
+
export function createFloatingToolbar() {
|
|
24
|
+
const el = document.createElement("div");
|
|
25
|
+
el.className = "udoc-floating-toolbar";
|
|
26
|
+
// Navigation section
|
|
27
|
+
const navSection = document.createElement("div");
|
|
28
|
+
navSection.className = "udoc-floating-toolbar__section";
|
|
29
|
+
const prevBtn = document.createElement("button");
|
|
30
|
+
prevBtn.className = "udoc-floating-toolbar__btn";
|
|
31
|
+
prevBtn.innerHTML = ICON_CHEVRON_LEFT;
|
|
32
|
+
prevBtn.title = "Previous page";
|
|
33
|
+
const pageInfo = document.createElement("div");
|
|
34
|
+
pageInfo.className = "udoc-floating-toolbar__page-info";
|
|
35
|
+
const pageInput = document.createElement("input");
|
|
36
|
+
pageInput.className = "udoc-floating-toolbar__page-input";
|
|
37
|
+
pageInput.type = "text";
|
|
38
|
+
pageInput.inputMode = "numeric";
|
|
39
|
+
const pageTotal = document.createElement("span");
|
|
40
|
+
pageTotal.className = "udoc-floating-toolbar__page-total";
|
|
41
|
+
pageInfo.appendChild(pageInput);
|
|
42
|
+
pageInfo.appendChild(pageTotal);
|
|
43
|
+
const nextBtn = document.createElement("button");
|
|
44
|
+
nextBtn.className = "udoc-floating-toolbar__btn";
|
|
45
|
+
nextBtn.innerHTML = ICON_CHEVRON_RIGHT;
|
|
46
|
+
nextBtn.title = "Next page";
|
|
47
|
+
navSection.appendChild(prevBtn);
|
|
48
|
+
navSection.appendChild(pageInfo);
|
|
49
|
+
navSection.appendChild(nextBtn);
|
|
50
|
+
// Divider
|
|
51
|
+
const divider = document.createElement("div");
|
|
52
|
+
divider.className = "udoc-floating-toolbar__divider";
|
|
53
|
+
// Zoom section
|
|
54
|
+
const zoomSection = document.createElement("div");
|
|
55
|
+
zoomSection.className = "udoc-floating-toolbar__section";
|
|
56
|
+
const zoomOutBtn = document.createElement("button");
|
|
57
|
+
zoomOutBtn.className = "udoc-floating-toolbar__btn";
|
|
58
|
+
zoomOutBtn.innerHTML = ICON_ZOOM_OUT;
|
|
59
|
+
zoomOutBtn.title = "Zoom out";
|
|
60
|
+
// Zoom dropdown container
|
|
61
|
+
const zoomDropdownContainer = document.createElement("div");
|
|
62
|
+
zoomDropdownContainer.className = "udoc-zoom-dropdown";
|
|
63
|
+
const zoomToggle = document.createElement("div");
|
|
64
|
+
zoomToggle.className = "udoc-zoom-dropdown__toggle";
|
|
65
|
+
const zoomInput = document.createElement("input");
|
|
66
|
+
zoomInput.className = "udoc-zoom-dropdown__input";
|
|
67
|
+
zoomInput.type = "text";
|
|
68
|
+
zoomInput.inputMode = "numeric";
|
|
69
|
+
zoomInput.title = "Zoom level";
|
|
70
|
+
const zoomChevron = document.createElement("button");
|
|
71
|
+
zoomChevron.className = "udoc-zoom-dropdown__chevron";
|
|
72
|
+
zoomChevron.innerHTML = ICON_CHEVRON_DOWN;
|
|
73
|
+
zoomChevron.title = "Zoom options";
|
|
74
|
+
zoomToggle.appendChild(zoomInput);
|
|
75
|
+
zoomToggle.appendChild(zoomChevron);
|
|
76
|
+
const zoomDropdown = document.createElement("div");
|
|
77
|
+
zoomDropdown.className = "udoc-zoom-dropdown__menu";
|
|
78
|
+
zoomDropdown.style.display = "none";
|
|
79
|
+
zoomDropdownContainer.appendChild(zoomToggle);
|
|
80
|
+
zoomDropdownContainer.appendChild(zoomDropdown);
|
|
81
|
+
const zoomInBtn = document.createElement("button");
|
|
82
|
+
zoomInBtn.className = "udoc-floating-toolbar__btn";
|
|
83
|
+
zoomInBtn.innerHTML = ICON_ZOOM_IN;
|
|
84
|
+
zoomInBtn.title = "Zoom in";
|
|
85
|
+
zoomSection.appendChild(zoomOutBtn);
|
|
86
|
+
zoomSection.appendChild(zoomDropdownContainer);
|
|
87
|
+
zoomSection.appendChild(zoomInBtn);
|
|
88
|
+
// Second divider
|
|
89
|
+
const divider2 = document.createElement("div");
|
|
90
|
+
divider2.className = "udoc-floating-toolbar__divider";
|
|
91
|
+
// View mode menu
|
|
92
|
+
const viewModeMenu = createViewModeMenu();
|
|
93
|
+
el.appendChild(navSection);
|
|
94
|
+
el.appendChild(divider);
|
|
95
|
+
el.appendChild(zoomSection);
|
|
96
|
+
el.appendChild(divider2);
|
|
97
|
+
el.appendChild(viewModeMenu.el);
|
|
98
|
+
let unsub = null;
|
|
99
|
+
const unsubEvents = [];
|
|
100
|
+
function mount(container, store) {
|
|
101
|
+
container.appendChild(el);
|
|
102
|
+
// Mount view mode menu
|
|
103
|
+
viewModeMenu.mount(store);
|
|
104
|
+
// Event handlers
|
|
105
|
+
unsubEvents.push(on(prevBtn, "click", () => {
|
|
106
|
+
const state = store.getState();
|
|
107
|
+
if (state.page > 1) {
|
|
108
|
+
store.dispatch({ type: "NAVIGATE_TO_PAGE", page: state.page - 1 });
|
|
109
|
+
}
|
|
110
|
+
}), on(nextBtn, "click", () => {
|
|
111
|
+
const state = store.getState();
|
|
112
|
+
if (state.page < state.pageCount) {
|
|
113
|
+
store.dispatch({ type: "NAVIGATE_TO_PAGE", page: state.page + 1 });
|
|
114
|
+
}
|
|
115
|
+
}), on(zoomOutBtn, "click", () => {
|
|
116
|
+
store.dispatch({ type: "ZOOM_OUT" });
|
|
117
|
+
}), on(zoomInBtn, "click", () => {
|
|
118
|
+
store.dispatch({ type: "ZOOM_IN" });
|
|
119
|
+
}), on(pageInput, "keydown", (e) => {
|
|
120
|
+
if (e.key === "Enter") {
|
|
121
|
+
const value = parseInt(pageInput.value, 10);
|
|
122
|
+
const state = store.getState();
|
|
123
|
+
if (!isNaN(value) && value >= 1 && value <= state.pageCount) {
|
|
124
|
+
store.dispatch({ type: "NAVIGATE_TO_PAGE", page: value });
|
|
125
|
+
}
|
|
126
|
+
else {
|
|
127
|
+
// Reset to current page
|
|
128
|
+
pageInput.value = String(state.page);
|
|
129
|
+
}
|
|
130
|
+
pageInput.blur();
|
|
131
|
+
}
|
|
132
|
+
}), on(pageInput, "blur", () => {
|
|
133
|
+
// Reset to current page on blur
|
|
134
|
+
const state = store.getState();
|
|
135
|
+
pageInput.value = String(state.page);
|
|
136
|
+
}));
|
|
137
|
+
// Zoom dropdown state
|
|
138
|
+
let isZoomDropdownOpen = false;
|
|
139
|
+
const openZoomDropdown = () => {
|
|
140
|
+
if (!isZoomDropdownOpen) {
|
|
141
|
+
isZoomDropdownOpen = true;
|
|
142
|
+
zoomDropdown.style.display = "block";
|
|
143
|
+
zoomChevron.classList.add("udoc-zoom-dropdown__chevron--active");
|
|
144
|
+
}
|
|
145
|
+
};
|
|
146
|
+
const closeZoomDropdown = () => {
|
|
147
|
+
if (isZoomDropdownOpen) {
|
|
148
|
+
isZoomDropdownOpen = false;
|
|
149
|
+
zoomDropdown.style.display = "none";
|
|
150
|
+
zoomChevron.classList.remove("udoc-zoom-dropdown__chevron--active");
|
|
151
|
+
}
|
|
152
|
+
};
|
|
153
|
+
const toggleZoomDropdown = () => {
|
|
154
|
+
if (isZoomDropdownOpen) {
|
|
155
|
+
closeZoomDropdown();
|
|
156
|
+
}
|
|
157
|
+
else {
|
|
158
|
+
openZoomDropdown();
|
|
159
|
+
}
|
|
160
|
+
};
|
|
161
|
+
// Zoom input handlers
|
|
162
|
+
unsubEvents.push(on(zoomInput, "keydown", (e) => {
|
|
163
|
+
if (e.key === "Enter") {
|
|
164
|
+
const value = parseFloat(zoomInput.value);
|
|
165
|
+
const state = store.getState();
|
|
166
|
+
if (!isNaN(value) && value >= 10 && value <= 500) {
|
|
167
|
+
store.dispatch({ type: "SET_ZOOM", zoom: value / 100 });
|
|
168
|
+
}
|
|
169
|
+
else {
|
|
170
|
+
// Reset to current zoom
|
|
171
|
+
const displayZoom = state.zoomMode === "custom"
|
|
172
|
+
? state.zoom
|
|
173
|
+
: (state.effectiveZoom ?? state.zoom);
|
|
174
|
+
zoomInput.value = formatZoomPercent(displayZoom);
|
|
175
|
+
}
|
|
176
|
+
zoomInput.blur();
|
|
177
|
+
}
|
|
178
|
+
}), on(zoomInput, "focus", () => {
|
|
179
|
+
// Select all text on focus for easy editing
|
|
180
|
+
zoomInput.select();
|
|
181
|
+
}), on(zoomInput, "blur", () => {
|
|
182
|
+
// Reset to current zoom on blur
|
|
183
|
+
const state = store.getState();
|
|
184
|
+
const displayZoom = state.zoomMode === "custom"
|
|
185
|
+
? state.zoom
|
|
186
|
+
: (state.effectiveZoom ?? state.zoom);
|
|
187
|
+
zoomInput.value = formatZoomPercent(displayZoom);
|
|
188
|
+
}));
|
|
189
|
+
// Zoom chevron toggle
|
|
190
|
+
unsubEvents.push(on(zoomChevron, "click", (e) => {
|
|
191
|
+
e.stopPropagation();
|
|
192
|
+
toggleZoomDropdown();
|
|
193
|
+
}));
|
|
194
|
+
// Close on outside click
|
|
195
|
+
const handleOutsideClick = (e) => {
|
|
196
|
+
if (!zoomDropdownContainer.contains(e.target)) {
|
|
197
|
+
closeZoomDropdown();
|
|
198
|
+
}
|
|
199
|
+
};
|
|
200
|
+
document.addEventListener("click", handleOutsideClick);
|
|
201
|
+
unsubEvents.push(() => document.removeEventListener("click", handleOutsideClick));
|
|
202
|
+
// Close on escape
|
|
203
|
+
const handleEscape = (e) => {
|
|
204
|
+
if (e.key === "Escape") {
|
|
205
|
+
closeZoomDropdown();
|
|
206
|
+
}
|
|
207
|
+
};
|
|
208
|
+
document.addEventListener("keydown", handleEscape);
|
|
209
|
+
unsubEvents.push(() => document.removeEventListener("keydown", handleEscape));
|
|
210
|
+
const ZOOM_MODE_OPTIONS = [
|
|
211
|
+
{ mode: "fit-spread-width", label: "Fit Width" },
|
|
212
|
+
{ mode: "fit-spread-height", label: "Fit Height" },
|
|
213
|
+
{ mode: "fit-spread", label: "Fit Page" }
|
|
214
|
+
];
|
|
215
|
+
const buildZoomDropdown = (slice) => {
|
|
216
|
+
zoomDropdown.innerHTML = "";
|
|
217
|
+
// Zoom mode options
|
|
218
|
+
const modeSection = document.createElement("div");
|
|
219
|
+
modeSection.className = "udoc-zoom-dropdown__section";
|
|
220
|
+
for (const opt of ZOOM_MODE_OPTIONS) {
|
|
221
|
+
const item = document.createElement("button");
|
|
222
|
+
item.className = "udoc-zoom-dropdown__item";
|
|
223
|
+
if (slice.zoomMode === opt.mode) {
|
|
224
|
+
item.classList.add("udoc-zoom-dropdown__item--active");
|
|
225
|
+
}
|
|
226
|
+
item.textContent = opt.label;
|
|
227
|
+
item.addEventListener("click", (e) => {
|
|
228
|
+
e.stopPropagation();
|
|
229
|
+
const state = store.getState();
|
|
230
|
+
store.dispatch({ type: "SET_ZOOM_MODE", mode: opt.mode });
|
|
231
|
+
// Re-center if already in this mode
|
|
232
|
+
if (state.zoomMode === opt.mode) {
|
|
233
|
+
store.dispatch({ type: "NAVIGATE_TO_PAGE", page: state.page });
|
|
234
|
+
}
|
|
235
|
+
closeZoomDropdown();
|
|
236
|
+
});
|
|
237
|
+
modeSection.appendChild(item);
|
|
238
|
+
}
|
|
239
|
+
zoomDropdown.appendChild(modeSection);
|
|
240
|
+
// Divider
|
|
241
|
+
const dividerEl = document.createElement("div");
|
|
242
|
+
dividerEl.className = "udoc-zoom-dropdown__divider";
|
|
243
|
+
zoomDropdown.appendChild(dividerEl);
|
|
244
|
+
// Zoom step options
|
|
245
|
+
const stepsSection = document.createElement("div");
|
|
246
|
+
stepsSection.className = "udoc-zoom-dropdown__section";
|
|
247
|
+
for (const step of slice.zoomSteps) {
|
|
248
|
+
const item = document.createElement("button");
|
|
249
|
+
item.className = "udoc-zoom-dropdown__item";
|
|
250
|
+
const stepPercent = Math.round(step * 100);
|
|
251
|
+
const currentPercent = Math.round(slice.zoom * 100);
|
|
252
|
+
if (slice.zoomMode === "custom" && stepPercent === currentPercent) {
|
|
253
|
+
item.classList.add("udoc-zoom-dropdown__item--active");
|
|
254
|
+
}
|
|
255
|
+
item.textContent = `${stepPercent}%`;
|
|
256
|
+
item.addEventListener("click", (e) => {
|
|
257
|
+
e.stopPropagation();
|
|
258
|
+
store.dispatch({ type: "SET_ZOOM", zoom: step });
|
|
259
|
+
closeZoomDropdown();
|
|
260
|
+
});
|
|
261
|
+
stepsSection.appendChild(item);
|
|
262
|
+
}
|
|
263
|
+
zoomDropdown.appendChild(stepsSection);
|
|
264
|
+
};
|
|
265
|
+
const applyState = (slice) => {
|
|
266
|
+
pageInput.value = String(slice.page);
|
|
267
|
+
pageTotal.textContent = `\u00A0/ ${slice.pageCount}`;
|
|
268
|
+
// Only update zoom input if it's not focused (user might be typing)
|
|
269
|
+
if (document.activeElement !== zoomInput) {
|
|
270
|
+
zoomInput.value = formatZoomPercent(getDisplayZoom(slice));
|
|
271
|
+
}
|
|
272
|
+
// Update button states
|
|
273
|
+
prevBtn.disabled = slice.page <= 1;
|
|
274
|
+
nextBtn.disabled = slice.page >= slice.pageCount;
|
|
275
|
+
// Rebuild zoom dropdown
|
|
276
|
+
buildZoomDropdown(slice);
|
|
277
|
+
};
|
|
278
|
+
// Initial state
|
|
279
|
+
applyState(selectSlice(store.getState()));
|
|
280
|
+
// Subscribe to changes
|
|
281
|
+
unsub = subscribeSelector(store, selectSlice, applyState, {
|
|
282
|
+
equality: sliceEqual
|
|
283
|
+
});
|
|
284
|
+
}
|
|
285
|
+
function destroy() {
|
|
286
|
+
if (unsub)
|
|
287
|
+
unsub();
|
|
288
|
+
for (const off of unsubEvents)
|
|
289
|
+
off();
|
|
290
|
+
viewModeMenu.destroy();
|
|
291
|
+
el.remove();
|
|
292
|
+
}
|
|
293
|
+
return { el, mount, destroy };
|
|
294
|
+
}
|
|
295
|
+
function selectSlice(state) {
|
|
296
|
+
return {
|
|
297
|
+
page: state.page,
|
|
298
|
+
pageCount: state.pageCount,
|
|
299
|
+
zoom: state.zoom,
|
|
300
|
+
zoomMode: state.zoomMode,
|
|
301
|
+
effectiveZoom: state.effectiveZoom,
|
|
302
|
+
zoomSteps: state.zoomSteps
|
|
303
|
+
};
|
|
304
|
+
}
|
|
305
|
+
//# sourceMappingURL=FloatingToolbar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FloatingToolbar.js","sourceRoot":"","sources":["../../../../src/ui/viewer/components/FloatingToolbar.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 { RenderManager } from "../rendering/RenderManager";
|
|
5
|
+
export declare function createLeftPanel(): {
|
|
6
|
+
el: HTMLDivElement;
|
|
7
|
+
mount: (container: HTMLElement, store: Store<ViewerState, Action>, renderManager: RenderManager) => void;
|
|
8
|
+
destroy: () => void;
|
|
9
|
+
};
|
|
10
|
+
//# sourceMappingURL=LeftPanel.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LeftPanel.d.ts","sourceRoot":"","sources":["../../../../src/ui/viewer/components/LeftPanel.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAEnD,OAAO,KAAK,EAAE,WAAW,EAAgB,MAAM,UAAU,CAAC;AAE1D,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AA+BhE,wBAAgB,eAAe;;uBAoHZ,WAAW,SACf,KAAK,CAAC,WAAW,EAAE,MAAM,CAAC,iBAClB,aAAa,KAC7B,IAAI;mBAiCa,IAAI;EAoB3B"}
|