@dxos/plugin-deck 0.8.4-main.d05673bc65 → 0.8.4-main.d9fc60f731
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/LICENSE +102 -5
- package/PLUGIN.mdl +541 -0
- package/README.md +1 -1
- package/dist/lib/neutral/DeckLayout-YABVXRDU.mjs +291 -0
- package/dist/lib/neutral/DeckLayout-YABVXRDU.mjs.map +7 -0
- package/dist/lib/neutral/DeckPlugin.mjs +87 -0
- package/dist/lib/neutral/DeckPlugin.mjs.map +7 -0
- package/dist/lib/neutral/DeckPlugin.node.mjs +18 -0
- package/dist/lib/neutral/DeckPlugin.node.mjs.map +7 -0
- package/dist/lib/neutral/DeckPlugin.workerd.mjs +16 -0
- package/dist/lib/neutral/DeckPlugin.workerd.mjs.map +7 -0
- package/dist/lib/neutral/DeckSettings-W5I57OXM.mjs +27 -0
- package/dist/lib/neutral/DeckSettings-W5I57OXM.mjs.map +7 -0
- package/dist/lib/neutral/add-toast-TNB6DXWU.mjs +24 -0
- package/dist/lib/neutral/add-toast-TNB6DXWU.mjs.map +7 -0
- package/dist/lib/neutral/adjust-HNU5CCRO.mjs +93 -0
- package/dist/lib/neutral/adjust-HNU5CCRO.mjs.map +7 -0
- package/dist/lib/neutral/app-graph-builder-HMLT627T.mjs +129 -0
- package/dist/lib/neutral/app-graph-builder-HMLT627T.mjs.map +7 -0
- package/dist/lib/neutral/capabilities/index.mjs +25 -0
- package/dist/lib/neutral/capabilities/index.mjs.map +7 -0
- package/dist/lib/neutral/check-app-scheme-A7FZVNZO.mjs +10 -0
- package/dist/lib/neutral/chunk-BS4EOYMK.mjs +282 -0
- package/dist/lib/neutral/chunk-BS4EOYMK.mjs.map +7 -0
- package/dist/lib/neutral/chunk-GBIGQKYW.mjs +112 -0
- package/dist/lib/neutral/chunk-GBIGQKYW.mjs.map +7 -0
- package/dist/lib/neutral/chunk-GLB73Q6U.mjs +22 -0
- package/dist/lib/neutral/chunk-GLB73Q6U.mjs.map +7 -0
- package/dist/lib/neutral/chunk-J5LGTIGS.mjs +10 -0
- package/dist/lib/neutral/chunk-OQGC7JYT.mjs +8 -0
- package/dist/lib/neutral/chunk-OQGC7JYT.mjs.map +7 -0
- package/dist/lib/neutral/chunk-PYEY5SEC.mjs +37 -0
- package/dist/lib/neutral/chunk-PYEY5SEC.mjs.map +7 -0
- package/dist/lib/neutral/chunk-Q534NBCS.mjs +1305 -0
- package/dist/lib/neutral/chunk-Q534NBCS.mjs.map +7 -0
- package/dist/lib/neutral/chunk-VHETZ22W.mjs +101 -0
- package/dist/lib/neutral/chunk-VHETZ22W.mjs.map +7 -0
- package/dist/lib/neutral/chunk-ZYYOSX5I.mjs +69 -0
- package/dist/lib/neutral/chunk-ZYYOSX5I.mjs.map +7 -0
- package/dist/lib/neutral/close-ASKR22A6.mjs +44 -0
- package/dist/lib/neutral/close-ASKR22A6.mjs.map +7 -0
- package/dist/lib/neutral/components/index.mjs +126 -0
- package/dist/lib/neutral/components/index.mjs.map +7 -0
- package/dist/lib/neutral/containers/index.mjs +32 -0
- package/dist/lib/neutral/containers/index.mjs.map +7 -0
- package/dist/lib/{browser/chunk-TAHLKBDO.mjs → neutral/hooks/index.mjs} +34 -62
- package/dist/lib/neutral/hooks/index.mjs.map +7 -0
- package/dist/lib/neutral/index.mjs +38 -0
- package/dist/lib/neutral/index.mjs.map +7 -0
- package/dist/lib/neutral/meta.json +1 -0
- package/dist/lib/neutral/meta.mjs +8 -0
- package/dist/lib/neutral/meta.mjs.map +7 -0
- package/dist/lib/neutral/notification-tracker-BYKXOXDE.mjs +128 -0
- package/dist/lib/neutral/notification-tracker-BYKXOXDE.mjs.map +7 -0
- package/dist/lib/neutral/open-IFIEYVHG.mjs +159 -0
- package/dist/lib/neutral/open-IFIEYVHG.mjs.map +7 -0
- package/dist/lib/neutral/operation-handler-266CVMTW.mjs +13 -0
- package/dist/lib/neutral/operation-handler-266CVMTW.mjs.map +7 -0
- package/dist/lib/neutral/operations/index.mjs +8 -0
- package/dist/lib/neutral/operations/index.mjs.map +7 -0
- package/dist/lib/neutral/plugin.mjs +16 -0
- package/dist/lib/neutral/plugin.mjs.map +7 -0
- package/dist/lib/neutral/react-root-HH5DEUOG.mjs +44 -0
- package/dist/lib/neutral/react-root-HH5DEUOG.mjs.map +7 -0
- package/dist/lib/neutral/react-surface-3UVVCK3O.mjs +34 -0
- package/dist/lib/neutral/react-surface-3UVVCK3O.mjs.map +7 -0
- package/dist/lib/neutral/revert-workspace-B2QLT2C4.mjs +21 -0
- package/dist/lib/neutral/revert-workspace-B2QLT2C4.mjs.map +7 -0
- package/dist/lib/neutral/scroll-into-view-B52C3PJO.mjs +21 -0
- package/dist/lib/neutral/scroll-into-view-B52C3PJO.mjs.map +7 -0
- package/dist/lib/neutral/set-PA35ONXO.mjs +37 -0
- package/dist/lib/neutral/set-PA35ONXO.mjs.map +7 -0
- package/dist/lib/neutral/set-layout-mode-RPCCPQRB.mjs +85 -0
- package/dist/lib/neutral/set-layout-mode-RPCCPQRB.mjs.map +7 -0
- package/dist/lib/{browser/settings-PTMGCSJH.mjs → neutral/settings-EGNYUM4T.mjs} +7 -14
- package/dist/lib/neutral/settings-EGNYUM4T.mjs.map +7 -0
- package/dist/lib/{browser/state-MA4SQ7BE.mjs → neutral/state-IIDXMQUO.mjs} +13 -33
- package/dist/lib/neutral/state-IIDXMQUO.mjs.map +7 -0
- package/dist/lib/neutral/switch-workspace-LZF4KZXH.mjs +60 -0
- package/dist/lib/neutral/switch-workspace-LZF4KZXH.mjs.map +7 -0
- package/dist/lib/neutral/translations.mjs +59 -0
- package/dist/lib/neutral/translations.mjs.map +7 -0
- package/dist/lib/neutral/types/index.mjs +34 -0
- package/dist/lib/neutral/types/index.mjs.map +7 -0
- package/dist/lib/neutral/update-companion-YUCZZVGY.mjs +32 -0
- package/dist/lib/neutral/update-companion-YUCZZVGY.mjs.map +7 -0
- package/dist/lib/neutral/update-complementary-7FZNB55J.mjs +28 -0
- package/dist/lib/neutral/update-complementary-7FZNB55J.mjs.map +7 -0
- package/dist/lib/neutral/update-dialog-FNQTSSAP.mjs +29 -0
- package/dist/lib/neutral/update-dialog-FNQTSSAP.mjs.map +7 -0
- package/dist/lib/neutral/update-plank-size-3YW4NXEY.mjs +26 -0
- package/dist/lib/neutral/update-plank-size-3YW4NXEY.mjs.map +7 -0
- package/dist/lib/neutral/update-popover-G2VUD7E6.mjs +33 -0
- package/dist/lib/neutral/update-popover-G2VUD7E6.mjs.map +7 -0
- package/dist/lib/neutral/update-sidebar-KRHPUHUB.mjs +25 -0
- package/dist/lib/neutral/update-sidebar-KRHPUHUB.mjs.map +7 -0
- package/dist/lib/neutral/url-handler-4SW6BFAC.mjs +229 -0
- package/dist/lib/neutral/url-handler-4SW6BFAC.mjs.map +7 -0
- package/dist/types/src/DeckPlugin.d.ts +1 -0
- package/dist/types/src/DeckPlugin.d.ts.map +1 -1
- package/dist/types/src/DeckPlugin.node.d.ts +4 -0
- package/dist/types/src/DeckPlugin.node.d.ts.map +1 -0
- package/dist/types/src/DeckPlugin.test.d.ts +2 -0
- package/dist/types/src/DeckPlugin.test.d.ts.map +1 -0
- package/dist/types/src/DeckPlugin.workerd.d.ts +4 -0
- package/dist/types/src/DeckPlugin.workerd.d.ts.map +1 -0
- package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -0
- package/dist/types/src/capabilities/check-app-scheme.d.ts +19 -0
- package/dist/types/src/capabilities/check-app-scheme.d.ts.map +1 -0
- package/dist/types/src/capabilities/index.d.ts +199 -9
- package/dist/types/src/capabilities/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/notification-tracker.d.ts +13 -0
- package/dist/types/src/capabilities/notification-tracker.d.ts.map +1 -0
- 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.map +1 -0
- package/dist/types/src/capabilities/react-surface.d.ts.map +1 -0
- package/dist/types/src/capabilities/settings.d.ts +7 -0
- package/dist/types/src/capabilities/settings.d.ts.map +1 -0
- package/dist/types/src/capabilities/{state/state.d.ts → state.d.ts} +50 -34
- package/dist/types/src/capabilities/state.d.ts.map +1 -0
- package/dist/types/src/capabilities/{tools/tools.d.ts → tools.d.ts} +1 -1
- package/dist/types/src/capabilities/tools.d.ts.map +1 -0
- package/dist/types/src/capabilities/{url-handler/url-handler.d.ts → url-handler.d.ts} +1 -1
- package/dist/types/src/capabilities/url-handler.d.ts.map +1 -0
- package/dist/types/src/components/DeckSettings/DeckSettings.d.ts +6 -0
- package/dist/types/src/components/DeckSettings/DeckSettings.d.ts.map +1 -0
- package/dist/types/src/components/DeckSettings/DeckSettings.stories.d.ts +63 -0
- package/dist/types/src/components/DeckSettings/DeckSettings.stories.d.ts.map +1 -0
- package/dist/types/src/components/DeckSettings/index.d.ts +2 -0
- package/dist/types/src/components/DeckSettings/index.d.ts.map +1 -0
- package/dist/types/src/components/Matrix/Matrix.d.ts +41 -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 -1
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/{components/DeckLayout → containers/Deck}/Banner.d.ts +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 +63 -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 +39 -0
- package/dist/types/src/containers/Deck/DeckRoot.d.ts.map +1 -0
- package/dist/types/src/containers/Deck/DeckViewport.d.ts +16 -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/{components → containers}/DeckLayout/ActiveNode.d.ts.map +1 -1
- package/dist/types/src/containers/DeckLayout/DeckLayout.d.ts.map +1 -0
- package/dist/types/src/containers/DeckLayout/DeckLayout.stories.d.ts +65 -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 +1 -1
- 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 +17 -0
- package/dist/types/src/containers/Plank/Plank.d.ts.map +1 -0
- package/dist/types/src/containers/Plank/Plank.stories.d.ts +63 -0
- package/dist/types/src/containers/Plank/Plank.stories.d.ts.map +1 -0
- package/dist/types/src/containers/Plank/PlankComponent.d.ts +17 -0
- package/dist/types/src/containers/Plank/PlankComponent.d.ts.map +1 -0
- package/dist/types/src/containers/Plank/PlankContent.d.ts +10 -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/{components → containers}/Plank/PlankError.d.ts +2 -2
- package/dist/types/src/containers/Plank/PlankError.d.ts.map +1 -0
- package/dist/types/src/{components → containers}/Plank/PlankHeading.d.ts +3 -2
- 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 +1 -1
- package/dist/types/src/containers/Sidebar/SidebarButton.d.ts.map +1 -0
- package/dist/types/src/{components → containers}/Sidebar/index.d.ts.map +1 -1
- package/dist/types/src/containers/index.d.ts +4 -2
- package/dist/types/src/containers/index.d.ts.map +1 -1
- package/dist/types/src/hooks/index.d.ts +0 -1
- package/dist/types/src/hooks/index.d.ts.map +1 -1
- package/dist/types/src/hooks/useBreakpoints.d.ts +1 -1
- package/dist/types/src/hooks/useCompanions.d.ts.map +1 -1
- package/dist/types/src/hooks/useDeckCompanions.d.ts +2 -1
- package/dist/types/src/hooks/useDeckCompanions.d.ts.map +1 -1
- package/dist/types/src/hooks/useDeckState.d.ts +3 -3
- package/dist/types/src/hooks/useDeckState.d.ts.map +1 -1
- package/dist/types/src/hooks/useMainSize.d.ts.map +1 -1
- package/dist/types/src/hooks/useNodeActionExpander.d.ts.map +1 -1
- package/dist/types/src/hooks/useSelectedCompanion.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +1 -3
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/layout.d.ts +20 -3
- 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 +1 -1
- 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/close.d.ts +5 -0
- package/dist/types/src/operations/close.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 +3 -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/switch-workspace.d.ts +5 -0
- package/dist/types/src/operations/switch-workspace.d.ts.map +1 -0
- package/dist/types/src/operations/update-companion.d.ts +5 -0
- package/dist/types/src/operations/update-companion.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/plugin.d.ts +4 -0
- package/dist/types/src/plugin.d.ts.map +1 -0
- package/dist/types/src/translations.d.ts +44 -56
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/{capabilities/state/index.d.ts → types/DeckCapabilities.d.ts} +63 -47
- package/dist/types/src/types/DeckCapabilities.d.ts.map +1 -0
- package/dist/types/src/types/DeckEvents.d.ts +5 -0
- package/dist/types/src/types/DeckEvents.d.ts.map +1 -0
- package/dist/types/src/types/DeckOperation.d.ts +15 -0
- package/dist/types/src/types/DeckOperation.d.ts.map +1 -0
- 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/types/index.d.ts +4 -2
- package/dist/types/src/types/index.d.ts.map +1 -1
- package/dist/types/src/types/schema.d.ts +45 -106
- 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 +2 -2
- 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 +112 -56
- package/src/DeckPlugin.node.ts +17 -0
- package/src/DeckPlugin.test.ts +27 -0
- package/src/DeckPlugin.ts +23 -16
- package/src/DeckPlugin.workerd.ts +16 -0
- package/src/capabilities/app-graph-builder.ts +127 -0
- package/src/capabilities/check-app-scheme.ts +139 -0
- package/src/capabilities/index.ts +15 -10
- package/src/capabilities/notification-tracker.ts +132 -0
- package/src/capabilities/operation-handler.ts +16 -0
- package/src/capabilities/react-root.tsx +52 -0
- package/src/capabilities/{react-surface/react-surface.tsx → react-surface.tsx} +12 -14
- package/src/capabilities/{settings/settings.ts → settings.ts} +4 -7
- package/src/capabilities/{state/state.ts → state.ts} +12 -26
- package/src/capabilities/{tools/tools.ts → tools.ts} +7 -7
- package/src/capabilities/url-handler.ts +302 -0
- package/src/components/DeckSettings/DeckSettings.stories.tsx +37 -0
- package/src/components/DeckSettings/DeckSettings.tsx +34 -0
- package/src/components/DeckSettings/index.ts +5 -0
- package/src/components/Matrix/Matrix.stories.tsx +220 -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 -2
- package/src/{components/DeckLayout → containers/Deck}/Banner.tsx +7 -5
- package/src/containers/Deck/Deck.stories.tsx +81 -0
- package/src/containers/Deck/Deck.tsx +21 -0
- package/src/containers/Deck/DeckContent.tsx +102 -0
- package/src/containers/Deck/DeckRoot.tsx +50 -0
- package/src/containers/Deck/DeckViewport.tsx +450 -0
- package/src/containers/Deck/index.ts +5 -0
- package/src/{components → containers}/DeckLayout/ActiveNode.tsx +8 -4
- package/src/containers/DeckLayout/DeckLayout.stories.tsx +395 -0
- package/src/containers/DeckLayout/DeckLayout.tsx +62 -0
- package/src/{components → containers}/DeckLayout/Dialog.tsx +11 -4
- package/src/{components → containers}/DeckLayout/Fallback.tsx +5 -5
- package/src/containers/DeckLayout/Popover.tsx +166 -0
- package/src/{components → containers}/DeckLayout/Toast.tsx +20 -30
- 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 +108 -0
- package/src/containers/Plank/Plank.tsx +22 -0
- package/src/containers/Plank/PlankComponent.tsx +218 -0
- package/src/containers/Plank/PlankContent.tsx +45 -0
- package/src/{components → containers}/Plank/PlankControls.tsx +37 -28
- package/src/{components → containers}/Plank/PlankError.tsx +25 -6
- package/src/{components → containers}/Plank/PlankHeading.tsx +52 -40
- 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 +191 -0
- package/src/containers/Sidebar/Sidebar.tsx +39 -0
- package/src/{components → containers}/Sidebar/SidebarButton.tsx +17 -11
- package/src/containers/index.ts +5 -2
- package/src/hooks/index.ts +0 -1
- package/src/hooks/useCompanions.ts +1 -1
- package/src/hooks/useDeckCompanions.ts +3 -2
- package/src/hooks/useDeckState.ts +11 -20
- package/src/hooks/useSelectedCompanion.ts +4 -4
- package/src/index.ts +1 -3
- package/src/layout.test.ts +59 -0
- package/src/layout.ts +38 -27
- package/src/meta.ts +24 -6
- package/src/operations/add-toast.ts +24 -0
- package/src/operations/adjust.ts +82 -0
- package/src/operations/close.ts +35 -0
- package/src/operations/helpers.ts +22 -0
- package/src/operations/index.ts +23 -0
- package/src/operations/open.ts +200 -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/switch-workspace.ts +66 -0
- package/src/operations/update-companion.ts +35 -0
- package/src/operations/update-complementary.ts +33 -0
- package/src/operations/update-dialog.ts +34 -0
- package/src/operations/update-plank-size.ts +28 -0
- package/src/operations/update-popover.ts +36 -0
- package/src/operations/update-sidebar.ts +28 -0
- package/src/plugin.ts +11 -0
- package/src/translations.ts +44 -55
- package/src/types/DeckCapabilities.ts +34 -0
- package/src/types/DeckEvents.ts +21 -0
- package/src/types/DeckOperation.ts +56 -0
- package/src/types/Settings.ts +36 -0
- package/src/types/index.ts +5 -2
- package/src/types/schema.ts +33 -113
- package/src/util/index.ts +2 -1
- package/src/util/layoutAppliesTopbar.ts +1 -1
- 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 +2 -2
- package/src/vite-env.d.ts +10 -0
- package/dist/lib/browser/Banner-HXRXEUOZ.mjs +0 -14
- package/dist/lib/browser/Banner-HXRXEUOZ.mjs.map +0 -7
- package/dist/lib/browser/DeckSettings-HSSQKFNE.mjs +0 -96
- package/dist/lib/browser/DeckSettings-HSSQKFNE.mjs.map +0 -7
- package/dist/lib/browser/app-graph-builder-MP6INIM2.mjs +0 -123
- package/dist/lib/browser/app-graph-builder-MP6INIM2.mjs.map +0 -7
- package/dist/lib/browser/check-app-scheme-AUNCD2Y6.mjs +0 -33
- package/dist/lib/browser/check-app-scheme-AUNCD2Y6.mjs.map +0 -7
- package/dist/lib/browser/chunk-3P2FJVXC.mjs +0 -278
- package/dist/lib/browser/chunk-3P2FJVXC.mjs.map +0 -7
- package/dist/lib/browser/chunk-BJDEG7YZ.mjs +0 -74
- package/dist/lib/browser/chunk-BJDEG7YZ.mjs.map +0 -7
- package/dist/lib/browser/chunk-ITNJS5QX.mjs +0 -1386
- package/dist/lib/browser/chunk-ITNJS5QX.mjs.map +0 -7
- package/dist/lib/browser/chunk-L3RYMAV7.mjs +0 -16
- package/dist/lib/browser/chunk-L3RYMAV7.mjs.map +0 -7
- package/dist/lib/browser/chunk-TAHLKBDO.mjs.map +0 -7
- package/dist/lib/browser/index.mjs +0 -184
- package/dist/lib/browser/index.mjs.map +0 -7
- package/dist/lib/browser/meta.json +0 -1
- package/dist/lib/browser/operation-resolver-2TEGT4PG.mjs +0 -639
- package/dist/lib/browser/operation-resolver-2TEGT4PG.mjs.map +0 -7
- package/dist/lib/browser/react-root-AS4IOYDG.mjs +0 -48
- package/dist/lib/browser/react-root-AS4IOYDG.mjs.map +0 -7
- package/dist/lib/browser/react-surface-FH7TC6WW.mjs +0 -44
- package/dist/lib/browser/react-surface-FH7TC6WW.mjs.map +0 -7
- package/dist/lib/browser/settings-PTMGCSJH.mjs.map +0 -7
- package/dist/lib/browser/state-MA4SQ7BE.mjs.map +0 -7
- package/dist/lib/browser/toolkit-6B34QFU3.mjs +0 -55
- package/dist/lib/browser/toolkit-6B34QFU3.mjs.map +0 -7
- package/dist/lib/browser/types/index.mjs +0 -38
- package/dist/lib/browser/url-handler-FEUFPQIP.mjs +0 -98
- package/dist/lib/browser/url-handler-FEUFPQIP.mjs.map +0 -7
- package/dist/lib/node-esm/Banner-RN7XXOXY.mjs +0 -15
- package/dist/lib/node-esm/Banner-RN7XXOXY.mjs.map +0 -7
- package/dist/lib/node-esm/DeckSettings-DJRFLKQS.mjs +0 -97
- package/dist/lib/node-esm/DeckSettings-DJRFLKQS.mjs.map +0 -7
- package/dist/lib/node-esm/app-graph-builder-ACHG5HY7.mjs +0 -124
- package/dist/lib/node-esm/app-graph-builder-ACHG5HY7.mjs.map +0 -7
- package/dist/lib/node-esm/check-app-scheme-WN76GWVC.mjs +0 -34
- package/dist/lib/node-esm/check-app-scheme-WN76GWVC.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-DGTRKKWZ.mjs +0 -76
- package/dist/lib/node-esm/chunk-DGTRKKWZ.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-EMU4VIPH.mjs +0 -188
- package/dist/lib/node-esm/chunk-EMU4VIPH.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-GZJAQ5IP.mjs +0 -279
- package/dist/lib/node-esm/chunk-GZJAQ5IP.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-MBCCNIWY.mjs +0 -1387
- package/dist/lib/node-esm/chunk-MBCCNIWY.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-XCNF4COU.mjs +0 -18
- package/dist/lib/node-esm/chunk-XCNF4COU.mjs.map +0 -7
- package/dist/lib/node-esm/index.mjs +0 -185
- package/dist/lib/node-esm/index.mjs.map +0 -7
- package/dist/lib/node-esm/meta.json +0 -1
- package/dist/lib/node-esm/operation-resolver-GCMCCI7A.mjs +0 -640
- package/dist/lib/node-esm/operation-resolver-GCMCCI7A.mjs.map +0 -7
- package/dist/lib/node-esm/react-root-7DTDLAF4.mjs +0 -49
- package/dist/lib/node-esm/react-root-7DTDLAF4.mjs.map +0 -7
- package/dist/lib/node-esm/react-surface-U6Z2K324.mjs +0 -45
- package/dist/lib/node-esm/react-surface-U6Z2K324.mjs.map +0 -7
- package/dist/lib/node-esm/settings-LPPFLXNJ.mjs +0 -41
- package/dist/lib/node-esm/settings-LPPFLXNJ.mjs.map +0 -7
- package/dist/lib/node-esm/state-KNRU3GDC.mjs +0 -107
- package/dist/lib/node-esm/state-KNRU3GDC.mjs.map +0 -7
- package/dist/lib/node-esm/toolkit-SOWYKJY3.mjs +0 -56
- package/dist/lib/node-esm/toolkit-SOWYKJY3.mjs.map +0 -7
- package/dist/lib/node-esm/types/index.mjs +0 -39
- package/dist/lib/node-esm/url-handler-4LEB7UWF.mjs +0 -99
- package/dist/lib/node-esm/url-handler-4LEB7UWF.mjs.map +0 -7
- package/dist/types/src/capabilities/app-graph-builder/app-graph-builder.d.ts.map +0 -1
- package/dist/types/src/capabilities/app-graph-builder/index.d.ts +0 -3
- package/dist/types/src/capabilities/app-graph-builder/index.d.ts.map +0 -1
- package/dist/types/src/capabilities/check-app-scheme/check-app-scheme.d.ts +0 -5
- package/dist/types/src/capabilities/check-app-scheme/check-app-scheme.d.ts.map +0 -1
- package/dist/types/src/capabilities/check-app-scheme/index.d.ts +0 -3
- package/dist/types/src/capabilities/check-app-scheme/index.d.ts.map +0 -1
- package/dist/types/src/capabilities/operation-resolver/index.d.ts +0 -3
- package/dist/types/src/capabilities/operation-resolver/index.d.ts.map +0 -1
- package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts +0 -5
- package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts.map +0 -1
- package/dist/types/src/capabilities/react-root/index.d.ts +0 -6
- package/dist/types/src/capabilities/react-root/index.d.ts.map +0 -1
- package/dist/types/src/capabilities/react-root/react-root.d.ts.map +0 -1
- package/dist/types/src/capabilities/react-surface/index.d.ts +0 -3
- package/dist/types/src/capabilities/react-surface/index.d.ts.map +0 -1
- package/dist/types/src/capabilities/react-surface/react-surface.d.ts.map +0 -1
- package/dist/types/src/capabilities/settings/index.d.ts +0 -19
- package/dist/types/src/capabilities/settings/index.d.ts.map +0 -1
- package/dist/types/src/capabilities/settings/settings.d.ts +0 -22
- package/dist/types/src/capabilities/settings/settings.d.ts.map +0 -1
- package/dist/types/src/capabilities/state/index.d.ts.map +0 -1
- package/dist/types/src/capabilities/state/state.d.ts.map +0 -1
- package/dist/types/src/capabilities/toolkit/index.d.ts +0 -3
- package/dist/types/src/capabilities/toolkit/index.d.ts.map +0 -1
- package/dist/types/src/capabilities/toolkit/toolkit.d.ts +0 -27
- package/dist/types/src/capabilities/toolkit/toolkit.d.ts.map +0 -1
- package/dist/types/src/capabilities/tools/index.d.ts +0 -3
- package/dist/types/src/capabilities/tools/index.d.ts.map +0 -1
- package/dist/types/src/capabilities/tools/tools.d.ts.map +0 -1
- package/dist/types/src/capabilities/url-handler/index.d.ts +0 -3
- package/dist/types/src/capabilities/url-handler/index.d.ts.map +0 -1
- package/dist/types/src/capabilities/url-handler/url-handler.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 -75
- 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 -108
- 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.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/Sidebar/SidebarButton.d.ts.map +0 -1
- package/dist/types/src/components/fragments.d.ts +0 -7
- package/dist/types/src/components/fragments.d.ts.map +0 -1
- package/dist/types/src/containers/Banner/Banner.d.ts +0 -2
- package/dist/types/src/containers/Banner/Banner.d.ts.map +0 -1
- package/dist/types/src/containers/Banner/index.d.ts +0 -3
- package/dist/types/src/containers/Banner/index.d.ts.map +0 -1
- package/dist/types/src/containers/DeckSettings/DeckSettings.d.ts +0 -8
- package/dist/types/src/containers/DeckSettings/DeckSettings.d.ts.map +0 -1
- package/dist/types/src/containers/DeckSettings/index.d.ts +0 -3
- package/dist/types/src/containers/DeckSettings/index.d.ts.map +0 -1
- package/dist/types/src/hooks/useHoistStatusbar.d.ts +0 -3
- package/dist/types/src/hooks/useHoistStatusbar.d.ts.map +0 -1
- package/dist/types/src/types/capabilities.d.ts +0 -190
- package/dist/types/src/types/capabilities.d.ts.map +0 -1
- package/dist/types/src/types/events.d.ts +0 -7
- package/dist/types/src/types/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/app-graph-builder/app-graph-builder.ts +0 -119
- package/src/capabilities/app-graph-builder/index.ts +0 -7
- package/src/capabilities/check-app-scheme/check-app-scheme.ts +0 -45
- package/src/capabilities/check-app-scheme/index.ts +0 -7
- package/src/capabilities/operation-resolver/index.ts +0 -10
- package/src/capabilities/operation-resolver/operation-resolver.ts +0 -558
- package/src/capabilities/react-root/index.ts +0 -7
- package/src/capabilities/react-root/react-root.tsx +0 -47
- package/src/capabilities/react-surface/index.ts +0 -7
- package/src/capabilities/settings/index.ts +0 -7
- package/src/capabilities/state/index.ts +0 -7
- package/src/capabilities/toolkit/index.ts +0 -7
- package/src/capabilities/toolkit/toolkit.ts +0 -64
- package/src/capabilities/tools/index.ts +0 -7
- package/src/capabilities/url-handler/index.ts +0 -7
- package/src/capabilities/url-handler/url-handler.ts +0 -98
- package/src/components/DeckLayout/ContentEmpty.tsx +0 -30
- package/src/components/DeckLayout/DeckLayout.stories.tsx +0 -53
- package/src/components/DeckLayout/DeckLayout.tsx +0 -34
- package/src/components/DeckLayout/DeckMain.tsx +0 -287
- package/src/components/DeckLayout/Popover.tsx +0 -142
- package/src/components/DeckLayout/Topbar.tsx +0 -11
- package/src/components/Plank/Plank.stories.tsx +0 -64
- package/src/components/Plank/Plank.tsx +0 -307
- package/src/components/Sidebar/ComplementarySidebar.tsx +0 -218
- package/src/components/Sidebar/Sidebar.tsx +0 -42
- package/src/components/fragments.ts +0 -19
- package/src/containers/Banner/Banner.tsx +0 -5
- package/src/containers/Banner/index.ts +0 -7
- package/src/containers/DeckSettings/DeckSettings.tsx +0 -113
- package/src/containers/DeckSettings/index.ts +0 -7
- package/src/hooks/useHoistStatusbar.ts +0 -24
- package/src/types/capabilities.ts +0 -33
- package/src/types/events.ts +0 -21
- package/src/util/overscroll.ts +0 -69
- /package/dist/lib/{browser/types/index.mjs.map → neutral/check-app-scheme-A7FZVNZO.mjs.map} +0 -0
- /package/dist/lib/{node-esm/types/index.mjs.map → neutral/chunk-J5LGTIGS.mjs.map} +0 -0
- /package/dist/types/src/capabilities/{app-graph-builder/app-graph-builder.d.ts → app-graph-builder.d.ts} +0 -0
- /package/dist/types/src/capabilities/{react-root/react-root.d.ts → react-root.d.ts} +0 -0
- /package/dist/types/src/capabilities/{react-surface/react-surface.d.ts → react-surface.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/index.d.ts +0 -0
- /package/src/{components/DeckLayout → containers/Deck}/StatusBar.tsx +0 -0
- /package/src/{components → containers}/Sidebar/index.ts +0 -0
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/containers/DeckSettings/DeckSettings.tsx", "../../../src/containers/DeckSettings/index.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Input, Select, useTranslation } from '@dxos/react-ui';\nimport { Settings } from '@dxos/react-ui-form';\n\nimport { meta } from '../../meta';\nimport {\n type DeckSettingsProps,\n type NewPlankPositioning,\n NewPlankPositions,\n OverScrollToProps,\n type Overscroll,\n} from '../../types';\n\nconst isSocket = !!(globalThis as any).__args;\n\nexport type DeckSettingsComponentProps = {\n settings: DeckSettingsProps;\n onSettingsChange: (fn: (current: DeckSettingsProps) => DeckSettingsProps) => void;\n};\n\nexport const DeckSettings = ({ settings, onSettingsChange }: DeckSettingsComponentProps) => {\n const { t } = useTranslation(meta.id);\n\n return (\n <Settings.Root>\n <Settings.Section title={t('settings title', { ns: meta.id })}>\n <Settings.Group>\n <Settings.ItemInput title={t('settings enable deck label')}>\n <Input.Switch\n checked={settings.enableDeck}\n onCheckedChange={(checked) => onSettingsChange((s) => ({ ...s, enableDeck: checked }))}\n />\n </Settings.ItemInput>\n <Settings.ItemInput title={t('settings encapsulated planks label')}>\n <Input.Switch\n checked={settings.encapsulatedPlanks ?? false}\n onCheckedChange={(checked) => onSettingsChange((s) => ({ ...s, encapsulatedPlanks: checked }))}\n />\n </Settings.ItemInput>\n <Settings.ItemInput title={t('select new plank positioning label')}>\n <Select.Root\n disabled={!settings.enableDeck}\n value={settings.newPlankPositioning ?? 'start'}\n onValueChange={(value) =>\n onSettingsChange((s) => ({ ...s, newPlankPositioning: value as NewPlankPositioning }))\n }\n >\n <Select.TriggerButton placeholder={t('select new plank positioning placeholder')} />\n <Select.Portal>\n <Select.Content>\n <Select.Viewport>\n {NewPlankPositions.map((position) => (\n <Select.Option key={position} value={position}>\n {t(`settings new plank position ${position} label`)}\n </Select.Option>\n ))}\n </Select.Viewport>\n <Select.Arrow />\n </Select.Content>\n </Select.Portal>\n </Select.Root>\n </Settings.ItemInput>\n <Settings.ItemInput title={t('settings overscroll label')}>\n <Select.Root\n disabled={!settings.enableDeck}\n value={settings.overscroll ?? 'none'}\n onValueChange={(value) => onSettingsChange((s) => ({ ...s, overscroll: value as Overscroll }))}\n >\n <Select.TriggerButton placeholder={t('select overscroll placeholder')} />\n <Select.Portal>\n <Select.Content>\n <Select.Viewport>\n {OverScrollToProps.map((option) => (\n <Select.Option key={option} value={option}>\n {t(`settings overscroll ${option} label`)}\n </Select.Option>\n ))}\n </Select.Viewport>\n <Select.Arrow />\n </Select.Content>\n </Select.Portal>\n </Select.Root>\n </Settings.ItemInput>\n <Settings.ItemInput title={t('settings enable statusbar label')}>\n <Input.Switch\n checked={settings.enableStatusbar}\n onCheckedChange={(checked) => onSettingsChange((s) => ({ ...s, enableStatusbar: checked }))}\n />\n </Settings.ItemInput>\n <Settings.ItemInput title={t('settings show hints label')}>\n <Input.Switch\n checked={settings.showHints}\n onCheckedChange={(checked) => onSettingsChange((s) => ({ ...s, showHints: checked }))}\n />\n </Settings.ItemInput>\n {!isSocket && (\n <Settings.ItemInput title={t('settings native redirect label')}>\n <Input.Switch\n checked={settings.enableNativeRedirect}\n onCheckedChange={(checked) => onSettingsChange((s) => ({ ...s, enableNativeRedirect: checked }))}\n />\n </Settings.ItemInput>\n )}\n </Settings.Group>\n </Settings.Section>\n </Settings.Root>\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { DeckSettings } from './DeckSettings';\n\nexport default DeckSettings;\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["React", "Input", "Select", "useTranslation", "Settings", "isSocket", "globalThis", "__args", "DeckSettings", "settings", "onSettingsChange", "t", "useTranslation", "meta", "id", "Settings", "Root", "Section", "title", "ns", "Group", "ItemInput", "Input", "Switch", "checked", "enableDeck", "onCheckedChange", "s", "encapsulatedPlanks", "Select", "disabled", "value", "newPlankPositioning", "onValueChange", "TriggerButton", "placeholder", "Portal", "Content", "Viewport", "NewPlankPositions", "map", "position", "Option", "key", "Arrow", "overscroll", "OverScrollToProps", "option", "enableStatusbar", "showHints", "enableNativeRedirect", "DeckSettings"]
|
|
7
|
-
}
|
|
@@ -1,124 +0,0 @@
|
|
|
1
|
-
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
|
-
import {
|
|
3
|
-
DeckCapabilities
|
|
4
|
-
} from "./chunk-GZJAQ5IP.mjs";
|
|
5
|
-
import {
|
|
6
|
-
meta
|
|
7
|
-
} from "./chunk-XCNF4COU.mjs";
|
|
8
|
-
|
|
9
|
-
// src/capabilities/app-graph-builder/app-graph-builder.ts
|
|
10
|
-
import * as Effect from "effect/Effect";
|
|
11
|
-
import { Capabilities, Capability } from "@dxos/app-framework";
|
|
12
|
-
import { AppCapabilities, LayoutOperation } from "@dxos/app-toolkit";
|
|
13
|
-
import { Operation } from "@dxos/operation";
|
|
14
|
-
import { AttentionCapabilities } from "@dxos/plugin-attention";
|
|
15
|
-
import { GraphBuilder, NodeMatcher } from "@dxos/plugin-graph";
|
|
16
|
-
var app_graph_builder_default = Capability.makeModule(Effect.fnUntraced(function* () {
|
|
17
|
-
const extensions = yield* GraphBuilder.createExtension({
|
|
18
|
-
id: meta.id,
|
|
19
|
-
match: NodeMatcher.whenRoot,
|
|
20
|
-
actions: (_node, get) => Effect.gen(function* () {
|
|
21
|
-
const closeCurrent = {
|
|
22
|
-
id: `${LayoutOperation.Close.meta.key}.current`,
|
|
23
|
-
data: Effect.fnUntraced(function* () {
|
|
24
|
-
const attention = yield* Capability.get(AttentionCapabilities.Attention);
|
|
25
|
-
const attended = attention.getCurrent().at(-1);
|
|
26
|
-
if (attended) {
|
|
27
|
-
yield* Operation.invoke(LayoutOperation.Close, {
|
|
28
|
-
subject: [
|
|
29
|
-
attended
|
|
30
|
-
]
|
|
31
|
-
});
|
|
32
|
-
}
|
|
33
|
-
}),
|
|
34
|
-
properties: {
|
|
35
|
-
label: [
|
|
36
|
-
"close current label",
|
|
37
|
-
{
|
|
38
|
-
ns: meta.id
|
|
39
|
-
}
|
|
40
|
-
],
|
|
41
|
-
icon: "ph--x--regular"
|
|
42
|
-
}
|
|
43
|
-
};
|
|
44
|
-
const closeOthers = {
|
|
45
|
-
id: `${LayoutOperation.Close.meta.key}.others`,
|
|
46
|
-
data: Effect.fnUntraced(function* () {
|
|
47
|
-
const attention = yield* Capability.get(AttentionCapabilities.Attention);
|
|
48
|
-
const deck2 = yield* DeckCapabilities.getDeck();
|
|
49
|
-
const attended = attention.getCurrent().at(-1);
|
|
50
|
-
const ids = deck2.active.filter((id) => id !== attended) ?? [];
|
|
51
|
-
yield* Operation.invoke(LayoutOperation.Close, {
|
|
52
|
-
subject: ids
|
|
53
|
-
});
|
|
54
|
-
}),
|
|
55
|
-
properties: {
|
|
56
|
-
label: [
|
|
57
|
-
"close others label",
|
|
58
|
-
{
|
|
59
|
-
ns: meta.id
|
|
60
|
-
}
|
|
61
|
-
],
|
|
62
|
-
icon: "ph--x-square--regular"
|
|
63
|
-
}
|
|
64
|
-
};
|
|
65
|
-
const closeAll = {
|
|
66
|
-
id: `${LayoutOperation.Close.meta.key}.all`,
|
|
67
|
-
data: Effect.fnUntraced(function* () {
|
|
68
|
-
const deck2 = yield* DeckCapabilities.getDeck();
|
|
69
|
-
yield* Operation.invoke(LayoutOperation.Close, {
|
|
70
|
-
subject: deck2.active
|
|
71
|
-
});
|
|
72
|
-
}),
|
|
73
|
-
properties: {
|
|
74
|
-
label: [
|
|
75
|
-
"close all label",
|
|
76
|
-
{
|
|
77
|
-
ns: meta.id
|
|
78
|
-
}
|
|
79
|
-
],
|
|
80
|
-
icon: "ph--x-circle--regular"
|
|
81
|
-
}
|
|
82
|
-
};
|
|
83
|
-
const state = get(yield* Capability.get(DeckCapabilities.State));
|
|
84
|
-
const deck = state.decks[state.activeDeck];
|
|
85
|
-
const toggleSidebar = {
|
|
86
|
-
id: `${LayoutOperation.UpdateSidebar.meta.key}.nav`,
|
|
87
|
-
data: Effect.fnUntraced(function* () {
|
|
88
|
-
yield* Capabilities.updateAtomValue(DeckCapabilities.State, (s) => ({
|
|
89
|
-
...s,
|
|
90
|
-
sidebarState: s.sidebarState === "expanded" ? "collapsed" : "expanded"
|
|
91
|
-
}));
|
|
92
|
-
}),
|
|
93
|
-
properties: {
|
|
94
|
-
label: [
|
|
95
|
-
state.sidebarState === "expanded" ? "collapse navigation sidebar label" : "open navigation sidebar label",
|
|
96
|
-
{
|
|
97
|
-
ns: meta.id
|
|
98
|
-
}
|
|
99
|
-
],
|
|
100
|
-
icon: "ph--sidebar--regular",
|
|
101
|
-
keyBinding: {
|
|
102
|
-
macos: "meta+'"
|
|
103
|
-
},
|
|
104
|
-
disposition: "pin-end",
|
|
105
|
-
position: "hoist",
|
|
106
|
-
l0Breakpoint: "lg"
|
|
107
|
-
}
|
|
108
|
-
};
|
|
109
|
-
return !deck?.solo ? [
|
|
110
|
-
closeCurrent,
|
|
111
|
-
closeOthers,
|
|
112
|
-
closeAll,
|
|
113
|
-
toggleSidebar
|
|
114
|
-
] : [
|
|
115
|
-
toggleSidebar
|
|
116
|
-
];
|
|
117
|
-
})
|
|
118
|
-
});
|
|
119
|
-
return Capability.contributes(AppCapabilities.AppGraphBuilder, extensions);
|
|
120
|
-
}));
|
|
121
|
-
export {
|
|
122
|
-
app_graph_builder_default as default
|
|
123
|
-
};
|
|
124
|
-
//# sourceMappingURL=app-graph-builder-ACHG5HY7.mjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/capabilities/app-graph-builder/app-graph-builder.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\n\nimport { Capabilities, Capability } from '@dxos/app-framework';\nimport { AppCapabilities, LayoutOperation } from '@dxos/app-toolkit';\nimport { Operation } from '@dxos/operation';\nimport { AttentionCapabilities } from '@dxos/plugin-attention';\nimport { GraphBuilder, NodeMatcher } from '@dxos/plugin-graph';\n\nimport { meta } from '../../meta';\nimport { DeckCapabilities } from '../../types';\n\nexport default Capability.makeModule(\n Effect.fnUntraced(function* () {\n const extensions = yield* GraphBuilder.createExtension({\n id: meta.id,\n match: NodeMatcher.whenRoot,\n actions: (_node, get) =>\n Effect.gen(function* () {\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.get(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: `${LayoutOperation.Close.meta.key}.current`,\n data: Effect.fnUntraced(function* () {\n const attention = yield* Capability.get(AttentionCapabilities.Attention);\n const attended = attention.getCurrent().at(-1);\n if (attended) {\n yield* Operation.invoke(LayoutOperation.Close, { subject: [attended] });\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: `${LayoutOperation.Close.meta.key}.others`,\n data: Effect.fnUntraced(function* () {\n const attention = yield* Capability.get(AttentionCapabilities.Attention);\n const deck = yield* DeckCapabilities.getDeck();\n const attended = attention.getCurrent().at(-1);\n const ids = deck.active.filter((id: string) => id !== attended) ?? [];\n yield* Operation.invoke(LayoutOperation.Close, { subject: ids });\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: `${LayoutOperation.Close.meta.key}.all`,\n data: Effect.fnUntraced(function* () {\n const deck = yield* DeckCapabilities.getDeck();\n yield* Operation.invoke(LayoutOperation.Close, { subject: deck.active });\n }),\n properties: {\n label: ['close all label', { ns: meta.id }],\n icon: 'ph--x-circle--regular',\n },\n };\n\n const state = get(yield* Capability.get(DeckCapabilities.State));\n const deck = state.decks[state.activeDeck];\n\n const toggleSidebar = {\n id: `${LayoutOperation.UpdateSidebar.meta.key}.nav`,\n data: Effect.fnUntraced(function* () {\n yield* Capabilities.updateAtomValue(DeckCapabilities.State, (s) => ({\n ...s,\n sidebarState: s.sidebarState === 'expanded' ? ('collapsed' as const) : ('expanded' as const),\n }));\n }),\n properties: {\n label: [\n state.sidebarState === 'expanded'\n ? 'collapse navigation sidebar label'\n : 'open navigation sidebar label',\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 !deck?.solo ? [closeCurrent, closeOthers, closeAll, toggleSidebar] : [toggleSidebar];\n }),\n });\n\n return Capability.contributes(AppCapabilities.AppGraphBuilder, extensions);\n }),\n);\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["Effect", "Capabilities", "Capability", "AppCapabilities", "LayoutOperation", "Operation", "AttentionCapabilities", "GraphBuilder", "NodeMatcher", "Capability", "makeModule", "fnUntraced", "extensions", "GraphBuilder", "createExtension", "id", "meta", "match", "NodeMatcher", "whenRoot", "actions", "_node", "get", "gen", "closeCurrent", "LayoutOperation", "Close", "key", "data", "attention", "AttentionCapabilities", "Attention", "attended", "getCurrent", "at", "Operation", "invoke", "subject", "properties", "label", "ns", "icon", "closeOthers", "deck", "DeckCapabilities", "getDeck", "ids", "active", "filter", "closeAll", "state", "State", "decks", "activeDeck", "toggleSidebar", "UpdateSidebar", "Capabilities", "updateAtomValue", "s", "sidebarState", "keyBinding", "macos", "disposition", "position", "l0Breakpoint", "solo", "contributes", "AppCapabilities", "AppGraphBuilder"]
|
|
7
|
-
}
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
|
-
import {
|
|
3
|
-
DeckCapabilities
|
|
4
|
-
} from "./chunk-GZJAQ5IP.mjs";
|
|
5
|
-
import "./chunk-XCNF4COU.mjs";
|
|
6
|
-
|
|
7
|
-
// src/capabilities/check-app-scheme/check-app-scheme.ts
|
|
8
|
-
import * as Effect from "effect/Effect";
|
|
9
|
-
import { Capabilities, Capability } from "@dxos/app-framework";
|
|
10
|
-
import { isTauri } from "@dxos/util";
|
|
11
|
-
var APP_SCHEME = "composer://";
|
|
12
|
-
var checkAppScheme = (url) => {
|
|
13
|
-
const iframe = document.createElement("iframe");
|
|
14
|
-
iframe.style.display = "none";
|
|
15
|
-
document.body.appendChild(iframe);
|
|
16
|
-
iframe.src = url + window.location.pathname.replace(/^\/+/, "") + window.location.search;
|
|
17
|
-
const timer = setTimeout(() => {
|
|
18
|
-
document.body.removeChild(iframe);
|
|
19
|
-
}, 3e3);
|
|
20
|
-
window.addEventListener("pagehide", (event) => {
|
|
21
|
-
clearTimeout(timer);
|
|
22
|
-
document.body.removeChild(iframe);
|
|
23
|
-
});
|
|
24
|
-
};
|
|
25
|
-
var check_app_scheme_default = Capability.makeModule(Effect.fnUntraced(function* () {
|
|
26
|
-
const settings = yield* Capabilities.getAtomValue(DeckCapabilities.Settings);
|
|
27
|
-
if (!isTauri() && settings?.enableNativeRedirect) {
|
|
28
|
-
checkAppScheme(APP_SCHEME);
|
|
29
|
-
}
|
|
30
|
-
}));
|
|
31
|
-
export {
|
|
32
|
-
check_app_scheme_default as default
|
|
33
|
-
};
|
|
34
|
-
//# sourceMappingURL=check-app-scheme-WN76GWVC.mjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/capabilities/check-app-scheme/check-app-scheme.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\n\nimport { Capabilities, Capability } from '@dxos/app-framework';\nimport { isTauri } from '@dxos/util';\n\nimport { DeckCapabilities } from '../../types';\n\nconst APP_SCHEME = 'composer://';\n\n/**\n * Attempts to redirect from the web app to the native desktop app using a custom URL scheme.\n * Creates a hidden iframe that navigates to the custom scheme URL (e.g., composer://workspace/123).\n * If the native app is installed and handles the scheme, the user will be redirected.\n * The iframe is automatically removed after 3 seconds or when the page is hidden.\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 Capability.makeModule(\n Effect.fnUntraced(function* () {\n const settings = yield* Capabilities.getAtomValue(DeckCapabilities.Settings);\n if (!isTauri() && settings?.enableNativeRedirect) {\n checkAppScheme(APP_SCHEME);\n }\n }),\n);\n"],
|
|
5
|
-
"mappings": ";;;;;;;AAIA,YAAYA,YAAY;AAExB,SAASC,cAAcC,kBAAkB;AACzC,SAASC,eAAe;AAIxB,IAAMC,aAAa;AASnB,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,2BAAemB,WAAWC,WACjBC,kBAAW,aAAA;AAChB,QAAMC,WAAW,OAAOC,aAAaC,aAAaC,iBAAiBC,QAAQ;AAC3E,MAAI,CAACC,QAAAA,KAAaL,UAAUM,sBAAsB;AAChD9B,mBAAeD,UAAAA;EACjB;AACF,CAAA,CAAA;",
|
|
6
|
-
"names": ["Effect", "Capabilities", "Capability", "isTauri", "APP_SCHEME", "checkAppScheme", "url", "iframe", "document", "createElement", "style", "display", "body", "appendChild", "src", "window", "location", "pathname", "replace", "search", "timer", "setTimeout", "removeChild", "addEventListener", "event", "clearTimeout", "Capability", "makeModule", "fnUntraced", "settings", "Capabilities", "getAtomValue", "DeckCapabilities", "Settings", "isTauri", "enableNativeRedirect"]
|
|
7
|
-
}
|
|
@@ -1,76 +0,0 @@
|
|
|
1
|
-
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
|
-
|
|
3
|
-
// src/util/set-active.ts
|
|
4
|
-
var computeActiveUpdates = ({ next, deck, attention }) => {
|
|
5
|
-
const active = deck.solo ? [
|
|
6
|
-
deck.solo
|
|
7
|
-
] : deck.active;
|
|
8
|
-
const removed = active.filter((id) => !next.includes(id));
|
|
9
|
-
const closed = Array.from(/* @__PURE__ */ new Set([
|
|
10
|
-
...deck.inactive.filter((id) => !next.includes(id)),
|
|
11
|
-
...removed
|
|
12
|
-
]));
|
|
13
|
-
const updates = {
|
|
14
|
-
inactive: closed,
|
|
15
|
-
solo: deck.solo,
|
|
16
|
-
active: deck.active,
|
|
17
|
-
fullscreen: deck.fullscreen
|
|
18
|
-
};
|
|
19
|
-
if (deck.solo || !deck.initialized) {
|
|
20
|
-
updates.solo = next[0];
|
|
21
|
-
} else {
|
|
22
|
-
updates.active = next;
|
|
23
|
-
}
|
|
24
|
-
if (deck.fullscreen && !updates.solo) {
|
|
25
|
-
updates.fullscreen = false;
|
|
26
|
-
}
|
|
27
|
-
let toAttend;
|
|
28
|
-
if (attention) {
|
|
29
|
-
const attended = attention.getCurrent();
|
|
30
|
-
const [attendedId] = Array.from(attended);
|
|
31
|
-
const isAttendedAvailable = !!attendedId && next.includes(attendedId);
|
|
32
|
-
if (!isAttendedAvailable) {
|
|
33
|
-
const attendedIndex = active.indexOf(attendedId);
|
|
34
|
-
const index = attendedIndex === -1 ? 0 : attendedIndex >= next.length ? next.length - 1 : attendedIndex;
|
|
35
|
-
toAttend = next[index];
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
return {
|
|
39
|
-
deckUpdates: updates,
|
|
40
|
-
toAttend
|
|
41
|
-
};
|
|
42
|
-
};
|
|
43
|
-
|
|
44
|
-
// src/util/layoutAppliesTopbar.ts
|
|
45
|
-
var layoutAppliesTopbar = (breakpoint, layoutMode) => {
|
|
46
|
-
return document.body.getAttribute("data-platform") === "windows" && breakpoint === "desktop" && layoutMode !== "solo--fullscreen";
|
|
47
|
-
};
|
|
48
|
-
|
|
49
|
-
// src/util/overscroll.ts
|
|
50
|
-
var calculateOverscroll = (planksCount) => {
|
|
51
|
-
if (!planksCount) {
|
|
52
|
-
return {
|
|
53
|
-
paddingInlineStart: 0,
|
|
54
|
-
paddingInlineEnd: 0
|
|
55
|
-
};
|
|
56
|
-
}
|
|
57
|
-
if (planksCount === 1) {
|
|
58
|
-
const overscrollPadding = "max(0px, calc(((100dvw - var(--dx-main-sidebar-width) - var(--dx-main-complementary-width) - (var(--dx-main-content-first-width) + 1px)) / 2)))";
|
|
59
|
-
return {
|
|
60
|
-
paddingInlineStart: overscrollPadding,
|
|
61
|
-
paddingInlineEnd: overscrollPadding
|
|
62
|
-
};
|
|
63
|
-
} else {
|
|
64
|
-
return {
|
|
65
|
-
paddingInlineStart: "max(0px, calc(((100dvw - (var(--dx-main-content-first-width) + 1px)) / 2) - var(--dx-main-sidebar-width)))",
|
|
66
|
-
paddingInlineEnd: "max(0px, calc(((100dvw - (var(--dx-main-content-last-width) + 1px)) / 2) - var(--dx-main-complementary-width)))"
|
|
67
|
-
};
|
|
68
|
-
}
|
|
69
|
-
};
|
|
70
|
-
|
|
71
|
-
export {
|
|
72
|
-
layoutAppliesTopbar,
|
|
73
|
-
calculateOverscroll,
|
|
74
|
-
computeActiveUpdates
|
|
75
|
-
};
|
|
76
|
-
//# sourceMappingURL=chunk-DGTRKKWZ.mjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/util/set-active.ts", "../../../src/util/layoutAppliesTopbar.ts", "../../../src/util/overscroll.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { type AttentionManager } from '@dxos/plugin-attention';\n\nimport { type DeckState } from '../types';\n\nexport type SetActiveOptions = {\n next: string[];\n deck: DeckState;\n attention?: AttentionManager;\n};\n\nexport type SetActiveResult = {\n /** Updates to apply to the deck. */\n deckUpdates: {\n inactive: string[];\n solo: string | undefined;\n active: string[];\n fullscreen: boolean;\n };\n /** ID of the item to attend (scroll into view) if attention changed. */\n toAttend?: string;\n};\n\n/**\n * Computes the new active state for the deck without mutating.\n * Returns the updates to apply and optionally an item to attend.\n */\nexport const computeActiveUpdates = ({ next, deck, attention }: SetActiveOptions): SetActiveResult => {\n const active = deck.solo ? [deck.solo] : deck.active;\n const removed = active.filter((id) => !next.includes(id));\n const closed = Array.from(new Set([...deck.inactive.filter((id) => !next.includes(id)), ...removed]));\n\n const updates = {\n inactive: closed,\n solo: deck.solo,\n active: deck.active,\n fullscreen: deck.fullscreen,\n };\n\n if (deck.solo || !deck.initialized) {\n updates.solo = next[0];\n } else {\n updates.active = next;\n }\n\n if (deck.fullscreen && !updates.solo) {\n updates.fullscreen = false;\n }\n\n let toAttend: string | undefined;\n if (attention) {\n const attended = attention.getCurrent();\n const [attendedId] = Array.from(attended);\n const isAttendedAvailable = !!attendedId && next.includes(attendedId);\n if (!isAttendedAvailable) {\n const attendedIndex = active.indexOf(attendedId);\n // If outside of bounds, focus on the first/last plank, otherwise focus on the new plank in the same position.\n const index = attendedIndex === -1 ? 0 : attendedIndex >= next.length ? next.length - 1 : attendedIndex;\n toAttend = next[index];\n }\n }\n\n return { deckUpdates: updates, toAttend };\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type LayoutMode } from '../types';\n\nexport const layoutAppliesTopbar = (breakpoint: string, layoutMode?: LayoutMode) => {\n return (\n document.body.getAttribute('data-platform') === 'windows' &&\n breakpoint === 'desktop' &&\n layoutMode !== 'solo--fullscreen'\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport type { CSSProperties } from 'react';\n\n/**\n * ┌────────────────────────────────────────────────────────────────────────────────────────────────────┐\n * | Overscroll Padding Calculation for Centering Planks on Screen. │\n * ├────────────────────────────────────────────────────────────────────────────────────────────────────┤\n * │ NOTE(Zan): I found the way you calculate the overscroll padding to center a plank on the screen │\n * │ at the edges of the scroll context a bit confusing, so I've diagrammed it here. │\n * │ │\n * │ Multiple Planks: │\n * │ ─────────────── │\n * | Use the following overscroll padding calculation centering the boundary planks on the SCREEN. │\n * │ │\n * │ Left Padding: Right Padding: │\n * │ ┌───┬────┬──────────────────┬──────┐ ┌──────┬──────────────────┬────┬───┐ │\n * │ │ │████│ Ideal │ │ │ │ Ideal │████│ │ │\n * │ │ S │█PL█│ first │ │ │ │ last │█PR█│ C │ │\n * │ │ │████│ plank │ │ │ │ plank │████│ │ │\n * │ └───┴────┴──────────────────┴──────┘ └──────┴──────────────────┴────┴───┘ │\n * │ <--------- screen width -----------> <---------- screen width ----------> │\n * │ │\n * │ PL = ((screen width - Plank Width) / 2) - S │\n * │ PR = ((screen width - Plank Width) / 2) - C │\n * │ │\n * │ S = Sidebar width C = Complementary sidebar width │\n * │ PL = Padding Left PR = Padding Right │\n * │ │\n * │ Single Plank: │\n * │ ───────────── │\n * │ For a single plank we use the following overscroll padding calculation to center the plank in │\n * │ the content area: │\n * │ │\n * │ ┌───┬───────────────────────┬───┬───────────────────────┬───┐ │\n * │ │ │███████████████████████│ │███████████████████████│ │ │\n * │ │ S │█████ Left Padding ████│ P │████ Right Padding ████│ C │ │\n * │ │ │███████████████████████│ │███████████████████████│ │ │\n * │ └───┴───────────────────────┴───┴───────────────────────┴───┘ │\n * │ <------------------------ screen width ---------------------> │\n * │ │\n * │ Left/Right Padding Width = (screen width - S - P - C) / 2 │\n * │ │\n * │ S = Sidebar width (may be 0) │\n * │ P = Plank width (centered) │\n * │ C = Complementary sidebar width (may be 0) │\n * └────────────────────────────────────────────────────────────────────────────────────────────────────┘\n */\nexport const calculateOverscroll = (\n planksCount: number,\n): Pick<CSSProperties, 'paddingInlineStart' | 'paddingInlineEnd'> | undefined => {\n if (!planksCount) {\n return { paddingInlineStart: 0, paddingInlineEnd: 0 };\n }\n if (planksCount === 1) {\n const overscrollPadding =\n 'max(0px, calc(((100dvw - var(--dx-main-sidebar-width) - var(--dx-main-complementary-width) - (var(--dx-main-content-first-width) + 1px)) / 2)))';\n return { paddingInlineStart: overscrollPadding, paddingInlineEnd: overscrollPadding };\n } else {\n return {\n paddingInlineStart:\n 'max(0px, calc(((100dvw - (var(--dx-main-content-first-width) + 1px)) / 2) - var(--dx-main-sidebar-width)))',\n paddingInlineEnd:\n 'max(0px, calc(((100dvw - (var(--dx-main-content-last-width) + 1px)) / 2) - var(--dx-main-complementary-width)))',\n };\n }\n};\n"],
|
|
5
|
-
"mappings": ";;;AA8BO,IAAMA,uBAAuB,CAAC,EAAEC,MAAMC,MAAMC,UAAS,MAAoB;AAC9E,QAAMC,SAASF,KAAKG,OAAO;IAACH,KAAKG;MAAQH,KAAKE;AAC9C,QAAME,UAAUF,OAAOG,OAAO,CAACC,OAAO,CAACP,KAAKQ,SAASD,EAAAA,CAAAA;AACrD,QAAME,SAASC,MAAMC,KAAK,oBAAIC,IAAI;OAAIX,KAAKY,SAASP,OAAO,CAACC,OAAO,CAACP,KAAKQ,SAASD,EAAAA,CAAAA;OAASF;GAAQ,CAAA;AAEnG,QAAMS,UAAU;IACdD,UAAUJ;IACVL,MAAMH,KAAKG;IACXD,QAAQF,KAAKE;IACbY,YAAYd,KAAKc;EACnB;AAEA,MAAId,KAAKG,QAAQ,CAACH,KAAKe,aAAa;AAClCF,YAAQV,OAAOJ,KAAK,CAAA;EACtB,OAAO;AACLc,YAAQX,SAASH;EACnB;AAEA,MAAIC,KAAKc,cAAc,CAACD,QAAQV,MAAM;AACpCU,YAAQC,aAAa;EACvB;AAEA,MAAIE;AACJ,MAAIf,WAAW;AACb,UAAMgB,WAAWhB,UAAUiB,WAAU;AACrC,UAAM,CAACC,UAAAA,IAAcV,MAAMC,KAAKO,QAAAA;AAChC,UAAMG,sBAAsB,CAAC,CAACD,cAAcpB,KAAKQ,SAASY,UAAAA;AAC1D,QAAI,CAACC,qBAAqB;AACxB,YAAMC,gBAAgBnB,OAAOoB,QAAQH,UAAAA;AAErC,YAAMI,QAAQF,kBAAkB,KAAK,IAAIA,iBAAiBtB,KAAKyB,SAASzB,KAAKyB,SAAS,IAAIH;AAC1FL,iBAAWjB,KAAKwB,KAAAA;IAClB;EACF;AAEA,SAAO;IAAEE,aAAaZ;IAASG;EAAS;AAC1C;;;AC5DO,IAAMU,sBAAsB,CAACC,YAAoBC,eAAAA;AACtD,SACEC,SAASC,KAAKC,aAAa,eAAA,MAAqB,aAChDJ,eAAe,aACfC,eAAe;AAEnB;;;ACsCO,IAAMI,sBAAsB,CACjCC,gBAAAA;AAEA,MAAI,CAACA,aAAa;AAChB,WAAO;MAAEC,oBAAoB;MAAGC,kBAAkB;IAAE;EACtD;AACA,MAAIF,gBAAgB,GAAG;AACrB,UAAMG,oBACJ;AACF,WAAO;MAAEF,oBAAoBE;MAAmBD,kBAAkBC;IAAkB;EACtF,OAAO;AACL,WAAO;MACLF,oBACE;MACFC,kBACE;IACJ;EACF;AACF;",
|
|
6
|
-
"names": ["computeActiveUpdates", "next", "deck", "attention", "active", "solo", "removed", "filter", "id", "includes", "closed", "Array", "from", "Set", "inactive", "updates", "fullscreen", "initialized", "toAttend", "attended", "getCurrent", "attendedId", "isAttendedAvailable", "attendedIndex", "indexOf", "index", "length", "deckUpdates", "layoutAppliesTopbar", "breakpoint", "layoutMode", "document", "body", "getAttribute", "calculateOverscroll", "planksCount", "paddingInlineStart", "paddingInlineEnd", "overscrollPadding"]
|
|
7
|
-
}
|
|
@@ -1,188 +0,0 @@
|
|
|
1
|
-
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
|
-
import {
|
|
3
|
-
DECK_COMPANION_TYPE,
|
|
4
|
-
DeckCapabilities,
|
|
5
|
-
PLANK_COMPANION_TYPE
|
|
6
|
-
} from "./chunk-GZJAQ5IP.mjs";
|
|
7
|
-
|
|
8
|
-
// src/hooks/useCompanions.ts
|
|
9
|
-
import { useMemo } from "react";
|
|
10
|
-
import { useAppGraph } from "@dxos/app-toolkit/ui";
|
|
11
|
-
import { useConnections } from "@dxos/plugin-graph";
|
|
12
|
-
import { byPosition } from "@dxos/util";
|
|
13
|
-
var useCompanions = (id) => {
|
|
14
|
-
const { graph } = useAppGraph();
|
|
15
|
-
const nodes = useConnections(graph, id, "child");
|
|
16
|
-
const companions = nodes.filter((node) => node.type === PLANK_COMPANION_TYPE);
|
|
17
|
-
return useMemo(() => companions.toSorted((a, b) => byPosition(a.properties, b.properties)), [
|
|
18
|
-
companions
|
|
19
|
-
]);
|
|
20
|
-
};
|
|
21
|
-
|
|
22
|
-
// src/hooks/useDeckState.ts
|
|
23
|
-
import { useAtomValue } from "@effect-atom/atom-react";
|
|
24
|
-
import { useCallback, useMemo as useMemo2 } from "react";
|
|
25
|
-
import { Capabilities } from "@dxos/app-framework";
|
|
26
|
-
import { useCapability } from "@dxos/app-framework/ui";
|
|
27
|
-
import { invariant } from "@dxos/invariant";
|
|
28
|
-
var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-deck/src/hooks/useDeckState.ts";
|
|
29
|
-
var useDeckState = () => {
|
|
30
|
-
const registry = useCapability(Capabilities.AtomRegistry);
|
|
31
|
-
const stateAtom = useCapability(DeckCapabilities.State);
|
|
32
|
-
const ephemeralAtom = useCapability(DeckCapabilities.EphemeralState);
|
|
33
|
-
const persistedState = useAtomValue(stateAtom);
|
|
34
|
-
const ephemeralState = useAtomValue(ephemeralAtom);
|
|
35
|
-
const deck = useMemo2(() => {
|
|
36
|
-
const d = persistedState.decks[persistedState.activeDeck];
|
|
37
|
-
invariant(d, `Deck not found: ${persistedState.activeDeck}`, {
|
|
38
|
-
F: __dxlog_file,
|
|
39
|
-
L: 46,
|
|
40
|
-
S: void 0,
|
|
41
|
-
A: [
|
|
42
|
-
"d",
|
|
43
|
-
"`Deck not found: ${persistedState.activeDeck}`"
|
|
44
|
-
]
|
|
45
|
-
});
|
|
46
|
-
return d;
|
|
47
|
-
}, [
|
|
48
|
-
persistedState.decks,
|
|
49
|
-
persistedState.activeDeck
|
|
50
|
-
]);
|
|
51
|
-
const state = useMemo2(() => ({
|
|
52
|
-
...persistedState,
|
|
53
|
-
...ephemeralState
|
|
54
|
-
}), [
|
|
55
|
-
persistedState,
|
|
56
|
-
ephemeralState
|
|
57
|
-
]);
|
|
58
|
-
const updateState = useCallback((fn) => {
|
|
59
|
-
registry.set(stateAtom, fn(registry.get(stateAtom)));
|
|
60
|
-
}, [
|
|
61
|
-
registry,
|
|
62
|
-
stateAtom
|
|
63
|
-
]);
|
|
64
|
-
const updateEphemeral = useCallback((fn) => {
|
|
65
|
-
registry.set(ephemeralAtom, fn(registry.get(ephemeralAtom)));
|
|
66
|
-
}, [
|
|
67
|
-
registry,
|
|
68
|
-
ephemeralAtom
|
|
69
|
-
]);
|
|
70
|
-
return useMemo2(() => ({
|
|
71
|
-
state,
|
|
72
|
-
deck,
|
|
73
|
-
updateState,
|
|
74
|
-
updateEphemeral
|
|
75
|
-
}), [
|
|
76
|
-
state,
|
|
77
|
-
deck,
|
|
78
|
-
updateState,
|
|
79
|
-
updateEphemeral
|
|
80
|
-
]);
|
|
81
|
-
};
|
|
82
|
-
|
|
83
|
-
// src/hooks/useBreakpoints.ts
|
|
84
|
-
import { useMediaQuery } from "@dxos/react-ui";
|
|
85
|
-
var useBreakpoints = () => {
|
|
86
|
-
const [isNotMobile] = useMediaQuery("md");
|
|
87
|
-
const [isDesktop] = useMediaQuery("lg");
|
|
88
|
-
return isDesktop ? "desktop" : isNotMobile ? "tablet" : "mobile";
|
|
89
|
-
};
|
|
90
|
-
|
|
91
|
-
// src/hooks/useDeckCompanions.ts
|
|
92
|
-
import { useAppGraph as useAppGraph2 } from "@dxos/app-toolkit/ui";
|
|
93
|
-
import { Node } from "@dxos/plugin-graph";
|
|
94
|
-
import { useConnections as useConnections2 } from "@dxos/plugin-graph";
|
|
95
|
-
import { byPosition as byPosition2 } from "@dxos/util";
|
|
96
|
-
var useDeckCompanions = () => {
|
|
97
|
-
const { graph } = useAppGraph2();
|
|
98
|
-
const connections = useConnections2(graph, Node.RootId, "child");
|
|
99
|
-
const companions = connections.filter((node) => node.type === DECK_COMPANION_TYPE);
|
|
100
|
-
return companions.toSorted((a, b) => byPosition2(a.properties, b.properties));
|
|
101
|
-
};
|
|
102
|
-
|
|
103
|
-
// src/hooks/useHoistStatusbar.ts
|
|
104
|
-
import { useMemo as useMemo3 } from "react";
|
|
105
|
-
import { useAtomCapability } from "@dxos/app-framework/ui";
|
|
106
|
-
import { useThemeContext } from "@dxos/react-ui";
|
|
107
|
-
var useHoistStatusbar = (breakpoint, layoutMode) => {
|
|
108
|
-
const { safeAreaPadding } = useThemeContext();
|
|
109
|
-
const enableStatusbar = useAtomCapability(DeckCapabilities.Settings).enableStatusbar;
|
|
110
|
-
return useMemo3(() => {
|
|
111
|
-
return breakpoint === "desktop" && layoutMode !== "solo--fullscreen" && !!enableStatusbar && safeAreaPadding?.bottom === 0;
|
|
112
|
-
}, [
|
|
113
|
-
enableStatusbar,
|
|
114
|
-
breakpoint,
|
|
115
|
-
safeAreaPadding?.bottom,
|
|
116
|
-
layoutMode
|
|
117
|
-
]);
|
|
118
|
-
};
|
|
119
|
-
|
|
120
|
-
// src/hooks/useMainSize.ts
|
|
121
|
-
import { useMainContext } from "@dxos/react-ui";
|
|
122
|
-
var useMainSize = () => {
|
|
123
|
-
const { navigationSidebarState, complementarySidebarState } = useMainContext("DeckPluginPlank");
|
|
124
|
-
return {
|
|
125
|
-
"data-sidebar-left-state": navigationSidebarState,
|
|
126
|
-
"data-sidebar-right-state": complementarySidebarState
|
|
127
|
-
};
|
|
128
|
-
};
|
|
129
|
-
|
|
130
|
-
// src/hooks/useNodeActionExpander.ts
|
|
131
|
-
import { useEffect } from "react";
|
|
132
|
-
import { Graph } from "@dxos/plugin-graph";
|
|
133
|
-
var useNodeActionExpander = (node) => {
|
|
134
|
-
useEffect(() => {
|
|
135
|
-
if (node) {
|
|
136
|
-
const frame = requestAnimationFrame(() => {
|
|
137
|
-
const graph = Graph.getGraph(node);
|
|
138
|
-
void Graph.expand(graph, node.id, "action");
|
|
139
|
-
});
|
|
140
|
-
return () => cancelAnimationFrame(frame);
|
|
141
|
-
}
|
|
142
|
-
}, [
|
|
143
|
-
node
|
|
144
|
-
]);
|
|
145
|
-
};
|
|
146
|
-
|
|
147
|
-
// src/hooks/useSelectedCompanion.ts
|
|
148
|
-
import { useMemo as useMemo4 } from "react";
|
|
149
|
-
import { getCompanionVariant } from "@dxos/app-toolkit";
|
|
150
|
-
var useSelectedCompanion = (companions, preferredVariant) => {
|
|
151
|
-
return useMemo4(() => {
|
|
152
|
-
if (companions.length === 0) {
|
|
153
|
-
return {
|
|
154
|
-
companionId: void 0,
|
|
155
|
-
variant: void 0
|
|
156
|
-
};
|
|
157
|
-
}
|
|
158
|
-
if (preferredVariant) {
|
|
159
|
-
const preferred = companions.find((companion) => getCompanionVariant(companion.id) === preferredVariant);
|
|
160
|
-
if (preferred) {
|
|
161
|
-
return {
|
|
162
|
-
companionId: preferred.id,
|
|
163
|
-
variant: getCompanionVariant(preferred.id)
|
|
164
|
-
};
|
|
165
|
-
}
|
|
166
|
-
}
|
|
167
|
-
const first = companions[0];
|
|
168
|
-
return {
|
|
169
|
-
companionId: first.id,
|
|
170
|
-
variant: getCompanionVariant(first.id)
|
|
171
|
-
};
|
|
172
|
-
}, [
|
|
173
|
-
companions,
|
|
174
|
-
preferredVariant
|
|
175
|
-
]);
|
|
176
|
-
};
|
|
177
|
-
|
|
178
|
-
export {
|
|
179
|
-
useBreakpoints,
|
|
180
|
-
useCompanions,
|
|
181
|
-
useDeckCompanions,
|
|
182
|
-
useDeckState,
|
|
183
|
-
useHoistStatusbar,
|
|
184
|
-
useMainSize,
|
|
185
|
-
useNodeActionExpander,
|
|
186
|
-
useSelectedCompanion
|
|
187
|
-
};
|
|
188
|
-
//# sourceMappingURL=chunk-EMU4VIPH.mjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/hooks/useCompanions.ts", "../../../src/hooks/useDeckState.ts", "../../../src/hooks/useBreakpoints.ts", "../../../src/hooks/useDeckCompanions.ts", "../../../src/hooks/useHoistStatusbar.ts", "../../../src/hooks/useMainSize.ts", "../../../src/hooks/useNodeActionExpander.ts", "../../../src/hooks/useSelectedCompanion.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { useMemo } from 'react';\n\nimport { useAppGraph } from '@dxos/app-toolkit/ui';\nimport { useConnections } from '@dxos/plugin-graph';\nimport { byPosition } from '@dxos/util';\n\nimport { PLANK_COMPANION_TYPE } from '../types';\n\nexport const useCompanions = (id?: string) => {\n const { graph } = useAppGraph();\n const nodes = useConnections(graph, id, 'child');\n const companions = nodes.filter((node) => node.type === PLANK_COMPANION_TYPE);\n return useMemo(() => companions.toSorted((a, b) => byPosition(a.properties, b.properties)), [companions]);\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { useAtomValue } from '@effect-atom/atom-react';\nimport { useCallback, useMemo } from 'react';\n\nimport { Capabilities } from '@dxos/app-framework';\nimport { useCapability } from '@dxos/app-framework/ui';\nimport { invariant } from '@dxos/invariant';\n\nimport {\n DeckCapabilities,\n type DeckEphemeralStateProps,\n type DeckPluginState,\n type DeckState,\n type DeckStateProps,\n} from '../types';\n\nexport type DeckStateHook = {\n /** Combined state value (reactive). Includes both persisted and ephemeral state. */\n state: DeckPluginState;\n /** The active deck, computed from decks[activeDeck]. */\n deck: DeckState;\n /** Update persisted state. */\n updateState: (fn: (current: DeckStateProps) => DeckStateProps) => void;\n /** Update ephemeral state. */\n updateEphemeral: (fn: (current: DeckEphemeralStateProps) => DeckEphemeralStateProps) => void;\n};\n\n/**\n * Hook to access the deck plugin state reactively.\n * Returns the combined state, the active deck, and update functions for each atom.\n */\nexport const useDeckState = (): DeckStateHook => {\n const registry = useCapability(Capabilities.AtomRegistry);\n const stateAtom = useCapability(DeckCapabilities.State);\n const ephemeralAtom = useCapability(DeckCapabilities.EphemeralState);\n\n const persistedState = useAtomValue(stateAtom);\n const ephemeralState = useAtomValue(ephemeralAtom);\n\n // Compute deck from decks[activeDeck] to ensure it's always current.\n const deck = useMemo(() => {\n const d = persistedState.decks[persistedState.activeDeck];\n invariant(d, `Deck not found: ${persistedState.activeDeck}`);\n return d;\n }, [persistedState.decks, persistedState.activeDeck]);\n\n // Combine persisted and ephemeral state into a unified view.\n const state = useMemo(\n (): DeckPluginState => ({\n ...persistedState,\n ...ephemeralState,\n }),\n [persistedState, ephemeralState],\n );\n\n const updateState = useCallback(\n (fn: (current: DeckStateProps) => DeckStateProps) => {\n registry.set(stateAtom, fn(registry.get(stateAtom)));\n },\n [registry, stateAtom],\n );\n\n const updateEphemeral = useCallback(\n (fn: (current: DeckEphemeralStateProps) => DeckEphemeralStateProps) => {\n registry.set(ephemeralAtom, fn(registry.get(ephemeralAtom)));\n },\n [registry, ephemeralAtom],\n );\n\n return useMemo(\n () => ({\n state,\n deck,\n updateState,\n updateEphemeral,\n }),\n [state, deck, updateState, updateEphemeral],\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { useMediaQuery } from '@dxos/react-ui';\n\nexport const useBreakpoints = () => {\n const [isNotMobile] = useMediaQuery('md');\n const [isDesktop] = useMediaQuery('lg');\n return isDesktop ? 'desktop' : isNotMobile ? 'tablet' : 'mobile';\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { useAppGraph } from '@dxos/app-toolkit/ui';\nimport { Node, type Node as NodeType } from '@dxos/plugin-graph';\nimport { useConnections } from '@dxos/plugin-graph';\nimport { type Label } from '@dxos/ui-types';\nimport { type Position, byPosition } from '@dxos/util';\n\nimport { DECK_COMPANION_TYPE } from '../types';\n\nexport type DeckCompanion = NodeType.Node<\n any,\n {\n label: Label;\n icon: string;\n // TODO(burdon): Scroll area should be controlled by surface.\n /** If true, the panel will not be wrapped in a scroll area. */\n fixed?: boolean;\n position?: Position;\n }\n>;\n\nexport const useDeckCompanions = (): DeckCompanion[] => {\n const { graph } = useAppGraph();\n const connections = useConnections(graph, Node.RootId, 'child');\n const companions = connections.filter((node) => node.type === DECK_COMPANION_TYPE) as DeckCompanion[];\n return companions.toSorted((a, b) => byPosition(a.properties, b.properties));\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { useMemo } from 'react';\n\nimport { useAtomCapability } from '@dxos/app-framework/ui';\nimport { useThemeContext } from '@dxos/react-ui';\n\nimport { DeckCapabilities, type LayoutMode } from '../types';\n\nexport const useHoistStatusbar = (breakpoint: string, layoutMode?: LayoutMode): boolean => {\n const { safeAreaPadding } = useThemeContext();\n const enableStatusbar = useAtomCapability(DeckCapabilities.Settings).enableStatusbar;\n\n return useMemo(() => {\n return (\n breakpoint === 'desktop' &&\n layoutMode !== 'solo--fullscreen' &&\n !!enableStatusbar &&\n safeAreaPadding?.bottom === 0\n );\n }, [enableStatusbar, breakpoint, safeAreaPadding?.bottom, layoutMode]);\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { useMainContext } from '@dxos/react-ui';\n\nexport const useMainSize = () => {\n const { navigationSidebarState, complementarySidebarState } = useMainContext('DeckPluginPlank');\n return {\n 'data-sidebar-left-state': navigationSidebarState,\n 'data-sidebar-right-state': complementarySidebarState,\n };\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { useEffect } from 'react';\n\nimport { Graph, type Node } from '@dxos/plugin-graph';\n\nexport const useNodeActionExpander = (node?: Node.Node) => {\n useEffect(() => {\n if (node) {\n const frame = requestAnimationFrame(() => {\n const graph = Graph.getGraph(node);\n void Graph.expand(graph, node.id, 'action');\n });\n return () => cancelAnimationFrame(frame);\n }\n }, [node]);\n};\n", "//\n// Copyright 2026 DXOS.org\n//\n\nimport { useMemo } from 'react';\n\nimport { getCompanionVariant } from '@dxos/app-toolkit';\nimport { type Node } from '@dxos/plugin-graph';\n\n/**\n * Resolves which companion to show based on variant preference.\n * Falls back to first available if preferred variant not found.\n */\nexport const useSelectedCompanion = (companions: Node.Node[], preferredVariant?: string) => {\n return useMemo(() => {\n if (companions.length === 0) {\n return { companionId: undefined, variant: undefined };\n }\n\n // Try to find companion matching the preferred variant.\n if (preferredVariant) {\n const preferred = companions.find((companion) => getCompanionVariant(companion.id) === preferredVariant);\n if (preferred) {\n return { companionId: preferred.id, variant: getCompanionVariant(preferred.id) };\n }\n }\n\n // Fallback to first companion.\n const first = companions[0];\n return { companionId: first.id, variant: getCompanionVariant(first.id) };\n }, [companions, preferredVariant]);\n};\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["useMemo", "useAppGraph", "useConnections", "byPosition", "useCompanions", "id", "graph", "useAppGraph", "nodes", "useConnections", "companions", "filter", "node", "type", "PLANK_COMPANION_TYPE", "useMemo", "toSorted", "a", "b", "byPosition", "properties", "useAtomValue", "useCallback", "useMemo", "Capabilities", "useCapability", "invariant", "useDeckState", "registry", "useCapability", "Capabilities", "AtomRegistry", "stateAtom", "DeckCapabilities", "State", "ephemeralAtom", "EphemeralState", "persistedState", "useAtomValue", "ephemeralState", "deck", "useMemo", "d", "decks", "activeDeck", "invariant", "state", "updateState", "useCallback", "fn", "set", "get", "updateEphemeral", "useMediaQuery", "useBreakpoints", "isNotMobile", "useMediaQuery", "isDesktop", "useAppGraph", "Node", "useConnections", "byPosition", "useDeckCompanions", "graph", "useAppGraph", "connections", "useConnections", "Node", "RootId", "companions", "filter", "node", "type", "DECK_COMPANION_TYPE", "toSorted", "a", "b", "byPosition", "properties", "useMemo", "useAtomCapability", "useThemeContext", "useHoistStatusbar", "breakpoint", "layoutMode", "safeAreaPadding", "useThemeContext", "enableStatusbar", "useAtomCapability", "DeckCapabilities", "Settings", "useMemo", "bottom", "useMainContext", "useMainSize", "navigationSidebarState", "complementarySidebarState", "useMainContext", "useEffect", "Graph", "useNodeActionExpander", "node", "useEffect", "frame", "requestAnimationFrame", "graph", "Graph", "getGraph", "expand", "id", "cancelAnimationFrame", "useMemo", "getCompanionVariant", "useSelectedCompanion", "companions", "preferredVariant", "useMemo", "length", "companionId", "undefined", "variant", "preferred", "find", "companion", "getCompanionVariant", "id", "first"]
|
|
7
|
-
}
|