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

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 (325) hide show
  1. package/LICENSE +102 -5
  2. package/README.md +1 -1
  3. package/dist/lib/browser/chunk-A5QCIG5R.mjs +24 -0
  4. package/dist/lib/browser/chunk-A5QCIG5R.mjs.map +7 -0
  5. package/dist/lib/browser/{chunk-2FKSMWNY.mjs → chunk-LY5XDQR5.mjs} +84 -12
  6. package/dist/lib/browser/chunk-LY5XDQR5.mjs.map +7 -0
  7. package/dist/lib/browser/index.mjs +1559 -1062
  8. package/dist/lib/browser/index.mjs.map +4 -4
  9. package/dist/lib/browser/meta.json +1 -1
  10. package/dist/lib/browser/testing/index.mjs +44 -20
  11. package/dist/lib/browser/testing/index.mjs.map +4 -4
  12. package/dist/lib/browser/translations.mjs +9 -0
  13. package/dist/lib/browser/translations.mjs.map +7 -0
  14. package/dist/lib/node-esm/{chunk-ZNBLTSHI.mjs → chunk-NGKLIKP3.mjs} +84 -12
  15. package/dist/lib/node-esm/chunk-NGKLIKP3.mjs.map +7 -0
  16. package/dist/lib/node-esm/chunk-XCFLA74M.mjs +26 -0
  17. package/dist/lib/node-esm/chunk-XCFLA74M.mjs.map +7 -0
  18. package/dist/lib/node-esm/index.mjs +1559 -1062
  19. package/dist/lib/node-esm/index.mjs.map +4 -4
  20. package/dist/lib/node-esm/meta.json +1 -1
  21. package/dist/lib/node-esm/testing/index.mjs +44 -20
  22. package/dist/lib/node-esm/testing/index.mjs.map +4 -4
  23. package/dist/lib/node-esm/translations.mjs +10 -0
  24. package/dist/lib/node-esm/translations.mjs.map +7 -0
  25. package/dist/types/src/components/Avatars/Avatar.d.ts +1 -1
  26. package/dist/types/src/components/Avatars/Avatar.d.ts.map +1 -1
  27. package/dist/types/src/components/Avatars/Avatar.stories.d.ts.map +1 -1
  28. package/dist/types/src/components/Avatars/AvatarGroup.stories.d.ts.map +1 -1
  29. package/dist/types/src/components/Breadcrumb/Breadcrumb.d.ts.map +1 -1
  30. package/dist/types/src/components/Breadcrumb/Breadcrumb.stories.d.ts.map +1 -1
  31. package/dist/types/src/components/Button/Button.d.ts +2 -2
  32. package/dist/types/src/components/Button/Button.d.ts.map +1 -1
  33. package/dist/types/src/components/Button/Button.stories.d.ts +1 -1
  34. package/dist/types/src/components/Button/Button.stories.d.ts.map +1 -1
  35. package/dist/types/src/components/Button/IconButton.d.ts +1 -0
  36. package/dist/types/src/components/Button/IconButton.d.ts.map +1 -1
  37. package/dist/types/src/components/Button/IconButton.stories.d.ts +3 -0
  38. package/dist/types/src/components/Button/IconButton.stories.d.ts.map +1 -1
  39. package/dist/types/src/components/Button/Toggle.d.ts +2 -2
  40. package/dist/types/src/components/Button/Toggle.d.ts.map +1 -1
  41. package/dist/types/src/components/Button/Toggle.stories.d.ts.map +1 -1
  42. package/dist/types/src/components/Button/ToggleGroup.d.ts +6 -6
  43. package/dist/types/src/components/Button/ToggleGroup.d.ts.map +1 -1
  44. package/dist/types/src/components/Button/ToggleGroup.stories.d.ts +2 -2
  45. package/dist/types/src/components/Button/ToggleGroup.stories.d.ts.map +1 -1
  46. package/dist/types/src/components/Card/Card.d.ts +68 -65
  47. package/dist/types/src/components/Card/Card.d.ts.map +1 -1
  48. package/dist/types/src/components/Card/Card.stories.d.ts +2 -2
  49. package/dist/types/src/components/Card/Card.stories.d.ts.map +1 -1
  50. package/dist/types/src/components/Carousel/Carousel.d.ts +106 -0
  51. package/dist/types/src/components/Carousel/Carousel.d.ts.map +1 -0
  52. package/dist/types/src/components/Carousel/index.d.ts +2 -0
  53. package/dist/types/src/components/Carousel/index.d.ts.map +1 -0
  54. package/dist/types/src/components/Clipboard/ClipboardProvider.d.ts.map +1 -1
  55. package/dist/types/src/components/Clipboard/CopyButton.d.ts.map +1 -1
  56. package/dist/types/src/components/Clipboard/index.d.ts +10 -1
  57. package/dist/types/src/components/Clipboard/index.d.ts.map +1 -1
  58. package/dist/types/src/components/DensityProvider/DensityProvider.d.ts.map +1 -1
  59. package/dist/types/src/components/Dialog/AlertDialog.d.ts +42 -31
  60. package/dist/types/src/components/Dialog/AlertDialog.d.ts.map +1 -1
  61. package/dist/types/src/components/Dialog/AlertDialog.stories.d.ts.map +1 -1
  62. package/dist/types/src/components/Dialog/Dialog.d.ts +47 -30
  63. package/dist/types/src/components/Dialog/Dialog.d.ts.map +1 -1
  64. package/dist/types/src/components/Dialog/Dialog.stories.d.ts +3 -2
  65. package/dist/types/src/components/Dialog/Dialog.stories.d.ts.map +1 -1
  66. package/dist/types/src/components/ElevationProvider/ElevationProvider.d.ts.map +1 -1
  67. package/dist/types/src/components/ErrorFallback/ErrorFallback.d.ts.map +1 -1
  68. package/dist/types/src/components/ErrorFallback/ErrorFallback.stories.d.ts.map +1 -1
  69. package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts +14 -3
  70. package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts.map +1 -1
  71. package/dist/types/src/components/ErrorFallback/ThrowError.d.ts.map +1 -1
  72. package/dist/types/src/components/Focus/Focus.d.ts +36 -0
  73. package/dist/types/src/components/Focus/Focus.d.ts.map +1 -0
  74. package/dist/types/src/components/Focus/Focus.stories.d.ts +9 -0
  75. package/dist/types/src/components/Focus/Focus.stories.d.ts.map +1 -0
  76. package/dist/types/src/components/Focus/index.d.ts +2 -0
  77. package/dist/types/src/components/Focus/index.d.ts.map +1 -0
  78. package/dist/types/src/components/Icon/Icon.d.ts +4 -0
  79. package/dist/types/src/components/Icon/Icon.d.ts.map +1 -1
  80. package/dist/types/src/components/Icon/Icon.stories.d.ts +11 -3
  81. package/dist/types/src/components/Icon/Icon.stories.d.ts.map +1 -1
  82. package/dist/types/src/components/Image/Image.d.ts +2 -1
  83. package/dist/types/src/components/Image/Image.d.ts.map +1 -1
  84. package/dist/types/src/components/Image/Image.stories.d.ts +3 -2
  85. package/dist/types/src/components/Image/Image.stories.d.ts.map +1 -1
  86. package/dist/types/src/components/Input/Input.d.ts +14 -17
  87. package/dist/types/src/components/Input/Input.d.ts.map +1 -1
  88. package/dist/types/src/components/Input/Input.stories.d.ts +3 -3
  89. package/dist/types/src/components/Input/Input.stories.d.ts.map +1 -1
  90. package/dist/types/src/components/Link/Link.d.ts.map +1 -1
  91. package/dist/types/src/components/Link/Link.stories.d.ts.map +1 -1
  92. package/dist/types/src/components/List/List.d.ts +5 -3
  93. package/dist/types/src/components/List/List.d.ts.map +1 -1
  94. package/dist/types/src/components/List/List.stories.d.ts +3 -1
  95. package/dist/types/src/components/List/List.stories.d.ts.map +1 -1
  96. package/dist/types/src/components/List/ListDropIndicator.d.ts.map +1 -1
  97. package/dist/types/src/components/List/Tree.d.ts +2 -2
  98. package/dist/types/src/components/List/Tree.d.ts.map +1 -1
  99. package/dist/types/src/components/List/Tree.stories.d.ts.map +1 -1
  100. package/dist/types/src/components/List/TreeDropIndicator.d.ts.map +1 -1
  101. package/dist/types/src/components/List/Treegrid.d.ts +5 -9
  102. package/dist/types/src/components/List/Treegrid.d.ts.map +1 -1
  103. package/dist/types/src/components/List/Treegrid.stories.d.ts.map +1 -1
  104. package/dist/types/src/components/Main/Main.d.ts +7 -3
  105. package/dist/types/src/components/Main/Main.d.ts.map +1 -1
  106. package/dist/types/src/components/Main/Main.stories.d.ts.map +1 -1
  107. package/dist/types/src/components/Main/useSwipeToDismiss.d.ts.map +1 -1
  108. package/dist/types/src/components/MediaPlayer/MediaPlayer.d.ts +46 -0
  109. package/dist/types/src/components/MediaPlayer/MediaPlayer.d.ts.map +1 -0
  110. package/dist/types/src/components/MediaPlayer/MediaPlayer.stories.d.ts +16 -0
  111. package/dist/types/src/components/MediaPlayer/MediaPlayer.stories.d.ts.map +1 -0
  112. package/dist/types/src/components/MediaPlayer/index.d.ts +2 -0
  113. package/dist/types/src/components/MediaPlayer/index.d.ts.map +1 -0
  114. package/dist/types/src/components/Menu/ContextMenu.d.ts.map +1 -1
  115. package/dist/types/src/components/Menu/ContextMenu.stories.d.ts.map +1 -1
  116. package/dist/types/src/components/Menu/DropdownMenu.d.ts +58 -49
  117. package/dist/types/src/components/Menu/DropdownMenu.d.ts.map +1 -1
  118. package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts +14 -1
  119. package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts.map +1 -1
  120. package/dist/types/src/components/Message/Message.d.ts +1 -1
  121. package/dist/types/src/components/Message/Message.d.ts.map +1 -1
  122. package/dist/types/src/components/Message/Message.stories.d.ts +2 -2
  123. package/dist/types/src/components/Message/Message.stories.d.ts.map +1 -1
  124. package/dist/types/src/components/Popover/Popover.d.ts +38 -22
  125. package/dist/types/src/components/Popover/Popover.d.ts.map +1 -1
  126. package/dist/types/src/components/Popover/Popover.stories.d.ts.map +1 -1
  127. package/dist/types/src/components/ScrollArea/ScrollArea.d.ts +12 -11
  128. package/dist/types/src/components/ScrollArea/ScrollArea.d.ts.map +1 -1
  129. package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts +21 -10
  130. package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts.map +1 -1
  131. package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts +42 -13
  132. package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts.map +1 -1
  133. package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts +5 -6
  134. package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts.map +1 -1
  135. package/dist/types/src/components/Select/Select.d.ts.map +1 -1
  136. package/dist/types/src/components/Select/Select.stories.d.ts +2 -2
  137. package/dist/types/src/components/Select/Select.stories.d.ts.map +1 -1
  138. package/dist/types/src/components/Separator/Separator.d.ts +3 -3
  139. package/dist/types/src/components/Separator/Separator.d.ts.map +1 -1
  140. package/dist/types/src/components/Skeleton/Skeleton.stories.d.ts.map +1 -1
  141. package/dist/types/src/components/Splitter/Splitter.d.ts +19 -21
  142. package/dist/types/src/components/Splitter/Splitter.d.ts.map +1 -1
  143. package/dist/types/src/components/Splitter/Splitter.stories.d.ts.map +1 -1
  144. package/dist/types/src/components/Status/Status.d.ts +3 -4
  145. package/dist/types/src/components/Status/Status.d.ts.map +1 -1
  146. package/dist/types/src/components/Status/Status.stories.d.ts.map +1 -1
  147. package/dist/types/src/components/Tag/Tag.stories.d.ts.map +1 -1
  148. package/dist/types/src/components/ThemeProvider/ThemeProvider.d.ts +1 -1
  149. package/dist/types/src/components/ThemeProvider/ThemeProvider.d.ts.map +1 -1
  150. package/dist/types/src/components/ThemeProvider/ThemeProvider.stories.d.ts +1 -1
  151. package/dist/types/src/components/ThemeProvider/ThemeProvider.stories.d.ts.map +1 -1
  152. package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts +54 -55
  153. package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts.map +1 -1
  154. package/dist/types/src/components/ThemeProvider/index.d.ts +1 -1
  155. package/dist/types/src/components/ThemeProvider/index.d.ts.map +1 -1
  156. package/dist/types/src/components/Toast/Toast.d.ts +16 -16
  157. package/dist/types/src/components/Toast/Toast.d.ts.map +1 -1
  158. package/dist/types/src/components/Toast/Toast.stories.d.ts.map +1 -1
  159. package/dist/types/src/components/Toolbar/Toolbar.d.ts +10 -20
  160. package/dist/types/src/components/Toolbar/Toolbar.d.ts.map +1 -1
  161. package/dist/types/src/components/Toolbar/Toolbar.stories.d.ts.map +1 -1
  162. package/dist/types/src/components/Tooltip/Tooltip.d.ts +16 -16
  163. package/dist/types/src/components/Tooltip/Tooltip.d.ts.map +1 -1
  164. package/dist/types/src/components/Tooltip/Tooltip.stories.d.ts +2 -2
  165. package/dist/types/src/components/Tooltip/Tooltip.stories.d.ts.map +1 -1
  166. package/dist/types/src/components/index.d.ts +3 -0
  167. package/dist/types/src/components/index.d.ts.map +1 -1
  168. package/dist/types/src/exemplars/generics.stories.d.ts +6 -5
  169. package/dist/types/src/exemplars/generics.stories.d.ts.map +1 -1
  170. package/dist/types/src/exemplars/slot.stories.d.ts +1 -0
  171. package/dist/types/src/exemplars/slot.stories.d.ts.map +1 -1
  172. package/dist/types/src/exemplars/tabster.stories.d.ts.map +1 -1
  173. package/dist/types/src/exemplars/virtualizer.stories.d.ts.map +1 -1
  174. package/dist/types/src/hooks/index.d.ts +1 -0
  175. package/dist/types/src/hooks/index.d.ts.map +1 -1
  176. package/dist/types/src/hooks/useDensityContext.d.ts +1 -1
  177. package/dist/types/src/hooks/useDensityContext.d.ts.map +1 -1
  178. package/dist/types/src/hooks/useElevationContext.d.ts.map +1 -1
  179. package/dist/types/src/hooks/useIconHref.d.ts.map +1 -1
  180. package/dist/types/src/hooks/useSafeArea.d.ts.map +1 -1
  181. package/dist/types/src/hooks/useSafeCollisionPadding.d.ts.map +1 -1
  182. package/dist/types/src/hooks/useVisualViewport.d.ts.map +1 -1
  183. package/dist/types/src/playground/Controls.stories.d.ts.map +1 -1
  184. package/dist/types/src/playground/Custom.stories.d.ts +1 -1
  185. package/dist/types/src/playground/Custom.stories.d.ts.map +1 -1
  186. package/dist/types/src/playground/Typography.stories.d.ts.map +1 -1
  187. package/dist/types/src/primitives/Column/Column.d.ts +20 -19
  188. package/dist/types/src/primitives/Column/Column.d.ts.map +1 -1
  189. package/dist/types/src/primitives/Column/Column.stories.d.ts +19 -0
  190. package/dist/types/src/primitives/Column/Column.stories.d.ts.map +1 -1
  191. package/dist/types/src/primitives/Container/Container.d.ts +7 -0
  192. package/dist/types/src/primitives/Container/Container.d.ts.map +1 -0
  193. package/dist/types/src/primitives/Container/Container.stories.d.ts +6 -0
  194. package/dist/types/src/primitives/Container/Container.stories.d.ts.map +1 -0
  195. package/dist/types/src/primitives/Container/index.d.ts +2 -0
  196. package/dist/types/src/primitives/Container/index.d.ts.map +1 -0
  197. package/dist/types/src/primitives/Flex/Flex.d.ts +8 -5
  198. package/dist/types/src/primitives/Flex/Flex.d.ts.map +1 -1
  199. package/dist/types/src/primitives/Flex/Flex.stories.d.ts.map +1 -1
  200. package/dist/types/src/primitives/Grid/Grid.d.ts +6 -5
  201. package/dist/types/src/primitives/Grid/Grid.d.ts.map +1 -1
  202. package/dist/types/src/primitives/Grid/Grid.stories.d.ts.map +1 -1
  203. package/dist/types/src/primitives/Panel/Panel.d.ts +23 -22
  204. package/dist/types/src/primitives/Panel/Panel.d.ts.map +1 -1
  205. package/dist/types/src/primitives/Panel/Panel.stories.d.ts.map +1 -1
  206. package/dist/types/src/primitives/index.d.ts +1 -0
  207. package/dist/types/src/primitives/index.d.ts.map +1 -1
  208. package/dist/types/src/testing/Loading.d.ts +9 -0
  209. package/dist/types/src/testing/Loading.d.ts.map +1 -0
  210. package/dist/types/src/testing/decorators/withLayout.d.ts.map +1 -1
  211. package/dist/types/src/testing/decorators/withLayoutVariants.d.ts.map +1 -1
  212. package/dist/types/src/testing/decorators/withTheme.d.ts +1 -1
  213. package/dist/types/src/testing/decorators/withTheme.d.ts.map +1 -1
  214. package/dist/types/src/testing/index.d.ts +1 -0
  215. package/dist/types/src/testing/index.d.ts.map +1 -1
  216. package/dist/types/src/translations.d.ts +8 -3
  217. package/dist/types/src/translations.d.ts.map +1 -1
  218. package/dist/types/src/util/usePx.d.ts.map +1 -1
  219. package/dist/types/tsconfig.tsbuildinfo +1 -1
  220. package/package.json +29 -26
  221. package/src/components/Avatars/Avatar.stories.tsx +2 -3
  222. package/src/components/Avatars/Avatar.tsx +1 -2
  223. package/src/components/Avatars/AvatarGroup.stories.tsx +0 -1
  224. package/src/components/Breadcrumb/Breadcrumb.stories.tsx +1 -2
  225. package/src/components/Button/Button.stories.tsx +0 -1
  226. package/src/components/Button/Button.tsx +5 -13
  227. package/src/components/Button/IconButton.stories.tsx +6 -4
  228. package/src/components/Button/IconButton.tsx +3 -4
  229. package/src/components/Button/Toggle.stories.tsx +0 -1
  230. package/src/components/Button/Toggle.tsx +4 -4
  231. package/src/components/Button/ToggleGroup.stories.tsx +0 -1
  232. package/src/components/Button/ToggleGroup.tsx +12 -16
  233. package/src/components/Card/Card.stories.tsx +15 -15
  234. package/src/components/Card/Card.tsx +294 -132
  235. package/src/components/Carousel/Carousel.tsx +379 -0
  236. package/src/components/Carousel/index.ts +5 -0
  237. package/src/components/Clipboard/CopyButton.tsx +5 -6
  238. package/src/components/Dialog/AlertDialog.stories.tsx +5 -6
  239. package/src/components/Dialog/AlertDialog.tsx +67 -126
  240. package/src/components/Dialog/Dialog.stories.tsx +64 -9
  241. package/src/components/Dialog/Dialog.tsx +84 -88
  242. package/src/components/ErrorFallback/ErrorFallback.stories.tsx +3 -8
  243. package/src/components/ErrorFallback/ErrorStack.tsx +36 -2
  244. package/src/components/Focus/AUDIT.md +43 -0
  245. package/src/components/Focus/Focus.stories.tsx +230 -0
  246. package/src/components/Focus/Focus.tsx +201 -0
  247. package/src/components/Focus/index.ts +5 -0
  248. package/src/components/Icon/Icon.stories.tsx +43 -13
  249. package/src/components/Icon/Icon.tsx +14 -3
  250. package/src/components/Image/Image.stories.tsx +3 -3
  251. package/src/components/Image/Image.tsx +31 -8
  252. package/src/components/Input/Input.stories.tsx +3 -4
  253. package/src/components/Input/Input.tsx +7 -7
  254. package/src/components/Link/Link.stories.tsx +0 -1
  255. package/src/components/Link/Link.tsx +10 -2
  256. package/src/components/List/List.stories.tsx +3 -4
  257. package/src/components/List/List.tsx +7 -6
  258. package/src/components/List/ListDropIndicator.tsx +0 -1
  259. package/src/components/List/Tree.stories.tsx +2 -3
  260. package/src/components/List/Tree.tsx +0 -1
  261. package/src/components/List/TreeDropIndicator.tsx +1 -1
  262. package/src/components/List/Treegrid.stories.tsx +26 -27
  263. package/src/components/List/Treegrid.tsx +14 -14
  264. package/src/components/Main/Main.stories.tsx +0 -1
  265. package/src/components/Main/Main.tsx +1 -2
  266. package/src/components/MediaPlayer/MediaPlayer.stories.tsx +50 -0
  267. package/src/components/MediaPlayer/MediaPlayer.tsx +153 -0
  268. package/src/components/MediaPlayer/index.ts +5 -0
  269. package/src/components/Menu/ContextMenu.stories.tsx +0 -1
  270. package/src/components/Menu/DropdownMenu.stories.tsx +0 -1
  271. package/src/components/Menu/DropdownMenu.tsx +48 -42
  272. package/src/components/Message/Message.stories.tsx +7 -8
  273. package/src/components/Message/Message.tsx +23 -10
  274. package/src/components/Popover/Popover.stories.tsx +4 -5
  275. package/src/components/Popover/Popover.tsx +42 -42
  276. package/src/components/ScrollArea/ScrollArea.stories.tsx +89 -30
  277. package/src/components/ScrollArea/ScrollArea.tsx +41 -25
  278. package/src/components/ScrollContainer/ScrollContainer.stories.tsx +20 -18
  279. package/src/components/ScrollContainer/ScrollContainer.tsx +199 -92
  280. package/src/components/Select/Select.stories.tsx +5 -6
  281. package/src/components/Separator/Separator.tsx +4 -7
  282. package/src/components/Skeleton/Skeleton.stories.tsx +0 -1
  283. package/src/components/Splitter/Splitter.stories.tsx +29 -29
  284. package/src/components/Splitter/Splitter.tsx +35 -46
  285. package/src/components/Status/Status.stories.tsx +0 -1
  286. package/src/components/Status/Status.tsx +8 -5
  287. package/src/components/Tag/Tag.stories.tsx +0 -1
  288. package/src/components/ThemeProvider/ThemeProvider.stories.tsx +0 -1
  289. package/src/components/ThemeProvider/ThemeProvider.tsx +5 -4
  290. package/src/components/ThemeProvider/index.ts +1 -1
  291. package/src/components/Toast/Toast.stories.tsx +0 -1
  292. package/src/components/Toast/Toast.tsx +16 -31
  293. package/src/components/Toolbar/Toolbar.stories.tsx +0 -1
  294. package/src/components/Toolbar/Toolbar.tsx +36 -48
  295. package/src/components/Tooltip/Tooltip.stories.tsx +7 -8
  296. package/src/components/Tooltip/Tooltip.tsx +29 -29
  297. package/src/components/index.ts +3 -0
  298. package/src/exemplars/generics.stories.tsx +7 -15
  299. package/src/exemplars/slot.stories.tsx +64 -68
  300. package/src/exemplars/tabster.stories.tsx +1 -1
  301. package/src/exemplars/virtualizer.stories.tsx +4 -5
  302. package/src/hooks/index.ts +1 -0
  303. package/src/hooks/useDensityContext.ts +2 -2
  304. package/src/playground/Custom.stories.tsx +6 -9
  305. package/src/primitives/Column/AUDIT.md +148 -0
  306. package/src/primitives/Column/Column.stories.tsx +128 -19
  307. package/src/primitives/Column/Column.tsx +89 -80
  308. package/src/primitives/Container/Container.stories.tsx +29 -0
  309. package/src/primitives/Container/Container.tsx +19 -0
  310. package/src/primitives/Container/index.ts +5 -0
  311. package/src/primitives/Flex/Flex.stories.tsx +0 -1
  312. package/src/primitives/Flex/Flex.tsx +20 -20
  313. package/src/primitives/Grid/Grid.stories.tsx +0 -1
  314. package/src/primitives/Grid/Grid.tsx +23 -36
  315. package/src/primitives/Panel/Panel.stories.tsx +9 -8
  316. package/src/primitives/Panel/Panel.tsx +43 -60
  317. package/src/primitives/index.ts +1 -0
  318. package/src/testing/Loading.tsx +47 -0
  319. package/src/testing/decorators/withLayout.tsx +7 -17
  320. package/src/testing/decorators/withTheme.tsx +10 -7
  321. package/src/testing/index.ts +2 -0
  322. package/src/translations.ts +8 -3
  323. package/src/util/usePx.ts +1 -0
  324. package/dist/lib/browser/chunk-2FKSMWNY.mjs.map +0 -7
  325. package/dist/lib/node-esm/chunk-ZNBLTSHI.mjs.map +0 -7
