@dxos/react-ui 0.8.4-main.d05673bc65 → 0.8.4-main.dfabb4ec29

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 (290) hide show
  1. package/dist/lib/browser/{chunk-2FKSMWNY.mjs → chunk-BDBC6H6V.mjs} +79 -5
  2. package/dist/lib/browser/chunk-BDBC6H6V.mjs.map +7 -0
  3. package/dist/lib/browser/index.mjs +949 -758
  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 +30 -24
  7. package/dist/lib/browser/testing/index.mjs.map +3 -3
  8. package/dist/lib/browser/translations.mjs +18 -0
  9. package/dist/lib/browser/translations.mjs.map +7 -0
  10. package/dist/lib/node-esm/{chunk-ZNBLTSHI.mjs → chunk-3JSJK2ZY.mjs} +79 -5
  11. package/dist/lib/node-esm/chunk-3JSJK2ZY.mjs.map +7 -0
  12. package/dist/lib/node-esm/index.mjs +949 -758
  13. package/dist/lib/node-esm/index.mjs.map +4 -4
  14. package/dist/lib/node-esm/meta.json +1 -1
  15. package/dist/lib/node-esm/testing/index.mjs +30 -24
  16. package/dist/lib/node-esm/testing/index.mjs.map +3 -3
  17. package/dist/lib/node-esm/translations.mjs +20 -0
  18. package/dist/lib/node-esm/translations.mjs.map +7 -0
  19. package/dist/types/src/components/Avatars/Avatar.d.ts +1 -1
  20. package/dist/types/src/components/Avatars/Avatar.d.ts.map +1 -1
  21. package/dist/types/src/components/Avatars/Avatar.stories.d.ts.map +1 -1
  22. package/dist/types/src/components/Avatars/AvatarGroup.stories.d.ts.map +1 -1
  23. package/dist/types/src/components/Breadcrumb/Breadcrumb.d.ts.map +1 -1
  24. package/dist/types/src/components/Breadcrumb/Breadcrumb.stories.d.ts.map +1 -1
  25. package/dist/types/src/components/Button/Button.d.ts +2 -2
  26. package/dist/types/src/components/Button/Button.d.ts.map +1 -1
  27. package/dist/types/src/components/Button/Button.stories.d.ts +1 -1
  28. package/dist/types/src/components/Button/Button.stories.d.ts.map +1 -1
  29. package/dist/types/src/components/Button/IconButton.d.ts +1 -0
  30. package/dist/types/src/components/Button/IconButton.d.ts.map +1 -1
  31. package/dist/types/src/components/Button/IconButton.stories.d.ts +3 -0
  32. package/dist/types/src/components/Button/IconButton.stories.d.ts.map +1 -1
  33. package/dist/types/src/components/Button/Toggle.d.ts +2 -2
  34. package/dist/types/src/components/Button/Toggle.d.ts.map +1 -1
  35. package/dist/types/src/components/Button/Toggle.stories.d.ts.map +1 -1
  36. package/dist/types/src/components/Button/ToggleGroup.d.ts +6 -6
  37. package/dist/types/src/components/Button/ToggleGroup.d.ts.map +1 -1
  38. package/dist/types/src/components/Button/ToggleGroup.stories.d.ts +2 -2
  39. package/dist/types/src/components/Button/ToggleGroup.stories.d.ts.map +1 -1
  40. package/dist/types/src/components/Card/Card.d.ts +68 -51
  41. package/dist/types/src/components/Card/Card.d.ts.map +1 -1
  42. package/dist/types/src/components/Card/Card.stories.d.ts +2 -2
  43. package/dist/types/src/components/Card/Card.stories.d.ts.map +1 -1
  44. package/dist/types/src/components/Clipboard/ClipboardProvider.d.ts.map +1 -1
  45. package/dist/types/src/components/Clipboard/CopyButton.d.ts.map +1 -1
  46. package/dist/types/src/components/Clipboard/index.d.ts +10 -1
  47. package/dist/types/src/components/Clipboard/index.d.ts.map +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 +42 -31
  50. package/dist/types/src/components/Dialog/AlertDialog.d.ts.map +1 -1
  51. package/dist/types/src/components/Dialog/AlertDialog.stories.d.ts.map +1 -1
  52. package/dist/types/src/components/Dialog/Dialog.d.ts +47 -30
  53. package/dist/types/src/components/Dialog/Dialog.d.ts.map +1 -1
  54. package/dist/types/src/components/Dialog/Dialog.stories.d.ts +3 -2
  55. package/dist/types/src/components/Dialog/Dialog.stories.d.ts.map +1 -1
  56. package/dist/types/src/components/ElevationProvider/ElevationProvider.d.ts.map +1 -1
  57. package/dist/types/src/components/ErrorFallback/ErrorFallback.d.ts.map +1 -1
  58. package/dist/types/src/components/ErrorFallback/ErrorFallback.stories.d.ts.map +1 -1
  59. package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts +14 -3
  60. package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts.map +1 -1
  61. package/dist/types/src/components/ErrorFallback/ThrowError.d.ts.map +1 -1
  62. package/dist/types/src/components/Focus/Focus.d.ts +36 -0
  63. package/dist/types/src/components/Focus/Focus.d.ts.map +1 -0
  64. package/dist/types/src/components/Focus/Focus.stories.d.ts +9 -0
  65. package/dist/types/src/components/Focus/Focus.stories.d.ts.map +1 -0
  66. package/dist/types/src/components/Focus/index.d.ts +2 -0
  67. package/dist/types/src/components/Focus/index.d.ts.map +1 -0
  68. package/dist/types/src/components/Icon/Icon.d.ts +4 -0
  69. package/dist/types/src/components/Icon/Icon.d.ts.map +1 -1
  70. package/dist/types/src/components/Icon/Icon.stories.d.ts +11 -3
  71. package/dist/types/src/components/Icon/Icon.stories.d.ts.map +1 -1
  72. package/dist/types/src/components/Image/Image.d.ts +2 -1
  73. package/dist/types/src/components/Image/Image.d.ts.map +1 -1
  74. package/dist/types/src/components/Image/Image.stories.d.ts +3 -2
  75. package/dist/types/src/components/Image/Image.stories.d.ts.map +1 -1
  76. package/dist/types/src/components/Input/Input.d.ts +14 -17
  77. package/dist/types/src/components/Input/Input.d.ts.map +1 -1
  78. package/dist/types/src/components/Input/Input.stories.d.ts +3 -3
  79. package/dist/types/src/components/Input/Input.stories.d.ts.map +1 -1
  80. package/dist/types/src/components/Link/Link.stories.d.ts.map +1 -1
  81. package/dist/types/src/components/List/List.d.ts +5 -3
  82. package/dist/types/src/components/List/List.d.ts.map +1 -1
  83. package/dist/types/src/components/List/List.stories.d.ts +3 -1
  84. package/dist/types/src/components/List/List.stories.d.ts.map +1 -1
  85. package/dist/types/src/components/List/ListDropIndicator.d.ts.map +1 -1
  86. package/dist/types/src/components/List/Tree.d.ts +2 -2
  87. package/dist/types/src/components/List/Tree.d.ts.map +1 -1
  88. package/dist/types/src/components/List/Tree.stories.d.ts.map +1 -1
  89. package/dist/types/src/components/List/TreeDropIndicator.d.ts.map +1 -1
  90. package/dist/types/src/components/List/Treegrid.d.ts +5 -9
  91. package/dist/types/src/components/List/Treegrid.d.ts.map +1 -1
  92. package/dist/types/src/components/List/Treegrid.stories.d.ts.map +1 -1
  93. package/dist/types/src/components/Main/Main.d.ts +7 -3
  94. package/dist/types/src/components/Main/Main.d.ts.map +1 -1
  95. package/dist/types/src/components/Main/Main.stories.d.ts.map +1 -1
  96. package/dist/types/src/components/Main/useSwipeToDismiss.d.ts.map +1 -1
  97. package/dist/types/src/components/Menu/ContextMenu.d.ts.map +1 -1
  98. package/dist/types/src/components/Menu/ContextMenu.stories.d.ts.map +1 -1
  99. package/dist/types/src/components/Menu/DropdownMenu.d.ts +58 -49
  100. package/dist/types/src/components/Menu/DropdownMenu.d.ts.map +1 -1
  101. package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts +14 -1
  102. package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts.map +1 -1
  103. package/dist/types/src/components/Message/Message.d.ts +1 -1
  104. package/dist/types/src/components/Message/Message.d.ts.map +1 -1
  105. package/dist/types/src/components/Message/Message.stories.d.ts +2 -2
  106. package/dist/types/src/components/Message/Message.stories.d.ts.map +1 -1
  107. package/dist/types/src/components/Popover/Popover.d.ts +38 -22
  108. package/dist/types/src/components/Popover/Popover.d.ts.map +1 -1
  109. package/dist/types/src/components/Popover/Popover.stories.d.ts.map +1 -1
  110. package/dist/types/src/components/ScrollArea/ScrollArea.d.ts +12 -9
  111. package/dist/types/src/components/ScrollArea/ScrollArea.d.ts.map +1 -1
  112. package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts +18 -5
  113. package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts.map +1 -1
  114. package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts +42 -13
  115. package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts.map +1 -1
  116. package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts +5 -6
  117. package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts.map +1 -1
  118. package/dist/types/src/components/Select/Select.d.ts.map +1 -1
  119. package/dist/types/src/components/Select/Select.stories.d.ts +2 -2
  120. package/dist/types/src/components/Select/Select.stories.d.ts.map +1 -1
  121. package/dist/types/src/components/Separator/Separator.d.ts +3 -3
  122. package/dist/types/src/components/Separator/Separator.d.ts.map +1 -1
  123. package/dist/types/src/components/Skeleton/Skeleton.stories.d.ts.map +1 -1
  124. package/dist/types/src/components/Splitter/Splitter.d.ts +19 -17
  125. package/dist/types/src/components/Splitter/Splitter.d.ts.map +1 -1
  126. package/dist/types/src/components/Splitter/Splitter.stories.d.ts.map +1 -1
  127. package/dist/types/src/components/Status/Status.d.ts +3 -4
  128. package/dist/types/src/components/Status/Status.d.ts.map +1 -1
  129. package/dist/types/src/components/Status/Status.stories.d.ts.map +1 -1
  130. package/dist/types/src/components/Tag/Tag.stories.d.ts.map +1 -1
  131. package/dist/types/src/components/ThemeProvider/ThemeProvider.d.ts +1 -1
  132. package/dist/types/src/components/ThemeProvider/ThemeProvider.d.ts.map +1 -1
  133. package/dist/types/src/components/ThemeProvider/ThemeProvider.stories.d.ts +1 -1
  134. package/dist/types/src/components/ThemeProvider/ThemeProvider.stories.d.ts.map +1 -1
  135. package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts +54 -55
  136. package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts.map +1 -1
  137. package/dist/types/src/components/ThemeProvider/index.d.ts +1 -1
  138. package/dist/types/src/components/ThemeProvider/index.d.ts.map +1 -1
  139. package/dist/types/src/components/Toast/Toast.d.ts +16 -16
  140. package/dist/types/src/components/Toast/Toast.d.ts.map +1 -1
  141. package/dist/types/src/components/Toast/Toast.stories.d.ts.map +1 -1
  142. package/dist/types/src/components/Toolbar/Toolbar.d.ts +11 -19
  143. package/dist/types/src/components/Toolbar/Toolbar.d.ts.map +1 -1
  144. package/dist/types/src/components/Toolbar/Toolbar.stories.d.ts.map +1 -1
  145. package/dist/types/src/components/Tooltip/Tooltip.d.ts +10 -10
  146. package/dist/types/src/components/Tooltip/Tooltip.d.ts.map +1 -1
  147. package/dist/types/src/components/Tooltip/Tooltip.stories.d.ts +2 -2
  148. package/dist/types/src/components/Tooltip/Tooltip.stories.d.ts.map +1 -1
  149. package/dist/types/src/components/index.d.ts +1 -0
  150. package/dist/types/src/components/index.d.ts.map +1 -1
  151. package/dist/types/src/exemplars/generics.stories.d.ts +6 -5
  152. package/dist/types/src/exemplars/generics.stories.d.ts.map +1 -1
  153. package/dist/types/src/exemplars/slot.stories.d.ts +1 -0
  154. package/dist/types/src/exemplars/slot.stories.d.ts.map +1 -1
  155. package/dist/types/src/exemplars/tabster.stories.d.ts.map +1 -1
  156. package/dist/types/src/exemplars/virtualizer.stories.d.ts.map +1 -1
  157. package/dist/types/src/hooks/index.d.ts +1 -0
  158. package/dist/types/src/hooks/index.d.ts.map +1 -1
  159. package/dist/types/src/hooks/useDensityContext.d.ts +1 -1
  160. package/dist/types/src/hooks/useDensityContext.d.ts.map +1 -1
  161. package/dist/types/src/hooks/useElevationContext.d.ts.map +1 -1
  162. package/dist/types/src/hooks/useIconHref.d.ts.map +1 -1
  163. package/dist/types/src/hooks/useSafeArea.d.ts.map +1 -1
  164. package/dist/types/src/hooks/useSafeCollisionPadding.d.ts.map +1 -1
  165. package/dist/types/src/hooks/useVisualViewport.d.ts.map +1 -1
  166. package/dist/types/src/playground/Controls.stories.d.ts.map +1 -1
  167. package/dist/types/src/playground/Custom.stories.d.ts +1 -1
  168. package/dist/types/src/playground/Custom.stories.d.ts.map +1 -1
  169. package/dist/types/src/playground/Typography.stories.d.ts.map +1 -1
  170. package/dist/types/src/primitives/Column/Column.d.ts +21 -14
  171. package/dist/types/src/primitives/Column/Column.d.ts.map +1 -1
  172. package/dist/types/src/primitives/Column/Column.stories.d.ts +19 -0
  173. package/dist/types/src/primitives/Column/Column.stories.d.ts.map +1 -1
  174. package/dist/types/src/primitives/Container/Container.d.ts +4 -5
  175. package/dist/types/src/primitives/Container/Container.d.ts.map +1 -1
  176. package/dist/types/src/primitives/Container/Container.stories.d.ts.map +1 -1
  177. package/dist/types/src/primitives/Flex/Flex.d.ts +5 -7
  178. package/dist/types/src/primitives/Flex/Flex.d.ts.map +1 -1
  179. package/dist/types/src/primitives/Flex/Flex.stories.d.ts.map +1 -1
  180. package/dist/types/src/primitives/Grid/Grid.d.ts +3 -8
  181. package/dist/types/src/primitives/Grid/Grid.d.ts.map +1 -1
  182. package/dist/types/src/primitives/Grid/Grid.stories.d.ts.map +1 -1
  183. package/dist/types/src/primitives/Panel/Panel.d.ts +24 -15
  184. package/dist/types/src/primitives/Panel/Panel.d.ts.map +1 -1
  185. package/dist/types/src/primitives/Panel/Panel.stories.d.ts.map +1 -1
  186. package/dist/types/src/testing/Loading.d.ts.map +1 -1
  187. package/dist/types/src/testing/decorators/withLayout.d.ts.map +1 -1
  188. package/dist/types/src/testing/decorators/withLayoutVariants.d.ts.map +1 -1
  189. package/dist/types/src/testing/decorators/withTheme.d.ts +1 -1
  190. package/dist/types/src/testing/decorators/withTheme.d.ts.map +1 -1
  191. package/dist/types/src/translations.d.ts +3 -3
  192. package/dist/types/src/translations.d.ts.map +1 -1
  193. package/dist/types/src/util/usePx.d.ts.map +1 -1
  194. package/dist/types/tsconfig.tsbuildinfo +1 -1
  195. package/package.json +28 -25
  196. package/src/components/Avatars/Avatar.stories.tsx +2 -3
  197. package/src/components/Avatars/Avatar.tsx +1 -2
  198. package/src/components/Avatars/AvatarGroup.stories.tsx +0 -1
  199. package/src/components/Breadcrumb/Breadcrumb.stories.tsx +1 -2
  200. package/src/components/Button/Button.stories.tsx +0 -1
  201. package/src/components/Button/Button.tsx +5 -13
  202. package/src/components/Button/IconButton.stories.tsx +6 -4
  203. package/src/components/Button/IconButton.tsx +3 -4
  204. package/src/components/Button/Toggle.stories.tsx +0 -1
  205. package/src/components/Button/Toggle.tsx +4 -4
  206. package/src/components/Button/ToggleGroup.stories.tsx +0 -1
  207. package/src/components/Button/ToggleGroup.tsx +12 -16
  208. package/src/components/Card/Card.stories.tsx +15 -15
  209. package/src/components/Card/Card.tsx +280 -115
  210. package/src/components/Clipboard/CopyButton.tsx +5 -6
  211. package/src/components/Dialog/AlertDialog.stories.tsx +5 -6
  212. package/src/components/Dialog/AlertDialog.tsx +67 -126
  213. package/src/components/Dialog/Dialog.stories.tsx +64 -9
  214. package/src/components/Dialog/Dialog.tsx +84 -88
  215. package/src/components/ErrorFallback/ErrorFallback.stories.tsx +3 -8
  216. package/src/components/ErrorFallback/ErrorStack.tsx +36 -2
  217. package/src/components/Focus/AUDIT.md +43 -0
  218. package/src/components/Focus/Focus.stories.tsx +230 -0
  219. package/src/components/Focus/Focus.tsx +201 -0
  220. package/src/components/Focus/index.ts +5 -0
  221. package/src/components/Icon/Icon.stories.tsx +43 -13
  222. package/src/components/Icon/Icon.tsx +14 -3
  223. package/src/components/Image/Image.stories.tsx +3 -3
  224. package/src/components/Image/Image.tsx +31 -8
  225. package/src/components/Input/Input.stories.tsx +3 -4
  226. package/src/components/Input/Input.tsx +7 -7
  227. package/src/components/Link/Link.stories.tsx +0 -1
  228. package/src/components/List/List.stories.tsx +1 -2
  229. package/src/components/List/List.tsx +7 -6
  230. package/src/components/List/ListDropIndicator.tsx +0 -1
  231. package/src/components/List/Tree.stories.tsx +2 -3
  232. package/src/components/List/Tree.tsx +0 -1
  233. package/src/components/List/Treegrid.stories.tsx +26 -27
  234. package/src/components/List/Treegrid.tsx +14 -14
  235. package/src/components/Main/Main.stories.tsx +0 -1
  236. package/src/components/Main/Main.tsx +1 -2
  237. package/src/components/Menu/ContextMenu.stories.tsx +0 -1
  238. package/src/components/Menu/DropdownMenu.stories.tsx +0 -1
  239. package/src/components/Menu/DropdownMenu.tsx +48 -42
  240. package/src/components/Message/Message.stories.tsx +7 -8
  241. package/src/components/Message/Message.tsx +23 -10
  242. package/src/components/Popover/Popover.stories.tsx +4 -5
  243. package/src/components/Popover/Popover.tsx +42 -42
  244. package/src/components/ScrollArea/ScrollArea.stories.tsx +89 -30
  245. package/src/components/ScrollArea/ScrollArea.tsx +39 -23
  246. package/src/components/ScrollContainer/ScrollContainer.stories.tsx +20 -18
  247. package/src/components/ScrollContainer/ScrollContainer.tsx +199 -92
  248. package/src/components/Select/Select.stories.tsx +5 -6
  249. package/src/components/Separator/Separator.tsx +4 -7
  250. package/src/components/Skeleton/Skeleton.stories.tsx +0 -1
  251. package/src/components/Splitter/Splitter.stories.tsx +29 -29
  252. package/src/components/Splitter/Splitter.tsx +35 -34
  253. package/src/components/Status/Status.stories.tsx +0 -1
  254. package/src/components/Status/Status.tsx +8 -5
  255. package/src/components/Tag/Tag.stories.tsx +0 -1
  256. package/src/components/ThemeProvider/ThemeProvider.stories.tsx +0 -1
  257. package/src/components/ThemeProvider/ThemeProvider.tsx +5 -4
  258. package/src/components/ThemeProvider/index.ts +1 -1
  259. package/src/components/Toast/Toast.stories.tsx +0 -1
  260. package/src/components/Toast/Toast.tsx +16 -31
  261. package/src/components/Toolbar/Toolbar.stories.tsx +0 -1
  262. package/src/components/Toolbar/Toolbar.tsx +21 -35
  263. package/src/components/Tooltip/Tooltip.stories.tsx +7 -8
  264. package/src/components/Tooltip/Tooltip.tsx +15 -16
  265. package/src/components/index.ts +1 -0
  266. package/src/exemplars/generics.stories.tsx +7 -15
  267. package/src/exemplars/slot.stories.tsx +65 -57
  268. package/src/exemplars/tabster.stories.tsx +1 -1
  269. package/src/exemplars/virtualizer.stories.tsx +4 -5
  270. package/src/hooks/index.ts +1 -0
  271. package/src/hooks/useDensityContext.ts +2 -2
  272. package/src/playground/Custom.stories.tsx +6 -9
  273. package/src/primitives/Column/AUDIT.md +148 -0
  274. package/src/primitives/Column/Column.stories.tsx +122 -19
  275. package/src/primitives/Column/Column.tsx +73 -42
  276. package/src/primitives/Container/Container.stories.tsx +0 -1
  277. package/src/primitives/Container/Container.tsx +5 -8
  278. package/src/primitives/Flex/Flex.stories.tsx +0 -1
  279. package/src/primitives/Flex/Flex.tsx +10 -12
  280. package/src/primitives/Grid/Grid.stories.tsx +0 -1
  281. package/src/primitives/Grid/Grid.tsx +4 -9
  282. package/src/primitives/Panel/Panel.stories.tsx +9 -8
  283. package/src/primitives/Panel/Panel.tsx +64 -63
  284. package/src/testing/Loading.tsx +25 -4
  285. package/src/testing/decorators/withLayout.tsx +7 -17
  286. package/src/testing/decorators/withTheme.tsx +10 -7
  287. package/src/translations.ts +3 -3
  288. package/src/util/usePx.ts +1 -0
  289. package/dist/lib/browser/chunk-2FKSMWNY.mjs.map +0 -7
  290. package/dist/lib/node-esm/chunk-ZNBLTSHI.mjs.map +0 -7
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dxos/react-ui",
3
- "version": "0.8.4-main.d05673bc65",
3
+ "version": "0.8.4-main.dfabb4ec29",
4
4
  "description": "Low-level React components for DXOS, applying a theme to a core group of primitives",
