@dxos/plugin-deck 0.9.0 → 0.9.1-main.c7dcc2e112
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/neutral/{DeckLayout-DEURA3KR.mjs → DeckLayout-VX2BP4Q2.mjs} +35 -22
- package/dist/lib/neutral/DeckLayout-VX2BP4Q2.mjs.map +7 -0
- package/dist/lib/neutral/DeckPlugin.mjs +2 -2
- package/dist/lib/neutral/DeckPlugin.mjs.map +4 -4
- package/dist/lib/neutral/{DeckSettings-W5I57OXM.mjs → DeckSettings-CQQZJ2YS.mjs} +3 -3
- package/dist/lib/neutral/DeckSettings-CQQZJ2YS.mjs.map +7 -0
- package/dist/lib/neutral/{add-toast-TNB6DXWU.mjs → add-toast-APKTCLIA.mjs} +2 -2
- package/dist/lib/neutral/{adjust-HNU5CCRO.mjs → adjust-7CZI4GK3.mjs} +3 -3
- package/dist/lib/neutral/{app-graph-builder-HMLT627T.mjs → app-graph-builder-6HTXRTU2.mjs} +5 -5
- package/dist/lib/neutral/app-graph-builder-6HTXRTU2.mjs.map +7 -0
- package/dist/lib/neutral/capabilities/index.mjs +8 -8
- package/dist/lib/neutral/{check-app-scheme-INSOF72J.mjs → check-app-scheme-HSAORHHX.mjs} +2 -2
- package/dist/lib/neutral/{chunk-BS4EOYMK.mjs → chunk-CL7JIOI5.mjs} +28 -14
- package/dist/lib/neutral/chunk-CL7JIOI5.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-WAXJPQJI.mjs → chunk-DNG3L5QN.mjs} +31 -33
- package/dist/lib/neutral/chunk-DNG3L5QN.mjs.map +7 -0
- package/dist/lib/neutral/chunk-KY7LMF4D.mjs +46 -0
- package/dist/lib/neutral/chunk-KY7LMF4D.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-324PPIZB.mjs → chunk-KZFJ4PBT.mjs} +4 -4
- package/dist/lib/neutral/chunk-KZFJ4PBT.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-GBIGQKYW.mjs → chunk-NGX6RXNV.mjs} +4 -4
- package/dist/lib/neutral/chunk-NGX6RXNV.mjs.map +7 -0
- package/dist/lib/neutral/chunk-UZLAR4DR.mjs +8 -0
- package/dist/lib/neutral/{close-ASKR22A6.mjs → close-KJUCFIJ5.mjs} +3 -3
- package/dist/lib/neutral/components/index.mjs +1 -1
- package/dist/lib/neutral/containers/index.mjs +3 -3
- package/dist/lib/neutral/index.mjs +12 -2
- package/dist/lib/neutral/meta.json +1 -1
- package/dist/lib/neutral/meta.mjs +1 -1
- package/dist/lib/neutral/{notification-tracker-P36322BH.mjs → notification-tracker-CUDFRDCF.mjs} +9 -9
- package/dist/lib/neutral/{notification-tracker-P36322BH.mjs.map → notification-tracker-CUDFRDCF.mjs.map} +3 -3
- package/dist/lib/neutral/{open-5OYNO3RT.mjs → open-VU7YS3HB.mjs} +7 -7
- package/dist/lib/neutral/open-VU7YS3HB.mjs.map +7 -0
- package/dist/lib/neutral/operations/index.mjs +1 -1
- package/dist/lib/neutral/plugin.mjs +2 -2
- package/dist/lib/neutral/{react-root-HH5DEUOG.mjs → react-root-E6TAFHX6.mjs} +2 -2
- package/dist/lib/neutral/react-root-E6TAFHX6.mjs.map +7 -0
- package/dist/lib/neutral/{react-surface-3UVVCK3O.mjs → react-surface-O4POQWYL.mjs} +4 -5
- package/dist/lib/neutral/react-surface-O4POQWYL.mjs.map +7 -0
- package/dist/lib/neutral/{revert-workspace-B2QLT2C4.mjs → revert-workspace-24TKG3I7.mjs} +2 -2
- package/dist/lib/neutral/{scroll-into-view-B52C3PJO.mjs → scroll-into-view-3VXT6TWC.mjs} +2 -2
- package/dist/lib/neutral/{set-PA35ONXO.mjs → set-RFOLTI57.mjs} +3 -3
- package/dist/lib/neutral/{set-layout-mode-RPCCPQRB.mjs → set-layout-mode-AZ73W52Z.mjs} +2 -2
- package/dist/lib/neutral/{settings-EGNYUM4T.mjs → settings-6CDQEB6B.mjs} +3 -3
- package/dist/lib/neutral/settings-6CDQEB6B.mjs.map +7 -0
- package/dist/lib/neutral/{state-IIDXMQUO.mjs → state-D3YXB5NP.mjs} +3 -3
- package/dist/lib/neutral/{state-IIDXMQUO.mjs.map → state-D3YXB5NP.mjs.map} +2 -2
- package/dist/lib/neutral/{switch-workspace-LZF4KZXH.mjs → switch-workspace-TBPT23CZ.mjs} +4 -4
- package/dist/lib/neutral/switch-workspace-TBPT23CZ.mjs.map +7 -0
- package/dist/lib/neutral/translations.mjs +1 -1
- package/dist/lib/neutral/translations.mjs.map +3 -3
- package/dist/lib/neutral/types/index.mjs +11 -1
- package/dist/lib/neutral/{update-companion-YUCZZVGY.mjs → update-companion-5LCY6QME.mjs} +2 -2
- package/dist/lib/neutral/{update-complementary-7FZNB55J.mjs → update-complementary-HZ7QXZYE.mjs} +2 -2
- package/dist/lib/neutral/{update-dialog-FNQTSSAP.mjs → update-dialog-A7W3R5EI.mjs} +2 -2
- package/dist/lib/neutral/{update-plank-size-3YW4NXEY.mjs → update-plank-size-XHTYBLSD.mjs} +2 -2
- package/dist/lib/neutral/{update-popover-G2VUD7E6.mjs → update-popover-RDIHG73B.mjs} +2 -2
- package/dist/lib/neutral/{update-sidebar-KRHPUHUB.mjs → update-sidebar-GEI7USA5.mjs} +2 -2
- package/dist/lib/neutral/{url-handler-A6HLW4RB.mjs → url-handler-PUS4X33T.mjs} +10 -10
- package/dist/lib/neutral/url-handler-PUS4X33T.mjs.map +7 -0
- package/dist/types/dx.config.d.ts +28 -0
- package/dist/types/dx.config.d.ts.map +1 -0
- package/dist/types/src/capabilities/index.d.ts +8 -196
- package/dist/types/src/capabilities/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-surface.d.ts +2 -2
- package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
- package/dist/types/src/capabilities/state.d.ts +2 -2
- package/dist/types/src/components/Matrix/Matrix.stories.d.ts.map +1 -1
- package/dist/types/src/containers/Deck/Banner.d.ts.map +1 -1
- package/dist/types/src/containers/Deck/DeckViewport.d.ts.map +1 -1
- package/dist/types/src/containers/Deck/StatusBar.d.ts.map +1 -1
- package/dist/types/src/containers/DeckLayout/DeckLayout.stories.d.ts.map +1 -1
- package/dist/types/src/containers/DeckLayout/Popover.d.ts.map +1 -1
- package/dist/types/src/containers/Plank/PlankHeading.d.ts.map +1 -1
- package/dist/types/src/containers/Sidebar/ComplementarySidebar.d.ts.map +1 -1
- package/dist/types/src/meta.d.ts +28 -2
- package/dist/types/src/meta.d.ts.map +1 -1
- package/dist/types/src/operations/open.d.ts.map +1 -1
- package/dist/types/src/operations/switch-workspace.d.ts.map +1 -1
- package/dist/types/src/types/DeckCapabilities.d.ts +2 -2
- package/dist/types/src/types/DeckCapabilities.d.ts.map +1 -1
- package/dist/types/src/types/index.d.ts +1 -0
- package/dist/types/src/types/index.d.ts.map +1 -1
- package/dist/types/src/types/schema.d.ts +4 -2
- package/dist/types/src/types/schema.d.ts.map +1 -1
- package/dist/types/src/types/surface.d.ts +12 -0
- package/dist/types/src/types/surface.d.ts.map +1 -0
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/dx.config.ts +35 -0
- package/package.json +39 -39
- package/src/DeckPlugin.test.ts +1 -1
- package/src/DeckPlugin.ts +1 -1
- package/src/capabilities/app-graph-builder.ts +4 -4
- package/src/capabilities/check-app-scheme.ts +3 -3
- package/src/capabilities/notification-tracker.ts +8 -8
- package/src/capabilities/react-root.tsx +1 -1
- package/src/capabilities/react-surface.tsx +3 -4
- package/src/capabilities/settings.ts +2 -2
- package/src/capabilities/state.ts +1 -1
- package/src/capabilities/url-handler.ts +7 -15
- package/src/components/DeckSettings/DeckSettings.tsx +2 -2
- package/src/components/Matrix/Matrix.stories.tsx +2 -1
- package/src/containers/Deck/Banner.tsx +5 -4
- package/src/containers/Deck/DeckViewport.tsx +3 -4
- package/src/containers/Deck/StatusBar.tsx +4 -2
- package/src/containers/DeckLayout/DeckLayout.stories.tsx +6 -9
- package/src/containers/DeckLayout/Fallback.tsx +1 -1
- package/src/containers/DeckLayout/Popover.tsx +37 -20
- package/src/containers/DeckLayout/Toast.tsx +1 -1
- package/src/containers/Plank/Plank.stories.tsx +2 -2
- package/src/containers/Plank/PlankControls.tsx +2 -2
- package/src/containers/Plank/PlankError.tsx +1 -1
- package/src/containers/Plank/PlankHeading.tsx +5 -6
- package/src/containers/Sidebar/ComplementarySidebar.tsx +6 -5
- package/src/containers/Sidebar/Sidebar.tsx +1 -1
- package/src/containers/Sidebar/SidebarButton.tsx +3 -3
- package/src/meta.ts +2 -27
- package/src/operations/open.ts +12 -10
- package/src/operations/switch-workspace.ts +2 -2
- package/src/translations.ts +1 -1
- package/src/types/DeckCapabilities.ts +5 -3
- package/src/types/DeckEvents.ts +1 -1
- package/src/types/DeckOperation.ts +1 -1
- package/src/types/index.ts +1 -0
- package/src/types/schema.ts +16 -12
- package/src/types/surface.ts +28 -0
- package/src/util/plank-url-params.ts +3 -3
- package/dist/lib/neutral/DeckLayout-DEURA3KR.mjs.map +0 -7
- package/dist/lib/neutral/DeckSettings-W5I57OXM.mjs.map +0 -7
- package/dist/lib/neutral/app-graph-builder-HMLT627T.mjs.map +0 -7
- package/dist/lib/neutral/chunk-324PPIZB.mjs.map +0 -7
- package/dist/lib/neutral/chunk-BS4EOYMK.mjs.map +0 -7
- package/dist/lib/neutral/chunk-GBIGQKYW.mjs.map +0 -7
- package/dist/lib/neutral/chunk-PYEY5SEC.mjs +0 -37
- package/dist/lib/neutral/chunk-PYEY5SEC.mjs.map +0 -7
- package/dist/lib/neutral/chunk-Q4W6B4IB.mjs +0 -8
- package/dist/lib/neutral/chunk-WAXJPQJI.mjs.map +0 -7
- package/dist/lib/neutral/open-5OYNO3RT.mjs.map +0 -7
- package/dist/lib/neutral/react-root-HH5DEUOG.mjs.map +0 -7
- package/dist/lib/neutral/react-surface-3UVVCK3O.mjs.map +0 -7
- package/dist/lib/neutral/settings-EGNYUM4T.mjs.map +0 -7
- package/dist/lib/neutral/switch-workspace-LZF4KZXH.mjs.map +0 -7
- package/dist/lib/neutral/url-handler-A6HLW4RB.mjs.map +0 -7
- /package/dist/lib/neutral/{add-toast-TNB6DXWU.mjs.map → add-toast-APKTCLIA.mjs.map} +0 -0
- /package/dist/lib/neutral/{adjust-HNU5CCRO.mjs.map → adjust-7CZI4GK3.mjs.map} +0 -0
- /package/dist/lib/neutral/{check-app-scheme-INSOF72J.mjs.map → check-app-scheme-HSAORHHX.mjs.map} +0 -0
- /package/dist/lib/neutral/{chunk-Q4W6B4IB.mjs.map → chunk-UZLAR4DR.mjs.map} +0 -0
- /package/dist/lib/neutral/{close-ASKR22A6.mjs.map → close-KJUCFIJ5.mjs.map} +0 -0
- /package/dist/lib/neutral/{revert-workspace-B2QLT2C4.mjs.map → revert-workspace-24TKG3I7.mjs.map} +0 -0
- /package/dist/lib/neutral/{scroll-into-view-B52C3PJO.mjs.map → scroll-into-view-3VXT6TWC.mjs.map} +0 -0
- /package/dist/lib/neutral/{set-PA35ONXO.mjs.map → set-RFOLTI57.mjs.map} +0 -0
- /package/dist/lib/neutral/{set-layout-mode-RPCCPQRB.mjs.map → set-layout-mode-AZ73W52Z.mjs.map} +0 -0
- /package/dist/lib/neutral/{update-companion-YUCZZVGY.mjs.map → update-companion-5LCY6QME.mjs.map} +0 -0
- /package/dist/lib/neutral/{update-complementary-7FZNB55J.mjs.map → update-complementary-HZ7QXZYE.mjs.map} +0 -0
- /package/dist/lib/neutral/{update-dialog-FNQTSSAP.mjs.map → update-dialog-A7W3R5EI.mjs.map} +0 -0
- /package/dist/lib/neutral/{update-plank-size-3YW4NXEY.mjs.map → update-plank-size-XHTYBLSD.mjs.map} +0 -0
- /package/dist/lib/neutral/{update-popover-G2VUD7E6.mjs.map → update-popover-RDIHG73B.mjs.map} +0 -0
- /package/dist/lib/neutral/{update-sidebar-KRHPUHUB.mjs.map → update-sidebar-GEI7USA5.mjs.map} +0 -0
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/containers/Plank/PlankLoading.tsx", "../../../src/containers/Plank/PlankError.tsx", "../../../src/containers/Plank/PlankHeading.tsx", "../../../src/containers/Plank/PlankControls.tsx", "../../../src/containers/Plank/PlankRoot.tsx", "../../../src/containers/Plank/PlankComponent.tsx", "../../../src/containers/Plank/PlankContent.tsx", "../../../src/containers/Plank/Plank.tsx", "../../../src/containers/Sidebar/SidebarButton.tsx", "../../../src/containers/Sidebar/ComplementarySidebar.tsx", "../../../src/containers/Sidebar/Sidebar.tsx", "../../../src/containers/Deck/DeckContent.tsx", "../../../src/containers/Deck/Banner.tsx", "../../../src/containers/Deck/DeckRoot.tsx", "../../../src/containers/Deck/DeckViewport.tsx", "../../../src/containers/Deck/Deck.tsx"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport React from 'react';\n\n// TODO(burdon): Show skeleton: https://github.com/dxos/dxos/issues/8259\nexport const PlankLoading = () => {\n return <div className='grid place-items-center dx-attention-surface' />;\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { useEffect, useMemo, useState } from 'react';\n\nimport { TimeoutError } from '@dxos/errors';\nimport { log } from '@dxos/log';\nimport { type Node } from '@dxos/plugin-graph';\nimport { ErrorFallback, type ErrorFallbackProps, useTranslation } from '@dxos/react-ui';\nimport { descriptionMessage, mx } from '@dxos/ui-theme';\n\nimport { meta } from '#meta';\n\nimport { PlankHeading, type PlankHeadingProps } from './PlankHeading';\nimport { PlankLoading } from './PlankLoading';\n\nexport const PlankError = ({\n id,\n part,\n node,\n error: errorProp,\n}: {\n id: string;\n part: PlankHeadingProps['part'];\n node?: Node.Node;\n error?: Error;\n}) => {\n const [timedOut, setTimedOut] = useState(false);\n useEffect(() => {\n const timer = setTimeout(() => setTimedOut(true), 5_000);\n return () => clearTimeout(timer);\n }, []);\n\n const error = useMemo(() => {\n if (timedOut) {\n return new TimeoutError({ message: 'Timeout loading content' });\n }\n\n return errorProp;\n }, [timedOut, errorProp]);\n\n return (\n <>\n <PlankHeading id={id} part={part} node={node} pending={!timedOut} />\n {timedOut ? <PlankErrorFallback error={error} /> : <PlankLoading />}\n </>\n );\n};\n\n/**\n * User facing error fallback.\n */\nexport const PlankErrorFallback = ({ error }: ErrorFallbackProps) => {\n const { t } = useTranslation(meta.profile.key);\n\n useEffect(() => {\n if (error) {\n log.error('plank error', { error });\n }\n }, [error]);\n\n if (process.env.NODE_ENV === 'development') {\n return <ErrorFallback title='Plank Error' error={error} />;\n } else {\n const errorString = error?.toString() ?? '';\n\n return (\n <div\n role='alert'\n data-testid='plank-content-error'\n className='dx-attention-surface overflow-y-auto p-8 grid place-items-center'\n >\n <div className='flex flex-col items-center gap-2'>\n <p className={mx(descriptionMessage, 'break-all rounded-md p-4')}>\n {error ? errorString : t('error-fallback.message')}\n </p>\n </div>\n </div>\n );\n }\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { Fragment, type MouseEvent, memo, useCallback, useEffect, useMemo } from 'react';\n\nimport { Surface } from '@dxos/app-framework/ui';\nimport { AppSurface } from '@dxos/app-toolkit/ui';\nimport { Graph, type Node, useActionRunner } from '@dxos/plugin-graph';\nimport { Icon, IconButton, Popover, TextTooltip, toLocalizedString, useTranslation } from '@dxos/react-ui';\nimport { getLinkedVariant } from '@dxos/react-ui-attention';\nimport { StackItem, type StackItemSigilAction } from '@dxos/react-ui-stack';\nimport { hoverableControls, hoverableFocusedWithinControls, iconSize } from '@dxos/ui-theme';\n\nimport { useBreakpoints } from '#hooks';\nimport { meta } from '#meta';\nimport { DeckOperation } from '#types';\nimport { type LayoutMode, PLANK_COMPANION_TYPE, type ResolvedPart } from '#types';\n\nimport { PlankCompanionControls, PlankControls } from './PlankControls';\nimport { usePlankContext } from './PlankRoot';\n\nconst MAX_COMPANIONS = 5;\n\nexport type PlankHeadingProps = {\n id: string;\n part: ResolvedPart;\n layoutMode?: LayoutMode;\n node?: Node.Node;\n deckEnabled?: boolean;\n canIncrementStart?: boolean;\n canIncrementEnd?: boolean;\n popoverAnchorId?: string;\n primaryId?: string;\n pending?: boolean;\n companioned?: 'primary' | 'companion';\n companions?: Node.Node[];\n actions?: StackItemSigilAction[];\n debug?: boolean;\n};\n\nexport const PlankHeading = memo(\n ({\n id,\n part,\n node,\n deckEnabled,\n canIncrementStart,\n canIncrementEnd,\n popoverAnchorId,\n primaryId,\n pending,\n companioned,\n companions,\n layoutMode,\n actions = [],\n debug = false,\n }: PlankHeadingProps) => {\n const { t } = useTranslation(meta.profile.key);\n const { graph, onAdjust, onUpdateCompanion } = usePlankContext('PlankHeading');\n const runAction = useActionRunner();\n const breakpoint = useBreakpoints();\n const icon = node?.properties?.icon ?? 'ph--circle-dashed--regular';\n const label = pending\n ? t('pending.heading')\n : toLocalizedString(node?.properties?.label ?? ['plank-heading-fallback.label', { ns: meta.profile.key }], t);\n\n const isCompanionNode = node?.type === PLANK_COMPANION_TYPE;\n\n useEffect(() => {\n const frame = requestAnimationFrame(() => {\n // Load actions for the node.\n if (node) {\n void Graph.expand(graph, node.id, 'child');\n }\n });\n\n return () => cancelAnimationFrame(frame);\n }, [node]);\n\n const attendableId = primaryId ?? id;\n const capabilities = useMemo(\n () => ({\n deck: deckEnabled ?? true,\n solo: breakpoint !== 'mobile' && (part === 'solo' || part === 'multi'),\n incrementStart: canIncrementStart,\n incrementEnd: canIncrementEnd,\n fullscreen: !isCompanionNode,\n companion: layoutMode !== 'multi' && !isCompanionNode && companions && companions.length > 0,\n }),\n [breakpoint, part, companions, canIncrementStart, canIncrementEnd, isCompanionNode, deckEnabled, layoutMode],\n );\n\n const variant = isCompanionNode ? getLinkedVariant(id) : undefined;\n const sigilActions = useMemo(() => {\n if (!node) {\n return undefined;\n } else if (variant) {\n return [];\n } else {\n return [\n actions,\n Graph.getActions(graph, node.id).filter((action) =>\n ['list-item', 'list-item-primary', 'heading-list-item'].includes(action.properties.disposition),\n ),\n ].filter((a) => a.length > 0);\n }\n }, [actions, node, variant, graph]);\n\n const handleAction = useCallback(\n (action: StackItemSigilAction) => {\n if (typeof action.data === 'function') {\n void runAction(action as Node.Action, { parent: node, caller: meta.profile.key });\n }\n },\n [node, runAction],\n );\n\n const handlePlankAction = useCallback(\n (eventType: DeckOperation.PartAdjustment) => {\n onAdjust?.(id, eventType);\n },\n [onAdjust, id],\n );\n\n const ActionRoot = node && popoverAnchorId === `${meta.profile.key}:${node.id}` ? Popover.Anchor : Fragment;\n\n const handleTabClick = useCallback(\n (event: MouseEvent) => {\n const target = (event.target as HTMLElement).closest('[data-id]') as HTMLElement | null;\n const tabId = target?.dataset?.id;\n if (tabId) {\n onUpdateCompanion?.(tabId);\n }\n },\n [onUpdateCompanion],\n );\n\n return (\n <StackItem.Heading\n data-tauri-drag-region\n data-plank-heading\n style={iconSize(5)}\n classNames={[\n 'py-1 items-stretch gap-1 sticky left-12 dx-app-drag min-w-0 dx-contain-layout dx-density-lg',\n part === 'solo'\n ? 'ps-[calc(env(safe-area-inset-left)+.25rem)] pe-[calc(env(safe-area-inset-right)+.25rem)]'\n : 'px-1',\n ...(layoutMode === 'solo--fullscreen'\n ? [\n hoverableControls,\n hoverableFocusedWithinControls,\n '*:transition-opacity *:opacity-(--controls-opacity) bg-transparent',\n 'border-transparent transition-[background-color,border-color]',\n 'hover-hover:hover:bg-header-surface focus-within:bg-header-surface',\n 'hover-hover:hover:border-subdued-separator focus-within:border-subdued-separator',\n ]\n : []),\n ]}\n >\n {companions && isCompanionNode ? (\n /* TODO(thure): IMPORTANT: This is a tablist; it should be implemented as such. */\n <div data-tauri-drag-region className='flex-1 min-w-0 overflow-x-auto scrollbar-none flex gap-1'>\n {companions.map(({ id, properties: { icon, label } }) => (\n <IconButton\n key={id}\n data-id={id}\n icon={icon}\n iconOnly={companions.length > MAX_COMPANIONS && node?.id !== id}\n label={toLocalizedString(label, t)}\n variant={node?.id === id ? 'primary' : 'ghost'}\n onClick={handleTabClick}\n />\n ))}\n </div>\n ) : (\n <>\n <ActionRoot>\n {node && sigilActions ? (\n <StackItem.Sigil\n icon={icon}\n related={part === 'complementary'}\n attendableId={attendableId}\n triggerLabel={t('actions-menu.label')}\n actions={sigilActions}\n onAction={handleAction}\n >\n <Surface.Surface\n type={AppSurface.MenuFooter}\n data={{ subject: node.data } satisfies AppSurface.MenuFooterData}\n />\n </StackItem.Sigil>\n ) : (\n <StackItem.SigilButton>\n <span className='sr-only'>{label}</span>\n <Icon icon={icon} />\n </StackItem.SigilButton>\n )}\n </ActionRoot>\n <TextTooltip text={label} onlyWhenTruncating>\n <StackItem.HeadingLabel\n data-tauri-drag-region\n attendableId={attendableId}\n related={part === 'complementary'}\n {...(pending && { classNames: 'text-description' })}\n >\n {label}\n </StackItem.HeadingLabel>\n </TextTooltip>\n </>\n )}\n {debug && (\n <div className='flex items-center text-sm text-info-text'>\n {layoutMode}:{part}:{companioned}\n </div>\n )}\n {node && part !== 'complementary' && (\n <Surface.Surface\n type={AppSurface.NavbarEnd}\n data={{ subject: node.data } satisfies AppSurface.NavbarEndData}\n />\n )}\n {companioned === 'companion' ? (\n <PlankCompanionControls primary={primaryId} />\n ) : (\n <PlankControls\n capabilities={capabilities}\n layoutMode={layoutMode}\n close={part === 'complementary' ? 'minify-end' : true}\n onClick={handlePlankAction}\n />\n )}\n </StackItem.Heading>\n );\n },\n);\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { forwardRef, useCallback } from 'react';\n\nimport { useOperationInvoker } from '@dxos/app-framework/ui';\nimport { LayoutOperation } from '@dxos/app-toolkit';\nimport { ButtonGroup, type ButtonGroupProps, type ButtonProps, IconButton, useTranslation } from '@dxos/react-ui';\n\nimport { meta } from '#meta';\nimport { type DeckAction, type LayoutMode } from '#types';\n\nexport type PlankControlHandler = (event: DeckAction.PartAdjustment) => void;\n\nexport type PlankCapabilities = {\n incrementStart?: boolean;\n incrementEnd?: boolean;\n deck?: boolean;\n solo?: boolean;\n fullscreen?: boolean;\n companion?: boolean;\n};\n\n//\n// Controls\n//\n\nconst plankControlSpacing = 'px-2';\n\nexport type PlankCompanionControlsProps = {\n primary?: string;\n};\n\nexport const PlankCompanionControls = forwardRef<HTMLDivElement, PlankCompanionControlsProps>(\n ({ primary }, forwardedRef) => {\n const { t } = useTranslation(meta.profile.key);\n const { invokePromise } = useOperationInvoker();\n const handleCloseCompanion = useCallback(() => {\n return invokePromise(LayoutOperation.UpdateCompanion, { subject: null });\n }, [invokePromise]);\n return (\n <div ref={forwardedRef} className='contents dx-app-no-drag'>\n <PlankControl\n label={t('close-companion.label')}\n variant='ghost'\n icon='ph--x--regular'\n onClick={handleCloseCompanion}\n classNames={plankControlSpacing}\n />\n </div>\n );\n },\n);\n\nconst PlankControl = ({ icon, label, ...props }: Omit<ButtonProps, 'children'> & { label: string; icon: string }) => {\n return <IconButton label={label} icon={icon} iconOnly variant='ghost' tooltipSide='bottom' {...props} />;\n};\n\n//\n// PlankControls\n//\n\nexport type PlankControlsProps = Omit<ButtonGroupProps, 'onClick'> & {\n onClick?: PlankControlHandler;\n variant?: 'hide-disabled' | 'default';\n close?: boolean | 'minify-start' | 'minify-end';\n capabilities: PlankCapabilities;\n layoutMode?: LayoutMode;\n pin?: 'start' | 'end' | 'both';\n};\n\n// TODO(wittjosiah): Duplicate of stack LayoutControls?\n// Translations were to be duplicated between packages.\n// NOTE(thure): Pinning & unpinning are disabled indefinitely.\nexport const PlankControls = forwardRef<HTMLDivElement, PlankControlsProps>(\n (\n { children, classNames, variant = 'default', capabilities, layoutMode, pin, close = false, onClick, ...props },\n forwardedRef,\n ) => {\n const { t } = useTranslation(meta.profile.key);\n const buttonClassNames =\n variant === 'hide-disabled' ? `disabled:hidden ${plankControlSpacing}` : plankControlSpacing;\n\n const layoutIsAnySolo = !!layoutMode?.startsWith('solo');\n\n return (\n <ButtonGroup {...props} classNames={['dx-app-no-drag opacity-100!', classNames]} ref={forwardedRef}>\n {capabilities.deck ? (\n <>\n {capabilities.solo && (\n <>\n {layoutMode === 'solo' && (\n <PlankControl\n label={t('show-fullscreen-plank.label')}\n classNames={buttonClassNames}\n icon='ph--corners-out--regular'\n onClick={() => onClick?.('solo--fullscreen')}\n />\n )}\n <PlankControl\n label={t(\n layoutMode === 'solo--fullscreen'\n ? 'exit-fullscreen.label'\n : layoutIsAnySolo\n ? 'show-deck-plank.label'\n : 'show-solo-plank.label',\n )}\n classNames={buttonClassNames}\n icon={\n layoutMode === 'solo--fullscreen'\n ? 'ph--corners-in--regular'\n : layoutIsAnySolo\n ? 'ph--arrows-in-line-horizontal--regular'\n : 'ph--arrows-out-line-horizontal--regular'\n }\n onClick={() => onClick?.(layoutMode === 'solo--fullscreen' ? 'solo--fullscreen' : 'solo')}\n />\n </>\n )}\n\n {!layoutIsAnySolo && layoutMode !== 'multi' && (\n <>\n <PlankControl\n label={t('increment-start.label')}\n disabled={!capabilities.incrementStart}\n classNames={buttonClassNames}\n icon='ph--caret-left--regular'\n onClick={() => onClick?.('increment-start')}\n />\n <PlankControl\n label={t('increment-end.label')}\n disabled={!capabilities.incrementEnd}\n classNames={buttonClassNames}\n icon='ph--caret-right--regular'\n onClick={() => onClick?.('increment-end')}\n />\n </>\n )}\n </>\n ) : (\n capabilities.fullscreen && (\n <PlankControl\n label={t(layoutMode === 'solo--fullscreen' ? 'exit-fullscreen.label' : 'show-fullscreen-plank.label')}\n classNames={buttonClassNames}\n icon={layoutMode === 'solo--fullscreen' ? 'ph--corners-in--regular' : 'ph--corners-out--regular'}\n onClick={() => onClick?.('solo--fullscreen')}\n />\n )\n )}\n\n {close && !layoutIsAnySolo && (\n <PlankControl\n label={t(`${typeof close === 'string' ? 'minify' : 'close'}.label`)}\n classNames={buttonClassNames}\n data-testid='plankHeading.close'\n icon={\n close === 'minify-start'\n ? 'ph--caret-line-left--regular'\n : close === 'minify-end'\n ? 'ph--caret-line-right--regular'\n : 'ph--x--regular'\n }\n onClick={() => onClick?.('close')}\n />\n )}\n\n {capabilities.companion && (\n <PlankControl\n label={t('open-companion.label')}\n classNames={buttonClassNames}\n data-testid='plankHeading.companion'\n icon='ph--square-split-horizontal--regular'\n onClick={() => onClick?.('companion')}\n />\n )}\n {children}\n </ButtonGroup>\n );\n },\n);\n", "//\n// Copyright 2026 DXOS.org\n//\n\nimport { createContext } from '@radix-ui/react-context';\nimport React, { PropsWithChildren } from 'react';\n\nimport { type Graph } from '@dxos/plugin-graph';\n\nimport { type DeckOperation } from '#types';\nimport { type LayoutMode, type PlankSizing, type ResolvedPart, type Settings } from '#types';\n\nconst PLANK_NAME = 'Plank';\n\nexport type PlankContextValue = {\n /** The application graph. */\n graph: Graph.ExpandableGraph;\n /** Which part of the layout this plank occupies. */\n part: ResolvedPart;\n /** Current layout mode. */\n layoutMode: LayoutMode;\n /** Deck settings. */\n settings?: Settings.Settings;\n /** Popover anchor ID for heading menus. */\n popoverAnchorId?: string;\n /** ID of plank that should be scrolled into view. */\n scrollIntoView?: string;\n /** Persisted plank sizes keyed by plank ID. */\n plankSizing?: PlankSizing;\n /** Callback for plank adjustments (close, solo, increment, companion). */\n onAdjust?: (id: string, type: DeckOperation.PartAdjustment) => void;\n /** Callback for plank resize. */\n onResize?: (id: string, size: number) => void;\n /** Callback to clear scroll-into-view state. */\n onScrollIntoView?: (id?: string) => void;\n /** Callback to update the companion. */\n onUpdateCompanion?: (companion: string | null) => void;\n};\n\nexport const [PlankProvider, usePlankContext] = createContext<PlankContextValue>(PLANK_NAME);\n\nexport type PlankRootProps = PropsWithChildren<PlankContextValue>;\n\n/**\n * Headless root that provides plank context.\n */\nexport const PlankRoot = ({ children, ...context }: PlankRootProps) => {\n return <PlankProvider {...context}>{children}</PlankProvider>;\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { useFocusFinders } from '@fluentui/react-tabster';\nimport React, { type KeyboardEvent, memo, useCallback, useLayoutEffect, useMemo, useRef } from 'react';\n\nimport { Surface } from '@dxos/app-framework/ui';\nimport { AppSurface } from '@dxos/app-toolkit/ui';\nimport { debounce } from '@dxos/async';\nimport { type Node } from '@dxos/plugin-graph';\nimport { mainIntrinsicSize } from '@dxos/react-ui';\nimport { getLinkedVariant } from '@dxos/react-ui-attention';\nimport { useAttentionAttributes } from '@dxos/react-ui-attention';\nimport { StackItem, type StackItemSize, railGridHorizontal } from '@dxos/react-ui-stack';\nimport { mx } from '@dxos/ui-theme';\n\nimport { useMainSize } from '#hooks';\nimport { PLANK_COMPANION_TYPE } from '#types';\n\nimport { PlankError, PlankErrorFallback } from './PlankError';\nimport { PlankHeading } from './PlankHeading';\nimport { PlankLoading } from './PlankLoading';\nimport { PlankRootProps, usePlankContext } from './PlankRoot';\n\n/**\n * JS-based smooth scroll that won't be interrupted by MutationObserver or layout changes.\n */\nconst smoothScrollTo = (element: HTMLElement, target: number, duration: number) => {\n const start = element.scrollLeft;\n const distance = target - start;\n const startTime = performance.now();\n\n const step = (currentTime: number) => {\n const elapsed = currentTime - startTime;\n const progress = Math.min(elapsed / duration, 1);\n // Ease-out cubic.\n const eased = 1 - Math.pow(1 - progress, 3);\n element.scrollLeft = start + distance * eased;\n if (progress < 1) {\n requestAnimationFrame(step);\n }\n };\n\n requestAnimationFrame(step);\n};\n\n// NOTE: Calibrated to show PLANK + COMPANION on MBP 16\" screen.\nexport const DEFAULT_SIZE = 48 satisfies StackItemSize;\nexport const DEFAULT_COMPANION_SIZE = 35 satisfies StackItemSize;\n\nexport type PlankComponentProps = Pick<PlankRootProps, 'part'> & {\n id: string;\n path?: string[];\n order?: number;\n active?: string[];\n node?: Node.Node;\n primary?: Node.Node;\n companions?: Node.Node[];\n companioned?: 'primary' | 'companion';\n};\n\nexport const PlankComponent = memo(\n ({ part, id, path, order, active, node, primary, companions, companioned }: PlankComponentProps) => {\n const { layoutMode, settings, popoverAnchorId, scrollIntoView, plankSizing, onResize, onScrollIntoView } =\n usePlankContext('PlankComponent');\n\n const canResize = layoutMode === 'multi';\n const { findFirstFocusable } = useFocusFinders();\n const isCompanion = companioned === 'companion';\n // Companions share attention with their primary; non-companions key attention to their own id.\n const attentionId = isCompanion ? (primary?.id ?? id) : id;\n const attentionAttrs = useAttentionAttributes(attentionId);\n const orderId = isCompanion ? primary?.id : id;\n const index = orderId && active ? active.findIndex((entryId) => entryId === orderId) : -1;\n const length = active?.length ?? 1;\n const isOrdered = !!active && index >= 0;\n const canIncrementStart = isOrdered && index > 0;\n const canIncrementEnd = isOrdered && index < length - 1;\n const rootElement = useRef<HTMLDivElement | null>(null);\n const variant = node?.type === PLANK_COMPANION_TYPE ? getLinkedVariant(id) : undefined;\n\n // Sizing.\n const sizeAttrs = useMainSize();\n const sizeKey = id.split('+')[0];\n const size = isCompanion\n ? DEFAULT_COMPANION_SIZE\n : ((plankSizing?.[sizeKey] as number | undefined) ?? DEFAULT_SIZE);\n const handleSizeChange = useCallback(\n debounce((nextSize: number) => {\n const size = Math.round(nextSize);\n onResize?.(sizeKey, size);\n }, 200),\n [sizeKey, onResize],\n );\n\n // TODO(thure): Tabster's focus group should handle moving focus to Main, but something is blocking it.\n const handleKeyDown = useCallback((event: KeyboardEvent) => {\n if (event.target === event.currentTarget) {\n switch (event.key) {\n case 'Escape':\n rootElement.current?.closest('main')?.focus();\n break;\n case 'Enter':\n rootElement.current && findFirstFocusable(rootElement.current)?.focus();\n break;\n }\n }\n }, []);\n\n useLayoutEffect(() => {\n if (scrollIntoView === id && layoutMode === 'multi' && rootElement.current) {\n const element = rootElement.current;\n const scrollParent = element.closest('[style*=\"overflow\"], .overflow-x-auto') as HTMLElement | null;\n if (scrollParent) {\n const elementRect = element.getBoundingClientRect();\n const parentRect = scrollParent.getBoundingClientRect();\n const targetScrollLeft = scrollParent.scrollLeft + (elementRect.left - parentRect.left);\n\n smoothScrollTo(scrollParent, targetScrollLeft, 300);\n }\n\n onScrollIntoView?.(undefined);\n }\n }, [id, scrollIntoView, layoutMode, onScrollIntoView]);\n\n const isSolo = layoutMode.startsWith('solo') && part === 'solo';\n const isAttendable =\n (layoutMode.startsWith('solo') && part.startsWith('solo')) || (layoutMode === 'multi' && part === 'multi');\n\n // Companions share attention with their primary, so they attend to the primary's id\n // (matching the plank's attention container, which keys to `primary?.id ?? id`).\n const attendableId = isCompanion ? (primary?.id ?? id) : id;\n const data = useMemo<AppSurface.ArticleData | undefined>(\n () =>\n node && {\n attendableId,\n subject: node.data,\n companionTo: primary?.data,\n properties: node.properties,\n variant,\n path,\n popoverAnchorId,\n },\n [node, node?.data, node?.properties, path, popoverAnchorId, primary?.data, variant, attendableId],\n );\n\n // TODO(wittjosiah): Change prop to accept a component.\n const placeholder = useMemo(() => <PlankLoading />, []);\n\n const Root = part.startsWith('solo') ? 'article' : StackItem.Root;\n const fullscreen = layoutMode === 'solo--fullscreen';\n const classNames = [\n 'dx-attention-surface relative dx-focus-ring-inset-over-all dx-density-lg',\n isSolo && 'absolute inset-0',\n isSolo && mainIntrinsicSize,\n railGridHorizontal,\n part.startsWith('solo') && 'grid',\n part.startsWith('solo-') && 'grid-rows-subgrid row-span-2 min-w-0',\n fullscreen && 'grid-rows-1',\n part === 'multi' && (isCompanion ? 'border-separator! border-e' : 'border-separator! border-x'),\n part === 'solo-companion' && 'border-separator! border-s',\n settings?.encapsulatedPlanks &&\n !part.startsWith('solo') &&\n 'mx-(--main-spacing) border-separator! border rounded-sm overflow-hidden',\n ];\n\n return (\n <Root\n ref={rootElement}\n data-testid='deck.plank'\n data-popover-collision-boundary={true}\n tabIndex={0}\n {...(part.startsWith('solo')\n ? ({\n className: mx(classNames),\n ...sizeAttrs,\n } as any)\n : {\n role: 'article',\n item: { id },\n classNames,\n order,\n size,\n onSizeChange: handleSizeChange,\n })}\n {...(isAttendable ? attentionAttrs : {})}\n onKeyDown={handleKeyDown}\n >\n {node ? (\n <>\n {!fullscreen && (\n <PlankHeading\n id={id}\n part={part.startsWith('solo-') ? 'solo' : part}\n node={node}\n layoutMode={layoutMode}\n deckEnabled={settings?.enableDeck}\n canIncrementStart={canIncrementStart}\n canIncrementEnd={canIncrementEnd}\n popoverAnchorId={popoverAnchorId}\n primaryId={primary?.id}\n companioned={companioned}\n companions={companions}\n />\n )}\n <Surface.Surface\n key={node.id}\n type={AppSurface.Article}\n data={data}\n limit={1}\n fallback={PlankErrorFallback}\n placeholder={placeholder}\n />\n </>\n ) : (\n <PlankError id={id} part={part} />\n )}\n {canResize && <StackItem.ResizeHandle />}\n </Root>\n );\n },\n);\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { type PropsWithChildren } from 'react';\n\nimport { composable, composableProps, mainIntrinsicSize } from '@dxos/react-ui';\nimport { railGridHorizontal } from '@dxos/react-ui-stack';\n\nimport { useMainSize } from '#hooks';\n\nexport type PlankContentProps = PropsWithChildren<{\n solo: boolean;\n companion: boolean;\n encapsulate: boolean;\n}>;\n\nexport const PlankContent = composable<HTMLDivElement, PlankContentProps>(\n ({ children, solo, companion, encapsulate, ...props }, forwardedRef) => {\n const sizeAttrs = useMainSize();\n if (!solo) {\n return children;\n }\n\n return (\n <div\n {...sizeAttrs}\n {...composableProps(props, {\n role: 'none',\n classNames: [\n 'absolute inset-(--main-spacing) grid',\n railGridHorizontal,\n mainIntrinsicSize,\n companion && 'grid-cols-[6fr_4fr]', // Ration of primary to companion.\n encapsulate && 'border border-separator rounded-sm overflow-hidden',\n ],\n })}\n data-popover-collision-boundary={true}\n ref={forwardedRef}\n >\n {children}\n </div>\n );\n },\n);\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { PlankComponent, PlankComponentProps } from './PlankComponent';\nimport { PlankContent, PlankContentProps } from './PlankContent';\nimport { PlankControls } from './PlankControls';\nimport { PlankHeading } from './PlankHeading';\nimport { PlankRoot, PlankRootProps } from './PlankRoot';\n\n/**\n * Radix-style composite Plank component.\n */\nexport const Plank = {\n Root: PlankRoot,\n Content: PlankContent,\n Component: PlankComponent,\n Heading: PlankHeading,\n Controls: PlankControls,\n};\n\nexport type { PlankRootProps, PlankComponentProps, PlankContentProps };\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useCallback } from 'react';\n\nimport { useOperationInvoker } from '@dxos/app-framework/ui';\nimport { LayoutOperation } from '@dxos/app-toolkit';\nimport { IconButton, type IconButtonProps, type ThemedClassName, useTranslation } from '@dxos/react-ui';\nimport { getLinkedVariant } from '@dxos/react-ui-attention';\n\nimport { useDeckCompanions, useDeckState } from '#hooks';\nimport { meta } from '#meta';\n\nexport const ToggleSidebarButton = ({\n classNames,\n variant = 'ghost',\n}: ThemedClassName<Pick<IconButtonProps, 'variant'>>) => {\n const { updateState } = useDeckState();\n const { t } = useTranslation(meta.profile.key);\n\n const handleClick = useCallback(() => {\n updateState((state) => ({\n ...state,\n sidebarState: state.sidebarState === 'expanded' ? 'collapsed' : 'expanded',\n }));\n }, [updateState]);\n\n return (\n <IconButton\n variant={variant}\n icon='ph--sidebar--regular'\n iconOnly\n size={4}\n label={t('open-navigation-sidebar.label')}\n onClick={handleClick}\n classNames={classNames}\n />\n );\n};\n\nexport const CloseSidebarButton = () => {\n const { updateState } = useDeckState();\n const { t } = useTranslation(meta.profile.key);\n\n const handleClick = useCallback(() => {\n updateState((state) => ({ ...state, sidebarState: 'collapsed' }));\n }, [updateState]);\n\n return (\n <IconButton\n variant='ghost'\n icon='ph--caret-line-left--regular'\n iconOnly\n size={4}\n label={t('close-navigation-sidebar.button')}\n onClick={handleClick}\n classNames='rounded-none px-1 dx-focus-ring-inset pe-[max(.5rem,env(safe-area-inset-left))]'\n />\n );\n};\n\nexport const ToggleComplementarySidebarButton = ({\n inR0,\n classNames,\n current,\n}: ThemedClassName<{ inR0?: boolean; current?: string }>) => {\n const { invokePromise } = useOperationInvoker();\n const { state, updateState } = useDeckState();\n const { t } = useTranslation(meta.profile.key);\n\n const companions = useDeckCompanions();\n const handleClick = useCallback(() => {\n const nextState = state.complementarySidebarState === 'expanded' ? 'collapsed' : 'expanded';\n updateState((state) => ({ ...state, complementarySidebarState: nextState }));\n\n const subject = state.complementarySidebarPanel ?? (companions[0] && getLinkedVariant(companions[0].id));\n if (nextState === 'expanded' && !current && subject) {\n void invokePromise(LayoutOperation.UpdateComplementary, { subject });\n }\n }, [state, updateState, current, companions, invokePromise]);\n\n const label = t(\n state.complementarySidebarState === 'expanded'\n ? 'close-complementary-sidebar.label'\n : 'open-complementary-sidebar.label',\n );\n\n return (\n <IconButton\n variant='ghost'\n classNames={['[&>svg]:-scale-x-100', classNames]}\n icon='ph--sidebar-simple--regular'\n iconOnly\n label={label}\n tooltipSide={inR0 ? 'left' : undefined}\n onClick={handleClick}\n />\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { type MouseEvent, useCallback, useEffect, useMemo, useState } from 'react';\n\nimport { Surface, useOperationInvoker } from '@dxos/app-framework/ui';\nimport { LayoutOperation } from '@dxos/app-toolkit';\nimport { AppSurface } from '@dxos/app-toolkit/ui';\nimport { IconButton, type Label, Main, Panel, toLocalizedString, Toolbar, useTranslation } from '@dxos/react-ui';\nimport { getLinkedVariant } from '@dxos/react-ui-attention';\nimport { Tabs } from '@dxos/react-ui-tabs';\nimport { iconSize, mx } from '@dxos/ui-theme';\n\nimport { type DeckCompanion, useBreakpoints, useDeckCompanions, useDeckState } from '#hooks';\nimport { meta } from '#meta';\nimport { getMode } from '#types';\n\nimport { layoutAppliesTopbar } from '../../util';\nimport { PlankErrorFallback, PlankLoading } from '../Plank';\nimport { ToggleComplementarySidebarButton } from './SidebarButton';\n\nconst label = ['complementary-sidebar.title', { ns: meta.profile.key }] satisfies Label;\n\nexport type ComplementarySidebarProps = {\n current?: string;\n};\n\nexport const ComplementarySidebar = ({ current }: ComplementarySidebarProps) => {\n const { invokePromise } = useOperationInvoker();\n const { t } = useTranslation(meta.profile.key);\n const { state, deck, updateState } = useDeckState();\n const layoutMode = getMode(deck);\n const breakpoint = useBreakpoints();\n const topbar = layoutAppliesTopbar(breakpoint, layoutMode);\n\n const companions = useDeckCompanions();\n const activeCompanion = companions.find((companion) => getLinkedVariant(companion.id) === current);\n const activeId = activeCompanion && getLinkedVariant(activeCompanion.id);\n const [internalValue, setInternalValue] = useState(activeId);\n\n useEffect(() => {\n setInternalValue(activeId);\n }, [activeId]);\n\n const handleTabClick = useCallback(\n (event: MouseEvent) => {\n const nextValue = event.currentTarget.getAttribute('data-value') as string;\n if (nextValue === activeId) {\n updateState((state) => ({\n ...state,\n complementarySidebarState: state.complementarySidebarState === 'expanded' ? 'collapsed' : 'expanded',\n }));\n } else {\n setInternalValue(nextValue);\n updateState((state) => ({ ...state, complementarySidebarState: 'expanded' }));\n void invokePromise(LayoutOperation.UpdateComplementary, { subject: nextValue });\n }\n },\n [state.complementarySidebarState, activeId, invokePromise, updateState],\n );\n\n const data = useMemo(\n () =>\n activeCompanion && {\n id: activeCompanion.id,\n subject: activeCompanion.data,\n },\n [activeCompanion?.id, activeCompanion?.data],\n );\n\n useEffect(() => {\n if (!activeId) {\n void invokePromise(LayoutOperation.UpdateComplementary, { state: 'collapsed' });\n }\n }, [activeId, invokePromise]);\n\n return (\n <Main.ComplementarySidebar\n label={label}\n classNames={[topbar && 'top-[calc(env(safe-area-inset-top)+var(--dx-rail-size))]']}\n >\n {/* R0 Tabs */}\n <Tabs.Root classNames='contents' orientation='vertical' value={internalValue}>\n <div\n data-tauri-drag-region\n style={iconSize(5)}\n className={mx(\n 'absolute z-1 inset-y-0 end-0 w-(--dx-r0-size)!',\n 'py-[env(safe-area-inset-top)] pb-[env(safe-area-inset-bottom)] border-s border-subdued-separator',\n 'grid grid-cols-1 grid-rows-[1fr_min-content] bg-r0-surface dx-contain-layout dx-app-drag',\n )}\n >\n <Tabs.Tablist classNames='grid grid-cols-1 auto-rows-(--dx-rail-action) overflow-y-auto scrollbar-none gap-1 p-1'>\n {companions.map((companion) => (\n <Tabs.Tab key={getLinkedVariant(companion.id)} value={getLinkedVariant(companion.id)} asChild>\n <IconButton\n classNames='w-(--dx-rail-action) h-(--dx-rail-action) min-h-0 px-0'\n label={toLocalizedString(companion.properties.label, t)}\n icon={companion.properties.icon}\n iconOnly\n tooltipSide='left'\n data-value={getLinkedVariant(companion.id)}\n {...(companion.properties.joyride && { 'data-joyride': companion.properties.joyride })}\n variant={\n activeId === getLinkedVariant(companion.id)\n ? state.complementarySidebarState === 'expanded'\n ? 'primary'\n : 'ghost'\n : 'ghost'\n }\n onClick={handleTabClick}\n />\n </Tabs.Tab>\n ))}\n </Tabs.Tablist>\n <div\n className='grid grid-cols-1 auto-rows-(--dx-rail-item) py-0.5 gap-0.5 overflow-y-auto scrollbar-none'\n style={iconSize(4)}\n >\n <Surface.Surface type={AppSurface.StatusIndicator} />\n </div>\n <div className='hidden lg:grid grid-cols-1 auto-rows-(--dx-rail-action) p-1'>\n <ToggleComplementarySidebarButton />\n </div>\n </div>\n\n {/* R1 Content. */}\n {activeId &&\n companions.map((companion) => (\n <Tabs.Panel\n key={getLinkedVariant(companion.id)}\n value={getLinkedVariant(companion.id)}\n classNames={[\n 'absolute data-[state=\"inactive\"]:-z-[1] overflow-hidden',\n 'inset-y-0 start-0 w-full lg:w-(--dx-r1-size)',\n ]}\n {...(state.complementarySidebarState !== 'expanded' && { inert: true })}\n >\n <ComplementarySidebarPanel companion={companion} activeId={activeId} data={data} />\n </Tabs.Panel>\n ))}\n </Tabs.Root>\n </Main.ComplementarySidebar>\n );\n};\n\ntype ComplementarySidebarPanelProps = {\n companion: DeckCompanion;\n activeId: string;\n data?: {\n id: string;\n subject: any;\n };\n};\n\nconst ComplementarySidebarPanel = ({ companion, activeId, data }: ComplementarySidebarPanelProps) => {\n const { t } = useTranslation(meta.profile.key);\n\n if (getLinkedVariant(companion.id) !== activeId && !data) {\n return null;\n }\n\n return (\n <Panel.Root>\n <Panel.Toolbar asChild size='lg'>\n <Toolbar.Root style={iconSize(5)} classNames='bg-header-surface'>\n <IconButton\n classNames='w-(--dx-rail-action) h-(--dx-rail-action) min-h-0 px-0'\n label={toLocalizedString(companion.properties.label, t)}\n icon={companion.properties.icon}\n iconOnly\n tooltipSide='left'\n data-value={getLinkedVariant(companion.id)}\n variant='default'\n />\n <div className='px-1'>{toLocalizedString(companion.properties.label, t)}</div>\n </Toolbar.Root>\n </Panel.Toolbar>\n <Panel.Content classNames='bg-r1-surface'>\n <Surface.Surface\n type={AppSurface.deckCompanion(getLinkedVariant(companion.id))}\n data={data}\n fallback={PlankErrorFallback}\n placeholder={<PlankLoading />}\n />\n </Panel.Content>\n </Panel.Root>\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { useMemo } from 'react';\n\nimport { Surface } from '@dxos/app-framework/ui';\nimport { AppSurface } from '@dxos/app-toolkit/ui';\nimport { type Label, Main } from '@dxos/react-ui';\n\nimport { useBreakpoints, useDeckState } from '#hooks';\nimport { meta } from '#meta';\nimport { getMode } from '#types';\n\nimport { layoutAppliesTopbar } from '../../util';\n\nconst label = ['sidebar.title', { ns: meta.profile.key }] satisfies Label;\n\nexport const Sidebar = () => {\n const { state, deck } = useDeckState();\n const { popoverAnchorId, activeDeck: current } = state;\n const breakpoint = useBreakpoints();\n const layoutMode = getMode(deck);\n const topbar = layoutAppliesTopbar(breakpoint, layoutMode);\n\n const navigationData = useMemo<AppSurface.NavigationData<{ topbar: boolean }>>(\n () => ({ popoverAnchorId, topbar, current }),\n [popoverAnchorId, topbar, current],\n );\n\n return (\n <Main.NavigationSidebar\n label={label}\n classNames={['grid', topbar && 'top-[calc(env(safe-area-inset-top)+var(--dx-rail-size))]']}\n >\n <Surface.Surface type={AppSurface.Navigation} data={navigationData} limit={1} />\n </Main.NavigationSidebar>\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React, { type PropsWithChildren, useCallback, useEffect, useRef } from 'react';\n\nimport { AttentionCapabilities } from '@dxos/plugin-attention';\nimport { Main, useMediaQuery } from '@dxos/react-ui';\n\nimport { useBreakpoints } from '#hooks';\n\nimport { layoutAppliesTopbar } from '../../util';\nimport { ComplementarySidebar, Sidebar } from '../Sidebar';\nimport { Banner } from './Banner';\nimport { useDeckContext } from './DeckRoot';\n\nconst DECK_CONTENT_NAME = 'DeckContent';\n\nexport type DeckContentProps = PropsWithChildren;\n\nexport const DeckContent = ({ children }: DeckContentProps) => {\n const {\n state: { sidebarState, complementarySidebarState, complementarySidebarPanel },\n deck: { active, fullscreen, solo },\n updateState,\n layoutMode,\n settings,\n pluginManager,\n onLayoutChange,\n } = useDeckContext(DECK_CONTENT_NAME);\n const breakpoint = useBreakpoints();\n const topbar = layoutAppliesTopbar(breakpoint, layoutMode);\n\n // Ensure the first plank is attended when the deck is first rendered.\n useEffect(() => {\n // NOTE: Not `useAttended` so that the layout component is not re-rendered when the attended list changes.\n const attention = pluginManager.capabilities.get(AttentionCapabilities.Attention);\n const attended = attention.getCurrent();\n const firstId = solo ?? active[0];\n if (attended.length === 0 && firstId) {\n // TODO(wittjosiah): Focusing the type button is a workaround.\n // If the plank is directly focused on first load the focus ring appears.\n document.querySelector<HTMLElement>(`article[data-attendable-id=\"${firstId}\"] button`)?.focus();\n }\n }, []);\n\n // Not using `breakpoint` to avoid firing when breakpoint changes between tablet and desktop.\n // `ssr: false` to avoid using fallback values and flashing into solo mode on startup.\n const [isNotMobile] = useMediaQuery('md');\n const shouldRevert = useRef(false);\n useEffect(() => {\n if (!isNotMobile && layoutMode === 'multi') {\n // NOTE: Not `useAttended` so that the layout component is not re-rendered when the attended list changes.\n const attention = pluginManager.capabilities.get(AttentionCapabilities.Attention);\n const attended = attention.getCurrent();\n shouldRevert.current = true;\n onLayoutChange({ subject: attended[0], mode: 'solo' });\n } else if (isNotMobile && layoutMode === 'solo' && shouldRevert.current) {\n onLayoutChange({ revert: true });\n }\n // NOTE: Using `layoutMode` instead of `deck` to avoid infinite loops caused by object reference changes.\n }, [isNotMobile, layoutMode, onLayoutChange]);\n\n // When deck is disabled in settings, set to solo mode if the current layout mode is deck.\n // TODO(thure): Applying this as an effect should be avoided over emitting the operation only when the setting changes.\n useEffect(() => {\n if (!settings?.enableDeck && layoutMode === 'multi') {\n onLayoutChange({ subject: active[0], mode: 'solo' });\n }\n }, [settings?.enableDeck, onLayoutChange, active, layoutMode]);\n\n const handleNavigationSidebarStateChange = useCallback(\n (next: typeof sidebarState) => {\n updateState((s) => ({ ...s, sidebarState: next }));\n },\n [updateState],\n );\n\n const handleComplementarySidebarStateChange = useCallback(\n (next: typeof complementarySidebarState) => {\n updateState((s) => ({ ...s, complementarySidebarState: next }));\n },\n [updateState],\n );\n\n return (\n <Main.Root\n navigationSidebarState={fullscreen ? 'closed' : sidebarState}\n complementarySidebarState={fullscreen ? 'closed' : complementarySidebarState}\n onNavigationSidebarStateChange={handleNavigationSidebarStateChange}\n onComplementarySidebarStateChange={handleComplementarySidebarStateChange}\n >\n <Sidebar />\n <ComplementarySidebar current={complementarySidebarPanel} />\n <Main.Overlay />\n {children}\n {topbar && <Banner variant='topbar' />}\n </Main.Root>\n );\n};\n\nDeckContent.displayName = DECK_CONTENT_NAME;\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Surface } from '@dxos/app-framework/ui';\nimport { AppSurface } from '@dxos/app-toolkit/ui';\nimport { type ThemedClassName, useTranslation } from '@dxos/react-ui';\nimport { mx, osTranslations } from '@dxos/ui-theme';\n\nimport { meta } from '#meta';\nimport { VersionInfo } from '#types';\n\nimport { CloseSidebarButton, ToggleSidebarButton } from '../Sidebar';\n\nexport const Banner = ({ variant, classNames }: ThemedClassName<{ variant?: 'topbar' | 'sidebar' }>) => {\n const { t } = useTranslation(meta.profile.key);\n\n return (\n <header\n className={mx(\n 'flex items-stretch relative py-1 ps-1 pe-2',\n variant === 'topbar' &&\n 'fixed inset-x-0 top-[env(safe-area-inset-top)] h-(--dx-rail-size) border-b border-separator',\n classNames,\n )}\n >\n {variant === 'sidebar' ? <CloseSidebarButton /> : <ToggleSidebarButton />}\n <span className='self-center grow ms-1'>{t('current-app.name', { ns: osTranslations })}</span>\n {variant === 'topbar' && (\n <div className='absolute inset-0 pointer-events-none'>\n <div className='grid h-full pointer-fine:p-1 max-w-md mx-auto pointer-events-auto'>\n <Surface.Surface type={AppSurface.SearchInput} limit={1} />\n </div>\n </div>\n )}\n <span className='grow' />\n <Surface.Surface type={VersionInfo} limit={1} />\n </header>\n );\n};\n", "//\n// Copyright 2026 DXOS.org\n//\n\nimport { createContext } from '@radix-ui/react-context';\nimport React, { PropsWithChildren } from 'react';\n\nimport { type PluginManager } from '@dxos/app-framework';\n\nimport { type LayoutMode, type Settings } from '#types';\n\nimport { type DeckStateHook } from '../../hooks/useDeckState';\n\nconst DECK_NAME = 'Deck';\nconst DECK_ROOT_NAME = 'DeckRoot';\n\n/** Request to change the layout mode. */\nexport type DeckLayoutChangeRequest = { subject?: string; mode: LayoutMode } | { revert: true };\n\n//\n// Context\n//\n\nexport type DeckContextValue = {\n /** Deck plugin settings. */\n settings?: Settings.Settings;\n /** Plugin manager for capability access. */\n pluginManager: PluginManager.PluginManager;\n /** Layout mode. */\n layoutMode: LayoutMode;\n /** Callback for layout mode changes. */\n onLayoutChange: (request: DeckLayoutChangeRequest) => void;\n} & Pick<DeckStateHook, 'state' | 'deck' | 'updateState'>;\n\nexport const [DeckProvider, useDeckContext] = createContext<DeckContextValue>(DECK_NAME);\n\n//\n// Root\n//\n\nexport type DeckRootProps = PropsWithChildren<DeckContextValue>;\n\n/**\n * Headless root that provides Deck context.\n */\nexport const DeckRoot = ({ children, ...context }: DeckRootProps) => {\n return <DeckProvider {...context}>{children}</DeckProvider>;\n};\n\nDeckRoot.displayName = DECK_ROOT_NAME;\n", "//\n// Copyright 2026 DXOS.org\n//\n\nimport React, {\n Fragment,\n memo,\n type PropsWithChildren,\n type UIEvent,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n} from 'react';\n\nimport { Surface, useOperationInvoker } from '@dxos/app-framework/ui';\nimport { LayoutOperation } from '@dxos/app-toolkit';\nimport { useAppGraph } from '@dxos/app-toolkit/ui';\nimport { addEventListener } from '@dxos/async';\nimport { invariant } from '@dxos/invariant';\nimport { useNode } from '@dxos/plugin-graph';\nimport { IconButton, Main, type MainContentProps, useOnTransition, useTranslation } from '@dxos/react-ui';\nimport { mainPaddingTransitions } from '@dxos/react-ui';\nimport { DEFAULT_HORIZONTAL_SIZE, Stack, StackContext } from '@dxos/react-ui-stack';\nimport { hoverableControls, hoverableFocusedWithinControls, mx } from '@dxos/ui-theme';\n\nimport { useBreakpoints, useCompanions, useDeckState, useSelectedCompanion } from '#hooks';\nimport { meta } from '#meta';\nimport { DeckOperation, getMode, Keyshortcuts } from '#types';\n\nimport { layoutAppliesTopbar } from '../../util';\nimport { Plank, PlankRootProps, type PlankComponentProps } from '../Plank';\nimport {\n ToggleComplementarySidebarButton as NaturalToggleComplementarySidebarButton,\n ToggleSidebarButton as NaturalToggleSidebarButton,\n} from '../Sidebar';\nimport { useDeckContext } from './DeckRoot';\n\nconst DECK_VIEWPORT_NAME = 'DeckViewport';\n\n//\n// DeckViewport\n//\n\nexport type DeckViewportProps = PropsWithChildren;\n\n/**\n * Deck viewport that renders the main content area and sets CSS variables for plank sizing.\n */\nexport const DeckViewport = ({ children }: DeckViewportProps) => {\n const {\n deck: { active, plankSizing },\n state: { sidebarState, complementarySidebarState },\n settings,\n layoutMode,\n } = useDeckContext(DECK_VIEWPORT_NAME);\n\n const breakpoint = useBreakpoints();\n const topbar = layoutAppliesTopbar(breakpoint, layoutMode);\n\n return (\n <Main.Content\n bounce\n handlesFocus\n classNames={[\n 'grid top-[env(safe-area-inset-top)]!',\n topbar && 'top-[calc(env(safe-area-inset-top)+var(--dx-rail-size))]!',\n ]}\n style={\n {\n '--main-spacing': settings?.encapsulatedPlanks ? '0.75rem' : '0',\n '--main-sidebar-width':\n sidebarState === 'expanded'\n ? 'var(--dx-nav-sidebar-size)'\n : sidebarState === 'collapsed'\n ? 'var(--dx-l0-size)'\n : '0',\n '--main-complementary-width':\n complementarySidebarState === 'expanded'\n ? 'var(--dx-complementary-sidebar-size)'\n : complementarySidebarState === 'collapsed'\n ? 'var(--dx-rail-size)'\n : '0',\n '--main-content-first-width': `${plankSizing[active[0] ?? 'never'] ?? DEFAULT_HORIZONTAL_SIZE}rem`,\n '--main-content-last-width': `${plankSizing[active[(active.length ?? 1) - 1] ?? 'never'] ?? DEFAULT_HORIZONTAL_SIZE}rem`,\n } as MainContentProps['style']\n }\n >\n {children}\n </Main.Content>\n );\n};\n\nDeckViewport.displayName = DECK_VIEWPORT_NAME;\n\n//\n// ContentEmpty\n//\n\nexport const DeckContentEmpty = () => {\n const breakpoint = useBreakpoints();\n const { deck } = useDeckState();\n const layoutMode = getMode(deck);\n const topbar = layoutAppliesTopbar(breakpoint, layoutMode);\n return (\n <div className='grid place-items-center p-8 relative bg-deck-surface' data-testid='layoutPlugin.firstRunMessage'>\n <Surface.Surface type={Keyshortcuts} />\n {!topbar && <ToggleSidebarButton />}\n </div>\n );\n};\n\n//\n// DeckSoloMode\n//\n\n/**\n * Single-plank layout with optional companion.\n */\nexport const DeckSoloMode = () => {\n const { deck, settings, layoutMode, onLayoutChange } = useDeckContext('DeckSoloMode');\n const { companionOpen, companionVariant, fullscreen, solo } = deck;\n const effectiveCompanionVariant = fullscreen ? undefined : companionOpen ? companionVariant : undefined;\n const breakpoint = useBreakpoints();\n const topbar = layoutAppliesTopbar(breakpoint, layoutMode);\n invariant(solo);\n\n useEffect(() => {\n if (!fullscreen) {\n return;\n }\n\n const handleKeyDown = (event: globalThis.KeyboardEvent) => {\n if (event.key === 'Escape') {\n event.preventDefault();\n event.stopPropagation();\n onLayoutChange({ mode: 'solo--fullscreen' });\n }\n };\n\n document.addEventListener('keydown', handleKeyDown);\n return () => document.removeEventListener('keydown', handleKeyDown);\n }, [fullscreen, onLayoutChange]);\n\n return (\n <div className='relative overflow-hidden bg-deck-surface'>\n <DeckSidebarToggles topbar={topbar} fullscreen={fullscreen} />\n {fullscreen && <ExitFullscreenButton onExit={() => onLayoutChange({ mode: 'solo--fullscreen' })} />}\n <StackContext.Provider\n value={{\n orientation: 'horizontal',\n size: 'contain',\n rail: true,\n }}\n >\n <PlankContainer\n id={solo}\n part='solo'\n layoutMode={layoutMode}\n companionVariant={effectiveCompanionVariant}\n settings={settings}\n />\n </StackContext.Provider>\n </div>\n );\n};\n\n//\n// DeckMultiMode\n//\n\n/**\n * Multi-plank horizontal scrolling layout.\n */\nexport const DeckMultiMode = () => {\n const {\n deck: { active, companionVariant, fullscreen },\n settings,\n layoutMode,\n } = useDeckContext('DeckMultiMode');\n /** In multi mode the companion column is always shown when the last plank has companions (not gated by `companionOpen`). */\n const effectiveCompanionVariant = companionVariant;\n const lastPlankId = active[active.length - 1];\n const lastPlankCompanions = useCompanions(lastPlankId);\n const breakpoint = useBreakpoints();\n const topbar = layoutAppliesTopbar(breakpoint, layoutMode);\n const deckRef = useRef<HTMLDivElement>(null);\n\n /** Clear scroll restoration state if the window is resized. */\n const scrollLeftRef = useRef<number>(null);\n useEffect(\n () =>\n addEventListener(window, 'resize', () => {\n scrollLeftRef.current = null;\n }),\n [],\n );\n\n const restoreScroll = useCallback(() => {\n if (deckRef.current && scrollLeftRef.current != null) {\n deckRef.current.scrollLeft = scrollLeftRef.current;\n }\n }, []);\n\n useOnTransition(layoutMode, (mode) => mode !== 'multi', 'multi', restoreScroll);\n\n /** Save scroll position as the user scrolls. */\n const handleScroll = useCallback((event: UIEvent) => {\n if (event.currentTarget === event.target) {\n scrollLeftRef.current = (event.target as HTMLDivElement).scrollLeft;\n }\n }, []);\n\n // Create order map.\n // In multi mode only the last plank hosts the companion pane, so only that plank adds the extra column.\n const { order, itemsCount } = useMemo(() => {\n const lastHasCompanions = lastPlankCompanions.length > 0;\n return active.reduce(\n (acc: { order: Record<string, number>; itemsCount: number }, entryId, index) => {\n const isLastPlank = index === active.length - 1;\n acc.order[entryId] = acc.itemsCount + 1;\n acc.itemsCount += lastHasCompanions && isLastPlank ? 3 : 2;\n return acc;\n },\n { order: {}, itemsCount: 0 },\n );\n }, [active, lastPlankCompanions.length]);\n\n return (\n <div className='relative bg-deck-surface overflow-hidden'>\n <DeckSidebarToggles topbar={topbar} fullscreen={fullscreen} />\n <Stack\n classNames={[\n 'absolute h-[calc(100%-2*var(--main-spacing))] w-full inset-y-(--main-spacing) -inset-w-px',\n mainPaddingTransitions,\n ]}\n orientation='horizontal'\n size='contain'\n itemsCount={itemsCount - 1}\n onScroll={handleScroll}\n ref={deckRef}\n >\n {active.map((entryId) => (\n <Fragment key={entryId}>\n {/* TODO(burdon): Setting for separator. */}\n <PlankSeparator hidden order={order[entryId] - 1} encapsulate={!!settings?.encapsulatedPlanks} />\n <PlankContainer\n id={entryId}\n part='multi'\n active={active}\n order={order[entryId]}\n layoutMode={layoutMode}\n companionVariant={effectiveCompanionVariant}\n settings={settings}\n />\n </Fragment>\n ))}\n </Stack>\n </div>\n );\n};\n\n//\n// SidebarToggles\n//\n\nconst sidebarToggleStyles = 'h-(--dx-rail-item) w-(--dx-rail-item) absolute bottom-2 z-[1] bg-deck-surface! lg:hidden';\n\nconst ToggleSidebarButton = () => <NaturalToggleSidebarButton classNames={mx(sidebarToggleStyles, 'left-2')} />;\nconst ToggleComplementarySidebarButton = () => (\n <NaturalToggleComplementarySidebarButton classNames={mx(sidebarToggleStyles, 'right-2')} />\n);\n\nconst ExitFullscreenButton = ({ onExit }: { onExit: () => void }) => {\n const { t } = useTranslation(meta.profile.key);\n return (\n <div\n className={mx(\n 'fixed top-2 right-2 z-[1]',\n hoverableControls,\n hoverableFocusedWithinControls,\n 'transition-opacity opacity-(--controls-opacity)',\n )}\n >\n <IconButton\n label={t('exit-fullscreen.label')}\n icon='ph--corners-in--regular'\n iconOnly\n variant='ghost'\n tooltipSide='bottom'\n onClick={onExit}\n />\n </div>\n );\n};\n\nconst DeckSidebarToggles = ({ topbar, fullscreen }: { topbar: boolean; fullscreen: boolean }) => {\n if (topbar || fullscreen) {\n return null;\n }\n\n return (\n <>\n <ToggleSidebarButton />\n <ToggleComplementarySidebarButton />\n </>\n );\n};\n\n//\n// PlankSeparator\n//\n\nconst PlankSeparator = ({ order, hidden, encapsulate }: { order: number; hidden?: boolean; encapsulate?: boolean }) =>\n order > 0 && (\n <span\n role='separator'\n className={mx('row-span-2 bg-deck-surface', hidden && 'hidden', encapsulate ? 'w-0' : 'w-4')}\n style={{ gridColumn: order }}\n />\n );\n\n//\n// PlankContainer\n//\n\ntype PlankContainerProps = Pick<PlankRootProps, 'layoutMode' | 'part' | 'settings'> &\n Pick<PlankComponentProps, 'id'> &\n Partial<Pick<PlankComponentProps, 'path' | 'order' | 'active'>> & {\n companionVariant?: string;\n };\n\n/**\n * Connected Plank that calls hooks and renders the radix-style Plank tree.\n * This is the bridge between DeckViewport (which knows about framework hooks) and\n * the pure Plank components (which receive everything via context).\n */\nconst PlankContainer = memo(\n ({ id, layoutMode, part, order, settings, companionVariant, active, ...props }: PlankContainerProps) => {\n const { graph } = useAppGraph();\n const { invokePromise } = useOperationInvoker();\n const { state, deck } = useDeckState();\n const node = useNode(graph, id);\n const companions = useCompanions(id);\n const isLastPlankInMulti =\n layoutMode === 'multi' && active && active.length > 0 && active[active.length - 1] === id;\n const variantForThisPlank =\n layoutMode === 'multi' ? (isLastPlankInMulti ? companionVariant : undefined) : companionVariant;\n const { companionId } = useSelectedCompanion(companions, variantForThisPlank);\n const resolvedCompanionId =\n layoutMode === 'multi' && isLastPlankInMulti && companions.length > 0\n ? companionId\n : variantForThisPlank\n ? companionId\n : undefined;\n const currentCompanion = companions.find(({ id }) => id === resolvedCompanionId);\n const hasCompanion = !!(resolvedCompanionId && currentCompanion);\n\n const handleAdjust = useCallback(\n (plankId: string, type: DeckOperation.PartAdjustment) => {\n if (type === 'close') {\n if (part === 'complementary') {\n return invokePromise(LayoutOperation.UpdateComplementary, { state: 'collapsed' });\n } else if (active) {\n // Close the plank and everything to the right (stack pop).\n const index = active.indexOf(plankId);\n const toClose = index !== -1 ? active.slice(index) : [plankId];\n return invokePromise(LayoutOperation.Close, { subject: toClose });\n } else {\n return invokePromise(LayoutOperation.Close, { subject: [plankId] });\n }\n } else {\n return invokePromise(DeckOperation.Adjust, { type, id: plankId });\n }\n },\n [invokePromise, part, active],\n );\n\n const handleResize = useCallback(\n (plankId: string, size: number) => invokePromise(DeckOperation.UpdatePlankSize, { id: plankId, size }),\n [invokePromise],\n );\n\n const handleScrollIntoView = useCallback(\n (subject?: string) => invokePromise(LayoutOperation.ScrollIntoView, { subject }),\n [invokePromise],\n );\n\n const handleUpdateCompanion = useCallback(\n (companion: string | null) => invokePromise(LayoutOperation.UpdateCompanion, { subject: companion }),\n [invokePromise],\n );\n\n return (\n <Plank.Root\n graph={graph}\n layoutMode={layoutMode}\n part={part}\n settings={settings}\n popoverAnchorId={state.popoverAnchorId}\n scrollIntoView={state.scrollIntoView}\n plankSizing={deck.plankSizing}\n onAdjust={handleAdjust}\n onResize={handleResize}\n onScrollIntoView={handleScrollIntoView}\n onUpdateCompanion={handleUpdateCompanion}\n >\n <Plank.Content solo={part === 'solo'} companion={hasCompanion} encapsulate={!!settings?.encapsulatedPlanks}>\n <Plank.Component\n {...props}\n active={active}\n id={id}\n node={node}\n companioned={hasCompanion ? 'primary' : undefined}\n companions={hasCompanion ? [] : companions}\n order={order}\n {...(part === 'solo'\n ? {\n part: 'solo-primary',\n }\n : {\n part,\n })}\n />\n {hasCompanion && (\n <Plank.Component\n {...props}\n active={active}\n id={resolvedCompanionId}\n node={currentCompanion}\n companions={companions}\n companioned='companion'\n primary={node}\n {...(part === 'solo'\n ? {\n order,\n part: 'solo-companion',\n }\n : {\n order: (order ?? 0) + 1,\n part,\n })}\n />\n )}\n </Plank.Content>\n </Plank.Root>\n );\n },\n);\n", "//\n// Copyright 2026 DXOS.org\n//\n\nimport { DeckContent, DeckContentProps } from './DeckContent';\nimport { DeckRoot, DeckLayoutChangeRequest, DeckRootProps } from './DeckRoot';\nimport { DeckViewport, DeckMultiMode, DeckSoloMode, DeckViewportProps, DeckContentEmpty } from './DeckViewport';\n\n/**\n * Radix-style composite Deck component.\n */\nexport const Deck = {\n Root: DeckRoot,\n Content: DeckContent,\n Viewport: DeckViewport,\n ContentEmpty: DeckContentEmpty,\n MultiMode: DeckMultiMode,\n SoloMode: DeckSoloMode,\n};\n\nexport type { DeckLayoutChangeRequest, DeckRootProps, DeckContentProps, DeckViewportProps };\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["React", "PlankLoading", "div", "className", "React", "useEffect", "useMemo", "useState", "TimeoutError", "log", "ErrorFallback", "useTranslation", "descriptionMessage", "mx", "meta", "React", "Fragment", "memo", "useCallback", "useEffect", "useMemo", "Surface", "AppSurface", "Graph", "useActionRunner", "Icon", "IconButton", "Popover", "TextTooltip", "toLocalizedString", "useTranslation", "getLinkedVariant", "StackItem", "hoverableControls", "hoverableFocusedWithinControls", "iconSize", "useBreakpoints", "meta", "PLANK_COMPANION_TYPE", "React", "forwardRef", "useCallback", "useOperationInvoker", "LayoutOperation", "ButtonGroup", "IconButton", "useTranslation", "meta", "plankControlSpacing", "PlankCompanionControls", "primary", "forwardedRef", "t", "profile", "key", "invokePromise", "handleCloseCompanion", "UpdateCompanion", "subject", "div", "ref", "className", "PlankControl", "label", "variant", "icon", "onClick", "classNames", "props", "iconOnly", "tooltipSide", "PlankControls", "children", "capabilities", "layoutMode", "pin", "close", "buttonClassNames", "layoutIsAnySolo", "startsWith", "deck", "solo", "disabled", "incrementStart", "incrementEnd", "fullscreen", "data-testid", "companion", "createContext", "React", "PLANK_NAME", "PlankProvider", "usePlankContext", "PlankRoot", "children", "context", "MAX_COMPANIONS", "PlankHeading", "memo", "id", "part", "node", "deckEnabled", "canIncrementStart", "canIncrementEnd", "popoverAnchorId", "primaryId", "pending", "companioned", "companions", "layoutMode", "actions", "debug", "t", "useTranslation", "meta", "profile", "key", "graph", "onAdjust", "onUpdateCompanion", "usePlankContext", "runAction", "useActionRunner", "breakpoint", "useBreakpoints", "icon", "properties", "label", "toLocalizedString", "ns", "isCompanionNode", "type", "PLANK_COMPANION_TYPE", "useEffect", "frame", "requestAnimationFrame", "Graph", "expand", "cancelAnimationFrame", "attendableId", "capabilities", "useMemo", "deck", "solo", "incrementStart", "incrementEnd", "fullscreen", "companion", "length", "variant", "getLinkedVariant", "undefined", "sigilActions", "getActions", "filter", "action", "includes", "disposition", "a", "handleAction", "useCallback", "data", "parent", "caller", "handlePlankAction", "eventType", "ActionRoot", "Popover", "Anchor", "Fragment", "handleTabClick", "event", "target", "closest", "tabId", "dataset", "React", "StackItem", "Heading", "data-tauri-drag-region", "data-plank-heading", "style", "iconSize", "classNames", "hoverableControls", "hoverableFocusedWithinControls", "div", "className", "map", "IconButton", "data-id", "iconOnly", "onClick", "Sigil", "related", "triggerLabel", "onAction", "Surface", "AppSurface", "MenuFooter", "subject", "SigilButton", "span", "Icon", "TextTooltip", "text", "onlyWhenTruncating", "HeadingLabel", "NavbarEnd", "PlankCompanionControls", "primary", "PlankControls", "close", "PlankError", "useEffect", "timer", "setTimeout", "setTimedOut", "error", "useMemo", "TimeoutError", "message", "timedOut", "part", "node", "pending", "React", "PlankLoading", "meta", "log", "process", "title", "role", "className", "p", "mx", "errorString", "useFocusFinders", "React", "memo", "useCallback", "useLayoutEffect", "useMemo", "useRef", "Surface", "AppSurface", "debounce", "mainIntrinsicSize", "getLinkedVariant", "useAttentionAttributes", "StackItem", "railGridHorizontal", "mx", "useMainSize", "PLANK_COMPANION_TYPE", "smoothScrollTo", "element", "target", "duration", "start", "scrollLeft", "distance", "startTime", "performance", "now", "step", "currentTime", "elapsed", "progress", "Math", "min", "eased", "pow", "requestAnimationFrame", "DEFAULT_SIZE", "DEFAULT_COMPANION_SIZE", "PlankComponent", "memo", "part", "id", "path", "order", "active", "node", "primary", "companions", "companioned", "layoutMode", "settings", "popoverAnchorId", "scrollIntoView", "plankSizing", "onResize", "onScrollIntoView", "usePlankContext", "canResize", "findFirstFocusable", "useFocusFinders", "isCompanion", "attentionId", "attentionAttrs", "useAttentionAttributes", "orderId", "index", "findIndex", "entryId", "length", "isOrdered", "canIncrementStart", "canIncrementEnd", "rootElement", "useRef", "variant", "type", "PLANK_COMPANION_TYPE", "getLinkedVariant", "undefined", "sizeAttrs", "useMainSize", "sizeKey", "split", "size", "handleSizeChange", "useCallback", "debounce", "nextSize", "round", "handleKeyDown", "event", "currentTarget", "key", "current", "closest", "focus", "useLayoutEffect", "scrollParent", "elementRect", "getBoundingClientRect", "parentRect", "targetScrollLeft", "left", "isSolo", "startsWith", "isAttendable", "attendableId", "data", "useMemo", "subject", "companionTo", "properties", "placeholder", "React", "PlankLoading", "Root", "StackItem", "fullscreen", "classNames", "mainIntrinsicSize", "railGridHorizontal", "encapsulatedPlanks", "ref", "data-testid", "data-popover-collision-boundary", "tabIndex", "className", "mx", "role", "item", "onSizeChange", "onKeyDown", "PlankHeading", "deckEnabled", "enableDeck", "primaryId", "Surface", "AppSurface", "Article", "limit", "fallback", "PlankErrorFallback", "PlankError", "ResizeHandle", "React", "composable", "composableProps", "mainIntrinsicSize", "railGridHorizontal", "useMainSize", "PlankContent", "children", "solo", "companion", "encapsulate", "props", "forwardedRef", "sizeAttrs", "div", "role", "classNames", "data-popover-collision-boundary", "ref", "Plank", "Root", "PlankRoot", "Content", "PlankContent", "Component", "PlankComponent", "Heading", "PlankHeading", "Controls", "PlankControls", "React", "useCallback", "useOperationInvoker", "LayoutOperation", "IconButton", "useTranslation", "getLinkedVariant", "useDeckCompanions", "useDeckState", "meta", "ToggleSidebarButton", "classNames", "variant", "updateState", "t", "profile", "key", "handleClick", "state", "sidebarState", "icon", "iconOnly", "size", "label", "onClick", "CloseSidebarButton", "ToggleComplementarySidebarButton", "inR0", "current", "invokePromise", "companions", "nextState", "complementarySidebarState", "subject", "complementarySidebarPanel", "id", "UpdateComplementary", "tooltipSide", "undefined", "React", "useCallback", "useEffect", "useMemo", "useState", "Surface", "useOperationInvoker", "LayoutOperation", "AppSurface", "IconButton", "Main", "Panel", "toLocalizedString", "Toolbar", "useTranslation", "getLinkedVariant", "Tabs", "iconSize", "mx", "useBreakpoints", "useDeckCompanions", "useDeckState", "meta", "getMode", "label", "ns", "meta", "profile", "key", "ComplementarySidebar", "current", "invokePromise", "useOperationInvoker", "t", "useTranslation", "state", "deck", "updateState", "useDeckState", "layoutMode", "getMode", "breakpoint", "useBreakpoints", "topbar", "layoutAppliesTopbar", "companions", "useDeckCompanions", "activeCompanion", "find", "companion", "getLinkedVariant", "id", "activeId", "internalValue", "setInternalValue", "useState", "useEffect", "handleTabClick", "useCallback", "event", "nextValue", "currentTarget", "getAttribute", "complementarySidebarState", "LayoutOperation", "UpdateComplementary", "subject", "data", "useMemo", "React", "Main", "classNames", "Tabs", "Root", "orientation", "value", "div", "data-tauri-drag-region", "style", "iconSize", "className", "mx", "Tablist", "map", "Tab", "asChild", "IconButton", "toLocalizedString", "properties", "icon", "iconOnly", "tooltipSide", "data-value", "joyride", "variant", "onClick", "Surface", "type", "AppSurface", "StatusIndicator", "ToggleComplementarySidebarButton", "Panel", "inert", "ComplementarySidebarPanel", "Toolbar", "size", "Content", "deckCompanion", "fallback", "PlankErrorFallback", "placeholder", "PlankLoading", "React", "useMemo", "Surface", "AppSurface", "Main", "useBreakpoints", "useDeckState", "meta", "getMode", "label", "ns", "meta", "profile", "key", "Sidebar", "state", "deck", "useDeckState", "popoverAnchorId", "activeDeck", "current", "breakpoint", "useBreakpoints", "layoutMode", "getMode", "topbar", "layoutAppliesTopbar", "navigationData", "useMemo", "React", "Main", "NavigationSidebar", "classNames", "Surface", "type", "AppSurface", "Navigation", "data", "limit", "React", "useCallback", "useEffect", "useRef", "AttentionCapabilities", "Main", "useMediaQuery", "useBreakpoints", "React", "Surface", "AppSurface", "useTranslation", "mx", "osTranslations", "meta", "VersionInfo", "Banner", "variant", "classNames", "t", "useTranslation", "meta", "profile", "key", "React", "header", "className", "mx", "CloseSidebarButton", "ToggleSidebarButton", "span", "ns", "osTranslations", "div", "Surface", "type", "AppSurface", "SearchInput", "limit", "VersionInfo", "createContext", "React", "DECK_NAME", "DECK_ROOT_NAME", "DeckProvider", "useDeckContext", "DeckRoot", "children", "context", "displayName", "DECK_CONTENT_NAME", "DeckContent", "children", "state", "sidebarState", "complementarySidebarState", "complementarySidebarPanel", "deck", "active", "fullscreen", "solo", "updateState", "layoutMode", "settings", "pluginManager", "onLayoutChange", "useDeckContext", "breakpoint", "useBreakpoints", "topbar", "layoutAppliesTopbar", "useEffect", "attention", "capabilities", "get", "AttentionCapabilities", "Attention", "attended", "getCurrent", "firstId", "length", "document", "querySelector", "focus", "isNotMobile", "useMediaQuery", "shouldRevert", "useRef", "current", "subject", "mode", "revert", "enableDeck", "handleNavigationSidebarStateChange", "useCallback", "next", "s", "handleComplementarySidebarStateChange", "React", "Main", "Root", "navigationSidebarState", "onNavigationSidebarStateChange", "onComplementarySidebarStateChange", "Sidebar", "ComplementarySidebar", "Overlay", "Banner", "variant", "displayName", "React", "Fragment", "memo", "useCallback", "useEffect", "useMemo", "useRef", "Surface", "useOperationInvoker", "LayoutOperation", "useAppGraph", "addEventListener", "invariant", "useNode", "IconButton", "Main", "useOnTransition", "useTranslation", "mainPaddingTransitions", "DEFAULT_HORIZONTAL_SIZE", "Stack", "StackContext", "hoverableControls", "hoverableFocusedWithinControls", "mx", "useBreakpoints", "useCompanions", "useDeckState", "useSelectedCompanion", "meta", "DeckOperation", "getMode", "Keyshortcuts", "__dxlog_file", "DECK_VIEWPORT_NAME", "breakpoint", "useBreakpoints", "topbar", "layoutAppliesTopbar", "layoutMode", "bounce", "handlesFocus", "classNames", "style", "complementarySidebarState", "plankSizing", "DEFAULT_HORIZONTAL_SIZE", "length", "children", "DeckViewport", "displayName", "deck", "useDeckState", "getMode", "className", "React", "type", "Keyshortcuts", "Surface", "ToggleSidebarButton", "companionOpen", "companionVariant", "effectiveCompanionVariant", "fullscreen", "undefined", "invariant", "solo", "useEffect", "preventDefault", "event", "stopPropagation", "onLayoutChange", "mode", "document", "DeckSidebarToggles", "onExit", "value", "orientation", "size", "rail", "id", "settings", "lastPlankId", "active", "deckRef", "useRef", "addEventListener", "restoreScroll", "useCallback", "current", "scrollLeftRef", "useOnTransition", "currentTarget", "scrollLeft", "acc", "entryId", "index", "itemsCount", "lastHasCompanions", "isLastPlank", "order", "mainPaddingTransitions", "onScroll", "ref", "key", "PlankSeparator", "hidden", "encapsulate", "sidebarToggleStyles", "ToggleComplementarySidebarButton", "ExitFullscreenButton", "meta", "IconButton", "label", "mx", "hoverableControls", "hoverableFocusedWithinControls", "iconOnly", "variant", "tooltipSide", "onClick", "gridColumn", "useOperationInvoker", "state", "node", "graph", "companions", "useCompanions", "isLastPlankInMulti", "variantForThisPlank", "useSelectedCompanion", "resolvedCompanionId", "companionId", "currentCompanion", "hasCompanion", "handleAdjust", "plankId", "invokePromise", "LayoutOperation", "part", "popoverAnchorId", "scrollIntoView", "onAdjust", "onResize", "handleResize", "onScrollIntoView", "onUpdateCompanion", "companioned", "primary", "Deck", "Root", "DeckRoot", "Content", "DeckContent", "Viewport", "DeckViewport", "ContentEmpty", "DeckContentEmpty", "MultiMode", "DeckMultiMode", "SoloMode", "DeckSoloMode"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
// src/meta.ts
|
|
2
|
+
import { Plugin } from "@dxos/app-framework";
|
|
3
|
+
|
|
4
|
+
// dx.config.ts
|
|
5
|
+
import { Config2 } from "@dxos/app-framework/config";
|
|
6
|
+
import { trim } from "@dxos/util";
|
|
7
|
+
var dx_config_default = Config2.make({
|
|
8
|
+
plugin: {
|
|
9
|
+
key: "org.dxos.plugin.deck",
|
|
10
|
+
name: "Layout",
|
|
11
|
+
author: "DXOS",
|
|
12
|
+
description: trim`
|
|
13
|
+
The Deck plugin is the core layout engine for DXOS Composer. It manages the multi-plank
|
|
14
|
+
workspace (the "deck"), sidebar panels, dialogs, popovers, and toast notifications, giving
|
|
15
|
+
users a flexible, persistent workspace they can arrange to match their workflow.
|
|
16
|
+
|
|
17
|
+
In multi mode, subjects are opened as resizable "planks" arranged side by side. Users can
|
|
18
|
+
navigate with stack semantics — opening from a pivot truncates planks to the right and
|
|
19
|
+
appends the new one — or switch to solo or fullscreen mode for focused, distraction-free
|
|
20
|
+
viewing.
|
|
21
|
+
|
|
22
|
+
Layout state (active planks, sidebar visibility, plank sizes, companion pane) is persisted
|
|
23
|
+
across sessions via KVS/localStorage. URL routing is handled by the plugin so that any
|
|
24
|
+
workspace configuration can be bookmarked or shared as a deep link.
|
|
25
|
+
|
|
26
|
+
All layout changes are expressed through typed LayoutOperations (Open, Close, SetLayoutMode,
|
|
27
|
+
UpdateSidebar, UpdateDialog, UpdatePopover, etc.) that any plugin in the system can dispatch,
|
|
28
|
+
keeping the layout logic centralised and easy to extend.
|
|
29
|
+
`,
|
|
30
|
+
icon: {
|
|
31
|
+
key: "ph--layout--regular"
|
|
32
|
+
},
|
|
33
|
+
spec: "PLUGIN.mdl",
|
|
34
|
+
tags: [
|
|
35
|
+
"system"
|
|
36
|
+
]
|
|
37
|
+
}
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
// src/meta.ts
|
|
41
|
+
var meta = Plugin.getMetaFromConfig(dx_config_default);
|
|
42
|
+
|
|
43
|
+
export {
|
|
44
|
+
meta
|
|
45
|
+
};
|
|
46
|
+
//# sourceMappingURL=chunk-KY7LMF4D.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/meta.ts", "../../../dx.config.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { Plugin } from '@dxos/app-framework';\n\nimport config from '../dx.config';\n\nexport const meta = Plugin.getMetaFromConfig(config);\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Config2 } from '@dxos/app-framework/config';\nimport { trim } from '@dxos/util';\n\nexport default Config2.make({\n plugin: {\n key: 'org.dxos.plugin.deck',\n name: 'Layout',\n author: 'DXOS',\n description: trim`\n The Deck plugin is the core layout engine for DXOS Composer. It manages the multi-plank\n workspace (the \"deck\"), sidebar panels, dialogs, popovers, and toast notifications, giving\n users a flexible, persistent workspace they can arrange to match their workflow.\n\n In multi mode, subjects are opened as resizable \"planks\" arranged side by side. Users can\n navigate with stack semantics — opening from a pivot truncates planks to the right and\n appends the new one — or switch to solo or fullscreen mode for focused, distraction-free\n viewing.\n\n Layout state (active planks, sidebar visibility, plank sizes, companion pane) is persisted\n across sessions via KVS/localStorage. URL routing is handled by the plugin so that any\n workspace configuration can be bookmarked or shared as a deep link.\n\n All layout changes are expressed through typed LayoutOperations (Open, Close, SetLayoutMode,\n UpdateSidebar, UpdateDialog, UpdatePopover, etc.) that any plugin in the system can dispatch,\n keeping the layout logic centralised and easy to extend.\n `,\n icon: { key: 'ph--layout--regular' },\n spec: 'PLUGIN.mdl',\n tags: ['system'],\n },\n});\n"],
|
|
5
|
+
"mappings": ";AAIA,SAASA,cAAc;;;ACAvB,SAASC,eAAe;AACxB,SAASC,YAAY;AAErB,IAAA,oBAAeD,QAAQE,KAAK;EAC1BC,QAAQ;IACNC,KAAK;IACLC,MAAM;IACNC,QAAQ;IACRC,aAAaN;;;;;;;;;;;;;;;;;;IAkBbO,MAAM;MAAEJ,KAAK;IAAsB;IACnCK,MAAM;IACNC,MAAM;MAAC;;EACT;AACF,CAAA;;;AD1BO,IAAMC,OAAOC,OAAOC,kBAAkBC,iBAAAA;",
|
|
6
|
+
"names": ["Plugin", "Config2", "trim", "make", "plugin", "key", "name", "author", "description", "icon", "spec", "tags", "meta", "Plugin", "getMetaFromConfig", "config"]
|
|
7
|
+
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
// src/capabilities/check-app-scheme.ts
|
|
2
2
|
import * as Effect from "effect/Effect";
|
|
3
3
|
import { Capabilities, Capability } from "@dxos/app-framework";
|
|
4
|
-
import {
|
|
4
|
+
import { AppCapabilities, LayoutOperation, NativePasskey } from "@dxos/app-toolkit";
|
|
5
5
|
import { EffectEx } from "@dxos/effect";
|
|
6
6
|
import { isTauri } from "@dxos/util";
|
|
7
7
|
import { DeckCapabilities } from "#types";
|
|
@@ -13,7 +13,7 @@ var isSafari = () => {
|
|
|
13
13
|
};
|
|
14
14
|
var canRedirectToScheme = () => {
|
|
15
15
|
try {
|
|
16
|
-
const schemeUrl = APP_SCHEME + window.location.pathname.replace(/^\/+/, "") + window.location.search;
|
|
16
|
+
const schemeUrl = NativePasskey.APP_SCHEME + window.location.pathname.replace(/^\/+/, "") + window.location.search;
|
|
17
17
|
new URL(schemeUrl);
|
|
18
18
|
return true;
|
|
19
19
|
} catch {
|
|
@@ -41,7 +41,7 @@ var tryOpenNativeApp = () => {
|
|
|
41
41
|
};
|
|
42
42
|
window.addEventListener("blur", onBlur);
|
|
43
43
|
document.addEventListener("visibilitychange", onVisibilityChange);
|
|
44
|
-
const schemeUrl = APP_SCHEME + window.location.pathname.replace(/^\/+/, "") + window.location.search;
|
|
44
|
+
const schemeUrl = NativePasskey.APP_SCHEME + window.location.pathname.replace(/^\/+/, "") + window.location.search;
|
|
45
45
|
const iframe = document.createElement("iframe");
|
|
46
46
|
iframe.style.display = "none";
|
|
47
47
|
iframe.src = schemeUrl;
|
|
@@ -98,4 +98,4 @@ export {
|
|
|
98
98
|
shouldDeferNavigationHandlers,
|
|
99
99
|
check_app_scheme_default
|
|
100
100
|
};
|
|
101
|
-
//# sourceMappingURL=chunk-
|
|
101
|
+
//# sourceMappingURL=chunk-KZFJ4PBT.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/capabilities/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 { AppCapabilities, LayoutOperation, NativePasskey } from '@dxos/app-toolkit';\nimport { EffectEx } from '@dxos/effect';\nimport { isTauri } from '@dxos/util';\n\nimport { DeckCapabilities } from '#types';\n\n/** Identifier for the native redirect dialog surface (defined in welcome plugin). */\nconst NATIVE_REDIRECT_DIALOG = 'org.dxos.plugin.welcome.component.native-redirect-dialog';\n\nconst SCHEME_TIMEOUT_MS = 500;\n\nconst isSafari = (): boolean => {\n const ua = navigator.userAgent;\n return ua.includes('Safari') && !ua.includes('Chrome') && !ua.includes('Chromium');\n};\n\n/** Check if the current page URL can be converted to a valid custom scheme URL. */\nconst canRedirectToScheme = (): boolean => {\n try {\n const schemeUrl = NativePasskey.APP_SCHEME + window.location.pathname.replace(/^\\/+/, '') + window.location.search;\n new URL(schemeUrl);\n return true;\n } catch {\n return false;\n }\n};\n\n/**\n * Try to open the native app via custom scheme.\n * Resolves `true` if the app opened (page lost focus), `false` if it didn't within the timeout.\n */\nconst tryOpenNativeApp = (): Promise<boolean> => {\n return new Promise((resolve) => {\n let resolved = false;\n\n const onBlur = () => {\n if (!resolved) {\n resolved = true;\n cleanup();\n resolve(true);\n }\n };\n\n const cleanup = () => {\n window.removeEventListener('blur', onBlur);\n document.removeEventListener('visibilitychange', onVisibilityChange);\n };\n\n const onVisibilityChange = () => {\n if (document.hidden) {\n onBlur();\n }\n };\n\n window.addEventListener('blur', onBlur);\n document.addEventListener('visibilitychange', onVisibilityChange);\n\n // Try the scheme via hidden iframe.\n const schemeUrl = NativePasskey.APP_SCHEME + window.location.pathname.replace(/^\\/+/, '') + window.location.search;\n const iframe = document.createElement('iframe');\n iframe.style.display = 'none';\n iframe.src = schemeUrl;\n document.body.appendChild(iframe);\n setTimeout(() => iframe.remove(), 3000);\n\n // If no blur within timeout, the app isn't running.\n setTimeout(() => {\n if (!resolved) {\n resolved = true;\n cleanup();\n resolve(false);\n }\n }, SCHEME_TIMEOUT_MS);\n });\n};\n\n/** Dispatch all NavigationHandler contributions with the current page URL. */\nconst dispatchNavigationHandlers = Effect.fn(function* () {\n const url = new URL(window.location.href);\n const handlers = yield* Capability.getAll(AppCapabilities.NavigationHandler);\n yield* Effect.all(\n handlers.map((handler) => handler(url)),\n { concurrency: 'unbounded' },\n );\n});\n\n/**\n * Checks whether the native redirect setting is enabled and the redirect should be attempted.\n * Exported for the URL handler to decide whether to defer NavigationHandler dispatch.\n */\nexport const shouldDeferNavigationHandlers = (): boolean => {\n return !isTauri() && !isSafari() && !import.meta.env.DEV && canRedirectToScheme();\n};\n\n/**\n * When running in a web browser (not Tauri) with native redirect enabled,\n * tries to open the native app via custom scheme. Defers NavigationHandlers\n * to prevent the web app from consuming one-time tokens before the native app.\n *\n * If the app opens: shows dialog with \"Open here\" callback that dispatches handlers.\n * If the app doesn't open: dispatches handlers immediately.\n * In Safari: universal links handle this natively, so the check is skipped.\n */\nexport default Capability.makeModule(\n Effect.fnUntraced(function* () {\n const capabilities = yield* Capability.Service;\n const { invoke } = yield* Capability.get(Capabilities.OperationInvoker);\n const settings = yield* Capabilities.getAtomValue(DeckCapabilities.Settings);\n\n if (!settings?.enableNativeRedirect || !shouldDeferNavigationHandlers()) {\n return;\n }\n\n const appOpened = yield* Effect.promise(() => tryOpenNativeApp());\n if (appOpened) {\n const onOpenHere = () =>\n Effect.gen(function* () {\n yield* dispatchNavigationHandlers();\n yield* invoke(LayoutOperation.UpdateDialog, { state: false });\n }).pipe(Effect.provideService(Capability.Service, capabilities), EffectEx.runAndForwardErrors);\n\n yield* invoke(LayoutOperation.UpdateDialog, {\n subject: NATIVE_REDIRECT_DIALOG,\n type: 'alert',\n overlayClasses: 'dark bg-neutral-950!',\n props: { onOpenHere },\n });\n } else {\n yield* dispatchNavigationHandlers();\n }\n }),\n);\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["Effect", "Capabilities", "Capability", "AppCapabilities", "LayoutOperation", "NativePasskey", "EffectEx", "isTauri", "DeckCapabilities", "NATIVE_REDIRECT_DIALOG", "SCHEME_TIMEOUT_MS", "isSafari", "ua", "navigator", "userAgent", "includes", "canRedirectToScheme", "schemeUrl", "APP_SCHEME", "window", "location", "pathname", "replace", "search", "URL", "tryOpenNativeApp", "Promise", "resolve", "resolved", "onBlur", "cleanup", "removeEventListener", "document", "onVisibilityChange", "hidden", "addEventListener", "iframe", "createElement", "style", "display", "src", "body", "appendChild", "setTimeout", "remove", "dispatchNavigationHandlers", "fn", "url", "href", "handlers", "getAll", "NavigationHandler", "all", "map", "handler", "concurrency", "shouldDeferNavigationHandlers", "env", "DEV", "makeModule", "fnUntraced", "capabilities", "Service", "invoke", "get", "OperationInvoker", "settings", "getAtomValue", "Settings", "enableNativeRedirect", "appOpened", "promise", "onOpenHere", "gen", "UpdateDialog", "state", "pipe", "provideService", "runAndForwardErrors", "subject", "type", "overlayClasses", "props"]
|
|
7
|
+
}
|
|
@@ -1,16 +1,16 @@
|
|
|
1
1
|
// src/util/plank-url-params.ts
|
|
2
|
-
import {
|
|
2
|
+
import { Paths } from "@dxos/app-toolkit";
|
|
3
3
|
var PLANK_PARAM = "plank";
|
|
4
4
|
var serializePlanks = (active, existingSearch) => {
|
|
5
5
|
const params = new URLSearchParams(existingSearch);
|
|
6
6
|
params.delete(PLANK_PARAM);
|
|
7
7
|
for (const id of active) {
|
|
8
|
-
params.append(PLANK_PARAM, toUrlPath(id));
|
|
8
|
+
params.append(PLANK_PARAM, Paths.toUrlPath(id));
|
|
9
9
|
}
|
|
10
10
|
return params.size > 0 ? `?${params.toString()}` : "";
|
|
11
11
|
};
|
|
12
12
|
var deserializePlanks = (url) => {
|
|
13
|
-
return url.searchParams.getAll(PLANK_PARAM).map(fromUrlPath);
|
|
13
|
+
return url.searchParams.getAll(PLANK_PARAM).map(Paths.fromUrlPath);
|
|
14
14
|
};
|
|
15
15
|
var stripPlanks = (existingSearch) => {
|
|
16
16
|
const params = new URLSearchParams(existingSearch);
|
|
@@ -109,4 +109,4 @@ export {
|
|
|
109
109
|
sanitizePersistedState,
|
|
110
110
|
computeActiveUpdates
|
|
111
111
|
};
|
|
112
|
-
//# sourceMappingURL=chunk-
|
|
112
|
+
//# sourceMappingURL=chunk-NGX6RXNV.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/util/plank-url-params.ts", "../../../src/util/sanitize-persisted-state.ts", "../../../src/util/set-active.ts", "../../../src/util/layoutAppliesTopbar.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Paths } from '@dxos/app-toolkit';\n\nconst PLANK_PARAM = 'plank';\n\n/**\n * Serialize deck active qualified IDs into a URL search string.\n * Preserves non-plank query params from the existing search string.\n */\nexport const serializePlanks = (active: readonly string[], existingSearch: string): string => {\n const params = new URLSearchParams(existingSearch);\n params.delete(PLANK_PARAM);\n for (const id of active) {\n params.append(PLANK_PARAM, Paths.toUrlPath(id));\n }\n return params.size > 0 ? `?${params.toString()}` : '';\n};\n\n/**\n * Deserialize plank query params from a URL back to qualified graph IDs.\n */\nexport const deserializePlanks = (url: URL): string[] => {\n return url.searchParams.getAll(PLANK_PARAM).map(Paths.fromUrlPath);\n};\n\n/**\n * Strip plank query params from a search string, preserving all others.\n */\nexport const stripPlanks = (existingSearch: string): string => {\n const params = new URLSearchParams(existingSearch);\n params.delete(PLANK_PARAM);\n return params.size > 0 ? `?${params.toString()}` : '';\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type StoredDeckState } from '#types';\n\n/**\n * Sanitizes persisted deck state on startup.\n *\n * Persisted state may contain values that are inappropriate to restore across sessions:\n *\n * - **Fullscreen**: Cleared unconditionally to prevent the user from getting stuck in fullscreen\n * mode if the app was closed (or crashed) while fullscreen was active.\n *\n * - **Active planks in solo-mode decks**: When a deck is in solo mode, any items in `active`\n * represent planks that were kept mounted (hidden) during the session for fast deck↔solo\n * switching. After a restart these planks would need to fully remount anyway, so retaining\n * them only adds unnecessary load. Clearing `active` for solo-mode decks avoids rendering\n * stale planks in the background on startup.\n *\n * Returns a new state object if any changes were made, or the original state if clean.\n */\nexport const sanitizePersistedState = (state: StoredDeckState): StoredDeckState => {\n let needsUpdate = false;\n const cleanedDecks = { ...state.decks };\n\n for (const [id, deck] of Object.entries(cleanedDecks)) {\n if (!deck) {\n continue;\n }\n\n let updated = false;\n let cleanedDeck = deck;\n\n if (deck.fullscreen) {\n cleanedDeck = { ...cleanedDeck, fullscreen: false };\n updated = true;\n }\n\n if (deck.solo && deck.active.length > 0) {\n cleanedDeck = { ...cleanedDeck, active: [] };\n updated = true;\n }\n\n if (updated) {\n cleanedDecks[id] = cleanedDeck;\n needsUpdate = true;\n }\n }\n\n return needsUpdate ? { ...state, decks: cleanedDecks } : state;\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type AttentionManager } from '@dxos/react-ui-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"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["Paths", "PLANK_PARAM", "serializePlanks", "active", "existingSearch", "params", "URLSearchParams", "delete", "id", "append", "toUrlPath", "size", "toString", "deserializePlanks", "url", "searchParams", "getAll", "map", "fromUrlPath", "stripPlanks", "sanitizePersistedState", "state", "needsUpdate", "cleanedDecks", "decks", "id", "deck", "Object", "entries", "updated", "cleanedDeck", "fullscreen", "solo", "active", "length", "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"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
// src/operations/index.ts
|
|
2
|
+
import { OperationHandlerSet } from "@dxos/compute";
|
|
3
|
+
var DeckOperationHandlerSet = OperationHandlerSet.lazy(() => import("./add-toast-APKTCLIA.mjs"), () => import("./adjust-7CZI4GK3.mjs"), () => import("./close-KJUCFIJ5.mjs"), () => import("./open-VU7YS3HB.mjs"), () => import("./revert-workspace-24TKG3I7.mjs"), () => import("./scroll-into-view-3VXT6TWC.mjs"), () => import("./set-RFOLTI57.mjs"), () => import("./set-layout-mode-AZ73W52Z.mjs"), () => import("./switch-workspace-TBPT23CZ.mjs"), () => import("./update-companion-5LCY6QME.mjs"), () => import("./update-complementary-HZ7QXZYE.mjs"), () => import("./update-dialog-A7W3R5EI.mjs"), () => import("./update-plank-size-XHTYBLSD.mjs"), () => import("./update-popover-RDIHG73B.mjs"), () => import("./update-sidebar-GEI7USA5.mjs"));
|
|
4
|
+
|
|
5
|
+
export {
|
|
6
|
+
DeckOperationHandlerSet
|
|
7
|
+
};
|
|
8
|
+
//# sourceMappingURL=chunk-UZLAR4DR.mjs.map
|
|
@@ -6,10 +6,10 @@ import {
|
|
|
6
6
|
} from "./chunk-GLB73Q6U.mjs";
|
|
7
7
|
import {
|
|
8
8
|
DeckCapabilities_exports
|
|
9
|
-
} from "./chunk-
|
|
9
|
+
} from "./chunk-CL7JIOI5.mjs";
|
|
10
10
|
import {
|
|
11
11
|
computeActiveUpdates
|
|
12
|
-
} from "./chunk-
|
|
12
|
+
} from "./chunk-NGX6RXNV.mjs";
|
|
13
13
|
import "./chunk-J5LGTIGS.mjs";
|
|
14
14
|
|
|
15
15
|
// src/operations/close.ts
|
|
@@ -41,4 +41,4 @@ var close_default = handler;
|
|
|
41
41
|
export {
|
|
42
42
|
close_default as default
|
|
43
43
|
};
|
|
44
|
-
//# sourceMappingURL=close-
|
|
44
|
+
//# sourceMappingURL=close-KJUCFIJ5.mjs.map
|
|
@@ -9,13 +9,13 @@ import {
|
|
|
9
9
|
Sidebar,
|
|
10
10
|
ToggleComplementarySidebarButton,
|
|
11
11
|
ToggleSidebarButton
|
|
12
|
-
} from "../chunk-
|
|
13
|
-
import "../chunk-
|
|
12
|
+
} from "../chunk-DNG3L5QN.mjs";
|
|
13
|
+
import "../chunk-NGX6RXNV.mjs";
|
|
14
14
|
import "../chunk-J5LGTIGS.mjs";
|
|
15
15
|
|
|
16
16
|
// src/containers/index.ts
|
|
17
17
|
import { lazy } from "react";
|
|
18
|
-
var DeckLayout = lazy(() => import("../DeckLayout-
|
|
18
|
+
var DeckLayout = lazy(() => import("../DeckLayout-VX2BP4Q2.mjs"));
|
|
19
19
|
export {
|
|
20
20
|
CloseSidebarButton,
|
|
21
21
|
ComplementarySidebar,
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
meta
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-KY7LMF4D.mjs";
|
|
4
4
|
import {
|
|
5
5
|
DECK_COMPANION_TYPE,
|
|
6
6
|
DeckAction,
|
|
@@ -9,14 +9,19 @@ import {
|
|
|
9
9
|
DeckOperation_exports,
|
|
10
10
|
DeckState,
|
|
11
11
|
EphemeralDeckState,
|
|
12
|
+
Hints,
|
|
13
|
+
Keyshortcuts,
|
|
12
14
|
PLANK_COMPANION_TYPE,
|
|
13
15
|
PlankSizing,
|
|
14
16
|
Settings_exports,
|
|
17
|
+
StatusBar,
|
|
18
|
+
StatusBarFooter,
|
|
15
19
|
StoredDeckState,
|
|
20
|
+
VersionInfo,
|
|
16
21
|
defaultDeck,
|
|
17
22
|
getMode,
|
|
18
23
|
isLayoutMode
|
|
19
|
-
} from "./chunk-
|
|
24
|
+
} from "./chunk-CL7JIOI5.mjs";
|
|
20
25
|
import "./chunk-J5LGTIGS.mjs";
|
|
21
26
|
export {
|
|
22
27
|
DECK_COMPANION_TYPE,
|
|
@@ -26,10 +31,15 @@ export {
|
|
|
26
31
|
DeckOperation_exports as DeckOperation,
|
|
27
32
|
DeckState,
|
|
28
33
|
EphemeralDeckState,
|
|
34
|
+
Hints,
|
|
35
|
+
Keyshortcuts,
|
|
29
36
|
PLANK_COMPANION_TYPE,
|
|
30
37
|
PlankSizing,
|
|
31
38
|
Settings_exports as Settings,
|
|
39
|
+
StatusBar,
|
|
40
|
+
StatusBarFooter,
|
|
32
41
|
StoredDeckState,
|
|
42
|
+
VersionInfo,
|
|
33
43
|
defaultDeck,
|
|
34
44
|
getMode,
|
|
35
45
|
isLayoutMode,
|