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

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 (459) hide show
  1. package/dist/lib/browser/chunk-EJSGYGYH.mjs +774 -0
  2. package/dist/lib/browser/chunk-EJSGYGYH.mjs.map +7 -0
  3. package/dist/lib/browser/index.mjs +3917 -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 +100 -60
  7. package/dist/lib/browser/testing/index.mjs.map +4 -4
  8. package/dist/lib/node-esm/chunk-B7MXDDMJ.mjs +776 -0
  9. package/dist/lib/node-esm/chunk-B7MXDDMJ.mjs.map +7 -0
  10. package/dist/lib/node-esm/index.mjs +3917 -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 +100 -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 +4 -4
  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/{Buttons → Button}/Toggle.d.ts +2 -2
  34. package/dist/types/src/components/Button/Toggle.d.ts.map +1 -0
  35. package/dist/types/src/components/Button/Toggle.stories.d.ts +16 -0
  36. package/dist/types/src/components/Button/Toggle.stories.d.ts.map +1 -0
  37. package/dist/types/src/components/Button/ToggleGroup.d.ts +27 -0
  38. package/dist/types/src/components/Button/ToggleGroup.d.ts.map +1 -0
  39. package/dist/types/src/components/Button/ToggleGroup.stories.d.ts +27 -0
  40. package/dist/types/src/components/Button/ToggleGroup.stories.d.ts.map +1 -0
  41. package/dist/types/src/components/Button/index.d.ts.map +1 -0
  42. package/dist/types/src/components/Card/Card.d.ts +107 -0
  43. package/dist/types/src/components/Card/Card.d.ts.map +1 -0
  44. package/dist/types/src/components/Card/Card.stories.d.ts +21 -0
  45. package/dist/types/src/components/Card/Card.stories.d.ts.map +1 -0
  46. package/dist/types/src/components/Card/index.d.ts +2 -0
  47. package/dist/types/src/components/Card/index.d.ts.map +1 -0
  48. package/dist/types/src/components/Clipboard/ClipboardProvider.d.ts.map +1 -1
  49. package/dist/types/src/components/Clipboard/CopyButton.d.ts +1 -1
  50. package/dist/types/src/components/Clipboard/CopyButton.d.ts.map +1 -1
  51. package/dist/types/src/components/Clipboard/index.d.ts +10 -1
  52. package/dist/types/src/components/Clipboard/index.d.ts.map +1 -1
  53. package/dist/types/src/components/DensityProvider/DensityProvider.d.ts +1 -1
  54. package/dist/types/src/components/DensityProvider/DensityProvider.d.ts.map +1 -1
  55. package/dist/types/src/components/Dialog/AlertDialog.d.ts +40 -0
  56. package/dist/types/src/components/Dialog/AlertDialog.d.ts.map +1 -0
  57. package/dist/types/src/components/Dialog/AlertDialog.stories.d.ts +11 -0
  58. package/dist/types/src/components/Dialog/AlertDialog.stories.d.ts.map +1 -0
  59. package/dist/types/src/components/Dialog/Dialog.d.ts +47 -0
  60. package/dist/types/src/components/Dialog/Dialog.d.ts.map +1 -0
  61. package/dist/types/src/components/Dialog/Dialog.stories.d.ts +24 -0
  62. package/dist/types/src/components/Dialog/Dialog.stories.d.ts.map +1 -0
  63. package/dist/types/src/components/Dialog/index.d.ts.map +1 -0
  64. package/dist/types/src/components/ElevationProvider/ElevationProvider.d.ts +1 -1
  65. package/dist/types/src/components/ElevationProvider/ElevationProvider.d.ts.map +1 -1
  66. package/dist/types/src/components/ErrorFallback/ErrorFallback.d.ts +11 -0
  67. package/dist/types/src/components/ErrorFallback/ErrorFallback.d.ts.map +1 -0
  68. package/dist/types/src/components/ErrorFallback/ErrorFallback.stories.d.ts +7 -0
  69. package/dist/types/src/components/ErrorFallback/ErrorFallback.stories.d.ts.map +1 -0
  70. package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts +8 -0
  71. package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts.map +1 -0
  72. package/dist/types/src/components/ErrorFallback/ThrowError.d.ts +9 -0
  73. package/dist/types/src/components/ErrorFallback/ThrowError.d.ts.map +1 -0
  74. package/dist/types/src/components/ErrorFallback/index.d.ts +5 -0
  75. package/dist/types/src/components/ErrorFallback/index.d.ts.map +1 -0
  76. package/dist/types/src/components/Icon/Icon.d.ts +2 -2
  77. package/dist/types/src/components/Icon/Icon.d.ts.map +1 -1
  78. package/dist/types/src/components/Icon/Icon.stories.d.ts +17 -0
  79. package/dist/types/src/components/Icon/Icon.stories.d.ts.map +1 -0
  80. package/dist/types/src/components/Image/Image.d.ts +14 -0
  81. package/dist/types/src/components/Image/Image.d.ts.map +1 -0
  82. package/dist/types/src/components/Image/Image.stories.d.ts +33 -0
  83. package/dist/types/src/components/Image/Image.stories.d.ts.map +1 -0
  84. package/dist/types/src/components/Image/index.d.ts +2 -0
  85. package/dist/types/src/components/Image/index.d.ts.map +1 -0
  86. package/dist/types/src/components/Input/Input.d.ts +8 -10
  87. package/dist/types/src/components/Input/Input.d.ts.map +1 -1
  88. package/dist/types/src/components/Input/Input.stories.d.ts +17 -18
  89. package/dist/types/src/components/Input/Input.stories.d.ts.map +1 -1
  90. package/dist/types/src/components/Link/Link.stories.d.ts +8 -8
  91. package/dist/types/src/components/Link/Link.stories.d.ts.map +1 -1
  92. package/dist/types/src/components/{Lists → List}/List.d.ts +3 -3
  93. package/dist/types/src/components/List/List.d.ts.map +1 -0
  94. package/dist/types/src/components/List/List.stories.d.ts +14 -0
  95. package/dist/types/src/components/List/List.stories.d.ts.map +1 -0
  96. package/dist/types/src/components/List/ListDropIndicator.d.ts.map +1 -0
  97. package/dist/types/src/components/{Lists → List}/Tree.d.ts +1 -1
  98. package/dist/types/src/components/List/Tree.d.ts.map +1 -0
  99. package/dist/types/src/components/List/Tree.stories.d.ts +15 -0
  100. package/dist/types/src/components/List/Tree.stories.d.ts.map +1 -0
  101. package/dist/types/src/components/List/TreeDropIndicator.d.ts.map +1 -0
  102. package/dist/types/src/components/{Lists → List}/Treegrid.d.ts +1 -1
  103. package/dist/types/src/components/{Lists → List}/Treegrid.d.ts.map +1 -1
  104. package/dist/types/src/components/List/Treegrid.stories.d.ts +12 -0
  105. package/dist/types/src/components/List/Treegrid.stories.d.ts.map +1 -0
  106. package/dist/types/src/components/List/index.d.ts.map +1 -0
  107. package/dist/types/src/components/Main/Main.d.ts +18 -28
  108. package/dist/types/src/components/Main/Main.d.ts.map +1 -1
  109. package/dist/types/src/components/Main/Main.stories.d.ts +6 -10
  110. package/dist/types/src/components/Main/Main.stories.d.ts.map +1 -1
  111. package/dist/types/src/components/{Menus → Menu}/ContextMenu.d.ts +6 -6
  112. package/dist/types/src/components/Menu/ContextMenu.d.ts.map +1 -0
  113. package/dist/types/src/components/Menu/ContextMenu.stories.d.ts +12 -0
  114. package/dist/types/src/components/Menu/ContextMenu.stories.d.ts.map +1 -0
  115. package/dist/types/src/components/Menu/DropdownMenu.d.ts +114 -0
  116. package/dist/types/src/components/Menu/DropdownMenu.d.ts.map +1 -0
  117. package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts +20 -0
  118. package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts.map +1 -0
  119. package/dist/types/src/components/Menu/index.d.ts.map +1 -0
  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 +10 -20
  123. package/dist/types/src/components/Message/Message.stories.d.ts.map +1 -1
  124. package/dist/types/src/components/Popover/Popover.d.ts +30 -24
  125. package/dist/types/src/components/Popover/Popover.d.ts.map +1 -1
  126. package/dist/types/src/components/Popover/Popover.stories.d.ts +6 -34
  127. package/dist/types/src/components/Popover/Popover.stories.d.ts.map +1 -1
  128. package/dist/types/src/components/ScrollArea/ScrollArea.d.ts +23 -26
  129. package/dist/types/src/components/ScrollArea/ScrollArea.d.ts.map +1 -1
  130. package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts +35 -25
  131. package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts.map +1 -1
  132. package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts +39 -0
  133. package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts.map +1 -0
  134. package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts +24 -0
  135. package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts.map +1 -0
  136. package/dist/types/src/components/ScrollContainer/index.d.ts +2 -0
  137. package/dist/types/src/components/ScrollContainer/index.d.ts.map +1 -0
  138. package/dist/types/src/components/Select/Select.d.ts +10 -10
  139. package/dist/types/src/components/Select/Select.d.ts.map +1 -1
  140. package/dist/types/src/components/Select/Select.stories.d.ts +4 -9
  141. package/dist/types/src/components/Select/Select.stories.d.ts.map +1 -1
  142. package/dist/types/src/components/Separator/Separator.d.ts +4 -4
  143. package/dist/types/src/components/Separator/Separator.d.ts.map +1 -1
  144. package/dist/types/src/components/Skeleton/Skeleton.d.ts +12 -0
  145. package/dist/types/src/components/Skeleton/Skeleton.d.ts.map +1 -0
  146. package/dist/types/src/components/Skeleton/Skeleton.stories.d.ts +17 -0
  147. package/dist/types/src/components/Skeleton/Skeleton.stories.d.ts.map +1 -0
  148. package/dist/types/src/components/Skeleton/index.d.ts +2 -0
  149. package/dist/types/src/components/Skeleton/index.d.ts.map +1 -0
  150. package/dist/types/src/components/Splitter/Splitter.d.ts +32 -0
  151. package/dist/types/src/components/Splitter/Splitter.d.ts.map +1 -0
  152. package/dist/types/src/components/Splitter/Splitter.stories.d.ts +7 -0
  153. package/dist/types/src/components/Splitter/Splitter.stories.d.ts.map +1 -0
  154. package/dist/types/src/components/Splitter/index.d.ts +2 -0
  155. package/dist/types/src/components/Splitter/index.d.ts.map +1 -0
  156. package/dist/types/src/components/Status/Status.stories.d.ts +6 -10
  157. package/dist/types/src/components/Status/Status.stories.d.ts.map +1 -1
  158. package/dist/types/src/components/Tag/Tag.d.ts +1 -1
  159. package/dist/types/src/components/Tag/Tag.d.ts.map +1 -1
  160. package/dist/types/src/components/Tag/Tag.stories.d.ts +8 -13
  161. package/dist/types/src/components/Tag/Tag.stories.d.ts.map +1 -1
  162. package/dist/types/src/components/ThemeProvider/ThemeProvider.d.ts +3 -3
  163. package/dist/types/src/components/ThemeProvider/ThemeProvider.d.ts.map +1 -1
  164. package/dist/types/src/components/ThemeProvider/ThemeProvider.stories.d.ts +12 -0
  165. package/dist/types/src/components/ThemeProvider/ThemeProvider.stories.d.ts.map +1 -0
  166. package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts +1 -8
  167. package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts.map +1 -1
  168. package/dist/types/src/components/ThemeProvider/index.d.ts +2 -1
  169. package/dist/types/src/components/ThemeProvider/index.d.ts.map +1 -1
  170. package/dist/types/src/components/Toast/Toast.d.ts +19 -19
  171. package/dist/types/src/components/Toast/Toast.d.ts.map +1 -1
  172. package/dist/types/src/components/Toast/Toast.stories.d.ts +6 -44
  173. package/dist/types/src/components/Toast/Toast.stories.d.ts.map +1 -1
  174. package/dist/types/src/components/Toolbar/Toolbar.d.ts +42 -20
  175. package/dist/types/src/components/Toolbar/Toolbar.d.ts.map +1 -1
  176. package/dist/types/src/components/Toolbar/Toolbar.stories.d.ts +6 -50
  177. package/dist/types/src/components/Toolbar/Toolbar.stories.d.ts.map +1 -1
  178. package/dist/types/src/components/Tooltip/Tooltip.d.ts +10 -12
  179. package/dist/types/src/components/Tooltip/Tooltip.d.ts.map +1 -1
  180. package/dist/types/src/components/Tooltip/Tooltip.stories.d.ts +8 -61
  181. package/dist/types/src/components/Tooltip/Tooltip.stories.d.ts.map +1 -1
  182. package/dist/types/src/components/index.d.ts +13 -8
  183. package/dist/types/src/components/index.d.ts.map +1 -1
  184. package/dist/types/src/exemplars/generics.stories.d.ts +18 -0
  185. package/dist/types/src/exemplars/generics.stories.d.ts.map +1 -0
  186. package/dist/types/src/exemplars/slot.stories.d.ts +14 -0
  187. package/dist/types/src/exemplars/slot.stories.d.ts.map +1 -0
  188. package/dist/types/src/exemplars/tabster.stories.d.ts +8 -0
  189. package/dist/types/src/exemplars/tabster.stories.d.ts.map +1 -0
  190. package/dist/types/src/exemplars/virtualizer.stories.d.ts +11 -0
  191. package/dist/types/src/exemplars/virtualizer.stories.d.ts.map +1 -0
  192. package/dist/types/src/hooks/index.d.ts +1 -0
  193. package/dist/types/src/hooks/index.d.ts.map +1 -1
  194. package/dist/types/src/hooks/useDensityContext.d.ts +1 -1
  195. package/dist/types/src/hooks/useDensityContext.d.ts.map +1 -1
  196. package/dist/types/src/hooks/useElevationContext.d.ts +1 -1
  197. package/dist/types/src/hooks/useElevationContext.d.ts.map +1 -1
  198. package/dist/types/src/hooks/useSafeArea.d.ts.map +1 -1
  199. package/dist/types/src/hooks/useVisualViewport.d.ts +2 -2
  200. package/dist/types/src/hooks/useVisualViewport.d.ts.map +1 -1
  201. package/dist/types/src/index.d.ts +2 -1
  202. package/dist/types/src/index.d.ts.map +1 -1
  203. package/dist/types/src/playground/Controls.stories.d.ts +5 -9
  204. package/dist/types/src/playground/Controls.stories.d.ts.map +1 -1
  205. package/dist/types/src/playground/Custom.stories.d.ts +12 -4
  206. package/dist/types/src/playground/Custom.stories.d.ts.map +1 -1
  207. package/dist/types/src/playground/Typography.stories.d.ts +5 -11
  208. package/dist/types/src/playground/Typography.stories.d.ts.map +1 -1
  209. package/dist/types/src/primitives/Column/Column.d.ts +26 -0
  210. package/dist/types/src/primitives/Column/Column.d.ts.map +1 -0
  211. package/dist/types/src/primitives/Column/Column.stories.d.ts +6 -0
  212. package/dist/types/src/primitives/Column/Column.stories.d.ts.map +1 -0
  213. package/dist/types/src/primitives/Column/index.d.ts +2 -0
  214. package/dist/types/src/primitives/Column/index.d.ts.map +1 -0
  215. package/dist/types/src/primitives/Container/Container.d.ts +8 -0
  216. package/dist/types/src/primitives/Container/Container.d.ts.map +1 -0
  217. package/dist/types/src/primitives/Container/Container.stories.d.ts +6 -0
  218. package/dist/types/src/primitives/Container/Container.stories.d.ts.map +1 -0
  219. package/dist/types/src/primitives/Container/index.d.ts +2 -0
  220. package/dist/types/src/primitives/Container/index.d.ts.map +1 -0
  221. package/dist/types/src/primitives/Flex/Flex.d.ts +13 -0
  222. package/dist/types/src/primitives/Flex/Flex.d.ts.map +1 -0
  223. package/dist/types/src/primitives/Flex/Flex.stories.d.ts +8 -0
  224. package/dist/types/src/primitives/Flex/Flex.stories.d.ts.map +1 -0
  225. package/dist/types/src/primitives/Flex/index.d.ts +2 -0
  226. package/dist/types/src/primitives/Flex/index.d.ts.map +1 -0
  227. package/dist/types/src/primitives/Grid/Grid.d.ts +15 -0
  228. package/dist/types/src/primitives/Grid/Grid.d.ts.map +1 -0
  229. package/dist/types/src/primitives/Grid/Grid.stories.d.ts +8 -0
  230. package/dist/types/src/primitives/Grid/Grid.stories.d.ts.map +1 -0
  231. package/dist/types/src/primitives/Grid/index.d.ts +2 -0
  232. package/dist/types/src/primitives/Grid/index.d.ts.map +1 -0
  233. package/dist/types/src/primitives/Panel/Panel.d.ts +26 -0
  234. package/dist/types/src/primitives/Panel/Panel.d.ts.map +1 -0
  235. package/dist/types/src/primitives/Panel/Panel.stories.d.ts +6 -0
  236. package/dist/types/src/primitives/Panel/Panel.stories.d.ts.map +1 -0
  237. package/dist/types/src/primitives/Panel/index.d.ts +2 -0
  238. package/dist/types/src/primitives/Panel/index.d.ts.map +1 -0
  239. package/dist/types/src/primitives/index.d.ts +6 -0
  240. package/dist/types/src/primitives/index.d.ts.map +1 -0
  241. package/dist/types/src/testing/Loading.d.ts +9 -0
  242. package/dist/types/src/testing/Loading.d.ts.map +1 -0
  243. package/dist/types/src/testing/decorators/index.d.ts +2 -1
  244. package/dist/types/src/testing/decorators/index.d.ts.map +1 -1
  245. package/dist/types/src/testing/decorators/withLayout.d.ts +15 -0
  246. package/dist/types/src/testing/decorators/withLayout.d.ts.map +1 -0
  247. package/dist/types/src/testing/decorators/withLayoutVariants.d.ts +12 -0
  248. package/dist/types/src/testing/decorators/withLayoutVariants.d.ts.map +1 -0
  249. package/dist/types/src/testing/decorators/withTheme.d.ts +5 -1
  250. package/dist/types/src/testing/decorators/withTheme.d.ts.map +1 -1
  251. package/dist/types/src/testing/index.d.ts +1 -0
  252. package/dist/types/src/testing/index.d.ts.map +1 -1
  253. package/dist/types/src/translations.d.ts +11 -0
  254. package/dist/types/src/translations.d.ts.map +1 -0
  255. package/dist/types/src/util/index.d.ts +2 -1
  256. package/dist/types/src/util/index.d.ts.map +1 -1
  257. package/dist/types/src/util/usePx.d.ts +8 -0
  258. package/dist/types/src/util/usePx.d.ts.map +1 -0
  259. package/dist/types/tsconfig.tsbuildinfo +1 -1
  260. package/package.json +43 -31
  261. package/src/components/Avatars/Avatar.stories.tsx +24 -16
  262. package/src/components/Avatars/Avatar.tsx +9 -16
  263. package/src/components/Avatars/AvatarGroup.stories.tsx +12 -8
  264. package/src/components/Breadcrumb/Breadcrumb.stories.tsx +20 -15
  265. package/src/components/Breadcrumb/Breadcrumb.tsx +12 -38
  266. package/src/components/{Buttons → Button}/Button.stories.tsx +10 -11
  267. package/src/components/{Buttons → Button}/Button.tsx +9 -15
  268. package/src/components/{Buttons → Button}/IconButton.stories.tsx +15 -12
  269. package/src/components/{Buttons → Button}/IconButton.tsx +22 -16
  270. package/src/components/Button/Toggle.stories.tsx +37 -0
  271. package/src/components/{Buttons → Button}/Toggle.tsx +4 -4
  272. package/src/components/{Buttons → Button}/ToggleGroup.stories.tsx +12 -9
  273. package/src/components/Button/ToggleGroup.tsx +50 -0
  274. package/src/components/Card/Card.stories.tsx +151 -0
  275. package/src/components/Card/Card.tsx +390 -0
  276. package/src/components/Card/index.ts +5 -0
  277. package/src/components/Clipboard/ClipboardProvider.tsx +1 -1
  278. package/src/components/Clipboard/CopyButton.tsx +9 -8
  279. package/src/components/DensityProvider/DensityProvider.tsx +2 -2
  280. package/src/components/Dialog/AlertDialog.stories.tsx +69 -0
  281. package/src/components/Dialog/AlertDialog.tsx +255 -0
  282. package/src/components/Dialog/Dialog.stories.tsx +122 -0
  283. package/src/components/Dialog/Dialog.tsx +275 -0
  284. package/src/components/ElevationProvider/ElevationProvider.tsx +2 -2
  285. package/src/components/ErrorFallback/ErrorFallback.stories.tsx +50 -0
  286. package/src/components/ErrorFallback/ErrorFallback.tsx +70 -0
  287. package/src/components/ErrorFallback/ErrorStack.tsx +80 -0
  288. package/src/components/ErrorFallback/ThrowError.tsx +37 -0
  289. package/src/components/ErrorFallback/index.ts +9 -0
  290. package/src/components/Icon/Icon.stories.tsx +113 -0
  291. package/src/components/Icon/Icon.tsx +3 -2
  292. package/src/components/Image/Image.stories.tsx +86 -0
  293. package/src/components/Image/Image.tsx +223 -0
  294. package/src/components/Image/index.ts +5 -0
  295. package/src/components/Input/Input.stories.tsx +28 -49
  296. package/src/components/Input/Input.tsx +49 -85
  297. package/src/components/Link/Link.stories.tsx +12 -8
  298. package/src/components/Link/Link.tsx +2 -2
  299. package/src/components/{Lists → List}/List.stories.tsx +44 -45
  300. package/src/components/{Lists → List}/List.tsx +27 -28
  301. package/src/components/{Lists → List}/ListDropIndicator.tsx +7 -7
  302. package/src/components/{Lists → List}/Tree.stories.tsx +15 -12
  303. package/src/components/{Lists → List}/Tree.tsx +4 -3
  304. package/src/components/{Lists → List}/TreeDropIndicator.tsx +7 -7
  305. package/src/components/{Lists → List}/Treegrid.stories.tsx +15 -9
  306. package/src/components/{Lists → List}/Treegrid.tsx +67 -31
  307. package/src/components/Main/Main.stories.tsx +53 -27
  308. package/src/components/Main/Main.tsx +177 -105
  309. package/src/components/{Menus → Menu}/ContextMenu.stories.tsx +13 -10
  310. package/src/components/{Menus → Menu}/ContextMenu.tsx +10 -33
  311. package/src/components/{Menus → Menu}/DropdownMenu.stories.tsx +14 -11
  312. package/src/components/{Menus → Menu}/DropdownMenu.tsx +155 -118
  313. package/src/components/Message/Message.stories.tsx +35 -16
  314. package/src/components/Message/Message.tsx +46 -33
  315. package/src/components/Popover/Popover.stories.tsx +16 -13
  316. package/src/components/Popover/Popover.tsx +123 -101
  317. package/src/components/ScrollArea/ScrollArea.stories.tsx +163 -34
  318. package/src/components/ScrollArea/ScrollArea.tsx +84 -82
  319. package/src/components/ScrollArea/index.ts +1 -1
  320. package/src/components/ScrollContainer/ScrollContainer.stories.tsx +89 -0
  321. package/src/components/ScrollContainer/ScrollContainer.tsx +238 -0
  322. package/src/components/ScrollContainer/index.ts +5 -0
  323. package/src/components/Select/Select.stories.tsx +15 -12
  324. package/src/components/Select/Select.tsx +16 -31
  325. package/src/components/Separator/Separator.tsx +5 -8
  326. package/src/components/Skeleton/Skeleton.stories.tsx +52 -0
  327. package/src/components/Skeleton/Skeleton.tsx +26 -0
  328. package/src/components/Skeleton/index.ts +5 -0
  329. package/src/components/Splitter/Splitter.stories.tsx +83 -0
  330. package/src/components/Splitter/Splitter.tsx +126 -0
  331. package/src/components/Splitter/index.ts +5 -0
  332. package/src/components/Status/Status.stories.tsx +30 -23
  333. package/src/components/Status/Status.tsx +2 -2
  334. package/src/components/Tag/Tag.stories.tsx +17 -13
  335. package/src/components/Tag/Tag.tsx +3 -8
  336. package/src/components/ThemeProvider/ThemeProvider.stories.tsx +32 -0
  337. package/src/components/ThemeProvider/ThemeProvider.tsx +7 -7
  338. package/src/components/ThemeProvider/TranslationsProvider.tsx +3 -18
  339. package/src/components/ThemeProvider/index.ts +3 -3
  340. package/src/components/Toast/Toast.stories.tsx +14 -11
  341. package/src/components/Toast/Toast.tsx +23 -42
  342. package/src/components/Toolbar/Toolbar.stories.tsx +16 -14
  343. package/src/components/Toolbar/Toolbar.tsx +183 -11
  344. package/src/components/Tooltip/Tooltip.stories.tsx +31 -25
  345. package/src/components/Tooltip/Tooltip.tsx +44 -41
  346. package/src/components/index.ts +14 -9
  347. package/src/exemplars/generics.stories.tsx +49 -0
  348. package/src/exemplars/slot.stories.tsx +107 -0
  349. package/src/exemplars/tabster.stories.tsx +127 -0
  350. package/src/exemplars/virtualizer.stories.tsx +137 -0
  351. package/src/hooks/index.ts +1 -0
  352. package/src/hooks/useDensityContext.ts +1 -1
  353. package/src/hooks/useElevationContext.ts +1 -1
  354. package/src/hooks/useSafeArea.ts +3 -2
  355. package/src/hooks/useVisualViewport.ts +4 -4
  356. package/src/index.ts +2 -1
  357. package/src/playground/Controls.stories.tsx +12 -15
  358. package/src/playground/Custom.stories.tsx +16 -27
  359. package/src/playground/Typography.stories.tsx +11 -9
  360. package/src/primitives/Column/Column.stories.tsx +78 -0
  361. package/src/primitives/Column/Column.tsx +133 -0
  362. package/src/primitives/Column/index.ts +5 -0
  363. package/src/primitives/Container/Container.stories.tsx +30 -0
  364. package/src/primitives/Container/Container.tsx +22 -0
  365. package/src/primitives/Container/index.ts +5 -0
  366. package/src/primitives/Flex/Flex.stories.tsx +58 -0
  367. package/src/primitives/Flex/Flex.tsx +29 -0
  368. package/src/primitives/Flex/index.ts +5 -0
  369. package/src/primitives/Grid/Grid.stories.tsx +57 -0
  370. package/src/primitives/Grid/Grid.tsx +35 -0
  371. package/src/primitives/Grid/index.ts +5 -0
  372. package/src/primitives/Panel/Panel.stories.tsx +67 -0
  373. package/src/primitives/Panel/Panel.tsx +119 -0
  374. package/src/primitives/Panel/index.ts +5 -0
  375. package/src/primitives/index.ts +9 -0
  376. package/src/testing/Loading.tsx +26 -0
  377. package/src/testing/decorators/index.ts +2 -1
  378. package/src/testing/decorators/withLayout.tsx +77 -0
  379. package/src/testing/decorators/withLayoutVariants.tsx +48 -0
  380. package/src/testing/decorators/withTheme.tsx +34 -0
  381. package/src/testing/index.ts +2 -0
  382. package/src/translations.ts +19 -0
  383. package/src/util/index.ts +3 -1
  384. package/src/util/usePx.ts +61 -0
  385. package/dist/lib/browser/chunk-2COVUP44.mjs +0 -4373
  386. package/dist/lib/browser/chunk-2COVUP44.mjs.map +0 -7
  387. package/dist/lib/node-esm/chunk-GHXHND5V.mjs +0 -4375
  388. package/dist/lib/node-esm/chunk-GHXHND5V.mjs.map +0 -7
  389. package/dist/types/src/components/AnchoredOverflow/AnchoredOverflow.d.ts +0 -15
  390. package/dist/types/src/components/AnchoredOverflow/AnchoredOverflow.d.ts.map +0 -1
  391. package/dist/types/src/components/AnchoredOverflow/index.d.ts +0 -2
  392. package/dist/types/src/components/AnchoredOverflow/index.d.ts.map +0 -1
  393. package/dist/types/src/components/Buttons/Button.d.ts.map +0 -1
  394. package/dist/types/src/components/Buttons/Button.stories.d.ts +0 -12
  395. package/dist/types/src/components/Buttons/Button.stories.d.ts.map +0 -1
  396. package/dist/types/src/components/Buttons/IconButton.d.ts.map +0 -1
  397. package/dist/types/src/components/Buttons/IconButton.stories.d.ts +0 -22
  398. package/dist/types/src/components/Buttons/IconButton.stories.d.ts.map +0 -1
  399. package/dist/types/src/components/Buttons/Toggle.d.ts.map +0 -1
  400. package/dist/types/src/components/Buttons/Toggle.stories.d.ts +0 -19
  401. package/dist/types/src/components/Buttons/Toggle.stories.d.ts.map +0 -1
  402. package/dist/types/src/components/Buttons/ToggleGroup.d.ts +0 -28
  403. package/dist/types/src/components/Buttons/ToggleGroup.d.ts.map +0 -1
  404. package/dist/types/src/components/Buttons/ToggleGroup.stories.d.ts +0 -39
  405. package/dist/types/src/components/Buttons/ToggleGroup.stories.d.ts.map +0 -1
  406. package/dist/types/src/components/Buttons/index.d.ts.map +0 -1
  407. package/dist/types/src/components/Dialogs/AlertDialog.d.ts +0 -31
  408. package/dist/types/src/components/Dialogs/AlertDialog.d.ts.map +0 -1
  409. package/dist/types/src/components/Dialogs/AlertDialog.stories.d.ts +0 -43
  410. package/dist/types/src/components/Dialogs/AlertDialog.stories.d.ts.map +0 -1
  411. package/dist/types/src/components/Dialogs/Dialog.d.ts +0 -31
  412. package/dist/types/src/components/Dialogs/Dialog.d.ts.map +0 -1
  413. package/dist/types/src/components/Dialogs/Dialog.stories.d.ts +0 -48
  414. package/dist/types/src/components/Dialogs/Dialog.stories.d.ts.map +0 -1
  415. package/dist/types/src/components/Dialogs/index.d.ts.map +0 -1
  416. package/dist/types/src/components/Lists/List.d.ts.map +0 -1
  417. package/dist/types/src/components/Lists/List.stories.d.ts +0 -37
  418. package/dist/types/src/components/Lists/List.stories.d.ts.map +0 -1
  419. package/dist/types/src/components/Lists/ListDropIndicator.d.ts.map +0 -1
  420. package/dist/types/src/components/Lists/Tree.d.ts.map +0 -1
  421. package/dist/types/src/components/Lists/Tree.stories.d.ts +0 -41
  422. package/dist/types/src/components/Lists/Tree.stories.d.ts.map +0 -1
  423. package/dist/types/src/components/Lists/TreeDropIndicator.d.ts.map +0 -1
  424. package/dist/types/src/components/Lists/Treegrid.stories.d.ts +0 -10
  425. package/dist/types/src/components/Lists/Treegrid.stories.d.ts.map +0 -1
  426. package/dist/types/src/components/Lists/index.d.ts.map +0 -1
  427. package/dist/types/src/components/Menus/ContextMenu.d.ts.map +0 -1
  428. package/dist/types/src/components/Menus/ContextMenu.stories.d.ts +0 -50
  429. package/dist/types/src/components/Menus/ContextMenu.stories.d.ts.map +0 -1
  430. package/dist/types/src/components/Menus/DropdownMenu.d.ts +0 -112
  431. package/dist/types/src/components/Menus/DropdownMenu.d.ts.map +0 -1
  432. package/dist/types/src/components/Menus/DropdownMenu.stories.d.ts +0 -50
  433. package/dist/types/src/components/Menus/DropdownMenu.stories.d.ts.map +0 -1
  434. package/dist/types/src/components/Menus/index.d.ts.map +0 -1
  435. package/dist/types/src/testing/decorators/withSurfaceVariantsLayout.d.ts +0 -12
  436. package/dist/types/src/testing/decorators/withSurfaceVariantsLayout.d.ts.map +0 -1
  437. package/dist/types/src/util/ThemedClassName.d.ts +0 -5
  438. package/dist/types/src/util/ThemedClassName.d.ts.map +0 -1
  439. package/src/components/AnchoredOverflow/AnchoredOverflow.tsx +0 -59
  440. package/src/components/AnchoredOverflow/index.ts +0 -5
  441. package/src/components/Buttons/Toggle.stories.tsx +0 -33
  442. package/src/components/Buttons/ToggleGroup.tsx +0 -41
  443. package/src/components/Dialogs/AlertDialog.stories.tsx +0 -66
  444. package/src/components/Dialogs/AlertDialog.tsx +0 -172
  445. package/src/components/Dialogs/Dialog.stories.tsx +0 -65
  446. package/src/components/Dialogs/Dialog.tsx +0 -159
  447. package/src/testing/decorators/withSurfaceVariantsLayout.tsx +0 -51
  448. package/src/testing/decorators/withTheme.ts +0 -25
  449. package/src/util/ThemedClassName.ts +0 -7
  450. /package/dist/types/src/components/{Buttons → Button}/index.d.ts +0 -0
  451. /package/dist/types/src/components/{Dialogs → Dialog}/index.d.ts +0 -0
  452. /package/dist/types/src/components/{Lists → List}/ListDropIndicator.d.ts +0 -0
  453. /package/dist/types/src/components/{Lists → List}/TreeDropIndicator.d.ts +0 -0
  454. /package/dist/types/src/components/{Lists → List}/index.d.ts +0 -0
  455. /package/dist/types/src/components/{Menus → Menu}/index.d.ts +0 -0
  456. /package/src/components/{Buttons → Button}/index.ts +0 -0
  457. /package/src/components/{Dialogs → Dialog}/index.ts +0 -0
  458. /package/src/components/{Lists → List}/index.ts +0 -0
  459. /package/src/components/{Menus → Menu}/index.ts +0 -0