@@ -2,26 +2,26 @@
2
2
  // Copyright 2026 DXOS.org
3
3
  //
4
4
 
5
- import React, { type HTMLAttributes } from 'react';
5
+ import { Primitive } from '@radix-ui/react-primitive';
6
+ import { Slot } from '@radix-ui/react-slot';
7
+ import React from 'react';
6
8
 
7
- import { mx } from '@dxos/ui-theme';
8
- import { type ComposableProps } from '@dxos/ui-types';
9
+ import { composableProps, mx, slottable } from '@dxos/ui-theme';
9
10
 
10
- export type FlexProps = ComposableProps<
11
- HTMLAttributes<HTMLDivElement> & {
12
- column?: boolean;
13
- grow?: boolean;
14
- }
15
- >;
11
+ export type FlexProps = { column?: boolean; grow?: boolean };
16
12
 
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
- };
13
+ export const Flex = slottable<HTMLDivElement, FlexProps>(
14
+ ({ children, asChild, column, grow, ...props }, forwardedRef) => {
15
+ const { className, ...rest } = composableProps(props);
16
+ const Comp = asChild ? Slot : Primitive.div;
17
+ return (
18
+ <Comp
19
+ ref={forwardedRef}
20
+ {...rest}
21
+ className={mx('flex', column && 'flex-col', grow && 'flex-1 overflow-hidden', className)}
22
+ >
23
+ {children}
24
+ </Comp>
25
+ );
26
+ },
27
+ );
@@ -8,7 +8,6 @@ import React from 'react';
8
8
  import { type ChromaticPalette } from '@dxos/ui-types';
