@dxos/react-ui 0.8.4-main.c1de068 → 0.8.4-main.c85a9c8dae

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 (433) hide show
  1. package/dist/lib/browser/chunk-2FKSMWNY.mjs +774 -0
  2. package/dist/lib/browser/chunk-2FKSMWNY.mjs.map +7 -0
  3. package/dist/lib/browser/index.mjs +3931 -61
  4. package/dist/lib/browser/index.mjs.map +4 -4
  5. package/dist/lib/browser/meta.json +1 -1
  6. package/dist/lib/browser/testing/index.mjs +82 -60
  7. package/dist/lib/browser/testing/index.mjs.map +4 -4
  8. package/dist/lib/node-esm/chunk-ZNBLTSHI.mjs +776 -0
  9. package/dist/lib/node-esm/chunk-ZNBLTSHI.mjs.map +7 -0
  10. package/dist/lib/node-esm/index.mjs +3931 -61
  11. package/dist/lib/node-esm/index.mjs.map +4 -4
  12. package/dist/lib/node-esm/meta.json +1 -1
  13. package/dist/lib/node-esm/testing/index.mjs +82 -60
  14. package/dist/lib/node-esm/testing/index.mjs.map +4 -4
  15. package/dist/types/src/components/Avatars/Avatar.d.ts +1 -1
  16. package/dist/types/src/components/Avatars/Avatar.d.ts.map +1 -1
  17. package/dist/types/src/components/Avatars/Avatar.stories.d.ts +5 -31
  18. package/dist/types/src/components/Avatars/Avatar.stories.d.ts.map +1 -1
  19. package/dist/types/src/components/Avatars/AvatarGroup.stories.d.ts +5 -11
  20. package/dist/types/src/components/Avatars/AvatarGroup.stories.d.ts.map +1 -1
  21. package/dist/types/src/components/Breadcrumb/Breadcrumb.d.ts +1 -1
  22. package/dist/types/src/components/Breadcrumb/Breadcrumb.d.ts.map +1 -1
  23. package/dist/types/src/components/Breadcrumb/Breadcrumb.stories.d.ts +8 -20
  24. package/dist/types/src/components/Breadcrumb/Breadcrumb.stories.d.ts.map +1 -1
  25. package/dist/types/src/components/{Buttons → Button}/Button.d.ts +2 -2
  26. package/dist/types/src/components/Button/Button.d.ts.map +1 -0
  27. package/dist/types/src/components/Button/Button.stories.d.ts +17 -0
  28. package/dist/types/src/components/Button/Button.stories.d.ts.map +1 -0
  29. package/dist/types/src/components/{Buttons → Button}/IconButton.d.ts +4 -4
  30. package/dist/types/src/components/Button/IconButton.d.ts.map +1 -0
  31. package/dist/types/src/components/Button/IconButton.stories.d.ts +13 -0
  32. package/dist/types/src/components/Button/IconButton.stories.d.ts.map +1 -0
  33. package/dist/types/src/components/Button/Toggle.d.ts.map +1 -0
  34. package/dist/types/src/components/Button/Toggle.stories.d.ts +16 -0
  35. package/dist/types/src/components/Button/Toggle.stories.d.ts.map +1 -0
  36. package/dist/types/src/components/Button/ToggleGroup.d.ts +27 -0
  37. package/dist/types/src/components/Button/ToggleGroup.d.ts.map +1 -0
  38. package/dist/types/src/components/Button/ToggleGroup.stories.d.ts +27 -0
  39. package/dist/types/src/components/Button/ToggleGroup.stories.d.ts.map +1 -0
  40. package/dist/types/src/components/Button/index.d.ts.map +1 -0
  41. package/dist/types/src/components/Card/Card.d.ts +121 -0
  42. package/dist/types/src/components/Card/Card.d.ts.map +1 -0
  43. package/dist/types/src/components/Card/Card.stories.d.ts +21 -0
  44. package/dist/types/src/components/Card/Card.stories.d.ts.map +1 -0
  45. package/dist/types/src/components/Card/index.d.ts +2 -0
  46. package/dist/types/src/components/Card/index.d.ts.map +1 -0
  47. package/dist/types/src/components/Clipboard/ClipboardProvider.d.ts.map +1 -1
  48. package/dist/types/src/components/Clipboard/CopyButton.d.ts +1 -1
  49. package/dist/types/src/components/Clipboard/CopyButton.d.ts.map +1 -1
  50. package/dist/types/src/components/DensityProvider/DensityProvider.d.ts +1 -1
  51. package/dist/types/src/components/DensityProvider/DensityProvider.d.ts.map +1 -1
  52. package/dist/types/src/components/{Dialogs → Dialog}/AlertDialog.d.ts +13 -4
  53. package/dist/types/src/components/Dialog/AlertDialog.d.ts.map +1 -0
  54. package/dist/types/src/components/Dialog/AlertDialog.stories.d.ts +11 -0
  55. package/dist/types/src/components/Dialog/AlertDialog.stories.d.ts.map +1 -0
  56. package/dist/types/src/components/Dialog/Dialog.d.ts +47 -0
  57. package/dist/types/src/components/Dialog/Dialog.d.ts.map +1 -0
  58. package/dist/types/src/components/Dialog/Dialog.stories.d.ts +24 -0
  59. package/dist/types/src/components/Dialog/Dialog.stories.d.ts.map +1 -0
  60. package/dist/types/src/components/Dialog/index.d.ts.map +1 -0
  61. package/dist/types/src/components/ElevationProvider/ElevationProvider.d.ts +1 -1
  62. package/dist/types/src/components/ElevationProvider/ElevationProvider.d.ts.map +1 -1
  63. package/dist/types/src/components/ErrorFallback/ErrorFallback.d.ts +11 -0
  64. package/dist/types/src/components/ErrorFallback/ErrorFallback.d.ts.map +1 -0
  65. package/dist/types/src/components/ErrorFallback/ErrorFallback.stories.d.ts +7 -0
  66. package/dist/types/src/components/ErrorFallback/ErrorFallback.stories.d.ts.map +1 -0
  67. package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts +8 -0
  68. package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts.map +1 -0
  69. package/dist/types/src/components/ErrorFallback/ThrowError.d.ts +9 -0
  70. package/dist/types/src/components/ErrorFallback/ThrowError.d.ts.map +1 -0
  71. package/dist/types/src/components/ErrorFallback/index.d.ts +5 -0
  72. package/dist/types/src/components/ErrorFallback/index.d.ts.map +1 -0
  73. package/dist/types/src/components/Icon/Icon.d.ts +2 -2
  74. package/dist/types/src/components/Icon/Icon.d.ts.map +1 -1
  75. package/dist/types/src/components/Icon/Icon.stories.d.ts +17 -0
  76. package/dist/types/src/components/Icon/Icon.stories.d.ts.map +1 -0
  77. package/dist/types/src/components/Image/Image.d.ts +14 -0
  78. package/dist/types/src/components/Image/Image.d.ts.map +1 -0
  79. package/dist/types/src/components/Image/Image.stories.d.ts +33 -0
  80. package/dist/types/src/components/Image/Image.stories.d.ts.map +1 -0
  81. package/dist/types/src/components/Image/index.d.ts +2 -0
  82. package/dist/types/src/components/Image/index.d.ts.map +1 -0
  83. package/dist/types/src/components/Input/Input.d.ts +6 -8
  84. package/dist/types/src/components/Input/Input.d.ts.map +1 -1
  85. package/dist/types/src/components/Input/Input.stories.d.ts +17 -18
  86. package/dist/types/src/components/Input/Input.stories.d.ts.map +1 -1
  87. package/dist/types/src/components/Link/Link.stories.d.ts +8 -8
  88. package/dist/types/src/components/Link/Link.stories.d.ts.map +1 -1
  89. package/dist/types/src/components/{Lists → List}/List.d.ts +3 -3
  90. package/dist/types/src/components/List/List.d.ts.map +1 -0
  91. package/dist/types/src/components/List/List.stories.d.ts +14 -0
  92. package/dist/types/src/components/List/List.stories.d.ts.map +1 -0
  93. package/dist/types/src/components/List/ListDropIndicator.d.ts.map +1 -0
  94. package/dist/types/src/components/{Lists → List}/Tree.d.ts +1 -1
  95. package/dist/types/src/components/List/Tree.d.ts.map +1 -0
  96. package/dist/types/src/components/List/Tree.stories.d.ts +15 -0
  97. package/dist/types/src/components/List/Tree.stories.d.ts.map +1 -0
  98. package/dist/types/src/components/List/TreeDropIndicator.d.ts.map +1 -0
  99. package/dist/types/src/components/{Lists → List}/Treegrid.d.ts +1 -1
  100. package/dist/types/src/components/{Lists → List}/Treegrid.d.ts.map +1 -1
  101. package/dist/types/src/components/List/Treegrid.stories.d.ts +12 -0
  102. package/dist/types/src/components/List/Treegrid.stories.d.ts.map +1 -0
  103. package/dist/types/src/components/List/index.d.ts.map +1 -0
  104. package/dist/types/src/components/Main/Main.d.ts +18 -28
  105. package/dist/types/src/components/Main/Main.d.ts.map +1 -1
  106. package/dist/types/src/components/Main/Main.stories.d.ts +6 -10
  107. package/dist/types/src/components/Main/Main.stories.d.ts.map +1 -1
  108. package/dist/types/src/components/{Menus → Menu}/ContextMenu.d.ts +6 -6
  109. package/dist/types/src/components/Menu/ContextMenu.d.ts.map +1 -0
  110. package/dist/types/src/components/Menu/ContextMenu.stories.d.ts +12 -0
  111. package/dist/types/src/components/Menu/ContextMenu.stories.d.ts.map +1 -0
  112. package/dist/types/src/components/{Menus → Menu}/DropdownMenu.d.ts +8 -8
  113. package/dist/types/src/components/Menu/DropdownMenu.d.ts.map +1 -0
  114. package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts +15 -0
  115. package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts.map +1 -0
  116. package/dist/types/src/components/Menu/index.d.ts.map +1 -0
  117. package/dist/types/src/components/Message/Message.d.ts +1 -1
  118. package/dist/types/src/components/Message/Message.d.ts.map +1 -1
  119. package/dist/types/src/components/Message/Message.stories.d.ts +10 -20
  120. package/dist/types/src/components/Message/Message.stories.d.ts.map +1 -1
  121. package/dist/types/src/components/Popover/Popover.d.ts +4 -3
  122. package/dist/types/src/components/Popover/Popover.d.ts.map +1 -1
  123. package/dist/types/src/components/Popover/Popover.stories.d.ts +6 -34
  124. package/dist/types/src/components/Popover/Popover.stories.d.ts.map +1 -1
  125. package/dist/types/src/components/ScrollArea/ScrollArea.d.ts +25 -26
  126. package/dist/types/src/components/ScrollArea/ScrollArea.d.ts.map +1 -1
  127. package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts +37 -25
  128. package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts.map +1 -1
  129. package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts +39 -0
  130. package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts.map +1 -0
  131. package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts +24 -0
  132. package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts.map +1 -0
  133. package/dist/types/src/components/ScrollContainer/index.d.ts +2 -0
  134. package/dist/types/src/components/ScrollContainer/index.d.ts.map +1 -0
  135. package/dist/types/src/components/Select/Select.d.ts +10 -10
  136. package/dist/types/src/components/Select/Select.d.ts.map +1 -1
  137. package/dist/types/src/components/Select/Select.stories.d.ts +4 -9
  138. package/dist/types/src/components/Select/Select.stories.d.ts.map +1 -1
  139. package/dist/types/src/components/Separator/Separator.d.ts +1 -1
  140. package/dist/types/src/components/Skeleton/Skeleton.d.ts +12 -0
  141. package/dist/types/src/components/Skeleton/Skeleton.d.ts.map +1 -0
  142. package/dist/types/src/components/Skeleton/Skeleton.stories.d.ts +17 -0
  143. package/dist/types/src/components/Skeleton/Skeleton.stories.d.ts.map +1 -0
  144. package/dist/types/src/components/Skeleton/index.d.ts +2 -0
  145. package/dist/types/src/components/Skeleton/index.d.ts.map +1 -0
  146. package/dist/types/src/components/Splitter/Splitter.d.ts +36 -0
  147. package/dist/types/src/components/Splitter/Splitter.d.ts.map +1 -0
  148. package/dist/types/src/components/Splitter/Splitter.stories.d.ts +7 -0
  149. package/dist/types/src/components/Splitter/Splitter.stories.d.ts.map +1 -0
  150. package/dist/types/src/components/Splitter/index.d.ts +2 -0
  151. package/dist/types/src/components/Splitter/index.d.ts.map +1 -0
  152. package/dist/types/src/components/Status/Status.stories.d.ts +6 -10
  153. package/dist/types/src/components/Status/Status.stories.d.ts.map +1 -1
  154. package/dist/types/src/components/Tag/Tag.d.ts +1 -1
  155. package/dist/types/src/components/Tag/Tag.d.ts.map +1 -1
  156. package/dist/types/src/components/Tag/Tag.stories.d.ts +8 -13
  157. package/dist/types/src/components/Tag/Tag.stories.d.ts.map +1 -1
  158. package/dist/types/src/components/ThemeProvider/ThemeProvider.d.ts +3 -3
  159. package/dist/types/src/components/ThemeProvider/ThemeProvider.d.ts.map +1 -1
  160. package/dist/types/src/components/ThemeProvider/ThemeProvider.stories.d.ts +12 -0
  161. package/dist/types/src/components/ThemeProvider/ThemeProvider.stories.d.ts.map +1 -0
  162. package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts +1 -8
  163. package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts.map +1 -1
  164. package/dist/types/src/components/ThemeProvider/index.d.ts +2 -1
  165. package/dist/types/src/components/ThemeProvider/index.d.ts.map +1 -1
  166. package/dist/types/src/components/Toast/Toast.d.ts +5 -5
  167. package/dist/types/src/components/Toast/Toast.d.ts.map +1 -1
  168. package/dist/types/src/components/Toast/Toast.stories.d.ts +6 -44
  169. package/dist/types/src/components/Toast/Toast.stories.d.ts.map +1 -1
  170. package/dist/types/src/components/Toolbar/Toolbar.d.ts +47 -19
  171. package/dist/types/src/components/Toolbar/Toolbar.d.ts.map +1 -1
  172. package/dist/types/src/components/Toolbar/Toolbar.stories.d.ts +6 -50
  173. package/dist/types/src/components/Toolbar/Toolbar.stories.d.ts.map +1 -1
  174. package/dist/types/src/components/Tooltip/Tooltip.d.ts +2 -4
  175. package/dist/types/src/components/Tooltip/Tooltip.d.ts.map +1 -1
  176. package/dist/types/src/components/Tooltip/Tooltip.stories.d.ts +8 -61
  177. package/dist/types/src/components/Tooltip/Tooltip.stories.d.ts.map +1 -1
  178. package/dist/types/src/components/index.d.ts +13 -8
  179. package/dist/types/src/components/index.d.ts.map +1 -1
  180. package/dist/types/src/exemplars/generics.stories.d.ts +18 -0
  181. package/dist/types/src/exemplars/generics.stories.d.ts.map +1 -0
  182. package/dist/types/src/exemplars/slot.stories.d.ts +14 -0
  183. package/dist/types/src/exemplars/slot.stories.d.ts.map +1 -0
  184. package/dist/types/src/exemplars/tabster.stories.d.ts +8 -0
  185. package/dist/types/src/exemplars/tabster.stories.d.ts.map +1 -0
  186. package/dist/types/src/exemplars/virtualizer.stories.d.ts +11 -0
  187. package/dist/types/src/exemplars/virtualizer.stories.d.ts.map +1 -0
  188. package/dist/types/src/hooks/useDensityContext.d.ts +1 -1
  189. package/dist/types/src/hooks/useDensityContext.d.ts.map +1 -1
  190. package/dist/types/src/hooks/useElevationContext.d.ts +1 -1
  191. package/dist/types/src/hooks/useElevationContext.d.ts.map +1 -1
  192. package/dist/types/src/hooks/useSafeArea.d.ts.map +1 -1
  193. package/dist/types/src/hooks/useVisualViewport.d.ts +2 -2
  194. package/dist/types/src/hooks/useVisualViewport.d.ts.map +1 -1
  195. package/dist/types/src/index.d.ts +2 -1
  196. package/dist/types/src/index.d.ts.map +1 -1
  197. package/dist/types/src/playground/Controls.stories.d.ts +5 -9
  198. package/dist/types/src/playground/Controls.stories.d.ts.map +1 -1
  199. package/dist/types/src/playground/Custom.stories.d.ts +12 -4
  200. package/dist/types/src/playground/Custom.stories.d.ts.map +1 -1
  201. package/dist/types/src/playground/Typography.stories.d.ts +5 -11
  202. package/dist/types/src/playground/Typography.stories.d.ts.map +1 -1
  203. package/dist/types/src/primitives/Column/Column.d.ts +32 -0
  204. package/dist/types/src/primitives/Column/Column.d.ts.map +1 -0
  205. package/dist/types/src/primitives/Column/Column.stories.d.ts +6 -0
  206. package/dist/types/src/primitives/Column/Column.stories.d.ts.map +1 -0
  207. package/dist/types/src/primitives/Column/index.d.ts +2 -0
  208. package/dist/types/src/primitives/Column/index.d.ts.map +1 -0
  209. package/dist/types/src/primitives/Flex/Flex.d.ts +8 -0
  210. package/dist/types/src/primitives/Flex/Flex.d.ts.map +1 -0
  211. package/dist/types/src/primitives/Flex/Flex.stories.d.ts +8 -0
  212. package/dist/types/src/primitives/Flex/Flex.stories.d.ts.map +1 -0
  213. package/dist/types/src/primitives/Flex/index.d.ts +2 -0
  214. package/dist/types/src/primitives/Flex/index.d.ts.map +1 -0
  215. package/dist/types/src/primitives/Grid/Grid.d.ts +9 -0
  216. package/dist/types/src/primitives/Grid/Grid.d.ts.map +1 -0
  217. package/dist/types/src/primitives/Grid/Grid.stories.d.ts +8 -0
  218. package/dist/types/src/primitives/Grid/Grid.stories.d.ts.map +1 -0
  219. package/dist/types/src/primitives/Grid/index.d.ts +2 -0
  220. package/dist/types/src/primitives/Grid/index.d.ts.map +1 -0
  221. package/dist/types/src/primitives/Panel/Panel.d.ts +34 -0
  222. package/dist/types/src/primitives/Panel/Panel.d.ts.map +1 -0
  223. package/dist/types/src/primitives/Panel/Panel.stories.d.ts +6 -0
  224. package/dist/types/src/primitives/Panel/Panel.stories.d.ts.map +1 -0
  225. package/dist/types/src/primitives/Panel/index.d.ts +2 -0
  226. package/dist/types/src/primitives/Panel/index.d.ts.map +1 -0
  227. package/dist/types/src/primitives/index.d.ts +5 -0
  228. package/dist/types/src/primitives/index.d.ts.map +1 -0
  229. package/dist/types/src/testing/decorators/index.d.ts +2 -1
  230. package/dist/types/src/testing/decorators/index.d.ts.map +1 -1
  231. package/dist/types/src/testing/decorators/withLayout.d.ts +15 -0
  232. package/dist/types/src/testing/decorators/withLayout.d.ts.map +1 -0
  233. package/dist/types/src/testing/decorators/withLayoutVariants.d.ts +12 -0
  234. package/dist/types/src/testing/decorators/withLayoutVariants.d.ts.map +1 -0
  235. package/dist/types/src/testing/decorators/withTheme.d.ts +5 -1
  236. package/dist/types/src/testing/decorators/withTheme.d.ts.map +1 -1
  237. package/dist/types/src/translations.d.ts +11 -0
  238. package/dist/types/src/translations.d.ts.map +1 -0
  239. package/dist/types/src/util/index.d.ts +2 -1
  240. package/dist/types/src/util/index.d.ts.map +1 -1
  241. package/dist/types/src/util/usePx.d.ts +8 -0
  242. package/dist/types/src/util/usePx.d.ts.map +1 -0
  243. package/dist/types/tsconfig.tsbuildinfo +1 -1
  244. package/package.json +43 -31
  245. package/src/components/Avatars/Avatar.stories.tsx +24 -16
  246. package/src/components/Avatars/Avatar.tsx +9 -16
  247. package/src/components/Avatars/AvatarGroup.stories.tsx +12 -8
  248. package/src/components/Breadcrumb/Breadcrumb.stories.tsx +20 -15
  249. package/src/components/Breadcrumb/Breadcrumb.tsx +12 -38
  250. package/src/components/{Buttons → Button}/Button.stories.tsx +10 -11
  251. package/src/components/{Buttons → Button}/Button.tsx +7 -13
  252. package/src/components/{Buttons → Button}/IconButton.stories.tsx +15 -12
  253. package/src/components/{Buttons → Button}/IconButton.tsx +23 -16
  254. package/src/components/Button/Toggle.stories.tsx +37 -0
  255. package/src/components/{Buttons → Button}/ToggleGroup.stories.tsx +12 -9
  256. package/src/components/{Buttons → Button}/ToggleGroup.tsx +17 -4
  257. package/src/components/Card/Card.stories.tsx +151 -0
  258. package/src/components/Card/Card.tsx +352 -0
  259. package/src/components/Card/index.ts +5 -0
  260. package/src/components/Clipboard/ClipboardProvider.tsx +1 -1
  261. package/src/components/Clipboard/CopyButton.tsx +9 -8
  262. package/src/components/DensityProvider/DensityProvider.tsx +2 -2
  263. package/src/components/Dialog/AlertDialog.stories.tsx +69 -0
  264. package/src/components/{Dialogs → Dialog}/AlertDialog.tsx +128 -28
  265. package/src/components/Dialog/Dialog.stories.tsx +122 -0
  266. package/src/components/{Dialogs → Dialog}/Dialog.tsx +190 -60
  267. package/src/components/ElevationProvider/ElevationProvider.tsx +2 -2
  268. package/src/components/ErrorFallback/ErrorFallback.stories.tsx +50 -0
  269. package/src/components/ErrorFallback/ErrorFallback.tsx +70 -0
  270. package/src/components/ErrorFallback/ErrorStack.tsx +80 -0
  271. package/src/components/ErrorFallback/ThrowError.tsx +37 -0
  272. package/src/components/ErrorFallback/index.ts +9 -0
  273. package/src/components/Icon/Icon.stories.tsx +113 -0
  274. package/src/components/Icon/Icon.tsx +3 -3
  275. package/src/components/Image/Image.stories.tsx +86 -0
  276. package/src/components/Image/Image.tsx +223 -0
  277. package/src/components/Image/index.ts +5 -0
  278. package/src/components/Input/Input.stories.tsx +28 -49
  279. package/src/components/Input/Input.tsx +46 -82
  280. package/src/components/Link/Link.stories.tsx +12 -8
  281. package/src/components/Link/Link.tsx +2 -2
  282. package/src/components/{Lists → List}/List.stories.tsx +44 -45
  283. package/src/components/{Lists → List}/List.tsx +27 -28
  284. package/src/components/{Lists → List}/ListDropIndicator.tsx +7 -7
  285. package/src/components/{Lists → List}/Tree.stories.tsx +15 -12
  286. package/src/components/{Lists → List}/Tree.tsx +4 -3
  287. package/src/components/{Lists → List}/TreeDropIndicator.tsx +7 -7
  288. package/src/components/{Lists → List}/Treegrid.stories.tsx +15 -9
  289. package/src/components/{Lists → List}/Treegrid.tsx +67 -31
  290. package/src/components/Main/Main.stories.tsx +53 -27
  291. package/src/components/Main/Main.tsx +176 -104
  292. package/src/components/{Menus → Menu}/ContextMenu.stories.tsx +13 -10
  293. package/src/components/{Menus → Menu}/ContextMenu.tsx +10 -33
  294. package/src/components/{Menus → Menu}/DropdownMenu.stories.tsx +14 -11
  295. package/src/components/{Menus → Menu}/DropdownMenu.tsx +111 -80
  296. package/src/components/Message/Message.stories.tsx +35 -16
  297. package/src/components/Message/Message.tsx +46 -33
  298. package/src/components/Popover/Popover.stories.tsx +16 -13
  299. package/src/components/Popover/Popover.tsx +86 -64
  300. package/src/components/ScrollArea/ScrollArea.stories.tsx +163 -34
  301. package/src/components/ScrollArea/ScrollArea.tsx +84 -82
  302. package/src/components/ScrollArea/index.ts +1 -1
  303. package/src/components/ScrollContainer/ScrollContainer.stories.tsx +89 -0
  304. package/src/components/ScrollContainer/ScrollContainer.tsx +238 -0
  305. package/src/components/ScrollContainer/index.ts +5 -0
  306. package/src/components/Select/Select.stories.tsx +15 -12
  307. package/src/components/Select/Select.tsx +16 -31
  308. package/src/components/Separator/Separator.tsx +1 -1
  309. package/src/components/Skeleton/Skeleton.stories.tsx +52 -0
  310. package/src/components/Skeleton/Skeleton.tsx +26 -0
  311. package/src/components/Skeleton/index.ts +5 -0
  312. package/src/components/Splitter/Splitter.stories.tsx +83 -0
  313. package/src/components/Splitter/Splitter.tsx +138 -0
  314. package/src/components/Splitter/index.ts +5 -0
  315. package/src/components/Status/Status.stories.tsx +30 -23
  316. package/src/components/Status/Status.tsx +2 -2
  317. package/src/components/Tag/Tag.stories.tsx +17 -13
  318. package/src/components/Tag/Tag.tsx +3 -8
  319. package/src/components/ThemeProvider/ThemeProvider.stories.tsx +32 -0
  320. package/src/components/ThemeProvider/ThemeProvider.tsx +7 -7
  321. package/src/components/ThemeProvider/TranslationsProvider.tsx +3 -18
  322. package/src/components/ThemeProvider/index.ts +3 -3
  323. package/src/components/Toast/Toast.stories.tsx +14 -11
  324. package/src/components/Toast/Toast.tsx +19 -23
  325. package/src/components/Toolbar/Toolbar.stories.tsx +16 -14
  326. package/src/components/Toolbar/Toolbar.tsx +199 -11
  327. package/src/components/Tooltip/Tooltip.stories.tsx +31 -25
  328. package/src/components/Tooltip/Tooltip.tsx +30 -26
  329. package/src/components/index.ts +14 -9
  330. package/src/exemplars/generics.stories.tsx +49 -0
  331. package/src/exemplars/slot.stories.tsx +119 -0
  332. package/src/exemplars/tabster.stories.tsx +127 -0
  333. package/src/exemplars/virtualizer.stories.tsx +137 -0
  334. package/src/hooks/useDensityContext.ts +1 -1
  335. package/src/hooks/useElevationContext.ts +1 -1
  336. package/src/hooks/useSafeArea.ts +3 -2
  337. package/src/hooks/useVisualViewport.ts +4 -4
  338. package/src/index.ts +2 -1
  339. package/src/playground/Controls.stories.tsx +12 -15
  340. package/src/playground/Custom.stories.tsx +15 -26
  341. package/src/playground/Typography.stories.tsx +11 -9
  342. package/src/primitives/Column/Column.stories.tsx +72 -0
  343. package/src/primitives/Column/Column.tsx +156 -0
  344. package/src/primitives/Column/index.ts +5 -0
  345. package/src/primitives/Flex/Flex.stories.tsx +58 -0
  346. package/src/primitives/Flex/Flex.tsx +27 -0
  347. package/src/primitives/Flex/index.ts +5 -0
  348. package/src/primitives/Grid/Grid.stories.tsx +57 -0
  349. package/src/primitives/Grid/Grid.tsx +43 -0
  350. package/src/primitives/Grid/index.ts +5 -0
  351. package/src/primitives/Panel/Panel.stories.tsx +67 -0
  352. package/src/primitives/Panel/Panel.tsx +137 -0
  353. package/src/primitives/Panel/index.ts +5 -0
  354. package/src/primitives/index.ts +8 -0
  355. package/src/testing/decorators/index.ts +2 -1
  356. package/src/testing/decorators/withLayout.tsx +77 -0
  357. package/src/testing/decorators/withLayoutVariants.tsx +48 -0
  358. package/src/testing/decorators/withTheme.tsx +34 -0
  359. package/src/translations.ts +19 -0
  360. package/src/util/index.ts +3 -1
  361. package/src/util/usePx.ts +61 -0
  362. package/dist/lib/browser/chunk-2COVUP44.mjs +0 -4373
  363. package/dist/lib/browser/chunk-2COVUP44.mjs.map +0 -7
  364. package/dist/lib/node-esm/chunk-GHXHND5V.mjs +0 -4375
  365. package/dist/lib/node-esm/chunk-GHXHND5V.mjs.map +0 -7
  366. package/dist/types/src/components/AnchoredOverflow/AnchoredOverflow.d.ts +0 -15
  367. package/dist/types/src/components/AnchoredOverflow/AnchoredOverflow.d.ts.map +0 -1
  368. package/dist/types/src/components/AnchoredOverflow/index.d.ts +0 -2
  369. package/dist/types/src/components/AnchoredOverflow/index.d.ts.map +0 -1
  370. package/dist/types/src/components/Buttons/Button.d.ts.map +0 -1
  371. package/dist/types/src/components/Buttons/Button.stories.d.ts +0 -12
  372. package/dist/types/src/components/Buttons/Button.stories.d.ts.map +0 -1
  373. package/dist/types/src/components/Buttons/IconButton.d.ts.map +0 -1
  374. package/dist/types/src/components/Buttons/IconButton.stories.d.ts +0 -22
  375. package/dist/types/src/components/Buttons/IconButton.stories.d.ts.map +0 -1
  376. package/dist/types/src/components/Buttons/Toggle.d.ts.map +0 -1
  377. package/dist/types/src/components/Buttons/Toggle.stories.d.ts +0 -19
  378. package/dist/types/src/components/Buttons/Toggle.stories.d.ts.map +0 -1
  379. package/dist/types/src/components/Buttons/ToggleGroup.d.ts +0 -28
  380. package/dist/types/src/components/Buttons/ToggleGroup.d.ts.map +0 -1
  381. package/dist/types/src/components/Buttons/ToggleGroup.stories.d.ts +0 -39
  382. package/dist/types/src/components/Buttons/ToggleGroup.stories.d.ts.map +0 -1
  383. package/dist/types/src/components/Buttons/index.d.ts.map +0 -1
  384. package/dist/types/src/components/Dialogs/AlertDialog.d.ts.map +0 -1
  385. package/dist/types/src/components/Dialogs/AlertDialog.stories.d.ts +0 -43
  386. package/dist/types/src/components/Dialogs/AlertDialog.stories.d.ts.map +0 -1
  387. package/dist/types/src/components/Dialogs/Dialog.d.ts +0 -31
  388. package/dist/types/src/components/Dialogs/Dialog.d.ts.map +0 -1
  389. package/dist/types/src/components/Dialogs/Dialog.stories.d.ts +0 -48
  390. package/dist/types/src/components/Dialogs/Dialog.stories.d.ts.map +0 -1
  391. package/dist/types/src/components/Dialogs/index.d.ts.map +0 -1
  392. package/dist/types/src/components/Lists/List.d.ts.map +0 -1
  393. package/dist/types/src/components/Lists/List.stories.d.ts +0 -37
  394. package/dist/types/src/components/Lists/List.stories.d.ts.map +0 -1
  395. package/dist/types/src/components/Lists/ListDropIndicator.d.ts.map +0 -1
  396. package/dist/types/src/components/Lists/Tree.d.ts.map +0 -1
  397. package/dist/types/src/components/Lists/Tree.stories.d.ts +0 -41
  398. package/dist/types/src/components/Lists/Tree.stories.d.ts.map +0 -1
  399. package/dist/types/src/components/Lists/TreeDropIndicator.d.ts.map +0 -1
  400. package/dist/types/src/components/Lists/Treegrid.stories.d.ts +0 -10
  401. package/dist/types/src/components/Lists/Treegrid.stories.d.ts.map +0 -1
  402. package/dist/types/src/components/Lists/index.d.ts.map +0 -1
  403. package/dist/types/src/components/Menus/ContextMenu.d.ts.map +0 -1
  404. package/dist/types/src/components/Menus/ContextMenu.stories.d.ts +0 -50
  405. package/dist/types/src/components/Menus/ContextMenu.stories.d.ts.map +0 -1
  406. package/dist/types/src/components/Menus/DropdownMenu.d.ts.map +0 -1
  407. package/dist/types/src/components/Menus/DropdownMenu.stories.d.ts +0 -50
  408. package/dist/types/src/components/Menus/DropdownMenu.stories.d.ts.map +0 -1
  409. package/dist/types/src/components/Menus/index.d.ts.map +0 -1
  410. package/dist/types/src/testing/decorators/withSurfaceVariantsLayout.d.ts +0 -12
  411. package/dist/types/src/testing/decorators/withSurfaceVariantsLayout.d.ts.map +0 -1
  412. package/dist/types/src/util/ThemedClassName.d.ts +0 -5
  413. package/dist/types/src/util/ThemedClassName.d.ts.map +0 -1
  414. package/src/components/AnchoredOverflow/AnchoredOverflow.tsx +0 -59
  415. package/src/components/AnchoredOverflow/index.ts +0 -5
  416. package/src/components/Buttons/Toggle.stories.tsx +0 -33
  417. package/src/components/Dialogs/AlertDialog.stories.tsx +0 -66
  418. package/src/components/Dialogs/Dialog.stories.tsx +0 -65
  419. package/src/testing/decorators/withSurfaceVariantsLayout.tsx +0 -51
  420. package/src/testing/decorators/withTheme.ts +0 -25
  421. package/src/util/ThemedClassName.ts +0 -7
  422. /package/dist/types/src/components/{Buttons → Button}/Toggle.d.ts +0 -0
  423. /package/dist/types/src/components/{Buttons → Button}/index.d.ts +0 -0
  424. /package/dist/types/src/components/{Dialogs → Dialog}/index.d.ts +0 -0
  425. /package/dist/types/src/components/{Lists → List}/ListDropIndicator.d.ts +0 -0
  426. /package/dist/types/src/components/{Lists → List}/TreeDropIndicator.d.ts +0 -0
  427. /package/dist/types/src/components/{Lists → List}/index.d.ts +0 -0
  428. /package/dist/types/src/components/{Menus → Menu}/index.d.ts +0 -0
  429. /package/src/components/{Buttons → Button}/Toggle.tsx +0 -0
  430. /package/src/components/{Buttons → Button}/index.ts +0 -0
  431. /package/src/components/{Dialogs → Dialog}/index.ts +0 -0
  432. /package/src/components/{Lists → List}/index.ts +0 -0
  433. /package/src/components/{Menus → Menu}/index.ts +0 -0