5
5
  "homepage": "https://dxos.org",
6
6
  "bugs": "https://github.com/dxos/dxos/issues",
@@ -12,6 +12,9 @@
12
12
  "author": "DXOS.org",
13
13
  "sideEffects": false,
14
14
  "type": "module",
15
+ "imports": {
16
+ "#translations": "./src/translations.ts"
17
+ },
15
18
  "exports": {
16
19
  ".": {
17
20
  "source": "./src/index.ts",
@@ -24,16 +27,15 @@
24
27
  "browser": "./dist/lib/browser/testing/index.mjs",
25
28
  "node": "./dist/lib/node-esm/testing/index.mjs",
26
29
  "types": "./dist/types/src/testing/index.d.ts"
30
+ },
31
+ "./translations": {
32
+ "source": "./src/translations.ts",
33
+ "types": "./dist/types/src/translations.d.ts",
34
+ "browser": "./dist/lib/browser/translations.mjs",
35
+ "node": "./dist/lib/node-esm/translations.mjs"
27
36
  }
28
37
  },
29
38
  "types": "dist/types/src/index.d.ts",
30
- "typesVersions": {
31
- "*": {
32
- "testing": [
33
- "./dist/types/src/testing/index.d.ts"
34
- ]
35
- }
36
- },
37
39
  "files": [
38
40
  "dist",
39
41
  "src"
@@ -73,24 +75,25 @@
73
75
  "@radix-ui/react-use-controllable-state": "1.1.0",
74
76
  "@radix-ui/react-visually-hidden": "1.1.2",
75
77
  "aria-hidden": "^1.2.4",
76
- "date-fns": "^3.3.1",
78
+ "date-fns": "^3.6.0",
79
+ "dompurify": "^3.3.1",
77
80
  "error-stack-parser": "^2.1.4",
78
81
  "i18next": "^21.10.0",
79
82
  "keyborg": "^2.5.0",
80
83
  "react-error-boundary": "^4.0.13",
81
84
  "react-i18next": "^11.18.6",
82
85
  "react-remove-scroll": "^2.6.0",
83
- "@dxos/debug": "0.8.4-main.d05673bc65",
84
- "@dxos/invariant": "0.8.4-main.d05673bc65",
85
- "@dxos/lit-ui": "0.8.4-main.d05673bc65",
86
- "@dxos/react-error-boundary": "0.8.4-main.d05673bc65",
87
- "@dxos/async": "0.8.4-main.d05673bc65",
88
- "@dxos/log": "0.8.4-main.d05673bc65",
89
- "@dxos/react-hooks": "0.8.4-main.d05673bc65",
90
- "@dxos/react-input": "0.8.4-main.d05673bc65",
91
- "@dxos/react-list": "0.8.4-main.d05673bc65",
92
- "@dxos/ui-types": "0.8.4-main.d05673bc65",
93
- "@dxos/util": "0.8.4-main.d05673bc65"
86
+ "@dxos/async": "0.8.4-main.dfabb4ec29",
87
+ "@dxos/debug": "0.8.4-main.dfabb4ec29",
88
+ "@dxos/lit-ui": "0.8.4-main.dfabb4ec29",
89
+ "@dxos/log": "0.8.4-main.dfabb4ec29",
90
+ "@dxos/invariant": "0.8.4-main.dfabb4ec29",
91
+ "@dxos/react-error-boundary": "0.8.4-main.dfabb4ec29",
92
+ "@dxos/react-input": "0.8.4-main.dfabb4ec29",
93
+ "@dxos/ui-types": "0.8.4-main.dfabb4ec29",
94
+ "@dxos/util": "0.8.4-main.dfabb4ec29",
95
+ "@dxos/react-list": "0.8.4-main.dfabb4ec29",
96
+ "@dxos/react-hooks": "0.8.4-main.dfabb4ec29"
94
97
  },
