@dxos/react-ui 0.8.4-main.fffef41 → 0.8.4-staging.60fe92afc8

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 (604) hide show
  1. package/LICENSE +102 -5
  2. package/README.md +1 -1
  3. package/dist/lib/browser/chunk-5SPBSIWS.mjs +33 -0
  4. package/dist/lib/browser/chunk-5SPBSIWS.mjs.map +7 -0
  5. package/dist/lib/browser/chunk-7JFD5ZHZ.mjs +1612 -0
  6. package/dist/lib/browser/chunk-7JFD5ZHZ.mjs.map +7 -0
  7. package/dist/lib/browser/index.mjs +5259 -67
  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 +91 -70
  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-FPVTVXND.mjs +35 -0
  15. package/dist/lib/node-esm/chunk-FPVTVXND.mjs.map +7 -0
  16. package/dist/lib/node-esm/chunk-TTEL2FP2.mjs +1614 -0
  17. package/dist/lib/node-esm/chunk-TTEL2FP2.mjs.map +7 -0
  18. package/dist/lib/node-esm/index.mjs +5259 -67
  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 +91 -70
  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 +4 -4
  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 +3 -1
  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 +10 -10
  52. package/dist/types/src/components/Button/ToggleGroup.d.ts.map +1 -1
  53. package/dist/types/src/components/Button/ToggleGroup.stories.d.ts +6 -6
  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 +126 -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 +106 -0
  72. package/dist/types/src/components/Carousel/Carousel.d.ts.map +1 -0
  73. package/dist/types/src/components/Carousel/Carousel.stories.d.ts +14 -0
  74. package/dist/types/src/components/Carousel/Carousel.stories.d.ts.map +1 -0
  75. package/dist/types/src/components/Carousel/index.d.ts +2 -0
  76. package/dist/types/src/components/Carousel/index.d.ts.map +1 -0
  77. package/dist/types/src/components/Clipboard/ClipboardProvider.d.ts.map +1 -1
  78. package/dist/types/src/components/Clipboard/CopyButton.d.ts.map +1 -1
  79. package/dist/types/src/components/Clipboard/index.d.ts +10 -1
  80. package/dist/types/src/components/Clipboard/index.d.ts.map +1 -1
  81. package/dist/types/src/components/Column/Column.d.ts +33 -0
  82. package/dist/types/src/components/Column/Column.d.ts.map +1 -0
  83. package/dist/types/src/components/Column/Column.stories.d.ts +25 -0
  84. package/dist/types/src/components/Column/Column.stories.d.ts.map +1 -0
  85. package/dist/types/src/components/Column/Column.theme.d.ts +9 -0
  86. package/dist/types/src/components/Column/Column.theme.d.ts.map +1 -0
  87. package/dist/types/src/components/Column/index.d.ts +3 -0
  88. package/dist/types/src/components/Column/index.d.ts.map +1 -0
  89. package/dist/types/src/components/Column/withColumn.d.ts +21 -0
  90. package/dist/types/src/components/Column/withColumn.d.ts.map +1 -0
  91. package/dist/types/src/components/DatePicker/DatePicker.d.ts +72 -0
  92. package/dist/types/src/components/DatePicker/DatePicker.d.ts.map +1 -0
  93. package/dist/types/src/components/DatePicker/DatePicker.stories.d.ts +10 -0
  94. package/dist/types/src/components/DatePicker/DatePicker.stories.d.ts.map +1 -0
  95. package/dist/types/src/components/DatePicker/DatePicker.theme.d.ts +6 -0
  96. package/dist/types/src/components/DatePicker/DatePicker.theme.d.ts.map +1 -0
  97. package/dist/types/src/components/DatePicker/index.d.ts +2 -0
  98. package/dist/types/src/components/DatePicker/index.d.ts.map +1 -0
  99. package/dist/types/src/components/Dialog/AlertDialog.d.ts +43 -23
  100. package/dist/types/src/components/Dialog/AlertDialog.d.ts.map +1 -1
  101. package/dist/types/src/components/Dialog/AlertDialog.stories.d.ts.map +1 -1
  102. package/dist/types/src/components/Dialog/Dialog.d.ts +58 -23
  103. package/dist/types/src/components/Dialog/Dialog.d.ts.map +1 -1
  104. package/dist/types/src/components/Dialog/Dialog.stories.d.ts +10 -10
  105. package/dist/types/src/components/Dialog/Dialog.stories.d.ts.map +1 -1
  106. package/dist/types/src/components/Dialog/Dialog.theme.d.ts +10 -0
  107. package/dist/types/src/components/Dialog/Dialog.theme.d.ts.map +1 -0
  108. package/dist/types/src/components/ErrorFallback/ErrorFallback.d.ts +11 -0
  109. package/dist/types/src/components/ErrorFallback/ErrorFallback.d.ts.map +1 -0
  110. package/dist/types/src/components/ErrorFallback/ErrorFallback.stories.d.ts +7 -0
  111. package/dist/types/src/components/ErrorFallback/ErrorFallback.stories.d.ts.map +1 -0
  112. package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts +19 -0
  113. package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts.map +1 -0
  114. package/dist/types/src/components/ErrorFallback/ThrowError.d.ts +9 -0
  115. package/dist/types/src/components/ErrorFallback/ThrowError.d.ts.map +1 -0
  116. package/dist/types/src/components/ErrorFallback/index.d.ts +5 -0
  117. package/dist/types/src/components/ErrorFallback/index.d.ts.map +1 -0
  118. package/dist/types/src/components/Focus/Focus.d.ts +36 -0
  119. package/dist/types/src/components/Focus/Focus.d.ts.map +1 -0
  120. package/dist/types/src/components/Focus/Focus.stories.d.ts +9 -0
  121. package/dist/types/src/components/Focus/Focus.stories.d.ts.map +1 -0
  122. package/dist/types/src/components/Focus/Focus.theme.d.ts +6 -0
  123. package/dist/types/src/components/Focus/Focus.theme.d.ts.map +1 -0
  124. package/dist/types/src/components/Focus/index.d.ts +2 -0
  125. package/dist/types/src/components/Focus/index.d.ts.map +1 -0
  126. package/dist/types/src/components/Icon/Icon.d.ts +5 -1
  127. package/dist/types/src/components/Icon/Icon.d.ts.map +1 -1
  128. package/dist/types/src/components/Icon/Icon.stories.d.ts +11 -3
  129. package/dist/types/src/components/Icon/Icon.stories.d.ts.map +1 -1
  130. package/dist/types/src/components/Icon/Icon.theme.d.ts +11 -0
  131. package/dist/types/src/components/Icon/Icon.theme.d.ts.map +1 -0
  132. package/dist/types/src/components/Icon/IconBlock.d.ts +15 -0
  133. package/dist/types/src/components/Icon/IconBlock.d.ts.map +1 -0
  134. package/dist/types/src/components/Icon/index.d.ts +1 -0
  135. package/dist/types/src/components/Icon/index.d.ts.map +1 -1
  136. package/dist/types/src/components/Image/Image.d.ts +21 -0
  137. package/dist/types/src/components/Image/Image.d.ts.map +1 -0
  138. package/dist/types/src/components/Image/Image.stories.d.ts +34 -0
  139. package/dist/types/src/components/Image/Image.stories.d.ts.map +1 -0
  140. package/dist/types/src/components/Image/index.d.ts +2 -0
  141. package/dist/types/src/components/Image/index.d.ts.map +1 -0
  142. package/dist/types/src/components/Input/Input.d.ts +95 -20
  143. package/dist/types/src/components/Input/Input.d.ts.map +1 -1
  144. package/dist/types/src/components/Input/Input.stories.d.ts +21 -10
  145. package/dist/types/src/components/Input/Input.stories.d.ts.map +1 -1
  146. package/dist/types/src/components/Input/Input.theme.d.ts +115 -0
  147. package/dist/types/src/components/Input/Input.theme.d.ts.map +1 -0
  148. package/dist/types/src/components/Input/SegmentedInput.d.ts +79 -0
  149. package/dist/types/src/components/Input/SegmentedInput.d.ts.map +1 -0
  150. package/dist/types/src/components/Input/constants.d.ts +2 -0
  151. package/dist/types/src/components/Input/constants.d.ts.map +1 -0
  152. package/dist/types/src/components/Input/index.d.ts +2 -0
  153. package/dist/types/src/components/Input/index.d.ts.map +1 -1
  154. package/dist/types/src/components/Link/Link.d.ts.map +1 -1
  155. package/dist/types/src/components/Link/Link.stories.d.ts.map +1 -1
  156. package/dist/types/src/components/Link/Link.theme.d.ts +6 -0
  157. package/dist/types/src/components/Link/Link.theme.d.ts.map +1 -0
  158. package/dist/types/src/components/List/List.d.ts +6 -4
  159. package/dist/types/src/components/List/List.d.ts.map +1 -1
  160. package/dist/types/src/components/List/List.stories.d.ts +3 -1
  161. package/dist/types/src/components/List/List.stories.d.ts.map +1 -1
  162. package/dist/types/src/components/List/List.theme.d.ts +7 -0
  163. package/dist/types/src/components/List/List.theme.d.ts.map +1 -0
  164. package/dist/types/src/components/List/ListDropIndicator.d.ts.map +1 -1
  165. package/dist/types/src/components/List/Tree.d.ts +2 -2
  166. package/dist/types/src/components/List/Tree.d.ts.map +1 -1
  167. package/dist/types/src/components/List/Tree.stories.d.ts.map +1 -1
  168. package/dist/types/src/components/List/TreeDropIndicator.d.ts.map +1 -1
  169. package/dist/types/src/components/List/Treegrid.d.ts +6 -10
  170. package/dist/types/src/components/List/Treegrid.d.ts.map +1 -1
  171. package/dist/types/src/components/List/Treegrid.stories.d.ts.map +1 -1
  172. package/dist/types/src/components/List/Treegrid.theme.d.ts +7 -0
  173. package/dist/types/src/components/List/Treegrid.theme.d.ts.map +1 -0
  174. package/dist/types/src/components/Main/Main.d.ts +17 -14
  175. package/dist/types/src/components/Main/Main.d.ts.map +1 -1
  176. package/dist/types/src/components/Main/Main.stories.d.ts +0 -3
  177. package/dist/types/src/components/Main/Main.stories.d.ts.map +1 -1
  178. package/dist/types/src/components/Main/Main.theme.d.ts +20 -0
  179. package/dist/types/src/components/Main/Main.theme.d.ts.map +1 -0
  180. package/dist/types/src/components/Main/constants.d.ts +3 -0
  181. package/dist/types/src/components/Main/constants.d.ts.map +1 -0
  182. package/dist/types/src/components/Main/index.d.ts +1 -0
  183. package/dist/types/src/components/Main/index.d.ts.map +1 -1
  184. package/dist/types/src/components/Main/useSwipeToDismiss.d.ts.map +1 -1
  185. package/dist/types/src/components/MediaPlayer/MediaPlayer.d.ts +47 -0
  186. package/dist/types/src/components/MediaPlayer/MediaPlayer.d.ts.map +1 -0
  187. package/dist/types/src/components/MediaPlayer/MediaPlayer.stories.d.ts +16 -0
  188. package/dist/types/src/components/MediaPlayer/MediaPlayer.stories.d.ts.map +1 -0
  189. package/dist/types/src/components/MediaPlayer/index.d.ts +2 -0
  190. package/dist/types/src/components/MediaPlayer/index.d.ts.map +1 -0
  191. package/dist/types/src/components/{Menus → Menu}/ContextMenu.d.ts +6 -6
  192. package/dist/types/src/components/Menu/ContextMenu.d.ts.map +1 -0
  193. package/dist/types/src/components/Menu/ContextMenu.stories.d.ts.map +1 -0
  194. package/dist/types/src/components/Menu/DropdownMenu.d.ts +121 -0
  195. package/dist/types/src/components/Menu/DropdownMenu.d.ts.map +1 -0
  196. package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts +28 -0
  197. package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts.map +1 -0
  198. package/dist/types/src/components/Menu/Menu.theme.d.ts +7 -0
  199. package/dist/types/src/components/Menu/Menu.theme.d.ts.map +1 -0
  200. package/dist/types/src/components/Menu/index.d.ts.map +1 -0
  201. package/dist/types/src/components/Message/Message.d.ts +4 -4
  202. package/dist/types/src/components/Message/Message.d.ts.map +1 -1
  203. package/dist/types/src/components/Message/Message.stories.d.ts +9 -6
  204. package/dist/types/src/components/Message/Message.stories.d.ts.map +1 -1
  205. package/dist/types/src/components/Message/Message.theme.d.ts +7 -0
  206. package/dist/types/src/components/Message/Message.theme.d.ts.map +1 -0
  207. package/dist/types/src/components/Panel/Panel.d.ts +35 -0
  208. package/dist/types/src/components/Panel/Panel.d.ts.map +1 -0
  209. package/dist/types/src/components/Panel/Panel.stories.d.ts +6 -0
  210. package/dist/types/src/components/Panel/Panel.stories.d.ts.map +1 -0
  211. package/dist/types/src/components/Panel/Panel.theme.d.ts +13 -0
  212. package/dist/types/src/components/Panel/Panel.theme.d.ts.map +1 -0
  213. package/dist/types/src/components/Panel/index.d.ts +2 -0
  214. package/dist/types/src/components/Panel/index.d.ts.map +1 -0
  215. package/dist/types/src/components/Popover/Popover.d.ts +40 -23
  216. package/dist/types/src/components/Popover/Popover.d.ts.map +1 -1
  217. package/dist/types/src/components/Popover/Popover.stories.d.ts.map +1 -1
  218. package/dist/types/src/components/Popover/Popover.theme.d.ts +8 -0
  219. package/dist/types/src/components/Popover/Popover.theme.d.ts.map +1 -0
  220. package/dist/types/src/components/ScrollArea/ScrollArea.d.ts +27 -27
  221. package/dist/types/src/components/ScrollArea/ScrollArea.d.ts.map +1 -1
  222. package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts +57 -8
  223. package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts.map +1 -1
  224. package/dist/types/src/components/ScrollArea/ScrollArea.theme.d.ts +17 -0
  225. package/dist/types/src/components/ScrollArea/ScrollArea.theme.d.ts.map +1 -0
  226. package/dist/types/src/components/ScrollArea/index.d.ts +1 -0
  227. package/dist/types/src/components/ScrollArea/index.d.ts.map +1 -1
  228. package/dist/types/src/components/ScrollArea/scrollbar.d.ts +18 -0
  229. package/dist/types/src/components/ScrollArea/scrollbar.d.ts.map +1 -0
  230. package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts +44 -19
  231. package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts.map +1 -1
  232. package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts +10 -5
  233. package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts.map +1 -1
  234. package/dist/types/src/components/Select/Select.d.ts +9 -9
  235. package/dist/types/src/components/Select/Select.d.ts.map +1 -1
  236. package/dist/types/src/components/Select/Select.stories.d.ts +2 -2
  237. package/dist/types/src/components/Select/Select.stories.d.ts.map +1 -1
  238. package/dist/types/src/components/Select/Select.theme.d.ts +6 -0
  239. package/dist/types/src/components/Select/Select.theme.d.ts.map +1 -0
  240. package/dist/types/src/components/Separator/Separator.d.ts +4 -4
  241. package/dist/types/src/components/Separator/Separator.d.ts.map +1 -1
  242. package/dist/types/src/components/Separator/Separator.theme.d.ts +7 -0
  243. package/dist/types/src/components/Separator/Separator.theme.d.ts.map +1 -0
  244. package/dist/types/src/components/Skeleton/Skeleton.d.ts +12 -0
  245. package/dist/types/src/components/Skeleton/Skeleton.d.ts.map +1 -0
  246. package/dist/types/src/components/Skeleton/Skeleton.stories.d.ts +17 -0
  247. package/dist/types/src/components/Skeleton/Skeleton.stories.d.ts.map +1 -0
  248. package/dist/types/src/components/Skeleton/Skeleton.theme.d.ts +6 -0
  249. package/dist/types/src/components/Skeleton/Skeleton.theme.d.ts.map +1 -0
  250. package/dist/types/src/components/Skeleton/index.d.ts +2 -0
  251. package/dist/types/src/components/Skeleton/index.d.ts.map +1 -0
  252. package/dist/types/src/components/Splitter/Splitter.d.ts +32 -0
  253. package/dist/types/src/components/Splitter/Splitter.d.ts.map +1 -0
  254. package/dist/types/src/components/Splitter/Splitter.stories.d.ts +7 -0
  255. package/dist/types/src/components/Splitter/Splitter.stories.d.ts.map +1 -0
  256. package/dist/types/src/components/Splitter/Splitter.theme.d.ts +4 -0
  257. package/dist/types/src/components/Splitter/Splitter.theme.d.ts.map +1 -0
  258. package/dist/types/src/components/Splitter/index.d.ts +2 -0
  259. package/dist/types/src/components/Splitter/index.d.ts.map +1 -0
  260. package/dist/types/src/components/Status/Status.d.ts +3 -4
  261. package/dist/types/src/components/Status/Status.d.ts.map +1 -1
  262. package/dist/types/src/components/Status/Status.stories.d.ts +4 -2
  263. package/dist/types/src/components/Status/Status.stories.d.ts.map +1 -1
  264. package/dist/types/src/components/Status/Status.theme.d.ts +7 -0
  265. package/dist/types/src/components/Status/Status.theme.d.ts.map +1 -0
  266. package/dist/types/src/components/Tag/Tag.d.ts +1 -1
  267. package/dist/types/src/components/Tag/Tag.d.ts.map +1 -1
  268. package/dist/types/src/components/Tag/Tag.stories.d.ts +0 -5
  269. package/dist/types/src/components/Tag/Tag.stories.d.ts.map +1 -1
  270. package/dist/types/src/components/Tag/Tag.theme.d.ts +6 -0
  271. package/dist/types/src/components/Tag/Tag.theme.d.ts.map +1 -0
  272. package/dist/types/src/components/Toast/Toast.d.ts +27 -24
  273. package/dist/types/src/components/Toast/Toast.d.ts.map +1 -1
  274. package/dist/types/src/components/Toast/Toast.stories.d.ts +5 -2
  275. package/dist/types/src/components/Toast/Toast.stories.d.ts.map +1 -1
  276. package/dist/types/src/components/Toast/Toast.theme.d.ts +4 -0
  277. package/dist/types/src/components/Toast/Toast.theme.d.ts.map +1 -0
  278. package/dist/types/src/components/Toolbar/Toolbar.d.ts +52 -22
  279. package/dist/types/src/components/Toolbar/Toolbar.d.ts.map +1 -1
  280. package/dist/types/src/components/Toolbar/Toolbar.stories.d.ts.map +1 -1
  281. package/dist/types/src/components/Toolbar/Toolbar.theme.d.ts +8 -0
  282. package/dist/types/src/components/Toolbar/Toolbar.theme.d.ts.map +1 -0
  283. package/dist/types/src/components/Tooltip/Tooltip.d.ts +16 -16
  284. package/dist/types/src/components/Tooltip/Tooltip.d.ts.map +1 -1
  285. package/dist/types/src/components/Tooltip/Tooltip.stories.d.ts +2 -2
  286. package/dist/types/src/components/Tooltip/Tooltip.stories.d.ts.map +1 -1
  287. package/dist/types/src/components/Tooltip/Tooltip.theme.d.ts +6 -0
  288. package/dist/types/src/components/Tooltip/Tooltip.theme.d.ts.map +1 -0
  289. package/dist/types/src/components/Tooltip/index.d.ts +1 -0
  290. package/dist/types/src/components/Tooltip/index.d.ts.map +1 -1
  291. package/dist/types/src/components/Tooltip/tooltipContent.d.ts +4 -0
  292. package/dist/types/src/components/Tooltip/tooltipContent.d.ts.map +1 -0
  293. package/dist/types/src/components/index.d.ts +14 -6
  294. package/dist/types/src/components/index.d.ts.map +1 -1
  295. package/dist/types/src/exemplars/generics.stories.d.ts +19 -0
  296. package/dist/types/src/exemplars/generics.stories.d.ts.map +1 -0
  297. package/dist/types/src/exemplars/slot.stories.d.ts +15 -0
  298. package/dist/types/src/exemplars/slot.stories.d.ts.map +1 -0
  299. package/dist/types/src/exemplars/tabster.stories.d.ts +8 -0
  300. package/dist/types/src/exemplars/tabster.stories.d.ts.map +1 -0
  301. package/dist/types/src/exemplars/virtualizer.stories.d.ts +11 -0
  302. package/dist/types/src/exemplars/virtualizer.stories.d.ts.map +1 -0
  303. package/dist/types/src/hooks/index.d.ts +1 -0
  304. package/dist/types/src/hooks/index.d.ts.map +1 -1
  305. package/dist/types/src/hooks/useDensityContext.d.ts +2 -2
  306. package/dist/types/src/hooks/useDensityContext.d.ts.map +1 -1
  307. package/dist/types/src/hooks/useElevationContext.d.ts +1 -1
  308. package/dist/types/src/hooks/useElevationContext.d.ts.map +1 -1
  309. package/dist/types/src/hooks/useIconHref.d.ts.map +1 -1
  310. package/dist/types/src/hooks/useSafeArea.d.ts.map +1 -1
  311. package/dist/types/src/hooks/useSafeCollisionPadding.d.ts.map +1 -1
  312. package/dist/types/src/hooks/useTranslationsContext.d.ts +1 -1
  313. package/dist/types/src/hooks/useVisualViewport.d.ts.map +1 -1
  314. package/dist/types/src/index.d.ts +3 -1
  315. package/dist/types/src/index.d.ts.map +1 -1
  316. package/dist/types/src/playground/Controls.stories.d.ts.map +1 -1
  317. package/dist/types/src/playground/Custom.stories.d.ts +1 -1
  318. package/dist/types/src/playground/Custom.stories.d.ts.map +1 -1
  319. package/dist/types/src/playground/Typography.stories.d.ts.map +1 -1
  320. package/dist/types/src/primitives/Container/Container.d.ts +7 -0
  321. package/dist/types/src/primitives/Container/Container.d.ts.map +1 -0
  322. package/dist/types/src/primitives/Container/Container.stories.d.ts +6 -0
  323. package/dist/types/src/primitives/Container/Container.stories.d.ts.map +1 -0
  324. package/dist/types/src/primitives/Container/index.d.ts +2 -0
  325. package/dist/types/src/primitives/Container/index.d.ts.map +1 -0
  326. package/dist/types/src/{components → primitives}/DensityProvider/DensityProvider.d.ts +1 -1
  327. package/dist/types/src/{components → primitives}/DensityProvider/DensityProvider.d.ts.map +1 -1
  328. package/dist/types/src/primitives/DensityProvider/index.d.ts.map +1 -0
  329. package/dist/types/src/{components → primitives}/ElevationProvider/ElevationProvider.d.ts +1 -1
  330. package/dist/types/src/{components → primitives}/ElevationProvider/ElevationProvider.d.ts.map +1 -1
  331. package/dist/types/src/primitives/ElevationProvider/index.d.ts.map +1 -0
  332. package/dist/types/src/primitives/Flex/Flex.d.ts +11 -0
  333. package/dist/types/src/primitives/Flex/Flex.d.ts.map +1 -0
  334. package/dist/types/src/primitives/Flex/Flex.stories.d.ts +8 -0
  335. package/dist/types/src/primitives/Flex/Flex.stories.d.ts.map +1 -0
  336. package/dist/types/src/primitives/Flex/index.d.ts +2 -0
  337. package/dist/types/src/primitives/Flex/index.d.ts.map +1 -0
  338. package/dist/types/src/primitives/Grid/Grid.d.ts +10 -0
  339. package/dist/types/src/primitives/Grid/Grid.d.ts.map +1 -0
  340. package/dist/types/src/primitives/Grid/Grid.stories.d.ts +8 -0
  341. package/dist/types/src/primitives/Grid/Grid.stories.d.ts.map +1 -0
  342. package/dist/types/src/primitives/Grid/index.d.ts +2 -0
  343. package/dist/types/src/primitives/Grid/index.d.ts.map +1 -0
  344. package/dist/types/src/{components → primitives}/ThemeProvider/ThemeProvider.d.ts +3 -3
  345. package/dist/types/src/primitives/ThemeProvider/ThemeProvider.d.ts.map +1 -0
  346. package/dist/types/src/{components/Menus/DropdownMenu.stories.d.ts → primitives/ThemeProvider/ThemeProvider.stories.d.ts} +2 -5
  347. package/dist/types/src/primitives/ThemeProvider/ThemeProvider.stories.d.ts.map +1 -0
  348. package/dist/types/src/primitives/ThemeProvider/TranslationsProvider.d.ts +128 -0
  349. package/dist/types/src/primitives/ThemeProvider/TranslationsProvider.d.ts.map +1 -0
  350. package/dist/types/src/primitives/ThemeProvider/index.d.ts +4 -0
  351. package/dist/types/src/primitives/ThemeProvider/index.d.ts.map +1 -0
  352. package/dist/types/src/primitives/index.d.ts +7 -0
  353. package/dist/types/src/primitives/index.d.ts.map +1 -0
  354. package/dist/types/src/testing/Loading.d.ts +9 -0
  355. package/dist/types/src/testing/Loading.d.ts.map +1 -0
  356. package/dist/types/src/testing/decorators/withLayout.d.ts +3 -3
  357. package/dist/types/src/testing/decorators/withLayout.d.ts.map +1 -1
  358. package/dist/types/src/testing/decorators/withLayoutVariants.d.ts +1 -1
  359. package/dist/types/src/testing/decorators/withLayoutVariants.d.ts.map +1 -1
  360. package/dist/types/src/testing/decorators/withTheme.d.ts +7 -2
  361. package/dist/types/src/testing/decorators/withTheme.d.ts.map +1 -1
  362. package/dist/types/src/testing/index.d.ts +1 -0
  363. package/dist/types/src/testing/index.d.ts.map +1 -1
  364. package/dist/types/src/theme/bindTheme.d.ts +3 -0
  365. package/dist/types/src/theme/bindTheme.d.ts.map +1 -0
  366. package/dist/types/src/theme/defaultTheme.d.ts +4 -0
  367. package/dist/types/src/theme/defaultTheme.d.ts.map +1 -0
  368. package/dist/types/src/theme/index.d.ts +31 -0
  369. package/dist/types/src/theme/index.d.ts.map +1 -0
  370. package/dist/types/src/translations.d.ts +25 -0
  371. package/dist/types/src/translations.d.ts.map +1 -0
  372. package/dist/types/src/util/index.d.ts +3 -3
  373. package/dist/types/src/util/index.d.ts.map +1 -1
  374. package/dist/types/src/util/mobile.d.ts +5 -0
  375. package/dist/types/src/util/mobile.d.ts.map +1 -0
  376. package/dist/types/src/util/slots.d.ts +57 -0
  377. package/dist/types/src/util/slots.d.ts.map +1 -0
  378. package/dist/types/src/util/usePx.d.ts.map +1 -1
  379. package/dist/types/tsconfig.tsbuildinfo +1 -1
  380. package/package.json +54 -40
  381. package/src/components/Avatars/Avatar.stories.tsx +7 -9
  382. package/src/components/Avatars/Avatar.theme.ts +93 -0
  383. package/src/components/Avatars/Avatar.tsx +7 -15
  384. package/src/components/Avatars/AvatarGroup.stories.tsx +2 -3
  385. package/src/components/Breadcrumb/Breadcrumb.stories.tsx +3 -4
  386. package/src/components/Breadcrumb/Breadcrumb.theme.ts +26 -0
  387. package/src/components/Breadcrumb/Breadcrumb.tsx +25 -39
  388. package/src/components/Button/Button.stories.tsx +3 -4
  389. package/src/components/Button/Button.theme.ts +31 -0
  390. package/src/components/Button/Button.tsx +13 -27
  391. package/src/components/Button/IconButton.stories.tsx +58 -8
  392. package/src/components/Button/IconButton.theme.ts +21 -0
  393. package/src/components/Button/IconButton.tsx +10 -6
  394. package/src/components/Button/Toggle.stories.tsx +2 -3
  395. package/src/components/Button/Toggle.tsx +4 -4
  396. package/src/components/Button/ToggleGroup.stories.tsx +2 -3
  397. package/src/components/Button/ToggleGroup.tsx +12 -16
  398. package/src/components/Calendar/Calendar.stories.tsx +43 -0
  399. package/src/components/Calendar/Calendar.theme.ts +74 -0
  400. package/src/components/Calendar/Calendar.tsx +196 -0
  401. package/src/components/Calendar/index.ts +5 -0
  402. package/src/components/Card/Card.stories.tsx +172 -0
  403. package/src/components/Card/Card.theme.ts +93 -0
  404. package/src/components/Card/Card.tsx +485 -0
  405. package/src/components/Card/index.ts +5 -0
  406. package/src/components/Carousel/Carousel.stories.tsx +47 -0
  407. package/src/components/Carousel/Carousel.tsx +373 -0
  408. package/src/components/Carousel/index.ts +5 -0
  409. package/src/components/Clipboard/CopyButton.tsx +10 -11
  410. package/src/components/Column/AUDIT.md +148 -0
  411. package/src/components/Column/Column.stories.tsx +181 -0
  412. package/src/components/Column/Column.theme.ts +48 -0
  413. package/src/components/Column/Column.tsx +166 -0
  414. package/src/components/Column/index.ts +6 -0
  415. package/src/components/Column/withColumn.ts +27 -0
  416. package/src/components/DatePicker/DatePicker.stories.tsx +102 -0
  417. package/src/components/DatePicker/DatePicker.theme.ts +35 -0
  418. package/src/components/DatePicker/DatePicker.tsx +279 -0
  419. package/src/components/DatePicker/index.ts +5 -0
  420. package/src/components/Dialog/AlertDialog.stories.tsx +16 -17
  421. package/src/components/Dialog/AlertDialog.tsx +122 -85
  422. package/src/components/Dialog/Dialog.stories.tsx +138 -28
  423. package/src/components/Dialog/Dialog.theme.ts +61 -0
  424. package/src/components/Dialog/Dialog.tsx +227 -72
  425. package/src/components/ErrorFallback/ErrorFallback.stories.tsx +45 -0
  426. package/src/components/ErrorFallback/ErrorFallback.tsx +76 -0
  427. package/src/components/ErrorFallback/ErrorStack.tsx +120 -0
  428. package/src/components/ErrorFallback/ThrowError.tsx +37 -0
  429. package/src/components/ErrorFallback/index.ts +9 -0
  430. package/src/components/Focus/AUDIT.md +43 -0
  431. package/src/components/Focus/Focus.stories.tsx +230 -0
  432. package/src/components/Focus/Focus.theme.ts +32 -0
  433. package/src/components/Focus/Focus.tsx +201 -0
  434. package/src/components/Focus/index.ts +5 -0
  435. package/src/components/Icon/Icon.stories.tsx +45 -15
  436. package/src/components/Icon/Icon.theme.ts +45 -0
  437. package/src/components/Icon/Icon.tsx +15 -4
  438. package/src/components/Icon/IconBlock.tsx +38 -0
  439. package/src/components/Icon/index.ts +1 -0
  440. package/src/components/Image/Image.stories.tsx +86 -0
  441. package/src/components/Image/Image.tsx +252 -0
  442. package/src/components/Image/index.ts +5 -0
  443. package/src/components/Input/Input.stories.tsx +148 -65
  444. package/src/components/Input/Input.theme.ts +191 -0
  445. package/src/components/Input/Input.tsx +245 -75
  446. package/src/components/Input/SegmentedInput.tsx +454 -0
  447. package/src/components/Input/constants.ts +5 -0
  448. package/src/components/Input/index.ts +2 -0
  449. package/src/components/Link/Link.stories.tsx +2 -3
  450. package/src/components/Link/Link.theme.ts +16 -0
  451. package/src/components/Link/Link.tsx +11 -3
  452. package/src/components/List/List.stories.tsx +31 -35
  453. package/src/components/List/List.theme.ts +47 -0
  454. package/src/components/List/List.tsx +18 -22
  455. package/src/components/List/ListDropIndicator.tsx +7 -8
  456. package/src/components/List/Tree.stories.tsx +6 -7
  457. package/src/components/List/Tree.tsx +0 -1
  458. package/src/components/List/TreeDropIndicator.tsx +6 -6
  459. package/src/components/List/Treegrid.stories.tsx +29 -30
  460. package/src/components/List/Treegrid.theme.ts +35 -0
  461. package/src/components/List/Treegrid.tsx +24 -30
  462. package/src/components/Main/Main.stories.tsx +41 -24
  463. package/src/components/Main/Main.theme.ts +29 -0
  464. package/src/components/Main/Main.tsx +146 -88
  465. package/src/components/Main/constants.ts +6 -0
  466. package/src/components/Main/index.ts +1 -0
  467. package/src/components/MediaPlayer/MediaPlayer.stories.tsx +50 -0
  468. package/src/components/MediaPlayer/MediaPlayer.tsx +182 -0
  469. package/src/components/MediaPlayer/index.ts +5 -0
  470. package/src/components/{Menus → Menu}/ContextMenu.stories.tsx +2 -6
  471. package/src/components/{Menus → Menu}/ContextMenu.tsx +9 -33
  472. package/src/components/{Menus → Menu}/DropdownMenu.stories.tsx +2 -6
  473. package/src/components/{Menus → Menu}/DropdownMenu.tsx +130 -122
  474. package/src/components/Menu/Menu.theme.ts +48 -0
  475. package/src/components/Message/Message.stories.tsx +66 -14
  476. package/src/components/Message/Message.theme.ts +44 -0
  477. package/src/components/Message/Message.tsx +107 -38
  478. package/src/components/Panel/Panel.stories.tsx +67 -0
  479. package/src/components/Panel/Panel.theme.ts +41 -0
  480. package/src/components/Panel/Panel.tsx +121 -0
  481. package/src/components/Panel/index.ts +5 -0
  482. package/src/components/Popover/Popover.stories.tsx +7 -8
  483. package/src/components/Popover/Popover.theme.ts +40 -0
  484. package/src/components/Popover/Popover.tsx +104 -99
  485. package/src/components/ScrollArea/ScrollArea.stories.tsx +221 -36
  486. package/src/components/ScrollArea/ScrollArea.theme.ts +107 -0
  487. package/src/components/ScrollArea/ScrollArea.tsx +98 -79
  488. package/src/components/ScrollArea/index.ts +2 -1
  489. package/src/components/ScrollArea/scrollbar.ts +21 -0
  490. package/src/components/ScrollContainer/ScrollContainer.stories.tsx +47 -25
  491. package/src/components/ScrollContainer/ScrollContainer.tsx +239 -123
  492. package/src/components/Select/Select.stories.tsx +7 -8
  493. package/src/components/Select/Select.theme.ts +55 -0
  494. package/src/components/Select/Select.tsx +35 -35
  495. package/src/components/Separator/Separator.theme.ts +23 -0
  496. package/src/components/Separator/Separator.tsx +5 -8
  497. package/src/components/Skeleton/Skeleton.stories.tsx +51 -0
  498. package/src/components/Skeleton/Skeleton.theme.ts +22 -0
  499. package/src/components/Skeleton/Skeleton.tsx +26 -0
  500. package/src/components/Skeleton/index.ts +5 -0
  501. package/src/components/Splitter/Splitter.stories.tsx +83 -0
  502. package/src/components/Splitter/Splitter.theme.ts +18 -0
  503. package/src/components/Splitter/Splitter.tsx +122 -0
  504. package/src/components/Splitter/index.ts +5 -0
  505. package/src/components/Status/Status.stories.tsx +21 -18
  506. package/src/components/Status/Status.theme.ts +31 -0
  507. package/src/components/Status/Status.tsx +9 -7
  508. package/src/components/Tag/Tag.stories.tsx +6 -12
  509. package/src/components/Tag/Tag.theme.ts +22 -0
  510. package/src/components/Tag/Tag.tsx +3 -8
  511. package/src/components/Toast/Toast.stories.tsx +43 -23
  512. package/src/components/Toast/Toast.theme.ts +56 -0
  513. package/src/components/Toast/Toast.tsx +103 -54
  514. package/src/components/Toolbar/Toolbar.stories.tsx +2 -3
  515. package/src/components/Toolbar/Toolbar.theme.ts +36 -0
  516. package/src/components/Toolbar/Toolbar.tsx +237 -23
  517. package/src/components/Tooltip/Tooltip.stories.tsx +20 -28
  518. package/src/components/Tooltip/Tooltip.theme.ts +19 -0
  519. package/src/components/Tooltip/Tooltip.tsx +58 -55
  520. package/src/components/Tooltip/index.ts +1 -0
  521. package/src/components/Tooltip/tooltipContent.ts +16 -0
  522. package/src/components/index.ts +14 -7
  523. package/src/exemplars/generics.stories.tsx +40 -0
  524. package/src/exemplars/slot.stories.tsx +116 -0
  525. package/src/exemplars/tabster.stories.tsx +127 -0
  526. package/src/exemplars/virtualizer.stories.tsx +136 -0
  527. package/src/hooks/index.ts +1 -0
  528. package/src/hooks/useDensityContext.ts +4 -4
  529. package/src/hooks/useElevationContext.ts +2 -2
  530. package/src/hooks/useThemeContext.ts +1 -1
  531. package/src/hooks/useTranslationsContext.ts +1 -1
  532. package/src/index.ts +3 -1
  533. package/src/playground/Controls.stories.tsx +3 -10
  534. package/src/playground/Custom.stories.tsx +18 -41
  535. package/src/playground/Typography.stories.tsx +3 -3
  536. package/src/primitives/Container/Container.stories.tsx +29 -0
  537. package/src/primitives/Container/Container.tsx +21 -0
  538. package/src/primitives/Container/index.ts +5 -0
  539. package/src/{components → primitives}/DensityProvider/DensityProvider.tsx +2 -2
  540. package/src/{components → primitives}/ElevationProvider/ElevationProvider.tsx +1 -1
  541. package/src/primitives/Flex/Flex.stories.tsx +57 -0
  542. package/src/primitives/Flex/Flex.tsx +29 -0
  543. package/src/primitives/Flex/index.ts +5 -0
  544. package/src/primitives/Grid/Grid.stories.tsx +56 -0
  545. package/src/primitives/Grid/Grid.tsx +32 -0
  546. package/src/primitives/Grid/index.ts +5 -0
  547. package/src/primitives/ThemeProvider/ThemeProvider.stories.tsx +31 -0
  548. package/src/{components → primitives}/ThemeProvider/ThemeProvider.tsx +11 -11
  549. package/src/{components → primitives}/ThemeProvider/TranslationsProvider.tsx +1 -16
  550. package/src/primitives/ThemeProvider/index.ts +8 -0
  551. package/src/primitives/index.ts +11 -0
  552. package/src/testing/Loading.tsx +47 -0
  553. package/src/testing/decorators/withLayout.tsx +32 -21
  554. package/src/testing/decorators/withLayoutVariants.tsx +21 -24
  555. package/src/testing/decorators/withTheme.tsx +34 -20
  556. package/src/testing/index.ts +2 -0
  557. package/src/theme/bindTheme.ts +13 -0
  558. package/src/theme/defaultTheme.ts +83 -0
  559. package/src/theme/index.ts +37 -0
  560. package/src/translations.ts +33 -0
  561. package/src/util/index.ts +4 -3
  562. package/src/util/mobile.ts +11 -0
  563. package/src/util/slots.ts +129 -0
  564. package/src/util/usePx.ts +5 -1
  565. package/dist/lib/browser/chunk-N5GDJTT2.mjs +0 -4707
  566. package/dist/lib/browser/chunk-N5GDJTT2.mjs.map +0 -7
  567. package/dist/lib/node-esm/chunk-SP7VQH72.mjs +0 -4709
  568. package/dist/lib/node-esm/chunk-SP7VQH72.mjs.map +0 -7
  569. package/dist/types/src/components/AnchoredOverflow/AnchoredOverflow.d.ts +0 -15
  570. package/dist/types/src/components/AnchoredOverflow/AnchoredOverflow.d.ts.map +0 -1
  571. package/dist/types/src/components/AnchoredOverflow/index.d.ts +0 -2
  572. package/dist/types/src/components/AnchoredOverflow/index.d.ts.map +0 -1
  573. package/dist/types/src/components/DensityProvider/index.d.ts.map +0 -1
  574. package/dist/types/src/components/ElevationProvider/index.d.ts.map +0 -1
  575. package/dist/types/src/components/Menus/ContextMenu.d.ts.map +0 -1
  576. package/dist/types/src/components/Menus/ContextMenu.stories.d.ts.map +0 -1
  577. package/dist/types/src/components/Menus/DropdownMenu.d.ts +0 -112
  578. package/dist/types/src/components/Menus/DropdownMenu.d.ts.map +0 -1
  579. package/dist/types/src/components/Menus/DropdownMenu.stories.d.ts.map +0 -1
  580. package/dist/types/src/components/Menus/index.d.ts.map +0 -1
  581. package/dist/types/src/components/ThemeProvider/ThemeProvider.d.ts.map +0 -1
  582. package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts +0 -136
  583. package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts.map +0 -1
  584. package/dist/types/src/components/ThemeProvider/index.d.ts +0 -3
  585. package/dist/types/src/components/ThemeProvider/index.d.ts.map +0 -1
  586. package/dist/types/src/util/ThemedClassName.d.ts +0 -5
  587. package/dist/types/src/util/ThemedClassName.d.ts.map +0 -1
  588. package/dist/types/src/util/domino.d.ts +0 -18
  589. package/dist/types/src/util/domino.d.ts.map +0 -1
  590. package/dist/types/src/util/hasIosKeyboard.d.ts +0 -2
  591. package/dist/types/src/util/hasIosKeyboard.d.ts.map +0 -1
  592. package/src/components/AnchoredOverflow/AnchoredOverflow.tsx +0 -59
  593. package/src/components/AnchoredOverflow/index.ts +0 -5
  594. package/src/components/ThemeProvider/index.ts +0 -8
  595. package/src/util/ThemedClassName.ts +0 -7
  596. package/src/util/domino.ts +0 -53
  597. package/src/util/hasIosKeyboard.ts +0 -8
  598. /package/dist/types/src/components/{Menus → Menu}/ContextMenu.stories.d.ts +0 -0
  599. /package/dist/types/src/components/{Menus → Menu}/index.d.ts +0 -0
  600. /package/dist/types/src/{components → primitives}/DensityProvider/index.d.ts +0 -0
  601. /package/dist/types/src/{components → primitives}/ElevationProvider/index.d.ts +0 -0
  602. /package/src/components/{Menus → Menu}/index.ts +0 -0
  603. /package/src/{components → primitives}/DensityProvider/index.ts +0 -0
  604. /package/src/{components → primitives}/ElevationProvider/index.ts +0 -0
