@dxos/plugin-deck 0.8.4-main.bc674ce → 0.8.4-main.bcb3aa67d6

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 (523) hide show
  1. package/dist/lib/browser/add-toast-QUWRKFDD.mjs +24 -0
  2. package/dist/lib/browser/add-toast-QUWRKFDD.mjs.map +7 -0
  3. package/dist/lib/browser/adjust-J6F24WWJ.mjs +96 -0
  4. package/dist/lib/browser/adjust-J6F24WWJ.mjs.map +7 -0
  5. package/dist/lib/browser/change-companion-EZI57WDZ.mjs +34 -0
  6. package/dist/lib/browser/change-companion-EZI57WDZ.mjs.map +7 -0
  7. package/dist/lib/browser/chunk-2YNVGCOQ.mjs +88 -0
  8. package/dist/lib/browser/chunk-2YNVGCOQ.mjs.map +7 -0
  9. package/dist/lib/browser/chunk-AYFQHPPP.mjs +69 -0
  10. package/dist/lib/browser/chunk-AYFQHPPP.mjs.map +7 -0
  11. package/dist/lib/browser/chunk-GCDWE37Y.mjs +220 -0
  12. package/dist/lib/browser/chunk-GCDWE37Y.mjs.map +7 -0
  13. package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
  14. package/dist/lib/browser/chunk-J5LGTIGS.mjs.map +7 -0
  15. package/dist/lib/browser/chunk-KUTDCWZF.mjs +30 -0
  16. package/dist/lib/browser/chunk-KUTDCWZF.mjs.map +7 -0
  17. package/dist/lib/browser/chunk-OHKLENIG.mjs +45 -0
  18. package/dist/lib/browser/chunk-OHKLENIG.mjs.map +7 -0
  19. package/dist/lib/browser/close-6RB62DEY.mjs +44 -0
  20. package/dist/lib/browser/close-6RB62DEY.mjs.map +7 -0
  21. package/dist/lib/browser/index.mjs +161 -126
  22. package/dist/lib/browser/index.mjs.map +4 -4
  23. package/dist/lib/browser/meta.json +1 -1
  24. package/dist/lib/browser/open-YL3JKXGK.mjs +115 -0
  25. package/dist/lib/browser/open-YL3JKXGK.mjs.map +7 -0
  26. package/dist/lib/browser/operations/index.mjs +13 -0
  27. package/dist/lib/browser/operations/index.mjs.map +7 -0
  28. package/dist/lib/browser/revert-workspace-JC66YMWB.mjs +21 -0
  29. package/dist/lib/browser/revert-workspace-JC66YMWB.mjs.map +7 -0
  30. package/dist/lib/browser/scroll-into-view-QSSFZ3KD.mjs +21 -0
  31. package/dist/lib/browser/scroll-into-view-QSSFZ3KD.mjs.map +7 -0
  32. package/dist/lib/browser/set-LPAGXY3F.mjs +37 -0
  33. package/dist/lib/browser/set-LPAGXY3F.mjs.map +7 -0
  34. package/dist/lib/browser/set-layout-mode-XZ4VHS2X.mjs +90 -0
  35. package/dist/lib/browser/set-layout-mode-XZ4VHS2X.mjs.map +7 -0
  36. package/dist/lib/browser/show-undo-IWX4S777.mjs +59 -0
  37. package/dist/lib/browser/show-undo-IWX4S777.mjs.map +7 -0
  38. package/dist/lib/browser/switch-workspace-5RKQ2LVK.mjs +68 -0
  39. package/dist/lib/browser/switch-workspace-5RKQ2LVK.mjs.map +7 -0
  40. package/dist/lib/browser/types/index.mjs +8 -15
  41. package/dist/lib/browser/update-complementary-QIIZWLGY.mjs +28 -0
  42. package/dist/lib/browser/update-complementary-QIIZWLGY.mjs.map +7 -0
  43. package/dist/lib/browser/update-dialog-5IKCWFPW.mjs +29 -0
  44. package/dist/lib/browser/update-dialog-5IKCWFPW.mjs.map +7 -0
  45. package/dist/lib/browser/update-plank-size-YDM67P65.mjs +28 -0
  46. package/dist/lib/browser/update-plank-size-YDM67P65.mjs.map +7 -0
  47. package/dist/lib/browser/update-popover-AUVAWH3D.mjs +33 -0
  48. package/dist/lib/browser/update-popover-AUVAWH3D.mjs.map +7 -0
  49. package/dist/lib/browser/update-sidebar-BT3L5GJN.mjs +25 -0
  50. package/dist/lib/browser/update-sidebar-BT3L5GJN.mjs.map +7 -0
  51. package/dist/lib/node-esm/add-toast-MR53ZMTS.mjs +25 -0
  52. package/dist/lib/node-esm/add-toast-MR53ZMTS.mjs.map +7 -0
  53. package/dist/lib/node-esm/adjust-IXRBIVAO.mjs +97 -0
  54. package/dist/lib/node-esm/adjust-IXRBIVAO.mjs.map +7 -0
  55. package/dist/lib/node-esm/change-companion-RLMI5EYL.mjs +35 -0
  56. package/dist/lib/node-esm/change-companion-RLMI5EYL.mjs.map +7 -0
  57. package/dist/lib/node-esm/chunk-7BNWWWAF.mjs +221 -0
  58. package/dist/lib/node-esm/chunk-7BNWWWAF.mjs.map +7 -0
  59. package/dist/lib/node-esm/chunk-C2AWKR2S.mjs +71 -0
  60. package/dist/lib/node-esm/chunk-C2AWKR2S.mjs.map +7 -0
  61. package/dist/lib/node-esm/chunk-GI5JXNBT.mjs +89 -0
  62. package/dist/lib/node-esm/chunk-GI5JXNBT.mjs.map +7 -0
  63. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +11 -0
  64. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs.map +7 -0
  65. package/dist/lib/node-esm/chunk-MLVJ2ODW.mjs +32 -0
  66. package/dist/lib/node-esm/chunk-MLVJ2ODW.mjs.map +7 -0
  67. package/dist/lib/node-esm/chunk-TFFZ7NWH.mjs +47 -0
  68. package/dist/lib/node-esm/chunk-TFFZ7NWH.mjs.map +7 -0
  69. package/dist/lib/node-esm/close-UD7KBYZP.mjs +45 -0
  70. package/dist/lib/node-esm/close-UD7KBYZP.mjs.map +7 -0
  71. package/dist/lib/node-esm/index.mjs +161 -126
  72. package/dist/lib/node-esm/index.mjs.map +4 -4
  73. package/dist/lib/node-esm/meta.json +1 -1
  74. package/dist/lib/node-esm/open-XZ7YGVPZ.mjs +116 -0
  75. package/dist/lib/node-esm/open-XZ7YGVPZ.mjs.map +7 -0
  76. package/dist/lib/node-esm/operations/index.mjs +14 -0
  77. package/dist/lib/node-esm/operations/index.mjs.map +7 -0
  78. package/dist/lib/node-esm/revert-workspace-F3FUP4ZL.mjs +22 -0
  79. package/dist/lib/node-esm/revert-workspace-F3FUP4ZL.mjs.map +7 -0
  80. package/dist/lib/node-esm/scroll-into-view-24TF2WYQ.mjs +22 -0
  81. package/dist/lib/node-esm/scroll-into-view-24TF2WYQ.mjs.map +7 -0
  82. package/dist/lib/node-esm/set-F2QWLSJR.mjs +38 -0
  83. package/dist/lib/node-esm/set-F2QWLSJR.mjs.map +7 -0
  84. package/dist/lib/node-esm/set-layout-mode-Z54OX33H.mjs +91 -0
  85. package/dist/lib/node-esm/set-layout-mode-Z54OX33H.mjs.map +7 -0
  86. package/dist/lib/node-esm/show-undo-B2XVCKGX.mjs +60 -0
  87. package/dist/lib/node-esm/show-undo-B2XVCKGX.mjs.map +7 -0
  88. package/dist/lib/node-esm/switch-workspace-PM57REEV.mjs +69 -0
  89. package/dist/lib/node-esm/switch-workspace-PM57REEV.mjs.map +7 -0
  90. package/dist/lib/node-esm/types/index.mjs +8 -15
  91. package/dist/lib/node-esm/update-complementary-26H5UYJP.mjs +29 -0
  92. package/dist/lib/node-esm/update-complementary-26H5UYJP.mjs.map +7 -0
  93. package/dist/lib/node-esm/update-dialog-EYP3QNFG.mjs +30 -0
  94. package/dist/lib/node-esm/update-dialog-EYP3QNFG.mjs.map +7 -0
  95. package/dist/lib/node-esm/update-plank-size-LLFUB57G.mjs +29 -0
  96. package/dist/lib/node-esm/update-plank-size-LLFUB57G.mjs.map +7 -0
  97. package/dist/lib/node-esm/update-popover-G55PS7T4.mjs +34 -0
  98. package/dist/lib/node-esm/update-popover-G55PS7T4.mjs.map +7 -0
  99. package/dist/lib/node-esm/update-sidebar-W4ND5MUL.mjs +26 -0
  100. package/dist/lib/node-esm/update-sidebar-W4ND5MUL.mjs.map +7 -0
  101. package/dist/types/src/DeckPlugin.d.ts.map +1 -1
  102. package/dist/types/src/capabilities/app-graph-builder.d.ts +6 -0
  103. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -0
  104. package/dist/types/src/capabilities/check-app-scheme.d.ts +19 -0
  105. package/dist/types/src/capabilities/check-app-scheme.d.ts.map +1 -0
  106. package/dist/types/src/capabilities/index.d.ts +198 -9
  107. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  108. package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
  109. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
  110. package/dist/types/src/capabilities/{react-root/react-root.d.ts → react-root.d.ts} +1 -1
  111. package/dist/types/src/capabilities/react-root.d.ts.map +1 -0
  112. package/dist/types/src/capabilities/react-surface.d.ts +5 -0
  113. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -0
  114. package/dist/types/src/capabilities/{settings/settings.d.ts → settings.d.ts} +4 -3
  115. package/dist/types/src/capabilities/settings.d.ts.map +1 -0
  116. package/dist/types/src/capabilities/{state/state.d.ts → state.d.ts} +11 -11
  117. package/dist/types/src/capabilities/state.d.ts.map +1 -0
  118. package/dist/types/src/capabilities/{tools/tools.d.ts → tools.d.ts} +2 -2
  119. package/dist/types/src/capabilities/tools.d.ts.map +1 -0
  120. package/dist/types/src/capabilities/url-handler.d.ts +5 -0
  121. package/dist/types/src/capabilities/url-handler.d.ts.map +1 -0
  122. package/dist/types/src/components/DeckSettings/DeckSettings.d.ts +4 -6
  123. package/dist/types/src/components/DeckSettings/DeckSettings.d.ts.map +1 -1
  124. package/dist/types/src/components/DeckSettings/DeckSettings.stories.d.ts +85 -0
  125. package/dist/types/src/components/DeckSettings/DeckSettings.stories.d.ts.map +1 -0
  126. package/dist/types/src/components/DeckSettings/index.d.ts +2 -1
  127. package/dist/types/src/components/DeckSettings/index.d.ts.map +1 -1
  128. package/dist/types/src/components/Matrix/Matrix.d.ts +49 -0
  129. package/dist/types/src/components/Matrix/Matrix.d.ts.map +1 -0
  130. package/dist/types/src/components/Matrix/Matrix.stories.d.ts +17 -0
  131. package/dist/types/src/components/Matrix/Matrix.stories.d.ts.map +1 -0
  132. package/dist/types/src/components/Matrix/index.d.ts +3 -0
  133. package/dist/types/src/components/Matrix/index.d.ts.map +1 -0
  134. package/dist/types/src/components/index.d.ts +3 -2
  135. package/dist/types/src/components/index.d.ts.map +1 -1
  136. package/dist/types/src/containers/Deck/Banner.d.ts.map +1 -0
  137. package/dist/types/src/containers/Deck/Deck.d.ts +25 -0
  138. package/dist/types/src/containers/Deck/Deck.d.ts.map +1 -0
  139. package/dist/types/src/containers/Deck/Deck.stories.d.ts +85 -0
  140. package/dist/types/src/containers/Deck/Deck.stories.d.ts.map +1 -0
  141. package/dist/types/src/containers/Deck/DeckContent.d.ts +7 -0
  142. package/dist/types/src/containers/Deck/DeckContent.d.ts.map +1 -0
  143. package/dist/types/src/containers/Deck/DeckRoot.d.ts +42 -0
  144. package/dist/types/src/containers/Deck/DeckRoot.d.ts.map +1 -0
  145. package/dist/types/src/containers/Deck/DeckViewport.d.ts +19 -0
  146. package/dist/types/src/containers/Deck/DeckViewport.d.ts.map +1 -0
  147. package/dist/types/src/containers/Deck/StatusBar.d.ts.map +1 -0
  148. package/dist/types/src/containers/Deck/index.d.ts +2 -0
  149. package/dist/types/src/containers/Deck/index.d.ts.map +1 -0
  150. package/dist/types/src/containers/DeckLayout/ActiveNode.d.ts.map +1 -0
  151. package/dist/types/src/containers/DeckLayout/DeckLayout.d.ts.map +1 -0
  152. package/dist/types/src/containers/DeckLayout/DeckLayout.stories.d.ts +87 -0
  153. package/dist/types/src/containers/DeckLayout/DeckLayout.stories.d.ts.map +1 -0
  154. package/dist/types/src/{components → containers}/DeckLayout/Dialog.d.ts.map +1 -1
  155. package/dist/types/src/containers/DeckLayout/Fallback.d.ts +2 -0
  156. package/dist/types/src/containers/DeckLayout/Fallback.d.ts.map +1 -0
  157. package/dist/types/src/containers/DeckLayout/Popover.d.ts +5 -0
  158. package/dist/types/src/containers/DeckLayout/Popover.d.ts.map +1 -0
  159. package/dist/types/src/{components → containers}/DeckLayout/Toast.d.ts +3 -3
  160. package/dist/types/src/containers/DeckLayout/Toast.d.ts.map +1 -0
  161. package/dist/types/src/containers/DeckLayout/constants.d.ts.map +1 -0
  162. package/dist/types/src/containers/DeckLayout/index.d.ts +4 -0
  163. package/dist/types/src/containers/DeckLayout/index.d.ts.map +1 -0
  164. package/dist/types/src/containers/Plank/Plank.d.ts +21 -0
  165. package/dist/types/src/containers/Plank/Plank.d.ts.map +1 -0
  166. package/dist/types/src/containers/Plank/Plank.stories.d.ts +84 -0
  167. package/dist/types/src/containers/Plank/Plank.stories.d.ts.map +1 -0
  168. package/dist/types/src/containers/Plank/PlankComponent.d.ts +15 -0
  169. package/dist/types/src/containers/Plank/PlankComponent.d.ts.map +1 -0
  170. package/dist/types/src/containers/Plank/PlankContent.d.ts +14 -0
  171. package/dist/types/src/containers/Plank/PlankContent.d.ts.map +1 -0
  172. package/dist/types/src/{components → containers}/Plank/PlankControls.d.ts +5 -6
  173. package/dist/types/src/containers/Plank/PlankControls.d.ts.map +1 -0
  174. package/dist/types/src/containers/Plank/PlankError.d.ts +15 -0
  175. package/dist/types/src/containers/Plank/PlankError.d.ts.map +1 -0
  176. package/dist/types/src/{components → containers}/Plank/PlankHeading.d.ts +1 -1
  177. package/dist/types/src/containers/Plank/PlankHeading.d.ts.map +1 -0
  178. package/dist/types/src/{components → containers}/Plank/PlankLoading.d.ts.map +1 -1
  179. package/dist/types/src/containers/Plank/PlankRoot.d.ts +37 -0
  180. package/dist/types/src/containers/Plank/PlankRoot.d.ts.map +1 -0
  181. package/dist/types/src/containers/Plank/index.d.ts +4 -0
  182. package/dist/types/src/containers/Plank/index.d.ts.map +1 -0
  183. package/dist/types/src/containers/Sidebar/ComplementarySidebar.d.ts.map +1 -0
  184. package/dist/types/src/{components → containers}/Sidebar/Sidebar.d.ts.map +1 -1
  185. package/dist/types/src/{components → containers}/Sidebar/SidebarButton.d.ts.map +1 -1
  186. package/dist/types/src/{components → containers}/Sidebar/index.d.ts.map +1 -1
  187. package/dist/types/src/containers/index.d.ts +6 -0
  188. package/dist/types/src/containers/index.d.ts.map +1 -0
  189. package/dist/types/src/hooks/index.d.ts +1 -0
  190. package/dist/types/src/hooks/index.d.ts.map +1 -1
  191. package/dist/types/src/hooks/useDeckCompanions.d.ts +0 -1
  192. package/dist/types/src/hooks/useDeckCompanions.d.ts.map +1 -1
  193. package/dist/types/src/hooks/useDeckState.d.ts +3 -3
  194. package/dist/types/src/hooks/useDeckState.d.ts.map +1 -1
  195. package/dist/types/src/hooks/useHoistStatusbar.d.ts +1 -1
  196. package/dist/types/src/hooks/useHoistStatusbar.d.ts.map +1 -1
  197. package/dist/types/src/hooks/useMainSize.d.ts +2 -2
  198. package/dist/types/src/hooks/useSelectedCompanion.d.ts +13 -0
  199. package/dist/types/src/hooks/useSelectedCompanion.d.ts.map +1 -0
  200. package/dist/types/src/layout.d.ts +3 -9
  201. package/dist/types/src/layout.d.ts.map +1 -1
  202. package/dist/types/src/operations/add-toast.d.ts +5 -0
  203. package/dist/types/src/operations/add-toast.d.ts.map +1 -0
  204. package/dist/types/src/operations/adjust.d.ts +5 -0
  205. package/dist/types/src/operations/adjust.d.ts.map +1 -0
  206. package/dist/types/src/operations/change-companion.d.ts +5 -0
  207. package/dist/types/src/operations/change-companion.d.ts.map +1 -0
  208. package/dist/types/src/operations/close.d.ts +5 -0
  209. package/dist/types/src/operations/close.d.ts.map +1 -0
  210. package/dist/types/src/operations/definitions.d.ts +18 -0
  211. package/dist/types/src/operations/definitions.d.ts.map +1 -0
  212. package/dist/types/src/operations/helpers.d.ts +3 -0
  213. package/dist/types/src/operations/helpers.d.ts.map +1 -0
  214. package/dist/types/src/operations/index.d.ts +4 -0
  215. package/dist/types/src/operations/index.d.ts.map +1 -0
  216. package/dist/types/src/operations/open.d.ts +5 -0
  217. package/dist/types/src/operations/open.d.ts.map +1 -0
  218. package/dist/types/src/operations/revert-workspace.d.ts +5 -0
  219. package/dist/types/src/operations/revert-workspace.d.ts.map +1 -0
  220. package/dist/types/src/operations/scroll-into-view.d.ts +5 -0
  221. package/dist/types/src/operations/scroll-into-view.d.ts.map +1 -0
  222. package/dist/types/src/operations/set-layout-mode.d.ts +9 -0
  223. package/dist/types/src/operations/set-layout-mode.d.ts.map +1 -0
  224. package/dist/types/src/operations/set.d.ts +5 -0
  225. package/dist/types/src/operations/set.d.ts.map +1 -0
  226. package/dist/types/src/operations/show-undo.d.ts +5 -0
  227. package/dist/types/src/operations/show-undo.d.ts.map +1 -0
  228. package/dist/types/src/operations/switch-workspace.d.ts +5 -0
  229. package/dist/types/src/operations/switch-workspace.d.ts.map +1 -0
  230. package/dist/types/src/operations/update-complementary.d.ts +5 -0
  231. package/dist/types/src/operations/update-complementary.d.ts.map +1 -0
  232. package/dist/types/src/operations/update-dialog.d.ts +5 -0
  233. package/dist/types/src/operations/update-dialog.d.ts.map +1 -0
  234. package/dist/types/src/operations/update-plank-size.d.ts +5 -0
  235. package/dist/types/src/operations/update-plank-size.d.ts.map +1 -0
  236. package/dist/types/src/operations/update-popover.d.ts +5 -0
  237. package/dist/types/src/operations/update-popover.d.ts.map +1 -0
  238. package/dist/types/src/operations/update-sidebar.d.ts +5 -0
  239. package/dist/types/src/operations/update-sidebar.d.ts.map +1 -0
  240. package/dist/types/src/testing/DeckLayoutStoryNavigation.d.ts +10 -0
  241. package/dist/types/src/testing/DeckLayoutStoryNavigation.d.ts.map +1 -0
  242. package/dist/types/src/testing/index.d.ts +2 -0
  243. package/dist/types/src/testing/index.d.ts.map +1 -0
  244. package/dist/types/src/translations.d.ts +66 -54
  245. package/dist/types/src/translations.d.ts.map +1 -1
  246. package/dist/types/src/types/Settings.d.ts +16 -0
  247. package/dist/types/src/types/Settings.d.ts.map +1 -0
  248. package/dist/types/src/types/capabilities.d.ts +11 -11
  249. package/dist/types/src/types/capabilities.d.ts.map +1 -1
  250. package/dist/types/src/types/events.d.ts.map +1 -1
  251. package/dist/types/src/types/index.d.ts +1 -0
  252. package/dist/types/src/types/index.d.ts.map +1 -1
  253. package/dist/types/src/types/schema.d.ts +38 -94
  254. package/dist/types/src/types/schema.d.ts.map +1 -1
  255. package/dist/types/src/util/index.d.ts +1 -0
  256. package/dist/types/src/util/index.d.ts.map +1 -1
  257. package/dist/types/src/util/layoutAppliesTopbar.d.ts +1 -1
  258. package/dist/types/src/util/layoutAppliesTopbar.d.ts.map +1 -1
  259. package/dist/types/src/util/sanitize-persisted-state.d.ts +19 -0
  260. package/dist/types/src/util/sanitize-persisted-state.d.ts.map +1 -0
  261. package/dist/types/src/util/sanitize-persisted-state.test.d.ts +2 -0
  262. package/dist/types/src/util/sanitize-persisted-state.test.d.ts.map +1 -0
  263. package/dist/types/src/util/set-active.d.ts +2 -2
  264. package/dist/types/src/util/set-active.d.ts.map +1 -1
  265. package/dist/types/src/util/set-active.test.d.ts +2 -0
  266. package/dist/types/src/util/set-active.test.d.ts.map +1 -0
  267. package/dist/types/tsconfig.tsbuildinfo +1 -1
  268. package/package.json +77 -44
  269. package/src/DeckPlugin.ts +18 -22
  270. package/src/capabilities/app-graph-builder.ts +127 -0
  271. package/src/capabilities/check-app-scheme.ts +139 -0
  272. package/src/capabilities/index.ts +14 -10
  273. package/src/capabilities/operation-handler.ts +16 -0
  274. package/src/capabilities/{react-root/react-root.tsx → react-root.tsx} +5 -5
  275. package/src/capabilities/react-surface.tsx +38 -0
  276. package/src/capabilities/{settings/settings.ts → settings.ts} +8 -7
  277. package/src/capabilities/{state/state.ts → state.ts} +17 -31
  278. package/src/capabilities/{tools/tools.ts → tools.ts} +4 -5
  279. package/src/capabilities/url-handler.ts +209 -0
  280. package/src/components/DeckSettings/DeckSettings.stories.tsx +40 -0
  281. package/src/components/DeckSettings/DeckSettings.tsx +103 -93
  282. package/src/components/DeckSettings/index.ts +4 -2
  283. package/src/components/Matrix/Matrix.stories.tsx +213 -0
  284. package/src/components/Matrix/Matrix.tsx +205 -0
  285. package/src/components/Matrix/SPEC.md +219 -0
  286. package/src/components/Matrix/index.ts +6 -0
  287. package/src/components/index.ts +6 -3
  288. package/src/{components/DeckLayout → containers/Deck}/Banner.tsx +10 -9
  289. package/src/containers/Deck/Deck.stories.tsx +85 -0
  290. package/src/containers/Deck/Deck.tsx +21 -0
  291. package/src/containers/Deck/DeckContent.tsx +104 -0
  292. package/src/containers/Deck/DeckRoot.tsx +49 -0
  293. package/src/containers/Deck/DeckViewport.tsx +397 -0
  294. package/src/{components/DeckLayout → containers/Deck}/StatusBar.tsx +4 -4
  295. package/src/containers/Deck/index.ts +5 -0
  296. package/src/{components → containers}/DeckLayout/ActiveNode.tsx +4 -3
  297. package/src/containers/DeckLayout/DeckLayout.stories.tsx +174 -0
  298. package/src/containers/DeckLayout/DeckLayout.tsx +62 -0
  299. package/src/{components → containers}/DeckLayout/Dialog.tsx +11 -5
  300. package/src/containers/DeckLayout/Fallback.tsx +24 -0
  301. package/src/{components → containers}/DeckLayout/Popover.tsx +58 -18
  302. package/src/{components → containers}/DeckLayout/Toast.tsx +4 -4
  303. package/src/{components → containers}/DeckLayout/constants.ts +1 -0
  304. package/src/{components → containers}/DeckLayout/index.ts +3 -2
  305. package/src/containers/Plank/Plank.stories.tsx +105 -0
  306. package/src/containers/Plank/Plank.tsx +22 -0
  307. package/src/containers/Plank/PlankComponent.tsx +179 -0
  308. package/src/containers/Plank/PlankContent.tsx +45 -0
  309. package/src/{components → containers}/Plank/PlankControls.tsx +41 -34
  310. package/src/containers/Plank/PlankError.tsx +79 -0
  311. package/src/{components → containers}/Plank/PlankHeading.tsx +36 -45
  312. package/src/{components → containers}/Plank/PlankLoading.tsx +1 -1
  313. package/src/containers/Plank/PlankRoot.tsx +49 -0
  314. package/src/{components → containers}/Plank/index.ts +0 -2
  315. package/src/containers/Sidebar/ComplementarySidebar.tsx +209 -0
  316. package/src/{components → containers}/Sidebar/Sidebar.tsx +8 -8
  317. package/src/{components → containers}/Sidebar/SidebarButton.tsx +19 -19
  318. package/src/containers/index.ts +11 -0
  319. package/src/hooks/index.ts +1 -0
  320. package/src/hooks/useCompanions.ts +3 -3
  321. package/src/hooks/useDeckCompanions.ts +3 -8
  322. package/src/hooks/useDeckState.ts +14 -23
  323. package/src/hooks/useHoistStatusbar.ts +2 -2
  324. package/src/hooks/useMainSize.ts +2 -2
  325. package/src/hooks/useNodeActionExpander.ts +1 -1
  326. package/src/hooks/useSelectedCompanion.ts +32 -0
  327. package/src/layout.ts +3 -16
  328. package/src/meta.ts +1 -1
  329. package/src/operations/add-toast.ts +24 -0
  330. package/src/operations/adjust.ts +83 -0
  331. package/src/operations/change-companion.ts +35 -0
  332. package/src/operations/close.ts +35 -0
  333. package/src/operations/definitions.ts +61 -0
  334. package/src/operations/helpers.ts +22 -0
  335. package/src/operations/index.ts +26 -0
  336. package/src/operations/open.ts +117 -0
  337. package/src/operations/revert-workspace.ts +22 -0
  338. package/src/operations/scroll-into-view.ts +24 -0
  339. package/src/operations/set-layout-mode.ts +84 -0
  340. package/src/operations/set.ts +36 -0
  341. package/src/operations/show-undo.ts +46 -0
  342. package/src/operations/switch-workspace.ts +60 -0
  343. package/src/operations/update-complementary.ts +33 -0
  344. package/src/operations/update-dialog.ts +34 -0
  345. package/src/operations/update-plank-size.ts +29 -0
  346. package/src/operations/update-popover.ts +36 -0
  347. package/src/operations/update-sidebar.ts +28 -0
  348. package/src/testing/DeckLayoutStoryNavigation.tsx +57 -0
  349. package/src/testing/index.ts +5 -0
  350. package/src/translations.ts +67 -54
  351. package/src/types/Settings.ts +26 -0
  352. package/src/types/capabilities.ts +9 -8
  353. package/src/types/events.ts +6 -5
  354. package/src/types/index.ts +1 -0
  355. package/src/types/schema.ts +35 -110
  356. package/src/util/index.ts +1 -0
  357. package/src/util/layoutAppliesTopbar.ts +1 -1
  358. package/src/util/overscroll.ts +3 -3
  359. package/src/util/sanitize-persisted-state.test.ts +79 -0
  360. package/src/util/sanitize-persisted-state.ts +52 -0
  361. package/src/util/set-active.test.ts +106 -0
  362. package/src/util/set-active.ts +2 -2
  363. package/src/vite-env.d.ts +5 -0
  364. package/dist/lib/browser/app-graph-builder-DTVCULQ4.mjs +0 -120
  365. package/dist/lib/browser/app-graph-builder-DTVCULQ4.mjs.map +0 -7
  366. package/dist/lib/browser/check-app-scheme-JSRXXIYF.mjs +0 -32
  367. package/dist/lib/browser/check-app-scheme-JSRXXIYF.mjs.map +0 -7
  368. package/dist/lib/browser/chunk-ATFPDN6J.mjs +0 -292
  369. package/dist/lib/browser/chunk-ATFPDN6J.mjs.map +0 -7
  370. package/dist/lib/browser/chunk-NHABISX2.mjs +0 -152
  371. package/dist/lib/browser/chunk-NHABISX2.mjs.map +0 -7
  372. package/dist/lib/browser/chunk-S4A5UO4K.mjs +0 -1448
  373. package/dist/lib/browser/chunk-S4A5UO4K.mjs.map +0 -7
  374. package/dist/lib/browser/chunk-UNG4CLLP.mjs +0 -161
  375. package/dist/lib/browser/chunk-UNG4CLLP.mjs.map +0 -7
  376. package/dist/lib/browser/operation-resolver-CDYBLZJ4.mjs +0 -595
  377. package/dist/lib/browser/operation-resolver-CDYBLZJ4.mjs.map +0 -7
  378. package/dist/lib/browser/react-root-XDCMNENQ.mjs +0 -47
  379. package/dist/lib/browser/react-root-XDCMNENQ.mjs.map +0 -7
  380. package/dist/lib/browser/react-surface-HODERLOL.mjs +0 -42
  381. package/dist/lib/browser/react-surface-HODERLOL.mjs.map +0 -7
  382. package/dist/lib/browser/settings-OMHVGZ6V.mjs +0 -37
  383. package/dist/lib/browser/settings-OMHVGZ6V.mjs.map +0 -7
  384. package/dist/lib/browser/state-OC3BSB6E.mjs +0 -103
  385. package/dist/lib/browser/state-OC3BSB6E.mjs.map +0 -7
  386. package/dist/lib/browser/toolkit-R53LD3EA.mjs +0 -53
  387. package/dist/lib/browser/toolkit-R53LD3EA.mjs.map +0 -7
  388. package/dist/lib/browser/url-handler-53TE6JZO.mjs +0 -93
  389. package/dist/lib/browser/url-handler-53TE6JZO.mjs.map +0 -7
  390. package/dist/lib/node-esm/app-graph-builder-473BNZDJ.mjs +0 -121
  391. package/dist/lib/node-esm/app-graph-builder-473BNZDJ.mjs.map +0 -7
  392. package/dist/lib/node-esm/check-app-scheme-IVYRHKRH.mjs +0 -33
  393. package/dist/lib/node-esm/check-app-scheme-IVYRHKRH.mjs.map +0 -7
  394. package/dist/lib/node-esm/chunk-ADPMWKLL.mjs +0 -154
  395. package/dist/lib/node-esm/chunk-ADPMWKLL.mjs.map +0 -7
  396. package/dist/lib/node-esm/chunk-D34L3ECT.mjs +0 -1449
  397. package/dist/lib/node-esm/chunk-D34L3ECT.mjs.map +0 -7
  398. package/dist/lib/node-esm/chunk-SKEVPQ7E.mjs +0 -162
  399. package/dist/lib/node-esm/chunk-SKEVPQ7E.mjs.map +0 -7
  400. package/dist/lib/node-esm/chunk-XAKTY3EB.mjs +0 -294
  401. package/dist/lib/node-esm/chunk-XAKTY3EB.mjs.map +0 -7
  402. package/dist/lib/node-esm/operation-resolver-WUOE33ID.mjs +0 -596
  403. package/dist/lib/node-esm/operation-resolver-WUOE33ID.mjs.map +0 -7
  404. package/dist/lib/node-esm/react-root-O6GZO62Z.mjs +0 -48
  405. package/dist/lib/node-esm/react-root-O6GZO62Z.mjs.map +0 -7
  406. package/dist/lib/node-esm/react-surface-IHDJDGC5.mjs +0 -43
  407. package/dist/lib/node-esm/react-surface-IHDJDGC5.mjs.map +0 -7
  408. package/dist/lib/node-esm/settings-2HB6FKIK.mjs +0 -38
  409. package/dist/lib/node-esm/settings-2HB6FKIK.mjs.map +0 -7
  410. package/dist/lib/node-esm/state-JRQ45ACJ.mjs +0 -104
  411. package/dist/lib/node-esm/state-JRQ45ACJ.mjs.map +0 -7
  412. package/dist/lib/node-esm/toolkit-JLPZNNKB.mjs +0 -54
  413. package/dist/lib/node-esm/toolkit-JLPZNNKB.mjs.map +0 -7
  414. package/dist/lib/node-esm/url-handler-QGF2R24T.mjs +0 -94
  415. package/dist/lib/node-esm/url-handler-QGF2R24T.mjs.map +0 -7
  416. package/dist/types/src/capabilities/app-graph-builder/app-graph-builder.d.ts +0 -6
  417. package/dist/types/src/capabilities/app-graph-builder/app-graph-builder.d.ts.map +0 -1
  418. package/dist/types/src/capabilities/app-graph-builder/index.d.ts +0 -3
  419. package/dist/types/src/capabilities/app-graph-builder/index.d.ts.map +0 -1
  420. package/dist/types/src/capabilities/check-app-scheme/check-app-scheme.d.ts +0 -5
  421. package/dist/types/src/capabilities/check-app-scheme/check-app-scheme.d.ts.map +0 -1
  422. package/dist/types/src/capabilities/check-app-scheme/index.d.ts +0 -3
  423. package/dist/types/src/capabilities/check-app-scheme/index.d.ts.map +0 -1
  424. package/dist/types/src/capabilities/operation-resolver/index.d.ts +0 -3
  425. package/dist/types/src/capabilities/operation-resolver/index.d.ts.map +0 -1
  426. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts +0 -5
  427. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts.map +0 -1
  428. package/dist/types/src/capabilities/react-root/index.d.ts +0 -6
  429. package/dist/types/src/capabilities/react-root/index.d.ts.map +0 -1
  430. package/dist/types/src/capabilities/react-root/react-root.d.ts.map +0 -1
  431. package/dist/types/src/capabilities/react-surface/index.d.ts +0 -3
  432. package/dist/types/src/capabilities/react-surface/index.d.ts.map +0 -1
  433. package/dist/types/src/capabilities/react-surface/react-surface.d.ts +0 -5
  434. package/dist/types/src/capabilities/react-surface/react-surface.d.ts.map +0 -1
  435. package/dist/types/src/capabilities/settings/index.d.ts +0 -19
  436. package/dist/types/src/capabilities/settings/index.d.ts.map +0 -1
  437. package/dist/types/src/capabilities/settings/settings.d.ts.map +0 -1
  438. package/dist/types/src/capabilities/state/index.d.ts +0 -172
  439. package/dist/types/src/capabilities/state/index.d.ts.map +0 -1
  440. package/dist/types/src/capabilities/state/state.d.ts.map +0 -1
  441. package/dist/types/src/capabilities/toolkit/index.d.ts +0 -3
  442. package/dist/types/src/capabilities/toolkit/index.d.ts.map +0 -1
  443. package/dist/types/src/capabilities/toolkit/toolkit.d.ts +0 -26
  444. package/dist/types/src/capabilities/toolkit/toolkit.d.ts.map +0 -1
  445. package/dist/types/src/capabilities/tools/index.d.ts +0 -3
  446. package/dist/types/src/capabilities/tools/index.d.ts.map +0 -1
  447. package/dist/types/src/capabilities/tools/tools.d.ts.map +0 -1
  448. package/dist/types/src/capabilities/url-handler/index.d.ts +0 -3
  449. package/dist/types/src/capabilities/url-handler/index.d.ts.map +0 -1
  450. package/dist/types/src/capabilities/url-handler/url-handler.d.ts +0 -5
  451. package/dist/types/src/capabilities/url-handler/url-handler.d.ts.map +0 -1
  452. package/dist/types/src/components/DeckLayout/ActiveNode.d.ts.map +0 -1
  453. package/dist/types/src/components/DeckLayout/Banner.d.ts.map +0 -1
  454. package/dist/types/src/components/DeckLayout/ContentEmpty.d.ts +0 -3
  455. package/dist/types/src/components/DeckLayout/ContentEmpty.d.ts.map +0 -1
  456. package/dist/types/src/components/DeckLayout/DeckLayout.d.ts.map +0 -1
  457. package/dist/types/src/components/DeckLayout/DeckLayout.stories.d.ts +0 -74
  458. package/dist/types/src/components/DeckLayout/DeckLayout.stories.d.ts.map +0 -1
  459. package/dist/types/src/components/DeckLayout/DeckMain.d.ts +0 -3
  460. package/dist/types/src/components/DeckLayout/DeckMain.d.ts.map +0 -1
  461. package/dist/types/src/components/DeckLayout/Fallback.d.ts +0 -3
  462. package/dist/types/src/components/DeckLayout/Fallback.d.ts.map +0 -1
  463. package/dist/types/src/components/DeckLayout/Popover.d.ts +0 -5
  464. package/dist/types/src/components/DeckLayout/Popover.d.ts.map +0 -1
  465. package/dist/types/src/components/DeckLayout/StatusBar.d.ts.map +0 -1
  466. package/dist/types/src/components/DeckLayout/Toast.d.ts.map +0 -1
  467. package/dist/types/src/components/DeckLayout/Topbar.d.ts +0 -3
  468. package/dist/types/src/components/DeckLayout/Topbar.d.ts.map +0 -1
  469. package/dist/types/src/components/DeckLayout/constants.d.ts.map +0 -1
  470. package/dist/types/src/components/DeckLayout/index.d.ts +0 -4
  471. package/dist/types/src/components/DeckLayout/index.d.ts.map +0 -1
  472. package/dist/types/src/components/Plank/Plank.d.ts +0 -27
  473. package/dist/types/src/components/Plank/Plank.d.ts.map +0 -1
  474. package/dist/types/src/components/Plank/Plank.stories.d.ts +0 -107
  475. package/dist/types/src/components/Plank/Plank.stories.d.ts.map +0 -1
  476. package/dist/types/src/components/Plank/PlankControls.d.ts.map +0 -1
  477. package/dist/types/src/components/Plank/PlankError.d.ts +0 -13
  478. package/dist/types/src/components/Plank/PlankError.d.ts.map +0 -1
  479. package/dist/types/src/components/Plank/PlankHeading.d.ts.map +0 -1
  480. package/dist/types/src/components/Plank/index.d.ts +0 -6
  481. package/dist/types/src/components/Plank/index.d.ts.map +0 -1
  482. package/dist/types/src/components/Sidebar/ComplementarySidebar.d.ts.map +0 -1
  483. package/dist/types/src/components/fragments.d.ts +0 -4
  484. package/dist/types/src/components/fragments.d.ts.map +0 -1
  485. package/src/capabilities/app-graph-builder/app-graph-builder.ts +0 -118
  486. package/src/capabilities/app-graph-builder/index.ts +0 -7
  487. package/src/capabilities/check-app-scheme/check-app-scheme.ts +0 -41
  488. package/src/capabilities/check-app-scheme/index.ts +0 -7
  489. package/src/capabilities/operation-resolver/index.ts +0 -10
  490. package/src/capabilities/operation-resolver/operation-resolver.ts +0 -555
  491. package/src/capabilities/react-root/index.ts +0 -7
  492. package/src/capabilities/react-surface/index.ts +0 -7
  493. package/src/capabilities/react-surface/react-surface.tsx +0 -37
  494. package/src/capabilities/settings/index.ts +0 -7
  495. package/src/capabilities/state/index.ts +0 -7
  496. package/src/capabilities/toolkit/index.ts +0 -7
  497. package/src/capabilities/toolkit/toolkit.ts +0 -63
  498. package/src/capabilities/tools/index.ts +0 -7
  499. package/src/capabilities/url-handler/index.ts +0 -7
  500. package/src/capabilities/url-handler/url-handler.ts +0 -95
  501. package/src/components/DeckLayout/ContentEmpty.tsx +0 -30
  502. package/src/components/DeckLayout/DeckLayout.stories.tsx +0 -51
  503. package/src/components/DeckLayout/DeckLayout.tsx +0 -34
  504. package/src/components/DeckLayout/DeckMain.tsx +0 -286
  505. package/src/components/DeckLayout/Fallback.tsx +0 -28
  506. package/src/components/DeckLayout/Topbar.tsx +0 -11
  507. package/src/components/Plank/Plank.stories.tsx +0 -62
  508. package/src/components/Plank/Plank.tsx +0 -299
  509. package/src/components/Plank/PlankError.tsx +0 -49
  510. package/src/components/Sidebar/ComplementarySidebar.tsx +0 -221
  511. package/src/components/fragments.ts +0 -14
  512. /package/dist/types/src/{components/DeckLayout → containers/Deck}/Banner.d.ts +0 -0
  513. /package/dist/types/src/{components/DeckLayout → containers/Deck}/StatusBar.d.ts +0 -0
  514. /package/dist/types/src/{components → containers}/DeckLayout/ActiveNode.d.ts +0 -0
  515. /package/dist/types/src/{components → containers}/DeckLayout/DeckLayout.d.ts +0 -0
  516. /package/dist/types/src/{components → containers}/DeckLayout/Dialog.d.ts +0 -0
  517. /package/dist/types/src/{components → containers}/DeckLayout/constants.d.ts +0 -0
  518. /package/dist/types/src/{components → containers}/Plank/PlankLoading.d.ts +0 -0
  519. /package/dist/types/src/{components → containers}/Sidebar/ComplementarySidebar.d.ts +0 -0
  520. /package/dist/types/src/{components → containers}/Sidebar/Sidebar.d.ts +0 -0
  521. /package/dist/types/src/{components → containers}/Sidebar/SidebarButton.d.ts +0 -0
  522. /package/dist/types/src/{components → containers}/Sidebar/index.d.ts +0 -0
  523. /package/src/{components → containers}/Sidebar/index.ts +0 -0
