@dxos/react-ui 0.8.4-main.406dc2a → 0.8.4-main.422d1c7879

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 (443) hide show
  1. package/dist/lib/browser/chunk-OCVRIJCH.mjs +848 -0
  2. package/dist/lib/browser/chunk-OCVRIJCH.mjs.map +7 -0
  3. package/dist/lib/browser/index.mjs +4120 -65
  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 +91 -67
  7. package/dist/lib/browser/testing/index.mjs.map +4 -4
  8. package/dist/lib/node-esm/chunk-QUD5P3RU.mjs +850 -0
  9. package/dist/lib/node-esm/chunk-QUD5P3RU.mjs.map +7 -0
  10. package/dist/lib/node-esm/index.mjs +4120 -65
  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 +91 -67
  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.map +1 -1
  18. package/dist/types/src/components/Avatars/AvatarGroup.stories.d.ts.map +1 -1
  19. package/dist/types/src/components/Breadcrumb/Breadcrumb.d.ts.map +1 -1
  20. package/dist/types/src/components/Breadcrumb/Breadcrumb.stories.d.ts.map +1 -1
  21. package/dist/types/src/components/{Buttons → Button}/Button.d.ts +3 -3
  22. package/dist/types/src/components/Button/Button.d.ts.map +1 -0
  23. package/dist/types/src/components/Button/Button.stories.d.ts.map +1 -0
  24. package/dist/types/src/components/{Buttons → Button}/IconButton.d.ts +2 -2
  25. package/dist/types/src/components/Button/IconButton.d.ts.map +1 -0
  26. package/dist/types/src/components/{Buttons → Button}/IconButton.stories.d.ts +3 -0
  27. package/dist/types/src/components/Button/IconButton.stories.d.ts.map +1 -0
  28. package/dist/types/src/components/{Buttons → Button}/Toggle.d.ts +2 -2
  29. package/dist/types/src/components/Button/Toggle.d.ts.map +1 -0
  30. package/dist/types/src/components/Button/Toggle.stories.d.ts +16 -0
  31. package/dist/types/src/components/Button/Toggle.stories.d.ts.map +1 -0
  32. package/dist/types/src/components/Button/ToggleGroup.d.ts +27 -0
  33. package/dist/types/src/components/Button/ToggleGroup.d.ts.map +1 -0
  34. package/dist/types/src/components/{Buttons → Button}/ToggleGroup.stories.d.ts +4 -4
  35. package/dist/types/src/components/Button/ToggleGroup.stories.d.ts.map +1 -0
  36. package/dist/types/src/components/Button/index.d.ts.map +1 -0
  37. package/dist/types/src/components/Card/Card.d.ts +127 -0
  38. package/dist/types/src/components/Card/Card.d.ts.map +1 -0
  39. package/dist/types/src/components/Card/Card.stories.d.ts +21 -0
  40. package/dist/types/src/components/Card/Card.stories.d.ts.map +1 -0
  41. package/dist/types/src/components/Card/index.d.ts +2 -0
  42. package/dist/types/src/components/Card/index.d.ts.map +1 -0
  43. package/dist/types/src/components/Clipboard/CopyButton.d.ts +1 -1
  44. package/dist/types/src/components/Clipboard/CopyButton.d.ts.map +1 -1
  45. package/dist/types/src/components/Clipboard/index.d.ts +10 -1
  46. package/dist/types/src/components/Clipboard/index.d.ts.map +1 -1
  47. package/dist/types/src/components/DensityProvider/DensityProvider.d.ts +1 -1
  48. package/dist/types/src/components/DensityProvider/DensityProvider.d.ts.map +1 -1
  49. package/dist/types/src/components/Dialog/AlertDialog.d.ts +51 -0
  50. package/dist/types/src/components/Dialog/AlertDialog.d.ts.map +1 -0
  51. package/dist/types/src/components/Dialog/AlertDialog.stories.d.ts.map +1 -0
  52. package/dist/types/src/components/Dialog/Dialog.d.ts +64 -0
  53. package/dist/types/src/components/Dialog/Dialog.d.ts.map +1 -0
  54. package/dist/types/src/components/Dialog/Dialog.stories.d.ts +25 -0
  55. package/dist/types/src/components/Dialog/Dialog.stories.d.ts.map +1 -0
  56. package/dist/types/src/components/Dialog/index.d.ts.map +1 -0
  57. package/dist/types/src/components/ElevationProvider/ElevationProvider.d.ts +1 -1
  58. package/dist/types/src/components/ElevationProvider/ElevationProvider.d.ts.map +1 -1
  59. package/dist/types/src/components/ErrorFallback/ErrorFallback.d.ts +11 -0
  60. package/dist/types/src/components/ErrorFallback/ErrorFallback.d.ts.map +1 -0
  61. package/dist/types/src/components/ErrorFallback/ErrorFallback.stories.d.ts +7 -0
  62. package/dist/types/src/components/ErrorFallback/ErrorFallback.stories.d.ts.map +1 -0
  63. package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts +19 -0
  64. package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts.map +1 -0
  65. package/dist/types/src/components/ErrorFallback/ThrowError.d.ts +9 -0
  66. package/dist/types/src/components/ErrorFallback/ThrowError.d.ts.map +1 -0
  67. package/dist/types/src/components/ErrorFallback/index.d.ts +5 -0
  68. package/dist/types/src/components/ErrorFallback/index.d.ts.map +1 -0
  69. package/dist/types/src/components/Focus/Focus.d.ts +36 -0
  70. package/dist/types/src/components/Focus/Focus.d.ts.map +1 -0
  71. package/dist/types/src/components/Focus/Focus.stories.d.ts +9 -0
  72. package/dist/types/src/components/Focus/Focus.stories.d.ts.map +1 -0
  73. package/dist/types/src/components/Focus/index.d.ts +2 -0
  74. package/dist/types/src/components/Focus/index.d.ts.map +1 -0
  75. package/dist/types/src/components/Icon/Icon.d.ts +4 -1
  76. package/dist/types/src/components/Icon/Icon.d.ts.map +1 -1
  77. package/dist/types/src/components/Icon/Icon.stories.d.ts +25 -0
  78. package/dist/types/src/components/Icon/Icon.stories.d.ts.map +1 -0
  79. package/dist/types/src/components/Image/Image.d.ts +15 -0
  80. package/dist/types/src/components/Image/Image.d.ts.map +1 -0
  81. package/dist/types/src/components/Image/Image.stories.d.ts +34 -0
  82. package/dist/types/src/components/Image/Image.stories.d.ts.map +1 -0
  83. package/dist/types/src/components/Image/index.d.ts +2 -0
  84. package/dist/types/src/components/Image/index.d.ts.map +1 -0
  85. package/dist/types/src/components/Input/Input.d.ts +7 -7
  86. package/dist/types/src/components/Input/Input.d.ts.map +1 -1
  87. package/dist/types/src/components/Input/Input.stories.d.ts +8 -8
  88. package/dist/types/src/components/Input/Input.stories.d.ts.map +1 -1
  89. package/dist/types/src/components/Link/Link.stories.d.ts.map +1 -1
  90. package/dist/types/src/components/{Lists → List}/List.d.ts +6 -4
  91. package/dist/types/src/components/List/List.d.ts.map +1 -0
  92. package/dist/types/src/components/{Lists → List}/List.stories.d.ts +3 -1
  93. package/dist/types/src/components/List/List.stories.d.ts.map +1 -0
  94. package/dist/types/src/components/List/ListDropIndicator.d.ts.map +1 -0
  95. package/dist/types/src/components/List/Tree.d.ts.map +1 -0
  96. package/dist/types/src/components/List/Tree.stories.d.ts.map +1 -0
  97. package/dist/types/src/components/List/TreeDropIndicator.d.ts.map +1 -0
  98. package/dist/types/src/components/{Lists → List}/Treegrid.d.ts +5 -9
  99. package/dist/types/src/components/List/Treegrid.d.ts.map +1 -0
  100. package/dist/types/src/components/List/Treegrid.stories.d.ts.map +1 -0
  101. package/dist/types/src/components/List/index.d.ts.map +1 -0
  102. package/dist/types/src/components/Main/Main.d.ts +17 -18
  103. package/dist/types/src/components/Main/Main.d.ts.map +1 -1
  104. package/dist/types/src/components/Main/Main.stories.d.ts +0 -3
  105. package/dist/types/src/components/Main/Main.stories.d.ts.map +1 -1
  106. package/dist/types/src/components/{Menus → Menu}/ContextMenu.d.ts +6 -6
  107. package/dist/types/src/components/Menu/ContextMenu.d.ts.map +1 -0
  108. package/dist/types/src/components/Menu/ContextMenu.stories.d.ts.map +1 -0
  109. package/dist/types/src/components/Menu/DropdownMenu.d.ts +113 -0
  110. package/dist/types/src/components/Menu/DropdownMenu.d.ts.map +1 -0
  111. package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts +28 -0
  112. package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts.map +1 -0
  113. package/dist/types/src/components/Menu/index.d.ts.map +1 -0
  114. package/dist/types/src/components/Message/Message.d.ts +1 -1
  115. package/dist/types/src/components/Message/Message.d.ts.map +1 -1
  116. package/dist/types/src/components/Message/Message.stories.d.ts +5 -6
  117. package/dist/types/src/components/Message/Message.stories.d.ts.map +1 -1
  118. package/dist/types/src/components/Popover/Popover.d.ts +33 -24
  119. package/dist/types/src/components/Popover/Popover.d.ts.map +1 -1
  120. package/dist/types/src/components/Popover/Popover.stories.d.ts.map +1 -1
  121. package/dist/types/src/components/ScrollArea/ScrollArea.d.ts +27 -27
  122. package/dist/types/src/components/ScrollArea/ScrollArea.d.ts.map +1 -1
  123. package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts +57 -8
  124. package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts.map +1 -1
  125. package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts +60 -0
  126. package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts.map +1 -0
  127. package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts +23 -0
  128. package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts.map +1 -0
  129. package/dist/types/src/components/ScrollContainer/index.d.ts +2 -0
  130. package/dist/types/src/components/ScrollContainer/index.d.ts.map +1 -0
  131. package/dist/types/src/components/Select/Select.d.ts +10 -10
  132. package/dist/types/src/components/Select/Select.d.ts.map +1 -1
  133. package/dist/types/src/components/Select/Select.stories.d.ts +2 -2
  134. package/dist/types/src/components/Select/Select.stories.d.ts.map +1 -1
  135. package/dist/types/src/components/Separator/Separator.d.ts +4 -4
  136. package/dist/types/src/components/Separator/Separator.d.ts.map +1 -1
  137. package/dist/types/src/components/Skeleton/Skeleton.d.ts +12 -0
  138. package/dist/types/src/components/Skeleton/Skeleton.d.ts.map +1 -0
  139. package/dist/types/src/components/Skeleton/Skeleton.stories.d.ts +17 -0
  140. package/dist/types/src/components/Skeleton/Skeleton.stories.d.ts.map +1 -0
  141. package/dist/types/src/components/Skeleton/index.d.ts +2 -0
  142. package/dist/types/src/components/Skeleton/index.d.ts.map +1 -0
  143. package/dist/types/src/components/Splitter/Splitter.d.ts +34 -0
  144. package/dist/types/src/components/Splitter/Splitter.d.ts.map +1 -0
  145. package/dist/types/src/components/Splitter/Splitter.stories.d.ts +7 -0
  146. package/dist/types/src/components/Splitter/Splitter.stories.d.ts.map +1 -0
  147. package/dist/types/src/components/Splitter/index.d.ts +2 -0
  148. package/dist/types/src/components/Splitter/index.d.ts.map +1 -0
  149. package/dist/types/src/components/Status/Status.d.ts +3 -4
  150. package/dist/types/src/components/Status/Status.d.ts.map +1 -1
  151. package/dist/types/src/components/Status/Status.stories.d.ts +4 -2
  152. package/dist/types/src/components/Status/Status.stories.d.ts.map +1 -1
  153. package/dist/types/src/components/Tag/Tag.d.ts +1 -1
  154. package/dist/types/src/components/Tag/Tag.d.ts.map +1 -1
  155. package/dist/types/src/components/Tag/Tag.stories.d.ts +0 -5
  156. package/dist/types/src/components/Tag/Tag.stories.d.ts.map +1 -1
  157. package/dist/types/src/components/ThemeProvider/ThemeProvider.d.ts +3 -3
  158. package/dist/types/src/components/ThemeProvider/ThemeProvider.d.ts.map +1 -1
  159. package/dist/types/src/components/{Menus/DropdownMenu.stories.d.ts → ThemeProvider/ThemeProvider.stories.d.ts} +2 -5
  160. package/dist/types/src/components/ThemeProvider/ThemeProvider.stories.d.ts.map +1 -0
  161. package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts +1 -8
  162. package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts.map +1 -1
  163. package/dist/types/src/components/ThemeProvider/index.d.ts +2 -1
  164. package/dist/types/src/components/ThemeProvider/index.d.ts.map +1 -1
  165. package/dist/types/src/components/Toast/Toast.d.ts +19 -19
  166. package/dist/types/src/components/Toast/Toast.d.ts.map +1 -1
  167. package/dist/types/src/components/Toast/Toast.stories.d.ts.map +1 -1
  168. package/dist/types/src/components/Toolbar/Toolbar.d.ts +37 -17
  169. package/dist/types/src/components/Toolbar/Toolbar.d.ts.map +1 -1
  170. package/dist/types/src/components/Toolbar/Toolbar.stories.d.ts.map +1 -1
  171. package/dist/types/src/components/Tooltip/Tooltip.d.ts +9 -9
  172. package/dist/types/src/components/Tooltip/Tooltip.d.ts.map +1 -1
  173. package/dist/types/src/components/Tooltip/Tooltip.stories.d.ts +2 -2
  174. package/dist/types/src/components/Tooltip/Tooltip.stories.d.ts.map +1 -1
  175. package/dist/types/src/components/index.d.ts +14 -8
  176. package/dist/types/src/components/index.d.ts.map +1 -1
  177. package/dist/types/src/exemplars/generics.stories.d.ts +19 -0
  178. package/dist/types/src/exemplars/generics.stories.d.ts.map +1 -0
  179. package/dist/types/src/exemplars/slot.stories.d.ts +15 -0
  180. package/dist/types/src/exemplars/slot.stories.d.ts.map +1 -0
  181. package/dist/types/src/exemplars/tabster.stories.d.ts +8 -0
  182. package/dist/types/src/exemplars/tabster.stories.d.ts.map +1 -0
  183. package/dist/types/src/exemplars/virtualizer.stories.d.ts +11 -0
  184. package/dist/types/src/exemplars/virtualizer.stories.d.ts.map +1 -0
  185. package/dist/types/src/hooks/index.d.ts +1 -0
  186. package/dist/types/src/hooks/index.d.ts.map +1 -1
  187. package/dist/types/src/hooks/useDensityContext.d.ts +2 -2
  188. package/dist/types/src/hooks/useDensityContext.d.ts.map +1 -1
  189. package/dist/types/src/hooks/useElevationContext.d.ts +1 -1
  190. package/dist/types/src/hooks/useElevationContext.d.ts.map +1 -1
  191. package/dist/types/src/index.d.ts +2 -1
  192. package/dist/types/src/index.d.ts.map +1 -1
  193. package/dist/types/src/playground/Controls.stories.d.ts.map +1 -1
  194. package/dist/types/src/playground/Custom.stories.d.ts.map +1 -1
  195. package/dist/types/src/primitives/Column/Column.d.ts +33 -0
  196. package/dist/types/src/primitives/Column/Column.d.ts.map +1 -0
  197. package/dist/types/src/primitives/Column/Column.stories.d.ts +25 -0
  198. package/dist/types/src/primitives/Column/Column.stories.d.ts.map +1 -0
  199. package/dist/types/src/primitives/Column/index.d.ts +2 -0
  200. package/dist/types/src/primitives/Column/index.d.ts.map +1 -0
  201. package/dist/types/src/primitives/Container/Container.d.ts +7 -0
  202. package/dist/types/src/primitives/Container/Container.d.ts.map +1 -0
  203. package/dist/types/src/primitives/Container/Container.stories.d.ts +6 -0
  204. package/dist/types/src/primitives/Container/Container.stories.d.ts.map +1 -0
  205. package/dist/types/src/primitives/Container/index.d.ts +2 -0
  206. package/dist/types/src/primitives/Container/index.d.ts.map +1 -0
  207. package/dist/types/src/primitives/Flex/Flex.d.ts +11 -0
  208. package/dist/types/src/primitives/Flex/Flex.d.ts.map +1 -0
  209. package/dist/types/src/primitives/Flex/Flex.stories.d.ts +8 -0
  210. package/dist/types/src/primitives/Flex/Flex.stories.d.ts.map +1 -0
  211. package/dist/types/src/primitives/Flex/index.d.ts +2 -0
  212. package/dist/types/src/primitives/Flex/index.d.ts.map +1 -0
  213. package/dist/types/src/primitives/Grid/Grid.d.ts +10 -0
  214. package/dist/types/src/primitives/Grid/Grid.d.ts.map +1 -0
  215. package/dist/types/src/primitives/Grid/Grid.stories.d.ts +8 -0
  216. package/dist/types/src/primitives/Grid/Grid.stories.d.ts.map +1 -0
  217. package/dist/types/src/primitives/Grid/index.d.ts +2 -0
  218. package/dist/types/src/primitives/Grid/index.d.ts.map +1 -0
  219. package/dist/types/src/primitives/Panel/Panel.d.ts +35 -0
  220. package/dist/types/src/primitives/Panel/Panel.d.ts.map +1 -0
  221. package/dist/types/src/primitives/Panel/Panel.stories.d.ts +6 -0
  222. package/dist/types/src/primitives/Panel/Panel.stories.d.ts.map +1 -0
  223. package/dist/types/src/primitives/Panel/index.d.ts +2 -0
  224. package/dist/types/src/primitives/Panel/index.d.ts.map +1 -0
  225. package/dist/types/src/primitives/index.d.ts +6 -0
  226. package/dist/types/src/primitives/index.d.ts.map +1 -0
  227. package/dist/types/src/testing/Loading.d.ts +9 -0
  228. package/dist/types/src/testing/Loading.d.ts.map +1 -0
  229. package/dist/types/src/testing/decorators/index.d.ts +1 -1
  230. package/dist/types/src/testing/decorators/index.d.ts.map +1 -1
  231. package/dist/types/src/testing/decorators/withLayout.d.ts +3 -3
  232. package/dist/types/src/testing/decorators/withLayout.d.ts.map +1 -1
  233. package/dist/types/src/testing/decorators/withLayoutVariants.d.ts +12 -0
  234. package/dist/types/src/testing/decorators/withLayoutVariants.d.ts.map +1 -0
  235. package/dist/types/src/testing/decorators/withTheme.d.ts +3 -2
  236. package/dist/types/src/testing/decorators/withTheme.d.ts.map +1 -1
  237. package/dist/types/src/testing/index.d.ts +1 -0
  238. package/dist/types/src/testing/index.d.ts.map +1 -1
  239. package/dist/types/src/translations.d.ts +11 -0
  240. package/dist/types/src/translations.d.ts.map +1 -0
  241. package/dist/types/src/util/index.d.ts +1 -2
  242. package/dist/types/src/util/index.d.ts.map +1 -1
  243. package/dist/types/src/util/usePx.d.ts.map +1 -1
  244. package/dist/types/tsconfig.tsbuildinfo +1 -1
  245. package/package.json +43 -37
  246. package/src/components/Avatars/Avatar.stories.tsx +7 -9
  247. package/src/components/Avatars/Avatar.tsx +7 -15
  248. package/src/components/Avatars/AvatarGroup.stories.tsx +2 -3
  249. package/src/components/Breadcrumb/Breadcrumb.stories.tsx +4 -5
  250. package/src/components/Breadcrumb/Breadcrumb.tsx +11 -37
  251. package/src/components/{Buttons → Button}/Button.stories.tsx +4 -5
  252. package/src/components/{Buttons → Button}/Button.tsx +12 -26
  253. package/src/components/{Buttons → Button}/IconButton.stories.tsx +8 -6
  254. package/src/components/{Buttons → Button}/IconButton.tsx +19 -15
  255. package/src/components/{Buttons → Button}/Toggle.stories.tsx +7 -7
  256. package/src/components/{Buttons → Button}/Toggle.tsx +4 -4
  257. package/src/components/{Buttons → Button}/ToggleGroup.stories.tsx +2 -3
  258. package/src/components/{Buttons → Button}/ToggleGroup.tsx +12 -16
  259. package/src/components/Card/Card.stories.tsx +151 -0
  260. package/src/components/Card/Card.tsx +505 -0
  261. package/src/components/Card/index.ts +5 -0
  262. package/src/components/Clipboard/CopyButton.tsx +8 -9
  263. package/src/components/DensityProvider/DensityProvider.tsx +1 -1
  264. package/src/components/Dialog/AlertDialog.stories.tsx +68 -0
  265. package/src/components/{Dialogs → Dialog}/AlertDialog.tsx +123 -82
  266. package/src/components/Dialog/Dialog.stories.tsx +177 -0
  267. package/src/components/Dialog/Dialog.tsx +285 -0
  268. package/src/components/ElevationProvider/ElevationProvider.tsx +1 -1
  269. package/src/components/ErrorFallback/ErrorFallback.stories.tsx +45 -0
  270. package/src/components/ErrorFallback/ErrorFallback.tsx +70 -0
  271. package/src/components/ErrorFallback/ErrorStack.tsx +114 -0
  272. package/src/components/ErrorFallback/ThrowError.tsx +37 -0
  273. package/src/components/ErrorFallback/index.ts +9 -0
  274. package/src/components/Focus/AUDIT.md +43 -0
  275. package/src/components/Focus/Focus.stories.tsx +230 -0
  276. package/src/components/Focus/Focus.tsx +201 -0
  277. package/src/components/Focus/index.ts +5 -0
  278. package/src/components/Icon/Icon.stories.tsx +143 -0
  279. package/src/components/Icon/Icon.tsx +6 -2
  280. package/src/components/Image/Image.stories.tsx +86 -0
  281. package/src/components/Image/Image.tsx +236 -0
  282. package/src/components/Image/index.ts +5 -0
  283. package/src/components/Input/Input.stories.tsx +21 -41
  284. package/src/components/Input/Input.tsx +38 -74
  285. package/src/components/Link/Link.stories.tsx +2 -3
  286. package/src/components/Link/Link.tsx +2 -2
  287. package/src/components/{Lists → List}/List.stories.tsx +30 -34
  288. package/src/components/{Lists → List}/List.tsx +17 -21
  289. package/src/components/{Lists → List}/ListDropIndicator.tsx +7 -7
  290. package/src/components/{Lists → List}/Tree.stories.tsx +5 -6
  291. package/src/components/{Lists → List}/Tree.tsx +0 -1
  292. package/src/components/{Lists → List}/TreeDropIndicator.tsx +6 -6
  293. package/src/components/{Lists → List}/Treegrid.stories.tsx +29 -30
  294. package/src/components/{Lists → List}/Treegrid.tsx +23 -28
  295. package/src/components/Main/Main.stories.tsx +41 -24
  296. package/src/components/Main/Main.tsx +150 -94
  297. package/src/components/{Menus → Menu}/ContextMenu.stories.tsx +2 -3
  298. package/src/components/{Menus → Menu}/ContextMenu.tsx +9 -33
  299. package/src/components/{Menus → Menu}/DropdownMenu.stories.tsx +3 -4
  300. package/src/components/{Menus → Menu}/DropdownMenu.tsx +137 -110
  301. package/src/components/Message/Message.stories.tsx +27 -13
  302. package/src/components/Message/Message.tsx +43 -34
  303. package/src/components/Popover/Popover.stories.tsx +8 -9
  304. package/src/components/Popover/Popover.tsx +114 -92
  305. package/src/components/ScrollArea/ScrollArea.stories.tsx +223 -34
  306. package/src/components/ScrollArea/ScrollArea.tsx +97 -79
  307. package/src/components/ScrollArea/index.ts +1 -1
  308. package/src/components/ScrollContainer/ScrollContainer.stories.tsx +91 -0
  309. package/src/components/ScrollContainer/ScrollContainer.tsx +347 -0
  310. package/src/components/ScrollContainer/index.ts +5 -0
  311. package/src/components/Select/Select.stories.tsx +8 -9
  312. package/src/components/Select/Select.tsx +11 -27
  313. package/src/components/Separator/Separator.tsx +5 -8
  314. package/src/components/Skeleton/Skeleton.stories.tsx +51 -0
  315. package/src/components/Skeleton/Skeleton.tsx +26 -0
  316. package/src/components/Skeleton/index.ts +5 -0
  317. package/src/components/Splitter/Splitter.stories.tsx +83 -0
  318. package/src/components/Splitter/Splitter.tsx +127 -0
  319. package/src/components/Splitter/index.ts +5 -0
  320. package/src/components/Status/Status.stories.tsx +21 -18
  321. package/src/components/Status/Status.tsx +10 -7
  322. package/src/components/Tag/Tag.stories.tsx +6 -12
  323. package/src/components/Tag/Tag.tsx +3 -8
  324. package/src/components/ThemeProvider/ThemeProvider.stories.tsx +31 -0
  325. package/src/components/ThemeProvider/ThemeProvider.tsx +10 -10
  326. package/src/components/ThemeProvider/TranslationsProvider.tsx +1 -16
  327. package/src/components/ThemeProvider/index.ts +3 -3
  328. package/src/components/Toast/Toast.stories.tsx +3 -4
  329. package/src/components/Toast/Toast.tsx +22 -41
  330. package/src/components/Toolbar/Toolbar.stories.tsx +4 -7
  331. package/src/components/Toolbar/Toolbar.tsx +186 -23
  332. package/src/components/Tooltip/Tooltip.stories.tsx +21 -20
  333. package/src/components/Tooltip/Tooltip.tsx +40 -38
  334. package/src/components/index.ts +15 -9
  335. package/src/exemplars/generics.stories.tsx +41 -0
  336. package/src/exemplars/slot.stories.tsx +117 -0
  337. package/src/exemplars/tabster.stories.tsx +127 -0
  338. package/src/exemplars/virtualizer.stories.tsx +137 -0
  339. package/src/hooks/index.ts +1 -0
  340. package/src/hooks/useDensityContext.ts +3 -3
  341. package/src/hooks/useElevationContext.ts +1 -1
  342. package/src/index.ts +2 -1
  343. package/src/playground/Controls.stories.tsx +3 -10
  344. package/src/playground/Custom.stories.tsx +13 -18
  345. package/src/playground/Typography.stories.tsx +3 -3
  346. package/src/primitives/Column/AUDIT.md +148 -0
  347. package/src/primitives/Column/Column.stories.tsx +181 -0
  348. package/src/primitives/Column/Column.tsx +165 -0
  349. package/src/primitives/Column/index.ts +5 -0
  350. package/src/primitives/Container/Container.stories.tsx +29 -0
  351. package/src/primitives/Container/Container.tsx +19 -0
  352. package/src/primitives/Container/index.ts +5 -0
  353. package/src/primitives/Flex/Flex.stories.tsx +57 -0
  354. package/src/primitives/Flex/Flex.tsx +27 -0
  355. package/src/primitives/Flex/index.ts +5 -0
  356. package/src/primitives/Grid/Grid.stories.tsx +56 -0
  357. package/src/primitives/Grid/Grid.tsx +30 -0
  358. package/src/primitives/Grid/index.ts +5 -0
  359. package/src/primitives/Panel/Panel.stories.tsx +68 -0
  360. package/src/primitives/Panel/Panel.tsx +120 -0
  361. package/src/primitives/Panel/index.ts +5 -0
  362. package/src/primitives/index.ts +9 -0
  363. package/src/testing/Loading.tsx +47 -0
  364. package/src/testing/decorators/index.ts +1 -1
  365. package/src/testing/decorators/withLayout.tsx +39 -18
  366. package/src/testing/decorators/withLayoutVariants.tsx +48 -0
  367. package/src/testing/decorators/withTheme.tsx +26 -20
  368. package/src/testing/index.ts +2 -0
  369. package/src/translations.ts +19 -0
  370. package/src/util/index.ts +2 -2
  371. package/src/util/usePx.ts +1 -0
  372. package/dist/lib/browser/chunk-KX5JDELJ.mjs +0 -4521
  373. package/dist/lib/browser/chunk-KX5JDELJ.mjs.map +0 -7
  374. package/dist/lib/node-esm/chunk-3HDQYL5S.mjs +0 -4523
  375. package/dist/lib/node-esm/chunk-3HDQYL5S.mjs.map +0 -7
  376. package/dist/types/src/components/AnchoredOverflow/AnchoredOverflow.d.ts +0 -15
  377. package/dist/types/src/components/AnchoredOverflow/AnchoredOverflow.d.ts.map +0 -1
  378. package/dist/types/src/components/AnchoredOverflow/index.d.ts +0 -2
  379. package/dist/types/src/components/AnchoredOverflow/index.d.ts.map +0 -1
  380. package/dist/types/src/components/Buttons/Button.d.ts.map +0 -1
  381. package/dist/types/src/components/Buttons/Button.stories.d.ts.map +0 -1
  382. package/dist/types/src/components/Buttons/IconButton.d.ts.map +0 -1
  383. package/dist/types/src/components/Buttons/IconButton.stories.d.ts.map +0 -1
  384. package/dist/types/src/components/Buttons/Toggle.d.ts.map +0 -1
  385. package/dist/types/src/components/Buttons/Toggle.stories.d.ts +0 -13
  386. package/dist/types/src/components/Buttons/Toggle.stories.d.ts.map +0 -1
  387. package/dist/types/src/components/Buttons/ToggleGroup.d.ts +0 -27
  388. package/dist/types/src/components/Buttons/ToggleGroup.d.ts.map +0 -1
  389. package/dist/types/src/components/Buttons/ToggleGroup.stories.d.ts.map +0 -1
  390. package/dist/types/src/components/Buttons/index.d.ts.map +0 -1
  391. package/dist/types/src/components/Dialogs/AlertDialog.d.ts +0 -31
  392. package/dist/types/src/components/Dialogs/AlertDialog.d.ts.map +0 -1
  393. package/dist/types/src/components/Dialogs/AlertDialog.stories.d.ts.map +0 -1
  394. package/dist/types/src/components/Dialogs/Dialog.d.ts +0 -31
  395. package/dist/types/src/components/Dialogs/Dialog.d.ts.map +0 -1
  396. package/dist/types/src/components/Dialogs/Dialog.stories.d.ts +0 -25
  397. package/dist/types/src/components/Dialogs/Dialog.stories.d.ts.map +0 -1
  398. package/dist/types/src/components/Dialogs/index.d.ts.map +0 -1
  399. package/dist/types/src/components/Lists/List.d.ts.map +0 -1
  400. package/dist/types/src/components/Lists/List.stories.d.ts.map +0 -1
  401. package/dist/types/src/components/Lists/ListDropIndicator.d.ts.map +0 -1
  402. package/dist/types/src/components/Lists/Tree.d.ts.map +0 -1
  403. package/dist/types/src/components/Lists/Tree.stories.d.ts.map +0 -1
  404. package/dist/types/src/components/Lists/TreeDropIndicator.d.ts.map +0 -1
  405. package/dist/types/src/components/Lists/Treegrid.d.ts.map +0 -1
  406. package/dist/types/src/components/Lists/Treegrid.stories.d.ts.map +0 -1
  407. package/dist/types/src/components/Lists/index.d.ts.map +0 -1
  408. package/dist/types/src/components/Menus/ContextMenu.d.ts.map +0 -1
  409. package/dist/types/src/components/Menus/ContextMenu.stories.d.ts.map +0 -1
  410. package/dist/types/src/components/Menus/DropdownMenu.d.ts +0 -113
  411. package/dist/types/src/components/Menus/DropdownMenu.d.ts.map +0 -1
  412. package/dist/types/src/components/Menus/DropdownMenu.stories.d.ts.map +0 -1
  413. package/dist/types/src/components/Menus/index.d.ts.map +0 -1
  414. package/dist/types/src/testing/decorators/withSurfaceVariantsLayout.d.ts +0 -12
  415. package/dist/types/src/testing/decorators/withSurfaceVariantsLayout.d.ts.map +0 -1
  416. package/dist/types/src/util/ThemedClassName.d.ts +0 -5
  417. package/dist/types/src/util/ThemedClassName.d.ts.map +0 -1
  418. package/dist/types/src/util/domino.d.ts +0 -18
  419. package/dist/types/src/util/domino.d.ts.map +0 -1
  420. package/src/components/AnchoredOverflow/AnchoredOverflow.tsx +0 -59
  421. package/src/components/AnchoredOverflow/index.ts +0 -5
  422. package/src/components/Dialogs/AlertDialog.stories.tsx +0 -69
  423. package/src/components/Dialogs/Dialog.stories.tsx +0 -67
  424. package/src/components/Dialogs/Dialog.tsx +0 -159
  425. package/src/testing/decorators/withSurfaceVariantsLayout.tsx +0 -51
  426. package/src/util/ThemedClassName.ts +0 -7
  427. package/src/util/domino.ts +0 -53
  428. /package/dist/types/src/components/{Buttons → Button}/Button.stories.d.ts +0 -0
  429. /package/dist/types/src/components/{Buttons → Button}/index.d.ts +0 -0
  430. /package/dist/types/src/components/{Dialogs → Dialog}/AlertDialog.stories.d.ts +0 -0
  431. /package/dist/types/src/components/{Dialogs → Dialog}/index.d.ts +0 -0
  432. /package/dist/types/src/components/{Lists → List}/ListDropIndicator.d.ts +0 -0
  433. /package/dist/types/src/components/{Lists → List}/Tree.d.ts +0 -0
  434. /package/dist/types/src/components/{Lists → List}/Tree.stories.d.ts +0 -0
  435. /package/dist/types/src/components/{Lists → List}/TreeDropIndicator.d.ts +0 -0
  436. /package/dist/types/src/components/{Lists → List}/Treegrid.stories.d.ts +0 -0
  437. /package/dist/types/src/components/{Lists → List}/index.d.ts +0 -0
  438. /package/dist/types/src/components/{Menus → Menu}/ContextMenu.stories.d.ts +0 -0
  439. /package/dist/types/src/components/{Menus → Menu}/index.d.ts +0 -0
  440. /package/src/components/{Buttons → Button}/index.ts +0 -0
  441. /package/src/components/{Dialogs → Dialog}/index.ts +0 -0
  442. /package/src/components/{Lists → List}/index.ts +0 -0
  443. /package/src/components/{Menus → Menu}/index.ts +0 -0