@@ -0,0 +1,279 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ import { createContext } from '@radix-ui/react-context';
6
+ import { format as formatDate } from 'date-fns';
7
+ import React, {
8
+ type ComponentPropsWithoutRef,
9
+ type PropsWithChildren,
10
+ type ReactNode,
11
+ forwardRef,
12
+ useCallback,
13
+ useState,
14
+ } from 'react';
15
+
16
+ import { useThemeContext } from '../../hooks';
17
+ import { useTranslation } from '../../primitives';
18
+ import { translationKey } from '../../translations';
19
+ import { type ThemedClassName } from '../../util';
20
+ import { Calendar, type DateRange } from '../Calendar';
21
+ import { Icon } from '../Icon';
22
+ import { Popover } from '../Popover';
23
+
24
+ //
25
+ // Public API.
26
+ //
27
+ // Wraps the new react-aria-components-backed `<Calendar>` (single + range) in a Radix Popover,
28
+ // preserving the previous slot-style namespace: `<DatePicker.Root>`, `<DatePicker.Trigger>`,
29
+ // `<DatePicker.Content>`, `<DatePicker.Calendar>`. Multi-select is no longer supported (no
30
+ // in-repo consumers); use `<Calendar.Root>` directly with custom state if needed.
31
+ //
32
+
33
+ export type DatePickerMode = 'single' | 'range';
34
+
35
+ type ValueByMode = {
36
+ single: Date | undefined;
37
+ range: DateRange | undefined;
38
+ };
39
+
40
+ type DatePickerContextValue = {
41
+ mode: DatePickerMode;
42
+ value: ValueByMode[DatePickerMode];
43
+ setValue: (next: ValueByMode[DatePickerMode]) => void;
44
+ withTime: boolean;
45
+ open: boolean;
46
+ onOpenChange: (open: boolean) => void;
47
+ };
48
+
49
+ const [DatePickerProvider, useDatePickerContext] = createContext<DatePickerContextValue>('DatePicker');
50
+
51
+ //
52
+ // Root.
53
+ //
54
+
55
+ export type DatePickerRootProps<M extends DatePickerMode = 'single'> = {
56
+ mode?: M;
57
+ value?: ValueByMode[M];
58
+ defaultValue?: ValueByMode[M];
59
+ onValueChange?: (value: ValueByMode[M]) => void;
60
+ /** Preserve hour/minute on the selected date(s) when picking a new day. */
61
+ withTime?: boolean;
62
+ open?: boolean;
63
+ defaultOpen?: boolean;
64
+ onOpenChange?: (open: boolean) => void;
65
+ children?: ReactNode;
66
+ };
67
+
68
+ const DatePickerRoot = <M extends DatePickerMode = 'single'>({
69
+ mode = 'single' as M,
70
+ value,
71
+ defaultValue,
72
+ onValueChange,
73
+ withTime = false,
74
+ open,
75
+ defaultOpen,
76
+ onOpenChange,
77
+ children,
78
+ }: DatePickerRootProps<M>) => {
79
+ const [internalValue, setInternalValue] = useState<ValueByMode[M] | undefined>(defaultValue);
80
+ const [internalOpen, setInternalOpen] = useState(defaultOpen ?? false);
81
+
82
+ const controlled = value !== undefined || onValueChange !== undefined;
83
+ const resolvedValue = (controlled ? value : internalValue) as ValueByMode[DatePickerMode];
84
+
85
+ const setValue = useCallback(
86
+ (next: ValueByMode[DatePickerMode]) => {
87
+ if (!controlled) {
88
+ setInternalValue(next as ValueByMode[M] | undefined);
89
+ }
90
+ onValueChange?.(next as ValueByMode[M]);
91
+ },
92
+ [controlled, onValueChange],
93
+ );
94
+
95
+ const resolvedOpen = open ?? internalOpen;
96
+ const handleOpenChange = useCallback(
97
+ (next: boolean) => {
98
+ if (open === undefined) {
99
+ setInternalOpen(next);
100
+ }
101
+ onOpenChange?.(next);
102
+ },
103
+ [open, onOpenChange],
104
+ );
105
+
106
+ return (
107
+ <DatePickerProvider
108
+ mode={mode as DatePickerMode}
109
+ value={resolvedValue}
110
+ setValue={setValue}
111
+ withTime={withTime}
112
+ open={resolvedOpen}
113
+ onOpenChange={handleOpenChange}
114
+ >
115
+ <Popover.Root open={resolvedOpen} onOpenChange={handleOpenChange}>
116
+ {children}
117
+ </Popover.Root>
118
+ </DatePickerProvider>
119
+ );
120
+ };
121
+
122
+ //
123
+ // Trigger.
124
+ //
125
+
126
+ const formatValue = (mode: DatePickerMode, value: unknown, fmt: string): string | undefined => {
127
+ if (value === undefined || value === null) {
128
+ return undefined;
129
+ }
130
+ switch (mode) {
131
+ case 'single':
132
+ return formatDate(value as Date, fmt);
133
+ case 'range': {
134
+ const r = value as DateRange;
135
+ if (!r.from) {
136
+ return undefined;
137
+ }
138
+ return r.to ? `${formatDate(r.from, fmt)} – ${formatDate(r.to, fmt)}` : formatDate(r.from, fmt);
139
+ }
140
+ }
141
+ };
142
+
143
+ export type DatePickerTriggerProps = ThemedClassName<Omit<ComponentPropsWithoutRef<'button'>, 'children'>> &
144
+ PropsWithChildren<{
145
+ format?: string;
146
+ placeholder?: string;
147
+ /** Show the leading calendar icon in the default trigger. Defaults to true. */
148
+ icon?: boolean;
149
+ }>;
150
+
151
+ const DatePickerTrigger = forwardRef<HTMLButtonElement, DatePickerTriggerProps>(
152
+ ({ classNames, format: fmt = 'PPP', placeholder, icon = true, children, ...props }, forwardedRef) => {
153
+ const { tx } = useThemeContext();
154
+ const { t } = useTranslation(translationKey);
155
+ const { mode, value } = useDatePickerContext('DatePickerTrigger');
156
+
157
+ const placeholderText = placeholder ?? (t(`date-picker.placeholder.${mode}.label`) as string);
158
+ const label = formatValue(mode, value, fmt) ?? placeholderText;
159
+ const hasValue = label !== placeholderText;
160
+
161
+ return (
162
+ <Popover.Trigger asChild>
163
+ <button
164
+ ref={forwardedRef}
165
+ type='button'
166
+ {...props}
167
+ className={tx('datePicker.trigger', { hasValue }, classNames) ?? undefined}
168
+ >
169
+ {children ?? (
170
+ <>
171
+ {icon && <Icon size={4} icon='ph--calendar--regular' />}
172
+ {label}
173
+ </>
174
+ )}
175
+ </button>
176
+ </Popover.Trigger>
177
+ );
178
+ },
179
+ );
180
+
181
+ DatePickerTrigger.displayName = 'DatePickerTrigger';
182
+
183
+ //
184
+ // Content.
185
+ //
186
+
187
+ export type DatePickerContentProps = ThemedClassName<ComponentPropsWithoutRef<typeof Popover.Content>>;
188
+
189
+ const DatePickerContent = forwardRef<HTMLDivElement, DatePickerContentProps>(
190
+ ({ classNames, children, ...props }, forwardedRef) => {
191
+ const { tx } = useThemeContext();
192
+ return (
193
+ <Popover.Portal>
194
+ <Popover.Content ref={forwardedRef} align='start' sideOffset={4} {...props}>
195
+ <div className={tx('datePicker.content', {}, classNames)}>{children}</div>
196
+ </Popover.Content>
197
+ </Popover.Portal>
198
+ );
199
+ },
200
+ );
201
+
202
+ DatePickerContent.displayName = 'DatePickerContent';
203
+
204
+ //
205
+ // Calendar — single or range, time-of-day preservation, auto-dismiss on completion.
206
+ //
207
+
208
+ const carryTime = (oldDate: Date | undefined, newDate: Date | undefined): Date | undefined => {
209
+ if (!newDate) {
210
+ return newDate;
211
+ }
212
+ if (!oldDate) {
213
+ return newDate;
214
+ }
215
+ const out = new Date(newDate);
216
+ out.setHours(oldDate.getHours(), oldDate.getMinutes(), 0, 0);
217
+ return out;
218
+ };
219
+
220
+ const DatePickerCalendar = ({ classNames }: { classNames?: string } = {}) => {
221
+ const { mode, value, setValue, withTime, onOpenChange } = useDatePickerContext('DatePickerCalendar');
222
+
223
+ if (mode === 'single') {
224
+ const date = value as Date | undefined;
225
+ return (
226
+ <Calendar.Root
227
+ mode='single'
228
+ classNames={classNames}
229
+ selected={date}
230
+ onSelect={(next) => {
231
+ const merged = withTime ? carryTime(date, next) : next;
232
+ setValue(merged);
233
+ if (next !== undefined) {
234
+ onOpenChange(false);
235
+ }
236
+ }}
237
+ />
238
+ );
239
+ }
240
+
241
+ const range = value as DateRange | undefined;
242
+ return (
243
+ <Calendar.Root
244
+ mode='range'
245
+ classNames={classNames}
246
+ selected={range}
247
+ onSelect={(next) => {
248
+ if (!next) {
249
+ setValue(undefined);
250
+ return;
251
+ }
252
+ const merged: DateRange = withTime
253
+ ? { from: carryTime(range?.from, next.from)!, to: carryTime(range?.to, next.to) }
254
+ : next;
255
+ setValue(merged);
256
+ if (merged.from && merged.to) {
257
+ onOpenChange(false);
258
+ }
259
+ }}
260
+ />
261
+ );
262
+ };
263
+
264
+ DatePickerCalendar.displayName = 'DatePickerCalendar';
265
+
266
+ //
267
+ // Public namespace.
268
+ //
269
+
270
+ export const DatePicker = {
271
+ Root: DatePickerRoot,
272
+ Trigger: DatePickerTrigger,
273
+ Content: DatePickerContent,
274
+ Calendar: DatePickerCalendar,
275
+ };
276
+
277
+ export { useDatePickerContext };
278
+
279
+ export type { ValueByMode };
@@ -0,0 +1,5 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ export * from './DatePicker';
@@ -5,22 +5,21 @@
5
5
  import { type Meta, type StoryObj } from '@storybook/react-vite';
