@dxos/react-ui 0.8.4-main.f5c0578 → 0.8.4-main.fcc0d83b33

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 (478) hide show
  1. package/dist/lib/browser/chunk-BDBC6H6V.mjs +848 -0
  2. package/dist/lib/browser/chunk-BDBC6H6V.mjs.map +7 -0
  3. package/dist/lib/browser/index.mjs +4102 -60
  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 +112 -60
  7. package/dist/lib/browser/testing/index.mjs.map +4 -4
  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-3JSJK2ZY.mjs +850 -0
  11. package/dist/lib/node-esm/chunk-3JSJK2ZY.mjs.map +7 -0
  12. package/dist/lib/node-esm/index.mjs +4102 -60
  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 +112 -60
  16. package/dist/lib/node-esm/testing/index.mjs.map +4 -4
  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 +5 -31
  22. package/dist/types/src/components/Avatars/Avatar.stories.d.ts.map +1 -1
  23. package/dist/types/src/components/Avatars/AvatarGroup.stories.d.ts +5 -11
  24. package/dist/types/src/components/Avatars/AvatarGroup.stories.d.ts.map +1 -1
  25. package/dist/types/src/components/Breadcrumb/Breadcrumb.d.ts.map +1 -1
  26. package/dist/types/src/components/Breadcrumb/Breadcrumb.stories.d.ts +8 -20
  27. package/dist/types/src/components/Breadcrumb/Breadcrumb.stories.d.ts.map +1 -1
  28. package/dist/types/src/components/{Buttons → Button}/Button.d.ts +4 -4
  29. package/dist/types/src/components/Button/Button.d.ts.map +1 -0
  30. package/dist/types/src/components/Button/Button.stories.d.ts +17 -0
  31. package/dist/types/src/components/Button/Button.stories.d.ts.map +1 -0
  32. package/dist/types/src/components/{Buttons → Button}/IconButton.d.ts +4 -3
  33. package/dist/types/src/components/Button/IconButton.d.ts.map +1 -0
  34. package/dist/types/src/components/Button/IconButton.stories.d.ts +16 -0
  35. package/dist/types/src/components/Button/IconButton.stories.d.ts.map +1 -0
  36. package/dist/types/src/components/{Buttons → Button}/Toggle.d.ts +2 -2
  37. package/dist/types/src/components/Button/Toggle.d.ts.map +1 -0
  38. package/dist/types/src/components/Button/Toggle.stories.d.ts +16 -0
  39. package/dist/types/src/components/Button/Toggle.stories.d.ts.map +1 -0
  40. package/dist/types/src/components/Button/ToggleGroup.d.ts +27 -0
  41. package/dist/types/src/components/Button/ToggleGroup.d.ts.map +1 -0
  42. package/dist/types/src/components/Button/ToggleGroup.stories.d.ts +27 -0
  43. package/dist/types/src/components/Button/ToggleGroup.stories.d.ts.map +1 -0
  44. package/dist/types/src/components/Button/index.d.ts.map +1 -0
  45. package/dist/types/src/components/Card/Card.d.ts +127 -0
  46. package/dist/types/src/components/Card/Card.d.ts.map +1 -0
  47. package/dist/types/src/components/Card/Card.stories.d.ts +21 -0
  48. package/dist/types/src/components/Card/Card.stories.d.ts.map +1 -0
  49. package/dist/types/src/components/Card/index.d.ts +2 -0
  50. package/dist/types/src/components/Card/index.d.ts.map +1 -0
  51. package/dist/types/src/components/Clipboard/ClipboardProvider.d.ts.map +1 -1
  52. package/dist/types/src/components/Clipboard/CopyButton.d.ts +1 -1
  53. package/dist/types/src/components/Clipboard/CopyButton.d.ts.map +1 -1
  54. package/dist/types/src/components/Clipboard/index.d.ts +10 -1
  55. package/dist/types/src/components/Clipboard/index.d.ts.map +1 -1
  56. package/dist/types/src/components/DensityProvider/DensityProvider.d.ts +1 -1
  57. package/dist/types/src/components/DensityProvider/DensityProvider.d.ts.map +1 -1
  58. package/dist/types/src/components/Dialog/AlertDialog.d.ts +51 -0
  59. package/dist/types/src/components/Dialog/AlertDialog.d.ts.map +1 -0
  60. package/dist/types/src/components/Dialog/AlertDialog.stories.d.ts +11 -0
  61. package/dist/types/src/components/Dialog/AlertDialog.stories.d.ts.map +1 -0
  62. package/dist/types/src/components/Dialog/Dialog.d.ts +64 -0
  63. package/dist/types/src/components/Dialog/Dialog.d.ts.map +1 -0
  64. package/dist/types/src/components/Dialog/Dialog.stories.d.ts +25 -0
  65. package/dist/types/src/components/Dialog/Dialog.stories.d.ts.map +1 -0
  66. package/dist/types/src/components/Dialog/index.d.ts.map +1 -0
  67. package/dist/types/src/components/ElevationProvider/ElevationProvider.d.ts +1 -1
  68. package/dist/types/src/components/ElevationProvider/ElevationProvider.d.ts.map +1 -1
  69. package/dist/types/src/components/ErrorFallback/ErrorFallback.d.ts +11 -0
  70. package/dist/types/src/components/ErrorFallback/ErrorFallback.d.ts.map +1 -0
  71. package/dist/types/src/components/ErrorFallback/ErrorFallback.stories.d.ts +7 -0
  72. package/dist/types/src/components/ErrorFallback/ErrorFallback.stories.d.ts.map +1 -0
  73. package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts +19 -0
  74. package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts.map +1 -0
  75. package/dist/types/src/components/ErrorFallback/ThrowError.d.ts +9 -0
  76. package/dist/types/src/components/ErrorFallback/ThrowError.d.ts.map +1 -0
  77. package/dist/types/src/components/ErrorFallback/index.d.ts +5 -0
  78. package/dist/types/src/components/ErrorFallback/index.d.ts.map +1 -0
  79. package/dist/types/src/components/Focus/Focus.d.ts +36 -0
  80. package/dist/types/src/components/Focus/Focus.d.ts.map +1 -0
  81. package/dist/types/src/components/Focus/Focus.stories.d.ts +9 -0
  82. package/dist/types/src/components/Focus/Focus.stories.d.ts.map +1 -0
  83. package/dist/types/src/components/Focus/index.d.ts +2 -0
  84. package/dist/types/src/components/Focus/index.d.ts.map +1 -0
  85. package/dist/types/src/components/Icon/Icon.d.ts +5 -2
  86. package/dist/types/src/components/Icon/Icon.d.ts.map +1 -1
  87. package/dist/types/src/components/Icon/Icon.stories.d.ts +25 -0
  88. package/dist/types/src/components/Icon/Icon.stories.d.ts.map +1 -0
  89. package/dist/types/src/components/Image/Image.d.ts +15 -0
  90. package/dist/types/src/components/Image/Image.d.ts.map +1 -0
  91. package/dist/types/src/components/Image/Image.stories.d.ts +34 -0
  92. package/dist/types/src/components/Image/Image.stories.d.ts.map +1 -0
  93. package/dist/types/src/components/Image/index.d.ts +2 -0
  94. package/dist/types/src/components/Image/index.d.ts.map +1 -0
  95. package/dist/types/src/components/Input/Input.d.ts +19 -24
  96. package/dist/types/src/components/Input/Input.d.ts.map +1 -1
  97. package/dist/types/src/components/Input/Input.stories.d.ts +16 -17
  98. package/dist/types/src/components/Input/Input.stories.d.ts.map +1 -1
  99. package/dist/types/src/components/Link/Link.stories.d.ts +8 -8
  100. package/dist/types/src/components/Link/Link.stories.d.ts.map +1 -1
  101. package/dist/types/src/components/{Lists → List}/List.d.ts +6 -4
  102. package/dist/types/src/components/List/List.d.ts.map +1 -0
  103. package/dist/types/src/components/List/List.stories.d.ts +16 -0
  104. package/dist/types/src/components/List/List.stories.d.ts.map +1 -0
  105. package/dist/types/src/components/List/ListDropIndicator.d.ts.map +1 -0
  106. package/dist/types/src/components/{Lists → List}/Tree.d.ts +2 -2
  107. package/dist/types/src/components/List/Tree.d.ts.map +1 -0
  108. package/dist/types/src/components/List/Tree.stories.d.ts +15 -0
  109. package/dist/types/src/components/List/Tree.stories.d.ts.map +1 -0
  110. package/dist/types/src/components/List/TreeDropIndicator.d.ts.map +1 -0
  111. package/dist/types/src/components/{Lists → List}/Treegrid.d.ts +5 -9
  112. package/dist/types/src/components/List/Treegrid.d.ts.map +1 -0
  113. package/dist/types/src/components/List/Treegrid.stories.d.ts +12 -0
  114. package/dist/types/src/components/List/Treegrid.stories.d.ts.map +1 -0
  115. package/dist/types/src/components/List/index.d.ts.map +1 -0
  116. package/dist/types/src/components/Main/Main.d.ts +24 -30
  117. package/dist/types/src/components/Main/Main.d.ts.map +1 -1
  118. package/dist/types/src/components/Main/Main.stories.d.ts +6 -10
  119. package/dist/types/src/components/Main/Main.stories.d.ts.map +1 -1
  120. package/dist/types/src/components/Main/useSwipeToDismiss.d.ts.map +1 -1
  121. package/dist/types/src/components/{Menus → Menu}/ContextMenu.d.ts +6 -6
  122. package/dist/types/src/components/Menu/ContextMenu.d.ts.map +1 -0
  123. package/dist/types/src/components/Menu/ContextMenu.stories.d.ts +12 -0
  124. package/dist/types/src/components/Menu/ContextMenu.stories.d.ts.map +1 -0
  125. package/dist/types/src/components/Menu/DropdownMenu.d.ts +121 -0
  126. package/dist/types/src/components/Menu/DropdownMenu.d.ts.map +1 -0
  127. package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts +28 -0
  128. package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts.map +1 -0
  129. package/dist/types/src/components/Menu/index.d.ts.map +1 -0
  130. package/dist/types/src/components/Message/Message.d.ts +1 -1
  131. package/dist/types/src/components/Message/Message.d.ts.map +1 -1
  132. package/dist/types/src/components/Message/Message.stories.d.ts +12 -22
  133. package/dist/types/src/components/Message/Message.stories.d.ts.map +1 -1
  134. package/dist/types/src/components/Popover/Popover.d.ts +41 -24
  135. package/dist/types/src/components/Popover/Popover.d.ts.map +1 -1
  136. package/dist/types/src/components/Popover/Popover.stories.d.ts +6 -34
  137. package/dist/types/src/components/Popover/Popover.stories.d.ts.map +1 -1
  138. package/dist/types/src/components/ScrollArea/ScrollArea.d.ts +27 -27
  139. package/dist/types/src/components/ScrollArea/ScrollArea.d.ts.map +1 -1
  140. package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts +50 -27
  141. package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts.map +1 -1
  142. package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts +68 -0
  143. package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts.map +1 -0
  144. package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts +23 -0
  145. package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts.map +1 -0
  146. package/dist/types/src/components/ScrollContainer/index.d.ts +2 -0
  147. package/dist/types/src/components/ScrollContainer/index.d.ts.map +1 -0
  148. package/dist/types/src/components/Select/Select.d.ts +10 -10
  149. package/dist/types/src/components/Select/Select.d.ts.map +1 -1
  150. package/dist/types/src/components/Select/Select.stories.d.ts +6 -11
  151. package/dist/types/src/components/Select/Select.stories.d.ts.map +1 -1
  152. package/dist/types/src/components/Separator/Separator.d.ts +4 -4
  153. package/dist/types/src/components/Separator/Separator.d.ts.map +1 -1
  154. package/dist/types/src/components/Skeleton/Skeleton.d.ts +12 -0
  155. package/dist/types/src/components/Skeleton/Skeleton.d.ts.map +1 -0
  156. package/dist/types/src/components/Skeleton/Skeleton.stories.d.ts +17 -0
  157. package/dist/types/src/components/Skeleton/Skeleton.stories.d.ts.map +1 -0
  158. package/dist/types/src/components/Skeleton/index.d.ts +2 -0
  159. package/dist/types/src/components/Skeleton/index.d.ts.map +1 -0
  160. package/dist/types/src/components/Splitter/Splitter.d.ts +34 -0
  161. package/dist/types/src/components/Splitter/Splitter.d.ts.map +1 -0
  162. package/dist/types/src/components/Splitter/Splitter.stories.d.ts +7 -0
  163. package/dist/types/src/components/Splitter/Splitter.stories.d.ts.map +1 -0
  164. package/dist/types/src/components/Splitter/index.d.ts +2 -0
  165. package/dist/types/src/components/Splitter/index.d.ts.map +1 -0
  166. package/dist/types/src/components/Status/Status.d.ts +3 -4
  167. package/dist/types/src/components/Status/Status.d.ts.map +1 -1
  168. package/dist/types/src/components/Status/Status.stories.d.ts +6 -10
  169. package/dist/types/src/components/Status/Status.stories.d.ts.map +1 -1
  170. package/dist/types/src/components/Tag/Tag.d.ts +1 -1
  171. package/dist/types/src/components/Tag/Tag.d.ts.map +1 -1
  172. package/dist/types/src/components/Tag/Tag.stories.d.ts +8 -13
  173. package/dist/types/src/components/Tag/Tag.stories.d.ts.map +1 -1
  174. package/dist/types/src/components/ThemeProvider/ThemeProvider.d.ts +3 -3
  175. package/dist/types/src/components/ThemeProvider/ThemeProvider.d.ts.map +1 -1
  176. package/dist/types/src/components/ThemeProvider/ThemeProvider.stories.d.ts +12 -0
  177. package/dist/types/src/components/ThemeProvider/ThemeProvider.stories.d.ts.map +1 -0
  178. package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts +55 -63
  179. package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts.map +1 -1
  180. package/dist/types/src/components/ThemeProvider/index.d.ts +2 -1
  181. package/dist/types/src/components/ThemeProvider/index.d.ts.map +1 -1
  182. package/dist/types/src/components/Toast/Toast.d.ts +20 -20
  183. package/dist/types/src/components/Toast/Toast.d.ts.map +1 -1
  184. package/dist/types/src/components/Toast/Toast.stories.d.ts +6 -44
  185. package/dist/types/src/components/Toast/Toast.stories.d.ts.map +1 -1
  186. package/dist/types/src/components/Toolbar/Toolbar.d.ts +41 -23
  187. package/dist/types/src/components/Toolbar/Toolbar.d.ts.map +1 -1
  188. package/dist/types/src/components/Toolbar/Toolbar.stories.d.ts +6 -50
  189. package/dist/types/src/components/Toolbar/Toolbar.stories.d.ts.map +1 -1
  190. package/dist/types/src/components/Tooltip/Tooltip.d.ts +11 -13
  191. package/dist/types/src/components/Tooltip/Tooltip.d.ts.map +1 -1
  192. package/dist/types/src/components/Tooltip/Tooltip.stories.d.ts +10 -63
  193. package/dist/types/src/components/Tooltip/Tooltip.stories.d.ts.map +1 -1
  194. package/dist/types/src/components/index.d.ts +14 -8
  195. package/dist/types/src/components/index.d.ts.map +1 -1
  196. package/dist/types/src/exemplars/generics.stories.d.ts +19 -0
  197. package/dist/types/src/exemplars/generics.stories.d.ts.map +1 -0
  198. package/dist/types/src/exemplars/slot.stories.d.ts +15 -0
  199. package/dist/types/src/exemplars/slot.stories.d.ts.map +1 -0
  200. package/dist/types/src/exemplars/tabster.stories.d.ts +8 -0
  201. package/dist/types/src/exemplars/tabster.stories.d.ts.map +1 -0
  202. package/dist/types/src/exemplars/virtualizer.stories.d.ts +11 -0
  203. package/dist/types/src/exemplars/virtualizer.stories.d.ts.map +1 -0
  204. package/dist/types/src/hooks/index.d.ts +1 -0
  205. package/dist/types/src/hooks/index.d.ts.map +1 -1
  206. package/dist/types/src/hooks/useDensityContext.d.ts +2 -2
  207. package/dist/types/src/hooks/useDensityContext.d.ts.map +1 -1
  208. package/dist/types/src/hooks/useElevationContext.d.ts +1 -1
  209. package/dist/types/src/hooks/useElevationContext.d.ts.map +1 -1
  210. package/dist/types/src/hooks/useIconHref.d.ts.map +1 -1
  211. package/dist/types/src/hooks/useSafeArea.d.ts.map +1 -1
  212. package/dist/types/src/hooks/useSafeCollisionPadding.d.ts.map +1 -1
  213. package/dist/types/src/hooks/useVisualViewport.d.ts +2 -2
  214. package/dist/types/src/hooks/useVisualViewport.d.ts.map +1 -1
  215. package/dist/types/src/index.d.ts +2 -1
  216. package/dist/types/src/index.d.ts.map +1 -1
  217. package/dist/types/src/playground/Controls.stories.d.ts +5 -9
  218. package/dist/types/src/playground/Controls.stories.d.ts.map +1 -1
  219. package/dist/types/src/playground/Custom.stories.d.ts +12 -4
  220. package/dist/types/src/playground/Custom.stories.d.ts.map +1 -1
  221. package/dist/types/src/playground/Typography.stories.d.ts +5 -11
  222. package/dist/types/src/playground/Typography.stories.d.ts.map +1 -1
  223. package/dist/types/src/primitives/Column/Column.d.ts +33 -0
  224. package/dist/types/src/primitives/Column/Column.d.ts.map +1 -0
  225. package/dist/types/src/primitives/Column/Column.stories.d.ts +25 -0
  226. package/dist/types/src/primitives/Column/Column.stories.d.ts.map +1 -0
  227. package/dist/types/src/primitives/Column/index.d.ts +2 -0
  228. package/dist/types/src/primitives/Column/index.d.ts.map +1 -0
  229. package/dist/types/src/primitives/Container/Container.d.ts +7 -0
  230. package/dist/types/src/primitives/Container/Container.d.ts.map +1 -0
  231. package/dist/types/src/primitives/Container/Container.stories.d.ts +6 -0
  232. package/dist/types/src/primitives/Container/Container.stories.d.ts.map +1 -0
  233. package/dist/types/src/primitives/Container/index.d.ts +2 -0
  234. package/dist/types/src/primitives/Container/index.d.ts.map +1 -0
  235. package/dist/types/src/primitives/Flex/Flex.d.ts +11 -0
  236. package/dist/types/src/primitives/Flex/Flex.d.ts.map +1 -0
  237. package/dist/types/src/primitives/Flex/Flex.stories.d.ts +8 -0
  238. package/dist/types/src/primitives/Flex/Flex.stories.d.ts.map +1 -0
  239. package/dist/types/src/primitives/Flex/index.d.ts +2 -0
  240. package/dist/types/src/primitives/Flex/index.d.ts.map +1 -0
  241. package/dist/types/src/primitives/Grid/Grid.d.ts +10 -0
  242. package/dist/types/src/primitives/Grid/Grid.d.ts.map +1 -0
  243. package/dist/types/src/primitives/Grid/Grid.stories.d.ts +8 -0
  244. package/dist/types/src/primitives/Grid/Grid.stories.d.ts.map +1 -0
  245. package/dist/types/src/primitives/Grid/index.d.ts +2 -0
  246. package/dist/types/src/primitives/Grid/index.d.ts.map +1 -0
  247. package/dist/types/src/primitives/Panel/Panel.d.ts +35 -0
  248. package/dist/types/src/primitives/Panel/Panel.d.ts.map +1 -0
  249. package/dist/types/src/primitives/Panel/Panel.stories.d.ts +6 -0
  250. package/dist/types/src/primitives/Panel/Panel.stories.d.ts.map +1 -0
  251. package/dist/types/src/primitives/Panel/index.d.ts +2 -0
  252. package/dist/types/src/primitives/Panel/index.d.ts.map +1 -0
  253. package/dist/types/src/primitives/index.d.ts +6 -0
  254. package/dist/types/src/primitives/index.d.ts.map +1 -0
  255. package/dist/types/src/testing/Loading.d.ts +9 -0
  256. package/dist/types/src/testing/Loading.d.ts.map +1 -0
  257. package/dist/types/src/testing/decorators/index.d.ts +2 -1
  258. package/dist/types/src/testing/decorators/index.d.ts.map +1 -1
  259. package/dist/types/src/testing/decorators/withLayout.d.ts +15 -0
  260. package/dist/types/src/testing/decorators/withLayout.d.ts.map +1 -0
  261. package/dist/types/src/testing/decorators/withLayoutVariants.d.ts +12 -0
  262. package/dist/types/src/testing/decorators/withLayoutVariants.d.ts.map +1 -0
  263. package/dist/types/src/testing/decorators/withTheme.d.ts +5 -1
  264. package/dist/types/src/testing/decorators/withTheme.d.ts.map +1 -1
  265. package/dist/types/src/testing/index.d.ts +1 -0
  266. package/dist/types/src/testing/index.d.ts.map +1 -1
  267. package/dist/types/src/translations.d.ts +11 -0
  268. package/dist/types/src/translations.d.ts.map +1 -0
  269. package/dist/types/src/util/index.d.ts +2 -1
  270. package/dist/types/src/util/index.d.ts.map +1 -1
  271. package/dist/types/src/util/usePx.d.ts +8 -0
  272. package/dist/types/src/util/usePx.d.ts.map +1 -0
  273. package/dist/types/tsconfig.tsbuildinfo +1 -1
  274. package/package.json +52 -39
  275. package/src/components/Avatars/Avatar.stories.tsx +22 -16
  276. package/src/components/Avatars/Avatar.tsx +7 -15
  277. package/src/components/Avatars/AvatarGroup.stories.tsx +10 -8
  278. package/src/components/Breadcrumb/Breadcrumb.stories.tsx +19 -16
  279. package/src/components/Breadcrumb/Breadcrumb.tsx +11 -37
  280. package/src/components/{Buttons → Button}/Button.stories.tsx +7 -10
  281. package/src/components/{Buttons → Button}/Button.tsx +12 -26
  282. package/src/components/{Buttons → Button}/IconButton.stories.tsx +17 -13
  283. package/src/components/{Buttons → Button}/IconButton.tsx +21 -16
  284. package/src/components/Button/Toggle.stories.tsx +36 -0
  285. package/src/components/{Buttons → Button}/Toggle.tsx +4 -4
  286. package/src/components/{Buttons → Button}/ToggleGroup.stories.tsx +10 -9
  287. package/src/components/Button/ToggleGroup.tsx +50 -0
  288. package/src/components/Card/Card.stories.tsx +151 -0
  289. package/src/components/Card/Card.tsx +505 -0
  290. package/src/components/Card/index.ts +5 -0
  291. package/src/components/Clipboard/CopyButton.tsx +8 -9
  292. package/src/components/DensityProvider/DensityProvider.tsx +1 -1
  293. package/src/components/Dialog/AlertDialog.stories.tsx +68 -0
  294. package/src/components/{Dialogs → Dialog}/AlertDialog.tsx +123 -82
  295. package/src/components/Dialog/Dialog.stories.tsx +177 -0
  296. package/src/components/Dialog/Dialog.tsx +285 -0
  297. package/src/components/ElevationProvider/ElevationProvider.tsx +1 -1
  298. package/src/components/ErrorFallback/ErrorFallback.stories.tsx +45 -0
  299. package/src/components/ErrorFallback/ErrorFallback.tsx +70 -0
  300. package/src/components/ErrorFallback/ErrorStack.tsx +114 -0
  301. package/src/components/ErrorFallback/ThrowError.tsx +37 -0
  302. package/src/components/ErrorFallback/index.ts +9 -0
  303. package/src/components/Focus/AUDIT.md +43 -0
  304. package/src/components/Focus/Focus.stories.tsx +230 -0
  305. package/src/components/Focus/Focus.tsx +201 -0
  306. package/src/components/Focus/index.ts +5 -0
  307. package/src/components/Icon/Icon.stories.tsx +143 -0
  308. package/src/components/Icon/Icon.tsx +6 -2
  309. package/src/components/Image/Image.stories.tsx +86 -0
  310. package/src/components/Image/Image.tsx +246 -0
  311. package/src/components/Image/index.ts +5 -0
  312. package/src/components/Input/Input.stories.tsx +25 -48
  313. package/src/components/Input/Input.tsx +40 -76
  314. package/src/components/Link/Link.stories.tsx +10 -8
  315. package/src/components/Link/Link.tsx +2 -2
  316. package/src/components/{Lists → List}/List.stories.tsx +41 -44
  317. package/src/components/{Lists → List}/List.tsx +21 -22
  318. package/src/components/{Lists → List}/ListDropIndicator.tsx +7 -7
  319. package/src/components/{Lists → List}/Tree.stories.tsx +14 -13
  320. package/src/components/{Lists → List}/Tree.tsx +0 -1
  321. package/src/components/{Lists → List}/TreeDropIndicator.tsx +6 -6
  322. package/src/components/{Lists → List}/Treegrid.stories.tsx +39 -35
  323. package/src/components/List/Treegrid.tsx +188 -0
  324. package/src/components/Main/Main.stories.tsx +52 -28
  325. package/src/components/Main/Main.tsx +170 -100
  326. package/src/components/{Menus → Menu}/ContextMenu.stories.tsx +11 -10
  327. package/src/components/{Menus → Menu}/ContextMenu.tsx +10 -33
  328. package/src/components/{Menus → Menu}/DropdownMenu.stories.tsx +12 -11
  329. package/src/components/{Menus → Menu}/DropdownMenu.tsx +151 -114
  330. package/src/components/Message/Message.stories.tsx +35 -18
  331. package/src/components/Message/Message.tsx +43 -34
  332. package/src/components/Popover/Popover.stories.tsx +17 -16
  333. package/src/components/Popover/Popover.tsx +118 -96
  334. package/src/components/ScrollArea/ScrollArea.stories.tsx +223 -32
  335. package/src/components/ScrollArea/ScrollArea.tsx +97 -79
  336. package/src/components/ScrollArea/index.ts +1 -1
  337. package/src/components/ScrollContainer/ScrollContainer.stories.tsx +91 -0
  338. package/src/components/ScrollContainer/ScrollContainer.tsx +347 -0
  339. package/src/components/ScrollContainer/index.ts +5 -0
  340. package/src/components/Select/Select.stories.tsx +19 -18
  341. package/src/components/Select/Select.tsx +16 -31
  342. package/src/components/Separator/Separator.tsx +5 -8
  343. package/src/components/Skeleton/Skeleton.stories.tsx +51 -0
  344. package/src/components/Skeleton/Skeleton.tsx +26 -0
  345. package/src/components/Skeleton/index.ts +5 -0
  346. package/src/components/Splitter/Splitter.stories.tsx +83 -0
  347. package/src/components/Splitter/Splitter.tsx +127 -0
  348. package/src/components/Splitter/index.ts +5 -0
  349. package/src/components/Status/Status.stories.tsx +28 -23
  350. package/src/components/Status/Status.tsx +10 -7
  351. package/src/components/Tag/Tag.stories.tsx +16 -14
  352. package/src/components/Tag/Tag.tsx +3 -8
  353. package/src/components/ThemeProvider/ThemeProvider.stories.tsx +31 -0
  354. package/src/components/ThemeProvider/ThemeProvider.tsx +10 -10
  355. package/src/components/ThemeProvider/TranslationsProvider.tsx +1 -16
  356. package/src/components/ThemeProvider/index.ts +3 -3
  357. package/src/components/Toast/Toast.stories.tsx +12 -11
  358. package/src/components/Toast/Toast.tsx +22 -41
  359. package/src/components/Toolbar/Toolbar.stories.tsx +14 -14
  360. package/src/components/Toolbar/Toolbar.tsx +186 -11
  361. package/src/components/Tooltip/Tooltip.stories.tsx +34 -30
  362. package/src/components/Tooltip/Tooltip.tsx +42 -39
  363. package/src/components/index.ts +15 -9
  364. package/src/exemplars/generics.stories.tsx +41 -0
  365. package/src/exemplars/slot.stories.tsx +117 -0
  366. package/src/exemplars/tabster.stories.tsx +127 -0
  367. package/src/exemplars/virtualizer.stories.tsx +137 -0
  368. package/src/hooks/index.ts +1 -0
  369. package/src/hooks/useDensityContext.ts +3 -3
  370. package/src/hooks/useElevationContext.ts +1 -1
  371. package/src/hooks/useSafeArea.ts +3 -2
  372. package/src/hooks/useVisualViewport.ts +4 -4
  373. package/src/index.ts +2 -1
  374. package/src/playground/Controls.stories.tsx +12 -15
  375. package/src/playground/Custom.stories.tsx +18 -32
  376. package/src/playground/Typography.stories.tsx +11 -9
  377. package/src/primitives/Column/AUDIT.md +148 -0
  378. package/src/primitives/Column/Column.stories.tsx +181 -0
  379. package/src/primitives/Column/Column.tsx +165 -0
  380. package/src/primitives/Column/index.ts +5 -0
  381. package/src/primitives/Container/Container.stories.tsx +29 -0
  382. package/src/primitives/Container/Container.tsx +19 -0
  383. package/src/primitives/Container/index.ts +5 -0
  384. package/src/primitives/Flex/Flex.stories.tsx +57 -0
  385. package/src/primitives/Flex/Flex.tsx +27 -0
  386. package/src/primitives/Flex/index.ts +5 -0
  387. package/src/primitives/Grid/Grid.stories.tsx +56 -0
  388. package/src/primitives/Grid/Grid.tsx +30 -0
  389. package/src/primitives/Grid/index.ts +5 -0
  390. package/src/primitives/Panel/Panel.stories.tsx +68 -0
  391. package/src/primitives/Panel/Panel.tsx +120 -0
  392. package/src/primitives/Panel/index.ts +5 -0
  393. package/src/primitives/index.ts +9 -0
  394. package/src/testing/Loading.tsx +47 -0
  395. package/src/testing/decorators/index.ts +2 -1
  396. package/src/testing/decorators/withLayout.tsx +77 -0
  397. package/src/testing/decorators/withLayoutVariants.tsx +48 -0
  398. package/src/testing/decorators/withTheme.tsx +37 -0
  399. package/src/testing/index.ts +2 -0
  400. package/src/translations.ts +19 -0
  401. package/src/util/index.ts +3 -1
  402. package/src/util/usePx.ts +62 -0
  403. package/dist/lib/browser/chunk-BKNGMGOK.mjs +0 -4373
  404. package/dist/lib/browser/chunk-BKNGMGOK.mjs.map +0 -7
  405. package/dist/lib/node-esm/chunk-D2HZS6F4.mjs +0 -4375
  406. package/dist/lib/node-esm/chunk-D2HZS6F4.mjs.map +0 -7
  407. package/dist/types/src/components/AnchoredOverflow/AnchoredOverflow.d.ts +0 -15
  408. package/dist/types/src/components/AnchoredOverflow/AnchoredOverflow.d.ts.map +0 -1
  409. package/dist/types/src/components/AnchoredOverflow/index.d.ts +0 -2
  410. package/dist/types/src/components/AnchoredOverflow/index.d.ts.map +0 -1
  411. package/dist/types/src/components/Buttons/Button.d.ts.map +0 -1
  412. package/dist/types/src/components/Buttons/Button.stories.d.ts +0 -12
  413. package/dist/types/src/components/Buttons/Button.stories.d.ts.map +0 -1
  414. package/dist/types/src/components/Buttons/IconButton.d.ts.map +0 -1
  415. package/dist/types/src/components/Buttons/IconButton.stories.d.ts +0 -22
  416. package/dist/types/src/components/Buttons/IconButton.stories.d.ts.map +0 -1
  417. package/dist/types/src/components/Buttons/Toggle.d.ts.map +0 -1
  418. package/dist/types/src/components/Buttons/Toggle.stories.d.ts +0 -19
  419. package/dist/types/src/components/Buttons/Toggle.stories.d.ts.map +0 -1
  420. package/dist/types/src/components/Buttons/ToggleGroup.d.ts +0 -28
  421. package/dist/types/src/components/Buttons/ToggleGroup.d.ts.map +0 -1
  422. package/dist/types/src/components/Buttons/ToggleGroup.stories.d.ts +0 -39
  423. package/dist/types/src/components/Buttons/ToggleGroup.stories.d.ts.map +0 -1
  424. package/dist/types/src/components/Buttons/index.d.ts.map +0 -1
  425. package/dist/types/src/components/Dialogs/AlertDialog.d.ts +0 -31
  426. package/dist/types/src/components/Dialogs/AlertDialog.d.ts.map +0 -1
  427. package/dist/types/src/components/Dialogs/AlertDialog.stories.d.ts +0 -43
  428. package/dist/types/src/components/Dialogs/AlertDialog.stories.d.ts.map +0 -1
  429. package/dist/types/src/components/Dialogs/Dialog.d.ts +0 -31
  430. package/dist/types/src/components/Dialogs/Dialog.d.ts.map +0 -1
  431. package/dist/types/src/components/Dialogs/Dialog.stories.d.ts +0 -48
  432. package/dist/types/src/components/Dialogs/Dialog.stories.d.ts.map +0 -1
  433. package/dist/types/src/components/Dialogs/index.d.ts.map +0 -1
  434. package/dist/types/src/components/Lists/List.d.ts.map +0 -1
  435. package/dist/types/src/components/Lists/List.stories.d.ts +0 -37
  436. package/dist/types/src/components/Lists/List.stories.d.ts.map +0 -1
  437. package/dist/types/src/components/Lists/ListDropIndicator.d.ts.map +0 -1
  438. package/dist/types/src/components/Lists/Tree.d.ts.map +0 -1
  439. package/dist/types/src/components/Lists/Tree.stories.d.ts +0 -41
  440. package/dist/types/src/components/Lists/Tree.stories.d.ts.map +0 -1
  441. package/dist/types/src/components/Lists/TreeDropIndicator.d.ts.map +0 -1
  442. package/dist/types/src/components/Lists/Treegrid.d.ts.map +0 -1
  443. package/dist/types/src/components/Lists/Treegrid.stories.d.ts +0 -10
  444. package/dist/types/src/components/Lists/Treegrid.stories.d.ts.map +0 -1
  445. package/dist/types/src/components/Lists/index.d.ts.map +0 -1
  446. package/dist/types/src/components/Menus/ContextMenu.d.ts.map +0 -1
  447. package/dist/types/src/components/Menus/ContextMenu.stories.d.ts +0 -50
  448. package/dist/types/src/components/Menus/ContextMenu.stories.d.ts.map +0 -1
  449. package/dist/types/src/components/Menus/DropdownMenu.d.ts +0 -112
  450. package/dist/types/src/components/Menus/DropdownMenu.d.ts.map +0 -1
  451. package/dist/types/src/components/Menus/DropdownMenu.stories.d.ts +0 -50
  452. package/dist/types/src/components/Menus/DropdownMenu.stories.d.ts.map +0 -1
  453. package/dist/types/src/components/Menus/index.d.ts.map +0 -1
  454. package/dist/types/src/testing/decorators/withSurfaceVariantsLayout.d.ts +0 -12
  455. package/dist/types/src/testing/decorators/withSurfaceVariantsLayout.d.ts.map +0 -1
  456. package/dist/types/src/util/ThemedClassName.d.ts +0 -5
  457. package/dist/types/src/util/ThemedClassName.d.ts.map +0 -1
  458. package/src/components/AnchoredOverflow/AnchoredOverflow.tsx +0 -59
  459. package/src/components/AnchoredOverflow/index.ts +0 -5
  460. package/src/components/Buttons/Toggle.stories.tsx +0 -34
  461. package/src/components/Buttons/ToggleGroup.tsx +0 -41
  462. package/src/components/Dialogs/AlertDialog.stories.tsx +0 -67
  463. package/src/components/Dialogs/Dialog.stories.tsx +0 -66
  464. package/src/components/Dialogs/Dialog.tsx +0 -159
  465. package/src/components/Lists/Treegrid.tsx +0 -152
  466. package/src/testing/decorators/withSurfaceVariantsLayout.tsx +0 -51
  467. package/src/testing/decorators/withTheme.ts +0 -25
  468. package/src/util/ThemedClassName.ts +0 -7
  469. /package/dist/types/src/components/{Buttons → Button}/index.d.ts +0 -0
  470. /package/dist/types/src/components/{Dialogs → Dialog}/index.d.ts +0 -0
  471. /package/dist/types/src/components/{Lists → List}/ListDropIndicator.d.ts +0 -0
  472. /package/dist/types/src/components/{Lists → List}/TreeDropIndicator.d.ts +0 -0
  473. /package/dist/types/src/components/{Lists → List}/index.d.ts +0 -0
  474. /package/dist/types/src/components/{Menus → Menu}/index.d.ts +0 -0
  475. /package/src/components/{Buttons → Button}/index.ts +0 -0
  476. /package/src/components/{Dialogs → Dialog}/index.ts +0 -0
  477. /package/src/components/{Lists → List}/index.ts +0 -0
  478. /package/src/components/{Menus → Menu}/index.ts +0 -0
