@dxos/plugin-deck 0.8.4-staging.60fe92afc8 → 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
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/containers/DeckLayout/DeckLayout.tsx", "../../../src/containers/DeckLayout/ActiveNode.tsx", "../../../src/containers/DeckLayout/Dialog.tsx", "../../../src/containers/DeckLayout/Popover.tsx", "../../../src/containers/DeckLayout/Toast.tsx", "../../../src/containers/DeckLayout/constants.ts", "../../../src/containers/DeckLayout/index.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport React, { useCallback } from 'react';\n\nimport { useAtomCapability, useOperationInvoker, usePluginManager } from '@dxos/app-framework/ui';\nimport { LayoutOperation } from '@dxos/app-toolkit';\nimport { Mosaic } from '@dxos/react-ui-mosaic';\n\nimport { useDeckState } from '#hooks';\nimport { DeckCapabilities, getMode } from '#types';\n\nimport { Deck, type DeckLayoutChangeRequest } from '../Deck';\nimport { ActiveNode } from './ActiveNode';\nimport { Dialog } from './Dialog';\nimport { PopoverContent, PopoverRoot } from './Popover';\nimport { Toaster, type ToasterProps } from './Toast';\n\nexport type DeckLayoutProps = Pick<ToasterProps, 'onDismissToast'>;\n\nexport const DeckLayout = ({ onDismissToast }: DeckLayoutProps) => {\n const settings = useAtomCapability(DeckCapabilities.Settings);\n const pluginManager = usePluginManager();\n const { invokePromise } = useOperationInvoker();\n const { deck, state, updateState } = useDeckState();\n const layoutMode = getMode(deck);\n const { toasts } = state;\n\n const handleLayoutChange = useCallback(\n (request: DeckLayoutChangeRequest) => {\n void invokePromise(LayoutOperation.SetLayoutMode, request);\n },\n [invokePromise],\n );\n\n return (\n <Mosaic.Root>\n <PopoverRoot>\n <ActiveNode />\n <Deck.Root\n settings={settings}\n pluginManager={pluginManager}\n layoutMode={layoutMode}\n deck={deck}\n state={state}\n updateState={updateState}\n onLayoutChange={handleLayoutChange}\n >\n <Deck.Content>\n <Deck.Viewport>\n {deck.solo ? <Deck.SoloMode /> : deck.active.length === 0 ? <Deck.ContentEmpty /> : <Deck.MultiMode />}\n </Deck.Viewport>\n </Deck.Content>\n </Deck.Root>\n <PopoverContent />\n <Dialog />\n <Toaster toasts={toasts} onDismissToast={onDismissToast} />\n </PopoverRoot>\n </Mosaic.Root>\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Surface } from '@dxos/app-framework/ui';\nimport { AppSurface, useAppGraph } from '@dxos/app-toolkit/ui';\nimport { useNode } from '@dxos/plugin-graph';\nimport { useAttended } from '@dxos/react-ui-attention';\n\nimport { useNodeActionExpander } from '#hooks';\n\n// TODO(burdon): Factor out to effect in plugin set document title.\nexport const ActiveNode = () => {\n const [id] = useAttended();\n const { graph } = useAppGraph();\n const activeNode = useNode(graph, id);\n useNodeActionExpander(activeNode);\n\n return (\n <div className='sr-only'>\n {/* TODO(wittjosiah): Weird that this is a surface, feel like it's not really render logic.\n Probably this lives in React-land currently in order to access translations? */}\n <Surface.Surface\n type={AppSurface.DocumentTitle}\n data={{ subject: activeNode } satisfies AppSurface.DocumentTitleData}\n limit={1}\n />\n </div>\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useCallback } from 'react';\n\nimport { Surface } from '@dxos/app-framework/ui';\nimport { AppSurface } from '@dxos/app-toolkit/ui';\nimport { AlertDialog, Dialog as NaturalDialog } from '@dxos/react-ui';\n\nimport { useDeckState } from '#hooks';\n\nimport { PlankErrorFallback } from '../Plank';\n\nexport const Dialog = () => {\n const { state, updateEphemeral } = useDeckState();\n const { dialogOpen, dialogType, dialogBlockAlign, dialogOverlayClasses, dialogOverlayStyle, dialogContent } = state;\n const Root = dialogType === 'alert' ? AlertDialog.Root : NaturalDialog.Root;\n const Overlay = dialogType === 'alert' ? AlertDialog.Overlay : NaturalDialog.Overlay;\n\n const handleOpenChange = useCallback(\n (nextOpen: boolean) => {\n updateEphemeral((s) => ({ ...s, dialogOpen: nextOpen }));\n },\n [updateEphemeral],\n );\n\n // TODO(thure): End block alignment affecting `modal` and whether the surface renders in an overlay is tailored to the needs of the ambient chat dialog. As the feature matures, consider separating concerns.\n return (\n <Root modal={dialogBlockAlign !== 'end'} open={dialogOpen} onOpenChange={handleOpenChange}>\n {dialogBlockAlign === 'end' ? (\n // TODO(burdon): Placeholder creates a suspense boundary; replace with defaults.\n <Surface.Surface\n type={AppSurface.Dialog}\n data={dialogContent ?? undefined}\n limit={1}\n fallback={PlankErrorFallback}\n placeholder={<div />}\n />\n ) : (\n <Overlay blockAlign={dialogBlockAlign} classNames={dialogOverlayClasses} style={dialogOverlayStyle}>\n <Surface.Surface\n type={AppSurface.Dialog}\n data={dialogContent ?? undefined}\n limit={1}\n fallback={PlankErrorFallback}\n />\n </Overlay>\n )}\n </Root>\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { createContext } from '@radix-ui/react-context';\nimport React, { type PropsWithChildren, useCallback, useEffect, useRef, useState } from 'react';\n\nimport { Surface } from '@dxos/app-framework/ui';\nimport { AppSurface, useObjectMenuItems } from '@dxos/app-toolkit/ui';\nimport { Obj } from '@dxos/echo';\nimport {\n Card,\n Popover,\n type PopoverContentInteractOutsideEvent,\n toLocalizedString,\n Toolbar,\n useTranslation,\n} from '@dxos/react-ui';\nimport { Menu } from '@dxos/react-ui-menu';\n\nimport { useDeckState } from '#hooks';\nimport { meta } from '#meta';\n\nconst DEBOUNCE_DELAY = 40;\n\ntype DeckPopoverContextValue = {\n setOpen: (open: boolean) => void;\n};\n\nconst [DeckPopoverProvider, useDeckPopoverContext] = createContext<DeckPopoverContextValue>('DeckPopover');\n\nexport type PopoverRootProps = PropsWithChildren;\n\nexport const PopoverRoot = ({ children }: PopoverRootProps) => {\n const { state } = useDeckState();\n const virtualRef = useRef<HTMLButtonElement | null>(null);\n const [virtualIter, setVirtualIter] = useState(0);\n const [open, setOpen] = useState(false);\n const debounceRef = useRef<NodeJS.Timeout | null>(null);\n\n // TODO(thure): This is a workaround for the race condition between displaying a Popover and either rendering\n // the anchor further down the tree or measuring the virtual trigger's client rect.\n useEffect(() => {\n setOpen(false);\n if (state.popoverOpen) {\n if (debounceRef.current) {\n clearTimeout(debounceRef.current);\n }\n if (state.popoverAnchor && virtualRef.current !== state.popoverAnchor) {\n virtualRef.current = state.popoverAnchor ?? null;\n setVirtualIter((iter) => iter + 1);\n }\n debounceRef.current = setTimeout(() => setOpen(true), DEBOUNCE_DELAY);\n }\n }, [state.popoverOpen, state.popoverAnchorId, state.popoverAnchor, state.popoverContent]);\n\n return (\n <DeckPopoverProvider setOpen={setOpen}>\n <Popover.Root modal={false} open={open}>\n {state.popoverAnchor && <Popover.VirtualTrigger key={virtualIter} virtualRef={virtualRef} />}\n {children}\n </Popover.Root>\n </DeckPopoverProvider>\n );\n};\n\nexport const PopoverContent = () => {\n const { t } = useTranslation(meta.id);\n const { state, updateEphemeral } = useDeckState();\n const { setOpen } = useDeckPopoverContext('PopoverContent');\n const popoverSubject =\n state.popoverContent && 'subject' in state.popoverContent ? state.popoverContent.subject : undefined;\n const isObjectPopover = Obj.isObject(popoverSubject);\n const objectMenuItems = useObjectMenuItems(popoverSubject);\n const title = state.popoverTitle ? toLocalizedString(state.popoverTitle, t) : 'Unknown';\n const icon = isObjectPopover ? (Obj.getIcon(popoverSubject)?.icon ?? 'ph--circle-dashed--regular') : undefined;\n const content = state.popoverContent;\n // A base popover renders a plugin-provided component; everything else falls through to the card.\n const isBasePopover = state.popoverKind === 'base' && !!content && 'component' in content;\n\n const handleClose = useCallback(() => {\n setOpen(false);\n updateEphemeral((state) => ({\n ...state,\n popoverOpen: false,\n popoverAnchor: undefined,\n popoverAnchorId: undefined,\n popoverSide: undefined,\n }));\n }, [updateEphemeral]);\n\n const handleInteractOutside = useCallback(\n (event: KeyboardEvent | PopoverContentInteractOutsideEvent) => {\n if (\n // TODO(thure): CodeMirror should not focus itself when it updates.\n event.type === 'dismissableLayer.focusOutside' &&\n (event.currentTarget as HTMLElement | undefined)?.classList.contains('cm-content')\n ) {\n event.preventDefault();\n } else {\n handleClose();\n }\n },\n [handleClose],\n );\n\n return (\n <Popover.Portal>\n <Popover.Content\n side={state.popoverSide}\n sticky='always'\n hideWhenDetached\n onOpenAutoFocus={(event) => event.preventDefault()}\n onInteractOutside={handleInteractOutside}\n onEscapeKeyDown={handleInteractOutside}\n >\n <Popover.Viewport>\n {isBasePopover && content && 'component' in content ? (\n /* Base popover: a plugin-provided component (e.g. editor link preview). */\n <Surface.Surface type={AppSurface.Popover} data={content} limit={1} />\n ) : (\n /*\n * Card popover (default). Rendered for any open popover that isn't an explicit\n * base-component popover so the popover can never collapse to a bare 1px frame: the\n * header (icon + title + menu) always renders, and the body falls back to a fixed-\n * height \"no preview\" row when no subject resolves a card Surface (e.g. system-type\n * objects like a raw Feed that have no registered card and no renderable fields).\n */\n <Menu.Root>\n <Card.Root border={false} classNames='dx-card-popover'>\n <Card.Header>\n <Card.IconBlock>{icon && <Card.Icon icon={icon} />}</Card.IconBlock>\n <Card.Title>{title}</Card.Title>\n {/* TODO(wittjosiah): Reconcile with Card.Menu. */}\n <Card.IconBlock>\n <Menu.Trigger asChild disabled={!objectMenuItems.length}>\n <Toolbar.IconButton\n variant='ghost'\n density='sm'\n icon='ph--dots-three-vertical--regular'\n iconOnly\n label='Actions'\n />\n </Menu.Trigger>\n <Menu.Content items={objectMenuItems} />\n </Card.IconBlock>\n </Card.Header>\n\n {content && 'subject' in content ? (\n <Surface.Surface type={AppSurface.Card} data={content} limit={1} />\n ) : (\n <Card.Body classNames='min-bs-8'>\n <Card.Row>\n <Card.Text variant='description'>{t('popover-no-preview.message')}</Card.Text>\n </Card.Row>\n </Card.Body>\n )}\n </Card.Root>\n </Menu.Root>\n )}\n </Popover.Viewport>\n <Popover.Arrow />\n </Popover.Content>\n </Popover.Portal>\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { useState } from 'react';\n\nimport { type LayoutOperation } from '@dxos/app-toolkit';\nimport { Button, Toast as NaturalToast, type ToastRootProps, toLocalizedString, useTranslation } from '@dxos/react-ui';\n\nimport { meta } from '#meta';\n\n// TODO(wittjosiah): Render remaining duration as a progress bar within the toast.\nexport const Toast = ({\n id,\n title,\n description,\n icon,\n duration,\n actionLabel,\n actionAlt,\n onAction,\n onOpenChange,\n}: LayoutOperation.Toast & Pick<ToastRootProps, 'onOpenChange'>) => {\n const { t } = useTranslation(meta.id);\n\n // Control the open state so closing flips Radix's `open` (playing the exit animation) rather than\n // unmounting abruptly. Both the close button and Radix's own timeout/swipe route through here.\n const [open, setOpen] = useState(true);\n const handleOpenChange = (next: boolean) => {\n setOpen(next);\n onOpenChange?.(next);\n };\n\n return (\n <NaturalToast.Root data-testid={id} open={open} duration={duration} onOpenChange={handleOpenChange}>\n <NaturalToast.Title icon={icon} onClose={() => handleOpenChange(false)}>\n {title && <span>{toLocalizedString(title, t)}</span>}\n </NaturalToast.Title>\n {description && <NaturalToast.Description>{toLocalizedString(description, t)}</NaturalToast.Description>}\n {onAction && actionAlt && actionLabel && (\n <NaturalToast.Actions>\n <NaturalToast.Action altText={toLocalizedString(actionAlt, t)} asChild>\n <Button data-testid='toast.action' variant='primary' onClick={() => onAction?.()}>\n {toLocalizedString(actionLabel, t)}\n </Button>\n </NaturalToast.Action>\n </NaturalToast.Actions>\n )}\n </NaturalToast.Root>\n );\n};\n\nexport type ToasterProps = {\n toasts?: LayoutOperation.Toast[];\n onDismissToast?: (id: string) => void;\n};\n\nexport const Toaster = ({ toasts, onDismissToast }: ToasterProps) => {\n return (\n <>\n {toasts?.map((toast) => (\n <Toast\n {...toast}\n key={toast.id}\n onOpenChange={(open: boolean) => {\n if (!open) {\n onDismissToast?.(toast.id);\n }\n\n return open;\n }}\n />\n ))}\n </>\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nexport const NAV_ID = 'NavTree';\n\nexport const SURFACE_PREFIX = 'surface:';\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { DeckLayout } from './DeckLayout';\n\nexport { NAV_ID } from './constants';\n\nexport default DeckLayout;\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["React", "useCallback", "useAtomCapability", "useOperationInvoker", "usePluginManager", "LayoutOperation", "Mosaic", "useDeckState", "DeckCapabilities", "getMode", "React", "Surface", "AppSurface", "useAppGraph", "useNode", "useAttended", "useNodeActionExpander", "ActiveNode", "id", "graph", "activeNode", "div", "className", "type", "DocumentTitle", "data", "subject", "limit", "React", "useCallback", "Surface", "AppSurface", "AlertDialog", "Dialog", "NaturalDialog", "useDeckState", "Dialog", "state", "updateEphemeral", "useDeckState", "dialogOpen", "dialogType", "dialogBlockAlign", "dialogOverlayClasses", "dialogOverlayStyle", "dialogContent", "Root", "AlertDialog", "NaturalDialog", "Overlay", "handleOpenChange", "useCallback", "nextOpen", "s", "React", "modal", "open", "onOpenChange", "Surface", "type", "AppSurface", "data", "undefined", "limit", "fallback", "PlankErrorFallback", "placeholder", "div", "blockAlign", "classNames", "style", "createContext", "React", "useCallback", "useEffect", "useRef", "useState", "Surface", "AppSurface", "useObjectMenuItems", "Obj", "Card", "Popover", "toLocalizedString", "Toolbar", "useTranslation", "Menu", "useDeckState", "meta", "DEBOUNCE_DELAY", "DeckPopoverProvider", "useDeckPopoverContext", "PopoverRoot", "children", "state", "virtualRef", "virtualIter", "setVirtualIter", "open", "setOpen", "debounceRef", "popoverOpen", "current", "clearTimeout", "popoverAnchor", "iter", "setTimeout", "popoverAnchorId", "popoverContent", "Root", "modal", "VirtualTrigger", "key", "PopoverContent", "t", "id", "updateEphemeral", "popoverSubject", "subject", "undefined", "isObjectPopover", "isObject", "objectMenuItems", "title", "popoverTitle", "icon", "getIcon", "content", "isBasePopover", "popoverKind", "handleClose", "popoverSide", "handleInteractOutside", "event", "type", "currentTarget", "classList", "contains", "preventDefault", "Portal", "Content", "side", "sticky", "hideWhenDetached", "onOpenAutoFocus", "onInteractOutside", "onEscapeKeyDown", "Viewport", "data", "limit", "border", "classNames", "Header", "IconBlock", "Icon", "Title", "Trigger", "asChild", "disabled", "length", "IconButton", "variant", "density", "iconOnly", "label", "items", "Body", "Row", "Text", "Arrow", "React", "useState", "Button", "Toast", "NaturalToast", "toLocalizedString", "useTranslation", "meta", "id", "title", "description", "icon", "duration", "actionLabel", "actionAlt", "onAction", "onOpenChange", "t", "open", "setOpen", "handleOpenChange", "next", "Root", "data-testid", "Title", "onClose", "span", "Description", "Actions", "Action", "altText", "asChild", "variant", "onClick", "Toaster", "toasts", "onDismissToast", "map", "toast", "key", "DeckLayout", "onDismissToast", "settings", "useAtomCapability", "DeckCapabilities", "Settings", "pluginManager", "usePluginManager", "invokePromise", "useOperationInvoker", "deck", "state", "updateState", "useDeckState", "layoutMode", "getMode", "toasts", "handleLayoutChange", "useCallback", "request", "LayoutOperation", "SetLayoutMode", "React", "Mosaic", "Root", "PopoverRoot", "ActiveNode", "Deck", "onLayoutChange", "Content", "Viewport", "solo", "SoloMode", "active", "length", "ContentEmpty", "MultiMode", "PopoverContent", "Dialog", "Toaster", "NAV_ID", "DeckLayout"]
|
|
7
|
-
}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/components/DeckSettings/DeckSettings.tsx"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport React from 'react';\n\nimport { type AppSurface } from '@dxos/app-toolkit/ui';\nimport { useTranslation } from '@dxos/react-ui';\nimport { Settings as SettingsForm } from '@dxos/react-ui-form';\n\nimport { meta } from '#meta';\nimport { Settings } from '#types';\n\nconst isSocket = !!(globalThis as any).__args;\n\nexport type DeckSettingsProps = AppSurface.SettingsArticleProps<Settings.Settings>;\n\nexport const DeckSettings = ({ settings, onSettingsChange }: DeckSettingsProps) => {\n const { t } = useTranslation(meta.id);\n\n return (\n <SettingsForm.Viewport>\n <SettingsForm.Section title={t('settings.title', { ns: meta.id })}>\n <SettingsForm.FieldSet\n readonly={!onSettingsChange}\n schema={Settings.Settings}\n visible={(path) => path !== 'enableNativeRedirect' || !isSocket}\n values={settings}\n onValuesChanged={(values) => onSettingsChange?.(() => values)}\n />\n </SettingsForm.Section>\n </SettingsForm.Viewport>\n );\n};\n"],
|
|
5
|
-
"mappings": ";;;AAIA,OAAOA,WAAW;AAGlB,SAASC,sBAAsB;AAC/B,SAASC,YAAYC,oBAAoB;AAEzC,SAASC,YAAY;AACrB,SAASF,gBAAgB;AAEzB,IAAMG,WAAW,CAAC,CAAEC,WAAmBC;AAIhC,IAAMC,eAAe,CAAC,EAAEC,UAAUC,iBAAgB,MAAqB;AAC5E,QAAM,EAAEC,EAAC,IAAKV,eAAeG,KAAKQ,EAAE;AAEpC,SACE,sBAAA,cAACT,aAAaU,UAAQ,MACpB,sBAAA,cAACV,aAAaW,SAAO;IAACC,OAAOJ,EAAE,kBAAkB;MAAEK,IAAIZ,KAAKQ;IAAG,CAAA;KAC7D,sBAAA,cAACT,aAAac,UAAQ;IACpBC,UAAU,CAACR;IACXS,QAAQjB,SAASA;IACjBkB,SAAS,CAACC,SAASA,SAAS,0BAA0B,CAAChB;IACvDiB,QAAQb;IACRc,iBAAiB,CAACD,WAAWZ,mBAAmB,MAAMY,MAAAA;;AAKhE;",
|
|
6
|
-
"names": ["React", "useTranslation", "Settings", "SettingsForm", "meta", "isSocket", "globalThis", "__args", "DeckSettings", "settings", "onSettingsChange", "t", "id", "Viewport", "Section", "title", "ns", "FieldSet", "readonly", "schema", "visible", "path", "values", "onValuesChanged"]
|
|
7
|
-
}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/capabilities/app-graph-builder.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\n\nimport { Capabilities, Capability } from '@dxos/app-framework';\nimport { AppCapabilities, AppNode, LayoutOperation } from '@dxos/app-toolkit';\nimport { Operation } from '@dxos/compute';\nimport { AttentionCapabilities } from '@dxos/plugin-attention';\nimport { GraphBuilder, NodeMatcher } from '@dxos/plugin-graph';\n\nimport { meta } from '#meta';\nimport { DeckCapabilities } from '#types';\n\nexport default Capability.makeModule(\n Effect.fnUntraced(function* () {\n const extensions = yield* Effect.all([\n GraphBuilder.createExtension({\n id: 'notFound',\n match: NodeMatcher.whenRoot,\n connector: () => Effect.succeed([AppNode.makeNotFound()]),\n }),\n\n GraphBuilder.createExtension({\n id: 'root',\n match: NodeMatcher.whenRoot,\n actions: (_node, get) =>\n Effect.gen(function* () {\n // NOTE(Zan): This is currently disabled.\n // TODO(Zan): Fullscreen needs to know the active node and provide that to the layout part.\n // const _fullscreen = {\n // id: `${LayoutAction.UpdateLayout._tag}/fullscreen`,\n // data: async () => {\n // const { dispatchPromise: dispatch } = context.get(Capabilities.IntentDispatcher);\n // await dispatch(\n // createIntent(LayoutAction.SetLayoutMode, { part: 'mode', options: { mode: 'fullscreen' } }),\n // );\n // },\n // properties: {\n // label: ['toggle-fullscreen.label', { ns: meta.id }],\n // icon: 'ph--arrows-out--regular',\n // keyBinding: {\n // macos: 'ctrl+meta+f',\n // windows: 'shift+ctrl+f',\n // },\n // },\n // };\n\n const closeCurrent = {\n id: `${LayoutOperation.Close.meta.key}.current`,\n data: Effect.fnUntraced(function* () {\n const attention = yield* Capability.get(AttentionCapabilities.Attention);\n const attended = attention.getCurrent().at(-1);\n if (attended) {\n yield* Operation.invoke(LayoutOperation.Close, { subject: [attended] });\n }\n }),\n properties: {\n label: ['close-current.label', { ns: meta.id }],\n icon: 'ph--x--regular',\n },\n };\n\n const closeOthers = {\n id: `${LayoutOperation.Close.meta.key}.others`,\n data: Effect.fnUntraced(function* () {\n const attention = yield* Capability.get(AttentionCapabilities.Attention);\n const deck = yield* DeckCapabilities.getDeck();\n const attended = attention.getCurrent().at(-1);\n const ids = deck.active.filter((id: string) => id !== attended) ?? [];\n yield* Operation.invoke(LayoutOperation.Close, { subject: ids });\n }),\n properties: {\n label: ['close-others.label', { ns: meta.id }],\n icon: 'ph--x-square--regular',\n },\n };\n\n const closeAll = {\n id: `${LayoutOperation.Close.meta.key}.all`,\n data: Effect.fnUntraced(function* () {\n const deck = yield* DeckCapabilities.getDeck();\n yield* Operation.invoke(LayoutOperation.Close, { subject: deck.active });\n }),\n properties: {\n label: ['close-all.label', { ns: meta.id }],\n icon: 'ph--x-circle--regular',\n },\n };\n\n const state = get(yield* Capability.get(DeckCapabilities.State));\n const deck = state.decks[state.activeDeck];\n\n const toggleSidebar = {\n id: `${LayoutOperation.UpdateSidebar.meta.key}.nav`,\n data: Effect.fnUntraced(function* () {\n yield* Capabilities.updateAtomValue(DeckCapabilities.State, (s) => ({\n ...s,\n sidebarState: s.sidebarState === 'expanded' ? ('collapsed' as const) : ('expanded' as const),\n }));\n }),\n properties: {\n label: [\n state.sidebarState === 'expanded'\n ? 'collapse-navigation-sidebar.label'\n : 'open-navigation-sidebar.label',\n { ns: meta.id },\n ],\n icon: 'ph--sidebar--regular',\n keyBinding: {\n macos: \"meta+'\",\n },\n disposition: 'pin-end',\n position: 'last',\n l0Breakpoint: 'lg',\n },\n };\n\n return !deck?.solo ? [closeCurrent, closeOthers, closeAll, toggleSidebar] : [toggleSidebar];\n }),\n }),\n ]);\n\n return Capability.contributes(AppCapabilities.AppGraphBuilder, extensions.flat());\n }),\n);\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["Effect", "Capabilities", "Capability", "AppCapabilities", "AppNode", "LayoutOperation", "Operation", "AttentionCapabilities", "GraphBuilder", "NodeMatcher", "meta", "DeckCapabilities", "makeModule", "fnUntraced", "extensions", "all", "createExtension", "id", "match", "whenRoot", "connector", "succeed", "makeNotFound", "actions", "_node", "get", "gen", "closeCurrent", "Close", "key", "data", "attention", "Attention", "attended", "getCurrent", "at", "invoke", "subject", "properties", "label", "ns", "icon", "closeOthers", "deck", "getDeck", "ids", "active", "filter", "closeAll", "state", "State", "decks", "activeDeck", "toggleSidebar", "UpdateSidebar", "updateAtomValue", "s", "sidebarState", "keyBinding", "macos", "disposition", "position", "l0Breakpoint", "solo", "contributes", "AppGraphBuilder", "flat"]
|
|
7
|
-
}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/capabilities/check-app-scheme.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\n\nimport { Capabilities, Capability } from '@dxos/app-framework';\nimport { APP_SCHEME, AppCapabilities, LayoutOperation } 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 = 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 = 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", "APP_SCHEME", "AppCapabilities", "LayoutOperation", "EffectEx", "isTauri", "DeckCapabilities", "NATIVE_REDIRECT_DIALOG", "SCHEME_TIMEOUT_MS", "isSafari", "ua", "navigator", "userAgent", "includes", "canRedirectToScheme", "schemeUrl", "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,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/types/schema.ts", "../../../src/types/DeckCapabilities.ts", "../../../src/types/DeckEvents.ts", "../../../src/types/DeckOperation.ts", "../../../src/types/Settings.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport * as Schema from 'effect/Schema';\n\nimport { Label, LayoutOperation } from '@dxos/app-toolkit';\nimport { type DeepReadonly } from '@dxos/util';\n\nimport { meta } from '#meta';\n\nexport { PLANK_COMPANION_TYPE, DECK_COMPANION_TYPE } from '@dxos/app-toolkit';\n\nexport type Part = 'solo' | 'multi' | 'complementary';\nexport type ResolvedPart = Part | 'solo-primary' | 'solo-companion';\n\nexport const PlankSizing = Schema.Record({ key: Schema.String, value: Schema.Number });\nexport type PlankSizing = Schema.Schema.Type<typeof PlankSizing>;\n\nexport const DeckState = Schema.Struct({\n /** If false, the deck has not yet left solo mode and new planks should be soloed. */\n initialized: Schema.Boolean,\n /** Item IDs of planks currently displayed in multi-mode. */\n active: Schema.mutable(Schema.Array(Schema.String)),\n /** Item IDs of planks that have been closed; used for state persistence and reopening. */\n inactive: Schema.mutable(Schema.Array(Schema.String)),\n /** Item ID of the single plank displayed in solo or fullscreen mode. */\n solo: Schema.optional(Schema.String),\n /** Whether the solo plank is displayed in fullscreen mode (no heading or sidebars). */\n fullscreen: Schema.Boolean,\n /** Persisted plank widths in rem, keyed by item ID. */\n plankSizing: Schema.mutable(PlankSizing),\n /** Whether the companion pane is visible alongside the active plank(s). */\n companionOpen: Schema.Boolean,\n /** Which companion variant to display when the companion pane is open. */\n companionVariant: Schema.optional(Schema.String),\n /** Persisted companion frame widths in rem, keyed by frame ID. */\n companionFrameSizing: Schema.mutable(PlankSizing),\n});\nexport type DeckState = Schema.Schema.Type<typeof DeckState>;\n\nexport const defaultDeck: DeckState = {\n initialized: false,\n active: [],\n inactive: [],\n solo: undefined,\n fullscreen: false,\n plankSizing: {},\n companionOpen: false,\n companionVariant: undefined,\n companionFrameSizing: {},\n};\n\n//\n// Layout\n//\n\nconst LayoutMode = Schema.Literal('multi', 'solo', 'solo--fullscreen');\nexport type LayoutMode = Schema.Schema.Type<typeof LayoutMode>;\nexport const isLayoutMode = (value: any): value is LayoutMode => Schema.is(LayoutMode)(value);\nexport const getMode = (deck: DeckState | DeepReadonly<DeckState>): LayoutMode => {\n if (deck.solo) {\n return deck.fullscreen ? 'solo--fullscreen' : 'solo';\n }\n\n return 'multi';\n};\n\n// Persisted plugin state (stored in KVS/localStorage).\nexport const StoredDeckState = Schema.Struct({\n sidebarState: Schema.Literal('closed', 'collapsed', 'expanded'),\n complementarySidebarState: Schema.Literal('closed', 'collapsed', 'expanded'),\n complementarySidebarPanel: Schema.optional(Schema.String),\n activeDeck: Schema.String,\n previousDeck: Schema.String,\n decks: Schema.mutable(Schema.Record({ key: Schema.String, value: Schema.mutable(DeckState) })),\n previousMode: Schema.mutable(Schema.Record({ key: Schema.String, value: LayoutMode })),\n}).pipe(Schema.mutable);\nexport type StoredDeckState = Schema.Schema.Type<typeof StoredDeckState>;\n\n// Transient/ephemeral plugin state (not persisted).\nexport const EphemeralDeckState = Schema.Struct({\n dialogOpen: Schema.Boolean,\n dialogType: Schema.optional(Schema.Literal('default', 'alert')),\n dialogBlockAlign: Schema.optional(Schema.Literal('start', 'center', 'end')),\n dialogOverlayClasses: Schema.optional(Schema.String),\n dialogOverlayStyle: Schema.optional(Schema.Record({ key: Schema.String, value: Schema.Any })),\n /** Data to be passed to the dialog Surface. */\n dialogContent: Schema.NullOr(Schema.Struct({ component: Schema.String, props: Schema.optional(Schema.Any) })),\n popoverOpen: Schema.Boolean,\n popoverSide: Schema.optional(Schema.Literal('top', 'right', 'bottom', 'left')),\n popoverAnchor: Schema.optional(Schema.Any),\n popoverAnchorId: Schema.optional(Schema.String),\n popoverKind: Schema.optional(Schema.Literal('base', 'card')),\n popoverTitle: Schema.optional(Label.annotations({ description: 'The title of the popover.' })),\n /** Ref of the subject to be passed to the popover Surface. */\n popoverContentRef: Schema.optional(Schema.String),\n /** Data to be passed to the popover Surface. */\n popoverContent: Schema.NullOr(\n Schema.Union(\n Schema.Struct({ component: Schema.String, props: Schema.optional(Schema.Any) }),\n Schema.Struct({ subject: Schema.Any }),\n ),\n ),\n toasts: Schema.mutable(Schema.Array(LayoutOperation.Toast)),\n currentUndoId: Schema.optional(Schema.String),\n /** The identifier of a component to scroll into view when it is mounted. */\n scrollIntoView: Schema.optional(Schema.String),\n}).pipe(Schema.mutable);\nexport type EphemeralDeckState = Schema.Schema.Type<typeof EphemeralDeckState>;\n\n// Combined state type (for convenience in components that need both).\nexport type DeckPluginState = StoredDeckState & EphemeralDeckState;\n\nexport namespace DeckAction {\n const PartAdjustmentSchema = Schema.Union(\n Schema.Literal('close').annotations({ description: 'Close the plank.' }),\n Schema.Literal('companion').annotations({ description: 'Open the companion plank.' }),\n Schema.Literal('solo').annotations({ description: 'Solo the plank.' }),\n Schema.Literal('solo--fullscreen').annotations({ description: 'Fullscreen the plank.' }),\n Schema.Literal('increment-start').annotations({ description: 'Move the plank towards the start of the deck.' }),\n Schema.Literal('increment-end').annotations({ description: 'Move the plank towards the end of the deck.' }),\n );\n export type PartAdjustment = Schema.Schema.Type<typeof PartAdjustmentSchema>;\n export const Adjustment = Schema.mutable(Schema.Struct({ id: Schema.String, type: PartAdjustmentSchema }));\n export type Adjustment = Schema.Schema.Type<typeof Adjustment>;\n\n // An atomic transaction to apply to the deck, describing which element to move to which location.\n export class Adjust extends Schema.TaggedClass<Adjust>()(`${meta.id}.action.adjust`, {\n input: Adjustment,\n output: Schema.Void,\n }) {}\n\n export class UpdatePlankSize extends Schema.TaggedClass<UpdatePlankSize>()(`${meta.id}.action.update-plank-size`, {\n input: Schema.Struct({\n id: Schema.String,\n size: Schema.Number,\n }),\n output: Schema.Void,\n }) {}\n}\n", "//\n// Copyright 2025 DXOS.org\n//\n\n// @import-as-namespace\n\nimport { type Atom } from '@effect-atom/atom-react';\nimport * as Effect from 'effect/Effect';\n\nimport { Capabilities, Capability } from '@dxos/app-framework';\nimport { invariant } from '@dxos/invariant';\n\nimport { meta } from '#meta';\n\nimport { type EphemeralDeckState, type DeckState, type StoredDeckState } from './schema';\n\nexport const Settings = Capability.make<Atom.Writable<import('./Settings').Settings>>(`${meta.id}.capability.settings`);\n\n/** Persisted state (stored in KVS/localStorage). */\nexport const State = Capability.make<Atom.Writable<StoredDeckState>>(`${meta.id}.capability.state`);\n\n/** Transient/ephemeral state (not persisted). */\nexport const EphemeralState = Capability.make<Atom.Writable<EphemeralDeckState>>(\n `${meta.id}.capability.ephemeral-state`,\n);\n\n/** Get the current active deck from state. */\nexport const getDeck = (): Effect.Effect<DeckState, Error, Capability.Service> =>\n Effect.gen(function* () {\n const state = yield* Capabilities.getAtomValue(State);\n const deck = state.decks[state.activeDeck];\n invariant(deck, `Deck not found: ${state.activeDeck}`);\n return deck;\n });\n", "//\n// Copyright 2025 DXOS.org\n//\n\n// @import-as-namespace\n\nimport { type ActivationEvent } from '@dxos/app-framework';\nimport { AppActivationEvents } from '@dxos/app-toolkit';\n\nimport { meta } from '#meta';\n\nimport * as DeckCapabilities from './DeckCapabilities';\n\nexport const StateReady: ActivationEvent.ActivationEvent = AppActivationEvents.createStateEvent(\n `${meta.id}.state-ready`,\n);\n\n/** Fired when DeckSettings capability is ready. */\nexport const SettingsReady: ActivationEvent.ActivationEvent = AppActivationEvents.createSettingsEvent(\n DeckCapabilities.Settings.identifier,\n);\n", "//\n// Copyright 2025 DXOS.org\n//\n\n// @import-as-namespace\n\nimport * as Schema from 'effect/Schema';\n\nimport { Capability } from '@dxos/app-framework';\nimport { Operation } from '@dxos/compute';\nimport { DXN } from '@dxos/keys';\n\nimport { meta } from '#meta';\n\nconst makeKey = (name: string) => DXN.make(`${meta.id}.operation.${name}`);\n\nconst PartAdjustmentSchema = Schema.Union(\n Schema.Literal('close').annotations({ description: 'Close the plank.' }),\n Schema.Literal('companion').annotations({ description: 'Open the companion plank.' }),\n Schema.Literal('solo').annotations({ description: 'Solo the plank.' }),\n Schema.Literal('solo--fullscreen').annotations({ description: 'Fullscreen the plank.' }),\n Schema.Literal('increment-start').annotations({ description: 'Move the plank towards the start of the deck.' }),\n Schema.Literal('increment-end').annotations({ description: 'Move the plank towards the end of the deck.' }),\n);\n\nexport type PartAdjustment = Schema.Schema.Type<typeof PartAdjustmentSchema>;\n\nexport const Adjust = Operation.make({\n meta: {\n key: makeKey('adjust'),\n name: 'Adjust',\n description: 'Adjust the layout of a plank.',\n icon: 'ph--layout--regular',\n },\n services: [Capability.Service],\n input: Schema.Struct({\n id: Schema.String.annotations({ description: 'The id of the plank to adjust.' }),\n type: PartAdjustmentSchema.annotations({ description: 'The type of adjustment to make.' }),\n }),\n output: Schema.Void,\n});\n\nexport const UpdatePlankSize = Operation.make({\n meta: {\n key: makeKey('updatePlankSize'),\n name: 'Update Plank Size',\n description: 'Update the size of a plank.',\n icon: 'ph--arrows-out--regular',\n },\n services: [Capability.Service],\n input: Schema.Struct({\n id: Schema.String.annotations({ description: 'The id of the plank to resize.' }),\n size: Schema.Number.annotations({ description: 'The new size of the plank.' }),\n }),\n output: Schema.Void,\n});\n", "//\n// Copyright 2023 DXOS.org\n//\n\n// @import-as-namespace\n\nimport * as Schema from 'effect/Schema';\n\nexport const Settings = Schema.Struct({\n enableDeck: Schema.optional(\n Schema.Boolean.annotations({\n title: 'Enable Deck',\n description: 'Display multiple panels side by side instead of one at a time.',\n }),\n ),\n // TODO(burdon): Rename layoutMode? (e.g., bento/encapsulated or floating/compact, etc.)\n encapsulatedPlanks: Schema.optional(\n Schema.Boolean.annotations({\n title: 'Encapsulated planks',\n description: 'Render each plank inside its own isolated container.',\n }),\n ),\n showHints: Schema.optional(\n Schema.Boolean.annotations({\n title: 'Show hints',\n description: 'Show helpful tips and keyboard shortcut hints in the interface.',\n }),\n ),\n enableNativeRedirect: Schema.optional(\n Schema.Boolean.annotations({\n title: 'Enable native url redirect',\n description: 'Redirect supported URLs to the native desktop application.',\n }),\n ),\n}).pipe(Schema.mutable);\nexport interface Settings extends Schema.Schema.Type<typeof Settings> {}\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["Schema", "Label", "LayoutOperation", "meta", "PLANK_COMPANION_TYPE", "DECK_COMPANION_TYPE", "PlankSizing", "Record", "key", "String", "value", "Number", "DeckState", "Struct", "initialized", "Boolean", "active", "mutable", "Array", "inactive", "solo", "optional", "fullscreen", "plankSizing", "companionOpen", "companionVariant", "companionFrameSizing", "defaultDeck", "undefined", "LayoutMode", "Literal", "isLayoutMode", "is", "getMode", "deck", "StoredDeckState", "sidebarState", "complementarySidebarState", "complementarySidebarPanel", "activeDeck", "previousDeck", "decks", "previousMode", "pipe", "EphemeralDeckState", "dialogOpen", "dialogType", "dialogBlockAlign", "dialogOverlayClasses", "dialogOverlayStyle", "Any", "dialogContent", "NullOr", "component", "props", "popoverOpen", "popoverSide", "popoverAnchor", "popoverAnchorId", "popoverKind", "popoverTitle", "annotations", "description", "popoverContentRef", "popoverContent", "Union", "subject", "toasts", "Toast", "currentUndoId", "scrollIntoView", "DeckAction", "PartAdjustmentSchema", "Adjustment", "id", "type", "Adjust", "TaggedClass", "input", "output", "Void", "UpdatePlankSize", "size", "Effect", "Capabilities", "Capability", "invariant", "meta", "Settings", "EphemeralState", "getDeck", "State", "deck", "activeDeck", "AppActivationEvents", "meta", "StateReady", "AppActivationEvents", "createStateEvent", "meta", "id", "SettingsReady", "createSettingsEvent", "Settings", "identifier", "Schema", "Capability", "Operation", "DXN", "meta", "makeKey", "name", "make", "id", "PartAdjustmentSchema", "Union", "Literal", "annotations", "description", "Adjust", "key", "icon", "services", "Service", "input", "Struct", "String", "type", "output", "Void", "UpdatePlankSize", "size", "Number", "Settings", "Schema", "Struct", "enableDeck", "optional", "Boolean", "annotations", "title", "description", "encapsulatedPlanks", "showHints", "enableNativeRedirect", "pipe", "mutable"]
|
|
7
|
-
}
|
|
@@ -1,7 +0,0 @@
|
|
|
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 { fromUrlPath, toUrlPath } 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, 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(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": ["fromUrlPath", "toUrlPath", "PLANK_PARAM", "serializePlanks", "active", "existingSearch", "params", "URLSearchParams", "delete", "id", "append", "size", "toString", "deserializePlanks", "url", "searchParams", "getAll", "map", "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
|
-
}
|
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
// src/meta.ts
|
|
2
|
-
import { Plugin } from "@dxos/app-framework";
|
|
3
|
-
import { DXN } from "@dxos/keys";
|
|
4
|
-
import { trim } from "@dxos/util";
|
|
5
|
-
var meta = Plugin.makeMeta({
|
|
6
|
-
key: DXN.make("org.dxos.plugin.deck"),
|
|
7
|
-
name: "Layout",
|
|
8
|
-
author: "DXOS",
|
|
9
|
-
spec: "PLUGIN.mdl",
|
|
10
|
-
description: trim`
|
|
11
|
-
The Deck plugin is the core layout engine for DXOS Composer. It manages the multi-plank
|
|
12
|
-
workspace (the "deck"), sidebar panels, dialogs, popovers, and toast notifications, giving
|
|
13
|
-
users a flexible, persistent workspace they can arrange to match their workflow.
|
|
14
|
-
|
|
15
|
-
In multi mode, subjects are opened as resizable "planks" arranged side by side. Users can
|
|
16
|
-
navigate with stack semantics — opening from a pivot truncates planks to the right and
|
|
17
|
-
appends the new one — or switch to solo or fullscreen mode for focused, distraction-free
|
|
18
|
-
viewing.
|
|
19
|
-
|
|
20
|
-
Layout state (active planks, sidebar visibility, plank sizes, companion pane) is persisted
|
|
21
|
-
across sessions via KVS/localStorage. URL routing is handled by the plugin so that any
|
|
22
|
-
workspace configuration can be bookmarked or shared as a deep link.
|
|
23
|
-
|
|
24
|
-
All layout changes are expressed through typed LayoutOperations (Open, Close, SetLayoutMode,
|
|
25
|
-
UpdateSidebar, UpdateDialog, UpdatePopover, etc.) that any plugin in the system can dispatch,
|
|
26
|
-
keeping the layout logic centralised and easy to extend.
|
|
27
|
-
`,
|
|
28
|
-
icon: "ph--layout--regular",
|
|
29
|
-
tags: [
|
|
30
|
-
"system"
|
|
31
|
-
]
|
|
32
|
-
});
|
|
33
|
-
|
|
34
|
-
export {
|
|
35
|
-
meta
|
|
36
|
-
};
|
|
37
|
-
//# sourceMappingURL=chunk-PYEY5SEC.mjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/meta.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { Plugin } from '@dxos/app-framework';\nimport { DXN } from '@dxos/keys';\nimport { trim } from '@dxos/util';\n\nexport const meta = Plugin.makeMeta({\n key: DXN.make('org.dxos.plugin.deck'),\n name: 'Layout',\n author: 'DXOS',\n spec: 'PLUGIN.mdl',\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: 'ph--layout--regular',\n tags: ['system'],\n});\n"],
|
|
5
|
-
"mappings": ";AAIA,SAASA,cAAc;AACvB,SAASC,WAAW;AACpB,SAASC,YAAY;AAEd,IAAMC,OAAOH,OAAOI,SAAS;EAClCC,KAAKJ,IAAIK,KAAK,sBAAA;EACdC,MAAM;EACNC,QAAQ;EACRC,MAAM;EACNC,aAAaR;;;;;;;;;;;;;;;;;;EAkBbS,MAAM;EACNC,MAAM;IAAC;;AACT,CAAA;",
|
|
6
|
-
"names": ["Plugin", "DXN", "trim", "meta", "makeMeta", "key", "make", "name", "author", "spec", "description", "icon", "tags"]
|
|
7
|
-
}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
// src/operations/index.ts
|
|
2
|
-
import { OperationHandlerSet } from "@dxos/compute";
|
|
3
|
-
var DeckOperationHandlerSet = OperationHandlerSet.lazy(() => import("./add-toast-TNB6DXWU.mjs"), () => import("./adjust-HNU5CCRO.mjs"), () => import("./close-ASKR22A6.mjs"), () => import("./open-5OYNO3RT.mjs"), () => import("./revert-workspace-B2QLT2C4.mjs"), () => import("./scroll-into-view-B52C3PJO.mjs"), () => import("./set-PA35ONXO.mjs"), () => import("./set-layout-mode-RPCCPQRB.mjs"), () => import("./switch-workspace-LZF4KZXH.mjs"), () => import("./update-companion-YUCZZVGY.mjs"), () => import("./update-complementary-7FZNB55J.mjs"), () => import("./update-dialog-FNQTSSAP.mjs"), () => import("./update-plank-size-3YW4NXEY.mjs"), () => import("./update-popover-G2VUD7E6.mjs"), () => import("./update-sidebar-KRHPUHUB.mjs"));
|
|
4
|
-
|
|
5
|
-
export {
|
|
6
|
-
DeckOperationHandlerSet
|
|
7
|
-
};
|
|
8
|
-
//# sourceMappingURL=chunk-Q4W6B4IB.mjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
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.id);\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, toLocalizedString, useTranslation } from '@dxos/react-ui';\nimport { getLinkedVariant } from '@dxos/react-ui-attention';\nimport { StackItem, type StackItemSigilAction } from '@dxos/react-ui-stack';\nimport { TextTooltip } from '@dxos/react-ui-text-tooltip';\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.id);\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.id }], 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.id });\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.id}:${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.id);\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.id);\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.id);\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.id);\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.id);\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 { 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.id }] 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.id);\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 role='status-indicator' />\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.id);\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 role={`deck-companion--${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.id }] 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 { type ThemedClassName, useTranslation } from '@dxos/react-ui';\nimport { mx, osTranslations } from '@dxos/ui-theme';\n\nimport { meta } from '#meta';\n\nimport { CloseSidebarButton, ToggleSidebarButton } from '../Sidebar';\n\nexport const Banner = ({ variant, classNames }: ThemedClassName<{ variant?: 'topbar' | 'sidebar' }>) => {\n const { t } = useTranslation(meta.id);\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 role='search-input' limit={1} />\n </div>\n </div>\n )}\n <span className='grow' />\n <Surface.Surface role='version-info' limit={1} />\n <Surface.Surface role='notch-start' 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 } from '#types';\nimport { getMode } 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 role='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.id);\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", "toLocalizedString", "useTranslation", "getLinkedVariant", "StackItem", "TextTooltip", "hoverableControls", "hoverableFocusedWithinControls", "iconSize", "useBreakpoints", "meta", "PLANK_COMPANION_TYPE", "React", "forwardRef", "useCallback", "useOperationInvoker", "LayoutOperation", "ButtonGroup", "IconButton", "useTranslation", "meta", "plankControlSpacing", "PlankCompanionControls", "primary", "forwardedRef", "t", "id", "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", "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", "key", "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", "id", "handleClick", "state", "sidebarState", "icon", "iconOnly", "size", "label", "onClick", "CloseSidebarButton", "ToggleComplementarySidebarButton", "inR0", "current", "invokePromise", "companions", "nextState", "complementarySidebarState", "subject", "complementarySidebarPanel", "UpdateComplementary", "tooltipSide", "undefined", "React", "useCallback", "useEffect", "useMemo", "useState", "Surface", "useOperationInvoker", "LayoutOperation", "IconButton", "Main", "Panel", "toLocalizedString", "Toolbar", "useTranslation", "getLinkedVariant", "Tabs", "iconSize", "mx", "useBreakpoints", "useDeckCompanions", "useDeckState", "meta", "getMode", "label", "ns", "meta", "id", "ComplementarySidebar", "current", "invokePromise", "useOperationInvoker", "t", "useTranslation", "state", "deck", "updateState", "useDeckState", "layoutMode", "getMode", "breakpoint", "useBreakpoints", "topbar", "layoutAppliesTopbar", "companions", "useDeckCompanions", "activeCompanion", "find", "companion", "getLinkedVariant", "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", "key", "asChild", "IconButton", "toLocalizedString", "properties", "icon", "iconOnly", "tooltipSide", "data-value", "joyride", "variant", "onClick", "Surface", "role", "ToggleComplementarySidebarButton", "Panel", "inert", "ComplementarySidebarPanel", "Toolbar", "size", "Content", "fallback", "PlankErrorFallback", "placeholder", "PlankLoading", "React", "useMemo", "Surface", "AppSurface", "Main", "useBreakpoints", "useDeckState", "meta", "getMode", "label", "ns", "meta", "id", "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", "useTranslation", "mx", "osTranslations", "meta", "Banner", "variant", "classNames", "t", "useTranslation", "meta", "id", "React", "header", "className", "mx", "CloseSidebarButton", "ToggleSidebarButton", "span", "ns", "osTranslations", "div", "Surface", "role", "limit", "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", "__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", "role", "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", "type", "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
|
-
}
|