6
6
  import React from 'react';
7
7
 
8
+ import { random } from '@dxos/random';
9
+
8
10
  import { withTheme } from '../../testing';
9
11
  import { Button } from '../Button';
10
- import { Toolbar } from '../Toolbar';
11
-
12
12
  import { AlertDialog } from './AlertDialog';
13
13
 
14
- type StoryProps = Partial<{
14
+ type DefaultStoryProps = Partial<{
15
15
  title: string;
16
16
  description: string;
17
- body: string;
18
17
  openTrigger: string;
19
18
  cancelTrigger: string;
20
19
  actionTrigger: string;
21
20
  }>;
22
21
 
23
- const DefaultStory = ({ title, description, body, openTrigger, cancelTrigger, actionTrigger }: StoryProps) => {
22
+ const DefaultStory = ({ title, description, openTrigger, cancelTrigger, actionTrigger }: DefaultStoryProps) => {
24
23
  return (
25
24
  <AlertDialog.Root defaultOpen>
26
25
  <AlertDialog.Trigger asChild>
@@ -28,18 +27,19 @@ const DefaultStory = ({ title, description, body, openTrigger, cancelTrigger, ac
28
27
  </AlertDialog.Trigger>
29
28
  <AlertDialog.Overlay>
30
29
  <AlertDialog.Content>
31
- <AlertDialog.Title>{title}</AlertDialog.Title>
32
- <AlertDialog.Description>{description}</AlertDialog.Description>
33
- <p className='mbs-2 mbe-8'>{body}</p>
34
- <Toolbar.Root>
30
+ <AlertDialog.Body>
31
+ <AlertDialog.Title>{title}</AlertDialog.Title>
32
+ <AlertDialog.Description>{description}</AlertDialog.Description>
33
+ </AlertDialog.Body>
34
+ <AlertDialog.ActionBar>
35
35
  <div className='grow' />
36
36
  <AlertDialog.Cancel asChild>
37
- <Toolbar.Button>{cancelTrigger}</Toolbar.Button>
37
+ <Button>{cancelTrigger}</Button>
38
38
  </AlertDialog.Cancel>
39
39
  <AlertDialog.Action asChild>
40
- <Toolbar.Button variant='primary'>{actionTrigger}</Toolbar.Button>
40
+ <Button variant='primary'>{actionTrigger}</Button>
41
41
  </AlertDialog.Action>
42
- </Toolbar.Root>
42
+ </AlertDialog.ActionBar>
43
43
  </AlertDialog.Content>
44
44
  </AlertDialog.Overlay>
45
45
  </AlertDialog.Root>
@@ -47,10 +47,10 @@ const DefaultStory = ({ title, description, body, openTrigger, cancelTrigger, ac
47
47
  };
48
48
 
49
49
  const meta = {
50
- title: 'ui/react-ui-core/AlertDialog',
50
+ title: 'ui/react-ui-core/components/AlertDialog',
51
51
  component: AlertDialog.Root as any,
52
52
  render: DefaultStory as any,
53
- decorators: [withTheme],
53
+ decorators: [withTheme()],
54
54
  } satisfies Meta<typeof DefaultStory>;
55
55
 
56
56
  export default meta;
@@ -59,10 +59,9 @@ type Story = StoryObj<typeof meta>;
59
59
 
60
60
  export const Default: Story = {
61
61
  args: {
62
- title: 'AlertDialog title',
62
+ title: random.lorem.sentence(3),
63
+ description: random.lorem.paragraph(1),
63
64
  openTrigger: 'Open AlertDialog',
64
- description: 'AlertDialog description',
65
- body: 'Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.',
66
65
  cancelTrigger: 'Cancel',
67
66
  actionTrigger: 'Action',
68
67
  },
@@ -2,102 +2,88 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import {
6
- AlertDialogAction as AlertDialogActionPrimitive,
7
- type AlertDialogActionProps as AlertDialogActionPrimitiveProps,
8
- AlertDialogCancel as AlertDialogCancelPrimitive,
9
- type AlertDialogCancelProps as AlertDialogCancelPrimitiveProps,
10
- AlertDialogContent as AlertDialogContentPrimitive,
11
- type AlertDialogContentProps as AlertDialogContentPrimitiveProps,
12
- AlertDialogDescription as AlertDialogDescriptionPrimitive,
13
- type AlertDialogDescriptionProps as AlertDialogDescriptionPrimitiveProps,
14
- AlertDialogOverlay as AlertDialogOverlayPrimitive,
15
- type AlertDialogOverlayProps as AlertDialogOverlayPrimitiveProps,
16
- AlertDialogPortal as AlertDialogPortalPrimitive,
17
- type AlertDialogPortalProps as AlertDialogPortalPrimitiveProps,
18
- Root as AlertDialogRootPrimitive,
19
- type AlertDialogProps as AlertDialogRootPrimitiveProps,
20
- AlertDialogTitle as AlertDialogTitlePrimitive,
21
- type AlertDialogTitleProps as AlertDialogTitlePrimitiveProps,
22
- AlertDialogTrigger as AlertDialogTriggerPrimitive,
23
- type AlertDialogTriggerProps as AlertDialogTriggerPrimitiveProps,
24
- } from '@radix-ui/react-alert-dialog';
5
+ import * as AlertDialogPrimitive from '@radix-ui/react-alert-dialog';
25
6
  import { createContext } from '@radix-ui/react-context';
26
7
  import React, { type ForwardRefExoticComponent, type FunctionComponent, forwardRef } from 'react';
27
8
 
28
9
  import { useThemeContext } from '../../hooks';
10
+ import { ElevationProvider } from '../../primitives';
11
+ import { type DialogSize } from '../../theme';
29
12
  import { type ThemedClassName } from '../../util';
30
- import { ElevationProvider } from '../ElevationProvider';
13
+ import { Column } from '../Column';
14
+ import {
15
+ Dialog,
16
+ type DialogHeaderProps,
17
+ type DialogBodyProps,
18
+ type DialogActionBarProps,
19
+ type DialogActionIconButtonProps,
20
+ } from './Dialog';
21
+
22
+ //
23
+ // Root
24
+ //
31
25
 
32
- type AlertDialogRootProps = AlertDialogRootPrimitiveProps;
26
+ type AlertDialogRootProps = AlertDialogPrimitive.AlertDialogProps;
33
27
 
34
28
  const AlertDialogRoot: FunctionComponent<AlertDialogRootProps> = (props) => (
35
29
  <ElevationProvider elevation='dialog'>
36
- <AlertDialogRootPrimitive {...props} />
30
+ <AlertDialogPrimitive.Root {...props} />
37
31
  </ElevationProvider>
38
32
  );
39
33
 
40
- type AlertDialogTriggerProps = AlertDialogTriggerPrimitiveProps;
34
+ //
35
+ // Trigger
36
+ //
41
37
 
42
- const AlertDialogTrigger: FunctionComponent<AlertDialogTriggerProps> = AlertDialogTriggerPrimitive;
38
+ type AlertDialogTriggerProps = AlertDialogPrimitive.AlertDialogTriggerProps;
43
39
 
44
- type AlertDialogPortalProps = AlertDialogPortalPrimitiveProps;
40
+ const AlertDialogTrigger = AlertDialogPrimitive.Trigger;
45
41
 
46
- const AlertDialogPortal: FunctionComponent<AlertDialogPortalProps> = AlertDialogPortalPrimitive;
42
+ //
43
+ // Portal
44
+ //
47
45
 
48
- type AlertDialogCancelProps = AlertDialogCancelPrimitiveProps;
46
+ type AlertDialogPortalProps = AlertDialogPrimitive.AlertDialogPortalProps;
49
47
 
50
- const AlertDialogCancel: FunctionComponent<AlertDialogCancelProps> = AlertDialogCancelPrimitive;
48
+ const AlertDialogPortal = AlertDialogPrimitive.Portal;
51
49
 
52
- type AlertDialogActionProps = AlertDialogActionPrimitiveProps;
50
+ //
51
+ // Cancel
52
+ //
53
53
 
54
- const AlertDialogAction: FunctionComponent<AlertDialogActionProps> = AlertDialogActionPrimitive;
54
+ type AlertDialogCancelProps = AlertDialogPrimitive.AlertDialogCancelProps;
55
55
 
56
- type AlertDialogTitleProps = ThemedClassName<AlertDialogTitlePrimitiveProps> & { srOnly?: boolean };
56
+ const AlertDialogCancel = AlertDialogPrimitive.Cancel;
57
57
 
58
- const AlertDialogTitle: ForwardRefExoticComponent<AlertDialogTitleProps> = forwardRef<
59
- HTMLHeadingElement,
60
- AlertDialogTitleProps
61
- >(({ classNames, srOnly, ...props }, forwardedRef) => {
62
- const { tx } = useThemeContext();
63
- return (
64
- <AlertDialogTitlePrimitive
65
- {...props}
66
- className={tx('dialog.title', 'dialog--alert__title', { srOnly }, classNames)}
67
- ref={forwardedRef}
68
- />
69
- );
70
- });
58
+ //
59
+ // Action
60
+ //
71
61
 
72
- type AlertDialogDescriptionProps = ThemedClassName<AlertDialogDescriptionPrimitiveProps> & { srOnly?: boolean };
62
+ type AlertDialogActionProps = AlertDialogPrimitive.AlertDialogActionProps;
73
63
 
74
- const AlertDialogDescription: ForwardRefExoticComponent<AlertDialogTitleProps> = forwardRef<
75
- HTMLParagraphElement,
76
- AlertDialogDescriptionProps
77
- >(({ classNames, srOnly, ...props }, forwardedRef) => {
78
- const { tx } = useThemeContext();
79
- return (
80
- <AlertDialogDescriptionPrimitive
81
- {...props}
82
- className={tx('dialog.description', 'dialog--alert__description', { srOnly }, classNames)}
83
- ref={forwardedRef}
84
- />
85
- );
86
- });
64
+ const AlertDialogAction = AlertDialogPrimitive.Action;
65
+
66
+ //
67
+ // Context
68
+ //
87
69
 
88
70
  type OverlayLayoutContextValue = { inOverlayLayout?: boolean };
89
- const ALERT_DIALOG_OVERLAY_NAME = 'AlertDialogOverlay';
90
- const ALERT_DIALOG_CONTENT_NAME = 'AlertDialogContent';
71
+
72
+ const ALERT_DIALOG_OVERLAY_NAME = 'AlertDialog.Overlay';
73
+ const ALERT_DIALOG_CONTENT_NAME = 'AlertDialog.Content';
74
+
91
75
  const [OverlayLayoutProvider, useOverlayLayoutContext] = createContext<OverlayLayoutContextValue>(
92
76
  ALERT_DIALOG_OVERLAY_NAME,
93
- {
94
- inOverlayLayout: false,
95
- },
77
+ { inOverlayLayout: false },
96
78
  );
97
79
 
98
- type AlertDialogOverlayProps = ThemedClassName<AlertDialogOverlayPrimitiveProps> & {
99
- blockAlign?: 'center' | 'start' | 'end';
100
- };
80
+ //
81
+ // Overlay
82
+ //
83
+
84
+ type AlertDialogOverlayProps = ThemedClassName<
85
+ AlertDialogPrimitive.AlertDialogOverlayProps & { blockAlign?: 'center' | 'start' | 'end' }
86
+ >;
101
87
 
102
88
  const AlertDialogOverlay: ForwardRefExoticComponent<AlertDialogOverlayProps> = forwardRef<
103
89
  HTMLDivElement,
@@ -105,56 +91,102 @@ const AlertDialogOverlay: ForwardRefExoticComponent<AlertDialogOverlayProps> = f
105
91
  >(({ classNames, children, blockAlign, ...props }, forwardedRef) => {
106
92
  const { tx } = useThemeContext();
107
93
  return (
108
- <AlertDialogOverlayPrimitive
94
+ <AlertDialogPrimitive.Overlay
109
95
  {...props}
110
- className={tx(
111
- 'dialog.overlay',
112
- 'dialog--alert__overlay',
113
- {},
114
- classNames,
115
- 'data-[block-align=start]:justify-center',
116
- 'data-[block-align=start]:items-start',
117
- 'data-[block-align=center]:place-content-center',
118
- )}
119
- ref={forwardedRef}
120
96
  data-block-align={blockAlign}
97
+ className={tx('dialog.overlay', {}, classNames)}
98
+ ref={forwardedRef}
121
99
  >
122
100
  <OverlayLayoutProvider inOverlayLayout>{children}</OverlayLayoutProvider>
123
- </AlertDialogOverlayPrimitive>
101
+ </AlertDialogPrimitive.Overlay>
124
102
  );
125
103
  });
126
104
 
127
105
  AlertDialogOverlay.displayName = ALERT_DIALOG_OVERLAY_NAME;
128
106
 
129
- type AlertDialogContentProps = ThemedClassName<AlertDialogContentPrimitiveProps>;
107
+ //
108
+ // Content
109
+ //
110
+
111
+ type AlertDialogContentProps = ThemedClassName<AlertDialogPrimitive.AlertDialogContentProps> & { size?: DialogSize };
130
112
 
131
113
  const AlertDialogContent: ForwardRefExoticComponent<AlertDialogContentProps> = forwardRef<
132
114
  HTMLDivElement,
133
115
  AlertDialogContentProps
134
- >(({ classNames, children, ...props }, forwardedRef) => {
116
+ >(({ classNames, children, size = 'md', ...props }, forwardedRef) => {
135
117
  const { tx } = useThemeContext();
136
118
  const { inOverlayLayout } = useOverlayLayoutContext(ALERT_DIALOG_CONTENT_NAME);
137
119
  return (
138
- <AlertDialogContentPrimitive
120
+ <AlertDialogPrimitive.Content
139
121
  {...props}
140
- className={tx('dialog.content', 'dialog--alert', { inOverlayLayout }, classNames)}
122
+ className={tx('dialog.content', { inOverlayLayout, size }, classNames)}
141
123
  ref={forwardedRef}
142
124
  >
143
- {children}
144
- </AlertDialogContentPrimitive>
125
+ <Column.Root classNames='dx-expander' gutter='sm'>
126
+ {children}
127
+ </Column.Root>
128
+ </AlertDialogPrimitive.Content>
145
129
  );
146
130
  });
147
131
 
148
132
  AlertDialogContent.displayName = ALERT_DIALOG_CONTENT_NAME;
149
133
 
134
+ //
135
+ // Title
136
+ //
137
+
138
+ type AlertDialogTitleProps = ThemedClassName<AlertDialogPrimitive.AlertDialogTitleProps> & { srOnly?: boolean };
139
+
140
+ const AlertDialogTitle: ForwardRefExoticComponent<AlertDialogTitleProps> = forwardRef<
141
+ HTMLHeadingElement,
142
+ AlertDialogTitleProps
143
+ >(({ classNames, srOnly, ...props }, forwardedRef) => {
144
+ const { tx } = useThemeContext();
145
+ return (
146
+ <AlertDialogPrimitive.Title {...props} className={tx('dialog.title', { srOnly }, classNames)} ref={forwardedRef} />
147
+ );
148
+ });
149
+
150
+ //
151
+ // Description
152
+ //
153
+
154
+ type AlertDialogDescriptionProps = ThemedClassName<AlertDialogPrimitive.AlertDialogDescriptionProps> & {
155
+ srOnly?: boolean;
156
+ };
157
+
158
+ const AlertDialogDescription: ForwardRefExoticComponent<AlertDialogDescriptionProps> = forwardRef<
159
+ HTMLParagraphElement,
160
+ AlertDialogDescriptionProps
161
+ >(({ classNames, srOnly, ...props }, forwardedRef) => {
162
+ const { tx } = useThemeContext();
163
+ return (
164
+ <AlertDialogPrimitive.Description
165
+ {...props}
166
+ className={tx('dialog.description', { srOnly }, classNames)}
167
+ ref={forwardedRef}
168
+ />
169
+ );
170
+ });
171
+
172
+ //
173
+ // AlertDialog
174
+ //
175
+
150
176
  export const AlertDialog = {
151
177
  Root: AlertDialogRoot,
152
178
  Trigger: AlertDialogTrigger,
153
179
  Portal: AlertDialogPortal,
154
180
  Overlay: AlertDialogOverlay,
155
181
  Content: AlertDialogContent,
182
+ // Shared with Dialog.
183
+ Header: Dialog.Header,
184
+ Body: Dialog.Body,
156
185
  Title: AlertDialogTitle,
157
186
  Description: AlertDialogDescription,
187
+ ActionBar: Dialog.ActionBar,
188
+ ActionIconButton: Dialog.ActionIconButton,
189
+ // AlertDialog-specific dismissal.
158
190
  Cancel: AlertDialogCancel,
159
191
  Action: AlertDialogAction,
160
192
  };
@@ -169,4 +201,9 @@ export type {
169
201
  AlertDialogDescriptionProps,
170
202
  AlertDialogCancelProps,
171
203
  AlertDialogActionProps,
204
+ // Re-export shared types.
205
+ DialogHeaderProps as AlertDialogHeaderProps,
206
+ DialogBodyProps as AlertDialogBodyProps,
207
+ DialogActionBarProps as AlertDialogActionBarProps,
208
+ DialogActionIconButtonProps as AlertDialogActionIconButtonProps,
172
209
  };