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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (443) hide show
  1. package/dist/lib/browser/chunk-OCVRIJCH.mjs +848 -0
  2. package/dist/lib/browser/chunk-OCVRIJCH.mjs.map +7 -0
  3. package/dist/lib/browser/index.mjs +4120 -65
  4. package/dist/lib/browser/index.mjs.map +4 -4
  5. package/dist/lib/browser/meta.json +1 -1
  6. package/dist/lib/browser/testing/index.mjs +91 -67
  7. package/dist/lib/browser/testing/index.mjs.map +4 -4
  8. package/dist/lib/node-esm/chunk-QUD5P3RU.mjs +850 -0
  9. package/dist/lib/node-esm/chunk-QUD5P3RU.mjs.map +7 -0
  10. package/dist/lib/node-esm/index.mjs +4120 -65
  11. package/dist/lib/node-esm/index.mjs.map +4 -4
  12. package/dist/lib/node-esm/meta.json +1 -1
  13. package/dist/lib/node-esm/testing/index.mjs +91 -67
  14. package/dist/lib/node-esm/testing/index.mjs.map +4 -4
  15. package/dist/types/src/components/Avatars/Avatar.d.ts +1 -1
  16. package/dist/types/src/components/Avatars/Avatar.d.ts.map +1 -1
  17. package/dist/types/src/components/Avatars/Avatar.stories.d.ts.map +1 -1
  18. package/dist/types/src/components/Avatars/AvatarGroup.stories.d.ts.map +1 -1
  19. package/dist/types/src/components/Breadcrumb/Breadcrumb.d.ts.map +1 -1
  20. package/dist/types/src/components/Breadcrumb/Breadcrumb.stories.d.ts.map +1 -1
  21. package/dist/types/src/components/{Buttons → Button}/Button.d.ts +3 -3
  22. package/dist/types/src/components/Button/Button.d.ts.map +1 -0
  23. package/dist/types/src/components/Button/Button.stories.d.ts.map +1 -0
  24. package/dist/types/src/components/{Buttons → Button}/IconButton.d.ts +2 -2
  25. package/dist/types/src/components/Button/IconButton.d.ts.map +1 -0
  26. package/dist/types/src/components/{Buttons → Button}/IconButton.stories.d.ts +3 -0
  27. package/dist/types/src/components/Button/IconButton.stories.d.ts.map +1 -0
  28. package/dist/types/src/components/{Buttons → Button}/Toggle.d.ts +2 -2
  29. package/dist/types/src/components/Button/Toggle.d.ts.map +1 -0
  30. package/dist/types/src/components/Button/Toggle.stories.d.ts +16 -0
  31. package/dist/types/src/components/Button/Toggle.stories.d.ts.map +1 -0
  32. package/dist/types/src/components/Button/ToggleGroup.d.ts +27 -0
  33. package/dist/types/src/components/Button/ToggleGroup.d.ts.map +1 -0
  34. package/dist/types/src/components/{Buttons → Button}/ToggleGroup.stories.d.ts +4 -4
  35. package/dist/types/src/components/Button/ToggleGroup.stories.d.ts.map +1 -0
  36. package/dist/types/src/components/Button/index.d.ts.map +1 -0
  37. package/dist/types/src/components/Card/Card.d.ts +127 -0
  38. package/dist/types/src/components/Card/Card.d.ts.map +1 -0
  39. package/dist/types/src/components/Card/Card.stories.d.ts +21 -0
  40. package/dist/types/src/components/Card/Card.stories.d.ts.map +1 -0
  41. package/dist/types/src/components/Card/index.d.ts +2 -0
  42. package/dist/types/src/components/Card/index.d.ts.map +1 -0
  43. package/dist/types/src/components/Clipboard/CopyButton.d.ts +1 -1
  44. package/dist/types/src/components/Clipboard/CopyButton.d.ts.map +1 -1
  45. package/dist/types/src/components/Clipboard/index.d.ts +10 -1
  46. package/dist/types/src/components/Clipboard/index.d.ts.map +1 -1
  47. package/dist/types/src/components/DensityProvider/DensityProvider.d.ts +1 -1
  48. package/dist/types/src/components/DensityProvider/DensityProvider.d.ts.map +1 -1
  49. package/dist/types/src/components/Dialog/AlertDialog.d.ts +51 -0
  50. package/dist/types/src/components/Dialog/AlertDialog.d.ts.map +1 -0
  51. package/dist/types/src/components/Dialog/AlertDialog.stories.d.ts.map +1 -0
  52. package/dist/types/src/components/Dialog/Dialog.d.ts +64 -0
  53. package/dist/types/src/components/Dialog/Dialog.d.ts.map +1 -0
  54. package/dist/types/src/components/Dialog/Dialog.stories.d.ts +25 -0
  55. package/dist/types/src/components/Dialog/Dialog.stories.d.ts.map +1 -0
  56. package/dist/types/src/components/Dialog/index.d.ts.map +1 -0
  57. package/dist/types/src/components/ElevationProvider/ElevationProvider.d.ts +1 -1
  58. package/dist/types/src/components/ElevationProvider/ElevationProvider.d.ts.map +1 -1
  59. package/dist/types/src/components/ErrorFallback/ErrorFallback.d.ts +11 -0
  60. package/dist/types/src/components/ErrorFallback/ErrorFallback.d.ts.map +1 -0
  61. package/dist/types/src/components/ErrorFallback/ErrorFallback.stories.d.ts +7 -0
  62. package/dist/types/src/components/ErrorFallback/ErrorFallback.stories.d.ts.map +1 -0
  63. package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts +19 -0
  64. package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts.map +1 -0
  65. package/dist/types/src/components/ErrorFallback/ThrowError.d.ts +9 -0
  66. package/dist/types/src/components/ErrorFallback/ThrowError.d.ts.map +1 -0
  67. package/dist/types/src/components/ErrorFallback/index.d.ts +5 -0
  68. package/dist/types/src/components/ErrorFallback/index.d.ts.map +1 -0
  69. package/dist/types/src/components/Focus/Focus.d.ts +36 -0
  70. package/dist/types/src/components/Focus/Focus.d.ts.map +1 -0
  71. package/dist/types/src/components/Focus/Focus.stories.d.ts +9 -0
  72. package/dist/types/src/components/Focus/Focus.stories.d.ts.map +1 -0
  73. package/dist/types/src/components/Focus/index.d.ts +2 -0
  74. package/dist/types/src/components/Focus/index.d.ts.map +1 -0
  75. package/dist/types/src/components/Icon/Icon.d.ts +4 -1
  76. package/dist/types/src/components/Icon/Icon.d.ts.map +1 -1
  77. package/dist/types/src/components/Icon/Icon.stories.d.ts +25 -0
  78. package/dist/types/src/components/Icon/Icon.stories.d.ts.map +1 -0
  79. package/dist/types/src/components/Image/Image.d.ts +15 -0
  80. package/dist/types/src/components/Image/Image.d.ts.map +1 -0
  81. package/dist/types/src/components/Image/Image.stories.d.ts +34 -0
  82. package/dist/types/src/components/Image/Image.stories.d.ts.map +1 -0
  83. package/dist/types/src/components/Image/index.d.ts +2 -0
  84. package/dist/types/src/components/Image/index.d.ts.map +1 -0
  85. package/dist/types/src/components/Input/Input.d.ts +7 -7
  86. package/dist/types/src/components/Input/Input.d.ts.map +1 -1
  87. package/dist/types/src/components/Input/Input.stories.d.ts +8 -8
  88. package/dist/types/src/components/Input/Input.stories.d.ts.map +1 -1
  89. package/dist/types/src/components/Link/Link.stories.d.ts.map +1 -1
  90. package/dist/types/src/components/{Lists → List}/List.d.ts +6 -4
  91. package/dist/types/src/components/List/List.d.ts.map +1 -0
  92. package/dist/types/src/components/{Lists → List}/List.stories.d.ts +3 -1
  93. package/dist/types/src/components/List/List.stories.d.ts.map +1 -0
  94. package/dist/types/src/components/List/ListDropIndicator.d.ts.map +1 -0
  95. package/dist/types/src/components/List/Tree.d.ts.map +1 -0
  96. package/dist/types/src/components/List/Tree.stories.d.ts.map +1 -0
  97. package/dist/types/src/components/List/TreeDropIndicator.d.ts.map +1 -0
  98. package/dist/types/src/components/{Lists → List}/Treegrid.d.ts +5 -9
  99. package/dist/types/src/components/List/Treegrid.d.ts.map +1 -0
  100. package/dist/types/src/components/List/Treegrid.stories.d.ts.map +1 -0
  101. package/dist/types/src/components/List/index.d.ts.map +1 -0
  102. package/dist/types/src/components/Main/Main.d.ts +17 -18
  103. package/dist/types/src/components/Main/Main.d.ts.map +1 -1
  104. package/dist/types/src/components/Main/Main.stories.d.ts +0 -3
  105. package/dist/types/src/components/Main/Main.stories.d.ts.map +1 -1
  106. package/dist/types/src/components/{Menus → Menu}/ContextMenu.d.ts +6 -6
  107. package/dist/types/src/components/Menu/ContextMenu.d.ts.map +1 -0
  108. package/dist/types/src/components/Menu/ContextMenu.stories.d.ts.map +1 -0
  109. package/dist/types/src/components/Menu/DropdownMenu.d.ts +113 -0
  110. package/dist/types/src/components/Menu/DropdownMenu.d.ts.map +1 -0
  111. package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts +28 -0
  112. package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts.map +1 -0
  113. package/dist/types/src/components/Menu/index.d.ts.map +1 -0
  114. package/dist/types/src/components/Message/Message.d.ts +1 -1
  115. package/dist/types/src/components/Message/Message.d.ts.map +1 -1
  116. package/dist/types/src/components/Message/Message.stories.d.ts +5 -6
  117. package/dist/types/src/components/Message/Message.stories.d.ts.map +1 -1
  118. package/dist/types/src/components/Popover/Popover.d.ts +33 -24
  119. package/dist/types/src/components/Popover/Popover.d.ts.map +1 -1
  120. package/dist/types/src/components/Popover/Popover.stories.d.ts.map +1 -1
  121. package/dist/types/src/components/ScrollArea/ScrollArea.d.ts +27 -27
  122. package/dist/types/src/components/ScrollArea/ScrollArea.d.ts.map +1 -1
  123. package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts +57 -8
  124. package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts.map +1 -1
  125. package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts +60 -0
  126. package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts.map +1 -0
  127. package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts +23 -0
  128. package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts.map +1 -0
  129. package/dist/types/src/components/ScrollContainer/index.d.ts +2 -0
  130. package/dist/types/src/components/ScrollContainer/index.d.ts.map +1 -0
  131. package/dist/types/src/components/Select/Select.d.ts +10 -10
  132. package/dist/types/src/components/Select/Select.d.ts.map +1 -1
  133. package/dist/types/src/components/Select/Select.stories.d.ts +2 -2
  134. package/dist/types/src/components/Select/Select.stories.d.ts.map +1 -1
  135. package/dist/types/src/components/Separator/Separator.d.ts +4 -4
  136. package/dist/types/src/components/Separator/Separator.d.ts.map +1 -1
  137. package/dist/types/src/components/Skeleton/Skeleton.d.ts +12 -0
  138. package/dist/types/src/components/Skeleton/Skeleton.d.ts.map +1 -0
  139. package/dist/types/src/components/Skeleton/Skeleton.stories.d.ts +17 -0
  140. package/dist/types/src/components/Skeleton/Skeleton.stories.d.ts.map +1 -0
  141. package/dist/types/src/components/Skeleton/index.d.ts +2 -0
  142. package/dist/types/src/components/Skeleton/index.d.ts.map +1 -0
  143. package/dist/types/src/components/Splitter/Splitter.d.ts +34 -0
  144. package/dist/types/src/components/Splitter/Splitter.d.ts.map +1 -0
  145. package/dist/types/src/components/Splitter/Splitter.stories.d.ts +7 -0
  146. package/dist/types/src/components/Splitter/Splitter.stories.d.ts.map +1 -0
  147. package/dist/types/src/components/Splitter/index.d.ts +2 -0
  148. package/dist/types/src/components/Splitter/index.d.ts.map +1 -0
  149. package/dist/types/src/components/Status/Status.d.ts +3 -4
  150. package/dist/types/src/components/Status/Status.d.ts.map +1 -1
  151. package/dist/types/src/components/Status/Status.stories.d.ts +4 -2
  152. package/dist/types/src/components/Status/Status.stories.d.ts.map +1 -1
  153. package/dist/types/src/components/Tag/Tag.d.ts +1 -1
  154. package/dist/types/src/components/Tag/Tag.d.ts.map +1 -1
  155. package/dist/types/src/components/Tag/Tag.stories.d.ts +0 -5
  156. package/dist/types/src/components/Tag/Tag.stories.d.ts.map +1 -1
  157. package/dist/types/src/components/ThemeProvider/ThemeProvider.d.ts +3 -3
  158. package/dist/types/src/components/ThemeProvider/ThemeProvider.d.ts.map +1 -1
  159. package/dist/types/src/components/{Menus/DropdownMenu.stories.d.ts → ThemeProvider/ThemeProvider.stories.d.ts} +2 -5
  160. package/dist/types/src/components/ThemeProvider/ThemeProvider.stories.d.ts.map +1 -0
  161. package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts +1 -8
  162. package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts.map +1 -1
  163. package/dist/types/src/components/ThemeProvider/index.d.ts +2 -1
  164. package/dist/types/src/components/ThemeProvider/index.d.ts.map +1 -1
  165. package/dist/types/src/components/Toast/Toast.d.ts +19 -19
  166. package/dist/types/src/components/Toast/Toast.d.ts.map +1 -1
  167. package/dist/types/src/components/Toast/Toast.stories.d.ts.map +1 -1
  168. package/dist/types/src/components/Toolbar/Toolbar.d.ts +37 -17
  169. package/dist/types/src/components/Toolbar/Toolbar.d.ts.map +1 -1
  170. package/dist/types/src/components/Toolbar/Toolbar.stories.d.ts.map +1 -1
  171. package/dist/types/src/components/Tooltip/Tooltip.d.ts +9 -9
  172. package/dist/types/src/components/Tooltip/Tooltip.d.ts.map +1 -1
  173. package/dist/types/src/components/Tooltip/Tooltip.stories.d.ts +2 -2
  174. package/dist/types/src/components/Tooltip/Tooltip.stories.d.ts.map +1 -1
  175. package/dist/types/src/components/index.d.ts +14 -8
  176. package/dist/types/src/components/index.d.ts.map +1 -1
  177. package/dist/types/src/exemplars/generics.stories.d.ts +19 -0
  178. package/dist/types/src/exemplars/generics.stories.d.ts.map +1 -0
  179. package/dist/types/src/exemplars/slot.stories.d.ts +15 -0
  180. package/dist/types/src/exemplars/slot.stories.d.ts.map +1 -0
  181. package/dist/types/src/exemplars/tabster.stories.d.ts +8 -0
  182. package/dist/types/src/exemplars/tabster.stories.d.ts.map +1 -0
  183. package/dist/types/src/exemplars/virtualizer.stories.d.ts +11 -0
  184. package/dist/types/src/exemplars/virtualizer.stories.d.ts.map +1 -0
  185. package/dist/types/src/hooks/index.d.ts +1 -0
  186. package/dist/types/src/hooks/index.d.ts.map +1 -1
  187. package/dist/types/src/hooks/useDensityContext.d.ts +2 -2
  188. package/dist/types/src/hooks/useDensityContext.d.ts.map +1 -1
  189. package/dist/types/src/hooks/useElevationContext.d.ts +1 -1
  190. package/dist/types/src/hooks/useElevationContext.d.ts.map +1 -1
  191. package/dist/types/src/index.d.ts +2 -1
  192. package/dist/types/src/index.d.ts.map +1 -1
  193. package/dist/types/src/playground/Controls.stories.d.ts.map +1 -1
  194. package/dist/types/src/playground/Custom.stories.d.ts.map +1 -1
  195. package/dist/types/src/primitives/Column/Column.d.ts +33 -0
  196. package/dist/types/src/primitives/Column/Column.d.ts.map +1 -0
  197. package/dist/types/src/primitives/Column/Column.stories.d.ts +25 -0
  198. package/dist/types/src/primitives/Column/Column.stories.d.ts.map +1 -0
  199. package/dist/types/src/primitives/Column/index.d.ts +2 -0
  200. package/dist/types/src/primitives/Column/index.d.ts.map +1 -0
  201. package/dist/types/src/primitives/Container/Container.d.ts +7 -0
  202. package/dist/types/src/primitives/Container/Container.d.ts.map +1 -0
  203. package/dist/types/src/primitives/Container/Container.stories.d.ts +6 -0
  204. package/dist/types/src/primitives/Container/Container.stories.d.ts.map +1 -0
  205. package/dist/types/src/primitives/Container/index.d.ts +2 -0
  206. package/dist/types/src/primitives/Container/index.d.ts.map +1 -0
  207. package/dist/types/src/primitives/Flex/Flex.d.ts +11 -0
  208. package/dist/types/src/primitives/Flex/Flex.d.ts.map +1 -0
  209. package/dist/types/src/primitives/Flex/Flex.stories.d.ts +8 -0
  210. package/dist/types/src/primitives/Flex/Flex.stories.d.ts.map +1 -0
  211. package/dist/types/src/primitives/Flex/index.d.ts +2 -0
  212. package/dist/types/src/primitives/Flex/index.d.ts.map +1 -0
  213. package/dist/types/src/primitives/Grid/Grid.d.ts +10 -0
  214. package/dist/types/src/primitives/Grid/Grid.d.ts.map +1 -0
  215. package/dist/types/src/primitives/Grid/Grid.stories.d.ts +8 -0
  216. package/dist/types/src/primitives/Grid/Grid.stories.d.ts.map +1 -0
  217. package/dist/types/src/primitives/Grid/index.d.ts +2 -0
  218. package/dist/types/src/primitives/Grid/index.d.ts.map +1 -0
  219. package/dist/types/src/primitives/Panel/Panel.d.ts +35 -0
  220. package/dist/types/src/primitives/Panel/Panel.d.ts.map +1 -0
  221. package/dist/types/src/primitives/Panel/Panel.stories.d.ts +6 -0
  222. package/dist/types/src/primitives/Panel/Panel.stories.d.ts.map +1 -0
  223. package/dist/types/src/primitives/Panel/index.d.ts +2 -0
  224. package/dist/types/src/primitives/Panel/index.d.ts.map +1 -0
  225. package/dist/types/src/primitives/index.d.ts +6 -0
  226. package/dist/types/src/primitives/index.d.ts.map +1 -0
  227. package/dist/types/src/testing/Loading.d.ts +9 -0
  228. package/dist/types/src/testing/Loading.d.ts.map +1 -0
  229. package/dist/types/src/testing/decorators/index.d.ts +1 -1
  230. package/dist/types/src/testing/decorators/index.d.ts.map +1 -1
  231. package/dist/types/src/testing/decorators/withLayout.d.ts +3 -3
  232. package/dist/types/src/testing/decorators/withLayout.d.ts.map +1 -1
  233. package/dist/types/src/testing/decorators/withLayoutVariants.d.ts +12 -0
  234. package/dist/types/src/testing/decorators/withLayoutVariants.d.ts.map +1 -0
  235. package/dist/types/src/testing/decorators/withTheme.d.ts +3 -2
  236. package/dist/types/src/testing/decorators/withTheme.d.ts.map +1 -1
  237. package/dist/types/src/testing/index.d.ts +1 -0
  238. package/dist/types/src/testing/index.d.ts.map +1 -1
  239. package/dist/types/src/translations.d.ts +11 -0
  240. package/dist/types/src/translations.d.ts.map +1 -0
  241. package/dist/types/src/util/index.d.ts +1 -2
  242. package/dist/types/src/util/index.d.ts.map +1 -1
  243. package/dist/types/src/util/usePx.d.ts.map +1 -1
  244. package/dist/types/tsconfig.tsbuildinfo +1 -1
  245. package/package.json +43 -37
  246. package/src/components/Avatars/Avatar.stories.tsx +7 -9
  247. package/src/components/Avatars/Avatar.tsx +7 -15
  248. package/src/components/Avatars/AvatarGroup.stories.tsx +2 -3
  249. package/src/components/Breadcrumb/Breadcrumb.stories.tsx +4 -5
  250. package/src/components/Breadcrumb/Breadcrumb.tsx +11 -37
  251. package/src/components/{Buttons → Button}/Button.stories.tsx +4 -5
  252. package/src/components/{Buttons → Button}/Button.tsx +12 -26
  253. package/src/components/{Buttons → Button}/IconButton.stories.tsx +8 -6
  254. package/src/components/{Buttons → Button}/IconButton.tsx +19 -15
  255. package/src/components/{Buttons → Button}/Toggle.stories.tsx +7 -7
  256. package/src/components/{Buttons → Button}/Toggle.tsx +4 -4
  257. package/src/components/{Buttons → Button}/ToggleGroup.stories.tsx +2 -3
  258. package/src/components/{Buttons → Button}/ToggleGroup.tsx +12 -16
  259. package/src/components/Card/Card.stories.tsx +151 -0
  260. package/src/components/Card/Card.tsx +505 -0
  261. package/src/components/Card/index.ts +5 -0
  262. package/src/components/Clipboard/CopyButton.tsx +8 -9
  263. package/src/components/DensityProvider/DensityProvider.tsx +1 -1
  264. package/src/components/Dialog/AlertDialog.stories.tsx +68 -0
  265. package/src/components/{Dialogs → Dialog}/AlertDialog.tsx +123 -82
  266. package/src/components/Dialog/Dialog.stories.tsx +177 -0
  267. package/src/components/Dialog/Dialog.tsx +285 -0
  268. package/src/components/ElevationProvider/ElevationProvider.tsx +1 -1
  269. package/src/components/ErrorFallback/ErrorFallback.stories.tsx +45 -0
  270. package/src/components/ErrorFallback/ErrorFallback.tsx +70 -0
  271. package/src/components/ErrorFallback/ErrorStack.tsx +114 -0
  272. package/src/components/ErrorFallback/ThrowError.tsx +37 -0
  273. package/src/components/ErrorFallback/index.ts +9 -0
  274. package/src/components/Focus/AUDIT.md +43 -0
  275. package/src/components/Focus/Focus.stories.tsx +230 -0
  276. package/src/components/Focus/Focus.tsx +201 -0
  277. package/src/components/Focus/index.ts +5 -0
  278. package/src/components/Icon/Icon.stories.tsx +143 -0
  279. package/src/components/Icon/Icon.tsx +6 -2
  280. package/src/components/Image/Image.stories.tsx +86 -0
  281. package/src/components/Image/Image.tsx +236 -0
  282. package/src/components/Image/index.ts +5 -0
  283. package/src/components/Input/Input.stories.tsx +21 -41
  284. package/src/components/Input/Input.tsx +38 -74
  285. package/src/components/Link/Link.stories.tsx +2 -3
  286. package/src/components/Link/Link.tsx +2 -2
  287. package/src/components/{Lists → List}/List.stories.tsx +30 -34
  288. package/src/components/{Lists → List}/List.tsx +17 -21
  289. package/src/components/{Lists → List}/ListDropIndicator.tsx +7 -7
  290. package/src/components/{Lists → List}/Tree.stories.tsx +5 -6
  291. package/src/components/{Lists → List}/Tree.tsx +0 -1
  292. package/src/components/{Lists → List}/TreeDropIndicator.tsx +6 -6
  293. package/src/components/{Lists → List}/Treegrid.stories.tsx +29 -30
  294. package/src/components/{Lists → List}/Treegrid.tsx +23 -28
  295. package/src/components/Main/Main.stories.tsx +41 -24
  296. package/src/components/Main/Main.tsx +150 -94
  297. package/src/components/{Menus → Menu}/ContextMenu.stories.tsx +2 -3
  298. package/src/components/{Menus → Menu}/ContextMenu.tsx +9 -33
  299. package/src/components/{Menus → Menu}/DropdownMenu.stories.tsx +3 -4
  300. package/src/components/{Menus → Menu}/DropdownMenu.tsx +137 -110
  301. package/src/components/Message/Message.stories.tsx +27 -13
  302. package/src/components/Message/Message.tsx +43 -34
  303. package/src/components/Popover/Popover.stories.tsx +8 -9
  304. package/src/components/Popover/Popover.tsx +114 -92
  305. package/src/components/ScrollArea/ScrollArea.stories.tsx +223 -34
  306. package/src/components/ScrollArea/ScrollArea.tsx +97 -79
  307. package/src/components/ScrollArea/index.ts +1 -1
  308. package/src/components/ScrollContainer/ScrollContainer.stories.tsx +91 -0
  309. package/src/components/ScrollContainer/ScrollContainer.tsx +347 -0
  310. package/src/components/ScrollContainer/index.ts +5 -0
  311. package/src/components/Select/Select.stories.tsx +8 -9
  312. package/src/components/Select/Select.tsx +11 -27
  313. package/src/components/Separator/Separator.tsx +5 -8
  314. package/src/components/Skeleton/Skeleton.stories.tsx +51 -0
  315. package/src/components/Skeleton/Skeleton.tsx +26 -0
  316. package/src/components/Skeleton/index.ts +5 -0
  317. package/src/components/Splitter/Splitter.stories.tsx +83 -0
  318. package/src/components/Splitter/Splitter.tsx +127 -0
  319. package/src/components/Splitter/index.ts +5 -0
  320. package/src/components/Status/Status.stories.tsx +21 -18
  321. package/src/components/Status/Status.tsx +10 -7
  322. package/src/components/Tag/Tag.stories.tsx +6 -12
  323. package/src/components/Tag/Tag.tsx +3 -8
  324. package/src/components/ThemeProvider/ThemeProvider.stories.tsx +31 -0
  325. package/src/components/ThemeProvider/ThemeProvider.tsx +10 -10
  326. package/src/components/ThemeProvider/TranslationsProvider.tsx +1 -16
  327. package/src/components/ThemeProvider/index.ts +3 -3
  328. package/src/components/Toast/Toast.stories.tsx +3 -4
  329. package/src/components/Toast/Toast.tsx +22 -41
  330. package/src/components/Toolbar/Toolbar.stories.tsx +4 -7
  331. package/src/components/Toolbar/Toolbar.tsx +186 -23
  332. package/src/components/Tooltip/Tooltip.stories.tsx +21 -20
  333. package/src/components/Tooltip/Tooltip.tsx +40 -38
  334. package/src/components/index.ts +15 -9
  335. package/src/exemplars/generics.stories.tsx +41 -0
  336. package/src/exemplars/slot.stories.tsx +117 -0
  337. package/src/exemplars/tabster.stories.tsx +127 -0
  338. package/src/exemplars/virtualizer.stories.tsx +137 -0
  339. package/src/hooks/index.ts +1 -0
  340. package/src/hooks/useDensityContext.ts +3 -3
  341. package/src/hooks/useElevationContext.ts +1 -1
  342. package/src/index.ts +2 -1
  343. package/src/playground/Controls.stories.tsx +3 -10
  344. package/src/playground/Custom.stories.tsx +13 -18
  345. package/src/playground/Typography.stories.tsx +3 -3
  346. package/src/primitives/Column/AUDIT.md +148 -0
  347. package/src/primitives/Column/Column.stories.tsx +181 -0
  348. package/src/primitives/Column/Column.tsx +165 -0
  349. package/src/primitives/Column/index.ts +5 -0
  350. package/src/primitives/Container/Container.stories.tsx +29 -0
  351. package/src/primitives/Container/Container.tsx +19 -0
  352. package/src/primitives/Container/index.ts +5 -0
  353. package/src/primitives/Flex/Flex.stories.tsx +57 -0
  354. package/src/primitives/Flex/Flex.tsx +27 -0
  355. package/src/primitives/Flex/index.ts +5 -0
  356. package/src/primitives/Grid/Grid.stories.tsx +56 -0
  357. package/src/primitives/Grid/Grid.tsx +30 -0
  358. package/src/primitives/Grid/index.ts +5 -0
  359. package/src/primitives/Panel/Panel.stories.tsx +68 -0
  360. package/src/primitives/Panel/Panel.tsx +120 -0
  361. package/src/primitives/Panel/index.ts +5 -0
  362. package/src/primitives/index.ts +9 -0
  363. package/src/testing/Loading.tsx +47 -0
  364. package/src/testing/decorators/index.ts +1 -1
  365. package/src/testing/decorators/withLayout.tsx +39 -18
  366. package/src/testing/decorators/withLayoutVariants.tsx +48 -0
  367. package/src/testing/decorators/withTheme.tsx +26 -20
  368. package/src/testing/index.ts +2 -0
  369. package/src/translations.ts +19 -0
  370. package/src/util/index.ts +2 -2
  371. package/src/util/usePx.ts +1 -0
  372. package/dist/lib/browser/chunk-KX5JDELJ.mjs +0 -4521
  373. package/dist/lib/browser/chunk-KX5JDELJ.mjs.map +0 -7
  374. package/dist/lib/node-esm/chunk-3HDQYL5S.mjs +0 -4523
  375. package/dist/lib/node-esm/chunk-3HDQYL5S.mjs.map +0 -7
  376. package/dist/types/src/components/AnchoredOverflow/AnchoredOverflow.d.ts +0 -15
  377. package/dist/types/src/components/AnchoredOverflow/AnchoredOverflow.d.ts.map +0 -1
  378. package/dist/types/src/components/AnchoredOverflow/index.d.ts +0 -2
  379. package/dist/types/src/components/AnchoredOverflow/index.d.ts.map +0 -1
  380. package/dist/types/src/components/Buttons/Button.d.ts.map +0 -1
  381. package/dist/types/src/components/Buttons/Button.stories.d.ts.map +0 -1
  382. package/dist/types/src/components/Buttons/IconButton.d.ts.map +0 -1
  383. package/dist/types/src/components/Buttons/IconButton.stories.d.ts.map +0 -1
  384. package/dist/types/src/components/Buttons/Toggle.d.ts.map +0 -1
  385. package/dist/types/src/components/Buttons/Toggle.stories.d.ts +0 -13
  386. package/dist/types/src/components/Buttons/Toggle.stories.d.ts.map +0 -1
  387. package/dist/types/src/components/Buttons/ToggleGroup.d.ts +0 -27
  388. package/dist/types/src/components/Buttons/ToggleGroup.d.ts.map +0 -1
  389. package/dist/types/src/components/Buttons/ToggleGroup.stories.d.ts.map +0 -1
  390. package/dist/types/src/components/Buttons/index.d.ts.map +0 -1
  391. package/dist/types/src/components/Dialogs/AlertDialog.d.ts +0 -31
  392. package/dist/types/src/components/Dialogs/AlertDialog.d.ts.map +0 -1
  393. package/dist/types/src/components/Dialogs/AlertDialog.stories.d.ts.map +0 -1
  394. package/dist/types/src/components/Dialogs/Dialog.d.ts +0 -31
  395. package/dist/types/src/components/Dialogs/Dialog.d.ts.map +0 -1
  396. package/dist/types/src/components/Dialogs/Dialog.stories.d.ts +0 -25
  397. package/dist/types/src/components/Dialogs/Dialog.stories.d.ts.map +0 -1
  398. package/dist/types/src/components/Dialogs/index.d.ts.map +0 -1
  399. package/dist/types/src/components/Lists/List.d.ts.map +0 -1
  400. package/dist/types/src/components/Lists/List.stories.d.ts.map +0 -1
  401. package/dist/types/src/components/Lists/ListDropIndicator.d.ts.map +0 -1
  402. package/dist/types/src/components/Lists/Tree.d.ts.map +0 -1
  403. package/dist/types/src/components/Lists/Tree.stories.d.ts.map +0 -1
  404. package/dist/types/src/components/Lists/TreeDropIndicator.d.ts.map +0 -1
  405. package/dist/types/src/components/Lists/Treegrid.d.ts.map +0 -1
  406. package/dist/types/src/components/Lists/Treegrid.stories.d.ts.map +0 -1
  407. package/dist/types/src/components/Lists/index.d.ts.map +0 -1
  408. package/dist/types/src/components/Menus/ContextMenu.d.ts.map +0 -1
  409. package/dist/types/src/components/Menus/ContextMenu.stories.d.ts.map +0 -1
  410. package/dist/types/src/components/Menus/DropdownMenu.d.ts +0 -113
  411. package/dist/types/src/components/Menus/DropdownMenu.d.ts.map +0 -1
  412. package/dist/types/src/components/Menus/DropdownMenu.stories.d.ts.map +0 -1
  413. package/dist/types/src/components/Menus/index.d.ts.map +0 -1
  414. package/dist/types/src/testing/decorators/withSurfaceVariantsLayout.d.ts +0 -12
  415. package/dist/types/src/testing/decorators/withSurfaceVariantsLayout.d.ts.map +0 -1
  416. package/dist/types/src/util/ThemedClassName.d.ts +0 -5
  417. package/dist/types/src/util/ThemedClassName.d.ts.map +0 -1
  418. package/dist/types/src/util/domino.d.ts +0 -18
  419. package/dist/types/src/util/domino.d.ts.map +0 -1
  420. package/src/components/AnchoredOverflow/AnchoredOverflow.tsx +0 -59
  421. package/src/components/AnchoredOverflow/index.ts +0 -5
  422. package/src/components/Dialogs/AlertDialog.stories.tsx +0 -69
  423. package/src/components/Dialogs/Dialog.stories.tsx +0 -67
  424. package/src/components/Dialogs/Dialog.tsx +0 -159
  425. package/src/testing/decorators/withSurfaceVariantsLayout.tsx +0 -51
  426. package/src/util/ThemedClassName.ts +0 -7
  427. package/src/util/domino.ts +0 -53
  428. /package/dist/types/src/components/{Buttons → Button}/Button.stories.d.ts +0 -0
  429. /package/dist/types/src/components/{Buttons → Button}/index.d.ts +0 -0
  430. /package/dist/types/src/components/{Dialogs → Dialog}/AlertDialog.stories.d.ts +0 -0
  431. /package/dist/types/src/components/{Dialogs → Dialog}/index.d.ts +0 -0
  432. /package/dist/types/src/components/{Lists → List}/ListDropIndicator.d.ts +0 -0
  433. /package/dist/types/src/components/{Lists → List}/Tree.d.ts +0 -0
  434. /package/dist/types/src/components/{Lists → List}/Tree.stories.d.ts +0 -0
  435. /package/dist/types/src/components/{Lists → List}/TreeDropIndicator.d.ts +0 -0
  436. /package/dist/types/src/components/{Lists → List}/Treegrid.stories.d.ts +0 -0
  437. /package/dist/types/src/components/{Lists → List}/index.d.ts +0 -0
  438. /package/dist/types/src/components/{Menus → Menu}/ContextMenu.stories.d.ts +0 -0
  439. /package/dist/types/src/components/{Menus → Menu}/index.d.ts +0 -0
  440. /package/src/components/{Buttons → Button}/index.ts +0 -0
  441. /package/src/components/{Dialogs → Dialog}/index.ts +0 -0
  442. /package/src/components/{Lists → List}/index.ts +0 -0
  443. /package/src/components/{Menus → Menu}/index.ts +0 -0
