@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,67 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { type Meta, type StoryObj } from '@storybook/react-vite';
6
+ import React from 'react';
7
+
8
+ import { Input, ScrollArea, ScrollAreaRootProps, Toolbar } from '../../components';
9
+ import { withLayout, withTheme } from '../../testing';
10
+ import { composable, composableProps } from '../../util';
11
+ import { Panel } from './Panel';
12
+
13
+ const List = composable<HTMLDivElement, ScrollAreaRootProps>((props, forwardedRef) => {
14
+ return (
15
+ <ScrollArea.Root centered {...composableProps(props, { role: 'list' })} ref={forwardedRef}>
16
+ <ScrollArea.Viewport>
17
+ {Array.from({ length: 100 }).map((_, i) => (
18
+ <div key={i} role='listitem' className='p-1 hover:bg-hover-surface'>
19
+ Item {i}
20
+ </div>
21
+ ))}
22
+ </ScrollArea.Viewport>
23
+ </ScrollArea.Root>
24
+ );
25
+ });
26
+
27
+ const DefaultStory = () => {
28
+ return (
29
+ <Panel.Root className='dx-document'>
30
+ <Panel.Toolbar asChild>
31
+ <Toolbar.Root classNames='gap-2'>
32
+ <Toolbar.IconButton icon='ph--plus--regular' variant='primary' label='Add' />
33
+ <Input.Root>
34
+ <Input.TextInput placeholder='Search' />
35
+ </Input.Root>
36
+ <Toolbar.IconButton icon='ph--dots-three-vertical--regular' iconOnly label='Menu' />
37
+ </Toolbar.Root>
38
+ </Panel.Toolbar>
39
+
40
+ <Panel.Content asChild>
41
+ <List />
42
+ </Panel.Content>
43
+
44
+ <Panel.Statusbar asChild>
45
+ <Toolbar.Root classNames='justify-between'>
46
+ <Toolbar.IconButton variant='ghost' icon='ph--house--regular' iconOnly label='Add' />
47
+ <Toolbar.IconButton variant='ghost' icon='ph--alarm--regular' iconOnly label='Status' />
48
+ </Toolbar.Root>
49
+ </Panel.Statusbar>
50
+ </Panel.Root>
51
+ );
52
+ };
53
+
54
+ const meta: Meta = {
55
+ title: 'ui/react-ui-core/components/Panel',
56
+ render: DefaultStory,
57
+ decorators: [withTheme(), withLayout({ layout: 'fullscreen' })],
58
+ parameters: {
59
+ layout: 'fullscreen',
60
+ },
61
+ };
62
+
63
+ export default meta;
64
+
65
+ type Story = StoryObj<typeof meta>;
66
+
67
+ export const Default: Story = {};
@@ -0,0 +1,42 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ import { mx } from '@dxos/ui-theme';
6
+ import { type ComponentFunction } from '@dxos/ui-types';
7
+
8
+ type Size = 'lg' | 'md' | 'sm';
9
+
10
+ export type PanelStyleProps = {
11
+ size?: Size;
12
+ };
13
+
14
+ const sizes: Record<Size, string> = {
15
+ lg: 'h-(--dx-topbar-size)',
16
+ md: 'h-(--dx-toolbar-size)',
17
+ sm: 'h-(--dx-statusbar-size)',
18
+ };
19
+
20
+ const root: ComponentFunction<PanelStyleProps> = (_, ...etc) =>
21
+ mx(
22
+ // prettier-ignore
23
+ 'dx-container grid grid-cols-[100%] overflow-hidden',
24
+ // Add uncategorized children to content slot.
25
+ '[&>*:not([data-slot])]:[grid-area:content]',
26
+ ...etc,
27
+ );
28
+
29
+ const toolbar: ComponentFunction<PanelStyleProps> = ({ size = 'md' }, ...etc) =>
30
+ mx('[grid-area:toolbar]', 'shrink-0', sizes[size], ...etc);
31
+
32
+ const content: ComponentFunction<PanelStyleProps> = (_, ...etc) => mx('[grid-area:content] min-h-0', ...etc);
33
+
34
+ const statusbar: ComponentFunction<PanelStyleProps> = ({ size = 'md' }, ...etc) =>
35
+ mx('[grid-area:statusbar]', 'shrink-0', sizes[size], ...etc);
36
+
37
+ export const panelTheme = {
38
+ root,
39
+ toolbar,
40
+ content,
41
+ statusbar,
42
+ };
@@ -0,0 +1,121 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ import { Primitive } from '@radix-ui/react-primitive';
6
+ import { Slot } from '@radix-ui/react-slot';
7
+ import React, { type CSSProperties } from 'react';
8
+
9
+ import { type SlottableProps } from '@dxos/ui-types';
10
+
11
+ import { useThemeContext } from '../../hooks';
12
+ import { PanelStyleProps } from '../../theme';
13
+ import { composableProps, slottable } from '../../util';
14
+
15
+ //
16
+ // Root
17
+ //
18
+
19
+ const GRID_TEMPLATE_ROWS = 'auto 1fr auto';
20
+ const GRID_TEMPLATE_AREAS = '"toolbar" "content" "statusbar"';
21
+
22
+ type PanelRootProps = SlottableProps<{ style?: CSSProperties }>;
23
+
24
+ const PanelRoot = slottable<HTMLDivElement, { style?: CSSProperties }>(
25
+ ({ children, asChild, role, style, ...props }, forwardedRef) => {
26
+ const { className, ...rest } = composableProps(props);
27
+ const Comp = asChild ? Slot : Primitive.div;
28
+ const { tx } = useThemeContext();
29
+ return (
30
+ <Comp
31
+ {...rest}
32
+ role={role ?? 'none'}
33
+ style={{
34
+ gridTemplateRows: GRID_TEMPLATE_ROWS,
35
+ gridTemplateAreas: GRID_TEMPLATE_AREAS,
36
+ ...style,
37
+ }}
38
+ className={tx('panel.root', {}, className)}
39
+ ref={forwardedRef}
40
+ >
41
+ {children}
42
+ </Comp>
43
+ );
44
+ },
45
+ );
46
+
47
+ PanelRoot.displayName = 'Panel.Root';
48
+
49
+ //
50
+ // Toolbar
51
+ //
52
+
53
+ type PanelToolbarProps = SlottableProps & Pick<PanelStyleProps, 'size'>;
54
+
55
+ const PanelToolbar = slottable<HTMLDivElement, Pick<PanelStyleProps, 'size'>>(
56
+ ({ children, asChild, size, ...props }, forwardedRef) => {
57
+ const { className, ...rest } = composableProps(props);
58
+ const Comp = asChild ? Slot : Primitive.div;
59
+ const { tx } = useThemeContext();
60
+ return (
61
+ <Comp {...rest} data-slot='toolbar' className={tx('panel.toolbar', { size }, className)} ref={forwardedRef}>
62
+ {children}
63
+ </Comp>
64
+ );
65
+ },
66
+ );
67
+
68
+ PanelToolbar.displayName = 'Panel.Toolbar';
69
+
70
+ //
71
+ // Content
72
+ //
73
+
74
+ type PanelContentProps = SlottableProps;
75
+
76
+ const PanelContent = slottable<HTMLDivElement>(({ children, asChild, ...props }, forwardedRef) => {
77
+ const { className, ...rest } = composableProps(props);
78
+ const Comp = asChild ? Slot : Primitive.div;
79
+ const { tx } = useThemeContext();
80
+ return (
81
+ <Comp {...rest} data-slot='content' className={tx('panel.content', {}, className)} ref={forwardedRef}>
82
+ {children}
83
+ </Comp>
84
+ );
85
+ });
86
+
87
+ PanelContent.displayName = 'Panel.Content';
88
+
89
+ //
90
+ // Statusbar
91
+ //
92
+
93
+ type PanelStatusbarProps = SlottableProps & Pick<PanelStyleProps, 'size'>;
94
+
95
+ const PanelStatusbar = slottable<HTMLDivElement, Pick<PanelStyleProps, 'size'>>(
96
+ ({ children, asChild, size, ...props }, forwardedRef) => {
97
+ const { className, ...rest } = composableProps(props);
98
+ const Comp = asChild ? Slot : Primitive.div;
99
+ const { tx } = useThemeContext();
100
+ return (
101
+ <Comp {...rest} data-slot='statusbar' className={tx('panel.statusbar', { size }, className)} ref={forwardedRef}>
102
+ {children}
103
+ </Comp>
104
+ );
105
+ },
106
+ );
107
+
108
+ PanelStatusbar.displayName = 'Panel.Statusbar';
109
+
110
+ //
111
+ // Panel
112
+ //
113
+
114
+ export const Panel = {
115
+ Root: PanelRoot,
116
+ Toolbar: PanelToolbar,
117
+ Content: PanelContent,
118
+ Statusbar: PanelStatusbar,
119
+ };
120
+
121
+ export type { PanelRootProps, PanelToolbarProps, PanelContentProps, PanelStatusbarProps };
@@ -0,0 +1,5 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ export * from './Panel';
@@ -5,14 +5,13 @@
5
5
  import { type Meta, type StoryObj } from '@storybook/react-vite';
