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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (470) hide show
  1. package/dist/lib/browser/add-toast-QUWRKFDD.mjs +24 -0
  2. package/dist/lib/browser/add-toast-QUWRKFDD.mjs.map +7 -0
  3. package/dist/lib/browser/adjust-J6F24WWJ.mjs +96 -0
  4. package/dist/lib/browser/adjust-J6F24WWJ.mjs.map +7 -0
  5. package/dist/lib/browser/change-companion-EZI57WDZ.mjs +34 -0
  6. package/dist/lib/browser/change-companion-EZI57WDZ.mjs.map +7 -0
  7. package/dist/lib/browser/chunk-2YNVGCOQ.mjs +88 -0
  8. package/dist/lib/browser/chunk-2YNVGCOQ.mjs.map +7 -0
  9. package/dist/lib/browser/chunk-AYFQHPPP.mjs +69 -0
  10. package/dist/lib/browser/chunk-AYFQHPPP.mjs.map +7 -0
  11. package/dist/lib/browser/chunk-GCDWE37Y.mjs +220 -0
  12. package/dist/lib/browser/chunk-GCDWE37Y.mjs.map +7 -0
  13. package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
  14. package/dist/lib/browser/chunk-KUTDCWZF.mjs +30 -0
  15. package/dist/lib/browser/chunk-KUTDCWZF.mjs.map +7 -0
  16. package/dist/lib/browser/chunk-OHKLENIG.mjs +45 -0
  17. package/dist/lib/browser/chunk-OHKLENIG.mjs.map +7 -0
  18. package/dist/lib/browser/close-6RB62DEY.mjs +44 -0
  19. package/dist/lib/browser/close-6RB62DEY.mjs.map +7 -0
  20. package/dist/lib/browser/index.mjs +177 -130
  21. package/dist/lib/browser/index.mjs.map +4 -4
  22. package/dist/lib/browser/meta.json +1 -1
  23. package/dist/lib/browser/open-YL3JKXGK.mjs +115 -0
  24. package/dist/lib/browser/open-YL3JKXGK.mjs.map +7 -0
  25. package/dist/lib/browser/operations/index.mjs +13 -0
  26. package/dist/lib/browser/operations/index.mjs.map +7 -0
  27. package/dist/lib/browser/revert-workspace-JC66YMWB.mjs +21 -0
  28. package/dist/lib/browser/revert-workspace-JC66YMWB.mjs.map +7 -0
  29. package/dist/lib/browser/scroll-into-view-QSSFZ3KD.mjs +21 -0
  30. package/dist/lib/browser/scroll-into-view-QSSFZ3KD.mjs.map +7 -0
  31. package/dist/lib/browser/set-LPAGXY3F.mjs +37 -0
  32. package/dist/lib/browser/set-LPAGXY3F.mjs.map +7 -0
  33. package/dist/lib/browser/set-layout-mode-XZ4VHS2X.mjs +90 -0
  34. package/dist/lib/browser/set-layout-mode-XZ4VHS2X.mjs.map +7 -0
  35. package/dist/lib/browser/show-undo-IWX4S777.mjs +59 -0
  36. package/dist/lib/browser/show-undo-IWX4S777.mjs.map +7 -0
  37. package/dist/lib/browser/switch-workspace-5RKQ2LVK.mjs +68 -0
  38. package/dist/lib/browser/switch-workspace-5RKQ2LVK.mjs.map +7 -0
  39. package/dist/lib/browser/types/index.mjs +12 -12
  40. package/dist/lib/browser/update-complementary-QIIZWLGY.mjs +28 -0
  41. package/dist/lib/browser/update-complementary-QIIZWLGY.mjs.map +7 -0
  42. package/dist/lib/browser/update-dialog-5IKCWFPW.mjs +29 -0
  43. package/dist/lib/browser/update-dialog-5IKCWFPW.mjs.map +7 -0
  44. package/dist/lib/browser/update-plank-size-YDM67P65.mjs +28 -0
  45. package/dist/lib/browser/update-plank-size-YDM67P65.mjs.map +7 -0
  46. package/dist/lib/browser/update-popover-AUVAWH3D.mjs +33 -0
  47. package/dist/lib/browser/update-popover-AUVAWH3D.mjs.map +7 -0
  48. package/dist/lib/browser/update-sidebar-BT3L5GJN.mjs +25 -0
  49. package/dist/lib/browser/update-sidebar-BT3L5GJN.mjs.map +7 -0
  50. package/dist/lib/node-esm/add-toast-MR53ZMTS.mjs +25 -0
  51. package/dist/lib/node-esm/add-toast-MR53ZMTS.mjs.map +7 -0
  52. package/dist/lib/node-esm/adjust-IXRBIVAO.mjs +97 -0
  53. package/dist/lib/node-esm/adjust-IXRBIVAO.mjs.map +7 -0
  54. package/dist/lib/node-esm/change-companion-RLMI5EYL.mjs +35 -0
  55. package/dist/lib/node-esm/change-companion-RLMI5EYL.mjs.map +7 -0
  56. package/dist/lib/node-esm/chunk-7BNWWWAF.mjs +221 -0
  57. package/dist/lib/node-esm/chunk-7BNWWWAF.mjs.map +7 -0
  58. package/dist/lib/node-esm/chunk-C2AWKR2S.mjs +71 -0
  59. package/dist/lib/node-esm/chunk-C2AWKR2S.mjs.map +7 -0
  60. package/dist/lib/node-esm/chunk-GI5JXNBT.mjs +89 -0
  61. package/dist/lib/node-esm/chunk-GI5JXNBT.mjs.map +7 -0
  62. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +11 -0
  63. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs.map +7 -0
  64. package/dist/lib/node-esm/chunk-MLVJ2ODW.mjs +32 -0
  65. package/dist/lib/node-esm/chunk-MLVJ2ODW.mjs.map +7 -0
  66. package/dist/lib/node-esm/chunk-TFFZ7NWH.mjs +47 -0
  67. package/dist/lib/node-esm/chunk-TFFZ7NWH.mjs.map +7 -0
  68. package/dist/lib/node-esm/close-UD7KBYZP.mjs +45 -0
  69. package/dist/lib/node-esm/close-UD7KBYZP.mjs.map +7 -0
  70. package/dist/lib/node-esm/index.mjs +216 -0
  71. package/dist/lib/node-esm/index.mjs.map +7 -0
  72. package/dist/lib/node-esm/meta.json +1 -0
  73. package/dist/lib/node-esm/open-XZ7YGVPZ.mjs +116 -0
  74. package/dist/lib/node-esm/open-XZ7YGVPZ.mjs.map +7 -0
  75. package/dist/lib/node-esm/operations/index.mjs +14 -0
  76. package/dist/lib/node-esm/operations/index.mjs.map +7 -0
  77. package/dist/lib/node-esm/revert-workspace-F3FUP4ZL.mjs +22 -0
  78. package/dist/lib/node-esm/revert-workspace-F3FUP4ZL.mjs.map +7 -0
  79. package/dist/lib/node-esm/scroll-into-view-24TF2WYQ.mjs +22 -0
  80. package/dist/lib/node-esm/scroll-into-view-24TF2WYQ.mjs.map +7 -0
  81. package/dist/lib/node-esm/set-F2QWLSJR.mjs +38 -0
  82. package/dist/lib/node-esm/set-F2QWLSJR.mjs.map +7 -0
  83. package/dist/lib/node-esm/set-layout-mode-Z54OX33H.mjs +91 -0
  84. package/dist/lib/node-esm/set-layout-mode-Z54OX33H.mjs.map +7 -0
  85. package/dist/lib/node-esm/show-undo-B2XVCKGX.mjs +60 -0
  86. package/dist/lib/node-esm/show-undo-B2XVCKGX.mjs.map +7 -0
  87. package/dist/lib/node-esm/switch-workspace-PM57REEV.mjs +69 -0
  88. package/dist/lib/node-esm/switch-workspace-PM57REEV.mjs.map +7 -0
  89. package/dist/lib/node-esm/types/index.mjs +33 -0
  90. package/dist/lib/node-esm/types/index.mjs.map +7 -0
  91. package/dist/lib/node-esm/update-complementary-26H5UYJP.mjs +29 -0
  92. package/dist/lib/node-esm/update-complementary-26H5UYJP.mjs.map +7 -0
  93. package/dist/lib/node-esm/update-dialog-EYP3QNFG.mjs +30 -0
  94. package/dist/lib/node-esm/update-dialog-EYP3QNFG.mjs.map +7 -0
  95. package/dist/lib/node-esm/update-plank-size-LLFUB57G.mjs +29 -0
  96. package/dist/lib/node-esm/update-plank-size-LLFUB57G.mjs.map +7 -0
  97. package/dist/lib/node-esm/update-popover-G55PS7T4.mjs +34 -0
  98. package/dist/lib/node-esm/update-popover-G55PS7T4.mjs.map +7 -0
  99. package/dist/lib/node-esm/update-sidebar-W4ND5MUL.mjs +26 -0
  100. package/dist/lib/node-esm/update-sidebar-W4ND5MUL.mjs.map +7 -0
  101. package/dist/types/src/DeckPlugin.d.ts +2 -1
  102. package/dist/types/src/DeckPlugin.d.ts.map +1 -1
  103. package/dist/types/src/capabilities/app-graph-builder.d.ts +4 -2
  104. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  105. package/dist/types/src/capabilities/check-app-scheme.d.ts +17 -2
  106. package/dist/types/src/capabilities/check-app-scheme.d.ts.map +1 -1
  107. package/dist/types/src/capabilities/index.d.ts +196 -12
  108. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  109. package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
  110. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
  111. package/dist/types/src/capabilities/react-root.d.ts +4 -2
  112. package/dist/types/src/capabilities/react-root.d.ts.map +1 -1
  113. package/dist/types/src/capabilities/react-surface.d.ts +3 -2
  114. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  115. package/dist/types/src/capabilities/settings.d.ts +20 -2
  116. package/dist/types/src/capabilities/settings.d.ts.map +1 -1
  117. package/dist/types/src/capabilities/state.d.ts +115 -41
  118. package/dist/types/src/capabilities/state.d.ts.map +1 -1
  119. package/dist/types/src/capabilities/tools.d.ts +4 -3
  120. package/dist/types/src/capabilities/tools.d.ts.map +1 -1
  121. package/dist/types/src/capabilities/url-handler.d.ts +3 -2
  122. package/dist/types/src/capabilities/url-handler.d.ts.map +1 -1
  123. package/dist/types/src/components/DeckSettings/DeckSettings.d.ts +4 -4
  124. package/dist/types/src/components/DeckSettings/DeckSettings.d.ts.map +1 -1
  125. package/dist/types/src/components/DeckSettings/DeckSettings.stories.d.ts +85 -0
  126. package/dist/types/src/components/DeckSettings/DeckSettings.stories.d.ts.map +1 -0
  127. package/dist/types/src/components/DeckSettings/index.d.ts +2 -1
  128. package/dist/types/src/components/DeckSettings/index.d.ts.map +1 -1
  129. package/dist/types/src/components/Matrix/Matrix.d.ts +49 -0
  130. package/dist/types/src/components/Matrix/Matrix.d.ts.map +1 -0
  131. package/dist/types/src/components/Matrix/Matrix.stories.d.ts +17 -0
  132. package/dist/types/src/components/Matrix/Matrix.stories.d.ts.map +1 -0
  133. package/dist/types/src/components/Matrix/index.d.ts +3 -0
  134. package/dist/types/src/components/Matrix/index.d.ts.map +1 -0
  135. package/dist/types/src/components/index.d.ts +3 -2
  136. package/dist/types/src/components/index.d.ts.map +1 -1
  137. package/dist/types/src/containers/Deck/Banner.d.ts.map +1 -0
  138. package/dist/types/src/containers/Deck/Deck.d.ts +25 -0
  139. package/dist/types/src/containers/Deck/Deck.d.ts.map +1 -0
  140. package/dist/types/src/containers/Deck/Deck.stories.d.ts +85 -0
  141. package/dist/types/src/containers/Deck/Deck.stories.d.ts.map +1 -0
  142. package/dist/types/src/containers/Deck/DeckContent.d.ts +7 -0
  143. package/dist/types/src/containers/Deck/DeckContent.d.ts.map +1 -0
  144. package/dist/types/src/containers/Deck/DeckRoot.d.ts +42 -0
  145. package/dist/types/src/containers/Deck/DeckRoot.d.ts.map +1 -0
  146. package/dist/types/src/containers/Deck/DeckViewport.d.ts +19 -0
  147. package/dist/types/src/containers/Deck/DeckViewport.d.ts.map +1 -0
  148. package/dist/types/src/containers/Deck/StatusBar.d.ts.map +1 -0
  149. package/dist/types/src/containers/Deck/index.d.ts +2 -0
  150. package/dist/types/src/containers/Deck/index.d.ts.map +1 -0
  151. package/dist/types/src/containers/DeckLayout/ActiveNode.d.ts.map +1 -0
  152. package/dist/types/src/containers/DeckLayout/DeckLayout.d.ts +5 -0
  153. package/dist/types/src/containers/DeckLayout/DeckLayout.d.ts.map +1 -0
  154. package/dist/types/src/containers/DeckLayout/DeckLayout.stories.d.ts +87 -0
  155. package/dist/types/src/containers/DeckLayout/DeckLayout.stories.d.ts.map +1 -0
  156. package/dist/types/src/containers/DeckLayout/Dialog.d.ts.map +1 -0
  157. package/dist/types/src/containers/DeckLayout/Fallback.d.ts +2 -0
  158. package/dist/types/src/containers/DeckLayout/Fallback.d.ts.map +1 -0
  159. package/dist/types/src/containers/DeckLayout/Popover.d.ts +5 -0
  160. package/dist/types/src/containers/DeckLayout/Popover.d.ts.map +1 -0
  161. package/dist/types/src/containers/DeckLayout/Toast.d.ts +10 -0
  162. package/dist/types/src/containers/DeckLayout/Toast.d.ts.map +1 -0
  163. package/dist/types/src/containers/DeckLayout/constants.d.ts.map +1 -0
  164. package/dist/types/src/containers/DeckLayout/index.d.ts +4 -0
  165. package/dist/types/src/containers/DeckLayout/index.d.ts.map +1 -0
  166. package/dist/types/src/containers/Plank/Plank.d.ts +21 -0
  167. package/dist/types/src/containers/Plank/Plank.d.ts.map +1 -0
  168. package/dist/types/src/containers/Plank/Plank.stories.d.ts +84 -0
  169. package/dist/types/src/containers/Plank/Plank.stories.d.ts.map +1 -0
  170. package/dist/types/src/containers/Plank/PlankComponent.d.ts +15 -0
  171. package/dist/types/src/containers/Plank/PlankComponent.d.ts.map +1 -0
  172. package/dist/types/src/containers/Plank/PlankContent.d.ts +14 -0
  173. package/dist/types/src/containers/Plank/PlankContent.d.ts.map +1 -0
  174. package/dist/types/src/{components → containers}/Plank/PlankControls.d.ts +5 -6
  175. package/dist/types/src/containers/Plank/PlankControls.d.ts.map +1 -0
  176. package/dist/types/src/containers/Plank/PlankError.d.ts +15 -0
  177. package/dist/types/src/containers/Plank/PlankError.d.ts.map +1 -0
  178. package/dist/types/src/{components → containers}/Plank/PlankHeading.d.ts +3 -3
  179. package/dist/types/src/containers/Plank/PlankHeading.d.ts.map +1 -0
  180. package/dist/types/src/{components → containers}/Plank/PlankLoading.d.ts.map +1 -1
  181. package/dist/types/src/containers/Plank/PlankRoot.d.ts +37 -0
  182. package/dist/types/src/containers/Plank/PlankRoot.d.ts.map +1 -0
  183. package/dist/types/src/containers/Plank/index.d.ts +4 -0
  184. package/dist/types/src/containers/Plank/index.d.ts.map +1 -0
  185. package/dist/types/src/containers/Sidebar/ComplementarySidebar.d.ts.map +1 -0
  186. package/dist/types/src/containers/Sidebar/Sidebar.d.ts.map +1 -0
  187. package/dist/types/src/containers/Sidebar/SidebarButton.d.ts.map +1 -0
  188. package/dist/types/src/{components → containers}/Sidebar/index.d.ts.map +1 -1
  189. package/dist/types/src/containers/index.d.ts +6 -0
  190. package/dist/types/src/containers/index.d.ts.map +1 -0
  191. package/dist/types/src/hooks/index.d.ts +2 -0
  192. package/dist/types/src/hooks/index.d.ts.map +1 -1
  193. package/dist/types/src/hooks/useDeckCompanions.d.ts +3 -4
  194. package/dist/types/src/hooks/useDeckCompanions.d.ts.map +1 -1
  195. package/dist/types/src/hooks/useDeckState.d.ts +17 -0
  196. package/dist/types/src/hooks/useDeckState.d.ts.map +1 -0
  197. package/dist/types/src/hooks/useHoistStatusbar.d.ts +1 -1
  198. package/dist/types/src/hooks/useHoistStatusbar.d.ts.map +1 -1
  199. package/dist/types/src/hooks/useMainSize.d.ts +2 -2
  200. package/dist/types/src/hooks/useNodeActionExpander.d.ts +1 -1
  201. package/dist/types/src/hooks/useNodeActionExpander.d.ts.map +1 -1
  202. package/dist/types/src/hooks/useSelectedCompanion.d.ts +13 -0
  203. package/dist/types/src/hooks/useSelectedCompanion.d.ts.map +1 -0
  204. package/dist/types/src/index.d.ts +1 -2
  205. package/dist/types/src/index.d.ts.map +1 -1
  206. package/dist/types/src/layout.d.ts +3 -9
  207. package/dist/types/src/layout.d.ts.map +1 -1
  208. package/dist/types/src/meta.d.ts +2 -3
  209. package/dist/types/src/meta.d.ts.map +1 -1
  210. package/dist/types/src/operations/add-toast.d.ts +5 -0
  211. package/dist/types/src/operations/add-toast.d.ts.map +1 -0
  212. package/dist/types/src/operations/adjust.d.ts +5 -0
  213. package/dist/types/src/operations/adjust.d.ts.map +1 -0
  214. package/dist/types/src/operations/change-companion.d.ts +5 -0
  215. package/dist/types/src/operations/change-companion.d.ts.map +1 -0
  216. package/dist/types/src/operations/close.d.ts +5 -0
  217. package/dist/types/src/operations/close.d.ts.map +1 -0
  218. package/dist/types/src/operations/definitions.d.ts +18 -0
  219. package/dist/types/src/operations/definitions.d.ts.map +1 -0
  220. package/dist/types/src/operations/helpers.d.ts +3 -0
  221. package/dist/types/src/operations/helpers.d.ts.map +1 -0
  222. package/dist/types/src/operations/index.d.ts +4 -0
  223. package/dist/types/src/operations/index.d.ts.map +1 -0
  224. package/dist/types/src/operations/open.d.ts +5 -0
  225. package/dist/types/src/operations/open.d.ts.map +1 -0
  226. package/dist/types/src/operations/revert-workspace.d.ts +5 -0
  227. package/dist/types/src/operations/revert-workspace.d.ts.map +1 -0
  228. package/dist/types/src/operations/scroll-into-view.d.ts +5 -0
  229. package/dist/types/src/operations/scroll-into-view.d.ts.map +1 -0
  230. package/dist/types/src/operations/set-layout-mode.d.ts +9 -0
  231. package/dist/types/src/operations/set-layout-mode.d.ts.map +1 -0
  232. package/dist/types/src/operations/set.d.ts +5 -0
  233. package/dist/types/src/operations/set.d.ts.map +1 -0
  234. package/dist/types/src/operations/show-undo.d.ts +5 -0
  235. package/dist/types/src/operations/show-undo.d.ts.map +1 -0
  236. package/dist/types/src/operations/switch-workspace.d.ts +5 -0
  237. package/dist/types/src/operations/switch-workspace.d.ts.map +1 -0
  238. package/dist/types/src/operations/update-complementary.d.ts +5 -0
  239. package/dist/types/src/operations/update-complementary.d.ts.map +1 -0
  240. package/dist/types/src/operations/update-dialog.d.ts +5 -0
  241. package/dist/types/src/operations/update-dialog.d.ts.map +1 -0
  242. package/dist/types/src/operations/update-plank-size.d.ts +5 -0
  243. package/dist/types/src/operations/update-plank-size.d.ts.map +1 -0
  244. package/dist/types/src/operations/update-popover.d.ts +5 -0
  245. package/dist/types/src/operations/update-popover.d.ts.map +1 -0
  246. package/dist/types/src/operations/update-sidebar.d.ts +5 -0
  247. package/dist/types/src/operations/update-sidebar.d.ts.map +1 -0
  248. package/dist/types/src/testing/DeckLayoutStoryNavigation.d.ts +10 -0
  249. package/dist/types/src/testing/DeckLayoutStoryNavigation.d.ts.map +1 -0
  250. package/dist/types/src/testing/index.d.ts +2 -0
  251. package/dist/types/src/testing/index.d.ts.map +1 -0
  252. package/dist/types/src/translations.d.ts +66 -52
  253. package/dist/types/src/translations.d.ts.map +1 -1
  254. package/dist/types/src/types/Settings.d.ts +16 -0
  255. package/dist/types/src/types/Settings.d.ts.map +1 -0
  256. package/dist/types/src/{capabilities → types}/capabilities.d.ts +96 -90
  257. package/dist/types/src/types/capabilities.d.ts.map +1 -0
  258. package/dist/types/src/types/events.d.ts +7 -0
  259. package/dist/types/src/types/events.d.ts.map +1 -0
  260. package/dist/types/src/types/index.d.ts +3 -0
  261. package/dist/types/src/types/index.d.ts.map +1 -1
  262. package/dist/types/src/types/schema.d.ts +58 -54
  263. package/dist/types/src/types/schema.d.ts.map +1 -1
  264. package/dist/types/src/util/index.d.ts +1 -0
  265. package/dist/types/src/util/index.d.ts.map +1 -1
  266. package/dist/types/src/util/layoutAppliesTopbar.d.ts +1 -1
  267. package/dist/types/src/util/layoutAppliesTopbar.d.ts.map +1 -1
  268. package/dist/types/src/util/sanitize-persisted-state.d.ts +19 -0
  269. package/dist/types/src/util/sanitize-persisted-state.d.ts.map +1 -0
  270. package/dist/types/src/util/sanitize-persisted-state.test.d.ts +2 -0
  271. package/dist/types/src/util/sanitize-persisted-state.test.d.ts.map +1 -0
  272. package/dist/types/src/util/set-active.d.ts +19 -4
  273. package/dist/types/src/util/set-active.d.ts.map +1 -1
  274. package/dist/types/src/util/set-active.test.d.ts +2 -0
  275. package/dist/types/src/util/set-active.test.d.ts.map +1 -0
  276. package/dist/types/tsconfig.tsbuildinfo +1 -1
  277. package/package.json +90 -47
  278. package/src/DeckPlugin.ts +44 -64
  279. package/src/capabilities/app-graph-builder.ts +113 -127
  280. package/src/capabilities/check-app-scheme.ts +123 -24
  281. package/src/capabilities/index.ts +13 -13
  282. package/src/capabilities/operation-handler.ts +16 -0
  283. package/src/capabilities/react-root.tsx +37 -28
  284. package/src/capabilities/react-surface.tsx +30 -22
  285. package/src/capabilities/settings.ts +32 -19
  286. package/src/capabilities/state.ts +74 -88
  287. package/src/capabilities/tools.ts +64 -54
  288. package/src/capabilities/url-handler.ts +199 -49
  289. package/src/components/DeckSettings/DeckSettings.stories.tsx +40 -0
  290. package/src/components/DeckSettings/DeckSettings.tsx +104 -69
  291. package/src/components/DeckSettings/index.ts +4 -2
  292. package/src/components/Matrix/Matrix.stories.tsx +213 -0
  293. package/src/components/Matrix/Matrix.tsx +205 -0
  294. package/src/components/Matrix/SPEC.md +219 -0
  295. package/src/components/Matrix/index.ts +6 -0
  296. package/src/components/index.ts +6 -3
  297. package/src/containers/Deck/Banner.tsx +40 -0
  298. package/src/containers/Deck/Deck.stories.tsx +85 -0
  299. package/src/containers/Deck/Deck.tsx +21 -0
  300. package/src/containers/Deck/DeckContent.tsx +104 -0
  301. package/src/containers/Deck/DeckRoot.tsx +49 -0
  302. package/src/containers/Deck/DeckViewport.tsx +397 -0
  303. package/src/{components/DeckLayout → containers/Deck}/StatusBar.tsx +4 -4
  304. package/src/containers/Deck/index.ts +5 -0
  305. package/src/{components → containers}/DeckLayout/ActiveNode.tsx +4 -3
  306. package/src/containers/DeckLayout/DeckLayout.stories.tsx +174 -0
  307. package/src/containers/DeckLayout/DeckLayout.tsx +62 -0
  308. package/src/{components → containers}/DeckLayout/Dialog.tsx +22 -13
  309. package/src/containers/DeckLayout/Fallback.tsx +24 -0
  310. package/src/containers/DeckLayout/Popover.tsx +156 -0
  311. package/src/{components → containers}/DeckLayout/Toast.tsx +30 -5
  312. package/src/{components → containers}/DeckLayout/constants.ts +1 -0
  313. package/src/{components → containers}/DeckLayout/index.ts +3 -2
  314. package/src/containers/Plank/Plank.stories.tsx +105 -0
  315. package/src/containers/Plank/Plank.tsx +22 -0
  316. package/src/containers/Plank/PlankComponent.tsx +179 -0
  317. package/src/containers/Plank/PlankContent.tsx +45 -0
  318. package/src/{components → containers}/Plank/PlankControls.tsx +44 -37
  319. package/src/containers/Plank/PlankError.tsx +79 -0
  320. package/src/{components → containers}/Plank/PlankHeading.tsx +50 -63
  321. package/src/{components → containers}/Plank/PlankLoading.tsx +1 -1
  322. package/src/containers/Plank/PlankRoot.tsx +49 -0
  323. package/src/{components → containers}/Plank/index.ts +0 -2
  324. package/src/containers/Sidebar/ComplementarySidebar.tsx +209 -0
  325. package/src/{components → containers}/Sidebar/Sidebar.tsx +10 -10
  326. package/src/containers/Sidebar/SidebarButton.tsx +94 -0
  327. package/src/containers/index.ts +11 -0
  328. package/src/hooks/index.ts +2 -0
  329. package/src/hooks/useCompanions.ts +3 -3
  330. package/src/hooks/useDeckCompanions.ts +8 -11
  331. package/src/hooks/useDeckState.ts +73 -0
  332. package/src/hooks/useHoistStatusbar.ts +4 -5
  333. package/src/hooks/useMainSize.ts +2 -2
  334. package/src/hooks/useNodeActionExpander.ts +4 -4
  335. package/src/hooks/useSelectedCompanion.ts +32 -0
  336. package/src/index.ts +1 -2
  337. package/src/layout.ts +3 -16
  338. package/src/meta.ts +8 -5
  339. package/src/operations/add-toast.ts +24 -0
  340. package/src/operations/adjust.ts +83 -0
  341. package/src/operations/change-companion.ts +35 -0
  342. package/src/operations/close.ts +35 -0
  343. package/src/operations/definitions.ts +61 -0
  344. package/src/operations/helpers.ts +22 -0
  345. package/src/operations/index.ts +26 -0
  346. package/src/operations/open.ts +117 -0
  347. package/src/operations/revert-workspace.ts +22 -0
  348. package/src/operations/scroll-into-view.ts +24 -0
  349. package/src/operations/set-layout-mode.ts +84 -0
  350. package/src/operations/set.ts +36 -0
  351. package/src/operations/show-undo.ts +46 -0
  352. package/src/operations/switch-workspace.ts +60 -0
  353. package/src/operations/update-complementary.ts +33 -0
  354. package/src/operations/update-dialog.ts +34 -0
  355. package/src/operations/update-plank-size.ts +29 -0
  356. package/src/operations/update-popover.ts +36 -0
  357. package/src/operations/update-sidebar.ts +28 -0
  358. package/src/testing/DeckLayoutStoryNavigation.tsx +57 -0
  359. package/src/testing/index.ts +5 -0
  360. package/src/translations.ts +67 -52
  361. package/src/types/Settings.ts +26 -0
  362. package/src/types/capabilities.ts +34 -0
  363. package/src/types/events.ts +21 -0
  364. package/src/types/index.ts +3 -0
  365. package/src/types/schema.ts +45 -48
  366. package/src/util/index.ts +1 -0
  367. package/src/util/layoutAppliesTopbar.ts +2 -2
  368. package/src/util/overscroll.ts +3 -3
  369. package/src/util/sanitize-persisted-state.test.ts +79 -0
  370. package/src/util/sanitize-persisted-state.ts +52 -0
  371. package/src/util/set-active.test.ts +106 -0
  372. package/src/util/set-active.ts +50 -30
  373. package/src/vite-env.d.ts +5 -0
  374. package/dist/lib/browser/app-graph-builder-JTFSDT2I.mjs +0 -152
  375. package/dist/lib/browser/app-graph-builder-JTFSDT2I.mjs.map +0 -7
  376. package/dist/lib/browser/check-app-scheme-57U62A3A.mjs +0 -32
  377. package/dist/lib/browser/check-app-scheme-57U62A3A.mjs.map +0 -7
  378. package/dist/lib/browser/chunk-CNTGBCMK.mjs +0 -145
  379. package/dist/lib/browser/chunk-CNTGBCMK.mjs.map +0 -7
  380. package/dist/lib/browser/chunk-D7KTFCUV.mjs +0 -1494
  381. package/dist/lib/browser/chunk-D7KTFCUV.mjs.map +0 -7
  382. package/dist/lib/browser/chunk-F5BQOOEG.mjs +0 -160
  383. package/dist/lib/browser/chunk-F5BQOOEG.mjs.map +0 -7
  384. package/dist/lib/browser/chunk-JFTXENFN.mjs +0 -129
  385. package/dist/lib/browser/chunk-JFTXENFN.mjs.map +0 -7
  386. package/dist/lib/browser/chunk-M57WD3V6.mjs +0 -16
  387. package/dist/lib/browser/chunk-M57WD3V6.mjs.map +0 -7
  388. package/dist/lib/browser/chunk-QDZO4AJ4.mjs +0 -127
  389. package/dist/lib/browser/chunk-QDZO4AJ4.mjs.map +0 -7
  390. package/dist/lib/browser/chunk-Z5KITAZW.mjs +0 -13
  391. package/dist/lib/browser/chunk-Z5KITAZW.mjs.map +0 -7
  392. package/dist/lib/browser/intent-resolver-P2OBK5HK.mjs +0 -521
  393. package/dist/lib/browser/intent-resolver-P2OBK5HK.mjs.map +0 -7
  394. package/dist/lib/browser/react-root-PO64J7ML.mjs +0 -43
  395. package/dist/lib/browser/react-root-PO64J7ML.mjs.map +0 -7
  396. package/dist/lib/browser/react-surface-E45YOVF5.mjs +0 -40
  397. package/dist/lib/browser/react-surface-E45YOVF5.mjs.map +0 -7
  398. package/dist/lib/browser/settings-6AJZPZPM.mjs +0 -29
  399. package/dist/lib/browser/settings-6AJZPZPM.mjs.map +0 -7
  400. package/dist/lib/browser/state-MVDYX77Y.mjs +0 -12
  401. package/dist/lib/browser/tools-TKQDPCHJ.mjs +0 -88
  402. package/dist/lib/browser/tools-TKQDPCHJ.mjs.map +0 -7
  403. package/dist/lib/browser/url-handler-7L7M6IKH.mjs +0 -70
  404. package/dist/lib/browser/url-handler-7L7M6IKH.mjs.map +0 -7
  405. package/dist/types/src/capabilities/capabilities.d.ts.map +0 -1
  406. package/dist/types/src/capabilities/intent-resolver.d.ts +0 -4
  407. package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
  408. package/dist/types/src/components/DeckLayout/ActiveNode.d.ts.map +0 -1
  409. package/dist/types/src/components/DeckLayout/Banner.d.ts.map +0 -1
  410. package/dist/types/src/components/DeckLayout/ContentEmpty.d.ts +0 -3
  411. package/dist/types/src/components/DeckLayout/ContentEmpty.d.ts.map +0 -1
  412. package/dist/types/src/components/DeckLayout/DeckLayout.d.ts +0 -6
  413. package/dist/types/src/components/DeckLayout/DeckLayout.d.ts.map +0 -1
  414. package/dist/types/src/components/DeckLayout/Dialog.d.ts.map +0 -1
  415. package/dist/types/src/components/DeckLayout/Fallback.d.ts +0 -3
  416. package/dist/types/src/components/DeckLayout/Fallback.d.ts.map +0 -1
  417. package/dist/types/src/components/DeckLayout/Popover.d.ts +0 -5
  418. package/dist/types/src/components/DeckLayout/Popover.d.ts.map +0 -1
  419. package/dist/types/src/components/DeckLayout/StatusBar.d.ts.map +0 -1
  420. package/dist/types/src/components/DeckLayout/Toast.d.ts +0 -5
  421. package/dist/types/src/components/DeckLayout/Toast.d.ts.map +0 -1
  422. package/dist/types/src/components/DeckLayout/Topbar.d.ts +0 -3
  423. package/dist/types/src/components/DeckLayout/Topbar.d.ts.map +0 -1
  424. package/dist/types/src/components/DeckLayout/constants.d.ts.map +0 -1
  425. package/dist/types/src/components/DeckLayout/index.d.ts +0 -4
  426. package/dist/types/src/components/DeckLayout/index.d.ts.map +0 -1
  427. package/dist/types/src/components/Plank/Plank.d.ts +0 -27
  428. package/dist/types/src/components/Plank/Plank.d.ts.map +0 -1
  429. package/dist/types/src/components/Plank/Plank.stories.d.ts +0 -8
  430. package/dist/types/src/components/Plank/Plank.stories.d.ts.map +0 -1
  431. package/dist/types/src/components/Plank/PlankControls.d.ts.map +0 -1
  432. package/dist/types/src/components/Plank/PlankError.d.ts +0 -13
  433. package/dist/types/src/components/Plank/PlankError.d.ts.map +0 -1
  434. package/dist/types/src/components/Plank/PlankHeading.d.ts.map +0 -1
  435. package/dist/types/src/components/Plank/index.d.ts +0 -6
  436. package/dist/types/src/components/Plank/index.d.ts.map +0 -1
  437. package/dist/types/src/components/Sidebar/ComplementarySidebar.d.ts.map +0 -1
  438. package/dist/types/src/components/Sidebar/Sidebar.d.ts.map +0 -1
  439. package/dist/types/src/components/Sidebar/SidebarButton.d.ts.map +0 -1
  440. package/dist/types/src/components/fragments.d.ts +0 -4
  441. package/dist/types/src/components/fragments.d.ts.map +0 -1
  442. package/dist/types/src/events.d.ts +0 -4
  443. package/dist/types/src/events.d.ts.map +0 -1
  444. package/src/capabilities/capabilities.ts +0 -14
  445. package/src/capabilities/intent-resolver.ts +0 -468
  446. package/src/components/DeckLayout/Banner.tsx +0 -39
  447. package/src/components/DeckLayout/ContentEmpty.tsx +0 -31
  448. package/src/components/DeckLayout/DeckLayout.tsx +0 -301
  449. package/src/components/DeckLayout/Fallback.tsx +0 -28
  450. package/src/components/DeckLayout/Popover.tsx +0 -104
  451. package/src/components/DeckLayout/Topbar.tsx +0 -11
  452. package/src/components/Plank/Plank.stories.tsx +0 -55
  453. package/src/components/Plank/Plank.tsx +0 -266
  454. package/src/components/Plank/PlankError.tsx +0 -48
  455. package/src/components/Sidebar/ComplementarySidebar.tsx +0 -193
  456. package/src/components/Sidebar/SidebarButton.tsx +0 -87
  457. package/src/components/fragments.ts +0 -14
  458. package/src/events.ts +0 -11
  459. /package/dist/lib/browser/{state-MVDYX77Y.mjs.map → chunk-J5LGTIGS.mjs.map} +0 -0
  460. /package/dist/types/src/{components/DeckLayout → containers/Deck}/Banner.d.ts +0 -0
  461. /package/dist/types/src/{components/DeckLayout → containers/Deck}/StatusBar.d.ts +0 -0
  462. /package/dist/types/src/{components → containers}/DeckLayout/ActiveNode.d.ts +0 -0
  463. /package/dist/types/src/{components → containers}/DeckLayout/Dialog.d.ts +0 -0
  464. /package/dist/types/src/{components → containers}/DeckLayout/constants.d.ts +0 -0
  465. /package/dist/types/src/{components → containers}/Plank/PlankLoading.d.ts +0 -0
  466. /package/dist/types/src/{components → containers}/Sidebar/ComplementarySidebar.d.ts +0 -0
  467. /package/dist/types/src/{components → containers}/Sidebar/Sidebar.d.ts +0 -0
  468. /package/dist/types/src/{components → containers}/Sidebar/SidebarButton.d.ts +0 -0
  469. /package/dist/types/src/{components → containers}/Sidebar/index.d.ts +0 -0
  470. /package/src/{components → containers}/Sidebar/index.ts +0 -0