@@ -6,10 +6,9 @@ import { type Meta, type StoryObj } from '@storybook/react-vite';
6
6
  import React from 'react';
7
7
 
8
8
  import { withTheme } from '../../testing';
9
- import { Toggle } from '../Buttons';
9
+ import { Toggle } from '../Button';
10
10
  import { Icon } from '../Icon';
11
11
  import { Select } from '../Select';
12
-
13
12
  import { Toolbar } from './Toolbar';
14
13
 
15
14
  type StorybookToolbarProps = {};
@@ -63,18 +62,16 @@ const DefaultStory = (props: StorybookToolbarProps) => {
63
62
  </Toolbar.Button>
64
63
  <Toolbar.Separator />
65
64
  <Toolbar.Button>Test</Toolbar.Button>
66
- <Toolbar.Button>
67
- <Icon icon='ph--arrow-clockwise--regular' />
68
- </Toolbar.Button>
65
+ <Toolbar.IconButton icon='ph--arrow-clockwise--regular' label='Refresh' iconOnly />
69
66
  </Toolbar.Root>
70
67
  );
71
68
  };
72
69
 
73
70
  const meta = {
74
- title: 'ui/react-ui-core/Toolbar',
71
+ title: 'ui/react-ui-core/components/Toolbar',
75
72
  component: Toolbar as any,
76
73
  render: DefaultStory,
77
- decorators: [withTheme],
74
+ decorators: [withTheme()],
78
75
  } satisfies Meta<typeof DefaultStory>;