6
6
  import React, { type PropsWithChildren, type ReactNode, useRef, useState } from 'react';
7
7
 
8
- import { faker } from '@dxos/random';
8
+ import { random } from '@dxos/random';
9
9
 
10
10
  import { withTheme } from '../../testing';
11
11
  import { Button } from '../Button';
12
-
13
12
  import { Popover } from './Popover';
14
13
 
15
- faker.seed(1234);
14
+ random.seed(1234);
16
15
 
17
16
  const DefaultStory = ({ openTrigger, children }: PropsWithChildren<{ openTrigger: ReactNode }>) => {
18
17
  return (
@@ -20,7 +19,7 @@ const DefaultStory = ({ openTrigger, children }: PropsWithChildren<{ openTrigger
20
19
  <Popover.Trigger asChild>{openTrigger}</Popover.Trigger>
21
20
  <Popover.Content>
22
21
  <Popover.Viewport>
23
- <p className='pli-2 plb-1 min-is-[18rem] max-is-[38rem]'>{children}</p>
22
+ <p className='px-2 py-1 min-w-[18rem] max-w-[38rem]'>{children}</p>
24
23
  </Popover.Viewport>
25
24
  <Popover.Arrow />
26
25
  </Popover.Content>
@@ -42,7 +41,7 @@ type Story = StoryObj<typeof meta>;
42
41
  export const Default: Story = {
43
42
  args: {
44
43
  openTrigger: <Button>Open popover</Button>,
45
- children: faker.lorem.paragraphs(3),
44
+ children: random.lorem.paragraphs(3),
46
45
  },
47
46
  };
48
47
 
@@ -59,7 +58,7 @@ export const VirtualTrigger = {
59
58
  <Popover.VirtualTrigger virtualRef={buttonRef} />
60
59
  <Popover.Content>
61
60
  <Popover.Viewport>
62
- <p className='pli-2 plb-1 min-is-[18rem] max-is-[38rem]'>{faker.lorem.paragraphs(3)}</p>
61
+ <p className='px-2 py-1 min-w-[18rem] max-w-[38rem]'>{random.lorem.paragraphs(3)}</p>
63
62
  </Popover.Viewport>
64
63
  <Popover.Arrow />
65
64
  </Popover.Content>
@@ -0,0 +1,40 @@
1
+ //
2
+ // Copyright 2023 DXOS.org
3
+ //
4
+
5
+ import { mx, surfaceShadow, surfaceZIndex } from '@dxos/ui-theme';
6
+ import { type ComponentFunction, type Elevation, type Theme } from '@dxos/ui-types';
7
+
8
+ export type PopoverStyleProps = Partial<{
9
+ constrainBlock: boolean;
10
+ constrainInline: boolean;
11
+ elevation: Elevation;
12
+ }>;
13
+
14
+ const content: ComponentFunction<PopoverStyleProps> = ({ elevation }, ...etc) =>
15
+ mx(
16
+ 'dx-modal-surface border border-separator rounded-sm',
17
+ surfaceShadow({ elevation: 'positioned' }),
18
+ surfaceZIndex({ elevation, level: 'menu' }),
19
+ 'dx-focus-ring',
20
+ ...etc,
21
+ );
22
+
23
+ const viewport: ComponentFunction<PopoverStyleProps> = ({ constrainBlock, constrainInline }, ...etc) =>
24
+ mx(
25
+ 'grid grid-rows-[1fr] min-h-0 min-w-popover-min-width',
26
+ (constrainBlock || constrainInline) && 'overflow-hidden',
27
+ constrainBlock && 'max-h-(--radix-popover-content-available-height)',
28
+ constrainBlock &&
29
+ 'max-h-[min(var(--radix-popover-content-available-height),calc(100dvh-var(--spacing-screen-border)*2))]',
30
+ constrainInline && 'max-w-(--radix-popover-content-available-width)',
31
+ ...etc,
32
+ );
33
+
34
+ const arrow: ComponentFunction<PopoverStyleProps> = (_props, ...etc) => mx('fill-separator', ...etc);
35
+
36
+ export const popoverTheme: Theme<PopoverStyleProps> = {
37
+ content,
38
+ viewport,
39
+ arrow,
40
+ };
@@ -2,7 +2,7 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- // This is based upon `@radix-ui/react-popover` fetched 25 Oct 2024 at https://github.com/radix-ui/primitives at commit 374c7d7.
5
+ // This is based upon `@radix-ui/react-popover` fetched Oct 25, 2024 at https://github.com/radix-ui/primitives at commit 374c7d7.
6
6
 
7
7
  import { composeEventHandlers } from '@radix-ui/primitive';
8
8
  import { useComposedRefs } from '@radix-ui/react-compose-refs';
@@ -23,9 +23,8 @@ import { hideOthers } from 'aria-hidden';
23
23
  import React, {
24
24
  type ComponentPropsWithRef,
25
25
  type ComponentPropsWithoutRef,
26
- type ElementRef,
26
+ type ComponentRef,
27
27
  type FC,
28
- type MutableRefObject,
29
28
  type ReactNode,
30
29
  type RefObject,
31
30
  forwardRef,
@@ -37,30 +36,31 @@ import React, {
37
36
  } from 'react';
38
37
  import { RemoveScroll } from 'react-remove-scroll';
39
38
 
40
- import { useElevationContext, useThemeContext } from '../../hooks';
41
- import { useSafeCollisionPadding } from '../../hooks/useSafeCollisionPadding';
39
+ import { useSafeCollisionPadding, useElevationContext, useThemeContext } from '../../hooks';
42
40
  import { type ThemedClassName } from '../../util';
43
41
 
44
42
  //
45
43
  // Context
46
44
  //
47
45
 
46
+ type ScopedProps<P> = P & { __scopePopover?: Scope };
47
+
48
48
  const POPOVER_NAME = 'Popover';
49
49
 
50
- type ScopedProps<P> = P & { __scopePopover?: Scope };
51
50
  const [createPopoverContext, createPopoverScope] = createContextScope(POPOVER_NAME, [createPopperScope]);
51
+
52
52
  const usePopperScope = createPopperScope();
53
53
 
54
54
  type PopoverContextValue = {
55
- triggerRef: MutableRefObject<HTMLButtonElement>;
55
+ triggerRef: RefObject<HTMLButtonElement>;
56
56
  contentId: string;
57
+ hasCustomAnchor: boolean;
58
+ modal: boolean;
57
59
  open: boolean;
58
60
  onOpenChange(open: boolean): void;
59
61
  onOpenToggle(): void;
60
- hasCustomAnchor: boolean;
61
62
  onCustomAnchorAdd(): void;
62
63
  onCustomAnchorRemove(): void;
63
- modal: boolean;
64
64
  };
65
65
 
66
66
  const [PopoverProvider, usePopoverContext] = createPopoverContext<PopoverContextValue>(POPOVER_NAME);
@@ -69,13 +69,13 @@ const [PopoverProvider, usePopoverContext] = createPopoverContext<PopoverContext
69
69
  // PopoverRoot
70
70
  //
71
71
 
72
- interface PopoverRootProps {
72
+ type PopoverRootProps = {
73
73
  children?: ReactNode;
74
74
  open?: boolean;
75
75
  defaultOpen?: boolean;
76
76
  onOpenChange?: (open: boolean) => void;
77
77
  modal?: boolean;
78
- }
78
+ };
79
79
 
80
80
  const PopoverRoot: FC<PopoverRootProps> = (props: ScopedProps<PopoverRootProps>) => {
81
81
  const { __scopePopover, children, open: openProp, defaultOpen, onOpenChange, modal = false } = props;
@@ -93,7 +93,7 @@ const PopoverRoot: FC<PopoverRootProps> = (props: ScopedProps<PopoverRootProps>)
93
93
  <PopoverProvider
94
94
  scope={__scopePopover}
95
95
  contentId={useId()}
96
- triggerRef={triggerRef as MutableRefObject<HTMLButtonElement>}
96
+ triggerRef={triggerRef as RefObject<HTMLButtonElement>}
97
97
  open={open}
98
98
  onOpenChange={setOpen}
99
99
  onOpenToggle={useCallback(() => setOpen((prevOpen) => !prevOpen), [setOpen])}
@@ -114,11 +114,11 @@ PopoverRoot.displayName = POPOVER_NAME;
114
114
  // PopoverAnchor
115
115
  //
116
116
 
117
- const ANCHOR_NAME = 'PopoverAnchor';
117
+ const ANCHOR_NAME = 'Popover.Anchor';
118
118
 
119
- type PopoverAnchorElement = ElementRef<typeof PopperPrimitive.Anchor>;
119
+ type PopoverAnchorElement = ComponentRef<typeof PopperPrimitive.Anchor>;
120
120
  type PopperAnchorProps = ComponentPropsWithoutRef<typeof PopperPrimitive.Anchor>;
121
- interface PopoverAnchorProps extends PopperAnchorProps {}
121
+ type PopoverAnchorProps = PopperAnchorProps;
122
122
 
123
123
  const PopoverAnchor = forwardRef<PopoverAnchorElement, PopoverAnchorProps>(
124
124
  (props: ScopedProps<PopoverAnchorProps>, forwardedRef) => {
@@ -142,21 +142,24 @@ PopoverAnchor.displayName = ANCHOR_NAME;
142
142
  // PopoverTrigger
143
143
  //
144
144
 
145
- const TRIGGER_NAME = 'PopoverTrigger';
145
+ const TRIGGER_NAME = 'Popover.Trigger';
146
146
 
147
- type PopoverTriggerElement = ElementRef<typeof Primitive.button>;
147
+ type PopoverTriggerElement = ComponentRef<typeof Primitive.button>;
148
148
  type PrimitiveButtonProps = ComponentPropsWithoutRef<typeof Primitive.button>;
149
- interface PopoverTriggerProps extends PrimitiveButtonProps {}
149
+ type PopoverTriggerProps = PrimitiveButtonProps & {
150
+ asChild?: boolean;
151
+ };
150
152
 
151
153
  const PopoverTrigger = forwardRef<PopoverTriggerElement, PopoverTriggerProps>(
152
154
  (props: ScopedProps<PopoverTriggerProps>, forwardedRef) => {
153
- const { __scopePopover, ...triggerProps } = props;
155
+ const { __scopePopover, asChild, ...triggerProps } = props;
154
156
  const context = usePopoverContext(TRIGGER_NAME, __scopePopover);
155
157
  const popperScope = usePopperScope(__scopePopover);
156
158
  const composedTriggerRef = useComposedRefs(forwardedRef, context.triggerRef);
159
+ const Comp = asChild ? Slot : Primitive.button;
157
160
 
158
161
  const trigger = (
159
- <Primitive.button
162
+ <Comp
160
163
  type='button'
161
164
  aria-haspopup='dialog'
162
165
  aria-expanded={context.open}
@@ -184,11 +187,11 @@ PopoverTrigger.displayName = TRIGGER_NAME;
184
187
  // PopoverVirtualTrigger
185
188
  //
186
189
 
187
- const VIRTUAL_TRIGGER_NAME = 'PopoverVirtualTrigger';
190
+ const VIRTUAL_TRIGGER_NAME = 'Popover.VirtualTrigger';
188
191
 
189
- interface PopoverVirtualTriggerProps {
192
+ type PopoverVirtualTriggerProps = {
190
193
  virtualRef: RefObject<PopoverTriggerElement | null>;
191
- }
194
+ };
192
195
 
193
196
  const PopoverVirtualTrigger = (props: ScopedProps<PopoverVirtualTriggerProps>) => {
194
197
  const { __scopePopover, virtualRef } = props;
@@ -208,7 +211,7 @@ PopoverVirtualTrigger.displayName = VIRTUAL_TRIGGER_NAME;
208
211
  // PopoverPortal
209
212
  //
210
213
 
211
- const PORTAL_NAME = 'PopoverPortal';
214
+ const PORTAL_NAME = 'Popover.Portal';
212
215
 
213
216
  type PortalContextValue = { forceMount?: true };
214
217
  const [PortalProvider, usePortalContext] = createPopoverContext<PortalContextValue>(PORTAL_NAME, {
@@ -216,7 +219,7 @@ const [PortalProvider, usePortalContext] = createPopoverContext<PortalContextVal
216
219
  });
217
220
 
218
221
  type PortalProps = ComponentPropsWithoutRef<typeof PortalPrimitive>;
219
- interface PopoverPortalProps {
222
+ type PopoverPortalProps = {
220
223
  children?: ReactNode;
221
224
  /**
222
225
  * Specify a container element to portal the content into.
@@ -227,9 +230,9 @@ interface PopoverPortalProps {
227
230
  * controlling animation with React animation libraries.
228
231
  */
229
232
  forceMount?: true;
230
- }
233
+ };
231
234
 
232
- const PopoverPortal: FC<PopoverPortalProps> = (props: ScopedProps<PopoverPortalProps>) => {
235
+ const PopoverPortal = (props: ScopedProps<PopoverPortalProps>) => {
233
236
  const { __scopePopover, forceMount, children, container } = props;
234
237
  const context = usePopoverContext(PORTAL_NAME, __scopePopover);
235
238
  return (
@@ -249,7 +252,7 @@ PopoverPortal.displayName = PORTAL_NAME;
249
252
  // PopoverContent
250
253
  //
251
254
 
252
- const CONTENT_NAME = 'PopoverContent';
255
+ const CONTENT_NAME = 'Popover.Content';
253
256
 
254
257
  type PopoverContentProps = ThemedClassName<PopoverContentTypeProps> & {
255
258
  /**
@@ -280,8 +283,10 @@ const PopoverContent = forwardRef<PopoverContentTypeElement, PopoverContentProps
280
283
  PopoverContent.displayName = CONTENT_NAME;
281
284
 
282
285
  type PopoverContentTypeElement = PopoverContentImplElement;
283
- export interface PopoverContentTypeProps
284
- extends Omit<PopoverContentImplProps, 'trapFocus' | 'disableOutsidePointerEvents'> {}
286
+ export interface PopoverContentTypeProps extends Omit<
287
+ PopoverContentImplProps,
288
+ 'trapFocus' | 'disableOutsidePointerEvents'
289
+ > {}
285
290
 
286
291
  const PopoverContentModal = forwardRef<PopoverContentTypeElement, PopoverContentTypeProps>(
287
292
  (props: ScopedProps<PopoverContentTypeProps>, forwardedRef) => {
@@ -303,8 +308,7 @@ const PopoverContentModal = forwardRef<PopoverContentTypeElement, PopoverContent
303
308
  <PopoverContentImpl
304
309
  {...props}
305
310
  ref={composedRefs}
306
- // we make sure we're not trapping once it's been closed
307
- // (closed !== unmounted when animating out)
311
+ // Make sure we're not trapping once it's been closed (closed !== unmounted when animating out).
308
312
  trapFocus={context.open}
309
313
  disableOutsidePointerEvents
310
314
  onCloseAutoFocus={composeEventHandlers(props.onCloseAutoFocus, (event) => {
@@ -393,32 +397,31 @@ const PopoverContentNonModal = forwardRef<PopoverContentTypeElement, PopoverCont
393
397
  },
394
398
  );
395
399
 
396
- type PopoverContentImplElement = ElementRef<typeof PopperPrimitive.Content>;
400
+ type PopoverContentImplElement = ComponentRef<typeof PopperPrimitive.Content>;
397
401
  type FocusScopeProps = ComponentPropsWithoutRef<typeof FocusScope>;
398
402
  type DismissableLayerProps = ComponentPropsWithoutRef<typeof DismissableLayer>;
399
403
  type PopperContentProps = ThemedClassName<ComponentPropsWithoutRef<typeof PopperPrimitive.Content>>;
400
404
 
401
- interface PopoverContentImplProps
402
- extends Omit<PopperContentProps, 'onPlaced'>,
403
- Omit<DismissableLayerProps, 'onDismiss'> {
404
- /**
405
- * Whether focus should be trapped within the `Popover`
406
- * (default: false)
407
- */
408
- trapFocus?: FocusScopeProps['trapped'];
409
-
410
- /**
411
- * Event handler called when auto-focusing on open.
412
- * Can be prevented.
413
- */
414
- onOpenAutoFocus?: FocusScopeProps['onMountAutoFocus'];
415
-
416
- /**
417
- * Event handler called when auto-focusing on close.
418
- * Can be prevented.
419
- */
420
- onCloseAutoFocus?: FocusScopeProps['onUnmountAutoFocus'];
421
- }
405
+ type PopoverContentImplProps = Omit<PopperContentProps, 'onPlaced'> &
406
+ Omit<DismissableLayerProps, 'onDismiss'> & {
407
+ /**
408
+ * Whether focus should be trapped within the `Popover`
409
+ * (default: false)
410
+ */
411
+ trapFocus?: FocusScopeProps['trapped'];
412
+
413
+ /**
414
+ * Event handler called when auto-focusing on open.
415
+ * Can be prevented.
416
+ */
417
+ onOpenAutoFocus?: FocusScopeProps['onMountAutoFocus'];
418
+
419
+ /**
420
+ * Event handler called when auto-focusing on close.
421
+ * Can be prevented.
422
+ */
423
+ onCloseAutoFocus?: FocusScopeProps['onUnmountAutoFocus'];
424
+ };
422
425
 
423
426
  const PopoverContentImpl = forwardRef<PopoverContentImplElement, PopoverContentImplProps>(
424
427
  (props: ScopedProps<PopoverContentImplProps>, forwardedRef) => {
@@ -485,7 +488,7 @@ const PopoverContentImpl = forwardRef<PopoverContentImplElement, PopoverContentI
485
488
  {...contentProps}
486
489
  collisionPadding={safeCollisionPadding}
487
490
  collisionBoundary={computedCollisionBoundary}
488
- className={tx('popover.content', 'popover', { elevation }, classNames)}
491
+ className={tx('popover.content', { elevation }, classNames)}
489
492
  ref={forwardedRef}
490
493
  style={{
491
494
  ...contentProps.style,
@@ -509,10 +512,10 @@ const PopoverContentImpl = forwardRef<PopoverContentImplElement, PopoverContentI
509
512
  // PopoverClose
510
513
  //
511
514
 
512
- const CLOSE_NAME = 'PopoverClose';
515
+ const CLOSE_NAME = 'Popover.Close';
513
516
 
514
- type PopoverCloseElement = ElementRef<typeof Primitive.button>;
515
- interface PopoverCloseProps extends PrimitiveButtonProps {}
517
+ type PopoverCloseElement = ComponentRef<typeof Primitive.button>;
518
+ type PopoverCloseProps = PrimitiveButtonProps;
516
519
 
517
520
  const PopoverClose = forwardRef<PopoverCloseElement, PopoverCloseProps>(
518
521
  (props: ScopedProps<PopoverCloseProps>, forwardedRef) => {
@@ -535,11 +538,11 @@ PopoverClose.displayName = CLOSE_NAME;
535
538
  // PopoverArrow
536
539
  //
537
540
 
538
- const ARROW_NAME = 'PopoverArrow';
541
+ const ARROW_NAME = 'Popover.Arrow';
539
542
 
540
- type PopoverArrowElement = ElementRef<typeof PopperPrimitive.Arrow>;
543
+ type PopoverArrowElement = ComponentRef<typeof PopperPrimitive.Arrow>;
541
544
  type PopperArrowProps = ThemedClassName<ComponentPropsWithoutRef<typeof PopperPrimitive.Arrow>>;
542
- interface PopoverArrowProps extends PopperArrowProps {}
545
+ type PopoverArrowProps = PopperArrowProps;
543
546
 
544
547
  const PopoverArrow = forwardRef<PopoverArrowElement, PopoverArrowProps>(
545
548
  (props: ScopedProps<PopoverArrowProps>, forwardedRef) => {
@@ -550,7 +553,7 @@ const PopoverArrow = forwardRef<PopoverArrowElement, PopoverArrowProps>(
550
553
  <PopperPrimitive.Arrow
551
554
  {...popperScope}
552
555
  {...arrowProps}
553
- className={tx('popover.arrow', 'popover__arrow', {}, classNames)}
556
+ className={tx('popover.arrow', {}, classNames)}
554
557
  ref={forwardedRef}
555
558
  />
556
559
  );
@@ -572,15 +575,15 @@ type PopoverViewportProps = ThemedClassName<ComponentPropsWithRef<typeof Primiti
572
575
  const PopoverViewport = forwardRef<HTMLDivElement, PopoverViewportProps>(
573
576
  ({ classNames, asChild, constrainInline = true, constrainBlock = true, children, ...props }, forwardedRef) => {
574
577
  const { tx } = useThemeContext();
575
- const Root = asChild ? Slot : Primitive.div;
578
+ const Comp = asChild ? Slot : Primitive.div;
576
579
  return (
577
- <Root
580
+ <Comp
578
581
  {...props}
579
- className={tx('popover.viewport', 'popover__viewport', { constrainInline, constrainBlock }, classNames)}
582
+ className={tx('popover.viewport', { constrainInline, constrainBlock }, classNames)}
580
583
  ref={forwardedRef}
581
584
  >
582
585
  {children}
583
- </Root>
586
+ </Comp>
584
587
  );
585
588
  },
586
589
  );