@@ -0,0 +1,106 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { describe, test } from 'vitest';
6
+
7
+ import { defaultDeck, type DeckState } from '#types';
8
+
9
+ import { computeActiveUpdates } from './set-active';
10
+
11
+ const makeDeck = (overrides: Partial<DeckState> = {}): DeckState => ({
12
+ ...defaultDeck,
13
+ ...overrides,
14
+ });
15
+
16
+ describe('computeActiveUpdates', () => {
17
+ describe('routing to solo vs active', () => {
18
+ test('routes to solo when initialized is false and solo is undefined', ({ expect }) => {
19
+ const deck = makeDeck({ initialized: false });
20
+ const { deckUpdates } = computeActiveUpdates({ next: ['item1'], deck });
21
+ expect(deckUpdates.solo).toBe('item1');
22
+ expect(deckUpdates.active).toEqual([]);
23
+ });
24
+
25
+ test('routes to solo when solo is set (regardless of initialized)', ({ expect }) => {
26
+ const deck = makeDeck({ solo: 'current', initialized: true });
27
+ const { deckUpdates } = computeActiveUpdates({ next: ['item1'], deck });
28
+ expect(deckUpdates.solo).toBe('item1');
29
+ expect(deckUpdates.active).toEqual([]);
30
+ });
31
+
32
+ test('routes to active when initialized is true and solo is undefined', ({ expect }) => {
33
+ const deck = makeDeck({ initialized: true });
34
+ const { deckUpdates } = computeActiveUpdates({ next: ['item1', 'item2'], deck });
35
+ expect(deckUpdates.solo).toBeUndefined();
36
+ expect(deckUpdates.active).toEqual(['item1', 'item2']);
37
+ });
38
+ });
39
+
40
+ describe('active preservation', () => {
41
+ test('preserves active unchanged when routing to solo', ({ expect }) => {
42
+ const deck = makeDeck({ solo: 'current', active: ['a', 'b', 'c'], initialized: true });
43
+ const { deckUpdates } = computeActiveUpdates({ next: ['item1'], deck });
44
+ expect(deckUpdates.solo).toBe('item1');
45
+ expect(deckUpdates.active).toEqual(['a', 'b', 'c']);
46
+ });
47
+
48
+ test('preserves active when initialized is false', ({ expect }) => {
49
+ const deck = makeDeck({ initialized: false, active: ['stale'] });
50
+ const { deckUpdates } = computeActiveUpdates({ next: ['item1'], deck });
51
+ expect(deckUpdates.solo).toBe('item1');
52
+ expect(deckUpdates.active).toEqual(['stale']);
53
+ });
54
+ });
55
+
56
+ describe('inactive handling', () => {
57
+ test('moves removed items to inactive', ({ expect }) => {
58
+ const deck = makeDeck({ initialized: true, active: ['a', 'b', 'c'] });
59
+ const { deckUpdates } = computeActiveUpdates({ next: ['a', 'c'], deck });
60
+ expect(deckUpdates.active).toEqual(['a', 'c']);
61
+ expect(deckUpdates.inactive).toContain('b');
62
+ });
63
+
64
+ test('moves displaced solo item to inactive', ({ expect }) => {
65
+ const deck = makeDeck({ solo: 'old', initialized: true });
66
+ const { deckUpdates } = computeActiveUpdates({ next: ['new'], deck });
67
+ expect(deckUpdates.solo).toBe('new');
68
+ expect(deckUpdates.inactive).toContain('old');
69
+ });
70
+
71
+ test('does not duplicate items already in inactive', ({ expect }) => {
72
+ const deck = makeDeck({ solo: 'old', initialized: true, inactive: ['old'] });
73
+ const { deckUpdates } = computeActiveUpdates({ next: ['new'], deck });
74
+ const oldCount = deckUpdates.inactive.filter((id) => id === 'old').length;
75
+ expect(oldCount).toBe(1);
76
+ });
77
+ });
78
+
79
+ describe('fullscreen', () => {
80
+ test('clears fullscreen when solo is cleared', ({ expect }) => {
81
+ const deck = makeDeck({ solo: 'item', fullscreen: true, initialized: true });
82
+ const { deckUpdates } = computeActiveUpdates({ next: [], deck });
83
+ expect(deckUpdates.fullscreen).toBe(false);
84
+ });
85
+
86
+ test('preserves fullscreen when solo is set', ({ expect }) => {
87
+ const deck = makeDeck({ solo: 'old', fullscreen: true, initialized: true });
88
+ const { deckUpdates } = computeActiveUpdates({ next: ['new'], deck });
89
+ expect(deckUpdates.fullscreen).toBe(true);
90
+ });
91
+ });
92
+
93
+ describe('empty next', () => {
94
+ test('clears solo when next is empty and in solo mode', ({ expect }) => {
95
+ const deck = makeDeck({ solo: 'item', initialized: false });
96
+ const { deckUpdates } = computeActiveUpdates({ next: [], deck });
97
+ expect(deckUpdates.solo).toBeUndefined();
98
+ });
99
+
100
+ test('clears active when next is empty and in deck mode', ({ expect }) => {
101
+ const deck = makeDeck({ initialized: true, active: ['a', 'b'] });
102
+ const { deckUpdates } = computeActiveUpdates({ next: [], deck });
103
+ expect(deckUpdates.active).toEqual([]);
104
+ });
105
+ });
106
+ });
@@ -2,46 +2,66 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { batch } from '@preact/signals-core';
5
+ import { type AttentionManager } from '@dxos/react-ui-attention';
6
6
 