@@ -4,12 +4,12 @@
4
4
 
5
5
  import React, { forwardRef, useCallback } from 'react';
6
6
 
7
- import { useOperationInvoker } from '@dxos/app-framework/react';
8
- import { invariant } from '@dxos/invariant';
7
+ import { useOperationInvoker } from '@dxos/app-framework/ui';
9
8
  import { ButtonGroup, type ButtonGroupProps, type ButtonProps, IconButton, useTranslation } from '@dxos/react-ui';
10
9
 
11
- import { meta } from '../../meta';
12
- import { type DeckAction, DeckOperation, type LayoutMode } from '../../types';
10
+ import { meta } from '#meta';
11
+ import { type DeckAction, type LayoutMode } from '#types';
12
+ import { DeckOperation } from '#operations';
13
13
 
14
14
  export type PlankControlHandler = (event: DeckAction.PartAdjustment) => void;
15
15
 
@@ -22,37 +22,27 @@ export type PlankCapabilities = {
22
22
  companion?: boolean;
23
23
  };
24
24
 
25
- export type PlankControlsProps = Omit<ButtonGroupProps, 'onClick'> & {
26
- onClick?: PlankControlHandler;
27
- variant?: 'hide-disabled' | 'default';
28
- close?: boolean | 'minify-start' | 'minify-end';
29
- capabilities: PlankCapabilities;
30
- layoutMode?: LayoutMode;
31
- pin?: 'start' | 'end' | 'both';
32
- };
33
-
34
- const PlankControl = ({ icon, label, ...props }: Omit<ButtonProps, 'children'> & { label: string; icon: string }) => {
35
- return <IconButton label={label} icon={icon} iconOnly variant='ghost' tooltipSide='bottom' {...props} />;
36
- };
25
+ //
26
+ // Controls
27
+ //
37
28
 
