@dxos/plugin-deck 0.8.4-main.70d3990 → 0.8.4-main.74a063c4e0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/lib/browser/add-toast-HW74YZHJ.mjs +24 -0
- package/dist/lib/browser/add-toast-HW74YZHJ.mjs.map +7 -0
- package/dist/lib/browser/adjust-OXVHZTBE.mjs +96 -0
- package/dist/lib/browser/adjust-OXVHZTBE.mjs.map +7 -0
- package/dist/lib/browser/change-companion-Z3Q2UPX4.mjs +34 -0
- package/dist/lib/browser/change-companion-Z3Q2UPX4.mjs.map +7 -0
- package/dist/lib/browser/chunk-2YNVGCOQ.mjs +88 -0
- package/dist/lib/browser/chunk-2YNVGCOQ.mjs.map +7 -0
- package/dist/lib/browser/chunk-BRZAVPMC.mjs +48 -0
- package/dist/lib/browser/chunk-BRZAVPMC.mjs.map +7 -0
- package/dist/lib/browser/chunk-DF2VZ6W3.mjs +69 -0
- package/dist/lib/browser/chunk-DF2VZ6W3.mjs.map +7 -0
- package/dist/lib/browser/chunk-GFOCQS7S.mjs +216 -0
- package/dist/lib/browser/chunk-GFOCQS7S.mjs.map +7 -0
- package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
- package/dist/lib/browser/chunk-KUTDCWZF.mjs +30 -0
- package/dist/lib/browser/chunk-KUTDCWZF.mjs.map +7 -0
- package/dist/lib/browser/close-N5FCDT7Y.mjs +44 -0
- package/dist/lib/browser/close-N5FCDT7Y.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +160 -133
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/open-J5HV42UN.mjs +150 -0
- package/dist/lib/browser/open-J5HV42UN.mjs.map +7 -0
- package/dist/lib/browser/operations/index.mjs +13 -0
- package/dist/lib/browser/operations/index.mjs.map +7 -0
- package/dist/lib/browser/revert-workspace-VWNN7RYF.mjs +21 -0
- package/dist/lib/browser/revert-workspace-VWNN7RYF.mjs.map +7 -0
- package/dist/lib/browser/scroll-into-view-CA7E3PSO.mjs +21 -0
- package/dist/lib/browser/scroll-into-view-CA7E3PSO.mjs.map +7 -0
- package/dist/lib/browser/set-YVWQQZLE.mjs +37 -0
- package/dist/lib/browser/set-YVWQQZLE.mjs.map +7 -0
- package/dist/lib/browser/set-layout-mode-DRNBZHE7.mjs +90 -0
- package/dist/lib/browser/set-layout-mode-DRNBZHE7.mjs.map +7 -0
- package/dist/lib/browser/show-undo-KA2XHQ6E.mjs +59 -0
- package/dist/lib/browser/show-undo-KA2XHQ6E.mjs.map +7 -0
- package/dist/lib/browser/switch-workspace-U7SPENHU.mjs +68 -0
- package/dist/lib/browser/switch-workspace-U7SPENHU.mjs.map +7 -0
- package/dist/lib/browser/types/index.mjs +12 -12
- package/dist/lib/browser/update-complementary-W6UVLWLI.mjs +28 -0
- package/dist/lib/browser/update-complementary-W6UVLWLI.mjs.map +7 -0
- package/dist/lib/browser/update-dialog-VCTI7WKS.mjs +29 -0
- package/dist/lib/browser/update-dialog-VCTI7WKS.mjs.map +7 -0
- package/dist/lib/browser/update-plank-size-6TPVOYLT.mjs +28 -0
- package/dist/lib/browser/update-plank-size-6TPVOYLT.mjs.map +7 -0
- package/dist/lib/browser/update-popover-4EVVZSB6.mjs +33 -0
- package/dist/lib/browser/update-popover-4EVVZSB6.mjs.map +7 -0
- package/dist/lib/browser/update-sidebar-PAZARC4Q.mjs +25 -0
- package/dist/lib/browser/update-sidebar-PAZARC4Q.mjs.map +7 -0
- package/dist/lib/node-esm/add-toast-FA7NTWKA.mjs +25 -0
- package/dist/lib/node-esm/add-toast-FA7NTWKA.mjs.map +7 -0
- package/dist/lib/node-esm/adjust-G6FGZW6H.mjs +97 -0
- package/dist/lib/node-esm/adjust-G6FGZW6H.mjs.map +7 -0
- package/dist/lib/node-esm/change-companion-V6343HMY.mjs +35 -0
- package/dist/lib/node-esm/change-companion-V6343HMY.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-6BWQJDNT.mjs +217 -0
- package/dist/lib/node-esm/chunk-6BWQJDNT.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-GI5JXNBT.mjs +89 -0
- package/dist/lib/node-esm/chunk-GI5JXNBT.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +11 -0
- package/dist/lib/node-esm/chunk-HSLMI22Q.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-IRWCUYJY.mjs +71 -0
- package/dist/lib/node-esm/chunk-IRWCUYJY.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-MB4SDDVY.mjs +50 -0
- package/dist/lib/node-esm/chunk-MB4SDDVY.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-MLVJ2ODW.mjs +32 -0
- package/dist/lib/node-esm/chunk-MLVJ2ODW.mjs.map +7 -0
- package/dist/lib/node-esm/close-AMA63RJN.mjs +45 -0
- package/dist/lib/node-esm/close-AMA63RJN.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +202 -0
- package/dist/lib/node-esm/index.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -0
- package/dist/lib/node-esm/open-KRCARMEB.mjs +151 -0
- package/dist/lib/node-esm/open-KRCARMEB.mjs.map +7 -0
- package/dist/lib/node-esm/operations/index.mjs +14 -0
- package/dist/lib/node-esm/operations/index.mjs.map +7 -0
- package/dist/lib/node-esm/revert-workspace-A2K3JQFS.mjs +22 -0
- package/dist/lib/node-esm/revert-workspace-A2K3JQFS.mjs.map +7 -0
- package/dist/lib/node-esm/scroll-into-view-B2U4RQK7.mjs +22 -0
- package/dist/lib/node-esm/scroll-into-view-B2U4RQK7.mjs.map +7 -0
- package/dist/lib/node-esm/set-HCWNW76S.mjs +38 -0
- package/dist/lib/node-esm/set-HCWNW76S.mjs.map +7 -0
- package/dist/lib/node-esm/set-layout-mode-E27AI5KE.mjs +91 -0
- package/dist/lib/node-esm/set-layout-mode-E27AI5KE.mjs.map +7 -0
- package/dist/lib/node-esm/show-undo-YTZXH422.mjs +60 -0
- package/dist/lib/node-esm/show-undo-YTZXH422.mjs.map +7 -0
- package/dist/lib/node-esm/switch-workspace-AQCNGS4Y.mjs +69 -0
- package/dist/lib/node-esm/switch-workspace-AQCNGS4Y.mjs.map +7 -0
- package/dist/lib/node-esm/types/index.mjs +33 -0
- package/dist/lib/node-esm/types/index.mjs.map +7 -0
- package/dist/lib/node-esm/update-complementary-7HIRM7OT.mjs +29 -0
- package/dist/lib/node-esm/update-complementary-7HIRM7OT.mjs.map +7 -0
- package/dist/lib/node-esm/update-dialog-F3JF7MBZ.mjs +30 -0
- package/dist/lib/node-esm/update-dialog-F3JF7MBZ.mjs.map +7 -0
- package/dist/lib/node-esm/update-plank-size-IIZKU7YR.mjs +29 -0
- package/dist/lib/node-esm/update-plank-size-IIZKU7YR.mjs.map +7 -0
- package/dist/lib/node-esm/update-popover-RO5QEH4C.mjs +34 -0
- package/dist/lib/node-esm/update-popover-RO5QEH4C.mjs.map +7 -0
- package/dist/lib/node-esm/update-sidebar-2RX6VLEK.mjs +26 -0
- package/dist/lib/node-esm/update-sidebar-2RX6VLEK.mjs.map +7 -0
- package/dist/types/src/DeckPlugin.d.ts +2 -1
- package/dist/types/src/DeckPlugin.d.ts.map +1 -1
- package/dist/types/src/capabilities/app-graph-builder.d.ts +4 -2
- package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
- package/dist/types/src/capabilities/check-app-scheme.d.ts +17 -2
- package/dist/types/src/capabilities/check-app-scheme.d.ts.map +1 -1
- package/dist/types/src/capabilities/index.d.ts +208 -12
- package/dist/types/src/capabilities/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
- package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
- package/dist/types/src/capabilities/react-root.d.ts +4 -2
- package/dist/types/src/capabilities/react-root.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-surface.d.ts +3 -2
- package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
- package/dist/types/src/capabilities/settings.d.ts +16 -2
- package/dist/types/src/capabilities/settings.d.ts.map +1 -1
- package/dist/types/src/capabilities/state.d.ts +134 -47
- package/dist/types/src/capabilities/state.d.ts.map +1 -1
- package/dist/types/src/capabilities/tools.d.ts +4 -3
- package/dist/types/src/capabilities/tools.d.ts.map +1 -1
- package/dist/types/src/capabilities/url-handler.d.ts +3 -2
- package/dist/types/src/capabilities/url-handler.d.ts.map +1 -1
- package/dist/types/src/components/DeckSettings/DeckSettings.d.ts +4 -4
- package/dist/types/src/components/DeckSettings/DeckSettings.d.ts.map +1 -1
- package/dist/types/src/components/DeckSettings/DeckSettings.stories.d.ts +71 -0
- package/dist/types/src/components/DeckSettings/DeckSettings.stories.d.ts.map +1 -0
- package/dist/types/src/components/DeckSettings/index.d.ts +1 -1
- package/dist/types/src/components/DeckSettings/index.d.ts.map +1 -1
- package/dist/types/src/components/Matrix/Matrix.d.ts +49 -0
- package/dist/types/src/components/Matrix/Matrix.d.ts.map +1 -0
- package/dist/types/src/components/Matrix/Matrix.stories.d.ts +17 -0
- package/dist/types/src/components/Matrix/Matrix.stories.d.ts.map +1 -0
- package/dist/types/src/components/Matrix/index.d.ts +3 -0
- package/dist/types/src/components/Matrix/index.d.ts.map +1 -0
- package/dist/types/src/components/index.d.ts +3 -2
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/containers/Deck/Banner.d.ts.map +1 -0
- package/dist/types/src/containers/Deck/Deck.d.ts +25 -0
- package/dist/types/src/containers/Deck/Deck.d.ts.map +1 -0
- package/dist/types/src/containers/Deck/Deck.stories.d.ts +71 -0
- package/dist/types/src/containers/Deck/Deck.stories.d.ts.map +1 -0
- package/dist/types/src/containers/Deck/DeckContent.d.ts +7 -0
- package/dist/types/src/containers/Deck/DeckContent.d.ts.map +1 -0
- package/dist/types/src/containers/Deck/DeckRoot.d.ts +42 -0
- package/dist/types/src/containers/Deck/DeckRoot.d.ts.map +1 -0
- package/dist/types/src/containers/Deck/DeckViewport.d.ts +19 -0
- package/dist/types/src/containers/Deck/DeckViewport.d.ts.map +1 -0
- package/dist/types/src/containers/Deck/StatusBar.d.ts.map +1 -0
- package/dist/types/src/containers/Deck/index.d.ts +2 -0
- package/dist/types/src/containers/Deck/index.d.ts.map +1 -0
- package/dist/types/src/containers/DeckLayout/ActiveNode.d.ts.map +1 -0
- package/dist/types/src/containers/DeckLayout/DeckLayout.d.ts.map +1 -0
- package/dist/types/src/containers/DeckLayout/DeckLayout.stories.d.ts +73 -0
- package/dist/types/src/containers/DeckLayout/DeckLayout.stories.d.ts.map +1 -0
- package/dist/types/src/containers/DeckLayout/Dialog.d.ts.map +1 -0
- package/dist/types/src/containers/DeckLayout/Fallback.d.ts +2 -0
- package/dist/types/src/containers/DeckLayout/Fallback.d.ts.map +1 -0
- package/dist/types/src/containers/DeckLayout/Popover.d.ts +5 -0
- package/dist/types/src/containers/DeckLayout/Popover.d.ts.map +1 -0
- package/dist/types/src/{components → containers}/DeckLayout/Toast.d.ts +3 -3
- package/dist/types/src/containers/DeckLayout/Toast.d.ts.map +1 -0
- package/dist/types/src/containers/DeckLayout/constants.d.ts.map +1 -0
- package/dist/types/src/containers/DeckLayout/index.d.ts +4 -0
- package/dist/types/src/containers/DeckLayout/index.d.ts.map +1 -0
- package/dist/types/src/containers/Plank/Plank.d.ts +21 -0
- package/dist/types/src/containers/Plank/Plank.d.ts.map +1 -0
- package/dist/types/src/containers/Plank/Plank.stories.d.ts +70 -0
- package/dist/types/src/containers/Plank/Plank.stories.d.ts.map +1 -0
- package/dist/types/src/containers/Plank/PlankComponent.d.ts +15 -0
- package/dist/types/src/containers/Plank/PlankComponent.d.ts.map +1 -0
- package/dist/types/src/containers/Plank/PlankContent.d.ts +14 -0
- package/dist/types/src/containers/Plank/PlankContent.d.ts.map +1 -0
- package/dist/types/src/{components → containers}/Plank/PlankControls.d.ts +5 -6
- package/dist/types/src/containers/Plank/PlankControls.d.ts.map +1 -0
- package/dist/types/src/containers/Plank/PlankError.d.ts +15 -0
- package/dist/types/src/containers/Plank/PlankError.d.ts.map +1 -0
- package/dist/types/src/{components → containers}/Plank/PlankHeading.d.ts +3 -3
- package/dist/types/src/containers/Plank/PlankHeading.d.ts.map +1 -0
- package/dist/types/src/{components → containers}/Plank/PlankLoading.d.ts.map +1 -1
- package/dist/types/src/containers/Plank/PlankRoot.d.ts +37 -0
- package/dist/types/src/containers/Plank/PlankRoot.d.ts.map +1 -0
- package/dist/types/src/containers/Plank/index.d.ts +4 -0
- package/dist/types/src/containers/Plank/index.d.ts.map +1 -0
- package/dist/types/src/containers/Sidebar/ComplementarySidebar.d.ts.map +1 -0
- package/dist/types/src/containers/Sidebar/Sidebar.d.ts.map +1 -0
- package/dist/types/src/{components → containers}/Sidebar/SidebarButton.d.ts.map +1 -1
- package/dist/types/src/{components → containers}/Sidebar/index.d.ts.map +1 -1
- package/dist/types/src/containers/index.d.ts +6 -0
- package/dist/types/src/containers/index.d.ts.map +1 -0
- package/dist/types/src/hooks/index.d.ts +2 -0
- package/dist/types/src/hooks/index.d.ts.map +1 -1
- package/dist/types/src/hooks/useDeckCompanions.d.ts +3 -4
- package/dist/types/src/hooks/useDeckCompanions.d.ts.map +1 -1
- package/dist/types/src/hooks/useDeckState.d.ts +17 -0
- package/dist/types/src/hooks/useDeckState.d.ts.map +1 -0
- package/dist/types/src/hooks/useHoistStatusbar.d.ts +1 -1
- package/dist/types/src/hooks/useHoistStatusbar.d.ts.map +1 -1
- package/dist/types/src/hooks/useMainSize.d.ts +2 -2
- package/dist/types/src/hooks/useNodeActionExpander.d.ts +1 -1
- package/dist/types/src/hooks/useNodeActionExpander.d.ts.map +1 -1
- package/dist/types/src/hooks/useSelectedCompanion.d.ts +13 -0
- package/dist/types/src/hooks/useSelectedCompanion.d.ts.map +1 -0
- package/dist/types/src/index.d.ts +1 -2
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/layout.d.ts +20 -9
- package/dist/types/src/layout.d.ts.map +1 -1
- package/dist/types/src/layout.test.d.ts +2 -0
- package/dist/types/src/layout.test.d.ts.map +1 -0
- package/dist/types/src/meta.d.ts +2 -2
- package/dist/types/src/meta.d.ts.map +1 -1
- package/dist/types/src/operations/add-toast.d.ts +5 -0
- package/dist/types/src/operations/add-toast.d.ts.map +1 -0
- package/dist/types/src/operations/adjust.d.ts +5 -0
- package/dist/types/src/operations/adjust.d.ts.map +1 -0
- package/dist/types/src/operations/change-companion.d.ts +5 -0
- package/dist/types/src/operations/change-companion.d.ts.map +1 -0
- package/dist/types/src/operations/close.d.ts +5 -0
- package/dist/types/src/operations/close.d.ts.map +1 -0
- package/dist/types/src/operations/definitions.d.ts +18 -0
- package/dist/types/src/operations/definitions.d.ts.map +1 -0
- package/dist/types/src/operations/helpers.d.ts +3 -0
- package/dist/types/src/operations/helpers.d.ts.map +1 -0
- package/dist/types/src/operations/index.d.ts +4 -0
- package/dist/types/src/operations/index.d.ts.map +1 -0
- package/dist/types/src/operations/open.d.ts +5 -0
- package/dist/types/src/operations/open.d.ts.map +1 -0
- package/dist/types/src/operations/revert-workspace.d.ts +5 -0
- package/dist/types/src/operations/revert-workspace.d.ts.map +1 -0
- package/dist/types/src/operations/scroll-into-view.d.ts +5 -0
- package/dist/types/src/operations/scroll-into-view.d.ts.map +1 -0
- package/dist/types/src/operations/set-layout-mode.d.ts +9 -0
- package/dist/types/src/operations/set-layout-mode.d.ts.map +1 -0
- package/dist/types/src/operations/set.d.ts +5 -0
- package/dist/types/src/operations/set.d.ts.map +1 -0
- package/dist/types/src/operations/show-undo.d.ts +5 -0
- package/dist/types/src/operations/show-undo.d.ts.map +1 -0
- package/dist/types/src/operations/switch-workspace.d.ts +5 -0
- package/dist/types/src/operations/switch-workspace.d.ts.map +1 -0
- package/dist/types/src/operations/update-complementary.d.ts +5 -0
- package/dist/types/src/operations/update-complementary.d.ts.map +1 -0
- package/dist/types/src/operations/update-dialog.d.ts +5 -0
- package/dist/types/src/operations/update-dialog.d.ts.map +1 -0
- package/dist/types/src/operations/update-plank-size.d.ts +5 -0
- package/dist/types/src/operations/update-plank-size.d.ts.map +1 -0
- package/dist/types/src/operations/update-popover.d.ts +5 -0
- package/dist/types/src/operations/update-popover.d.ts.map +1 -0
- package/dist/types/src/operations/update-sidebar.d.ts +5 -0
- package/dist/types/src/operations/update-sidebar.d.ts.map +1 -0
- package/dist/types/src/translations.d.ts +52 -54
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types/Settings.d.ts +10 -0
- package/dist/types/src/types/Settings.d.ts.map +1 -0
- package/dist/types/src/{capabilities → types}/capabilities.d.ts +114 -96
- package/dist/types/src/types/capabilities.d.ts.map +1 -0
- package/dist/types/src/types/events.d.ts +7 -0
- package/dist/types/src/types/events.d.ts.map +1 -0
- package/dist/types/src/types/index.d.ts +3 -0
- package/dist/types/src/types/index.d.ts.map +1 -1
- package/dist/types/src/types/schema.d.ts +67 -56
- package/dist/types/src/types/schema.d.ts.map +1 -1
- package/dist/types/src/util/index.d.ts +2 -1
- package/dist/types/src/util/index.d.ts.map +1 -1
- package/dist/types/src/util/layoutAppliesTopbar.d.ts +1 -1
- package/dist/types/src/util/layoutAppliesTopbar.d.ts.map +1 -1
- package/dist/types/src/util/plank-url-params.d.ts +14 -0
- package/dist/types/src/util/plank-url-params.d.ts.map +1 -0
- package/dist/types/src/util/plank-url-params.test.d.ts +2 -0
- package/dist/types/src/util/plank-url-params.test.d.ts.map +1 -0
- package/dist/types/src/util/sanitize-persisted-state.d.ts +19 -0
- package/dist/types/src/util/sanitize-persisted-state.d.ts.map +1 -0
- package/dist/types/src/util/sanitize-persisted-state.test.d.ts +2 -0
- package/dist/types/src/util/sanitize-persisted-state.test.d.ts.map +1 -0
- package/dist/types/src/util/set-active.d.ts +19 -4
- package/dist/types/src/util/set-active.d.ts.map +1 -1
- package/dist/types/src/util/set-active.test.d.ts +2 -0
- package/dist/types/src/util/set-active.test.d.ts.map +1 -0
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +87 -49
- package/src/DeckPlugin.ts +29 -54
- package/src/capabilities/app-graph-builder.ts +112 -128
- package/src/capabilities/check-app-scheme.ts +123 -24
- package/src/capabilities/index.ts +13 -14
- package/src/capabilities/operation-handler.ts +16 -0
- package/src/capabilities/react-root.tsx +37 -30
- package/src/capabilities/react-surface.tsx +29 -22
- package/src/capabilities/settings.ts +30 -20
- package/src/capabilities/state.ts +74 -96
- package/src/capabilities/tools.ts +56 -49
- package/src/capabilities/url-handler.ts +216 -50
- package/src/components/DeckSettings/DeckSettings.stories.tsx +37 -0
- package/src/components/DeckSettings/DeckSettings.tsx +56 -86
- package/src/components/DeckSettings/index.ts +2 -2
- package/src/components/Matrix/Matrix.stories.tsx +213 -0
- package/src/components/Matrix/Matrix.tsx +205 -0
- package/src/components/Matrix/SPEC.md +219 -0
- package/src/components/Matrix/index.ts +6 -0
- package/src/components/index.ts +6 -3
- package/src/{components/DeckLayout → containers/Deck}/Banner.tsx +12 -10
- package/src/containers/Deck/Deck.stories.tsx +83 -0
- package/src/containers/Deck/Deck.tsx +21 -0
- package/src/containers/Deck/DeckContent.tsx +105 -0
- package/src/containers/Deck/DeckRoot.tsx +50 -0
- package/src/containers/Deck/DeckViewport.tsx +456 -0
- package/src/{components/DeckLayout → containers/Deck}/StatusBar.tsx +4 -4
- package/src/containers/Deck/index.ts +5 -0
- package/src/{components → containers}/DeckLayout/ActiveNode.tsx +8 -3
- package/src/containers/DeckLayout/DeckLayout.stories.tsx +397 -0
- package/src/containers/DeckLayout/DeckLayout.tsx +62 -0
- package/src/{components → containers}/DeckLayout/Dialog.tsx +23 -13
- package/src/containers/DeckLayout/Fallback.tsx +24 -0
- package/src/containers/DeckLayout/Popover.tsx +159 -0
- package/src/{components → containers}/DeckLayout/Toast.tsx +5 -5
- package/src/{components → containers}/DeckLayout/constants.ts +1 -0
- package/src/{components → containers}/DeckLayout/index.ts +3 -2
- package/src/containers/Plank/Plank.stories.tsx +105 -0
- package/src/containers/Plank/Plank.tsx +22 -0
- package/src/containers/Plank/PlankComponent.tsx +180 -0
- package/src/containers/Plank/PlankContent.tsx +45 -0
- package/src/{components → containers}/Plank/PlankControls.tsx +43 -37
- package/src/containers/Plank/PlankError.tsx +79 -0
- package/src/{components → containers}/Plank/PlankHeading.tsx +56 -63
- package/src/{components → containers}/Plank/PlankLoading.tsx +1 -1
- package/src/containers/Plank/PlankRoot.tsx +49 -0
- package/src/{components → containers}/Plank/index.ts +0 -2
- package/src/containers/Sidebar/ComplementarySidebar.tsx +209 -0
- package/src/containers/Sidebar/Sidebar.tsx +44 -0
- package/src/containers/Sidebar/SidebarButton.tsx +94 -0
- package/src/containers/index.ts +11 -0
- package/src/hooks/index.ts +2 -0
- package/src/hooks/useCompanions.ts +3 -3
- package/src/hooks/useDeckCompanions.ts +7 -11
- package/src/hooks/useDeckState.ts +73 -0
- package/src/hooks/useHoistStatusbar.ts +3 -6
- package/src/hooks/useMainSize.ts +2 -2
- package/src/hooks/useNodeActionExpander.ts +4 -4
- package/src/hooks/useSelectedCompanion.ts +32 -0
- package/src/index.ts +1 -2
- package/src/layout.test.ts +59 -0
- package/src/layout.ts +38 -40
- package/src/meta.ts +3 -3
- package/src/operations/add-toast.ts +24 -0
- package/src/operations/adjust.ts +83 -0
- package/src/operations/change-companion.ts +35 -0
- package/src/operations/close.ts +35 -0
- package/src/operations/definitions.ts +61 -0
- package/src/operations/helpers.ts +22 -0
- package/src/operations/index.ts +26 -0
- package/src/operations/open.ts +184 -0
- package/src/operations/revert-workspace.ts +22 -0
- package/src/operations/scroll-into-view.ts +24 -0
- package/src/operations/set-layout-mode.ts +84 -0
- package/src/operations/set.ts +36 -0
- package/src/operations/show-undo.ts +47 -0
- package/src/operations/switch-workspace.ts +60 -0
- package/src/operations/update-complementary.ts +33 -0
- package/src/operations/update-dialog.ts +34 -0
- package/src/operations/update-plank-size.ts +29 -0
- package/src/operations/update-popover.ts +36 -0
- package/src/operations/update-sidebar.ts +28 -0
- package/src/translations.ts +52 -54
- package/src/types/Settings.ts +17 -0
- package/src/types/capabilities.ts +35 -0
- package/src/types/events.ts +21 -0
- package/src/types/index.ts +3 -0
- package/src/types/schema.ts +51 -51
- package/src/util/index.ts +2 -1
- package/src/util/layoutAppliesTopbar.ts +2 -2
- package/src/util/plank-url-params.test.ts +85 -0
- package/src/util/plank-url-params.ts +36 -0
- package/src/util/sanitize-persisted-state.test.ts +79 -0
- package/src/util/sanitize-persisted-state.ts +52 -0
- package/src/util/set-active.test.ts +106 -0
- package/src/util/set-active.ts +50 -30
- package/src/vite-env.d.ts +5 -0
- package/dist/lib/browser/app-graph-builder-D74NTOMK.mjs +0 -128
- package/dist/lib/browser/app-graph-builder-D74NTOMK.mjs.map +0 -7
- package/dist/lib/browser/check-app-scheme-HIEVFAAX.mjs +0 -32
- package/dist/lib/browser/check-app-scheme-HIEVFAAX.mjs.map +0 -7
- package/dist/lib/browser/chunk-5KMJPIQC.mjs +0 -16
- package/dist/lib/browser/chunk-5KMJPIQC.mjs.map +0 -7
- package/dist/lib/browser/chunk-CNTGBCMK.mjs +0 -145
- package/dist/lib/browser/chunk-CNTGBCMK.mjs.map +0 -7
- package/dist/lib/browser/chunk-F3VCCHVL.mjs +0 -162
- package/dist/lib/browser/chunk-F3VCCHVL.mjs.map +0 -7
- package/dist/lib/browser/chunk-QKCGZ45E.mjs +0 -128
- package/dist/lib/browser/chunk-QKCGZ45E.mjs.map +0 -7
- package/dist/lib/browser/chunk-UXLU6CMW.mjs +0 -16
- package/dist/lib/browser/chunk-UXLU6CMW.mjs.map +0 -7
- package/dist/lib/browser/chunk-VBYJ664A.mjs +0 -132
- package/dist/lib/browser/chunk-VBYJ664A.mjs.map +0 -7
- package/dist/lib/browser/chunk-VUJ6UNIJ.mjs +0 -1553
- package/dist/lib/browser/chunk-VUJ6UNIJ.mjs.map +0 -7
- package/dist/lib/browser/intent-resolver-UA4YQGAC.mjs +0 -524
- package/dist/lib/browser/intent-resolver-UA4YQGAC.mjs.map +0 -7
- package/dist/lib/browser/react-root-JAMHKYWN.mjs +0 -44
- package/dist/lib/browser/react-root-JAMHKYWN.mjs.map +0 -7
- package/dist/lib/browser/react-surface-6LW337ZT.mjs +0 -40
- package/dist/lib/browser/react-surface-6LW337ZT.mjs.map +0 -7
- package/dist/lib/browser/settings-SDPTOCCM.mjs +0 -30
- package/dist/lib/browser/settings-SDPTOCCM.mjs.map +0 -7
- package/dist/lib/browser/state-7IFAGZQO.mjs +0 -12
- package/dist/lib/browser/toolkit-L5CFXJCF.mjs +0 -52
- package/dist/lib/browser/toolkit-L5CFXJCF.mjs.map +0 -7
- package/dist/lib/browser/url-handler-QEYGYE2H.mjs +0 -70
- package/dist/lib/browser/url-handler-QEYGYE2H.mjs.map +0 -7
- package/dist/types/src/capabilities/capabilities.d.ts.map +0 -1
- package/dist/types/src/capabilities/intent-resolver.d.ts +0 -4
- package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
- package/dist/types/src/capabilities/toolkit.d.ts +0 -25
- package/dist/types/src/capabilities/toolkit.d.ts.map +0 -1
- package/dist/types/src/components/DeckLayout/ActiveNode.d.ts.map +0 -1
- package/dist/types/src/components/DeckLayout/Banner.d.ts.map +0 -1
- package/dist/types/src/components/DeckLayout/ContentEmpty.d.ts +0 -3
- package/dist/types/src/components/DeckLayout/ContentEmpty.d.ts.map +0 -1
- package/dist/types/src/components/DeckLayout/DeckLayout.d.ts.map +0 -1
- package/dist/types/src/components/DeckLayout/DeckLayout.stories.d.ts +0 -74
- package/dist/types/src/components/DeckLayout/DeckLayout.stories.d.ts.map +0 -1
- package/dist/types/src/components/DeckLayout/DeckMain.d.ts +0 -3
- package/dist/types/src/components/DeckLayout/DeckMain.d.ts.map +0 -1
- package/dist/types/src/components/DeckLayout/Dialog.d.ts.map +0 -1
- package/dist/types/src/components/DeckLayout/Fallback.d.ts +0 -3
- package/dist/types/src/components/DeckLayout/Fallback.d.ts.map +0 -1
- package/dist/types/src/components/DeckLayout/Popover.d.ts +0 -5
- package/dist/types/src/components/DeckLayout/Popover.d.ts.map +0 -1
- package/dist/types/src/components/DeckLayout/StatusBar.d.ts.map +0 -1
- package/dist/types/src/components/DeckLayout/Toast.d.ts.map +0 -1
- package/dist/types/src/components/DeckLayout/Topbar.d.ts +0 -3
- package/dist/types/src/components/DeckLayout/Topbar.d.ts.map +0 -1
- package/dist/types/src/components/DeckLayout/constants.d.ts.map +0 -1
- package/dist/types/src/components/DeckLayout/index.d.ts +0 -4
- package/dist/types/src/components/DeckLayout/index.d.ts.map +0 -1
- package/dist/types/src/components/Plank/Plank.d.ts +0 -27
- package/dist/types/src/components/Plank/Plank.d.ts.map +0 -1
- package/dist/types/src/components/Plank/Plank.stories.d.ts +0 -89
- package/dist/types/src/components/Plank/Plank.stories.d.ts.map +0 -1
- package/dist/types/src/components/Plank/PlankControls.d.ts.map +0 -1
- package/dist/types/src/components/Plank/PlankError.d.ts +0 -13
- package/dist/types/src/components/Plank/PlankError.d.ts.map +0 -1
- package/dist/types/src/components/Plank/PlankHeading.d.ts.map +0 -1
- package/dist/types/src/components/Plank/index.d.ts +0 -6
- package/dist/types/src/components/Plank/index.d.ts.map +0 -1
- package/dist/types/src/components/Sidebar/ComplementarySidebar.d.ts.map +0 -1
- package/dist/types/src/components/Sidebar/Sidebar.d.ts.map +0 -1
- package/dist/types/src/components/fragments.d.ts +0 -4
- package/dist/types/src/components/fragments.d.ts.map +0 -1
- package/dist/types/src/events.d.ts +0 -4
- package/dist/types/src/events.d.ts.map +0 -1
- package/dist/types/src/util/overscroll.d.ts +0 -47
- package/dist/types/src/util/overscroll.d.ts.map +0 -1
- package/src/capabilities/capabilities.ts +0 -14
- package/src/capabilities/intent-resolver.ts +0 -471
- package/src/capabilities/toolkit.ts +0 -66
- package/src/components/DeckLayout/ContentEmpty.tsx +0 -31
- package/src/components/DeckLayout/DeckLayout.stories.tsx +0 -63
- package/src/components/DeckLayout/DeckLayout.tsx +0 -32
- package/src/components/DeckLayout/DeckMain.tsx +0 -281
- package/src/components/DeckLayout/Fallback.tsx +0 -28
- package/src/components/DeckLayout/Popover.tsx +0 -95
- package/src/components/DeckLayout/Topbar.tsx +0 -11
- package/src/components/Plank/Plank.stories.tsx +0 -54
- package/src/components/Plank/Plank.tsx +0 -299
- package/src/components/Plank/PlankError.tsx +0 -49
- package/src/components/Sidebar/ComplementarySidebar.tsx +0 -214
- package/src/components/Sidebar/Sidebar.tsx +0 -42
- package/src/components/Sidebar/SidebarButton.tsx +0 -88
- package/src/components/fragments.ts +0 -14
- package/src/events.ts +0 -11
- package/src/util/overscroll.ts +0 -69
- /package/dist/lib/browser/{state-7IFAGZQO.mjs.map → chunk-J5LGTIGS.mjs.map} +0 -0
- /package/dist/types/src/{components/DeckLayout → containers/Deck}/Banner.d.ts +0 -0
- /package/dist/types/src/{components/DeckLayout → containers/Deck}/StatusBar.d.ts +0 -0
- /package/dist/types/src/{components → containers}/DeckLayout/ActiveNode.d.ts +0 -0
- /package/dist/types/src/{components → containers}/DeckLayout/DeckLayout.d.ts +0 -0
- /package/dist/types/src/{components → containers}/DeckLayout/Dialog.d.ts +0 -0
- /package/dist/types/src/{components → containers}/DeckLayout/constants.d.ts +0 -0
- /package/dist/types/src/{components → containers}/Plank/PlankLoading.d.ts +0 -0
- /package/dist/types/src/{components → containers}/Sidebar/ComplementarySidebar.d.ts +0 -0
- /package/dist/types/src/{components → containers}/Sidebar/Sidebar.d.ts +0 -0
- /package/dist/types/src/{components → containers}/Sidebar/SidebarButton.d.ts +0 -0
- /package/dist/types/src/{components → containers}/Sidebar/index.d.ts +0 -0
- /package/src/{components → containers}/Sidebar/index.ts +0 -0
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import { type StoredDeckState } from '#types';
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Sanitizes persisted deck state on startup.
|
|
9
|
+
*
|
|
10
|
+
* Persisted state may contain values that are inappropriate to restore across sessions:
|
|
11
|
+
*
|
|
12
|
+
* - **Fullscreen**: Cleared unconditionally to prevent the user from getting stuck in fullscreen
|
|
13
|
+
* mode if the app was closed (or crashed) while fullscreen was active.
|
|
14
|
+
*
|
|
15
|
+
* - **Active planks in solo-mode decks**: When a deck is in solo mode, any items in `active`
|
|
16
|
+
* represent planks that were kept mounted (hidden) during the session for fast deck↔solo
|
|
17
|
+
* switching. After a restart these planks would need to fully remount anyway, so retaining
|
|
18
|
+
* them only adds unnecessary load. Clearing `active` for solo-mode decks avoids rendering
|
|
19
|
+
* stale planks in the background on startup.
|
|
20
|
+
*
|
|
21
|
+
* Returns a new state object if any changes were made, or the original state if clean.
|
|
22
|
+
*/
|
|
23
|
+
export const sanitizePersistedState = (state: StoredDeckState): StoredDeckState => {
|
|
24
|
+
let needsUpdate = false;
|
|
25
|
+
const cleanedDecks = { ...state.decks };
|
|
26
|
+
|
|
27
|
+
for (const [id, deck] of Object.entries(cleanedDecks)) {
|
|
28
|
+
if (!deck) {
|
|
29
|
+
continue;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
let updated = false;
|
|
33
|
+
let cleanedDeck = deck;
|
|
34
|
+
|
|
35
|
+
if (deck.fullscreen) {
|
|
36
|
+
cleanedDeck = { ...cleanedDeck, fullscreen: false };
|
|
37
|
+
updated = true;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
if (deck.solo && deck.active.length > 0) {
|
|
41
|
+
cleanedDeck = { ...cleanedDeck, active: [] };
|
|
42
|
+
updated = true;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
if (updated) {
|
|
46
|
+
cleanedDecks[id] = cleanedDeck;
|
|
47
|
+
needsUpdate = true;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
return needsUpdate ? { ...state, decks: cleanedDecks } : state;
|
|
52
|
+
};
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import { describe, test } from 'vitest';
|
|
6
|
+
|
|
7
|
+
import { defaultDeck, type DeckState } from '#types';
|
|
8
|
+
|
|
9
|
+
import { computeActiveUpdates } from './set-active';
|
|
10
|
+
|
|
11
|
+
const makeDeck = (overrides: Partial<DeckState> = {}): DeckState => ({
|
|
12
|
+
...defaultDeck,
|
|
13
|
+
...overrides,
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
describe('computeActiveUpdates', () => {
|
|
17
|
+
describe('routing to solo vs active', () => {
|
|
18
|
+
test('routes to solo when initialized is false and solo is undefined', ({ expect }) => {
|
|
19
|
+
const deck = makeDeck({ initialized: false });
|
|
20
|
+
const { deckUpdates } = computeActiveUpdates({ next: ['item1'], deck });
|
|
21
|
+
expect(deckUpdates.solo).toBe('item1');
|
|
22
|
+
expect(deckUpdates.active).toEqual([]);
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
test('routes to solo when solo is set (regardless of initialized)', ({ expect }) => {
|
|
26
|
+
const deck = makeDeck({ solo: 'current', initialized: true });
|
|
27
|
+
const { deckUpdates } = computeActiveUpdates({ next: ['item1'], deck });
|
|
28
|
+
expect(deckUpdates.solo).toBe('item1');
|
|
29
|
+
expect(deckUpdates.active).toEqual([]);
|
|
30
|
+
});
|
|
31
|
+
|
|
32
|
+
test('routes to active when initialized is true and solo is undefined', ({ expect }) => {
|
|
33
|
+
const deck = makeDeck({ initialized: true });
|
|
34
|
+
const { deckUpdates } = computeActiveUpdates({ next: ['item1', 'item2'], deck });
|
|
35
|
+
expect(deckUpdates.solo).toBeUndefined();
|
|
36
|
+
expect(deckUpdates.active).toEqual(['item1', 'item2']);
|
|
37
|
+
});
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
describe('active preservation', () => {
|
|
41
|
+
test('preserves active unchanged when routing to solo', ({ expect }) => {
|
|
42
|
+
const deck = makeDeck({ solo: 'current', active: ['a', 'b', 'c'], initialized: true });
|
|
43
|
+
const { deckUpdates } = computeActiveUpdates({ next: ['item1'], deck });
|
|
44
|
+
expect(deckUpdates.solo).toBe('item1');
|
|
45
|
+
expect(deckUpdates.active).toEqual(['a', 'b', 'c']);
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
test('preserves active when initialized is false', ({ expect }) => {
|
|
49
|
+
const deck = makeDeck({ initialized: false, active: ['stale'] });
|
|
50
|
+
const { deckUpdates } = computeActiveUpdates({ next: ['item1'], deck });
|
|
51
|
+
expect(deckUpdates.solo).toBe('item1');
|
|
52
|
+
expect(deckUpdates.active).toEqual(['stale']);
|
|
53
|
+
});
|
|
54
|
+
});
|
|
55
|
+
|
|
56
|
+
describe('inactive handling', () => {
|
|
57
|
+
test('moves removed items to inactive', ({ expect }) => {
|
|
58
|
+
const deck = makeDeck({ initialized: true, active: ['a', 'b', 'c'] });
|
|
59
|
+
const { deckUpdates } = computeActiveUpdates({ next: ['a', 'c'], deck });
|
|
60
|
+
expect(deckUpdates.active).toEqual(['a', 'c']);
|
|
61
|
+
expect(deckUpdates.inactive).toContain('b');
|
|
62
|
+
});
|
|
63
|
+
|
|
64
|
+
test('moves displaced solo item to inactive', ({ expect }) => {
|
|
65
|
+
const deck = makeDeck({ solo: 'old', initialized: true });
|
|
66
|
+
const { deckUpdates } = computeActiveUpdates({ next: ['new'], deck });
|
|
67
|
+
expect(deckUpdates.solo).toBe('new');
|
|
68
|
+
expect(deckUpdates.inactive).toContain('old');
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
test('does not duplicate items already in inactive', ({ expect }) => {
|
|
72
|
+
const deck = makeDeck({ solo: 'old', initialized: true, inactive: ['old'] });
|
|
73
|
+
const { deckUpdates } = computeActiveUpdates({ next: ['new'], deck });
|
|
74
|
+
const oldCount = deckUpdates.inactive.filter((id) => id === 'old').length;
|
|
75
|
+
expect(oldCount).toBe(1);
|
|
76
|
+
});
|
|
77
|
+
});
|
|
78
|
+
|
|
79
|
+
describe('fullscreen', () => {
|
|
80
|
+
test('clears fullscreen when solo is cleared', ({ expect }) => {
|
|
81
|
+
const deck = makeDeck({ solo: 'item', fullscreen: true, initialized: true });
|
|
82
|
+
const { deckUpdates } = computeActiveUpdates({ next: [], deck });
|
|
83
|
+
expect(deckUpdates.fullscreen).toBe(false);
|
|
84
|
+
});
|
|
85
|
+
|
|
86
|
+
test('preserves fullscreen when solo is set', ({ expect }) => {
|
|
87
|
+
const deck = makeDeck({ solo: 'old', fullscreen: true, initialized: true });
|
|
88
|
+
const { deckUpdates } = computeActiveUpdates({ next: ['new'], deck });
|
|
89
|
+
expect(deckUpdates.fullscreen).toBe(true);
|
|
90
|
+
});
|
|
91
|
+
});
|
|
92
|
+
|
|
93
|
+
describe('empty next', () => {
|
|
94
|
+
test('clears solo when next is empty and in solo mode', ({ expect }) => {
|
|
95
|
+
const deck = makeDeck({ solo: 'item', initialized: false });
|
|
96
|
+
const { deckUpdates } = computeActiveUpdates({ next: [], deck });
|
|
97
|
+
expect(deckUpdates.solo).toBeUndefined();
|
|
98
|
+
});
|
|
99
|
+
|
|
100
|
+
test('clears active when next is empty and in deck mode', ({ expect }) => {
|
|
101
|
+
const deck = makeDeck({ initialized: true, active: ['a', 'b'] });
|
|
102
|
+
const { deckUpdates } = computeActiveUpdates({ next: [], deck });
|
|
103
|
+
expect(deckUpdates.active).toEqual([]);
|
|
104
|
+
});
|
|
105
|
+
});
|
|
106
|
+
});
|
package/src/util/set-active.ts
CHANGED
|
@@ -2,46 +2,66 @@
|
|
|
2
2
|
// Copyright 2025 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import {
|
|
5
|
+
import { type AttentionManager } from '@dxos/react-ui-attention';
|
|
6
6
|
|
|
7
|
-
import { type
|
|
8
|
-
|
|
9
|
-
import { type DeckPluginState } from '../types';
|
|
7
|
+
import { type DeckState } from '#types';
|
|
10
8
|
|
|
11
9
|
export type SetActiveOptions = {
|
|
12
10
|
next: string[];
|
|
13
|
-
|
|
11
|
+
deck: DeckState;
|
|
14
12
|
attention?: AttentionManager;
|
|
15
13
|
};
|
|
16
14
|
|
|
17
|
-
export
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
15
|
+
export type SetActiveResult = {
|
|
16
|
+
/** Updates to apply to the deck. */
|
|
17
|
+
deckUpdates: {
|
|
18
|
+
inactive: string[];
|
|
19
|
+
solo: string | undefined;
|
|
20
|
+
active: string[];
|
|
21
|
+
fullscreen: boolean;
|
|
22
|
+
};
|
|
23
|
+
/** ID of the item to attend (scroll into view) if attention changed. */
|
|
24
|
+
toAttend?: string;
|
|
25
|
+
};
|
|
22
26
|
|
|
23
|
-
|
|
27
|
+
/**
|
|
28
|
+
* Computes the new active state for the deck without mutating.
|
|
29
|
+
* Returns the updates to apply and optionally an item to attend.
|
|
30
|
+
*/
|
|
31
|
+
export const computeActiveUpdates = ({ next, deck, attention }: SetActiveOptions): SetActiveResult => {
|
|
32
|
+
const active = deck.solo ? [deck.solo] : deck.active;
|
|
33
|
+
const removed = active.filter((id) => !next.includes(id));
|
|
34
|
+
const closed = Array.from(new Set([...deck.inactive.filter((id) => !next.includes(id)), ...removed]));
|
|
24
35
|
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
36
|
+
const updates = {
|
|
37
|
+
inactive: closed,
|
|
38
|
+
solo: deck.solo,
|
|
39
|
+
active: deck.active,
|
|
40
|
+
fullscreen: deck.fullscreen,
|
|
41
|
+
};
|
|
30
42
|
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
43
|
+
if (deck.solo || !deck.initialized) {
|
|
44
|
+
updates.solo = next[0];
|
|
45
|
+
} else {
|
|
46
|
+
updates.active = next;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
if (deck.fullscreen && !updates.solo) {
|
|
50
|
+
updates.fullscreen = false;
|
|
51
|
+
}
|
|
34
52
|
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
53
|
+
let toAttend: string | undefined;
|
|
54
|
+
if (attention) {
|
|
55
|
+
const attended = attention.getCurrent();
|
|
56
|
+
const [attendedId] = Array.from(attended);
|
|
57
|
+
const isAttendedAvailable = !!attendedId && next.includes(attendedId);
|
|
58
|
+
if (!isAttendedAvailable) {
|
|
59
|
+
const attendedIndex = active.indexOf(attendedId);
|
|
60
|
+
// If outside of bounds, focus on the first/last plank, otherwise focus on the new plank in the same position.
|
|
61
|
+
const index = attendedIndex === -1 ? 0 : attendedIndex >= next.length ? next.length - 1 : attendedIndex;
|
|
62
|
+
toAttend = next[index];
|
|
45
63
|
}
|
|
46
|
-
}
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
return { deckUpdates: updates, toAttend };
|
|
47
67
|
};
|
|
@@ -1,128 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
DeckCapabilities
|
|
3
|
-
} from "./chunk-5KMJPIQC.mjs";
|
|
4
|
-
import {
|
|
5
|
-
meta
|
|
6
|
-
} from "./chunk-UXLU6CMW.mjs";
|
|
7
|
-
|
|
8
|
-
// src/capabilities/app-graph-builder.ts
|
|
9
|
-
import { Atom } from "@effect-atom/atom-react";
|
|
10
|
-
import * as Function from "effect/Function";
|
|
11
|
-
import * as Option from "effect/Option";
|
|
12
|
-
import { Capabilities, LayoutAction, contributes, createIntent } from "@dxos/app-framework";
|
|
13
|
-
import { AttentionCapabilities } from "@dxos/plugin-attention";
|
|
14
|
-
import { ROOT_ID, atomFromSignal, createExtension } from "@dxos/plugin-graph";
|
|
15
|
-
var app_graph_builder_default = ((context) => contributes(Capabilities.AppGraphBuilder, createExtension({
|
|
16
|
-
id: meta.id,
|
|
17
|
-
actions: (node) => Atom.make((get) => Function.pipe(get(node), Option.flatMap((node2) => node2.id === ROOT_ID ? Option.some(node2) : Option.none()), Option.map(() => {
|
|
18
|
-
const state = context.getCapability(DeckCapabilities.MutableDeckState);
|
|
19
|
-
const closeCurrent = {
|
|
20
|
-
id: `${LayoutAction.Close._tag}/current`,
|
|
21
|
-
data: async () => {
|
|
22
|
-
const attention = context.getCapability(AttentionCapabilities.Attention);
|
|
23
|
-
const attended = attention.current.at(-1);
|
|
24
|
-
if (attended) {
|
|
25
|
-
const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
|
|
26
|
-
await dispatch(createIntent(LayoutAction.Close, {
|
|
27
|
-
part: "main",
|
|
28
|
-
subject: [
|
|
29
|
-
attended
|
|
30
|
-
],
|
|
31
|
-
options: {
|
|
32
|
-
state: false
|
|
33
|
-
}
|
|
34
|
-
}));
|
|
35
|
-
}
|
|
36
|
-
},
|
|
37
|
-
properties: {
|
|
38
|
-
label: [
|
|
39
|
-
"close current label",
|
|
40
|
-
{
|
|
41
|
-
ns: meta.id
|
|
42
|
-
}
|
|
43
|
-
],
|
|
44
|
-
icon: "ph--x--regular"
|
|
45
|
-
}
|
|
46
|
-
};
|
|
47
|
-
const closeOthers = {
|
|
48
|
-
id: `${LayoutAction.Close._tag}/others`,
|
|
49
|
-
data: async () => {
|
|
50
|
-
const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
|
|
51
|
-
const attention = context.getCapability(AttentionCapabilities.Attention);
|
|
52
|
-
const attended = attention.current.at(-1);
|
|
53
|
-
const ids = state.deck.active.filter((id) => id !== attended) ?? [];
|
|
54
|
-
await dispatch(createIntent(LayoutAction.Close, {
|
|
55
|
-
part: "main",
|
|
56
|
-
subject: ids,
|
|
57
|
-
options: {
|
|
58
|
-
state: false
|
|
59
|
-
}
|
|
60
|
-
}));
|
|
61
|
-
},
|
|
62
|
-
properties: {
|
|
63
|
-
label: [
|
|
64
|
-
"close others label",
|
|
65
|
-
{
|
|
66
|
-
ns: meta.id
|
|
67
|
-
}
|
|
68
|
-
],
|
|
69
|
-
icon: "ph--x-square--regular"
|
|
70
|
-
}
|
|
71
|
-
};
|
|
72
|
-
const closeAll = {
|
|
73
|
-
id: `${LayoutAction.Close._tag}/all`,
|
|
74
|
-
data: async () => {
|
|
75
|
-
const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
|
|
76
|
-
await dispatch(createIntent(LayoutAction.Close, {
|
|
77
|
-
part: "main",
|
|
78
|
-
subject: state.deck.active,
|
|
79
|
-
options: {
|
|
80
|
-
state: false
|
|
81
|
-
}
|
|
82
|
-
}));
|
|
83
|
-
},
|
|
84
|
-
properties: {
|
|
85
|
-
label: [
|
|
86
|
-
"close all label",
|
|
87
|
-
{
|
|
88
|
-
ns: meta.id
|
|
89
|
-
}
|
|
90
|
-
],
|
|
91
|
-
icon: "ph--x-circle--regular"
|
|
92
|
-
}
|
|
93
|
-
};
|
|
94
|
-
const toggleSidebar = {
|
|
95
|
-
id: `${LayoutAction.UpdateSidebar._tag}/nav`,
|
|
96
|
-
data: async () => {
|
|
97
|
-
state.sidebarState = state.sidebarState === "expanded" ? "collapsed" : "expanded";
|
|
98
|
-
},
|
|
99
|
-
properties: {
|
|
100
|
-
label: [
|
|
101
|
-
get(atomFromSignal(() => state.sidebarState === "expanded" ? "collapse navigation sidebar label" : "open navigation sidebar label")),
|
|
102
|
-
{
|
|
103
|
-
ns: meta.id
|
|
104
|
-
}
|
|
105
|
-
],
|
|
106
|
-
icon: "ph--sidebar--regular",
|
|
107
|
-
keyBinding: {
|
|
108
|
-
macos: "meta+'"
|
|
109
|
-
},
|
|
110
|
-
disposition: "pin-end",
|
|
111
|
-
position: "hoist",
|
|
112
|
-
l0Breakpoint: "lg"
|
|
113
|
-
}
|
|
114
|
-
};
|
|
115
|
-
return get(atomFromSignal(() => !state.deck.solo ? [
|
|
116
|
-
closeCurrent,
|
|
117
|
-
closeOthers,
|
|
118
|
-
closeAll,
|
|
119
|
-
toggleSidebar
|
|
120
|
-
] : [
|
|
121
|
-
toggleSidebar
|
|
122
|
-
]));
|
|
123
|
-
}), Option.getOrElse(() => [])))
|
|
124
|
-
})));
|
|
125
|
-
export {
|
|
126
|
-
app_graph_builder_default as default
|
|
127
|
-
};
|
|
128
|
-
//# sourceMappingURL=app-graph-builder-D74NTOMK.mjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/capabilities/app-graph-builder.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Atom } from '@effect-atom/atom-react';\nimport * as Function from 'effect/Function';\nimport * as Option from 'effect/Option';\n\nimport { Capabilities, LayoutAction, type PluginContext, contributes, createIntent } from '@dxos/app-framework';\nimport { AttentionCapabilities } from '@dxos/plugin-attention';\nimport { ROOT_ID, atomFromSignal, createExtension } from '@dxos/plugin-graph';\n\nimport { meta } from '../meta';\n\nimport { DeckCapabilities } from './capabilities';\n\nexport default (context: PluginContext) =>\n contributes(\n Capabilities.AppGraphBuilder,\n createExtension({\n id: meta.id,\n actions: (node) =>\n Atom.make((get) =>\n Function.pipe(\n get(node),\n Option.flatMap((node) => (node.id === ROOT_ID ? Option.some(node) : Option.none())),\n Option.map(() => {\n const state = context.getCapability(DeckCapabilities.MutableDeckState);\n\n // NOTE(Zan): This is currently disabled.\n // TODO(Zan): Fullscreen needs to know the active node and provide that to the layout part.\n // const _fullscreen = {\n // id: `${LayoutAction.UpdateLayout._tag}/fullscreen`,\n // data: async () => {\n // const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);\n // await dispatch(\n // createIntent(LayoutAction.SetLayoutMode, { part: 'mode', options: { mode: 'fullscreen' } }),\n // );\n // },\n // properties: {\n // label: ['toggle fullscreen label', { ns: meta.id }],\n // icon: 'ph--arrows-out--regular',\n // keyBinding: {\n // macos: 'ctrl+meta+f',\n // windows: 'shift+ctrl+f',\n // },\n // },\n // };\n\n const closeCurrent = {\n id: `${LayoutAction.Close._tag}/current`,\n data: async () => {\n const attention = context.getCapability(AttentionCapabilities.Attention);\n const attended = attention.current.at(-1);\n if (attended) {\n const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);\n await dispatch(\n createIntent(LayoutAction.Close, {\n part: 'main',\n subject: [attended],\n options: { state: false },\n }),\n );\n }\n },\n properties: {\n label: ['close current label', { ns: meta.id }],\n icon: 'ph--x--regular',\n },\n };\n\n const closeOthers = {\n id: `${LayoutAction.Close._tag}/others`,\n data: async () => {\n const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);\n const attention = context.getCapability(AttentionCapabilities.Attention);\n const attended = attention.current.at(-1);\n const ids = state.deck.active.filter((id) => id !== attended) ?? [];\n await dispatch(\n createIntent(LayoutAction.Close, { part: 'main', subject: ids, options: { state: false } }),\n );\n },\n properties: {\n label: ['close others label', { ns: meta.id }],\n icon: 'ph--x-square--regular',\n },\n };\n\n const closeAll = {\n id: `${LayoutAction.Close._tag}/all`,\n data: async () => {\n const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);\n await dispatch(\n createIntent(LayoutAction.Close, {\n part: 'main',\n subject: state.deck.active,\n options: { state: false },\n }),\n );\n },\n properties: {\n label: ['close all label', { ns: meta.id }],\n icon: 'ph--x-circle--regular',\n },\n };\n\n const toggleSidebar = {\n id: `${LayoutAction.UpdateSidebar._tag}/nav`,\n data: async () => {\n state.sidebarState = state.sidebarState === 'expanded' ? 'collapsed' : 'expanded';\n },\n properties: {\n label: [\n get(\n atomFromSignal(() =>\n state.sidebarState === 'expanded'\n ? 'collapse navigation sidebar label'\n : 'open navigation sidebar label',\n ),\n ),\n { ns: meta.id },\n ],\n icon: 'ph--sidebar--regular',\n keyBinding: {\n macos: \"meta+'\",\n },\n disposition: 'pin-end',\n position: 'hoist',\n l0Breakpoint: 'lg',\n },\n };\n\n return get(\n atomFromSignal(() =>\n !state.deck.solo ? [closeCurrent, closeOthers, closeAll, toggleSidebar] : [toggleSidebar],\n ),\n );\n }),\n Option.getOrElse(() => []),\n ),\n ),\n }),\n );\n"],
|
|
5
|
-
"mappings": ";;;;;;;;AAIA,SAASA,YAAY;AACrB,YAAYC,cAAc;AAC1B,YAAYC,YAAY;AAExB,SAASC,cAAcC,cAAkCC,aAAaC,oBAAoB;AAC1F,SAASC,6BAA6B;AACtC,SAASC,SAASC,gBAAgBC,uBAAuB;AAMzD,IAAA,6BAAe,CAACC,YACdC,YACEC,aAAaC,iBACbC,gBAAgB;EACdC,IAAIC,KAAKD;EACTE,SAAS,CAACC,SACRC,KAAKC,KAAK,CAACC,QACAC,cACPD,IAAIH,IAAAA,GACGK,eAAQ,CAACL,UAAUA,MAAKH,OAAOS,UAAiBC,YAAKP,KAAAA,IAAeQ,YAAI,CAAA,GACxEC,WAAI,MAAA;AACT,UAAMC,QAAQlB,QAAQmB,cAAcC,iBAAiBC,gBAAgB;AAsBrE,UAAMC,eAAe;MACnBjB,IAAI,GAAGkB,aAAaC,MAAMC,IAAI;MAC9BC,MAAM,YAAA;AACJ,cAAMC,YAAY3B,QAAQmB,cAAcS,sBAAsBC,SAAS;AACvE,cAAMC,WAAWH,UAAUI,QAAQC,GAAG,EAAC;AACvC,YAAIF,UAAU;AACZ,gBAAM,EAAEG,iBAAiBC,SAAQ,IAAKlC,QAAQmB,cAAcjB,aAAaiC,gBAAgB;AACzF,gBAAMD,SACJE,aAAab,aAAaC,OAAO;YAC/Ba,MAAM;YACNC,SAAS;cAACR;;YACVS,SAAS;cAAErB,OAAO;YAAM;UAC1B,CAAA,CAAA;QAEJ;MACF;MACAsB,YAAY;QACVC,OAAO;UAAC;UAAuB;YAAEC,IAAIpC,KAAKD;UAAG;;QAC7CsC,MAAM;MACR;IACF;AAEA,UAAMC,cAAc;MAClBvC,IAAI,GAAGkB,aAAaC,MAAMC,IAAI;MAC9BC,MAAM,YAAA;AACJ,cAAM,EAAEO,iBAAiBC,SAAQ,IAAKlC,QAAQmB,cAAcjB,aAAaiC,gBAAgB;AACzF,cAAMR,YAAY3B,QAAQmB,cAAcS,sBAAsBC,SAAS;AACvE,cAAMC,WAAWH,UAAUI,QAAQC,GAAG,EAAC;AACvC,cAAMa,MAAM3B,MAAM4B,KAAKC,OAAOC,OAAO,CAAC3C,OAAOA,OAAOyB,QAAAA,KAAa,CAAA;AACjE,cAAMI,SACJE,aAAab,aAAaC,OAAO;UAAEa,MAAM;UAAQC,SAASO;UAAKN,SAAS;YAAErB,OAAO;UAAM;QAAE,CAAA,CAAA;MAE7F;MACAsB,YAAY;QACVC,OAAO;UAAC;UAAsB;YAAEC,IAAIpC,KAAKD;UAAG;;QAC5CsC,MAAM;MACR;IACF;AAEA,UAAMM,WAAW;MACf5C,IAAI,GAAGkB,aAAaC,MAAMC,IAAI;MAC9BC,MAAM,YAAA;AACJ,cAAM,EAAEO,iBAAiBC,SAAQ,IAAKlC,QAAQmB,cAAcjB,aAAaiC,gBAAgB;AACzF,cAAMD,SACJE,aAAab,aAAaC,OAAO;UAC/Ba,MAAM;UACNC,SAASpB,MAAM4B,KAAKC;UACpBR,SAAS;YAAErB,OAAO;UAAM;QAC1B,CAAA,CAAA;MAEJ;MACAsB,YAAY;QACVC,OAAO;UAAC;UAAmB;YAAEC,IAAIpC,KAAKD;UAAG;;QACzCsC,MAAM;MACR;IACF;AAEA,UAAMO,gBAAgB;MACpB7C,IAAI,GAAGkB,aAAa4B,cAAc1B,IAAI;MACtCC,MAAM,YAAA;AACJR,cAAMkC,eAAelC,MAAMkC,iBAAiB,aAAa,cAAc;MACzE;MACAZ,YAAY;QACVC,OAAO;UACL9B,IACE0C,eAAe,MACbnC,MAAMkC,iBAAiB,aACnB,sCACA,+BAAA,CAAA;UAGR;YAAEV,IAAIpC,KAAKD;UAAG;;QAEhBsC,MAAM;QACNW,YAAY;UACVC,OAAO;QACT;QACAC,aAAa;QACbC,UAAU;QACVC,cAAc;MAChB;IACF;AAEA,WAAO/C,IACL0C,eAAe,MACb,CAACnC,MAAM4B,KAAKa,OAAO;MAACrC;MAAcsB;MAAaK;MAAUC;QAAiB;MAACA;KAAc,CAAA;EAG/F,CAAA,GACOU,iBAAU,MAAM,CAAA,CAAE,CAAA,CAAA;AAGjC,CAAA,CAAA;",
|
|
6
|
-
"names": ["Atom", "Function", "Option", "Capabilities", "LayoutAction", "contributes", "createIntent", "AttentionCapabilities", "ROOT_ID", "atomFromSignal", "createExtension", "context", "contributes", "Capabilities", "AppGraphBuilder", "createExtension", "id", "meta", "actions", "node", "Atom", "make", "get", "pipe", "flatMap", "ROOT_ID", "some", "none", "map", "state", "getCapability", "DeckCapabilities", "MutableDeckState", "closeCurrent", "LayoutAction", "Close", "_tag", "data", "attention", "AttentionCapabilities", "Attention", "attended", "current", "at", "dispatchPromise", "dispatch", "IntentDispatcher", "createIntent", "part", "subject", "options", "properties", "label", "ns", "icon", "closeOthers", "ids", "deck", "active", "filter", "closeAll", "toggleSidebar", "UpdateSidebar", "sidebarState", "atomFromSignal", "keyBinding", "macos", "disposition", "position", "l0Breakpoint", "solo", "getOrElse"]
|
|
7
|
-
}
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
meta
|
|
3
|
-
} from "./chunk-UXLU6CMW.mjs";
|
|
4
|
-
|
|
5
|
-
// src/capabilities/check-app-scheme.ts
|
|
6
|
-
import { Capabilities, contributes } from "@dxos/app-framework";
|
|
7
|
-
var isSocket = !!globalThis.__args;
|
|
8
|
-
var appScheme = "composer://";
|
|
9
|
-
var checkAppScheme = (url) => {
|
|
10
|
-
const iframe = document.createElement("iframe");
|
|
11
|
-
iframe.style.display = "none";
|
|
12
|
-
document.body.appendChild(iframe);
|
|
13
|
-
iframe.src = url + window.location.pathname.replace(/^\/+/, "") + window.location.search;
|
|
14
|
-
const timer = setTimeout(() => {
|
|
15
|
-
document.body.removeChild(iframe);
|
|
16
|
-
}, 3e3);
|
|
17
|
-
window.addEventListener("pagehide", (event) => {
|
|
18
|
-
clearTimeout(timer);
|
|
19
|
-
document.body.removeChild(iframe);
|
|
20
|
-
});
|
|
21
|
-
};
|
|
22
|
-
var check_app_scheme_default = (async (context) => {
|
|
23
|
-
const settings = context.getCapability(Capabilities.SettingsStore).getStore(meta.id)?.value;
|
|
24
|
-
if (!isSocket && settings?.enableNativeRedirect) {
|
|
25
|
-
checkAppScheme(appScheme);
|
|
26
|
-
}
|
|
27
|
-
return contributes(Capabilities.Null, null);
|
|
28
|
-
});
|
|
29
|
-
export {
|
|
30
|
-
check_app_scheme_default as default
|
|
31
|
-
};
|
|
32
|
-
//# sourceMappingURL=check-app-scheme-HIEVFAAX.mjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/capabilities/check-app-scheme.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Capabilities, type PluginContext, contributes } from '@dxos/app-framework';\n\nimport { meta } from '../meta';\nimport { type DeckSettingsProps } from '../types';\n\nconst isSocket = !!(globalThis as any).__args;\n\n// TODO(mjamesderocher): Can we get this directly from Socket?\nconst appScheme = 'composer://';\n\n// TODO(mjamesderocher): Factor out as part of NavigationPlugin.\nconst checkAppScheme = (url: string) => {\n const iframe = document.createElement('iframe');\n iframe.style.display = 'none';\n document.body.appendChild(iframe);\n\n iframe.src = url + window.location.pathname.replace(/^\\/+/, '') + window.location.search;\n\n const timer = setTimeout(() => {\n document.body.removeChild(iframe);\n }, 3000);\n\n window.addEventListener('pagehide', (event) => {\n clearTimeout(timer);\n document.body.removeChild(iframe);\n });\n};\n\nexport default async (context: PluginContext) => {\n const settings = context.getCapability(Capabilities.SettingsStore).getStore<DeckSettingsProps>(meta.id)?.value;\n if (!isSocket && settings?.enableNativeRedirect) {\n checkAppScheme(appScheme);\n }\n\n return contributes(Capabilities.Null, null);\n};\n"],
|
|
5
|
-
"mappings": ";;;;;AAIA,SAASA,cAAkCC,mBAAmB;AAK9D,IAAMC,WAAW,CAAC,CAAEC,WAAmBC;AAGvC,IAAMC,YAAY;AAGlB,IAAMC,iBAAiB,CAACC,QAAAA;AACtB,QAAMC,SAASC,SAASC,cAAc,QAAA;AACtCF,SAAOG,MAAMC,UAAU;AACvBH,WAASI,KAAKC,YAAYN,MAAAA;AAE1BA,SAAOO,MAAMR,MAAMS,OAAOC,SAASC,SAASC,QAAQ,QAAQ,EAAA,IAAMH,OAAOC,SAASG;AAElF,QAAMC,QAAQC,WAAW,MAAA;AACvBb,aAASI,KAAKU,YAAYf,MAAAA;EAC5B,GAAG,GAAA;AAEHQ,SAAOQ,iBAAiB,YAAY,CAACC,UAAAA;AACnCC,iBAAaL,KAAAA;AACbZ,aAASI,KAAKU,YAAYf,MAAAA;EAC5B,CAAA;AACF;AAEA,IAAA,4BAAe,OAAOmB,YAAAA;AACpB,QAAMC,WAAWD,QAAQE,cAAcC,aAAaC,aAAa,EAAEC,SAA4BC,KAAKC,EAAE,GAAGC;AACzG,MAAI,CAACjC,YAAY0B,UAAUQ,sBAAsB;AAC/C9B,mBAAeD,SAAAA;EACjB;AAEA,SAAOgC,YAAYP,aAAaQ,MAAM,IAAA;AACxC;",
|
|
6
|
-
"names": ["Capabilities", "contributes", "isSocket", "globalThis", "__args", "appScheme", "checkAppScheme", "url", "iframe", "document", "createElement", "style", "display", "body", "appendChild", "src", "window", "location", "pathname", "replace", "search", "timer", "setTimeout", "removeChild", "addEventListener", "event", "clearTimeout", "context", "settings", "getCapability", "Capabilities", "SettingsStore", "getStore", "meta", "id", "value", "enableNativeRedirect", "contributes", "Null"]
|
|
7
|
-
}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
meta
|
|
3
|
-
} from "./chunk-UXLU6CMW.mjs";
|
|
4
|
-
|
|
5
|
-
// src/capabilities/capabilities.ts
|
|
6
|
-
import { defineCapability } from "@dxos/app-framework";
|
|
7
|
-
(function(DeckCapabilities2) {
|
|
8
|
-
DeckCapabilities2.DeckState = defineCapability(`${meta.id}/capability/state`);
|
|
9
|
-
DeckCapabilities2.MutableDeckState = defineCapability(`${meta.id}/capability/state`);
|
|
10
|
-
})(DeckCapabilities || (DeckCapabilities = {}));
|
|
11
|
-
var DeckCapabilities;
|
|
12
|
-
|
|
13
|
-
export {
|
|
14
|
-
DeckCapabilities
|
|
15
|
-
};
|
|
16
|
-
//# sourceMappingURL=chunk-5KMJPIQC.mjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/capabilities/capabilities.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { defineCapability } from '@dxos/app-framework';\nimport { type DeepReadonly } from '@dxos/util';\n\nimport { meta } from '../meta';\nimport { type DeckPluginState } from '../types';\n\nexport namespace DeckCapabilities {\n export const DeckState = defineCapability<DeepReadonly<DeckPluginState>>(`${meta.id}/capability/state`);\n export const MutableDeckState = defineCapability<DeckPluginState>(`${meta.id}/capability/state`);\n}\n"],
|
|
5
|
-
"mappings": ";;;;;AAIA,SAASA,wBAAwB;UAMhBC,mBAAAA;oBACFC,YAAYC,iBAAgD,GAAGC,KAAKC,EAAE,mBAAmB;oBACzFC,mBAAmBH,iBAAkC,GAAGC,KAAKC,EAAE,mBAAmB;AACjG,GAHiBJ,qBAAAA,mBAAAA,CAAAA,EAAAA;;",
|
|
6
|
-
"names": ["defineCapability", "DeckCapabilities", "DeckState", "defineCapability", "meta", "id", "MutableDeckState"]
|
|
7
|
-
}
|
|
@@ -1,145 +0,0 @@
|
|
|
1
|
-
// src/layout.ts
|
|
2
|
-
import { produce } from "immer";
|
|
3
|
-
import { ATTENDABLE_PATH_SEPARATOR } from "@dxos/react-ui-attention";
|
|
4
|
-
var createEntryId = (entryId, variant) => variant ? `${entryId}${ATTENDABLE_PATH_SEPARATOR}${variant}` : entryId;
|
|
5
|
-
var parseEntryId = (entryId) => {
|
|
6
|
-
const [id, variant] = entryId.split(ATTENDABLE_PATH_SEPARATOR);
|
|
7
|
-
return {
|
|
8
|
-
id,
|
|
9
|
-
variant
|
|
10
|
-
};
|
|
11
|
-
};
|
|
12
|
-
var openEntry = (deck, _entryId, options) => {
|
|
13
|
-
return produce(deck, (draft) => {
|
|
14
|
-
const entryId = createEntryId(_entryId, options?.variant);
|
|
15
|
-
if (draft.find((id) => id === entryId)) {
|
|
16
|
-
return;
|
|
17
|
-
}
|
|
18
|
-
const key = options?.key;
|
|
19
|
-
const plankPositioning = options?.positioning ?? "start";
|
|
20
|
-
const pivotId = options?.pivotId;
|
|
21
|
-
if (key) {
|
|
22
|
-
const index = draft.findIndex((id) => id.split("+")[0] === key);
|
|
23
|
-
if (index !== -1) {
|
|
24
|
-
draft.splice(index, 1, entryId);
|
|
25
|
-
return;
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
if (pivotId) {
|
|
29
|
-
const pivotIndex = draft.findIndex((id) => id === pivotId);
|
|
30
|
-
if (pivotIndex !== -1) {
|
|
31
|
-
if (plankPositioning === "start") {
|
|
32
|
-
draft.splice(pivotIndex, 0, entryId);
|
|
33
|
-
} else {
|
|
34
|
-
draft.splice(pivotIndex + 1, 0, entryId);
|
|
35
|
-
}
|
|
36
|
-
return;
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
if (plankPositioning === "start") {
|
|
40
|
-
draft.unshift(entryId);
|
|
41
|
-
} else {
|
|
42
|
-
draft.push(entryId);
|
|
43
|
-
}
|
|
44
|
-
});
|
|
45
|
-
};
|
|
46
|
-
var closeEntry = (deck, entryId) => {
|
|
47
|
-
return produce(deck, (draft) => {
|
|
48
|
-
const index = draft.findIndex((id) => id === entryId);
|
|
49
|
-
if (index !== -1) {
|
|
50
|
-
draft.splice(index, 1);
|
|
51
|
-
}
|
|
52
|
-
});
|
|
53
|
-
};
|
|
54
|
-
var incrementPlank = (deck, adjustment) => {
|
|
55
|
-
return produce(deck, (draft) => {
|
|
56
|
-
const index = draft.findIndex((id) => id === adjustment.id);
|
|
57
|
-
if (index === -1 || adjustment.type === "increment-start" && index === 0 || adjustment.type === "increment-end" && index === draft.length - 1) {
|
|
58
|
-
return;
|
|
59
|
-
}
|
|
60
|
-
if (adjustment.type === "increment-start") {
|
|
61
|
-
[draft[index - 1], draft[index]] = [
|
|
62
|
-
draft[index],
|
|
63
|
-
draft[index - 1]
|
|
64
|
-
];
|
|
65
|
-
} else if (adjustment.type === "increment-end") {
|
|
66
|
-
[draft[index], draft[index + 1]] = [
|
|
67
|
-
draft[index + 1],
|
|
68
|
-
draft[index]
|
|
69
|
-
];
|
|
70
|
-
}
|
|
71
|
-
});
|
|
72
|
-
};
|
|
73
|
-
|
|
74
|
-
// src/util/set-active.ts
|
|
75
|
-
import { batch } from "@preact/signals-core";
|
|
76
|
-
var setActive = ({ next, state, attention }) => {
|
|
77
|
-
return batch(() => {
|
|
78
|
-
const active = state.deck.solo ? [
|
|
79
|
-
state.deck.solo
|
|
80
|
-
] : state.deck.active;
|
|
81
|
-
const removed = active.filter((id) => !next.includes(id));
|
|
82
|
-
const closed = Array.from(/* @__PURE__ */ new Set([
|
|
83
|
-
...state.deck.inactive.filter((id) => !next.includes(id)),
|
|
84
|
-
...removed
|
|
85
|
-
]));
|
|
86
|
-
state.deck.inactive = closed;
|
|
87
|
-
if (state.deck.solo || !state.deck.initialized) {
|
|
88
|
-
state.deck.solo = next[0];
|
|
89
|
-
} else {
|
|
90
|
-
state.deck.active = next;
|
|
91
|
-
}
|
|
92
|
-
if (state.deck.fullscreen && !state.deck.solo) {
|
|
93
|
-
state.deck.fullscreen = false;
|
|
94
|
-
}
|
|
95
|
-
if (attention) {
|
|
96
|
-
const attended = attention.current;
|
|
97
|
-
const [attendedId] = Array.from(attended);
|
|
98
|
-
const isAttendedAvailable = !!attendedId && next.includes(attendedId);
|
|
99
|
-
if (!isAttendedAvailable) {
|
|
100
|
-
const attendedIndex = active.indexOf(attendedId);
|
|
101
|
-
const index = attendedIndex === -1 ? 0 : attendedIndex >= next.length ? next.length - 1 : attendedIndex;
|
|
102
|
-
return next[index];
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
});
|
|
106
|
-
};
|
|
107
|
-
|
|
108
|
-
// src/util/layoutAppliesTopbar.ts
|
|
109
|
-
var layoutAppliesTopbar = (breakpoint, layoutMode) => {
|
|
110
|
-
return document.body.getAttribute("data-platform") === "win" && breakpoint === "desktop" && layoutMode !== "solo--fullscreen";
|
|
111
|
-
};
|
|
112
|
-
|
|
113
|
-
// src/util/overscroll.ts
|
|
114
|
-
var calculateOverscroll = (planksCount) => {
|
|
115
|
-
if (!planksCount) {
|
|
116
|
-
return {
|
|
117
|
-
paddingInlineStart: 0,
|
|
118
|
-
paddingInlineEnd: 0
|
|
119
|
-
};
|
|
120
|
-
}
|
|
121
|
-
if (planksCount === 1) {
|
|
122
|
-
const overscrollPadding = "max(0px, calc(((100dvw - var(--dx-main-sidebarWidth) - var(--dx-main-complementaryWidth) - (var(--dx-main-contentFirstWidth) + 1px)) / 2)))";
|
|
123
|
-
return {
|
|
124
|
-
paddingInlineStart: overscrollPadding,
|
|
125
|
-
paddingInlineEnd: overscrollPadding
|
|
126
|
-
};
|
|
127
|
-
} else {
|
|
128
|
-
return {
|
|
129
|
-
paddingInlineStart: "max(0px, calc(((100dvw - (var(--dx-main-contentFirstWidth) + 1px)) / 2) - var(--dx-main-sidebarWidth)))",
|
|
130
|
-
paddingInlineEnd: "max(0px, calc(((100dvw - (var(--dx-main-contentLastWidth) + 1px)) / 2) - var(--dx-main-complementaryWidth)))"
|
|
131
|
-
};
|
|
132
|
-
}
|
|
133
|
-
};
|
|
134
|
-
|
|
135
|
-
export {
|
|
136
|
-
createEntryId,
|
|
137
|
-
parseEntryId,
|
|
138
|
-
openEntry,
|
|
139
|
-
closeEntry,
|
|
140
|
-
incrementPlank,
|
|
141
|
-
layoutAppliesTopbar,
|
|
142
|
-
calculateOverscroll,
|
|
143
|
-
setActive
|
|
144
|
-
};
|
|
145
|
-
//# sourceMappingURL=chunk-CNTGBCMK.mjs.map
|