9
9
 
10
10
  import { withLayout, withTheme } from '../../testing';
11
-
12
11
  import { Grid } from './Grid';
13
12
 
14
13
  const Cell = ({ label, hue }: { label: string; hue: ChromaticPalette }) => (
@@ -2,42 +2,29 @@
2
2
  // Copyright 2026 DXOS.org
3
3
  //
4
4
 
5
- import React, { type HTMLAttributes } from 'react';
5
+ import React from 'react';
6
6
 
7
- import { mx } from '@dxos/ui-theme';
8
- import { type ComposableProps } from '@dxos/ui-types';
7
+ import { composable, composableProps, mx } from '@dxos/ui-theme';
9
8
 
10
- export type GridProps = ComposableProps<
11
- HTMLAttributes<HTMLDivElement> & {
12
- cols?: number;
13
- rows?: number;
14
- grow?: boolean;
15
- }
16
- >;
9
+ export type GridProps = { cols?: number; rows?: number; grow?: boolean };
17
10
 
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
- };
11
+ export const Grid = composable<HTMLDivElement, GridProps>(
12
+ ({ children, style, role, cols, rows, grow = true, ...props }, forwardedRef) => {
13
+ const { className, ...rest } = composableProps(props);
14
+ return (
15
+ <div
16
+ ref={forwardedRef}
17
+ {...rest}
18
+ role={role ?? 'none'}
19
+ className={mx('grid overflow-hidden', grow && 'dx-container', className)}
20
+ style={{
21
+ gridTemplateColumns: cols ? `repeat(${cols}, 1fr)` : undefined,
22
+ gridTemplateRows: rows ? `repeat(${rows}, 1fr)` : undefined,
23
+ ...style,
24
+ }}
25
+ >
26
+ {children}
27
+ </div>
28
+ );
29
+ },
30
+ );
@@ -5,14 +5,15 @@
5
5
  import { type Meta, type StoryObj } from '@storybook/react-vite';