@@ -0,0 +1,56 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ import { type Meta, type StoryObj } from '@storybook/react-vite';
6
+ import React from 'react';
7
+
8
+ import { type ChromaticPalette } from '@dxos/ui-types';
9
+
10
+ import { withLayout, withTheme } from '../../testing';
11
+ import { Grid } from './Grid';
12
+
13
+ const Cell = ({ label, hue }: { label: string; hue: ChromaticPalette }) => (
14
+ <div data-hue={hue} className='dx-panel p-2 text-sm font-mono border rounded-sm'>
15
+ {label}
16
+ </div>
17
+ );
18
+
19
+ const ColsStory = () => (
20
+ <Grid cols={3} classNames='gap-2 p-2'>
21
+ <Cell label='Row 1' hue='red' />
22
+ <Cell label='Row 2' hue='green' />
23
+ <Cell label='Row 3' hue='blue' />
24
+ </Grid>
25
+ );
26
+
27
+ const RowsStory = () => (
28
+ <Grid rows={3} classNames='gap-2 p-2'>
29
+ <Cell label='Row 1' hue='red' />
30
+ <Cell label='Row 2' hue='green' />
31
+ <Cell label='Row 3' hue='blue' />
32
+ </Grid>
33
+ );
34
+
35
+ const MixedStory = () => (
36
+ <Grid cols={2} rows={2} classNames='gap-2 p-2'>
37
+ <Cell label='A' hue='red' />
38
+ <Cell label='B' hue='green' />
39
+ <Cell label='C' hue='blue' />
40
+ <Cell label='D' hue='yellow' />
41
+ </Grid>
42
+ );
43
+
44
+ const meta: Meta = {
45
+ title: 'ui/react-ui-core/primitives/Grid',
46
+ decorators: [withTheme(), withLayout({ layout: 'column' })],
47
+ parameters: { layout: 'fullscreen' },
48
+ };
49
+
50
+ export default meta;
51
+
52
+ type Story = StoryObj<typeof meta>;
53
+
54
+ export const Cols: Story = { render: ColsStory };
55
+ export const Rows: Story = { render: RowsStory };
56
+ export const Mixed: Story = { render: MixedStory };
@@ -0,0 +1,30 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ import React from 'react';
6
+
7
+ import { composable, composableProps, mx } from '@dxos/ui-theme';
8
+
9
+ export type GridProps = { cols?: number; rows?: number; grow?: boolean };
10
+
11
+ export const Grid = composable<HTMLDivElement, GridProps>(
12
+ ({ children, style, role, cols, rows, grow = true, ...props }, forwardedRef) => {
13
+ const { className, ...rest } = composableProps(props);
14
+ return (
15
+ <div
16
+ ref={forwardedRef}
17
+ {...rest}
18
+ role={role ?? 'none'}
19
+ className={mx('grid overflow-hidden', grow && 'dx-container', className)}
20
+ style={{
21
+ gridTemplateColumns: cols ? `repeat(${cols}, 1fr)` : undefined,
22
+ gridTemplateRows: rows ? `repeat(${rows}, 1fr)` : undefined,
23
+ ...style,
24
+ }}
25
+ >
26
+ {children}
27
+ </div>
28
+ );
29
+ },
30
+ );
@@ -0,0 +1,5 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ export * from './Grid';
@@ -0,0 +1,68 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { type Meta, type StoryObj } from '@storybook/react-vite';
6
+ import React from 'react';
7
+
8
+ import { composable, composableProps } from '@dxos/ui-theme';
9
+
10
+ import { Input, ScrollArea, ScrollAreaRootProps, Toolbar } from '../../components';
11
+ import { withLayout, withTheme } from '../../testing';
12
+ import { Panel } from './Panel';
13
+
14
+ const List = composable<HTMLDivElement, ScrollAreaRootProps>((props, forwardedRef) => {
15
+ return (
16
+ <ScrollArea.Root centered {...composableProps(props, { role: 'list' })} ref={forwardedRef}>
17
+ <ScrollArea.Viewport>
18
+ {Array.from({ length: 100 }).map((_, i) => (
19
+ <div key={i} role='listitem' className='p-1 hover:bg-hover-surface'>
20
+ Item {i}
21
+ </div>
22
+ ))}
23
+ </ScrollArea.Viewport>
24
+ </ScrollArea.Root>
25
+ );
26
+ });
27
+
28
+ const DefaultStory = () => {
29
+ return (
30
+ <Panel.Root className='dx-document'>
31
+ <Panel.Toolbar asChild>
32
+ <Toolbar.Root classNames='gap-2'>
33
+ <Toolbar.IconButton icon='ph--plus--regular' variant='primary' label='Add' />
34
+ <Input.Root>
35
+ <Input.TextInput placeholder='Search' />
36
+ </Input.Root>
37
+ <Toolbar.IconButton icon='ph--dots-three-vertical--regular' iconOnly label='Menu' />
38
+ </Toolbar.Root>
39
+ </Panel.Toolbar>
40
+
41
+ <Panel.Content asChild>
42
+ <List />
43
+ </Panel.Content>
44
+
45
+ <Panel.Statusbar asChild>
46
+ <Toolbar.Root classNames='justify-between'>
47
+ <Toolbar.IconButton variant='ghost' icon='ph--house--regular' iconOnly label='Add' />
48
+ <Toolbar.IconButton variant='ghost' icon='ph--alarm--regular' iconOnly label='Status' />
49
+ </Toolbar.Root>
50
+ </Panel.Statusbar>
51
+ </Panel.Root>
52
+ );
53
+ };
54
+
55
+ const meta: Meta = {
56
+ title: 'ui/react-ui-core/primitives/Panel',
57
+ render: DefaultStory,
58
+ decorators: [withTheme(), withLayout({ layout: 'fullscreen' })],
59
+ parameters: {
60
+ layout: 'fullscreen',
61
+ },
62
+ };
63
+
64
+ export default meta;
65
+
66
+ type Story = StoryObj<typeof meta>;
67
+
68
+ export const Default: Story = {};
@@ -0,0 +1,120 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ import { Primitive } from '@radix-ui/react-primitive';
6
+ import { Slot } from '@radix-ui/react-slot';
7
+ import React, { type CSSProperties } from 'react';
8
+
9
+ import { composableProps, PanelStyleProps, slottable } from '@dxos/ui-theme';
10
+ import { type SlottableProps } from '@dxos/ui-types';
11
+
12
+ import { useThemeContext } from '../../hooks';
13
+
14
+ //
15
+ // Root
16
+ //
17
+
18
+ const GRID_TEMPLATE_ROWS = 'auto 1fr auto';
19
+ const GRID_TEMPLATE_AREAS = '"toolbar" "content" "statusbar"';
20
+
21
+ type PanelRootProps = SlottableProps<{ style?: CSSProperties }>;
22
+
23
+ const PanelRoot = slottable<HTMLDivElement, { style?: CSSProperties }>(
24
+ ({ children, asChild, role, style, ...props }, forwardedRef) => {
25
+ const { className, ...rest } = composableProps(props);
26
+ const Comp = asChild ? Slot : Primitive.div;
27
+ const { tx } = useThemeContext();
28
+ return (
29
+ <Comp
30
+ {...rest}
31
+ role={role ?? 'none'}
32
+ style={{
33
+ gridTemplateRows: GRID_TEMPLATE_ROWS,
34
+ gridTemplateAreas: GRID_TEMPLATE_AREAS,
35
+ ...style,
36
+ }}
37
+ className={tx('panel.root', {}, className)}
38
+ ref={forwardedRef}
39
+ >
40
+ {children}
41
+ </Comp>
42
+ );
43
+ },
44
+ );
45
+
46
+ PanelRoot.displayName = 'Panel.Root';
47
+
48
+ //
49
+ // Toolbar
50
+ //
51
+
52
+ type PanelToolbarProps = SlottableProps & Pick<PanelStyleProps, 'size'>;
53
+
54
+ const PanelToolbar = slottable<HTMLDivElement, Pick<PanelStyleProps, 'size'>>(
55
+ ({ children, asChild, size, ...props }, forwardedRef) => {
56
+ const { className, ...rest } = composableProps(props);
57
+ const Comp = asChild ? Slot : Primitive.div;
58
+ const { tx } = useThemeContext();
59
+ return (
60
+ <Comp {...rest} data-slot='toolbar' className={tx('panel.toolbar', { size }, className)} ref={forwardedRef}>
61
+ {children}
62
+ </Comp>
63
+ );
64
+ },
65
+ );
66
+
67
+ PanelToolbar.displayName = 'Panel.Toolbar';
68
+
69
+ //
70
+ // Content
71
+ //
72
+
73
+ type PanelContentProps = SlottableProps;
74
+
75
+ const PanelContent = slottable<HTMLDivElement>(({ children, asChild, ...props }, forwardedRef) => {
76
+ const { className, ...rest } = composableProps(props);
77
+ const Comp = asChild ? Slot : Primitive.div;
78
+ const { tx } = useThemeContext();
79
+ return (
80
+ <Comp {...rest} data-slot='content' className={tx('panel.content', {}, className)} ref={forwardedRef}>
81
+ {children}
82
+ </Comp>
83
+ );
84
+ });
85
+
86
+ PanelContent.displayName = 'Panel.Content';
87
+
88
+ //
89
+ // Statusbar
90
+ //
91
+
92
+ type PanelStatusbarProps = SlottableProps & Pick<PanelStyleProps, 'size'>;
93
+
94
+ const PanelStatusbar = slottable<HTMLDivElement, Pick<PanelStyleProps, 'size'>>(
95
+ ({ children, asChild, size, ...props }, forwardedRef) => {
96
+ const { className, ...rest } = composableProps(props);
97
+ const Comp = asChild ? Slot : Primitive.div;
98
+ const { tx } = useThemeContext();
99
+ return (
100
+ <Comp {...rest} data-slot='statusbar' className={tx('panel.statusbar', { size }, className)} ref={forwardedRef}>
101
+ {children}
102
+ </Comp>
103
+ );
104
+ },
105
+ );
106
+
107
+ PanelStatusbar.displayName = 'Panel.Statusbar';
108
+
109
+ //
110
+ // Panel
111
+ //
112
+
113
+ export const Panel = {
114
+ Root: PanelRoot,
115
+ Toolbar: PanelToolbar,
116
+ Content: PanelContent,
117
+ Statusbar: PanelStatusbar,
118
+ };
119
+
120
+ export type { PanelRootProps, PanelToolbarProps, PanelContentProps, PanelStatusbarProps };
@@ -0,0 +1,5 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ export * from './Panel';
@@ -0,0 +1,9 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ export * from './Column';
6
+ export * from './Container';
7
+ export * from './Flex';
8
+ export * from './Grid';
9
+ export * from './Panel';
@@ -0,0 +1,47 @@
1
+ //
2
+ // Copyright 2023 DXOS.org
3
+ //
4
+
5
+ import React, { captureOwnerStack, useEffect, useState } from 'react';
6
+
7
+ import { mx } from '@dxos/ui-theme';
8
+ import { safeStringify } from '@dxos/util';
9
+
10
+ import { ErrorStack, parseCaptureOwnerStack } from '../components';
11
+
12
+ export type LoadingProps = { data?: any };
13
+
14
+ /**
15
+ * Storybook loading component.
16
+ */
17
+ export const Loading = ({ data }: LoadingProps) => {
18
+ const [visible, setVisible] = useState(false);
19
+ const ownerFrames = parseCaptureOwnerStack(captureOwnerStack());
20
+
21
+ useEffect(() => {
22
+ const t = setTimeout(() => setVisible(true), 500);
23
+ return () => clearTimeout(t);
24
+ }, []);
25
+
26
+ return (
27
+ <div className='w-full p-2'>
28
+ <div
29
+ className={mx(
30
+ 'flex flex-col w-full p-2 border-2 border-teal-500 rounded-md',
31
+ 'opacity-0 transition delay-1000 duration-1000',
32
+ visible && 'opacity-100',
33
+ )}
34
+ >
35
+ <h2 className='uppercase capitalize text-xs'>Loading State</h2>
36
+ <pre className='text-sm text-description'>{safeStringify(data, undefined, 2)}</pre>
37
+
38
+ <h3 className='uppercase capitalize text-xs mt-2'>Owner stack</h3>
39
+ {ownerFrames && ownerFrames.length > 0 ? (
40
+ <ErrorStack frames={ownerFrames} />
41
+ ) : (
42
+ <p className='text-xs text-subdued'>No owner stack (production build or unsupported context).</p>
43
+ )}
44
+ </div>
45
+ </div>
46
+ );
47
+ };
@@ -3,5 +3,5 @@
3
3
  //