@@ -0,0 +1,58 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ import { type Meta, type StoryObj } from '@storybook/react-vite';
6
+ import React from 'react';
7
+
8
+ import { type ChromaticPalette } from '@dxos/ui-types';
9
+
10
+ import { withLayout, withTheme } from '../../testing';
11
+
12
+ import { Flex } from './Flex';
13
+
14
+ const Cell = ({ label, hue }: { label: string; hue: ChromaticPalette }) => (
15
+ <div data-hue={hue} className='flex w-full dx-panel p-2 text-sm font-mono border rounded-sm'>
16
+ {label}
17
+ </div>
18
+ );
19
+
20
+ const RowStory = () => (
21
+ <Flex classNames='gap-2 p-2'>
22
+ <Cell label='A' hue='red' />
23
+ <Cell label='B' hue='green' />
24
+ <Cell label='C' hue='blue' />
25
+ </Flex>
26
+ );
27
+
28
+ const ColumnStory = () => (
29
+ <Flex column classNames='gap-2 p-2'>
30
+ <Cell label='A' hue='red' />
31
+ <Cell label='B' hue='green' />
32
+ <Cell label='C' hue='blue' />
33
+ </Flex>
34
+ );
35
+
36
+ const GrowStory = () => (
37
+ <Flex column grow classNames='gap-2 p-2'>
38
+ <Cell label='Header' hue='yellow' />
39
+ <Flex grow>
40
+ <Cell label='Content (grows)' hue='blue' />
41
+ </Flex>
42
+ <Cell label='Footer' hue='orange' />
43
+ </Flex>
44
+ );
45
+
46
+ const meta: Meta = {
47
+ title: 'ui/react-ui-core/primitives/Flex',
48
+ decorators: [withTheme(), withLayout({ layout: 'column' })],
49
+ parameters: { layout: 'fullscreen' },
50
+ };
51
+
52
+ export default meta;
53
+
54
+ type Story = StoryObj<typeof meta>;
55
+
56
+ export const Row: Story = { render: RowStory };
57
+ export const Column: Story = { render: ColumnStory };
58
+ export const Grow: Story = { render: GrowStory };
@@ -0,0 +1,27 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ import React, { type HTMLAttributes } from 'react';
6
+
7
+ import { mx } from '@dxos/ui-theme';
8
+ import { type ComposableProps } from '@dxos/ui-types';
9
+
10
+ export type FlexProps = ComposableProps<
11
+ HTMLAttributes<HTMLDivElement> & {
12
+ column?: boolean;
13
+ grow?: boolean;
14
+ }
15
+ >;
16
+
17
+ export const Flex = ({ children, classNames, className, role, column, grow, ...props }: FlexProps) => {
18
+ return (
19
+ <div
20
+ {...props}
21
+ role={role ?? 'none'}
22
+ className={mx('flex', column && 'flex-col', grow && 'flex-1 overflow-hidden', className, classNames)}
23
+ >
24
+ {children}
25
+ </div>
26
+ );
27
+ };
@@ -0,0 +1,5 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ export * from './Flex';
@@ -0,0 +1,57 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ import { type Meta, type StoryObj } from '@storybook/react-vite';
6
+ import React from 'react';
7
+
8
+ import { type ChromaticPalette } from '@dxos/ui-types';
9
+
10
+ import { withLayout, withTheme } from '../../testing';
11
+
12
+ import { Grid } from './Grid';
13
+
14
+ const Cell = ({ label, hue }: { label: string; hue: ChromaticPalette }) => (
15
+ <div data-hue={hue} className='dx-panel p-2 text-sm font-mono border rounded-sm'>
16
+ {label}
17
+ </div>
18
+ );
19
+
20
+ const ColsStory = () => (
21
+ <Grid cols={3} classNames='gap-2 p-2'>
22
+ <Cell label='Row 1' hue='red' />
23
+ <Cell label='Row 2' hue='green' />
24
+ <Cell label='Row 3' hue='blue' />
25
+ </Grid>
26
+ );
27
+
28
+ const RowsStory = () => (
29
+ <Grid rows={3} classNames='gap-2 p-2'>
30
+ <Cell label='Row 1' hue='red' />
31
+ <Cell label='Row 2' hue='green' />
32
+ <Cell label='Row 3' hue='blue' />
33
+ </Grid>
34
+ );
35
+
36
+ const MixedStory = () => (
37
+ <Grid cols={2} rows={2} classNames='gap-2 p-2'>
38
+ <Cell label='A' hue='red' />
39
+ <Cell label='B' hue='green' />
40
+ <Cell label='C' hue='blue' />
41
+ <Cell label='D' hue='yellow' />
42
+ </Grid>
43
+ );
44
+
45
+ const meta: Meta = {
46
+ title: 'ui/react-ui-core/primitives/Grid',
47
+ decorators: [withTheme(), withLayout({ layout: 'column' })],
48
+ parameters: { layout: 'fullscreen' },
49
+ };
50
+
51
+ export default meta;
52
+
53
+ type Story = StoryObj<typeof meta>;
54
+
55
+ export const Cols: Story = { render: ColsStory };
56
+ export const Rows: Story = { render: RowsStory };
57
+ export const Mixed: Story = { render: MixedStory };
@@ -0,0 +1,43 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ import React, { type HTMLAttributes } from 'react';
6
+
7
+ import { mx } from '@dxos/ui-theme';
8
+ import { type ComposableProps } from '@dxos/ui-types';
9
+
10
+ export type GridProps = ComposableProps<
11
+ HTMLAttributes<HTMLDivElement> & {
12
+ cols?: number;
13
+ rows?: number;
14
+ grow?: boolean;
15
+ }
16
+ >;
17
+
18
+ export const Grid = ({
19
+ children,
20
+ classNames,
21
+ className,
22
+ style,
23
+ role,
24
+ cols,
25
+ rows,
26
+ grow = true,
27
+ ...props
28
+ }: GridProps) => {
29
+ return (
30
+ <div
31
+ {...props}
32
+ role={role ?? 'none'}
33
+ style={{
34
+ gridTemplateColumns: cols ? `repeat(${cols}, 1fr)` : undefined,
35
+ gridTemplateRows: rows ? `repeat(${rows}, 1fr)` : undefined,
36
+ ...style,
37
+ }}
38
+ className={mx('grid overflow-hidden', grow && 'dx-container', className, classNames)}
39
+ >
40
+ {children}
41
+ </div>
42
+ );
43
+ };
@@ -0,0 +1,5 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ export * from './Grid';
@@ -0,0 +1,67 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { type Meta, type StoryObj } from '@storybook/react-vite';
6
+ import React from 'react';
7
+
8
+ import { Input, ScrollArea, Toolbar } from '../../components';
9
+ import { withLayout, withTheme } from '../../testing';
10
+
11
+ import { Panel } from './Panel';
12
+
13
+ const List = () => {
14
+ return (
15
+ <ScrollArea.Root margin role='list'>
16
+ <ScrollArea.Viewport>
17
+ {Array.from({ length: 100 }).map((_, i) => (
18
+ <div key={i} role='listitem' className='p-1 hover:bg-hover-surface'>
19
+ Item {i}
20
+ </div>
21
+ ))}
22
+ </ScrollArea.Viewport>
23
+ </ScrollArea.Root>
24
+ );
25
+ };
26
+
27
+ const DefaultStory = () => {
28
+ return (
29
+ <Panel.Root className='dx-article'>
30
+ <Panel.Toolbar asChild>
31
+ <Toolbar.Root classNames='gap-2'>
32
+ <Toolbar.IconButton icon='ph--plus--regular' variant='primary' label='Add' />
33
+ <Input.Root>
34
+ <Input.TextInput placeholder='Search' />
35
+ </Input.Root>
36
+ <Toolbar.IconButton icon='ph--dots-three-vertical--regular' iconOnly label='Menu' />
37
+ </Toolbar.Root>
38
+ </Panel.Toolbar>
39
+
40
+ <Panel.Content asChild>
41
+ <List />
42
+ </Panel.Content>
43
+
44
+ <Panel.Statusbar asChild>
45
+ <Toolbar.Root classNames='justify-between'>
46
+ <Toolbar.IconButton variant='ghost' icon='ph--house--regular' iconOnly label='Add' size={4} />
47
+ <Toolbar.IconButton variant='ghost' icon='ph--alarm--regular' iconOnly label='Status' size={4} />
48
+ </Toolbar.Root>
49
+ </Panel.Statusbar>
50
+ </Panel.Root>
51
+ );
52
+ };
53
+
54
+ const meta: Meta = {
55
+ title: 'ui/react-ui-core/primitives/Panel',
56
+ render: DefaultStory,
57
+ decorators: [withTheme(), withLayout({ layout: 'fullscreen' })],
58
+ parameters: {
59
+ layout: 'fullscreen',
60
+ },
61
+ };
62
+
63
+ export default meta;
64
+
65
+ type Story = StoryObj<typeof meta>;
66
+
67
+ export const Default: Story = {};
@@ -0,0 +1,137 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ import { Primitive } from '@radix-ui/react-primitive';
6
+ import { Slot } from '@radix-ui/react-slot';
7
+ import React, { forwardRef } from 'react';
8
+
9
+ import { type SlottableProps } from '@dxos/ui-types';
10
+
11
+ import { useThemeContext } from '../../hooks';
12
+
13
+ //
14
+ // Root
15
+ //
16
+
17
+ const GRID_TEMPLATE_ROWS = 'auto 1fr auto';
18
+ const GRID_TEMPLATE_AREAS = '"toolbar" "content" "statusbar"';
19
+
20
+ type PanelRootProps = SlottableProps<HTMLDivElement>;
21
+
22
+ const Root = forwardRef<HTMLDivElement, PanelRootProps>(
23
+ ({ classNames, className, asChild, children, role, ...props }, forwardedRef) => {
24
+ const { tx } = useThemeContext();
25
+ const Comp = asChild ? Slot : Primitive.div;
26
+ return (
27
+ <Comp
28
+ ref={forwardedRef}
29
+ role={role ?? 'none'}
30
+ {...props}
31
+ style={{
32
+ gridTemplateRows: GRID_TEMPLATE_ROWS,
33
+ gridTemplateAreas: GRID_TEMPLATE_AREAS,
34
+ ...props.style,
35
+ }}
36
+ className={tx('panel.root', {}, [className, classNames])}
37
+ >
38
+ {children}
39
+ </Comp>
40
+ );
41
+ },
42
+ );
43
+
44
+ Root.displayName = 'Panel.Root';
45
+
46
+ //
47
+ // Toolbar
48
+ //
49
+
50
+ type ToolbarProps = SlottableProps<HTMLDivElement>;
51
+
52
+ const Toolbar = forwardRef<HTMLDivElement, ToolbarProps>(
53
+ ({ classNames, className, asChild, children, ...props }, forwardedRef) => {
54
+ const { tx } = useThemeContext();
55
+ const Comp = asChild ? Slot : Primitive.div;
56
+ return (
57
+ <Comp
58
+ ref={forwardedRef}
59
+ data-slot='toolbar'
60
+ {...props}
61
+ className={tx('panel.toolbar', {}, [className, classNames])}
62
+ >
63
+ {children}
64
+ </Comp>
65
+ );
66
+ },
67
+ );
68
+
69
+ Toolbar.displayName = 'Panel.Toolbar';
70
+
71
+ //
72
+ // Content
73
+ //
74
+
75
+ type ContentProps = SlottableProps<HTMLDivElement>;
76
+
77
+ const Content = forwardRef<HTMLDivElement, ContentProps>(
78
+ ({ classNames, className, asChild, children, ...props }, forwardedRef) => {
79
+ const { tx } = useThemeContext();
80
+ const Comp = asChild ? Slot : Primitive.div;
81
+ return (
82
+ <Comp
83
+ ref={forwardedRef}
84
+ data-slot='content'
85
+ {...props}
86
+ className={tx('panel.content', {}, [className, classNames])}
87
+ >
88
+ {children}
89
+ </Comp>
90
+ );
91
+ },
92
+ );
93
+
94
+ Content.displayName = 'Panel.Content';
95
+
96
+ //
97
+ // Statusbar
98
+ //
99
+
100
+ type StatusbarProps = SlottableProps<HTMLDivElement>;
101
+
102
+ const Statusbar = forwardRef<HTMLDivElement, StatusbarProps>(
103
+ ({ classNames, className, asChild, children, ...props }, forwardedRef) => {
104
+ const { tx } = useThemeContext();
105
+ const Comp = asChild ? Slot : Primitive.div;
106
+ return (
107
+ <Comp
108
+ ref={forwardedRef}
109
+ data-slot='statusbar'
110
+ {...props}
111
+ className={tx('panel.statusbar', {}, [className, classNames])}
112
+ >
113
+ {children}
114
+ </Comp>
115
+ );
116
+ },
117
+ );
118
+
119
+ Statusbar.displayName = 'Panel.Statusbar';
120
+
121
+ //
122
+ // Panel
123
+ //
124
+
125
+ export const Panel = {
126
+ Root,
127
+ Toolbar,
128
+ Content,
129
+ Statusbar,
130
+ };
131
+
132
+ export type {
133
+ PanelRootProps,
134
+ ToolbarProps as PanelToolbarProps,
135
+ ContentProps as PanelContentProps,
136
+ StatusbarProps as PanelStatusbarProps,
137
+ };
@@ -0,0 +1,5 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ export * from './Panel';
@@ -0,0 +1,8 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ export * from './Column';
6
+ export * from './Flex';
7
+ export * from './Grid';
8
+ export * from './Panel';
@@ -2,5 +2,6 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
+ export * from './withLayout';
6
+ export * from './withLayoutVariants';
5
7
  export * from './withTheme';