@@ -0,0 +1,238 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { createContext } from '@radix-ui/react-context';
6
+ import React, {
7
+ type HTMLAttributes,
8
+ type PropsWithChildren,
9
+ forwardRef,
10
+ useCallback,
11
+ useEffect,
12
+ useImperativeHandle,
13
+ useMemo,
14
+ useRef,
15
+ useState,
16
+ } from 'react';
17
+
18
+ import { addEventListener, combine } from '@dxos/async';
19
+ import { invariant } from '@dxos/invariant';
20
+ import { useForwardedRef } from '@dxos/react-hooks';
21
+ import { mx } from '@dxos/ui-theme';
22
+
23
+ import { type ThemedClassName } from '../../util';
24
+ import { IconButton } from '../Button';
25
+ import { ScrollArea } from '../ScrollArea';
26
+
27
+ const isBottom = (el: HTMLElement | null) => {
28
+ return !!(el && el.scrollHeight - el.scrollTop === el.clientHeight);
29
+ };
30
+
31
+ export interface ScrollController {
32
+ viewport: HTMLDivElement | null;
33
+ scrollToTop: (behavior?: ScrollBehavior) => void;
34
+ scrollToBottom: (behavior?: ScrollBehavior) => void;
35
+ }
36
+
37
+ type ScrollContainerContextValue = {
38
+ scrollToBottom: (behavior?: ScrollBehavior) => void;
39
+ controller?: ScrollController;
40
+ pinned?: boolean;
41
+ };
42
+
43
+ const [ScrollContainerProvider, useScrollContainerContext] =
44
+ createContext<ScrollContainerContextValue>('ScrollContainer');
45
+
46
+ //
47
+ // Root
48
+ //
49
+
50
+ type RootProps = ThemedClassName<
51
+ PropsWithChildren<{
52
+ pin?: boolean;
53
+ fade?: boolean;
54
+ behavior?: ScrollBehavior;
55
+ }>
56
+ >;
57
+
58
+ /**
59
+ * Scroll container that automatically scrolls to the bottom when new content is added.
60
+ */
61
+ const Root = forwardRef<ScrollController, RootProps>(
62
+ ({ children, classNames, pin, fade, behavior: behaviorProp = 'smooth' }, forwardedRef) => {
63
+ const scrollerRef = useRef<HTMLDivElement>(null);
64
+ const autoScrollRef = useRef(false);
65
+ const [overflow, setOverflow] = useState(false);
66
+ const [pinned, setPinned] = useState(pin);
67
+
68
+ const timeoutRef = useRef<NodeJS.Timeout>(undefined);
69
+ const scrollToBottom = useCallback((behavior: ScrollBehavior = behaviorProp) => {
70
+ if (scrollerRef.current) {
71
+ // Temporarily hide scrollbar to prevent flickering.
72
+ autoScrollRef.current = true;
73
+ scrollerRef.current.classList.add('scrollbar-none');
74
+ scrollerRef.current.scrollTo({
75
+ top: scrollerRef.current.scrollHeight,
76
+ behavior,
77
+ });
78
+
79
+ clearTimeout(timeoutRef.current);
80
+ if (behavior !== 'instant') {
81
+ timeoutRef.current = setTimeout(() => {
82
+ scrollerRef.current?.classList.remove('scrollbar-none');
83
+ autoScrollRef.current = false;
84
+ }, 500);
85
+ }
86
+
87
+ setPinned(true);
88
+ }
89
+ }, []);
90
+
91
+ const controller = useMemo(
92
+ () => ({
93
+ viewport: scrollerRef.current,
94
+ scrollToTop: () => {
95
+ invariant(scrollerRef.current);
96
+ scrollerRef.current.scrollTo({ top: 0, behavior: 'smooth' });
97
+ setPinned(false);
98
+ },
99
+ scrollToBottom: () => {
100
+ scrollToBottom('smooth');
101
+ },
102
+ }),
103
+ [scrollToBottom, scrollerRef.current],
104
+ );
105
+
106
+ // Scroll controller imperative ref.
107
+ useImperativeHandle(forwardedRef, () => controller, [controller]);
108
+
109
+ // Listen for scroll events.
110
+ useEffect(() => {
111
+ if (!scrollerRef.current) {
112
+ return;
113
+ }
114
+
115
+ return combine(
116
+ // Check if user scrolls.
117
+ addEventListener(scrollerRef.current, 'wheel', () => {
118
+ setPinned(isBottom(scrollerRef.current));
119
+ }),
120
+ // Check if scrolls.
121
+ addEventListener(scrollerRef.current, 'scroll', () => {
122
+ setOverflow((scrollerRef.current?.scrollTop ?? 0) > 0);
123
+ }),
124
+ );
125
+ }, []);
126
+
127
+ return (
128
+ <ScrollContainerProvider pinned={pinned} controller={controller} scrollToBottom={scrollToBottom}>
129
+ <div className='relative grid dx-container overflow-hidden'>
130
+ {fade && (
131
+ <div
132
+ role='none'
133
+ data-visible={overflow}
134
+ className={mx(
135
+ // NOTE: Gradients may not be visible with dark reader extensions.
136
+ 'z-10 absolute top-0 inset-x-0 h-24 w-full',
137
+ 'opacity-0 duration-200 transition-opacity data-[visible="true"]:opacity-100',
138
+ 'bg-gradient-to-b from-(--surface-bg) to-transparent pointer-events-none',
139
+ )}
140
+ />
141
+ )}
142
+ <ScrollArea.Root classNames={mx('min-h-0', classNames)} thin>
143
+ <ScrollArea.Viewport ref={scrollerRef}>{children}</ScrollArea.Viewport>
144
+ </ScrollArea.Root>
145
+ </div>
146
+ </ScrollContainerProvider>
147
+ );
148
+ },
149
+ );
150
+
151
+ Root.displayName = 'ScrollContainer.Root';
152
+
153
+ //
154
+ // Viewport
155
+ //
156
+
157
+ const VIEWPORT_NAME = 'ScrollContainer.Viewport';
158
+
159
+ type ViewportProps = ThemedClassName<PropsWithChildren<Omit<HTMLAttributes<HTMLDivElement>, 'className'>>>;
160
+
161
+ const Viewport = forwardRef<HTMLDivElement, ViewportProps>(({ classNames, children, ...props }, forwardedRef) => {
162
+ const contentRef = useForwardedRef(forwardedRef);
163
+ const { pinned, scrollToBottom } = useScrollContainerContext(VIEWPORT_NAME);
164
+
165
+ useEffect(() => {
166
+ if (!pinned || !contentRef.current) {
167
+ return;
168
+ }
169
+
170
+ // Scroll instantly otherwise it might move while we're scrolling.
171
+ scrollToBottom();
172
+
173
+ // Setup resize observer to detect content changes.
174
+ const resizeObserver = new ResizeObserver(() => scrollToBottom());
175
+ resizeObserver.observe(contentRef.current);
176
+ return () => resizeObserver.disconnect();
177
+ }, [pinned, scrollToBottom]);
178
+
179
+ return (
180
+ <div className={mx('w-full', classNames)} {...props} ref={contentRef}>
181
+ {children}
182
+ </div>
183
+ );
184
+ });
185
+
186
+ Viewport.displayName = VIEWPORT_NAME;
187
+
188
+ //
189
+ // ScrollDownButton
190
+ //
191
+
192
+ const SCROLL_DOWN_BUTTON_NAME = 'ScrollContainer.ScrollDownButton';
193
+
194
+ type ScrollDownButtonProps = ThemedClassName;
195
+
196
+ const ScrollDownButton = ({ classNames }: ScrollDownButtonProps) => {
197
+ const { pinned, scrollToBottom } = useScrollContainerContext(SCROLL_DOWN_BUTTON_NAME);
198
+
199
+ return (
200
+ <div
201
+ role='none'
202
+ className={mx(
203
+ 'absolute bottom-2 right-4 opacity-100 transition-opacity duration-300',
204
+ pinned && 'opacity-0',
205
+ classNames,
206
+ )}
207
+ >
208
+ <IconButton
209
+ variant='primary'
210
+ icon='ph--arrow-down--regular'
211
+ iconOnly
212
+ size={4}
213
+ label='Scroll down'
214
+ onClick={() => scrollToBottom()}
215
+ />
216
+ </div>
217
+ );
218
+ };
219
+
220
+ ScrollDownButton.displayName = SCROLL_DOWN_BUTTON_NAME;
221
+
222
+ //
223
+ // ScrollContainer
224
+ //
225
+
226
+ export { useScrollContainerContext };
227
+
228
+ export const ScrollContainer = {
229
+ Root,
230
+ Viewport,
231
+ ScrollDownButton,
232
+ };
233
+
234
+ export type {
235
+ RootProps as ScrollContainerRootProps,
236
+ ViewportProps as ScrollContainerViewportProps,
237
+ ScrollDownButtonProps as ScrollContainerScrollDownButtonProps,
238
+ };
@@ -0,0 +1,5 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ export * from './ScrollContainer';
@@ -2,15 +2,15 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import '@dxos-theme';
6
-
7
- import { type StoryObj } from '@storybook/react-vite';
5
+ import { type Meta, type StoryObj } from '@storybook/react-vite';
8
6
  import React, { useState } from 'react';
