@dxos/react-ui 0.8.4-main.ef1bc66f44 → 0.8.4-main.effb148878

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 (563) hide show
  1. package/LICENSE +102 -5
  2. package/README.md +1 -1
  3. package/dist/lib/browser/chunk-FFPB5LWE.mjs +1600 -0
  4. package/dist/lib/browser/chunk-FFPB5LWE.mjs.map +7 -0
  5. package/dist/lib/browser/chunk-WU2YVQX4.mjs +32 -0
  6. package/dist/lib/browser/chunk-WU2YVQX4.mjs.map +7 -0
  7. package/dist/lib/browser/index.mjs +4422 -2412
  8. package/dist/lib/browser/index.mjs.map +4 -4
  9. package/dist/lib/browser/meta.json +1 -1
  10. package/dist/lib/browser/testing/index.mjs +77 -45
  11. package/dist/lib/browser/testing/index.mjs.map +4 -4
  12. package/dist/lib/browser/translations.mjs +9 -0
  13. package/dist/lib/browser/translations.mjs.map +7 -0
  14. package/dist/lib/node-esm/chunk-TIKGPZSG.mjs +34 -0
  15. package/dist/lib/node-esm/chunk-TIKGPZSG.mjs.map +7 -0
  16. package/dist/lib/node-esm/chunk-WOYP6QDI.mjs +1602 -0
  17. package/dist/lib/node-esm/chunk-WOYP6QDI.mjs.map +7 -0
  18. package/dist/lib/node-esm/index.mjs +4422 -2412
  19. package/dist/lib/node-esm/index.mjs.map +4 -4
  20. package/dist/lib/node-esm/meta.json +1 -1
  21. package/dist/lib/node-esm/testing/index.mjs +77 -45
  22. package/dist/lib/node-esm/testing/index.mjs.map +4 -4
  23. package/dist/lib/node-esm/translations.mjs +10 -0
  24. package/dist/lib/node-esm/translations.mjs.map +7 -0
  25. package/dist/types/src/components/Avatars/Avatar.d.ts +1 -1
  26. package/dist/types/src/components/Avatars/Avatar.d.ts.map +1 -1
  27. package/dist/types/src/components/Avatars/Avatar.stories.d.ts.map +1 -1
  28. package/dist/types/src/components/Avatars/Avatar.theme.d.ts +11 -0
  29. package/dist/types/src/components/Avatars/Avatar.theme.d.ts.map +1 -0
  30. package/dist/types/src/components/Avatars/AvatarGroup.stories.d.ts.map +1 -1
  31. package/dist/types/src/components/Breadcrumb/Breadcrumb.d.ts +5 -1
  32. package/dist/types/src/components/Breadcrumb/Breadcrumb.d.ts.map +1 -1
  33. package/dist/types/src/components/Breadcrumb/Breadcrumb.stories.d.ts.map +1 -1
  34. package/dist/types/src/components/Breadcrumb/Breadcrumb.theme.d.ts +4 -0
  35. package/dist/types/src/components/Breadcrumb/Breadcrumb.theme.d.ts.map +1 -0
  36. package/dist/types/src/components/Button/Button.d.ts +2 -2
  37. package/dist/types/src/components/Button/Button.d.ts.map +1 -1
  38. package/dist/types/src/components/Button/Button.stories.d.ts +1 -1
  39. package/dist/types/src/components/Button/Button.stories.d.ts.map +1 -1
  40. package/dist/types/src/components/Button/Button.theme.d.ts +11 -0
  41. package/dist/types/src/components/Button/Button.theme.d.ts.map +1 -0
  42. package/dist/types/src/components/Button/IconButton.d.ts +1 -0
  43. package/dist/types/src/components/Button/IconButton.d.ts.map +1 -1
  44. package/dist/types/src/components/Button/IconButton.stories.d.ts +4 -0
  45. package/dist/types/src/components/Button/IconButton.stories.d.ts.map +1 -1
  46. package/dist/types/src/components/Button/IconButton.theme.d.ts +8 -0
  47. package/dist/types/src/components/Button/IconButton.theme.d.ts.map +1 -0
  48. package/dist/types/src/components/Button/Toggle.d.ts +2 -2
  49. package/dist/types/src/components/Button/Toggle.d.ts.map +1 -1
  50. package/dist/types/src/components/Button/Toggle.stories.d.ts.map +1 -1
  51. package/dist/types/src/components/Button/ToggleGroup.d.ts +6 -6
  52. package/dist/types/src/components/Button/ToggleGroup.d.ts.map +1 -1
  53. package/dist/types/src/components/Button/ToggleGroup.stories.d.ts +2 -2
  54. package/dist/types/src/components/Button/ToggleGroup.stories.d.ts.map +1 -1
  55. package/dist/types/src/components/Calendar/Calendar.d.ts +33 -0
  56. package/dist/types/src/components/Calendar/Calendar.d.ts.map +1 -0
  57. package/dist/types/src/components/Calendar/Calendar.stories.d.ts +9 -0
  58. package/dist/types/src/components/Calendar/Calendar.stories.d.ts.map +1 -0
  59. package/dist/types/src/components/Calendar/Calendar.theme.d.ts +4 -0
  60. package/dist/types/src/components/Calendar/Calendar.theme.d.ts.map +1 -0
  61. package/dist/types/src/components/Calendar/index.d.ts +2 -0
  62. package/dist/types/src/components/Calendar/index.d.ts.map +1 -0
  63. package/dist/types/src/components/Card/Card.d.ts +135 -0
  64. package/dist/types/src/components/Card/Card.d.ts.map +1 -0
  65. package/dist/types/src/components/Card/Card.stories.d.ts +22 -0
  66. package/dist/types/src/components/Card/Card.stories.d.ts.map +1 -0
  67. package/dist/types/src/components/Card/Card.theme.d.ts +12 -0
  68. package/dist/types/src/components/Card/Card.theme.d.ts.map +1 -0
  69. package/dist/types/src/components/Card/index.d.ts +2 -0
  70. package/dist/types/src/components/Card/index.d.ts.map +1 -0
  71. package/dist/types/src/components/Carousel/Carousel.d.ts +102 -0
  72. package/dist/types/src/components/Carousel/Carousel.d.ts.map +1 -0
  73. package/dist/types/src/components/Carousel/index.d.ts +2 -0
  74. package/dist/types/src/components/Carousel/index.d.ts.map +1 -0
  75. package/dist/types/src/components/Clipboard/ClipboardProvider.d.ts.map +1 -1
  76. package/dist/types/src/components/Clipboard/CopyButton.d.ts.map +1 -1
  77. package/dist/types/src/components/Clipboard/index.d.ts +10 -1
  78. package/dist/types/src/components/Clipboard/index.d.ts.map +1 -1
  79. package/dist/types/src/components/Column/Column.d.ts +33 -0
  80. package/dist/types/src/components/Column/Column.d.ts.map +1 -0
  81. package/dist/types/src/components/Column/Column.stories.d.ts +25 -0
  82. package/dist/types/src/components/Column/Column.stories.d.ts.map +1 -0
  83. package/dist/types/src/components/Column/Column.theme.d.ts +9 -0
  84. package/dist/types/src/components/Column/Column.theme.d.ts.map +1 -0
  85. package/dist/types/src/components/Column/index.d.ts +3 -0
  86. package/dist/types/src/components/Column/index.d.ts.map +1 -0
  87. package/dist/types/src/components/Column/withColumn.d.ts +21 -0
  88. package/dist/types/src/components/Column/withColumn.d.ts.map +1 -0
  89. package/dist/types/src/components/DatePicker/DatePicker.d.ts +72 -0
  90. package/dist/types/src/components/DatePicker/DatePicker.d.ts.map +1 -0
  91. package/dist/types/src/components/DatePicker/DatePicker.stories.d.ts +10 -0
  92. package/dist/types/src/components/DatePicker/DatePicker.stories.d.ts.map +1 -0
  93. package/dist/types/src/components/DatePicker/DatePicker.theme.d.ts +6 -0
  94. package/dist/types/src/components/DatePicker/DatePicker.theme.d.ts.map +1 -0
  95. package/dist/types/src/components/DatePicker/index.d.ts +2 -0
  96. package/dist/types/src/components/DatePicker/index.d.ts.map +1 -0
  97. package/dist/types/src/components/Dialog/AlertDialog.d.ts +43 -23
  98. package/dist/types/src/components/Dialog/AlertDialog.d.ts.map +1 -1
  99. package/dist/types/src/components/Dialog/AlertDialog.stories.d.ts.map +1 -1
  100. package/dist/types/src/components/Dialog/Dialog.d.ts +52 -32
  101. package/dist/types/src/components/Dialog/Dialog.d.ts.map +1 -1
  102. package/dist/types/src/components/Dialog/Dialog.stories.d.ts +6 -8
  103. package/dist/types/src/components/Dialog/Dialog.stories.d.ts.map +1 -1
  104. package/dist/types/src/components/Dialog/Dialog.theme.d.ts +10 -0
  105. package/dist/types/src/components/Dialog/Dialog.theme.d.ts.map +1 -0
  106. package/dist/types/src/components/ErrorFallback/ErrorFallback.d.ts +11 -0
  107. package/dist/types/src/components/ErrorFallback/ErrorFallback.d.ts.map +1 -0
  108. package/dist/types/src/components/ErrorFallback/ErrorFallback.stories.d.ts +7 -0
  109. package/dist/types/src/components/ErrorFallback/ErrorFallback.stories.d.ts.map +1 -0
  110. package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts +19 -0
  111. package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts.map +1 -0
  112. package/dist/types/src/components/ErrorFallback/ThrowError.d.ts +9 -0
  113. package/dist/types/src/components/ErrorFallback/ThrowError.d.ts.map +1 -0
  114. package/dist/types/src/components/ErrorFallback/index.d.ts +5 -0
  115. package/dist/types/src/components/ErrorFallback/index.d.ts.map +1 -0
  116. package/dist/types/src/components/Focus/Focus.d.ts +36 -0
  117. package/dist/types/src/components/Focus/Focus.d.ts.map +1 -0
  118. package/dist/types/src/components/Focus/Focus.stories.d.ts +9 -0
  119. package/dist/types/src/components/Focus/Focus.stories.d.ts.map +1 -0
  120. package/dist/types/src/components/Focus/Focus.theme.d.ts +6 -0
  121. package/dist/types/src/components/Focus/Focus.theme.d.ts.map +1 -0
  122. package/dist/types/src/components/Focus/index.d.ts +2 -0
  123. package/dist/types/src/components/Focus/index.d.ts.map +1 -0
  124. package/dist/types/src/components/Icon/Icon.d.ts +4 -0
  125. package/dist/types/src/components/Icon/Icon.d.ts.map +1 -1
  126. package/dist/types/src/components/Icon/Icon.stories.d.ts +11 -3
  127. package/dist/types/src/components/Icon/Icon.stories.d.ts.map +1 -1
  128. package/dist/types/src/components/Icon/Icon.theme.d.ts +6 -0
  129. package/dist/types/src/components/Icon/Icon.theme.d.ts.map +1 -0
  130. package/dist/types/src/components/Image/Image.d.ts +15 -0
  131. package/dist/types/src/components/Image/Image.d.ts.map +1 -0
  132. package/dist/types/src/components/Image/Image.stories.d.ts +34 -0
  133. package/dist/types/src/components/Image/Image.stories.d.ts.map +1 -0
  134. package/dist/types/src/components/Image/index.d.ts +2 -0
  135. package/dist/types/src/components/Image/index.d.ts.map +1 -0
  136. package/dist/types/src/components/Input/Input.d.ts +90 -19
  137. package/dist/types/src/components/Input/Input.d.ts.map +1 -1
  138. package/dist/types/src/components/Input/Input.stories.d.ts +20 -9
  139. package/dist/types/src/components/Input/Input.stories.d.ts.map +1 -1
  140. package/dist/types/src/components/Input/Input.theme.d.ts +115 -0
  141. package/dist/types/src/components/Input/Input.theme.d.ts.map +1 -0
  142. package/dist/types/src/components/Input/SegmentedInput.d.ts +79 -0
  143. package/dist/types/src/components/Input/SegmentedInput.d.ts.map +1 -0
  144. package/dist/types/src/components/Input/constants.d.ts +2 -0
  145. package/dist/types/src/components/Input/constants.d.ts.map +1 -0
  146. package/dist/types/src/components/Input/index.d.ts +2 -0
  147. package/dist/types/src/components/Input/index.d.ts.map +1 -1
  148. package/dist/types/src/components/Link/Link.d.ts.map +1 -1
  149. package/dist/types/src/components/Link/Link.stories.d.ts.map +1 -1
  150. package/dist/types/src/components/Link/Link.theme.d.ts +6 -0
  151. package/dist/types/src/components/Link/Link.theme.d.ts.map +1 -0
  152. package/dist/types/src/components/List/List.d.ts +5 -3
  153. package/dist/types/src/components/List/List.d.ts.map +1 -1
  154. package/dist/types/src/components/List/List.stories.d.ts +3 -1
  155. package/dist/types/src/components/List/List.stories.d.ts.map +1 -1
  156. package/dist/types/src/components/List/List.theme.d.ts +7 -0
  157. package/dist/types/src/components/List/List.theme.d.ts.map +1 -0
  158. package/dist/types/src/components/List/ListDropIndicator.d.ts.map +1 -1
  159. package/dist/types/src/components/List/Tree.d.ts +2 -2
  160. package/dist/types/src/components/List/Tree.d.ts.map +1 -1
  161. package/dist/types/src/components/List/Tree.stories.d.ts.map +1 -1
  162. package/dist/types/src/components/List/TreeDropIndicator.d.ts.map +1 -1
  163. package/dist/types/src/components/List/Treegrid.d.ts +5 -9
  164. package/dist/types/src/components/List/Treegrid.d.ts.map +1 -1
  165. package/dist/types/src/components/List/Treegrid.stories.d.ts.map +1 -1
  166. package/dist/types/src/components/List/Treegrid.theme.d.ts +7 -0
  167. package/dist/types/src/components/List/Treegrid.theme.d.ts.map +1 -0
  168. package/dist/types/src/components/Main/Main.d.ts +13 -9
  169. package/dist/types/src/components/Main/Main.d.ts.map +1 -1
  170. package/dist/types/src/components/Main/Main.stories.d.ts +0 -3
  171. package/dist/types/src/components/Main/Main.stories.d.ts.map +1 -1
  172. package/dist/types/src/components/Main/Main.theme.d.ts +20 -0
  173. package/dist/types/src/components/Main/Main.theme.d.ts.map +1 -0
  174. package/dist/types/src/components/Main/constants.d.ts +3 -0
  175. package/dist/types/src/components/Main/constants.d.ts.map +1 -0
  176. package/dist/types/src/components/Main/index.d.ts +1 -0
  177. package/dist/types/src/components/Main/index.d.ts.map +1 -1
  178. package/dist/types/src/components/Main/useSwipeToDismiss.d.ts.map +1 -1
  179. package/dist/types/src/components/MediaPlayer/MediaPlayer.d.ts +43 -0
  180. package/dist/types/src/components/MediaPlayer/MediaPlayer.d.ts.map +1 -0
  181. package/dist/types/src/components/MediaPlayer/MediaPlayer.stories.d.ts +16 -0
  182. package/dist/types/src/components/MediaPlayer/MediaPlayer.stories.d.ts.map +1 -0
  183. package/dist/types/src/components/MediaPlayer/index.d.ts +2 -0
  184. package/dist/types/src/components/MediaPlayer/index.d.ts.map +1 -0
  185. package/dist/types/src/components/Menu/ContextMenu.d.ts.map +1 -1
  186. package/dist/types/src/components/Menu/ContextMenu.stories.d.ts.map +1 -1
  187. package/dist/types/src/components/Menu/DropdownMenu.d.ts +58 -49
  188. package/dist/types/src/components/Menu/DropdownMenu.d.ts.map +1 -1
  189. package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts +14 -1
  190. package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts.map +1 -1
  191. package/dist/types/src/components/Menu/Menu.theme.d.ts +7 -0
  192. package/dist/types/src/components/Menu/Menu.theme.d.ts.map +1 -0
  193. package/dist/types/src/components/Message/Message.d.ts +1 -1
  194. package/dist/types/src/components/Message/Message.d.ts.map +1 -1
  195. package/dist/types/src/components/Message/Message.stories.d.ts +4 -5
  196. package/dist/types/src/components/Message/Message.stories.d.ts.map +1 -1
  197. package/dist/types/src/components/Message/Message.theme.d.ts +7 -0
  198. package/dist/types/src/components/Message/Message.theme.d.ts.map +1 -0
  199. package/dist/types/src/components/Panel/Panel.d.ts +35 -0
  200. package/dist/types/src/components/Panel/Panel.d.ts.map +1 -0
  201. package/dist/types/src/components/Panel/Panel.stories.d.ts +6 -0
  202. package/dist/types/src/components/Panel/Panel.stories.d.ts.map +1 -0
  203. package/dist/types/src/components/Panel/Panel.theme.d.ts +13 -0
  204. package/dist/types/src/components/Panel/Panel.theme.d.ts.map +1 -0
  205. package/dist/types/src/components/Panel/index.d.ts +2 -0
  206. package/dist/types/src/components/Panel/index.d.ts.map +1 -0
  207. package/dist/types/src/components/Popover/Popover.d.ts +39 -22
  208. package/dist/types/src/components/Popover/Popover.d.ts.map +1 -1
  209. package/dist/types/src/components/Popover/Popover.stories.d.ts.map +1 -1
  210. package/dist/types/src/components/Popover/Popover.theme.d.ts +8 -0
  211. package/dist/types/src/components/Popover/Popover.theme.d.ts.map +1 -0
  212. package/dist/types/src/components/ScrollArea/ScrollArea.d.ts +12 -11
  213. package/dist/types/src/components/ScrollArea/ScrollArea.d.ts.map +1 -1
  214. package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts +21 -10
  215. package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts.map +1 -1
  216. package/dist/types/src/components/ScrollArea/ScrollArea.theme.d.ts +17 -0
  217. package/dist/types/src/components/ScrollArea/ScrollArea.theme.d.ts.map +1 -0
  218. package/dist/types/src/components/ScrollArea/index.d.ts +1 -0
  219. package/dist/types/src/components/ScrollArea/index.d.ts.map +1 -1
  220. package/dist/types/src/components/ScrollArea/scrollbar.d.ts +18 -0
  221. package/dist/types/src/components/ScrollArea/scrollbar.d.ts.map +1 -0
  222. package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts +41 -18
  223. package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts.map +1 -1
  224. package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts +9 -5
  225. package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts.map +1 -1
  226. package/dist/types/src/components/Select/Select.d.ts.map +1 -1
  227. package/dist/types/src/components/Select/Select.stories.d.ts +2 -2
  228. package/dist/types/src/components/Select/Select.stories.d.ts.map +1 -1
  229. package/dist/types/src/components/Select/Select.theme.d.ts +6 -0
  230. package/dist/types/src/components/Select/Select.theme.d.ts.map +1 -0
  231. package/dist/types/src/components/Separator/Separator.d.ts +3 -3
  232. package/dist/types/src/components/Separator/Separator.d.ts.map +1 -1
  233. package/dist/types/src/components/Separator/Separator.theme.d.ts +7 -0
  234. package/dist/types/src/components/Separator/Separator.theme.d.ts.map +1 -0
  235. package/dist/types/src/components/Skeleton/Skeleton.stories.d.ts.map +1 -1
  236. package/dist/types/src/components/Skeleton/Skeleton.theme.d.ts +6 -0
  237. package/dist/types/src/components/Skeleton/Skeleton.theme.d.ts.map +1 -0
  238. package/dist/types/src/components/Splitter/Splitter.d.ts +22 -16
  239. package/dist/types/src/components/Splitter/Splitter.d.ts.map +1 -1
  240. package/dist/types/src/components/Splitter/Splitter.stories.d.ts.map +1 -1
  241. package/dist/types/src/components/Splitter/Splitter.theme.d.ts +4 -0
  242. package/dist/types/src/components/Splitter/Splitter.theme.d.ts.map +1 -0
  243. package/dist/types/src/components/Status/Status.d.ts +3 -4
  244. package/dist/types/src/components/Status/Status.d.ts.map +1 -1
  245. package/dist/types/src/components/Status/Status.stories.d.ts +4 -2
  246. package/dist/types/src/components/Status/Status.stories.d.ts.map +1 -1
  247. package/dist/types/src/components/Status/Status.theme.d.ts +7 -0
  248. package/dist/types/src/components/Status/Status.theme.d.ts.map +1 -0
  249. package/dist/types/src/components/Tag/Tag.d.ts.map +1 -1
  250. package/dist/types/src/components/Tag/Tag.stories.d.ts +0 -5
  251. package/dist/types/src/components/Tag/Tag.stories.d.ts.map +1 -1
  252. package/dist/types/src/components/Tag/Tag.theme.d.ts +6 -0
  253. package/dist/types/src/components/Tag/Tag.theme.d.ts.map +1 -0
  254. package/dist/types/src/components/Toast/Toast.d.ts +15 -15
  255. package/dist/types/src/components/Toast/Toast.d.ts.map +1 -1
  256. package/dist/types/src/components/Toast/Toast.stories.d.ts.map +1 -1
  257. package/dist/types/src/components/Toast/Toast.theme.d.ts +6 -0
  258. package/dist/types/src/components/Toast/Toast.theme.d.ts.map +1 -0
  259. package/dist/types/src/components/Toolbar/Toolbar.d.ts +46 -17
  260. package/dist/types/src/components/Toolbar/Toolbar.d.ts.map +1 -1
  261. package/dist/types/src/components/Toolbar/Toolbar.stories.d.ts.map +1 -1
  262. package/dist/types/src/components/Toolbar/Toolbar.theme.d.ts +8 -0
  263. package/dist/types/src/components/Toolbar/Toolbar.theme.d.ts.map +1 -0
  264. package/dist/types/src/components/Tooltip/Tooltip.d.ts +16 -16
  265. package/dist/types/src/components/Tooltip/Tooltip.d.ts.map +1 -1
  266. package/dist/types/src/components/Tooltip/Tooltip.stories.d.ts +2 -2
  267. package/dist/types/src/components/Tooltip/Tooltip.stories.d.ts.map +1 -1
  268. package/dist/types/src/components/Tooltip/Tooltip.theme.d.ts +6 -0
  269. package/dist/types/src/components/Tooltip/Tooltip.theme.d.ts.map +1 -0
  270. package/dist/types/src/components/Tooltip/index.d.ts +1 -0
  271. package/dist/types/src/components/Tooltip/index.d.ts.map +1 -1
  272. package/dist/types/src/components/Tooltip/tooltipContent.d.ts +4 -0
  273. package/dist/types/src/components/Tooltip/tooltipContent.d.ts.map +1 -0
  274. package/dist/types/src/components/index.d.ts +11 -5
  275. package/dist/types/src/components/index.d.ts.map +1 -1
  276. package/dist/types/src/exemplars/generics.stories.d.ts +8 -6
  277. package/dist/types/src/exemplars/generics.stories.d.ts.map +1 -1
  278. package/dist/types/src/exemplars/slot.stories.d.ts +1 -0
  279. package/dist/types/src/exemplars/slot.stories.d.ts.map +1 -1
  280. package/dist/types/src/exemplars/tabster.stories.d.ts.map +1 -1
  281. package/dist/types/src/exemplars/virtualizer.stories.d.ts +11 -0
  282. package/dist/types/src/exemplars/virtualizer.stories.d.ts.map +1 -0
  283. package/dist/types/src/hooks/index.d.ts +1 -0
  284. package/dist/types/src/hooks/index.d.ts.map +1 -1
  285. package/dist/types/src/hooks/useDensityContext.d.ts +1 -1
  286. package/dist/types/src/hooks/useDensityContext.d.ts.map +1 -1
  287. package/dist/types/src/hooks/useElevationContext.d.ts.map +1 -1
  288. package/dist/types/src/hooks/useIconHref.d.ts.map +1 -1
  289. package/dist/types/src/hooks/useSafeArea.d.ts.map +1 -1
  290. package/dist/types/src/hooks/useSafeCollisionPadding.d.ts.map +1 -1
  291. package/dist/types/src/hooks/useTranslationsContext.d.ts +1 -1
  292. package/dist/types/src/hooks/useVisualViewport.d.ts.map +1 -1
  293. package/dist/types/src/index.d.ts +1 -0
  294. package/dist/types/src/index.d.ts.map +1 -1
  295. package/dist/types/src/playground/Controls.stories.d.ts.map +1 -1
  296. package/dist/types/src/playground/Custom.stories.d.ts +1 -1
  297. package/dist/types/src/playground/Custom.stories.d.ts.map +1 -1
  298. package/dist/types/src/playground/Typography.stories.d.ts.map +1 -1
  299. package/dist/types/src/primitives/Container/Container.d.ts +6 -22
  300. package/dist/types/src/primitives/Container/Container.d.ts.map +1 -1
  301. package/dist/types/src/primitives/Container/Container.stories.d.ts +2 -7
  302. package/dist/types/src/primitives/Container/Container.stories.d.ts.map +1 -1
  303. package/dist/types/src/primitives/Container/index.d.ts +0 -1
  304. package/dist/types/src/primitives/Container/index.d.ts.map +1 -1
  305. package/dist/types/src/{components → primitives}/DensityProvider/DensityProvider.d.ts.map +1 -1
  306. package/dist/types/src/primitives/DensityProvider/index.d.ts.map +1 -0
  307. package/dist/types/src/{components → primitives}/ElevationProvider/ElevationProvider.d.ts.map +1 -1
  308. package/dist/types/src/primitives/ElevationProvider/index.d.ts.map +1 -0
  309. package/dist/types/src/primitives/Flex/Flex.d.ts +8 -5
  310. package/dist/types/src/primitives/Flex/Flex.d.ts.map +1 -1
  311. package/dist/types/src/primitives/Flex/Flex.stories.d.ts +8 -0
  312. package/dist/types/src/primitives/Flex/Flex.stories.d.ts.map +1 -0
  313. package/dist/types/src/primitives/Grid/Grid.d.ts +10 -0
  314. package/dist/types/src/primitives/Grid/Grid.d.ts.map +1 -0
  315. package/dist/types/src/primitives/Grid/Grid.stories.d.ts +8 -0
  316. package/dist/types/src/primitives/Grid/Grid.stories.d.ts.map +1 -0
  317. package/dist/types/src/primitives/Grid/index.d.ts +2 -0
  318. package/dist/types/src/primitives/Grid/index.d.ts.map +1 -0
  319. package/dist/types/src/{components → primitives}/ThemeProvider/ThemeProvider.d.ts +1 -1
  320. package/dist/types/src/{components → primitives}/ThemeProvider/ThemeProvider.d.ts.map +1 -1
  321. package/dist/types/src/primitives/ThemeProvider/ThemeProvider.stories.d.ts +12 -0
  322. package/dist/types/src/primitives/ThemeProvider/ThemeProvider.stories.d.ts.map +1 -0
  323. package/dist/types/src/primitives/ThemeProvider/TranslationsProvider.d.ts +128 -0
  324. package/dist/types/src/primitives/ThemeProvider/TranslationsProvider.d.ts.map +1 -0
  325. package/dist/types/src/primitives/ThemeProvider/index.d.ts +4 -0
  326. package/dist/types/src/primitives/ThemeProvider/index.d.ts.map +1 -0
  327. package/dist/types/src/primitives/index.d.ts +4 -0
  328. package/dist/types/src/primitives/index.d.ts.map +1 -1
  329. package/dist/types/src/testing/Loading.d.ts +9 -0
  330. package/dist/types/src/testing/Loading.d.ts.map +1 -0
  331. package/dist/types/src/testing/decorators/withLayout.d.ts +1 -1
  332. package/dist/types/src/testing/decorators/withLayout.d.ts.map +1 -1
  333. package/dist/types/src/testing/decorators/withLayoutVariants.d.ts.map +1 -1
  334. package/dist/types/src/testing/decorators/withTheme.d.ts +6 -2
  335. package/dist/types/src/testing/decorators/withTheme.d.ts.map +1 -1
  336. package/dist/types/src/testing/index.d.ts +1 -0
  337. package/dist/types/src/testing/index.d.ts.map +1 -1
  338. package/dist/types/src/theme/bindTheme.d.ts +3 -0
  339. package/dist/types/src/theme/bindTheme.d.ts.map +1 -0
  340. package/dist/types/src/theme/defaultTheme.d.ts +4 -0
  341. package/dist/types/src/theme/defaultTheme.d.ts.map +1 -0
  342. package/dist/types/src/theme/index.d.ts +31 -0
  343. package/dist/types/src/theme/index.d.ts.map +1 -0
  344. package/dist/types/src/translations.d.ts +24 -0
  345. package/dist/types/src/translations.d.ts.map +1 -0
  346. package/dist/types/src/util/index.d.ts +2 -1
  347. package/dist/types/src/util/index.d.ts.map +1 -1
  348. package/dist/types/src/util/mobile.d.ts +5 -0
  349. package/dist/types/src/util/mobile.d.ts.map +1 -0
  350. package/dist/types/src/util/slots.d.ts +57 -0
  351. package/dist/types/src/util/slots.d.ts.map +1 -0
  352. package/dist/types/src/util/usePx.d.ts.map +1 -1
  353. package/dist/types/tsconfig.tsbuildinfo +1 -1
  354. package/package.json +36 -27
  355. package/src/components/Avatars/Avatar.stories.tsx +5 -7
  356. package/src/components/Avatars/Avatar.theme.ts +93 -0
  357. package/src/components/Avatars/Avatar.tsx +6 -14
  358. package/src/components/Avatars/AvatarGroup.stories.tsx +0 -1
  359. package/src/components/Breadcrumb/Breadcrumb.stories.tsx +1 -2
  360. package/src/components/Breadcrumb/Breadcrumb.theme.ts +26 -0
  361. package/src/components/Breadcrumb/Breadcrumb.tsx +25 -39
  362. package/src/components/Button/Button.stories.tsx +1 -2
  363. package/src/components/Button/Button.theme.ts +31 -0
  364. package/src/components/Button/Button.tsx +11 -25
  365. package/src/components/Button/IconButton.stories.tsx +56 -6
  366. package/src/components/Button/IconButton.theme.ts +21 -0
  367. package/src/components/Button/IconButton.tsx +3 -4
  368. package/src/components/Button/Toggle.stories.tsx +0 -1
  369. package/src/components/Button/Toggle.tsx +4 -4
  370. package/src/components/Button/ToggleGroup.stories.tsx +0 -1
  371. package/src/components/Button/ToggleGroup.tsx +12 -16
  372. package/src/components/Calendar/Calendar.stories.tsx +43 -0
  373. package/src/components/Calendar/Calendar.theme.ts +74 -0
  374. package/src/components/Calendar/Calendar.tsx +196 -0
  375. package/src/components/Calendar/index.ts +5 -0
  376. package/src/components/Card/Card.stories.tsx +172 -0
  377. package/src/components/Card/Card.theme.ts +101 -0
  378. package/src/components/Card/Card.tsx +496 -0
  379. package/src/components/Card/index.ts +5 -0
  380. package/src/components/Carousel/Carousel.tsx +371 -0
  381. package/src/components/Carousel/index.ts +5 -0
  382. package/src/components/Clipboard/CopyButton.tsx +7 -8
  383. package/src/components/Column/AUDIT.md +148 -0
  384. package/src/components/Column/Column.stories.tsx +181 -0
  385. package/src/components/Column/Column.theme.ts +48 -0
  386. package/src/components/Column/Column.tsx +165 -0
  387. package/src/components/Column/index.ts +6 -0
  388. package/src/components/Column/withColumn.ts +27 -0
  389. package/src/components/DatePicker/DatePicker.stories.tsx +102 -0
  390. package/src/components/DatePicker/DatePicker.theme.ts +35 -0
  391. package/src/components/DatePicker/DatePicker.tsx +279 -0
  392. package/src/components/DatePicker/index.ts +5 -0
  393. package/src/components/Dialog/AlertDialog.stories.tsx +14 -15
  394. package/src/components/Dialog/AlertDialog.tsx +125 -85
  395. package/src/components/Dialog/Dialog.stories.tsx +91 -15
  396. package/src/components/Dialog/Dialog.theme.ts +61 -0
  397. package/src/components/Dialog/Dialog.tsx +131 -117
  398. package/src/components/ErrorFallback/ErrorFallback.stories.tsx +45 -0
  399. package/src/components/ErrorFallback/ErrorFallback.tsx +76 -0
  400. package/src/components/ErrorFallback/ErrorStack.tsx +120 -0
  401. package/src/components/ErrorFallback/ThrowError.tsx +37 -0
  402. package/src/components/ErrorFallback/index.ts +9 -0
  403. package/src/components/Focus/AUDIT.md +43 -0
  404. package/src/components/Focus/Focus.stories.tsx +230 -0
  405. package/src/components/Focus/Focus.theme.ts +32 -0
  406. package/src/components/Focus/Focus.tsx +201 -0
  407. package/src/components/Focus/index.ts +5 -0
  408. package/src/components/Icon/Icon.stories.tsx +43 -13
  409. package/src/components/Icon/Icon.theme.ts +27 -0
  410. package/src/components/Icon/Icon.tsx +14 -3
  411. package/src/components/Image/Image.stories.tsx +86 -0
  412. package/src/components/Image/Image.tsx +246 -0
  413. package/src/components/Image/index.ts +5 -0
  414. package/src/components/Input/Input.stories.tsx +146 -64
  415. package/src/components/Input/Input.theme.ts +191 -0
  416. package/src/components/Input/Input.tsx +230 -72
  417. package/src/components/Input/SegmentedInput.tsx +453 -0
  418. package/src/components/Input/constants.ts +5 -0
  419. package/src/components/Input/index.ts +2 -0
  420. package/src/components/Link/Link.stories.tsx +0 -1
  421. package/src/components/Link/Link.theme.ts +16 -0
  422. package/src/components/Link/Link.tsx +11 -3
  423. package/src/components/List/List.stories.tsx +14 -22
  424. package/src/components/List/List.theme.ts +47 -0
  425. package/src/components/List/List.tsx +17 -21
  426. package/src/components/List/ListDropIndicator.tsx +7 -8
  427. package/src/components/List/Tree.stories.tsx +4 -5
  428. package/src/components/List/Tree.tsx +0 -1
  429. package/src/components/List/TreeDropIndicator.tsx +6 -6
  430. package/src/components/List/Treegrid.stories.tsx +27 -28
  431. package/src/components/List/Treegrid.theme.ts +35 -0
  432. package/src/components/List/Treegrid.tsx +22 -28
  433. package/src/components/Main/Main.stories.tsx +3 -7
  434. package/src/components/Main/Main.theme.ts +29 -0
  435. package/src/components/Main/Main.tsx +64 -53
  436. package/src/components/Main/constants.ts +6 -0
  437. package/src/components/Main/index.ts +1 -0
  438. package/src/components/MediaPlayer/MediaPlayer.stories.tsx +50 -0
  439. package/src/components/MediaPlayer/MediaPlayer.tsx +178 -0
  440. package/src/components/MediaPlayer/index.ts +5 -0
  441. package/src/components/Menu/ContextMenu.stories.tsx +0 -1
  442. package/src/components/Menu/ContextMenu.tsx +9 -33
  443. package/src/components/Menu/DropdownMenu.stories.tsx +0 -1
  444. package/src/components/Menu/DropdownMenu.tsx +73 -67
  445. package/src/components/Menu/Menu.theme.ts +48 -0
  446. package/src/components/Message/Message.stories.tsx +25 -11
  447. package/src/components/Message/Message.theme.ts +39 -0
  448. package/src/components/Message/Message.tsx +32 -31
  449. package/src/components/Panel/Panel.stories.tsx +67 -0
  450. package/src/components/Panel/Panel.theme.ts +42 -0
  451. package/src/components/Panel/Panel.tsx +121 -0
  452. package/src/components/Panel/index.ts +5 -0
  453. package/src/components/Popover/Popover.stories.tsx +5 -6
  454. package/src/components/Popover/Popover.theme.ts +40 -0
  455. package/src/components/Popover/Popover.tsx +69 -66
  456. package/src/components/ScrollArea/ScrollArea.stories.tsx +98 -39
  457. package/src/components/ScrollArea/ScrollArea.theme.ts +104 -0
  458. package/src/components/ScrollArea/ScrollArea.tsx +46 -33
  459. package/src/components/ScrollArea/index.ts +1 -0
  460. package/src/components/ScrollArea/scrollbar.ts +21 -0
  461. package/src/components/ScrollContainer/ScrollContainer.stories.tsx +46 -25
  462. package/src/components/ScrollContainer/ScrollContainer.tsx +215 -106
  463. package/src/components/Select/Select.stories.tsx +5 -6
  464. package/src/components/Select/Select.theme.ts +55 -0
  465. package/src/components/Select/Select.tsx +35 -35
  466. package/src/components/Separator/Separator.theme.ts +23 -0
  467. package/src/components/Separator/Separator.tsx +5 -8
  468. package/src/components/Skeleton/Skeleton.stories.tsx +12 -13
  469. package/src/components/Skeleton/Skeleton.theme.ts +22 -0
  470. package/src/components/Skeleton/Skeleton.tsx +1 -1
  471. package/src/components/Splitter/Splitter.stories.tsx +47 -37
  472. package/src/components/Splitter/Splitter.theme.ts +18 -0
  473. package/src/components/Splitter/Splitter.tsx +45 -46
  474. package/src/components/Status/Status.stories.tsx +19 -16
  475. package/src/components/Status/Status.theme.ts +31 -0
  476. package/src/components/Status/Status.tsx +9 -7
  477. package/src/components/Tag/Tag.stories.tsx +3 -9
  478. package/src/components/Tag/Tag.theme.ts +22 -0
  479. package/src/components/Tag/Tag.tsx +2 -7
  480. package/src/components/Toast/Toast.stories.tsx +0 -1
  481. package/src/components/Toast/Toast.theme.ts +52 -0
  482. package/src/components/Toast/Toast.tsx +24 -43
  483. package/src/components/Toolbar/Toolbar.stories.tsx +0 -1
  484. package/src/components/Toolbar/Toolbar.theme.ts +36 -0
  485. package/src/components/Toolbar/Toolbar.tsx +225 -30
  486. package/src/components/Tooltip/Tooltip.stories.tsx +18 -17
  487. package/src/components/Tooltip/Tooltip.theme.ts +19 -0
  488. package/src/components/Tooltip/Tooltip.tsx +36 -35
  489. package/src/components/Tooltip/index.ts +1 -0
  490. package/src/components/Tooltip/tooltipContent.ts +16 -0
  491. package/src/components/index.ts +11 -6
  492. package/src/exemplars/generics.stories.tsx +12 -16
  493. package/src/exemplars/slot.stories.tsx +68 -60
  494. package/src/exemplars/tabster.stories.tsx +5 -5
  495. package/src/exemplars/virtualizer.stories.tsx +136 -0
  496. package/src/hooks/index.ts +1 -0
  497. package/src/hooks/useDensityContext.ts +3 -3
  498. package/src/hooks/useElevationContext.ts +1 -1
  499. package/src/hooks/useThemeContext.ts +1 -1
  500. package/src/hooks/useTranslationsContext.ts +1 -1
  501. package/src/index.ts +1 -0
  502. package/src/playground/Controls.stories.tsx +0 -6
  503. package/src/playground/Custom.stories.tsx +16 -39
  504. package/src/playground/Typography.stories.tsx +1 -1
  505. package/src/primitives/Container/Container.stories.tsx +13 -51
  506. package/src/primitives/Container/Container.tsx +13 -74
  507. package/src/primitives/Container/index.ts +0 -1
  508. package/src/{components → primitives}/DensityProvider/DensityProvider.tsx +1 -1
  509. package/src/primitives/Flex/Flex.stories.tsx +57 -0
  510. package/src/primitives/Flex/Flex.tsx +21 -18
  511. package/src/primitives/Grid/Grid.stories.tsx +56 -0
  512. package/src/primitives/Grid/Grid.tsx +32 -0
  513. package/src/primitives/Grid/index.ts +5 -0
  514. package/src/primitives/ThemeProvider/ThemeProvider.stories.tsx +31 -0
  515. package/src/{components → primitives}/ThemeProvider/ThemeProvider.tsx +9 -8
  516. package/src/{components → primitives}/ThemeProvider/index.ts +2 -2
  517. package/src/primitives/index.ts +5 -0
  518. package/src/testing/Loading.tsx +47 -0
  519. package/src/testing/decorators/withLayout.tsx +15 -11
  520. package/src/testing/decorators/withLayoutVariants.tsx +19 -22
  521. package/src/testing/decorators/withTheme.tsx +23 -12
  522. package/src/testing/index.ts +2 -0
  523. package/src/theme/bindTheme.ts +13 -0
  524. package/src/theme/defaultTheme.ts +83 -0
  525. package/src/theme/index.ts +37 -0
  526. package/src/translations.ts +32 -0
  527. package/src/util/index.ts +2 -1
  528. package/src/util/mobile.ts +11 -0
  529. package/src/util/slots.ts +129 -0
  530. package/src/util/usePx.ts +5 -1
  531. package/dist/lib/browser/chunk-EJYV4HAH.mjs +0 -774
  532. package/dist/lib/browser/chunk-EJYV4HAH.mjs.map +0 -7
  533. package/dist/lib/node-esm/chunk-YTLZCZ2M.mjs +0 -776
  534. package/dist/lib/node-esm/chunk-YTLZCZ2M.mjs.map +0 -7
  535. package/dist/types/src/components/AnchoredOverflow/AnchoredOverflow.d.ts +0 -22
  536. package/dist/types/src/components/AnchoredOverflow/AnchoredOverflow.d.ts.map +0 -1
  537. package/dist/types/src/components/AnchoredOverflow/index.d.ts +0 -2
  538. package/dist/types/src/components/AnchoredOverflow/index.d.ts.map +0 -1
  539. package/dist/types/src/components/DensityProvider/index.d.ts.map +0 -1
  540. package/dist/types/src/components/ElevationProvider/index.d.ts.map +0 -1
  541. package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts +0 -129
  542. package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts.map +0 -1
  543. package/dist/types/src/components/ThemeProvider/index.d.ts +0 -4
  544. package/dist/types/src/components/ThemeProvider/index.d.ts.map +0 -1
  545. package/dist/types/src/primitives/Container/Layout.d.ts +0 -18
  546. package/dist/types/src/primitives/Container/Layout.d.ts.map +0 -1
  547. package/dist/types/src/primitives/Container/Layout.stories.d.ts +0 -10
  548. package/dist/types/src/primitives/Container/Layout.stories.d.ts.map +0 -1
  549. package/dist/types/src/util/hasIosKeyboard.d.ts +0 -2
  550. package/dist/types/src/util/hasIosKeyboard.d.ts.map +0 -1
  551. package/src/components/AnchoredOverflow/AnchoredOverflow.tsx +0 -67
  552. package/src/components/AnchoredOverflow/index.ts +0 -5
  553. package/src/primitives/Container/Layout.stories.tsx +0 -57
  554. package/src/primitives/Container/Layout.tsx +0 -61
  555. package/src/util/hasIosKeyboard.ts +0 -8
  556. /package/dist/types/src/{components → primitives}/DensityProvider/DensityProvider.d.ts +0 -0
  557. /package/dist/types/src/{components → primitives}/DensityProvider/index.d.ts +0 -0
  558. /package/dist/types/src/{components → primitives}/ElevationProvider/ElevationProvider.d.ts +0 -0
  559. /package/dist/types/src/{components → primitives}/ElevationProvider/index.d.ts +0 -0
  560. /package/src/{components → primitives}/DensityProvider/index.ts +0 -0
  561. /package/src/{components → primitives}/ElevationProvider/ElevationProvider.tsx +0 -0
  562. /package/src/{components → primitives}/ElevationProvider/index.ts +0 -0
  563. /package/src/{components → primitives}/ThemeProvider/TranslationsProvider.tsx +0 -0