@@ -2,10 +2,9 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import { type IconWeight } from '@phosphor-icons/react';
6
- import { Root as CheckboxPrimitive, type CheckboxProps as CheckboxPrimitiveProps } from '@radix-ui/react-checkbox';
5
+ import * as CheckboxPrimitive from '@radix-ui/react-checkbox';
7
6
  import { useControllableState } from '@radix-ui/react-use-controllable-state';
8
- import React, { type ComponentPropsWithRef, type ForwardRefExoticComponent, forwardRef, useCallback } from 'react';
7
+ import React, { type ComponentPropsWithRef, type ForwardRefExoticComponent, forwardRef } from 'react';
9
8
 
10
9
  import {
11
10
  DescriptionAndValidation as DescriptionAndValidationPrimitive,
@@ -28,8 +27,8 @@ import {
28
27
  type ValidationProps as ValidationPrimitiveProps,
29
28
  useInputContext,
30
29
  } from '@dxos/react-input';
31
- import { mx } from '@dxos/react-ui-theme';
32
- import { type ClassNameValue, type Density, type Elevation, type Size } from '@dxos/react-ui-types';
30
+ import { mx } from '@dxos/ui-theme';
31
+ import { type Density, type Elevation, type Size } from '@dxos/ui-types';
33
32
 
34
33
  import { useDensityContext, useElevationContext, useThemeContext } from '../../hooks';
35
34
  import { type ThemedClassName } from '../../util';
@@ -41,10 +40,10 @@ type InputSharedProps = Partial<{ density: Density; elevation: Elevation; varian
41
40
 
42
41
  type LabelProps = ThemedClassName<LabelPrimitiveProps> & { srOnly?: boolean };
43
42
 
44
- const Label = forwardRef<HTMLLabelElement, LabelProps>(({ srOnly, classNames, children, ...props }, forwardedRef) => {
43
+ const Label = forwardRef<HTMLLabelElement, LabelProps>(({ classNames, children, srOnly, ...props }, forwardedRef) => {
45
44
  const { tx } = useThemeContext();
46
45
  return (
47
- <LabelPrimitive {...props} className={tx('input.label', 'input__label', { srOnly }, classNames)} ref={forwardedRef}>
46
+ <LabelPrimitive {...props} className={tx('input.label', { srOnly }, classNames)} ref={forwardedRef}>
48
47
  {children}
49
48
  </LabelPrimitive>
50
49
  );
@@ -53,14 +52,10 @@ const Label = forwardRef<HTMLLabelElement, LabelProps>(({ srOnly, classNames, ch
53
52
  type DescriptionProps = ThemedClassName<DescriptionPrimitiveProps> & { srOnly?: boolean };
54
53
 
55
54
  const Description = forwardRef<HTMLSpanElement, DescriptionProps>(
56
- ({ srOnly, classNames, children, ...props }, forwardedRef) => {
55
+ ({ classNames, children, srOnly, ...props }, forwardedRef) => {
57
56
  const { tx } = useThemeContext();
58
57
  return (
59
- <DescriptionPrimitive
60
- {...props}
61
- className={tx('input.description', 'input__description', { srOnly }, classNames)}
62
- ref={forwardedRef}
63
- >
58
+ <DescriptionPrimitive {...props} className={tx('input.description', { srOnly }, classNames)} ref={forwardedRef}>
64
59
  {children}
65
60
  </DescriptionPrimitive>
66
61
  );
@@ -70,18 +65,13 @@ const Description = forwardRef<HTMLSpanElement, DescriptionProps>(
70
65
  type ValidationProps = ThemedClassName<ValidationPrimitiveProps> & { srOnly?: boolean };
71
66
 
72
67
  const Validation = forwardRef<HTMLSpanElement, InputScopedProps<ValidationProps>>(
73
- ({ __inputScope, srOnly, classNames, children, ...props }, forwardedRef) => {
68
+ ({ __inputScope, classNames, children, srOnly, ...props }, forwardedRef) => {
74
69
  const { tx } = useThemeContext();
75
70
  const { validationValence } = useInputContext(INPUT_NAME, __inputScope);
76
71
  return (
77
72
  <ValidationPrimitive
78
73
  {...props}
79
- className={tx(
80
- 'input.validation',
81
- `input__validation-message input__validation-message--${validationValence}`,
82
- { srOnly, validationValence },
83
- classNames,
84
- )}
74
+ className={tx('input.validation', { srOnly, validationValence }, classNames)}
85
75
  ref={forwardedRef}
86
76
  >
87
77
  {children}
@@ -93,12 +83,12 @@ const Validation = forwardRef<HTMLSpanElement, InputScopedProps<ValidationProps>
93
83
  type DescriptionAndValidationProps = ThemedClassName<DescriptionAndValidationPrimitiveProps> & { srOnly?: boolean };
94
84
 
95
85
  const DescriptionAndValidation = forwardRef<HTMLParagraphElement, DescriptionAndValidationProps>(
96
- ({ srOnly, classNames, children, ...props }, forwardedRef) => {
86
+ ({ classNames, children, srOnly, ...props }, forwardedRef) => {
97
87
  const { tx } = useThemeContext();
98
88
  return (
99
89
  <DescriptionAndValidationPrimitive
100
90
  {...props}
101
- className={tx('input.descriptionAndValidation', 'input__description-and-validation', { srOnly }, classNames)}
91
+ className={tx('input.descriptionAndValidation', { srOnly }, classNames)}
102
92
  ref={forwardedRef}
103
93
  >
104
94
  {children}
@@ -107,54 +97,23 @@ const DescriptionAndValidation = forwardRef<HTMLParagraphElement, DescriptionAnd
107
97
  },
108
98
  );
109
99
 
110
- type PinInputProps = InputSharedProps &
111
- Omit<PinInputPrimitiveProps, 'segmentClassName' | 'inputClassName'> & {
112
- segmentClassName?: ClassNameValue;
113
- inputClassName?: ClassNameValue;
114
- };
100
+ type PinInputProps = ThemedClassName<InputSharedProps & Omit<PinInputPrimitiveProps, 'className' | 'segmentClassName'>>;
115
101
 
116
102
  const PinInput = forwardRef<HTMLInputElement, PinInputProps>(
117
- (
118
- {
119
- density: propsDensity,
120
- elevation: propsElevation,
121
- segmentClassName: propsSegmentClassName,
122
- inputClassName,
123
- variant,
124
- ...props
125
- },
126
- forwardedRef,
127
- ) => {
103
+ ({ classNames, density: propsDensity, elevation: propsElevation, ...props }, forwardedRef) => {
128
104
  const { hasIosKeyboard } = useThemeContext();
129
105
  const { tx } = useThemeContext();
130
106
  const density = useDensityContext(propsDensity);
131
107
  const elevation = useElevationContext(propsElevation);
132
108
 
133
- const segmentClassName = useCallback(
134
- ({ focused, validationValence }: Parameters<Exclude<PinInputPrimitiveProps['segmentClassName'], undefined>>[0]) =>
135
- tx(
136
- 'input.input',
137
- 'input--pin-segment',
138
- {
139
- variant: 'static',
140
- focused,
141
- disabled: props.disabled,
142
- density,
143
- elevation,
144
- validationValence,
145
- },
146
- propsSegmentClassName,
147
- ),
148
- [tx, props.disabled, elevation, propsElevation, density],
149
- );
150
109
  return (
151
110
  <PinInputPrimitive
152
111
  {...{
153
112
  ...props,
154
- segmentClassName,
155
113
  ...(props.autoFocus && !hasIosKeyboard && { autoFocus: true }),
156
114
  }}
157
- inputClassName={tx('input.inputWithSegments', 'input input--pin', { disabled: props.disabled }, inputClassName)}
115
+ className={tx('input.inputWithSegments', { disabled: props.disabled }, classNames) || ''}
116
+ segmentClassName={tx('input.segment', { disabled: props.disabled, density, elevation }) || ''}
158
117
  ref={forwardedRef}
159
118
  />
160
119
  );
@@ -163,24 +122,30 @@ const PinInput = forwardRef<HTMLInputElement, PinInputProps>(
163
122
 
164
123
  // TODO(burdon): Implement inline icon within button: e.g., https://www.radix-ui.com/themes/playground#text-field
165
124
 
166
- type TextInputProps = InputSharedProps & ThemedClassName<TextInputPrimitiveProps>;
125
+ type AutoFillProps = {
126
+ noAutoFill?: boolean;
127
+ };
128
+
129
+ type TextInputProps = InputSharedProps & ThemedClassName<TextInputPrimitiveProps> & AutoFillProps;
167
130
 
168
131
  const TextInput = forwardRef<HTMLInputElement, InputScopedProps<TextInputProps>>(
169
- ({ __inputScope, classNames, density: propsDensity, elevation: propsElevation, variant, ...props }, forwardedRef) => {
132
+ (
133
+ { __inputScope, classNames, density: densityProp, elevation: elevationProp, variant, noAutoFill, ...props },
134
+ forwardedRef,
135
+ ) => {
170
136
  const { hasIosKeyboard } = useThemeContext();
171
- const themeContextValue = useThemeContext();
172
- const density = useDensityContext(propsDensity);
173
- const elevation = useElevationContext(propsElevation);
137
+ const { tx } = useThemeContext();
138
+ const density = useDensityContext(densityProp);
139
+ const elevation = useElevationContext(elevationProp);
174
140
  const { validationValence } = useInputContext(INPUT_NAME, __inputScope);
175
141
 
176
- const { tx } = themeContextValue;
177
-
178
142
  return (
179
143
  <TextInputPrimitive
180
144
  {...props}
145
+ // TODO(wittjosiah): Factor out autofill properies.
146
+ {...{ 'data-1p-ignore': noAutoFill }}
181
147
  className={tx(
182
148
  'input.input',
183
- 'input',
184
149
  {
185
150
  variant,
186
151
  disabled: props.disabled,
@@ -211,8 +176,7 @@ const TextArea = forwardRef<HTMLTextAreaElement, InputScopedProps<TextAreaProps>
211
176
  <TextAreaPrimitive
212
177
  {...props}
213
178
  className={tx(
214
- 'input.input',
215
- 'input--text-area',
179
+ 'input.textArea',
216
180
  {
217
181
  variant,
218
182
  disabled: props.disabled,
@@ -220,7 +184,6 @@ const TextArea = forwardRef<HTMLTextAreaElement, InputScopedProps<TextAreaProps>
220
184
  elevation,
221
185
  validationValence,
222
186
  },
223
- '-mbe-labelSpacingBlock',
224
187
  classNames,
225
188
  )}
226
189
  {...(props.autoFocus && !hasIosKeyboard && { autoFocus: true })}
@@ -230,7 +193,9 @@ const TextArea = forwardRef<HTMLTextAreaElement, InputScopedProps<TextAreaProps>
230
193
  },
231
194
  );
232
195
 
233
- type CheckboxProps = ThemedClassName<Omit<CheckboxPrimitiveProps, 'children'>> & { size?: Size; weight?: IconWeight };
196
+ type CheckboxProps = ThemedClassName<Omit<CheckboxPrimitive.CheckboxProps, 'children'>> & {
197
+ size?: Size;
198
+ };
234
199
 
235
200
  const Checkbox: ForwardRefExoticComponent<CheckboxProps> = forwardRef<
236
201
  HTMLButtonElement,
@@ -239,12 +204,11 @@ const Checkbox: ForwardRefExoticComponent<CheckboxProps> = forwardRef<
239
204
  (
240
205
  {
241
206
  __inputScope,
207
+ classNames,
242
208
  checked: propsChecked,
243
209
  defaultChecked: propsDefaultChecked,
244
210
  onCheckedChange: propsOnCheckedChange,
245
211
  size,
246
- weight = 'bold',
247
- classNames,
248
212
  ...props
249
213
  },
250
214
  forwardedRef,
@@ -258,7 +222,7 @@ const Checkbox: ForwardRefExoticComponent<CheckboxProps> = forwardRef<
258
222
  const { tx } = useThemeContext();
259
223
 
260
224
  return (
261
- <CheckboxPrimitive
225
+ <CheckboxPrimitive.Root
262
226
  {...{
263
227
  ...props,
264
228
  checked,
@@ -269,15 +233,15 @@ const Checkbox: ForwardRefExoticComponent<CheckboxProps> = forwardRef<
269
233
  'aria-invalid': 'true' as const,
270
234
  'aria-errormessage': errorMessageId,
271
235
  }),
272
- className: tx('input.checkbox', 'input--checkbox', { size }, 'shrink-0', classNames),
236
+ className: tx('input.checkbox', { size }, 'shrink-0', classNames),
273
237
  }}
274
238
  ref={forwardedRef}
275
239
  >
276
240
  <Icon
277
241
  icon={checked === 'indeterminate' ? 'ph--minus--regular' : 'ph--check--regular'}
278
- classNames={tx('input.checkboxIndicator', 'input--checkbox__indicator', { size, checked })}
242
+ classNames={tx('input.checkboxIndicator', { size, checked })}
279
243
  />
280
- </CheckboxPrimitive>
244
+ </CheckboxPrimitive.Root>
281
245
  );
282
246
  },
283
247
  );
@@ -290,10 +254,10 @@ const Switch = forwardRef<HTMLInputElement, InputScopedProps<SwitchProps>>(
290
254
  (
291
255
  {
292
256
  __inputScope,
257
+ classNames,
293
258
  checked: propsChecked,
294
259
  defaultChecked: propsDefaultChecked,
295
260
  onCheckedChange: propsOnCheckedChange,
296
- classNames,
297
261
  ...props
298
262
  },
299
263
  forwardedRef,
@@ -2,17 +2,19 @@
2
2
  // Copyright 2022 DXOS.org
3
3
  //
4
4
 
5
- import '@dxos-theme';
5
+ import { type Meta, type StoryObj } from '@storybook/react-vite';
6
6
 
7
7
  import { withTheme } from '../../testing';
8
-
9
8
  import { Link } from './Link';
10
9
 
11
- export default {
12
- title: 'ui/react-ui-core/Link',
10
+ const meta = {
11
+ title: 'ui/react-ui-core/components/Link',
13
12
  component: Link,
14
- decorators: [withTheme],
15
- parameters: { chromatic: { disableSnapshot: false } },
16
- } as any;
13
+ decorators: [withTheme()],
14
+ } satisfies Meta<typeof Link>;
15
+
16
+ export default meta;
17
+
18
+ type Story = StoryObj<typeof meta>;
17
19
 
18
- export const Default = { args: { children: 'Hello', href: '#' } };
20
+ export const Default: Story = { args: { children: 'Hello', href: '#' } };
@@ -18,7 +18,7 @@ export type LinkProps = ThemedClassName<ComponentPropsWithRef<typeof Primitive.a
18
18
  export const Link = forwardRef<HTMLAnchorElement, LinkProps>(
19
19
  ({ asChild, variant, classNames, ...props }, forwardedRef) => {
20
20
  const { tx } = useThemeContext();
21
- const Root = asChild ? Slot : Primitive.a;
22
- return <Root {...props} className={tx('link.root', 'link', { variant }, classNames)} ref={forwardedRef} />;
21
+ const Comp = asChild ? Slot : Primitive.a;
22
+ return <Comp {...props} className={tx('link.root', { variant }, classNames)} ref={forwardedRef} />;
23
23
  },
24
24
  );
@@ -2,34 +2,28 @@
2
2
  // Copyright 2022 DXOS.org
3
3
  //
4
4
 
5
- import '@dxos-theme';
6
-
7
5
  import { DndContext, type DragEndEvent, type DragStartEvent } from '@dnd-kit/core';
8
6
  import { SortableContext, arrayMove, useSortable, verticalListSortingStrategy } from '@dnd-kit/sortable';
9
7
  import { CSS } from '@dnd-kit/utilities';
10
8
  import { useArrowNavigationGroup } from '@fluentui/react-tabster';
11
- import React, { type ReactNode, useState } from 'react';
9
+ import { type Meta, type StoryObj } from '@storybook/react-vite';
10
+ import React, { type ReactNode, useCallback, useState } from 'react';
12
11
 
13
- import {
14
- getSize,
15
- ghostHover,
16
- ghostSelected,
17
- ghostSelectedTrackingInterFromNormal,
18
- mx,
19
- surfaceShadow,
20
- } from '@dxos/react-ui-theme';
12
+ import { getSize, ghostHover, mx, surfaceShadow } from '@dxos/ui-theme';
21
13
 
22
14
  import { withTheme } from '../../testing';
23
15
  import { Icon } from '../Icon';
24
-
25
16
  import { List, ListItem, type ListScopedProps } from './List';
26
17
 
27
- export default {
28
- title: 'ui/react-ui-core/List',
18
+ const meta = {
19
+ title: 'ui/react-ui-core/components/List',
29
20
  component: List,
30
- decorators: [withTheme],
31
- parameters: { chromatic: { disableSnapshot: false } },
32
- };
21
+ decorators: [withTheme()],
22
+ } satisfies Meta<typeof List>;
23
+
24
+ export default meta;
25
+
26
+ type Story = StoryObj<typeof meta>;
33
27
 
34
28
  const UniformListItem = ({ id, text }: { id: string; text: string }) => {
35
29
  const { attributes, listeners, setNodeRef, transform } = useSortable({ id });
@@ -42,17 +36,17 @@ const UniformListItem = ({ id, text }: { id: string; text: string }) => {
42
36
  style={{ transform: CSS.Transform.toString(transform) }}
43
37
  >
44
38
  <ListItem.Endcap>
45
- <Icon icon='ph--dots-six-vertical--regular' classNames={mx(getSize(5), 'mbs-2.5')} />
39
+ <Icon icon='ph--dots-six-vertical--regular' classNames={mx(getSize(5), 'mt-2.5')} />
46
40
  </ListItem.Endcap>
47
- <ListItem.Heading classNames='grow pbs-2'>{text}</ListItem.Heading>
41
+ <ListItem.Heading classNames='grow pt-2'>{text}</ListItem.Heading>
48
42
  <ListItem.Endcap>
49
- <Icon icon='ph--push-pin--regular' classNames={mx(getSize(5), 'mbs-2.5')} />
43
+ <Icon icon='ph--push-pin--regular' classNames={mx(getSize(5), 'mt-2.5')} />
50
44
  </ListItem.Endcap>
51
45
  </ListItem.Root>
52
46
  );
53
47
  };
54
48
 
55
- export const UniformSizeDraggable = {
49
+ export const UniformSizeDraggable: Story = {
56
50
  render: ({ ...args }) => {
57
51
  const [items, setItems] = useState(
58
52
  [...Array(12)].map((_, index) => ({
@@ -61,16 +55,20 @@ export const UniformSizeDraggable = {
61
55
  })),
62
56
  );
63
57
 
64
- const handleDragEnd = (event: DragEndEvent) => {
65
- const { active, over } = event;
66
- if (active.id !== over?.id) {
67
- setItems((items) => {
68
- const oldIndex = items.findIndex((item) => item.id === active.id);
69
- const newIndex = items.findIndex((item) => item.id === over?.id);
70
- return arrayMove(items, oldIndex, newIndex);
71
- });
72
- }
73
- };
58
+ const handleDragEnd = useCallback(
59
+ (event: DragEndEvent) => {
60
+ const { active, over } = event;
61
+ if (active.id !== over?.id) {
62
+ setItems((items) => {
63
+ const oldIndex = items.findIndex((item) => item.id === active.id);
64
+ const newIndex = items.findIndex((item) => item.id === over?.id);
65
+ return arrayMove(items, oldIndex, newIndex);
66
+ });
67
+ }
68
+ },
69
+ [items],
70
+ );
71
+
74
72
  return (
75
73
  <DndContext onDragEnd={handleDragEnd}>
76
74
  <SortableContext items={items.map(({ id }) => id)} strategy={verticalListSortingStrategy}>
@@ -104,19 +102,19 @@ const ManySizesDraggableListItem = ({
104
102
  style={{ transform: CSS.Translate.toString(transform) }}
105
103
  >
106
104
  <ListItem.Endcap>
107
- <Icon icon='ph--dots-six-vertical--regular' classNames={mx(getSize(5), 'mbs-2.5')} />
105
+ <Icon icon='ph--dots-six-vertical--regular' classNames={mx(getSize(5), 'mt-2.5')} />
108
106
  </ListItem.Endcap>
109
- <ListItem.Heading classNames='grow pbs-2' asChild>
107
+ <ListItem.Heading classNames='grow pt-2' asChild>
110
108
  {text}
111
109
  </ListItem.Heading>
112
110
  <ListItem.Endcap>
113
- <Icon icon='ph--push-pin--regular' classNames={mx(getSize(5), 'mbs-2.5')} />
111
+ <Icon icon='ph--push-pin--regular' classNames={mx(getSize(5), 'mt-2.5')} />
114
112
  </ListItem.Endcap>
115
113
  </ListItem.Root>
116
114
  );
117
115
  };
118
116
 
119
- export const ManySizesDraggable = {
117
+ export const ManySizesDraggable: Story = {
120
118
  render: ({ ...args }) => {
121
119
  const [items, setItems] = useState(
122
120
  [...Array(12)].map((_, index) => ({
@@ -124,9 +122,9 @@ export const ManySizesDraggable = {
124
122
  text: (
125
123
  <p
126
124
  className={mx(
127
- index % 3 === 0 ? 'bs-20' : index % 2 === 0 ? 'bs-12' : 'bs-8',
125
+ index % 3 === 0 ? 'h-20' : index % 2 === 0 ? 'h-12' : 'h-8',
128
126
  surfaceShadow({ elevation: 'positioned' }),
129
- 'mbe-2 p-2 bg-white dark:bg-neutral-800 rounded',
127
+ 'mb-2 p-2 bg-white dark:bg-neutral-800 rounded-sm',
130
128
  )}
131
129
  >{`List item ${index + 1}`}</p>
132
130
  ),
@@ -164,7 +162,7 @@ export const ManySizesDraggable = {
164
162
  args: {},
165
163
  };
166
164
 
167
- export const Collapsible = {
165
+ export const Collapsible: Story = {
168
166
  render: ({ ...args }) => {
169
167
  const [items, _setItems] = useState(
170
168
  [...Array(12)].map((_, index) => ({
@@ -180,9 +178,9 @@ export const Collapsible = {
180
178
  <ListItem.Root key={id} id={id} collapsible={index !== 2} defaultOpen={index % 2 === 0}>
181
179
  <div role='none' className='grow flex'>
182
180
  {index !== 2 ? <ListItem.OpenTrigger /> : <ListItem.MockOpenTrigger />}
183
- <ListItem.Heading classNames='grow pbs-2'>{text}</ListItem.Heading>
181
+ <ListItem.Heading classNames='grow pt-2'>{text}</ListItem.Heading>
184
182
  <ListItem.Endcap>
185
- <Icon icon='ph--push-pin--regular' classNames={mx(getSize(5), 'mbs-2.5')} />
183
+ <Icon icon='ph--push-pin--regular' classNames={mx(getSize(5), 'mt-2.5')} />
186
184
  </ListItem.Endcap>
187
185
  </div>
188
186
  {index !== 2 && <ListItem.CollapsibleContent>{body}</ListItem.CollapsibleContent>}
@@ -193,11 +191,10 @@ export const Collapsible = {
193
191
  },
194
192
  args: {
195
193
  variant: 'unordered',
196
- // toggleOpenLabel: 'Open/close storybook list item', // TODO(burdon): ???
197
194
  },
198
195
  };
199
196
 
200
- export const SelectableListbox = {
197
+ export const SelectableListbox: Story = {
201
198
  render: () => {
202
199
  const [selectedId, setSelectedId] = useState<string>();
203
200
  const arrowNavigationAttrs = useArrowNavigationGroup({ axis: 'vertical' });
@@ -224,11 +221,11 @@ export const SelectableListbox = {
224
221
  key={id}
225
222
  tabIndex={0}
226
223
  selected={selectedId === id}
227
- classNames={mx('items-center', ghostHover, ghostSelected, ghostSelectedTrackingInterFromNormal)}
224
+ classNames={mx(ghostHover, 'dx-selected')}
228
225
  onClick={() => setSelectedId(id)}
229
226
  onKeyUp={(event) => handleKeyUp(event, id)}
230
227
  >
231
- <ListItem.Heading classNames='grow'>Lorem ipsum dolor sit amet</ListItem.Heading>
228
+ <ListItem.Heading classNames='flex px-1 items-center grow truncate'>{text}</ListItem.Heading>
232
229
  </ListItem.Root>
233
230
  ))}
234
231
  </List>
@@ -2,6 +2,7 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
+ import { Primitive } from '@radix-ui/react-primitive';
5
6
  import { Slot } from '@radix-ui/react-slot';
6
7
  import React, { type ComponentPropsWithoutRef, type FC, type ForwardRefExoticComponent, forwardRef } from 'react';
7
8
 
@@ -23,24 +24,25 @@ import {
23
24
  useListContext,
24
25
  useListItemContext,
25
26
  } from '@dxos/react-list';
26
- import { type Density } from '@dxos/react-ui-types';
27
+ import { composable, composableProps } from '@dxos/ui-theme';
28
+ import { type Density } from '@dxos/ui-types';
27
29
 
28
30
  import { useDensityContext, useThemeContext } from '../../hooks';
29
31
  import { type ThemedClassName } from '../../util';
30
32
  import { DensityProvider } from '../DensityProvider';
31
33
  import { Icon } from '../Icon';
32
-
33
34
  import { ListDropIndicator } from './ListDropIndicator';
34
35
 
35
- type ListProps = ThemedClassName<ListPrimitiveProps> & { density?: Density };
36
+ type ListProps = ThemedClassName<ListPrimitiveProps & { density?: Density }>;
36
37
 
37
- const List = forwardRef<HTMLOListElement, ListProps>(({ classNames, children, ...props }, forwardedRef) => {
38
+ const List = composable<HTMLOListElement, ListProps>(({ children, ...props }, forwardedRef) => {
38
39
  const { tx } = useThemeContext();
39
40
  const density = useDensityContext(props.density);
41
+ const { className, ...rest } = composableProps(props);
40
42
 
41
43
  return (
42
44
  <DensityProvider density={density}>
43
- <ListPrimitive {...props} className={tx('list.root', 'list', {}, classNames)} ref={forwardedRef}>
45
+ <ListPrimitive {...rest} className={tx('list.root', {}, className)} ref={forwardedRef}>
44
46
  {children}
45
47
  </ListPrimitive>
46
48
  </DensityProvider>
@@ -51,18 +53,18 @@ type ListItemEndcapProps = ThemedClassName<ComponentPropsWithoutRef<'div'>> & {
51
53
 
52
54
  const ListItemEndcap = forwardRef<HTMLDivElement, ListItemEndcapProps>(
53
55
  ({ children, classNames, asChild, ...props }, forwardedRef) => {
54
- const Root = asChild ? Slot : 'div';
56
+ const Comp = asChild ? Slot : Primitive.div;
55
57
  const density = useDensityContext();
56
58
  const { tx } = useThemeContext();
57
59
  return (
58
- <Root
60
+ <Comp
59
61
  {...(!asChild && { role: 'none' })}
60
62
  {...props}
61
- className={tx('list.item.endcap', 'list__listItem__endcap', { density }, classNames)}
63
+ className={tx('list.item.endcap', { density }, classNames)}
62
64
  ref={forwardedRef}
63
65
  >
64
66
  {children}
65
- </Root>
67
+ </Comp>
66
68
  );
67
69
  },
68
70
  );
@@ -73,13 +75,7 @@ const MockListItemOpenTrigger = ({
73
75
  }: ThemedClassName<Omit<ComponentPropsWithoutRef<'div'>, 'children'>>) => {
74
76
  const density = useDensityContext();
75
77
  const { tx } = useThemeContext();
76
- return (
77
- <div
78
- role='none'
79
- {...props}
80
- className={tx('list.item.openTrigger', 'list__listItem__openTrigger--mock', { density }, classNames)}
81
- />
82
- );
78
+ return <div role='none' {...props} className={tx('list.item.openTrigger', { density }, classNames)} />;
83
79
  };
84
80
 
85
81
  type ListItemHeadingProps = ThemedClassName<ListPrimitiveItemHeadingProps>;
@@ -91,10 +87,10 @@ const ListItemHeading = forwardRef<HTMLParagraphElement, ListItemHeadingProps>(
91
87
  return (
92
88
  <ListPrimitiveItemHeading
93
89
  {...props}
94
- className={tx('list.item.heading', 'list__listItem__heading', { density }, classNames)}
90
+ className={tx('list.item.heading', { density }, classNames)}
95
91
  ref={forwardedRef}
96
92
  >
97
- {children}
93
+ <span>{children}</span>
98
94
  </ListPrimitiveItemHeading>
99
95
  );
100
96
  },
@@ -107,15 +103,18 @@ const ListItemOpenTrigger = forwardRef<HTMLButtonElement, ListItemOpenTriggerPro
107
103
  const { tx } = useThemeContext();
108
104
  const density = useDensityContext();
109
105
  const { open } = useListItemContext(LIST_ITEM_NAME, __listItemScope);
110
- const iconName = open ? 'ph--caret-down--bold' : 'ph--caret-right--bold';
111
106
  return (
112
107
  <ListPrimitiveItemOpenTrigger
113
108
  {...props}
114
- className={tx('list.item.openTrigger', 'list__listItem__openTrigger', { density }, classNames)}
109
+ className={tx('list.item.openTrigger', { density }, classNames)}
115
110
  ref={forwardedRef}
116
111
  >
117
112
  {children || (
118
- <Icon icon={iconName} classNames={tx('list.item.openTriggerIcon', 'list__listItem__openTrigger__icon', {})} />
113
+ <Icon
114
+ size={3}
115
+ icon={open ? 'ph--caret-down--bold' : 'ph--caret-right--bold'}
116
+ classNames={tx('list.item.openTriggerIcon', {})}
117
+ />
119
118
  )}
120
119
  </ListPrimitiveItemOpenTrigger>
121
120
  );
@@ -131,7 +130,7 @@ const ListItemRoot = forwardRef<HTMLLIElement, ListItemRootProps>(
131
130
  return (
132
131
  <ListPrimitiveItem
133
132
  {...props}
134
- className={tx('list.item.root', 'list__listItem', { density, collapsible: props.collapsible }, classNames)}
133
+ className={tx('list.item.root', { density, collapsible: props.collapsible }, classNames)}
135
134
  ref={forwardedRef}
136
135
  >
137
136
  {children}
@@ -16,16 +16,16 @@ const edgeToOrientationMap: Record<Edge, Orientation> = {
16
16
 
17
17
  const orientationStyles: Record<Orientation, HTMLAttributes<HTMLElement>['className']> = {
18
18
  horizontal:
19
- 'h-[--line-thickness] left-[calc(var(--line-inset)+var(--terminal-radius))] right-[--line-inset] before:left-[--terminal-inset]',
19
+ 'h-(--line-thickness) left-[calc(var(--line-inset)+var(--terminal-radius))] right-(--line-inset) before:left-(--terminal-inset)',
20
20
  vertical:
21
- 'w-[--line-thickness] top-[calc(var(--line-inset)+var(--terminal-radius))] bottom-[--line-inset] before:top-[--terminal-inset]',
21
+ 'w-(--line-thickness) top-[calc(var(--line-inset)+var(--terminal-radius))] bottom-(--line-inset) before:top-(--terminal-inset)',
22
22
  };
23
23
 
24
24
  const edgeStyles: Record<Edge, HTMLAttributes<HTMLElement>['className']> = {
25
- top: 'top-[--line-offset] before:top-[--offset-terminal]',
26
- right: 'right-[--line-offset] before:right-[--offset-terminal]',
27
- bottom: 'bottom-[--line-offset] before:bottom-[--offset-terminal]',
28
- left: 'left-[--line-offset] before:left-[--offset-terminal]',
25
+ top: 'top-(--line-offset) before:top-(--offset-terminal)',
26
+ right: 'right-(--line-offset) before:right-(--offset-terminal)',
27
+ bottom: 'bottom-(--line-offset) before:bottom-(--offset-terminal)',
28
+ left: 'left-(--line-offset) before:left-(--offset-terminal)',
29
29
  };
30
30
 
31
31
  const strokeSize = 2;
@@ -64,7 +64,7 @@ export const ListDropIndicator = ({
64
64
  '--offset-terminal': `${offsetToAlignTerminalWithLine}px`,
65
65
  } as CSSProperties
66
66
  }
67
- className={`absolute z-10 pointer-events-none bg-accentSurface before:content-[''] before:w-[--terminal-size] before:h-[--terminal-size] box-border before:absolute before:border-[length:--line-thickness] before:border-solid before:border-accentSurface before:rounded-full ${orientationStyles[orientation]} ${edgeStyles[edge]}`}
67
+ className={`absolute z-10 pointer-events-none bg-accent-surface before:content-[''] before:w-(--terminal-size) before:h-(--terminal-size) box-border before:absolute before:border-[length:--line-thickness] before:border-solid before:border-accent-surface before:rounded-full ${orientationStyles[orientation]} ${edgeStyles[edge]}`}
68
68
  />
69
69
  );
70
70
  };