@dxos/plugin-deck 0.8.4-main.937b3ca → 0.8.4-main.9be5663bfe

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 (531) hide show
  1. package/dist/lib/browser/add-toast-HW74YZHJ.mjs +24 -0
  2. package/dist/lib/browser/add-toast-HW74YZHJ.mjs.map +7 -0
  3. package/dist/lib/browser/adjust-OXVHZTBE.mjs +96 -0
  4. package/dist/lib/browser/adjust-OXVHZTBE.mjs.map +7 -0
  5. package/dist/lib/browser/change-companion-Z3Q2UPX4.mjs +34 -0
  6. package/dist/lib/browser/change-companion-Z3Q2UPX4.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-BRZAVPMC.mjs +48 -0
  10. package/dist/lib/browser/chunk-BRZAVPMC.mjs.map +7 -0
  11. package/dist/lib/browser/chunk-DF2VZ6W3.mjs +69 -0
  12. package/dist/lib/browser/chunk-DF2VZ6W3.mjs.map +7 -0
  13. package/dist/lib/browser/chunk-GFOCQS7S.mjs +216 -0
  14. package/dist/lib/browser/chunk-GFOCQS7S.mjs.map +7 -0
  15. package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
  16. package/dist/lib/browser/chunk-J5LGTIGS.mjs.map +7 -0
  17. package/dist/lib/browser/chunk-KUTDCWZF.mjs +30 -0
  18. package/dist/lib/browser/chunk-KUTDCWZF.mjs.map +7 -0
  19. package/dist/lib/browser/close-N5FCDT7Y.mjs +44 -0
  20. package/dist/lib/browser/close-N5FCDT7Y.mjs.map +7 -0
  21. package/dist/lib/browser/index.mjs +147 -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-J5HV42UN.mjs +150 -0
  25. package/dist/lib/browser/open-J5HV42UN.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-VWNN7RYF.mjs +21 -0
  29. package/dist/lib/browser/revert-workspace-VWNN7RYF.mjs.map +7 -0
  30. package/dist/lib/browser/scroll-into-view-CA7E3PSO.mjs +21 -0
  31. package/dist/lib/browser/scroll-into-view-CA7E3PSO.mjs.map +7 -0
  32. package/dist/lib/browser/set-YVWQQZLE.mjs +37 -0
  33. package/dist/lib/browser/set-YVWQQZLE.mjs.map +7 -0
  34. package/dist/lib/browser/set-layout-mode-DRNBZHE7.mjs +90 -0
  35. package/dist/lib/browser/set-layout-mode-DRNBZHE7.mjs.map +7 -0
  36. package/dist/lib/browser/show-undo-KA2XHQ6E.mjs +59 -0
  37. package/dist/lib/browser/show-undo-KA2XHQ6E.mjs.map +7 -0
  38. package/dist/lib/browser/switch-workspace-U7SPENHU.mjs +68 -0
  39. package/dist/lib/browser/switch-workspace-U7SPENHU.mjs.map +7 -0
  40. package/dist/lib/browser/types/index.mjs +8 -15
  41. package/dist/lib/browser/update-complementary-W6UVLWLI.mjs +28 -0
  42. package/dist/lib/browser/update-complementary-W6UVLWLI.mjs.map +7 -0
  43. package/dist/lib/browser/update-dialog-VCTI7WKS.mjs +29 -0
  44. package/dist/lib/browser/update-dialog-VCTI7WKS.mjs.map +7 -0
  45. package/dist/lib/browser/update-plank-size-6TPVOYLT.mjs +28 -0
  46. package/dist/lib/browser/update-plank-size-6TPVOYLT.mjs.map +7 -0
  47. package/dist/lib/browser/update-popover-4EVVZSB6.mjs +33 -0
  48. package/dist/lib/browser/update-popover-4EVVZSB6.mjs.map +7 -0
  49. package/dist/lib/browser/update-sidebar-PAZARC4Q.mjs +25 -0
  50. package/dist/lib/browser/update-sidebar-PAZARC4Q.mjs.map +7 -0
  51. package/dist/lib/node-esm/add-toast-FA7NTWKA.mjs +25 -0
  52. package/dist/lib/node-esm/add-toast-FA7NTWKA.mjs.map +7 -0
  53. package/dist/lib/node-esm/adjust-G6FGZW6H.mjs +97 -0
  54. package/dist/lib/node-esm/adjust-G6FGZW6H.mjs.map +7 -0
  55. package/dist/lib/node-esm/change-companion-V6343HMY.mjs +35 -0
  56. package/dist/lib/node-esm/change-companion-V6343HMY.mjs.map +7 -0
  57. package/dist/lib/node-esm/chunk-6BWQJDNT.mjs +217 -0
  58. package/dist/lib/node-esm/chunk-6BWQJDNT.mjs.map +7 -0
  59. package/dist/lib/node-esm/chunk-GI5JXNBT.mjs +89 -0
  60. package/dist/lib/node-esm/chunk-GI5JXNBT.mjs.map +7 -0
  61. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +11 -0
  62. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs.map +7 -0
  63. package/dist/lib/node-esm/chunk-IRWCUYJY.mjs +71 -0
  64. package/dist/lib/node-esm/chunk-IRWCUYJY.mjs.map +7 -0
  65. package/dist/lib/node-esm/chunk-MB4SDDVY.mjs +50 -0
  66. package/dist/lib/node-esm/chunk-MB4SDDVY.mjs.map +7 -0
  67. package/dist/lib/node-esm/chunk-MLVJ2ODW.mjs +32 -0
  68. package/dist/lib/node-esm/chunk-MLVJ2ODW.mjs.map +7 -0
  69. package/dist/lib/node-esm/close-AMA63RJN.mjs +45 -0
  70. package/dist/lib/node-esm/close-AMA63RJN.mjs.map +7 -0
  71. package/dist/lib/node-esm/index.mjs +147 -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-KRCARMEB.mjs +151 -0
  75. package/dist/lib/node-esm/open-KRCARMEB.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-A2K3JQFS.mjs +22 -0
  79. package/dist/lib/node-esm/revert-workspace-A2K3JQFS.mjs.map +7 -0
  80. package/dist/lib/node-esm/scroll-into-view-B2U4RQK7.mjs +22 -0
  81. package/dist/lib/node-esm/scroll-into-view-B2U4RQK7.mjs.map +7 -0
  82. package/dist/lib/node-esm/set-HCWNW76S.mjs +38 -0
  83. package/dist/lib/node-esm/set-HCWNW76S.mjs.map +7 -0
  84. package/dist/lib/node-esm/set-layout-mode-E27AI5KE.mjs +91 -0
  85. package/dist/lib/node-esm/set-layout-mode-E27AI5KE.mjs.map +7 -0
  86. package/dist/lib/node-esm/show-undo-YTZXH422.mjs +60 -0
  87. package/dist/lib/node-esm/show-undo-YTZXH422.mjs.map +7 -0
  88. package/dist/lib/node-esm/switch-workspace-AQCNGS4Y.mjs +69 -0
  89. package/dist/lib/node-esm/switch-workspace-AQCNGS4Y.mjs.map +7 -0
  90. package/dist/lib/node-esm/types/index.mjs +8 -15
  91. package/dist/lib/node-esm/update-complementary-7HIRM7OT.mjs +29 -0
  92. package/dist/lib/node-esm/update-complementary-7HIRM7OT.mjs.map +7 -0
  93. package/dist/lib/node-esm/update-dialog-F3JF7MBZ.mjs +30 -0
  94. package/dist/lib/node-esm/update-dialog-F3JF7MBZ.mjs.map +7 -0
  95. package/dist/lib/node-esm/update-plank-size-IIZKU7YR.mjs +29 -0
  96. package/dist/lib/node-esm/update-plank-size-IIZKU7YR.mjs.map +7 -0
  97. package/dist/lib/node-esm/update-popover-RO5QEH4C.mjs +34 -0
  98. package/dist/lib/node-esm/update-popover-RO5QEH4C.mjs.map +7 -0
  99. package/dist/lib/node-esm/update-sidebar-2RX6VLEK.mjs +26 -0
  100. package/dist/lib/node-esm/update-sidebar-2RX6VLEK.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 +210 -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.d.ts +18 -0
  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} +33 -17
  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 +71 -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 +1 -1
  127. package/dist/types/src/components/DeckSettings/index.d.ts.map +1 -1
  128. package/dist/types/src/components/Matrix/Matrix.d.ts +41 -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 +71 -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 +73 -0
  153. package/dist/types/src/containers/DeckLayout/DeckLayout.stories.d.ts.map +1 -0
  154. package/dist/types/src/containers/DeckLayout/Dialog.d.ts.map +1 -0
  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 +17 -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 +71 -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 +10 -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/containers/Sidebar/Sidebar.d.ts.map +1 -0
  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 +20 -9
  201. package/dist/types/src/layout.d.ts.map +1 -1
  202. package/dist/types/src/layout.test.d.ts +2 -0
  203. package/dist/types/src/layout.test.d.ts.map +1 -0
  204. package/dist/types/src/operations/add-toast.d.ts +5 -0
  205. package/dist/types/src/operations/add-toast.d.ts.map +1 -0
  206. package/dist/types/src/operations/adjust.d.ts +5 -0
  207. package/dist/types/src/operations/adjust.d.ts.map +1 -0
  208. package/dist/types/src/operations/change-companion.d.ts +5 -0
  209. package/dist/types/src/operations/change-companion.d.ts.map +1 -0
  210. package/dist/types/src/operations/close.d.ts +5 -0
  211. package/dist/types/src/operations/close.d.ts.map +1 -0
  212. package/dist/types/src/operations/definitions.d.ts +18 -0
  213. package/dist/types/src/operations/definitions.d.ts.map +1 -0
  214. package/dist/types/src/operations/helpers.d.ts +3 -0
  215. package/dist/types/src/operations/helpers.d.ts.map +1 -0
  216. package/dist/types/src/operations/index.d.ts +4 -0
  217. package/dist/types/src/operations/index.d.ts.map +1 -0
  218. package/dist/types/src/operations/open.d.ts +5 -0
  219. package/dist/types/src/operations/open.d.ts.map +1 -0
  220. package/dist/types/src/operations/revert-workspace.d.ts +5 -0
  221. package/dist/types/src/operations/revert-workspace.d.ts.map +1 -0
  222. package/dist/types/src/operations/scroll-into-view.d.ts +5 -0
  223. package/dist/types/src/operations/scroll-into-view.d.ts.map +1 -0
  224. package/dist/types/src/operations/set-layout-mode.d.ts +9 -0
  225. package/dist/types/src/operations/set-layout-mode.d.ts.map +1 -0
  226. package/dist/types/src/operations/set.d.ts +5 -0
  227. package/dist/types/src/operations/set.d.ts.map +1 -0
  228. package/dist/types/src/operations/show-undo.d.ts +5 -0
  229. package/dist/types/src/operations/show-undo.d.ts.map +1 -0
  230. package/dist/types/src/operations/switch-workspace.d.ts +5 -0
  231. package/dist/types/src/operations/switch-workspace.d.ts.map +1 -0
  232. package/dist/types/src/operations/update-complementary.d.ts +5 -0
  233. package/dist/types/src/operations/update-complementary.d.ts.map +1 -0
  234. package/dist/types/src/operations/update-dialog.d.ts +5 -0
  235. package/dist/types/src/operations/update-dialog.d.ts.map +1 -0
  236. package/dist/types/src/operations/update-plank-size.d.ts +5 -0
  237. package/dist/types/src/operations/update-plank-size.d.ts.map +1 -0
  238. package/dist/types/src/operations/update-popover.d.ts +5 -0
  239. package/dist/types/src/operations/update-popover.d.ts.map +1 -0
  240. package/dist/types/src/operations/update-sidebar.d.ts +5 -0
  241. package/dist/types/src/operations/update-sidebar.d.ts.map +1 -0
  242. package/dist/types/src/translations.d.ts +52 -54
  243. package/dist/types/src/translations.d.ts.map +1 -1
  244. package/dist/types/src/types/Settings.d.ts +10 -0
  245. package/dist/types/src/types/Settings.d.ts.map +1 -0
  246. package/dist/types/src/types/capabilities.d.ts +33 -21
  247. package/dist/types/src/types/capabilities.d.ts.map +1 -1
  248. package/dist/types/src/types/events.d.ts.map +1 -1
  249. package/dist/types/src/types/index.d.ts +1 -0
  250. package/dist/types/src/types/index.d.ts.map +1 -1
  251. package/dist/types/src/types/schema.d.ts +48 -96
  252. package/dist/types/src/types/schema.d.ts.map +1 -1
  253. package/dist/types/src/util/index.d.ts +2 -1
  254. package/dist/types/src/util/index.d.ts.map +1 -1
  255. package/dist/types/src/util/layoutAppliesTopbar.d.ts +1 -1
  256. package/dist/types/src/util/layoutAppliesTopbar.d.ts.map +1 -1
  257. package/dist/types/src/util/plank-url-params.d.ts +14 -0
  258. package/dist/types/src/util/plank-url-params.d.ts.map +1 -0
  259. package/dist/types/src/util/plank-url-params.test.d.ts +2 -0
  260. package/dist/types/src/util/plank-url-params.test.d.ts.map +1 -0
  261. package/dist/types/src/util/sanitize-persisted-state.d.ts +19 -0
  262. package/dist/types/src/util/sanitize-persisted-state.d.ts.map +1 -0
  263. package/dist/types/src/util/sanitize-persisted-state.test.d.ts +2 -0
  264. package/dist/types/src/util/sanitize-persisted-state.test.d.ts.map +1 -0
  265. package/dist/types/src/util/set-active.d.ts +2 -2
  266. package/dist/types/src/util/set-active.d.ts.map +1 -1
  267. package/dist/types/src/util/set-active.test.d.ts +2 -0
  268. package/dist/types/src/util/set-active.test.d.ts.map +1 -0
  269. package/dist/types/tsconfig.tsbuildinfo +1 -1
  270. package/package.json +76 -44
  271. package/src/DeckPlugin.ts +17 -21
  272. package/src/capabilities/app-graph-builder.ts +127 -0
  273. package/src/capabilities/check-app-scheme.ts +139 -0
  274. package/src/capabilities/index.ts +14 -10
  275. package/src/capabilities/operation-handler.ts +16 -0
  276. package/src/capabilities/{react-root/react-root.tsx → react-root.tsx} +5 -5
  277. package/src/capabilities/react-surface.tsx +37 -0
  278. package/src/capabilities/{settings/settings.ts → settings.ts} +8 -9
  279. package/src/capabilities/{state/state.ts → state.ts} +18 -31
  280. package/src/capabilities/{tools/tools.ts → tools.ts} +4 -5
  281. package/src/capabilities/url-handler.ts +226 -0
  282. package/src/components/DeckSettings/DeckSettings.stories.tsx +37 -0
  283. package/src/components/DeckSettings/DeckSettings.tsx +55 -95
  284. package/src/components/DeckSettings/index.ts +2 -2
  285. package/src/components/Matrix/Matrix.stories.tsx +216 -0
  286. package/src/components/Matrix/Matrix.tsx +205 -0
  287. package/src/components/Matrix/SPEC.md +219 -0
  288. package/src/components/Matrix/index.ts +6 -0
  289. package/src/components/index.ts +6 -3
  290. package/src/{components/DeckLayout → containers/Deck}/Banner.tsx +11 -9
  291. package/src/containers/Deck/Deck.stories.tsx +81 -0
  292. package/src/containers/Deck/Deck.tsx +21 -0
  293. package/src/containers/Deck/DeckContent.tsx +105 -0
  294. package/src/containers/Deck/DeckRoot.tsx +50 -0
  295. package/src/containers/Deck/DeckViewport.tsx +456 -0
  296. package/src/{components/DeckLayout → containers/Deck}/StatusBar.tsx +4 -4
  297. package/src/containers/Deck/index.ts +5 -0
  298. package/src/{components → containers}/DeckLayout/ActiveNode.tsx +8 -3
  299. package/src/containers/DeckLayout/DeckLayout.stories.tsx +393 -0
  300. package/src/containers/DeckLayout/DeckLayout.tsx +62 -0
  301. package/src/{components → containers}/DeckLayout/Dialog.tsx +12 -5
  302. package/src/containers/DeckLayout/Fallback.tsx +24 -0
  303. package/src/{components → containers}/DeckLayout/Popover.tsx +61 -18
  304. package/src/{components → containers}/DeckLayout/Toast.tsx +4 -4
  305. package/src/{components → containers}/DeckLayout/constants.ts +1 -0
  306. package/src/{components → containers}/DeckLayout/index.ts +3 -2
  307. package/src/containers/Plank/Plank.stories.tsx +106 -0
  308. package/src/containers/Plank/Plank.tsx +22 -0
  309. package/src/containers/Plank/PlankComponent.tsx +180 -0
  310. package/src/containers/Plank/PlankContent.tsx +45 -0
  311. package/src/{components → containers}/Plank/PlankControls.tsx +42 -35
  312. package/src/containers/Plank/PlankError.tsx +79 -0
  313. package/src/{components → containers}/Plank/PlankHeading.tsx +46 -47
  314. package/src/{components → containers}/Plank/PlankLoading.tsx +1 -1
  315. package/src/containers/Plank/PlankRoot.tsx +49 -0
  316. package/src/{components → containers}/Plank/index.ts +0 -2
  317. package/src/containers/Sidebar/ComplementarySidebar.tsx +209 -0
  318. package/src/{components → containers}/Sidebar/Sidebar.tsx +11 -9
  319. package/src/{components → containers}/Sidebar/SidebarButton.tsx +19 -19
  320. package/src/containers/index.ts +11 -0
  321. package/src/hooks/index.ts +1 -0
  322. package/src/hooks/useCompanions.ts +3 -3
  323. package/src/hooks/useDeckCompanions.ts +3 -8
  324. package/src/hooks/useDeckState.ts +14 -23
  325. package/src/hooks/useHoistStatusbar.ts +2 -2
  326. package/src/hooks/useMainSize.ts +2 -2
  327. package/src/hooks/useNodeActionExpander.ts +1 -1
  328. package/src/hooks/useSelectedCompanion.ts +32 -0
  329. package/src/layout.test.ts +59 -0
  330. package/src/layout.ts +38 -40
  331. package/src/meta.ts +1 -1
  332. package/src/operations/add-toast.ts +24 -0
  333. package/src/operations/adjust.ts +83 -0
  334. package/src/operations/change-companion.ts +35 -0
  335. package/src/operations/close.ts +35 -0
  336. package/src/operations/definitions.ts +61 -0
  337. package/src/operations/helpers.ts +22 -0
  338. package/src/operations/index.ts +26 -0
  339. package/src/operations/open.ts +184 -0
  340. package/src/operations/revert-workspace.ts +22 -0
  341. package/src/operations/scroll-into-view.ts +24 -0
  342. package/src/operations/set-layout-mode.ts +84 -0
  343. package/src/operations/set.ts +36 -0
  344. package/src/operations/show-undo.ts +47 -0
  345. package/src/operations/switch-workspace.ts +60 -0
  346. package/src/operations/update-complementary.ts +33 -0
  347. package/src/operations/update-dialog.ts +34 -0
  348. package/src/operations/update-plank-size.ts +29 -0
  349. package/src/operations/update-popover.ts +36 -0
  350. package/src/operations/update-sidebar.ts +28 -0
  351. package/src/translations.ts +52 -54
  352. package/src/types/Settings.ts +17 -0
  353. package/src/types/capabilities.ts +10 -8
  354. package/src/types/events.ts +6 -5
  355. package/src/types/index.ts +1 -0
  356. package/src/types/schema.ts +42 -112
  357. package/src/util/index.ts +2 -1
  358. package/src/util/layoutAppliesTopbar.ts +1 -1
  359. package/src/util/plank-url-params.test.ts +85 -0
  360. package/src/util/plank-url-params.ts +36 -0
  361. package/src/util/sanitize-persisted-state.test.ts +79 -0
  362. package/src/util/sanitize-persisted-state.ts +52 -0
  363. package/src/util/set-active.test.ts +106 -0
  364. package/src/util/set-active.ts +2 -2
  365. package/src/vite-env.d.ts +5 -0
  366. package/dist/lib/browser/app-graph-builder-DTVCULQ4.mjs +0 -120
  367. package/dist/lib/browser/app-graph-builder-DTVCULQ4.mjs.map +0 -7
  368. package/dist/lib/browser/check-app-scheme-JSRXXIYF.mjs +0 -32
  369. package/dist/lib/browser/check-app-scheme-JSRXXIYF.mjs.map +0 -7
  370. package/dist/lib/browser/chunk-ATFPDN6J.mjs +0 -292
  371. package/dist/lib/browser/chunk-ATFPDN6J.mjs.map +0 -7
  372. package/dist/lib/browser/chunk-EREEXCHO.mjs +0 -1448
  373. package/dist/lib/browser/chunk-EREEXCHO.mjs.map +0 -7
  374. package/dist/lib/browser/chunk-NHABISX2.mjs +0 -152
  375. package/dist/lib/browser/chunk-NHABISX2.mjs.map +0 -7
  376. package/dist/lib/browser/chunk-UNG4CLLP.mjs +0 -161
  377. package/dist/lib/browser/chunk-UNG4CLLP.mjs.map +0 -7
  378. package/dist/lib/browser/operation-resolver-CDYBLZJ4.mjs +0 -595
  379. package/dist/lib/browser/operation-resolver-CDYBLZJ4.mjs.map +0 -7
  380. package/dist/lib/browser/react-root-LYNEKGHM.mjs +0 -47
  381. package/dist/lib/browser/react-root-LYNEKGHM.mjs.map +0 -7
  382. package/dist/lib/browser/react-surface-RPKD7XUR.mjs +0 -42
  383. package/dist/lib/browser/react-surface-RPKD7XUR.mjs.map +0 -7
  384. package/dist/lib/browser/settings-OMHVGZ6V.mjs +0 -37
  385. package/dist/lib/browser/settings-OMHVGZ6V.mjs.map +0 -7
  386. package/dist/lib/browser/state-OC3BSB6E.mjs +0 -103
  387. package/dist/lib/browser/state-OC3BSB6E.mjs.map +0 -7
  388. package/dist/lib/browser/toolkit-R53LD3EA.mjs +0 -53
  389. package/dist/lib/browser/toolkit-R53LD3EA.mjs.map +0 -7
  390. package/dist/lib/browser/url-handler-53TE6JZO.mjs +0 -93
  391. package/dist/lib/browser/url-handler-53TE6JZO.mjs.map +0 -7
  392. package/dist/lib/node-esm/app-graph-builder-473BNZDJ.mjs +0 -121
  393. package/dist/lib/node-esm/app-graph-builder-473BNZDJ.mjs.map +0 -7
  394. package/dist/lib/node-esm/check-app-scheme-IVYRHKRH.mjs +0 -33
  395. package/dist/lib/node-esm/check-app-scheme-IVYRHKRH.mjs.map +0 -7
  396. package/dist/lib/node-esm/chunk-ADPMWKLL.mjs +0 -154
  397. package/dist/lib/node-esm/chunk-ADPMWKLL.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-V6VEXRD4.mjs +0 -1449
  401. package/dist/lib/node-esm/chunk-V6VEXRD4.mjs.map +0 -7
  402. package/dist/lib/node-esm/chunk-XAKTY3EB.mjs +0 -294
  403. package/dist/lib/node-esm/chunk-XAKTY3EB.mjs.map +0 -7
  404. package/dist/lib/node-esm/operation-resolver-WUOE33ID.mjs +0 -596
  405. package/dist/lib/node-esm/operation-resolver-WUOE33ID.mjs.map +0 -7
  406. package/dist/lib/node-esm/react-root-L7H43AS3.mjs +0 -48
  407. package/dist/lib/node-esm/react-root-L7H43AS3.mjs.map +0 -7
  408. package/dist/lib/node-esm/react-surface-77DKVMDV.mjs +0 -43
  409. package/dist/lib/node-esm/react-surface-77DKVMDV.mjs.map +0 -7
  410. package/dist/lib/node-esm/settings-2HB6FKIK.mjs +0 -38
  411. package/dist/lib/node-esm/settings-2HB6FKIK.mjs.map +0 -7
  412. package/dist/lib/node-esm/state-JRQ45ACJ.mjs +0 -104
  413. package/dist/lib/node-esm/state-JRQ45ACJ.mjs.map +0 -7
  414. package/dist/lib/node-esm/toolkit-JLPZNNKB.mjs +0 -54
  415. package/dist/lib/node-esm/toolkit-JLPZNNKB.mjs.map +0 -7
  416. package/dist/lib/node-esm/url-handler-QGF2R24T.mjs +0 -94
  417. package/dist/lib/node-esm/url-handler-QGF2R24T.mjs.map +0 -7
  418. package/dist/types/src/capabilities/app-graph-builder/app-graph-builder.d.ts +0 -6
  419. package/dist/types/src/capabilities/app-graph-builder/app-graph-builder.d.ts.map +0 -1
  420. package/dist/types/src/capabilities/app-graph-builder/index.d.ts +0 -3
  421. package/dist/types/src/capabilities/app-graph-builder/index.d.ts.map +0 -1
  422. package/dist/types/src/capabilities/check-app-scheme/check-app-scheme.d.ts +0 -5
  423. package/dist/types/src/capabilities/check-app-scheme/check-app-scheme.d.ts.map +0 -1
  424. package/dist/types/src/capabilities/check-app-scheme/index.d.ts +0 -3
  425. package/dist/types/src/capabilities/check-app-scheme/index.d.ts.map +0 -1
  426. package/dist/types/src/capabilities/operation-resolver/index.d.ts +0 -3
  427. package/dist/types/src/capabilities/operation-resolver/index.d.ts.map +0 -1
  428. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts +0 -5
  429. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts.map +0 -1
  430. package/dist/types/src/capabilities/react-root/index.d.ts +0 -6
  431. package/dist/types/src/capabilities/react-root/index.d.ts.map +0 -1
  432. package/dist/types/src/capabilities/react-root/react-root.d.ts.map +0 -1
  433. package/dist/types/src/capabilities/react-surface/index.d.ts +0 -3
  434. package/dist/types/src/capabilities/react-surface/index.d.ts.map +0 -1
  435. package/dist/types/src/capabilities/react-surface/react-surface.d.ts +0 -5
  436. package/dist/types/src/capabilities/react-surface/react-surface.d.ts.map +0 -1
  437. package/dist/types/src/capabilities/settings/index.d.ts +0 -19
  438. package/dist/types/src/capabilities/settings/index.d.ts.map +0 -1
  439. package/dist/types/src/capabilities/settings/settings.d.ts +0 -21
  440. package/dist/types/src/capabilities/settings/settings.d.ts.map +0 -1
  441. package/dist/types/src/capabilities/state/index.d.ts +0 -172
  442. package/dist/types/src/capabilities/state/index.d.ts.map +0 -1
  443. package/dist/types/src/capabilities/state/state.d.ts.map +0 -1
  444. package/dist/types/src/capabilities/toolkit/index.d.ts +0 -3
  445. package/dist/types/src/capabilities/toolkit/index.d.ts.map +0 -1
  446. package/dist/types/src/capabilities/toolkit/toolkit.d.ts +0 -26
  447. package/dist/types/src/capabilities/toolkit/toolkit.d.ts.map +0 -1
  448. package/dist/types/src/capabilities/tools/index.d.ts +0 -3
  449. package/dist/types/src/capabilities/tools/index.d.ts.map +0 -1
  450. package/dist/types/src/capabilities/tools/tools.d.ts.map +0 -1
  451. package/dist/types/src/capabilities/url-handler/index.d.ts +0 -3
  452. package/dist/types/src/capabilities/url-handler/index.d.ts.map +0 -1
  453. package/dist/types/src/capabilities/url-handler/url-handler.d.ts +0 -5
  454. package/dist/types/src/capabilities/url-handler/url-handler.d.ts.map +0 -1
  455. package/dist/types/src/components/DeckLayout/ActiveNode.d.ts.map +0 -1
  456. package/dist/types/src/components/DeckLayout/Banner.d.ts.map +0 -1
  457. package/dist/types/src/components/DeckLayout/ContentEmpty.d.ts +0 -3
  458. package/dist/types/src/components/DeckLayout/ContentEmpty.d.ts.map +0 -1
  459. package/dist/types/src/components/DeckLayout/DeckLayout.d.ts.map +0 -1
  460. package/dist/types/src/components/DeckLayout/DeckLayout.stories.d.ts +0 -74
  461. package/dist/types/src/components/DeckLayout/DeckLayout.stories.d.ts.map +0 -1
  462. package/dist/types/src/components/DeckLayout/DeckMain.d.ts +0 -3
  463. package/dist/types/src/components/DeckLayout/DeckMain.d.ts.map +0 -1
  464. package/dist/types/src/components/DeckLayout/Dialog.d.ts.map +0 -1
  465. package/dist/types/src/components/DeckLayout/Fallback.d.ts +0 -3
  466. package/dist/types/src/components/DeckLayout/Fallback.d.ts.map +0 -1
  467. package/dist/types/src/components/DeckLayout/Popover.d.ts +0 -5
  468. package/dist/types/src/components/DeckLayout/Popover.d.ts.map +0 -1
  469. package/dist/types/src/components/DeckLayout/StatusBar.d.ts.map +0 -1
  470. package/dist/types/src/components/DeckLayout/Toast.d.ts.map +0 -1
  471. package/dist/types/src/components/DeckLayout/Topbar.d.ts +0 -3
  472. package/dist/types/src/components/DeckLayout/Topbar.d.ts.map +0 -1
  473. package/dist/types/src/components/DeckLayout/constants.d.ts.map +0 -1
  474. package/dist/types/src/components/DeckLayout/index.d.ts +0 -4
  475. package/dist/types/src/components/DeckLayout/index.d.ts.map +0 -1
  476. package/dist/types/src/components/Plank/Plank.d.ts +0 -27
  477. package/dist/types/src/components/Plank/Plank.d.ts.map +0 -1
  478. package/dist/types/src/components/Plank/Plank.stories.d.ts +0 -107
  479. package/dist/types/src/components/Plank/Plank.stories.d.ts.map +0 -1
  480. package/dist/types/src/components/Plank/PlankControls.d.ts.map +0 -1
  481. package/dist/types/src/components/Plank/PlankError.d.ts +0 -13
  482. package/dist/types/src/components/Plank/PlankError.d.ts.map +0 -1
  483. package/dist/types/src/components/Plank/PlankHeading.d.ts.map +0 -1
  484. package/dist/types/src/components/Plank/index.d.ts +0 -6
  485. package/dist/types/src/components/Plank/index.d.ts.map +0 -1
  486. package/dist/types/src/components/Sidebar/ComplementarySidebar.d.ts.map +0 -1
  487. package/dist/types/src/components/Sidebar/Sidebar.d.ts.map +0 -1
  488. package/dist/types/src/components/fragments.d.ts +0 -4
  489. package/dist/types/src/components/fragments.d.ts.map +0 -1
  490. package/dist/types/src/util/overscroll.d.ts +0 -47
  491. package/dist/types/src/util/overscroll.d.ts.map +0 -1
  492. package/src/capabilities/app-graph-builder/app-graph-builder.ts +0 -118
  493. package/src/capabilities/app-graph-builder/index.ts +0 -7
  494. package/src/capabilities/check-app-scheme/check-app-scheme.ts +0 -41
  495. package/src/capabilities/check-app-scheme/index.ts +0 -7
  496. package/src/capabilities/operation-resolver/index.ts +0 -10
  497. package/src/capabilities/operation-resolver/operation-resolver.ts +0 -555
  498. package/src/capabilities/react-root/index.ts +0 -7
  499. package/src/capabilities/react-surface/index.ts +0 -7
  500. package/src/capabilities/react-surface/react-surface.tsx +0 -37
  501. package/src/capabilities/settings/index.ts +0 -7
  502. package/src/capabilities/state/index.ts +0 -7
  503. package/src/capabilities/toolkit/index.ts +0 -7
  504. package/src/capabilities/toolkit/toolkit.ts +0 -63
  505. package/src/capabilities/tools/index.ts +0 -7
  506. package/src/capabilities/url-handler/index.ts +0 -7
  507. package/src/capabilities/url-handler/url-handler.ts +0 -95
  508. package/src/components/DeckLayout/ContentEmpty.tsx +0 -30
  509. package/src/components/DeckLayout/DeckLayout.stories.tsx +0 -51
  510. package/src/components/DeckLayout/DeckLayout.tsx +0 -34
  511. package/src/components/DeckLayout/DeckMain.tsx +0 -286
  512. package/src/components/DeckLayout/Fallback.tsx +0 -28
  513. package/src/components/DeckLayout/Topbar.tsx +0 -11
  514. package/src/components/Plank/Plank.stories.tsx +0 -62
  515. package/src/components/Plank/Plank.tsx +0 -299
  516. package/src/components/Plank/PlankError.tsx +0 -49
  517. package/src/components/Sidebar/ComplementarySidebar.tsx +0 -221
  518. package/src/components/fragments.ts +0 -14
  519. package/src/util/overscroll.ts +0 -69
  520. /package/dist/types/src/{components/DeckLayout → containers/Deck}/Banner.d.ts +0 -0
  521. /package/dist/types/src/{components/DeckLayout → containers/Deck}/StatusBar.d.ts +0 -0
  522. /package/dist/types/src/{components → containers}/DeckLayout/ActiveNode.d.ts +0 -0
  523. /package/dist/types/src/{components → containers}/DeckLayout/DeckLayout.d.ts +0 -0
  524. /package/dist/types/src/{components → containers}/DeckLayout/Dialog.d.ts +0 -0
  525. /package/dist/types/src/{components → containers}/DeckLayout/constants.d.ts +0 -0
  526. /package/dist/types/src/{components → containers}/Plank/PlankLoading.d.ts +0 -0
  527. /package/dist/types/src/{components → containers}/Sidebar/ComplementarySidebar.d.ts +0 -0
  528. /package/dist/types/src/{components → containers}/Sidebar/Sidebar.d.ts +0 -0
  529. /package/dist/types/src/{components → containers}/Sidebar/SidebarButton.d.ts +0 -0
  530. /package/dist/types/src/{components → containers}/Sidebar/index.d.ts +0 -0
  531. /package/src/{components → containers}/Sidebar/index.ts +0 -0
