@dxos/plugin-deck 0.8.4-main.e098934 → 0.8.4-main.ead640a

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.
Files changed (111) hide show
  1. package/dist/lib/browser/{app-graph-builder-DVEKLXB4.mjs → app-graph-builder-YYP67JHW.mjs} +15 -14
  2. package/dist/lib/browser/app-graph-builder-YYP67JHW.mjs.map +7 -0
  3. package/dist/lib/browser/{check-app-scheme-3BQJXWEY.mjs → check-app-scheme-GCOL6YDT.mjs} +6 -6
  4. package/dist/lib/browser/check-app-scheme-GCOL6YDT.mjs.map +7 -0
  5. package/dist/lib/browser/{chunk-F5BQOOEG.mjs → chunk-7I6H3N4Q.mjs} +8 -6
  6. package/dist/lib/browser/chunk-7I6H3N4Q.mjs.map +7 -0
  7. package/dist/lib/browser/chunk-HUWUYTOI.mjs +16 -0
  8. package/dist/lib/browser/chunk-HUWUYTOI.mjs.map +7 -0
  9. package/dist/lib/browser/{chunk-NU7H23SK.mjs → chunk-JQKOS2HB.mjs} +341 -308
  10. package/dist/lib/browser/chunk-JQKOS2HB.mjs.map +7 -0
  11. package/dist/lib/browser/chunk-MHP4GPX5.mjs +11 -0
  12. package/dist/lib/browser/chunk-MHP4GPX5.mjs.map +7 -0
  13. package/dist/lib/browser/{chunk-WILMPGDV.mjs → chunk-RJP5R7PY.mjs} +14 -14
  14. package/dist/lib/browser/{chunk-WILMPGDV.mjs.map → chunk-RJP5R7PY.mjs.map} +3 -3
  15. package/dist/lib/browser/{chunk-NRCPV6AV.mjs → chunk-VX7MMQOW.mjs} +9 -9
  16. package/dist/lib/browser/chunk-VX7MMQOW.mjs.map +7 -0
  17. package/dist/lib/browser/index.mjs +8 -9
  18. package/dist/lib/browser/index.mjs.map +3 -3
  19. package/dist/lib/browser/{intent-resolver-2SUIIV6N.mjs → intent-resolver-7XNOEPVN.mjs} +20 -17
  20. package/dist/lib/browser/intent-resolver-7XNOEPVN.mjs.map +7 -0
  21. package/dist/lib/browser/meta.json +1 -1
  22. package/dist/lib/browser/{react-root-7PRVDLF7.mjs → react-root-OJEF7YCH.mjs} +11 -11
  23. package/dist/lib/browser/react-root-OJEF7YCH.mjs.map +7 -0
  24. package/dist/lib/browser/{react-surface-FNY2YC2F.mjs → react-surface-XN2NJYHO.mjs} +13 -13
  25. package/dist/lib/browser/react-surface-XN2NJYHO.mjs.map +7 -0
  26. package/dist/lib/browser/{settings-LUPQPZ27.mjs → settings-M3KSKRAP.mjs} +7 -6
  27. package/dist/lib/browser/{settings-LUPQPZ27.mjs.map → settings-M3KSKRAP.mjs.map} +3 -3
  28. package/dist/lib/browser/state-6ZSDTF6Q.mjs +12 -0
  29. package/dist/lib/browser/{toolkit-XGJSBY67.mjs → toolkit-L7C3UAEU.mjs} +14 -12
  30. package/dist/lib/browser/toolkit-L7C3UAEU.mjs.map +7 -0
  31. package/dist/lib/browser/types/index.mjs +2 -2
  32. package/dist/lib/browser/{url-handler-LROZYQ26.mjs → url-handler-EHTLXZRR.mjs} +6 -6
  33. package/dist/lib/browser/{url-handler-LROZYQ26.mjs.map → url-handler-EHTLXZRR.mjs.map} +1 -1
  34. package/dist/types/src/DeckPlugin.d.ts +1 -1
  35. package/dist/types/src/DeckPlugin.d.ts.map +1 -1
  36. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  37. package/dist/types/src/capabilities/capabilities.d.ts.map +1 -1
  38. package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
  39. package/dist/types/src/capabilities/settings.d.ts.map +1 -1
  40. package/dist/types/src/capabilities/state.d.ts +3 -0
  41. package/dist/types/src/capabilities/state.d.ts.map +1 -1
  42. package/dist/types/src/capabilities/toolkit.d.ts +3 -2
  43. package/dist/types/src/capabilities/toolkit.d.ts.map +1 -1
  44. package/dist/types/src/components/DeckLayout/DeckLayout.d.ts +2 -3
  45. package/dist/types/src/components/DeckLayout/DeckLayout.d.ts.map +1 -1
  46. package/dist/types/src/components/DeckLayout/DeckLayout.stories.d.ts +74 -0
  47. package/dist/types/src/components/DeckLayout/DeckLayout.stories.d.ts.map +1 -0
  48. package/dist/types/src/components/DeckLayout/DeckMain.d.ts +3 -0
  49. package/dist/types/src/components/DeckLayout/DeckMain.d.ts.map +1 -0
  50. package/dist/types/src/components/DeckLayout/Toast.d.ts +5 -0
  51. package/dist/types/src/components/DeckLayout/Toast.d.ts.map +1 -1
  52. package/dist/types/src/components/DeckSettings/DeckSettings.d.ts.map +1 -1
  53. package/dist/types/src/components/Plank/Plank.d.ts.map +1 -1
  54. package/dist/types/src/components/Plank/Plank.stories.d.ts +2 -1
  55. package/dist/types/src/components/Plank/Plank.stories.d.ts.map +1 -1
  56. package/dist/types/src/events.d.ts.map +1 -1
  57. package/dist/types/src/hooks/useHoistStatusbar.d.ts.map +1 -1
  58. package/dist/types/src/meta.d.ts +0 -1
  59. package/dist/types/src/meta.d.ts.map +1 -1
  60. package/dist/types/src/translations.d.ts +1 -0
  61. package/dist/types/src/translations.d.ts.map +1 -1
  62. package/dist/types/src/types/schema.d.ts +4 -3
  63. package/dist/types/src/types/schema.d.ts.map +1 -1
  64. package/dist/types/tsconfig.tsbuildinfo +1 -1
  65. package/package.json +43 -43
  66. package/src/DeckPlugin.ts +62 -63
  67. package/src/capabilities/app-graph-builder.ts +10 -9
  68. package/src/capabilities/capabilities.ts +3 -3
  69. package/src/capabilities/check-app-scheme.ts +2 -2
  70. package/src/capabilities/intent-resolver.ts +12 -9
  71. package/src/capabilities/react-root.tsx +2 -2
  72. package/src/capabilities/react-surface.tsx +4 -4
  73. package/src/capabilities/settings.ts +1 -0
  74. package/src/capabilities/state.ts +7 -4
  75. package/src/capabilities/toolkit.ts +9 -7
  76. package/src/capabilities/tools.ts +1 -1
  77. package/src/components/DeckLayout/Banner.tsx +2 -2
  78. package/src/components/DeckLayout/DeckLayout.stories.tsx +64 -0
  79. package/src/components/DeckLayout/DeckLayout.tsx +8 -278
  80. package/src/components/DeckLayout/DeckMain.tsx +285 -0
  81. package/src/components/DeckLayout/Fallback.tsx +2 -2
  82. package/src/components/DeckLayout/Toast.tsx +27 -2
  83. package/src/components/DeckSettings/DeckSettings.tsx +9 -3
  84. package/src/components/Plank/Plank.stories.tsx +3 -5
  85. package/src/components/Plank/Plank.tsx +25 -9
  86. package/src/components/Plank/PlankControls.tsx +3 -3
  87. package/src/components/Plank/PlankError.tsx +2 -2
  88. package/src/components/Plank/PlankHeading.tsx +5 -5
  89. package/src/components/Sidebar/ComplementarySidebar.tsx +5 -5
  90. package/src/components/Sidebar/Sidebar.tsx +2 -2
  91. package/src/components/Sidebar/SidebarButton.tsx +4 -4
  92. package/src/events.ts +2 -2
  93. package/src/hooks/useHoistStatusbar.ts +4 -3
  94. package/src/meta.ts +1 -3
  95. package/src/translations.ts +1 -0
  96. package/src/types/schema.ts +5 -3
  97. package/dist/lib/browser/app-graph-builder-DVEKLXB4.mjs.map +0 -7
  98. package/dist/lib/browser/check-app-scheme-3BQJXWEY.mjs.map +0 -7
  99. package/dist/lib/browser/chunk-F5BQOOEG.mjs.map +0 -7
  100. package/dist/lib/browser/chunk-M57WD3V6.mjs +0 -16
  101. package/dist/lib/browser/chunk-M57WD3V6.mjs.map +0 -7
  102. package/dist/lib/browser/chunk-NRCPV6AV.mjs.map +0 -7
  103. package/dist/lib/browser/chunk-NU7H23SK.mjs.map +0 -7
  104. package/dist/lib/browser/chunk-Z5KITAZW.mjs +0 -13
  105. package/dist/lib/browser/chunk-Z5KITAZW.mjs.map +0 -7
  106. package/dist/lib/browser/intent-resolver-2SUIIV6N.mjs.map +0 -7
  107. package/dist/lib/browser/react-root-7PRVDLF7.mjs.map +0 -7
  108. package/dist/lib/browser/react-surface-FNY2YC2F.mjs.map +0 -7
  109. package/dist/lib/browser/state-CRXR7X63.mjs +0 -12
  110. package/dist/lib/browser/toolkit-XGJSBY67.mjs.map +0 -7
  111. /package/dist/lib/browser/{state-CRXR7X63.mjs.map → state-6ZSDTF6Q.mjs.map} +0 -0
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/DeckLayout/Banner.tsx", "../../../src/components/Sidebar/ComplementarySidebar.tsx", "../../../src/components/Plank/Plank.tsx", "../../../src/components/Plank/PlankError.tsx", "../../../src/components/Plank/PlankHeading.tsx", "../../../src/components/fragments.ts", "../../../src/components/Plank/PlankControls.tsx", "../../../src/components/Plank/PlankLoading.tsx", "../../../src/components/Sidebar/SidebarButton.tsx", "../../../src/components/Sidebar/Sidebar.tsx", "../../../src/components/DeckLayout/DeckLayout.tsx", "../../../src/components/DeckLayout/ActiveNode.tsx", "../../../src/components/DeckLayout/DeckMain.tsx", "../../../src/components/DeckLayout/ContentEmpty.tsx", "../../../src/components/DeckLayout/StatusBar.tsx", "../../../src/components/DeckLayout/Topbar.tsx", "../../../src/components/DeckLayout/Dialog.tsx", "../../../src/components/DeckLayout/Popover.tsx", "../../../src/components/DeckLayout/Toast.tsx", "../../../src/components/DeckSettings/DeckSettings.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Surface } from '@dxos/app-framework';\nimport { type ThemedClassName, useTranslation } from '@dxos/react-ui';\nimport { mx } from '@dxos/react-ui-theme';\n\nimport { meta } from '../../meta';\nimport { CloseSidebarButton, ToggleSidebarButton } from '../Sidebar';\n\nexport const Banner = ({ variant, classNames }: ThemedClassName<{ variant?: 'topbar' | 'sidebar' }>) => {\n const { t } = useTranslation(meta.id);\n return (\n <header\n className={mx(\n 'flex items-stretch relative plb-1 pis-1 pie-2',\n variant === 'topbar' &&\n 'fixed inset-inline-0 block-start-[env(safe-area-inset-top)] bs-[--rail-size] border-be border-separator',\n classNames,\n )}\n >\n {variant === 'sidebar' ? <CloseSidebarButton /> : <ToggleSidebarButton />}\n <span className='self-center grow mis-1'>{t('current app name', { ns: 'appkit' })}</span>\n {variant === 'topbar' && (\n <div role='none' className='absolute inset-0 pointer-events-none'>\n <div role='none' className='grid bs-full pointer-fine:p-1 max-is-md mli-auto pointer-events-auto'>\n <Surface role='search-input' limit={1} />\n </div>\n </div>\n )}\n <span role='none' className='grow' />\n <Surface role='header-end' limit={1} />\n <Surface role='notch-start' limit={1} />\n </header>\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, {\n Fragment,\n type MouseEvent,\n type PropsWithChildren,\n useCallback,\n useEffect,\n useMemo,\n useState,\n} from 'react';\n\nimport { LayoutAction, Surface, createIntent, useCapability, useIntentDispatcher } from '@dxos/app-framework';\nimport { IconButton, type Label, Main, toLocalizedString, useTranslation } from '@dxos/react-ui';\nimport { Tabs } from '@dxos/react-ui-tabs';\n\nimport { DeckCapabilities } from '../../capabilities';\nimport { type DeckCompanion, getCompanionId, useBreakpoints, useDeckCompanions, useHoistStatusbar } from '../../hooks';\nimport { meta } from '../../meta';\nimport { getMode } from '../../types';\nimport { layoutAppliesTopbar } from '../../util';\nimport { PlankContentError, PlankLoading } from '../Plank';\n\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 { t } = useTranslation(meta.id);\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const layout = useCapability(DeckCapabilities.MutableDeckState);\n const layoutMode = getMode(layout.deck);\n const breakpoint = useBreakpoints();\n const topbar = layoutAppliesTopbar(breakpoint, layoutMode);\n const hoistStatusbar = useHoistStatusbar(breakpoint, layoutMode);\n\n const companions = useDeckCompanions();\n const activeCompanion = companions.find((companion) => getCompanionId(companion.id) === current);\n const activeId = activeCompanion && getCompanionId(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 layout.complementarySidebarState = layout.complementarySidebarState === 'expanded' ? 'collapsed' : 'expanded';\n } else {\n setInternalValue(nextValue);\n layout.complementarySidebarState = 'expanded';\n void dispatch(createIntent(LayoutAction.UpdateComplementary, { part: 'complementary', subject: nextValue }));\n }\n },\n [layout, activeId, dispatch],\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 dispatch(\n createIntent(LayoutAction.UpdateComplementary, { part: 'complementary', options: { state: 'collapsed' } }),\n );\n }\n }, [activeId, dispatch]);\n\n return (\n <Main.ComplementarySidebar\n label={label}\n classNames={[\n topbar && 'block-start-[calc(env(safe-area-inset-top)+var(--rail-size))]',\n hoistStatusbar && 'block-end-[--statusbar-size]',\n ]}\n >\n <Tabs.Root orientation='vertical' verticalVariant='stateless' value={internalValue} classNames='contents'>\n <div\n role='none'\n className='absolute z-[1] inset-block-0 inline-end-0 !is-[--r0-size] pbs-[env(safe-area-inset-top)] pbe-[env(safe-area-inset-bottom)] border-is border-subduedSeparator grid grid-cols-1 grid-rows-[1fr_min-content] bg-baseSurface contain-layout app-drag'\n >\n <Tabs.Tablist classNames='grid grid-cols-1 auto-rows-[--rail-action] p-1 gap-1 !overflow-y-auto'>\n {companions.map((companion) => (\n <Tabs.Tab key={getCompanionId(companion.id)} value={getCompanionId(companion.id)} asChild>\n <IconButton\n label={toLocalizedString(companion.properties.label, t)}\n icon={companion.properties.icon}\n size={5}\n iconOnly\n tooltipSide='left'\n data-value={getCompanionId(companion.id)}\n variant={\n activeId === getCompanionId(companion.id)\n ? layout.complementarySidebarState === 'expanded'\n ? 'primary'\n : 'default'\n : 'ghost'\n }\n onClick={handleTabClick}\n />\n </Tabs.Tab>\n ))}\n </Tabs.Tablist>\n {!hoistStatusbar && (\n <div role='none' className='grid grid-cols-1 auto-rows-[--rail-item] p-1 overflow-y-auto'>\n <Surface role='status-bar--r0-footer' limit={1} />\n </div>\n )}\n <div role='none' className='hidden lg:grid grid-cols-1 auto-rows-[--rail-action] p-1'>\n <ToggleComplementarySidebarButton />\n </div>\n </div>\n {activeId &&\n companions.map((companion) => (\n <Tabs.Tabpanel\n key={getCompanionId(companion.id)}\n value={getCompanionId(companion.id)}\n classNames='absolute data-[state=\"inactive\"]:-z-[1] inset-block-0 inline-start-0 is-[calc(100%-var(--r0-size))] lg:is-[--r1-size] grid grid-cols-1 grid-rows-[var(--rail-size)_1fr_min-content] pbs-[env(safe-area-inset-top)]'\n {...(layout.complementarySidebarState !== 'expanded' && { inert: true })}\n >\n <ComplementarySidebarPanel\n companion={companion}\n activeId={activeId}\n data={data}\n hoistStatusbar={hoistStatusbar}\n />\n </Tabs.Tabpanel>\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 hoistStatusbar: boolean;\n};\n\nconst ScrollArea = ({ children }: PropsWithChildren) => {\n return <div className='flex flex-col grow overflow-x-hidden overflow-y-auto scrollbar-thin'>{children}</div>;\n};\n\nconst ComplementarySidebarPanel = ({ companion, activeId, data, hoistStatusbar }: ComplementarySidebarPanelProps) => {\n const { t } = useTranslation(meta.id);\n\n if (getCompanionId(companion.id) !== activeId && !data) {\n return null;\n }\n\n const Wrapper = companion.properties.fixed ? Fragment : ScrollArea;\n\n return (\n <>\n <h2 className='flex items-center pli-2 border-subduedSeparator border-be font-medium'>\n {toLocalizedString(companion.properties.label, t)}\n </h2>\n <Wrapper>\n <Surface\n role={`deck-companion--${getCompanionId(companion.id)}`}\n data={data}\n fallback={PlankContentError}\n placeholder={<PlankLoading />}\n />\n </Wrapper>\n {!hoistStatusbar && (\n <div\n role='contentinfo'\n className='flex flex-wrap justify-center items-center border-bs border-subduedSeparator pbs-1 pbe-[max(env(safe-area-inset-bottom),0.25rem)]'\n >\n <Surface role='status-bar--r1-footer' limit={1} />\n </div>\n )}\n </>\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, {\n type KeyboardEvent,\n type PropsWithChildren,\n memo,\n useCallback,\n useLayoutEffect,\n useMemo,\n useRef,\n} from 'react';\n\nimport {\n LayoutAction,\n Surface,\n createIntent,\n useAppGraph,\n useCapability,\n useIntentDispatcher,\n} from '@dxos/app-framework';\nimport { debounce } from '@dxos/async';\nimport { type Node, useNode } from '@dxos/plugin-graph';\nimport { ATTENDABLE_PATH_SEPARATOR, useAttentionAttributes } from '@dxos/react-ui-attention';\nimport { StackItem, railGridHorizontal } from '@dxos/react-ui-stack';\nimport { mainIntrinsicSize, mx } from '@dxos/react-ui-theme';\n\nimport { DeckCapabilities } from '../../capabilities';\nimport { useCompanions, useMainSize } from '../../hooks';\nimport { parseEntryId } from '../../layout';\nimport { DeckAction, type DeckSettingsProps, type LayoutMode, type ResolvedPart } from '../../types';\n\nimport { PlankContentError, PlankError } from './PlankError';\nimport { PlankHeading } from './PlankHeading';\nimport { PlankLoading } from './PlankLoading';\n\nconst UNKNOWN_ID = 'unknown_id';\n\nexport type PlankProps = Pick<PlankComponentProps, 'layoutMode' | 'part' | 'path' | 'order' | 'active' | 'settings'> & {\n id?: string;\n companionId?: string;\n};\n\n// TODO(burdon): Factor out conditional rendering.\n// Remove this wrapper component and render the entire set of planks in the deck with conditional visibility\n// to obviate mounting and unmounting when switching between solo and companion mode?\n// NOTE(thure, in reply): Whether any surface should be rendered and hidden is a performance matter — remember that\n// article surfaces contain full experiences, so being able to unmount them will yield relatively large performance\n// benefits. I think where we anticipate users will definitely want to quickly switch between showing and hiding entire\n// articles, over the (again probably large) performance benefit that unmounting them would confer, we can mount and\n// hide them, but I think that scenario in its most unambiguous form is probably rare. You could extrapolate\n// the scenario to include all “potential” planks such as companions, which we could keep mounted and hidden, but I\n// don’t think the resulting performance would be acceptable. I think the real issue is “perceived performance” which\n// has mitigations that are in between mounting and un-mounting since both of those have tradeoffs; we may need one or more\n// “partially-mounted” experiences, like loading skeletons at the simple end, or screenshots of “sleeping” planks at\n// the advanced end.\n\n/**\n * A Plank is the main container for surfaces within a Deck.\n * It may be paired with a companion plank that enables the user to select one of multiple companion surfaces.\n */\nexport const Plank = memo(({ id = UNKNOWN_ID, companionId, ...props }: PlankProps) => {\n const { graph } = useAppGraph();\n const node = useNode(graph, id);\n const companions = useCompanions(id);\n const currentCompanion = companions.find(({ id }) => id === companionId);\n const hasCompanion = !!(companionId && currentCompanion);\n\n return (\n <PlankContainer\n solo={props.part === 'solo'}\n companion={hasCompanion}\n encapsulate={!!props.settings?.encapsulatedPlanks}\n >\n <PlankComponent\n id={id}\n node={node}\n companioned={hasCompanion ? 'primary' : undefined}\n companions={hasCompanion ? [] : companions}\n {...props}\n {...(props.part === 'solo' ? { part: 'solo-primary' } : {})}\n />\n {hasCompanion && (\n <PlankComponent\n id={companionId}\n node={currentCompanion}\n primary={node}\n companions={companions}\n companioned='companion'\n {...props}\n {...(props.part === 'solo' ? { part: 'solo-companion' } : { order: (props.order ?? 0) + 1 })}\n />\n )}\n </PlankContainer>\n );\n});\n\nconst PlankContainer = ({\n children,\n solo,\n companion,\n encapsulate,\n}: PropsWithChildren<{ solo: boolean; companion: boolean; encapsulate: boolean }>) => {\n const sizeAttrs = useMainSize();\n if (!solo) {\n return children;\n }\n\n // TODO(burdon): Make resizable.\n return (\n <div\n role='none'\n className={mx(\n 'absolute inset-[--main-spacing] grid',\n encapsulate && 'border border-separator rounded overflow-hidden',\n companion && 'grid-cols-[6fr_4fr]',\n railGridHorizontal,\n mainIntrinsicSize,\n )}\n {...sizeAttrs}\n >\n {children}\n </div>\n );\n};\n\ntype PlankComponentProps = {\n layoutMode: LayoutMode;\n id: string;\n part: ResolvedPart;\n path?: string[];\n order?: number;\n active?: string[];\n // TODO(burdon): Change to role?\n companioned?: 'primary' | 'companion';\n node?: Node;\n primary?: Node;\n companions?: Node[];\n settings?: DeckSettingsProps;\n};\n\nconst PlankComponent = memo(\n ({\n layoutMode,\n id,\n part,\n path,\n order,\n active,\n companioned,\n node,\n primary,\n companions,\n settings,\n }: PlankComponentProps) => {\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const { deck, popoverAnchorId, scrollIntoView } = useCapability(DeckCapabilities.DeckState);\n const canResize = layoutMode === 'deck';\n\n const attentionAttrs = useAttentionAttributes(primary?.id ?? id);\n const index = active ? active.findIndex((entryId) => entryId === id) : 0;\n const length = active?.length ?? 1;\n const canIncrementStart = active && index !== undefined && index > 0 && length !== undefined && length > 1;\n const canIncrementEnd = active && index !== undefined && index < length - 1 && length !== undefined;\n\n const rootElement = useRef<HTMLDivElement | null>(null);\n\n const { variant } = parseEntryId(id);\n const sizeKey = `${id.split('+')[0]}${variant ? `${ATTENDABLE_PATH_SEPARATOR}${variant}` : ''}`;\n const size = deck.plankSizing[sizeKey] as number | undefined;\n\n const handleSizeChange = useCallback(\n debounce((nextSize: number) => {\n return dispatch(createIntent(DeckAction.UpdatePlankSize, { id: sizeKey, size: nextSize }));\n }, 200),\n [dispatch, sizeKey],\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 && event.key === 'Escape') {\n rootElement.current?.closest('main')?.focus();\n }\n }, []);\n\n useLayoutEffect(() => {\n if (scrollIntoView === id) {\n layoutMode === 'deck' && rootElement.current?.scrollIntoView({ behavior: 'smooth', inline: 'center' });\n // Clear the scroll into view state once it has been actioned.\n void dispatch(createIntent(LayoutAction.ScrollIntoView, { part: 'current', subject: undefined }));\n }\n }, [id, scrollIntoView, layoutMode]);\n\n const isSolo = layoutMode.startsWith('solo') && part === 'solo';\n const isAttendable =\n (layoutMode.startsWith('solo') && part.startsWith('solo')) || (layoutMode === 'deck' && part === 'deck');\n\n const sizeAttrs = useMainSize();\n\n const data = useMemo(\n () =>\n node && {\n attendableId: id,\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],\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 className = mx(\n 'attention-surface relative dx-focus-ring-inset-over-all density-coarse',\n isSolo && mainIntrinsicSize,\n isSolo && railGridHorizontal,\n isSolo && 'absolute inset-0',\n part.startsWith('solo') && 'grid',\n part === 'deck' && (companioned === 'companion' ? '!border-separator border-ie' : '!border-separator border-li'),\n part.startsWith('solo-') && 'row-span-2 grid-rows-subgrid min-is-0',\n part === 'solo-companion' && '!border-separator border-is',\n settings?.encapsulatedPlanks &&\n !part.startsWith('solo') &&\n 'mli-[--main-spacing] !border-separator border rounded overflow-hidden',\n );\n\n return (\n <Root\n ref={rootElement}\n data-testid='deck.plank'\n tabIndex={0}\n {...(part.startsWith('solo')\n ? ({ ...sizeAttrs, className } as any)\n : {\n item: { id },\n size,\n onSizeChange: handleSizeChange,\n classNames: className,\n order,\n role: 'article',\n })}\n {...(isAttendable ? attentionAttrs : {})}\n onKeyDown={handleKeyDown}\n >\n {node ? (\n <>\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 <Surface\n key={node.id}\n role='article'\n data={data}\n limit={1}\n fallback={PlankContentError}\n placeholder={placeholder}\n />\n </>\n ) : (\n <PlankError id={id} part={part} />\n )}\n\n {canResize && <StackItem.ResizeHandle />}\n </Root>\n );\n },\n);\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { useEffect, useState } from 'react';\n\nimport { type Node } from '@dxos/plugin-graph';\nimport { useTranslation } from '@dxos/react-ui';\nimport { descriptionMessage, mx } from '@dxos/react-ui-theme';\n\nimport { meta } from '../../meta';\n\nimport { PlankHeading, type PlankHeadingProps } from './PlankHeading';\nimport { PlankLoading } from './PlankLoading';\n\nexport const PlankContentError = ({ error }: { error?: Error }) => {\n const { t } = useTranslation(meta.id);\n const errorString = error?.toString() ?? '';\n return (\n <div role='none' className='overflow-y-auto p-8 attention-surface grid place-items-center'>\n <p role='alert' className={mx(descriptionMessage, 'break-all rounded-md p-4')}>\n {error ? errorString : t('error fallback message')}\n </p>\n </div>\n );\n};\n\nexport const PlankError = ({\n id,\n part,\n node,\n error,\n}: {\n id: string;\n part: PlankHeadingProps['part'];\n node?: Node;\n error?: Error;\n}) => {\n const [timedOut, setTimedOut] = useState(false);\n useEffect(() => {\n setTimeout(() => setTimedOut(true), 5e3);\n }, []);\n return (\n <>\n <PlankHeading id={id} part={part} node={node} pending={!timedOut} />\n {timedOut ? <PlankContentError error={error} /> : <PlankLoading />}\n </>\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { Fragment, type MouseEvent, memo, useCallback, useEffect, useMemo } from 'react';\n\nimport { LayoutAction, Surface, createIntent, useAppGraph, useIntentDispatcher } from '@dxos/app-framework';\nimport { type Node } from '@dxos/plugin-graph';\nimport { Icon, IconButton, Popover, toLocalizedString, useTranslation } from '@dxos/react-ui';\nimport { StackItem, type StackItemSigilAction } from '@dxos/react-ui-stack';\nimport { TextTooltip } from '@dxos/react-ui-text-tooltip';\nimport { hoverableControls, hoverableFocusedWithinControls } from '@dxos/react-ui-theme';\n\nimport { useBreakpoints } from '../../hooks';\nimport { parseEntryId } from '../../layout';\nimport { meta } from '../../meta';\nimport { DeckAction, type LayoutMode, PLANK_COMPANION_TYPE, type ResolvedPart } from '../../types';\nimport { soloInlinePadding } from '../fragments';\n\nimport { PlankCompanionControls, PlankControls } from './PlankControls';\n\nconst MAX_COMPANIONS = 5;\n\nexport type PlankHeadingProps = {\n id: string;\n part: ResolvedPart;\n layoutMode?: LayoutMode;\n 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[];\n actions?: StackItemSigilAction[];\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 }: PlankHeadingProps) => {\n const { t } = useTranslation(meta.id);\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const { graph } = useAppGraph();\n const breakpoint = useBreakpoints();\n const icon = node?.properties?.icon ?? 'ph--placeholder--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(node.id);\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 === 'deck'),\n incrementStart: canIncrementStart,\n incrementEnd: canIncrementEnd,\n fullscreen: !isCompanionNode,\n companion: !isCompanionNode && companions && companions.length > 0,\n }),\n [breakpoint, part, companions, canIncrementStart, canIncrementEnd, isCompanionNode, deckEnabled],\n );\n\n const { variant } = parseEntryId(id);\n const sigilActions = useMemo(() => {\n if (!node) {\n return undefined;\n } else if (variant) {\n return [];\n } else {\n return [\n actions,\n graph\n .getActions(node.id)\n .filter((a) => ['list-item', 'list-item-primary', 'heading-list-item'].includes(a.properties.disposition)),\n ].filter((a) => a.length > 0);\n }\n }, [actions, node, variant, graph]);\n\n const handleAction = useCallback(\n (action: StackItemSigilAction) => {\n typeof action.data === 'function' && void action.data?.({ parent: node, caller: meta.id });\n },\n [node],\n );\n\n const handlePlankAction = useCallback(\n (eventType: DeckAction.PartAdjustment) => {\n if (eventType.startsWith('solo')) {\n return dispatch(createIntent(DeckAction.Adjust, { type: eventType, id }));\n } else if (eventType === 'close') {\n if (part === 'complementary') {\n return dispatch(\n createIntent(LayoutAction.UpdateComplementary, {\n part: 'complementary',\n options: { state: 'collapsed' },\n }),\n );\n } else {\n return dispatch(\n createIntent(LayoutAction.Close, { part: 'main', subject: [id], options: { state: false } }),\n );\n }\n } else {\n return dispatch(createIntent(DeckAction.Adjust, { type: eventType, id }));\n }\n },\n [dispatch, id, part],\n );\n\n const ActionRoot = node && popoverAnchorId === `dxos.org/ui/${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 (primaryId && tabId) {\n void dispatch(\n createIntent(DeckAction.ChangeCompanion, {\n primary: primaryId,\n companion: tabId,\n }),\n );\n }\n },\n [primaryId],\n );\n\n return (\n <StackItem.Heading\n classNames={[\n 'plb-1 items-stretch gap-1 sticky inline-start-12 app-drag min-is-0 contain-layout density-coarse',\n part === 'solo' ? soloInlinePadding : 'pli-1',\n ...(layoutMode === 'solo--fullscreen'\n ? [\n hoverableControls,\n hoverableFocusedWithinControls,\n '*:transition-opacity *:opacity-[--controls-opacity] bg-transparent border-transparent transition-[background-color,border-color] hover-hover:hover:bg-headerSurface focus-within:bg-headerSurface hover-hover:hover:border-subduedSeparator focus-within:border-subduedSeparator',\n ]\n : []),\n ]}\n data-plank-heading\n >\n {companions && isCompanionNode ? (\n /* TODO(thure): IMPORTANT: This is a tablist; it should be implemented as such. */\n <div role='none' className='flex-1 min-is-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 size={5}\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 role='menu-footer' data={{ subject: node.data }} />\n </StackItem.Sigil>\n ) : (\n <StackItem.SigilButton>\n <span className='sr-only'>{label}</span>\n <Icon icon={icon} size={5} />\n </StackItem.SigilButton>\n )}\n </ActionRoot>\n <TextTooltip text={label} onlyWhenTruncating>\n <StackItem.HeadingLabel\n attendableId={attendableId}\n related={part === 'complementary'}\n {...(pending && { classNames: 'text-description' })}\n >\n {label}\n </StackItem.HeadingLabel>\n </TextTooltip>\n </>\n )}\n {node && part !== 'complementary' && <Surface role='navbar-end' data={{ subject: node.data }} />}\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 2025 DXOS.org\n//\n\nimport { mx } from '@dxos/react-ui-theme';\n\nexport const soloInlinePadding =\n 'pis-[calc(env(safe-area-inset-left)+.25rem)] pie-[calc(env(safe-area-inset-left)+.25rem)]';\n\nconst sidebarToggleStyles = 'bs-[--rail-item] is-[--rail-item] absolute block-end-2 z-[1] !bg-deckSurface lg:hidden';\n\nexport const fixedSidebarToggleStyles = mx(sidebarToggleStyles, 'inline-start-2');\n\nexport const fixedComplementarySidebarToggleStyles = mx(sidebarToggleStyles, 'inline-end-2');\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { forwardRef, useCallback } from 'react';\n\nimport { createIntent, useIntentDispatcher } from '@dxos/app-framework';\nimport { invariant } from '@dxos/invariant';\nimport { ButtonGroup, type ButtonGroupProps, type ButtonProps, IconButton, useTranslation } from '@dxos/react-ui';\n\nimport { meta } from '../../meta';\nimport { 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\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\nconst PlankControl = ({ icon, label, ...props }: Omit<ButtonProps, 'children'> & { label: string; icon: string }) => {\n return <IconButton iconOnly label={label} icon={icon} size={5} variant='ghost' tooltipSide='bottom' {...props} />;\n};\n\nconst plankControlSpacing = 'pli-2';\n\ntype PlankComplimentControlsProps = {\n primary?: string;\n};\n\nexport const PlankCompanionControls = forwardRef<HTMLDivElement, PlankComplimentControlsProps>(\n ({ primary }, forwardedRef) => {\n const { t } = useTranslation(meta.id);\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const handleCloseCompanion = useCallback(() => {\n invariant(primary);\n return dispatch(createIntent(DeckAction.ChangeCompanion, { primary, companion: null }));\n }, []);\n return (\n <div ref={forwardedRef} className='contents 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\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={['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 && (\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 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 role='none' className='grid place-items-center attention-surface' />;\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useCallback } from 'react';\n\nimport { LayoutAction, createIntent, useCapability, useIntentDispatcher } from '@dxos/app-framework';\nimport { IconButton, type IconButtonProps, type ThemedClassName, useTranslation } from '@dxos/react-ui';\n\nimport { DeckCapabilities } from '../../capabilities';\nimport { getCompanionId, useDeckCompanions } from '../../hooks';\nimport { meta } from '../../meta';\n\nexport const ToggleSidebarButton = ({\n classNames,\n variant = 'ghost',\n}: ThemedClassName<Pick<IconButtonProps, 'variant'>>) => {\n const layoutContext = useCapability(DeckCapabilities.MutableDeckState);\n const { t } = useTranslation(meta.id);\n return (\n <IconButton\n variant={variant}\n iconOnly\n icon='ph--sidebar--regular'\n size={4}\n label={t('open navigation sidebar label')}\n onClick={() =>\n (layoutContext.sidebarState = layoutContext.sidebarState === 'expanded' ? 'collapsed' : 'expanded')\n }\n classNames={classNames}\n />\n );\n};\n\nexport const CloseSidebarButton = () => {\n const layoutContext = useCapability(DeckCapabilities.MutableDeckState);\n const { t } = useTranslation(meta.id);\n return (\n <IconButton\n variant='ghost'\n iconOnly\n icon='ph--caret-line-left--regular'\n size={4}\n label={t('close navigation sidebar label')}\n onClick={() => (layoutContext.sidebarState = 'collapsed')}\n classNames='rounded-none pli-1 dx-focus-ring-inset pie-[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 { dispatchPromise: dispatch } = useIntentDispatcher();\n const layoutContext = useCapability(DeckCapabilities.MutableDeckState);\n const { t } = useTranslation(meta.id);\n\n const companions = useDeckCompanions();\n const handleClick = useCallback(async () => {\n layoutContext.complementarySidebarState =\n layoutContext.complementarySidebarState === 'expanded' ? 'collapsed' : 'expanded';\n const firstCompanion = companions[0];\n if (layoutContext.complementarySidebarState === 'expanded' && !current && firstCompanion) {\n await dispatch(\n createIntent(LayoutAction.UpdateComplementary, {\n part: 'complementary',\n subject: getCompanionId(firstCompanion.id),\n }),\n );\n }\n }, [layoutContext, current, companions, dispatch]);\n\n return (\n <IconButton\n iconOnly\n onClick={handleClick}\n variant='ghost'\n label={t('open complementary sidebar label')}\n classNames={['[&>svg]:-scale-x-100', classNames]}\n icon='ph--sidebar-simple--regular'\n size={inR0 ? 5 : 4}\n tooltipSide={inR0 ? 'left' : undefined}\n />\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { useMemo } from 'react';\n\nimport { Surface, useCapability } from '@dxos/app-framework';\nimport { type Label, Main } from '@dxos/react-ui';\n\nimport { DeckCapabilities } from '../../capabilities';\nimport { useBreakpoints, useHoistStatusbar } from '../../hooks';\nimport { meta } from '../../meta';\nimport { getMode } from '../../types';\nimport { layoutAppliesTopbar } from '../../util';\n\nconst label = ['sidebar title', { ns: meta.id }] satisfies Label;\n\nexport const Sidebar = () => {\n const { popoverAnchorId, activeDeck: current, deck } = useCapability(DeckCapabilities.DeckState);\n const breakpoint = useBreakpoints();\n const layoutMode = getMode(deck);\n const topbar = layoutAppliesTopbar(breakpoint, layoutMode);\n const hoistStatusbar = useHoistStatusbar(breakpoint, layoutMode);\n\n const navigationData = useMemo(\n () => ({ popoverAnchorId, topbar, hoistStatusbar, current }),\n [popoverAnchorId, topbar, hoistStatusbar, current],\n );\n\n return (\n <Main.NavigationSidebar\n label={label}\n classNames={[\n 'grid',\n topbar && 'block-start-[calc(env(safe-area-inset-top)+var(--rail-size))]',\n hoistStatusbar && 'block-end-[--statusbar-size]',\n ]}\n >\n <Surface role='navigation' data={navigationData} limit={1} />\n </Main.NavigationSidebar>\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React from 'react';\n\nimport { useCapability } from '@dxos/app-framework';\n\nimport { DeckCapabilities } from '../../capabilities';\n\nimport { ActiveNode } from './ActiveNode';\nimport { DeckMain } from './DeckMain';\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 context = useCapability(DeckCapabilities.MutableDeckState);\n const { toasts } = context;\n\n return (\n <PopoverRoot>\n <ActiveNode />\n <DeckMain />\n <PopoverContent />\n <Dialog />\n <Toaster toasts={toasts} onDismissToast={onDismissToast} />\n </PopoverRoot>\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Surface, useAppGraph } from '@dxos/app-framework';\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 role='none' 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 role='document-title' data={{ subject: activeNode }} limit={1} />\n </div>\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { untracked } from '@preact/signals-core';\nimport React, { Fragment, type UIEvent, useCallback, useEffect, useMemo, useRef } from 'react';\n\nimport {\n Capabilities,\n LayoutAction,\n createIntent,\n useCapability,\n useIntentDispatcher,\n usePluginManager,\n} from '@dxos/app-framework';\nimport { AttentionCapabilities } from '@dxos/plugin-attention';\nimport { Main, type MainProps, useMediaQuery, useOnTransition } from '@dxos/react-ui';\nimport { DEFAULT_HORIZONTAL_SIZE, Stack, StackContext } from '@dxos/react-ui-stack';\nimport { mainPaddingTransitions, mx } from '@dxos/react-ui-theme';\n\nimport { DeckCapabilities } from '../../capabilities';\nimport { useBreakpoints, useHoistStatusbar } from '../../hooks';\nimport { meta } from '../../meta';\nimport { type DeckSettingsProps, getMode } from '../../types';\nimport { calculateOverscroll, layoutAppliesTopbar } from '../../util';\nimport { fixedComplementarySidebarToggleStyles, fixedSidebarToggleStyles } from '../fragments';\nimport { Plank } from '../Plank';\nimport { ComplementarySidebar, Sidebar, ToggleComplementarySidebarButton, ToggleSidebarButton } from '../Sidebar';\n\nimport { ContentEmpty } from './ContentEmpty';\nimport { StatusBar } from './StatusBar';\nimport { Topbar } from './Topbar';\n\nexport const DeckMain = () => {\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const settings = useCapability(Capabilities.SettingsStore).getStore<DeckSettingsProps>(meta.id)?.value;\n const context = useCapability(DeckCapabilities.MutableDeckState);\n const { sidebarState, complementarySidebarState, complementarySidebarPanel, deck } = context;\n const { active, activeCompanions, fullscreen, solo, plankSizing } = deck;\n const layoutMode = getMode(deck);\n const breakpoint = useBreakpoints();\n const topbar = layoutAppliesTopbar(breakpoint, layoutMode);\n const hoistStatusbar = useHoistStatusbar(breakpoint, layoutMode);\n const pluginManager = usePluginManager();\n\n const scrollLeftRef = useRef<number>(null);\n const deckRef = useRef<HTMLDivElement>(null);\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 attended = untracked(() => {\n const attention = pluginManager.context.getCapability(AttentionCapabilities.Attention);\n return attention.current;\n });\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 && getMode(deck) === 'deck') {\n // NOTE: Not `useAttended` so that the layout component is not re-rendered when the attended list changes.\n const attended = untracked(() => {\n const attention = pluginManager.context.getCapability(AttentionCapabilities.Attention);\n return attention.current;\n });\n\n shouldRevert.current = true;\n void dispatch(\n createIntent(LayoutAction.SetLayoutMode, { part: 'mode', subject: attended[0], options: { mode: 'solo' } }),\n );\n } else if (isNotMobile && getMode(deck) === 'solo' && shouldRevert.current) {\n void dispatch(createIntent(LayoutAction.SetLayoutMode, { part: 'mode', options: { revert: true } }));\n }\n }, [isNotMobile, deck, dispatch]);\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 intent only when the setting changes.\n useEffect(() => {\n if (settings?.enableDeck && layoutMode === 'deck') {\n void dispatch(\n createIntent(LayoutAction.SetLayoutMode, { part: 'mode', subject: active[0], options: { mode: 'solo' } }),\n );\n }\n }, [settings?.enableDeck, dispatch, active, layoutMode]);\n\n /**\n * Clear scroll restoration state if the window is resized.\n */\n const handleResize = useCallback(() => {\n scrollLeftRef.current = null;\n }, []);\n\n useEffect(() => {\n window.addEventListener('resize', handleResize);\n return () => window.removeEventListener('resize', handleResize);\n }, [handleResize]);\n\n const restoreScroll = useCallback(() => {\n if (deckRef.current && scrollLeftRef.current != null) {\n deckRef.current.scrollLeft = scrollLeftRef.current;\n }\n }, []);\n useOnTransition(layoutMode, (mode) => mode !== 'deck', 'deck', restoreScroll);\n\n /**\n * Save scroll position as the user scrolls.\n */\n const handleScroll = useCallback(\n (event: UIEvent) => {\n if (!solo && event.currentTarget === event.target) {\n scrollLeftRef.current = (event.target as HTMLDivElement).scrollLeft;\n }\n },\n [solo],\n );\n\n const isEmpty = !solo && active.length === 0;\n\n const padding = useMemo(() => {\n if (!solo && settings?.overscroll === 'centering') {\n return calculateOverscroll(active.length);\n }\n return {};\n }, [solo, settings?.overscroll, deck]);\n\n const mainPosition = useMemo(\n () => [\n 'grid !block-start-[env(safe-area-inset-top)]',\n topbar && '!block-start-[calc(env(safe-area-inset-top)+var(--rail-size))]',\n hoistStatusbar && 'lg:block-end-[--statusbar-size]',\n ],\n [topbar, hoistStatusbar],\n );\n\n const { order, itemsCount }: { order: Record<string, number>; itemsCount: number } = useMemo(() => {\n return active.reduce(\n (acc: { order: Record<string, number>; itemsCount: number }, entryId) => {\n acc.order[entryId] = acc.itemsCount + 1;\n acc.itemsCount += activeCompanions?.[entryId] ? 3 : 2;\n return acc;\n },\n { order: {}, itemsCount: 0 },\n );\n }, [active, activeCompanions]);\n\n return (\n <Main.Root\n navigationSidebarState={fullscreen ? 'closed' : context.sidebarState}\n onNavigationSidebarStateChange={(next) => (context.sidebarState = next)}\n complementarySidebarState={fullscreen ? 'closed' : context.complementarySidebarState}\n onComplementarySidebarStateChange={(next) => (context.complementarySidebarState = next)}\n >\n {/* Left sidebar. */}\n <Sidebar />\n\n {/* Right sidebar. */}\n <ComplementarySidebar current={complementarySidebarPanel} />\n\n {/* Dialog overlay to dismiss dialogs. */}\n <Main.Overlay />\n\n {/* No content. */}\n {isEmpty && (\n <Main.Content bounce handlesFocus classNames={mainPosition}>\n <ContentEmpty />\n </Main.Content>\n )}\n\n {/* Solo/deck mode. */}\n {!isEmpty && (\n <Main.Content\n bounce\n handlesFocus\n classNames={mainPosition}\n style={\n {\n '--main-spacing': settings?.encapsulatedPlanks ? '0.75rem' : '0',\n '--dx-main-sidebarWidth':\n sidebarState === 'expanded'\n ? 'var(--nav-sidebar-size)'\n : sidebarState === 'collapsed'\n ? 'var(--l0-size)'\n : '0',\n '--dx-main-complementaryWidth':\n complementarySidebarState === 'expanded'\n ? 'var(--complementary-sidebar-size)'\n : complementarySidebarState === 'collapsed'\n ? 'var(--rail-size)'\n : '0',\n '--dx-main-contentFirstWidth': `${plankSizing[active[0] ?? 'never'] ?? DEFAULT_HORIZONTAL_SIZE}rem`,\n '--dx-main-contentLastWidth': `${plankSizing[active[(active.length ?? 1) - 1] ?? 'never'] ?? DEFAULT_HORIZONTAL_SIZE}rem`,\n } as MainProps['style']\n }\n >\n <div\n role='none'\n className={!solo ? 'relative bg-deckSurface overflow-hidden' : 'sr-only'}\n {...(solo && { inert: true })}\n >\n {!topbar && !fullscreen && <ToggleSidebarButton classNames={fixedSidebarToggleStyles} />}\n {!topbar && !fullscreen && (\n <ToggleComplementarySidebarButton classNames={fixedComplementarySidebarToggleStyles} />\n )}\n <Stack\n ref={deckRef}\n orientation='horizontal'\n size='contain'\n itemsCount={itemsCount - 1}\n classNames={[\n 'absolute inset-block-[--main-spacing] -inset-inline-px bs-[calc(100%-2*var(--main-spacing))]',\n mainPaddingTransitions,\n ]}\n style={padding}\n onScroll={handleScroll}\n >\n {active.map((entryId) => (\n <Fragment key={entryId}>\n <PlankSeparator order={order[entryId] - 1} encapsulate={!!settings?.enableDeck} />\n <Plank\n id={entryId}\n companionId={activeCompanions?.[entryId]}\n part='deck'\n order={order[entryId]}\n active={active}\n layoutMode={layoutMode}\n settings={settings}\n />\n </Fragment>\n ))}\n </Stack>\n </div>\n <div\n role='none'\n className={solo ? 'relative overflow-hidden bg-deckSurface' : 'sr-only'}\n {...(!solo && { inert: true })}\n >\n {!topbar && !fullscreen && <ToggleSidebarButton classNames={fixedSidebarToggleStyles} />}\n {!topbar && !fullscreen && (\n <ToggleComplementarySidebarButton classNames={fixedComplementarySidebarToggleStyles} />\n )}\n <StackContext.Provider\n value={{\n orientation: 'horizontal',\n size: 'contain',\n rail: true,\n }}\n >\n <Plank\n id={solo}\n companionId={solo ? activeCompanions?.[solo] : undefined}\n part='solo'\n layoutMode={layoutMode}\n settings={settings}\n />\n </StackContext.Provider>\n </div>\n </Main.Content>\n )}\n\n {/* Topbar. */}\n {topbar && <Topbar />}\n\n {/* Status bar. */}\n {hoistStatusbar && <StatusBar showHints={settings?.showHints} />}\n </Main.Root>\n );\n};\n\nconst PlankSeparator = ({ order, encapsulate }: { order: number; encapsulate?: boolean }) =>\n order > 0 ? (\n <span\n role='separator'\n className={mx('row-span-2 bg-deckSurface', encapsulate ? 'is-0' : 'is-4')}\n style={{ gridColumn: order }}\n />\n ) : null;\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Surface, useCapability } from '@dxos/app-framework';\n\nimport { DeckCapabilities } from '../../capabilities';\nimport { useBreakpoints } from '../../hooks';\nimport { getMode } from '../../types';\nimport { layoutAppliesTopbar } from '../../util';\nimport { fixedSidebarToggleStyles } from '../fragments';\nimport { ToggleSidebarButton } from '../Sidebar';\n\nexport const ContentEmpty = () => {\n const breakpoint = useBreakpoints();\n const { deck } = useCapability(DeckCapabilities.MutableDeckState);\n const layoutMode = getMode(deck);\n const topbar = layoutAppliesTopbar(breakpoint, layoutMode);\n return (\n <div\n role='none'\n className='grid place-items-center p-8 relative bg-deckSurface'\n data-testid='layoutPlugin.firstRunMessage'\n >\n <Surface role='keyshortcuts' />\n {!topbar && <ToggleSidebarButton variant='default' classNames={fixedSidebarToggleStyles} />}\n </div>\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Surface } from '@dxos/app-framework';\nimport { useLandmarkMover } from '@dxos/react-ui';\n\nexport const StatusBar = ({ showHints }: { showHints?: boolean }) => {\n const mover = useLandmarkMover(undefined, '3');\n return (\n <div\n role='contentinfo'\n className='fixed block-end-0 inset-inline-0 bs-[--statusbar-size] border-bs border-separator z-[2] flex text-description'\n {...mover}\n >\n {showHints && <Surface role='hints' limit={1} />}\n <Surface role='status-bar' limit={1} />\n </div>\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Banner } from './Banner';\n\nexport const Topbar = () => {\n return <Banner variant='topbar' />;\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Surface, useCapability } from '@dxos/app-framework';\nimport { AlertDialog, Dialog as NaturalDialog } from '@dxos/react-ui';\n\nimport { DeckCapabilities } from '../../capabilities';\nimport { PlankContentError } from '../Plank';\n\nexport const Dialog = () => {\n const context = useCapability(DeckCapabilities.MutableDeckState);\n const { dialogOpen, dialogType, dialogBlockAlign, dialogOverlayClasses, dialogOverlayStyle, dialogContent } = context;\n const Root = dialogType === 'alert' ? AlertDialog.Root : NaturalDialog.Root;\n const Overlay = dialogType === 'alert' ? AlertDialog.Overlay : NaturalDialog.Overlay;\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\n modal={dialogBlockAlign !== 'end'}\n open={dialogOpen}\n onOpenChange={(nextOpen) => (context.dialogOpen = nextOpen)}\n >\n {dialogBlockAlign === 'end' ? (\n // TODO(burdon): Placeholder creates a suspense boundary; replace with defaults.\n <Surface role='dialog' data={dialogContent} limit={1} fallback={PlankContentError} placeholder={<div />} />\n ) : (\n <Overlay blockAlign={dialogBlockAlign} classNames={dialogOverlayClasses} style={dialogOverlayStyle}>\n <Surface role='dialog' data={dialogContent} limit={1} fallback={PlankContentError} />\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, useMemo, useRef, useState } from 'react';\n\nimport { Surface, useCapability } from '@dxos/app-framework';\nimport { Popover, type PopoverContentInteractOutsideEvent } from '@dxos/react-ui';\n\nimport { DeckCapabilities } from '../../capabilities';\n\nexport type DeckPopoverRootProps = PropsWithChildren<{}>;\n\nconst DEBOUNCE_DELAY = 40;\n\ntype DeckPopoverContextValue = {\n setOpen: (open: boolean) => void;\n};\n\nconst [DeckPopoverProvider, useDeckPopoverContext] = createContext<DeckPopoverContextValue>('DeckPopover');\n\nexport const PopoverRoot = ({ children }: DeckPopoverRootProps) => {\n const layout = useCapability(DeckCapabilities.MutableDeckState);\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 (layout.popoverOpen) {\n if (debounceRef.current) {\n clearTimeout(debounceRef.current);\n }\n if (layout.popoverAnchor && virtualRef.current !== layout.popoverAnchor) {\n virtualRef.current = layout.popoverAnchor ?? null;\n setVirtualIter((iter) => iter + 1);\n }\n debounceRef.current = setTimeout(() => setOpen(true), DEBOUNCE_DELAY);\n }\n }, [layout.popoverOpen, layout.popoverAnchorId, layout.popoverAnchor, layout.popoverContent]);\n\n return (\n <DeckPopoverProvider setOpen={setOpen}>\n <Popover.Root modal={false} open={open}>\n {layout.popoverAnchor && <Popover.VirtualTrigger key={virtualIter} virtualRef={virtualRef} />}\n {children}\n </Popover.Root>\n </DeckPopoverProvider>\n );\n};\n\nexport const PopoverContent = () => {\n const layout = useCapability(DeckCapabilities.MutableDeckState);\n const { setOpen } = useDeckPopoverContext('PopoverContent');\n\n const handleClose = 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 setOpen(false);\n layout.popoverOpen = false;\n layout.popoverAnchor = undefined;\n layout.popoverAnchorId = undefined;\n layout.popoverSide = undefined;\n }\n },\n [setOpen],\n );\n\n const collisionBoundaries: HTMLElement[] = useMemo(() => {\n const closest = layout.popoverAnchor?.closest('[data-popover-collision-boundary]') as\n | HTMLElement\n | null\n | undefined;\n return closest ? [closest] : [];\n }, [layout.popoverAnchor]);\n\n return (\n <Popover.Portal>\n <Popover.Content\n side={layout.popoverSide}\n onInteractOutside={handleClose}\n onEscapeKeyDown={handleClose}\n collisionBoundary={collisionBoundaries}\n sticky='always'\n hideWhenDetached\n >\n <Popover.Viewport>\n <Surface role='card--popover' data={layout.popoverContent} limit={1} />\n </Popover.Viewport>\n <Popover.Arrow />\n </Popover.Content>\n </Popover.Portal>\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React from 'react';\n\nimport { type LayoutAction } from '@dxos/app-framework';\nimport {\n Button,\n Icon,\n Toast as NaturalToast,\n type ToastRootProps,\n toLocalizedString,\n useTranslation,\n} 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 closeLabel,\n onAction,\n onOpenChange,\n}: LayoutAction.Toast & Pick<ToastRootProps, 'onOpenChange'>) => {\n const { t } = useTranslation(meta.id);\n\n return (\n <NaturalToast.Root data-testid={id} defaultOpen duration={duration} onOpenChange={onOpenChange}>\n <NaturalToast.Body>\n <NaturalToast.Title classNames='items-center'>\n {icon && <Icon icon={icon} size={5} classNames='inline mr-1' />}\n {title && <span>{toLocalizedString(title, t)}</span>}\n </NaturalToast.Title>\n {description && (\n <NaturalToast.Description>{description && toLocalizedString(description, t)}</NaturalToast.Description>\n )}\n </NaturalToast.Body>\n <NaturalToast.Actions>\n {onAction && actionAlt && actionLabel && (\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 )}\n {closeLabel && (\n <NaturalToast.Close asChild>\n <Button data-testid='toast.close'>{toLocalizedString(closeLabel, t)}</Button>\n </NaturalToast.Close>\n )}\n </NaturalToast.Actions>\n </NaturalToast.Root>\n );\n};\n\nexport type ToasterProps = {\n toasts?: LayoutAction.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) => {\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\nimport React from 'react';\n\nimport { Input, Select, useTranslation } from '@dxos/react-ui';\nimport { ControlGroup, ControlItemInput, ControlPage, ControlSection } from '@dxos/react-ui-form';\n\nimport { meta } from '../../meta';\nimport {\n type DeckSettingsProps,\n type NewPlankPositioning,\n NewPlankPositions,\n type Overscroll,\n OverscrollOptions,\n} from '../../types';\n\nconst isSocket = !!(globalThis as any).__args;\n\nexport const DeckSettings = ({ settings }: { settings: DeckSettingsProps }) => {\n const { t } = useTranslation(meta.id);\n\n return (\n <ControlPage>\n <ControlSection title={t('settings title', { ns: meta.id })}>\n <ControlGroup>\n <ControlItemInput title={t('settings enable deck label')}>\n <Input.Switch\n checked={settings.enableDeck}\n onCheckedChange={(checked) => (settings.enableDeck = checked)}\n />\n </ControlItemInput>\n <ControlItemInput title={t('settings encapsulated planks label')}>\n <Input.Switch\n checked={settings.encapsulatedPlanks ?? false}\n onCheckedChange={(checked) => (settings.encapsulatedPlanks = checked)}\n />\n </ControlItemInput>\n <ControlItemInput title={t('select new plank positioning label')}>\n <Select.Root\n disabled={!settings.enableDeck}\n value={settings.newPlankPositioning ?? 'start'}\n onValueChange={(value) => (settings.newPlankPositioning = value as NewPlankPositioning)}\n >\n <Select.TriggerButton placeholder={t('select new plank positioning placeholder')} />\n <Select.Portal>\n <Select.Content>\n <Select.Viewport>\n {NewPlankPositions.map((position) => (\n <Select.Option key={position} value={position}>\n {t(`settings new plank position ${position} label`)}\n </Select.Option>\n ))}\n </Select.Viewport>\n <Select.Arrow />\n </Select.Content>\n </Select.Portal>\n </Select.Root>\n </ControlItemInput>\n <ControlItemInput title={t('settings overscroll label')}>\n <Select.Root\n disabled={!settings.enableDeck}\n value={settings.overscroll ?? 'none'}\n onValueChange={(value) => (settings.overscroll = value as Overscroll)}\n >\n <Select.TriggerButton placeholder={t('select overscroll placeholder')} />\n <Select.Portal>\n <Select.Content>\n <Select.Viewport>\n {OverscrollOptions.map((option) => (\n <Select.Option key={option} value={option}>\n {t(`settings overscroll ${option} label`)}\n </Select.Option>\n ))}\n </Select.Viewport>\n <Select.Arrow />\n </Select.Content>\n </Select.Portal>\n </Select.Root>\n </ControlItemInput>\n <ControlItemInput title={t('settings enable statusbar label')}>\n <Input.Switch\n checked={settings.enableStatusbar}\n onCheckedChange={(checked) => (settings.enableStatusbar = checked)}\n />\n </ControlItemInput>\n <ControlItemInput title={t('settings show hints label')}>\n <Input.Switch checked={settings.showHints} onCheckedChange={(checked) => (settings.showHints = checked)} />\n </ControlItemInput>\n {!isSocket && (\n <ControlItemInput title={t('settings native redirect label')}>\n <Input.Switch\n checked={settings.enableNativeRedirect}\n onCheckedChange={(checked) => (settings.enableNativeRedirect = checked)}\n />\n </ControlItemInput>\n )}\n </ControlGroup>\n </ControlSection>\n </ControlPage>\n );\n};\n"],
5
+ "mappings": "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",
6
+ "names": ["React", "Surface", "useTranslation", "mx", "React", "Fragment", "useCallback", "useEffect", "useMemo", "useState", "LayoutAction", "Surface", "createIntent", "useCapability", "useIntentDispatcher", "IconButton", "Main", "toLocalizedString", "useTranslation", "Tabs", "React", "memo", "useCallback", "useLayoutEffect", "useMemo", "useRef", "LayoutAction", "Surface", "createIntent", "useAppGraph", "useCapability", "useIntentDispatcher", "debounce", "useNode", "ATTENDABLE_PATH_SEPARATOR", "useAttentionAttributes", "StackItem", "railGridHorizontal", "mainIntrinsicSize", "mx", "React", "useEffect", "useState", "useTranslation", "descriptionMessage", "mx", "React", "Fragment", "memo", "useCallback", "useEffect", "useMemo", "LayoutAction", "Surface", "createIntent", "useAppGraph", "useIntentDispatcher", "Icon", "IconButton", "Popover", "toLocalizedString", "useTranslation", "StackItem", "TextTooltip", "hoverableControls", "hoverableFocusedWithinControls", "mx", "soloInlinePadding", "sidebarToggleStyles", "fixedSidebarToggleStyles", "mx", "fixedComplementarySidebarToggleStyles", "React", "forwardRef", "useCallback", "createIntent", "useIntentDispatcher", "invariant", "ButtonGroup", "IconButton", "useTranslation", "PlankControl", "icon", "label", "props", "IconButton", "iconOnly", "size", "variant", "tooltipSide", "plankControlSpacing", "PlankCompanionControls", "forwardRef", "primary", "forwardedRef", "t", "useTranslation", "meta", "id", "dispatchPromise", "dispatch", "useIntentDispatcher", "handleCloseCompanion", "useCallback", "invariant", "createIntent", "DeckAction", "ChangeCompanion", "companion", "div", "ref", "className", "onClick", "classNames", "PlankControls", "children", "capabilities", "layoutMode", "pin", "close", "buttonClassNames", "layoutIsAnySolo", "startsWith", "ButtonGroup", "deck", "solo", "disabled", "incrementStart", "incrementEnd", "fullscreen", "data-testid", "MAX_COMPANIONS", "PlankHeading", "memo", "id", "part", "node", "deckEnabled", "canIncrementStart", "canIncrementEnd", "popoverAnchorId", "primaryId", "pending", "companioned", "companions", "layoutMode", "actions", "t", "useTranslation", "meta", "dispatchPromise", "dispatch", "useIntentDispatcher", "graph", "useAppGraph", "breakpoint", "useBreakpoints", "icon", "properties", "label", "toLocalizedString", "ns", "isCompanionNode", "type", "PLANK_COMPANION_TYPE", "useEffect", "frame", "requestAnimationFrame", "expand", "cancelAnimationFrame", "attendableId", "capabilities", "useMemo", "deck", "solo", "incrementStart", "incrementEnd", "fullscreen", "companion", "length", "variant", "parseEntryId", "sigilActions", "undefined", "getActions", "filter", "a", "includes", "disposition", "handleAction", "useCallback", "action", "data", "parent", "caller", "handlePlankAction", "eventType", "startsWith", "createIntent", "DeckAction", "Adjust", "LayoutAction", "UpdateComplementary", "options", "state", "Close", "subject", "ActionRoot", "Popover", "Anchor", "Fragment", "handleTabClick", "event", "target", "closest", "tabId", "dataset", "ChangeCompanion", "primary", "React", "StackItem", "Heading", "classNames", "soloInlinePadding", "hoverableControls", "hoverableFocusedWithinControls", "data-plank-heading", "div", "role", "className", "map", "IconButton", "key", "data-id", "iconOnly", "size", "onClick", "Sigil", "related", "triggerLabel", "onAction", "Surface", "SigilButton", "span", "Icon", "TextTooltip", "text", "onlyWhenTruncating", "HeadingLabel", "PlankCompanionControls", "PlankControls", "close", "React", "PlankLoading", "React", "div", "role", "className", "PlankContentError", "error", "t", "useTranslation", "meta", "id", "errorString", "toString", "React", "div", "role", "className", "p", "mx", "descriptionMessage", "PlankError", "part", "node", "timedOut", "setTimedOut", "useState", "useEffect", "setTimeout", "PlankHeading", "pending", "PlankLoading", "UNKNOWN_ID", "Plank", "memo", "id", "companionId", "props", "graph", "useAppGraph", "node", "useNode", "companions", "useCompanions", "currentCompanion", "find", "hasCompanion", "React", "PlankContainer", "solo", "part", "companion", "encapsulate", "settings", "encapsulatedPlanks", "PlankComponent", "companioned", "undefined", "primary", "order", "children", "sizeAttrs", "useMainSize", "div", "role", "className", "mx", "railGridHorizontal", "mainIntrinsicSize", "layoutMode", "path", "active", "dispatchPromise", "dispatch", "useIntentDispatcher", "deck", "popoverAnchorId", "scrollIntoView", "useCapability", "DeckCapabilities", "DeckState", "canResize", "attentionAttrs", "useAttentionAttributes", "index", "findIndex", "entryId", "length", "canIncrementStart", "canIncrementEnd", "rootElement", "useRef", "variant", "parseEntryId", "sizeKey", "split", "ATTENDABLE_PATH_SEPARATOR", "size", "plankSizing", "handleSizeChange", "useCallback", "debounce", "nextSize", "createIntent", "DeckAction", "UpdatePlankSize", "handleKeyDown", "event", "target", "currentTarget", "key", "current", "closest", "focus", "useLayoutEffect", "behavior", "inline", "LayoutAction", "ScrollIntoView", "subject", "isSolo", "startsWith", "isAttendable", "data", "useMemo", "attendableId", "companionTo", "properties", "placeholder", "PlankLoading", "Root", "StackItem", "ref", "data-testid", "tabIndex", "item", "onSizeChange", "classNames", "onKeyDown", "PlankHeading", "deckEnabled", "enableDeck", "primaryId", "Surface", "limit", "fallback", "PlankContentError", "PlankError", "ResizeHandle", "React", "useCallback", "LayoutAction", "createIntent", "useCapability", "useIntentDispatcher", "IconButton", "useTranslation", "ToggleSidebarButton", "classNames", "variant", "layoutContext", "useCapability", "DeckCapabilities", "MutableDeckState", "t", "useTranslation", "meta", "id", "React", "IconButton", "iconOnly", "icon", "size", "label", "onClick", "sidebarState", "CloseSidebarButton", "ToggleComplementarySidebarButton", "inR0", "current", "dispatchPromise", "dispatch", "useIntentDispatcher", "companions", "useDeckCompanions", "handleClick", "useCallback", "complementarySidebarState", "firstCompanion", "createIntent", "LayoutAction", "UpdateComplementary", "part", "subject", "getCompanionId", "tooltipSide", "undefined", "label", "ns", "meta", "id", "ComplementarySidebar", "current", "t", "useTranslation", "dispatchPromise", "dispatch", "useIntentDispatcher", "layout", "useCapability", "DeckCapabilities", "MutableDeckState", "layoutMode", "getMode", "deck", "breakpoint", "useBreakpoints", "topbar", "layoutAppliesTopbar", "hoistStatusbar", "useHoistStatusbar", "companions", "useDeckCompanions", "activeCompanion", "find", "companion", "getCompanionId", "activeId", "internalValue", "setInternalValue", "useState", "useEffect", "handleTabClick", "useCallback", "event", "nextValue", "currentTarget", "getAttribute", "complementarySidebarState", "createIntent", "LayoutAction", "UpdateComplementary", "part", "subject", "data", "useMemo", "options", "state", "React", "Main", "classNames", "Tabs", "Root", "orientation", "verticalVariant", "value", "div", "role", "className", "Tablist", "map", "Tab", "key", "asChild", "IconButton", "toLocalizedString", "properties", "icon", "size", "iconOnly", "tooltipSide", "data-value", "variant", "onClick", "Surface", "limit", "ToggleComplementarySidebarButton", "Tabpanel", "inert", "ComplementarySidebarPanel", "ScrollArea", "children", "Wrapper", "fixed", "Fragment", "h2", "fallback", "PlankContentError", "placeholder", "PlankLoading", "React", "useMemo", "Surface", "useCapability", "Main", "label", "ns", "meta", "id", "Sidebar", "popoverAnchorId", "activeDeck", "current", "deck", "useCapability", "DeckCapabilities", "DeckState", "breakpoint", "useBreakpoints", "layoutMode", "getMode", "topbar", "layoutAppliesTopbar", "hoistStatusbar", "useHoistStatusbar", "navigationData", "useMemo", "React", "Main", "NavigationSidebar", "classNames", "Surface", "role", "data", "limit", "Banner", "variant", "classNames", "t", "useTranslation", "meta", "id", "React", "header", "className", "mx", "CloseSidebarButton", "ToggleSidebarButton", "span", "ns", "div", "role", "Surface", "limit", "React", "useCapability", "React", "Surface", "useAppGraph", "useNode", "useAttended", "ActiveNode", "id", "useAttended", "graph", "useAppGraph", "activeNode", "useNode", "useNodeActionExpander", "React", "div", "role", "className", "Surface", "data", "subject", "limit", "untracked", "React", "Fragment", "useCallback", "useEffect", "useMemo", "useRef", "Capabilities", "LayoutAction", "createIntent", "useCapability", "useIntentDispatcher", "usePluginManager", "AttentionCapabilities", "Main", "useMediaQuery", "useOnTransition", "DEFAULT_HORIZONTAL_SIZE", "Stack", "StackContext", "mainPaddingTransitions", "mx", "React", "Surface", "useCapability", "ContentEmpty", "breakpoint", "useBreakpoints", "deck", "useCapability", "DeckCapabilities", "MutableDeckState", "layoutMode", "getMode", "topbar", "layoutAppliesTopbar", "React", "div", "role", "className", "data-testid", "Surface", "ToggleSidebarButton", "variant", "classNames", "fixedSidebarToggleStyles", "React", "Surface", "useLandmarkMover", "StatusBar", "showHints", "mover", "useLandmarkMover", "undefined", "React", "div", "role", "className", "Surface", "limit", "React", "Topbar", "React", "Banner", "variant", "DeckMain", "dispatchPromise", "dispatch", "useIntentDispatcher", "settings", "useCapability", "Capabilities", "SettingsStore", "getStore", "meta", "id", "value", "context", "DeckCapabilities", "MutableDeckState", "sidebarState", "complementarySidebarState", "complementarySidebarPanel", "deck", "active", "activeCompanions", "fullscreen", "solo", "plankSizing", "layoutMode", "getMode", "breakpoint", "useBreakpoints", "topbar", "layoutAppliesTopbar", "hoistStatusbar", "useHoistStatusbar", "pluginManager", "usePluginManager", "scrollLeftRef", "useRef", "deckRef", "useEffect", "attended", "untracked", "attention", "getCapability", "AttentionCapabilities", "Attention", "current", "firstId", "length", "document", "querySelector", "focus", "isNotMobile", "useMediaQuery", "shouldRevert", "createIntent", "LayoutAction", "SetLayoutMode", "part", "subject", "options", "mode", "revert", "enableDeck", "handleResize", "useCallback", "window", "addEventListener", "removeEventListener", "restoreScroll", "scrollLeft", "useOnTransition", "handleScroll", "event", "currentTarget", "target", "isEmpty", "padding", "useMemo", "overscroll", "calculateOverscroll", "mainPosition", "order", "itemsCount", "reduce", "acc", "entryId", "React", "Main", "Root", "navigationSidebarState", "onNavigationSidebarStateChange", "next", "onComplementarySidebarStateChange", "Sidebar", "ComplementarySidebar", "Overlay", "Content", "bounce", "handlesFocus", "classNames", "ContentEmpty", "style", "encapsulatedPlanks", "DEFAULT_HORIZONTAL_SIZE", "div", "role", "className", "inert", "ToggleSidebarButton", "fixedSidebarToggleStyles", "ToggleComplementarySidebarButton", "fixedComplementarySidebarToggleStyles", "Stack", "ref", "orientation", "size", "mainPaddingTransitions", "onScroll", "map", "Fragment", "key", "PlankSeparator", "encapsulate", "Plank", "companionId", "StackContext", "Provider", "rail", "undefined", "Topbar", "StatusBar", "showHints", "span", "mx", "gridColumn", "React", "Surface", "useCapability", "AlertDialog", "Dialog", "NaturalDialog", "Dialog", "context", "useCapability", "DeckCapabilities", "MutableDeckState", "dialogOpen", "dialogType", "dialogBlockAlign", "dialogOverlayClasses", "dialogOverlayStyle", "dialogContent", "Root", "AlertDialog", "NaturalDialog", "Overlay", "React", "modal", "open", "onOpenChange", "nextOpen", "Surface", "role", "data", "limit", "fallback", "PlankContentError", "placeholder", "div", "blockAlign", "classNames", "style", "createContext", "React", "useCallback", "useEffect", "useMemo", "useRef", "useState", "Surface", "useCapability", "Popover", "DEBOUNCE_DELAY", "DeckPopoverProvider", "useDeckPopoverContext", "createContext", "PopoverRoot", "children", "layout", "useCapability", "DeckCapabilities", "MutableDeckState", "virtualRef", "useRef", "virtualIter", "setVirtualIter", "useState", "open", "setOpen", "debounceRef", "useEffect", "popoverOpen", "current", "clearTimeout", "popoverAnchor", "iter", "setTimeout", "popoverAnchorId", "popoverContent", "React", "Popover", "Root", "modal", "VirtualTrigger", "key", "PopoverContent", "handleClose", "useCallback", "event", "type", "currentTarget", "classList", "contains", "preventDefault", "undefined", "popoverSide", "collisionBoundaries", "useMemo", "closest", "Portal", "Content", "side", "onInteractOutside", "onEscapeKeyDown", "collisionBoundary", "sticky", "hideWhenDetached", "Viewport", "Surface", "role", "data", "limit", "Arrow", "React", "Button", "Icon", "Toast", "NaturalToast", "toLocalizedString", "useTranslation", "Toast", "id", "title", "description", "icon", "duration", "actionLabel", "actionAlt", "closeLabel", "onAction", "onOpenChange", "t", "useTranslation", "meta", "React", "NaturalToast", "Root", "data-testid", "defaultOpen", "Body", "Title", "classNames", "Icon", "size", "span", "toLocalizedString", "Description", "Actions", "Action", "altText", "asChild", "Button", "variant", "onClick", "Close", "Toaster", "toasts", "onDismissToast", "map", "toast", "key", "open", "DeckLayout", "onDismissToast", "context", "useCapability", "DeckCapabilities", "MutableDeckState", "toasts", "React", "PopoverRoot", "ActiveNode", "DeckMain", "PopoverContent", "Dialog", "Toaster", "React", "Input", "Select", "useTranslation", "ControlGroup", "ControlItemInput", "ControlPage", "ControlSection", "isSocket", "globalThis", "__args", "DeckSettings", "settings", "t", "useTranslation", "meta", "id", "React", "ControlPage", "ControlSection", "title", "ns", "ControlGroup", "ControlItemInput", "Input", "Switch", "checked", "enableDeck", "onCheckedChange", "encapsulatedPlanks", "Select", "Root", "disabled", "value", "newPlankPositioning", "onValueChange", "TriggerButton", "placeholder", "Portal", "Content", "Viewport", "NewPlankPositions", "map", "position", "Option", "key", "Arrow", "overscroll", "OverscrollOptions", "option", "enableStatusbar", "showHints", "enableNativeRedirect"]
7
+ }
@@ -0,0 +1,11 @@
1
+ // src/meta.ts
2
+ var meta = {
3
+ id: "dxos.org/plugin/deck",
4
+ name: "Layout",
5
+ icon: "ph--layout--regular"
6
+ };
7
+
8
+ export {
9
+ meta
10
+ };
11
+ //# sourceMappingURL=chunk-MHP4GPX5.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/meta.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { type PluginMeta } from '@dxos/app-framework';\n\nexport const meta: PluginMeta = {\n id: 'dxos.org/plugin/deck',\n name: 'Layout',\n icon: 'ph--layout--regular',\n};\n"],
5
+ "mappings": ";AAMO,IAAMA,OAAmB;EAC9BC,IAAI;EACJC,MAAM;EACNC,MAAM;AACR;",
6
+ "names": ["meta", "id", "name", "icon"]
7
+ }
@@ -2,10 +2,10 @@ import {
2
2
  ATTENDABLE_PATH_SEPARATOR,
3
3
  DECK_COMPANION_TYPE,
4
4
  PLANK_COMPANION_TYPE
5
- } from "./chunk-F5BQOOEG.mjs";
5
+ } from "./chunk-7I6H3N4Q.mjs";
6
6
  import {
7
- DECK_PLUGIN
8
- } from "./chunk-Z5KITAZW.mjs";
7
+ meta
8
+ } from "./chunk-MHP4GPX5.mjs";
9
9
 
10
10
  // src/hooks/useCompanions.ts
11
11
  import { useMemo } from "react";
@@ -52,8 +52,8 @@ import { useThemeContext } from "@dxos/react-ui";
52
52
  var useHoistStatusbar = (breakpoint, layoutMode) => {
53
53
  var _effect = _useSignals();
54
54
  try {
55
- const enableStatusbar = useCapability(Capabilities.SettingsStore).getStore(DECK_PLUGIN).value.enableStatusbar;
56
55
  const { safeAreaPadding } = useThemeContext();
56
+ const enableStatusbar = useCapability(Capabilities.SettingsStore).getStore(meta.id)?.value.enableStatusbar;
57
57
  return useMemo2(() => {
58
58
  return breakpoint === "desktop" && layoutMode !== "solo--fullscreen" && !!enableStatusbar && safeAreaPadding?.bottom === 0;
59
59
  }, [
@@ -96,15 +96,15 @@ var useNodeActionExpander = (node) => {
96
96
 
97
97
  // src/capabilities/index.ts
98
98
  import { lazy } from "@dxos/app-framework";
99
- var AppGraphBuilder = lazy(() => import("./app-graph-builder-DVEKLXB4.mjs"));
100
- var CheckAppScheme = lazy(() => import("./check-app-scheme-3BQJXWEY.mjs"));
101
- var DeckSettings = lazy(() => import("./settings-LUPQPZ27.mjs"));
102
- var DeckState = lazy(() => import("./state-CRXR7X63.mjs"));
103
- var LayoutIntentResolver = lazy(() => import("./intent-resolver-2SUIIV6N.mjs"));
104
- var ReactRoot = lazy(() => import("./react-root-7PRVDLF7.mjs"));
105
- var ReactSurface = lazy(() => import("./react-surface-FNY2YC2F.mjs"));
106
- var Toolkit = lazy(() => import("./toolkit-XGJSBY67.mjs"));
107
- var UrlHandler = lazy(() => import("./url-handler-LROZYQ26.mjs"));
99
+ var AppGraphBuilder = lazy(() => import("./app-graph-builder-YYP67JHW.mjs"));
100
+ var CheckAppScheme = lazy(() => import("./check-app-scheme-GCOL6YDT.mjs"));
101
+ var DeckSettings = lazy(() => import("./settings-M3KSKRAP.mjs"));
102
+ var DeckState = lazy(() => import("./state-6ZSDTF6Q.mjs"));
103
+ var LayoutIntentResolver = lazy(() => import("./intent-resolver-7XNOEPVN.mjs"));
104
+ var ReactRoot = lazy(() => import("./react-root-OJEF7YCH.mjs"));
105
+ var ReactSurface = lazy(() => import("./react-surface-XN2NJYHO.mjs"));
106
+ var Toolkit = lazy(() => import("./toolkit-L7C3UAEU.mjs"));
107
+ var UrlHandler = lazy(() => import("./url-handler-EHTLXZRR.mjs"));
108
108
 
109
109
  export {
110
110
  useBreakpoints,
@@ -124,4 +124,4 @@ export {
124
124
  Toolkit,
125
125
  UrlHandler
126
126
  };
127
- //# sourceMappingURL=chunk-WILMPGDV.mjs.map
127
+ //# sourceMappingURL=chunk-RJP5R7PY.mjs.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/hooks/useCompanions.ts", "../../../src/hooks/useBreakpoints.ts", "../../../src/hooks/useDeckCompanions.ts", "../../../src/hooks/useHoistStatusbar.ts", "../../../src/hooks/useMainSize.ts", "../../../src/hooks/useNodeActionExpander.ts", "../../../src/capabilities/index.ts"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { useMemo } from 'react';\n\nimport { useAppGraph } from '@dxos/app-framework';\nimport { useConnections } from '@dxos/plugin-graph';\nimport { byPosition } from '@dxos/util';\n\nimport { PLANK_COMPANION_TYPE } from '../types';\n\nexport const useCompanions = (id?: string) => {\n const { graph } = useAppGraph();\n const nodes = useConnections(graph, id);\n const companions = nodes.filter((node) => node.type === PLANK_COMPANION_TYPE);\n return useMemo(() => companions.toSorted((a, b) => byPosition(a.properties, b.properties)), [companions]);\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { useMediaQuery } from '@dxos/react-ui';\n\nexport const useBreakpoints = () => {\n const [isNotMobile] = useMediaQuery('md');\n const [isDesktop] = useMediaQuery('lg');\n return isDesktop ? 'desktop' : isNotMobile ? 'tablet' : 'mobile';\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type Label, useAppGraph } from '@dxos/app-framework';\nimport { type Node, ROOT_ID, useConnections } from '@dxos/plugin-graph';\nimport { type Position, byPosition } from '@dxos/util';\n\nimport { ATTENDABLE_PATH_SEPARATOR, DECK_COMPANION_TYPE } from '../types';\n\nexport const getCompanionId = (id: string) => {\n const [_, companionId] = id.split(ATTENDABLE_PATH_SEPARATOR);\n return companionId ?? 'never';\n};\n\nexport type DeckCompanion = Node<\n any,\n {\n label: Label;\n icon: string;\n // TODO(burdon): Scroll area should be controlled by surface.\n /** If true, the panel will not be wrapped in a scroll area. */\n fixed?: boolean;\n position?: Position;\n }\n>;\n\nexport const useDeckCompanions = (): DeckCompanion[] => {\n const { graph } = useAppGraph();\n const connections = useConnections(graph, ROOT_ID);\n const companions = connections.filter((node) => node.type === DECK_COMPANION_TYPE) as DeckCompanion[];\n return companions.toSorted((a, b) => byPosition(a.properties, b.properties));\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { useMemo } from 'react';\n\nimport { Capabilities, useCapability } from '@dxos/app-framework';\nimport { useThemeContext } from '@dxos/react-ui';\n\nimport { DECK_PLUGIN } from '../meta';\nimport type { DeckSettingsProps, LayoutMode } from '../types';\n\nexport const useHoistStatusbar = (breakpoint: string, layoutMode?: LayoutMode): boolean => {\n const enableStatusbar = useCapability(Capabilities.SettingsStore).getStore<DeckSettingsProps>(DECK_PLUGIN)!.value\n .enableStatusbar;\n const { safeAreaPadding } = useThemeContext();\n return useMemo(() => {\n return (\n breakpoint === 'desktop' &&\n layoutMode !== 'solo--fullscreen' &&\n !!enableStatusbar &&\n safeAreaPadding?.bottom === 0\n );\n }, [enableStatusbar, breakpoint, safeAreaPadding?.bottom, layoutMode]);\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { useMainContext } from '@dxos/react-ui';\n\nexport const useMainSize = () => {\n const { navigationSidebarState, complementarySidebarState } = useMainContext('DeckPluginPlank');\n return {\n 'data-sidebar-inline-start-state': navigationSidebarState,\n 'data-sidebar-inline-end-state': complementarySidebarState,\n };\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { useEffect } from 'react';\n\nimport { type Node, getGraph } from '@dxos/plugin-graph';\n\nexport const useNodeActionExpander = (node?: Node) => {\n useEffect(() => {\n if (node) {\n const frame = requestAnimationFrame(() => {\n const graph = getGraph(node);\n void graph.expand(node.id);\n });\n return () => cancelAnimationFrame(frame);\n }\n }, [node]);\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { lazy } from '@dxos/app-framework';\n\nexport const AppGraphBuilder = lazy(() => import('./app-graph-builder'));\nexport const CheckAppScheme = lazy(() => import('./check-app-scheme'));\nexport const DeckSettings = lazy(() => import('./settings'));\nexport const DeckState = lazy(() => import('./state'));\nexport const LayoutIntentResolver = lazy(() => import('./intent-resolver'));\nexport const ReactRoot = lazy(() => import('./react-root'));\nexport const ReactSurface = lazy(() => import('./react-surface'));\n// export const Tools = lazy(() => import('./tools'));\nexport const Toolkit = lazy(() => import('./toolkit'));\nexport const UrlHandler = lazy(() => import('./url-handler'));\n\nexport * from './capabilities';\nexport * from './state';\n"],
5
- "mappings": "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",
6
- "names": ["useMemo", "useAppGraph", "useConnections", "byPosition", "useCompanions", "id", "graph", "useAppGraph", "nodes", "useConnections", "companions", "filter", "node", "type", "PLANK_COMPANION_TYPE", "useMemo", "toSorted", "a", "b", "byPosition", "properties", "useMediaQuery", "useBreakpoints", "isNotMobile", "useMediaQuery", "isDesktop", "useAppGraph", "ROOT_ID", "useConnections", "byPosition", "getCompanionId", "id", "_", "companionId", "split", "ATTENDABLE_PATH_SEPARATOR", "useDeckCompanions", "graph", "useAppGraph", "connections", "useConnections", "ROOT_ID", "companions", "filter", "node", "type", "DECK_COMPANION_TYPE", "toSorted", "a", "b", "byPosition", "properties", "useMemo", "Capabilities", "useCapability", "useThemeContext", "useHoistStatusbar", "breakpoint", "layoutMode", "enableStatusbar", "useCapability", "Capabilities", "SettingsStore", "getStore", "DECK_PLUGIN", "value", "safeAreaPadding", "useThemeContext", "useMemo", "bottom", "useMainContext", "useMainSize", "navigationSidebarState", "complementarySidebarState", "useMainContext", "useEffect", "getGraph", "useNodeActionExpander", "node", "useEffect", "frame", "requestAnimationFrame", "graph", "getGraph", "expand", "id", "cancelAnimationFrame", "lazy", "AppGraphBuilder", "lazy", "CheckAppScheme", "DeckSettings", "DeckState", "LayoutIntentResolver", "ReactRoot", "ReactSurface", "Toolkit", "UrlHandler"]
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { useMemo } from 'react';\n\nimport { useAppGraph } from '@dxos/app-framework';\nimport { useConnections } from '@dxos/plugin-graph';\nimport { byPosition } from '@dxos/util';\n\nimport { PLANK_COMPANION_TYPE } from '../types';\n\nexport const useCompanions = (id?: string) => {\n const { graph } = useAppGraph();\n const nodes = useConnections(graph, id);\n const companions = nodes.filter((node) => node.type === PLANK_COMPANION_TYPE);\n return useMemo(() => companions.toSorted((a, b) => byPosition(a.properties, b.properties)), [companions]);\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { useMediaQuery } from '@dxos/react-ui';\n\nexport const useBreakpoints = () => {\n const [isNotMobile] = useMediaQuery('md');\n const [isDesktop] = useMediaQuery('lg');\n return isDesktop ? 'desktop' : isNotMobile ? 'tablet' : 'mobile';\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type Label, useAppGraph } from '@dxos/app-framework';\nimport { type Node, ROOT_ID, useConnections } from '@dxos/plugin-graph';\nimport { type Position, byPosition } from '@dxos/util';\n\nimport { ATTENDABLE_PATH_SEPARATOR, DECK_COMPANION_TYPE } from '../types';\n\nexport const getCompanionId = (id: string) => {\n const [_, companionId] = id.split(ATTENDABLE_PATH_SEPARATOR);\n return companionId ?? 'never';\n};\n\nexport type DeckCompanion = Node<\n any,\n {\n label: Label;\n icon: string;\n // TODO(burdon): Scroll area should be controlled by surface.\n /** If true, the panel will not be wrapped in a scroll area. */\n fixed?: boolean;\n position?: Position;\n }\n>;\n\nexport const useDeckCompanions = (): DeckCompanion[] => {\n const { graph } = useAppGraph();\n const connections = useConnections(graph, ROOT_ID);\n const companions = connections.filter((node) => node.type === DECK_COMPANION_TYPE) as DeckCompanion[];\n return companions.toSorted((a, b) => byPosition(a.properties, b.properties));\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { useMemo } from 'react';\n\nimport { Capabilities, useCapability } from '@dxos/app-framework';\nimport { useThemeContext } from '@dxos/react-ui';\n\nimport { meta } from '../meta';\nimport type { DeckSettingsProps, LayoutMode } from '../types';\n\nexport const useHoistStatusbar = (breakpoint: string, layoutMode?: LayoutMode): boolean => {\n const { safeAreaPadding } = useThemeContext();\n const enableStatusbar = useCapability(Capabilities.SettingsStore).getStore<DeckSettingsProps>(meta.id)?.value\n .enableStatusbar;\n\n return useMemo(() => {\n return (\n breakpoint === 'desktop' &&\n layoutMode !== 'solo--fullscreen' &&\n !!enableStatusbar &&\n safeAreaPadding?.bottom === 0\n );\n }, [enableStatusbar, breakpoint, safeAreaPadding?.bottom, layoutMode]);\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { useMainContext } from '@dxos/react-ui';\n\nexport const useMainSize = () => {\n const { navigationSidebarState, complementarySidebarState } = useMainContext('DeckPluginPlank');\n return {\n 'data-sidebar-inline-start-state': navigationSidebarState,\n 'data-sidebar-inline-end-state': complementarySidebarState,\n };\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { useEffect } from 'react';\n\nimport { type Node, getGraph } from '@dxos/plugin-graph';\n\nexport const useNodeActionExpander = (node?: Node) => {\n useEffect(() => {\n if (node) {\n const frame = requestAnimationFrame(() => {\n const graph = getGraph(node);\n void graph.expand(node.id);\n });\n return () => cancelAnimationFrame(frame);\n }\n }, [node]);\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { lazy } from '@dxos/app-framework';\n\nexport const AppGraphBuilder = lazy(() => import('./app-graph-builder'));\nexport const CheckAppScheme = lazy(() => import('./check-app-scheme'));\nexport const DeckSettings = lazy(() => import('./settings'));\nexport const DeckState = lazy(() => import('./state'));\nexport const LayoutIntentResolver = lazy(() => import('./intent-resolver'));\nexport const ReactRoot = lazy(() => import('./react-root'));\nexport const ReactSurface = lazy(() => import('./react-surface'));\n// export const Tools = lazy(() => import('./tools'));\nexport const Toolkit = lazy(() => import('./toolkit'));\nexport const UrlHandler = lazy(() => import('./url-handler'));\n\nexport * from './capabilities';\nexport * from './state';\n"],
5
+ "mappings": "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",
6
+ "names": ["useMemo", "useAppGraph", "useConnections", "byPosition", "useCompanions", "id", "graph", "useAppGraph", "nodes", "useConnections", "companions", "filter", "node", "type", "PLANK_COMPANION_TYPE", "useMemo", "toSorted", "a", "b", "byPosition", "properties", "useMediaQuery", "useBreakpoints", "isNotMobile", "useMediaQuery", "isDesktop", "useAppGraph", "ROOT_ID", "useConnections", "byPosition", "getCompanionId", "id", "_", "companionId", "split", "ATTENDABLE_PATH_SEPARATOR", "useDeckCompanions", "graph", "useAppGraph", "connections", "useConnections", "ROOT_ID", "companions", "filter", "node", "type", "DECK_COMPANION_TYPE", "toSorted", "a", "b", "byPosition", "properties", "useMemo", "Capabilities", "useCapability", "useThemeContext", "useHoistStatusbar", "breakpoint", "layoutMode", "safeAreaPadding", "useThemeContext", "enableStatusbar", "useCapability", "Capabilities", "SettingsStore", "getStore", "meta", "id", "value", "useMemo", "bottom", "useMainContext", "useMainSize", "navigationSidebarState", "complementarySidebarState", "useMainContext", "useEffect", "getGraph", "useNodeActionExpander", "node", "useEffect", "frame", "requestAnimationFrame", "graph", "getGraph", "expand", "id", "cancelAnimationFrame", "lazy", "AppGraphBuilder", "lazy", "CheckAppScheme", "DeckSettings", "DeckState", "LayoutIntentResolver", "ReactRoot", "ReactSurface", "Toolkit", "UrlHandler"]
7
7
  }
@@ -1,13 +1,13 @@
1
1
  import {
2
2
  DeckCapabilities
3
- } from "./chunk-M57WD3V6.mjs";
3
+ } from "./chunk-HUWUYTOI.mjs";
4
4
  import {
5
5
  defaultDeck,
6
6
  getMode
7
- } from "./chunk-F5BQOOEG.mjs";
7
+ } from "./chunk-7I6H3N4Q.mjs";
8
8
  import {
9
- DECK_PLUGIN
10
- } from "./chunk-Z5KITAZW.mjs";
9
+ meta
10
+ } from "./chunk-MHP4GPX5.mjs";
11
11
 
12
12
  // src/capabilities/state.ts
13
13
  import { Capabilities, contributes } from "@dxos/app-framework";
@@ -17,8 +17,8 @@ import { LocalStorageStore } from "@dxos/local-storage";
17
17
  var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-deck/src/capabilities/state.ts";
18
18
  var boolean = /true|false/;
19
19
  var migrateSidebarStateDefaults = {
20
- [`${DECK_PLUGIN}/complementary-sidebar-state`]: "expanded",
21
- [`${DECK_PLUGIN}/sidebar-state`]: "collapsed"
20
+ [`${meta.id}/complementary-sidebar-state`]: "expanded",
21
+ [`${meta.id}/sidebar-state`]: "collapsed"
22
22
  };
23
23
  var migrateSidebarState = () => {
24
24
  Object.entries(migrateSidebarStateDefaults).forEach(([key, defaultValue]) => {
@@ -29,7 +29,7 @@ var migrateSidebarState = () => {
29
29
  };
30
30
  var DeckStateFactory = () => {
31
31
  migrateSidebarState();
32
- const state = new LocalStorageStore(DECK_PLUGIN, {
32
+ const state = new LocalStorageStore(meta.id, {
33
33
  sidebarState: "expanded",
34
34
  complementarySidebarState: "collapsed",
35
35
  complementarySidebarPanel: void 0,
@@ -54,7 +54,7 @@ var DeckStateFactory = () => {
54
54
  const deck = this.decks[this.activeDeck];
55
55
  invariant(deck, `Deck not found: ${this.activeDeck}`, {
56
56
  F: __dxlog_file,
57
- L: 57,
57
+ L: 60,
58
58
  S: this,
59
59
  A: [
60
60
  "deck",
@@ -126,4 +126,4 @@ export {
126
126
  DeckStateFactory,
127
127
  state_default
128
128
  };
129
- //# sourceMappingURL=chunk-NRCPV6AV.mjs.map
129
+ //# sourceMappingURL=chunk-VX7MMQOW.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/state.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Capabilities, contributes } from '@dxos/app-framework';\nimport { invariant } from '@dxos/invariant';\nimport { live } from '@dxos/live-object';\nimport { LocalStorageStore } from '@dxos/local-storage';\nimport { type SidebarState } from '@dxos/react-ui';\n\nimport { meta } from '../meta';\nimport { type DeckPluginState, type DeckState, defaultDeck, getMode } from '../types';\n\nimport { DeckCapabilities } from './capabilities';\n\nconst boolean = /true|false/;\n\n// TODO(thure, 18 Feb 2025): Remove after the next release.\n\nconst migrateSidebarStateDefaults = {\n [`${meta.id}/complementary-sidebar-state`]: 'expanded',\n [`${meta.id}/sidebar-state`]: 'collapsed',\n};\n\nconst migrateSidebarState = () => {\n Object.entries(migrateSidebarStateDefaults).forEach(([key, defaultValue]) => {\n if (boolean.test(localStorage.getItem(key) ?? 'never')) {\n localStorage.setItem(key, defaultValue);\n }\n });\n};\n\n/**\n * @deprecated\n */\nexport const DeckStateFactory = () => {\n migrateSidebarState();\n\n const state = new LocalStorageStore<DeckPluginState>(meta.id, {\n sidebarState: 'expanded',\n complementarySidebarState: 'collapsed',\n complementarySidebarPanel: undefined,\n dialogContent: null,\n dialogOpen: false,\n dialogBlockAlign: undefined,\n dialogType: undefined,\n popoverContent: null,\n popoverAnchor: undefined,\n popoverAnchorId: undefined,\n popoverOpen: false,\n toasts: [],\n currentUndoId: undefined,\n activeDeck: 'default',\n previousDeck: 'default',\n decks: {\n default: { ...defaultDeck },\n },\n get deck() {\n const deck = this.decks[this.activeDeck];\n invariant(deck, `Deck not found: ${this.activeDeck}`);\n return deck;\n },\n previousMode: {},\n scrollIntoView: undefined,\n });\n\n state\n .prop({ key: 'sidebarState', type: LocalStorageStore.enum<SidebarState>() })\n .prop({ key: 'complementarySidebarState', type: LocalStorageStore.enum<SidebarState>() })\n .prop({ key: 'complementarySidebarPanel', type: LocalStorageStore.string({ allowUndefined: true }) })\n .prop({ key: 'decks', type: LocalStorageStore.json<Record<string, DeckState>>() })\n .prop({ key: 'activeDeck', type: LocalStorageStore.string() })\n .prop({ key: 'previousDeck', type: LocalStorageStore.string() });\n\n const layout = live<Capabilities.Layout>({\n get mode() {\n return getMode(state.values.deck);\n },\n get dialogOpen() {\n return state.values.dialogOpen;\n },\n get sidebarOpen() {\n return state.values.sidebarState === 'expanded';\n },\n get complementarySidebarOpen() {\n return state.values.complementarySidebarState === 'expanded';\n },\n get workspace() {\n return state.values.activeDeck;\n },\n get active() {\n return state.values.deck.solo ? [state.values.deck.solo] : state.values.deck.active;\n },\n get inactive() {\n return state.values.deck.inactive;\n },\n get scrollIntoView() {\n return state.values.scrollIntoView;\n },\n });\n\n return [\n contributes(DeckCapabilities.DeckState, state.values, () => state.close()),\n contributes(Capabilities.Layout, layout),\n ];\n};\n\nexport default DeckStateFactory;\n"],
5
+ "mappings": ";;;;;;;;;;;;AAIA,SAASA,cAAcC,mBAAmB;AAC1C,SAASC,iBAAiB;AAC1B,SAASC,YAAY;AACrB,SAASC,yBAAyB;;AAQlC,IAAMC,UAAU;AAIhB,IAAMC,8BAA8B;EAClC,CAAC,GAAGC,KAAKC,EAAE,8BAA8B,GAAG;EAC5C,CAAC,GAAGD,KAAKC,EAAE,gBAAgB,GAAG;AAChC;AAEA,IAAMC,sBAAsB,MAAA;AAC1BC,SAAOC,QAAQL,2BAAAA,EAA6BM,QAAQ,CAAC,CAACC,KAAKC,YAAAA,MAAa;AACtE,QAAIT,QAAQU,KAAKC,aAAaC,QAAQJ,GAAAA,KAAQ,OAAA,GAAU;AACtDG,mBAAaE,QAAQL,KAAKC,YAAAA;IAC5B;EACF,CAAA;AACF;AAKO,IAAMK,mBAAmB,MAAA;AAC9BV,sBAAAA;AAEA,QAAMW,QAAQ,IAAIC,kBAAmCd,KAAKC,IAAI;IAC5Dc,cAAc;IACdC,2BAA2B;IAC3BC,2BAA2BC;IAC3BC,eAAe;IACfC,YAAY;IACZC,kBAAkBH;IAClBI,YAAYJ;IACZK,gBAAgB;IAChBC,eAAeN;IACfO,iBAAiBP;IACjBQ,aAAa;IACbC,QAAQ,CAAA;IACRC,eAAeV;IACfW,YAAY;IACZC,cAAc;IACdC,OAAO;MACLC,SAAS;QAAE,GAAGC;MAAY;IAC5B;IACA,IAAIC,OAAO;AACT,YAAMA,OAAO,KAAKH,MAAM,KAAKF,UAAU;AACvCM,gBAAUD,MAAM,mBAAmB,KAAKL,UAAU,IAAE;;;;;;;;;AACpD,aAAOK;IACT;IACAE,cAAc,CAAC;IACfC,gBAAgBnB;EAClB,CAAA;AAEAL,QACGyB,KAAK;IAAEhC,KAAK;IAAgBiC,MAAMzB,kBAAkB0B,KAAI;EAAiB,CAAA,EACzEF,KAAK;IAAEhC,KAAK;IAA6BiC,MAAMzB,kBAAkB0B,KAAI;EAAiB,CAAA,EACtFF,KAAK;IAAEhC,KAAK;IAA6BiC,MAAMzB,kBAAkB2B,OAAO;MAAEC,gBAAgB;IAAK,CAAA;EAAG,CAAA,EAClGJ,KAAK;IAAEhC,KAAK;IAASiC,MAAMzB,kBAAkB6B,KAAI;EAA8B,CAAA,EAC/EL,KAAK;IAAEhC,KAAK;IAAciC,MAAMzB,kBAAkB2B,OAAM;EAAG,CAAA,EAC3DH,KAAK;IAAEhC,KAAK;IAAgBiC,MAAMzB,kBAAkB2B,OAAM;EAAG,CAAA;AAEhE,QAAMG,SAASC,KAA0B;IACvC,IAAIC,OAAO;AACT,aAAOC,QAAQlC,MAAMmC,OAAOd,IAAI;IAClC;IACA,IAAId,aAAa;AACf,aAAOP,MAAMmC,OAAO5B;IACtB;IACA,IAAI6B,cAAc;AAChB,aAAOpC,MAAMmC,OAAOjC,iBAAiB;IACvC;IACA,IAAImC,2BAA2B;AAC7B,aAAOrC,MAAMmC,OAAOhC,8BAA8B;IACpD;IACA,IAAImC,YAAY;AACd,aAAOtC,MAAMmC,OAAOnB;IACtB;IACA,IAAIuB,SAAS;AACX,aAAOvC,MAAMmC,OAAOd,KAAKmB,OAAO;QAACxC,MAAMmC,OAAOd,KAAKmB;UAAQxC,MAAMmC,OAAOd,KAAKkB;IAC/E;IACA,IAAIE,WAAW;AACb,aAAOzC,MAAMmC,OAAOd,KAAKoB;IAC3B;IACA,IAAIjB,iBAAiB;AACnB,aAAOxB,MAAMmC,OAAOX;IACtB;EACF,CAAA;AAEA,SAAO;IACLkB,YAAYC,iBAAiBC,WAAW5C,MAAMmC,QAAQ,MAAMnC,MAAM6C,MAAK,CAAA;IACvEH,YAAYI,aAAaC,QAAQhB,MAAAA;;AAErC;AAEA,IAAA,gBAAehC;",
6
+ "names": ["Capabilities", "contributes", "invariant", "live", "LocalStorageStore", "boolean", "migrateSidebarStateDefaults", "meta", "id", "migrateSidebarState", "Object", "entries", "forEach", "key", "defaultValue", "test", "localStorage", "getItem", "setItem", "DeckStateFactory", "state", "LocalStorageStore", "sidebarState", "complementarySidebarState", "complementarySidebarPanel", "undefined", "dialogContent", "dialogOpen", "dialogBlockAlign", "dialogType", "popoverContent", "popoverAnchor", "popoverAnchorId", "popoverOpen", "toasts", "currentUndoId", "activeDeck", "previousDeck", "decks", "default", "defaultDeck", "deck", "invariant", "previousMode", "scrollIntoView", "prop", "type", "enum", "string", "allowUndefined", "json", "layout", "live", "mode", "getMode", "values", "sidebarOpen", "complementarySidebarOpen", "workspace", "active", "solo", "inactive", "contributes", "DeckCapabilities", "DeckState", "close", "Capabilities", "Layout"]
7
+ }
@@ -9,21 +9,20 @@ import {
9
9
  Toolkit,
10
10
  UrlHandler,
11
11
  useCompanions
12
- } from "./chunk-WILMPGDV.mjs";
13
- import "./chunk-NRCPV6AV.mjs";
12
+ } from "./chunk-RJP5R7PY.mjs";
13
+ import "./chunk-VX7MMQOW.mjs";
14
14
  import {
15
15
  DeckCapabilities
16
- } from "./chunk-M57WD3V6.mjs";
17
- import "./chunk-F5BQOOEG.mjs";
16
+ } from "./chunk-HUWUYTOI.mjs";
17
+ import "./chunk-7I6H3N4Q.mjs";
18
18
  import {
19
- DECK_PLUGIN,
20
19
  meta
21
- } from "./chunk-Z5KITAZW.mjs";
20
+ } from "./chunk-MHP4GPX5.mjs";
22
21
 
23
22
  // src/events.ts
24
23
  import { Events } from "@dxos/app-framework";
25
24
  (function(DeckEvents2) {
26
- DeckEvents2.StateReady = Events.createStateEvent(`${DECK_PLUGIN}/state-ready`);
25
+ DeckEvents2.StateReady = Events.createStateEvent(`${meta.id}/state-ready`);
27
26
  })(DeckEvents || (DeckEvents = {}));
28
27
  var DeckEvents;
29
28
 
@@ -85,6 +84,7 @@ var translations = [
85
84
  "settings overscroll none label": "None",
86
85
  "settings enable statusbar label": "Show status bar",
87
86
  "settings enable deck label": "Enable Deck",
87
+ "settings encapsulated planks label": "Encapsulated planks",
88
88
  "close current label": "Close current plank",
89
89
  "close others label": "Close other planks",
90
90
  "close all label": "Close all planks",
@@ -96,7 +96,7 @@ var translations = [
96
96
 
97
97
  // src/DeckPlugin.ts
98
98
  setAutoFreeze(false);
99
- var DeckPlugin = () => definePlugin(meta, [
99
+ var DeckPlugin = definePlugin(meta, () => [
100
100
  defineModule({
101
101
  id: `${meta.id}/module/check-app-scheme`,
102
102
  activatesOn: Events2.SettingsReady,
@@ -165,7 +165,6 @@ var DeckPlugin = () => definePlugin(meta, [
165
165
  })
166
166
  ]);
167
167
  export {
168
- DECK_PLUGIN,
169
168
  DeckCapabilities,
170
169
  DeckEvents,
171
170
  DeckPlugin,