79
76
 
80
77
  export default meta;
@@ -2,12 +2,18 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
+ import { Primitive } from '@radix-ui/react-primitive';
6
+ import { Slot } from '@radix-ui/react-slot';
5
7
  import type { ToggleGroupItemProps as ToggleGroupItemPrimitiveProps } from '@radix-ui/react-toggle-group';
6
8
  import * as ToolbarPrimitive from '@radix-ui/react-toolbar';
7
- import React, { Fragment, forwardRef } from 'react';
9
+ import React, { forwardRef } from 'react';
10
+ import { useTranslation } from 'react-i18next';
11
+
12
+ import { composable, composableProps, slottable, type ToolbarStyleProps } from '@dxos/ui-theme';
13
+ import { type SlottableProps } from '@dxos/ui-types';
8
14
 
9
15
  import { useThemeContext } from '../../hooks';
10
- import { type ThemedClassName } from '../../util';
16
+ import { translationKey } from '../../translations';
11
17
  import {
12
18
  Button,
13
19
  ButtonGroup,
@@ -18,38 +24,59 @@ import {
18
24
  Toggle,
19
25
  type ToggleGroupItemProps,
20
26
  type ToggleProps,
21
- } from '../Buttons';
27
+ } from '../Button';
22
28
  import { Link, type LinkProps } from '../Link';