95
98
  "devDependencies": {
96
99
  "@dnd-kit/core": "^6.0.5",
@@ -103,15 +106,15 @@
103
106
  "react": "~19.2.3",
104
107
  "react-dom": "~19.2.3",
105
108
  "tabster": "^8.5.5",
106
- "vite": "^7.1.11",
107
- "@dxos/random": "0.8.4-main.d05673bc65",
108
- "@dxos/util": "0.8.4-main.d05673bc65",
109
- "@dxos/ui-theme": "0.8.4-main.d05673bc65"
109
+ "vite": "^8.0.10",
110
+ "@dxos/ui-theme": "0.8.4-main.dfabb4ec29",
111
+ "@dxos/util": "0.8.4-main.dfabb4ec29",
112
+ "@dxos/random": "0.8.4-main.dfabb4ec29"
110
113
  },
111
114
  "peerDependencies": {
112
115
  "react": "~19.2.3",
113
116
  "react-dom": "~19.2.3",
114
- "@dxos/ui-theme": "0.8.4-main.d05673bc65"
117
+ "@dxos/ui-theme": "0.8.4-main.dfabb4ec29"
115
118
  },
116
119
  "publishConfig": {
117
120
  "access": "public"
@@ -9,10 +9,9 @@ import { type ChromaticPalette, type Size } from '@dxos/ui-types';
9
9
  import { hexToFallback } from '@dxos/util';
10
10
 
11
11
  import { withTheme } from '../../testing';
12
-
13
12
  import { Avatar, type AvatarAnimation, type AvatarStatus, type AvatarVariant } from './Avatar';
14
13
 
15
- type StoryProps = PropsWithChildren<{
14
+ type DefaultStoryProps = PropsWithChildren<{
16
15
  id?: string;
17
16
  imgSrc?: string;
18
17
  fallbackText?: string;
@@ -25,7 +24,7 @@ type StoryProps = PropsWithChildren<{
25
24
  hue?: ChromaticPalette;
26
25
  }>;
27
26
 
28
- const DefaultStory = (props: StoryProps) => {
27
+ const DefaultStory = (props: DefaultStoryProps) => {
29
28
  const {
30
29
  id = '20970b563fc49b5bb194a6ffdff376031a3a11f9481360c071c3fed87874106b',
31
30
  status,
@@ -2,13 +2,12 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import '@dxos/lit-ui/dx-avatar.pcss';
6
-
7
5
  import { createContext } from '@radix-ui/react-context';
8
6
  import { Primitive } from '@radix-ui/react-primitive';
9
7
  import { Slot } from '@radix-ui/react-slot';
10
8
  import React, { type ComponentProps, type ComponentPropsWithRef, type PropsWithChildren, forwardRef } from 'react';
11
9
 
10
+ import '@dxos/lit-ui/dx-avatar.pcss';
12
11
  import {
13
12
  type AvatarAnimation,
14
13
  type AvatarStatus,
@@ -9,7 +9,6 @@ import { useId } from '@dxos/react-hooks';
9
9
  import { toEmoji } from '@dxos/util';
10
10
 
11
11
  import { withTheme } from '../../testing';
12
-
13
12
  import { Avatar } from './Avatar';
14
13
 
15
14
  const hues = ['lime', 'teal', 'purple', 'pink'];
@@ -7,7 +7,6 @@ import React from 'react';
7
7
 
8
8
  import { withTheme } from '../../testing';
9
9
  import { Button } from '../Button';
10
-
11
10
  import { Breadcrumb, type BreadcrumbRootProps } from './Breadcrumb';
12
11
 
13
12
  const DefaultStory = (props: BreadcrumbRootProps) => {
@@ -16,7 +15,7 @@ const DefaultStory = (props: BreadcrumbRootProps) => {
16
15
  <Breadcrumb.List>
17
16
  <Breadcrumb.ListItem>
18
17
  <Breadcrumb.Link asChild>
19
- <Button variant='ghost' density='fine' classNames='px-0 text-base-surface-text font-normal'>
18
+ <Button variant='ghost' classNames='px-0 text-base-surface-text font-normal'>
20
19
  Grocery
21
20
  </Button>
22
21
  </Breadcrumb.Link>
@@ -8,7 +8,6 @@ import React from 'react';
8
8
  import { withTheme } from '../../testing';
9
9
  import { withLayoutVariants } from '../../testing';
10
10
  import { Icon } from '../Icon';
11
-
12
11
  import { Button, ButtonGroup, type ButtonProps } from './Button';
13
12
 
14
13
  const DefaultStory = ({ children, ...args }: Omit<ButtonProps, 'ref'>) => {
@@ -12,12 +12,12 @@ import { type Density, type Elevation } from '@dxos/ui-types';
12
12
  import { useDensityContext, useElevationContext, useThemeContext } from '../../hooks';
13
13
  import { type ThemedClassName } from '../../util';
14
14
 
15
- interface ButtonProps extends ThemedClassName<ComponentPropsWithRef<typeof Primitive.button>> {
15
+ type ButtonProps = ThemedClassName<ComponentPropsWithRef<typeof Primitive.button>> & {
16
16
  variant?: 'default' | 'primary' | 'outline' | 'ghost' | 'destructive';
17
17
  density?: Density;
18
18
  elevation?: Elevation;
19
19
  asChild?: boolean;
20
- }
20
+ };
21
21
 
22
22
  type ButtonGroupContextValue = { inGroup?: boolean };
23
23
 
@@ -31,21 +31,13 @@ const [ButtonGroupProvider, useButtonGroupContext] = createContext<ButtonGroupCo
31
31
  const Button = memo(
32
32
  forwardRef<HTMLButtonElement, ButtonProps>(
33
33
  (
34
- {
35
- classNames,
36
- children,
37
- density: propsDensity,
38
- elevation: propsElevation,
39
- variant = 'default',
40
- asChild,
41
- ...props
42
- },
34
+ { classNames, children, density: densityProp, elevation: elevationProp, variant = 'default', asChild, ...props },
43
35
  ref,
44
36
  ) => {
45
37
  const { inGroup } = useButtonGroupContext(BUTTON_NAME);
46
38
  const { tx } = useThemeContext();
47
- const elevation = useElevationContext(propsElevation);
48
- const density = useDensityContext(propsDensity);
39
+ const elevation = useElevationContext(elevationProp);
40
+ const density = useDensityContext(densityProp);
49
41
  const Comp = asChild ? Slot : Primitive.button;
50
42
  return (
51
43
  <Comp
@@ -7,17 +7,16 @@ import React from 'react';
7
7
 
8
8
  import { withTheme } from '../../testing';
9
9
  import { Tooltip } from '../Tooltip';
10
-
10
+ import { Button } from './Button';
11
11
  import { IconButton, type IconButtonProps } from './IconButton';
12
12
 
13
13
  const DefaultStory = (props: IconButtonProps) => {
14
14
  return (
15
15
  <Tooltip.Provider>
16
- <div className='mb-4'>
16
+ <div className='flex gap-4'>
17
17
  <IconButton {...props} />
18
- </div>
19
- <div className='mb-4'>
20
18
  <IconButton iconOnly {...props} />
19
+ <Button>{props.label}</Button>
21
20
  </div>
22
21
  </Tooltip.Provider>
23
22
  );
@@ -28,6 +27,9 @@ const meta = {
28
27
  component: IconButton,
29
28
  render: DefaultStory as any,
30
29
  decorators: [withTheme()],
30
+ parameters: {
31
+ layout: 'centered',
32
+ },
31
33
  } satisfies Meta<typeof IconButton>;
32
34
 
33
35
  export default meta;
@@ -8,7 +8,6 @@ import { useThemeContext } from '../../hooks';
8
8
  import { type ThemedClassName } from '../../util';
9
9
  import { Icon, type IconProps } from '../Icon';
10
10
  import { Tooltip, type TooltipSide } from '../Tooltip';
11
-
12
11
  import { Button, type ButtonProps } from './Button';
13
12
 
14
13
  type IconButtonProps = Omit<ButtonProps, 'children'> &
@@ -17,6 +16,7 @@ type IconButtonProps = Omit<ButtonProps, 'children'> &
17
16
  noTooltip?: boolean;
18
17
  caretDown?: boolean;
19
18
  iconOnly?: boolean;
19
+ square?: boolean; // TODO(burdon): Handle more uniformly.
20
20
  iconEnd?: boolean;
21
21
  iconClassNames?: ThemedClassName<any>['classNames'];
22
22
  tooltipSide?: TooltipSide;
@@ -44,15 +44,14 @@ const IconOnlyButton = forwardRef<HTMLButtonElement, IconButtonProps>(
44
44
  },
45
45
  );
46
46
 
47
- // TODO(burdon): Inherit size from container/density.
48
47
  const LabelledIconButton = forwardRef<HTMLButtonElement, IconButtonProps>(
49
48
  (
50
- { size = 5, icon, iconOnly, iconEnd, iconClassNames, label, caretDown, noTooltip: _, classNames, ...props },
49
+ { size, icon, iconOnly, square, iconEnd, iconClassNames, label, caretDown, noTooltip: _, classNames, ...props },
51
50
  forwardedRef,
52
51
  ) => {
53
52
  const { tx } = useThemeContext();
54
53
  return (
55
- <Button {...props} classNames={tx('iconButton.root', { iconOnly }, classNames)} ref={forwardedRef}>
54
+ <Button {...props} classNames={tx('iconButton.root', { iconOnly, square }, classNames)} ref={forwardedRef}>
56
55
  {icon && !iconEnd && <Icon icon={icon} size={size} classNames={iconClassNames} />}
57
56
  <span className={iconOnly ? 'sr-only' : undefined}>{label}</span>
58
57
  {icon && iconEnd && <Icon icon={icon} size={size} classNames={iconClassNames} />}
@@ -7,7 +7,6 @@ import React from 'react';
7
7
 
8
8
  import { withTheme } from '../../testing';
9
9
  import { Icon } from '../Icon';
10
-
11
10
  import { Toggle, type ToggleProps } from './Toggle';
12
11
 
13
12
  const DefaultStory = (props: ToggleProps) => {
@@ -2,19 +2,19 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import { Toggle as TogglePrimitive, type ToggleProps as TogglePrimitiveProps } from '@radix-ui/react-toggle';
5
+ import * as TogglePrimitive from '@radix-ui/react-toggle';
6
6
  import React, { forwardRef } from 'react';
7
7
 
8
8
  import { Button, type ButtonProps } from './Button';
9
9
 
10
- type ToggleProps = Omit<TogglePrimitiveProps, 'asChild'> & ButtonProps;
10
+ type ToggleProps = Omit<TogglePrimitive.ToggleProps, 'asChild'> & ButtonProps;
11
11
 
12
12
  const Toggle = forwardRef<HTMLButtonElement, ToggleProps>(
13
13
  ({ defaultPressed, pressed, onPressedChange, ...props }, forwardedRef) => {
14
14
  return (
15
- <TogglePrimitive {...{ defaultPressed, pressed, onPressedChange }} asChild>
15
+ <TogglePrimitive.Root {...{ defaultPressed, pressed, onPressedChange }} asChild>
16
16
  <Button {...props} ref={forwardedRef} />
17
- </TogglePrimitive>
17
+ </TogglePrimitive.Root>
18
18
  );
19
19
  },
20
20
  );
@@ -7,7 +7,6 @@ import React from 'react';
7
7
 
8
8
  import { withTheme } from '../../testing';
9
9
  import { Icon } from '../Icon';
10
-
11
10
  import { ToggleGroup, ToggleGroupItem, type ToggleGroupProps } from './ToggleGroup';
12
11
 
13
12
  // TODO(burdon): Create Radix-style Root, Item, etc?
@@ -2,50 +2,46 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import {
6
- ToggleGroupItem as ToggleGroupItemPrimitive,
7
- type ToggleGroupItemProps as ToggleGroupItemPrimitiveProps,
8
- type ToggleGroupMultipleProps,
9
- ToggleGroup as ToggleGroupPrimitive,
10
- type ToggleGroupSingleProps,
11
- } from '@radix-ui/react-toggle-group';
5
+ import * as ToggleGroupPrimitive from '@radix-ui/react-toggle-group';
12
6
  import React, { forwardRef } from 'react';
13
7
 
14
8
  import { Button, ButtonGroup, type ButtonGroupProps, type ButtonProps } from './Button';
15
9
  import { IconButton, type IconButtonProps } from './IconButton';
16
10
 
17
- type ToggleGroupProps = Omit<ToggleGroupSingleProps, 'className'> | Omit<ToggleGroupMultipleProps, 'className'>;
11
+ type ToggleGroupProps =
12
+ | Omit<ToggleGroupPrimitive.ToggleGroupSingleProps, 'className'>
13
+ | Omit<ToggleGroupPrimitive.ToggleGroupMultipleProps, 'className'>;
18
14
 
19
15
  const ToggleGroup = forwardRef<HTMLDivElement, ToggleGroupProps & ButtonGroupProps>(
20
16
  ({ classNames, children, ...props }, forwardedRef) => {
21
17
  return (
22
- <ToggleGroupPrimitive {...props} asChild>
18
+ <ToggleGroupPrimitive.Root {...props} asChild>
23
19
  <ButtonGroup {...{ classNames, children }} ref={forwardedRef} />
24
- </ToggleGroupPrimitive>
20
+ </ToggleGroupPrimitive.Root>
25
21
  );
26
22
  },
27
23
  );
28
24
 
29
- type ToggleGroupItemProps = Omit<ToggleGroupItemPrimitiveProps, 'className'> & ButtonProps;
25
+ type ToggleGroupItemProps = Omit<ToggleGroupPrimitive.ToggleGroupItemProps, 'className'> & ButtonProps;
30
26
 
31
27
  const ToggleGroupItem = forwardRef<HTMLButtonElement, ToggleGroupItemProps>(
32
28
  ({ variant, elevation, density, classNames, children, ...props }, forwardedRef) => {
33
29
  return (
34
- <ToggleGroupItemPrimitive {...props} asChild>
30
+ <ToggleGroupPrimitive.Item {...props} asChild>
35
31
  <Button {...{ variant, elevation, density, classNames, children }} ref={forwardedRef} />
36
- </ToggleGroupItemPrimitive>
32
+ </ToggleGroupPrimitive.Item>
37
33
  );
38
34
  },
39
35
  );
40
36
 
41
- type ToggleGroupIconItemProps = Omit<ToggleGroupItemPrimitiveProps, 'className'> & IconButtonProps;
37
+ type ToggleGroupIconItemProps = Omit<ToggleGroupPrimitive.ToggleGroupItemProps, 'className'> & IconButtonProps;
42
38
 
43
39
  const ToggleGroupIconItem = forwardRef<HTMLButtonElement, ToggleGroupIconItemProps>(
44
40
  ({ variant, label, icon, size, elevation, density, classNames, ...props }, forwardedRef) => {
45
41
  return (
46
- <ToggleGroupItemPrimitive {...props} asChild>
42
+ <ToggleGroupPrimitive.Item {...props} asChild>
47
43
  <IconButton {...{ variant, elevation, density, classNames, label, icon, size }} ref={forwardedRef} />
48
- </ToggleGroupItemPrimitive>
44
+ </ToggleGroupPrimitive.Item>
49
45
  );
50
46
  },
51
47
  );
@@ -5,22 +5,22 @@
5
5
  import { type Meta, type StoryObj } from '@storybook/react-vite';
6
6
  import React, { useRef } from 'react';
7
7
 
8
- import { faker } from '@dxos/random';
8
+ import { random } from '@dxos/random';
9
9
  import { Icon } from '@dxos/react-ui';
10
10
  import { withLayout, withTheme } from '@dxos/react-ui/testing';
11
11
 
12
12
  import { Card } from './Card';
13
13
 
14
- faker.seed(0);
14
+ random.seed(0);
15
15
 
16
- type StoryProps = {
16
+ type DefaultStoryProps = {
17
17
  title: string;
18
18
  description?: string;
19
19
  image?: string;
20
20
  fullWidth?: boolean;
21
21
  };
22
22
 
23
- const DefaultStory = ({ title, description, image, fullWidth }: StoryProps) => {
23
+ const DefaultStory = ({ title, description, image, fullWidth }: DefaultStoryProps) => {
24
24
  const handleRef = useRef<HTMLButtonElement>(null);
25
25
  console.log(title);
26
26
  return (
@@ -65,20 +65,20 @@ export default meta;
65
65
 
66
66
  type Story = StoryObj<typeof meta>;
67
67
 
68
- const image = faker.image.url();
68
+ const image = random.image.url();
69
69
 
70
70
  export const Default: Story = {
71
71
  args: {
72
- title: faker.commerce.productName(),
73
- description: faker.lorem.paragraph(3),
72
+ title: random.commerce.productName(),
73
+ description: random.lorem.paragraph(3),
74
74
  image,
75
75
  },
76
76
  };
77
77
 
78
78
  export const FullWidth: Story = {
79
79
  args: {
80
- title: faker.commerce.productName(),
81
- description: faker.lorem.paragraph(3),
80
+ title: random.commerce.productName(),
81
+ description: random.lorem.paragraph(3),
82
82
  image,
83
83
  fullWidth: true,
84
84
  },
@@ -86,7 +86,7 @@ export const FullWidth: Story = {
86
86
 
87
87
  export const Simple: Story = {
88
88
  args: {
89
- title: faker.commerce.productName(),
89
+ title: random.commerce.productName(),
90
90
  },
91
91
  render: ({ title }) => {
92
92
  const handleRef = useRef<HTMLButtonElement>(null);
@@ -104,8 +104,8 @@ export const Simple: Story = {
104
104
 
105
105
  export const Description: Story = {
106
106
  args: {
107
- title: faker.commerce.productName(),
108
- description: faker.lorem.paragraph(3),
107
+ title: random.commerce.productName(),
108
+ description: random.lorem.paragraph(3),
109
109
  },
110
110
  render: ({ title, description }) => {
111
111
  const handleRef = useRef<HTMLButtonElement>(null);
@@ -129,18 +129,18 @@ export const Description: Story = {
129
129
  export const Mock = () => (
130
130
  <div className='grid grid-cols-[2rem_1fr_2rem] w-full dx-card-min-width dx-card-max-width border border-separator rounded-xs'>
131
131
  <div className='grid grid-cols-subgrid col-span-full'>
132
- <div role='none' className='grid h-[var(--dx-rail-item)] w-[var(--dx-rail-item)] place-items-center'>
132
+ <div className='grid h-[var(--dx-rail-item)] w-[var(--dx-rail-item)] place-items-center'>
133
133
  <Icon icon='ph--dots-six-vertical--regular' />
134
134
  </div>
135
135
  <div className='p-1 whitespace-normal break-words text-description items-center'>
136
136
  This line is very very long and it should wrap.
137
137
  </div>
138
- <div role='none' className='grid h-[var(--dx-rail-item)] w-[var(--dx-rail-item)] place-items-center'>
138
+ <div className='grid h-[var(--dx-rail-item)] w-[var(--dx-rail-item)] place-items-center'>
139
139
  <Icon icon='ph--x--regular' />
140
140
  </div>
141
141
  </div>
142
142
  <div className='grid grid-cols-subgrid col-span-3'>
143
- <div role='none' className='grid h-[var(--dx-rail-item)] w-[var(--dx-rail-item)] place-items-center'>
143
+ <div className='grid h-[var(--dx-rail-item)] w-[var(--dx-rail-item)] place-items-center'>
144
144
  <Icon icon='ph--dots-six-vertical--regular' />
145
145
  </div>
146
146
  <div className='p-1 text-description items-center col-span-2'>