@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
@@ -0,0 +1,371 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ import { useArrowNavigationGroup } from '@fluentui/react-tabster';
6
+ import React, {
7
+ createContext,
8
+ type KeyboardEvent,
9
+ type PropsWithChildren,
10
+ type ReactNode,
11
+ useCallback,
12
+ useContext,
13
+ useEffect,
14
+ useMemo,
15
+ useState,
16
+ } from 'react';
17
+
18
+ import { mx } from '@dxos/ui-theme';
19
+
20
+ import { useTranslation } from '../../primitives';
21
+ import { translationKey } from '../../translations';
22
+ import { type ThemedClassName } from '../../util';
23
+ import { IconButton } from '../Button';
24
+ import { MediaPlayer, type MediaKind } from '../MediaPlayer';
25
+
26
+ // TODO(burdon): Move per-element class strings to `@dxos/ui-theme` (theme tokens)
27
+ // so callers can re-theme via the same mechanism the rest of `react-ui` uses.
28
+
29
+ //
30
+ // Context
31
+ //
32
+
33
+ type CarouselContextValue = {
34
+ index: number;
35
+ count: number;
36
+ setIndex: (index: number) => void;
37
+ next: () => void;
38
+ prev: () => void;
39
+ };
40
+
41
+ const CarouselContext = createContext<CarouselContextValue | null>(null);
42
+
43
+ /** Returns the current carousel state. Must be used within {@link Carousel.Root}. */
44
+ export const useCarousel = (): CarouselContextValue => {
45
+ const context = useContext(CarouselContext);
46
+ if (!context) {
47
+ throw new Error('useCarousel must be used within Carousel.Root');
48
+ }
49
+ return context;
50
+ };
51
+
52
+ //
53
+ // Root
54
+ //
55
+
56
+ export type CarouselRootProps = ThemedClassName<
57
+ PropsWithChildren<{
58
+ /** Total number of slides; drives auto-advance and indicator counts. */
59
+ count: number;
60
+ /** Whether to auto-advance slides on mount. Defaults to `false`. */
61
+ autorun?: boolean;
62
+ /** Auto-advance interval in milliseconds. Set 0 to disable. */
63
+ intervalMs?: number;
64
+ defaultIndex?: number;
65
+ }>
66
+ >;
67
+
68
+ const CarouselRoot = ({
69
+ classNames,
70
+ children,
71
+ count,
72
+ autorun = false,
73
+ intervalMs = 5_000,
74
+ defaultIndex = 0,
75
+ }: CarouselRootProps) => {
76
+ const [index, setIndexState] = useState(defaultIndex);
77
+ const [autoAdvance, setAutoAdvance] = useState(autorun);
78
+
79
+ // Reset to first slide if the slide count shrinks below the current index.
80
+ useEffect(() => {
81
+ if (index >= count) {
82
+ setIndexState(0);
83
+ }
84
+ }, [count, index]);
85
+
86
+ // Auto-advance — stops permanently once the user interacts with any control.
87
+ useEffect(() => {
88
+ if (!autoAdvance || count <= 1 || intervalMs <= 0) {
89
+ return;
90
+ }
91
+ const handle = setInterval(() => setIndexState((i) => (i + 1) % count), intervalMs);
92
+ return () => clearInterval(handle);
93
+ }, [autoAdvance, count, intervalMs]);
94
+
95
+ const setIndex = useCallback((next: number) => {
96
+ setAutoAdvance(false);
97
+ setIndexState(next);
98
+ }, []);
99
+ const next = useCallback(() => {
100
+ setAutoAdvance(false);
101
+ setIndexState((i) => (i + 1) % count);
102
+ }, [count]);
103
+ const prev = useCallback(() => {
104
+ setAutoAdvance(false);
105
+ setIndexState((i) => (i - 1 + count) % count);
106
+ }, [count]);
107
+
108
+ const value = useMemo(() => ({ index, count, setIndex, next, prev }), [index, count, setIndex, next, prev]);
109
+
110
+ if (count === 0) {
111
+ return null;
112
+ }
113
+
114
+ return (
115
+ <CarouselContext.Provider value={value}>
116
+ {/*
117
+ * Rows are `[1fr, auto]`: row 1 (Previous|Viewport|Next) stretches when the parent
118
+ * gives the carousel a definite height, and row 2 (Indicators / Caption) sticks to
119
+ * its content height. With no parent height constraint, the `1fr` row simply tracks
120
+ * row-1 content — preserving the existing aspect-video behaviour for unbounded use.
121
+ */}
122
+ {/* TODO(burdon): Move to ui-theme. */}
123
+ <div
124
+ className={mx(
125
+ 'w-full grid grid-cols-[min-content_1fr_min-content] grid-rows-[minmax(0,1fr)_auto] gap-4 items-center',
126
+ classNames,
127
+ )}
128
+ >
129
+ {children}
130
+ </div>
131
+ </CarouselContext.Provider>
132
+ );
133
+ };
134
+
135
+ CarouselRoot.displayName = 'Carousel.Root';
136
+
137
+ //
138
+ // Viewport
139
+ //
140
+
141
+ export type CarouselViewportProps = ThemedClassName<PropsWithChildren<{}>>;
142
+
143
+ const CarouselViewport = ({ children, classNames }: CarouselViewportProps) => {
144
+ const { t } = useTranslation(translationKey);
145
+ const { count, next, prev } = useCarousel();
146
+ const handleKeyDown = useCallback(
147
+ (event: KeyboardEvent<HTMLDivElement>) => {
148
+ if (count <= 1) {
149
+ return;
150
+ }
151
+ if (event.key === 'ArrowLeft') {
152
+ event.preventDefault();
153
+ prev();
154
+ } else if (event.key === 'ArrowRight') {
155
+ event.preventDefault();
156
+ next();
157
+ }
158
+ },
159
+ [count, next, prev],
160
+ );
161
+
162
+ return (
163
+ <div
164
+ // TODO(burdon): Move to ui-theme.
165
+ className={mx(
166
+ 'relative w-full aspect-video overflow-hidden',
167
+ 'focus:outline-none focus-visible:ring-2 focus-visible:ring-primary-500',
168
+ classNames,
169
+ )}
170
+ tabIndex={0}
171
+ role='region'
172
+ aria-roledescription='carousel'
173
+ aria-label={t('carousel-viewport.label')}
174
+ onKeyDown={handleKeyDown}
175
+ >
176
+ {children}
177
+ </div>
178
+ );
179
+ };
180
+
181
+ CarouselViewport.displayName = 'Carousel.Viewport';
182
+
183
+ //
184
+ // Slide
185
+ //
186
+
187
+ export type CarouselSlideProps = ThemedClassName<{
188
+ index: number;
189
+ /** Media source URL — rendered via the embedded {@link MediaPlayer}. */
190
+ src: string;
191
+ /** Override media auto-detection (`'video' | 'audio'`). */
192
+ kind?: MediaKind;
193
+ /** Accessible label / `<img alt>` fallback. */
194
+ alt?: string;
195
+ controls?: boolean;
196
+ autoPlay?: boolean;
197
+ loop?: boolean;
198
+ muted?: boolean;
199
+ crossOrigin?: 'anonymous' | 'use-credentials' | '';
200
+ }>;
201
+
202
+ const CarouselSlide = ({
203
+ index,
204
+ classNames,
205
+ src,
206
+ kind,
207
+ alt,
208
+ controls,
209
+ autoPlay,
210
+ loop,
211
+ muted,
212
+ crossOrigin,
213
+ }: CarouselSlideProps) => {
214
+ const { index: active } = useCarousel();
215
+ if (active !== index) {
216
+ return null;
217
+ }
218
+
219
+ return (
220
+ <div className={mx('absolute inset-0 w-full h-full bg-baseSurface', classNames)}>
221
+ <MediaPlayer
222
+ src={src}
223
+ kind={kind}
224
+ alt={alt}
225
+ classNames='w-full h-full'
226
+ controls={controls}
227
+ autoPlay={autoPlay}
228
+ loop={loop}
229
+ muted={muted}
230
+ crossOrigin={crossOrigin}
231
+ />
232
+ </div>
233
+ );
234
+ };
235
+
236
+ CarouselSlide.displayName = 'Carousel.Slide';
237
+
238
+ //
239
+ // Previous / Next
240
+ //
241
+
242
+ export type CarouselButtonProps = ThemedClassName<{}>;
243
+
244
+ const CarouselPrevious = ({ classNames }: CarouselButtonProps) => {
245
+ const { t } = useTranslation(translationKey);
246
+ const { count, prev } = useCarousel();
247
+ if (count <= 1) {
248
+ return <div />;
249
+ }
250
+
251
+ return (
252
+ <IconButton
253
+ classNames={mx('self-center', classNames)}
254
+ square
255
+ variant='ghost'
256
+ icon='ph--caret-left--regular'
257
+ iconOnly
258
+ label={t('carousel-prev.label')}
259
+ onClick={prev}
260
+ />
261
+ );
262
+ };
263
+
264
+ CarouselPrevious.displayName = 'Carousel.Previous';
265
+
266
+ const CarouselNext = ({ classNames }: CarouselButtonProps) => {
267
+ const { t } = useTranslation(translationKey);
268
+ const { count, next } = useCarousel();
269
+ if (count <= 1) {
270
+ return <div />;
271
+ }
272
+
273
+ return (
274
+ <IconButton
275
+ classNames={mx('self-center', classNames)}
276
+ square
277
+ variant='ghost'
278
+ icon='ph--caret-right--regular'
279
+ iconOnly
280
+ label={t('carousel-next.label')}
281
+ onClick={next}
282
+ />
283
+ );
284
+ };
285
+
286
+ CarouselNext.displayName = 'Carousel.Next';
287
+
288
+ //
289
+ // Indicators
290
+ //
291
+
292
+ export type CarouselIndicatorsProps = ThemedClassName<{}>;
293
+
294
+ /** Tab-strip of slide indicators. Sits in the centre column so it matches the viewport's width. */
295
+ const CarouselIndicators = ({ classNames }: CarouselIndicatorsProps) => {
296
+ const { t } = useTranslation(translationKey);
297
+ const { count, index, setIndex } = useCarousel();
298
+ const arrowNavigationAttrs = useArrowNavigationGroup({ axis: 'horizontal', memorizeCurrent: true });
299
+ if (count <= 1) {
300
+ return null;
301
+ }
302
+
303
+ return (
304
+ <div className='col-start-2 overflow-hidden'>
305
+ <div
306
+ {...arrowNavigationAttrs}
307
+ className={mx('flex items-center justify-center', classNames)}
308
+ role='tablist'
309
+ aria-label={t('carousel-indicators.label')}
310
+ >
311
+ {Array.from({ length: count }).map((_, i) => (
312
+ <IconButton
313
+ key={i}
314
+ role='tab'
315
+ aria-selected={i === index}
316
+ classNames={i === index ? 'text-primary-500' : 'text-description'}
317
+ icon={i === index ? 'ph--circle--fill' : 'ph--circle--regular'}
318
+ iconOnly
319
+ label={t('carousel-go-to.label', { index: i + 1 })}
320
+ onClick={() => setIndex(i)}
321
+ onFocus={() => setIndex(i)}
322
+ size={3}
323
+ variant='ghost'
324
+ />
325
+ ))}
326
+ </div>
327
+ </div>
328
+ );
329
+ };
330
+
331
+ CarouselIndicators.displayName = 'Carousel.Indicators';
332
+
333
+ //
334
+ // Caption
335
+ //
336
+
337
+ export type CarouselCaptionProps = ThemedClassName<{
338
+ /** Render prop receiving the active slide index. */
339
+ children: (index: number) => ReactNode;
340
+ }>;
341
+
342
+ /** Caption sized to the viewport's column. */
343
+ const CarouselCaption = ({ children, classNames }: CarouselCaptionProps) => {
344
+ const { index } = useCarousel();
345
+ const content = children(index);
346
+ if (content == null || content === false || content === '') {
347
+ return null;
348
+ }
349
+ return (
350
+ // TODO(burdon): Move to ui-theme.
351
+ <div className='col-start-2'>
352
+ <p className={mx('text-center text-description', classNames)}>{content}</p>
353
+ </div>
354
+ );
355
+ };
356
+
357
+ CarouselCaption.displayName = 'Carousel.Caption';
358
+
359
+ //
360
+ // Carousel
361
+ //
362
+
363
+ export const Carousel = {
364
+ Root: CarouselRoot,
365
+ Viewport: CarouselViewport,
366
+ Slide: CarouselSlide,
367
+ Previous: CarouselPrevious,
368
+ Next: CarouselNext,
369
+ Indicators: CarouselIndicators,
370
+ Caption: CarouselCaption,
371
+ };
@@ -0,0 +1,5 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ export * from './Carousel';
@@ -6,11 +6,10 @@ import React from 'react';
6
6
 