29
+ import { DropdownMenu } from '../Menu';
23
30
  import { Separator, type SeparatorProps } from '../Separator';
24
31
 
25
- type ToolbarRootProps = ThemedClassName<
26
- ToolbarPrimitive.ToolbarProps & {
27
- layoutManaged?: boolean;
28
- textBlockWidth?: boolean;
29
- }
30
- >;
32
+ //
33
+ // Root
34
+ //
35
+
36
+ type ToolbarRootProps = ToolbarPrimitive.ToolbarProps & ToolbarStyleProps;
31
37
 
32
- const ToolbarRoot = forwardRef<HTMLDivElement, ToolbarRootProps>(
33
- ({ classNames, children, layoutManaged, textBlockWidth: wrapContents, ...props }, forwardedRef) => {
38
+ const ToolbarRoot = composable<HTMLDivElement, ToolbarRootProps>(
39
+ ({ children, density, disabled, layoutManaged, orientation, ...props }, forwardedRef) => {
40
+ const { className, role, ...rest } = composableProps(props);
34
41
  const { tx } = useThemeContext();
35
- const InnerRoot = wrapContents ? 'div' : Fragment;
36
- const innerRootProps = wrapContents
37
- ? { role: 'none', className: tx('toolbar.inner', 'toolbar', { layoutManaged }, classNames) }
38
- : {};
39
42
 
40
43
  return (
41
44
  <ToolbarPrimitive.Root
42
- {...props}
43
- data-arrow-keys={props.orientation === 'vertical' ? 'up down' : 'left right'}
44
- className={tx('toolbar.root', 'toolbar', { layoutManaged }, classNames)}
45
+ {...rest}
46
+ // Only pass role when explicitly set; radix provides role="toolbar" by default.
47
+ {...(role !== 'none' && { role })}
48
+ orientation={orientation}
49
+ data-arrow-keys={orientation === 'vertical' ? 'up down' : 'left right'}
50
+ className={tx('toolbar.root', { density, disabled, layoutManaged }, className)}
45
51
  ref={forwardedRef}
46
52
  >
47
- <InnerRoot {...innerRootProps}>{children}</InnerRoot>
53
+ {children}
48
54
  </ToolbarPrimitive.Root>
49
55
  );
50
56
  },
51
57
  );
52
58
 
59
+ //
60
+ // Text
61
+ //
62
+
63
+ type ToolbarTextProps = SlottableProps;
64
+
65
+ const ToolbarText = slottable<HTMLDivElement>(({ children, asChild, ...props }, forwardedRef) => {
66
+ const { className, ...rest } = composableProps(props);
67
+ const Comp = asChild ? Slot : Primitive.div;
68
+ const { tx } = useThemeContext();
69
+ return (
70
+ <Comp {...rest} className={tx('toolbar.text', {}, className)} ref={forwardedRef}>
71
+ {children}
72
+ </Comp>
73
+ );
74
+ });
75
+
76
+ //
77
+ // Button
78
+ //
79
+
53
80
  type ToolbarButtonProps = ButtonProps;
54
81
 
55
82
  const ToolbarButton = forwardRef<HTMLButtonElement, ToolbarButtonProps>((props, forwardedRef) => {
@@ -60,12 +87,16 @@ const ToolbarButton = forwardRef<HTMLButtonElement, ToolbarButtonProps>((props,
60
87
  );
61
88
  });
62
89
 
90
+ //
91
+ // IconButton
92
+ //
93
+
63
94
  type ToolbarIconButtonProps = IconButtonProps;
64
95
 
65
96
  const ToolbarIconButton = forwardRef<HTMLButtonElement, ToolbarIconButtonProps>((props, forwardedRef) => {
66
97
  return (
67
98
  <ToolbarPrimitive.Button asChild>
68
- <IconButton {...props} ref={forwardedRef} />
99
+ <IconButton {...props} noTooltip ref={forwardedRef} />
69
100
  </ToolbarPrimitive.Button>
70
101
  );
71
102
  });
@@ -80,6 +111,10 @@ const ToolbarToggle = forwardRef<HTMLButtonElement, ToolbarToggleProps>((props,
80
111
  );
81
112
  });
82
113
 
114
+ //
115
+ // Link
116
+ //
117
+
83
118
  type ToolbarLinkProps = LinkProps;
84
119
 
85
120
  const ToolbarLink = forwardRef<HTMLAnchorElement, ToolbarLinkProps>((props, forwardedRef) => {
@@ -96,6 +131,10 @@ type ToolbarToggleGroupProps = (
96
131
  ) &
97
132
  ButtonGroupProps;
98
133
 
134
+ //
135
+ // ToggleGroup
136
+ //
137
+
99
138
  const ToolbarToggleGroup = forwardRef<HTMLDivElement, ToolbarToggleGroupProps>(
100
139
  ({ classNames, children, elevation, ...props }, forwardedRef) => {
101
140
  return (
@@ -124,19 +163,34 @@ const ToolbarToggleGroupIconItem = forwardRef<HTMLButtonElement, ToolbarToggleGr
124
163
  ({ variant, density, elevation, classNames, icon, label, iconOnly, ...props }, forwardedRef) => {
125
164
  return (
126
165
  <ToolbarPrimitive.ToolbarToggleItem {...props} asChild>
127
- <IconButton {...{ variant, density, elevation, classNames, icon, label, iconOnly }} ref={forwardedRef} />
166
+ <IconButton
167
+ {...{
168
+ variant,
169
+ density,
170
+ elevation,
171
+ classNames,
172
+ icon,
173
+ label,
174
+ iconOnly,
175
+ }}
176
+ ref={forwardedRef}
177
+ />
128
178
  </ToolbarPrimitive.ToolbarToggleItem>
129
179
  );
130
180
  },
131
181
  );
132
182
 
183
+ //
184
+ // Separator
185
+ //
186
+
133
187
  type ToolbarSeparatorProps = SeparatorProps & { variant?: 'gap' | 'line' };
134
188
 
135
189
  const ToolbarSeparator = forwardRef<HTMLDivElement, ToolbarSeparatorProps>(
136
- ({ variant = 'line', ...props }, forwardedRef) => {
190
+ ({ variant = 'gap', ...props }, forwardedRef) => {
137
191
  return variant === 'line' ? (
138
192
  <ToolbarPrimitive.Separator asChild>
139
- <Separator {...props} ref={forwardedRef} />
193
+ <Separator orientation='vertical' {...props} ref={forwardedRef} />
140
194
  </ToolbarPrimitive.Separator>
141
195
  ) : (
142
196
  <ToolbarPrimitive.Separator className='grow' ref={forwardedRef} />
@@ -144,8 +198,109 @@ const ToolbarSeparator = forwardRef<HTMLDivElement, ToolbarSeparatorProps>(
144
198
  },
145
199
  );
146
200
 
201
+ //
202
+ // DragHandle
203
+ //
204
+
205
+ type ToolbarDragHandleProps = { testId?: string; label?: string };
206
+
207
+ const ToolbarDragHandle = forwardRef<HTMLButtonElement, ToolbarDragHandleProps>(
208
+ ({ testId = 'drag-handle', label }, forwardedRef) => {
209
+ const { t } = useTranslation(translationKey);
210
+ return (
211
+ <ToolbarIconButton
212
+ data-testid={testId}
213
+ tabIndex={-1}
214
+ noTooltip
215
+ iconOnly
216
+ icon='ph--dots-six-vertical--regular'
217
+ variant='ghost'
218
+ label={label ?? t('toolbar-drag-handle.label')}
219
+ classNames='dx-focus-ring-none cursor-pointer'
220
+ disabled={!forwardedRef}
221
+ ref={forwardedRef}
222
+ />
223
+ );
224
+ },
225
+ );
226
+
227
+ //
228
+ // CloseIconButton
229
+ //
230
+
231
+ type ToolbarCloseIconButtonProps = { onClick?: () => void; label?: string };
232
+
233
+ const ToolbarCloseIconButton = forwardRef<HTMLButtonElement, ToolbarCloseIconButtonProps>(
234
+ ({ onClick, label }, forwardedRef) => {
235
+ const { t } = useTranslation(translationKey);
236
+
237
+ return (
238
+ <ToolbarIconButton
239
+ iconOnly
240
+ icon='ph--x--regular'
241
+ variant='ghost'
242
+ label={label ?? t('toolbar-close.label')}
243
+ classNames='cursor-pointer'
244
+ onClick={onClick}
245
+ ref={forwardedRef}
246
+ />
247
+ );
248
+ },
249
+ );
250
+
251
+ //
252
+ // Menu
253
+ //
254
+
255
+ type ToolbarMenuItem<T extends any | void = void> = {
256
+ label: string;
257
+ onClick: (context: T) => void;
258
+ };
259
+
260
+ type ToolbarMenuProps<T extends any | void = void> = {
261
+ context?: T;
262
+ items?: ToolbarMenuItem<T>[];
263
+ };
264
+
265
+ // TODO(burdon): Make slottable.
266
+ const ToolbarMenu = <T extends any | void = void>({ context, items }: ToolbarMenuProps<T>) => {
267
+ const { t } = useTranslation(translationKey);
268
+
269
+ return (
270
+ <DropdownMenu.Root>
271
+ <DropdownMenu.Trigger disabled={!items?.length} asChild>
272
+ <ToolbarIconButton
273
+ iconOnly
274
+ variant='ghost'
275
+ icon='ph--dots-three-vertical--regular'
276
+ label={t('toolbar-menu.label')}
277
+ />
278
+ </DropdownMenu.Trigger>
279
+ {(items?.length ?? 0) > 0 && (
280
+ <DropdownMenu.Portal>
281
+ <DropdownMenu.Content>
282
+ <DropdownMenu.Viewport>
283
+ {items?.map(({ label, onClick: onSelect }, index) => (
284
+ <DropdownMenu.Item key={index} onSelect={() => onSelect(context as T)}>
285
+ {label}
286
+ </DropdownMenu.Item>
287
+ ))}
288
+ </DropdownMenu.Viewport>
289
+ <DropdownMenu.Arrow />
290
+ </DropdownMenu.Content>
291
+ </DropdownMenu.Portal>
292
+ )}
293
+ </DropdownMenu.Root>
294
+ );
295
+ };
296
+
297
+ //
298
+ // Toolbar
299
+ //
300
+
147
301
  export const Toolbar = {
148
302
  Root: ToolbarRoot,
303
+ Text: ToolbarText,
149
304
  Button: ToolbarButton,
150
305
  IconButton: ToolbarIconButton,
151
306
  Link: ToolbarLink,
@@ -154,10 +309,14 @@ export const Toolbar = {
154
309
  ToggleGroupItem: ToolbarToggleGroupItem,
155
310
  ToggleGroupIconItem: ToolbarToggleGroupIconItem,
156
311
  Separator: ToolbarSeparator,
312
+ DragHandle: ToolbarDragHandle,
313
+ CloseIconButton: ToolbarCloseIconButton,
314
+ Menu: ToolbarMenu,
157
315
  };
158
316
 
159
317
  export type {
160
318
  ToolbarRootProps,
319
+ ToolbarTextProps,
161
320
  ToolbarButtonProps,
162
321
  ToolbarIconButtonProps,
163
322
  ToolbarLinkProps,
@@ -166,4 +325,8 @@ export type {
166
325
  ToolbarToggleGroupItemProps,
167
326
  ToolbarToggleGroupIconItemProps,
168
327
  ToolbarSeparatorProps,
328
+ ToolbarDragHandleProps,
329
+ ToolbarCloseIconButtonProps,
330
+ ToolbarMenuItem,
331
+ ToolbarMenuProps,
169
332
  };
@@ -5,35 +5,36 @@
5
5
  import { type Meta, type StoryObj } from '@storybook/react-vite';
6
6
  import React from 'react';
7
7
 
8
- import { faker } from '@dxos/random';
8
+ import { random } from '@dxos/random';
9
9
 
10
10
  import { withTheme } from '../../testing';
11
- import { Button } from '../Buttons';
12
-
11
+ import { Button } from '../Button';
13
12
  import { Tooltip } from './Tooltip';
14
13
 
15
- type StoryProps = {
14
+ type DefaultStoryProps = {
16
15
  tooltips: { label: string; content: string }[];
17
16
  defaultOpen?: boolean;
18
17
  };
19
18
 
20
- const DefaultStory = ({ tooltips, defaultOpen }: StoryProps) => (
21
- <Tooltip.Provider defaultOpen={defaultOpen}>
22
- <div role='none' className='is-32'>
23
- {tooltips.map(({ label, content }, i) => (
24
- <Tooltip.Trigger asChild key={i} content={content} side='right'>
25
- <Button classNames='block is-full'>{label}</Button>
26
- </Tooltip.Trigger>
27
- ))}
28
- </div>
29
- </Tooltip.Provider>
30
- );
19
+ const DefaultStory = ({ tooltips, defaultOpen }: DefaultStoryProps) => {
20
+ return (
21
+ <Tooltip.Provider defaultOpen={defaultOpen}>
22
+ <div role='none' className='w-32'>
23
+ {tooltips.map(({ label, content }, i) => (
24
+ <Tooltip.Trigger asChild key={i} content={content} side='right'>
25
+ <Button classNames='block w-full'>{label}</Button>
26
+ </Tooltip.Trigger>
27
+ ))}
28
+ </div>
29
+ </Tooltip.Provider>
30
+ );
31
+ };
31
32
 
32
33
  const meta = {
33
- title: 'ui/react-ui-core/Tooltip',
34
+ title: 'ui/react-ui-core/components/Tooltip',
34
35
  component: Tooltip as any,
35
36
  render: DefaultStory,
36
- decorators: [withTheme],
37
+ decorators: [withTheme()],
37
38
  } satisfies Meta<typeof DefaultStory>;
38
39
 
39
40
  export default meta;
@@ -72,10 +73,10 @@ export const DefaultOpen: Story = {
72
73
  export const StressTest: Story = {
73
74
  args: {
74
75
  defaultOpen: true,
75
- tooltips: faker.helpers.multiple(
76
+ tooltips: random.helpers.multiple(
76
77
  () => ({
77
- label: faker.lorem.words(2),
78
- content: faker.lorem.words(5),
78
+ label: random.lorem.words(2),
79
+ content: random.lorem.words(5),
79
80
  }),
80
81
  { count: 32 },
81
82
  ),
@@ -3,6 +3,7 @@
3
3
  //
4
4
 
5
5
  // This is based upon `@radix-ui/react-tooltip` fetched 17 March 2025 at https://github.com/radix-ui/primitives at commit 6e75e11.
6
+ // TODO(burdon): Replace with https://ui.shadcn.com/docs/components/radix/tooltip
6
7
 
7
8
  import { composeEventHandlers } from '@radix-ui/primitive';
8
9
  import { useComposedRefs } from '@radix-ui/react-compose-refs';
@@ -21,9 +22,8 @@ import { useControllableState } from '@radix-ui/react-use-controllable-state';
21
22
  import * as VisuallyHiddenPrimitive from '@radix-ui/react-visually-hidden';
22
23
  import React, {
23
24
  type ComponentPropsWithoutRef,
24
- type ElementRef,
25
+ type ComponentRef,
25
26
  type FC,
26
- type MutableRefObject,
27
27
  type ReactNode,
28
28
  type RefObject,
29
29
  type SyntheticEvent,
@@ -41,9 +41,9 @@ type TooltipScopedProps<P = {}> = P & { __scopeTooltip?: Scope };
41
41
  const [createTooltipContext, createTooltipScope] = createContextScope('Tooltip', [createPopperScope]);
42
42
  const usePopperScope = createPopperScope();
43
43
 
44
- /* -------------------------------------------------------------------------------------------------
45
- * Tooltip
46
- * ----------------------------------------------------------------------------------------------- */
44
+ //
45
+ // Tooltip
46
+ //
47
47
 
48
48
  const DEFAULT_DELAY_DURATION = 700;
49
49
  const TOOLTIP_OPEN = 'tooltip.open';
@@ -60,13 +60,13 @@ type TooltipContextValue = {
60
60
  onOpen(): void;
61
61
  onClose(): void;
62
62
  onPointerInTransitChange(inTransit: boolean): void;
63
- isPointerInTransitRef: MutableRefObject<boolean>;
63
+ isPointerInTransitRef: RefObject<boolean>;
64
64
  disableHoverableContent: boolean;
65
65
  };
66
66
 
67
67
  const [TooltipContextProvider, useTooltipContext] = createTooltipContext<TooltipContextValue>(TOOLTIP_NAME);
68
68
 
69
- interface TooltipProviderProps {
69
+ type TooltipProviderProps = {
70
70
  children?: ReactNode;
71
71
  open?: boolean;
72
72
  defaultOpen?: boolean;
@@ -87,7 +87,7 @@ interface TooltipProviderProps {
87
87
  * @defaultValue 300
88
88
  */
89
89
  skipDelayDuration?: number;
90
- }
90
+ };
91
91
 
92
92
  const TooltipProvider: FC<TooltipProviderProps> = (props: TooltipScopedProps<TooltipProviderProps>) => {
93
93
  const {
@@ -215,9 +215,9 @@ const TooltipProvider: FC<TooltipProviderProps> = (props: TooltipScopedProps<Too
215
215
  isPointerInTransitRef.current = inTransit;
216
216
  }, [])}
217
217
  >
218
- <TooltipContent side={side} className={tx('tooltip.content', 'tooltip', { elevation })}>
218
+ <TooltipContent side={side} className={tx('tooltip.content', { elevation })}>
219
219
  {content}
220
- <TooltipArrow className={tx('tooltip.arrow', 'tooltip__arrow')} />
220
+ <TooltipArrow className={tx('tooltip.arrow')} />
221
221
  </TooltipContent>
222
222
  <TooltipVirtualTrigger virtualRef={triggerRef as RefObject<HTMLButtonElement>} />
223
223
  {children}
@@ -228,9 +228,9 @@ const TooltipProvider: FC<TooltipProviderProps> = (props: TooltipScopedProps<Too
228
228
 
229
229
  TooltipProvider.displayName = TOOLTIP_NAME;
230
230
 
231
- /* -------------------------------------------------------------------------------------------------
232
- * TooltipVirtualTrigger
233
- * ----------------------------------------------------------------------------------------------- */
231
+ //
232
+ // TooltipVirtualTrigger
233
+ //
234
234
 
235
235
  const TooltipVirtualTrigger = ({
236
236
  virtualRef,
@@ -240,13 +240,13 @@ const TooltipVirtualTrigger = ({
240
240
  return <PopperPrimitive.Anchor asChild {...popperScope} virtualRef={virtualRef} />;
241
241
  };
242
242
 
243
- /* -------------------------------------------------------------------------------------------------
244
- * TooltipTrigger
245
- * ----------------------------------------------------------------------------------------------- */
243
+ //
244
+ // TooltipTrigger
245
+ //
246
246
 
247
247
  const TRIGGER_NAME = 'TooltipTrigger';
248
248
 
249
- type TooltipTriggerElement = ElementRef<typeof Primitive.button>;
249
+ type TooltipTriggerElement = ComponentRef<typeof Primitive.button>;
250
250
  type PrimitiveButtonProps = ComponentPropsWithoutRef<typeof Primitive.button>;
251
251
  type TooltipTriggerProps = PrimitiveButtonProps &
252
252
  Pick<TooltipProps, 'delayDuration'> & {
@@ -322,9 +322,9 @@ const TooltipTrigger = forwardRef<TooltipTriggerElement, TooltipTriggerProps>(
322
322
 
323
323
  TooltipTrigger.displayName = TRIGGER_NAME;
324
324
 
325
- /* -------------------------------------------------------------------------------------------------
326
- * TooltipPortal
327
- * ----------------------------------------------------------------------------------------------- */
325
+ //
326
+ // TooltipPortal
327
+ //
328
328
 
329
329
  const PORTAL_NAME = 'TooltipPortal';
330
330
 
@@ -334,7 +334,7 @@ const [PortalProvider, usePortalContext] = createTooltipContext<PortalContextVal
334
334
  });
335
335
 
336
336
  type PortalProps = ComponentPropsWithoutRef<typeof PortalPrimitive>;
337
- interface TooltipPortalProps {
337
+ type TooltipPortalProps = {
338
338
  children?: ReactNode;
339
339
  /**
340
340
  * Specify a container element to portal the content into.
@@ -345,7 +345,7 @@ interface TooltipPortalProps {
345
345
  * controlling animation with React animation libraries.
346
346
  */
347
347
  forceMount?: true;
348
- }
348
+ };
349
349
 
350
350
  const TooltipPortal: FC<TooltipPortalProps> = (props: TooltipScopedProps<TooltipPortalProps>) => {
351
351
  const { __scopeTooltip, forceMount, children, container } = props;
@@ -363,20 +363,20 @@ const TooltipPortal: FC<TooltipPortalProps> = (props: TooltipScopedProps<Tooltip
363
363
 
364
364
  TooltipPortal.displayName = PORTAL_NAME;
365
365
 
366
- /* -------------------------------------------------------------------------------------------------
367
- * TooltipContent
368
- * ----------------------------------------------------------------------------------------------- */
366
+ //
367
+ // TooltipContent
368
+ //
369
369
 
370
370
  const CONTENT_NAME = 'TooltipContent';
371
371
 
372
372
  type TooltipContentElement = TooltipContentImplElement;
373
- interface TooltipContentProps extends TooltipContentImplProps {
373
+ type TooltipContentProps = TooltipContentImplProps & {
374
374
  /**
375
375
  * Used to force mounting when more control is needed. Useful when
376
376
  * controlling animation with React animation libraries.
377
377
  */
378
378
  forceMount?: true;
379
- }
379
+ };
380
380
 
381
381
  const TooltipContent = forwardRef<TooltipContentElement, TooltipContentProps>(
382
382
  (props: TooltipScopedProps<TooltipContentProps>, forwardedRef) => {
@@ -400,7 +400,7 @@ type Point = { x: number; y: number };
400
400
  type Polygon = Point[];
401
401
 
402
402
  type TooltipContentHoverableElement = TooltipContentImplElement;
403
- interface TooltipContentHoverableProps extends TooltipContentImplProps {}
403
+ type TooltipContentHoverableProps = TooltipContentImplProps;
404
404
 
405
405
  const TooltipContentHoverable = forwardRef<TooltipContentHoverableElement, TooltipContentHoverableProps>(
406
406
  (props: TooltipScopedProps<TooltipContentHoverableProps>, forwardedRef) => {
@@ -479,10 +479,10 @@ const [VisuallyHiddenContentContextProvider, useVisuallyHiddenContentContext] =
479
479
  isInside: false,
480
480
  });
481
481
 
482
- type TooltipContentImplElement = ElementRef<typeof PopperPrimitive.Content>;
482
+ type TooltipContentImplElement = ComponentRef<typeof PopperPrimitive.Content>;
483
483
  type DismissableLayerProps = ComponentPropsWithoutRef<typeof DismissableLayer>;
484
484
  type PopperContentProps = ComponentPropsWithoutRef<typeof PopperPrimitive.Content>;
485
- interface TooltipContentImplProps extends Omit<PopperContentProps, 'onPlaced'> {
485
+ type TooltipContentImplProps = Omit<PopperContentProps, 'onPlaced'> & {
486
486
  /**
487
487
  * A more descriptive label for accessibility purpose
488
488
  */
@@ -498,7 +498,7 @@ interface TooltipContentImplProps extends Omit<PopperContentProps, 'onPlaced'> {
498
498
  * Can be prevented.
499
499
  */
500
500
  onPointerDownOutside?: DismissableLayerProps['onPointerDownOutside'];
501
- }
501
+ };
502
502
 
503
503
  const TooltipContentImpl = forwardRef<TooltipContentImplElement, TooltipContentImplProps>(
504
504
  (props: TooltipScopedProps<TooltipContentImplProps>, forwardedRef) => {
@@ -574,15 +574,15 @@ const TooltipContentImpl = forwardRef<TooltipContentImplElement, TooltipContentI
574
574
 
575
575
  TooltipContent.displayName = CONTENT_NAME;
576
576
 
577
- /* -------------------------------------------------------------------------------------------------
578
- * TooltipArrow
579
- * ----------------------------------------------------------------------------------------------- */
577
+ //
578
+ // TooltipArrow
579
+ //
580
580
 
581
581
  const ARROW_NAME = 'TooltipArrow';
582
582
 
583
- type TooltipArrowElement = ElementRef<typeof PopperPrimitive.Arrow>;
583
+ type TooltipArrowElement = ComponentRef<typeof PopperPrimitive.Arrow>;
584
584
  type PopperArrowProps = ComponentPropsWithoutRef<typeof PopperPrimitive.Arrow>;
585
- interface TooltipArrowProps extends PopperArrowProps {}
585
+ type TooltipArrowProps = PopperArrowProps;
586
586
 
587
587
  const TooltipArrow = forwardRef<TooltipArrowElement, TooltipArrowProps>(
588
588
  (props: TooltipScopedProps<TooltipArrowProps>, forwardedRef) => {
@@ -599,8 +599,6 @@ const TooltipArrow = forwardRef<TooltipArrowElement, TooltipArrowProps>(
599
599
 
600
600
  TooltipArrow.displayName = ARROW_NAME;
601
601
 
602
- /* ----------------------------------------------------------------------------------------------- */
603
-
604
602
  type TooltipSide = NonNullable<TooltipContentProps['side']>;
605
603
 
606
604
  const getExitSideFromRect = (point: Point, rect: DOMRect): TooltipSide => {
@@ -755,6 +753,10 @@ const getHullPresorted = <P extends Point>(points: Readonly<Array<P>>): Array<P>
755
753
  }
756
754
  };
757
755
 
756
+ //
757
+ // Tooltip
758
+ //
759
+
758
760
  export const Tooltip = {
759
761
  Provider: TooltipProvider,
760
762
  Trigger: TooltipTrigger,
@@ -2,29 +2,35 @@
2
2
  // Copyright 2022 DXOS.org
3
3
  //
4
4
 
5
- export * from './AnchoredOverflow';
5
+ export * from './DensityProvider';
6
+ export * from './ElevationProvider';
7
+ export * from './ThemeProvider';
8
+
6
9
  export * from './Avatars';
7
10
  export * from './Breadcrumb';
8
- export * from './Buttons';
11
+ export * from './Button';
12
+ export * from './Card';
9
13
  export * from './Clipboard';
10
- export * from './Dialogs';
14
+ export * from './Dialog';
15
+ export * from './ErrorFallback';
16
+ export * from './Focus';
11
17
  export * from './Icon';
18
+ export * from './Image';
12
19
  export * from './Input';
13
20
  export * from './Link';
14
- export * from './Lists';
21
+ export * from './List';
15
22
  export * from './Main';
16
- export * from './Menus';
23
+ export * from './Menu';
17
24
  export * from './Message';
18
25
  export * from './Popover';
19
26
  export * from './Status';
20
27
  export * from './ScrollArea';
28
+ export * from './ScrollContainer';
21
29
  export * from './Select';
22
30
  export * from './Separator';
31
+ export * from './Skeleton';
32
+ export * from './Splitter';
23
33
  export * from './Tag';
24
34
  export * from './Toast';
25
35
  export * from './Toolbar';
26
36
  export * from './Tooltip';
27
-
28
- export * from './DensityProvider';
29
- export * from './ElevationProvider';
30
- export * from './ThemeProvider';