6
6
  import React from 'react';
7
7
 
8
- import { Input, ScrollArea, Toolbar } from '../../components';
9
- import { withLayout, withTheme } from '../../testing';
8
+ import { composable, composableProps } from '@dxos/ui-theme';
10
9
 
10
+ import { Input, ScrollArea, ScrollAreaRootProps, Toolbar } from '../../components';
11
+ import { withLayout, withTheme } from '../../testing';
11
12
  import { Panel } from './Panel';
12
13
 
13
- const List = () => {
14
+ const List = composable<HTMLDivElement, ScrollAreaRootProps>((props, forwardedRef) => {
14
15
  return (
15
- <ScrollArea.Root margin role='list'>
16
+ <ScrollArea.Root centered {...composableProps(props, { role: 'list' })} ref={forwardedRef}>
16
17
  <ScrollArea.Viewport>
17
18
  {Array.from({ length: 100 }).map((_, i) => (
18
19
  <div key={i} role='listitem' className='p-1 hover:bg-hover-surface'>
@@ -22,11 +23,11 @@ const List = () => {
22
23
  </ScrollArea.Viewport>
23
24
  </ScrollArea.Root>
24
25
  );
25
- };
26
+ });
26
27
 
27
28
  const DefaultStory = () => {
28
29
  return (
29
- <Panel.Root className='dx-article'>
30
+ <Panel.Root className='dx-document'>
30
31
  <Panel.Toolbar asChild>
31
32
  <Toolbar.Root classNames='gap-2'>
32
33
  <Toolbar.IconButton icon='ph--plus--regular' variant='primary' label='Add' />
@@ -43,8 +44,8 @@ const DefaultStory = () => {
43
44
 
44
45
  <Panel.Statusbar asChild>
45
46
  <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} />
47
+ <Toolbar.IconButton variant='ghost' icon='ph--house--regular' iconOnly label='Add' />
48
+ <Toolbar.IconButton variant='ghost' icon='ph--alarm--regular' iconOnly label='Status' />
48
49
  </Toolbar.Root>
49
50
  </Panel.Statusbar>
50
51
  </Panel.Root>
@@ -4,8 +4,9 @@
4
4
 
5
5
  import { Primitive } from '@radix-ui/react-primitive';
6
6
  import { Slot } from '@radix-ui/react-slot';
7
- import React, { forwardRef } from 'react';
7
+ import React, { type CSSProperties } from 'react';
8
8
 
9
+ import { composableProps, PanelStyleProps, slottable } from '@dxos/ui-theme';
9
10
  import { type SlottableProps } from '@dxos/ui-types';
10
11
 
11
12
  import { useThemeContext } from '../../hooks';
@@ -17,23 +18,24 @@ import { useThemeContext } from '../../hooks';
17
18
  const GRID_TEMPLATE_ROWS = 'auto 1fr auto';
18
19
  const GRID_TEMPLATE_AREAS = '"toolbar" "content" "statusbar"';
19
20
 
20
- type PanelRootProps = SlottableProps<HTMLDivElement>;
21
+ type PanelRootProps = SlottableProps<{ style?: CSSProperties }>;
21
22
 
22
- const Root = forwardRef<HTMLDivElement, PanelRootProps>(
23
- ({ classNames, className, asChild, children, role, ...props }, forwardedRef) => {
24
- const { tx } = useThemeContext();
23
+ const PanelRoot = slottable<HTMLDivElement, { style?: CSSProperties }>(
24
+ ({ children, asChild, role, style, ...props }, forwardedRef) => {
25
+ const { className, ...rest } = composableProps(props);
25
26
  const Comp = asChild ? Slot : Primitive.div;
27
+ const { tx } = useThemeContext();
26
28
  return (
27
29
  <Comp
28
- ref={forwardedRef}
30
+ {...rest}
29
31
  role={role ?? 'none'}
30
- {...props}
31
32
  style={{
32
33
  gridTemplateRows: GRID_TEMPLATE_ROWS,
33
34
  gridTemplateAreas: GRID_TEMPLATE_AREAS,
34
- ...props.style,
35
+ ...style,
35
36
  }}
36
- className={tx('panel.root', {}, [className, classNames])}
37
+ className={tx('panel.root', {}, className)}
38
+ ref={forwardedRef}
37
39
  >
38
40
  {children}
39
41
  </Comp>
@@ -41,97 +43,78 @@ const Root = forwardRef<HTMLDivElement, PanelRootProps>(
41
43
  },
42
44
  );
43
45
 
44
- Root.displayName = 'Panel.Root';
46
+ PanelRoot.displayName = 'Panel.Root';
45
47
 
46
48
  //
47
49
  // Toolbar
48
50
  //
49
51
 
50
- type ToolbarProps = SlottableProps<HTMLDivElement>;
52
+ type PanelToolbarProps = SlottableProps & Pick<PanelStyleProps, 'size'>;
51
53
 
52
- const Toolbar = forwardRef<HTMLDivElement, ToolbarProps>(
53
- ({ classNames, className, asChild, children, ...props }, forwardedRef) => {
54
- const { tx } = useThemeContext();
54
+ const PanelToolbar = slottable<HTMLDivElement, Pick<PanelStyleProps, 'size'>>(
55
+ ({ children, asChild, size, ...props }, forwardedRef) => {
56
+ const { className, ...rest } = composableProps(props);
55
57
  const Comp = asChild ? Slot : Primitive.div;
58
+ const { tx } = useThemeContext();
56
59
  return (
57
- <Comp
58
- ref={forwardedRef}
59
- data-slot='toolbar'
60
- {...props}
61
- className={tx('panel.toolbar', {}, [className, classNames])}
62
- >
60
+ <Comp {...rest} data-slot='toolbar' className={tx('panel.toolbar', { size }, className)} ref={forwardedRef}>
63
61
  {children}
64
62
  </Comp>
65
63
  );
66
64
  },
67
65
  );
68
66
 
69
- Toolbar.displayName = 'Panel.Toolbar';
67
+ PanelToolbar.displayName = 'Panel.Toolbar';
70
68
 
71
69
  //
72
70
  // Content
73
71
  //
74
72
 
75
- type ContentProps = SlottableProps<HTMLDivElement>;
73
+ type PanelContentProps = SlottableProps;
76
74
 
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
- );
75
+ const PanelContent = slottable<HTMLDivElement>(({ children, asChild, ...props }, forwardedRef) => {
76
+ const { className, ...rest } = composableProps(props);
77
+ const Comp = asChild ? Slot : Primitive.div;
78
+ const { tx } = useThemeContext();
79
+ return (
80
+ <Comp {...rest} data-slot='content' className={tx('panel.content', {}, className)} ref={forwardedRef}>
81
+ {children}
82
+ </Comp>
83
+ );
84
+ });
93
85
 
94
- Content.displayName = 'Panel.Content';
86
+ PanelContent.displayName = 'Panel.Content';
95
87
 
96
88
  //
97
89
  // Statusbar
98
90
  //
99
91
 
100
- type StatusbarProps = SlottableProps<HTMLDivElement>;
92
+ type PanelStatusbarProps = SlottableProps & Pick<PanelStyleProps, 'size'>;
101
93
 
102
- const Statusbar = forwardRef<HTMLDivElement, StatusbarProps>(
103
- ({ classNames, className, asChild, children, ...props }, forwardedRef) => {
104
- const { tx } = useThemeContext();
94
+ const PanelStatusbar = slottable<HTMLDivElement, Pick<PanelStyleProps, 'size'>>(
95
+ ({ children, asChild, size, ...props }, forwardedRef) => {
96
+ const { className, ...rest } = composableProps(props);
105
97
  const Comp = asChild ? Slot : Primitive.div;
98
+ const { tx } = useThemeContext();
106
99
  return (
107
- <Comp
108
- ref={forwardedRef}
109
- data-slot='statusbar'
110
- {...props}
111
- className={tx('panel.statusbar', {}, [className, classNames])}
112
- >
100
+ <Comp {...rest} data-slot='statusbar' className={tx('panel.statusbar', { size }, className)} ref={forwardedRef}>
113
101
  {children}
114
102
  </Comp>
115
103
  );
116
104
  },
117
105
  );
118
106
 
119
- Statusbar.displayName = 'Panel.Statusbar';
107
+ PanelStatusbar.displayName = 'Panel.Statusbar';
120
108
 
121
109
  //
122
110
  // Panel
123
111
  //
124
112
 
125
113
  export const Panel = {
126
- Root,
127
- Toolbar,
128
- Content,
129
- Statusbar,
114
+ Root: PanelRoot,
115
+ Toolbar: PanelToolbar,
116
+ Content: PanelContent,
117
+ Statusbar: PanelStatusbar,
130
118
  };
131
119
 
132
- export type {
133
- PanelRootProps,
134
- ToolbarProps as PanelToolbarProps,
135
- ContentProps as PanelContentProps,
136
- StatusbarProps as PanelStatusbarProps,
137
- };
120
+ export type { PanelRootProps, PanelToolbarProps, PanelContentProps, PanelStatusbarProps };
@@ -3,6 +3,7 @@
3
3
  //
4
4
 
5
5
  export * from './Column';
6
+ export * from './Container';
6
7
  export * from './Flex';
7
8
  export * from './Grid';
8
9
  export * from './Panel';
@@ -0,0 +1,47 @@
1
+ //
2
+ // Copyright 2023 DXOS.org
3
+ //
4
+
5
+ import React, { captureOwnerStack, useEffect, useState } from 'react';
6
+
7
+ import { mx } from '@dxos/ui-theme';
8
+ import { safeStringify } from '@dxos/util';
9
+
10
+ import { ErrorStack, parseCaptureOwnerStack } from '../components';
11
+
12
+ export type LoadingProps = { data?: any };
13
+
14
+ /**
15
+ * Storybook loading component.
16
+ */
17
+ export const Loading = ({ data }: LoadingProps) => {
18
+ const [visible, setVisible] = useState(false);
19
+ const ownerFrames = parseCaptureOwnerStack(captureOwnerStack());
20
+
21
+ useEffect(() => {
22
+ const t = setTimeout(() => setVisible(true), 500);
23
+ return () => clearTimeout(t);
24
+ }, []);
25
+
26
+ return (
27
+ <div className='w-full p-2'>
28
+ <div
29
+ className={mx(
30
+ 'flex flex-col w-full p-2 border-2 border-teal-500 rounded-md',
31
+ 'opacity-0 transition delay-1000 duration-1000',
32
+ visible && 'opacity-100',
33
+ )}
34
+ >
35
+ <h2 className='uppercase capitalize text-xs'>Loading State</h2>
36
+ <pre className='text-sm text-description'>{safeStringify(data, undefined, 2)}</pre>
37
+
38
+ <h3 className='uppercase capitalize text-xs mt-2'>Owner stack</h3>
39
+ {ownerFrames && ownerFrames.length > 0 ? (
40
+ <ErrorStack frames={ownerFrames} />
41
+ ) : (
42
+ <p className='text-xs text-subdued'>No owner stack (production build or unsupported context).</p>
43
+ )}
44
+ </div>
45
+ </div>
46
+ );
47
+ };
@@ -39,7 +39,7 @@ export const withLayout =
39
39
  const { layout = 'default', classNames, scroll } = props;
40
40
  const Container = layouts[layout] ?? layouts.fullscreen;
41
41
  return (
42
- <Container classNames={mx(classNames, scroll ? 'overflow-y-auto' : 'overflow-hidden')}>
42
+ <Container classNames={mx(scroll ? 'overflow-y-auto' : 'overflow-hidden', classNames)}>
43
43
  <MemoizedStory />
44
44
  </Container>
45
45
  );
@@ -47,31 +47,21 @@ export const withLayout =
47
47
  };
48
48
 
49
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
- ),
50
+ default: ({ classNames, children }: ContainerProps) => <div className={mx('p-4', classNames)}>{children}</div>,
55
51
 
56
52
  fullscreen: ({ classNames, children }: ContainerProps) => (
57
- <div role='none' className={mx('fixed inset-0 flex overflow-hidden bg-base-surface', classNames)}>
58
- {children}
59
- </div>
53
+ <div className={mx('fixed inset-0 flex overflow-hidden bg-black', classNames)}>{children}</div>
60
54
  ),
61
55
 
62
56
  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>
57
+ <div className={mx('fixed inset-0 grid overflow-hidden place-items-center bg-black')}>
58
+ <div className={mx('flex flex-col bg-base-surface', classNames)}>{children}</div>
67
59
  </div>
68
60
  ),
69
61
 
70
62
  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>
63
+ <div className='fixed inset-0 flex overflow-hidden justify-center bg-black'>
64
+ <div className={mx('flex flex-col w-[40rem] bg-base-surface', classNames)}>{children}</div>
75
65
  </div>
76
66
  ),
77
67
  };
@@ -3,7 +3,7 @@
3
3
  //
4
4
 
5
5
  import { type Decorator } from '@storybook/react';
6
- import React, { memo } from 'react';
6
+ import React from 'react';
7
7
 
8
8
  import { defaultTx } from '@dxos/ui-theme';
9
9
  import { type ThemeMode } from '@dxos/ui-types';
@@ -14,20 +14,23 @@ import { type ThemeContextValue, ThemeProvider, Tooltip } from '../../components
14
14
  * Adds theme decorator.
15
15
  */
16
16
  export const withTheme =
17
- ({ tx = defaultTx, ...props }: Partial<ThemeContextValue> = {}): Decorator =>
17
+ ({ tx = defaultTx, noCache, platform }: Partial<ThemeContextValue> = {}): Decorator =>
18
18
  (Story, context) => {
19
19
  const {
20
20
  globals: { theme },
21
21
  parameters: { translations },
22
22
  } = context;
23
23
 
24
- // Prevent re-rendering of the story.
25
- const MemoizedStory = memo(Story);
26
-
27
24
  return (
28
- <ThemeProvider {...props} tx={tx} themeMode={theme as ThemeMode} resourceExtensions={translations} noCache>
25
+ <ThemeProvider
26
+ tx={tx}
27
+ themeMode={theme as ThemeMode}
28
+ resourceExtensions={translations}
29
+ noCache={noCache}
30
+ platform={platform}
31
+ >
29
32
  <Tooltip.Provider>
30
- <MemoizedStory />
33
+ <Story />
31
34
  </Tooltip.Provider>
32
35
  </ThemeProvider>
33
36
  );
@@ -3,3 +3,5 @@
3
3
  //
4
4
 
5
5
  export * from './decorators';
6
+
7
+ export * from './Loading';
@@ -10,9 +10,14 @@ export const translations = [
10
10
  {
11
11
  'en-US': {
12
12
  [translationKey]: {
13
- 'toolbar menu label': 'Action menu',
14
- 'toolbar drag handle label': 'Drag to rearrange',
15
- 'toolbar close label': 'Close',
13
+ 'toolbar-menu.label': 'Action menu',
14
+ 'toolbar-drag-handle.label': 'Drag to rearrange',
15
+ 'toolbar-close.label': 'Close',
16
+ 'carousel-viewport.label': 'Carousel',
17
+ 'carousel-prev.label': 'Previous slide',
18
+ 'carousel-next.label': 'Next slide',
19
+ 'carousel-indicators.label': 'Carousel slides',
20
+ 'carousel-go-to.label': 'Go to slide {{index}}',
16
21
  },
17
22
  },
18
23
  },
package/src/util/usePx.ts CHANGED
@@ -17,6 +17,7 @@ export const usePx = (rem: number): number => {
17
17
  if (typeof document !== 'undefined') {
18
18
  return getDocumentElementFontSize();
19
19
  }
20
+
20
21
  return 16; // Default fallback for SSR
21
22
  });
22
23