9
7
 
10
8
  import { faker } from '@dxos/random';
11
9
 
10
+ import { withTheme } from '../../testing';
11
+ import { withLayoutVariants } from '../../testing';
12
+
12
13
  import { Select } from './Select';
13
- import { withSurfaceVariantsLayout, withTheme } from '../../testing';
14
14
 
15
15
  faker.seed(1234);
16
16
 
@@ -41,15 +41,18 @@ const DefaultStory = ({ items = [] }: StoryProps) => {
41
41
  );
42
42
  };
43
43
 
44
- export const Default: StoryObj<StoryProps> = {
44
+ const meta = {
45
+ title: 'ui/react-ui-core/components/Select',
46
+ render: DefaultStory,
47
+ decorators: [withTheme(), withLayoutVariants()],
48
+ } satisfies Meta<typeof DefaultStory>;
49
+
50
+ export default meta;
51
+
52
+ type Story = StoryObj<typeof meta>;
53
+
54
+ export const Default: Story = {
45
55
  args: {
46
56
  items: Array.from({ length: 16 }).map((_, i) => ({ id: `item-${i}`, text: faker.lorem.word() })),
47
57
  },
48
58
  };
49
-
50
- export default {
51
- title: 'ui/react-ui-core/Select',
52
- render: DefaultStory,
53
- decorators: [withSurfaceVariantsLayout(), withTheme],
54
- parameters: { chromatic: { disableSnapshot: false } },
55
- };
@@ -8,7 +8,7 @@ import React, { forwardRef } from 'react';
8
8
  import { useElevationContext, useThemeContext } from '../../hooks';
9
9
  import { useSafeCollisionPadding } from '../../hooks/useSafeCollisionPadding';
10
10
  import { type ThemedClassName } from '../../util';
11
- import { Button, type ButtonProps } from '../Buttons';
11
+ import { Button, type ButtonProps } from '../Button';
12
12
  import { Icon } from '../Icon';
13
13
 
14
14
  type SelectRootProps = SelectPrimitive.SelectProps;
@@ -35,14 +35,13 @@ type SelectTriggerButtonProps = Omit<ButtonProps, 'children'> & Pick<SelectValue
35
35
 
36
36
  const SelectTriggerButton = forwardRef<HTMLButtonElement, SelectTriggerButtonProps>(
37
37
  ({ children, placeholder, ...props }, forwardedRef) => {
38
- const { tx } = useThemeContext();
39
38
  return (
40
39
  <SelectPrimitive.Trigger asChild ref={forwardedRef}>
41
40
  <Button {...props}>
42
41
  <SelectPrimitive.Value placeholder={placeholder}>{children}</SelectPrimitive.Value>
43
42
  <span className='w-1 flex-1' />
44
43
  <SelectPrimitive.Icon asChild>
45
- <Icon icon='ph--caret-down--bold' classNames={tx('select.triggerIcon', 'select__trigger__icon', {})} />
44
+ <Icon size={3} icon='ph--caret-down--bold' />
46
45
  </SelectPrimitive.Icon>
47
46
  </Button>
48
47
  </SelectPrimitive.Trigger>
@@ -60,8 +59,9 @@ const SelectContent = forwardRef<HTMLDivElement, SelectContentProps>(
60
59
  return (
61
60
  <SelectPrimitive.Content
62
61
  {...props}
62
+ data-arrow-keys='up down'
63
63
  collisionPadding={safeCollisionPadding}
64
- className={tx('select.content', 'select__content', { elevation }, classNames)}
64
+ className={tx('select.content', { elevation }, classNames)}
65
65
  position='popper'
66
66
  ref={forwardedRef}
67
67
  >
@@ -79,10 +79,10 @@ const SelectScrollUpButton = forwardRef<HTMLDivElement, SelectScrollUpButtonProp
79
79
  return (
80
80
  <SelectPrimitive.SelectScrollUpButton
81
81
  {...props}
82
- className={tx('select.scrollButton', 'select__scroll-button--up', {}, classNames)}
82
+ className={tx('select.scrollButton', {}, classNames)}
83
83
  ref={forwardedRef}
84
84
  >
85
- {children ?? <Icon icon='ph--caret-up--bold' />}
85
+ {children ?? <Icon size={3} icon='ph--caret-up--bold' />}
86
86
  </SelectPrimitive.SelectScrollUpButton>
87
87
  );
88
88
  },
@@ -96,10 +96,10 @@ const SelectScrollDownButton = forwardRef<HTMLDivElement, SelectScrollDownButton
96
96
  return (
97
97
  <SelectPrimitive.SelectScrollDownButton
98
98
  {...props}
99
- className={tx('select.scrollButton', 'select__scroll-button--down', {}, classNames)}
99
+ className={tx('select.scrollButton', {}, classNames)}
100
100
  ref={forwardedRef}
101
101
  >
102
- {children ?? <Icon icon='ph--caret-down--bold' />}
102
+ {children ?? <Icon size={3} icon='ph--caret-down--bold' />}
103
103
  </SelectPrimitive.SelectScrollDownButton>
104
104
  );
105
105
  },
@@ -108,14 +108,10 @@ const SelectScrollDownButton = forwardRef<HTMLDivElement, SelectScrollDownButton
108
108
  type SelectViewportProps = ThemedClassName<SelectPrimitive.SelectViewportProps>;
109
109
 
110
110
  const SelectViewport = forwardRef<HTMLDivElement, SelectViewportProps>(
111
- ({ classNames, asChild, children, ...props }, forwardedRef) => {
111
+ ({ classNames, children, ...props }, forwardedRef) => {
112
112
  const { tx } = useThemeContext();
113
113
  return (
114
- <SelectPrimitive.SelectViewport
115
- {...props}
116
- className={tx('select.viewport', 'select__viewport', {}, classNames)}
117
- ref={forwardedRef}
118
- >
114
+ <SelectPrimitive.SelectViewport {...props} className={tx('select.viewport', {}, classNames)} ref={forwardedRef}>
119
115
  {children}
120
116
  </SelectPrimitive.SelectViewport>
121
117
  );
@@ -126,7 +122,7 @@ type SelectItemProps = ThemedClassName<SelectPrimitive.SelectItemProps>;
126
122
 
127
123
  const SelectItem = forwardRef<HTMLDivElement, SelectItemProps>(({ classNames, ...props }, forwardedRef) => {
128
124
  const { tx } = useThemeContext();
129
- return <SelectPrimitive.Item {...props} className={tx('select.item', 'option', {}, classNames)} ref={forwardedRef} />;
125
+ return <SelectPrimitive.Item {...props} className={tx('select.item', {}, classNames)} ref={forwardedRef} />;
130
126
  });
131
127
 
132
128
  type SelectItemTextProps = SelectPrimitive.SelectItemTextProps;
@@ -141,7 +137,7 @@ const SelectItemIndicator = forwardRef<HTMLDivElement, SelectItemIndicatorProps>
141
137
  return (
142
138
  <SelectPrimitive.ItemIndicator
143
139
  {...props}
144
- className={tx('select.itemIndicator', 'option__indicator', {}, classNames)}
140
+ className={tx('select.itemIndicator', {}, classNames)}
145
141
  ref={forwardedRef}
146
142
  >
147
143
  {children}
@@ -152,10 +148,11 @@ const SelectItemIndicator = forwardRef<HTMLDivElement, SelectItemIndicatorProps>
152
148
 
153
149
  type SelectOptionProps = SelectItemProps;
154
150
 
151
+ // TODO(burdon): Option to show icon on left/right.
155
152
  const SelectOption = forwardRef<HTMLDivElement, SelectItemProps>(({ children, classNames, ...props }, forwardedRef) => {
156
153
  const { tx } = useThemeContext();
157
154
  return (
158
- <SelectPrimitive.Item {...props} className={tx('select.item', 'option', {}, classNames)} ref={forwardedRef}>
155
+ <SelectPrimitive.Item {...props} className={tx('select.item', {}, classNames)} ref={forwardedRef}>
159
156
  <SelectPrimitive.ItemText>{children}</SelectPrimitive.ItemText>
160
157
  <span className='grow w-1' />
161
158
  {/* <SelectPrimitive.ItemIndicator className={tx('select.itemIndicator', 'option__indicator', {})}> */}
@@ -177,26 +174,14 @@ type SelectSeparatorProps = ThemedClassName<SelectPrimitive.SelectSeparatorProps
177
174
 
178
175
  const SelectSeparator = forwardRef<HTMLDivElement, SelectSeparatorProps>(({ classNames, ...props }, forwardedRef) => {
179
176
  const { tx } = useThemeContext();
180
- return (
181
- <SelectPrimitive.Separator
182
- {...props}
183
- className={tx('select.separator', 'select__separator', {}, classNames)}
184
- ref={forwardedRef}
185
- />
186
- );
177
+ return <SelectPrimitive.Separator {...props} className={tx('select.separator', {}, classNames)} ref={forwardedRef} />;
187
178
  });
188
179
 
189
180
  type SelectArrowProps = ThemedClassName<SelectPrimitive.SelectArrowProps>;
190
181
 
191
182
  const SelectArrow = forwardRef<SVGSVGElement, SelectArrowProps>(({ classNames, ...props }, forwardedRef) => {
192
183
  const { tx } = useThemeContext();
193
- return (
194
- <SelectPrimitive.Arrow
195
- {...props}
196
- className={tx('select.arrow', 'select__arrow', {}, classNames)}
197
- ref={forwardedRef}
198
- />
199
- );
184
+ return <SelectPrimitive.Arrow {...props} className={tx('select.arrow', {}, classNames)} ref={forwardedRef} />;
200
185
  });
201
186
 
202
187
  export const Select = {
@@ -1,25 +1,22 @@
1
1
  //
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
- import {
5
- Separator as SeparatorPrimitive,
6
- type SeparatorProps as SeparatorPrimitiveProps,
7
- } from '@radix-ui/react-separator';
4
+ import * as SeparatorPrimitive from '@radix-ui/react-separator';
8
5
  import React, { forwardRef } from 'react';
9
6
 
10
7
  import { useThemeContext } from '../../hooks';
11
8
  import { type ThemedClassName } from '../../util';
12
9
 
13
- type SeparatorProps = ThemedClassName<SeparatorPrimitiveProps> & { subdued?: boolean };
10
+ type SeparatorProps = ThemedClassName<SeparatorPrimitive.SeparatorProps> & { subdued?: boolean };
14
11
 
15
12
  const Separator = forwardRef<HTMLDivElement, SeparatorProps>(
16
13
  ({ classNames, orientation = 'horizontal', subdued, ...props }, forwardedRef) => {
17
14
  const { tx } = useThemeContext();
18
15
  return (
19
- <SeparatorPrimitive
20
- orientation={orientation}
16
+ <SeparatorPrimitive.Root
21
17
  {...props}
22
- className={tx('separator.root', 'separator', { orientation, subdued }, classNames)}
18
+ orientation={orientation}
19
+ className={tx('separator.root', { orientation, subdued }, classNames)}
23
20
  ref={forwardedRef}
24
21
  />
25
22
  );
@@ -0,0 +1,52 @@
1
+ //
2
+ // Copyright 2024 DXOS.org
3
+ //
4
+
5
+ import React from 'react';
6
+
7
+ import { withTheme } from '../../testing';
8
+
9
+ import { Skeleton } from './Skeleton';
10
+
11
+ export default {
12
+ title: 'ui/react-ui-core/components/Skeleton',
13
+ component: Skeleton,
14
+ decorators: [withTheme()],
15
+ parameters: {
16
+ layout: 'centered',
17
+ },
18
+ };
19
+
20
+ export const Default = {
21
+ render: () => (
22
+ <div className='flex flex-col gap-4 p-4 border border-separator rounded-xs'>
23
+ <div className='flex w-fit items-center gap-4'>
24
+ <Skeleton classNames='size-10 shrink-0 rounded-full' />
25
+ <div className='grid gap-2'>
26
+ <Skeleton classNames='h-4 w-[150px]' />
27
+ <Skeleton classNames='h-4 w-[100px]' />
28
+ </div>
29
+ </div>
30
+ </div>
31
+ ),
32
+ };
33
+
34
+ export const Card = {
35
+ render: () => (
36
+ <div className='flex flex-col gap-3 w-96 p-4 border border-separator rounded-xs'>
37
+ <div className='flex items-center gap-3'>
38
+ <Skeleton variant='circle' classNames='h-12 w-12 rounded-full' />
39
+ <div className='flex flex-col gap-2 flex-1'>
40
+ <Skeleton classNames='h-4 w-24' />
41
+ <Skeleton classNames='h-3 w-32' />
42
+ </div>
43
+ </div>
44
+ <Skeleton classNames='h-32 w-full rounded-sm' />
45
+ <div className='flex flex-col gap-2'>
46
+ <Skeleton classNames='h-3 w-full' />
47
+ <Skeleton classNames='h-3 w-5/6' />
48
+ <Skeleton classNames='h-3 w-4/6' />
49
+ </div>
50
+ </div>
51
+ ),
52
+ };
@@ -0,0 +1,26 @@
1
+ //
2
+ // Copyright 2024 DXOS.org
3
+ //
4
+
5
+ import React, { type ComponentPropsWithRef, forwardRef } from 'react';
6
+
7
+ import { useThemeContext } from '../../hooks';
8
+ import { type ThemedClassName } from '../../util';
9
+
10
+ type SkeletonProps = ThemedClassName<ComponentPropsWithRef<'div'>> & {
11
+ variant?: 'default' | 'circle' | 'text';
12
+ };
13
+
14
+ /**
15
+ * A skeleton loading component that displays a placeholder while content is loading.
16
+ */
17
+ const Skeleton = forwardRef<HTMLDivElement, SkeletonProps>(
18
+ ({ classNames, variant = 'default', ...props }, forwardedRef) => {
19
+ const { tx } = useThemeContext();
20
+ return <div {...props} className={tx('skeleton.root', { variant }, classNames)} ref={forwardedRef} />;
21
+ },
22
+ );
23
+
24
+ export { Skeleton };
25
+
26
+ export type { SkeletonProps };
@@ -0,0 +1,5 @@
1
+ //
2
+ // Copyright 2024 DXOS.org
3
+ //
4
+
5
+ export * from './Skeleton';
@@ -0,0 +1,83 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ import { type Meta, type StoryObj } from '@storybook/react-vite';
6
+ import React, { type ComponentPropsWithoutRef, forwardRef, useState } from 'react';
7
+
8
+ import { Panel } from '../../primitives';
9
+ import { withLayout, withTheme } from '../../testing';
10
+ import { ScrollArea } from '../ScrollArea';
11
+ import { Toolbar } from '../Toolbar';
12
+
13
+ import { Splitter, type SplitterRootProps } from './Splitter';
14
+
15
+ const PanelContent = forwardRef<HTMLDivElement, ComponentPropsWithoutRef<'div'> & { label: string }>(
16
+ ({ label, ...props }, ref) => (
17
+ <div ref={ref} {...props}>
18
+ <Panel.Root>
19
+ <Panel.Toolbar asChild>
20
+ <Toolbar.Root>{label}</Toolbar.Root>
21
+ </Panel.Toolbar>
22
+ <Panel.Content asChild>
23
+ <ScrollArea.Root orientation='vertical'>
24
+ <ScrollArea.Viewport>
25
+ {Array.from({ length: 100 }).map((_, i) => (
26
+ <div key={i} className='p-1'>
27
+ {label}-{i}
28
+ </div>
29
+ ))}
30
+ </ScrollArea.Viewport>
31
+ </ScrollArea.Root>
32
+ </Panel.Content>
33
+ </Panel.Root>
34
+ </div>
35
+ ),
36
+ );
37
+
38
+ const DefaultStory = (props: SplitterRootProps) => {
39
+ const [mode, setMode] = useState(props.mode ?? 'both');
40
+
41
+ return (
42
+ <Panel.Root>
43
+ <Panel.Toolbar asChild>
44
+ <Toolbar.Root>
45
+ <Toolbar.Button onClick={() => setMode('upper')}>A</Toolbar.Button>
46
+ <Toolbar.Button onClick={() => setMode('both')}>A + B</Toolbar.Button>
47
+ <Toolbar.Button onClick={() => setMode('lower')}>B</Toolbar.Button>
48
+ </Toolbar.Root>
49
+ </Panel.Toolbar>
50
+ <Panel.Content asChild>
51
+ <Splitter.Root mode={mode} ratio={props.ratio}>
52
+ <Splitter.Panel asChild position='upper'>
53
+ <PanelContent label='A' />
54
+ </Splitter.Panel>
55
+ <Splitter.Panel asChild position='lower'>
56
+ <PanelContent label='B' />
57
+ </Splitter.Panel>
58
+ </Splitter.Root>
59
+ </Panel.Content>
60
+ </Panel.Root>
61
+ );
62
+ };
63
+
64
+ const meta: Meta<SplitterRootProps> = {
65
+ title: 'ui/react-ui-core/components/Splitter',
66
+ component: Splitter.Root,
67
+ render: DefaultStory,
68
+ decorators: [withTheme(), withLayout({ layout: 'column' })],
69
+ parameters: {
70
+ layout: 'fullscreen',
71
+ },
72
+ };
73
+
74
+ export default meta;
75
+
76
+ type Story = StoryObj<SplitterRootProps>;
77
+
78
+ export const Default: Story = {
79
+ args: {
80
+ mode: 'both',
81
+ ratio: 0.5,
82
+ },
83
+ };