6
- export * from './withSurfaceVariantsLayout';
@@ -0,0 +1,77 @@
1
+ //
2
+ // Copyright 2023 DXOS.org
3
+ //
4
+
5
+ import { type Decorator } from '@storybook/react';
6
+ import React, { type FC, type PropsWithChildren, memo } from 'react';
7
+
8
+ import { type ClassNameValue, type ThemedClassName } from '@dxos/react-ui';
9
+ import { mx } from '@dxos/ui-theme';
10
+
11
+ export type ContainerProps = ThemedClassName<PropsWithChildren>;
12
+
13
+ export type ContainerType = 'default' | 'fullscreen' | 'centered' | 'column';
14
+
15
+ export type WithLayoutProps =
16
+ | FC<ContainerProps>
17
+ | {
18
+ classNames?: ClassNameValue;
19
+ layout?: ContainerType;
20
+ scroll?: boolean;
21
+ };
22
+
23
+ /**
24
+ * Adds layout container.
25
+ */
26
+ export const withLayout =
27
+ (props: WithLayoutProps = {}): Decorator =>
28
+ (Story) => {
29
+ // Prevent re-rendering of the story.
30
+ const MemoizedStory = memo(Story);
31
+ if (typeof props === 'function') {
32
+ const Container = props;
33
+ return (
34
+ <Container>
35
+ <MemoizedStory />
36
+ </Container>
37
+ );
38
+ } else {
39
+ const { layout = 'default', classNames, scroll } = props;
40
+ const Container = layouts[layout] ?? layouts.fullscreen;
41
+ return (
42
+ <Container classNames={mx(classNames, scroll ? 'overflow-y-auto' : 'overflow-hidden')}>
43
+ <MemoizedStory />
44
+ </Container>
45
+ );
46
+ }
47
+ };
48
+
49
+ const layouts: Record<ContainerType, FC<ContainerProps>> = {
50
+ default: ({ classNames, children }: ContainerProps) => (
51
+ <div role='none' className={mx('p-4', classNames)}>
52
+ {children}
53
+ </div>
54
+ ),
55
+
56
+ fullscreen: ({ classNames, children }: ContainerProps) => (
57
+ <div role='none' className={mx('fixed inset-0 flex overflow-hidden bg-base-surface', classNames)}>
58
+ {children}
59
+ </div>
60
+ ),
61
+
62
+ centered: ({ classNames, children }: ContainerProps) => (
63
+ <div role='none' className={mx('fixed inset-0 grid overflow-hidden place-items-center bg-base-surface')}>
64
+ <div role='none' className={mx('flex flex-col w-[40rem] bg-group-surface', classNames)}>
65
+ {children}
66
+ </div>
67
+ </div>
68
+ ),
69
+
70
+ column: ({ classNames, children }: ContainerProps) => (
71
+ <div role='none' className='fixed inset-0 flex overflow-hidden justify-center bg-base-surface'>
72
+ <div role='none' className={mx('flex flex-col w-[40rem] bg-group-surface', classNames)}>
73
+ {children}
74
+ </div>
75
+ </div>
76
+ ),
77
+ };
@@ -0,0 +1,48 @@
1
+ //
2
+ // Copyright 2023 DXOS.org
3
+ //
4
+
5
+ import { type Decorator } from '@storybook/react';
6
+ import React, { type ComponentType, type PropsWithChildren } from 'react';
7
+
8
+ import { mx, surfaceShadow } from '@dxos/ui-theme';
9
+ import { type Density, type Elevation } from '@dxos/ui-types';
10
+
11
+ type Config = {
12
+ elevations?: { elevation: Elevation; surface?: string }[];
13
+ densities?: Density[];
14
+ };
15
+
16
+ const Container = ({ children, elevation, surface }: PropsWithChildren<{ elevation: Elevation; surface?: string }>) => (
17
+ <div className={mx('p-4 rounded-sm', surface, surfaceShadow({ elevation }))}>{children}</div>
18
+ );
19
+
20
+ const Panel = ({
21
+ Story,
22
+ elevations,
23
+ densities,
24
+ className,
25
+ }: { Story: ComponentType } & Config & { className?: string }) => {
26
+ return (
27
+ <div className={mx('flex flex-col h-full p-8 gap-8', className)}>
28
+ {elevations?.map(({ elevation, surface }) =>
29
+ densities?.map((density) => (
30
+ <Container key={`${elevation}--${density}`} surface={surface} elevation={elevation}>
31
+ <Story />
32
+ </Container>
33
+ )),
34
+ )}
35
+ </div>
36
+ );
37
+ };
38
+
39
+ export const withLayoutVariants = ({
40
+ elevations = [
41
+ { elevation: 'dialog', surface: 'bg-modal-surface' },
42
+ { elevation: 'positioned', surface: 'bg-card-surface' },
43
+ { elevation: 'base', surface: 'bg-base-surface' },
44
+ ],
45
+ densities = ['coarse'],
46
+ }: Config = {}): Decorator => {
47
+ return (Story) => <Panel Story={Story} elevations={elevations} densities={densities} />;
48
+ };
@@ -0,0 +1,34 @@
1
+ //
2
+ // Copyright 2023 DXOS.org
3
+ //
4
+
5
+ import { type Decorator } from '@storybook/react';
6
+ import React, { memo } from 'react';
7
+
8
+ import { defaultTx } from '@dxos/ui-theme';
9
+ import { type ThemeMode } from '@dxos/ui-types';
10
+
11
+ import { type ThemeContextValue, ThemeProvider, Tooltip } from '../../components';
12
+
13
+ /**
14
+ * Adds theme decorator.
15
+ */
16
+ export const withTheme =
17
+ ({ tx = defaultTx, ...props }: Partial<ThemeContextValue> = {}): Decorator =>
18
+ (Story, context) => {
19
+ const {
20
+ globals: { theme },
21
+ parameters: { translations },
22
+ } = context;
23
+
24
+ // Prevent re-rendering of the story.
25
+ const MemoizedStory = memo(Story);
26
+
27
+ return (
28
+ <ThemeProvider {...props} tx={tx} themeMode={theme as ThemeMode} resourceExtensions={translations} noCache>
29
+ <Tooltip.Provider>
30
+ <MemoizedStory />
31
+ </Tooltip.Provider>
32
+ </ThemeProvider>
33
+ );
34
+ };
@@ -0,0 +1,19 @@
1
+ //
2
+ // Copyright 2023 DXOS.org
3
+ //
4
+
5
+ import { type Resource } from '@dxos/react-ui';
6
+
7
+ export const translationKey = '@dxos/react-ui';
8
+
9
+ export const translations = [
10
+ {
11
+ 'en-US': {
12
+ [translationKey]: {
13
+ 'toolbar menu label': 'Action menu',
14
+ 'toolbar drag handle label': 'Drag to rearrange',
15
+ 'toolbar close label': 'Close',
16
+ },
17
+ },
18
+ },
19
+ ] as const satisfies Resource[];
package/src/util/index.ts CHANGED
@@ -2,5 +2,7 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
+ export type { ThemedClassName } from '@dxos/ui-types';
6
+
5
7
  export * from './hasIosKeyboard';
