@dxos/plugin-deck 0.8.4-main.e8ec1fe → 0.8.4-main.effb148878

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 (502) hide show
  1. package/LICENSE +102 -5
  2. package/README.md +1 -1
  3. package/dist/lib/neutral/DeckLayout-NBVPPAQP.mjs +278 -0
  4. package/dist/lib/neutral/DeckLayout-NBVPPAQP.mjs.map +7 -0
  5. package/dist/lib/neutral/DeckPlugin.mjs +70 -0
  6. package/dist/lib/neutral/DeckPlugin.mjs.map +7 -0
  7. package/dist/lib/neutral/DeckPlugin.node.mjs +18 -0
  8. package/dist/lib/neutral/DeckPlugin.node.mjs.map +7 -0
  9. package/dist/lib/neutral/DeckPlugin.workerd.mjs +16 -0
  10. package/dist/lib/neutral/DeckPlugin.workerd.mjs.map +7 -0
  11. package/dist/lib/neutral/DeckSettings-W5I57OXM.mjs +27 -0
  12. package/dist/lib/neutral/DeckSettings-W5I57OXM.mjs.map +7 -0
  13. package/dist/lib/neutral/add-toast-H2PK2S3H.mjs +24 -0
  14. package/dist/lib/neutral/add-toast-H2PK2S3H.mjs.map +7 -0
  15. package/dist/lib/neutral/adjust-J6ZPQ5BT.mjs +93 -0
  16. package/dist/lib/neutral/adjust-J6ZPQ5BT.mjs.map +7 -0
  17. package/dist/lib/neutral/app-graph-builder-MRA3OMKO.mjs +129 -0
  18. package/dist/lib/neutral/app-graph-builder-MRA3OMKO.mjs.map +7 -0
  19. package/dist/lib/neutral/capabilities/index.mjs +23 -0
  20. package/dist/lib/neutral/capabilities/index.mjs.map +7 -0
  21. package/dist/lib/neutral/check-app-scheme-A7FZVNZO.mjs +10 -0
  22. package/dist/lib/neutral/chunk-3WIBNTUT.mjs +35 -0
  23. package/dist/lib/neutral/chunk-3WIBNTUT.mjs.map +7 -0
  24. package/dist/lib/neutral/chunk-FBN443XP.mjs +8 -0
  25. package/dist/lib/neutral/chunk-FBN443XP.mjs.map +7 -0
  26. package/dist/lib/neutral/chunk-FSIEKCMR.mjs +1305 -0
  27. package/dist/lib/neutral/chunk-FSIEKCMR.mjs.map +7 -0
  28. package/dist/lib/neutral/chunk-GBIGQKYW.mjs +112 -0
  29. package/dist/lib/neutral/chunk-GBIGQKYW.mjs.map +7 -0
  30. package/dist/lib/neutral/chunk-GLB73Q6U.mjs +22 -0
  31. package/dist/lib/neutral/chunk-GLB73Q6U.mjs.map +7 -0
  32. package/dist/lib/neutral/chunk-HD44H4CJ.mjs +280 -0
  33. package/dist/lib/neutral/chunk-HD44H4CJ.mjs.map +7 -0
  34. package/dist/lib/neutral/chunk-J5LGTIGS.mjs +10 -0
  35. package/dist/lib/neutral/chunk-VHETZ22W.mjs +101 -0
  36. package/dist/lib/neutral/chunk-VHETZ22W.mjs.map +7 -0
  37. package/dist/lib/neutral/chunk-ZYYOSX5I.mjs +69 -0
  38. package/dist/lib/neutral/chunk-ZYYOSX5I.mjs.map +7 -0
  39. package/dist/lib/neutral/close-IPQTWQXS.mjs +44 -0
  40. package/dist/lib/neutral/close-IPQTWQXS.mjs.map +7 -0
  41. package/dist/lib/neutral/components/index.mjs +126 -0
  42. package/dist/lib/neutral/components/index.mjs.map +7 -0
  43. package/dist/lib/neutral/containers/index.mjs +32 -0
  44. package/dist/lib/neutral/containers/index.mjs.map +7 -0
  45. package/dist/lib/neutral/hooks/index.mjs +159 -0
  46. package/dist/lib/neutral/hooks/index.mjs.map +7 -0
  47. package/dist/lib/neutral/index.mjs +38 -0
  48. package/dist/lib/neutral/index.mjs.map +7 -0
  49. package/dist/lib/neutral/meta.json +1 -0
  50. package/dist/lib/neutral/meta.mjs +8 -0
  51. package/dist/lib/neutral/meta.mjs.map +7 -0
  52. package/dist/lib/neutral/open-OAKTKZM2.mjs +149 -0
  53. package/dist/lib/neutral/open-OAKTKZM2.mjs.map +7 -0
  54. package/dist/lib/neutral/operation-handler-266CVMTW.mjs +13 -0
  55. package/dist/lib/neutral/operation-handler-266CVMTW.mjs.map +7 -0
  56. package/dist/lib/neutral/operations/index.mjs +8 -0
  57. package/dist/lib/neutral/operations/index.mjs.map +7 -0
  58. package/dist/lib/neutral/plugin.mjs +16 -0
  59. package/dist/lib/neutral/plugin.mjs.map +7 -0
  60. package/dist/lib/neutral/react-root-WZ6KH27J.mjs +41 -0
  61. package/dist/lib/neutral/react-root-WZ6KH27J.mjs.map +7 -0
  62. package/dist/lib/neutral/react-surface-KAAZDHV3.mjs +34 -0
  63. package/dist/lib/neutral/react-surface-KAAZDHV3.mjs.map +7 -0
  64. package/dist/lib/neutral/revert-workspace-PLY4YQ4X.mjs +21 -0
  65. package/dist/lib/neutral/revert-workspace-PLY4YQ4X.mjs.map +7 -0
  66. package/dist/lib/neutral/scroll-into-view-INJL3YOV.mjs +21 -0
  67. package/dist/lib/neutral/scroll-into-view-INJL3YOV.mjs.map +7 -0
  68. package/dist/lib/neutral/set-CQ6AO7QB.mjs +37 -0
  69. package/dist/lib/neutral/set-CQ6AO7QB.mjs.map +7 -0
  70. package/dist/lib/neutral/set-layout-mode-NBPJRYGC.mjs +85 -0
  71. package/dist/lib/neutral/set-layout-mode-NBPJRYGC.mjs.map +7 -0
  72. package/dist/lib/neutral/settings-EGNYUM4T.mjs +33 -0
  73. package/dist/lib/neutral/settings-EGNYUM4T.mjs.map +7 -0
  74. package/dist/lib/neutral/show-undo-EZH7JPAV.mjs +59 -0
  75. package/dist/lib/neutral/show-undo-EZH7JPAV.mjs.map +7 -0
  76. package/dist/lib/neutral/state-IIDXMQUO.mjs +86 -0
  77. package/dist/lib/neutral/state-IIDXMQUO.mjs.map +7 -0
  78. package/dist/lib/neutral/switch-workspace-UCFFW3B6.mjs +60 -0
  79. package/dist/lib/neutral/switch-workspace-UCFFW3B6.mjs.map +7 -0
  80. package/dist/lib/neutral/translations.mjs +58 -0
  81. package/dist/lib/neutral/translations.mjs.map +7 -0
  82. package/dist/lib/neutral/types/index.mjs +34 -0
  83. package/dist/lib/neutral/types/index.mjs.map +7 -0
  84. package/dist/lib/neutral/update-companion-NCPRS5MP.mjs +32 -0
  85. package/dist/lib/neutral/update-companion-NCPRS5MP.mjs.map +7 -0
  86. package/dist/lib/neutral/update-complementary-4RERA3VA.mjs +28 -0
  87. package/dist/lib/neutral/update-complementary-4RERA3VA.mjs.map +7 -0
  88. package/dist/lib/neutral/update-dialog-GMFMY7KZ.mjs +29 -0
  89. package/dist/lib/neutral/update-dialog-GMFMY7KZ.mjs.map +7 -0
  90. package/dist/lib/neutral/update-plank-size-TO7RMHQM.mjs +26 -0
  91. package/dist/lib/neutral/update-plank-size-TO7RMHQM.mjs.map +7 -0
  92. package/dist/lib/neutral/update-popover-H3KBQQZ4.mjs +33 -0
  93. package/dist/lib/neutral/update-popover-H3KBQQZ4.mjs.map +7 -0
  94. package/dist/lib/neutral/update-sidebar-OM7EGDQR.mjs +25 -0
  95. package/dist/lib/neutral/update-sidebar-OM7EGDQR.mjs.map +7 -0
  96. package/dist/lib/neutral/url-handler-3QTKEM2K.mjs +184 -0
  97. package/dist/lib/neutral/url-handler-3QTKEM2K.mjs.map +7 -0
  98. package/dist/types/src/DeckPlugin.d.ts +3 -1
  99. package/dist/types/src/DeckPlugin.d.ts.map +1 -1
  100. package/dist/types/src/DeckPlugin.node.d.ts +4 -0
  101. package/dist/types/src/DeckPlugin.node.d.ts.map +1 -0
  102. package/dist/types/src/DeckPlugin.test.d.ts +2 -0
  103. package/dist/types/src/DeckPlugin.test.d.ts.map +1 -0
  104. package/dist/types/src/DeckPlugin.workerd.d.ts +4 -0
  105. package/dist/types/src/DeckPlugin.workerd.d.ts.map +1 -0
  106. package/dist/types/src/capabilities/app-graph-builder.d.ts +4 -2
  107. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  108. package/dist/types/src/capabilities/check-app-scheme.d.ts +17 -2
  109. package/dist/types/src/capabilities/check-app-scheme.d.ts.map +1 -1
  110. package/dist/types/src/capabilities/index.d.ts +196 -12
  111. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  112. package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
  113. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
  114. package/dist/types/src/capabilities/react-root.d.ts +4 -2
  115. package/dist/types/src/capabilities/react-root.d.ts.map +1 -1
  116. package/dist/types/src/capabilities/react-surface.d.ts +3 -2
  117. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  118. package/dist/types/src/capabilities/settings.d.ts +5 -2
  119. package/dist/types/src/capabilities/settings.d.ts.map +1 -1
  120. package/dist/types/src/capabilities/state.d.ts +136 -49
  121. package/dist/types/src/capabilities/state.d.ts.map +1 -1
  122. package/dist/types/src/capabilities/tools.d.ts +4 -3
  123. package/dist/types/src/capabilities/tools.d.ts.map +1 -1
  124. package/dist/types/src/capabilities/url-handler.d.ts +3 -2
  125. package/dist/types/src/capabilities/url-handler.d.ts.map +1 -1
  126. package/dist/types/src/components/DeckSettings/DeckSettings.d.ts +4 -4
  127. package/dist/types/src/components/DeckSettings/DeckSettings.d.ts.map +1 -1
  128. package/dist/types/src/components/DeckSettings/DeckSettings.stories.d.ts +62 -0
  129. package/dist/types/src/components/DeckSettings/DeckSettings.stories.d.ts.map +1 -0
  130. package/dist/types/src/components/DeckSettings/index.d.ts +1 -1
  131. package/dist/types/src/components/DeckSettings/index.d.ts.map +1 -1
  132. package/dist/types/src/components/Matrix/Matrix.d.ts +41 -0
  133. package/dist/types/src/components/Matrix/Matrix.d.ts.map +1 -0
  134. package/dist/types/src/components/Matrix/Matrix.stories.d.ts +17 -0
  135. package/dist/types/src/components/Matrix/Matrix.stories.d.ts.map +1 -0
  136. package/dist/types/src/components/Matrix/index.d.ts +3 -0
  137. package/dist/types/src/components/Matrix/index.d.ts.map +1 -0
  138. package/dist/types/src/components/index.d.ts +3 -2
  139. package/dist/types/src/components/index.d.ts.map +1 -1
  140. package/dist/types/src/{components/DeckLayout → containers/Deck}/Banner.d.ts +1 -1
  141. package/dist/types/src/containers/Deck/Banner.d.ts.map +1 -0
  142. package/dist/types/src/containers/Deck/Deck.d.ts +25 -0
  143. package/dist/types/src/containers/Deck/Deck.d.ts.map +1 -0
  144. package/dist/types/src/containers/Deck/Deck.stories.d.ts +62 -0
  145. package/dist/types/src/containers/Deck/Deck.stories.d.ts.map +1 -0
  146. package/dist/types/src/containers/Deck/DeckContent.d.ts +7 -0
  147. package/dist/types/src/containers/Deck/DeckContent.d.ts.map +1 -0
  148. package/dist/types/src/containers/Deck/DeckRoot.d.ts +39 -0
  149. package/dist/types/src/containers/Deck/DeckRoot.d.ts.map +1 -0
  150. package/dist/types/src/containers/Deck/DeckViewport.d.ts +16 -0
  151. package/dist/types/src/containers/Deck/DeckViewport.d.ts.map +1 -0
  152. package/dist/types/src/containers/Deck/StatusBar.d.ts.map +1 -0
  153. package/dist/types/src/containers/Deck/index.d.ts +2 -0
  154. package/dist/types/src/containers/Deck/index.d.ts.map +1 -0
  155. package/dist/types/src/containers/DeckLayout/ActiveNode.d.ts.map +1 -0
  156. package/dist/types/src/containers/DeckLayout/DeckLayout.d.ts.map +1 -0
  157. package/dist/types/src/containers/DeckLayout/DeckLayout.stories.d.ts +64 -0
  158. package/dist/types/src/containers/DeckLayout/DeckLayout.stories.d.ts.map +1 -0
  159. package/dist/types/src/containers/DeckLayout/Dialog.d.ts.map +1 -0
  160. package/dist/types/src/containers/DeckLayout/Fallback.d.ts +2 -0
  161. package/dist/types/src/containers/DeckLayout/Fallback.d.ts.map +1 -0
  162. package/dist/types/src/containers/DeckLayout/Popover.d.ts +5 -0
  163. package/dist/types/src/containers/DeckLayout/Popover.d.ts.map +1 -0
  164. package/dist/types/src/{components → containers}/DeckLayout/Toast.d.ts +3 -3
  165. package/dist/types/src/containers/DeckLayout/Toast.d.ts.map +1 -0
  166. package/dist/types/src/containers/DeckLayout/constants.d.ts.map +1 -0
  167. package/dist/types/src/containers/DeckLayout/index.d.ts +4 -0
  168. package/dist/types/src/containers/DeckLayout/index.d.ts.map +1 -0
  169. package/dist/types/src/containers/Plank/Plank.d.ts +17 -0
  170. package/dist/types/src/containers/Plank/Plank.d.ts.map +1 -0
  171. package/dist/types/src/containers/Plank/Plank.stories.d.ts +62 -0
  172. package/dist/types/src/containers/Plank/Plank.stories.d.ts.map +1 -0
  173. package/dist/types/src/containers/Plank/PlankComponent.d.ts +17 -0
  174. package/dist/types/src/containers/Plank/PlankComponent.d.ts.map +1 -0
  175. package/dist/types/src/containers/Plank/PlankContent.d.ts +10 -0
  176. package/dist/types/src/containers/Plank/PlankContent.d.ts.map +1 -0
  177. package/dist/types/src/{components → containers}/Plank/PlankControls.d.ts +5 -6
  178. package/dist/types/src/containers/Plank/PlankControls.d.ts.map +1 -0
  179. package/dist/types/src/containers/Plank/PlankError.d.ts +15 -0
  180. package/dist/types/src/containers/Plank/PlankError.d.ts.map +1 -0
  181. package/dist/types/src/{components → containers}/Plank/PlankHeading.d.ts +5 -4
  182. package/dist/types/src/containers/Plank/PlankHeading.d.ts.map +1 -0
  183. package/dist/types/src/{components → containers}/Plank/PlankLoading.d.ts.map +1 -1
  184. package/dist/types/src/containers/Plank/PlankRoot.d.ts +37 -0
  185. package/dist/types/src/containers/Plank/PlankRoot.d.ts.map +1 -0
  186. package/dist/types/src/containers/Plank/index.d.ts +4 -0
  187. package/dist/types/src/containers/Plank/index.d.ts.map +1 -0
  188. package/dist/types/src/containers/Sidebar/ComplementarySidebar.d.ts.map +1 -0
  189. package/dist/types/src/containers/Sidebar/Sidebar.d.ts.map +1 -0
  190. package/dist/types/src/{components → containers}/Sidebar/SidebarButton.d.ts +1 -1
  191. package/dist/types/src/containers/Sidebar/SidebarButton.d.ts.map +1 -0
  192. package/dist/types/src/{components → containers}/Sidebar/index.d.ts.map +1 -1
  193. package/dist/types/src/containers/index.d.ts +6 -0
  194. package/dist/types/src/containers/index.d.ts.map +1 -0
  195. package/dist/types/src/hooks/index.d.ts +2 -1
  196. package/dist/types/src/hooks/index.d.ts.map +1 -1
  197. package/dist/types/src/hooks/useBreakpoints.d.ts +1 -1
  198. package/dist/types/src/hooks/useCompanions.d.ts.map +1 -1
  199. package/dist/types/src/hooks/useDeckCompanions.d.ts +4 -4
  200. package/dist/types/src/hooks/useDeckCompanions.d.ts.map +1 -1
  201. package/dist/types/src/hooks/useDeckState.d.ts +17 -0
  202. package/dist/types/src/hooks/useDeckState.d.ts.map +1 -0
  203. package/dist/types/src/hooks/useMainSize.d.ts +2 -2
  204. package/dist/types/src/hooks/useMainSize.d.ts.map +1 -1
  205. package/dist/types/src/hooks/useNodeActionExpander.d.ts +1 -1
  206. package/dist/types/src/hooks/useNodeActionExpander.d.ts.map +1 -1
  207. package/dist/types/src/hooks/useSelectedCompanion.d.ts +13 -0
  208. package/dist/types/src/hooks/useSelectedCompanion.d.ts.map +1 -0
  209. package/dist/types/src/index.d.ts +1 -4
  210. package/dist/types/src/index.d.ts.map +1 -1
  211. package/dist/types/src/layout.d.ts +20 -9
  212. package/dist/types/src/layout.d.ts.map +1 -1
  213. package/dist/types/src/layout.test.d.ts +2 -0
  214. package/dist/types/src/layout.test.d.ts.map +1 -0
  215. package/dist/types/src/meta.d.ts +2 -2
  216. package/dist/types/src/meta.d.ts.map +1 -1
  217. package/dist/types/src/operations/add-toast.d.ts +5 -0
  218. package/dist/types/src/operations/add-toast.d.ts.map +1 -0
  219. package/dist/types/src/operations/adjust.d.ts +5 -0
  220. package/dist/types/src/operations/adjust.d.ts.map +1 -0
  221. package/dist/types/src/operations/close.d.ts +5 -0
  222. package/dist/types/src/operations/close.d.ts.map +1 -0
  223. package/dist/types/src/operations/helpers.d.ts +3 -0
  224. package/dist/types/src/operations/helpers.d.ts.map +1 -0
  225. package/dist/types/src/operations/index.d.ts +3 -0
  226. package/dist/types/src/operations/index.d.ts.map +1 -0
  227. package/dist/types/src/operations/open.d.ts +5 -0
  228. package/dist/types/src/operations/open.d.ts.map +1 -0
  229. package/dist/types/src/operations/revert-workspace.d.ts +5 -0
  230. package/dist/types/src/operations/revert-workspace.d.ts.map +1 -0
  231. package/dist/types/src/operations/scroll-into-view.d.ts +5 -0
  232. package/dist/types/src/operations/scroll-into-view.d.ts.map +1 -0
  233. package/dist/types/src/operations/set-layout-mode.d.ts +9 -0
  234. package/dist/types/src/operations/set-layout-mode.d.ts.map +1 -0
  235. package/dist/types/src/operations/set.d.ts +5 -0
  236. package/dist/types/src/operations/set.d.ts.map +1 -0
  237. package/dist/types/src/operations/show-undo.d.ts +5 -0
  238. package/dist/types/src/operations/show-undo.d.ts.map +1 -0
  239. package/dist/types/src/operations/switch-workspace.d.ts +5 -0
  240. package/dist/types/src/operations/switch-workspace.d.ts.map +1 -0
  241. package/dist/types/src/operations/update-companion.d.ts +5 -0
  242. package/dist/types/src/operations/update-companion.d.ts.map +1 -0
  243. package/dist/types/src/operations/update-complementary.d.ts +5 -0
  244. package/dist/types/src/operations/update-complementary.d.ts.map +1 -0
  245. package/dist/types/src/operations/update-dialog.d.ts +5 -0
  246. package/dist/types/src/operations/update-dialog.d.ts.map +1 -0
  247. package/dist/types/src/operations/update-plank-size.d.ts +5 -0
  248. package/dist/types/src/operations/update-plank-size.d.ts.map +1 -0
  249. package/dist/types/src/operations/update-popover.d.ts +5 -0
  250. package/dist/types/src/operations/update-popover.d.ts.map +1 -0
  251. package/dist/types/src/operations/update-sidebar.d.ts +5 -0
  252. package/dist/types/src/operations/update-sidebar.d.ts.map +1 -0
  253. package/dist/types/src/plugin.d.ts +4 -0
  254. package/dist/types/src/plugin.d.ts.map +1 -0
  255. package/dist/types/src/translations.d.ts +43 -55
  256. package/dist/types/src/translations.d.ts.map +1 -1
  257. package/dist/types/src/types/DeckCapabilities.d.ts +188 -0
  258. package/dist/types/src/types/DeckCapabilities.d.ts.map +1 -0
  259. package/dist/types/src/types/DeckEvents.d.ts +5 -0
  260. package/dist/types/src/types/DeckEvents.d.ts.map +1 -0
  261. package/dist/types/src/types/DeckOperation.d.ts +15 -0
  262. package/dist/types/src/types/DeckOperation.d.ts.map +1 -0
  263. package/dist/types/src/types/Settings.d.ts +10 -0
  264. package/dist/types/src/types/Settings.d.ts.map +1 -0
  265. package/dist/types/src/types/index.d.ts +4 -0
  266. package/dist/types/src/types/index.d.ts.map +1 -1
  267. package/dist/types/src/types/schema.d.ts +64 -64
  268. package/dist/types/src/types/schema.d.ts.map +1 -1
  269. package/dist/types/src/util/index.d.ts +2 -1
  270. package/dist/types/src/util/index.d.ts.map +1 -1
  271. package/dist/types/src/util/layoutAppliesTopbar.d.ts +1 -1
  272. package/dist/types/src/util/layoutAppliesTopbar.d.ts.map +1 -1
  273. package/dist/types/src/util/plank-url-params.d.ts +14 -0
  274. package/dist/types/src/util/plank-url-params.d.ts.map +1 -0
  275. package/dist/types/src/util/plank-url-params.test.d.ts +2 -0
  276. package/dist/types/src/util/plank-url-params.test.d.ts.map +1 -0
  277. package/dist/types/src/util/sanitize-persisted-state.d.ts +19 -0
  278. package/dist/types/src/util/sanitize-persisted-state.d.ts.map +1 -0
  279. package/dist/types/src/util/sanitize-persisted-state.test.d.ts +2 -0
  280. package/dist/types/src/util/sanitize-persisted-state.test.d.ts.map +1 -0
  281. package/dist/types/src/util/set-active.d.ts +19 -4
  282. package/dist/types/src/util/set-active.d.ts.map +1 -1
  283. package/dist/types/src/util/set-active.test.d.ts +2 -0
  284. package/dist/types/src/util/set-active.test.d.ts.map +1 -0
  285. package/dist/types/tsconfig.tsbuildinfo +1 -1
  286. package/package.json +130 -61
  287. package/src/DeckPlugin.node.ts +17 -0
  288. package/src/DeckPlugin.test.ts +27 -0
  289. package/src/DeckPlugin.ts +32 -56
  290. package/src/DeckPlugin.workerd.ts +16 -0
  291. package/src/capabilities/app-graph-builder.ts +111 -127
  292. package/src/capabilities/check-app-scheme.ts +123 -24
  293. package/src/capabilities/index.ts +13 -14
  294. package/src/capabilities/operation-handler.ts +16 -0
  295. package/src/capabilities/react-root.tsx +37 -30
  296. package/src/capabilities/react-surface.tsx +28 -22
  297. package/src/capabilities/settings.ts +29 -20
  298. package/src/capabilities/state.ts +74 -96
  299. package/src/capabilities/tools.ts +57 -50
  300. package/src/capabilities/url-handler.ts +221 -50
  301. package/src/components/DeckSettings/DeckSettings.stories.tsx +37 -0
  302. package/src/components/DeckSettings/DeckSettings.tsx +19 -88
  303. package/src/components/DeckSettings/index.ts +2 -2
  304. package/src/components/Matrix/Matrix.stories.tsx +220 -0
  305. package/src/components/Matrix/Matrix.tsx +205 -0
  306. package/src/components/Matrix/SPEC.md +219 -0
  307. package/src/components/Matrix/index.ts +6 -0
  308. package/src/components/index.ts +6 -3
  309. package/src/containers/Deck/Banner.tsx +41 -0
  310. package/src/containers/Deck/Deck.stories.tsx +81 -0
  311. package/src/containers/Deck/Deck.tsx +21 -0
  312. package/src/containers/Deck/DeckContent.tsx +102 -0
  313. package/src/containers/Deck/DeckRoot.tsx +50 -0
  314. package/src/containers/Deck/DeckViewport.tsx +450 -0
  315. package/src/{components/DeckLayout → containers/Deck}/StatusBar.tsx +4 -4
  316. package/src/containers/Deck/index.ts +5 -0
  317. package/src/{components → containers}/DeckLayout/ActiveNode.tsx +9 -4
  318. package/src/containers/DeckLayout/DeckLayout.stories.tsx +395 -0
  319. package/src/containers/DeckLayout/DeckLayout.tsx +62 -0
  320. package/src/containers/DeckLayout/Dialog.tsx +52 -0
  321. package/src/containers/DeckLayout/Fallback.tsx +24 -0
  322. package/src/containers/DeckLayout/Popover.tsx +162 -0
  323. package/src/{components → containers}/DeckLayout/Toast.tsx +5 -5
  324. package/src/{components → containers}/DeckLayout/constants.ts +1 -0
  325. package/src/{components → containers}/DeckLayout/index.ts +3 -2
  326. package/src/containers/Plank/Plank.stories.tsx +108 -0
  327. package/src/containers/Plank/Plank.tsx +22 -0
  328. package/src/containers/Plank/PlankComponent.tsx +218 -0
  329. package/src/containers/Plank/PlankContent.tsx +45 -0
  330. package/src/{components → containers}/Plank/PlankControls.tsx +43 -37
  331. package/src/containers/Plank/PlankError.tsx +82 -0
  332. package/src/{components → containers}/Plank/PlankHeading.tsx +67 -64
  333. package/src/{components → containers}/Plank/PlankLoading.tsx +1 -1
  334. package/src/containers/Plank/PlankRoot.tsx +49 -0
  335. package/src/{components → containers}/Plank/index.ts +0 -2
  336. package/src/containers/Sidebar/ComplementarySidebar.tsx +192 -0
  337. package/src/containers/Sidebar/Sidebar.tsx +39 -0
  338. package/src/containers/Sidebar/SidebarButton.tsx +100 -0
  339. package/src/containers/index.ts +11 -0
  340. package/src/hooks/index.ts +2 -1
  341. package/src/hooks/useCompanions.ts +3 -3
  342. package/src/hooks/useDeckCompanions.ts +8 -11
  343. package/src/hooks/useDeckState.ts +73 -0
  344. package/src/hooks/useMainSize.ts +2 -2
  345. package/src/hooks/useNodeActionExpander.ts +4 -4
  346. package/src/hooks/useSelectedCompanion.ts +32 -0
  347. package/src/index.ts +1 -4
  348. package/src/layout.test.ts +59 -0
  349. package/src/layout.ts +38 -40
  350. package/src/meta.ts +22 -5
  351. package/src/operations/add-toast.ts +24 -0
  352. package/src/operations/adjust.ts +82 -0
  353. package/src/operations/close.ts +35 -0
  354. package/src/operations/helpers.ts +22 -0
  355. package/src/operations/index.ts +24 -0
  356. package/src/operations/open.ts +186 -0
  357. package/src/operations/revert-workspace.ts +22 -0
  358. package/src/operations/scroll-into-view.ts +24 -0
  359. package/src/operations/set-layout-mode.ts +84 -0
  360. package/src/operations/set.ts +36 -0
  361. package/src/operations/show-undo.ts +47 -0
  362. package/src/operations/switch-workspace.ts +66 -0
  363. package/src/operations/update-companion.ts +35 -0
  364. package/src/operations/update-complementary.ts +33 -0
  365. package/src/operations/update-dialog.ts +34 -0
  366. package/src/operations/update-plank-size.ts +28 -0
  367. package/src/operations/update-popover.ts +36 -0
  368. package/src/operations/update-sidebar.ts +28 -0
  369. package/src/plugin.ts +11 -0
  370. package/src/translations.ts +43 -54
  371. package/src/types/DeckCapabilities.ts +34 -0
  372. package/src/types/DeckEvents.ts +21 -0
  373. package/src/types/DeckOperation.ts +53 -0
  374. package/src/types/Settings.ts +36 -0
  375. package/src/types/index.ts +5 -0
  376. package/src/types/schema.ts +49 -58
  377. package/src/util/index.ts +2 -1
  378. package/src/util/layoutAppliesTopbar.ts +2 -2
  379. package/src/util/plank-url-params.test.ts +85 -0
  380. package/src/util/plank-url-params.ts +36 -0
  381. package/src/util/sanitize-persisted-state.test.ts +79 -0
  382. package/src/util/sanitize-persisted-state.ts +52 -0
  383. package/src/util/set-active.test.ts +106 -0
  384. package/src/util/set-active.ts +50 -30
  385. package/src/vite-env.d.ts +5 -0
  386. package/dist/lib/browser/app-graph-builder-D74NTOMK.mjs +0 -128
  387. package/dist/lib/browser/app-graph-builder-D74NTOMK.mjs.map +0 -7
  388. package/dist/lib/browser/check-app-scheme-HIEVFAAX.mjs +0 -32
  389. package/dist/lib/browser/check-app-scheme-HIEVFAAX.mjs.map +0 -7
  390. package/dist/lib/browser/chunk-5KMJPIQC.mjs +0 -16
  391. package/dist/lib/browser/chunk-5KMJPIQC.mjs.map +0 -7
  392. package/dist/lib/browser/chunk-CNTGBCMK.mjs +0 -145
  393. package/dist/lib/browser/chunk-CNTGBCMK.mjs.map +0 -7
  394. package/dist/lib/browser/chunk-F3VCCHVL.mjs +0 -162
  395. package/dist/lib/browser/chunk-F3VCCHVL.mjs.map +0 -7
  396. package/dist/lib/browser/chunk-QKCGZ45E.mjs +0 -128
  397. package/dist/lib/browser/chunk-QKCGZ45E.mjs.map +0 -7
  398. package/dist/lib/browser/chunk-UXLU6CMW.mjs +0 -16
  399. package/dist/lib/browser/chunk-UXLU6CMW.mjs.map +0 -7
  400. package/dist/lib/browser/chunk-VBYJ664A.mjs +0 -132
  401. package/dist/lib/browser/chunk-VBYJ664A.mjs.map +0 -7
  402. package/dist/lib/browser/chunk-VUJ6UNIJ.mjs +0 -1553
  403. package/dist/lib/browser/chunk-VUJ6UNIJ.mjs.map +0 -7
  404. package/dist/lib/browser/index.mjs +0 -174
  405. package/dist/lib/browser/index.mjs.map +0 -7
  406. package/dist/lib/browser/intent-resolver-UA4YQGAC.mjs +0 -524
  407. package/dist/lib/browser/intent-resolver-UA4YQGAC.mjs.map +0 -7
  408. package/dist/lib/browser/meta.json +0 -1
  409. package/dist/lib/browser/react-root-JAMHKYWN.mjs +0 -44
  410. package/dist/lib/browser/react-root-JAMHKYWN.mjs.map +0 -7
  411. package/dist/lib/browser/react-surface-6LW337ZT.mjs +0 -40
  412. package/dist/lib/browser/react-surface-6LW337ZT.mjs.map +0 -7
  413. package/dist/lib/browser/settings-SDPTOCCM.mjs +0 -30
  414. package/dist/lib/browser/settings-SDPTOCCM.mjs.map +0 -7
  415. package/dist/lib/browser/state-7IFAGZQO.mjs +0 -12
  416. package/dist/lib/browser/toolkit-L5CFXJCF.mjs +0 -52
  417. package/dist/lib/browser/toolkit-L5CFXJCF.mjs.map +0 -7
  418. package/dist/lib/browser/types/index.mjs +0 -32
  419. package/dist/lib/browser/url-handler-QEYGYE2H.mjs +0 -70
  420. package/dist/lib/browser/url-handler-QEYGYE2H.mjs.map +0 -7
  421. package/dist/types/src/capabilities/capabilities.d.ts +0 -184
  422. package/dist/types/src/capabilities/capabilities.d.ts.map +0 -1
  423. package/dist/types/src/capabilities/intent-resolver.d.ts +0 -4
  424. package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
  425. package/dist/types/src/capabilities/toolkit.d.ts +0 -25
  426. package/dist/types/src/capabilities/toolkit.d.ts.map +0 -1
  427. package/dist/types/src/components/DeckLayout/ActiveNode.d.ts.map +0 -1
  428. package/dist/types/src/components/DeckLayout/Banner.d.ts.map +0 -1
  429. package/dist/types/src/components/DeckLayout/ContentEmpty.d.ts +0 -3
  430. package/dist/types/src/components/DeckLayout/ContentEmpty.d.ts.map +0 -1
  431. package/dist/types/src/components/DeckLayout/DeckLayout.d.ts.map +0 -1
  432. package/dist/types/src/components/DeckLayout/DeckLayout.stories.d.ts +0 -74
  433. package/dist/types/src/components/DeckLayout/DeckLayout.stories.d.ts.map +0 -1
  434. package/dist/types/src/components/DeckLayout/DeckMain.d.ts +0 -3
  435. package/dist/types/src/components/DeckLayout/DeckMain.d.ts.map +0 -1
  436. package/dist/types/src/components/DeckLayout/Dialog.d.ts.map +0 -1
  437. package/dist/types/src/components/DeckLayout/Fallback.d.ts +0 -3
  438. package/dist/types/src/components/DeckLayout/Fallback.d.ts.map +0 -1
  439. package/dist/types/src/components/DeckLayout/Popover.d.ts +0 -5
  440. package/dist/types/src/components/DeckLayout/Popover.d.ts.map +0 -1
  441. package/dist/types/src/components/DeckLayout/StatusBar.d.ts.map +0 -1
  442. package/dist/types/src/components/DeckLayout/Toast.d.ts.map +0 -1
  443. package/dist/types/src/components/DeckLayout/Topbar.d.ts +0 -3
  444. package/dist/types/src/components/DeckLayout/Topbar.d.ts.map +0 -1
  445. package/dist/types/src/components/DeckLayout/constants.d.ts.map +0 -1
  446. package/dist/types/src/components/DeckLayout/index.d.ts +0 -4
  447. package/dist/types/src/components/DeckLayout/index.d.ts.map +0 -1
  448. package/dist/types/src/components/Plank/Plank.d.ts +0 -27
  449. package/dist/types/src/components/Plank/Plank.d.ts.map +0 -1
  450. package/dist/types/src/components/Plank/Plank.stories.d.ts +0 -89
  451. package/dist/types/src/components/Plank/Plank.stories.d.ts.map +0 -1
  452. package/dist/types/src/components/Plank/PlankControls.d.ts.map +0 -1
  453. package/dist/types/src/components/Plank/PlankError.d.ts +0 -13
  454. package/dist/types/src/components/Plank/PlankError.d.ts.map +0 -1
  455. package/dist/types/src/components/Plank/PlankHeading.d.ts.map +0 -1
  456. package/dist/types/src/components/Plank/index.d.ts +0 -6
  457. package/dist/types/src/components/Plank/index.d.ts.map +0 -1
  458. package/dist/types/src/components/Sidebar/ComplementarySidebar.d.ts.map +0 -1
  459. package/dist/types/src/components/Sidebar/Sidebar.d.ts.map +0 -1
  460. package/dist/types/src/components/Sidebar/SidebarButton.d.ts.map +0 -1
  461. package/dist/types/src/components/fragments.d.ts +0 -4
  462. package/dist/types/src/components/fragments.d.ts.map +0 -1
  463. package/dist/types/src/events.d.ts +0 -4
  464. package/dist/types/src/events.d.ts.map +0 -1
  465. package/dist/types/src/hooks/useHoistStatusbar.d.ts +0 -3
  466. package/dist/types/src/hooks/useHoistStatusbar.d.ts.map +0 -1
  467. package/dist/types/src/util/overscroll.d.ts +0 -47
  468. package/dist/types/src/util/overscroll.d.ts.map +0 -1
  469. package/src/capabilities/capabilities.ts +0 -14
  470. package/src/capabilities/intent-resolver.ts +0 -471
  471. package/src/capabilities/toolkit.ts +0 -66
  472. package/src/components/DeckLayout/Banner.tsx +0 -39
  473. package/src/components/DeckLayout/ContentEmpty.tsx +0 -31
  474. package/src/components/DeckLayout/DeckLayout.stories.tsx +0 -63
  475. package/src/components/DeckLayout/DeckLayout.tsx +0 -32
  476. package/src/components/DeckLayout/DeckMain.tsx +0 -281
  477. package/src/components/DeckLayout/Dialog.tsx +0 -36
  478. package/src/components/DeckLayout/Fallback.tsx +0 -28
  479. package/src/components/DeckLayout/Popover.tsx +0 -95
  480. package/src/components/DeckLayout/Topbar.tsx +0 -11
  481. package/src/components/Plank/Plank.stories.tsx +0 -54
  482. package/src/components/Plank/Plank.tsx +0 -299
  483. package/src/components/Plank/PlankError.tsx +0 -49
  484. package/src/components/Sidebar/ComplementarySidebar.tsx +0 -214
  485. package/src/components/Sidebar/Sidebar.tsx +0 -42
  486. package/src/components/Sidebar/SidebarButton.tsx +0 -88
  487. package/src/components/fragments.ts +0 -14
  488. package/src/events.ts +0 -11
  489. package/src/hooks/useHoistStatusbar.ts +0 -27
  490. package/src/util/overscroll.ts +0 -69
  491. /package/dist/lib/{browser/state-7IFAGZQO.mjs.map → neutral/check-app-scheme-A7FZVNZO.mjs.map} +0 -0
  492. /package/dist/lib/{browser/types/index.mjs.map → neutral/chunk-J5LGTIGS.mjs.map} +0 -0
  493. /package/dist/types/src/{components/DeckLayout → containers/Deck}/StatusBar.d.ts +0 -0
  494. /package/dist/types/src/{components → containers}/DeckLayout/ActiveNode.d.ts +0 -0
  495. /package/dist/types/src/{components → containers}/DeckLayout/DeckLayout.d.ts +0 -0
  496. /package/dist/types/src/{components → containers}/DeckLayout/Dialog.d.ts +0 -0
  497. /package/dist/types/src/{components → containers}/DeckLayout/constants.d.ts +0 -0
  498. /package/dist/types/src/{components → containers}/Plank/PlankLoading.d.ts +0 -0
  499. /package/dist/types/src/{components → containers}/Sidebar/ComplementarySidebar.d.ts +0 -0
  500. /package/dist/types/src/{components → containers}/Sidebar/Sidebar.d.ts +0 -0
  501. /package/dist/types/src/{components → containers}/Sidebar/index.d.ts +0 -0
  502. /package/src/{components → containers}/Sidebar/index.ts +0 -0
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/containers/Plank/PlankLoading.tsx", "../../../src/containers/Plank/PlankError.tsx", "../../../src/containers/Plank/PlankHeading.tsx", "../../../src/containers/Plank/PlankControls.tsx", "../../../src/containers/Plank/PlankRoot.tsx", "../../../src/containers/Plank/PlankComponent.tsx", "../../../src/containers/Plank/PlankContent.tsx", "../../../src/containers/Plank/Plank.tsx", "../../../src/containers/Sidebar/SidebarButton.tsx", "../../../src/containers/Sidebar/ComplementarySidebar.tsx", "../../../src/containers/Sidebar/Sidebar.tsx", "../../../src/containers/Deck/DeckContent.tsx", "../../../src/containers/Deck/Banner.tsx", "../../../src/containers/Deck/DeckRoot.tsx", "../../../src/containers/Deck/DeckViewport.tsx", "../../../src/containers/Deck/Deck.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport React from 'react';\n\n// TODO(burdon): Show skeleton: https://github.com/dxos/dxos/issues/8259\nexport const PlankLoading = () => {\n return <div className='grid place-items-center dx-attention-surface' />;\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { useEffect, useMemo, useState } from 'react';\n\nimport { TimeoutError } from '@dxos/errors';\nimport { log } from '@dxos/log';\nimport { type Node } from '@dxos/plugin-graph';\nimport { ErrorFallback, type ErrorFallbackProps, useTranslation } from '@dxos/react-ui';\nimport { descriptionMessage, mx } from '@dxos/ui-theme';\n\nimport { meta } from '#meta';\n\nimport { PlankHeading, type PlankHeadingProps } from './PlankHeading';\nimport { PlankLoading } from './PlankLoading';\n\nexport const PlankError = ({\n id,\n part,\n node,\n error: errorProp,\n}: {\n id: string;\n part: PlankHeadingProps['part'];\n node?: Node.Node;\n error?: Error;\n}) => {\n const [timedOut, setTimedOut] = useState(false);\n useEffect(() => {\n const timer = setTimeout(() => setTimedOut(true), 5_000);\n return () => clearTimeout(timer);\n }, []);\n\n const error = useMemo(() => {\n if (timedOut) {\n return new TimeoutError({ message: 'Timeout loading content' });\n }\n\n return errorProp;\n }, [timedOut, errorProp]);\n\n return (\n <>\n <PlankHeading id={id} part={part} node={node} pending={!timedOut} />\n {timedOut ? <PlankErrorFallback error={error} /> : <PlankLoading />}\n </>\n );\n};\n\n/**\n * User facing error fallback.\n */\nexport const PlankErrorFallback = ({ error }: ErrorFallbackProps) => {\n const { t } = useTranslation(meta.id);\n\n useEffect(() => {\n if (error) {\n log.error('plank error', { error });\n }\n }, [error]);\n\n if (process.env.NODE_ENV === 'development') {\n return <ErrorFallback title='Plank Error' error={error} />;\n } else {\n const errorString = error?.toString() ?? '';\n\n return (\n <div\n role='alert'\n data-testid='plank-content-error'\n className='dx-attention-surface overflow-y-auto p-8 grid place-items-center'\n >\n <div className='flex flex-col items-center gap-2'>\n <p className={mx(descriptionMessage, 'break-all rounded-md p-4')}>\n {error ? errorString : t('error-fallback.message')}\n </p>\n </div>\n </div>\n );\n }\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { Fragment, type MouseEvent, memo, useCallback, useEffect, useMemo } from 'react';\n\nimport { Surface } from '@dxos/app-framework/ui';\nimport { AppSurface } from '@dxos/app-toolkit/ui';\nimport { Graph, type Node, useActionRunner } from '@dxos/plugin-graph';\nimport { Icon, IconButton, Popover, toLocalizedString, useTranslation } from '@dxos/react-ui';\nimport { getLinkedVariant } from '@dxos/react-ui-attention';\nimport { StackItem, type StackItemSigilAction } from '@dxos/react-ui-stack';\nimport { TextTooltip } from '@dxos/react-ui-text-tooltip';\nimport { hoverableControls, hoverableFocusedWithinControls, iconSize } from '@dxos/ui-theme';\n\nimport { useBreakpoints } from '#hooks';\nimport { meta } from '#meta';\nimport { DeckOperation } from '#types';\nimport { type LayoutMode, PLANK_COMPANION_TYPE, type ResolvedPart } from '#types';\n\nimport { PlankCompanionControls, PlankControls } from './PlankControls';\nimport { usePlankContext } from './PlankRoot';\n\nconst MAX_COMPANIONS = 5;\n\nexport type PlankHeadingProps = {\n id: string;\n part: ResolvedPart;\n layoutMode?: LayoutMode;\n node?: Node.Node;\n deckEnabled?: boolean;\n canIncrementStart?: boolean;\n canIncrementEnd?: boolean;\n popoverAnchorId?: string;\n primaryId?: string;\n pending?: boolean;\n companioned?: 'primary' | 'companion';\n companions?: Node.Node[];\n actions?: StackItemSigilAction[];\n debug?: boolean;\n};\n\nexport const PlankHeading = memo(\n ({\n id,\n part,\n node,\n deckEnabled,\n canIncrementStart,\n canIncrementEnd,\n popoverAnchorId,\n primaryId,\n pending,\n companioned,\n companions,\n layoutMode,\n actions = [],\n debug = false,\n }: PlankHeadingProps) => {\n const { t } = useTranslation(meta.id);\n const { graph, onAdjust, onUpdateCompanion } = usePlankContext('PlankHeading');\n const runAction = useActionRunner();\n const breakpoint = useBreakpoints();\n const icon = node?.properties?.icon ?? 'ph--circle-dashed--regular';\n const label = pending\n ? t('pending.heading')\n : toLocalizedString(node?.properties?.label ?? ['plank-heading-fallback.label', { ns: meta.id }], t);\n\n const isCompanionNode = node?.type === PLANK_COMPANION_TYPE;\n\n useEffect(() => {\n const frame = requestAnimationFrame(() => {\n // Load actions for the node.\n if (node) {\n void Graph.expand(graph, node.id, 'child');\n }\n });\n\n return () => cancelAnimationFrame(frame);\n }, [node]);\n\n const attendableId = primaryId ?? id;\n const capabilities = useMemo(\n () => ({\n deck: deckEnabled ?? true,\n solo: breakpoint !== 'mobile' && (part === 'solo' || part === 'multi'),\n incrementStart: canIncrementStart,\n incrementEnd: canIncrementEnd,\n fullscreen: !isCompanionNode,\n companion: layoutMode !== 'multi' && !isCompanionNode && companions && companions.length > 0,\n }),\n [breakpoint, part, companions, canIncrementStart, canIncrementEnd, isCompanionNode, deckEnabled, layoutMode],\n );\n\n const variant = isCompanionNode ? getLinkedVariant(id) : undefined;\n const sigilActions = useMemo(() => {\n if (!node) {\n return undefined;\n } else if (variant) {\n return [];\n } else {\n return [\n actions,\n Graph.getActions(graph, node.id).filter((action) =>\n ['list-item', 'list-item-primary', 'heading-list-item'].includes(action.properties.disposition),\n ),\n ].filter((a) => a.length > 0);\n }\n }, [actions, node, variant, graph]);\n\n const handleAction = useCallback(\n (action: StackItemSigilAction) => {\n if (typeof action.data === 'function') {\n void runAction(action as Node.Action, { parent: node, caller: meta.id });\n }\n },\n [node, runAction],\n );\n\n const handlePlankAction = useCallback(\n (eventType: DeckOperation.PartAdjustment) => {\n onAdjust?.(id, eventType);\n },\n [onAdjust, id],\n );\n\n const ActionRoot = node && popoverAnchorId === `${meta.id}:${node.id}` ? Popover.Anchor : Fragment;\n\n const handleTabClick = useCallback(\n (event: MouseEvent) => {\n const target = (event.target as HTMLElement).closest('[data-id]') as HTMLElement | null;\n const tabId = target?.dataset?.id;\n if (tabId) {\n onUpdateCompanion?.(tabId);\n }\n },\n [onUpdateCompanion],\n );\n\n return (\n <StackItem.Heading\n data-tauri-drag-region\n data-plank-heading\n style={iconSize(5)}\n classNames={[\n 'py-1 items-stretch gap-1 sticky left-12 dx-app-drag min-w-0 dx-contain-layout dx-density-lg',\n part === 'solo'\n ? 'ps-[calc(env(safe-area-inset-left)+.25rem)] pe-[calc(env(safe-area-inset-right)+.25rem)]'\n : 'px-1',\n ...(layoutMode === 'solo--fullscreen'\n ? [\n hoverableControls,\n hoverableFocusedWithinControls,\n '*:transition-opacity *:opacity-(--controls-opacity) bg-transparent',\n 'border-transparent transition-[background-color,border-color]',\n 'hover-hover:hover:bg-header-surface focus-within:bg-header-surface',\n 'hover-hover:hover:border-subdued-separator focus-within:border-subdued-separator',\n ]\n : []),\n ]}\n >\n {companions && isCompanionNode ? (\n /* TODO(thure): IMPORTANT: This is a tablist; it should be implemented as such. */\n <div data-tauri-drag-region className='flex-1 min-w-0 overflow-x-auto scrollbar-none flex gap-1'>\n {companions.map(({ id, properties: { icon, label } }) => (\n <IconButton\n key={id}\n data-id={id}\n icon={icon}\n iconOnly={companions.length > MAX_COMPANIONS && node?.id !== id}\n label={toLocalizedString(label, t)}\n variant={node?.id === id ? 'primary' : 'ghost'}\n onClick={handleTabClick}\n />\n ))}\n </div>\n ) : (\n <>\n <ActionRoot>\n {node && sigilActions ? (\n <StackItem.Sigil\n icon={icon}\n related={part === 'complementary'}\n attendableId={attendableId}\n triggerLabel={t('actions-menu.label')}\n actions={sigilActions}\n onAction={handleAction}\n >\n <Surface.Surface\n type={AppSurface.MenuFooter}\n data={{ subject: node.data } satisfies AppSurface.MenuFooterData}\n />\n </StackItem.Sigil>\n ) : (\n <StackItem.SigilButton>\n <span className='sr-only'>{label}</span>\n <Icon icon={icon} />\n </StackItem.SigilButton>\n )}\n </ActionRoot>\n <TextTooltip text={label} onlyWhenTruncating>\n <StackItem.HeadingLabel\n data-tauri-drag-region\n attendableId={attendableId}\n related={part === 'complementary'}\n {...(pending && { classNames: 'text-description' })}\n >\n {label}\n </StackItem.HeadingLabel>\n </TextTooltip>\n </>\n )}\n {debug && (\n <div className='flex items-center text-sm text-info-text'>\n {layoutMode}:{part}:{companioned}\n </div>\n )}\n {node && part !== 'complementary' && (\n <Surface.Surface\n type={AppSurface.NavbarEnd}\n data={{ subject: node.data } satisfies AppSurface.NavbarEndData}\n />\n )}\n {companioned === 'companion' ? (\n <PlankCompanionControls primary={primaryId} />\n ) : (\n <PlankControls\n capabilities={capabilities}\n layoutMode={layoutMode}\n close={part === 'complementary' ? 'minify-end' : true}\n onClick={handlePlankAction}\n />\n )}\n </StackItem.Heading>\n );\n },\n);\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { forwardRef, useCallback } from 'react';\n\nimport { useOperationInvoker } from '@dxos/app-framework/ui';\nimport { LayoutOperation } from '@dxos/app-toolkit';\nimport { ButtonGroup, type ButtonGroupProps, type ButtonProps, IconButton, useTranslation } from '@dxos/react-ui';\n\nimport { meta } from '#meta';\nimport { type DeckAction, type LayoutMode } from '#types';\n\nexport type PlankControlHandler = (event: DeckAction.PartAdjustment) => void;\n\nexport type PlankCapabilities = {\n incrementStart?: boolean;\n incrementEnd?: boolean;\n deck?: boolean;\n solo?: boolean;\n fullscreen?: boolean;\n companion?: boolean;\n};\n\n//\n// Controls\n//\n\nconst plankControlSpacing = 'px-2';\n\nexport type PlankCompanionControlsProps = {\n primary?: string;\n};\n\nexport const PlankCompanionControls = forwardRef<HTMLDivElement, PlankCompanionControlsProps>(\n ({ primary }, forwardedRef) => {\n const { t } = useTranslation(meta.id);\n const { invokePromise } = useOperationInvoker();\n const handleCloseCompanion = useCallback(() => {\n return invokePromise(LayoutOperation.UpdateCompanion, { subject: null });\n }, [invokePromise]);\n return (\n <div ref={forwardedRef} className='contents dx-app-no-drag'>\n <PlankControl\n label={t('close-companion.label')}\n variant='ghost'\n icon='ph--x--regular'\n onClick={handleCloseCompanion}\n classNames={plankControlSpacing}\n />\n </div>\n );\n },\n);\n\nconst PlankControl = ({ icon, label, ...props }: Omit<ButtonProps, 'children'> & { label: string; icon: string }) => {\n return <IconButton label={label} icon={icon} iconOnly variant='ghost' tooltipSide='bottom' {...props} />;\n};\n\n//\n// PlankControls\n//\n\nexport type PlankControlsProps = Omit<ButtonGroupProps, 'onClick'> & {\n onClick?: PlankControlHandler;\n variant?: 'hide-disabled' | 'default';\n close?: boolean | 'minify-start' | 'minify-end';\n capabilities: PlankCapabilities;\n layoutMode?: LayoutMode;\n pin?: 'start' | 'end' | 'both';\n};\n\n// TODO(wittjosiah): Duplicate of stack LayoutControls?\n// Translations were to be duplicated between packages.\n// NOTE(thure): Pinning & unpinning are disabled indefinitely.\nexport const PlankControls = forwardRef<HTMLDivElement, PlankControlsProps>(\n (\n { children, classNames, variant = 'default', capabilities, layoutMode, pin, close = false, onClick, ...props },\n forwardedRef,\n ) => {\n const { t } = useTranslation(meta.id);\n const buttonClassNames =\n variant === 'hide-disabled' ? `disabled:hidden ${plankControlSpacing}` : plankControlSpacing;\n\n const layoutIsAnySolo = !!layoutMode?.startsWith('solo');\n\n return (\n <ButtonGroup {...props} classNames={['dx-app-no-drag opacity-100!', classNames]} ref={forwardedRef}>\n {capabilities.deck ? (\n <>\n {capabilities.solo && (\n <>\n {layoutMode === 'solo' && (\n <PlankControl\n label={t('show-fullscreen-plank.label')}\n classNames={buttonClassNames}\n icon='ph--corners-out--regular'\n onClick={() => onClick?.('solo--fullscreen')}\n />\n )}\n <PlankControl\n label={t(\n layoutMode === 'solo--fullscreen'\n ? 'exit-fullscreen.label'\n : layoutIsAnySolo\n ? 'show-deck-plank.label'\n : 'show-solo-plank.label',\n )}\n classNames={buttonClassNames}\n icon={\n layoutMode === 'solo--fullscreen'\n ? 'ph--corners-in--regular'\n : layoutIsAnySolo\n ? 'ph--arrows-in-line-horizontal--regular'\n : 'ph--arrows-out-line-horizontal--regular'\n }\n onClick={() => onClick?.(layoutMode === 'solo--fullscreen' ? 'solo--fullscreen' : 'solo')}\n />\n </>\n )}\n\n {!layoutIsAnySolo && layoutMode !== 'multi' && (\n <>\n <PlankControl\n label={t('increment-start.label')}\n disabled={!capabilities.incrementStart}\n classNames={buttonClassNames}\n icon='ph--caret-left--regular'\n onClick={() => onClick?.('increment-start')}\n />\n <PlankControl\n label={t('increment-end.label')}\n disabled={!capabilities.incrementEnd}\n classNames={buttonClassNames}\n icon='ph--caret-right--regular'\n onClick={() => onClick?.('increment-end')}\n />\n </>\n )}\n </>\n ) : (\n capabilities.fullscreen && (\n <PlankControl\n label={t(layoutMode === 'solo--fullscreen' ? 'exit-fullscreen.label' : 'show-fullscreen-plank.label')}\n classNames={buttonClassNames}\n icon={layoutMode === 'solo--fullscreen' ? 'ph--corners-in--regular' : 'ph--corners-out--regular'}\n onClick={() => onClick?.('solo--fullscreen')}\n />\n )\n )}\n\n {close && !layoutIsAnySolo && (\n <PlankControl\n label={t(`${typeof close === 'string' ? 'minify' : 'close'}.label`)}\n classNames={buttonClassNames}\n data-testid='plankHeading.close'\n icon={\n close === 'minify-start'\n ? 'ph--caret-line-left--regular'\n : close === 'minify-end'\n ? 'ph--caret-line-right--regular'\n : 'ph--x--regular'\n }\n onClick={() => onClick?.('close')}\n />\n )}\n\n {capabilities.companion && (\n <PlankControl\n label={t('open-companion.label')}\n classNames={buttonClassNames}\n data-testid='plankHeading.companion'\n icon='ph--square-split-horizontal--regular'\n onClick={() => onClick?.('companion')}\n />\n )}\n {children}\n </ButtonGroup>\n );\n },\n);\n", "//\n// Copyright 2026 DXOS.org\n//\n\nimport { createContext } from '@radix-ui/react-context';\nimport React, { PropsWithChildren } from 'react';\n\nimport { type Graph } from '@dxos/plugin-graph';\n\nimport { type DeckOperation } from '#types';\nimport { type LayoutMode, type PlankSizing, type ResolvedPart, type Settings } from '#types';\n\nconst PLANK_NAME = 'Plank';\n\nexport type PlankContextValue = {\n /** The application graph. */\n graph: Graph.ExpandableGraph;\n /** Which part of the layout this plank occupies. */\n part: ResolvedPart;\n /** Current layout mode. */\n layoutMode: LayoutMode;\n /** Deck settings. */\n settings?: Settings.Settings;\n /** Popover anchor ID for heading menus. */\n popoverAnchorId?: string;\n /** ID of plank that should be scrolled into view. */\n scrollIntoView?: string;\n /** Persisted plank sizes keyed by plank ID. */\n plankSizing?: PlankSizing;\n /** Callback for plank adjustments (close, solo, increment, companion). */\n onAdjust?: (id: string, type: DeckOperation.PartAdjustment) => void;\n /** Callback for plank resize. */\n onResize?: (id: string, size: number) => void;\n /** Callback to clear scroll-into-view state. */\n onScrollIntoView?: (id?: string) => void;\n /** Callback to update the companion. */\n onUpdateCompanion?: (companion: string | null) => void;\n};\n\nexport const [PlankProvider, usePlankContext] = createContext<PlankContextValue>(PLANK_NAME);\n\nexport type PlankRootProps = PropsWithChildren<PlankContextValue>;\n\n/**\n * Headless root that provides plank context.\n */\nexport const PlankRoot = ({ children, ...context }: PlankRootProps) => {\n return <PlankProvider {...context}>{children}</PlankProvider>;\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { useFocusFinders } from '@fluentui/react-tabster';\nimport React, { type KeyboardEvent, memo, useCallback, useLayoutEffect, useMemo, useRef } from 'react';\n\nimport { Surface } from '@dxos/app-framework/ui';\nimport { AppSurface } from '@dxos/app-toolkit/ui';\nimport { debounce } from '@dxos/async';\nimport { type Node } from '@dxos/plugin-graph';\nimport { mainIntrinsicSize } from '@dxos/react-ui';\nimport { getLinkedVariant } from '@dxos/react-ui-attention';\nimport { useAttentionAttributes } from '@dxos/react-ui-attention';\nimport { StackItem, type StackItemSize, railGridHorizontal } from '@dxos/react-ui-stack';\nimport { mx } from '@dxos/ui-theme';\n\nimport { useMainSize } from '#hooks';\nimport { PLANK_COMPANION_TYPE } from '#types';\n\nimport { PlankError, PlankErrorFallback } from './PlankError';\nimport { PlankHeading } from './PlankHeading';\nimport { PlankLoading } from './PlankLoading';\nimport { PlankRootProps, usePlankContext } from './PlankRoot';\n\n/**\n * JS-based smooth scroll that won't be interrupted by MutationObserver or layout changes.\n */\nconst smoothScrollTo = (element: HTMLElement, target: number, duration: number) => {\n const start = element.scrollLeft;\n const distance = target - start;\n const startTime = performance.now();\n\n const step = (currentTime: number) => {\n const elapsed = currentTime - startTime;\n const progress = Math.min(elapsed / duration, 1);\n // Ease-out cubic.\n const eased = 1 - Math.pow(1 - progress, 3);\n element.scrollLeft = start + distance * eased;\n if (progress < 1) {\n requestAnimationFrame(step);\n }\n };\n\n requestAnimationFrame(step);\n};\n\n// NOTE: Calibrated to show PLANK + COMPANION on MBP 16\" screen.\nexport const DEFAULT_SIZE = 48 satisfies StackItemSize;\nexport const DEFAULT_COMPANION_SIZE = 35 satisfies StackItemSize;\n\nexport type PlankComponentProps = Pick<PlankRootProps, 'part'> & {\n id: string;\n path?: string[];\n order?: number;\n active?: string[];\n node?: Node.Node;\n primary?: Node.Node;\n companions?: Node.Node[];\n companioned?: 'primary' | 'companion';\n};\n\nexport const PlankComponent = memo(\n ({ part, id, path, order, active, node, primary, companions, companioned }: PlankComponentProps) => {\n const { layoutMode, settings, popoverAnchorId, scrollIntoView, plankSizing, onResize, onScrollIntoView } =\n usePlankContext('PlankComponent');\n\n const canResize = layoutMode === 'multi';\n const { findFirstFocusable } = useFocusFinders();\n const isCompanion = companioned === 'companion';\n const attentionAttrs = useAttentionAttributes(primary?.id ?? id);\n const orderId = isCompanion ? primary?.id : id;\n const index = orderId && active ? active.findIndex((entryId) => entryId === orderId) : -1;\n const length = active?.length ?? 1;\n const isOrdered = !!active && index >= 0;\n const canIncrementStart = isOrdered && index > 0;\n const canIncrementEnd = isOrdered && index < length - 1;\n const rootElement = useRef<HTMLDivElement | null>(null);\n const variant = node?.type === PLANK_COMPANION_TYPE ? getLinkedVariant(id) : undefined;\n\n // Sizing.\n const sizeAttrs = useMainSize();\n const sizeKey = id.split('+')[0];\n const size = isCompanion\n ? DEFAULT_COMPANION_SIZE\n : ((plankSizing?.[sizeKey] as number | undefined) ?? DEFAULT_SIZE);\n const handleSizeChange = useCallback(\n debounce((nextSize: number) => {\n const size = Math.round(nextSize);\n onResize?.(sizeKey, size);\n }, 200),\n [sizeKey, onResize],\n );\n\n // TODO(thure): Tabster's focus group should handle moving focus to Main, but something is blocking it.\n const handleKeyDown = useCallback((event: KeyboardEvent) => {\n if (event.target === event.currentTarget) {\n switch (event.key) {\n case 'Escape':\n rootElement.current?.closest('main')?.focus();\n break;\n case 'Enter':\n rootElement.current && findFirstFocusable(rootElement.current)?.focus();\n break;\n }\n }\n }, []);\n\n useLayoutEffect(() => {\n if (scrollIntoView === id && layoutMode === 'multi' && rootElement.current) {\n const element = rootElement.current;\n const scrollParent = element.closest('[style*=\"overflow\"], .overflow-x-auto') as HTMLElement | null;\n if (scrollParent) {\n const elementRect = element.getBoundingClientRect();\n const parentRect = scrollParent.getBoundingClientRect();\n const targetScrollLeft = scrollParent.scrollLeft + (elementRect.left - parentRect.left);\n\n smoothScrollTo(scrollParent, targetScrollLeft, 300);\n }\n\n onScrollIntoView?.(undefined);\n }\n }, [id, scrollIntoView, layoutMode, onScrollIntoView]);\n\n const isSolo = layoutMode.startsWith('solo') && part === 'solo';\n const isAttendable =\n (layoutMode.startsWith('solo') && part.startsWith('solo')) || (layoutMode === 'multi' && part === 'multi');\n\n const data = useMemo<AppSurface.ArticleData | undefined>(\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 fullscreen = layoutMode === 'solo--fullscreen';\n const classNames = [\n 'dx-attention-surface relative dx-focus-ring-inset-over-all dx-density-lg',\n isSolo && 'absolute inset-0',\n isSolo && mainIntrinsicSize,\n railGridHorizontal,\n part.startsWith('solo') && 'grid',\n part.startsWith('solo-') && 'grid-rows-subgrid row-span-2 min-w-0',\n fullscreen && 'grid-rows-1',\n part === 'multi' && (isCompanion ? 'border-separator! border-e' : 'border-separator! border-x'),\n part === 'solo-companion' && 'border-separator! border-s',\n settings?.encapsulatedPlanks &&\n !part.startsWith('solo') &&\n 'mx-(--main-spacing) border-separator! border rounded-sm overflow-hidden',\n ];\n\n return (\n <Root\n ref={rootElement}\n data-testid='deck.plank'\n data-popover-collision-boundary={true}\n tabIndex={0}\n {...(part.startsWith('solo')\n ? ({\n className: mx(classNames),\n ...sizeAttrs,\n } as any)\n : {\n role: 'article',\n item: { id },\n classNames,\n order,\n size,\n onSizeChange: handleSizeChange,\n })}\n {...(isAttendable ? attentionAttrs : {})}\n onKeyDown={handleKeyDown}\n >\n {node ? (\n <>\n {!fullscreen && (\n <PlankHeading\n id={id}\n part={part.startsWith('solo-') ? 'solo' : part}\n node={node}\n layoutMode={layoutMode}\n deckEnabled={settings?.enableDeck}\n canIncrementStart={canIncrementStart}\n canIncrementEnd={canIncrementEnd}\n popoverAnchorId={popoverAnchorId}\n primaryId={primary?.id}\n companioned={companioned}\n companions={companions}\n />\n )}\n <Surface.Surface\n key={node.id}\n type={AppSurface.Article}\n data={data}\n limit={1}\n fallback={PlankErrorFallback}\n placeholder={placeholder}\n />\n </>\n ) : (\n <PlankError id={id} part={part} />\n )}\n {canResize && <StackItem.ResizeHandle />}\n </Root>\n );\n },\n);\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { type PropsWithChildren } from 'react';\n\nimport { composable, composableProps, mainIntrinsicSize } from '@dxos/react-ui';\nimport { railGridHorizontal } from '@dxos/react-ui-stack';\n\nimport { useMainSize } from '#hooks';\n\nexport type PlankContentProps = PropsWithChildren<{\n solo: boolean;\n companion: boolean;\n encapsulate: boolean;\n}>;\n\nexport const PlankContent = composable<HTMLDivElement, PlankContentProps>(\n ({ children, solo, companion, encapsulate, ...props }, forwardedRef) => {\n const sizeAttrs = useMainSize();\n if (!solo) {\n return children;\n }\n\n return (\n <div\n {...sizeAttrs}\n {...composableProps(props, {\n role: 'none',\n classNames: [\n 'absolute inset-(--main-spacing) grid',\n railGridHorizontal,\n mainIntrinsicSize,\n companion && 'grid-cols-[6fr_4fr]', // Ration of primary to companion.\n encapsulate && 'border border-separator rounded-sm overflow-hidden',\n ],\n })}\n data-popover-collision-boundary={true}\n ref={forwardedRef}\n >\n {children}\n </div>\n );\n },\n);\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { PlankComponent, PlankComponentProps } from './PlankComponent';\nimport { PlankContent, PlankContentProps } from './PlankContent';\nimport { PlankControls } from './PlankControls';\nimport { PlankHeading } from './PlankHeading';\nimport { PlankRoot, PlankRootProps } from './PlankRoot';\n\n/**\n * Radix-style composite Plank component.\n */\nexport const Plank = {\n Root: PlankRoot,\n Content: PlankContent,\n Component: PlankComponent,\n Heading: PlankHeading,\n Controls: PlankControls,\n};\n\nexport type { PlankRootProps, PlankComponentProps, PlankContentProps };\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useCallback } from 'react';\n\nimport { useOperationInvoker } from '@dxos/app-framework/ui';\nimport { LayoutOperation } from '@dxos/app-toolkit';\nimport { IconButton, type IconButtonProps, type ThemedClassName, useTranslation } from '@dxos/react-ui';\nimport { getLinkedVariant } from '@dxos/react-ui-attention';\n\nimport { useDeckCompanions, useDeckState } from '#hooks';\nimport { meta } from '#meta';\n\nexport const ToggleSidebarButton = ({\n classNames,\n variant = 'ghost',\n}: ThemedClassName<Pick<IconButtonProps, 'variant'>>) => {\n const { updateState } = useDeckState();\n const { t } = useTranslation(meta.id);\n\n const handleClick = useCallback(() => {\n updateState((state) => ({\n ...state,\n sidebarState: state.sidebarState === 'expanded' ? 'collapsed' : 'expanded',\n }));\n }, [updateState]);\n\n return (\n <IconButton\n variant={variant}\n icon='ph--sidebar--regular'\n iconOnly\n size={4}\n label={t('open-navigation-sidebar.label')}\n onClick={handleClick}\n classNames={classNames}\n />\n );\n};\n\nexport const CloseSidebarButton = () => {\n const { updateState } = useDeckState();\n const { t } = useTranslation(meta.id);\n\n const handleClick = useCallback(() => {\n updateState((state) => ({ ...state, sidebarState: 'collapsed' }));\n }, [updateState]);\n\n return (\n <IconButton\n variant='ghost'\n icon='ph--caret-line-left--regular'\n iconOnly\n size={4}\n label={t('close-navigation-sidebar.button')}\n onClick={handleClick}\n classNames='rounded-none px-1 dx-focus-ring-inset pe-[max(.5rem,env(safe-area-inset-left))]'\n />\n );\n};\n\nexport const ToggleComplementarySidebarButton = ({\n inR0,\n classNames,\n current,\n}: ThemedClassName<{ inR0?: boolean; current?: string }>) => {\n const { invokePromise } = useOperationInvoker();\n const { state, updateState } = useDeckState();\n const { t } = useTranslation(meta.id);\n\n const companions = useDeckCompanions();\n const handleClick = useCallback(() => {\n const nextState = state.complementarySidebarState === 'expanded' ? 'collapsed' : 'expanded';\n updateState((state) => ({ ...state, complementarySidebarState: nextState }));\n\n const subject = state.complementarySidebarPanel ?? (companions[0] && getLinkedVariant(companions[0].id));\n if (nextState === 'expanded' && !current && subject) {\n void invokePromise(LayoutOperation.UpdateComplementary, { subject });\n }\n }, [state, updateState, current, companions, invokePromise]);\n\n const label = t(\n state.complementarySidebarState === 'expanded'\n ? 'close-complementary-sidebar.label'\n : 'open-complementary-sidebar.label',\n );\n\n return (\n <IconButton\n variant='ghost'\n classNames={['[&>svg]:-scale-x-100', classNames]}\n icon='ph--sidebar-simple--regular'\n iconOnly\n label={label}\n tooltipSide={inR0 ? 'left' : undefined}\n onClick={handleClick}\n />\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { type MouseEvent, useCallback, useEffect, useMemo, useState } from 'react';\n\nimport { Surface, useOperationInvoker } from '@dxos/app-framework/ui';\nimport { LayoutOperation } from '@dxos/app-toolkit';\nimport { IconButton, type Label, Main, Panel, toLocalizedString, Toolbar, useTranslation } from '@dxos/react-ui';\nimport { getLinkedVariant } from '@dxos/react-ui-attention';\nimport { Tabs } from '@dxos/react-ui-tabs';\nimport { iconSize, mx } from '@dxos/ui-theme';\n\nimport { type DeckCompanion, useBreakpoints, useDeckCompanions, useDeckState } from '#hooks';\nimport { meta } from '#meta';\nimport { getMode } from '#types';\n\nimport { layoutAppliesTopbar } from '../../util';\nimport { PlankErrorFallback, PlankLoading } from '../Plank';\nimport { ToggleComplementarySidebarButton } from './SidebarButton';\n\nconst label = ['complementary-sidebar.title', { ns: meta.id }] satisfies Label;\n\nexport type ComplementarySidebarProps = {\n current?: string;\n};\n\nexport const ComplementarySidebar = ({ current }: ComplementarySidebarProps) => {\n const { invokePromise } = useOperationInvoker();\n const { t } = useTranslation(meta.id);\n const { state, deck, updateState } = useDeckState();\n const layoutMode = getMode(deck);\n const breakpoint = useBreakpoints();\n const topbar = layoutAppliesTopbar(breakpoint, layoutMode);\n\n const companions = useDeckCompanions();\n const activeCompanion = companions.find((companion) => getLinkedVariant(companion.id) === current);\n const activeId = activeCompanion && getLinkedVariant(activeCompanion.id);\n const [internalValue, setInternalValue] = useState(activeId);\n\n useEffect(() => {\n setInternalValue(activeId);\n }, [activeId]);\n\n const handleTabClick = useCallback(\n (event: MouseEvent) => {\n const nextValue = event.currentTarget.getAttribute('data-value') as string;\n if (nextValue === activeId) {\n updateState((state) => ({\n ...state,\n complementarySidebarState: state.complementarySidebarState === 'expanded' ? 'collapsed' : 'expanded',\n }));\n } else {\n setInternalValue(nextValue);\n updateState((state) => ({ ...state, complementarySidebarState: 'expanded' }));\n void invokePromise(LayoutOperation.UpdateComplementary, { subject: nextValue });\n }\n },\n [state.complementarySidebarState, activeId, invokePromise, updateState],\n );\n\n const data = useMemo(\n () =>\n activeCompanion && {\n id: activeCompanion.id,\n subject: activeCompanion.data,\n },\n [activeCompanion?.id, activeCompanion?.data],\n );\n\n useEffect(() => {\n if (!activeId) {\n void invokePromise(LayoutOperation.UpdateComplementary, { state: 'collapsed' });\n }\n }, [activeId, invokePromise]);\n\n return (\n <Main.ComplementarySidebar\n label={label}\n classNames={[topbar && 'top-[calc(env(safe-area-inset-top)+var(--dx-rail-size))]']}\n >\n {/* R0 Tabs */}\n <Tabs.Root classNames='contents' orientation='vertical' value={internalValue}>\n <div\n data-tauri-drag-region\n style={iconSize(5)}\n className={mx(\n 'absolute z-1 inset-y-0 end-0 w-(--dx-r0-size)!',\n 'py-[env(safe-area-inset-top)] pb-[env(safe-area-inset-bottom)] border-s border-subdued-separator',\n 'grid grid-cols-1 grid-rows-[1fr_min-content] bg-toolbar-surface dx-contain-layout dx-app-drag',\n )}\n >\n {/* TODO(burdon): ScrollArea. */}\n <Tabs.Tablist classNames='grid grid-cols-1 auto-rows-(--dx-rail-action) overflow-y-auto gap-1 p-1'>\n {companions.map((companion) => (\n <Tabs.Tab key={getLinkedVariant(companion.id)} value={getLinkedVariant(companion.id)} asChild>\n <IconButton\n classNames='w-(--dx-rail-action) h-(--dx-rail-action) min-h-0 px-0'\n label={toLocalizedString(companion.properties.label, t)}\n icon={companion.properties.icon}\n iconOnly\n tooltipSide='left'\n data-value={getLinkedVariant(companion.id)}\n {...(companion.properties.joyride && { 'data-joyride': companion.properties.joyride })}\n variant={\n activeId === getLinkedVariant(companion.id)\n ? state.complementarySidebarState === 'expanded'\n ? 'primary'\n : 'ghost'\n : 'ghost'\n }\n onClick={handleTabClick}\n />\n </Tabs.Tab>\n ))}\n </Tabs.Tablist>\n <div\n className='grid grid-cols-1 auto-rows-(--dx-rail-item) py-0.5 gap-0.5 overflow-y-auto scrollbar-none'\n style={iconSize(4)}\n >\n <Surface.Surface role='status-indicator' />\n </div>\n <div className='hidden lg:grid grid-cols-1 auto-rows-(--dx-rail-action) p-1'>\n <ToggleComplementarySidebarButton />\n </div>\n </div>\n\n {/* R1 Content. */}\n {activeId &&\n companions.map((companion) => (\n <Tabs.Panel\n key={getLinkedVariant(companion.id)}\n value={getLinkedVariant(companion.id)}\n classNames={[\n 'absolute data-[state=\"inactive\"]:-z-[1] overflow-hidden',\n 'inset-y-0 start-0 w-full lg:w-(--dx-r1-size)',\n ]}\n {...(state.complementarySidebarState !== 'expanded' && { inert: true })}\n >\n <ComplementarySidebarPanel companion={companion} activeId={activeId} data={data} />\n </Tabs.Panel>\n ))}\n </Tabs.Root>\n </Main.ComplementarySidebar>\n );\n};\n\ntype ComplementarySidebarPanelProps = {\n companion: DeckCompanion;\n activeId: string;\n data?: {\n id: string;\n subject: any;\n };\n};\n\nconst ComplementarySidebarPanel = ({ companion, activeId, data }: ComplementarySidebarPanelProps) => {\n const { t } = useTranslation(meta.id);\n\n if (getLinkedVariant(companion.id) !== activeId && !data) {\n return null;\n }\n\n return (\n <Panel.Root>\n <Panel.Toolbar asChild size='lg'>\n <Toolbar.Root style={iconSize(5)} classNames='bg-modal-surface border-b border-subdued-separator'>\n <IconButton\n classNames='w-(--dx-rail-action) h-(--dx-rail-action) min-h-0 px-0'\n label={toLocalizedString(companion.properties.label, t)}\n icon={companion.properties.icon}\n iconOnly\n tooltipSide='left'\n data-value={getLinkedVariant(companion.id)}\n variant='default'\n />\n <div role='none' className='px-1'>\n {toLocalizedString(companion.properties.label, t)}\n </div>\n </Toolbar.Root>\n </Panel.Toolbar>\n <Panel.Content classNames='bg-base-surface'>\n <Surface.Surface\n role={`deck-companion--${getLinkedVariant(companion.id)}`}\n data={data}\n fallback={PlankErrorFallback}\n placeholder={<PlankLoading />}\n />\n </Panel.Content>\n </Panel.Root>\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { useMemo } from 'react';\n\nimport { Surface } from '@dxos/app-framework/ui';\nimport { AppSurface } from '@dxos/app-toolkit/ui';\nimport { type Label, Main } from '@dxos/react-ui';\n\nimport { useBreakpoints, useDeckState } from '#hooks';\nimport { meta } from '#meta';\nimport { getMode } from '#types';\n\nimport { layoutAppliesTopbar } from '../../util';\n\nconst label = ['sidebar.title', { ns: meta.id }] satisfies Label;\n\nexport const Sidebar = () => {\n const { state, deck } = useDeckState();\n const { popoverAnchorId, activeDeck: current } = state;\n const breakpoint = useBreakpoints();\n const layoutMode = getMode(deck);\n const topbar = layoutAppliesTopbar(breakpoint, layoutMode);\n\n const navigationData = useMemo<AppSurface.NavigationData<{ topbar: boolean }>>(\n () => ({ popoverAnchorId, topbar, current }),\n [popoverAnchorId, topbar, current],\n );\n\n return (\n <Main.NavigationSidebar\n label={label}\n classNames={['grid', topbar && 'top-[calc(env(safe-area-inset-top)+var(--dx-rail-size))]']}\n >\n <Surface.Surface type={AppSurface.Navigation} data={navigationData} limit={1} />\n </Main.NavigationSidebar>\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React, { type PropsWithChildren, useCallback, useEffect, useRef } from 'react';\n\nimport { AttentionCapabilities } from '@dxos/plugin-attention';\nimport { Main, useMediaQuery } from '@dxos/react-ui';\n\nimport { useBreakpoints } from '#hooks';\n\nimport { layoutAppliesTopbar } from '../../util';\nimport { ComplementarySidebar, Sidebar } from '../Sidebar';\nimport { Banner } from './Banner';\nimport { useDeckContext } from './DeckRoot';\n\nconst DECK_CONTENT_NAME = 'DeckContent';\n\nexport type DeckContentProps = PropsWithChildren;\n\nexport const DeckContent = ({ children }: DeckContentProps) => {\n const {\n state: { sidebarState, complementarySidebarState, complementarySidebarPanel },\n deck: { active, fullscreen, solo },\n updateState,\n layoutMode,\n settings,\n pluginManager,\n onLayoutChange,\n } = useDeckContext(DECK_CONTENT_NAME);\n const breakpoint = useBreakpoints();\n const topbar = layoutAppliesTopbar(breakpoint, layoutMode);\n\n // Ensure the first plank is attended when the deck is first rendered.\n useEffect(() => {\n // NOTE: Not `useAttended` so that the layout component is not re-rendered when the attended list changes.\n const attention = pluginManager.capabilities.get(AttentionCapabilities.Attention);\n const attended = attention.getCurrent();\n const firstId = solo ?? active[0];\n if (attended.length === 0 && firstId) {\n // TODO(wittjosiah): Focusing the type button is a workaround.\n // If the plank is directly focused on first load the focus ring appears.\n document.querySelector<HTMLElement>(`article[data-attendable-id=\"${firstId}\"] button`)?.focus();\n }\n }, []);\n\n // Not using `breakpoint` to avoid firing when breakpoint changes between tablet and desktop.\n // `ssr: false` to avoid using fallback values and flashing into solo mode on startup.\n const [isNotMobile] = useMediaQuery('md');\n const shouldRevert = useRef(false);\n useEffect(() => {\n if (!isNotMobile && layoutMode === 'multi') {\n // NOTE: Not `useAttended` so that the layout component is not re-rendered when the attended list changes.\n const attention = pluginManager.capabilities.get(AttentionCapabilities.Attention);\n const attended = attention.getCurrent();\n shouldRevert.current = true;\n onLayoutChange({ subject: attended[0], mode: 'solo' });\n } else if (isNotMobile && layoutMode === 'solo' && shouldRevert.current) {\n onLayoutChange({ revert: true });\n }\n // NOTE: Using `layoutMode` instead of `deck` to avoid infinite loops caused by object reference changes.\n }, [isNotMobile, layoutMode, onLayoutChange]);\n\n // When deck is disabled in settings, set to solo mode if the current layout mode is deck.\n // TODO(thure): Applying this as an effect should be avoided over emitting the operation only when the setting changes.\n useEffect(() => {\n if (!settings?.enableDeck && layoutMode === 'multi') {\n onLayoutChange({ subject: active[0], mode: 'solo' });\n }\n }, [settings?.enableDeck, onLayoutChange, active, layoutMode]);\n\n const handleNavigationSidebarStateChange = useCallback(\n (next: typeof sidebarState) => {\n updateState((s) => ({ ...s, sidebarState: next }));\n },\n [updateState],\n );\n\n const handleComplementarySidebarStateChange = useCallback(\n (next: typeof complementarySidebarState) => {\n updateState((s) => ({ ...s, complementarySidebarState: next }));\n },\n [updateState],\n );\n\n return (\n <Main.Root\n navigationSidebarState={fullscreen ? 'closed' : sidebarState}\n complementarySidebarState={fullscreen ? 'closed' : complementarySidebarState}\n onNavigationSidebarStateChange={handleNavigationSidebarStateChange}\n onComplementarySidebarStateChange={handleComplementarySidebarStateChange}\n >\n <Sidebar />\n <ComplementarySidebar current={complementarySidebarPanel} />\n <Main.Overlay />\n {children}\n {topbar && <Banner variant='topbar' />}\n </Main.Root>\n );\n};\n\nDeckContent.displayName = DECK_CONTENT_NAME;\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Surface } from '@dxos/app-framework/ui';\nimport { type ThemedClassName, useTranslation } from '@dxos/react-ui';\nimport { mx, osTranslations } from '@dxos/ui-theme';\n\nimport { meta } from '#meta';\n\nimport { CloseSidebarButton, ToggleSidebarButton } from '../Sidebar';\n\nexport const Banner = ({ variant, classNames }: ThemedClassName<{ variant?: 'topbar' | 'sidebar' }>) => {\n const { t } = useTranslation(meta.id);\n\n return (\n <header\n className={mx(\n 'flex items-stretch relative py-1 ps-1 pe-2',\n variant === 'topbar' &&\n 'fixed inset-x-0 top-[env(safe-area-inset-top)] h-(--dx-rail-size) border-b border-separator',\n classNames,\n )}\n >\n {variant === 'sidebar' ? <CloseSidebarButton /> : <ToggleSidebarButton />}\n <span className='self-center grow ms-1'>{t('current-app.name', { ns: osTranslations })}</span>\n {variant === 'topbar' && (\n <div className='absolute inset-0 pointer-events-none'>\n <div className='grid h-full pointer-fine:p-1 max-w-md mx-auto pointer-events-auto'>\n <Surface.Surface role='search-input' limit={1} />\n </div>\n </div>\n )}\n <span role='none' className='grow' />\n <Surface.Surface role='version-info' limit={1} />\n <Surface.Surface role='notch-start' limit={1} />\n </header>\n );\n};\n", "//\n// Copyright 2026 DXOS.org\n//\n\nimport { createContext } from '@radix-ui/react-context';\nimport React, { PropsWithChildren } from 'react';\n\nimport { type PluginManager } from '@dxos/app-framework';\n\nimport { type LayoutMode, type Settings } from '#types';\n\nimport { type DeckStateHook } from '../../hooks/useDeckState';\n\nconst DECK_NAME = 'Deck';\nconst DECK_ROOT_NAME = 'DeckRoot';\n\n/** Request to change the layout mode. */\nexport type DeckLayoutChangeRequest = { subject?: string; mode: LayoutMode } | { revert: true };\n\n//\n// Context\n//\n\nexport type DeckContextValue = {\n /** Deck plugin settings. */\n settings?: Settings.Settings;\n /** Plugin manager for capability access. */\n pluginManager: PluginManager.PluginManager;\n /** Layout mode. */\n layoutMode: LayoutMode;\n /** Callback for layout mode changes. */\n onLayoutChange: (request: DeckLayoutChangeRequest) => void;\n} & Pick<DeckStateHook, 'state' | 'deck' | 'updateState'>;\n\nexport const [DeckProvider, useDeckContext] = createContext<DeckContextValue>(DECK_NAME);\n\n//\n// Root\n//\n\nexport type DeckRootProps = PropsWithChildren<DeckContextValue>;\n\n/**\n * Headless root that provides Deck context.\n */\nexport const DeckRoot = ({ children, ...context }: DeckRootProps) => {\n return <DeckProvider {...context}>{children}</DeckProvider>;\n};\n\nDeckRoot.displayName = DECK_ROOT_NAME;\n", "//\n// Copyright 2026 DXOS.org\n//\n\nimport React, {\n Fragment,\n memo,\n type PropsWithChildren,\n type UIEvent,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n} from 'react';\n\nimport { Surface, useOperationInvoker } from '@dxos/app-framework/ui';\nimport { LayoutOperation } from '@dxos/app-toolkit';\nimport { useAppGraph } from '@dxos/app-toolkit/ui';\nimport { addEventListener } from '@dxos/async';\nimport { invariant } from '@dxos/invariant';\nimport { useNode } from '@dxos/plugin-graph';\nimport { IconButton, Main, type MainContentProps, useOnTransition, useTranslation } from '@dxos/react-ui';\nimport { mainPaddingTransitions } from '@dxos/react-ui';\nimport { DEFAULT_HORIZONTAL_SIZE, Stack, StackContext } from '@dxos/react-ui-stack';\nimport { hoverableControls, hoverableFocusedWithinControls, mx } from '@dxos/ui-theme';\n\nimport { useBreakpoints, useCompanions, useDeckState, useSelectedCompanion } from '#hooks';\nimport { meta } from '#meta';\nimport { DeckOperation } from '#types';\nimport { getMode } from '#types';\n\nimport { layoutAppliesTopbar } from '../../util';\nimport { Plank, PlankRootProps, type PlankComponentProps } from '../Plank';\nimport {\n ToggleComplementarySidebarButton as NaturalToggleComplementarySidebarButton,\n ToggleSidebarButton as NaturalToggleSidebarButton,\n} from '../Sidebar';\nimport { useDeckContext } from './DeckRoot';\n\nconst DECK_VIEWPORT_NAME = 'DeckViewport';\n\n//\n// DeckViewport\n//\n\nexport type DeckViewportProps = PropsWithChildren;\n\n/**\n * Deck viewport that renders the main content area and sets CSS variables for plank sizing.\n */\nexport const DeckViewport = ({ children }: DeckViewportProps) => {\n const {\n deck: { active, plankSizing },\n state: { sidebarState, complementarySidebarState },\n settings,\n layoutMode,\n } = useDeckContext(DECK_VIEWPORT_NAME);\n\n const breakpoint = useBreakpoints();\n const topbar = layoutAppliesTopbar(breakpoint, layoutMode);\n\n return (\n <Main.Content\n bounce\n handlesFocus\n classNames={[\n 'grid top-[env(safe-area-inset-top)]!',\n topbar && 'top-[calc(env(safe-area-inset-top)+var(--dx-rail-size))]!',\n ]}\n style={\n {\n '--main-spacing': settings?.encapsulatedPlanks ? '0.75rem' : '0',\n '--main-sidebar-width':\n sidebarState === 'expanded'\n ? 'var(--dx-nav-sidebar-size)'\n : sidebarState === 'collapsed'\n ? 'var(--dx-l0-size)'\n : '0',\n '--main-complementary-width':\n complementarySidebarState === 'expanded'\n ? 'var(--dx-complementary-sidebar-size)'\n : complementarySidebarState === 'collapsed'\n ? 'var(--dx-rail-size)'\n : '0',\n '--main-content-first-width': `${plankSizing[active[0] ?? 'never'] ?? DEFAULT_HORIZONTAL_SIZE}rem`,\n '--main-content-last-width': `${plankSizing[active[(active.length ?? 1) - 1] ?? 'never'] ?? DEFAULT_HORIZONTAL_SIZE}rem`,\n } as MainContentProps['style']\n }\n >\n {children}\n </Main.Content>\n );\n};\n\nDeckViewport.displayName = DECK_VIEWPORT_NAME;\n\n//\n// ContentEmpty\n//\n\nexport const DeckContentEmpty = () => {\n const breakpoint = useBreakpoints();\n const { deck } = useDeckState();\n const layoutMode = getMode(deck);\n const topbar = layoutAppliesTopbar(breakpoint, layoutMode);\n return (\n <div className='grid place-items-center p-8 relative bg-deck-surface' data-testid='layoutPlugin.firstRunMessage'>\n <Surface.Surface role='keyshortcuts' />\n {!topbar && <ToggleSidebarButton />}\n </div>\n );\n};\n\n//\n// DeckSoloMode\n//\n\n/**\n * Single-plank layout with optional companion.\n */\nexport const DeckSoloMode = () => {\n const { deck, settings, layoutMode, onLayoutChange } = useDeckContext('DeckSoloMode');\n const { companionOpen, companionVariant, fullscreen, solo } = deck;\n const effectiveCompanionVariant = fullscreen ? undefined : companionOpen ? companionVariant : undefined;\n const breakpoint = useBreakpoints();\n const topbar = layoutAppliesTopbar(breakpoint, layoutMode);\n invariant(solo);\n\n useEffect(() => {\n if (!fullscreen) {\n return;\n }\n\n const handleKeyDown = (event: globalThis.KeyboardEvent) => {\n if (event.key === 'Escape') {\n event.preventDefault();\n event.stopPropagation();\n onLayoutChange({ mode: 'solo--fullscreen' });\n }\n };\n\n document.addEventListener('keydown', handleKeyDown);\n return () => document.removeEventListener('keydown', handleKeyDown);\n }, [fullscreen, onLayoutChange]);\n\n return (\n <div className='relative overflow-hidden bg-deck-surface'>\n <DeckSidebarToggles topbar={topbar} fullscreen={fullscreen} />\n {fullscreen && <ExitFullscreenButton onExit={() => onLayoutChange({ mode: 'solo--fullscreen' })} />}\n <StackContext.Provider\n value={{\n orientation: 'horizontal',\n size: 'contain',\n rail: true,\n }}\n >\n <PlankContainer\n id={solo}\n part='solo'\n layoutMode={layoutMode}\n companionVariant={effectiveCompanionVariant}\n settings={settings}\n />\n </StackContext.Provider>\n </div>\n );\n};\n\n//\n// DeckMultiMode\n//\n\n/**\n * Multi-plank horizontal scrolling layout.\n */\nexport const DeckMultiMode = () => {\n const {\n deck: { active, companionVariant, fullscreen },\n settings,\n layoutMode,\n } = useDeckContext('DeckMultiMode');\n /** In multi mode the companion column is always shown when the last plank has companions (not gated by `companionOpen`). */\n const effectiveCompanionVariant = companionVariant;\n const lastPlankId = active[active.length - 1];\n const lastPlankCompanions = useCompanions(lastPlankId);\n const breakpoint = useBreakpoints();\n const topbar = layoutAppliesTopbar(breakpoint, layoutMode);\n const deckRef = useRef<HTMLDivElement>(null);\n\n /** Clear scroll restoration state if the window is resized. */\n const scrollLeftRef = useRef<number>(null);\n useEffect(\n () =>\n addEventListener(window, 'resize', () => {\n scrollLeftRef.current = null;\n }),\n [],\n );\n\n const restoreScroll = useCallback(() => {\n if (deckRef.current && scrollLeftRef.current != null) {\n deckRef.current.scrollLeft = scrollLeftRef.current;\n }\n }, []);\n\n useOnTransition(layoutMode, (mode) => mode !== 'multi', 'multi', restoreScroll);\n\n /** Save scroll position as the user scrolls. */\n const handleScroll = useCallback((event: UIEvent) => {\n if (event.currentTarget === event.target) {\n scrollLeftRef.current = (event.target as HTMLDivElement).scrollLeft;\n }\n }, []);\n\n // Create order map.\n // In multi mode only the last plank hosts the companion pane, so only that plank adds the extra column.\n const { order, itemsCount } = useMemo(() => {\n const lastHasCompanions = lastPlankCompanions.length > 0;\n return active.reduce(\n (acc: { order: Record<string, number>; itemsCount: number }, entryId, index) => {\n const isLastPlank = index === active.length - 1;\n acc.order[entryId] = acc.itemsCount + 1;\n acc.itemsCount += lastHasCompanions && isLastPlank ? 3 : 2;\n return acc;\n },\n { order: {}, itemsCount: 0 },\n );\n }, [active, lastPlankCompanions.length]);\n\n return (\n <div className='relative bg-deck-surface overflow-hidden'>\n <DeckSidebarToggles topbar={topbar} fullscreen={fullscreen} />\n <Stack\n classNames={[\n 'absolute h-[calc(100%-2*var(--main-spacing))] w-full inset-y-(--main-spacing) -inset-w-px',\n mainPaddingTransitions,\n ]}\n orientation='horizontal'\n size='contain'\n itemsCount={itemsCount - 1}\n onScroll={handleScroll}\n ref={deckRef}\n >\n {active.map((entryId) => (\n <Fragment key={entryId}>\n {/* TODO(burdon): Setting for separator. */}\n <PlankSeparator hidden order={order[entryId] - 1} encapsulate={!!settings?.encapsulatedPlanks} />\n <PlankContainer\n id={entryId}\n part='multi'\n active={active}\n order={order[entryId]}\n layoutMode={layoutMode}\n companionVariant={effectiveCompanionVariant}\n settings={settings}\n />\n </Fragment>\n ))}\n </Stack>\n </div>\n );\n};\n\n//\n// SidebarToggles\n//\n\nconst sidebarToggleStyles = 'h-(--dx-rail-item) w-(--dx-rail-item) absolute bottom-2 z-[1] bg-deck-surface! lg:hidden';\n\nconst ToggleSidebarButton = () => <NaturalToggleSidebarButton classNames={mx(sidebarToggleStyles, 'left-2')} />;\nconst ToggleComplementarySidebarButton = () => (\n <NaturalToggleComplementarySidebarButton classNames={mx(sidebarToggleStyles, 'right-2')} />\n);\n\nconst ExitFullscreenButton = ({ onExit }: { onExit: () => void }) => {\n const { t } = useTranslation(meta.id);\n return (\n <div\n className={mx(\n 'fixed top-2 right-2 z-[1]',\n hoverableControls,\n hoverableFocusedWithinControls,\n 'transition-opacity opacity-(--controls-opacity)',\n )}\n >\n <IconButton\n label={t('exit-fullscreen.label')}\n icon='ph--corners-in--regular'\n iconOnly\n variant='ghost'\n tooltipSide='bottom'\n onClick={onExit}\n />\n </div>\n );\n};\n\nconst DeckSidebarToggles = ({ topbar, fullscreen }: { topbar: boolean; fullscreen: boolean }) => {\n if (topbar || fullscreen) {\n return null;\n }\n\n return (\n <>\n <ToggleSidebarButton />\n <ToggleComplementarySidebarButton />\n </>\n );\n};\n\n//\n// PlankSeparator\n//\n\nconst PlankSeparator = ({ order, hidden, encapsulate }: { order: number; hidden?: boolean; encapsulate?: boolean }) =>\n order > 0 && (\n <span\n role='separator'\n className={mx('row-span-2 bg-deck-surface', hidden && 'hidden', encapsulate ? 'w-0' : 'w-4')}\n style={{ gridColumn: order }}\n />\n );\n\n//\n// PlankContainer\n//\n\ntype PlankContainerProps = Pick<PlankRootProps, 'layoutMode' | 'part' | 'settings'> &\n Pick<PlankComponentProps, 'id'> &\n Partial<Pick<PlankComponentProps, 'path' | 'order' | 'active'>> & {\n companionVariant?: string;\n };\n\n/**\n * Connected Plank that calls hooks and renders the radix-style Plank tree.\n * This is the bridge between DeckViewport (which knows about framework hooks) and\n * the pure Plank components (which receive everything via context).\n */\nconst PlankContainer = memo(\n ({ id, layoutMode, part, order, settings, companionVariant, active, ...props }: PlankContainerProps) => {\n const { graph } = useAppGraph();\n const { invokePromise } = useOperationInvoker();\n const { state, deck } = useDeckState();\n const node = useNode(graph, id);\n const companions = useCompanions(id);\n const isLastPlankInMulti =\n layoutMode === 'multi' && active && active.length > 0 && active[active.length - 1] === id;\n const variantForThisPlank =\n layoutMode === 'multi' ? (isLastPlankInMulti ? companionVariant : undefined) : companionVariant;\n const { companionId } = useSelectedCompanion(companions, variantForThisPlank);\n const resolvedCompanionId =\n layoutMode === 'multi' && isLastPlankInMulti && companions.length > 0\n ? companionId\n : variantForThisPlank\n ? companionId\n : undefined;\n const currentCompanion = companions.find(({ id }) => id === resolvedCompanionId);\n const hasCompanion = !!(resolvedCompanionId && currentCompanion);\n\n const handleAdjust = useCallback(\n (plankId: string, type: DeckOperation.PartAdjustment) => {\n if (type === 'close') {\n if (part === 'complementary') {\n return invokePromise(LayoutOperation.UpdateComplementary, { state: 'collapsed' });\n } else if (active) {\n // Close the plank and everything to the right (stack pop).\n const index = active.indexOf(plankId);\n const toClose = index !== -1 ? active.slice(index) : [plankId];\n return invokePromise(LayoutOperation.Close, { subject: toClose });\n } else {\n return invokePromise(LayoutOperation.Close, { subject: [plankId] });\n }\n } else {\n return invokePromise(DeckOperation.Adjust, { type, id: plankId });\n }\n },\n [invokePromise, part, active],\n );\n\n const handleResize = useCallback(\n (plankId: string, size: number) => invokePromise(DeckOperation.UpdatePlankSize, { id: plankId, size }),\n [invokePromise],\n );\n\n const handleScrollIntoView = useCallback(\n (subject?: string) => invokePromise(LayoutOperation.ScrollIntoView, { subject }),\n [invokePromise],\n );\n\n const handleUpdateCompanion = useCallback(\n (companion: string | null) => invokePromise(LayoutOperation.UpdateCompanion, { subject: companion }),\n [invokePromise],\n );\n\n return (\n <Plank.Root\n graph={graph}\n layoutMode={layoutMode}\n part={part}\n settings={settings}\n popoverAnchorId={state.popoverAnchorId}\n scrollIntoView={state.scrollIntoView}\n plankSizing={deck.plankSizing}\n onAdjust={handleAdjust}\n onResize={handleResize}\n onScrollIntoView={handleScrollIntoView}\n onUpdateCompanion={handleUpdateCompanion}\n >\n <Plank.Content solo={part === 'solo'} companion={hasCompanion} encapsulate={!!settings?.encapsulatedPlanks}>\n <Plank.Component\n {...props}\n active={active}\n id={id}\n node={node}\n companioned={hasCompanion ? 'primary' : undefined}\n companions={hasCompanion ? [] : companions}\n order={order}\n {...(part === 'solo'\n ? {\n part: 'solo-primary',\n }\n : {\n part,\n })}\n />\n {hasCompanion && (\n <Plank.Component\n {...props}\n active={active}\n id={resolvedCompanionId}\n node={currentCompanion}\n companions={companions}\n companioned='companion'\n primary={node}\n {...(part === 'solo'\n ? {\n order,\n part: 'solo-companion',\n }\n : {\n order: (order ?? 0) + 1,\n part,\n })}\n />\n )}\n </Plank.Content>\n </Plank.Root>\n );\n },\n);\n", "//\n// Copyright 2026 DXOS.org\n//\n\nimport { DeckContent, DeckContentProps } from './DeckContent';\nimport { DeckRoot, DeckLayoutChangeRequest, DeckRootProps } from './DeckRoot';\nimport { DeckViewport, DeckMultiMode, DeckSoloMode, DeckViewportProps, DeckContentEmpty } from './DeckViewport';\n\n/**\n * Radix-style composite Deck component.\n */\nexport const Deck = {\n Root: DeckRoot,\n Content: DeckContent,\n Viewport: DeckViewport,\n ContentEmpty: DeckContentEmpty,\n MultiMode: DeckMultiMode,\n SoloMode: DeckSoloMode,\n};\n\nexport type { DeckLayoutChangeRequest, DeckRootProps, DeckContentProps, DeckViewportProps };\n"],
5
+ "mappings": "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",
6
+ "names": ["React", "PlankLoading", "div", "className", "React", "useEffect", "useMemo", "useState", "TimeoutError", "log", "ErrorFallback", "useTranslation", "descriptionMessage", "mx", "meta", "React", "Fragment", "memo", "useCallback", "useEffect", "useMemo", "Surface", "AppSurface", "Graph", "useActionRunner", "Icon", "IconButton", "Popover", "toLocalizedString", "useTranslation", "getLinkedVariant", "StackItem", "TextTooltip", "hoverableControls", "hoverableFocusedWithinControls", "iconSize", "useBreakpoints", "meta", "PLANK_COMPANION_TYPE", "React", "forwardRef", "useCallback", "useOperationInvoker", "LayoutOperation", "ButtonGroup", "IconButton", "useTranslation", "meta", "plankControlSpacing", "PlankCompanionControls", "primary", "forwardedRef", "t", "id", "invokePromise", "handleCloseCompanion", "UpdateCompanion", "subject", "div", "ref", "className", "PlankControl", "label", "variant", "icon", "onClick", "classNames", "props", "iconOnly", "tooltipSide", "PlankControls", "children", "capabilities", "layoutMode", "pin", "close", "buttonClassNames", "layoutIsAnySolo", "startsWith", "deck", "solo", "disabled", "incrementStart", "incrementEnd", "fullscreen", "data-testid", "companion", "createContext", "React", "PLANK_NAME", "PlankProvider", "usePlankContext", "PlankRoot", "children", "context", "MAX_COMPANIONS", "PlankHeading", "memo", "id", "part", "node", "deckEnabled", "canIncrementStart", "canIncrementEnd", "popoverAnchorId", "primaryId", "pending", "companioned", "companions", "layoutMode", "actions", "debug", "t", "useTranslation", "meta", "graph", "onAdjust", "onUpdateCompanion", "usePlankContext", "runAction", "useActionRunner", "breakpoint", "useBreakpoints", "icon", "properties", "label", "toLocalizedString", "ns", "isCompanionNode", "type", "PLANK_COMPANION_TYPE", "useEffect", "frame", "requestAnimationFrame", "Graph", "expand", "cancelAnimationFrame", "attendableId", "capabilities", "useMemo", "deck", "solo", "incrementStart", "incrementEnd", "fullscreen", "companion", "length", "variant", "getLinkedVariant", "undefined", "sigilActions", "getActions", "filter", "action", "includes", "disposition", "a", "handleAction", "useCallback", "data", "parent", "caller", "handlePlankAction", "eventType", "ActionRoot", "Popover", "Anchor", "Fragment", "handleTabClick", "event", "target", "closest", "tabId", "dataset", "React", "StackItem", "Heading", "data-tauri-drag-region", "data-plank-heading", "style", "iconSize", "classNames", "hoverableControls", "hoverableFocusedWithinControls", "div", "className", "map", "IconButton", "key", "data-id", "iconOnly", "onClick", "Sigil", "related", "triggerLabel", "onAction", "Surface", "AppSurface", "MenuFooter", "subject", "SigilButton", "span", "Icon", "TextTooltip", "text", "onlyWhenTruncating", "HeadingLabel", "NavbarEnd", "PlankCompanionControls", "primary", "PlankControls", "close", "PlankError", "useEffect", "timer", "setTimeout", "setTimedOut", "error", "useMemo", "TimeoutError", "message", "timedOut", "part", "node", "pending", "React", "PlankLoading", "meta", "log", "process", "title", "role", "className", "p", "mx", "errorString", "useFocusFinders", "React", "memo", "useCallback", "useLayoutEffect", "useMemo", "useRef", "Surface", "AppSurface", "debounce", "mainIntrinsicSize", "getLinkedVariant", "useAttentionAttributes", "StackItem", "railGridHorizontal", "mx", "useMainSize", "PLANK_COMPANION_TYPE", "smoothScrollTo", "element", "target", "duration", "start", "scrollLeft", "distance", "startTime", "performance", "now", "step", "currentTime", "elapsed", "progress", "Math", "min", "eased", "pow", "requestAnimationFrame", "DEFAULT_SIZE", "DEFAULT_COMPANION_SIZE", "PlankComponent", "memo", "part", "id", "path", "order", "active", "node", "primary", "companions", "companioned", "layoutMode", "settings", "popoverAnchorId", "scrollIntoView", "plankSizing", "onResize", "onScrollIntoView", "usePlankContext", "canResize", "findFirstFocusable", "useFocusFinders", "isCompanion", "attentionAttrs", "useAttentionAttributes", "orderId", "index", "findIndex", "entryId", "length", "isOrdered", "canIncrementStart", "canIncrementEnd", "rootElement", "useRef", "variant", "type", "PLANK_COMPANION_TYPE", "getLinkedVariant", "undefined", "sizeAttrs", "useMainSize", "sizeKey", "split", "size", "handleSizeChange", "useCallback", "debounce", "nextSize", "round", "handleKeyDown", "event", "currentTarget", "key", "current", "closest", "focus", "useLayoutEffect", "scrollParent", "elementRect", "getBoundingClientRect", "parentRect", "targetScrollLeft", "left", "isSolo", "startsWith", "isAttendable", "data", "useMemo", "attendableId", "subject", "companionTo", "properties", "placeholder", "React", "PlankLoading", "Root", "StackItem", "fullscreen", "classNames", "mainIntrinsicSize", "railGridHorizontal", "encapsulatedPlanks", "ref", "data-testid", "data-popover-collision-boundary", "tabIndex", "className", "mx", "role", "item", "onSizeChange", "onKeyDown", "PlankHeading", "deckEnabled", "enableDeck", "primaryId", "Surface", "AppSurface", "Article", "limit", "fallback", "PlankErrorFallback", "PlankError", "ResizeHandle", "React", "composable", "composableProps", "mainIntrinsicSize", "railGridHorizontal", "useMainSize", "PlankContent", "children", "solo", "companion", "encapsulate", "props", "forwardedRef", "sizeAttrs", "div", "role", "classNames", "data-popover-collision-boundary", "ref", "Plank", "Root", "PlankRoot", "Content", "PlankContent", "Component", "PlankComponent", "Heading", "PlankHeading", "Controls", "PlankControls", "React", "useCallback", "useOperationInvoker", "LayoutOperation", "IconButton", "useTranslation", "getLinkedVariant", "useDeckCompanions", "useDeckState", "meta", "ToggleSidebarButton", "classNames", "variant", "updateState", "t", "id", "handleClick", "state", "sidebarState", "icon", "iconOnly", "size", "label", "onClick", "CloseSidebarButton", "ToggleComplementarySidebarButton", "inR0", "current", "invokePromise", "companions", "nextState", "complementarySidebarState", "subject", "complementarySidebarPanel", "UpdateComplementary", "tooltipSide", "undefined", "React", "useCallback", "useEffect", "useMemo", "useState", "Surface", "useOperationInvoker", "LayoutOperation", "IconButton", "Main", "Panel", "toLocalizedString", "Toolbar", "useTranslation", "getLinkedVariant", "Tabs", "iconSize", "mx", "useBreakpoints", "useDeckCompanions", "useDeckState", "meta", "getMode", "label", "ns", "meta", "id", "ComplementarySidebar", "current", "invokePromise", "useOperationInvoker", "t", "useTranslation", "state", "deck", "updateState", "useDeckState", "layoutMode", "getMode", "breakpoint", "useBreakpoints", "topbar", "layoutAppliesTopbar", "companions", "useDeckCompanions", "activeCompanion", "find", "companion", "getLinkedVariant", "activeId", "internalValue", "setInternalValue", "useState", "useEffect", "handleTabClick", "useCallback", "event", "nextValue", "currentTarget", "getAttribute", "complementarySidebarState", "LayoutOperation", "UpdateComplementary", "subject", "data", "useMemo", "React", "Main", "classNames", "Tabs", "Root", "orientation", "value", "div", "data-tauri-drag-region", "style", "iconSize", "className", "mx", "Tablist", "map", "Tab", "key", "asChild", "IconButton", "toLocalizedString", "properties", "icon", "iconOnly", "tooltipSide", "data-value", "joyride", "variant", "onClick", "Surface", "role", "ToggleComplementarySidebarButton", "Panel", "inert", "ComplementarySidebarPanel", "Toolbar", "size", "Content", "fallback", "PlankErrorFallback", "placeholder", "PlankLoading", "React", "useMemo", "Surface", "AppSurface", "Main", "useBreakpoints", "useDeckState", "meta", "getMode", "label", "ns", "meta", "id", "Sidebar", "state", "deck", "useDeckState", "popoverAnchorId", "activeDeck", "current", "breakpoint", "useBreakpoints", "layoutMode", "getMode", "topbar", "layoutAppliesTopbar", "navigationData", "useMemo", "React", "Main", "NavigationSidebar", "classNames", "Surface", "type", "AppSurface", "Navigation", "data", "limit", "React", "useCallback", "useEffect", "useRef", "AttentionCapabilities", "Main", "useMediaQuery", "useBreakpoints", "React", "Surface", "useTranslation", "mx", "osTranslations", "meta", "Banner", "variant", "classNames", "t", "useTranslation", "meta", "id", "React", "header", "className", "mx", "CloseSidebarButton", "ToggleSidebarButton", "span", "ns", "osTranslations", "div", "Surface", "role", "limit", "createContext", "React", "DECK_NAME", "DECK_ROOT_NAME", "DeckProvider", "useDeckContext", "DeckRoot", "children", "context", "displayName", "DECK_CONTENT_NAME", "DeckContent", "children", "state", "sidebarState", "complementarySidebarState", "complementarySidebarPanel", "deck", "active", "fullscreen", "solo", "updateState", "layoutMode", "settings", "pluginManager", "onLayoutChange", "useDeckContext", "breakpoint", "useBreakpoints", "topbar", "layoutAppliesTopbar", "useEffect", "attention", "capabilities", "get", "AttentionCapabilities", "Attention", "attended", "getCurrent", "firstId", "length", "document", "querySelector", "focus", "isNotMobile", "useMediaQuery", "shouldRevert", "useRef", "current", "subject", "mode", "revert", "enableDeck", "handleNavigationSidebarStateChange", "useCallback", "next", "s", "handleComplementarySidebarStateChange", "React", "Main", "Root", "navigationSidebarState", "onNavigationSidebarStateChange", "onComplementarySidebarStateChange", "Sidebar", "ComplementarySidebar", "Overlay", "Banner", "variant", "displayName", "React", "Fragment", "memo", "useCallback", "useEffect", "useMemo", "useRef", "Surface", "useOperationInvoker", "LayoutOperation", "useAppGraph", "addEventListener", "invariant", "useNode", "IconButton", "Main", "useOnTransition", "useTranslation", "mainPaddingTransitions", "DEFAULT_HORIZONTAL_SIZE", "Stack", "StackContext", "hoverableControls", "hoverableFocusedWithinControls", "mx", "useBreakpoints", "useCompanions", "useDeckState", "useSelectedCompanion", "meta", "DeckOperation", "getMode", "__dxlog_file", "DECK_VIEWPORT_NAME", "breakpoint", "useBreakpoints", "topbar", "layoutAppliesTopbar", "layoutMode", "bounce", "handlesFocus", "classNames", "style", "complementarySidebarState", "plankSizing", "DEFAULT_HORIZONTAL_SIZE", "length", "children", "DeckViewport", "displayName", "deck", "useDeckState", "getMode", "className", "React", "role", "Surface", "ToggleSidebarButton", "companionOpen", "companionVariant", "effectiveCompanionVariant", "fullscreen", "undefined", "invariant", "solo", "useEffect", "preventDefault", "event", "stopPropagation", "onLayoutChange", "mode", "document", "DeckSidebarToggles", "onExit", "value", "orientation", "size", "rail", "id", "settings", "lastPlankId", "active", "deckRef", "useRef", "addEventListener", "restoreScroll", "useCallback", "current", "scrollLeftRef", "useOnTransition", "currentTarget", "scrollLeft", "acc", "entryId", "index", "itemsCount", "lastHasCompanions", "isLastPlank", "order", "mainPaddingTransitions", "onScroll", "ref", "key", "PlankSeparator", "hidden", "encapsulate", "sidebarToggleStyles", "ToggleComplementarySidebarButton", "ExitFullscreenButton", "meta", "IconButton", "label", "mx", "hoverableControls", "hoverableFocusedWithinControls", "iconOnly", "variant", "tooltipSide", "onClick", "gridColumn", "useOperationInvoker", "state", "node", "graph", "companions", "useCompanions", "isLastPlankInMulti", "variantForThisPlank", "useSelectedCompanion", "resolvedCompanionId", "companionId", "currentCompanion", "hasCompanion", "handleAdjust", "plankId", "type", "invokePromise", "LayoutOperation", "part", "popoverAnchorId", "scrollIntoView", "onAdjust", "onResize", "handleResize", "onScrollIntoView", "onUpdateCompanion", "companioned", "primary", "Deck", "Root", "DeckRoot", "Content", "DeckContent", "Viewport", "DeckViewport", "ContentEmpty", "DeckContentEmpty", "MultiMode", "DeckMultiMode", "SoloMode", "DeckSoloMode"]
7
+ }
@@ -0,0 +1,112 @@
1
+ // src/util/plank-url-params.ts
2
+ import { fromUrlPath, toUrlPath } from "@dxos/app-toolkit";
3
+ var PLANK_PARAM = "plank";
4
+ var serializePlanks = (active, existingSearch) => {
5
+ const params = new URLSearchParams(existingSearch);
6
+ params.delete(PLANK_PARAM);
7
+ for (const id of active) {
8
+ params.append(PLANK_PARAM, toUrlPath(id));
9
+ }
10
+ return params.size > 0 ? `?${params.toString()}` : "";
11
+ };
12
+ var deserializePlanks = (url) => {
13
+ return url.searchParams.getAll(PLANK_PARAM).map(fromUrlPath);
14
+ };
15
+ var stripPlanks = (existingSearch) => {
16
+ const params = new URLSearchParams(existingSearch);
17
+ params.delete(PLANK_PARAM);
18
+ return params.size > 0 ? `?${params.toString()}` : "";
19
+ };
20
+
21
+ // src/util/sanitize-persisted-state.ts
22
+ var sanitizePersistedState = (state) => {
23
+ let needsUpdate = false;
24
+ const cleanedDecks = {
25
+ ...state.decks
26
+ };
27
+ for (const [id, deck] of Object.entries(cleanedDecks)) {
28
+ if (!deck) {
29
+ continue;
30
+ }
31
+ let updated = false;
32
+ let cleanedDeck = deck;
33
+ if (deck.fullscreen) {
34
+ cleanedDeck = {
35
+ ...cleanedDeck,
36
+ fullscreen: false
37
+ };
38
+ updated = true;
39
+ }
40
+ if (deck.solo && deck.active.length > 0) {
41
+ cleanedDeck = {
42
+ ...cleanedDeck,
43
+ active: []
44
+ };
45
+ updated = true;
46
+ }
47
+ if (updated) {
48
+ cleanedDecks[id] = cleanedDeck;
49
+ needsUpdate = true;
50
+ }
51
+ }
52
+ return needsUpdate ? {
53
+ ...state,
54
+ decks: cleanedDecks
55
+ } : state;
56
+ };
57
+
58
+ // src/util/set-active.ts
59
+ var computeActiveUpdates = ({ next, deck, attention }) => {
60
+ const active = deck.solo ? [
61
+ deck.solo
62
+ ] : deck.active;
63
+ const removed = active.filter((id) => !next.includes(id));
64
+ const closed = Array.from(/* @__PURE__ */ new Set([
65
+ ...deck.inactive.filter((id) => !next.includes(id)),
66
+ ...removed
67
+ ]));
68
+ const updates = {
69
+ inactive: closed,
70
+ solo: deck.solo,
71
+ active: deck.active,
72
+ fullscreen: deck.fullscreen
73
+ };
74
+ if (deck.solo || !deck.initialized) {
75
+ updates.solo = next[0];
76
+ } else {
77
+ updates.active = next;
78
+ }
79
+ if (deck.fullscreen && !updates.solo) {
80
+ updates.fullscreen = false;
81
+ }
82
+ let toAttend;
83
+ if (attention) {
84
+ const attended = attention.getCurrent();
85
+ const [attendedId] = Array.from(attended);
86
+ const isAttendedAvailable = !!attendedId && next.includes(attendedId);
87
+ if (!isAttendedAvailable) {
88
+ const attendedIndex = active.indexOf(attendedId);
89
+ const index = attendedIndex === -1 ? 0 : attendedIndex >= next.length ? next.length - 1 : attendedIndex;
90
+ toAttend = next[index];
91
+ }
92
+ }
93
+ return {
94
+ deckUpdates: updates,
95
+ toAttend
96
+ };
97
+ };
98
+
99
+ // src/util/layoutAppliesTopbar.ts
100
+ var layoutAppliesTopbar = (breakpoint, layoutMode) => {
101
+ return document.body.getAttribute("data-platform") === "windows" && breakpoint === "desktop" && layoutMode !== "solo--fullscreen";
102
+ };
103
+
104
+ export {
105
+ layoutAppliesTopbar,
106
+ serializePlanks,
107
+ deserializePlanks,
108
+ stripPlanks,
109
+ sanitizePersistedState,
110
+ computeActiveUpdates
111
+ };
112
+ //# sourceMappingURL=chunk-GBIGQKYW.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/util/plank-url-params.ts", "../../../src/util/sanitize-persisted-state.ts", "../../../src/util/set-active.ts", "../../../src/util/layoutAppliesTopbar.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { fromUrlPath, toUrlPath } from '@dxos/app-toolkit';\n\nconst PLANK_PARAM = 'plank';\n\n/**\n * Serialize deck active qualified IDs into a URL search string.\n * Preserves non-plank query params from the existing search string.\n */\nexport const serializePlanks = (active: readonly string[], existingSearch: string): string => {\n const params = new URLSearchParams(existingSearch);\n params.delete(PLANK_PARAM);\n for (const id of active) {\n params.append(PLANK_PARAM, toUrlPath(id));\n }\n return params.size > 0 ? `?${params.toString()}` : '';\n};\n\n/**\n * Deserialize plank query params from a URL back to qualified graph IDs.\n */\nexport const deserializePlanks = (url: URL): string[] => {\n return url.searchParams.getAll(PLANK_PARAM).map(fromUrlPath);\n};\n\n/**\n * Strip plank query params from a search string, preserving all others.\n */\nexport const stripPlanks = (existingSearch: string): string => {\n const params = new URLSearchParams(existingSearch);\n params.delete(PLANK_PARAM);\n return params.size > 0 ? `?${params.toString()}` : '';\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type StoredDeckState } from '#types';\n\n/**\n * Sanitizes persisted deck state on startup.\n *\n * Persisted state may contain values that are inappropriate to restore across sessions:\n *\n * - **Fullscreen**: Cleared unconditionally to prevent the user from getting stuck in fullscreen\n * mode if the app was closed (or crashed) while fullscreen was active.\n *\n * - **Active planks in solo-mode decks**: When a deck is in solo mode, any items in `active`\n * represent planks that were kept mounted (hidden) during the session for fast deck↔solo\n * switching. After a restart these planks would need to fully remount anyway, so retaining\n * them only adds unnecessary load. Clearing `active` for solo-mode decks avoids rendering\n * stale planks in the background on startup.\n *\n * Returns a new state object if any changes were made, or the original state if clean.\n */\nexport const sanitizePersistedState = (state: StoredDeckState): StoredDeckState => {\n let needsUpdate = false;\n const cleanedDecks = { ...state.decks };\n\n for (const [id, deck] of Object.entries(cleanedDecks)) {\n if (!deck) {\n continue;\n }\n\n let updated = false;\n let cleanedDeck = deck;\n\n if (deck.fullscreen) {\n cleanedDeck = { ...cleanedDeck, fullscreen: false };\n updated = true;\n }\n\n if (deck.solo && deck.active.length > 0) {\n cleanedDeck = { ...cleanedDeck, active: [] };\n updated = true;\n }\n\n if (updated) {\n cleanedDecks[id] = cleanedDeck;\n needsUpdate = true;\n }\n }\n\n return needsUpdate ? { ...state, decks: cleanedDecks } : state;\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type AttentionManager } from '@dxos/react-ui-attention';\n\nimport { type DeckState } from '#types';\n\nexport type SetActiveOptions = {\n next: string[];\n deck: DeckState;\n attention?: AttentionManager;\n};\n\nexport type SetActiveResult = {\n /** Updates to apply to the deck. */\n deckUpdates: {\n inactive: string[];\n solo: string | undefined;\n active: string[];\n fullscreen: boolean;\n };\n /** ID of the item to attend (scroll into view) if attention changed. */\n toAttend?: string;\n};\n\n/**\n * Computes the new active state for the deck without mutating.\n * Returns the updates to apply and optionally an item to attend.\n */\nexport const computeActiveUpdates = ({ next, deck, attention }: SetActiveOptions): SetActiveResult => {\n const active = deck.solo ? [deck.solo] : deck.active;\n const removed = active.filter((id) => !next.includes(id));\n const closed = Array.from(new Set([...deck.inactive.filter((id) => !next.includes(id)), ...removed]));\n\n const updates = {\n inactive: closed,\n solo: deck.solo,\n active: deck.active,\n fullscreen: deck.fullscreen,\n };\n\n if (deck.solo || !deck.initialized) {\n updates.solo = next[0];\n } else {\n updates.active = next;\n }\n\n if (deck.fullscreen && !updates.solo) {\n updates.fullscreen = false;\n }\n\n let toAttend: string | undefined;\n if (attention) {\n const attended = attention.getCurrent();\n const [attendedId] = Array.from(attended);\n const isAttendedAvailable = !!attendedId && next.includes(attendedId);\n if (!isAttendedAvailable) {\n const attendedIndex = active.indexOf(attendedId);\n // If outside of bounds, focus on the first/last plank, otherwise focus on the new plank in the same position.\n const index = attendedIndex === -1 ? 0 : attendedIndex >= next.length ? next.length - 1 : attendedIndex;\n toAttend = next[index];\n }\n }\n\n return { deckUpdates: updates, toAttend };\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type LayoutMode } from '#types';\n\nexport const layoutAppliesTopbar = (breakpoint: string, layoutMode?: LayoutMode) => {\n return (\n document.body.getAttribute('data-platform') === 'windows' &&\n breakpoint === 'desktop' &&\n layoutMode !== 'solo--fullscreen'\n );\n};\n"],
5
+ "mappings": "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",
6
+ "names": ["fromUrlPath", "toUrlPath", "PLANK_PARAM", "serializePlanks", "active", "existingSearch", "params", "URLSearchParams", "delete", "id", "append", "size", "toString", "deserializePlanks", "url", "searchParams", "getAll", "map", "stripPlanks", "sanitizePersistedState", "state", "needsUpdate", "cleanedDecks", "decks", "id", "deck", "Object", "entries", "updated", "cleanedDeck", "fullscreen", "solo", "active", "length", "computeActiveUpdates", "next", "deck", "attention", "active", "solo", "removed", "filter", "id", "includes", "closed", "Array", "from", "Set", "inactive", "updates", "fullscreen", "initialized", "toAttend", "attended", "getCurrent", "attendedId", "isAttendedAvailable", "attendedIndex", "indexOf", "index", "length", "deckUpdates", "layoutAppliesTopbar", "breakpoint", "layoutMode", "document", "body", "getAttribute"]
7
+ }
@@ -0,0 +1,22 @@
1
+ // src/operations/helpers.ts
2
+ import { invariant } from "@dxos/invariant";
3
+ var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-deck/src/operations/helpers.ts";
4
+ var updateActiveDeck = (current, deckUpdates) => {
5
+ const currentDeck = current.decks[current.activeDeck];
6
+ invariant(currentDeck, `Deck not found: ${current.activeDeck}`, { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 7, S: void 0, A: ["currentDeck", "`Deck not found: ${current.activeDeck}`"] });
7
+ return {
8
+ ...current,
9
+ decks: {
10
+ ...current.decks,
11
+ [current.activeDeck]: {
12
+ ...currentDeck,
13
+ ...deckUpdates
14
+ }
15
+ }
16
+ };
17
+ };
18
+
19
+ export {
20
+ updateActiveDeck
21
+ };
22
+ //# sourceMappingURL=chunk-GLB73Q6U.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/operations/helpers.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { invariant } from '@dxos/invariant';\n\nimport { type DeckState, type StoredDeckState } from '../types';\n\nexport const updateActiveDeck = (current: StoredDeckState, deckUpdates: Partial<DeckState>): StoredDeckState => {\n const currentDeck = current.decks[current.activeDeck];\n invariant(currentDeck, `Deck not found: ${current.activeDeck}`);\n return {\n ...current,\n decks: {\n ...current.decks,\n [current.activeDeck]: {\n ...currentDeck,\n ...deckUpdates,\n },\n },\n };\n};\n"],
5
+ "mappings": ";AAIA,SAASA,iBAAiB;AAI1B,IAAA,eAAaC;AAEXD,IAAAA,mBAAwB,CAAA,SAAA,gBAA0BE;AAClD,QAAA,cAAO,QAAA,MAAA,QAAA,UAAA;YACFC,aAAO,mBAAA,QAAA,UAAA,IAAA,EAAA,YAAA,YAAA,GAAA,cAAA,GAAA,GAAA,GAAA,QAAA,GAAA,CAAA,eAAA,yCAAA,EAAA,CAAA;SACVC;;WAEGD;iBACIE;eACAC,UAAW,GAAA;QAChB,GAAA;QACF,GAAA;MACF;IACA;;;",
6
+ "names": ["invariant", "updateActiveDeck", "activeDeck", "current", "decks", "currentDeck", "deckUpdates"]
7
+ }