@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,165 @@
|
|
|
1
|
+
import { subscribeSelector, shallowEqual } from "../../framework/selectors";
|
|
2
|
+
import { isLeftPanelTab } from "../state";
|
|
3
|
+
import { ICON_THUMBNAIL, ICON_OUTLINE, ICON_BOOKMARK, ICON_LAYERS, ICON_ATTACHMENT } from "../icons";
|
|
4
|
+
import { createThumbnailPanel } from "./ThumbnailPanel";
|
|
5
|
+
import { createOutlinePanel } from "./OutlinePanel";
|
|
6
|
+
const TABS = [
|
|
7
|
+
{ id: "thumbnail", label: "Thumbnails", icon: ICON_THUMBNAIL },
|
|
8
|
+
{ id: "outline", label: "Outline", icon: ICON_OUTLINE },
|
|
9
|
+
{ id: "bookmarks", label: "Bookmarks", icon: ICON_BOOKMARK },
|
|
10
|
+
{ id: "layers", label: "Layers", icon: ICON_LAYERS },
|
|
11
|
+
{ id: "attachments", label: "Attachments", icon: ICON_ATTACHMENT },
|
|
12
|
+
];
|
|
13
|
+
export function createLeftPanel() {
|
|
14
|
+
const el = document.createElement("div");
|
|
15
|
+
el.className = "udoc-left-panel";
|
|
16
|
+
// Tab bar
|
|
17
|
+
const tabBar = document.createElement("div");
|
|
18
|
+
tabBar.className = "udoc-left-panel__tabs";
|
|
19
|
+
const tabButtons = new Map();
|
|
20
|
+
for (const tab of TABS) {
|
|
21
|
+
const btn = document.createElement("button");
|
|
22
|
+
btn.className = "udoc-left-panel__tab";
|
|
23
|
+
btn.setAttribute("aria-label", tab.label);
|
|
24
|
+
btn.setAttribute("data-tab", tab.id);
|
|
25
|
+
btn.innerHTML = tab.icon;
|
|
26
|
+
tabButtons.set(tab.id, btn);
|
|
27
|
+
tabBar.appendChild(btn);
|
|
28
|
+
}
|
|
29
|
+
// Content area
|
|
30
|
+
const content = document.createElement("div");
|
|
31
|
+
content.className = "udoc-left-panel__content";
|
|
32
|
+
// Resize handle
|
|
33
|
+
const resizeHandle = document.createElement("div");
|
|
34
|
+
resizeHandle.className = "udoc-left-panel__resize-handle";
|
|
35
|
+
el.append(tabBar, content, resizeHandle);
|
|
36
|
+
let unsubRender = null;
|
|
37
|
+
let unsubContent = null;
|
|
38
|
+
const unsubEvents = [];
|
|
39
|
+
// Panel content components
|
|
40
|
+
let thumbnailPanel = null;
|
|
41
|
+
let outlinePanel = null;
|
|
42
|
+
let storeRef = null;
|
|
43
|
+
let renderManagerRef = null;
|
|
44
|
+
function applyState(slice) {
|
|
45
|
+
el.classList.toggle("udoc-left-panel--closed", !slice.open);
|
|
46
|
+
// Apply width from state (only when open)
|
|
47
|
+
if (slice.open && slice.width !== null) {
|
|
48
|
+
el.style.width = `${slice.width}px`;
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
51
|
+
el.style.width = "";
|
|
52
|
+
}
|
|
53
|
+
for (const [tabId, btn] of tabButtons) {
|
|
54
|
+
btn.classList.toggle("udoc-left-panel__tab--active", tabId === slice.activeTab);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
function applyContent(activeTab) {
|
|
58
|
+
// Destroy previous content
|
|
59
|
+
if (thumbnailPanel) {
|
|
60
|
+
thumbnailPanel.destroy();
|
|
61
|
+
thumbnailPanel = null;
|
|
62
|
+
}
|
|
63
|
+
if (outlinePanel) {
|
|
64
|
+
outlinePanel.destroy();
|
|
65
|
+
outlinePanel = null;
|
|
66
|
+
}
|
|
67
|
+
// Mount new content based on active tab
|
|
68
|
+
if (activeTab === "thumbnail" && storeRef && renderManagerRef) {
|
|
69
|
+
thumbnailPanel = createThumbnailPanel();
|
|
70
|
+
thumbnailPanel.mount(content, storeRef, renderManagerRef);
|
|
71
|
+
}
|
|
72
|
+
else if (activeTab === "outline" && storeRef) {
|
|
73
|
+
outlinePanel = createOutlinePanel();
|
|
74
|
+
outlinePanel.mount(content, storeRef);
|
|
75
|
+
}
|
|
76
|
+
// Future: handle other tabs (bookmarks, layers, attachments)
|
|
77
|
+
}
|
|
78
|
+
function setupResize() {
|
|
79
|
+
let startX = 0;
|
|
80
|
+
let startWidth = 0;
|
|
81
|
+
const onPointerMove = (e) => {
|
|
82
|
+
const delta = e.clientX - startX;
|
|
83
|
+
const newWidth = Math.max(200, Math.min(500, startWidth + delta));
|
|
84
|
+
el.style.width = `${newWidth}px`;
|
|
85
|
+
};
|
|
86
|
+
const onPointerUp = () => {
|
|
87
|
+
document.removeEventListener("pointermove", onPointerMove);
|
|
88
|
+
document.removeEventListener("pointerup", onPointerUp);
|
|
89
|
+
el.classList.remove("udoc-left-panel--resizing");
|
|
90
|
+
document.body.style.cursor = "";
|
|
91
|
+
document.body.style.userSelect = "";
|
|
92
|
+
// Persist width to state
|
|
93
|
+
if (storeRef) {
|
|
94
|
+
const finalWidth = el.offsetWidth;
|
|
95
|
+
storeRef.dispatch({ type: "SET_LEFT_PANEL_WIDTH", width: finalWidth });
|
|
96
|
+
}
|
|
97
|
+
};
|
|
98
|
+
const onPointerDown = (e) => {
|
|
99
|
+
e.preventDefault();
|
|
100
|
+
startX = e.clientX;
|
|
101
|
+
startWidth = el.offsetWidth;
|
|
102
|
+
el.classList.add("udoc-left-panel--resizing");
|
|
103
|
+
document.body.style.cursor = "col-resize";
|
|
104
|
+
document.body.style.userSelect = "none";
|
|
105
|
+
document.addEventListener("pointermove", onPointerMove);
|
|
106
|
+
document.addEventListener("pointerup", onPointerUp);
|
|
107
|
+
};
|
|
108
|
+
resizeHandle.addEventListener("pointerdown", onPointerDown);
|
|
109
|
+
unsubEvents.push(() => resizeHandle.removeEventListener("pointerdown", onPointerDown));
|
|
110
|
+
}
|
|
111
|
+
function mount(container, store, renderManager) {
|
|
112
|
+
container.appendChild(el);
|
|
113
|
+
storeRef = store;
|
|
114
|
+
renderManagerRef = renderManager;
|
|
115
|
+
// Tab click handlers
|
|
116
|
+
for (const [tabId, btn] of tabButtons) {
|
|
117
|
+
const onClick = () => {
|
|
118
|
+
store.dispatch({ type: "TOGGLE_PANEL", panel: tabId });
|
|
119
|
+
};
|
|
120
|
+
btn.addEventListener("click", onClick);
|
|
121
|
+
unsubEvents.push(() => btn.removeEventListener("click", onClick));
|
|
122
|
+
}
|
|
123
|
+
// Setup resize handle
|
|
124
|
+
setupResize();
|
|
125
|
+
// Subscribe to state changes for panel open/close
|
|
126
|
+
const initialSlice = selectLeftPanel(store.getState());
|
|
127
|
+
applyState(initialSlice);
|
|
128
|
+
unsubRender = subscribeSelector(store, selectLeftPanel, applyState, {
|
|
129
|
+
equality: shallowEqual
|
|
130
|
+
});
|
|
131
|
+
// Subscribe to active tab changes for content
|
|
132
|
+
applyContent(initialSlice.activeTab);
|
|
133
|
+
unsubContent = subscribeSelector(store, (state) => selectLeftPanel(state).activeTab, applyContent);
|
|
134
|
+
}
|
|
135
|
+
function destroy() {
|
|
136
|
+
if (unsubRender)
|
|
137
|
+
unsubRender();
|
|
138
|
+
if (unsubContent)
|
|
139
|
+
unsubContent();
|
|
140
|
+
for (const off of unsubEvents)
|
|
141
|
+
off();
|
|
142
|
+
if (thumbnailPanel) {
|
|
143
|
+
thumbnailPanel.destroy();
|
|
144
|
+
thumbnailPanel = null;
|
|
145
|
+
}
|
|
146
|
+
if (outlinePanel) {
|
|
147
|
+
outlinePanel.destroy();
|
|
148
|
+
outlinePanel = null;
|
|
149
|
+
}
|
|
150
|
+
storeRef = null;
|
|
151
|
+
renderManagerRef = null;
|
|
152
|
+
el.remove();
|
|
153
|
+
}
|
|
154
|
+
return { el, mount, destroy };
|
|
155
|
+
}
|
|
156
|
+
function selectLeftPanel(state) {
|
|
157
|
+
const panel = state.activePanel;
|
|
158
|
+
const isLeftTab = panel !== null && isLeftPanelTab(panel);
|
|
159
|
+
return {
|
|
160
|
+
open: isLeftTab,
|
|
161
|
+
activeTab: isLeftTab ? panel : null,
|
|
162
|
+
width: state.leftPanelWidth
|
|
163
|
+
};
|
|
164
|
+
}
|
|
165
|
+
//# sourceMappingURL=LeftPanel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LeftPanel.js","sourceRoot":"","sources":["../../../../src/ui/viewer/components/LeftPanel.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
|
+
export declare function createOutlinePanel(): {
|
|
5
|
+
el: HTMLDivElement;
|
|
6
|
+
mount: (container: HTMLElement, store: Store<ViewerState, Action>) => void;
|
|
7
|
+
destroy: () => void;
|
|
8
|
+
};
|
|
9
|
+
export type OutlinePanelComponent = ReturnType<typeof createOutlinePanel>;
|
|
10
|
+
//# sourceMappingURL=OutlinePanel.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"OutlinePanel.d.ts","sourceRoot":"","sources":["../../../../src/ui/viewer/components/OutlinePanel.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAEnD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAC5C,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AAiBzC,wBAAgB,kBAAkB;;uBAuKf,WAAW,SACf,KAAK,CAAC,WAAW,EAAE,MAAM,CAAC,KAClC,IAAI;mBAea,IAAI;EAa3B;AAED,MAAM,MAAM,qBAAqB,GAAG,UAAU,CAAC,OAAO,kBAAkB,CAAC,CAAC"}
|
|
@@ -0,0 +1,169 @@
|
|
|
1
|
+
import { subscribeSelector, shallowEqual } from "../../framework/selectors";
|
|
2
|
+
function selectOutlineSlice(state) {
|
|
3
|
+
return {
|
|
4
|
+
outline: state.outline,
|
|
5
|
+
outlineLoading: state.outlineLoading,
|
|
6
|
+
currentPage: state.page
|
|
7
|
+
};
|
|
8
|
+
}
|
|
9
|
+
export function createOutlinePanel() {
|
|
10
|
+
const el = document.createElement("div");
|
|
11
|
+
el.className = "udoc-outline-panel";
|
|
12
|
+
let storeRef = null;
|
|
13
|
+
let currentSlice = null;
|
|
14
|
+
/** Track collapsed items by path (collapsed if in set) */
|
|
15
|
+
let collapsedItems = new Set();
|
|
16
|
+
let unsubRender = null;
|
|
17
|
+
const unsubEvents = [];
|
|
18
|
+
function createOutlineItemElement(item, path, depth) {
|
|
19
|
+
const container = document.createElement("div");
|
|
20
|
+
container.className = "udoc-outline-item";
|
|
21
|
+
container.dataset.path = path;
|
|
22
|
+
const header = document.createElement("div");
|
|
23
|
+
header.className = "udoc-outline-item__header";
|
|
24
|
+
header.style.paddingLeft = `${8 + depth * 16}px`;
|
|
25
|
+
// Expand/collapse toggle (only if has children)
|
|
26
|
+
if (item.children.length > 0) {
|
|
27
|
+
const toggle = document.createElement("button");
|
|
28
|
+
toggle.className = "udoc-outline-item__toggle";
|
|
29
|
+
toggle.type = "button";
|
|
30
|
+
toggle.innerHTML = `<svg viewBox="0 0 16 16" width="12" height="12"><path fill="currentColor" d="M6 4l4 4-4 4" stroke="currentColor" stroke-width="1.5" fill="none"/></svg>`;
|
|
31
|
+
// Determine initial expanded state
|
|
32
|
+
const isCollapsed = item.initiallyCollapsed || collapsedItems.has(path);
|
|
33
|
+
if (isCollapsed) {
|
|
34
|
+
collapsedItems.add(path);
|
|
35
|
+
}
|
|
36
|
+
toggle.classList.toggle("udoc-outline-item__toggle--expanded", !isCollapsed);
|
|
37
|
+
const onToggle = (e) => {
|
|
38
|
+
e.stopPropagation();
|
|
39
|
+
if (collapsedItems.has(path)) {
|
|
40
|
+
collapsedItems.delete(path);
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
collapsedItems.add(path);
|
|
44
|
+
}
|
|
45
|
+
updateExpandState(container, path);
|
|
46
|
+
};
|
|
47
|
+
toggle.addEventListener("click", onToggle);
|
|
48
|
+
unsubEvents.push(() => toggle.removeEventListener("click", onToggle));
|
|
49
|
+
header.appendChild(toggle);
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
// Spacer for alignment
|
|
53
|
+
const spacer = document.createElement("span");
|
|
54
|
+
spacer.className = "udoc-outline-item__spacer";
|
|
55
|
+
header.appendChild(spacer);
|
|
56
|
+
}
|
|
57
|
+
// Title
|
|
58
|
+
const title = document.createElement("span");
|
|
59
|
+
title.className = "udoc-outline-item__title";
|
|
60
|
+
title.textContent = item.title;
|
|
61
|
+
header.appendChild(title);
|
|
62
|
+
container.appendChild(header);
|
|
63
|
+
// Click handler for navigation
|
|
64
|
+
if (item.destination) {
|
|
65
|
+
header.classList.add("udoc-outline-item__header--clickable");
|
|
66
|
+
const dest = item.destination;
|
|
67
|
+
const onClick = () => {
|
|
68
|
+
if (storeRef) {
|
|
69
|
+
storeRef.dispatch({
|
|
70
|
+
type: "NAVIGATE_TO_DESTINATION",
|
|
71
|
+
destination: dest
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
header.addEventListener("click", onClick);
|
|
76
|
+
unsubEvents.push(() => header.removeEventListener("click", onClick));
|
|
77
|
+
}
|
|
78
|
+
// Children container
|
|
79
|
+
if (item.children.length > 0) {
|
|
80
|
+
const childrenContainer = document.createElement("div");
|
|
81
|
+
childrenContainer.className = "udoc-outline-item__children";
|
|
82
|
+
const isCollapsed = collapsedItems.has(path);
|
|
83
|
+
childrenContainer.style.display = isCollapsed ? "none" : "block";
|
|
84
|
+
// Recursively build children
|
|
85
|
+
item.children.forEach((child, index) => {
|
|
86
|
+
const childPath = `${path}/${index}`;
|
|
87
|
+
const childEl = createOutlineItemElement(child, childPath, depth + 1);
|
|
88
|
+
childrenContainer.appendChild(childEl);
|
|
89
|
+
});
|
|
90
|
+
container.appendChild(childrenContainer);
|
|
91
|
+
}
|
|
92
|
+
return container;
|
|
93
|
+
}
|
|
94
|
+
function updateExpandState(container, path) {
|
|
95
|
+
const toggle = container.querySelector(":scope > .udoc-outline-item__header > .udoc-outline-item__toggle");
|
|
96
|
+
const children = container.querySelector(":scope > .udoc-outline-item__children");
|
|
97
|
+
if (!toggle || !children)
|
|
98
|
+
return;
|
|
99
|
+
const isCollapsed = collapsedItems.has(path);
|
|
100
|
+
toggle.classList.toggle("udoc-outline-item__toggle--expanded", !isCollapsed);
|
|
101
|
+
children.style.display = isCollapsed ? "none" : "block";
|
|
102
|
+
}
|
|
103
|
+
function buildOutlineTree(outline) {
|
|
104
|
+
// Clear existing content but preserve event cleanup
|
|
105
|
+
el.innerHTML = "";
|
|
106
|
+
if (outline.length === 0) {
|
|
107
|
+
const empty = document.createElement("div");
|
|
108
|
+
empty.className = "udoc-outline-panel__empty";
|
|
109
|
+
empty.textContent = "No outline available";
|
|
110
|
+
el.appendChild(empty);
|
|
111
|
+
return;
|
|
112
|
+
}
|
|
113
|
+
// Build outline items
|
|
114
|
+
outline.forEach((item, index) => {
|
|
115
|
+
const path = String(index);
|
|
116
|
+
const itemEl = createOutlineItemElement(item, path, 0);
|
|
117
|
+
el.appendChild(itemEl);
|
|
118
|
+
});
|
|
119
|
+
}
|
|
120
|
+
function showLoading() {
|
|
121
|
+
el.innerHTML = "";
|
|
122
|
+
const loading = document.createElement("div");
|
|
123
|
+
loading.className = "udoc-outline-panel__loading";
|
|
124
|
+
loading.textContent = "Loading outline...";
|
|
125
|
+
el.appendChild(loading);
|
|
126
|
+
}
|
|
127
|
+
function applyState(slice) {
|
|
128
|
+
const outlineChanged = !currentSlice ||
|
|
129
|
+
slice.outline !== currentSlice.outline ||
|
|
130
|
+
slice.outlineLoading !== currentSlice.outlineLoading;
|
|
131
|
+
if (outlineChanged) {
|
|
132
|
+
// Clear old event listeners when rebuilding
|
|
133
|
+
for (const off of unsubEvents)
|
|
134
|
+
off();
|
|
135
|
+
unsubEvents.length = 0;
|
|
136
|
+
if (slice.outlineLoading) {
|
|
137
|
+
showLoading();
|
|
138
|
+
}
|
|
139
|
+
else if (slice.outline === null) {
|
|
140
|
+
// Not loaded yet and not loading - effect will trigger shortly
|
|
141
|
+
el.innerHTML = "";
|
|
142
|
+
}
|
|
143
|
+
else {
|
|
144
|
+
buildOutlineTree(slice.outline);
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
currentSlice = slice;
|
|
148
|
+
}
|
|
149
|
+
function mount(container, store) {
|
|
150
|
+
container.appendChild(el);
|
|
151
|
+
storeRef = store;
|
|
152
|
+
// Apply initial state
|
|
153
|
+
applyState(selectOutlineSlice(store.getState()));
|
|
154
|
+
unsubRender = subscribeSelector(store, selectOutlineSlice, applyState, { equality: shallowEqual });
|
|
155
|
+
}
|
|
156
|
+
function destroy() {
|
|
157
|
+
if (unsubRender)
|
|
158
|
+
unsubRender();
|
|
159
|
+
for (const off of unsubEvents)
|
|
160
|
+
off();
|
|
161
|
+
unsubEvents.length = 0;
|
|
162
|
+
collapsedItems.clear();
|
|
163
|
+
storeRef = null;
|
|
164
|
+
currentSlice = null;
|
|
165
|
+
el.remove();
|
|
166
|
+
}
|
|
167
|
+
return { el, mount, destroy };
|
|
168
|
+
}
|
|
169
|
+
//# sourceMappingURL=OutlinePanel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"OutlinePanel.js","sourceRoot":"","sources":["../../../../src/ui/viewer/components/OutlinePanel.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 createRightPanel(): {
|
|
5
|
+
el: HTMLDivElement;
|
|
6
|
+
mount: (container: HTMLElement, store: Store<ViewerState, Action>) => void;
|
|
7
|
+
destroy: () => void;
|
|
8
|
+
};
|
|
9
|
+
//# sourceMappingURL=RightPanel.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RightPanel.d.ts","sourceRoot":"","sources":["../../../../src/ui/viewer/components/RightPanel.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAEnD,OAAO,KAAK,EAAE,WAAW,EAAiB,MAAM,UAAU,CAAC;AAE3D,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AASzC,wBAAgB,gBAAgB;;uBA8EF,WAAW,SAAS,KAAK,CAAC,WAAW,EAAE,MAAM,CAAC,KAAG,IAAI;mBAiB3D,IAAI;EAS3B"}
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
import { subscribeSelector, shallowEqual } from "../../framework/selectors";
|
|
2
|
+
import { isLeftPanelTab } from "../state";
|
|
3
|
+
import { createAnnotationPanel } from "./AnnotationPanel";
|
|
4
|
+
export function createRightPanel() {
|
|
5
|
+
const el = document.createElement("div");
|
|
6
|
+
el.className = "udoc-right-panel";
|
|
7
|
+
// Resize handle (on left edge for right panel)
|
|
8
|
+
const resizeHandle = document.createElement("div");
|
|
9
|
+
resizeHandle.className = "udoc-right-panel__resize-handle";
|
|
10
|
+
// Content area (search or comments)
|
|
11
|
+
const content = document.createElement("div");
|
|
12
|
+
content.className = "udoc-right-panel__content";
|
|
13
|
+
el.append(resizeHandle, content);
|
|
14
|
+
// Child components
|
|
15
|
+
const annotationPanel = createAnnotationPanel();
|
|
16
|
+
let unsubRender = null;
|
|
17
|
+
const unsubEvents = [];
|
|
18
|
+
let storeRef = null;
|
|
19
|
+
function applyState(slice) {
|
|
20
|
+
el.classList.toggle("udoc-right-panel--closed", !slice.open);
|
|
21
|
+
// Apply width from state (only when open)
|
|
22
|
+
if (slice.open && slice.width !== null) {
|
|
23
|
+
el.style.width = `${slice.width}px`;
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
el.style.width = "";
|
|
27
|
+
}
|
|
28
|
+
if (slice.activeTab) {
|
|
29
|
+
content.setAttribute("data-tab", slice.activeTab);
|
|
30
|
+
}
|
|
31
|
+
else {
|
|
32
|
+
content.removeAttribute("data-tab");
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
function setupResize() {
|
|
36
|
+
let startX = 0;
|
|
37
|
+
let startWidth = 0;
|
|
38
|
+
const onPointerMove = (e) => {
|
|
39
|
+
// For right panel, dragging left increases width
|
|
40
|
+
const delta = startX - e.clientX;
|
|
41
|
+
const newWidth = Math.max(200, Math.min(500, startWidth + delta));
|
|
42
|
+
el.style.width = `${newWidth}px`;
|
|
43
|
+
};
|
|
44
|
+
const onPointerUp = () => {
|
|
45
|
+
document.removeEventListener("pointermove", onPointerMove);
|
|
46
|
+
document.removeEventListener("pointerup", onPointerUp);
|
|
47
|
+
el.classList.remove("udoc-right-panel--resizing");
|
|
48
|
+
document.body.style.cursor = "";
|
|
49
|
+
document.body.style.userSelect = "";
|
|
50
|
+
// Persist width to state
|
|
51
|
+
if (storeRef) {
|
|
52
|
+
const finalWidth = el.offsetWidth;
|
|
53
|
+
storeRef.dispatch({ type: "SET_RIGHT_PANEL_WIDTH", width: finalWidth });
|
|
54
|
+
}
|
|
55
|
+
};
|
|
56
|
+
const onPointerDown = (e) => {
|
|
57
|
+
e.preventDefault();
|
|
58
|
+
startX = e.clientX;
|
|
59
|
+
startWidth = el.offsetWidth;
|
|
60
|
+
el.classList.add("udoc-right-panel--resizing");
|
|
61
|
+
document.body.style.cursor = "col-resize";
|
|
62
|
+
document.body.style.userSelect = "none";
|
|
63
|
+
document.addEventListener("pointermove", onPointerMove);
|
|
64
|
+
document.addEventListener("pointerup", onPointerUp);
|
|
65
|
+
};
|
|
66
|
+
resizeHandle.addEventListener("pointerdown", onPointerDown);
|
|
67
|
+
unsubEvents.push(() => resizeHandle.removeEventListener("pointerdown", onPointerDown));
|
|
68
|
+
}
|
|
69
|
+
function mount(container, store) {
|
|
70
|
+
container.appendChild(el);
|
|
71
|
+
storeRef = store;
|
|
72
|
+
// Setup resize handle
|
|
73
|
+
setupResize();
|
|
74
|
+
// Mount annotation panel
|
|
75
|
+
annotationPanel.mount(content, store);
|
|
76
|
+
// Subscribe to state changes
|
|
77
|
+
applyState(selectRightPanel(store.getState()));
|
|
78
|
+
unsubRender = subscribeSelector(store, selectRightPanel, applyState, {
|
|
79
|
+
equality: shallowEqual
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
function destroy() {
|
|
83
|
+
if (unsubRender)
|
|
84
|
+
unsubRender();
|
|
85
|
+
for (const off of unsubEvents)
|
|
86
|
+
off();
|
|
87
|
+
annotationPanel.destroy();
|
|
88
|
+
storeRef = null;
|
|
89
|
+
el.remove();
|
|
90
|
+
}
|
|
91
|
+
return { el, mount, destroy };
|
|
92
|
+
}
|
|
93
|
+
function selectRightPanel(state) {
|
|
94
|
+
const panel = state.activePanel;
|
|
95
|
+
const isRightTab = panel !== null && !isLeftPanelTab(panel);
|
|
96
|
+
return {
|
|
97
|
+
open: isRightTab,
|
|
98
|
+
activeTab: isRightTab ? panel : null,
|
|
99
|
+
width: state.rightPanelWidth
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
//# sourceMappingURL=RightPanel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RightPanel.js","sourceRoot":"","sources":["../../../../src/ui/viewer/components/RightPanel.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import type { Spread as SpreadData } from "../layout/spreadLayout";
|
|
2
|
+
import type { RenderManager } from "../rendering/RenderManager";
|
|
3
|
+
import { type PageRotation, type PageInfo } from "../state";
|
|
4
|
+
import { type Annotation } from "../annotation";
|
|
5
|
+
export interface HighlightedAnnotation {
|
|
6
|
+
pageIndex: number;
|
|
7
|
+
bounds: {
|
|
8
|
+
x: number;
|
|
9
|
+
y: number;
|
|
10
|
+
width: number;
|
|
11
|
+
height: number;
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
export interface SpreadRenderOptions {
|
|
15
|
+
docId: string;
|
|
16
|
+
scale: number;
|
|
17
|
+
dpi: number;
|
|
18
|
+
}
|
|
19
|
+
export interface SpreadLayoutOptions {
|
|
20
|
+
pageInfos: readonly PageInfo[];
|
|
21
|
+
scale: number;
|
|
22
|
+
dpi: number;
|
|
23
|
+
rotation: PageRotation;
|
|
24
|
+
pageSpacing: number;
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Spread component - renders one or two pages side by side.
|
|
28
|
+
* Empty slots render as blank placeholders that preserve layout.
|
|
29
|
+
*/
|
|
30
|
+
export declare function createSpread(data: SpreadData): {
|
|
31
|
+
el: HTMLDivElement;
|
|
32
|
+
mount: (container: HTMLElement) => void;
|
|
33
|
+
destroy: () => void;
|
|
34
|
+
render: (renderManager: RenderManager, options: SpreadRenderOptions) => Promise<void>;
|
|
35
|
+
updateLayout: (options: SpreadLayoutOptions) => void;
|
|
36
|
+
updateAnnotations: (annotations: Map<number, Annotation[]>, options: SpreadLayoutOptions, highlightedAnnotation?: HighlightedAnnotation | null) => void;
|
|
37
|
+
getElement: () => HTMLDivElement;
|
|
38
|
+
getData: () => SpreadData;
|
|
39
|
+
};
|
|
40
|
+
export type SpreadComponent = ReturnType<typeof createSpread>;
|
|
41
|
+
//# sourceMappingURL=Spread.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Spread.d.ts","sourceRoot":"","sources":["../../../../src/ui/viewer/components/Spread.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,IAAI,UAAU,EAAY,MAAM,wBAAwB,CAAC;AAC7E,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAChE,OAAO,EAAqB,KAAK,YAAY,EAAE,KAAK,QAAQ,EAAE,MAAM,UAAU,CAAC;AAE/E,OAAO,EAA4B,KAAK,UAAU,EAAE,MAAM,eAAe,CAAC;AAE1E,MAAM,WAAW,qBAAqB;IAClC,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE;QAAE,CAAC,EAAE,MAAM,CAAC;QAAC,CAAC,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC;CACnE;AAED,MAAM,WAAW,mBAAmB;IAChC,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,GAAG,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,mBAAmB;IAChC,SAAS,EAAE,SAAS,QAAQ,EAAE,CAAC;IAC/B,KAAK,EAAE,MAAM,CAAC;IACd,GAAG,EAAE,MAAM,CAAC;IACZ,QAAQ,EAAE,YAAY,CAAC;IACvB,WAAW,EAAE,MAAM,CAAC;CACvB;AAoDD;;;GAGG;AACH,wBAAgB,YAAY,CAAC,IAAI,EAAE,UAAU;;uBAmNf,WAAW,KAAG,IAAI;mBAKxB,IAAI;4BAvEL,aAAa,WACnB,mBAAmB,KAC7B,OAAO,CAAC,IAAI,CAAC;4BA1Ee,mBAAmB,KAAG,IAAI;qCAkKxC,GAAG,CAAC,MAAM,EAAE,UAAU,EAAE,CAAC,WAC7B,mBAAmB,0BACJ,qBAAqB,GAAG,IAAI,KACrD,IAAI;sBAZgB,cAAc;mBAIjB,UAAU;EAqDjC;AAED,MAAM,MAAM,eAAe,GAAG,UAAU,CAAC,OAAO,YAAY,CAAC,CAAC"}
|