7
7
  import { mx, osTranslations } from '@dxos/ui-theme';
8
8
 
9
+ import { useTranslation } from '../../primitives';
9
10
  import { Button, type ButtonProps, IconButton } from '../Button';
10
11
  import { Icon, type IconProps } from '../Icon';
11
- import { useTranslation } from '../ThemeProvider';
12
12
  import { type TooltipScopedProps, useTooltipContext } from '../Tooltip';
13
-
14
13
  import { useClipboard } from './ClipboardProvider';
15
14
 
16
15
  export type CopyButtonProps = ButtonProps &
@@ -18,7 +17,7 @@ export type CopyButtonProps = ButtonProps &
18
17
  value: string;
19
18
  };
20
19
 
21
- const inactiveLabelStyles = 'invisible bs-px -mbe-px overflow-hidden';
20
+ const inactiveLabelStyles = 'invisible h-px -mb-px overflow-hidden';
22
21
 
23
22
  export const CopyButton = ({ classNames, value, size = 5, ...props }: CopyButtonProps) => {
24
23
  const { t } = useTranslation(osTranslations);
@@ -31,12 +30,12 @@ export const CopyButton = ({ classNames, value, size = 5, ...props }: CopyButton
31
30
  onClick={() => setTextValue(value)}
32
31
  data-testid='copy-invitation'
33
32
  >
34
- <div role='none' className={mx('flex gap-1 items-center', isCopied && inactiveLabelStyles)}>
35
- <span className='pli-1'>{t('copy label')}</span>
33
+ <div className={mx('flex gap-1 items-center', isCopied && inactiveLabelStyles)}>
34
+ <span className='px-1'>{t('copy.label')}</span>
36
35
  <Icon icon='ph--copy--regular' size={size} />
37
36
  </div>
38
- <div role='none' className={mx('flex gap-1 items-center', !isCopied && inactiveLabelStyles)}>
39
- <span className='pli-1'>{t('copy success label')}</span>
37
+ <div className={mx('flex gap-1 items-center', !isCopied && inactiveLabelStyles)}>
38
+ <span className='px-1'>{t('copy-success.label')}</span>
40
39
  <Icon icon='ph--check--regular' size={size} />
41
40
  </div>
42
41
  </Button>
@@ -58,7 +57,7 @@ export const CopyButtonIconOnly = ({
58
57
  const { t } = useTranslation(osTranslations);
59
58
  const { textValue, setTextValue } = useClipboard();
60
59
  const isCopied = textValue === value;
61
- const label = isCopied ? t('copy success label') : (props.label ?? t('copy label'));
60
+ const label = isCopied ? t('copy-success.label') : (props.label ?? t('copy.label'));
62
61
  const { onOpen } = useTooltipContext('CopyButton', __scopeTooltip);
63
62
  return (
64
63
  <IconButton
@@ -0,0 +1,148 @@
1
+ # Column architecture reference
2
+
3
+ ## Background
4
+
5
+ `Column` establishes a 3-column CSS grid with left/right gutter columns and a center content
6
+ channel. Two CSS custom properties drive the system:
7
+
8
+ - `--gutter` — the gutter track width (e.g. `var(--dx-gutter-md)`); consumed by `ScrollArea.Viewport` for padding.
9
+ - `--dx-col` — the grid-column placement token; set by `Column.Root` and consumed by `withColumn` utilities.
10
+
11
+ ## Column primitives
12
+
13
+ ### Column.Root
14
+
15
+ ```css
16
+ /* column.ts — columnRoot */
17
+ dx-column grid
18
+ /* inline style */
19
+ --gutter: <gutterSize>
20
+ --dx-col: 2 / span 1
21
+ grid-template-columns: <gutter> minmax(0,1fr) <gutter>
22
+ ```
23
+
24
+ Sets the 3-column grid and both CSS variables. All `withColumn` utilities are no-ops outside this context.
25
+
26
+ ### Column.Center
27
+
28
+ ```css
29
+ /* column.ts — columnCenter */
30
+ [grid-column:var(--dx-col,auto)] min-h-0
31
+ ```
32
+
33
+ Places a single element in col 2 (the center track). Does not use subgrid — placement is explicit
34
+ on this element only, so arbitrary compound components (including `display: contents` wrappers) can
35
+ be nested safely.
36
+
37
+ ### Column.Bleed
38
+
39
+ ```css
40
+ /* column.ts — columnBleed */
41
+ col-span-full grid grid-cols-subgrid min-h-0
42
+ ```
43
+
44
+ Spans all 3 columns and propagates the subgrid. Use for `ScrollArea`, full-width dividers, and
45
+ any content that should ignore the gutters.
46
+
47
+ ### Column.Row
48
+
49
+ ```css
50
+ /* column.ts — columnRow */
51
+ col-span-3 grid grid-cols-subgrid
52
+ ```
53
+
54
+ Three-slot icon row. Children map to: `[col-1: icon/slot] [col-2: content] [col-3: icon/action]`.
55
+ Must be a direct child of `Column.Root`.
56
+
57
+ ## withColumn theme utilities
58
+
59
+ Exported from `@dxos/ui-theme`. Components import and call these in their theme functions to
60
+ participate in the Column grid without importing Column React components.
61
+
62
+ ```ts
63
+ withColumn.center();
64
+ // → '[grid-column:var(--dx-col,auto)]'
65
+
66
+ withColumn.propagate();
67
+ // → '[.dx-column_&]:col-span-full [.dx-column_&]:grid [.dx-column_&]:grid-cols-subgrid'
68
+
69
+ withColumn.consumed();
70
+ // → '[--dx-col:auto]'
71
+ ```
72
+
73
+ | Utility | Purpose | Where used |
74
+ | :------------ | :-------------------------------------------------------------------------------- | :---------------------------------------------------------------------------- |
75
+ | `center()` | Place element in col 2 via `--dx-col`. No-op outside Column or inside ScrollArea. | Dialog.Header, Dialog.ActionBar, Form.Content, Form.Actions, SearchList.Input |
76
+ | `propagate()` | Extend Column subgrid to children. No-op outside Column. | Dialog.Body, SearchList.Content |
77
+ | `consumed()` | Reset `--dx-col` after `--gutter` is consumed. | ScrollArea.Viewport |
78
+
79
+ ## CSS custom property cascade
80
+
81
+ ```text
82
+ Column.Root
83
+ sets --gutter = var(--dx-gutter-<size>)
84
+ sets --dx-col = 2 / span 1
85
+
86
+ ├─ Column.Center → grid-column: var(--dx-col) ← consumes --dx-col
87
+ ├─ Column.Bleed → col-span-full, subgrid
88
+ ├─ Column.Row → col-span-3, subgrid
89
+
90
+ └─ withColumn.center() → grid-column: var(--dx-col) ← consumes --dx-col
91
+ withColumn.propagate() → col-span-full, grid, subgrid (inside .dx-column only)
92
+
93
+ └─ ScrollArea.Root → col-span-full (inside .dx-column only)
94
+ ScrollArea.Viewport
95
+ applies pl/pr using --gutter
96
+ withColumn.consumed() → sets --dx-col: auto
97
+
98
+ └─ (nested components no longer auto-position)
99
+ ```
100
+
101
+ ## Component integration
102
+
103
+ ### Dialog
104
+
105
+ | Sub-component | withColumn applied | Effect |
106
+ | :----------------- | :---------------------------- | :---------------------------- |
107
+ | `Dialog.Content` | `Column.Root` (gutter `'sm'`) | Establishes the 3-col grid. |
108
+ | `Dialog.Header` | `withColumn.center()` | Placed in col 2. |
109
+ | `Dialog.Body` | `withColumn.propagate()` | Children inherit the subgrid. |
110
+ | `Dialog.ActionBar` | `withColumn.center()` | Placed in col 2. |
111
+
112
+ ### Form
113
+
114
+ | Sub-component | withColumn applied | Effect |
115
+ | :------------- | :-------------------- | :---------------------------------- |
116
+ | `Form.Content` | `withColumn.center()` | Placed in col 2 when inside Column. |
117
+ | `Form.Actions` | `withColumn.center()` | Placed in col 2 when inside Column. |
118
+
119
+ ### SearchList
120
+
121
+ | Sub-component | withColumn applied | Effect |
122
+ | :------------------------- | :----------------------- | :---------------------------------------------- |
123
+ | `SearchList.Content` | `withColumn.propagate()` | Extends subgrid to children when inside Column. |
124
+ | `SearchList.Input` wrapper | `withColumn.center()` | Input row placed in col 2. |
125
+
126
+ ### Card
127
+
128
+ `Card.Row` uses its own inline subgrid CSS (`col-span-3 grid grid-cols-subgrid`) and does not
129
+ participate in an outer Column grid. `Card.Root` establishes a separate 3-column grid for its
130
+ own icon-slot layout.
131
+
132
+ ## Subgrid chain integrity
133
+
134
+ Every intermediate container between `Column.Root` and a `ScrollArea.Root` must propagate the
135
+ subgrid, otherwise `ScrollArea.Root`'s `[.dx-column_&]:col-span-full` selector will not match
136
+ and the scrollbar will not extend to the gutter.
137
+
138
+ Required chain:
139
+
140
+ ```
141
+ Column.Root (.dx-column)
142
+ → withColumn.propagate() container (col-span-full, grid, grid-cols-subgrid)
143
+ → ScrollArea.Root (.dx-container, [.dx-column_&]:col-span-full)
144
+ → ScrollArea.Viewport (applies --gutter padding, resets --dx-col)
145
+ ```
146
+
147
+ If any intermediate element wraps the ScrollArea without propagating, use `Column.Bleed` or
148
+ apply `withColumn.propagate()` to that wrapper.