@dxos/plugin-deck 0.8.4-main.ead640a → 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 -29
  296. package/src/capabilities/react-surface.tsx +28 -22
  297. package/src/capabilities/settings.ts +29 -20
  298. package/src/capabilities/state.ts +74 -91
  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 +6 -6
  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 -36
  331. package/src/containers/Plank/PlankError.tsx +82 -0
  332. package/src/{components → containers}/Plank/PlankHeading.tsx +68 -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 -10
  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 +25 -3
  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-YYP67JHW.mjs +0 -153
  387. package/dist/lib/browser/app-graph-builder-YYP67JHW.mjs.map +0 -7
  388. package/dist/lib/browser/check-app-scheme-GCOL6YDT.mjs +0 -32
  389. package/dist/lib/browser/check-app-scheme-GCOL6YDT.mjs.map +0 -7
  390. package/dist/lib/browser/chunk-7I6H3N4Q.mjs +0 -162
  391. package/dist/lib/browser/chunk-7I6H3N4Q.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-HUWUYTOI.mjs +0 -16
  395. package/dist/lib/browser/chunk-HUWUYTOI.mjs.map +0 -7
  396. package/dist/lib/browser/chunk-JQKOS2HB.mjs +0 -1531
  397. package/dist/lib/browser/chunk-JQKOS2HB.mjs.map +0 -7
  398. package/dist/lib/browser/chunk-MHP4GPX5.mjs +0 -11
  399. package/dist/lib/browser/chunk-MHP4GPX5.mjs.map +0 -7
  400. package/dist/lib/browser/chunk-RJP5R7PY.mjs +0 -127
  401. package/dist/lib/browser/chunk-RJP5R7PY.mjs.map +0 -7
  402. package/dist/lib/browser/chunk-VX7MMQOW.mjs +0 -129
  403. package/dist/lib/browser/chunk-VX7MMQOW.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-7XNOEPVN.mjs +0 -524
  407. package/dist/lib/browser/intent-resolver-7XNOEPVN.mjs.map +0 -7
  408. package/dist/lib/browser/meta.json +0 -1
  409. package/dist/lib/browser/react-root-OJEF7YCH.mjs +0 -43
  410. package/dist/lib/browser/react-root-OJEF7YCH.mjs.map +0 -7
  411. package/dist/lib/browser/react-surface-XN2NJYHO.mjs +0 -40
  412. package/dist/lib/browser/react-surface-XN2NJYHO.mjs.map +0 -7
  413. package/dist/lib/browser/settings-M3KSKRAP.mjs +0 -30
  414. package/dist/lib/browser/settings-M3KSKRAP.mjs.map +0 -7
  415. package/dist/lib/browser/state-6ZSDTF6Q.mjs +0 -12
  416. package/dist/lib/browser/toolkit-L7C3UAEU.mjs +0 -63
  417. package/dist/lib/browser/toolkit-L7C3UAEU.mjs.map +0 -7
  418. package/dist/lib/browser/types/index.mjs +0 -32
  419. package/dist/lib/browser/url-handler-EHTLXZRR.mjs +0 -70
  420. package/dist/lib/browser/url-handler-EHTLXZRR.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 -6
  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 -472
  471. package/src/capabilities/toolkit.ts +0 -57
  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 -64
  475. package/src/components/DeckLayout/DeckLayout.tsx +0 -32
  476. package/src/components/DeckLayout/DeckMain.tsx +0 -285
  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 -104
  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 -283
  483. package/src/components/Plank/PlankError.tsx +0 -49
  484. package/src/components/Sidebar/ComplementarySidebar.tsx +0 -194
  485. package/src/components/Sidebar/Sidebar.tsx +0 -42
  486. package/src/components/Sidebar/SidebarButton.tsx +0 -87
  487. package/src/components/fragments.ts +0 -14
  488. package/src/events.ts +0 -11
  489. package/src/hooks/useHoistStatusbar.ts +0 -26
  490. package/src/util/overscroll.ts +0 -69
  491. /package/dist/lib/{browser/state-6ZSDTF6Q.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
@@ -1,47 +0,0 @@
1
- import type { CSSProperties } from 'react';
2
- /**
3
- * ┌────────────────────────────────────────────────────────────────────────────────────────────────────┐
4
- * | Overscroll Padding Calculation for Centering Planks on Screen. │
5
- * ├────────────────────────────────────────────────────────────────────────────────────────────────────┤
6
- * │ NOTE(Zan): I found the way you calculate the overscroll padding to center a plank on the screen │
7
- * │ at the edges of the scroll context a bit confusing, so I've diagrammed it here. │
8
- * │ │
9
- * │ Multiple Planks: │
10
- * │ ─────────────── │
11
- * | Use the following overscroll padding calculation centering the boundary planks on the SCREEN. │
12
- * │ │
13
- * │ Left Padding: Right Padding: │
14
- * │ ┌───┬────┬──────────────────┬──────┐ ┌──────┬──────────────────┬────┬───┐ │
15
- * │ │ │████│ Ideal │ │ │ │ Ideal │████│ │ │
16
- * │ │ S │█PL█│ first │ │ │ │ last │█PR█│ C │ │
17
- * │ │ │████│ plank │ │ │ │ plank │████│ │ │
18
- * │ └───┴────┴──────────────────┴──────┘ └──────┴──────────────────┴────┴───┘ │
19
- * │ <--------- screen width -----------> <---------- screen width ----------> │
20
- * │ │
21
- * │ PL = ((screen width - Plank Width) / 2) - S │
22
- * │ PR = ((screen width - Plank Width) / 2) - C │
23
- * │ │
24
- * │ S = Sidebar width C = Complementary sidebar width │
25
- * │ PL = Padding Left PR = Padding Right │
26
- * │ │
27
- * │ Single Plank: │
28
- * │ ───────────── │
29
- * │ For a single plank we use the following overscroll padding calculation to center the plank in │
30
- * │ the content area: │
31
- * │ │
32
- * │ ┌───┬───────────────────────┬───┬───────────────────────┬───┐ │
33
- * │ │ │███████████████████████│ │███████████████████████│ │ │
34
- * │ │ S │█████ Left Padding ████│ P │████ Right Padding ████│ C │ │
35
- * │ │ │███████████████████████│ │███████████████████████│ │ │
36
- * │ └───┴───────────────────────┴───┴───────────────────────┴───┘ │
37
- * │ <------------------------ screen width ---------------------> │
38
- * │ │
39
- * │ Left/Right Padding Width = (screen width - S - P - C) / 2 │
40
- * │ │
41
- * │ S = Sidebar width (may be 0) │
42
- * │ P = Plank width (centered) │
43
- * │ C = Complementary sidebar width (may be 0) │
44
- * └────────────────────────────────────────────────────────────────────────────────────────────────────┘
45
- */
46
- export declare const calculateOverscroll: (planksCount: number) => Pick<CSSProperties, "paddingInlineStart" | "paddingInlineEnd"> | undefined;
47
- //# sourceMappingURL=overscroll.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"overscroll.d.ts","sourceRoot":"","sources":["../../../../src/util/overscroll.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AAE3C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2CG;AACH,eAAO,MAAM,mBAAmB,GAC9B,aAAa,MAAM,KAClB,IAAI,CAAC,aAAa,EAAE,oBAAoB,GAAG,kBAAkB,CAAC,GAAG,SAgBnE,CAAC"}
@@ -1,14 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import { defineCapability } from '@dxos/app-framework';
6
- import { type DeepReadonly } from '@dxos/util';
7
-
8
- import { meta } from '../meta';
9
- import { type DeckPluginState } from '../types';
10
-
11
- export namespace DeckCapabilities {
12
- export const DeckState = defineCapability<DeepReadonly<DeckPluginState>>(`${meta.id}/capability/state`);
13
- export const MutableDeckState = defineCapability<DeckPluginState>(`${meta.id}/capability/state`);
14
- }
@@ -1,472 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import { batch } from '@preact/signals-core';
6
- import * as Effect from 'effect/Effect';
7
- import * as Function from 'effect/Function';
8
- import * as Option from 'effect/Option';
9
- import * as Schema from 'effect/Schema';
10
-
11
- import {
12
- Capabilities,
13
- IntentAction,
14
- LayoutAction,
15
- type PluginContext,
16
- chain,
17
- contributes,
18
- createIntent,
19
- createResolver,
20
- } from '@dxos/app-framework';
21
- import { Obj } from '@dxos/echo';
22
- import { invariant } from '@dxos/invariant';
23
- import { isLiveObject } from '@dxos/live-object';
24
- import { log } from '@dxos/log';
25
- import { AttentionCapabilities } from '@dxos/plugin-attention';
26
- import { isActionLike } from '@dxos/plugin-graph';
27
- import { ObservabilityAction } from '@dxos/plugin-observability/types';
28
- import { byPosition, isNonNullable } from '@dxos/util';
29
-
30
- import { closeEntry, createEntryId, incrementPlank, openEntry } from '../layout';
31
- import { meta } from '../meta';
32
- import {
33
- DeckAction,
34
- type DeckSettingsProps,
35
- type LayoutMode,
36
- PLANK_COMPANION_TYPE,
37
- defaultDeck,
38
- getMode,
39
- isLayoutMode,
40
- } from '../types';
41
- import { setActive } from '../util';
42
-
43
- import { DeckCapabilities } from './capabilities';
44
-
45
- export default (context: PluginContext) =>
46
- contributes(Capabilities.IntentResolver, [
47
- createResolver({
48
- intent: IntentAction.ShowUndo,
49
- resolve: (data) => {
50
- const layout = context.getCapability(DeckCapabilities.MutableDeckState);
51
- const { undoPromise: undo } = context.getCapability(Capabilities.IntentDispatcher);
52
-
53
- // TODO(wittjosiah): Support undoing further back than the last action.
54
- if (layout.currentUndoId) {
55
- layout.toasts = layout.toasts.filter((toast) => toast.id !== layout.currentUndoId);
56
- }
57
- layout.currentUndoId = `${IntentAction.ShowUndo._tag}-${Date.now()}`;
58
- layout.toasts = [
59
- ...layout.toasts,
60
- {
61
- id: layout.currentUndoId,
62
- title: data.message ?? ['undo available label', { ns: meta.id }],
63
- duration: 10_000,
64
- actionLabel: ['undo action label', { ns: meta.id }],
65
- actionAlt: ['undo action alt', { ns: meta.id }],
66
- closeLabel: ['undo close label', { ns: meta.id }],
67
- onAction: () => undo(),
68
- },
69
- ];
70
- },
71
- }),
72
- createResolver({
73
- intent: LayoutAction.UpdateLayout,
74
- // TODO(wittjosiah): This should be able to just be `Schema.is(LayoutAction.UpdateSidebar.fields.input)`
75
- // but the filter is not being applied correctly.
76
- filter: (data): data is Schema.Schema.Type<typeof LayoutAction.UpdateSidebar.fields.input> =>
77
- Schema.is(LayoutAction.UpdateSidebar.fields.input)(data),
78
- resolve: ({ options }) => {
79
- const layout = context.getCapability(DeckCapabilities.MutableDeckState);
80
- const next = options?.state ?? layout.sidebarState;
81
- if (next !== layout.sidebarState) {
82
- layout.sidebarState = next;
83
- }
84
- },
85
- }),
86
- createResolver({
87
- intent: LayoutAction.UpdateLayout,
88
- // TODO(wittjosiah): This should be able to just be `Schema.is(LayoutAction.UpdateComplementary.fields.input)`
89
- // but the filter is not being applied correctly.
90
- filter: (data): data is Schema.Schema.Type<typeof LayoutAction.UpdateComplementary.fields.input> =>
91
- Schema.is(LayoutAction.UpdateComplementary.fields.input)(data),
92
- resolve: ({ subject, options }) => {
93
- const layout = context.getCapability(DeckCapabilities.MutableDeckState);
94
-
95
- if (layout.complementarySidebarPanel !== subject) {
96
- layout.complementarySidebarPanel = subject;
97
- }
98
-
99
- const next = subject ? 'expanded' : (options?.state ?? layout.complementarySidebarState);
100
- if (next !== layout.complementarySidebarState) {
101
- layout.complementarySidebarState = next;
102
- }
103
- },
104
- }),
105
- createResolver({
106
- intent: LayoutAction.UpdateLayout,
107
- // TODO(wittjosiah): This should be able to just be `Schema.is(LayoutAction.UpdateDialog.fields.input)`
108
- // but the filter is not being applied correctly.
109
- filter: (data): data is Schema.Schema.Type<typeof LayoutAction.UpdateDialog.fields.input> =>
110
- Schema.is(LayoutAction.UpdateDialog.fields.input)(data),
111
- resolve: ({ subject, options }) => {
112
- const layout = context.getCapability(DeckCapabilities.MutableDeckState);
113
- layout.dialogOpen = options.state ?? Boolean(subject);
114
- layout.dialogType = options.type ?? 'default';
115
- layout.dialogBlockAlign = options.blockAlign ?? 'center';
116
- layout.dialogOverlayClasses = options.overlayClasses;
117
- layout.dialogOverlayStyle = options.overlayStyle;
118
- layout.dialogContent = subject ? { component: subject, props: options.props } : null;
119
- },
120
- }),
121
- createResolver({
122
- intent: LayoutAction.UpdateLayout,
123
- // TODO(wittjosiah): This should be able to just be `Schema.is(LayoutAction.UpdatePopover.fields.input)`
124
- // but the filter is not being applied correctly.
125
- filter: (data): data is Schema.Schema.Type<typeof LayoutAction.UpdatePopover.fields.input> =>
126
- Schema.is(LayoutAction.UpdatePopover.fields.input)(data),
127
- resolve: ({ subject, options }) => {
128
- const layout = context.getCapability(DeckCapabilities.MutableDeckState);
129
- layout.popoverOpen = options.state ?? Boolean(subject);
130
- layout.popoverContent =
131
- typeof subject === 'string' ? { component: subject, props: options.props } : subject ? { subject } : null;
132
- layout.popoverSide = options.side;
133
- if (options.variant === 'virtual') {
134
- layout.popoverAnchor = options.anchor;
135
- } else {
136
- layout.popoverAnchorId = options.anchorId;
137
- }
138
- },
139
- }),
140
- createResolver({
141
- intent: LayoutAction.UpdateLayout,
142
- // TODO(wittjosiah): This should be able to just be `Schema.is(LayoutAction.AddToast.fields.input)`
143
- // but the filter is not being applied correctly.
144
- filter: (data): data is Schema.Schema.Type<typeof LayoutAction.AddToast.fields.input> =>
145
- Schema.is(LayoutAction.AddToast.fields.input)(data),
146
- resolve: ({ subject }) => {
147
- const layout = context.getCapability(DeckCapabilities.MutableDeckState);
148
- layout.toasts.push(subject);
149
- },
150
- }),
151
- createResolver({
152
- intent: LayoutAction.UpdateLayout,
153
- // TODO(wittjosiah): This should be able to just be `Schema.is(LayoutAction.SetLayoutMode.fields.input)`
154
- // but the filter is not being applied correctly.
155
- filter: (data): data is Schema.Schema.Type<typeof LayoutAction.SetLayoutMode.fields.input> => {
156
- if (!Schema.is(LayoutAction.SetLayoutMode.fields.input)(data)) {
157
- return false;
158
- }
159
-
160
- if ('mode' in data.options) {
161
- return isLayoutMode(data.options.mode);
162
- }
163
-
164
- return true;
165
- },
166
- resolve: ({ subject, options }) => {
167
- const state = context.getCapability(DeckCapabilities.MutableDeckState);
168
-
169
- const setMode = (mode: LayoutMode) => {
170
- const deck = state.deck;
171
- const current = deck.solo ? [deck.solo] : deck.active;
172
- // When un-soloing, the solo entry is added to the deck.
173
- const next = (
174
- mode !== 'deck' ? [subject ?? deck.solo ?? deck.active[0]] : [...deck.active, deck.solo]
175
- ).filter(isNonNullable);
176
-
177
- const removed = current.filter((id) => !next.includes(id));
178
- const closed = Array.from(new Set([...deck.inactive.filter((id) => !next.includes(id)), ...removed]));
179
- deck.inactive = closed;
180
-
181
- if (mode !== 'deck' && next[0]) {
182
- deck.solo = next[0];
183
- } else if (mode === 'deck' && deck.solo) {
184
- deck.solo = undefined;
185
- deck.initialized = true;
186
- }
187
-
188
- if (mode === 'solo--fullscreen') {
189
- deck.fullscreen = !deck.fullscreen;
190
- }
191
- };
192
-
193
- return batch(() => {
194
- if ('mode' in options) {
195
- const current = getMode(state.deck);
196
- if (current !== options.mode) {
197
- state.previousMode[state.activeDeck] = current;
198
- }
199
- setMode(options.mode as LayoutMode);
200
- } else if ('revert' in options) {
201
- const last = state.previousMode[state.activeDeck];
202
- setMode(last ?? 'solo');
203
- } else {
204
- log.warn('Invalid layout mode', options);
205
- }
206
- });
207
- },
208
- }),
209
- createResolver({
210
- intent: LayoutAction.UpdateLayout,
211
- filter: (data): data is Schema.Schema.Type<typeof LayoutAction.SwitchWorkspace.fields.input> =>
212
- Schema.is(LayoutAction.SwitchWorkspace.fields.input)(data),
213
- resolve: ({ subject }) => {
214
- const { graph } = context.getCapability(Capabilities.AppGraph);
215
- const state = context.getCapability(DeckCapabilities.MutableDeckState);
216
- batch(() => {
217
- // TODO(wittjosiah): This is a hack to prevent the previous deck from being set for pinned items.
218
- // Ideally this should be worked into the data model in a generic way.
219
- if (!state.activeDeck.startsWith('!')) {
220
- state.previousDeck = state.activeDeck;
221
- }
222
- state.activeDeck = subject;
223
- if (!state.decks[subject]) {
224
- state.decks[subject] = { ...defaultDeck };
225
- }
226
- });
227
-
228
- const first = state.deck.solo ? state.deck.solo : state.deck.active[0];
229
- if (first) {
230
- return {
231
- intents: [createIntent(LayoutAction.ScrollIntoView, { part: 'current', subject: first })],
232
- };
233
- } else {
234
- const [item] = graph
235
- .getConnections(subject)
236
- .filter((node) => !isActionLike(node) && !node.properties.disposition);
237
- if (item) {
238
- return {
239
- intents: [createIntent(LayoutAction.Open, { part: 'main', subject: [item.id] })],
240
- };
241
- }
242
- }
243
- },
244
- }),
245
- createResolver({
246
- intent: LayoutAction.UpdateLayout,
247
- filter: (data): data is Schema.Schema.Type<typeof LayoutAction.RevertWorkspace.fields.input> =>
248
- Schema.is(LayoutAction.RevertWorkspace.fields.input)(data),
249
- resolve: () => {
250
- const state = context.getCapability(DeckCapabilities.MutableDeckState);
251
- return {
252
- intents: [createIntent(LayoutAction.SwitchWorkspace, { part: 'workspace', subject: state.previousDeck })],
253
- };
254
- },
255
- }),
256
- createResolver({
257
- intent: LayoutAction.UpdateLayout,
258
- filter: (data): data is Schema.Schema.Type<typeof LayoutAction.Open.fields.input> =>
259
- Schema.is(LayoutAction.Open.fields.input)(data),
260
- resolve: ({ subject, options }) =>
261
- Effect.gen(function* () {
262
- const { graph } = context.getCapability(Capabilities.AppGraph);
263
- const state = context.getCapability(DeckCapabilities.MutableDeckState);
264
- const attention = context.getCapability(AttentionCapabilities.Attention);
265
- const settings = context
266
- .getCapabilities(Capabilities.SettingsStore)[0]
267
- ?.getStore<DeckSettingsProps>(meta.id)?.value;
268
-
269
- if (options?.workspace && state.activeDeck !== options?.workspace) {
270
- const { dispatch } = context.getCapability(Capabilities.IntentDispatcher);
271
- yield* dispatch(
272
- createIntent(LayoutAction.SwitchWorkspace, { part: 'workspace', subject: options.workspace }),
273
- );
274
- }
275
-
276
- const previouslyOpenIds = new Set<string>(state.deck.solo ? [state.deck.solo] : state.deck.active);
277
- batch(() => {
278
- const next = state.deck.solo
279
- ? (subject as string[]).map((id) => createEntryId(id, options?.variant))
280
- : subject.reduce(
281
- (acc, entryId) =>
282
- openEntry(acc, entryId, {
283
- key: options?.key,
284
- positioning: options?.positioning ?? settings?.newPlankPositioning,
285
- pivotId: options?.pivotId,
286
- variant: options?.variant,
287
- }),
288
- state.deck.active,
289
- );
290
-
291
- return setActive({ next, state, attention });
292
- });
293
-
294
- const ids = state.deck.solo ? [state.deck.solo] : state.deck.active;
295
- const newlyOpen = ids.filter((i) => !previouslyOpenIds.has(i));
296
-
297
- return {
298
- intents: [
299
- ...(options?.scrollIntoView !== false
300
- ? [createIntent(LayoutAction.ScrollIntoView, { part: 'current', subject: newlyOpen[0] ?? subject[0] })]
301
- : []),
302
- createIntent(LayoutAction.Expose, { part: 'navigation', subject: newlyOpen[0] ?? subject[0] }),
303
- ...newlyOpen.map((subjectId) => {
304
- const typename = Option.match(graph.getNode(subjectId), {
305
- onNone: () => undefined,
306
- onSome: (node) => {
307
- const active = node.data;
308
- return isLiveObject(active) ? Obj.getTypename(active) : undefined;
309
- },
310
- });
311
- return createIntent(ObservabilityAction.SendEvent, {
312
- name: 'navigation.activate',
313
- properties: {
314
- subjectId,
315
- typename,
316
- },
317
- });
318
- }),
319
- ],
320
- };
321
- }),
322
- }),
323
- createResolver({
324
- intent: LayoutAction.UpdateLayout,
325
- filter: (data): data is Schema.Schema.Type<typeof LayoutAction.Close.fields.input> =>
326
- Schema.is(LayoutAction.Close.fields.input)(data),
327
- resolve: ({ subject }) => {
328
- const state = context.getCapability(DeckCapabilities.MutableDeckState);
329
- const attention = context.getCapability(AttentionCapabilities.Attention);
330
- const active = state.deck.solo ? [state.deck.solo] : state.deck.active;
331
- const next = subject.reduce((acc, id) => closeEntry(acc, id), active);
332
- const toAttend = setActive({ next, state, attention });
333
-
334
- const clearCompanionIntents = subject
335
- .filter((id) => state.deck.activeCompanions && id in state.deck.activeCompanions)
336
- .map((primary) => createIntent(DeckAction.ChangeCompanion, { primary, companion: null }));
337
-
338
- return {
339
- intents: [
340
- ...clearCompanionIntents,
341
- ...(toAttend ? [createIntent(LayoutAction.ScrollIntoView, { part: 'current', subject: toAttend })] : []),
342
- ],
343
- };
344
- },
345
- }),
346
- createResolver({
347
- intent: LayoutAction.UpdateLayout,
348
- filter: (data): data is Schema.Schema.Type<typeof LayoutAction.Set.fields.input> =>
349
- Schema.is(LayoutAction.Set.fields.input)(data),
350
- resolve: ({ subject }) => {
351
- const state = context.getCapability(DeckCapabilities.MutableDeckState);
352
- const attention = context.getCapability(AttentionCapabilities.Attention);
353
- const toAttend = setActive({ next: subject as string[], state, attention });
354
- return {
355
- intents: toAttend ? [createIntent(LayoutAction.ScrollIntoView, { part: 'current', subject: toAttend })] : [],
356
- };
357
- },
358
- }),
359
- createResolver({
360
- intent: LayoutAction.UpdateLayout,
361
- filter: (data): data is Schema.Schema.Type<typeof LayoutAction.ScrollIntoView.fields.input> =>
362
- Schema.is(LayoutAction.ScrollIntoView.fields.input)(data),
363
- resolve: ({ subject }) => {
364
- const layout = context.getCapability(DeckCapabilities.MutableDeckState);
365
- layout.scrollIntoView = subject;
366
- },
367
- }),
368
- createResolver({
369
- intent: DeckAction.UpdatePlankSize,
370
- resolve: (data) => {
371
- const state = context.getCapability(DeckCapabilities.MutableDeckState);
372
- state.deck.plankSizing[data.id] = data.size;
373
- },
374
- }),
375
- createResolver({
376
- intent: DeckAction.ChangeCompanion,
377
- resolve: (data) => {
378
- const state = context.getCapability(DeckCapabilities.MutableDeckState);
379
- // TODO(thure): Reactivity only works when creating a lexically new `activeCompanions`… Are these not proxy objects?
380
- if (data.companion === null) {
381
- const { [data.primary]: _, ...nextActiveCompanions } = state.deck.activeCompanions ?? {};
382
- state.deck.activeCompanions = nextActiveCompanions;
383
- } else {
384
- invariant(data.companion !== data.primary);
385
- state.deck.activeCompanions = {
386
- ...state.deck.activeCompanions,
387
- [data.primary]: data.companion,
388
- };
389
- }
390
- },
391
- }),
392
- createResolver({
393
- intent: DeckAction.Adjust,
394
- resolve: (adjustment) => {
395
- const state = context.getCapability(DeckCapabilities.MutableDeckState);
396
- const attention = context.getCapability(AttentionCapabilities.Attention);
397
- const { graph } = context.getCapability(Capabilities.AppGraph);
398
-
399
- return batch(() => {
400
- if (adjustment.type === 'increment-end' || adjustment.type === 'increment-start') {
401
- setActive({
402
- next: incrementPlank(state.deck.active, adjustment),
403
- state,
404
- attention,
405
- });
406
- }
407
-
408
- if (adjustment.type === 'companion') {
409
- return Function.pipe(
410
- graph.getNode(adjustment.id),
411
- Option.map((node) =>
412
- graph
413
- .getConnections(node.id)
414
- .filter((n) => n.type === PLANK_COMPANION_TYPE)
415
- .toSorted((a, b) => byPosition(a.properties, b.properties)),
416
- ),
417
- Option.flatMap((companions) => (companions.length > 0 ? Option.some(companions[0]) : Option.none())),
418
- Option.match({
419
- onNone: () => ({}),
420
- onSome: (companion) => ({
421
- intents: [
422
- // TODO(wittjosiah): This should remember the previously selected companion.
423
- createIntent(DeckAction.ChangeCompanion, { primary: adjustment.id, companion: companion.id }),
424
- ],
425
- }),
426
- }),
427
- );
428
- }
429
-
430
- if (adjustment.type.startsWith('solo')) {
431
- const entryId = adjustment.id;
432
- if (!state.deck.solo) {
433
- // Solo the entry.
434
- return {
435
- intents: [
436
- createIntent(LayoutAction.SetLayoutMode, {
437
- part: 'mode',
438
- subject: entryId,
439
- options: { mode: adjustment.type },
440
- }),
441
- ],
442
- };
443
- } else {
444
- if (adjustment.type === 'solo--fullscreen') {
445
- // Toggle fullscreen on the current entry.
446
- return {
447
- intents: [
448
- createIntent(LayoutAction.SetLayoutMode, {
449
- part: 'mode',
450
- subject: entryId,
451
- options: { mode: 'solo--fullscreen' },
452
- }),
453
- ],
454
- };
455
- } else if (adjustment.type === 'solo') {
456
- // Un-solo the current entry.
457
- return {
458
- intents: [
459
- // NOTE: The order of these is important.
460
- Function.pipe(
461
- createIntent(LayoutAction.SetLayoutMode, { part: 'mode', options: { mode: 'deck' } }),
462
- chain(LayoutAction.Open, { part: 'main', subject: [entryId] }),
463
- ),
464
- ],
465
- };
466
- }
467
- }
468
- }
469
- });
470
- },
471
- }),
472
- ]);
@@ -1,57 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import * as Tool from '@effect/ai/Tool';
6
- import * as Toolkit from '@effect/ai/Toolkit';
7
- import * as Effect from 'effect/Effect';
8
- import * as Schema from 'effect/Schema';
9
-
10
- import { Capabilities, LayoutAction, type PluginContext, contributes, createIntent } from '@dxos/app-framework';
11
- import { ArtifactId } from '@dxos/assistant';
12
- import { type SpaceId } from '@dxos/keys';
13
- import { trim } from '@dxos/util';
14
-
15
- import { DeckCapabilities } from './capabilities';
16
-
17
- class DeckToolkit extends Toolkit.make(
18
- Tool.make('open-item', {
19
- description: trim`
20
- Opens an item in the application.
21
- `,
22
- parameters: {
23
- id: ArtifactId,
24
- },
25
- success: Schema.Any,
26
- failure: Schema.Never,
27
- }),
28
- ) {
29
- static layer = (context: PluginContext) =>
30
- DeckToolkit.toLayer({
31
- 'open-item': ({ id }) =>
32
- Effect.gen(function* () {
33
- const state = context.getCapability(DeckCapabilities.DeckState);
34
- const dxn = ArtifactId.toDXN(id, state.activeDeck as SpaceId);
35
-
36
- // TODO(wittjosiah): Support other variants.
37
- const echoDxn = dxn.asEchoDXN();
38
- if (!echoDxn) {
39
- throw new Error(`Invalid object ID: ${id}`);
40
- }
41
-
42
- // TODO(wittjosiah): Get capabilities via layers.
43
- const { dispatch } = context.getCapability(Capabilities.IntentDispatcher);
44
- yield* dispatch(
45
- createIntent(LayoutAction.Open, {
46
- subject: [`${echoDxn.spaceId!}:${echoDxn.echoId}`],
47
- part: 'main',
48
- }),
49
- );
50
- }).pipe(Effect.orDie),
51
- });
52
- }
53
-
54
- export default (context: PluginContext) => [
55
- contributes(Capabilities.Toolkit, DeckToolkit),
56
- contributes(Capabilities.ToolkitHandler, DeckToolkit.layer(context)),
57
- ];
@@ -1,39 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import React from 'react';
6
-
7
- import { Surface } from '@dxos/app-framework';
8
- import { type ThemedClassName, useTranslation } from '@dxos/react-ui';
9
- import { mx } from '@dxos/react-ui-theme';
10
-
11
- import { meta } from '../../meta';
12
- import { CloseSidebarButton, ToggleSidebarButton } from '../Sidebar';
13
-
14
- export const Banner = ({ variant, classNames }: ThemedClassName<{ variant?: 'topbar' | 'sidebar' }>) => {
15
- const { t } = useTranslation(meta.id);
16
- return (
17
- <header
18
- className={mx(
19
- 'flex items-stretch relative plb-1 pis-1 pie-2',
20
- variant === 'topbar' &&
21
- 'fixed inset-inline-0 block-start-[env(safe-area-inset-top)] bs-[--rail-size] border-be border-separator',
22
- classNames,
23
- )}
24
- >
25
- {variant === 'sidebar' ? <CloseSidebarButton /> : <ToggleSidebarButton />}
26
- <span className='self-center grow mis-1'>{t('current app name', { ns: 'appkit' })}</span>
27
- {variant === 'topbar' && (
28
- <div role='none' className='absolute inset-0 pointer-events-none'>
29
- <div role='none' className='grid bs-full pointer-fine:p-1 max-is-md mli-auto pointer-events-auto'>
30
- <Surface role='search-input' limit={1} />
31
- </div>
32
- </div>
33
- )}
34
- <span role='none' className='grow' />
35
- <Surface role='header-end' limit={1} />
36
- <Surface role='notch-start' limit={1} />
37
- </header>
38
- );
39
- };
@@ -1,31 +0,0 @@
1
- //
2
- // Copyright 2023 DXOS.org
3
- //
4
-
5
- import React from 'react';
6
-
7
- import { Surface, useCapability } from '@dxos/app-framework';
8
-
9
- import { DeckCapabilities } from '../../capabilities';
10
- import { useBreakpoints } from '../../hooks';
11
- import { getMode } from '../../types';
12
- import { layoutAppliesTopbar } from '../../util';
13
- import { fixedSidebarToggleStyles } from '../fragments';
14
- import { ToggleSidebarButton } from '../Sidebar';
15
-
16
- export const ContentEmpty = () => {
17
- const breakpoint = useBreakpoints();
18
- const { deck } = useCapability(DeckCapabilities.MutableDeckState);
19
- const layoutMode = getMode(deck);
20
- const topbar = layoutAppliesTopbar(breakpoint, layoutMode);
21
- return (
22
- <div
23
- role='none'
24
- className='grid place-items-center p-8 relative bg-deckSurface'
25
- data-testid='layoutPlugin.firstRunMessage'
26
- >
27
- <Surface role='keyshortcuts' />
28
- {!topbar && <ToggleSidebarButton variant='default' classNames={fixedSidebarToggleStyles} />}
29
- </div>
30
- );
31
- };