4
4
 
5
5
  export * from './withLayout';
6
- export * from './withSurfaceVariantsLayout';
6
+ export * from './withLayoutVariants';
7
7
  export * from './withTheme';
@@ -3,52 +3,73 @@
3
3
  //
4
4
 
5
5
  import { type Decorator } from '@storybook/react';
6
- import React, { type FC, type PropsWithChildren } from 'react';
6
+ import React, { type FC, type PropsWithChildren, memo } from 'react';
7
7
 
8
8
  import { type ClassNameValue, type ThemedClassName } from '@dxos/react-ui';
9
- import { mx } from '@dxos/react-ui-theme';
9
+ import { mx } from '@dxos/ui-theme';
10
10
 
11
11
  export type ContainerProps = ThemedClassName<PropsWithChildren>;
12
12
 
13
- export type ContainerType = 'default' | 'column';
13
+ export type ContainerType = 'default' | 'fullscreen' | 'centered' | 'column';
14
14
 
15
15
  export type WithLayoutProps =
16
16
  | FC<ContainerProps>
17
- | { classNames?: ClassNameValue; container?: ContainerType; scroll?: boolean };
17
+ | {
18
+ classNames?: ClassNameValue;
19
+ layout?: ContainerType;
20
+ scroll?: boolean;
21
+ };
18
22
 