@@ -1,121 +0,0 @@
1
- import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
- import {
3
- DeckCapabilities,
4
- meta
5
- } from "./chunk-XAKTY3EB.mjs";
6
-
7
- // src/capabilities/app-graph-builder/app-graph-builder.ts
8
- import * as Effect from "effect/Effect";
9
- import { Capability, Common } from "@dxos/app-framework";
10
- import { Operation } from "@dxos/operation";
11
- import { AttentionCapabilities } from "@dxos/plugin-attention";
12
- import { GraphBuilder, NodeMatcher } from "@dxos/plugin-graph";
13
- var app_graph_builder_default = Capability.makeModule(Effect.fnUntraced(function* () {
14
- const extensions = yield* GraphBuilder.createExtension({
15
- id: meta.id,
16
- match: NodeMatcher.whenRoot,
17
- actions: (_node, get) => Effect.gen(function* () {
18
- const closeCurrent = {
19
- id: `${Common.LayoutOperation.Close.meta.key}/current`,
20
- data: Effect.fnUntraced(function* () {
21
- const attention = yield* Capability.get(AttentionCapabilities.Attention);
22
- const attended = attention.getCurrent().at(-1);
23
- if (attended) {
24
- yield* Operation.invoke(Common.LayoutOperation.Close, {
25
- subject: [
26
- attended
27
- ]
28
- });
29
- }
30
- }),
31
- properties: {
32
- label: [
33
- "close current label",
34
- {
35
- ns: meta.id
36
- }
37
- ],
38
- icon: "ph--x--regular"
39
- }
40
- };
41
- const closeOthers = {
42
- id: `${Common.LayoutOperation.Close.meta.key}/others`,
43
- data: Effect.fnUntraced(function* () {
44
- const attention = yield* Capability.get(AttentionCapabilities.Attention);
45
- const deck2 = yield* DeckCapabilities.getDeck();
46
- const attended = attention.getCurrent().at(-1);
47
- const ids = deck2.active.filter((id) => id !== attended) ?? [];
48
- yield* Operation.invoke(Common.LayoutOperation.Close, {
49
- subject: ids
50
- });
51
- }),
52
- properties: {
53
- label: [
54
- "close others label",
55
- {
56
- ns: meta.id
57
- }
58
- ],
59
- icon: "ph--x-square--regular"
60
- }
61
- };
62
- const closeAll = {
63
- id: `${Common.LayoutOperation.Close.meta.key}/all`,
64
- data: Effect.fnUntraced(function* () {
65
- const deck2 = yield* DeckCapabilities.getDeck();
66
- yield* Operation.invoke(Common.LayoutOperation.Close, {
67
- subject: deck2.active
68
- });
69
- }),
70
- properties: {
71
- label: [
72
- "close all label",
73
- {
74
- ns: meta.id
75
- }
76
- ],
77
- icon: "ph--x-circle--regular"
78
- }
79
- };
80
- const state = get(yield* Capability.get(DeckCapabilities.State));
81
- const deck = state.decks[state.activeDeck];
82
- const toggleSidebar = {
83
- id: `${Common.LayoutOperation.UpdateSidebar.meta.key}/nav`,
84
- data: Effect.fnUntraced(function* () {
85
- yield* Common.Capability.updateAtomValue(DeckCapabilities.State, (s) => ({
86
- ...s,
87
- sidebarState: s.sidebarState === "expanded" ? "collapsed" : "expanded"
88
- }));
89
- }),
90
- properties: {
91
- label: [
92
- state.sidebarState === "expanded" ? "collapse navigation sidebar label" : "open navigation sidebar label",
93
- {
94
- ns: meta.id
95
- }
96
- ],
97
- icon: "ph--sidebar--regular",
98
- keyBinding: {
99
- macos: "meta+'"
100
- },
101
- disposition: "pin-end",
102
- position: "hoist",
103
- l0Breakpoint: "lg"
104
- }
105
- };
106
- return !deck?.solo ? [
107
- closeCurrent,
108
- closeOthers,
109
- closeAll,
110
- toggleSidebar
111
- ] : [
112
- toggleSidebar
113
- ];
114
- })
115
- });
116
- return Capability.contributes(Common.Capability.AppGraphBuilder, extensions);
117
- }));
118
- export {
119
- app_graph_builder_default as default
120
- };
121
- //# sourceMappingURL=app-graph-builder-473BNZDJ.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/capabilities/app-graph-builder/app-graph-builder.ts"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\n\nimport { Capability, Common } from '@dxos/app-framework';\nimport { Operation } from '@dxos/operation';\nimport { AttentionCapabilities } from '@dxos/plugin-attention';\nimport { GraphBuilder, NodeMatcher } from '@dxos/plugin-graph';\n\nimport { meta } from '../../meta';\nimport { DeckCapabilities } from '../../types';\n\nexport default Capability.makeModule(\n Effect.fnUntraced(function* () {\n const extensions = yield* GraphBuilder.createExtension({\n id: meta.id,\n match: NodeMatcher.whenRoot,\n actions: (_node, get) =>\n Effect.gen(function* () {\n // NOTE(Zan): This is currently disabled.\n // TODO(Zan): Fullscreen needs to know the active node and provide that to the layout part.\n // const _fullscreen = {\n // id: `${LayoutAction.UpdateLayout._tag}/fullscreen`,\n // data: async () => {\n // const { dispatchPromise: dispatch } = context.get(Capabilities.IntentDispatcher);\n // await dispatch(\n // createIntent(LayoutAction.SetLayoutMode, { part: 'mode', options: { mode: 'fullscreen' } }),\n // );\n // },\n // properties: {\n // label: ['toggle fullscreen label', { ns: meta.id }],\n // icon: 'ph--arrows-out--regular',\n // keyBinding: {\n // macos: 'ctrl+meta+f',\n // windows: 'shift+ctrl+f',\n // },\n // },\n // };\n\n const closeCurrent = {\n id: `${Common.LayoutOperation.Close.meta.key}/current`,\n data: Effect.fnUntraced(function* () {\n const attention = yield* Capability.get(AttentionCapabilities.Attention);\n const attended = attention.getCurrent().at(-1);\n if (attended) {\n yield* Operation.invoke(Common.LayoutOperation.Close, { subject: [attended] });\n }\n }),\n properties: {\n label: ['close current label', { ns: meta.id }],\n icon: 'ph--x--regular',\n },\n };\n\n const closeOthers = {\n id: `${Common.LayoutOperation.Close.meta.key}/others`,\n data: Effect.fnUntraced(function* () {\n const attention = yield* Capability.get(AttentionCapabilities.Attention);\n const deck = yield* DeckCapabilities.getDeck();\n const attended = attention.getCurrent().at(-1);\n const ids = deck.active.filter((id: string) => id !== attended) ?? [];\n yield* Operation.invoke(Common.LayoutOperation.Close, { subject: ids });\n }),\n properties: {\n label: ['close others label', { ns: meta.id }],\n icon: 'ph--x-square--regular',\n },\n };\n\n const closeAll = {\n id: `${Common.LayoutOperation.Close.meta.key}/all`,\n data: Effect.fnUntraced(function* () {\n const deck = yield* DeckCapabilities.getDeck();\n yield* Operation.invoke(Common.LayoutOperation.Close, { subject: deck.active });\n }),\n properties: {\n label: ['close all label', { ns: meta.id }],\n icon: 'ph--x-circle--regular',\n },\n };\n\n const state = get(yield* Capability.get(DeckCapabilities.State));\n const deck = state.decks[state.activeDeck];\n\n const toggleSidebar = {\n id: `${Common.LayoutOperation.UpdateSidebar.meta.key}/nav`,\n data: Effect.fnUntraced(function* () {\n yield* Common.Capability.updateAtomValue(DeckCapabilities.State, (s) => ({\n ...s,\n sidebarState: s.sidebarState === 'expanded' ? ('collapsed' as const) : ('expanded' as const),\n }));\n }),\n properties: {\n label: [\n state.sidebarState === 'expanded'\n ? 'collapse navigation sidebar label'\n : 'open navigation sidebar label',\n { ns: meta.id },\n ],\n icon: 'ph--sidebar--regular',\n keyBinding: {\n macos: \"meta+'\",\n },\n disposition: 'pin-end',\n position: 'hoist',\n l0Breakpoint: 'lg',\n },\n };\n\n return !deck?.solo ? [closeCurrent, closeOthers, closeAll, toggleSidebar] : [toggleSidebar];\n }),\n });\n\n return Capability.contributes(Common.Capability.AppGraphBuilder, extensions);\n }),\n);\n"],
5
- "mappings": "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",
6
- "names": ["Effect", "Capability", "Common", "Operation", "AttentionCapabilities", "GraphBuilder", "NodeMatcher", "Capability", "makeModule", "fnUntraced", "extensions", "GraphBuilder", "createExtension", "id", "meta", "match", "NodeMatcher", "whenRoot", "actions", "_node", "get", "gen", "closeCurrent", "Common", "LayoutOperation", "Close", "key", "data", "attention", "AttentionCapabilities", "Attention", "attended", "getCurrent", "at", "Operation", "invoke", "subject", "properties", "label", "ns", "icon", "closeOthers", "deck", "DeckCapabilities", "getDeck", "ids", "active", "filter", "closeAll", "state", "State", "decks", "activeDeck", "toggleSidebar", "UpdateSidebar", "updateAtomValue", "s", "sidebarState", "keyBinding", "macos", "disposition", "position", "l0Breakpoint", "solo", "contributes", "AppGraphBuilder"]
7
- }
@@ -1,33 +0,0 @@
1
- import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
- import {
3
- DeckCapabilities
4
- } from "./chunk-XAKTY3EB.mjs";
5
-
6
- // src/capabilities/check-app-scheme/check-app-scheme.ts
7
- import * as Effect from "effect/Effect";
8
- import { Capability, Common } from "@dxos/app-framework";
9
- var isSocket = !!globalThis.__args;
10
- var appScheme = "composer://";
11
- var checkAppScheme = (url) => {
12
- const iframe = document.createElement("iframe");
13
- iframe.style.display = "none";
14
- document.body.appendChild(iframe);
15
- iframe.src = url + window.location.pathname.replace(/^\/+/, "") + window.location.search;
16
- const timer = setTimeout(() => {
17
- document.body.removeChild(iframe);
18
- }, 3e3);
19
- window.addEventListener("pagehide", (event) => {
20
- clearTimeout(timer);
21
- document.body.removeChild(iframe);
22
- });
23
- };
24
- var check_app_scheme_default = Capability.makeModule(Effect.fnUntraced(function* () {
25
- const settings = yield* Common.Capability.getAtomValue(DeckCapabilities.Settings);
26
- if (!isSocket && settings?.enableNativeRedirect) {
27
- checkAppScheme(appScheme);
28
- }
29
- }));
30
- export {
31
- check_app_scheme_default as default
32
- };
33
- //# sourceMappingURL=check-app-scheme-IVYRHKRH.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/capabilities/check-app-scheme/check-app-scheme.ts"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\n\nimport { Capability, Common } from '@dxos/app-framework';\n\nimport { DeckCapabilities } from '../../types';\n\nconst isSocket = !!(globalThis as any).__args;\n\n// TODO(mjamesderocher): Can we get this directly from Socket?\nconst appScheme = 'composer://';\n\n// TODO(mjamesderocher): Factor out as part of NavigationPlugin.\nconst checkAppScheme = (url: string) => {\n const iframe = document.createElement('iframe');\n iframe.style.display = 'none';\n document.body.appendChild(iframe);\n\n iframe.src = url + window.location.pathname.replace(/^\\/+/, '') + window.location.search;\n\n const timer = setTimeout(() => {\n document.body.removeChild(iframe);\n }, 3000);\n\n window.addEventListener('pagehide', (event) => {\n clearTimeout(timer);\n document.body.removeChild(iframe);\n });\n};\n\nexport default Capability.makeModule(\n Effect.fnUntraced(function* () {\n const settings = yield* Common.Capability.getAtomValue(DeckCapabilities.Settings);\n if (!isSocket && settings?.enableNativeRedirect) {\n checkAppScheme(appScheme);\n }\n }),\n);\n"],
5
- "mappings": ";;;;;;AAIA,YAAYA,YAAY;AAExB,SAASC,YAAYC,cAAc;AAInC,IAAMC,WAAW,CAAC,CAAEC,WAAmBC;AAGvC,IAAMC,YAAY;AAGlB,IAAMC,iBAAiB,CAACC,QAAAA;AACtB,QAAMC,SAASC,SAASC,cAAc,QAAA;AACtCF,SAAOG,MAAMC,UAAU;AACvBH,WAASI,KAAKC,YAAYN,MAAAA;AAE1BA,SAAOO,MAAMR,MAAMS,OAAOC,SAASC,SAASC,QAAQ,QAAQ,EAAA,IAAMH,OAAOC,SAASG;AAElF,QAAMC,QAAQC,WAAW,MAAA;AACvBb,aAASI,KAAKU,YAAYf,MAAAA;EAC5B,GAAG,GAAA;AAEHQ,SAAOQ,iBAAiB,YAAY,CAACC,UAAAA;AACnCC,iBAAaL,KAAAA;AACbZ,aAASI,KAAKU,YAAYf,MAAAA;EAC5B,CAAA;AACF;AAEA,IAAA,2BAAemB,WAAWC,WACjBC,kBAAW,aAAA;AAChB,QAAMC,WAAW,OAAOC,OAAOJ,WAAWK,aAAaC,iBAAiBC,QAAQ;AAChF,MAAI,CAAChC,YAAY4B,UAAUK,sBAAsB;AAC/C7B,mBAAeD,SAAAA;EACjB;AACF,CAAA,CAAA;",
6
- "names": ["Effect", "Capability", "Common", "isSocket", "globalThis", "__args", "appScheme", "checkAppScheme", "url", "iframe", "document", "createElement", "style", "display", "body", "appendChild", "src", "window", "location", "pathname", "replace", "search", "timer", "setTimeout", "removeChild", "addEventListener", "event", "clearTimeout", "Capability", "makeModule", "fnUntraced", "settings", "Common", "getAtomValue", "DeckCapabilities", "Settings", "enableNativeRedirect"]
7
- }
@@ -1,154 +0,0 @@
1
- import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
-
3
- // src/layout.ts
4
- import { produce } from "immer";
5
- import { ATTENDABLE_PATH_SEPARATOR } from "@dxos/react-ui-attention";
6
- var createEntryId = (entryId, variant) => variant ? `${entryId}${ATTENDABLE_PATH_SEPARATOR}${variant}` : entryId;
7
- var parseEntryId = (entryId) => {
8
- const [id, variant] = entryId.split(ATTENDABLE_PATH_SEPARATOR);
9
- return {
10
- id,
11
- variant
12
- };
13
- };
14
- var openEntry = (deck, _entryId, options) => {
15
- return produce(deck, (draft) => {
16
- const entryId = createEntryId(_entryId, options?.variant);
17
- if (draft.find((id) => id === entryId)) {
18
- return;
19
- }
20
- const key = options?.key;
21
- const plankPositioning = options?.positioning ?? "start";
22
- const pivotId = options?.pivotId;
23
- if (key) {
24
- const index = draft.findIndex((id) => id.split("+")[0] === key);
25
- if (index !== -1) {
26
- draft.splice(index, 1, entryId);
27
- return;
28
- }
29
- }
30
- if (pivotId) {
31
- const pivotIndex = draft.findIndex((id) => id === pivotId);
32
- if (pivotIndex !== -1) {
33
- if (plankPositioning === "start") {
34
- draft.splice(pivotIndex, 0, entryId);
35
- } else {
36
- draft.splice(pivotIndex + 1, 0, entryId);
37
- }
38
- return;
39
- }
40
- }
41
- if (plankPositioning === "start") {
42
- draft.unshift(entryId);
43
- } else {
44
- draft.push(entryId);
45
- }
46
- });
47
- };
48
- var closeEntry = (deck, entryId) => {
49
- return produce(deck, (draft) => {
50
- const index = draft.findIndex((id) => id === entryId);
51
- if (index !== -1) {
52
- draft.splice(index, 1);
53
- }
54
- });
55
- };
56
- var incrementPlank = (deck, adjustment) => {
57
- return produce(deck, (draft) => {
58
- const index = draft.findIndex((id) => id === adjustment.id);
59
- if (index === -1 || adjustment.type === "increment-start" && index === 0 || adjustment.type === "increment-end" && index === draft.length - 1) {
60
- return;
61
- }
62
- if (adjustment.type === "increment-start") {
63
- [draft[index - 1], draft[index]] = [
64
- draft[index],
65
- draft[index - 1]
66
- ];
67
- } else if (adjustment.type === "increment-end") {
68
- [draft[index], draft[index + 1]] = [
69
- draft[index + 1],
70
- draft[index]
71
- ];
72
- }
73
- });
74
- };
75
-
76
- // src/util/set-active.ts
77
- var computeActiveUpdates = ({ next, deck, attention }) => {
78
- const active = deck.solo ? [
79
- deck.solo
80
- ] : deck.active;
81
- const removed = active.filter((id) => !next.includes(id));
82
- const closed = Array.from(/* @__PURE__ */ new Set([
83
- ...deck.inactive.filter((id) => !next.includes(id)),
84
- ...removed
85
- ]));
86
- const updates = {
87
- inactive: closed,
88
- solo: deck.solo,
89
- active: deck.active,
90
- fullscreen: deck.fullscreen
91
- };
92
- if (deck.solo || !deck.initialized) {
93
- updates.solo = next[0];
94
- } else {
95
- updates.active = next;
96
- }
97
- if (deck.fullscreen && !updates.solo) {
98
- updates.fullscreen = false;
99
- }
100
- let toAttend;
101
- if (attention) {
102
- const attended = attention.getCurrent();
103
- const [attendedId] = Array.from(attended);
104
- const isAttendedAvailable = !!attendedId && next.includes(attendedId);
105
- if (!isAttendedAvailable) {
106
- const attendedIndex = active.indexOf(attendedId);
107
- const index = attendedIndex === -1 ? 0 : attendedIndex >= next.length ? next.length - 1 : attendedIndex;
108
- toAttend = next[index];
109
- }
110
- }
111
- return {
112
- deckUpdates: updates,
113
- toAttend
114
- };
115
- };
116
-
117
- // src/util/layoutAppliesTopbar.ts
118
- var layoutAppliesTopbar = (breakpoint, layoutMode) => {
119
- return document.body.getAttribute("data-platform") === "windows" && breakpoint === "desktop" && layoutMode !== "solo--fullscreen";
120
- };
121
-
122
- // src/util/overscroll.ts
123
- var calculateOverscroll = (planksCount) => {
124
- if (!planksCount) {
125
- return {
126
- paddingInlineStart: 0,
127
- paddingInlineEnd: 0
128
- };
129
- }
130
- if (planksCount === 1) {
131
- const overscrollPadding = "max(0px, calc(((100dvw - var(--dx-main-sidebarWidth) - var(--dx-main-complementaryWidth) - (var(--dx-main-contentFirstWidth) + 1px)) / 2)))";
132
- return {
133
- paddingInlineStart: overscrollPadding,
134
- paddingInlineEnd: overscrollPadding
135
- };
136
- } else {
137
- return {
138
- paddingInlineStart: "max(0px, calc(((100dvw - (var(--dx-main-contentFirstWidth) + 1px)) / 2) - var(--dx-main-sidebarWidth)))",
139
- paddingInlineEnd: "max(0px, calc(((100dvw - (var(--dx-main-contentLastWidth) + 1px)) / 2) - var(--dx-main-complementaryWidth)))"
140
- };
141
- }
142
- };
143
-
144
- export {
145
- createEntryId,
146
- parseEntryId,
147
- openEntry,
148
- closeEntry,
149
- incrementPlank,
150
- layoutAppliesTopbar,
151
- calculateOverscroll,
152
- computeActiveUpdates
153
- };
154
- //# sourceMappingURL=chunk-ADPMWKLL.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/layout.ts", "../../../src/util/set-active.ts", "../../../src/util/layoutAppliesTopbar.ts", "../../../src/util/overscroll.ts"],
4
- "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport { produce } from 'immer';\n\nimport { ATTENDABLE_PATH_SEPARATOR } from '@dxos/react-ui-attention';\n\nimport { type DeckAction, type NewPlankPositioning } from './types';\n\nexport const createEntryId = (entryId: string, variant?: string) =>\n variant ? `${entryId}${ATTENDABLE_PATH_SEPARATOR}${variant}` : entryId;\n\nexport const parseEntryId = (entryId: string) => {\n const [id, variant] = entryId.split(ATTENDABLE_PATH_SEPARATOR);\n return { id, variant };\n};\n\ntype OpenLayoutEntryOptions = {\n key?: string;\n positioning?: NewPlankPositioning;\n pivotId?: string;\n variant?: string;\n};\n\nexport const openEntry = (deck: string[], _entryId: string, options?: OpenLayoutEntryOptions): string[] => {\n return produce(deck, (draft) => {\n const entryId = createEntryId(_entryId, options?.variant);\n\n // Check that the entry is not already in the part\n if (draft.find((id) => id === entryId)) {\n return;\n }\n\n const key = options?.key;\n const plankPositioning = options?.positioning ?? 'start';\n const pivotId = options?.pivotId;\n\n if (key) {\n const index = draft.findIndex((id) => id.split('+')[0] === key);\n if (index !== -1) {\n draft.splice(index, 1, entryId);\n return;\n }\n }\n\n if (pivotId) {\n const pivotIndex = draft.findIndex((id) => id === pivotId);\n if (pivotIndex !== -1) {\n if (plankPositioning === 'start') {\n draft.splice(pivotIndex, 0, entryId);\n } else {\n draft.splice(pivotIndex + 1, 0, entryId);\n }\n return;\n }\n }\n\n // If no pivot found or provided, fall back to original behavior\n if (plankPositioning === 'start') {\n draft.unshift(entryId);\n } else {\n draft.push(entryId);\n }\n });\n};\n\nexport const closeEntry = (deck: string[], entryId: string): string[] => {\n return produce(deck, (draft) => {\n const index = draft.findIndex((id) => id === entryId);\n if (index !== -1) {\n draft.splice(index, 1);\n }\n });\n};\n\nexport const incrementPlank = (deck: string[], adjustment: DeckAction.Adjustment): string[] => {\n return produce(deck, (draft) => {\n const index = draft.findIndex((id) => id === adjustment.id);\n if (\n index === -1 ||\n (adjustment.type === 'increment-start' && index === 0) ||\n (adjustment.type === 'increment-end' && index === draft.length - 1)\n ) {\n return;\n }\n\n if (adjustment.type === 'increment-start') {\n // Swap the current item with the previous item.\n [draft[index - 1], draft[index]] = [draft[index], draft[index - 1]];\n } else if (adjustment.type === 'increment-end') {\n // Swap the current item with the next item.\n [draft[index], draft[index + 1]] = [draft[index + 1], draft[index]];\n }\n });\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type AttentionManager } from '@dxos/plugin-attention';\n\nimport { type DeckState } from '../types';\n\nexport type SetActiveOptions = {\n next: string[];\n deck: DeckState;\n attention?: AttentionManager;\n};\n\nexport type SetActiveResult = {\n /** Updates to apply to the deck. */\n deckUpdates: {\n inactive: string[];\n solo: string | undefined;\n active: string[];\n fullscreen: boolean;\n };\n /** ID of the item to attend (scroll into view) if attention changed. */\n toAttend?: string;\n};\n\n/**\n * Computes the new active state for the deck without mutating.\n * Returns the updates to apply and optionally an item to attend.\n */\nexport const computeActiveUpdates = ({ next, deck, attention }: SetActiveOptions): SetActiveResult => {\n const active = deck.solo ? [deck.solo] : deck.active;\n const removed = active.filter((id) => !next.includes(id));\n const closed = Array.from(new Set([...deck.inactive.filter((id) => !next.includes(id)), ...removed]));\n\n const updates = {\n inactive: closed,\n solo: deck.solo,\n active: deck.active,\n fullscreen: deck.fullscreen,\n };\n\n if (deck.solo || !deck.initialized) {\n updates.solo = next[0];\n } else {\n updates.active = next;\n }\n\n if (deck.fullscreen && !updates.solo) {\n updates.fullscreen = false;\n }\n\n let toAttend: string | undefined;\n if (attention) {\n const attended = attention.getCurrent();\n const [attendedId] = Array.from(attended);\n const isAttendedAvailable = !!attendedId && next.includes(attendedId);\n if (!isAttendedAvailable) {\n const attendedIndex = active.indexOf(attendedId);\n // If outside of bounds, focus on the first/last plank, otherwise focus on the new plank in the same position.\n const index = attendedIndex === -1 ? 0 : attendedIndex >= next.length ? next.length - 1 : attendedIndex;\n toAttend = next[index];\n }\n }\n\n return { deckUpdates: updates, toAttend };\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type LayoutMode } from '../types';\n\nexport const layoutAppliesTopbar = (breakpoint: string, layoutMode?: LayoutMode) => {\n return (\n document.body.getAttribute('data-platform') === 'windows' &&\n breakpoint === 'desktop' &&\n layoutMode !== 'solo--fullscreen'\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport type { CSSProperties } from 'react';\n\n/**\n * ┌────────────────────────────────────────────────────────────────────────────────────────────────────┐\n * | Overscroll Padding Calculation for Centering Planks on Screen. │\n * ├────────────────────────────────────────────────────────────────────────────────────────────────────┤\n * │ NOTE(Zan): I found the way you calculate the overscroll padding to center a plank on the screen │\n * │ at the edges of the scroll context a bit confusing, so I've diagrammed it here. │\n * │ │\n * │ Multiple Planks: │\n * │ ─────────────── │\n * | Use the following overscroll padding calculation centering the boundary planks on the SCREEN. │\n * │ │\n * │ Left Padding: Right Padding: │\n * │ ┌───┬────┬──────────────────┬──────┐ ┌──────┬──────────────────┬────┬───┐ │\n * │ │ │████│ Ideal │ │ │ │ Ideal │████│ │ │\n * │ │ S │█PL█│ first │ │ │ │ last │█PR█│ C │ │\n * │ │ │████│ plank │ │ │ │ plank │████│ │ │\n * │ └───┴────┴──────────────────┴──────┘ └──────┴──────────────────┴────┴───┘ │\n * │ <--------- screen width -----------> <---------- screen width ----------> │\n * │ │\n * │ PL = ((screen width - Plank Width) / 2) - S │\n * │ PR = ((screen width - Plank Width) / 2) - C │\n * │ │\n * │ S = Sidebar width C = Complementary sidebar width │\n * │ PL = Padding Left PR = Padding Right │\n * │ │\n * │ Single Plank: │\n * │ ───────────── │\n * │ For a single plank we use the following overscroll padding calculation to center the plank in │\n * │ the content area: │\n * │ │\n * │ ┌───┬───────────────────────┬───┬───────────────────────┬───┐ │\n * │ │ │███████████████████████│ │███████████████████████│ │ │\n * │ │ S │█████ Left Padding ████│ P │████ Right Padding ████│ C │ │\n * │ │ │███████████████████████│ │███████████████████████│ │ │\n * │ └───┴───────────────────────┴───┴───────────────────────┴───┘ │\n * │ <------------------------ screen width ---------------------> │\n * │ │\n * │ Left/Right Padding Width = (screen width - S - P - C) / 2 │\n * │ │\n * │ S = Sidebar width (may be 0) │\n * │ P = Plank width (centered) │\n * │ C = Complementary sidebar width (may be 0) │\n * └────────────────────────────────────────────────────────────────────────────────────────────────────┘\n */\nexport const calculateOverscroll = (\n planksCount: number,\n): Pick<CSSProperties, 'paddingInlineStart' | 'paddingInlineEnd'> | undefined => {\n if (!planksCount) {\n return { paddingInlineStart: 0, paddingInlineEnd: 0 };\n }\n if (planksCount === 1) {\n const overscrollPadding =\n 'max(0px, calc(((100dvw - var(--dx-main-sidebarWidth) - var(--dx-main-complementaryWidth) - (var(--dx-main-contentFirstWidth) + 1px)) / 2)))';\n return { paddingInlineStart: overscrollPadding, paddingInlineEnd: overscrollPadding };\n } else {\n return {\n paddingInlineStart:\n 'max(0px, calc(((100dvw - (var(--dx-main-contentFirstWidth) + 1px)) / 2) - var(--dx-main-sidebarWidth)))',\n paddingInlineEnd:\n 'max(0px, calc(((100dvw - (var(--dx-main-contentLastWidth) + 1px)) / 2) - var(--dx-main-complementaryWidth)))',\n };\n }\n};\n"],
5
- "mappings": "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",
6
- "names": ["produce", "ATTENDABLE_PATH_SEPARATOR", "createEntryId", "entryId", "variant", "ATTENDABLE_PATH_SEPARATOR", "parseEntryId", "id", "split", "openEntry", "deck", "_entryId", "options", "produce", "draft", "find", "key", "plankPositioning", "positioning", "pivotId", "index", "findIndex", "splice", "pivotIndex", "unshift", "push", "closeEntry", "incrementPlank", "adjustment", "type", "length", "computeActiveUpdates", "next", "deck", "attention", "active", "solo", "removed", "filter", "id", "includes", "closed", "Array", "from", "Set", "inactive", "updates", "fullscreen", "initialized", "toAttend", "attended", "getCurrent", "attendedId", "isAttendedAvailable", "attendedIndex", "indexOf", "index", "length", "deckUpdates", "layoutAppliesTopbar", "breakpoint", "layoutMode", "document", "body", "getAttribute", "calculateOverscroll", "planksCount", "paddingInlineStart", "paddingInlineEnd", "overscrollPadding"]
7
- }
@@ -1,162 +0,0 @@
1
- import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
- import {
3
- ATTENDABLE_PATH_SEPARATOR,
4
- DECK_COMPANION_TYPE,
5
- DeckCapabilities,
6
- PLANK_COMPANION_TYPE
7
- } from "./chunk-XAKTY3EB.mjs";
8
-
9
- // src/hooks/useCompanions.ts
10
- import { useMemo } from "react";
11
- import { useAppGraph } from "@dxos/app-framework/react";
12
- import { useConnections } from "@dxos/plugin-graph";
13
- import { byPosition } from "@dxos/util";
14
- var useCompanions = (id) => {
15
- const { graph } = useAppGraph();
16
- const nodes = useConnections(graph, id);
17
- const companions = nodes.filter((node) => node.type === PLANK_COMPANION_TYPE);
18
- return useMemo(() => companions.toSorted((a, b) => byPosition(a.properties, b.properties)), [
19
- companions
20
- ]);
21
- };
22
-
23
- // src/hooks/useDeckState.ts
24
- import { useAtomValue } from "@effect-atom/atom-react";
25
- import { useCallback, useMemo as useMemo2 } from "react";
26
- import { Common } from "@dxos/app-framework";
27
- import { useCapability } from "@dxos/app-framework/react";
28
- import { invariant } from "@dxos/invariant";
29
- var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-deck/src/hooks/useDeckState.ts";
30
- var useDeckState = () => {
31
- const registry = useCapability(Common.Capability.AtomRegistry);
32
- const stateAtom = useCapability(DeckCapabilities.State);
33
- const ephemeralAtom = useCapability(DeckCapabilities.EphemeralState);
34
- const persistedState = useAtomValue(stateAtom);
35
- const ephemeralState = useAtomValue(ephemeralAtom);
36
- const deck = useMemo2(() => {
37
- const d = persistedState.decks[persistedState.activeDeck];
38
- invariant(d, `Deck not found: ${persistedState.activeDeck}`, {
39
- F: __dxlog_file,
40
- L: 46,
41
- S: void 0,
42
- A: [
43
- "d",
44
- "`Deck not found: ${persistedState.activeDeck}`"
45
- ]
46
- });
47
- return d;
48
- }, [
49
- persistedState.decks,
50
- persistedState.activeDeck
51
- ]);
52
- const state = useMemo2(() => ({
53
- ...persistedState,
54
- ...ephemeralState
55
- }), [
56
- persistedState,
57
- ephemeralState
58
- ]);
59
- const updateState = useCallback((fn) => {
60
- registry.set(stateAtom, fn(registry.get(stateAtom)));
61
- }, [
62
- registry,
63
- stateAtom
64
- ]);
65
- const updateEphemeral = useCallback((fn) => {
66
- registry.set(ephemeralAtom, fn(registry.get(ephemeralAtom)));
67
- }, [
68
- registry,
69
- ephemeralAtom
70
- ]);
71
- return useMemo2(() => ({
72
- state,
73
- deck,
74
- updateState,
75
- updateEphemeral
76
- }), [
77
- state,
78
- deck,
79
- updateState,
80
- updateEphemeral
81
- ]);
82
- };
83
-
84
- // src/hooks/useBreakpoints.ts
85
- import { useMediaQuery } from "@dxos/react-ui";
86
- var useBreakpoints = () => {
87
- const [isNotMobile] = useMediaQuery("md");
88
- const [isDesktop] = useMediaQuery("lg");
89
- return isDesktop ? "desktop" : isNotMobile ? "tablet" : "mobile";
90
- };
91
-
92
- // src/hooks/useDeckCompanions.ts
93
- import { useAppGraph as useAppGraph2 } from "@dxos/app-framework/react";
94
- import { Node } from "@dxos/plugin-graph";
95
- import { useConnections as useConnections2 } from "@dxos/plugin-graph";
96
- import { byPosition as byPosition2 } from "@dxos/util";
97
- var getCompanionId = (id) => {
98
- const [_, companionId] = id.split(ATTENDABLE_PATH_SEPARATOR);
99
- return companionId ?? "never";
100
- };
101
- var useDeckCompanions = () => {
102
- const { graph } = useAppGraph2();
103
- const connections = useConnections2(graph, Node.RootId);
104
- const companions = connections.filter((node) => node.type === DECK_COMPANION_TYPE);
105
- return companions.toSorted((a, b) => byPosition2(a.properties, b.properties));
106
- };
107
-
108
- // src/hooks/useHoistStatusbar.ts
109
- import { useMemo as useMemo3 } from "react";
110
- import { useAtomCapability } from "@dxos/app-framework/react";
111
- import { useThemeContext } from "@dxos/react-ui";
112
- var useHoistStatusbar = (breakpoint, layoutMode) => {
113
- const { safeAreaPadding } = useThemeContext();
114
- const enableStatusbar = useAtomCapability(DeckCapabilities.Settings).enableStatusbar;
115
- return useMemo3(() => {
116
- return breakpoint === "desktop" && layoutMode !== "solo--fullscreen" && !!enableStatusbar && safeAreaPadding?.bottom === 0;
117
- }, [
118
- enableStatusbar,
119
- breakpoint,
120
- safeAreaPadding?.bottom,
121
- layoutMode
122
- ]);
123
- };
124
-
125
- // src/hooks/useMainSize.ts
126
- import { useMainContext } from "@dxos/react-ui";
127
- var useMainSize = () => {
128
- const { navigationSidebarState, complementarySidebarState } = useMainContext("DeckPluginPlank");
129
- return {
130
- "data-sidebar-inline-start-state": navigationSidebarState,
131
- "data-sidebar-inline-end-state": complementarySidebarState
132
- };
133
- };
134
-
135
- // src/hooks/useNodeActionExpander.ts
136
- import { useEffect } from "react";
137
- import { Graph } from "@dxos/plugin-graph";
138
- var useNodeActionExpander = (node) => {
139
- useEffect(() => {
140
- if (node) {
141
- const frame = requestAnimationFrame(() => {
142
- const graph = Graph.getGraph(node);
143
- void Graph.expand(graph, node.id);
144
- });
145
- return () => cancelAnimationFrame(frame);
146
- }
147
- }, [
148
- node
149
- ]);
150
- };
151
-
152
- export {
153
- useBreakpoints,
154
- useCompanions,
155
- getCompanionId,
156
- useDeckCompanions,
157
- useDeckState,
158
- useHoistStatusbar,
159
- useMainSize,
160
- useNodeActionExpander
161
- };
162
- //# sourceMappingURL=chunk-SKEVPQ7E.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/hooks/useCompanions.ts", "../../../src/hooks/useDeckState.ts", "../../../src/hooks/useBreakpoints.ts", "../../../src/hooks/useDeckCompanions.ts", "../../../src/hooks/useHoistStatusbar.ts", "../../../src/hooks/useMainSize.ts", "../../../src/hooks/useNodeActionExpander.ts"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { useMemo } from 'react';\n\nimport { useAppGraph } from '@dxos/app-framework/react';\nimport { useConnections } from '@dxos/plugin-graph';\nimport { byPosition } from '@dxos/util';\n\nimport { PLANK_COMPANION_TYPE } from '../types';\n\nexport const useCompanions = (id?: string) => {\n const { graph } = useAppGraph();\n const nodes = useConnections(graph, id);\n const companions = nodes.filter((node) => node.type === PLANK_COMPANION_TYPE);\n return useMemo(() => companions.toSorted((a, b) => byPosition(a.properties, b.properties)), [companions]);\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { useAtomValue } from '@effect-atom/atom-react';\nimport { useCallback, useMemo } from 'react';\n\nimport { Common } from '@dxos/app-framework';\nimport { useCapability } from '@dxos/app-framework/react';\nimport { invariant } from '@dxos/invariant';\n\nimport {\n DeckCapabilities,\n type DeckEphemeralStateProps,\n type DeckPluginState,\n type DeckState,\n type DeckStateProps,\n} from '../types';\n\nexport type DeckStateHook = {\n /** Combined state value (reactive). Includes both persisted and ephemeral state. */\n state: DeckPluginState;\n /** The active deck, computed from decks[activeDeck]. */\n deck: DeckState;\n /** Update persisted state. */\n updateState: (fn: (current: DeckStateProps) => DeckStateProps) => void;\n /** Update ephemeral state. */\n updateEphemeral: (fn: (current: DeckEphemeralStateProps) => DeckEphemeralStateProps) => void;\n};\n\n/**\n * Hook to access the deck plugin state reactively.\n * Returns the combined state, the active deck, and update functions for each atom.\n */\nexport const useDeckState = (): DeckStateHook => {\n const registry = useCapability(Common.Capability.AtomRegistry);\n const stateAtom = useCapability(DeckCapabilities.State);\n const ephemeralAtom = useCapability(DeckCapabilities.EphemeralState);\n\n const persistedState = useAtomValue(stateAtom);\n const ephemeralState = useAtomValue(ephemeralAtom);\n\n // Compute deck from decks[activeDeck] to ensure it's always current.\n const deck = useMemo(() => {\n const d = persistedState.decks[persistedState.activeDeck];\n invariant(d, `Deck not found: ${persistedState.activeDeck}`);\n return d;\n }, [persistedState.decks, persistedState.activeDeck]);\n\n // Combine persisted and ephemeral state into a unified view.\n const state = useMemo(\n (): DeckPluginState => ({\n ...persistedState,\n ...ephemeralState,\n }),\n [persistedState, ephemeralState],\n );\n\n const updateState = useCallback(\n (fn: (current: DeckStateProps) => DeckStateProps) => {\n registry.set(stateAtom, fn(registry.get(stateAtom)));\n },\n [registry, stateAtom],\n );\n\n const updateEphemeral = useCallback(\n (fn: (current: DeckEphemeralStateProps) => DeckEphemeralStateProps) => {\n registry.set(ephemeralAtom, fn(registry.get(ephemeralAtom)));\n },\n [registry, ephemeralAtom],\n );\n\n return useMemo(\n () => ({\n state,\n deck,\n updateState,\n updateEphemeral,\n }),\n [state, deck, updateState, updateEphemeral],\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { useMediaQuery } from '@dxos/react-ui';\n\nexport const useBreakpoints = () => {\n const [isNotMobile] = useMediaQuery('md');\n const [isDesktop] = useMediaQuery('lg');\n return isDesktop ? 'desktop' : isNotMobile ? 'tablet' : 'mobile';\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { useAppGraph } from '@dxos/app-framework/react';\nimport { Node, type Node as NodeType } from '@dxos/plugin-graph';\nimport { useConnections } from '@dxos/plugin-graph';\nimport { type Label } from '@dxos/ui-types';\nimport { type Position, byPosition } from '@dxos/util';\n\nimport { ATTENDABLE_PATH_SEPARATOR, DECK_COMPANION_TYPE } from '../types';\n\nexport const getCompanionId = (id: string) => {\n const [_, companionId] = id.split(ATTENDABLE_PATH_SEPARATOR);\n return companionId ?? 'never';\n};\n\nexport type DeckCompanion = NodeType.Node<\n any,\n {\n label: Label;\n icon: string;\n // TODO(burdon): Scroll area should be controlled by surface.\n /** If true, the panel will not be wrapped in a scroll area. */\n fixed?: boolean;\n position?: Position;\n }\n>;\n\nexport const useDeckCompanions = (): DeckCompanion[] => {\n const { graph } = useAppGraph();\n const connections = useConnections(graph, Node.RootId);\n const companions = connections.filter((node) => node.type === DECK_COMPANION_TYPE) as DeckCompanion[];\n return companions.toSorted((a, b) => byPosition(a.properties, b.properties));\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { useMemo } from 'react';\n\nimport { useAtomCapability } from '@dxos/app-framework/react';\nimport { useThemeContext } from '@dxos/react-ui';\n\nimport { DeckCapabilities, type LayoutMode } from '../types';\n\nexport const useHoistStatusbar = (breakpoint: string, layoutMode?: LayoutMode): boolean => {\n const { safeAreaPadding } = useThemeContext();\n const enableStatusbar = useAtomCapability(DeckCapabilities.Settings).enableStatusbar;\n\n return useMemo(() => {\n return (\n breakpoint === 'desktop' &&\n layoutMode !== 'solo--fullscreen' &&\n !!enableStatusbar &&\n safeAreaPadding?.bottom === 0\n );\n }, [enableStatusbar, breakpoint, safeAreaPadding?.bottom, layoutMode]);\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { useMainContext } from '@dxos/react-ui';\n\nexport const useMainSize = () => {\n const { navigationSidebarState, complementarySidebarState } = useMainContext('DeckPluginPlank');\n return {\n 'data-sidebar-inline-start-state': navigationSidebarState,\n 'data-sidebar-inline-end-state': complementarySidebarState,\n };\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { useEffect } from 'react';\n\nimport { Graph, type Node } from '@dxos/plugin-graph';\n\nexport const useNodeActionExpander = (node?: Node.Node) => {\n useEffect(() => {\n if (node) {\n const frame = requestAnimationFrame(() => {\n const graph = Graph.getGraph(node);\n void Graph.expand(graph, node.id);\n });\n return () => cancelAnimationFrame(frame);\n }\n }, [node]);\n};\n"],
5
- "mappings": "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",
6
- "names": ["useMemo", "useAppGraph", "useConnections", "byPosition", "useCompanions", "id", "graph", "useAppGraph", "nodes", "useConnections", "companions", "filter", "node", "type", "PLANK_COMPANION_TYPE", "useMemo", "toSorted", "a", "b", "byPosition", "properties", "useAtomValue", "useCallback", "useMemo", "Common", "useCapability", "invariant", "useDeckState", "registry", "useCapability", "Common", "Capability", "AtomRegistry", "stateAtom", "DeckCapabilities", "State", "ephemeralAtom", "EphemeralState", "persistedState", "useAtomValue", "ephemeralState", "deck", "useMemo", "d", "decks", "activeDeck", "invariant", "state", "updateState", "useCallback", "fn", "set", "get", "updateEphemeral", "useMediaQuery", "useBreakpoints", "isNotMobile", "useMediaQuery", "isDesktop", "useAppGraph", "Node", "useConnections", "byPosition", "getCompanionId", "id", "_", "companionId", "split", "ATTENDABLE_PATH_SEPARATOR", "useDeckCompanions", "graph", "useAppGraph", "connections", "useConnections", "Node", "RootId", "companions", "filter", "node", "type", "DECK_COMPANION_TYPE", "toSorted", "a", "b", "byPosition", "properties", "useMemo", "useAtomCapability", "useThemeContext", "useHoistStatusbar", "breakpoint", "layoutMode", "safeAreaPadding", "useThemeContext", "enableStatusbar", "useAtomCapability", "DeckCapabilities", "Settings", "useMemo", "bottom", "useMainContext", "useMainSize", "navigationSidebarState", "complementarySidebarState", "useMainContext", "useEffect", "Graph", "useNodeActionExpander", "node", "useEffect", "frame", "requestAnimationFrame", "graph", "Graph", "getGraph", "expand", "id", "cancelAnimationFrame"]
7
- }