38
- const plankControlSpacing = 'pli-2';
29
+ const plankControlSpacing = 'px-2';
39
30
 
40
- type PlankComplimentControlsProps = {
31
+ export type PlankCompanionControlsProps = {
41
32
  primary?: string;
42
33
  };
43
34
 
44
- export const PlankCompanionControls = forwardRef<HTMLDivElement, PlankComplimentControlsProps>(
35
+ export const PlankCompanionControls = forwardRef<HTMLDivElement, PlankCompanionControlsProps>(
45
36
  ({ primary }, forwardedRef) => {
46
37
  const { t } = useTranslation(meta.id);
47
38
  const { invokePromise } = useOperationInvoker();
48
39
  const handleCloseCompanion = useCallback(() => {
49
- invariant(primary);
50
- return invokePromise(DeckOperation.ChangeCompanion, { primary, companion: null });
51
- }, [invokePromise, primary]);
40
+ return invokePromise(DeckOperation.ChangeCompanion, { companion: null });
41
+ }, [invokePromise]);
52
42
  return (
53
- <div ref={forwardedRef} className='contents app-no-drag'>
43
+ <div ref={forwardedRef} className='contents dx-app-no-drag'>
54
44
  <PlankControl
55
- label={t('close companion label')}
45
+ label={t('close-companion.label')}
56
46
  variant='ghost'
57
47
  icon='ph--x--regular'
58
48
  onClick={handleCloseCompanion}
@@ -63,6 +53,23 @@ export const PlankCompanionControls = forwardRef<HTMLDivElement, PlankCompliment
63
53
  },
64
54
  );
65
55
 
56
+ const PlankControl = ({ icon, label, ...props }: Omit<ButtonProps, 'children'> & { label: string; icon: string }) => {
57
+ return <IconButton label={label} icon={icon} iconOnly variant='ghost' tooltipSide='bottom' {...props} />;
58
+ };
59
+
60
+ //
61
+ // PlankControls
62
+ //
63
+
64
+ export type PlankControlsProps = Omit<ButtonGroupProps, 'onClick'> & {
65
+ onClick?: PlankControlHandler;
66
+ variant?: 'hide-disabled' | 'default';
67
+ close?: boolean | 'minify-start' | 'minify-end';
68
+ capabilities: PlankCapabilities;
69
+ layoutMode?: LayoutMode;
70
+ pin?: 'start' | 'end' | 'both';
71
+ };
72
+
66
73
  // TODO(wittjosiah): Duplicate of stack LayoutControls?
67
74
  // Translations were to be duplicated between packages.
68
75
  // NOTE(thure): Pinning & unpinning are disabled indefinitely.
@@ -78,14 +85,14 @@ export const PlankControls = forwardRef<HTMLDivElement, PlankControlsProps>(
78
85
  const layoutIsAnySolo = !!layoutMode?.startsWith('solo');
79
86
 
80
87
  return (
81
- <ButtonGroup {...props} classNames={['app-no-drag !opacity-100', classNames]} ref={forwardedRef}>
88
+ <ButtonGroup {...props} classNames={['dx-app-no-drag opacity-100!', classNames]} ref={forwardedRef}>
82
89
  {capabilities.deck ? (
83
90
  <>
84
91
  {capabilities.solo && (
85
92
  <>
86
93
  {layoutMode === 'solo' && (
87
94
  <PlankControl
88
- label={t('show fullscreen plank label')}
95
+ label={t('show-fullscreen-plank.label')}
89
96
  classNames={buttonClassNames}
90
97
  icon='ph--corners-out--regular'
91
98
  onClick={() => onClick?.('solo--fullscreen')}
@@ -94,10 +101,10 @@ export const PlankControls = forwardRef<HTMLDivElement, PlankControlsProps>(
94
101
  <PlankControl
95
102
  label={t(
96
103
  layoutMode === 'solo--fullscreen'
97
- ? 'exit fullscreen label'
104
+ ? 'exit-fullscreen.label'
98
105
  : layoutIsAnySolo
99
- ? 'show deck plank label'
100
- : 'show solo plank label',
106
+ ? 'show-deck-plank.label'
107
+ : 'show-solo-plank.label',
101
108
  )}
102
109
  classNames={buttonClassNames}
103
110
  icon={
@@ -115,14 +122,14 @@ export const PlankControls = forwardRef<HTMLDivElement, PlankControlsProps>(
115
122
  {!layoutIsAnySolo && (
116
123
  <>
117
124
  <PlankControl
118
- label={t('increment start label')}
125
+ label={t('increment-start.label')}
119
126
  disabled={!capabilities.incrementStart}
120
127
  classNames={buttonClassNames}
121
128
  icon='ph--caret-left--regular'
122
129
  onClick={() => onClick?.('increment-start')}
123
130
  />
124
131
  <PlankControl
125
- label={t('increment end label')}
132
+ label={t('increment-end.label')}
126
133
  disabled={!capabilities.incrementEnd}
127
134
  classNames={buttonClassNames}
128
135
  icon='ph--caret-right--regular'
@@ -134,7 +141,7 @@ export const PlankControls = forwardRef<HTMLDivElement, PlankControlsProps>(
134
141
  ) : (
135
142
  capabilities.fullscreen && (
136
143
  <PlankControl
137
- label={t(layoutMode === 'solo--fullscreen' ? 'exit fullscreen label' : 'show fullscreen plank label')}
144
+ label={t(layoutMode === 'solo--fullscreen' ? 'exit-fullscreen.label' : 'show-fullscreen-plank.label')}
138
145
  classNames={buttonClassNames}
139
146
  icon={layoutMode === 'solo--fullscreen' ? 'ph--corners-in--regular' : 'ph--corners-out--regular'}
140
147
  onClick={() => onClick?.('solo--fullscreen')}
@@ -144,7 +151,7 @@ export const PlankControls = forwardRef<HTMLDivElement, PlankControlsProps>(
144
151
 
145
152
  {close && !layoutIsAnySolo && (
146
153
  <PlankControl
147
- label={t(`${typeof close === 'string' ? 'minify' : 'close'} label`)}
154
+ label={t(`${typeof close === 'string' ? 'minify' : 'close'}.label`)}
148
155
  classNames={buttonClassNames}
149
156
  data-testid='plankHeading.close'
150
157
  icon={
@@ -160,7 +167,7 @@ export const PlankControls = forwardRef<HTMLDivElement, PlankControlsProps>(
160
167
 
161
168
  {capabilities.companion && (
162
169
  <PlankControl
163
- label={t('open companion label')}
170
+ label={t('open-companion.label')}
164
171
  classNames={buttonClassNames}
165
172
  data-testid='plankHeading.companion'
166
173
  icon='ph--square-split-horizontal--regular'
@@ -0,0 +1,79 @@
1
+ //
2
+ // Copyright 2024 DXOS.org
3
+ //
4
+
5
+ import React, { useEffect, useMemo, useState } from 'react';
6
+
7
+ import { TimeoutError } from '@dxos/errors';
8
+ import { log } from '@dxos/log';
9
+ import { type Node } from '@dxos/plugin-graph';
10
+ import { ErrorFallback, type ErrorFallbackProps, useTranslation } from '@dxos/react-ui';
11
+ import { descriptionMessage, mx } from '@dxos/ui-theme';
12
+
13
+ import { meta } from '#meta';
14
+
15
+ import { PlankHeading, type PlankHeadingProps } from './PlankHeading';
16
+ import { PlankLoading } from './PlankLoading';
17
+
18
+ export const PlankError = ({
19
+ id,
20
+ part,
21
+ node,
22
+ error: errorProp,
23
+ }: {
24
+ id: string;
25
+ part: PlankHeadingProps['part'];
26
+ node?: Node.Node;
27
+ error?: Error;
28
+ }) => {
29
+ const [timedOut, setTimedOut] = useState(false);
30
+ useEffect(() => {
31
+ const timer = setTimeout(() => setTimedOut(true), 5_000);
32
+ return () => clearTimeout(timer);
33
+ }, []);
34
+
35
+ const error = useMemo(() => {
36
+ if (timedOut) {
37
+ return new TimeoutError({ message: 'Timeout loading content' });
38
+ }
39
+
40
+ return errorProp;
41
+ }, [timedOut, errorProp]);
42
+
43
+ return (
44
+ <>
45
+ <PlankHeading id={id} part={part} node={node} pending={!timedOut} />
46
+ {timedOut ? <PlankErrorFallback error={error} /> : <PlankLoading />}
47
+ </>
48
+ );
49
+ };
50
+
51
+ /**
52
+ * User facing error fallback.
53
+ */
54
+ export const PlankErrorFallback = ({ error }: ErrorFallbackProps) => {
55
+ const { t } = useTranslation(meta.id);
56
+
57
+ useEffect(() => {
58
+ if (error) {
59
+ log.error(error);
60
+ }
61
+ }, [error]);
62
+
63
+ if (process.env.NODE_ENV === 'development') {
64
+ return <ErrorFallback title='Plank Error' error={error} />;
65
+ } else {
66
+ const errorString = error?.toString() ?? '';
67
+ return (
68
+ <div
69
+ role='alert'
70
+ data-testid='plank-content-error'
71
+ className='dx-attention-surface overflow-y-auto p-8 grid place-items-center'
72
+ >
73
+ <p className={mx(descriptionMessage, 'break-all rounded-md p-4')}>
74
+ {error ? errorString : t('error-fallback.message')}
75
+ </p>
76
+ </div>
77
+ );
78
+ }
79
+ };
@@ -4,20 +4,20 @@
4
4
 
5
5
  import React, { Fragment, type MouseEvent, memo, useCallback, useEffect, useMemo } from 'react';
6
6
 
7
- import { Common } from '@dxos/app-framework';
8
- import { Surface, useAppGraph, useOperationInvoker } from '@dxos/app-framework/react';
7
+ import { Surface } from '@dxos/app-framework/ui';
8
+ import { getLinkedVariant } from '@dxos/react-ui-attention';
9
9
  import { Graph, type Node, useActionRunner } from '@dxos/plugin-graph';
10
10
  import { Icon, IconButton, Popover, toLocalizedString, useTranslation } from '@dxos/react-ui';
11
11
  import { StackItem, type StackItemSigilAction } from '@dxos/react-ui-stack';
12
12
  import { TextTooltip } from '@dxos/react-ui-text-tooltip';
13
- import { hoverableControls, hoverableFocusedWithinControls } from '@dxos/ui-theme';
13
+ import { hoverableControls, hoverableFocusedWithinControls, iconSize } from '@dxos/ui-theme';
14
14
 
15
- import { useBreakpoints } from '../../hooks';
16
- import { parseEntryId } from '../../layout';
17
- import { meta } from '../../meta';
18
- import { DeckOperation, type LayoutMode, PLANK_COMPANION_TYPE, type ResolvedPart } from '../../types';
19
- import { soloInlinePadding } from '../fragments';
15
+ import { useBreakpoints } from '#hooks';
16
+ import { meta } from '#meta';
17
+ import { type LayoutMode, PLANK_COMPANION_TYPE, type ResolvedPart } from '#types';
18
+ import { DeckOperation } from '#operations';
20
19
 
20
+ import { usePlankContext } from './PlankRoot';
21
21
  import { PlankCompanionControls, PlankControls } from './PlankControls';
22
22
 
23
23
  const MAX_COMPANIONS = 5;
@@ -55,14 +55,13 @@ export const PlankHeading = memo(
55
55
  actions = [],
56
56
  }: PlankHeadingProps) => {
57
57
  const { t } = useTranslation(meta.id);
58
- const { invokePromise, invokeSync } = useOperationInvoker();
58
+ const { graph, onAdjust, onChangeCompanion } = usePlankContext('PlankHeading');
59
59
  const runAction = useActionRunner();
60
- const { graph } = useAppGraph();
61
60
  const breakpoint = useBreakpoints();
62
61
  const icon = node?.properties?.icon ?? 'ph--placeholder--regular';
63
62
  const label = pending
64
- ? t('pending heading')
65
- : toLocalizedString(node?.properties?.label ?? ['plank heading fallback label', { ns: meta.id }], t);
63
+ ? t('pending.heading')
64
+ : toLocalizedString(node?.properties?.label ?? ['plank-heading-fallback.label', { ns: meta.id }], t);
66
65
 
67
66
  const isCompanionNode = node?.type === PLANK_COMPANION_TYPE;
68
67
 
@@ -70,7 +69,7 @@ export const PlankHeading = memo(
70
69
  const frame = requestAnimationFrame(() => {
71
70
  // Load actions for the node.
72
71
  if (node) {
73
- void Graph.expand(graph, node.id);
72
+ void Graph.expand(graph, node.id, 'child');
74
73
  }
75
74
  });
76
75
 
@@ -81,7 +80,7 @@ export const PlankHeading = memo(
81
80
  const capabilities = useMemo(
82
81
  () => ({
83
82
  deck: deckEnabled ?? true,
84
- solo: breakpoint !== 'mobile' && (part === 'solo' || part === 'deck'),
83
+ solo: breakpoint !== 'mobile' && (part === 'solo' || part === 'multi'),
85
84
  incrementStart: canIncrementStart,
86
85
  incrementEnd: canIncrementEnd,
87
86
  fullscreen: !isCompanionNode,
@@ -90,7 +89,7 @@ export const PlankHeading = memo(
90
89
  [breakpoint, part, companions, canIncrementStart, canIncrementEnd, isCompanionNode, deckEnabled],
91
90
  );
92
91
 
93
- const { variant } = parseEntryId(id);
92
+ const variant = isCompanionNode ? getLinkedVariant(id) : undefined;
94
93
  const sigilActions = useMemo(() => {
95
94
  if (!node) {
96
95
  return undefined;
@@ -99,8 +98,8 @@ export const PlankHeading = memo(
99
98
  } else {
100
99
  return [
101
100
  actions,
102
- Graph.getActions(graph, node.id).filter((a) =>
103
- ['list-item', 'list-item-primary', 'heading-list-item'].includes(a.properties.disposition),
101
+ Graph.getActions(graph, node.id).filter((action) =>
102
+ ['list-item', 'list-item-primary', 'heading-list-item'].includes(action.properties.disposition),
104
103
  ),
105
104
  ].filter((a) => a.length > 0);
106
105
  }
@@ -117,56 +116,47 @@ export const PlankHeading = memo(
117
116
 
118
117
  const handlePlankAction = useCallback(
119
118
  (eventType: DeckOperation.PartAdjustment) => {
120
- if (eventType.startsWith('solo')) {
121
- return invokePromise(DeckOperation.Adjust, { type: eventType, id });
122
- } else if (eventType === 'close') {
123
- if (part === 'complementary') {
124
- return invokeSync(Common.LayoutOperation.UpdateComplementary, { state: 'collapsed' });
125
- } else {
126
- return invokeSync(Common.LayoutOperation.Close, { subject: [id] });
127
- }
128
- } else {
129
- return invokePromise(DeckOperation.Adjust, { type: eventType, id });
130
- }
119
+ onAdjust?.(id, eventType);
131
120
  },
132
- [invokePromise, invokeSync, id, part],
121
+ [onAdjust, id],
133
122
  );
134
123
 
135
- const ActionRoot = node && popoverAnchorId === `dxos.org/ui/${meta.id}/${node.id}` ? Popover.Anchor : Fragment;
124
+ const ActionRoot = node && popoverAnchorId === `${meta.id}:${node.id}` ? Popover.Anchor : Fragment;
136
125
 
137
126
  const handleTabClick = useCallback(
138
127
  (event: MouseEvent) => {
139
128
  const target = (event.target as HTMLElement).closest('[data-id]') as HTMLElement | null;
140
129
  const tabId = target?.dataset?.id;
141
- if (primaryId && tabId) {
142
- void invokePromise(DeckOperation.ChangeCompanion, {
143
- primary: primaryId,
144
- companion: tabId,
145
- });
130
+ if (tabId) {
131
+ onChangeCompanion?.(tabId);
146
132
  }
147
133
  },
148
- [primaryId, invokePromise],
134
+ [onChangeCompanion],
149
135
  );
150
136
 
151
137
  return (
152
138
  <StackItem.Heading
139
+ data-tauri-drag-region
140
+ data-plank-heading
141
+ style={iconSize(5)}
153
142
  classNames={[
154
- 'plb-1 items-stretch gap-1 sticky inline-start-12 app-drag min-is-0 contain-layout density-coarse',
155
- part === 'solo' ? soloInlinePadding : 'pli-1',
143
+ 'py-1 items-stretch gap-1 sticky left-12 dx-app-drag min-w-0 dx-contain-layout dx-density-coarse',
144
+ part === 'solo'
145
+ ? 'ps-[calc(env(safe-area-inset-left)+.25rem)] pe-[calc(env(safe-area-inset-right)+.25rem)]'
146
+ : 'px-1',
156
147
  ...(layoutMode === 'solo--fullscreen'
157
148
  ? [
158
149
  hoverableControls,
159
150
  hoverableFocusedWithinControls,
160
- '*:transition-opacity *:opacity-[--controls-opacity] bg-transparent border-transparent transition-[background-color,border-color]',
161
- 'hover-hover:hover:bg-headerSurface focus-within:bg-headerSurface hover-hover:hover:border-subduedSeparator focus-within:border-subduedSeparator',
151
+ '*:transition-opacity *:opacity-(--controls-opacity) bg-transparent border-transparent transition-[background-color,border-color]',
152
+ 'hover-hover:hover:bg-header-surface focus-within:bg-header-surface hover-hover:hover:border-subdued-separator focus-within:border-subdued-separator',
162
153
  ]
163
154
  : []),
164
155
  ]}
165
- data-plank-heading
166
156
  >
167
157
  {companions && isCompanionNode ? (
168
158
  /* TODO(thure): IMPORTANT: This is a tablist; it should be implemented as such. */
169
- <div role='none' className='flex-1 min-is-0 overflow-x-auto scrollbar-none flex gap-1'>
159
+ <div data-tauri-drag-region role='none' className='flex-1 min-w-0 overflow-x-auto scrollbar-none flex gap-1'>
170
160
  {companions.map(({ id, properties: { icon, label } }) => (
171
161
  <IconButton
172
162
  key={id}
@@ -187,11 +177,11 @@ export const PlankHeading = memo(
187
177
  icon={icon}
188
178
  related={part === 'complementary'}
189
179
  attendableId={attendableId}
190
- triggerLabel={t('actions menu label')}
180
+ triggerLabel={t('actions-menu.label')}
191
181
  actions={sigilActions}
192
182
  onAction={handleAction}
193
183
  >
194
- <Surface role='menu-footer' data={{ subject: node.data }} />
184
+ <Surface.Surface role='menu-footer' data={{ subject: node.data }} />
195
185
  </StackItem.Sigil>
196
186
  ) : (
197
187
  <StackItem.SigilButton>
@@ -202,6 +192,7 @@ export const PlankHeading = memo(
202
192
  </ActionRoot>
203
193
  <TextTooltip text={label} onlyWhenTruncating>
204
194
  <StackItem.HeadingLabel
195
+ data-tauri-drag-region
205
196
  attendableId={attendableId}
206
197
  related={part === 'complementary'}
207
198
  {...(pending && { classNames: 'text-description' })}
@@ -211,7 +202,7 @@ export const PlankHeading = memo(
211
202
  </TextTooltip>
212
203
  </>
213
204
  )}
214
- {node && part !== 'complementary' && <Surface role='navbar-end' data={{ subject: node.data }} />}
205
+ {node && part !== 'complementary' && <Surface.Surface role='navbar-end' data={{ subject: node.data }} />}
215
206
  {companioned === 'companion' ? (
216
207
  <PlankCompanionControls primary={primaryId} />
217
208
  ) : (
@@ -6,5 +6,5 @@ import React from 'react';
6
6
 
7
7
  // TODO(burdon): Show skeleton: https://github.com/dxos/dxos/issues/8259
8
8
  export const PlankLoading = () => {
9
- return <div role='none' className='grid place-items-center attention-surface' />;
9
+ return <div role='none' className='grid place-items-center dx-attention-surface' />;
10
10
  };
@@ -0,0 +1,49 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ import { createContext } from '@radix-ui/react-context';
6
+
7
+ import { type Graph } from '@dxos/plugin-graph';
8
+
9
+ import { type DeckOperation } from '#operations';
10
+ import { type LayoutMode, type PlankSizing, type ResolvedPart, type Settings } from '#types';
11
+ import React, { PropsWithChildren } from 'react';
12
+
13
+ const PLANK_NAME = 'Plank';
14
+
15
+ export type PlankContextValue = {
16
+ /** The application graph. */
17
+ graph: Graph.ExpandableGraph;
18
+ /** Which part of the layout this plank occupies. */
19
+ part: ResolvedPart;
20
+ /** Current layout mode. */
21
+ layoutMode: LayoutMode;
22
+ /** Deck settings. */
23
+ settings?: Settings.Settings;
24
+ /** Popover anchor ID for heading menus. */
25
+ popoverAnchorId?: string;
26
+ /** ID of plank that should be scrolled into view. */
27
+ scrollIntoView?: string;
28
+ /** Persisted plank sizes keyed by plank ID. */
29
+ plankSizing?: PlankSizing;
30
+ /** Callback for plank adjustments (close, solo, increment, companion). */
31
+ onAdjust?: (id: string, type: DeckOperation.PartAdjustment) => void;
32
+ /** Callback for plank resize. */
33
+ onResize?: (id: string, size: number) => void;
34
+ /** Callback to clear scroll-into-view state. */
35
+ onScrollIntoView?: (id?: string) => void;
36
+ /** Callback to change the companion. */
37
+ onChangeCompanion?: (companion: string | null) => void;
38
+ };
39
+
40
+ export const [PlankProvider, usePlankContext] = createContext<PlankContextValue>(PLANK_NAME);
41
+
42
+ export type PlankRootProps = PropsWithChildren<PlankContextValue>;
43
+
44
+ /**
45
+ * Headless root that provides plank context.
46
+ */
47
+ export const PlankRoot = ({ children, ...context }: PlankRootProps) => {
48
+ return <PlankProvider {...context}>{children}</PlankProvider>;
49
+ };
@@ -3,7 +3,5 @@
3
3
  //
4
4
 
5
5
  export * from './Plank';
6
- export * from './PlankControls';
7
6
  export * from './PlankError';
8
- export * from './PlankHeading';
9
7
  export * from './PlankLoading';