19
23
  /**
20
24
  * Adds layout container.
21
25
  */
22
26
  export const withLayout =
23
- (props: WithLayoutProps): Decorator =>
27
+ (props: WithLayoutProps = {}): Decorator =>
24
28
  (Story) => {
29
+ // Prevent re-rendering of the story.
30
+ const MemoizedStory = memo(Story);
25
31
  if (typeof props === 'function') {
26
32
  const Container = props;
27
33
  return (
28
34
  <Container>
29
- <Story />
35
+ <MemoizedStory />
36
+ </Container>
37
+ );
38
+ } else {
39
+ const { layout = 'default', classNames, scroll } = props;
40
+ const Container = layouts[layout] ?? layouts.fullscreen;
41
+ return (
42
+ <Container classNames={mx(scroll ? 'overflow-y-auto' : 'overflow-hidden', classNames)}>
43
+ <MemoizedStory />
30
44
  </Container>
31
45
  );
32
46
  }
33
-
34
- const Container = layouts[(props as any).container as ContainerType] ?? layouts.default;
35
- return (
36
- <Container classNames={mx(props.classNames, props.scroll ? 'overflow-y-auto' : 'overflow-hidden')}>
37
- <Story />
38
- </Container>
39
- );
40
47
  };
41
48
 
42
49
  const layouts: Record<ContainerType, FC<ContainerProps>> = {
43
- default: ({ children, classNames }: ContainerProps) => (
44
- <div role='none' className={mx(classNames)}>
50
+ default: ({ classNames, children }: ContainerProps) => (
51
+ <div role='none' className={mx('p-4', classNames)}>
45
52
  {children}
46
53
  </div>
47
54
  ),
48
55
 
49
- column: ({ children, classNames }: ContainerProps) => (
50
- <div role='none' className='fixed inset-0 flex justify-center overflow-hidden bg-deckSurface'>
51
- <div role='none' className={mx('flex flex-col is-[40rem] bg-baseSurface', classNames)}>
56
+ fullscreen: ({ classNames, children }: ContainerProps) => (
57
+ <div role='none' className={mx('fixed inset-0 flex overflow-hidden bg-black', classNames)}>
58
+ {children}
59
+ </div>
60
+ ),
61
+
62
+ centered: ({ classNames, children }: ContainerProps) => (
63
+ <div role='none' className={mx('fixed inset-0 grid overflow-hidden place-items-center bg-black')}>
64
+ <div role='none' className={mx('flex flex-col bg-base-surface', classNames)}>
65
+ {children}
66
+ </div>
67
+ </div>
68
+ ),
69
+
70
+ column: ({ classNames, children }: ContainerProps) => (
71
+ <div role='none' className='fixed inset-0 flex overflow-hidden justify-center bg-black'>
72
+ <div role='none' className={mx('flex flex-col w-[40rem] bg-base-surface', classNames)}>
52
73
  {children}
53
74
  </div>
54
75
  </div>
@@ -0,0 +1,48 @@
1
+ //
2
+ // Copyright 2023 DXOS.org
3
+ //
4
+
5
+ import { type Decorator } from '@storybook/react';
6
+ import React, { type ComponentType, type PropsWithChildren } from 'react';
7
+
8
+ import { mx, surfaceShadow } from '@dxos/ui-theme';
9
+ import { type Density, type Elevation } from '@dxos/ui-types';
10
+
11
+ type Config = {
12
+ elevations?: { elevation: Elevation; surface?: string }[];
13
+ densities?: Density[];
14
+ };
15
+
16
+ const Container = ({ children, elevation, surface }: PropsWithChildren<{ elevation: Elevation; surface?: string }>) => (
17
+ <div className={mx('p-4 rounded-sm', surface, surfaceShadow({ elevation }))}>{children}</div>
18
+ );
19
+
20
+ const Panel = ({
21
+ Story,
22
+ elevations,
23
+ densities,
24
+ className,
25
+ }: { Story: ComponentType } & Config & { className?: string }) => {
26
+ return (
27
+ <div className={mx('flex flex-col h-full p-8 gap-8', className)}>
28
+ {elevations?.map(({ elevation, surface }) =>
29
+ densities?.map((density) => (
30
+ <Container key={`${elevation}--${density}`} surface={surface} elevation={elevation}>
31
+ <Story />
32
+ </Container>
33
+ )),
34
+ )}
35
+ </div>
36
+ );
37
+ };
38
+
39
+ export const withLayoutVariants = ({
40
+ elevations = [
41
+ { elevation: 'dialog', surface: 'bg-modal-surface' },
42
+ { elevation: 'positioned', surface: 'bg-card-surface' },
43
+ { elevation: 'base', surface: 'bg-base-surface' },
44
+ ],
45
+ densities = ['coarse'],
46
+ }: Config = {}): Decorator => {
47
+ return (Story) => <Panel Story={Story} elevations={elevations} densities={densities} />;
48
+ };
@@ -3,29 +3,35 @@
3
3
  //
4
4
 
5
5
  import { type Decorator } from '@storybook/react';
6
- import React, { memo } from 'react';
6
+ import React from 'react';
7
7
 
8
- import { defaultTx } from '@dxos/react-ui-theme';
8
+ import { defaultTx } from '@dxos/ui-theme';
9
+ import { type ThemeMode } from '@dxos/ui-types';
9
10
 
10
- import { type ThemeMode, ThemeProvider, Tooltip } from '../../components';
11
+ import { type ThemeContextValue, ThemeProvider, Tooltip } from '../../components';
11
12
 
12
13
  /**
13
- * Adds theme decorator (add to preview.ts)
14
+ * Adds theme decorator.
14
15
  */
15
- export const withTheme: Decorator = (Story, context) => {
16
- const {
17
- globals: { theme },
18
- parameters: { translations },
19
- } = context;
16
+ export const withTheme =
17
+ ({ tx = defaultTx, noCache, platform }: Partial<ThemeContextValue> = {}): Decorator =>
18
+ (Story, context) => {
19
+ const {
20
+ globals: { theme },
21
+ parameters: { translations },
22
+ } = context;
20
23
 
21
- // Prevent re-rendering of the story.
22
- const MemoizedStory = memo(Story);
23
-
24
- return (
25
- <ThemeProvider tx={defaultTx} themeMode={theme as ThemeMode} resourceExtensions={translations} noCache>
26
- <Tooltip.Provider>
27
- <MemoizedStory />
28
- </Tooltip.Provider>
29
- </ThemeProvider>
30
- );
31
- };
24
+ return (
25
+ <ThemeProvider
26
+ tx={tx}
27
+ themeMode={theme as ThemeMode}
28
+ resourceExtensions={translations}
29
+ noCache={noCache}
30
+ platform={platform}
31
+ >
32
+ <Tooltip.Provider>
33
+ <Story />
34
+ </Tooltip.Provider>
35
+ </ThemeProvider>
36
+ );
37
+ };
@@ -3,3 +3,5 @@
3
3
  //
4
4
 
5
5
  export * from './decorators';
6
+
7
+ export * from './Loading';
@@ -0,0 +1,19 @@
1
+ //
2
+ // Copyright 2023 DXOS.org
3
+ //
4
+
5
+ import { type Resource } from '@dxos/react-ui';
6
+
7
+ export const translationKey = '@dxos/react-ui';
8
+
9
+ export const translations = [
10
+ {
11
+ 'en-US': {
12
+ [translationKey]: {
13
+ 'toolbar-menu.label': 'Action menu',
14
+ 'toolbar-drag-handle.label': 'Drag to rearrange',
15
+ 'toolbar-close.label': 'Close',
16
+ },
17
+ },
18
+ },
19
+ ] as const satisfies Resource[];
package/src/util/index.ts CHANGED
@@ -2,7 +2,7 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- export * from './domino';
5
+ export type { ThemedClassName } from '@dxos/ui-types';
6
+
6
7
  export * from './hasIosKeyboard';
7
- export type * from './ThemedClassName';
8
8
  export * from './usePx';
package/src/util/usePx.ts CHANGED
@@ -17,6 +17,7 @@ export const usePx = (rem: number): number => {
17
17
  if (typeof document !== 'undefined') {
18
18
  return getDocumentElementFontSize();
19
19
  }
20
+
20
21
  return 16; // Default fallback for SSR
21
22
  });
22
23