7
- import { type AttentionManager } from '@dxos/plugin-attention';
8
-
9
- import { type DeckPluginState } from '../types';
7
+ import { type DeckState } from '#types';
10
8
 
11
9
  export type SetActiveOptions = {
12
10
  next: string[];
13
- state: DeckPluginState;
11
+ deck: DeckState;
14
12
  attention?: AttentionManager;
15
13
  };
16
14
 
17
- export const setActive = ({ next, state, attention }: SetActiveOptions) => {
18
- return batch(() => {
19
- const active = state.deck.solo ? [state.deck.solo] : state.deck.active;
20
- const removed = active.filter((id) => !next.includes(id));
21
- const closed = Array.from(new Set([...state.deck.inactive.filter((id) => !next.includes(id)), ...removed]));
15
+ export type SetActiveResult = {
16
+ /** Updates to apply to the deck. */
17
+ deckUpdates: {
18
+ inactive: string[];
19
+ solo: string | undefined;
20
+ active: string[];
21
+ fullscreen: boolean;
22
+ };
23
+ /** ID of the item to attend (scroll into view) if attention changed. */
24
+ toAttend?: string;
25
+ };
22
26
 
23
- state.deck.inactive = closed;
27
+ /**
28
+ * Computes the new active state for the deck without mutating.
29
+ * Returns the updates to apply and optionally an item to attend.
30
+ */
31
+ export const computeActiveUpdates = ({ next, deck, attention }: SetActiveOptions): SetActiveResult => {
32
+ const active = deck.solo ? [deck.solo] : deck.active;
33
+ const removed = active.filter((id) => !next.includes(id));
34
+ const closed = Array.from(new Set([...deck.inactive.filter((id) => !next.includes(id)), ...removed]));
24
35
 
25
- if (state.deck.solo || !state.deck.initialized) {
26
- state.deck.solo = next[0];
27
- } else {
28
- state.deck.active = next;
29
- }
36
+ const updates = {
37
+ inactive: closed,
38
+ solo: deck.solo,
39
+ active: deck.active,
40
+ fullscreen: deck.fullscreen,
41
+ };
30
42
 
31
- if (state.deck.fullscreen && !state.deck.solo) {
32
- state.deck.fullscreen = false;
33
- }
43
+ if (deck.solo || !deck.initialized) {
44
+ updates.solo = next[0];
45
+ } else {
46
+ updates.active = next;
47
+ }
48
+
49
+ if (deck.fullscreen && !updates.solo) {
50
+ updates.fullscreen = false;
51
+ }
34
52
 
35
- if (attention) {
36
- const attended = attention.current;
37
- const [attendedId] = Array.from(attended);
38
- const isAttendedAvailable = !!attendedId && next.includes(attendedId);
39
- if (!isAttendedAvailable) {
40
- const attendedIndex = active.indexOf(attendedId);
41
- // If outside of bounds, focus on the first/last plank, otherwise focus on the new plank in the same position.
42
- const index = attendedIndex === -1 ? 0 : attendedIndex >= next.length ? next.length - 1 : attendedIndex;
43
- return next[index];
44
- }
53
+ let toAttend: string | undefined;
54
+ if (attention) {
55
+ const attended = attention.getCurrent();
56
+ const [attendedId] = Array.from(attended);
57
+ const isAttendedAvailable = !!attendedId && next.includes(attendedId);
58
+ if (!isAttendedAvailable) {
59
+ const attendedIndex = active.indexOf(attendedId);
60
+ // If outside of bounds, focus on the first/last plank, otherwise focus on the new plank in the same position.
61
+ const index = attendedIndex === -1 ? 0 : attendedIndex >= next.length ? next.length - 1 : attendedIndex;
62
+ toAttend = next[index];
45
63
  }
46
- });
64
+ }
65
+
66
+ return { deckUpdates: updates, toAttend };
47
67
  };
@@ -0,0 +1,5 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ /// <reference types="vite/client" />
@@ -1,152 +0,0 @@
1
- import {
2
- DeckCapabilities
3
- } from "./chunk-M57WD3V6.mjs";
4
- import {
5
- DECK_PLUGIN
6
- } from "./chunk-Z5KITAZW.mjs";
7
-
8
- // src/capabilities/app-graph-builder.ts
9
- import { Rx } from "@effect-rx/rx-react";
10
- import { Option, pipe } from "effect";
11
- import { Capabilities, contributes, createIntent, LayoutAction } from "@dxos/app-framework";
12
- import { AttentionCapabilities } from "@dxos/plugin-attention";
13
- import { createExtension, ROOT_ID, rxFromSignal } from "@dxos/plugin-graph";
14
- var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBuilder, createExtension({
15
- id: DECK_PLUGIN,
16
- actions: (node) => Rx.make((get) => pipe(get(node), Option.flatMap((node2) => node2.id === ROOT_ID ? Option.some(node2) : Option.none()), Option.map(() => {
17
- const state = context.getCapability(DeckCapabilities.MutableDeckState);
18
- const _fullscreen = {
19
- id: `${LayoutAction.UpdateLayout._tag}/fullscreen`,
20
- data: async () => {
21
- const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
22
- await dispatch(createIntent(LayoutAction.SetLayoutMode, {
23
- part: "mode",
24
- options: {
25
- mode: "fullscreen"
26
- }
27
- }));
28
- },
29
- properties: {
30
- label: [
31
- "toggle fullscreen label",
32
- {
33
- ns: DECK_PLUGIN
34
- }
35
- ],
36
- icon: "ph--arrows-out--regular",
37
- keyBinding: {
38
- macos: "ctrl+meta+f",
39
- windows: "shift+ctrl+f"
40
- }
41
- }
42
- };
43
- const closeCurrent = {
44
- id: `${LayoutAction.Close._tag}/current`,
45
- data: async () => {
46
- const attention = context.getCapability(AttentionCapabilities.Attention);
47
- const attended = attention.current.at(-1);
48
- if (attended) {
49
- const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
50
- await dispatch(createIntent(LayoutAction.Close, {
51
- part: "main",
52
- subject: [
53
- attended
54
- ],
55
- options: {
56
- state: false
57
- }
58
- }));
59
- }
60
- },
61
- properties: {
62
- label: [
63
- "close current label",
64
- {
65
- ns: DECK_PLUGIN
66
- }
67
- ],
68
- icon: "ph--x--regular"
69
- }
70
- };
71
- const closeOthers = {
72
- id: `${LayoutAction.Close._tag}/others`,
73
- data: async () => {
74
- const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
75
- const attention = context.getCapability(AttentionCapabilities.Attention);
76
- const attended = attention.current.at(-1);
77
- const ids = state.deck.active.filter((id) => id !== attended) ?? [];
78
- await dispatch(createIntent(LayoutAction.Close, {
79
- part: "main",
80
- subject: ids,
81
- options: {
82
- state: false
83
- }
84
- }));
85
- },
86
- properties: {
87
- label: [
88
- "close others label",
89
- {
90
- ns: DECK_PLUGIN
91
- }
92
- ],
93
- icon: "ph--x-square--regular"
94
- }
95
- };
96
- const closeAll = {
97
- id: `${LayoutAction.Close._tag}/all`,
98
- data: async () => {
99
- const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
100
- await dispatch(createIntent(LayoutAction.Close, {
101
- part: "main",
102
- subject: state.deck.active,
103
- options: {
104
- state: false
105
- }
106
- }));
107
- },
108
- properties: {
109
- label: [
110
- "close all label",
111
- {
112
- ns: DECK_PLUGIN
113
- }
114
- ],
115
- icon: "ph--x-circle--regular"
116
- }
117
- };
118
- const toggleSidebar = {
119
- id: `${LayoutAction.UpdateSidebar._tag}/nav`,
120
- data: async () => {
121
- state.sidebarState = state.sidebarState === "expanded" ? "collapsed" : "expanded";
122
- },
123
- properties: {
124
- label: [
125
- get(rxFromSignal(() => state.sidebarState === "expanded" ? "collapse navigation sidebar label" : "open navigation sidebar label")),
126
- {
127
- ns: DECK_PLUGIN
128
- }
129
- ],
130
- icon: "ph--sidebar--regular",
131
- keyBinding: {
132
- macos: "meta+'"
133
- },
134
- disposition: "pin-end",
135
- position: "hoist",
136
- l0Breakpoint: "lg"
137
- }
138
- };
139
- return get(rxFromSignal(() => !state.deck.solo ? [
140
- closeCurrent,
141
- closeOthers,
142
- closeAll,
143
- toggleSidebar
144
- ] : [
145
- toggleSidebar
146
- ]));
147
- }), Option.getOrElse(() => [])))
148
- }));
149
- export {
150
- app_graph_builder_default as default
151
- };
152
- //# sourceMappingURL=app-graph-builder-JTFSDT2I.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/capabilities/app-graph-builder.ts"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Rx } from '@effect-rx/rx-react';\nimport { Option, pipe } from 'effect';\n\nimport { Capabilities, contributes, createIntent, LayoutAction, type PluginContext } from '@dxos/app-framework';\nimport { AttentionCapabilities } from '@dxos/plugin-attention';\nimport { createExtension, ROOT_ID, rxFromSignal } from '@dxos/plugin-graph';\n\nimport { DeckCapabilities } from './capabilities';\nimport { DECK_PLUGIN } from '../meta';\n\nexport default (context: PluginContext) =>\n contributes(\n Capabilities.AppGraphBuilder,\n createExtension({\n id: DECK_PLUGIN,\n actions: (node) =>\n Rx.make((get) =>\n pipe(\n get(node),\n Option.flatMap((node) => (node.id === ROOT_ID ? Option.some(node) : Option.none())),\n Option.map(() => {\n const state = context.getCapability(DeckCapabilities.MutableDeckState);\n\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.getCapability(Capabilities.IntentDispatcher);\n await dispatch(\n createIntent(LayoutAction.SetLayoutMode, { part: 'mode', options: { mode: 'fullscreen' } }),\n );\n },\n properties: {\n label: ['toggle fullscreen label', { ns: DECK_PLUGIN }],\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: `${LayoutAction.Close._tag}/current`,\n data: async () => {\n const attention = context.getCapability(AttentionCapabilities.Attention);\n const attended = attention.current.at(-1);\n if (attended) {\n const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);\n await dispatch(\n createIntent(LayoutAction.Close, {\n part: 'main',\n subject: [attended],\n options: { state: false },\n }),\n );\n }\n },\n properties: {\n label: ['close current label', { ns: DECK_PLUGIN }],\n icon: 'ph--x--regular',\n },\n };\n\n const closeOthers = {\n id: `${LayoutAction.Close._tag}/others`,\n data: async () => {\n const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);\n const attention = context.getCapability(AttentionCapabilities.Attention);\n const attended = attention.current.at(-1);\n const ids = state.deck.active.filter((id) => id !== attended) ?? [];\n await dispatch(\n createIntent(LayoutAction.Close, { part: 'main', subject: ids, options: { state: false } }),\n );\n },\n properties: {\n label: ['close others label', { ns: DECK_PLUGIN }],\n icon: 'ph--x-square--regular',\n },\n };\n\n const closeAll = {\n id: `${LayoutAction.Close._tag}/all`,\n data: async () => {\n const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);\n await dispatch(\n createIntent(LayoutAction.Close, {\n part: 'main',\n subject: state.deck.active,\n options: { state: false },\n }),\n );\n },\n properties: {\n label: ['close all label', { ns: DECK_PLUGIN }],\n icon: 'ph--x-circle--regular',\n },\n };\n\n const toggleSidebar = {\n id: `${LayoutAction.UpdateSidebar._tag}/nav`,\n data: async () => {\n state.sidebarState = state.sidebarState === 'expanded' ? 'collapsed' : 'expanded';\n },\n properties: {\n label: [\n get(\n rxFromSignal(() =>\n state.sidebarState === 'expanded'\n ? 'collapse navigation sidebar label'\n : 'open navigation sidebar label',\n ),\n ),\n { ns: DECK_PLUGIN },\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 get(\n rxFromSignal(() =>\n !state.deck.solo ? [closeCurrent, closeOthers, closeAll, toggleSidebar] : [toggleSidebar],\n ),\n );\n }),\n Option.getOrElse(() => []),\n ),\n ),\n }),\n );\n"],
5
- "mappings": "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",
6
- "names": ["Rx", "Option", "pipe", "Capabilities", "contributes", "createIntent", "LayoutAction", "AttentionCapabilities", "createExtension", "ROOT_ID", "rxFromSignal", "context", "contributes", "Capabilities", "AppGraphBuilder", "createExtension", "id", "DECK_PLUGIN", "actions", "node", "Rx", "make", "get", "pipe", "Option", "flatMap", "ROOT_ID", "some", "none", "map", "state", "getCapability", "DeckCapabilities", "MutableDeckState", "_fullscreen", "LayoutAction", "UpdateLayout", "_tag", "data", "dispatchPromise", "dispatch", "IntentDispatcher", "createIntent", "SetLayoutMode", "part", "options", "mode", "properties", "label", "ns", "icon", "keyBinding", "macos", "windows", "closeCurrent", "Close", "attention", "AttentionCapabilities", "Attention", "attended", "current", "at", "subject", "closeOthers", "ids", "deck", "active", "filter", "closeAll", "toggleSidebar", "UpdateSidebar", "sidebarState", "rxFromSignal", "disposition", "position", "l0Breakpoint", "solo", "getOrElse"]
7
- }
@@ -1,32 +0,0 @@
1
- import {
2
- DECK_PLUGIN
3
- } from "./chunk-Z5KITAZW.mjs";
4
-
5
- // src/capabilities/check-app-scheme.ts
6
- import { Capabilities, contributes } from "@dxos/app-framework";
7
- var isSocket = !!globalThis.__args;
8
- var appScheme = "composer://";
9
- var checkAppScheme = (url) => {
10
- const iframe = document.createElement("iframe");
11
- iframe.style.display = "none";
12
- document.body.appendChild(iframe);
13
- iframe.src = url + window.location.pathname.replace(/^\/+/, "") + window.location.search;
14
- const timer = setTimeout(() => {
15
- document.body.removeChild(iframe);
16
- }, 3e3);
17
- window.addEventListener("pagehide", (event) => {
18
- clearTimeout(timer);
19
- document.body.removeChild(iframe);
20
- });
21
- };
22
- var check_app_scheme_default = async (context) => {
23
- const settings = context.getCapability(Capabilities.SettingsStore).getStore(DECK_PLUGIN)?.value;
24
- if (!isSocket && settings?.enableNativeRedirect) {
25
- checkAppScheme(appScheme);
26
- }
27
- return contributes(Capabilities.Null, null);
28
- };
29
- export {
30
- check_app_scheme_default as default
31
- };
32
- //# sourceMappingURL=check-app-scheme-57U62A3A.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/capabilities/check-app-scheme.ts"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Capabilities, contributes, type PluginContext } from '@dxos/app-framework';\n\nimport { DECK_PLUGIN } from '../meta';\nimport { type DeckSettingsProps } 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 async (context: PluginContext) => {\n const settings = context.getCapability(Capabilities.SettingsStore).getStore<DeckSettingsProps>(DECK_PLUGIN)?.value;\n if (!isSocket && settings?.enableNativeRedirect) {\n checkAppScheme(appScheme);\n }\n\n return contributes(Capabilities.Null, null);\n};\n"],
5
- "mappings": ";;;;;AAIA,SAASA,cAAcC,mBAAuC;AAK9D,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,2BAAe,OAAOmB,YAAAA;AACpB,QAAMC,WAAWD,QAAQE,cAAcC,aAAaC,aAAa,EAAEC,SAA4BC,WAAAA,GAAcC;AAC7G,MAAI,CAAChC,YAAY0B,UAAUO,sBAAsB;AAC/C7B,mBAAeD,SAAAA;EACjB;AAEA,SAAO+B,YAAYN,aAAaO,MAAM,IAAA;AACxC;",
6
- "names": ["Capabilities", "contributes", "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", "context", "settings", "getCapability", "Capabilities", "SettingsStore", "getStore", "DECK_PLUGIN", "value", "enableNativeRedirect", "contributes", "Null"]
7
- }
@@ -1,145 +0,0 @@
1
- // src/layout.ts
2
- import { produce } from "immer";
3
- import { ATTENDABLE_PATH_SEPARATOR } from "@dxos/react-ui-attention";
4
- var createEntryId = (entryId, variant) => variant ? `${entryId}${ATTENDABLE_PATH_SEPARATOR}${variant}` : entryId;
5
- var parseEntryId = (entryId) => {
6
- const [id, variant] = entryId.split(ATTENDABLE_PATH_SEPARATOR);
7
- return {
8
- id,
9
- variant
10
- };
11
- };
12
- var openEntry = (deck, _entryId, options) => {
13
- return produce(deck, (draft) => {
14
- const entryId = createEntryId(_entryId, options?.variant);
15
- if (draft.find((id) => id === entryId)) {
16
- return;
17
- }
18
- const key = options?.key;
19
- const plankPositioning = options?.positioning ?? "start";
20
- const pivotId = options?.pivotId;
21
- if (key) {
22
- const index = draft.findIndex((id) => id.split("+")[0] === key);
23
- if (index !== -1) {
24
- draft.splice(index, 1, entryId);
25
- return;
26
- }
27
- }
28
- if (pivotId) {
29
- const pivotIndex = draft.findIndex((id) => id === pivotId);
30
- if (pivotIndex !== -1) {
31
- if (plankPositioning === "start") {
32
- draft.splice(pivotIndex, 0, entryId);
33
- } else {
34
- draft.splice(pivotIndex + 1, 0, entryId);
35
- }
36
- return;
37
- }
38
- }
39
- if (plankPositioning === "start") {
40
- draft.unshift(entryId);
41
- } else {
42
- draft.push(entryId);
43
- }
44
- });
45
- };
46
- var closeEntry = (deck, entryId) => {
47
- return produce(deck, (draft) => {
48
- const index = draft.findIndex((id) => id === entryId);
49
- if (index !== -1) {
50
- draft.splice(index, 1);
51
- }
52
- });
53
- };
54
- var incrementPlank = (deck, adjustment) => {
55
- return produce(deck, (draft) => {
56
- const index = draft.findIndex((id) => id === adjustment.id);
57
- if (index === -1 || adjustment.type === "increment-start" && index === 0 || adjustment.type === "increment-end" && index === draft.length - 1) {
58
- return;
59
- }
60
- if (adjustment.type === "increment-start") {
61
- [draft[index - 1], draft[index]] = [
62
- draft[index],
63
- draft[index - 1]
64
- ];
65
- } else if (adjustment.type === "increment-end") {
66
- [draft[index], draft[index + 1]] = [
67
- draft[index + 1],
68
- draft[index]
69
- ];
70
- }
71
- });
72
- };
73
-
74
- // src/util/set-active.ts
75
- import { batch } from "@preact/signals-core";
76
- var setActive = ({ next, state, attention }) => {
77
- return batch(() => {
78
- const active = state.deck.solo ? [
79
- state.deck.solo
80
- ] : state.deck.active;
81
- const removed = active.filter((id) => !next.includes(id));
82
- const closed = Array.from(/* @__PURE__ */ new Set([
83
- ...state.deck.inactive.filter((id) => !next.includes(id)),
84
- ...removed
85
- ]));
86
- state.deck.inactive = closed;
87
- if (state.deck.solo || !state.deck.initialized) {
88
- state.deck.solo = next[0];
89
- } else {
90
- state.deck.active = next;
91
- }
92
- if (state.deck.fullscreen && !state.deck.solo) {
93
- state.deck.fullscreen = false;
94
- }
95
- if (attention) {
96
- const attended = attention.current;
97
- const [attendedId] = Array.from(attended);
98
- const isAttendedAvailable = !!attendedId && next.includes(attendedId);
99
- if (!isAttendedAvailable) {
100
- const attendedIndex = active.indexOf(attendedId);
101
- const index = attendedIndex === -1 ? 0 : attendedIndex >= next.length ? next.length - 1 : attendedIndex;
102
- return next[index];
103
- }
104
- }
105
- });
106
- };
107
-
108
- // src/util/layoutAppliesTopbar.ts
109
- var layoutAppliesTopbar = (breakpoint, layoutMode) => {
110
- return document.body.getAttribute("data-platform") === "win" && breakpoint === "desktop" && layoutMode !== "solo--fullscreen";
111
- };
112
-
113
- // src/util/overscroll.ts
114
- var calculateOverscroll = (planksCount) => {
115
- if (!planksCount) {
116
- return {
117
- paddingInlineStart: 0,
118
- paddingInlineEnd: 0
119
- };
120
- }
121
- if (planksCount === 1) {
122
- const overscrollPadding = "max(0px, calc(((100dvw - var(--dx-main-sidebarWidth) - var(--dx-main-complementaryWidth) - (var(--dx-main-contentFirstWidth) + 1px)) / 2)))";
123
- return {
124
- paddingInlineStart: overscrollPadding,
125
- paddingInlineEnd: overscrollPadding
126
- };
127
- } else {
128
- return {
129
- paddingInlineStart: "max(0px, calc(((100dvw - (var(--dx-main-contentFirstWidth) + 1px)) / 2) - var(--dx-main-sidebarWidth)))",
130
- paddingInlineEnd: "max(0px, calc(((100dvw - (var(--dx-main-contentLastWidth) + 1px)) / 2) - var(--dx-main-complementaryWidth)))"
131
- };
132
- }
133
- };
134
-
135
- export {
136
- createEntryId,
137
- parseEntryId,
138
- openEntry,
139
- closeEntry,
140
- incrementPlank,
141
- layoutAppliesTopbar,
142
- calculateOverscroll,
143
- setActive
144
- };
145
- //# sourceMappingURL=chunk-CNTGBCMK.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 { batch } from '@preact/signals-core';\n\nimport { type AttentionManager } from '@dxos/plugin-attention';\n\nimport { type DeckPluginState } from '../types';\n\nexport type SetActiveOptions = {\n next: string[];\n state: DeckPluginState;\n attention?: AttentionManager;\n};\n\nexport const setActive = ({ next, state, attention }: SetActiveOptions) => {\n return batch(() => {\n const active = state.deck.solo ? [state.deck.solo] : state.deck.active;\n const removed = active.filter((id) => !next.includes(id));\n const closed = Array.from(new Set([...state.deck.inactive.filter((id) => !next.includes(id)), ...removed]));\n\n state.deck.inactive = closed;\n\n if (state.deck.solo || !state.deck.initialized) {\n state.deck.solo = next[0];\n } else {\n state.deck.active = next;\n }\n\n if (state.deck.fullscreen && !state.deck.solo) {\n state.deck.fullscreen = false;\n }\n\n if (attention) {\n const attended = attention.current;\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 return next[index];\n }\n }\n });\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') === 'win' &&\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", "batch", "setActive", "next", "state", "attention", "batch", "active", "deck", "solo", "removed", "filter", "id", "includes", "closed", "Array", "from", "Set", "inactive", "initialized", "fullscreen", "attended", "current", "attendedId", "isAttendedAvailable", "attendedIndex", "indexOf", "index", "length", "layoutAppliesTopbar", "breakpoint", "layoutMode", "document", "body", "getAttribute", "calculateOverscroll", "planksCount", "paddingInlineStart", "paddingInlineEnd", "overscrollPadding"]
7
- }