6
- export type * from './ThemedClassName';
8
+ export * from './usePx';
@@ -0,0 +1,61 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { useCallback, useEffect, useMemo, useState } from 'react';
6
+
7
+ const getDocumentElementFontSize = () => parseFloat(getComputedStyle(document.documentElement).fontSize);
8
+
9
+ /**
10
+ * React hook that converts rem values to pixels and updates when the root font size changes.
11
+ *
12
+ * @param rem The rem value to convert to pixels
13
+ * @returns The current pixel value equivalent of the rem input
14
+ */
15
+ export const usePx = (rem: number): number => {
16
+ const [fontSize, setFontSize] = useState(() => {
17
+ if (typeof document !== 'undefined') {
18
+ return getDocumentElementFontSize();
19
+ }
20
+ return 16; // Default fallback for SSR
21
+ });
22
+
23
+ const updateFontSize = useCallback(() => {
24
+ setFontSize(getDocumentElementFontSize());
25
+ }, []);
26
+
27
+ useEffect(() => {
28
+ if (typeof document === 'undefined') {
29
+ return;
30
+ }
31
+
32
+ // Create a ResizeObserver to watch for font size changes on the document element
33
+ const resizeObserver = new ResizeObserver(updateFontSize);
34
+ resizeObserver.observe(document.documentElement);
35
+
36
+ // Also listen for viewport changes that might affect font size
37
+ const mediaQueryList = window.matchMedia('all');
38
+ const handleMediaChange = () => {
39
+ updateFontSize();
40
+ };
41
+
42
+ if (mediaQueryList.addEventListener) {
43
+ mediaQueryList.addEventListener('change', handleMediaChange);
44
+ } else {
45
+ // Fallback for older browsers
46
+ mediaQueryList.addListener(handleMediaChange);
47
+ }
48
+
49
+ return () => {
50
+ resizeObserver.disconnect();
51
+ if (mediaQueryList.removeEventListener) {
52
+ mediaQueryList.removeEventListener('change', handleMediaChange);
53
+ } else {
54
+ // Fallback for older browsers
55
+ mediaQueryList.removeListener(handleMediaChange);
56
+ }
57
+ };
58
+ }, []);
59
+
60
+ return useMemo(() => rem * fontSize, [fontSize]);
61
+ };