@@ -5,25 +5,30 @@
5
5
  import { type Meta, type StoryObj } from '@storybook/react-vite';
6
6
  import React from 'react';
7
7
 
8
- import { faker } from '@dxos/random';
8
+ import { random } from '@dxos/random';
9
9
 
10
10
  import { withTheme } from '../../testing';
11
11
  import { Button } from '../Button';
12
-
12
+ import { Input } from '../Input';
13
+ import { ScrollArea } from '../ScrollArea';
13
14
  import { Dialog, type DialogContentProps } from './Dialog';
14
15
 
15
- type StoryProps = Pick<DialogContentProps, 'size'> &
16
+ type DefaultStoryProps = Pick<DialogContentProps, 'size'> &
16
17
  Partial<{
17
18
  title: string;
18
19
  description: string;
19
20
  openTrigger: string;
20
21
  closeTrigger: string;
21
- blockAlign: 'center' | 'start';
22
+ blockAlign: 'start' | 'center';
22
23
  }>;
23
24
 
24
- const DefaultStory = ({ size, title, description, openTrigger, closeTrigger, blockAlign }: StoryProps) => {
25
+ /**
26
+ * Standard Dialog with non-scrolling content in Dialog.Body.
27
+ * Dialog.Body propagates the Column grid via subgrid. Children auto-center via --dx-col.
28
+ */
29
+ const DefaultStory = ({ size, title, description, openTrigger, closeTrigger, blockAlign }: DefaultStoryProps) => {
25
30
  return (
26
- <Dialog.Root defaultOpen>
31
+ <Dialog.Root defaultOpen modal>
27
32
  <Dialog.Trigger asChild>
28
33
  <Button>{openTrigger}</Button>
29
34
  </Dialog.Trigger>
@@ -33,12 +38,55 @@ const DefaultStory = ({ size, title, description, openTrigger, closeTrigger, blo
33
38
  <Dialog.Title>{title}</Dialog.Title>
34
39
  {closeTrigger && (
35
40
  <Dialog.Close asChild>
36
- <Dialog.CloseIconButton />
41
+ <Dialog.ActionIconButton action='close' />
37
42
  </Dialog.Close>
38
43
  )}
39
44
  </Dialog.Header>
40
45
  <Dialog.Body>
41
46
  <Dialog.Description>{description}</Dialog.Description>
47
+ <Input.Root>
48
+ <Input.Label>Value</Input.Label>
49
+ <Input.TextInput placeholder='Enter value' />
50
+ </Input.Root>
51
+ </Dialog.Body>
52
+ <Dialog.ActionBar>
53
+ <Dialog.Close asChild>
54
+ <Button variant='primary'>{closeTrigger}</Button>
55
+ </Dialog.Close>
56
+ </Dialog.ActionBar>
57
+ </Dialog.Content>
58
+ </Dialog.Overlay>
59
+ </Dialog.Root>
60
+ );
61
+ };
62
+
63
+ /**
64
+ * Dialog with a ScrollArea child inside Dialog.Body.
65
+ * The ScrollArea breaks out of Body's gutter padding via `--gutter`
66
+ * and applies its own asymmetric padding (accounting for scrollbar width).
67
+ */
68
+ const ScrollingStory = ({ size, title, description, openTrigger, closeTrigger, blockAlign }: DefaultStoryProps) => {
69
+ return (
70
+ <Dialog.Root defaultOpen modal>
71
+ <Dialog.Trigger asChild>
72
+ <Button>{openTrigger}</Button>
73
+ </Dialog.Trigger>
74
+ <Dialog.Overlay blockAlign={blockAlign}>
75
+ <Dialog.Content size={size}>
76
+ <Dialog.Header>
77
+ <Dialog.Title>{title}</Dialog.Title>
78
+ {closeTrigger && (
79
+ <Dialog.Close asChild>
80
+ <Dialog.ActionIconButton action='close' />
81
+ </Dialog.Close>
82
+ )}
83
+ </Dialog.Header>
84
+ <Dialog.Body>
85
+ <ScrollArea.Root orientation='vertical' padding thin>
86
+ <ScrollArea.Viewport>
87
+ <Dialog.Description>{description}</Dialog.Description>
88
+ </ScrollArea.Viewport>
89
+ </ScrollArea.Root>
42
90
  </Dialog.Body>
43
91
  <Dialog.ActionBar>
44
92
  <Dialog.Close asChild>
@@ -56,21 +104,26 @@ const meta = {
56
104
  component: Dialog as any,
57
105
  render: DefaultStory,
58
106
  decorators: [withTheme()],
59
- parameters: {
60
- chromatic: {
61
- disableSnapshot: false,
62
- },
63
- },
64
107
  } satisfies Meta<typeof DefaultStory>;
65
108
 
66
109
  export default meta;
67
110
 
68
111
  type Story = StoryObj<typeof meta>;
69
112
 
113
+ export const Default: Story = {
114
+ args: {
115
+ title: 'Dialog title',
116
+ description: random.lorem.paragraph(1),
117
+ openTrigger: 'Open',
118
+ closeTrigger: 'Close',
119
+ blockAlign: 'start',
120
+ },
121
+ };
122
+
70
123
  export const Small: Story = {
71
124
  args: {
72
125
  title: 'Dialog title',
73
- description: faker.lorem.paragraph(2),
126
+ description: random.lorem.paragraph(1),
74
127
  openTrigger: 'Open',
75
128
  closeTrigger: 'Close',
76
129
  blockAlign: 'center',
@@ -81,7 +134,7 @@ export const Small: Story = {
81
134
  export const Medium: Story = {
82
135
  args: {
83
136
  title: 'Dialog title',
84
- description: faker.lorem.paragraph(2),
137
+ description: random.lorem.paragraph(1),
85
138
  openTrigger: 'Open',
86
139
  closeTrigger: 'Close',
87
140
  blockAlign: 'center',
@@ -92,10 +145,33 @@ export const Medium: Story = {
92
145
  export const Large: Story = {
93
146
  args: {
94
147
  title: 'Dialog title',
95
- description: faker.lorem.paragraph(2),
148
+ description: random.lorem.paragraph(2),
96
149
  openTrigger: 'Open Dialog',
97
150
  closeTrigger: 'Close',
98
151
  blockAlign: 'center',
99
152
  size: 'lg',
100
153
  },
101
154
  };
155
+
156
+ export const ExtraLarge: Story = {
157
+ args: {
158
+ title: 'Dialog title',
159
+ description: random.lorem.paragraph(2),
160
+ openTrigger: 'Open Dialog',
161
+ closeTrigger: 'Close',
162
+ blockAlign: 'center',
163
+ size: 'xl',
164
+ },
165
+ };
166
+
167
+ export const Scrolling: Story = {
168
+ render: ScrollingStory,
169
+ args: {
170
+ title: 'Dialog title',
171
+ description: random.lorem.paragraph(20),
172
+ openTrigger: 'Open Dialog',
173
+ closeTrigger: 'Close',
174
+ blockAlign: 'center',
175
+ size: 'md',
176
+ },
177
+ };
@@ -0,0 +1,61 @@
1
+ //
2
+ // Copyright 2023 DXOS.org
3
+ //
4
+
5
+ import { mx } from '@dxos/ui-theme';
6
+ import { type ComponentFunction, type Elevation, type Theme } from '@dxos/ui-types';
7
+
8
+ import { withColumn } from '../Column/withColumn';
9
+
10
+ export type DialogSize = 'sm' | 'md' | 'lg' | 'xl';
11
+
12
+ const sizeMap: Record<DialogSize, string> = {
13
+ sm: 'md:max-w-[24rem]',
14
+ md: 'md:max-w-[32rem]!',
15
+ lg: 'md:max-w-[40rem]!',
16
+ xl: 'md:max-w-[60rem]!',
17
+ };
18
+
19
+ export type DialogStyleProps = {
20
+ srOnly?: boolean;
21
+ inOverlayLayout?: boolean;
22
+ elevation?: Elevation;
23
+ size?: DialogSize;
24
+ };
25
+
26
+ const overlay: ComponentFunction<DialogStyleProps> = (_props, ...etc) => mx('dx-dialog__overlay', ...etc);
27
+
28
+ const content: ComponentFunction<DialogStyleProps> = ({ inOverlayLayout, size = 'md' }, ...etc) => {
29
+ return mx(
30
+ '@container',
31
+ 'dx-dialog__content dx-focus-ring dx-modal-surface py-4',
32
+ !inOverlayLayout && 'fixed z-50 top-[50%] left-[50%] -translate-x-[50%] -translate-y-[50%]',
33
+ sizeMap[size],
34
+ ...etc,
35
+ );
36
+ };
37
+
38
+ const header: ComponentFunction<DialogStyleProps> = (_props, ...etc) =>
39
+ mx('dx-dialog__header flex pb-4 items-center justify-between', withColumn.center(), ...etc);
40
+
41
+ const body: ComponentFunction<DialogStyleProps> = (_props, ...etc) =>
42
+ mx('dx-dialog__body dx-expander', withColumn.propagate(), ...etc);
43
+
44
+ const actionBar: ComponentFunction<DialogStyleProps> = (_props, ...etc) =>
45
+ mx('dx-dialog__actionbar flex items-center pt-4 gap-2', withColumn.center(), ...etc);
46
+
47
+ const title: ComponentFunction<DialogStyleProps> = ({ srOnly }, ...etc) =>
48
+ mx('dx-dialog__title', srOnly && 'sr-only', ...etc);
49
+
50
+ const description: ComponentFunction<DialogStyleProps> = ({ srOnly }, ...etc) =>
51
+ mx('dx-dialog__description', 'text-description', srOnly && 'sr-only', ...etc);
52
+
53
+ export const dialogTheme: Theme<DialogStyleProps> = {
54
+ overlay,
55
+ content,
56
+ header,
57
+ body,
58
+ actionbar: actionBar,
59
+ title,
60
+ description,
61
+ };
@@ -3,72 +3,67 @@
3
3
  //
4
4
 
5
5
  import { createContext } from '@radix-ui/react-context';
6
- import {
7
- DialogClose as DialogClosePrimitive,
8
- type DialogCloseProps as DialogClosePrimitiveProps,
9
- DialogContent as DialogContentPrimitive,
10
- DialogDescription as DialogDescriptionPrimitive,
11
- type DialogDescriptionProps as DialogDescriptionPrimitiveProps,
12
- DialogOverlay as DialogOverlayPrimitive,
13
- type DialogOverlayProps as DialogOverlayPrimitiveProps,
14
- DialogPortal as DialogPortalPrimitive,
15
- type DialogPortalProps as DialogPortalPrimitiveProps,
16
- Root as DialogRootPrimitive,
17
- type DialogProps as DialogRootPrimitiveProps,
18
- DialogTitle as DialogTitlePrimitive,
19
- type DialogTitleProps as DialogTitlePrimitiveProps,
20
- DialogTrigger as DialogTriggerPrimitive,
21
- type DialogTriggerProps as DialogTriggerPrimitiveProps,
22
- } from '@radix-ui/react-dialog';
6
+ import * as DialogPrimitive from '@radix-ui/react-dialog';
7
+ import { Primitive } from '@radix-ui/react-primitive';
8
+ import { Slot } from '@radix-ui/react-slot';
23
9
  import React, {
24
10
  type ComponentPropsWithRef,
25
11
  type ForwardRefExoticComponent,
26
12
  type FunctionComponent,
27
- type PropsWithChildren,
28
13
  forwardRef,
29
14
  } from 'react';
30
15
  import { useTranslation } from 'react-i18next';
31
16
 
32
- import { type DialogSize, osTranslations } from '@dxos/ui-theme';
17
+ import { osTranslations } from '@dxos/ui-theme';
18
+ import { type SlottableProps } from '@dxos/ui-types';
33
19
 
34
20
  import { useThemeContext } from '../../hooks';
35
- import { type ThemedClassName } from '../../util';
36
- import { IconButton, type IconButtonProps } from '../Button';
37
- import { ElevationProvider } from '../ElevationProvider';
21
+ import { ElevationProvider } from '../../primitives';
22
+ import { type DialogSize } from '../../theme';
23
+ import { type ThemedClassName, composableProps, slottable } from '../../util';
24
+ import { IconButton } from '../Button';
25
+ import { Column } from '../Column';
38
26
 
39
27
  //
40
28
  // Root
41
29
  //
42
30
 
43
- type DialogRootProps = DialogRootPrimitiveProps;
31
+ type DialogRootProps = DialogPrimitive.DialogProps;
44
32
 
45
33
  const DialogRoot: FunctionComponent<DialogRootProps> = (props) => (
46
34
  <ElevationProvider elevation='dialog'>
47
- <DialogRootPrimitive {...props} />
35
+ <DialogPrimitive.Root
36
+ // NOTE: Radix warning unless set to undefined.
37
+ // https://www.radix-ui.com/primitives/docs/components/dialog#description
38
+ aria-describedby={undefined}
39
+ {...props}
40
+ />
48
41
  </ElevationProvider>
49
42
  );
50
43
 
44
+ DialogRoot.displayName = 'Dialog.Root';
45
+
51
46
  //
52
47
  // Trigger
53
48
  //
54
49
 
55
- type DialogTriggerProps = DialogTriggerPrimitiveProps;
50
+ type DialogTriggerProps = DialogPrimitive.DialogTriggerProps;
56
51
 
57
- const DialogTrigger: FunctionComponent<DialogTriggerProps> = DialogTriggerPrimitive;
52
+ const DialogTrigger = DialogPrimitive.Trigger;
58
53
 
59
54
  //
60
55
  // Portal
61
56
  //
62
57
 
63
- type DialogPortalProps = DialogPortalPrimitiveProps;
58
+ type DialogPortalProps = DialogPrimitive.DialogPortalProps;
64
59
 
65
- const DialogPortal: FunctionComponent<DialogPortalProps> = DialogPortalPrimitive;
60
+ const DialogPortal = DialogPrimitive.Portal;
66
61
 
67
62
  //
68
63
  // Overlay
69
64
  //
70
65
 
71
- const DIALOG_OVERLAY_NAME = 'DialogOverlay';
66
+ const DIALOG_OVERLAY_NAME = 'Dialog.Overlay';
72
67
 
73
68
  type OverlayLayoutContextValue = { inOverlayLayout?: boolean };
74
69
 
@@ -77,21 +72,23 @@ const [OverlayLayoutProvider, useOverlayLayoutContext] = createContext<OverlayLa
77
72
  {},
78
73
  );
79
74
 
80
- type DialogOverlayProps = ThemedClassName<DialogOverlayPrimitiveProps & { blockAlign?: 'center' | 'start' | 'end' }>;
75
+ type DialogOverlayProps = ThemedClassName<
76
+ DialogPrimitive.DialogOverlayProps & { blockAlign?: 'center' | 'start' | 'end' }
77
+ >;
81
78
 
82
79
  const DialogOverlay: ForwardRefExoticComponent<DialogOverlayProps> = forwardRef<HTMLDivElement, DialogOverlayProps>(
83
80
  ({ classNames, children, blockAlign, ...props }, forwardedRef) => {
84
81
  const { tx } = useThemeContext();
85
82
 
86
83
  return (
87
- <DialogOverlayPrimitive
84
+ <DialogPrimitive.Overlay
88
85
  {...props}
89
- className={tx('dialog.overlay', 'dialog__overlay', {}, classNames)}
90
- ref={forwardedRef}
91
86
  data-block-align={blockAlign}
87
+ className={tx('dialog.overlay', {}, classNames)}
88
+ ref={forwardedRef}
92
89
  >
93
90
  <OverlayLayoutProvider inOverlayLayout>{children}</OverlayLayoutProvider>
94
- </DialogOverlayPrimitive>
91
+ </DialogPrimitive.Overlay>
95
92
  );
96
93
  },
97
94
  );
@@ -102,34 +99,38 @@ DialogOverlay.displayName = DIALOG_OVERLAY_NAME;
102
99
  // Content
103
100
  //
104
101
 
105
- const DIALOG_CONTENT_NAME = 'DialogContent';
102
+ const DIALOG_CONTENT_NAME = 'Dialog.Content';
106
103
 
107
- type DialogContentProps = ThemedClassName<ComponentPropsWithRef<typeof DialogContentPrimitive>> & {
104
+ type DialogContentProps = ThemedClassName<ComponentPropsWithRef<typeof DialogPrimitive.Content>> & {
108
105
  size?: DialogSize;
109
106
  inOverlayLayout?: boolean;
110
107
  };
111
108
 
112
109
  const DialogContent: ForwardRefExoticComponent<DialogContentProps> = forwardRef<HTMLDivElement, DialogContentProps>(
113
- ({ classNames, children, size, inOverlayLayout: propsInOverlayLayout, ...props }, forwardedRef) => {
110
+ ({ classNames, children, size = 'md', inOverlayLayout: propsInOverlayLayout, ...props }, forwardedRef) => {
114
111
  const { tx } = useThemeContext();
115
112
  const { inOverlayLayout } = useOverlayLayoutContext(DIALOG_CONTENT_NAME);
116
113
 
117
114
  return (
118
- <DialogContentPrimitive
115
+ <DialogPrimitive.Content
116
+ {...props}
119
117
  // NOTE: Radix warning unless set to undefined.
120
118
  // https://www.radix-ui.com/primitives/docs/components/dialog#description
121
119
  aria-describedby={undefined}
122
- {...props}
123
120
  className={tx(
124
121
  'dialog.content',
125
- 'dialog',
126
- { inOverlayLayout: propsInOverlayLayout || inOverlayLayout, size },
122
+ {
123
+ size,
124
+ inOverlayLayout: propsInOverlayLayout || inOverlayLayout,
125
+ },
127
126
  classNames,
128
127
  )}
129
128
  ref={forwardedRef}
130
129
  >
131
- {children}
132
- </DialogContentPrimitive>
130
+ <Column.Root classNames='dx-expander' gutter='sm'>
131
+ {children}
132
+ </Column.Root>
133
+ </DialogPrimitive.Content>
133
134
  );
134
135
  },
135
136
  );
@@ -140,130 +141,142 @@ DialogContent.displayName = DIALOG_CONTENT_NAME;
140
141
  // Header
141
142
  //
142
143
 
143
- type DialogHeaderProps = ThemedClassName<PropsWithChildren> & { srOnly?: boolean };
144
+ type DialogHeaderProps = SlottableProps;
144
145
 
145
- const DialogHeader: ForwardRefExoticComponent<DialogTitleProps> = forwardRef<HTMLHeadingElement, DialogTitleProps>(
146
- ({ classNames, srOnly, ...props }, forwardedRef) => {
147
- const { tx } = useThemeContext();
146
+ const DialogHeader = slottable<HTMLDivElement>(({ children, asChild, ...props }, forwardedRef) => {
147
+ const { className, ...rest } = composableProps(props);
148
+ const Comp = asChild ? Slot : Primitive.div;
149
+ const { tx } = useThemeContext();
150
+ return (
151
+ <Comp {...rest} className={tx('dialog.header', {}, className)} ref={forwardedRef}>
152
+ {children}
153
+ </Comp>
154
+ );
155
+ });
156
+
157
+ DialogHeader.displayName = 'Dialog.Header';
158
+
159
+ //
160
+ // ActionIconButton
161
+ //
162
+
163
+ type DialogActionIconButtonAction = 'close' | 'delete';
164
+
165
+ type DialogActionIconButtonProps = { action: DialogActionIconButtonAction; label?: string };
166
+
167
+ const DIALOG_ACTION_ICONS: Record<DialogActionIconButtonAction, string> = {
168
+ close: 'ph--x--regular',
169
+ delete: 'ph--trash--regular',
170
+ };
171
+
172
+ const DIALOG_ACTION_LABEL_KEYS: Record<DialogActionIconButtonAction, string> = {
173
+ // Preserves the legacy `close-dialog.label` translation key for backward compat.
174
+ close: 'close-dialog.label',
175
+ delete: 'toolbar-delete.label',
176
+ };
177
+
178
+ const DialogActionIconButton = forwardRef<HTMLButtonElement, DialogActionIconButtonProps>(
179
+ ({ action, label, ...props }, forwardedRef) => {
180
+ const { t } = useTranslation(osTranslations);
148
181
  return (
149
- <div
182
+ <IconButton
150
183
  {...props}
151
- role='header'
152
- className={tx('dialog.header', 'dialog__header', { srOnly }, classNames)}
184
+ label={label ?? t(DIALOG_ACTION_LABEL_KEYS[action])}
185
+ icon={DIALOG_ACTION_ICONS[action]}
186
+ iconOnly
187
+ size={4}
188
+ variant='ghost'
153
189
  ref={forwardedRef}
154
190
  />
155
191
  );
156
192
  },
157
193
  );
158
194
 
195
+ DialogActionIconButton.displayName = 'Dialog.ActionIconButton';
196
+
159
197
  //
160
198
  // Body
161
199
  //
162
200
 
163
- type DialogBodyProps = PropsWithChildren;
201
+ type DialogBodyProps = SlottableProps;
202
+
203
+ const DialogBody = slottable<HTMLDivElement>(({ children, asChild, ...props }, forwardedRef) => {
204
+ const { className, ...rest } = composableProps(props);
205
+ const Comp = asChild ? Slot : Primitive.div;
206
+ const { tx } = useThemeContext();
207
+ return (
208
+ <Comp {...rest} className={tx('dialog.body', {}, className)} ref={forwardedRef}>
209
+ {children}
210
+ </Comp>
211
+ );
212
+ });
164
213
 
165
- const DialogBody: ForwardRefExoticComponent<DialogBodyProps> = forwardRef<HTMLDivElement, DialogBodyProps>(
166
- ({ children, ...props }, forwardedRef) => {
214
+ DialogBody.displayName = 'Dialog.Body';
215
+
216
+ //
217
+ // Title
218
+ //
219
+
220
+ type DialogTitleProps = ThemedClassName<DialogPrimitive.DialogTitleProps> & { srOnly?: boolean };
221
+
222
+ const DialogTitle = forwardRef<HTMLHeadingElement, DialogTitleProps>(
223
+ ({ classNames, srOnly, ...props }, forwardedRef) => {
167
224
  const { tx } = useThemeContext();
168
225
  return (
169
- <div {...props} className={tx('dialog.body', 'dialog__body')} ref={forwardedRef}>
170
- {children}
171
- </div>
226
+ <DialogPrimitive.Title {...props} className={tx('dialog.title', { srOnly }, classNames)} ref={forwardedRef} />
172
227
  );
173
228
  },
174
229
  );
175
230
 
176
- // TODO(burdon): Add ActionBar.
231
+ DialogTitle.displayName = 'Dialog.Title';
177
232
 
178
233
  //
179
- // Title
234
+ // Description
180
235
  //
181
236
 
182
- type DialogTitleProps = ThemedClassName<DialogTitlePrimitiveProps> & { srOnly?: boolean };
237
+ type DialogDescriptionProps = ThemedClassName<DialogPrimitive.DialogDescriptionProps> & { srOnly?: boolean };
183
238
 
184
- const DialogTitle: ForwardRefExoticComponent<DialogTitleProps> = forwardRef<HTMLHeadingElement, DialogTitleProps>(
239
+ const DialogDescription = forwardRef<HTMLParagraphElement, DialogDescriptionProps>(
185
240
  ({ classNames, srOnly, ...props }, forwardedRef) => {
186
241
  const { tx } = useThemeContext();
187
242
  return (
188
- <DialogTitlePrimitive
243
+ <DialogPrimitive.Description
189
244
  {...props}
190
- className={tx('dialog.title', 'dialog__title', { srOnly }, classNames)}
245
+ className={tx('dialog.description', { srOnly }, classNames)}
191
246
  ref={forwardedRef}
192
247
  />
193
248
  );
194
249
  },
195
250
  );
196
251
 
197
- //
198
- // Description
199
- //
200
-
201
- type DialogDescriptionProps = ThemedClassName<DialogDescriptionPrimitiveProps> & { srOnly?: boolean };
202
-
203
- const DialogDescription: ForwardRefExoticComponent<DialogTitleProps> = forwardRef<
204
- HTMLParagraphElement,
205
- DialogDescriptionProps
206
- >(({ classNames, srOnly, ...props }, forwardedRef) => {
207
- const { tx } = useThemeContext();
208
- return (
209
- <DialogDescriptionPrimitive
210
- {...props}
211
- className={tx('dialog.description', 'dialog__description', { srOnly }, classNames)}
212
- ref={forwardedRef}
213
- />
214
- );
215
- });
252
+ DialogDescription.displayName = 'Dialog.Description';
216
253
 
217
254
  //
218
255
  // ActionBar
219
256
  //
220
257
 
221
- type DialogActionBarProps = ThemedClassName<PropsWithChildren>;
258
+ type DialogActionBarProps = SlottableProps;
222
259
 
223
- const DialogActionBar: ForwardRefExoticComponent<DialogActionBarProps> = forwardRef<
224
- HTMLDivElement,
225
- DialogActionBarProps
226
- >(({ children, classNames, ...props }, forwardedRef) => {
260
+ const DialogActionBar = slottable<HTMLDivElement>(({ children, asChild, ...props }, forwardedRef) => {
261
+ const { className: classNames, ...rest } = composableProps(props);
262
+ const Comp = asChild ? Slot : Primitive.div;
227
263
  const { tx } = useThemeContext();
228
264
  return (
229
- <div {...props} className={tx('dialog.actionbar', 'dialog__actionbar', {}, classNames)} ref={forwardedRef}>
265
+ <Comp {...rest} className={tx('dialog.actionbar', {}, classNames)} ref={forwardedRef}>
230
266
  {children}
231
- </div>
267
+ </Comp>
232
268
  );
233
269
  });
234
270
 
235
- //
236
- // Close
237
- //
238
-
239
- type DialogCloseProps = DialogClosePrimitiveProps;
240
-
241
- const DialogClose: FunctionComponent<DialogCloseProps> = DialogClosePrimitive;
271
+ DialogActionBar.displayName = 'Dialog.ActionBar';
242
272
 
243
273
  //
244
- // Close Button
274
+ // Close
245
275
  //
246
276
 
247
- type DialogCloseIconButtonProps = ThemedClassName<Partial<IconButtonProps>>;
277
+ type DialogCloseProps = DialogPrimitive.DialogCloseProps;
248
278
 
249
- const DialogCloseIconButton: ForwardRefExoticComponent<DialogCloseIconButtonProps> = forwardRef<
250
- HTMLButtonElement,
251
- DialogCloseIconButtonProps
252
- >((props, forwardedRef) => {
253
- const { t } = useTranslation(osTranslations);
254
- return (
255
- <IconButton
256
- {...props}
257
- label={props.label ?? t('close dialog label')}
258
- icon='ph--x--regular'
259
- iconOnly
260
- size={4}
261
- density='fine'
262
- variant='ghost'
263
- ref={forwardedRef}
264
- />
265
- );
266
- });
279
+ const DialogClose = DialogPrimitive.Close;
267
280
 
268
281
  //
269
282
  // Dialog
@@ -281,7 +294,7 @@ export const Dialog = {
281
294
  Description: DialogDescription,
282
295
  ActionBar: DialogActionBar,
283
296
  Close: DialogClose,
284
- CloseIconButton: DialogCloseIconButton,
297
+ ActionIconButton: DialogActionIconButton,
285
298
  };
286
299
 
287
300
  export type {
@@ -296,5 +309,6 @@ export type {
296
309
  DialogDescriptionProps,
297
310
  DialogActionBarProps,
298
311
  DialogCloseProps,
299
- DialogCloseIconButtonProps,
312
+ DialogActionIconButtonAction,
313
+ DialogActionIconButtonProps,
300
314
  };
@@ -0,0 +1,45 @@
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 { ErrorBoundary } from '@dxos/react-error-boundary';
9
+
10
+ import { withLayout, withTheme } from '../../testing';
11
+ import { ErrorFallback } from './ErrorFallback';
12
+ import { ThrowError } from './ThrowError';
13
+
14
+ const DefaultStory = () => {
15
+ return (
16
+ <ErrorBoundary name='story' FallbackComponent={ErrorFallback}>
17
+ <ThrowError />
18
+ </ErrorBoundary>
19
+ );
20
+ };
21
+
22
+ const meta: Meta = {
23
+ title: 'ui/react-ui-core/components/ErrorFallback',
24
+ component: ErrorFallback,
25
+ decorators: [withTheme(), withLayout({ layout: 'column' })],
26
+ parameters: {
27
+ layout: 'fullscreen',
28
+ },
29
+ };
30
+
31
+ export default meta;
32
+
33
+ type Story = StoryObj<typeof meta>;
34
+
35
+ export const Default: Story = {
36
+ render: DefaultStory,
37
+ play: async () => {
38
+ // This story intentionally renders an ErrorBoundary fallback; clear the smoke-test error flag.
39
+ (window as any).__ERROR_BOUNDARY_ERRORS__ = [];
40
+ },
41
+ };
42
+
43
+ export const StringError: Story = {
44
+ render: () => <ErrorFallback error='This is a string error message' data={{ context: 'story' }} />,
45
+ };