@dxos/react-ui 0.8.4-main.72ec0f3 → 0.8.4-main.74a063c4e0

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 (383) hide show
  1. package/dist/lib/browser/chunk-KRSEIVRM.mjs +776 -0
  2. package/dist/lib/browser/chunk-KRSEIVRM.mjs.map +7 -0
  3. package/dist/lib/browser/index.mjs +4157 -67
  4. package/dist/lib/browser/index.mjs.map +4 -4
  5. package/dist/lib/browser/meta.json +1 -1
  6. package/dist/lib/browser/testing/index.mjs +74 -63
  7. package/dist/lib/browser/testing/index.mjs.map +4 -4
  8. package/dist/lib/node-esm/chunk-ENYC4TYH.mjs +778 -0
  9. package/dist/lib/node-esm/chunk-ENYC4TYH.mjs.map +7 -0
  10. package/dist/lib/node-esm/index.mjs +4157 -67
  11. package/dist/lib/node-esm/index.mjs.map +4 -4
  12. package/dist/lib/node-esm/meta.json +1 -1
  13. package/dist/lib/node-esm/testing/index.mjs +74 -63
  14. package/dist/lib/node-esm/testing/index.mjs.map +4 -4
  15. package/dist/types/src/components/Avatars/Avatar.d.ts +1 -1
  16. package/dist/types/src/components/Avatars/Avatar.d.ts.map +1 -1
  17. package/dist/types/src/components/Avatars/Avatar.stories.d.ts.map +1 -1
  18. package/dist/types/src/components/Avatars/AvatarGroup.stories.d.ts.map +1 -1
  19. package/dist/types/src/components/Breadcrumb/Breadcrumb.d.ts.map +1 -1
  20. package/dist/types/src/components/Breadcrumb/Breadcrumb.stories.d.ts.map +1 -1
  21. package/dist/types/src/components/Button/Button.d.ts +3 -3
  22. package/dist/types/src/components/Button/Button.d.ts.map +1 -1
  23. package/dist/types/src/components/Button/Button.stories.d.ts.map +1 -1
  24. package/dist/types/src/components/Button/IconButton.d.ts +2 -1
  25. package/dist/types/src/components/Button/IconButton.d.ts.map +1 -1
  26. package/dist/types/src/components/Button/IconButton.stories.d.ts +3 -0
  27. package/dist/types/src/components/Button/IconButton.stories.d.ts.map +1 -1
  28. package/dist/types/src/components/Button/Toggle.d.ts +2 -2
  29. package/dist/types/src/components/Button/Toggle.d.ts.map +1 -1
  30. package/dist/types/src/components/Button/Toggle.stories.d.ts.map +1 -1
  31. package/dist/types/src/components/Button/ToggleGroup.d.ts +10 -10
  32. package/dist/types/src/components/Button/ToggleGroup.d.ts.map +1 -1
  33. package/dist/types/src/components/Button/ToggleGroup.stories.d.ts +4 -4
  34. package/dist/types/src/components/Button/ToggleGroup.stories.d.ts.map +1 -1
  35. package/dist/types/src/components/Card/Card.d.ts +150 -0
  36. package/dist/types/src/components/Card/Card.d.ts.map +1 -0
  37. package/dist/types/src/components/Card/Card.stories.d.ts +21 -0
  38. package/dist/types/src/components/Card/Card.stories.d.ts.map +1 -0
  39. package/dist/types/src/components/Card/index.d.ts +2 -0
  40. package/dist/types/src/components/Card/index.d.ts.map +1 -0
  41. package/dist/types/src/components/Clipboard/CopyButton.d.ts.map +1 -1
  42. package/dist/types/src/components/Clipboard/index.d.ts +10 -1
  43. package/dist/types/src/components/Clipboard/index.d.ts.map +1 -1
  44. package/dist/types/src/components/DensityProvider/DensityProvider.d.ts +1 -1
  45. package/dist/types/src/components/DensityProvider/DensityProvider.d.ts.map +1 -1
  46. package/dist/types/src/components/Dialog/AlertDialog.d.ts +41 -19
  47. package/dist/types/src/components/Dialog/AlertDialog.d.ts.map +1 -1
  48. package/dist/types/src/components/Dialog/AlertDialog.stories.d.ts.map +1 -1
  49. package/dist/types/src/components/Dialog/Dialog.d.ts +56 -21
  50. package/dist/types/src/components/Dialog/Dialog.d.ts.map +1 -1
  51. package/dist/types/src/components/Dialog/Dialog.stories.d.ts +10 -10
  52. package/dist/types/src/components/Dialog/Dialog.stories.d.ts.map +1 -1
  53. package/dist/types/src/components/ElevationProvider/ElevationProvider.d.ts +1 -1
  54. package/dist/types/src/components/ElevationProvider/ElevationProvider.d.ts.map +1 -1
  55. package/dist/types/src/components/ErrorFallback/ErrorFallback.d.ts +11 -0
  56. package/dist/types/src/components/ErrorFallback/ErrorFallback.d.ts.map +1 -0
  57. package/dist/types/src/components/ErrorFallback/ErrorFallback.stories.d.ts +7 -0
  58. package/dist/types/src/components/ErrorFallback/ErrorFallback.stories.d.ts.map +1 -0
  59. package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts +8 -0
  60. package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts.map +1 -0
  61. package/dist/types/src/components/ErrorFallback/ThrowError.d.ts +9 -0
  62. package/dist/types/src/components/ErrorFallback/ThrowError.d.ts.map +1 -0
  63. package/dist/types/src/components/ErrorFallback/index.d.ts +5 -0
  64. package/dist/types/src/components/ErrorFallback/index.d.ts.map +1 -0
  65. package/dist/types/src/components/Focus/Focus.d.ts +44 -0
  66. package/dist/types/src/components/Focus/Focus.d.ts.map +1 -0
  67. package/dist/types/src/components/Focus/Focus.stories.d.ts +9 -0
  68. package/dist/types/src/components/Focus/Focus.stories.d.ts.map +1 -0
  69. package/dist/types/src/components/Focus/index.d.ts +2 -0
  70. package/dist/types/src/components/Focus/index.d.ts.map +1 -0
  71. package/dist/types/src/components/Icon/Icon.d.ts +4 -1
  72. package/dist/types/src/components/Icon/Icon.d.ts.map +1 -1
  73. package/dist/types/src/components/Icon/Icon.stories.d.ts +11 -3
  74. package/dist/types/src/components/Icon/Icon.stories.d.ts.map +1 -1
  75. package/dist/types/src/components/Image/Image.d.ts +14 -0
  76. package/dist/types/src/components/Image/Image.d.ts.map +1 -0
  77. package/dist/types/src/components/Image/Image.stories.d.ts +33 -0
  78. package/dist/types/src/components/Image/Image.stories.d.ts.map +1 -0
  79. package/dist/types/src/components/Image/index.d.ts +2 -0
  80. package/dist/types/src/components/Image/index.d.ts.map +1 -0
  81. package/dist/types/src/components/Input/Input.d.ts +7 -7
  82. package/dist/types/src/components/Input/Input.d.ts.map +1 -1
  83. package/dist/types/src/components/Input/Input.stories.d.ts +8 -8
  84. package/dist/types/src/components/Input/Input.stories.d.ts.map +1 -1
  85. package/dist/types/src/components/Link/Link.stories.d.ts.map +1 -1
  86. package/dist/types/src/components/List/List.d.ts +10 -4
  87. package/dist/types/src/components/List/List.d.ts.map +1 -1
  88. package/dist/types/src/components/List/List.stories.d.ts +8 -2
  89. package/dist/types/src/components/List/List.stories.d.ts.map +1 -1
  90. package/dist/types/src/components/List/Tree.d.ts.map +1 -1
  91. package/dist/types/src/components/List/Tree.stories.d.ts.map +1 -1
  92. package/dist/types/src/components/List/Treegrid.d.ts +9 -9
  93. package/dist/types/src/components/List/Treegrid.d.ts.map +1 -1
  94. package/dist/types/src/components/List/Treegrid.stories.d.ts.map +1 -1
  95. package/dist/types/src/components/Main/Main.d.ts +9 -10
  96. package/dist/types/src/components/Main/Main.d.ts.map +1 -1
  97. package/dist/types/src/components/Main/Main.stories.d.ts +0 -3
  98. package/dist/types/src/components/Main/Main.stories.d.ts.map +1 -1
  99. package/dist/types/src/components/{Menus → Menu}/ContextMenu.d.ts +6 -6
  100. package/dist/types/src/components/Menu/ContextMenu.d.ts.map +1 -0
  101. package/dist/types/src/components/Menu/ContextMenu.stories.d.ts.map +1 -0
  102. package/dist/types/src/components/Menu/DropdownMenu.d.ts +113 -0
  103. package/dist/types/src/components/Menu/DropdownMenu.d.ts.map +1 -0
  104. package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts +28 -0
  105. package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts.map +1 -0
  106. package/dist/types/src/components/Menu/index.d.ts.map +1 -0
  107. package/dist/types/src/components/Message/Message.d.ts +1 -1
  108. package/dist/types/src/components/Message/Message.d.ts.map +1 -1
  109. package/dist/types/src/components/Message/Message.stories.d.ts +5 -6
  110. package/dist/types/src/components/Message/Message.stories.d.ts.map +1 -1
  111. package/dist/types/src/components/Popover/Popover.d.ts +33 -24
  112. package/dist/types/src/components/Popover/Popover.d.ts.map +1 -1
  113. package/dist/types/src/components/Popover/Popover.stories.d.ts.map +1 -1
  114. package/dist/types/src/components/ScrollArea/ScrollArea.d.ts +32 -24
  115. package/dist/types/src/components/ScrollArea/ScrollArea.d.ts.map +1 -1
  116. package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts +65 -8
  117. package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts.map +1 -1
  118. package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts +48 -13
  119. package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts.map +1 -1
  120. package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts +10 -5
  121. package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts.map +1 -1
  122. package/dist/types/src/components/Select/Select.d.ts +9 -9
  123. package/dist/types/src/components/Select/Select.d.ts.map +1 -1
  124. package/dist/types/src/components/Select/Select.stories.d.ts +2 -2
  125. package/dist/types/src/components/Select/Select.stories.d.ts.map +1 -1
  126. package/dist/types/src/components/Separator/Separator.d.ts +4 -4
  127. package/dist/types/src/components/Separator/Separator.d.ts.map +1 -1
  128. package/dist/types/src/components/Skeleton/Skeleton.d.ts +12 -0
  129. package/dist/types/src/components/Skeleton/Skeleton.d.ts.map +1 -0
  130. package/dist/types/src/components/Skeleton/Skeleton.stories.d.ts +17 -0
  131. package/dist/types/src/components/Skeleton/Skeleton.stories.d.ts.map +1 -0
  132. package/dist/types/src/components/Skeleton/index.d.ts +2 -0
  133. package/dist/types/src/components/Skeleton/index.d.ts.map +1 -0
  134. package/dist/types/src/components/Splitter/Splitter.d.ts +42 -0
  135. package/dist/types/src/components/Splitter/Splitter.d.ts.map +1 -0
  136. package/dist/types/src/components/Splitter/Splitter.stories.d.ts +7 -0
  137. package/dist/types/src/components/Splitter/Splitter.stories.d.ts.map +1 -0
  138. package/dist/types/src/components/Splitter/index.d.ts +2 -0
  139. package/dist/types/src/components/Splitter/index.d.ts.map +1 -0
  140. package/dist/types/src/components/Status/Status.d.ts +3 -4
  141. package/dist/types/src/components/Status/Status.d.ts.map +1 -1
  142. package/dist/types/src/components/Status/Status.stories.d.ts +4 -2
  143. package/dist/types/src/components/Status/Status.stories.d.ts.map +1 -1
  144. package/dist/types/src/components/Tag/Tag.d.ts +1 -1
  145. package/dist/types/src/components/Tag/Tag.d.ts.map +1 -1
  146. package/dist/types/src/components/Tag/Tag.stories.d.ts +0 -5
  147. package/dist/types/src/components/Tag/Tag.stories.d.ts.map +1 -1
  148. package/dist/types/src/components/ThemeProvider/ThemeProvider.d.ts +3 -3
  149. package/dist/types/src/components/ThemeProvider/ThemeProvider.d.ts.map +1 -1
  150. package/dist/types/src/components/{Menus/DropdownMenu.stories.d.ts → ThemeProvider/ThemeProvider.stories.d.ts} +2 -5
  151. package/dist/types/src/components/ThemeProvider/ThemeProvider.stories.d.ts.map +1 -0
  152. package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts +1 -8
  153. package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts.map +1 -1
  154. package/dist/types/src/components/ThemeProvider/index.d.ts +2 -1
  155. package/dist/types/src/components/ThemeProvider/index.d.ts.map +1 -1
  156. package/dist/types/src/components/Toast/Toast.d.ts +19 -19
  157. package/dist/types/src/components/Toast/Toast.d.ts.map +1 -1
  158. package/dist/types/src/components/Toast/Toast.stories.d.ts.map +1 -1
  159. package/dist/types/src/components/Toolbar/Toolbar.d.ts +43 -17
  160. package/dist/types/src/components/Toolbar/Toolbar.d.ts.map +1 -1
  161. package/dist/types/src/components/Toolbar/Toolbar.stories.d.ts.map +1 -1
  162. package/dist/types/src/components/Tooltip/Tooltip.d.ts +9 -9
  163. package/dist/types/src/components/Tooltip/Tooltip.d.ts.map +1 -1
  164. package/dist/types/src/components/Tooltip/Tooltip.stories.d.ts +2 -2
  165. package/dist/types/src/components/Tooltip/Tooltip.stories.d.ts.map +1 -1
  166. package/dist/types/src/components/index.d.ts +10 -5
  167. package/dist/types/src/components/index.d.ts.map +1 -1
  168. package/dist/types/src/exemplars/generics.stories.d.ts +23 -0
  169. package/dist/types/src/exemplars/generics.stories.d.ts.map +1 -0
  170. package/dist/types/src/exemplars/slot.stories.d.ts +15 -0
  171. package/dist/types/src/exemplars/slot.stories.d.ts.map +1 -0
  172. package/dist/types/src/exemplars/tabster.stories.d.ts +8 -0
  173. package/dist/types/src/exemplars/tabster.stories.d.ts.map +1 -0
  174. package/dist/types/src/exemplars/virtualizer.stories.d.ts +11 -0
  175. package/dist/types/src/exemplars/virtualizer.stories.d.ts.map +1 -0
  176. package/dist/types/src/hooks/index.d.ts +1 -0
  177. package/dist/types/src/hooks/index.d.ts.map +1 -1
  178. package/dist/types/src/hooks/useDensityContext.d.ts +2 -2
  179. package/dist/types/src/hooks/useDensityContext.d.ts.map +1 -1
  180. package/dist/types/src/hooks/useElevationContext.d.ts +1 -1
  181. package/dist/types/src/hooks/useElevationContext.d.ts.map +1 -1
  182. package/dist/types/src/index.d.ts +2 -1
  183. package/dist/types/src/index.d.ts.map +1 -1
  184. package/dist/types/src/playground/Controls.stories.d.ts.map +1 -1
  185. package/dist/types/src/playground/Custom.stories.d.ts.map +1 -1
  186. package/dist/types/src/primitives/Column/Column.d.ts +51 -0
  187. package/dist/types/src/primitives/Column/Column.d.ts.map +1 -0
  188. package/dist/types/src/primitives/Column/Column.stories.d.ts +25 -0
  189. package/dist/types/src/primitives/Column/Column.stories.d.ts.map +1 -0
  190. package/dist/types/src/primitives/Column/index.d.ts +2 -0
  191. package/dist/types/src/primitives/Column/index.d.ts.map +1 -0
  192. package/dist/types/src/primitives/Container/Container.d.ts +11 -0
  193. package/dist/types/src/primitives/Container/Container.d.ts.map +1 -0
  194. package/dist/types/src/primitives/Container/Container.stories.d.ts +6 -0
  195. package/dist/types/src/primitives/Container/Container.stories.d.ts.map +1 -0
  196. package/dist/types/src/primitives/Container/index.d.ts +2 -0
  197. package/dist/types/src/primitives/Container/index.d.ts.map +1 -0
  198. package/dist/types/src/primitives/Flex/Flex.d.ts +15 -0
  199. package/dist/types/src/primitives/Flex/Flex.d.ts.map +1 -0
  200. package/dist/types/src/primitives/Flex/Flex.stories.d.ts +8 -0
  201. package/dist/types/src/primitives/Flex/Flex.stories.d.ts.map +1 -0
  202. package/dist/types/src/primitives/Flex/index.d.ts +2 -0
  203. package/dist/types/src/primitives/Flex/index.d.ts.map +1 -0
  204. package/dist/types/src/primitives/Grid/Grid.d.ts +14 -0
  205. package/dist/types/src/primitives/Grid/Grid.d.ts.map +1 -0
  206. package/dist/types/src/primitives/Grid/Grid.stories.d.ts +8 -0
  207. package/dist/types/src/primitives/Grid/Grid.stories.d.ts.map +1 -0
  208. package/dist/types/src/primitives/Grid/index.d.ts +2 -0
  209. package/dist/types/src/primitives/Grid/index.d.ts.map +1 -0
  210. package/dist/types/src/primitives/Panel/Panel.d.ts +51 -0
  211. package/dist/types/src/primitives/Panel/Panel.d.ts.map +1 -0
  212. package/dist/types/src/primitives/Panel/Panel.stories.d.ts +6 -0
  213. package/dist/types/src/primitives/Panel/Panel.stories.d.ts.map +1 -0
  214. package/dist/types/src/primitives/Panel/index.d.ts +2 -0
  215. package/dist/types/src/primitives/Panel/index.d.ts.map +1 -0
  216. package/dist/types/src/primitives/index.d.ts +6 -0
  217. package/dist/types/src/primitives/index.d.ts.map +1 -0
  218. package/dist/types/src/testing/Loading.d.ts +9 -0
  219. package/dist/types/src/testing/Loading.d.ts.map +1 -0
  220. package/dist/types/src/testing/decorators/withLayout.d.ts +3 -3
  221. package/dist/types/src/testing/decorators/withLayout.d.ts.map +1 -1
  222. package/dist/types/src/testing/decorators/withLayoutVariants.d.ts +1 -1
  223. package/dist/types/src/testing/decorators/withLayoutVariants.d.ts.map +1 -1
  224. package/dist/types/src/testing/decorators/withTheme.d.ts +3 -2
  225. package/dist/types/src/testing/decorators/withTheme.d.ts.map +1 -1
  226. package/dist/types/src/testing/index.d.ts +1 -0
  227. package/dist/types/src/testing/index.d.ts.map +1 -1
  228. package/dist/types/src/translations.d.ts +11 -0
  229. package/dist/types/src/translations.d.ts.map +1 -0
  230. package/dist/types/src/util/index.d.ts +1 -2
  231. package/dist/types/src/util/index.d.ts.map +1 -1
  232. package/dist/types/src/util/usePx.d.ts.map +1 -1
  233. package/dist/types/tsconfig.tsbuildinfo +1 -1
  234. package/package.json +42 -32
  235. package/src/components/Avatars/Avatar.stories.tsx +7 -9
  236. package/src/components/Avatars/Avatar.tsx +7 -15
  237. package/src/components/Avatars/AvatarGroup.stories.tsx +2 -3
  238. package/src/components/Breadcrumb/Breadcrumb.stories.tsx +3 -4
  239. package/src/components/Breadcrumb/Breadcrumb.tsx +11 -37
  240. package/src/components/Button/Button.stories.tsx +3 -4
  241. package/src/components/Button/Button.tsx +12 -26
  242. package/src/components/Button/IconButton.stories.tsx +8 -6
  243. package/src/components/Button/IconButton.tsx +9 -6
  244. package/src/components/Button/Toggle.stories.tsx +2 -3
  245. package/src/components/Button/Toggle.tsx +4 -4
  246. package/src/components/Button/ToggleGroup.stories.tsx +2 -3
  247. package/src/components/Button/ToggleGroup.tsx +12 -16
  248. package/src/components/Card/Card.stories.tsx +151 -0
  249. package/src/components/Card/Card.tsx +492 -0
  250. package/src/components/Card/index.ts +5 -0
  251. package/src/components/Clipboard/CopyButton.tsx +7 -8
  252. package/src/components/DensityProvider/DensityProvider.tsx +1 -1
  253. package/src/components/Dialog/AlertDialog.stories.tsx +16 -17
  254. package/src/components/Dialog/AlertDialog.tsx +123 -82
  255. package/src/components/Dialog/Dialog.stories.tsx +138 -28
  256. package/src/components/Dialog/Dialog.tsx +197 -71
  257. package/src/components/ElevationProvider/ElevationProvider.tsx +1 -1
  258. package/src/components/ErrorFallback/ErrorFallback.stories.tsx +45 -0
  259. package/src/components/ErrorFallback/ErrorFallback.tsx +70 -0
  260. package/src/components/ErrorFallback/ErrorStack.tsx +80 -0
  261. package/src/components/ErrorFallback/ThrowError.tsx +37 -0
  262. package/src/components/ErrorFallback/index.ts +9 -0
  263. package/src/components/Focus/AUDIT.md +43 -0
  264. package/src/components/Focus/Focus.stories.tsx +230 -0
  265. package/src/components/Focus/Focus.tsx +201 -0
  266. package/src/components/Focus/index.ts +5 -0
  267. package/src/components/Icon/Icon.stories.tsx +45 -15
  268. package/src/components/Icon/Icon.tsx +7 -3
  269. package/src/components/Image/Image.stories.tsx +86 -0
  270. package/src/components/Image/Image.tsx +223 -0
  271. package/src/components/Image/index.ts +5 -0
  272. package/src/components/Input/Input.stories.tsx +21 -41
  273. package/src/components/Input/Input.tsx +36 -72
  274. package/src/components/Link/Link.stories.tsx +2 -3
  275. package/src/components/Link/Link.tsx +2 -2
  276. package/src/components/List/List.stories.tsx +30 -34
  277. package/src/components/List/List.tsx +17 -21
  278. package/src/components/List/ListDropIndicator.tsx +7 -7
  279. package/src/components/List/Tree.stories.tsx +5 -6
  280. package/src/components/List/Tree.tsx +0 -1
  281. package/src/components/List/TreeDropIndicator.tsx +6 -6
  282. package/src/components/List/Treegrid.stories.tsx +29 -30
  283. package/src/components/List/Treegrid.tsx +23 -28
  284. package/src/components/Main/Main.stories.tsx +41 -24
  285. package/src/components/Main/Main.tsx +139 -83
  286. package/src/components/{Menus → Menu}/ContextMenu.stories.tsx +2 -3
  287. package/src/components/{Menus → Menu}/ContextMenu.tsx +9 -33
  288. package/src/components/{Menus → Menu}/DropdownMenu.stories.tsx +2 -3
  289. package/src/components/{Menus → Menu}/DropdownMenu.tsx +119 -109
  290. package/src/components/Message/Message.stories.tsx +27 -13
  291. package/src/components/Message/Message.tsx +43 -34
  292. package/src/components/Popover/Popover.stories.tsx +7 -8
  293. package/src/components/Popover/Popover.tsx +97 -92
  294. package/src/components/ScrollArea/ScrollArea.stories.tsx +223 -34
  295. package/src/components/ScrollArea/ScrollArea.tsx +97 -79
  296. package/src/components/ScrollArea/index.ts +1 -1
  297. package/src/components/ScrollContainer/ScrollContainer.stories.tsx +47 -25
  298. package/src/components/ScrollContainer/ScrollContainer.tsx +225 -109
  299. package/src/components/Select/Select.stories.tsx +7 -8
  300. package/src/components/Select/Select.tsx +11 -27
  301. package/src/components/Separator/Separator.tsx +5 -8
  302. package/src/components/Skeleton/Skeleton.stories.tsx +51 -0
  303. package/src/components/Skeleton/Skeleton.tsx +26 -0
  304. package/src/components/Skeleton/index.ts +5 -0
  305. package/src/components/Splitter/Splitter.stories.tsx +83 -0
  306. package/src/components/Splitter/Splitter.tsx +127 -0
  307. package/src/components/Splitter/index.ts +5 -0
  308. package/src/components/Status/Status.stories.tsx +21 -18
  309. package/src/components/Status/Status.tsx +10 -7
  310. package/src/components/Tag/Tag.stories.tsx +6 -12
  311. package/src/components/Tag/Tag.tsx +3 -8
  312. package/src/components/ThemeProvider/ThemeProvider.stories.tsx +31 -0
  313. package/src/components/ThemeProvider/ThemeProvider.tsx +10 -10
  314. package/src/components/ThemeProvider/TranslationsProvider.tsx +1 -16
  315. package/src/components/ThemeProvider/index.ts +3 -3
  316. package/src/components/Toast/Toast.stories.tsx +2 -3
  317. package/src/components/Toast/Toast.tsx +22 -41
  318. package/src/components/Toolbar/Toolbar.stories.tsx +2 -3
  319. package/src/components/Toolbar/Toolbar.tsx +185 -23
  320. package/src/components/Tooltip/Tooltip.stories.tsx +20 -19
  321. package/src/components/Tooltip/Tooltip.tsx +40 -38
  322. package/src/components/index.ts +11 -6
  323. package/src/exemplars/generics.stories.tsx +41 -0
  324. package/src/exemplars/slot.stories.tsx +117 -0
  325. package/src/exemplars/tabster.stories.tsx +127 -0
  326. package/src/exemplars/virtualizer.stories.tsx +137 -0
  327. package/src/hooks/index.ts +1 -0
  328. package/src/hooks/useDensityContext.ts +3 -3
  329. package/src/hooks/useElevationContext.ts +1 -1
  330. package/src/index.ts +2 -1
  331. package/src/playground/Controls.stories.tsx +3 -10
  332. package/src/playground/Custom.stories.tsx +11 -21
  333. package/src/playground/Typography.stories.tsx +3 -3
  334. package/src/primitives/Column/AUDIT.md +354 -0
  335. package/src/primitives/Column/Column.stories.tsx +182 -0
  336. package/src/primitives/Column/Column.tsx +169 -0
  337. package/src/primitives/Column/index.ts +5 -0
  338. package/src/primitives/Container/Container.stories.tsx +29 -0
  339. package/src/primitives/Container/Container.tsx +19 -0
  340. package/src/primitives/Container/index.ts +5 -0
  341. package/src/primitives/Flex/Flex.stories.tsx +57 -0
  342. package/src/primitives/Flex/Flex.tsx +27 -0
  343. package/src/primitives/Flex/index.ts +5 -0
  344. package/src/primitives/Grid/Grid.stories.tsx +56 -0
  345. package/src/primitives/Grid/Grid.tsx +30 -0
  346. package/src/primitives/Grid/index.ts +5 -0
  347. package/src/primitives/Panel/Panel.stories.tsx +68 -0
  348. package/src/primitives/Panel/Panel.tsx +120 -0
  349. package/src/primitives/Panel/index.ts +5 -0
  350. package/src/primitives/index.ts +9 -0
  351. package/src/testing/Loading.tsx +27 -0
  352. package/src/testing/decorators/withLayout.tsx +39 -18
  353. package/src/testing/decorators/withLayoutVariants.tsx +20 -23
  354. package/src/testing/decorators/withTheme.tsx +26 -20
  355. package/src/testing/index.ts +2 -0
  356. package/src/translations.ts +19 -0
  357. package/src/util/index.ts +2 -2
  358. package/src/util/usePx.ts +1 -0
  359. package/dist/lib/browser/chunk-53MI2QCM.mjs +0 -4707
  360. package/dist/lib/browser/chunk-53MI2QCM.mjs.map +0 -7
  361. package/dist/lib/node-esm/chunk-ID67AFFF.mjs +0 -4709
  362. package/dist/lib/node-esm/chunk-ID67AFFF.mjs.map +0 -7
  363. package/dist/types/src/components/AnchoredOverflow/AnchoredOverflow.d.ts +0 -15
  364. package/dist/types/src/components/AnchoredOverflow/AnchoredOverflow.d.ts.map +0 -1
  365. package/dist/types/src/components/AnchoredOverflow/index.d.ts +0 -2
  366. package/dist/types/src/components/AnchoredOverflow/index.d.ts.map +0 -1
  367. package/dist/types/src/components/Menus/ContextMenu.d.ts.map +0 -1
  368. package/dist/types/src/components/Menus/ContextMenu.stories.d.ts.map +0 -1
  369. package/dist/types/src/components/Menus/DropdownMenu.d.ts +0 -113
  370. package/dist/types/src/components/Menus/DropdownMenu.d.ts.map +0 -1
  371. package/dist/types/src/components/Menus/DropdownMenu.stories.d.ts.map +0 -1
  372. package/dist/types/src/components/Menus/index.d.ts.map +0 -1
  373. package/dist/types/src/util/ThemedClassName.d.ts +0 -5
  374. package/dist/types/src/util/ThemedClassName.d.ts.map +0 -1
  375. package/dist/types/src/util/domino.d.ts +0 -18
  376. package/dist/types/src/util/domino.d.ts.map +0 -1
  377. package/src/components/AnchoredOverflow/AnchoredOverflow.tsx +0 -59
  378. package/src/components/AnchoredOverflow/index.ts +0 -5
  379. package/src/util/ThemedClassName.ts +0 -7
  380. package/src/util/domino.ts +0 -53
  381. /package/dist/types/src/components/{Menus → Menu}/ContextMenu.stories.d.ts +0 -0
  382. /package/dist/types/src/components/{Menus → Menu}/index.d.ts +0 -0
  383. /package/src/components/{Menus → Menu}/index.ts +0 -0
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["../../../src/index.ts"],
4
- "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nexport { type Resource, type TFunction } from 'i18next';\nexport { Trans } from 'react-i18next';\n\nexport * from '@dxos/react-hooks';\nexport * from '@dxos/react-ui-types';\n\nexport * from './components';\nexport * from './hooks';\nexport * from './util';\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAKA,SAASA,aAAa;AAEtB,cAAc;AACd,cAAc;",
6
- "names": ["Trans"]
3
+ "sources": ["../../../src/index.ts", "../../../src/components/ThemeProvider/index.ts", "../../../src/hooks/useDensityContext.ts", "../../../src/hooks/useIconHref.ts", "../../../src/hooks/useSafeCollisionPadding.ts", "../../../src/hooks/useTranslationsContext.ts", "../../../src/hooks/useVisualViewport.ts", "../../../src/util/usePx.ts", "../../../src/components/Avatars/Avatar.tsx", "../../../src/components/Breadcrumb/Breadcrumb.tsx", "../../../src/components/Icon/Icon.tsx", "../../../src/components/Link/Link.tsx", "../../../src/components/Button/Button.tsx", "../../../src/components/Button/IconButton.tsx", "../../../src/components/Button/Toggle.tsx", "../../../src/components/Button/ToggleGroup.tsx", "../../../src/components/Card/Card.tsx", "../../../src/primitives/Column/Column.tsx", "../../../src/primitives/Container/Container.tsx", "../../../src/primitives/Flex/Flex.tsx", "../../../src/primitives/Grid/Grid.tsx", "../../../src/primitives/Panel/Panel.tsx", "../../../src/components/Image/Image.tsx", "../../../src/components/Toolbar/Toolbar.tsx", "../../../src/translations.ts", "../../../src/components/Menu/ContextMenu.tsx", "../../../src/components/Menu/DropdownMenu.tsx", "../../../src/components/Separator/Separator.tsx", "../../../src/components/Clipboard/ClipboardProvider.tsx", "../../../src/components/Clipboard/CopyButton.tsx", "../../../src/components/Clipboard/index.ts", "../../../src/components/Dialog/Dialog.tsx", "../../../src/components/Dialog/AlertDialog.tsx", "../../../src/components/ErrorFallback/index.ts", "../../../src/components/ErrorFallback/ErrorFallback.tsx", "../../../src/components/ErrorFallback/ErrorStack.tsx", "../../../src/components/ErrorFallback/ThrowError.tsx", "../../../src/components/Focus/Focus.tsx", "../../../src/components/Input/Input.tsx", "../../../src/components/List/List.tsx", "../../../src/components/List/ListDropIndicator.tsx", "../../../src/components/List/Tree.tsx", "../../../src/components/List/TreeDropIndicator.tsx", "../../../src/components/List/Treegrid.tsx", "../../../src/components/Main/Main.tsx", "../../../src/components/Main/useSwipeToDismiss.ts", "../../../src/components/Message/Message.tsx", "../../../src/components/Popover/Popover.tsx", "../../../src/components/Status/Status.tsx", "../../../src/components/ScrollArea/ScrollArea.tsx", "../../../src/components/ScrollContainer/ScrollContainer.tsx", "../../../src/components/Select/Select.tsx", "../../../src/components/Skeleton/Skeleton.tsx", "../../../src/components/Splitter/Splitter.tsx", "../../../src/components/Tag/Tag.tsx", "../../../src/components/Toast/Toast.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nexport { type Resource, type TFunction } from 'i18next';\nexport { Trans } from 'react-i18next';\n\nexport * from '@dxos/react-hooks';\nexport * from '@dxos/ui-types';\n\nexport * from './components';\nexport * from './hooks';\nexport * from './primitives';\nexport * from './util';\n", "//\n// Copyright 2022 DXOS.org\n//\n\nexport { type Label, isLabel, toLocalizedString } from '@dxos/ui-types';\n\nexport * from './ThemeProvider';\nexport { useTranslation } from './TranslationsProvider';\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { useContext } from 'react';\n\nimport { type Density } from '@dxos/ui-types';\n\nimport { DensityContext } from '../components';\n\nexport const useDensityContext = (densityProp?: Density): Density | undefined => {\n const { density } = useContext(DensityContext);\n return densityProp ?? density;\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { useThemeContext } from './useThemeContext';\n\nconst ICONS_URL = '/icons.svg';\n\nexport const useIconHref = (icon?: string) => {\n const { noCache } = useThemeContext();\n const url = noCache ? `${ICONS_URL}?nocache=${new Date().getMinutes()}` : ICONS_URL;\n return icon ? `${url}#${icon}` : undefined;\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type TooltipContentProps } from '@radix-ui/react-tooltip';\nimport { useMemo } from 'react';\n\nimport { type SafeAreaPadding } from './useSafeArea';\nimport { useThemeContext } from './useThemeContext';\n\ntype PaddingProp = TooltipContentProps['collisionPadding'];\ntype PaddingRecord = Exclude<PaddingProp, number | undefined>;\n\nconst propIsNumber = (prop: PaddingProp): prop is number => Number.isFinite(prop);\nconst propsIsRecord = (prop: PaddingProp): prop is PaddingRecord => !!(prop && typeof prop === 'object');\n\nconst safePadding = (\n propsPadding: TooltipContentProps['collisionPadding'],\n safePadding: SafeAreaPadding,\n side: keyof SafeAreaPadding,\n) => {\n return (\n (propIsNumber(safePadding[side]) ? safePadding[side] : 0) +\n (propIsNumber(propsPadding) ? propsPadding : propsIsRecord(propsPadding) ? (propsPadding[side] ?? 0) : 0)\n );\n};\n\nexport const useSafeCollisionPadding = (collisionPadding?: PaddingProp) => {\n const { safeAreaPadding } = useThemeContext();\n return useMemo(\n () => ({\n top: safePadding(collisionPadding, safeAreaPadding!, 'top'),\n right: safePadding(collisionPadding, safeAreaPadding!, 'right'),\n bottom: safePadding(collisionPadding, safeAreaPadding!, 'bottom'),\n left: safePadding(collisionPadding, safeAreaPadding!, 'left'),\n }),\n [collisionPadding, safeAreaPadding],\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { useContext } from 'react';\n\nimport { TranslationsContext } from '../components/ThemeProvider/TranslationsProvider';\n\nexport const useTranslationsContext = () => useContext(TranslationsContext);\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { useCallback, useState } from 'react';\n\nimport { useViewportResize } from '@dxos/react-hooks';\n\nexport const useVisualViewport = (deps?: Parameters<typeof useViewportResize>[1]) => {\n const [width, setWidth] = useState<number | null>(null);\n const [height, setHeight] = useState<number | null>(null);\n\n const handleResize = useCallback(() => {\n if (window.visualViewport) {\n setWidth(window.visualViewport.width);\n setHeight(window.visualViewport.height);\n }\n }, []);\n\n useViewportResize(handleResize, deps);\n\n return { width, height };\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { useCallback, useEffect, useMemo, useState } from 'react';\n\nconst getDocumentElementFontSize = () => parseFloat(getComputedStyle(document.documentElement).fontSize);\n\n/**\n * React hook that converts rem values to pixels and updates when the root font size changes.\n *\n * @param rem The rem value to convert to pixels\n * @returns The current pixel value equivalent of the rem input\n */\nexport const usePx = (rem: number): number => {\n const [fontSize, setFontSize] = useState(() => {\n if (typeof document !== 'undefined') {\n return getDocumentElementFontSize();\n }\n\n return 16; // Default fallback for SSR\n });\n\n const updateFontSize = useCallback(() => {\n setFontSize(getDocumentElementFontSize());\n }, []);\n\n useEffect(() => {\n if (typeof document === 'undefined') {\n return;\n }\n\n // Create a ResizeObserver to watch for font size changes on the document element\n const resizeObserver = new ResizeObserver(updateFontSize);\n resizeObserver.observe(document.documentElement);\n\n // Also listen for viewport changes that might affect font size\n const mediaQueryList = window.matchMedia('all');\n const handleMediaChange = () => {\n updateFontSize();\n };\n\n if (mediaQueryList.addEventListener) {\n mediaQueryList.addEventListener('change', handleMediaChange);\n } else {\n // Fallback for older browsers\n mediaQueryList.addListener(handleMediaChange);\n }\n\n return () => {\n resizeObserver.disconnect();\n if (mediaQueryList.removeEventListener) {\n mediaQueryList.removeEventListener('change', handleMediaChange);\n } else {\n // Fallback for older browsers\n mediaQueryList.removeListener(handleMediaChange);\n }\n };\n }, []);\n\n return useMemo(() => rem * fontSize, [fontSize]);\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { createContext } from '@radix-ui/react-context';\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slot } from '@radix-ui/react-slot';\nimport React, { type ComponentProps, type ComponentPropsWithRef, type PropsWithChildren, forwardRef } from 'react';\n\nimport '@dxos/lit-ui/dx-avatar.pcss';\nimport {\n type AvatarAnimation,\n type AvatarStatus,\n type AvatarVariant,\n type DxAvatar as NaturalDxAvatar,\n} from '@dxos/lit-ui';\nimport { DxAvatar } from '@dxos/lit-ui/react';\nimport { useId } from '@dxos/react-hooks';\nimport { mx } from '@dxos/ui-theme';\n\nimport { useIconHref, useThemeContext } from '../../hooks';\nimport { type ThemedClassName } from '../../util';\n\nexport type AvatarRootProps = PropsWithChildren<Partial<AvatarContextValue>>;\n\ntype AvatarContextValue = {\n labelId: string;\n descriptionId: string;\n};\n\nconst AVATAR_NAME = 'Avatar';\nconst [AvatarProvider, useAvatarContext] = createContext<AvatarContextValue>(AVATAR_NAME);\n\nconst AvatarRoot = ({ children, labelId: propsLabelId, descriptionId: propsDescriptionId }: AvatarRootProps) => {\n const labelId = useId('avatar__label', propsLabelId);\n const descriptionId = useId('avatar__description', propsDescriptionId);\n return <AvatarProvider {...{ labelId, descriptionId }}>{children}</AvatarProvider>;\n};\n\ntype AvatarContentProps = ThemedClassName<Omit<ComponentProps<typeof DxAvatar>, 'children'>>;\n\nconst AvatarContent = forwardRef<NaturalDxAvatar, AvatarContentProps>(\n ({ icon, classNames, ...props }, forwardedRef) => {\n const href = useIconHref(icon);\n const { labelId, descriptionId } = useAvatarContext('AvatarContent');\n return (\n <DxAvatar\n {...props}\n icon={href}\n aria-labelledby={labelId}\n aria-describedby={descriptionId}\n rootClassName={mx(classNames)}\n ref={forwardedRef}\n />\n );\n },\n);\n\ntype AvatarLabelProps = ThemedClassName<Omit<ComponentPropsWithRef<typeof Primitive.span>, 'id'>> & {\n asChild?: boolean;\n srOnly?: boolean;\n};\n\nconst AvatarLabel = forwardRef<HTMLSpanElement, AvatarLabelProps>(\n ({ asChild, srOnly, classNames, ...props }, forwardedRef) => {\n const Comp = asChild ? Slot : Primitive.span;\n const { tx } = useThemeContext();\n const { labelId } = useAvatarContext('AvatarLabel');\n return <Comp {...props} id={labelId} ref={forwardedRef} className={tx('avatar.label', { srOnly }, classNames)} />;\n },\n);\n\ntype AvatarDescriptionProps = ThemedClassName<Omit<ComponentPropsWithRef<typeof Primitive.span>, 'id'>> & {\n asChild?: boolean;\n srOnly?: boolean;\n};\n\nconst AvatarDescription = forwardRef<HTMLSpanElement, AvatarDescriptionProps>(\n ({ asChild, srOnly, classNames, ...props }, forwardedRef) => {\n const Comp = asChild ? Slot : Primitive.span;\n const { tx } = useThemeContext();\n const { descriptionId } = useAvatarContext('AvatarDescription');\n return (\n <Comp\n {...props}\n id={descriptionId}\n ref={forwardedRef}\n className={tx('avatar.description', { srOnly }, classNames)}\n />\n );\n },\n);\n\nexport const Avatar = {\n Root: AvatarRoot,\n Content: AvatarContent,\n Label: AvatarLabel,\n Description: AvatarDescription,\n};\n\nexport { useAvatarContext };\n\nexport type {\n AvatarStatus,\n AvatarVariant,\n AvatarAnimation,\n AvatarContentProps,\n AvatarLabelProps,\n AvatarDescriptionProps,\n NaturalDxAvatar as DxAvatar,\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slot } from '@radix-ui/react-slot';\nimport React, { type ComponentPropsWithRef, type ComponentPropsWithoutRef, forwardRef } from 'react';\n\nimport { useThemeContext } from '../../hooks';\nimport { type ThemedClassName } from '../../util';\nimport { Icon } from '../Icon';\nimport { Link, type LinkProps } from '../Link';\n\ntype BreadcrumbRootProps = ThemedClassName<ComponentPropsWithRef<typeof Primitive.div>> & {\n 'aria-label': string;\n asChild?: boolean;\n};\n\nconst BreadcrumbRoot = forwardRef<HTMLDivElement, BreadcrumbRootProps>(\n ({ asChild, classNames, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const Comp = asChild ? Slot : Primitive.div;\n return <Comp role='navigation' {...props} className={tx('breadcrumb.root', {}, classNames)} ref={forwardedRef} />;\n },\n);\n\ntype BreadcrumbListProps = ThemedClassName<ComponentPropsWithRef<typeof Primitive.ol>> & { asChild?: boolean };\n\nconst BreadcrumbList = forwardRef<HTMLOListElement, BreadcrumbListProps>(\n ({ asChild, classNames, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const Comp = asChild ? Slot : Primitive.ol;\n return <Comp role='list' {...props} className={tx('breadcrumb.list', {}, classNames)} ref={forwardedRef} />;\n },\n);\n\ntype BreadcrumbListItemProps = ThemedClassName<ComponentPropsWithRef<typeof Primitive.li>> & { asChild?: boolean };\n\nconst BreadcrumbListItem = forwardRef<HTMLLIElement, BreadcrumbListItemProps>(\n ({ asChild, classNames, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const Comp = asChild ? Slot : Primitive.li;\n return <Comp role='listitem' {...props} className={tx('breadcrumb.listItem', {}, classNames)} ref={forwardedRef} />;\n },\n);\n\ntype BreadcrumbLinkProps = LinkProps;\n\nconst BreadcrumbLink = forwardRef<HTMLAnchorElement, BreadcrumbLinkProps>(({ asChild, ...props }, forwardedRef) => {\n const Comp = asChild ? Slot : Link;\n return <Comp {...props} ref={forwardedRef} />;\n});\n\ntype BreadcrumbCurrentProps = ThemedClassName<ComponentPropsWithRef<'h1'>> & { asChild?: boolean };\n\nconst BreadcrumbCurrent = forwardRef<HTMLHeadingElement, BreadcrumbCurrentProps>(\n ({ asChild, classNames, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const Comp = asChild ? Slot : 'h1';\n return (\n <Comp {...props} aria-current='page' className={tx('breadcrumb.current', {}, classNames)} ref={forwardedRef} />\n );\n },\n);\n\ntype BreadcrumbSeparatorProps = ThemedClassName<ComponentPropsWithoutRef<typeof Primitive.span>>;\n\nconst BreadcrumbSeparator = ({ children, classNames, ...props }: BreadcrumbSeparatorProps) => {\n const { tx } = useThemeContext();\n return (\n <Primitive.span\n role='separator'\n aria-hidden='true'\n {...props}\n className={tx('breadcrumb.separator', {}, classNames)}\n >\n {children ?? <Icon icon='ph--dot--bold' />}\n </Primitive.span>\n );\n};\n\nexport const Breadcrumb = {\n Root: BreadcrumbRoot,\n List: BreadcrumbList,\n ListItem: BreadcrumbListItem,\n Link: BreadcrumbLink,\n Current: BreadcrumbCurrent,\n Separator: BreadcrumbSeparator,\n};\n\nexport type {\n BreadcrumbRootProps,\n BreadcrumbListProps,\n BreadcrumbListItemProps,\n BreadcrumbLinkProps,\n BreadcrumbCurrentProps,\n BreadcrumbSeparatorProps,\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { type Primitive } from '@radix-ui/react-primitive';\nimport React, { type ComponentPropsWithRef, forwardRef, memo } from 'react';\n\nimport { type Size } from '@dxos/ui-types';\n\nimport { useIconHref, useThemeContext } from '../../hooks';\nimport { type ThemedClassName } from '../../util';\n\nexport type IconProps = ThemedClassName<ComponentPropsWithRef<typeof Primitive.svg>> & {\n icon: string;\n size?: Size;\n};\n\n/**\n * The Icon's size can be set directly or inherited from the `--dx-icon-size` CSS variable.\n */\nexport const Icon = memo(\n forwardRef<SVGSVGElement, IconProps>(({ icon, classNames, size, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const href = useIconHref(icon);\n\n return (\n <svg {...props} className={tx('icon.root', { size }, classNames)} ref={forwardedRef}>\n <use href={href} />\n </svg>\n );\n }),\n);\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slot } from '@radix-ui/react-slot';\nimport React, { type ComponentPropsWithRef, forwardRef } from 'react';\n\nimport { useThemeContext } from '../../hooks';\nimport { type ThemedClassName } from '../../util';\n\nexport type LinkProps = ThemedClassName<ComponentPropsWithRef<typeof Primitive.a>> &\n Partial<{\n asChild: boolean;\n variant: 'accent' | 'neutral';\n }>;\n\nexport const Link = forwardRef<HTMLAnchorElement, LinkProps>(\n ({ asChild, variant, classNames, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const Comp = asChild ? Slot : Primitive.a;\n return <Comp {...props} className={tx('link.root', { variant }, classNames)} ref={forwardedRef} />;\n },\n);\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { createContext } from '@radix-ui/react-context';\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slot } from '@radix-ui/react-slot';\nimport React, { type ComponentPropsWithRef, forwardRef, memo } from 'react';\n\nimport { type Density, type Elevation } from '@dxos/ui-types';\n\nimport { useDensityContext, useElevationContext, useThemeContext } from '../../hooks';\nimport { type ThemedClassName } from '../../util';\n\ntype ButtonProps = ThemedClassName<ComponentPropsWithRef<typeof Primitive.button>> & {\n variant?: 'default' | 'primary' | 'outline' | 'ghost' | 'destructive';\n density?: Density;\n elevation?: Elevation;\n asChild?: boolean;\n};\n\ntype ButtonGroupContextValue = { inGroup?: boolean };\n\nconst BUTTON_GROUP_NAME = 'ButtonGroup';\nconst BUTTON_NAME = 'Button';\n\nconst [ButtonGroupProvider, useButtonGroupContext] = createContext<ButtonGroupContextValue>(BUTTON_GROUP_NAME, {\n inGroup: false,\n});\n\nconst Button = memo(\n forwardRef<HTMLButtonElement, ButtonProps>(\n (\n { classNames, children, density: densityProp, elevation: elevationProp, variant = 'default', asChild, ...props },\n ref,\n ) => {\n const { inGroup } = useButtonGroupContext(BUTTON_NAME);\n const { tx } = useThemeContext();\n const elevation = useElevationContext(elevationProp);\n const density = useDensityContext(densityProp);\n const Comp = asChild ? Slot : Primitive.button;\n return (\n <Comp\n ref={ref}\n {...props}\n data-variant={variant}\n data-density={density}\n data-props={inGroup ? 'grouped' : ''}\n className={tx(\n 'button.root',\n {\n variant,\n inGroup,\n disabled: props.disabled,\n density,\n elevation,\n },\n classNames,\n )}\n {...(props.disabled && { disabled: true })}\n >\n {children}\n </Comp>\n );\n },\n ),\n);\n\nButton.displayName = BUTTON_NAME;\n\ntype ButtonGroupProps = ThemedClassName<ComponentPropsWithRef<typeof Primitive.div>> & {\n elevation?: Elevation;\n asChild?: boolean;\n};\n\nconst ButtonGroup = forwardRef<HTMLDivElement, ButtonGroupProps>(\n ({ children, elevation: propsElevation, classNames, asChild, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const elevation = useElevationContext(propsElevation);\n const Comp = asChild ? Slot : Primitive.div;\n return (\n <Comp role='none' {...props} className={tx('button.group', { elevation }, classNames)} ref={forwardedRef}>\n <ButtonGroupProvider inGroup>{children}</ButtonGroupProvider>\n </Comp>\n );\n },\n);\n\nButtonGroup.displayName = BUTTON_GROUP_NAME;\n\nexport { Button, ButtonGroup, BUTTON_GROUP_NAME, useButtonGroupContext };\n\nexport type { ButtonProps, ButtonGroupProps };\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { forwardRef } from 'react';\n\nimport { useThemeContext } from '../../hooks';\nimport { type ThemedClassName } from '../../util';\nimport { Icon, type IconProps } from '../Icon';\nimport { Tooltip, type TooltipSide } from '../Tooltip';\nimport { Button, type ButtonProps } from './Button';\n\ntype IconButtonProps = Omit<ButtonProps, 'children'> &\n Partial<Pick<IconProps, 'icon' | 'size'>> & {\n label: string;\n noTooltip?: boolean;\n caretDown?: boolean;\n iconOnly?: boolean;\n iconEnd?: boolean;\n iconClassNames?: ThemedClassName<any>['classNames'];\n tooltipSide?: TooltipSide;\n };\n\nconst IconButton = forwardRef<HTMLButtonElement, IconButtonProps>((props, forwardedRef) =>\n props.iconOnly ? (\n <IconOnlyButton {...props} ref={forwardedRef} />\n ) : (\n <LabelledIconButton {...props} ref={forwardedRef} />\n ),\n);\n\nconst IconOnlyButton = forwardRef<HTMLButtonElement, IconButtonProps>(\n ({ noTooltip, tooltipSide, ...props }, forwardedRef) => {\n if (noTooltip) {\n return <LabelledIconButton {...props} ref={forwardedRef} />;\n }\n\n return (\n <Tooltip.Trigger asChild content={props.label} side={tooltipSide}>\n <LabelledIconButton {...props} ref={forwardedRef} />\n </Tooltip.Trigger>\n );\n },\n);\n\nconst LabelledIconButton = forwardRef<HTMLButtonElement, IconButtonProps>(\n (\n { size, icon, iconOnly, iconEnd, iconClassNames, label, caretDown, noTooltip: _, classNames, ...props },\n forwardedRef,\n ) => {\n const { tx } = useThemeContext();\n return (\n <Button {...props} classNames={tx('iconButton.root', { iconOnly }, classNames)} ref={forwardedRef}>\n {icon && !iconEnd && <Icon icon={icon} size={size} classNames={iconClassNames} />}\n <span className={iconOnly ? 'sr-only' : undefined}>{label}</span>\n {icon && iconEnd && <Icon icon={icon} size={size} classNames={iconClassNames} />}\n {caretDown && <Icon size={3} icon='ph--caret-down--bold' />}\n </Button>\n );\n },\n);\n\nexport { IconButton };\n\nexport type { IconButtonProps };\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport * as TogglePrimitive from '@radix-ui/react-toggle';\nimport React, { forwardRef } from 'react';\n\nimport { Button, type ButtonProps } from './Button';\n\ntype ToggleProps = Omit<TogglePrimitive.ToggleProps, 'asChild'> & ButtonProps;\n\nconst Toggle = forwardRef<HTMLButtonElement, ToggleProps>(\n ({ defaultPressed, pressed, onPressedChange, ...props }, forwardedRef) => {\n return (\n <TogglePrimitive.Root {...{ defaultPressed, pressed, onPressedChange }} asChild>\n <Button {...props} ref={forwardedRef} />\n </TogglePrimitive.Root>\n );\n },\n);\n\nexport { Toggle };\nexport type { ToggleProps };\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport * as ToggleGroupPrimitive from '@radix-ui/react-toggle-group';\nimport React, { forwardRef } from 'react';\n\nimport { Button, ButtonGroup, type ButtonGroupProps, type ButtonProps } from './Button';\nimport { IconButton, type IconButtonProps } from './IconButton';\n\ntype ToggleGroupProps =\n | Omit<ToggleGroupPrimitive.ToggleGroupSingleProps, 'className'>\n | Omit<ToggleGroupPrimitive.ToggleGroupMultipleProps, 'className'>;\n\nconst ToggleGroup = forwardRef<HTMLDivElement, ToggleGroupProps & ButtonGroupProps>(\n ({ classNames, children, ...props }, forwardedRef) => {\n return (\n <ToggleGroupPrimitive.Root {...props} asChild>\n <ButtonGroup {...{ classNames, children }} ref={forwardedRef} />\n </ToggleGroupPrimitive.Root>\n );\n },\n);\n\ntype ToggleGroupItemProps = Omit<ToggleGroupPrimitive.ToggleGroupItemProps, 'className'> & ButtonProps;\n\nconst ToggleGroupItem = forwardRef<HTMLButtonElement, ToggleGroupItemProps>(\n ({ variant, elevation, density, classNames, children, ...props }, forwardedRef) => {\n return (\n <ToggleGroupPrimitive.Item {...props} asChild>\n <Button {...{ variant, elevation, density, classNames, children }} ref={forwardedRef} />\n </ToggleGroupPrimitive.Item>\n );\n },\n);\n\ntype ToggleGroupIconItemProps = Omit<ToggleGroupPrimitive.ToggleGroupItemProps, 'className'> & IconButtonProps;\n\nconst ToggleGroupIconItem = forwardRef<HTMLButtonElement, ToggleGroupIconItemProps>(\n ({ variant, label, icon, size, elevation, density, classNames, ...props }, forwardedRef) => {\n return (\n <ToggleGroupPrimitive.Item {...props} asChild>\n <IconButton {...{ variant, elevation, density, classNames, label, icon, size }} ref={forwardedRef} />\n </ToggleGroupPrimitive.Item>\n );\n },\n);\n\nexport { ToggleGroup, ToggleGroupItem, ToggleGroupIconItem };\nexport type { ToggleGroupProps, ToggleGroupItemProps };\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slot } from '@radix-ui/react-slot';\nimport DOMPurify from 'dompurify';\nimport React, {\n CSSProperties,\n MouseEventHandler,\n type PropsWithChildren,\n createContext,\n forwardRef,\n useContext,\n useMemo,\n} from 'react';\n\nimport { composable, composableProps, iconSize, mx, slottable } from '@dxos/ui-theme';\nimport { type Density } from '@dxos/ui-types';\n\nimport { useThemeContext } from '../../hooks';\nimport { Column } from '../../primitives';\nimport { type ThemedClassName } from '../../util';\nimport { Button } from '../Button';\nimport { Icon, type IconProps } from '../Icon';\nimport { Image } from '../Image';\nimport {\n Toolbar,\n ToolbarCloseIconButtonProps,\n ToolbarDragHandleProps,\n type ToolbarMenuItem,\n type ToolbarMenuProps,\n type ToolbarRootProps,\n} from '../Toolbar';\n\n//\n// Context\n//\n\nconst CARD_NAME = 'Card';\n\ntype CardContextValue = {\n menuItems?: CardMenuItem<any>[];\n};\n\n/** @deprecated Use context for menus. */\nconst CardContext = createContext<CardContextValue>({});\n\n//\n// Root\n//\n\nconst CARD_ROOT_NAME = 'Card.Root';\n\ntype CardRootOwnProps = {\n id?: string;\n border?: boolean;\n fullWidth?: boolean;\n density?: Density;\n style?: CSSProperties;\n tabIndex?: number;\n onClick?: MouseEventHandler<HTMLDivElement>;\n 'data-selected'?: boolean;\n 'data-testid'?: string;\n};\n\ntype CardRootProps = CardRootOwnProps;\n\nconst CardRoot = slottable<HTMLDivElement, CardRootOwnProps>(\n ({ children, id, asChild, role, border = true, fullWidth, density, ...props }, forwardedRef) => {\n const { className, ...rest } = composableProps(props);\n const Comp = asChild ? Slot : Primitive.div;\n const { tx } = useThemeContext();\n\n return (\n <Comp\n {...rest}\n {...(id && { 'data-object-id': id })}\n role={role ?? 'group'}\n className={tx('card.root', { border, fullWidth }, className)}\n ref={forwardedRef}\n >\n <Column.Root gutter={density === 'coarse' ? 'lg' : 'md'}>{children}</Column.Root>\n </Comp>\n );\n },\n);\n\nCardRoot.displayName = CARD_ROOT_NAME;\n\n//\n// Toolbar\n//\n\nconst CARD_TOOLBAR_NAME = 'Card.Toolbar';\n\ntype CardToolbarProps = ToolbarRootProps;\n\nconst CardToolbar = composable<HTMLDivElement, CardToolbarProps>(({ children, classNames, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n\n return (\n <Toolbar.Root {...props} style={iconSize(5)} classNames={[tx('card.toolbar', {}), classNames]} ref={forwardedRef}>\n {children}\n </Toolbar.Root>\n );\n});\n\nCardToolbar.displayName = CARD_TOOLBAR_NAME;\n\n//\n// DragHandle\n//\n\nconst CARD_DRAG_HANDLE_NAME = 'Card.DragHandle';\n\ntype CardDragHandleProps = ToolbarDragHandleProps;\n\nconst CardDragHandle = forwardRef<HTMLButtonElement, CardDragHandleProps>((props, forwardedRef) => {\n return (\n <CardIconBlock padding>\n <Toolbar.DragHandle {...props} ref={forwardedRef} />\n </CardIconBlock>\n );\n});\n\nCardDragHandle.displayName = CARD_DRAG_HANDLE_NAME;\n\n//\n// CloseIconButton\n//\n\nconst CARD_CLOSE_ICON_BUTTON_NAME = 'Card.CloseIconButton';\n\ntype CloseIconButtonProps = ToolbarCloseIconButtonProps;\n\nconst CloseIconButton = forwardRef<HTMLButtonElement, CloseIconButtonProps>((props, forwardedRef) => {\n return (\n <CardIconBlock padding>\n <Toolbar.CloseIconButton {...props} ref={forwardedRef} />\n </CardIconBlock>\n );\n});\n\nCloseIconButton.displayName = CARD_CLOSE_ICON_BUTTON_NAME;\n\n//\n// Menu\n//\n\nconst CARD_MENU_NAME = 'Card.Menu';\n\ntype CardMenuItem<T extends any | void = void> = ToolbarMenuItem<T>;\n\ntype CardMenuProps<T extends any | void = void> = ToolbarMenuProps<T>;\n\nconst CardMenu = <T extends any | void = void>({ context, items, ...props }: CardMenuProps<T>) => {\n const { menuItems } = useContext(CardContext) ?? {};\n const combinedItems = [...(items ?? []), ...((menuItems as CardMenuItem<T>[]) ?? [])];\n\n return (\n <CardIconBlock padding>\n <Toolbar.Menu {...props} context={context} items={combinedItems} />\n </CardIconBlock>\n );\n};\n\n(CardMenu as any).displayName = CARD_MENU_NAME;\n\n//\n// Icon\n//\n\nconst CARD_ICON_NAME = 'Card.Icon';\n\nconst CardIcon = (props: IconProps) => {\n return (\n <CardIconBlock>\n <Icon {...props} />\n </CardIconBlock>\n );\n};\n\n(CardIcon as any).displayName = CARD_ICON_NAME;\n\n//\n// IconBlock\n//\n\nconst CARD_ICON_BLOCK_NAME = 'Card.IconBlock';\n\nconst CardIconBlock = forwardRef<HTMLDivElement, ThemedClassName<PropsWithChildren<{ padding?: boolean }>>>(\n ({ classNames, children, padding, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n\n return (\n <div {...props} role='none' className={tx('card.icon-block', { padding }, classNames)} ref={forwardedRef}>\n {children}\n </div>\n );\n },\n);\n\nCardIconBlock.displayName = CARD_ICON_BLOCK_NAME;\n\n//\n// Title\n//\n\nconst CARD_TITLE_NAME = 'Card.Title';\n\nconst CardTitle = slottable<HTMLDivElement>(({ children, asChild, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const { className, ...rest } = composableProps(props, { role: 'heading' });\n const Comp = asChild ? Slot : Primitive.div;\n\n return (\n <Comp {...rest} className={tx('card.title', {}, className)} ref={forwardedRef}>\n {children}\n </Comp>\n );\n});\n\nCardTitle.displayName = CARD_TITLE_NAME;\n\n//\n// Content\n//\n\nconst CARD_CONTENT_NAME = 'Card.Content';\n\nconst CardContent = slottable<HTMLDivElement>(({ children, asChild, ...props }, forwardedRef) => {\n const { className, ...rest } = composableProps(props);\n const Comp = asChild ? Slot : Primitive.div;\n const { tx } = useThemeContext();\n\n return (\n <Comp {...rest} className={tx('card.content', {}, className)} ref={forwardedRef}>\n {children}\n </Comp>\n );\n});\n\nCardContent.displayName = CARD_CONTENT_NAME;\n\n//\n// Row\n//\n\nconst CARD_ROW_NAME = 'Card.Row';\n\ntype CardRowProps = { icon?: string; fullWidth?: boolean };\n\nconst CardRow = composable<HTMLDivElement, CardRowProps>(({ children, icon, ...props }, forwardedRef) => {\n const { className, ...rest } = composableProps(props);\n const { tx } = useThemeContext();\n\n return (\n <Column.Row {...rest} className={tx('card.row', {}, className)} ref={forwardedRef}>\n {(icon && <CardIcon classNames='text-subdued' icon={icon} size={4} />) || <div />}\n {children}\n </Column.Row>\n );\n});\n\nCardRow.displayName = CARD_ROW_NAME;\n\n//\n// Section\n//\n\nconst CARD_SECTION_NAME = 'Card.Section';\n\n/**\n * @deprecated Merge with Card.Row fullWidth\n */\nconst CardSection = slottable<HTMLDivElement>(({ children, asChild, role, ...props }, forwardedRef) => {\n const { className, ...rest } = composableProps(props);\n const Comp = asChild ? Slot : Primitive.div;\n\n return (\n <Comp {...rest} role={role ?? 'none'} className={mx('col-span-full', className)} ref={forwardedRef}>\n {children}\n </Comp>\n );\n});\n\nCardSection.displayName = CARD_SECTION_NAME;\n\n//\n// Heading\n//\n\nconst CARD_HEADING_NAME = 'Card.Heading';\n\ntype CardHeadingProps = { variant?: 'default' | 'subtitle' };\n\n/**\n * @deprecated Use typography.\n */\nconst CardHeading = slottable<HTMLDivElement, CardHeadingProps>(\n ({ children, asChild, role, variant = 'default', ...props }, forwardedRef) => {\n const { className, ...rest } = composableProps(props);\n const Comp = asChild ? Slot : Primitive.div;\n const { tx } = useThemeContext();\n\n return (\n <Comp\n {...rest}\n role={role ?? 'heading'}\n className={tx('card.heading', { variant }, className)}\n ref={forwardedRef}\n >\n {children}\n </Comp>\n );\n },\n);\n\nCardHeading.displayName = CARD_HEADING_NAME;\n\n//\n// Text\n//\n\nconst CARD_TEXT_NAME = 'Card.Text';\n\ntype CardTextProps = { truncate?: boolean; variant?: 'default' | 'description' };\n\nconst CardText = slottable<HTMLDivElement, CardTextProps>(\n ({ children, asChild, role, truncate, variant = 'default', ...props }, forwardedRef) => {\n const { className, ...rest } = composableProps(props);\n const Comp = asChild ? Slot : Primitive.div;\n const { tx } = useThemeContext();\n\n return (\n <Comp {...rest} role={role ?? 'none'} className={tx('card.text', { variant }, className)} ref={forwardedRef}>\n <span className={tx('card.text-span', { variant, truncate })}>{children}</span>\n </Comp>\n );\n },\n);\n\nCardText.displayName = CARD_TEXT_NAME;\n\n//\n// Html\n//\n\nconst CARD_HTML_NAME = 'Card.Html';\n\ntype CardHtmlProps = { html: string; variant?: 'default' | 'description' };\n\n/**\n * Renders sanitized HTML content inside a card text slot.\n * Uses DOMPurify to prevent XSS from untrusted markup (e.g. RSS feed content).\n */\nconst CardHtml = ({ html, variant = 'default', ...props }: CardHtmlProps & ThemedClassName<object>) => {\n const { tx } = useThemeContext();\n const sanitized = useMemo(() => DOMPurify.sanitize(html), [html]);\n\n return (\n <div\n {...props}\n role='none'\n className={tx('card.text', { variant })}\n // eslint-disable-next-line react/no-danger\n dangerouslySetInnerHTML={{ __html: sanitized }}\n />\n );\n};\n\n(CardHtml as any).displayName = CARD_HTML_NAME;\n\n//\n// Poster\n//\n\nconst CARD_POSTER_NAME = 'Card.Poster';\n\ntype CardPosterProps = ThemedClassName<\n {\n alt: string;\n aspect?: 'video' | 'auto';\n } & Partial<{ image: string; icon: string }>\n>;\n\nconst CardPoster = (props: CardPosterProps) => {\n const { tx } = useThemeContext();\n const aspect = props.aspect === 'auto' ? 'aspect-auto' : 'aspect-video';\n\n if (props.image) {\n return (\n <div role='none' className='col-span-full mb-1'>\n <Image classNames={[tx('card.poster', {}), aspect, props.classNames]} src={props.image} alt={props.alt} />\n </div>\n );\n }\n\n if (props.icon) {\n return (\n <div role='image' className={tx('card.poster-icon', {}, [aspect, props.classNames])} aria-label={props.alt}>\n <Icon icon={props.icon} size={10} />\n </div>\n );\n }\n};\n\n(CardPoster as any).displayName = CARD_POSTER_NAME;\n\n//\n// Action\n//\n\nconst CARD_ACTION_NAME = 'Card.Action';\n\ntype CardActionProps = { icon?: string; label: string; actionIcon?: string; onClick?: () => void };\n\nconst CardAction = ({ icon, actionIcon = 'ph--arrow-right--regular', label, onClick }: CardActionProps) => {\n const { tx } = useThemeContext();\n return (\n <Button variant='ghost' classNames={tx('card.action', {})} onClick={onClick}>\n {icon ? <CardIcon classNames='text-subdued' icon={icon} size={4} /> : <div />}\n <span className={tx('card.action-label', {}, !actionIcon ? 'col-span-2' : undefined)}>{label}</span>\n {actionIcon && <CardIcon icon={actionIcon} size={4} />}\n </Button>\n );\n};\n\n(CardAction as any).displayName = CARD_ACTION_NAME;\n\n//\n// Link\n//\n\nconst CARD_LINK_NAME = 'Card.Link';\n\ntype CardLinkProps = { label: string; href: string };\n\nconst CardLink = ({ label, href }: CardLinkProps) => {\n const { tx } = useThemeContext();\n return (\n <a className={tx('card.link', {})} data-variant='ghost' href={href} target='_blank' rel='noreferrer'>\n <CardIcon classNames='text-subdued' icon='ph--link--regular' />\n <span className={tx('card.link-label', {})}>{label}</span>\n <CardIcon classNames='invisible group-hover:visible' icon='ph--arrow-square-out--regular' />\n </a>\n );\n};\n\n(CardLink as any).displayName = CARD_LINK_NAME;\n\n//\n// Card\n//\n\nexport const Card = {\n Root: CardRoot,\n\n // Toolbar\n Toolbar: CardToolbar,\n ToolbarIconButton: Toolbar.IconButton,\n ToolbarSeparator: Toolbar.Separator,\n\n // Toolbar blocks\n IconBlock: CardIconBlock,\n DragHandle: CardDragHandle,\n CloseIconButton: CloseIconButton,\n Menu: CardMenu,\n Icon: CardIcon,\n Title: CardTitle,\n\n // Content\n Content: CardContent,\n Row: CardRow,\n Section: CardSection,\n Heading: CardHeading,\n Text: CardText,\n Html: CardHtml,\n Poster: CardPoster,\n Action: CardAction,\n Link: CardLink,\n};\n\nexport type {\n CardContextValue,\n CardRootProps,\n CardToolbarProps,\n CardDragHandleProps,\n CloseIconButtonProps,\n CardMenuProps,\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slot } from '@radix-ui/react-slot';\nimport React, { type CSSProperties } from 'react';\n\nimport { type ColumnStyleProps, composableProps, slottable } from '@dxos/ui-theme';\nimport { type SlottableProps } from '@dxos/ui-types';\n\nimport { ScrollArea, type ScrollAreaRootProps } from '../../components';\nimport { useThemeContext } from '../../hooks';\n\n//\n// Root\n//\n\nconst COLUMN_ROOT_NAME = 'Column.Root';\n\ntype GutterSize = 'xs' | 'sm' | 'md' | 'lg';\n\nconst gutterSizes: Record<GutterSize, string> = {\n xs: 'var(--dx-gutter-xs)',\n sm: 'var(--dx-gutter-sm)',\n md: 'var(--dx-gutter-md)',\n lg: 'var(--dx-gutter-lg)',\n};\n\ntype ColumnRootProps = { gutter?: GutterSize };\n\n/**\n * Creates a 3-column CSS grid with left/right gutter columns and a center content column.\n * Sets the `--gutter` CSS variable for nested components.\n *\n * Direct children participate in the grid in one of three ways:\n * - **Column.Row** — 3-col subgrid row (icons in gutters, content in center).\n * - **Column.Content** — spans full width; re-applies gutters as `px-[var(--gutter)]` padding.\n * Sets `--gutter-offset` so nested ScrollAreas can break out of the padding.\n * - **Column.Viewport** — spans full width; delegates gutters to ScrollArea.\n *\n * Gutter sizes: `'sm'` for compact layouts (Dialog); `'md'` (default); `'lg'` for wider spacing.\n */\nconst ColumnRoot = slottable<HTMLDivElement, ColumnRootProps>(\n ({ children, asChild, role, gutter = 'md', ...props }, forwardedRef) => {\n const { className, ...rest } = composableProps(props);\n const Comp = asChild ? Slot : Primitive.div;\n const { tx } = useThemeContext();\n const gutterSize = gutterSizes[gutter];\n return (\n <Comp\n {...rest}\n role={role ?? 'none'}\n style={\n {\n '--gutter': gutterSize,\n gridTemplateColumns: [gutterSize, 'minmax(0,1fr)', gutterSize].join(' '),\n } as CSSProperties\n }\n className={tx('column.root', { gutter }, className)}\n ref={forwardedRef}\n >\n {children}\n </Comp>\n );\n },\n);\n\nColumnRoot.displayName = COLUMN_ROOT_NAME;\n\n//\n// Row\n//\n\nconst COLUMN_ROW_NAME = 'Column.Row';\n\ntype ColumnRowProps = ColumnStyleProps;\n\n/**\n * Spans all 3 columns of the parent Column.Root and uses CSS subgrid to inherit their sizing.\n * Children map to: [col-1: icon/slot] [col-2: content] [col-3: icon/action].\n * Must be a direct child of Column.Root.\n */\nconst ColumnRow = slottable<HTMLDivElement, ColumnRowProps>(\n ({ children, asChild, role, fullWidth, center, ...props }, forwardedRef) => {\n const { className, ...rest } = composableProps(props);\n const Comp = asChild ? Slot : Primitive.div;\n const { tx } = useThemeContext();\n return (\n <Comp\n {...rest}\n role={role ?? 'none'}\n className={tx('column.row', { fullWidth, center }, className)}\n ref={forwardedRef}\n >\n {children}\n </Comp>\n );\n },\n);\n\nColumnRow.displayName = COLUMN_ROW_NAME;\n\n//\n// Content\n//\n\nconst COLUMN_CONTENT_NAME = 'Column.Content';\n\ntype ColumnContentProps = SlottableProps;\n\n/**\n * Full-width content area that inherits Column.Root's 3-column grid via CSS subgrid.\n * Non-scrolling children default to the center column (between gutters).\n * ScrollArea children span all 3 columns via `[.dx-column_&]:col-span-full`.\n */\nconst ColumnContent = slottable<HTMLDivElement>(({ children, asChild, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const { className, ...rest } = composableProps(props);\n const Comp = asChild ? Slot : Primitive.div;\n return (\n <Comp {...rest} className={tx('column.content', {}, className)} ref={forwardedRef}>\n {children}\n </Comp>\n );\n});\n\nColumnContent.displayName = COLUMN_CONTENT_NAME;\n\n//\n// Viewport\n//\n\nconst COLUMN_VIEWPORT_NAME = 'Column.Viewport';\n\ntype ColumnViewportProps = Pick<ScrollAreaRootProps, 'thin'>;\n\nconst ColumnViewport = slottable<HTMLDivElement, ColumnViewportProps>(\n ({ children, asChild, role, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const { className, ...rest } = composableProps(props);\n return (\n <ScrollArea.Root\n {...rest}\n className={tx('column.viewport', {}, className)}\n orientation='vertical'\n padding\n ref={forwardedRef}\n >\n <ScrollArea.Viewport>{children}</ScrollArea.Viewport>\n </ScrollArea.Root>\n );\n },\n);\n\nColumnViewport.displayName = COLUMN_VIEWPORT_NAME;\n\n//\n// Column\n//\n\nexport const Column = {\n Root: ColumnRoot,\n Content: ColumnContent,\n Viewport: ColumnViewport,\n Row: ColumnRow,\n};\n\nexport type { ColumnRootProps, ColumnContentProps, ColumnViewportProps, ColumnRowProps };\n", "//\n// Copyright 2026 DXOS.org\n//\n\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slot } from '@radix-ui/react-slot';\nimport React from 'react';\n\nimport { composableProps, mx, slottable } from '@dxos/ui-theme';\n\nexport const Container = slottable<HTMLDivElement>(({ children, asChild, ...props }, forwardedRef) => {\n const { className, ...rest } = composableProps<HTMLDivElement>(props);\n const Comp = asChild ? Slot : Primitive.div;\n return (\n <Comp {...rest} className={mx('dx-container', className)} ref={forwardedRef}>\n {children}\n </Comp>\n );\n});\n", "//\n// Copyright 2026 DXOS.org\n//\n\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slot } from '@radix-ui/react-slot';\nimport React from 'react';\n\nimport { composableProps, mx, slottable } from '@dxos/ui-theme';\n\nexport type FlexProps = { column?: boolean; grow?: boolean };\n\nexport const Flex = slottable<HTMLDivElement, FlexProps>(\n ({ children, asChild, column, grow, ...props }, forwardedRef) => {\n const { className, ...rest } = composableProps(props);\n const Comp = asChild ? Slot : Primitive.div;\n return (\n <Comp\n ref={forwardedRef}\n {...rest}\n className={mx('flex', column && 'flex-col', grow && 'flex-1 overflow-hidden', className)}\n >\n {children}\n </Comp>\n );\n },\n);\n", "//\n// Copyright 2026 DXOS.org\n//\n\nimport React from 'react';\n\nimport { composable, composableProps, mx } from '@dxos/ui-theme';\n\nexport type GridProps = { cols?: number; rows?: number; grow?: boolean };\n\nexport const Grid = composable<HTMLDivElement, GridProps>(\n ({ children, style, role, cols, rows, grow = true, ...props }, forwardedRef) => {\n const { className, ...rest } = composableProps(props);\n return (\n <div\n ref={forwardedRef}\n {...rest}\n role={role ?? 'none'}\n className={mx('grid overflow-hidden', grow && 'dx-container', className)}\n style={{\n gridTemplateColumns: cols ? `repeat(${cols}, 1fr)` : undefined,\n gridTemplateRows: rows ? `repeat(${rows}, 1fr)` : undefined,\n ...style,\n }}\n >\n {children}\n </div>\n );\n },\n);\n", "//\n// Copyright 2026 DXOS.org\n//\n\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slot } from '@radix-ui/react-slot';\nimport React, { type CSSProperties } from 'react';\n\nimport { composableProps, PanelStyleProps, slottable } from '@dxos/ui-theme';\nimport { type SlottableProps } from '@dxos/ui-types';\n\nimport { useThemeContext } from '../../hooks';\n\n//\n// Root\n//\n\nconst GRID_TEMPLATE_ROWS = 'auto 1fr auto';\nconst GRID_TEMPLATE_AREAS = '\"toolbar\" \"content\" \"statusbar\"';\n\ntype PanelRootProps = SlottableProps<{ style?: CSSProperties }>;\n\nconst PanelRoot = slottable<HTMLDivElement, { style?: CSSProperties }>(\n ({ children, asChild, role, style, ...props }, forwardedRef) => {\n const { className, ...rest } = composableProps(props);\n const Comp = asChild ? Slot : Primitive.div;\n const { tx } = useThemeContext();\n return (\n <Comp\n {...rest}\n role={role ?? 'none'}\n style={{\n gridTemplateRows: GRID_TEMPLATE_ROWS,\n gridTemplateAreas: GRID_TEMPLATE_AREAS,\n ...style,\n }}\n className={tx('panel.root', {}, className)}\n ref={forwardedRef}\n >\n {children}\n </Comp>\n );\n },\n);\n\nPanelRoot.displayName = 'Panel.Root';\n\n//\n// Toolbar\n//\n\ntype PanelToolbarProps = SlottableProps & Pick<PanelStyleProps, 'size'>;\n\nconst PanelToolbar = slottable<HTMLDivElement, Pick<PanelStyleProps, 'size'>>(\n ({ children, asChild, size, ...props }, forwardedRef) => {\n const { className, ...rest } = composableProps(props);\n const Comp = asChild ? Slot : Primitive.div;\n const { tx } = useThemeContext();\n return (\n <Comp {...rest} data-slot='toolbar' className={tx('panel.toolbar', { size }, className)} ref={forwardedRef}>\n {children}\n </Comp>\n );\n },\n);\n\nPanelToolbar.displayName = 'Panel.Toolbar';\n\n//\n// Content\n//\n\ntype PanelContentProps = SlottableProps;\n\nconst PanelContent = slottable<HTMLDivElement>(({ children, asChild, ...props }, forwardedRef) => {\n const { className, ...rest } = composableProps(props);\n const Comp = asChild ? Slot : Primitive.div;\n const { tx } = useThemeContext();\n return (\n <Comp {...rest} data-slot='content' className={tx('panel.content', {}, className)} ref={forwardedRef}>\n {children}\n </Comp>\n );\n});\n\nPanelContent.displayName = 'Panel.Content';\n\n//\n// Statusbar\n//\n\ntype PanelStatusbarProps = SlottableProps & Pick<PanelStyleProps, 'size'>;\n\nconst PanelStatusbar = slottable<HTMLDivElement, Pick<PanelStyleProps, 'size'>>(\n ({ children, asChild, size, ...props }, forwardedRef) => {\n const { className, ...rest } = composableProps(props);\n const Comp = asChild ? Slot : Primitive.div;\n const { tx } = useThemeContext();\n return (\n <Comp {...rest} data-slot='statusbar' className={tx('panel.statusbar', { size }, className)} ref={forwardedRef}>\n {children}\n </Comp>\n );\n },\n);\n\nPanelStatusbar.displayName = 'Panel.Statusbar';\n\n//\n// Panel\n//\n\nexport const Panel = {\n Root: PanelRoot,\n Toolbar: PanelToolbar,\n Content: PanelContent,\n Statusbar: PanelStatusbar,\n};\n\nexport type { PanelRootProps, PanelToolbarProps, PanelContentProps, PanelStatusbarProps };\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { type SyntheticEvent, useCallback, useRef, useState } from 'react';\n\nimport { type ThemedClassName } from '@dxos/react-ui';\nimport { mx } from '@dxos/ui-theme';\n\nconst cache = new Map<string, string>();\n\nexport type ImageProps = ThemedClassName<\n {\n src: string;\n alt?: string;\n crossOrigin?: 'anonymous' | 'use-credentials' | '';\n } & ColorOptions\n>;\n\n// TODO(burdon): Option for neutral background color.\nexport const Image = ({\n classNames,\n src,\n alt = '',\n crossOrigin = 'anonymous',\n sampleSize = 64,\n contrast = 0.9,\n}: ImageProps) => {\n const [crossOriginState, setCrossOriginState] = useState<ImageProps['crossOrigin']>(crossOrigin);\n const [dominantColor, setDominantColor] = useState<string | undefined>(undefined);\n const [imageLoaded, setImageLoaded] = useState<boolean>(false);\n const canvasRef = useRef<HTMLCanvasElement>(null);\n\n // CORS not supported by server.\n const handleImageError = (): void => {\n setCrossOriginState(undefined);\n };\n\n const handleImageLoad = useCallback(\n ({ target }: SyntheticEvent<HTMLImageElement>): void => {\n const rgb = cache.get(src);\n if (rgb) {\n setDominantColor(rgb);\n setImageLoaded(true);\n return;\n }\n\n const img = target as HTMLImageElement;\n if (!canvasRef.current) {\n return;\n }\n\n try {\n const color = extractDominantColor(canvasRef.current, img, { sampleSize, contrast });\n if (color) {\n const rgb = `rgb(${color[0]}, ${color[1]}, ${color[2]})`;\n cache.set(src, rgb);\n setDominantColor(rgb);\n }\n } catch {\n setCrossOriginState(undefined);\n }\n\n setImageLoaded(true);\n },\n [sampleSize, contrast, src],\n );\n\n return (\n <div\n className={mx(`relative flex w-full justify-center overflow-hidden transition-all duration-700`, classNames)}\n style={{\n backgroundColor: dominantColor,\n }}\n >\n {/* Hidden canvas for color extraction. */}\n <canvas ref={canvasRef} style={{ display: 'none' }} aria-hidden='true' />\n\n {/* Background gradient overlay for smooth transition. */}\n <div\n className='absolute inset-0 pointer-events-none'\n style={{\n background: dominantColor\n ? `radial-gradient(circle at center, transparent 30%, ${dominantColor} 100%)`\n : undefined,\n transition: 'opacity 0.7s ease-in-out',\n opacity: 0.5,\n }}\n />\n\n <img\n src={src}\n alt={alt}\n crossOrigin={crossOriginState}\n onError={handleImageError}\n onLoad={handleImageLoad}\n className='z-10 object-contain transition-opacity duration-500'\n style={{\n opacity: imageLoaded ? 1 : 0,\n }}\n />\n </div>\n );\n};\n\ntype ColorOptions = {\n sampleSize?: number;\n contrast?: number;\n};\n\n/**\n * Get dominant color from image (esp. from corners).\n */\nconst extractDominantColor = (\n canvas: HTMLCanvasElement,\n img: HTMLImageElement,\n { sampleSize = 64, contrast = 0.95 }: ColorOptions,\n): [number, number, number] | null => {\n const ctx = canvas.getContext('2d');\n if (!ctx) {\n return null;\n }\n\n // Draw the image scaled down.\n canvas.width = sampleSize;\n canvas.height = sampleSize;\n ctx.drawImage(img, 0, 0, sampleSize, sampleSize);\n\n // Get image data.\n const imageData = ctx.getImageData(0, 0, sampleSize, sampleSize);\n const pixels = imageData.data;\n\n // Check for transparent background.\n if (isTransparent(pixels, sampleSize)) {\n return null;\n }\n\n let r = 0;\n let g = 0;\n let b = 0;\n let totalWeight = 0;\n\n // Define corner sampling areas (e.g., 25% of each dimension from each corner).\n const cornerSize = Math.floor(sampleSize * 0.125);\n\n // Sample only pixels in corner areas.\n for (let y = 0; y < sampleSize; y++) {\n for (let x = 0; x < sampleSize; x++) {\n // Check if pixel is in any corner area.\n const isInTopLeft = x < cornerSize && y < cornerSize;\n const isInTopRight = x >= sampleSize - cornerSize && y < cornerSize;\n const isInBottomLeft = x < cornerSize && y >= sampleSize - cornerSize;\n const isInBottomRight = x >= sampleSize - cornerSize && y >= sampleSize - cornerSize;\n if (!isInTopLeft && !isInTopRight && !isInBottomLeft && !isInBottomRight) {\n continue; // Skip pixels not in corner areas.\n }\n\n const i = (y * sampleSize + x) * 4;\n const red = pixels[i];\n const green = pixels[i + 1];\n const blue = pixels[i + 2];\n const alpha = pixels[i + 3];\n\n // Skip transparent pixels.\n if (alpha === 0) continue;\n\n // Calculate saturation to weight vibrant colors more.\n const max = Math.max(red, green, blue);\n const min = Math.min(red, green, blue);\n const saturation = max === 0 ? 0 : (max - min) / max;\n const weight = 1 + saturation * 2;\n\n r += red * weight;\n g += green * weight;\n b += blue * weight;\n totalWeight += weight;\n }\n }\n\n if (totalWeight > 0) {\n // Slightly darken the color for better contrast.\n r = Math.round(Math.round(r / totalWeight) * contrast);\n g = Math.round(Math.round(g / totalWeight) * contrast);\n b = Math.round(Math.round(b / totalWeight) * contrast);\n return [r, g, b];\n }\n\n return null;\n};\n\n/**\n * Detects if an image has a transparent background by examining edge pixels.\n * @param pixels - Image pixel data from canvas\n * @param sampleSize - Size of the sampled image\n * @param threshold - Percentage threshold for considering background transparent (default: 0.5)\n * @returns True if the image has a transparent background\n */\nconst isTransparent = (pixels: Uint8ClampedArray, sampleSize: number, threshold: number = 0.5): boolean => {\n let edgeTransparentPixels = 0;\n const edgePixels = sampleSize * 4 - 4; // Perimeter minus corners counted twice.\n\n for (let x = 0; x < sampleSize; x++) {\n // Top edge.\n const topIndex = x * 4;\n if (pixels[topIndex + 3] === 0) edgeTransparentPixels++;\n\n // Bottom edge.\n const bottomIndex = ((sampleSize - 1) * sampleSize + x) * 4;\n if (pixels[bottomIndex + 3] === 0) edgeTransparentPixels++;\n }\n\n for (let y = 1; y < sampleSize - 1; y++) {\n // Left edge.\n const leftIndex = y * sampleSize * 4;\n if (pixels[leftIndex + 3] === 0) edgeTransparentPixels++;\n\n // Right edge.\n const rightIndex = (y * sampleSize + sampleSize - 1) * 4;\n if (pixels[rightIndex + 3] === 0) edgeTransparentPixels++;\n }\n\n return edgeTransparentPixels / edgePixels > threshold;\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slot } from '@radix-ui/react-slot';\nimport type { ToggleGroupItemProps as ToggleGroupItemPrimitiveProps } from '@radix-ui/react-toggle-group';\nimport * as ToolbarPrimitive from '@radix-ui/react-toolbar';\nimport React, { forwardRef } from 'react';\nimport { useTranslation } from 'react-i18next';\n\nimport { composable, composableProps, slottable, type ToolbarStyleProps } from '@dxos/ui-theme';\nimport { type SlottableProps } from '@dxos/ui-types';\n\nimport { useThemeContext } from '../../hooks';\nimport { translationKey } from '../../translations';\nimport {\n Button,\n ButtonGroup,\n type ButtonGroupProps,\n type ButtonProps,\n IconButton,\n type IconButtonProps,\n Toggle,\n type ToggleGroupItemProps,\n type ToggleProps,\n} from '../Button';\nimport { Link, type LinkProps } from '../Link';\nimport { DropdownMenu } from '../Menu';\nimport { Separator, type SeparatorProps } from '../Separator';\n\n//\n// Root\n//\n\ntype ToolbarRootProps = ToolbarPrimitive.ToolbarProps & ToolbarStyleProps;\n\nconst ToolbarRoot = composable<HTMLDivElement, ToolbarRootProps>(\n ({ children, density, disabled, layoutManaged, orientation, ...props }, forwardedRef) => {\n const { className, role, ...rest } = composableProps(props);\n const { tx } = useThemeContext();\n\n return (\n <ToolbarPrimitive.Root\n {...rest}\n // Only pass role when explicitly set; radix provides role=\"toolbar\" by default.\n {...(role !== 'none' && { role })}\n orientation={orientation}\n data-arrow-keys={orientation === 'vertical' ? 'up down' : 'left right'}\n className={tx('toolbar.root', { density, disabled, layoutManaged }, className)}\n ref={forwardedRef}\n >\n {children}\n </ToolbarPrimitive.Root>\n );\n },\n);\n\n//\n// Text\n//\n\ntype ToolbarTextProps = SlottableProps;\n\nconst ToolbarText = slottable<HTMLDivElement>(({ children, asChild, ...props }, forwardedRef) => {\n const { className, ...rest } = composableProps(props);\n const Comp = asChild ? Slot : Primitive.div;\n const { tx } = useThemeContext();\n return (\n <Comp {...rest} className={tx('toolbar.text', {}, className)} ref={forwardedRef}>\n {children}\n </Comp>\n );\n});\n\n//\n// Button\n//\n\ntype ToolbarButtonProps = ButtonProps;\n\nconst ToolbarButton = forwardRef<HTMLButtonElement, ToolbarButtonProps>((props, forwardedRef) => {\n return (\n <ToolbarPrimitive.Button asChild>\n <Button {...props} ref={forwardedRef} />\n </ToolbarPrimitive.Button>\n );\n});\n\n//\n// IconButton\n//\n\ntype ToolbarIconButtonProps = IconButtonProps;\n\nconst ToolbarIconButton = forwardRef<HTMLButtonElement, ToolbarIconButtonProps>((props, forwardedRef) => {\n return (\n <ToolbarPrimitive.Button asChild>\n <IconButton {...props} noTooltip ref={forwardedRef} />\n </ToolbarPrimitive.Button>\n );\n});\n\ntype ToolbarToggleProps = ToggleProps;\n\nconst ToolbarToggle = forwardRef<HTMLButtonElement, ToolbarToggleProps>((props, forwardedRef) => {\n return (\n <ToolbarPrimitive.Button asChild>\n <Toggle {...props} ref={forwardedRef} />\n </ToolbarPrimitive.Button>\n );\n});\n\n//\n// Link\n//\n\ntype ToolbarLinkProps = LinkProps;\n\nconst ToolbarLink = forwardRef<HTMLAnchorElement, ToolbarLinkProps>((props, forwardedRef) => {\n return (\n <ToolbarPrimitive.Link asChild>\n <Link {...props} ref={forwardedRef} />\n </ToolbarPrimitive.Link>\n );\n});\n\ntype ToolbarToggleGroupProps = (\n | Omit<ToolbarPrimitive.ToolbarToggleGroupSingleProps, 'className'>\n | Omit<ToolbarPrimitive.ToolbarToggleGroupMultipleProps, 'className'>\n) &\n ButtonGroupProps;\n\n//\n// ToggleGroup\n//\n\nconst ToolbarToggleGroup = forwardRef<HTMLDivElement, ToolbarToggleGroupProps>(\n ({ classNames, children, elevation, ...props }, forwardedRef) => {\n return (\n <ToolbarPrimitive.ToolbarToggleGroup {...props} asChild>\n <ButtonGroup {...{ classNames, children, elevation }} ref={forwardedRef} />\n </ToolbarPrimitive.ToolbarToggleGroup>\n );\n },\n);\n\ntype ToolbarToggleGroupItemProps = ToggleGroupItemProps;\n\nconst ToolbarToggleGroupItem = forwardRef<HTMLButtonElement, ToolbarToggleGroupItemProps>(\n ({ variant, density, elevation, classNames, children, ...props }, forwardedRef) => {\n return (\n <ToolbarPrimitive.ToolbarToggleItem {...props} asChild>\n <Button {...{ variant, density, elevation, classNames, children }} ref={forwardedRef} />\n </ToolbarPrimitive.ToolbarToggleItem>\n );\n },\n);\n\ntype ToolbarToggleGroupIconItemProps = Omit<ToggleGroupItemPrimitiveProps, 'className'> & IconButtonProps;\n\nconst ToolbarToggleGroupIconItem = forwardRef<HTMLButtonElement, ToolbarToggleGroupIconItemProps>(\n ({ variant, density, elevation, classNames, icon, label, iconOnly, ...props }, forwardedRef) => {\n return (\n <ToolbarPrimitive.ToolbarToggleItem {...props} asChild>\n <IconButton\n {...{\n variant,\n density,\n elevation,\n classNames,\n icon,\n label,\n iconOnly,\n }}\n ref={forwardedRef}\n />\n </ToolbarPrimitive.ToolbarToggleItem>\n );\n },\n);\n\n//\n// Separator\n//\n\ntype ToolbarSeparatorProps = SeparatorProps & { variant?: 'gap' | 'line' };\n\nconst ToolbarSeparator = forwardRef<HTMLDivElement, ToolbarSeparatorProps>(\n ({ variant = 'gap', ...props }, forwardedRef) => {\n return variant === 'line' ? (\n <ToolbarPrimitive.Separator asChild>\n <Separator orientation='vertical' {...props} ref={forwardedRef} />\n </ToolbarPrimitive.Separator>\n ) : (\n <ToolbarPrimitive.Separator className='grow' ref={forwardedRef} />\n );\n },\n);\n\n//\n// DragHandle\n//\n\ntype ToolbarDragHandleProps = { testId?: string; label?: string };\n\nconst ToolbarDragHandle = forwardRef<HTMLButtonElement, ToolbarDragHandleProps>(\n ({ testId = 'drag-handle', label }, forwardedRef) => {\n const { t } = useTranslation(translationKey);\n return (\n <ToolbarIconButton\n data-testid={testId}\n tabIndex={-1}\n noTooltip\n iconOnly\n icon='ph--dots-six-vertical--regular'\n variant='ghost'\n label={label ?? t('toolbar-drag-handle.label')}\n classNames='dx-focus-ring-none cursor-pointer'\n disabled={!forwardedRef}\n ref={forwardedRef}\n />\n );\n },\n);\n\n//\n// CloseIconButton\n//\n\ntype ToolbarCloseIconButtonProps = { onClick?: () => void; label?: string };\n\nconst ToolbarCloseIconButton = forwardRef<HTMLButtonElement, ToolbarCloseIconButtonProps>(\n ({ onClick, label }, forwardedRef) => {\n const { t } = useTranslation(translationKey);\n\n return (\n <ToolbarIconButton\n iconOnly\n icon='ph--x--regular'\n variant='ghost'\n label={label ?? t('toolbar-close.label')}\n classNames='cursor-pointer'\n onClick={onClick}\n ref={forwardedRef}\n />\n );\n },\n);\n\n//\n// Menu\n//\n\ntype ToolbarMenuItem<T extends any | void = void> = {\n label: string;\n onClick: (context: T) => void;\n};\n\ntype ToolbarMenuProps<T extends any | void = void> = {\n context?: T;\n items?: ToolbarMenuItem<T>[];\n};\n\n// TODO(burdon): Make slottable.\nconst ToolbarMenu = <T extends any | void = void>({ context, items }: ToolbarMenuProps<T>) => {\n const { t } = useTranslation(translationKey);\n\n return (\n <DropdownMenu.Root>\n <DropdownMenu.Trigger disabled={!items?.length} asChild>\n <ToolbarIconButton\n iconOnly\n variant='ghost'\n icon='ph--dots-three-vertical--regular'\n label={t('toolbar-menu.label')}\n />\n </DropdownMenu.Trigger>\n {(items?.length ?? 0) > 0 && (\n <DropdownMenu.Portal>\n <DropdownMenu.Content>\n <DropdownMenu.Viewport>\n {items?.map(({ label, onClick: onSelect }, index) => (\n <DropdownMenu.Item key={index} onSelect={() => onSelect(context as T)}>\n {label}\n </DropdownMenu.Item>\n ))}\n </DropdownMenu.Viewport>\n <DropdownMenu.Arrow />\n </DropdownMenu.Content>\n </DropdownMenu.Portal>\n )}\n </DropdownMenu.Root>\n );\n};\n\n//\n// Toolbar\n//\n\nexport const Toolbar = {\n Root: ToolbarRoot,\n Text: ToolbarText,\n Button: ToolbarButton,\n IconButton: ToolbarIconButton,\n Link: ToolbarLink,\n Toggle: ToolbarToggle,\n ToggleGroup: ToolbarToggleGroup,\n ToggleGroupItem: ToolbarToggleGroupItem,\n ToggleGroupIconItem: ToolbarToggleGroupIconItem,\n Separator: ToolbarSeparator,\n DragHandle: ToolbarDragHandle,\n CloseIconButton: ToolbarCloseIconButton,\n Menu: ToolbarMenu,\n};\n\nexport type {\n ToolbarRootProps,\n ToolbarTextProps,\n ToolbarButtonProps,\n ToolbarIconButtonProps,\n ToolbarLinkProps,\n ToolbarToggleProps,\n ToolbarToggleGroupProps,\n ToolbarToggleGroupItemProps,\n ToolbarToggleGroupIconItemProps,\n ToolbarSeparatorProps,\n ToolbarDragHandleProps,\n ToolbarCloseIconButtonProps,\n ToolbarMenuItem,\n ToolbarMenuProps,\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { type Resource } from '@dxos/react-ui';\n\nexport const translationKey = '@dxos/react-ui';\n\nexport const translations = [\n {\n 'en-US': {\n [translationKey]: {\n 'toolbar-menu.label': 'Action menu',\n 'toolbar-drag-handle.label': 'Drag to rearrange',\n 'toolbar-close.label': 'Close',\n },\n },\n },\n] as const satisfies Resource[];\n", "//\n// Copyright 2023 DXOS.org\n//\nimport * as ContextMenuPrimitive from '@radix-ui/react-context-menu';\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slot } from '@radix-ui/react-slot';\nimport React, { type ComponentPropsWithRef, forwardRef } from 'react';\n\nimport { useElevationContext, useThemeContext } from '../../hooks';\nimport { useSafeCollisionPadding } from '../../hooks/useSafeCollisionPadding';\nimport { type ThemedClassName } from '../../util';\n\ntype ContextMenuRootProps = ContextMenuPrimitive.ContextMenuProps;\n\nconst ContextMenuRoot = ContextMenuPrimitive.ContextMenu;\n\ntype ContextMenuTriggerProps = ContextMenuPrimitive.ContextMenuTriggerProps;\n\nconst ContextMenuTrigger = ContextMenuPrimitive.Trigger;\n\ntype ContextMenuPortalProps = ContextMenuPrimitive.ContextMenuPortalProps;\n\nconst ContextMenuPortal = ContextMenuPrimitive.Portal;\n\ntype ContextMenuContentProps = ThemedClassName<ContextMenuPrimitive.ContextMenuContentProps> & {\n constrainBlockSize?: boolean;\n};\n\nconst ContextMenuContent = forwardRef<HTMLDivElement, ContextMenuContentProps>(\n ({ classNames, children, collisionPadding = 8, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const elevation = useElevationContext();\n const safeCollisionPadding = useSafeCollisionPadding(collisionPadding);\n return (\n <ContextMenuPrimitive.Content\n {...props}\n data-arrow-keys='up down'\n collisionPadding={safeCollisionPadding}\n className={tx('menu.content', { elevation }, classNames)}\n ref={forwardedRef}\n >\n {children}\n </ContextMenuPrimitive.Content>\n );\n },\n);\n\ntype ContextMenuViewportProps = ThemedClassName<ComponentPropsWithRef<typeof Primitive.div>> & {\n asChild?: boolean;\n};\n\nconst ContextMenuViewport = forwardRef<HTMLDivElement, ContextMenuViewportProps>(\n ({ classNames, asChild, children, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const Comp = asChild ? Slot : Primitive.div;\n return (\n <Comp {...props} className={tx('menu.viewport', {}, classNames)} ref={forwardedRef}>\n {children}\n </Comp>\n );\n },\n);\n\ntype ContextMenuArrowProps = ThemedClassName<ContextMenuPrimitive.ContextMenuArrowProps>;\n\nconst ContextMenuArrow = forwardRef<SVGSVGElement, ContextMenuArrowProps>(({ classNames, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return <ContextMenuPrimitive.Arrow {...props} className={tx('menu.arrow', {}, classNames)} ref={forwardedRef} />;\n});\n\ntype ContextMenuGroupProps = ContextMenuPrimitive.ContextMenuGroupProps;\n\nconst ContextMenuGroup = ContextMenuPrimitive.Group;\n\ntype ContextMenuItemIndicatorProps = ContextMenuPrimitive.ContextMenuItemIndicatorProps;\n\nconst ContextMenuItemIndicator = ContextMenuPrimitive.ItemIndicator;\n\ntype ContextMenuItemProps = ThemedClassName<ContextMenuPrimitive.ContextMenuItemProps>;\n\nconst ContextMenuItem = forwardRef<HTMLDivElement, ContextMenuItemProps>(\n ({ classNames, ...props }: ContextMenuItemProps, forwardedRef) => {\n const { tx } = useThemeContext();\n return <ContextMenuPrimitive.Item {...props} className={tx('menu.item', {}, classNames)} ref={forwardedRef} />;\n },\n);\n\ntype ContextMenuCheckboxItemProps = ThemedClassName<ContextMenuPrimitive.ContextMenuCheckboxItemProps>;\n\nconst ContextMenuCheckboxItem = forwardRef<HTMLDivElement, ContextMenuCheckboxItemProps>(\n ({ classNames, ...props }: ContextMenuItemProps, forwardedRef) => {\n const { tx } = useThemeContext();\n return (\n <ContextMenuPrimitive.CheckboxItem {...props} className={tx('menu.item', {}, classNames)} ref={forwardedRef} />\n );\n },\n);\n\ntype ContextMenuSeparatorProps = ThemedClassName<ContextMenuPrimitive.ContextMenuSeparatorProps>;\n\nconst ContextMenuSeparator = forwardRef<HTMLDivElement, ContextMenuSeparatorProps>(\n ({ classNames, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return (\n <ContextMenuPrimitive.Separator {...props} className={tx('menu.separator', {}, classNames)} ref={forwardedRef} />\n );\n },\n);\n\ntype ContextMenuGroupLabelProps = ThemedClassName<ContextMenuPrimitive.ContextMenuLabelProps>;\n\nconst ContextMenuGroupLabel = forwardRef<HTMLDivElement, ContextMenuGroupLabelProps>(\n ({ classNames, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return (\n <ContextMenuPrimitive.Label {...props} className={tx('menu.groupLabel', {}, classNames)} ref={forwardedRef} />\n );\n },\n);\n\nexport const ContextMenu = {\n Root: ContextMenuRoot,\n Trigger: ContextMenuTrigger,\n Portal: ContextMenuPortal,\n Content: ContextMenuContent,\n Viewport: ContextMenuViewport,\n Arrow: ContextMenuArrow,\n Group: ContextMenuGroup,\n Item: ContextMenuItem,\n CheckboxItem: ContextMenuCheckboxItem,\n ItemIndicator: ContextMenuItemIndicator,\n Separator: ContextMenuSeparator,\n GroupLabel: ContextMenuGroupLabel,\n};\n\nexport type {\n ContextMenuRootProps,\n ContextMenuTriggerProps,\n ContextMenuPortalProps,\n ContextMenuContentProps,\n ContextMenuViewportProps,\n ContextMenuArrowProps,\n ContextMenuGroupProps,\n ContextMenuItemProps,\n ContextMenuCheckboxItemProps,\n ContextMenuItemIndicatorProps,\n ContextMenuSeparatorProps,\n ContextMenuGroupLabelProps,\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\n// This is based upon `@radix-ui/react-dropdown-menu` fetched 25 Oct 2024 at https://github.com/radix-ui/primitives at commit 06de2d4.\n\nimport { composeEventHandlers } from '@radix-ui/primitive';\nimport { composeRefs } from '@radix-ui/react-compose-refs';\nimport { createContextScope } from '@radix-ui/react-context';\nimport type { Scope } from '@radix-ui/react-context';\nimport { useId } from '@radix-ui/react-id';\nimport * as MenuPrimitive from '@radix-ui/react-menu';\nimport { createMenuScope } from '@radix-ui/react-menu';\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slot } from '@radix-ui/react-slot';\nimport { useControllableState } from '@radix-ui/react-use-controllable-state';\nimport React, {\n type ComponentPropsWithRef,\n type ComponentPropsWithoutRef,\n type ComponentRef,\n type FC,\n PropsWithChildren,\n type ReactNode,\n type RefObject,\n forwardRef,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n} from 'react';\n\nimport { useElevationContext, useThemeContext } from '../../hooks';\nimport { useSafeCollisionPadding } from '../../hooks/useSafeCollisionPadding';\nimport { type ThemedClassName } from '../../util';\n\ntype Direction = 'ltr' | 'rtl';\n\n//\n// DropdownMenu\n//\n\nconst DROPDOWN_MENU_NAME = 'DropdownMenu';\n\ntype ScopedProps<P> = P & { __scopeDropdownMenu?: Scope };\nconst [createDropdownMenuContext, createDropdownMenuScope] = createContextScope(DROPDOWN_MENU_NAME, [createMenuScope]);\nconst useMenuScope: (scope?: Scope) => any = createMenuScope();\n\ntype DropdownMenuContextValue = {\n triggerId: string;\n triggerRef: RefObject<HTMLButtonElement | null>;\n contentId: string;\n open: boolean;\n onOpenChange(open: boolean): void;\n onOpenToggle(): void;\n modal: boolean;\n};\n\nconst [DropdownMenuProvider, useDropdownMenuContext] =\n createDropdownMenuContext<DropdownMenuContextValue>(DROPDOWN_MENU_NAME);\n\ntype DropdownMenuRootProps = PropsWithChildren<{\n dir?: Direction;\n modal?: boolean;\n open?: boolean;\n defaultOpen?: boolean;\n onOpenChange?(open: boolean): void;\n}>;\n\nconst DropdownMenuRoot = ({\n __scopeDropdownMenu,\n children,\n dir,\n modal = true,\n open: openProp,\n defaultOpen,\n onOpenChange,\n}: ScopedProps<DropdownMenuRootProps>) => {\n const menuScope = useMenuScope(__scopeDropdownMenu);\n const triggerRef = useRef<HTMLButtonElement | null>(null);\n const [open = false, setOpen] = useControllableState({\n prop: openProp,\n defaultProp: defaultOpen,\n onChange: onOpenChange,\n });\n\n return (\n <DropdownMenuProvider\n scope={__scopeDropdownMenu}\n triggerId={useId()}\n triggerRef={triggerRef}\n contentId={useId()}\n open={open}\n onOpenChange={setOpen}\n onOpenToggle={useCallback(() => setOpen((prevOpen) => !prevOpen), [setOpen])}\n modal={modal}\n >\n <MenuPrimitive.Root {...menuScope} dir={dir} modal={modal} open={open} onOpenChange={setOpen}>\n {children}\n </MenuPrimitive.Root>\n </DropdownMenuProvider>\n );\n};\n\nDropdownMenuRoot.displayName = DROPDOWN_MENU_NAME;\n\n//\n// DropdownMenuTrigger\n//\n\nconst TRIGGER_NAME = 'DropdownMenuTrigger';\n\ntype DropdownMenuTriggerElement = ComponentRef<typeof Primitive.button>;\ntype PrimitiveButtonProps = ComponentPropsWithoutRef<typeof Primitive.button>;\ntype DropdownMenuTriggerProps = PrimitiveButtonProps;\n\nconst DropdownMenuTrigger = forwardRef<DropdownMenuTriggerElement, DropdownMenuTriggerProps>(\n (props: ScopedProps<DropdownMenuTriggerProps>, forwardedRef) => {\n const { __scopeDropdownMenu, disabled = false, ...triggerProps } = props;\n const context = useDropdownMenuContext(TRIGGER_NAME, __scopeDropdownMenu);\n const menuScope = useMenuScope(__scopeDropdownMenu);\n return (\n <MenuPrimitive.Anchor asChild {...menuScope}>\n <Primitive.button\n type='button'\n id={context.triggerId}\n aria-haspopup='menu'\n aria-expanded={context.open}\n aria-controls={context.open ? context.contentId : undefined}\n data-state={context.open ? 'open' : 'closed'}\n data-disabled={disabled ? '' : undefined}\n disabled={disabled}\n {...triggerProps}\n ref={composeRefs(forwardedRef, context.triggerRef)}\n data-arrow-keys='down'\n onPointerDown={composeEventHandlers(props.onPointerDown, (event) => {\n // only call handler if it's the left button (mousedown gets triggered by all mouse buttons)\n // but not when the control key is pressed (avoiding MacOS right click)\n if (!disabled && event.button === 0 && event.ctrlKey === false) {\n context.onOpenToggle();\n // prevent trigger focusing when opening\n // this allows the content to be given focus without competition\n if (!context.open) {\n event.preventDefault();\n }\n }\n })}\n onKeyDown={composeEventHandlers(props.onKeyDown, (event) => {\n if (disabled) {\n return;\n }\n if (['Enter', ' '].includes(event.key)) {\n context.onOpenToggle();\n }\n if (event.key === 'ArrowDown') {\n context.onOpenChange(true);\n }\n // prevent keydown from scrolling window / first focused item to execute\n // that keydown (inadvertently closing the menu)\n if (['Enter', ' ', 'ArrowDown'].includes(event.key)) {\n event.preventDefault();\n }\n })}\n />\n </MenuPrimitive.Anchor>\n );\n },\n);\n\nDropdownMenuTrigger.displayName = TRIGGER_NAME;\n\n//\n// DropdownMenuVirtualTrigger\n//\n\nconst VIRTUAL_TRIGGER_NAME = 'DropdownMenuVirtualTrigger';\n\ntype DropdownMenuVirtualTriggerProps = {\n virtualRef: RefObject<DropdownMenuTriggerElement | null>;\n};\n\nconst DropdownMenuVirtualTrigger = (props: ScopedProps<DropdownMenuVirtualTriggerProps>) => {\n const { __scopeDropdownMenu, virtualRef } = props;\n const context = useDropdownMenuContext(VIRTUAL_TRIGGER_NAME, __scopeDropdownMenu);\n const menuScope = useMenuScope(__scopeDropdownMenu);\n useEffect(() => {\n if (virtualRef.current) {\n context.triggerRef.current = virtualRef.current;\n }\n });\n return <MenuPrimitive.Anchor {...menuScope} virtualRef={virtualRef as RefObject<DropdownMenuTriggerElement>} />;\n};\n\nDropdownMenuVirtualTrigger.displayName = VIRTUAL_TRIGGER_NAME;\n\n//\n// DropdownMenuPortal\n//\n\nconst PORTAL_NAME = 'DropdownMenuPortal';\n\ntype MenuPortalProps = ComponentPropsWithoutRef<typeof MenuPrimitive.Portal>;\ntype DropdownMenuPortalProps = MenuPortalProps;\n\nconst DropdownMenuPortal: FC<DropdownMenuPortalProps> = (props: ScopedProps<DropdownMenuPortalProps>) => {\n const { __scopeDropdownMenu, ...portalProps } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n return <MenuPrimitive.Portal {...menuScope} {...portalProps} />;\n};\n\nDropdownMenuPortal.displayName = PORTAL_NAME;\n\n//\n// DropdownMenuViewport\n//\n\ntype DropdownMenuViewportProps = ThemedClassName<ComponentPropsWithRef<typeof Primitive.div>> & {\n asChild?: boolean;\n};\n\nconst DropdownMenuViewport = forwardRef<HTMLDivElement, DropdownMenuViewportProps>(\n ({ classNames, asChild, children, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const Comp = asChild ? Slot : Primitive.div;\n return (\n <Comp {...props} className={tx('menu.viewport', {}, classNames)} ref={forwardedRef}>\n {children}\n </Comp>\n );\n },\n);\n\n//\n// DropdownMenuContent\n//\n\nconst CONTENT_NAME = 'DropdownMenuContent';\n\ntype DropdownMenuContentElement = ComponentRef<typeof MenuPrimitive.Content>;\ntype MenuContentProps = ThemedClassName<ComponentPropsWithoutRef<typeof MenuPrimitive.Content>>;\ntype DropdownMenuContentProps = Omit<MenuContentProps, 'onEntryFocus'>;\n\nconst DropdownMenuContent = forwardRef<DropdownMenuContentElement, DropdownMenuContentProps>(\n (props: ScopedProps<DropdownMenuContentProps>, forwardedRef) => {\n const { __scopeDropdownMenu, classNames, collisionPadding = 8, collisionBoundary, ...contentProps } = props;\n const { tx } = useThemeContext();\n const context = useDropdownMenuContext(CONTENT_NAME, __scopeDropdownMenu);\n const elevation = useElevationContext();\n const menuScope = useMenuScope(__scopeDropdownMenu);\n const hasInteractedOutsideRef = useRef(false);\n const safeCollisionPadding = useSafeCollisionPadding(collisionPadding);\n\n // Check for the closest annotated collision boundary in the DOM tree.\n const computedCollisionBoundary = useMemo(() => {\n const closestBoundary = context.triggerRef.current?.closest(\n '[data-popover-collision-boundary]',\n ) as HTMLElement | null;\n return closestBoundary\n ? Array.isArray(collisionBoundary)\n ? [closestBoundary, ...collisionBoundary]\n : collisionBoundary\n ? [closestBoundary, collisionBoundary]\n : [closestBoundary]\n : collisionBoundary;\n }, [context.open, collisionBoundary, context.triggerRef.current]);\n\n return (\n <MenuPrimitive.Content\n id={context.contentId}\n aria-labelledby={context.triggerId}\n {...menuScope}\n {...contentProps}\n collisionBoundary={computedCollisionBoundary}\n collisionPadding={safeCollisionPadding}\n ref={forwardedRef}\n onCloseAutoFocus={composeEventHandlers(props.onCloseAutoFocus, (event) => {\n if (!hasInteractedOutsideRef.current) {\n context.triggerRef.current?.focus();\n }\n hasInteractedOutsideRef.current = false;\n // Always prevent auto focus because we either focus manually or want user agent focus\n event.preventDefault();\n })}\n onInteractOutside={composeEventHandlers(props.onInteractOutside, (event) => {\n const originalEvent = event.detail.originalEvent as PointerEvent;\n const ctrlLeftClick = originalEvent.button === 0 && originalEvent.ctrlKey === true;\n const isRightClick = originalEvent.button === 2 || ctrlLeftClick;\n if (!context.modal || isRightClick) {\n hasInteractedOutsideRef.current = true;\n }\n })}\n data-arrow-keys='up down'\n className={tx('menu.content', { elevation }, classNames)}\n style={{\n ...props.style,\n // re-namespace exposed content custom properties\n ...{\n '--radix-dropdown-menu-content-transform-origin': 'var(--radix-popper-transform-origin)',\n '--radix-dropdown-menu-content-available-width': 'var(--radix-popper-available-width)',\n '--radix-dropdown-menu-content-available-height': 'var(--radix-popper-available-height)',\n '--radix-dropdown-menu-trigger-width': 'var(--radix-popper-anchor-width)',\n '--radix-dropdown-menu-trigger-height': 'var(--radix-popper-anchor-height)',\n },\n }}\n />\n );\n },\n);\n\nDropdownMenuContent.displayName = CONTENT_NAME;\n\n//\n// DropdownMenuGroup\n//\n\nconst GROUP_NAME = 'DropdownMenuGroup';\n\ntype DropdownMenuGroupElement = ComponentRef<typeof MenuPrimitive.Group>;\ntype MenuGroupProps = ComponentPropsWithoutRef<typeof MenuPrimitive.Group>;\ntype DropdownMenuGroupProps = MenuGroupProps;\n\nconst DropdownMenuGroup = forwardRef<DropdownMenuGroupElement, DropdownMenuGroupProps>(\n (props: ScopedProps<DropdownMenuGroupProps>, forwardedRef) => {\n const { __scopeDropdownMenu, ...groupProps } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n return <MenuPrimitive.Group {...menuScope} {...groupProps} ref={forwardedRef} />;\n },\n);\n\nDropdownMenuGroup.displayName = GROUP_NAME;\n\n//\n// DropdownMenuLabel\n//\n\nconst LABEL_NAME = 'DropdownMenuLabel';\n\ntype DropdownMenuLabelElement = ComponentRef<typeof MenuPrimitive.Label>;\ntype MenuLabelProps = ThemedClassName<ComponentPropsWithoutRef<typeof MenuPrimitive.Label>>;\ntype DropdownMenuLabelProps = MenuLabelProps;\n\nconst DropdownMenuGroupLabel = forwardRef<DropdownMenuLabelElement, DropdownMenuLabelProps>(\n (props: ScopedProps<DropdownMenuLabelProps>, forwardedRef) => {\n const { __scopeDropdownMenu, classNames, ...labelProps } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n const { tx } = useThemeContext();\n return (\n <MenuPrimitive.Label\n {...menuScope}\n {...labelProps}\n className={tx('menu.groupLabel', {}, classNames)}\n ref={forwardedRef}\n />\n );\n },\n);\n\nDropdownMenuGroupLabel.displayName = LABEL_NAME;\n\n//\n// DropdownMenuItem\n//\n\nconst ITEM_NAME = 'DropdownMenuItem';\n\ntype DropdownMenuItemElement = ComponentRef<typeof MenuPrimitive.Item>;\ntype MenuItemProps = ThemedClassName<ComponentPropsWithoutRef<typeof MenuPrimitive.Item>>;\ntype DropdownMenuItemProps = MenuItemProps;\n\nconst DropdownMenuItem = forwardRef<DropdownMenuItemElement, DropdownMenuItemProps>(\n (props: ScopedProps<DropdownMenuItemProps>, forwardedRef) => {\n const { __scopeDropdownMenu, classNames, ...itemProps } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n const { tx } = useThemeContext();\n return (\n <MenuPrimitive.Item\n {...menuScope}\n {...itemProps}\n className={tx('menu.item', {}, classNames)}\n ref={forwardedRef}\n />\n );\n },\n);\n\nDropdownMenuItem.displayName = ITEM_NAME;\n\n//\n// DropdownMenuCheckboxItem\n//\n\nconst CHECKBOX_ITEM_NAME = 'DropdownMenuCheckboxItem';\n\ntype DropdownMenuCheckboxItemElement = ComponentRef<typeof MenuPrimitive.CheckboxItem>;\ntype MenuCheckboxItemProps = ThemedClassName<ComponentPropsWithoutRef<typeof MenuPrimitive.CheckboxItem>>;\ntype DropdownMenuCheckboxItemProps = MenuCheckboxItemProps;\n\nconst DropdownMenuCheckboxItem = forwardRef<DropdownMenuCheckboxItemElement, DropdownMenuCheckboxItemProps>(\n (props: ScopedProps<DropdownMenuCheckboxItemProps>, forwardedRef) => {\n const { __scopeDropdownMenu, classNames, ...checkboxItemProps } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n const { tx } = useThemeContext();\n return (\n <MenuPrimitive.CheckboxItem\n {...menuScope}\n {...checkboxItemProps}\n className={tx('menu.item', {}, classNames)}\n ref={forwardedRef}\n />\n );\n },\n);\n\nDropdownMenuCheckboxItem.displayName = CHECKBOX_ITEM_NAME;\n\n//\n// DropdownMenuRadioGroup\n//\n\nconst RADIO_GROUP_NAME = 'DropdownMenuRadioGroup';\n\ntype DropdownMenuRadioGroupElement = ComponentRef<typeof MenuPrimitive.RadioGroup>;\ntype MenuRadioGroupProps = ComponentPropsWithoutRef<typeof MenuPrimitive.RadioGroup>;\ntype DropdownMenuRadioGroupProps = MenuRadioGroupProps;\n\nconst DropdownMenuRadioGroup = forwardRef<DropdownMenuRadioGroupElement, DropdownMenuRadioGroupProps>(\n (props: ScopedProps<DropdownMenuRadioGroupProps>, forwardedRef) => {\n const { __scopeDropdownMenu, ...radioGroupProps } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n return <MenuPrimitive.RadioGroup {...menuScope} {...radioGroupProps} ref={forwardedRef} />;\n },\n);\n\nDropdownMenuRadioGroup.displayName = RADIO_GROUP_NAME;\n\n//\n// DropdownMenuRadioItem\n//\n\nconst RADIO_ITEM_NAME = 'DropdownMenuRadioItem';\n\ntype DropdownMenuRadioItemElement = ComponentRef<typeof MenuPrimitive.RadioItem>;\ntype MenuRadioItemProps = ComponentPropsWithoutRef<typeof MenuPrimitive.RadioItem>;\ntype DropdownMenuRadioItemProps = ThemedClassName<MenuRadioItemProps>;\n\nconst DropdownMenuRadioItem = forwardRef<DropdownMenuRadioItemElement, DropdownMenuRadioItemProps>(\n (props: ScopedProps<DropdownMenuRadioItemProps>, forwardedRef) => {\n const { __scopeDropdownMenu, classNames, ...itemProps } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n const { tx } = useThemeContext();\n return (\n <MenuPrimitive.Item\n {...menuScope}\n {...itemProps}\n className={tx('menu.item', {}, classNames)}\n ref={forwardedRef}\n />\n );\n },\n);\n\nDropdownMenuRadioItem.displayName = RADIO_ITEM_NAME;\n\n//\n// DropdownMenuItemIndicator\n//\n\nconst INDICATOR_NAME = 'DropdownMenuItemIndicator';\n\ntype DropdownMenuItemIndicatorElement = ComponentRef<typeof MenuPrimitive.ItemIndicator>;\ntype MenuItemIndicatorProps = ComponentPropsWithoutRef<typeof MenuPrimitive.ItemIndicator>;\ntype DropdownMenuItemIndicatorProps = MenuItemIndicatorProps;\n\nconst DropdownMenuItemIndicator = forwardRef<DropdownMenuItemIndicatorElement, DropdownMenuItemIndicatorProps>(\n (props: ScopedProps<DropdownMenuItemIndicatorProps>, forwardedRef) => {\n const { __scopeDropdownMenu, ...itemIndicatorProps } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n return <MenuPrimitive.ItemIndicator {...menuScope} {...itemIndicatorProps} ref={forwardedRef} />;\n },\n);\n\nDropdownMenuItemIndicator.displayName = INDICATOR_NAME;\n\n//\n// DropdownMenuSeparator\n//\n\nconst SEPARATOR_NAME = 'DropdownMenuSeparator';\n\ntype DropdownMenuSeparatorElement = ComponentRef<typeof MenuPrimitive.Separator>;\ntype MenuSeparatorProps = ThemedClassName<ComponentPropsWithoutRef<typeof MenuPrimitive.Separator>>;\ntype DropdownMenuSeparatorProps = MenuSeparatorProps;\n\nconst DropdownMenuSeparator = forwardRef<DropdownMenuSeparatorElement, DropdownMenuSeparatorProps>(\n (props: ScopedProps<DropdownMenuSeparatorProps>, forwardedRef) => {\n const { __scopeDropdownMenu, classNames, ...separatorProps } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n const { tx } = useThemeContext();\n return (\n <MenuPrimitive.Separator\n {...menuScope}\n {...separatorProps}\n className={tx('menu.separator', {}, classNames)}\n ref={forwardedRef}\n />\n );\n },\n);\n\nDropdownMenuSeparator.displayName = SEPARATOR_NAME;\n\n//\n// DropdownMenuArrow\n//\n\nconst ARROW_NAME = 'DropdownMenuArrow';\n\ntype DropdownMenuArrowElement = ComponentRef<typeof MenuPrimitive.Arrow>;\ntype MenuArrowProps = ThemedClassName<ComponentPropsWithoutRef<typeof MenuPrimitive.Arrow>>;\ntype DropdownMenuArrowProps = MenuArrowProps;\n\nconst DropdownMenuArrow = forwardRef<DropdownMenuArrowElement, DropdownMenuArrowProps>(\n (props: ScopedProps<DropdownMenuArrowProps>, forwardedRef) => {\n const { __scopeDropdownMenu, classNames, ...arrowProps } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n const { tx } = useThemeContext();\n return (\n <MenuPrimitive.Arrow\n {...menuScope}\n {...arrowProps}\n className={tx('menu.arrow', {}, classNames)}\n ref={forwardedRef}\n />\n );\n },\n);\n\nDropdownMenuArrow.displayName = ARROW_NAME;\n\n//\n// DropdownMenuSub\n//\n\ntype DropdownMenuSubProps = {\n children?: ReactNode;\n open?: boolean;\n defaultOpen?: boolean;\n onOpenChange?(open: boolean): void;\n};\n\nconst DropdownMenuSub: FC<DropdownMenuSubProps> = (props: ScopedProps<DropdownMenuSubProps>) => {\n const { __scopeDropdownMenu, children, open: openProp, onOpenChange, defaultOpen } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n const [open = false, setOpen] = useControllableState({\n prop: openProp,\n defaultProp: defaultOpen,\n onChange: onOpenChange,\n });\n\n return (\n <MenuPrimitive.Sub {...menuScope} open={open} onOpenChange={setOpen}>\n {children}\n </MenuPrimitive.Sub>\n );\n};\n\n//\n// DropdownMenuSubTrigger\n//\n\nconst SUB_TRIGGER_NAME = 'DropdownMenuSubTrigger';\n\ntype DropdownMenuSubTriggerElement = ComponentRef<typeof MenuPrimitive.SubTrigger>;\ntype MenuSubTriggerProps = ComponentPropsWithoutRef<typeof MenuPrimitive.SubTrigger>;\ntype DropdownMenuSubTriggerProps = MenuSubTriggerProps;\n\nconst DropdownMenuSubTrigger = forwardRef<DropdownMenuSubTriggerElement, DropdownMenuSubTriggerProps>(\n (props: ScopedProps<DropdownMenuSubTriggerProps>, forwardedRef) => {\n const { __scopeDropdownMenu, ...subTriggerProps } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n return <MenuPrimitive.SubTrigger {...menuScope} {...subTriggerProps} ref={forwardedRef} />;\n },\n);\n\nDropdownMenuSubTrigger.displayName = SUB_TRIGGER_NAME;\n\n//\n// DropdownMenuSubContent\n//\n\nconst SUB_CONTENT_NAME = 'DropdownMenuSubContent';\n\ntype DropdownMenuSubContentElement = ComponentRef<typeof MenuPrimitive.Content>;\ntype MenuSubContentProps = ComponentPropsWithoutRef<typeof MenuPrimitive.SubContent>;\ntype DropdownMenuSubContentProps = MenuSubContentProps;\n\nconst DropdownMenuSubContent = forwardRef<DropdownMenuSubContentElement, DropdownMenuSubContentProps>(\n (props: ScopedProps<DropdownMenuSubContentProps>, forwardedRef) => {\n const { __scopeDropdownMenu, ...subContentProps } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n\n return (\n <MenuPrimitive.SubContent\n {...menuScope}\n {...subContentProps}\n ref={forwardedRef}\n style={{\n ...props.style,\n // re-namespace exposed content custom properties\n ...{\n '--radix-dropdown-menu-content-transform-origin': 'var(--radix-popper-transform-origin)',\n '--radix-dropdown-menu-content-available-width': 'var(--radix-popper-available-width)',\n '--radix-dropdown-menu-content-available-height': 'var(--radix-popper-available-height)',\n '--radix-dropdown-menu-trigger-width': 'var(--radix-popper-anchor-width)',\n '--radix-dropdown-menu-trigger-height': 'var(--radix-popper-anchor-height)',\n },\n }}\n />\n );\n },\n);\n\nDropdownMenuSubContent.displayName = SUB_CONTENT_NAME;\n\n//\n// DropdownMenu\n//\n\nexport const DropdownMenu = {\n Root: DropdownMenuRoot,\n Trigger: DropdownMenuTrigger,\n VirtualTrigger: DropdownMenuVirtualTrigger,\n Portal: DropdownMenuPortal,\n Content: DropdownMenuContent,\n Viewport: DropdownMenuViewport,\n Group: DropdownMenuGroup,\n GroupLabel: DropdownMenuGroupLabel,\n Item: DropdownMenuItem,\n CheckboxItem: DropdownMenuCheckboxItem,\n RadioGroup: DropdownMenuRadioGroup,\n RadioItem: DropdownMenuRadioItem,\n ItemIndicator: DropdownMenuItemIndicator,\n Separator: DropdownMenuSeparator,\n Arrow: DropdownMenuArrow,\n Sub: DropdownMenuSub,\n SubTrigger: DropdownMenuSubTrigger,\n SubContent: DropdownMenuSubContent,\n};\n\ntype DropdownMenuScope = Scope;\n\nconst useDropdownMenuMenuScope: (scope?: DropdownMenuScope) => any = useMenuScope;\n\nexport { createDropdownMenuScope, useDropdownMenuContext, useDropdownMenuMenuScope };\n\nexport type {\n DropdownMenuRootProps,\n DropdownMenuTriggerProps,\n DropdownMenuVirtualTriggerProps,\n DropdownMenuPortalProps,\n DropdownMenuContentProps,\n DropdownMenuViewportProps,\n DropdownMenuGroupProps,\n DropdownMenuLabelProps,\n DropdownMenuItemProps,\n DropdownMenuCheckboxItemProps,\n DropdownMenuRadioGroupProps,\n DropdownMenuRadioItemProps,\n DropdownMenuItemIndicatorProps,\n DropdownMenuSeparatorProps,\n DropdownMenuArrowProps,\n DropdownMenuSubProps,\n DropdownMenuSubTriggerProps,\n DropdownMenuSubContentProps,\n};\n", "//\n// Copyright 2023 DXOS.org\n//\nimport * as SeparatorPrimitive from '@radix-ui/react-separator';\nimport React, { forwardRef } from 'react';\n\nimport { useThemeContext } from '../../hooks';\nimport { type ThemedClassName } from '../../util';\n\ntype SeparatorProps = ThemedClassName<SeparatorPrimitive.SeparatorProps> & { subdued?: boolean };\n\nconst Separator = forwardRef<HTMLDivElement, SeparatorProps>(\n ({ classNames, orientation = 'horizontal', subdued, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return (\n <SeparatorPrimitive.Root\n {...props}\n orientation={orientation}\n className={tx('separator.root', { orientation, subdued }, classNames)}\n ref={forwardedRef}\n />\n );\n },\n);\n\nexport type { SeparatorProps };\n\nexport { Separator };\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React, { type PropsWithChildren, createContext, useCallback, useContext, useState } from 'react';\n\nexport type ClipboardContextValue = {\n textValue: string;\n setTextValue: (nextValue: string) => Promise<void>;\n};\n\nexport const ClipboardContext = createContext<ClipboardContextValue>({\n textValue: '',\n setTextValue: async (_) => {},\n});\n\nexport const useClipboard = () => useContext(ClipboardContext);\n\nexport const ClipboardProvider = ({ children }: PropsWithChildren<{}>) => {\n const [textValue, setInternalTextValue] = useState('');\n const setTextValue = useCallback(async (nextValue: string) => {\n await navigator.clipboard.writeText(nextValue);\n return setInternalTextValue(nextValue);\n }, []);\n return <ClipboardContext.Provider value={{ textValue, setTextValue }}>{children}</ClipboardContext.Provider>;\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React from 'react';\n\nimport { mx, osTranslations } from '@dxos/ui-theme';\n\nimport { Button, type ButtonProps, IconButton } from '../Button';\nimport { Icon, type IconProps } from '../Icon';\nimport { useTranslation } from '../ThemeProvider';\nimport { type TooltipScopedProps, useTooltipContext } from '../Tooltip';\nimport { useClipboard } from './ClipboardProvider';\n\nexport type CopyButtonProps = ButtonProps &\n Pick<IconProps, 'size'> & {\n value: string;\n };\n\nconst inactiveLabelStyles = 'invisible h-px -mb-px overflow-hidden';\n\nexport const CopyButton = ({ classNames, value, size = 5, ...props }: CopyButtonProps) => {\n const { t } = useTranslation(osTranslations);\n const { textValue, setTextValue } = useClipboard();\n const isCopied = textValue === value;\n return (\n <Button\n {...props}\n classNames={['inline-flex flex-col justify-center', classNames]}\n onClick={() => setTextValue(value)}\n data-testid='copy-invitation'\n >\n <div role='none' className={mx('flex gap-1 items-center', isCopied && inactiveLabelStyles)}>\n <span className='px-1'>{t('copy.label')}</span>\n <Icon icon='ph--copy--regular' size={size} />\n </div>\n <div role='none' className={mx('flex gap-1 items-center', !isCopied && inactiveLabelStyles)}>\n <span className='px-1'>{t('copy-success.label')}</span>\n <Icon icon='ph--check--regular' size={size} />\n </div>\n </Button>\n );\n};\n\ntype CopyButtonIconOnlyProps = CopyButtonProps & {\n label?: string;\n};\n\nexport const CopyButtonIconOnly = ({\n __scopeTooltip,\n value,\n classNames,\n size,\n variant,\n ...props\n}: TooltipScopedProps<CopyButtonIconOnlyProps>) => {\n const { t } = useTranslation(osTranslations);\n const { textValue, setTextValue } = useClipboard();\n const isCopied = textValue === value;\n const label = isCopied ? t('copy-success.label') : (props.label ?? t('copy.label'));\n const { onOpen } = useTooltipContext('CopyButton', __scopeTooltip);\n return (\n <IconButton\n iconOnly\n label={label!}\n icon='ph--copy--regular'\n size={size}\n variant={variant}\n classNames={['inline-flex flex-col justify-center', classNames]}\n onClick={() => setTextValue(value).then(onOpen)}\n data-testid='copy-invitation'\n />\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { ClipboardProvider } from './ClipboardProvider';\nimport { CopyButton, CopyButtonIconOnly } from './CopyButton';\n\nexport const Clipboard = {\n Button: CopyButton,\n IconButton: CopyButtonIconOnly,\n Provider: ClipboardProvider,\n};\n\nexport { useClipboard } from './ClipboardProvider';\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { createContext } from '@radix-ui/react-context';\nimport * as DialogPrimitive from '@radix-ui/react-dialog';\nimport React, {\n type ComponentPropsWithRef,\n type ForwardRefExoticComponent,\n type FunctionComponent,\n type PropsWithChildren,\n forwardRef,\n} from 'react';\nimport { useTranslation } from 'react-i18next';\n\nimport { type DialogSize, osTranslations } from '@dxos/ui-theme';\nimport { slottable } from '@dxos/ui-theme';\nimport { type SlottableProps } from '@dxos/ui-types';\n\nimport { useThemeContext } from '../../hooks';\nimport { Column } from '../../primitives';\nimport { type ThemedClassName } from '../../util';\nimport { IconButton } from '../Button';\nimport { ElevationProvider } from '../ElevationProvider';\n\n//\n// Root\n//\n\ntype DialogRootProps = DialogPrimitive.DialogProps;\n\nconst DialogRoot: FunctionComponent<DialogRootProps> = (props) => (\n <ElevationProvider elevation='dialog'>\n <DialogPrimitive.Root\n // NOTE: Radix warning unless set to undefined.\n // https://www.radix-ui.com/primitives/docs/components/dialog#description\n aria-describedby={undefined}\n {...props}\n />\n </ElevationProvider>\n);\n\n//\n// Trigger\n//\n\ntype DialogTriggerProps = DialogPrimitive.DialogTriggerProps;\n\nconst DialogTrigger: FunctionComponent<DialogTriggerProps> = DialogPrimitive.Trigger;\n\n//\n// Portal\n//\n\ntype DialogPortalProps = DialogPrimitive.DialogPortalProps;\n\nconst DialogPortal: FunctionComponent<DialogPortalProps> = DialogPrimitive.Portal;\n\n//\n// Overlay\n//\n\nconst DIALOG_OVERLAY_NAME = 'DialogOverlay';\n\ntype OverlayLayoutContextValue = { inOverlayLayout?: boolean };\n\nconst [OverlayLayoutProvider, useOverlayLayoutContext] = createContext<OverlayLayoutContextValue>(\n DIALOG_OVERLAY_NAME,\n {},\n);\n\ntype DialogOverlayProps = ThemedClassName<\n DialogPrimitive.DialogOverlayProps & { blockAlign?: 'center' | 'start' | 'end' }\n>;\n\nconst DialogOverlay: ForwardRefExoticComponent<DialogOverlayProps> = forwardRef<HTMLDivElement, DialogOverlayProps>(\n ({ classNames, children, blockAlign, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n\n return (\n <DialogPrimitive.Overlay\n {...props}\n data-block-align={blockAlign}\n className={tx('dialog.overlay', {}, classNames)}\n ref={forwardedRef}\n >\n <OverlayLayoutProvider inOverlayLayout>{children}</OverlayLayoutProvider>\n </DialogPrimitive.Overlay>\n );\n },\n);\n\nDialogOverlay.displayName = DIALOG_OVERLAY_NAME;\n\n//\n// Content\n//\n\nconst DIALOG_CONTENT_NAME = 'DialogContent';\n\ntype DialogContentProps = ThemedClassName<ComponentPropsWithRef<typeof DialogPrimitive.Content>> & {\n size?: DialogSize;\n inOverlayLayout?: boolean;\n};\n\nconst DialogContent: ForwardRefExoticComponent<DialogContentProps> = forwardRef<HTMLDivElement, DialogContentProps>(\n ({ classNames, children, size = 'md', inOverlayLayout: propsInOverlayLayout, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const { inOverlayLayout } = useOverlayLayoutContext(DIALOG_CONTENT_NAME);\n\n return (\n <DialogPrimitive.Content\n {...props}\n // NOTE: Radix warning unless set to undefined.\n // https://www.radix-ui.com/primitives/docs/components/dialog#description\n aria-describedby={undefined}\n className={tx(\n 'dialog.content',\n {\n size,\n inOverlayLayout: propsInOverlayLayout || inOverlayLayout,\n },\n classNames,\n )}\n ref={forwardedRef}\n >\n <Column.Root classNames='dx-expander' gutter='sm'>\n {children}\n </Column.Root>\n </DialogPrimitive.Content>\n );\n },\n);\n\nDialogContent.displayName = DIALOG_CONTENT_NAME;\n\n//\n// Header\n//\n\ntype DialogHeaderProps = PropsWithChildren;\n\nconst DialogHeader: ForwardRefExoticComponent<DialogHeaderProps> = forwardRef<HTMLHeadingElement, DialogHeaderProps>(\n ({ children }, forwardedRef) => {\n const { tx } = useThemeContext();\n return (\n <Column.Row className={tx('dialog.header')} center ref={forwardedRef}>\n {children}\n </Column.Row>\n );\n },\n);\n\n//\n// CloseIconButton\n//\n\ntype DialogCloseIconButtonProps = { label?: string };\n\nconst DialogCloseIconButton = forwardRef<HTMLButtonElement, DialogCloseIconButtonProps>(\n ({ label, ...props }, forwardedRef) => {\n const { t } = useTranslation(osTranslations);\n return (\n <IconButton\n {...props}\n label={label ?? t('close-dialog.label')}\n icon='ph--x--regular'\n iconOnly\n size={4}\n variant='ghost'\n ref={forwardedRef}\n />\n );\n },\n);\n\n//\n// Body\n//\n\ntype DialogBodyProps = SlottableProps;\n\nconst DialogBody = slottable<HTMLDivElement>(({ children, asChild, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return (\n <Column.Content {...props} asChild={asChild} className={tx('dialog.body', {})} ref={forwardedRef}>\n {children}\n </Column.Content>\n );\n});\n\n//\n// Title\n//\n\ntype DialogTitleProps = ThemedClassName<DialogPrimitive.DialogTitleProps> & { srOnly?: boolean };\n\nconst DialogTitle = forwardRef<HTMLHeadingElement, DialogTitleProps>(\n ({ classNames, srOnly, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return (\n <DialogPrimitive.Title {...props} className={tx('dialog.title', { srOnly }, classNames)} ref={forwardedRef} />\n );\n },\n);\n\n//\n// Description\n//\n\ntype DialogDescriptionProps = ThemedClassName<DialogPrimitive.DialogDescriptionProps> & { srOnly?: boolean };\n\nconst DialogDescription = forwardRef<HTMLParagraphElement, DialogDescriptionProps>(\n ({ classNames, srOnly, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return (\n <DialogPrimitive.Description\n {...props}\n className={tx('dialog.description', { srOnly }, classNames)}\n ref={forwardedRef}\n />\n );\n },\n);\n\n//\n// ActionBar\n//\n\ntype DialogActionBarProps = ThemedClassName<PropsWithChildren>;\n\nconst DialogActionBar = forwardRef<HTMLDivElement, DialogActionBarProps>(\n ({ children, classNames, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return (\n <Column.Row center>\n <div {...props} className={tx('dialog.actionbar', {}, classNames)} ref={forwardedRef}>\n {children}\n </div>\n </Column.Row>\n );\n },\n);\n\n//\n// Close\n//\n\ntype DialogCloseProps = DialogPrimitive.DialogCloseProps;\n\nconst DialogClose: FunctionComponent<DialogCloseProps> = DialogPrimitive.Close;\n\n//\n// Dialog\n//\n\nexport const Dialog = {\n Root: DialogRoot,\n Trigger: DialogTrigger,\n Portal: DialogPortal,\n Overlay: DialogOverlay,\n Content: DialogContent,\n Header: DialogHeader,\n Body: DialogBody,\n Title: DialogTitle,\n Description: DialogDescription,\n ActionBar: DialogActionBar,\n Close: DialogClose,\n CloseIconButton: DialogCloseIconButton,\n};\n\nexport type {\n DialogRootProps,\n DialogTriggerProps,\n DialogPortalProps,\n DialogOverlayProps,\n DialogContentProps,\n DialogHeaderProps,\n DialogBodyProps,\n DialogTitleProps,\n DialogDescriptionProps,\n DialogActionBarProps,\n DialogCloseProps,\n DialogCloseIconButtonProps,\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport * as AlertDialogPrimitive from '@radix-ui/react-alert-dialog';\nimport { createContext } from '@radix-ui/react-context';\nimport React, { type ForwardRefExoticComponent, type FunctionComponent, forwardRef } from 'react';\n\nimport { type DialogSize } from '@dxos/ui-theme';\n\nimport { useThemeContext } from '../../hooks';\nimport { Column } from '../../primitives';\nimport { type ThemedClassName } from '../../util';\nimport { ElevationProvider } from '../ElevationProvider';\nimport {\n Dialog,\n type DialogHeaderProps,\n type DialogBodyProps,\n type DialogActionBarProps,\n type DialogCloseIconButtonProps,\n} from './Dialog';\n\n//\n// Root\n//\n\ntype AlertDialogRootProps = AlertDialogPrimitive.AlertDialogProps;\n\nconst AlertDialogRoot: FunctionComponent<AlertDialogRootProps> = (props) => (\n <ElevationProvider elevation='dialog'>\n <AlertDialogPrimitive.Root {...props} />\n </ElevationProvider>\n);\n\n//\n// Trigger\n//\n\ntype AlertDialogTriggerProps = AlertDialogPrimitive.AlertDialogTriggerProps;\n\nconst AlertDialogTrigger: FunctionComponent<AlertDialogTriggerProps> = AlertDialogPrimitive.Trigger;\n\n//\n// Portal\n//\n\ntype AlertDialogPortalProps = AlertDialogPrimitive.AlertDialogPortalProps;\n\nconst AlertDialogPortal: FunctionComponent<AlertDialogPortalProps> = AlertDialogPrimitive.Portal;\n\n//\n// Cancel\n//\n\ntype AlertDialogCancelProps = AlertDialogPrimitive.AlertDialogCancelProps;\n\nconst AlertDialogCancel: FunctionComponent<AlertDialogCancelProps> = AlertDialogPrimitive.Cancel;\n\n//\n// Action\n//\n\ntype AlertDialogActionProps = AlertDialogPrimitive.AlertDialogActionProps;\n\nconst AlertDialogAction: FunctionComponent<AlertDialogActionProps> = AlertDialogPrimitive.Action;\n\n//\n// Context\n//\n\ntype OverlayLayoutContextValue = { inOverlayLayout?: boolean };\n\nconst ALERT_DIALOG_OVERLAY_NAME = 'AlertDialogOverlay';\nconst ALERT_DIALOG_CONTENT_NAME = 'AlertDialogContent';\n\nconst [OverlayLayoutProvider, useOverlayLayoutContext] = createContext<OverlayLayoutContextValue>(\n ALERT_DIALOG_OVERLAY_NAME,\n { inOverlayLayout: false },\n);\n\n//\n// Overlay\n//\n\ntype AlertDialogOverlayProps = ThemedClassName<\n AlertDialogPrimitive.AlertDialogOverlayProps & { blockAlign?: 'center' | 'start' | 'end' }\n>;\n\nconst AlertDialogOverlay: ForwardRefExoticComponent<AlertDialogOverlayProps> = forwardRef<\n HTMLDivElement,\n AlertDialogOverlayProps\n>(({ classNames, children, blockAlign, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return (\n <AlertDialogPrimitive.Overlay\n {...props}\n data-block-align={blockAlign}\n className={tx('dialog.overlay', {}, classNames)}\n ref={forwardedRef}\n >\n <OverlayLayoutProvider inOverlayLayout>{children}</OverlayLayoutProvider>\n </AlertDialogPrimitive.Overlay>\n );\n});\n\nAlertDialogOverlay.displayName = ALERT_DIALOG_OVERLAY_NAME;\n\n//\n// Content\n//\n\ntype AlertDialogContentProps = ThemedClassName<AlertDialogPrimitive.AlertDialogContentProps> & { size?: DialogSize };\n\nconst AlertDialogContent: ForwardRefExoticComponent<AlertDialogContentProps> = forwardRef<\n HTMLDivElement,\n AlertDialogContentProps\n>(({ classNames, children, size = 'md', ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const { inOverlayLayout } = useOverlayLayoutContext(ALERT_DIALOG_CONTENT_NAME);\n return (\n <AlertDialogPrimitive.Content\n {...props}\n className={tx('dialog.content', { inOverlayLayout, size }, classNames)}\n // NOTE: Radix warning unless set to undefined.\n // https://www.radix-ui.com/primitives/docs/components/dialog#description\n aria-describedby={undefined}\n ref={forwardedRef}\n >\n <Column.Root classNames='dx-expander' gutter='sm'>\n {children}\n </Column.Root>\n </AlertDialogPrimitive.Content>\n );\n});\n\nAlertDialogContent.displayName = ALERT_DIALOG_CONTENT_NAME;\n\n//\n// Title\n//\n\ntype AlertDialogTitleProps = ThemedClassName<AlertDialogPrimitive.AlertDialogTitleProps> & { srOnly?: boolean };\n\nconst AlertDialogTitle: ForwardRefExoticComponent<AlertDialogTitleProps> = forwardRef<\n HTMLHeadingElement,\n AlertDialogTitleProps\n>(({ classNames, srOnly, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return (\n <AlertDialogPrimitive.Title {...props} className={tx('dialog.title', { srOnly }, classNames)} ref={forwardedRef} />\n );\n});\n\n//\n// Description\n//\n\ntype AlertDialogDescriptionProps = ThemedClassName<AlertDialogPrimitive.AlertDialogDescriptionProps> & {\n srOnly?: boolean;\n};\n\nconst AlertDialogDescription: ForwardRefExoticComponent<AlertDialogDescriptionProps> = forwardRef<\n HTMLParagraphElement,\n AlertDialogDescriptionProps\n>(({ classNames, srOnly, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return (\n <AlertDialogPrimitive.Description\n {...props}\n className={tx('dialog.description', { srOnly }, classNames)}\n ref={forwardedRef}\n />\n );\n});\n\n//\n// AlertDialog\n//\n\nexport const AlertDialog = {\n Root: AlertDialogRoot,\n Trigger: AlertDialogTrigger,\n Portal: AlertDialogPortal,\n Overlay: AlertDialogOverlay,\n Content: AlertDialogContent,\n // Shared with Dialog.\n Header: Dialog.Header,\n Body: Dialog.Body,\n Title: AlertDialogTitle,\n Description: AlertDialogDescription,\n ActionBar: Dialog.ActionBar,\n CloseIconButton: Dialog.CloseIconButton,\n // AlertDialog-specific dismissal.\n Cancel: AlertDialogCancel,\n Action: AlertDialogAction,\n};\n\nexport type {\n AlertDialogRootProps,\n AlertDialogTriggerProps,\n AlertDialogPortalProps,\n AlertDialogOverlayProps,\n AlertDialogContentProps,\n AlertDialogTitleProps,\n AlertDialogDescriptionProps,\n AlertDialogCancelProps,\n AlertDialogActionProps,\n // Re-export shared types.\n DialogHeaderProps as AlertDialogHeaderProps,\n DialogBodyProps as AlertDialogBodyProps,\n DialogActionBarProps as AlertDialogActionBarProps,\n DialogCloseIconButtonProps as AlertDialogCloseIconButtonProps,\n};\n", "//\n// Copyright 2026 DXOS.org\n//\n\nexport { ErrorBoundary, type ErrorBoundaryProps, type FallbackProps } from '@dxos/react-error-boundary';\n\nexport * from './ErrorFallback';\nexport * from './ErrorStack';\nexport * from './ThrowError';\n", "//\n// Copyright 2026 DXOS.org\n//\n\nimport React, { type PropsWithChildren } from 'react';\nimport { type FallbackProps } from 'react-error-boundary';\n\nimport { safeStringify } from '@dxos/util';\n\nimport { ErrorStack } from './ErrorStack';\n\nexport type ErrorFallbackProps = PropsWithChildren<Pick<FallbackProps, 'error'> & { title?: string; data?: any }>;\n\n/**\n * Themed fallback component for `ErrorBoundary`.\n */\nexport const ErrorFallback = ({ children, error, title, data }: ErrorFallbackProps) => {\n const isDev = process.env.NODE_ENV === 'development';\n const message = error instanceof Error ? error.message : String(error);\n\n return (\n <div role='alert' data-testid='error-boundary-fallback' className='flex flex-col p-4 gap-4 overflow-auto'>\n <h1 className='text-lg text-info-text'>{title ?? 'Runtime Error'}</h1>\n <p>{message}</p>\n\n {isDev && error instanceof Error && (\n <Section\n title='Stack'\n onClick={() => {\n const text = error instanceof Error ? (error.stack ?? error.message) : String(error);\n void navigator.clipboard.writeText(text);\n }}\n >\n <ErrorStack error={error} />\n </Section>\n )}\n\n {data && (\n <Section\n title='Data'\n onClick={() => {\n void navigator.clipboard.writeText(JSON.stringify(data, undefined, 2));\n }}\n >\n <pre className='overflow-x-auto text-xs'>{safeStringify(data, undefined, 2)}</pre>\n </Section>\n )}\n\n {children}\n </div>\n );\n};\n\nconst Section = ({ children, title, onClick }: PropsWithChildren<{ title?: string; onClick?: () => void }>) => {\n return (\n <div className='flex flex-col gap-1'>\n {onClick && (\n <button\n type='button'\n onClick={onClick}\n className='flex items-center gap-1 text-xs text-subdued hover:text-primary-500 transition-colors'\n title={`Copy ${title}`}\n >\n <h2 className='text-xs uppercase text-subdued'>{title}</h2>\n </button>\n )}\n {children}\n </div>\n );\n};\n", "//\n// Copyright 2026 DXOS.org\n//\n\nimport ErrorStackParser from 'error-stack-parser';\nimport React from 'react';\n\nimport { mx } from '@dxos/ui-theme';\n\ntype LocalFrame = { href: string; fileName: string };\n\n/**\n * Renders a parsed error stack trace with tree connector symbols and clickable vscode:// links for local frames.\n */\nexport const ErrorStack = ({ error }: { error: Error }) => {\n const frames = ErrorStackParser.parse(error);\n\n return (\n <div className='font-mono text-sm'>\n {frames.map((frame, i) => {\n const isLast = i === frames.length - 1;\n const local = frame.fileName\n ? parseLocalFrame(frame.fileName, frame.lineNumber, frame.columnNumber)\n : undefined;\n const name = frame.functionName ?? '<anonymous>';\n return (\n <div\n key={i}\n className={mx(\n 'grid grid-cols-[16px_1fr_auto_auto] items-stretch gap-x-2',\n local && 'cursor-pointer hover:bg-hover-surface',\n )}\n >\n {/* Tree connector: vertical line full-height + horizontal branch at midpoint */}\n <div className='relative'>\n <div\n className={mx(\n 'absolute left-1/2 -translate-x-1/2 w-px bg-neutral-500',\n isLast ? 'top-0 h-1/2' : 'inset-y-0',\n )}\n />\n <div className='absolute top-1/2 -translate-y-1/2 left-1/2 right-0 h-px bg-neutral-500' />\n </div>\n {local ? (\n <a href={local.href} className='truncate self-center'>\n {name}\n </a>\n ) : (\n <span className='text-subdued truncate self-center'>{name}</span>\n )}\n <span className='text-xs text-subdued truncate self-center'>{local?.fileName ?? ''}</span>\n <span className='text-xs text-subdued text-right self-center'>\n {local ? `${frame.lineNumber}:${frame.columnNumber}` : ''}\n </span>\n </div>\n );\n })}\n </div>\n );\n};\n\n/**\n * Parses a Vite `/@fs/` URL into a `vscode://` deep link and short filename.\n * Returns undefined if the URL cannot be resolved to a local file.\n */\nconst parseLocalFrame = (fileUrl: string, line?: number, col?: number): LocalFrame | undefined => {\n try {\n const { pathname } = new URL(fileUrl);\n if (!pathname.startsWith('/@fs/')) {\n return undefined;\n }\n const localPath = pathname.slice(4); // /@fs/Users/... → /Users/...\n return {\n href: `vscode://file/${localPath}:${line ?? 1}:${col ?? 1}`,\n fileName: pathname.split('/').pop() ?? localPath,\n };\n } catch {\n return undefined;\n }\n};\n", "//\n// Copyright 2026 DXOS.org\n//\n\nimport { useEffect, useState } from 'react';\n\nexport type ThrowErrorProps = {\n error?: () => Error;\n delay?: number;\n};\n\n/**\n * Use this to debug the error boundary.\n */\nexport const ThrowError = ({ delay = 1_000, ...props }: ThrowErrorProps) => {\n const [error, setError] = useState<Error>();\n useEffect(() => {\n if (delay < 0) {\n return;\n }\n\n const t = setTimeout(() => {\n setError(generator({ delay, ...props }));\n }, delay);\n return () => clearTimeout(t);\n }, [delay, generator]);\n\n if (error) {\n throw error;\n }\n\n return null;\n};\n\nconst generator = ({ error, delay }: ThrowErrorProps) => {\n return error?.() ?? new Error(`Error generated after ${delay}ms`);\n};\n", "//\n// Copyright 2026 DXOS.org\n//\n\nimport {\n useArrowNavigationGroup,\n useFocusableGroup,\n useMergedTabsterAttributes_unstable,\n} from '@fluentui/react-tabster';\nimport { useComposedRefs } from '@radix-ui/react-compose-refs';\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slot } from '@radix-ui/react-slot';\nimport React, {\n type FocusEvent,\n type KeyboardEvent,\n type MouseEvent,\n createContext,\n useCallback,\n useContext,\n useRef,\n useState,\n} from 'react';\n\nimport { composableProps, slottable } from '@dxos/ui-theme';\nimport { type Axis } from '@dxos/ui-types';\n\nimport { useThemeContext } from '../../hooks';\n\n//\n// Context\n//\n\ntype FocusState = 'active' | 'error';\n\nconst FOCUS_STATE_ATTR = 'focus-state';\n\ntype ContextValue = {\n setFocus?: (state: FocusState | undefined) => void;\n /** True when any item within the group has DOM focus. */\n groupHasFocus?: boolean;\n};\n\nconst FocusContext = createContext<ContextValue>({});\n\nconst useFocus = () => useContext(FocusContext);\n\n//\n// Group\n//\n\ntype GroupProps = {\n orientation?: Axis;\n /** Show a subdued ring when unfocused (e.g., as a cell border). */\n border?: boolean;\n onKeyDown?: (event: KeyboardEvent<HTMLDivElement>) => void;\n};\n\n/**\n * Provides arrow-key navigation across focusable children via tabster.\n * Does not manage `aria-current` — use `Focus.Item` on each child for that.\n */\n// TODO(wittjosiah): Consider how this could integrate with with react-ui-attention.\n// Perhaps react-ui-attention comes under the mosaic umbrella as it supports selection?\nconst Group = slottable<HTMLDivElement, GroupProps>(\n ({ children, asChild, orientation = 'vertical', border = false, ...props }, forwardedRef) => {\n const Comp = asChild ? Slot : Primitive.div;\n const { tx } = useThemeContext();\n const rootRef = useRef<HTMLDivElement>(null);\n const focusableGroupAttrs = useFocusableGroup({ tabBehavior: 'limited-trap-focus' });\n const arrowNavigationAttrs = useArrowNavigationGroup({ axis: orientation, memorizeCurrent: true });\n const tabsterAttrs = useMergedTabsterAttributes_unstable(focusableGroupAttrs, arrowNavigationAttrs);\n const [state, setState] = useState<FocusState | undefined>();\n const [groupHasFocus, setGroupHasFocus] = useState(false);\n\n const handleFocusIn = useCallback(() => setGroupHasFocus(true), []);\n const handleFocusOut = useCallback((event: FocusEvent<HTMLDivElement>) => {\n const related = event.relatedTarget as HTMLElement | null;\n if (!related || !rootRef.current?.contains(related)) {\n setGroupHasFocus(false);\n }\n }, []);\n\n const { className, ...rest } = composableProps(props);\n return (\n <FocusContext.Provider value={{ setFocus: setState, groupHasFocus }}>\n <Comp\n {...rest}\n tabIndex={0}\n className={tx('focus.group', { border }, className)}\n {...tabsterAttrs}\n {...(state && {\n [`data-${FOCUS_STATE_ATTR}`]: state,\n })}\n onBlur={handleFocusOut}\n onFocus={handleFocusIn}\n ref={useComposedRefs<HTMLDivElement>(rootRef, forwardedRef)}\n >\n {children}\n </Comp>\n </FocusContext.Provider>\n );\n },\n);\n\n//\n// Item\n//\n\ntype ItemProps = {\n current?: boolean;\n /** Show a subdued ring when unfocused (e.g., as a cell border). */\n border?: boolean;\n onCurrentChange?: () => void;\n};\n\n/**\n * Focusable item within a `Focus.Group`.\n * Uses `useFocusableGroup` so the parent Group's arrow navigation treats this as a single unit\n * (internal buttons are not arrow-navigation targets; Enter/Escape to go in/out).\n * Supports controlled (`current` prop) and uncontrolled (focus-driven) `aria-current`.\n */\nconst Item = slottable<HTMLDivElement, ItemProps>(\n (\n { children, asChild, current, border = false, onCurrentChange, onClick, onFocus, onBlur, ...props },\n forwardedRef,\n ) => {\n const Comp = asChild ? Slot : Primitive.div;\n const { tx } = useThemeContext();\n // Tell tabster's groupper to ignore Enter so it doesn't move focus into the group.\n const focusableGroupAttrs = useFocusableGroup({ ignoreDefaultKeydown: { Enter: true } });\n const [focused, setFocused] = useState(false);\n\n const handleClick = useCallback(\n (event: MouseEvent<HTMLDivElement>) => {\n onCurrentChange?.();\n onClick?.(event);\n },\n [onCurrentChange, onClick],\n );\n\n const handleKeyDown = useCallback(\n (event: KeyboardEvent<HTMLDivElement>) => {\n if (event.key === 'Enter') {\n onCurrentChange?.();\n }\n },\n [onCurrentChange],\n );\n\n const handleFocus = useCallback(\n (event: FocusEvent<HTMLDivElement>) => {\n setFocused(true);\n onFocus?.(event);\n },\n [onFocus],\n );\n\n const handleBlur = useCallback(\n (event: FocusEvent<HTMLDivElement>) => {\n setFocused(false);\n onBlur?.(event);\n },\n [onBlur],\n );\n\n // Controlled `current` prop takes precedence (e.g., virtualized items that scroll back into view).\n // Otherwise fall back to DOM focus state.\n const isCurrent = current ?? focused;\n\n const { className, ...rest } = composableProps(props);\n return (\n <Comp\n {...rest}\n tabIndex={0}\n className={tx('focus.item', { border }, className)}\n {...focusableGroupAttrs}\n aria-current={isCurrent || undefined}\n onClick={handleClick}\n onKeyDown={handleKeyDown}\n onFocus={handleFocus}\n onBlur={handleBlur}\n ref={forwardedRef}\n >\n {children}\n </Comp>\n );\n },\n);\n\n//\n// Focus\n//\n\nexport const Focus = {\n Group,\n Item,\n};\n\nexport type { GroupProps as FocusGroupProps, ItemProps as FocusItemProps };\n\nexport { useFocus };\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport * as CheckboxPrimitive from '@radix-ui/react-checkbox';\nimport { useControllableState } from '@radix-ui/react-use-controllable-state';\nimport React, { type ComponentPropsWithRef, type ForwardRefExoticComponent, forwardRef } from 'react';\n\nimport {\n DescriptionAndValidation as DescriptionAndValidationPrimitive,\n type DescriptionAndValidationProps as DescriptionAndValidationPrimitiveProps,\n Description as DescriptionPrimitive,\n type DescriptionProps as DescriptionPrimitiveProps,\n INPUT_NAME,\n InputRoot,\n type InputRootProps,\n type InputScopedProps,\n Label as LabelPrimitive,\n type LabelProps as LabelPrimitiveProps,\n PinInput as PinInputPrimitive,\n type PinInputProps as PinInputPrimitiveProps,\n TextArea as TextAreaPrimitive,\n type TextAreaProps as TextAreaPrimitiveProps,\n TextInput as TextInputPrimitive,\n type TextInputProps as TextInputPrimitiveProps,\n Validation as ValidationPrimitive,\n type ValidationProps as ValidationPrimitiveProps,\n useInputContext,\n} from '@dxos/react-input';\nimport { mx } from '@dxos/ui-theme';\nimport { type Density, type Elevation, type Size } from '@dxos/ui-types';\n\nimport { useDensityContext, useElevationContext, useThemeContext } from '../../hooks';\nimport { type ThemedClassName } from '../../util';\nimport { Icon } from '../Icon';\n\ntype InputVariant = 'default' | 'subdued';\n\ntype InputSharedProps = Partial<{ density: Density; elevation: Elevation; variant: InputVariant }>;\n\ntype LabelProps = ThemedClassName<LabelPrimitiveProps> & { srOnly?: boolean };\n\nconst Label = forwardRef<HTMLLabelElement, LabelProps>(({ classNames, children, srOnly, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return (\n <LabelPrimitive {...props} className={tx('input.label', { srOnly }, classNames)} ref={forwardedRef}>\n {children}\n </LabelPrimitive>\n );\n});\n\ntype DescriptionProps = ThemedClassName<DescriptionPrimitiveProps> & { srOnly?: boolean };\n\nconst Description = forwardRef<HTMLSpanElement, DescriptionProps>(\n ({ classNames, children, srOnly, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return (\n <DescriptionPrimitive {...props} className={tx('input.description', { srOnly }, classNames)} ref={forwardedRef}>\n {children}\n </DescriptionPrimitive>\n );\n },\n);\n\ntype ValidationProps = ThemedClassName<ValidationPrimitiveProps> & { srOnly?: boolean };\n\nconst Validation = forwardRef<HTMLSpanElement, InputScopedProps<ValidationProps>>(\n ({ __inputScope, classNames, children, srOnly, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const { validationValence } = useInputContext(INPUT_NAME, __inputScope);\n return (\n <ValidationPrimitive\n {...props}\n className={tx('input.validation', { srOnly, validationValence }, classNames)}\n ref={forwardedRef}\n >\n {children}\n </ValidationPrimitive>\n );\n },\n);\n\ntype DescriptionAndValidationProps = ThemedClassName<DescriptionAndValidationPrimitiveProps> & { srOnly?: boolean };\n\nconst DescriptionAndValidation = forwardRef<HTMLParagraphElement, DescriptionAndValidationProps>(\n ({ classNames, children, srOnly, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return (\n <DescriptionAndValidationPrimitive\n {...props}\n className={tx('input.descriptionAndValidation', { srOnly }, classNames)}\n ref={forwardedRef}\n >\n {children}\n </DescriptionAndValidationPrimitive>\n );\n },\n);\n\ntype PinInputProps = ThemedClassName<InputSharedProps & Omit<PinInputPrimitiveProps, 'className' | 'segmentClassName'>>;\n\nconst PinInput = forwardRef<HTMLInputElement, PinInputProps>(\n ({ classNames, density: propsDensity, elevation: propsElevation, ...props }, forwardedRef) => {\n const { hasIosKeyboard } = useThemeContext();\n const { tx } = useThemeContext();\n const density = useDensityContext(propsDensity);\n const elevation = useElevationContext(propsElevation);\n\n return (\n <PinInputPrimitive\n {...{\n ...props,\n ...(props.autoFocus && !hasIosKeyboard && { autoFocus: true }),\n }}\n className={tx('input.inputWithSegments', { disabled: props.disabled }, classNames) || ''}\n segmentClassName={tx('input.segment', { disabled: props.disabled, density, elevation }) || ''}\n ref={forwardedRef}\n />\n );\n },\n);\n\n// TODO(burdon): Implement inline icon within button: e.g., https://www.radix-ui.com/themes/playground#text-field\n\ntype AutoFillProps = {\n noAutoFill?: boolean;\n};\n\ntype TextInputProps = InputSharedProps & ThemedClassName<TextInputPrimitiveProps> & AutoFillProps;\n\nconst TextInput = forwardRef<HTMLInputElement, InputScopedProps<TextInputProps>>(\n (\n { __inputScope, classNames, density: propsDensity, elevation: propsElevation, variant, noAutoFill, ...props },\n forwardedRef,\n ) => {\n const { hasIosKeyboard } = useThemeContext();\n const { tx } = useThemeContext();\n const density = useDensityContext(propsDensity);\n const elevation = useElevationContext(propsElevation);\n const { validationValence } = useInputContext(INPUT_NAME, __inputScope);\n\n return (\n <TextInputPrimitive\n {...props}\n // TODO(wittjosiah): Factor out autofill properies.\n {...{ 'data-1p-ignore': noAutoFill }}\n className={tx(\n 'input.input',\n {\n variant,\n disabled: props.disabled,\n density,\n elevation,\n validationValence,\n },\n classNames,\n )}\n {...(props.autoFocus && !hasIosKeyboard && { autoFocus: true })}\n ref={forwardedRef}\n />\n );\n },\n);\n\ntype TextAreaProps = InputSharedProps & ThemedClassName<TextAreaPrimitiveProps>;\n\nconst TextArea = forwardRef<HTMLTextAreaElement, InputScopedProps<TextAreaProps>>(\n ({ __inputScope, classNames, density: propsDensity, elevation: propsElevation, variant, ...props }, forwardedRef) => {\n const { hasIosKeyboard } = useThemeContext();\n const { tx } = useThemeContext();\n const density = useDensityContext(propsDensity);\n const elevation = useElevationContext(propsElevation);\n const { validationValence } = useInputContext(INPUT_NAME, __inputScope);\n\n return (\n <TextAreaPrimitive\n {...props}\n className={tx(\n 'input.textArea',\n {\n variant,\n disabled: props.disabled,\n density,\n elevation,\n validationValence,\n },\n classNames,\n )}\n {...(props.autoFocus && !hasIosKeyboard && { autoFocus: true })}\n ref={forwardedRef}\n />\n );\n },\n);\n\ntype CheckboxProps = ThemedClassName<Omit<CheckboxPrimitive.CheckboxProps, 'children'>> & {\n size?: Size;\n};\n\nconst Checkbox: ForwardRefExoticComponent<CheckboxProps> = forwardRef<\n HTMLButtonElement,\n InputScopedProps<CheckboxProps>\n>(\n (\n {\n __inputScope,\n classNames,\n checked: propsChecked,\n defaultChecked: propsDefaultChecked,\n onCheckedChange: propsOnCheckedChange,\n size,\n ...props\n },\n forwardedRef,\n ) => {\n const [checked, onCheckedChange] = useControllableState({\n prop: propsChecked,\n defaultProp: propsDefaultChecked,\n onChange: propsOnCheckedChange,\n });\n const { id, validationValence, descriptionId, errorMessageId } = useInputContext(INPUT_NAME, __inputScope);\n const { tx } = useThemeContext();\n\n return (\n <CheckboxPrimitive.Root\n {...{\n ...props,\n checked,\n onCheckedChange,\n id,\n 'aria-describedby': descriptionId,\n ...(validationValence === 'error' && {\n 'aria-invalid': 'true' as const,\n 'aria-errormessage': errorMessageId,\n }),\n className: tx('input.checkbox', { size }, 'shrink-0', classNames),\n }}\n ref={forwardedRef}\n >\n <Icon\n icon={checked === 'indeterminate' ? 'ph--minus--regular' : 'ph--check--regular'}\n classNames={tx('input.checkboxIndicator', { size, checked })}\n />\n </CheckboxPrimitive.Root>\n );\n },\n);\n\ntype SwitchProps = ThemedClassName<\n Omit<ComponentPropsWithRef<'input'>, 'children' | 'onChange'> & { onCheckedChange?: (checked: boolean) => void }\n>;\n\nconst Switch = forwardRef<HTMLInputElement, InputScopedProps<SwitchProps>>(\n (\n {\n __inputScope,\n classNames,\n checked: propsChecked,\n defaultChecked: propsDefaultChecked,\n onCheckedChange: propsOnCheckedChange,\n ...props\n },\n forwardedRef,\n ) => {\n const [checked, onCheckedChange] = useControllableState({\n prop: propsChecked,\n defaultProp: propsDefaultChecked ?? false,\n onChange: propsOnCheckedChange,\n });\n\n const { id, validationValence, descriptionId, errorMessageId } = useInputContext(INPUT_NAME, __inputScope);\n\n return (\n <input\n type='checkbox'\n className={mx('dx-checkbox--switch dx-focus-ring', classNames)}\n checked={checked}\n onChange={(event) => {\n onCheckedChange(event.target.checked);\n }}\n id={id}\n aria-describedby={descriptionId}\n {...props}\n {...(validationValence === 'error' && {\n 'aria-invalid': 'true' as const,\n 'aria-errormessage': errorMessageId,\n })}\n ref={forwardedRef}\n />\n );\n },\n);\n\nexport const Input = {\n Root: InputRoot,\n PinInput,\n TextInput,\n TextArea,\n Checkbox,\n Switch,\n Label,\n Description,\n Validation,\n DescriptionAndValidation,\n};\n\nexport type {\n InputVariant,\n InputRootProps,\n InputSharedProps,\n PinInputProps,\n TextInputProps,\n TextAreaProps,\n CheckboxProps,\n SwitchProps,\n LabelProps,\n DescriptionProps,\n ValidationProps,\n DescriptionAndValidationProps,\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slot } from '@radix-ui/react-slot';\nimport React, { type ComponentPropsWithoutRef, type FC, type ForwardRefExoticComponent, forwardRef } from 'react';\n\nimport {\n LIST_ITEM_NAME,\n LIST_NAME,\n ListItemCollapsibleContent,\n type ListItemCollapsibleContentProps,\n type ListItemScopedProps,\n List as ListPrimitive,\n ListItem as ListPrimitiveItem,\n ListItemHeading as ListPrimitiveItemHeading,\n type ListItemHeadingProps as ListPrimitiveItemHeadingProps,\n ListItemOpenTrigger as ListPrimitiveItemOpenTrigger,\n type ListItemOpenTriggerProps as ListPrimitiveItemOpenTriggerProps,\n type ListItemProps as ListPrimitiveItemProps,\n type ListProps as ListPrimitiveProps,\n type ListScopedProps,\n useListContext,\n useListItemContext,\n} from '@dxos/react-list';\nimport { composable, composableProps } from '@dxos/ui-theme';\nimport { type Density } from '@dxos/ui-types';\n\nimport { useDensityContext, useThemeContext } from '../../hooks';\nimport { type ThemedClassName } from '../../util';\nimport { DensityProvider } from '../DensityProvider';\nimport { Icon } from '../Icon';\nimport { ListDropIndicator } from './ListDropIndicator';\n\ntype ListProps = ThemedClassName<ListPrimitiveProps & { density?: Density }>;\n\nconst List = composable<HTMLOListElement, ListProps>(({ children, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const density = useDensityContext(props.density);\n const { className, ...rest } = composableProps(props);\n\n return (\n <DensityProvider density={density}>\n <ListPrimitive {...rest} className={tx('list.root', {}, className)} ref={forwardedRef}>\n {children}\n </ListPrimitive>\n </DensityProvider>\n );\n});\n\ntype ListItemEndcapProps = ThemedClassName<ComponentPropsWithoutRef<'div'>> & { asChild?: boolean };\n\nconst ListItemEndcap = forwardRef<HTMLDivElement, ListItemEndcapProps>(\n ({ children, classNames, asChild, ...props }, forwardedRef) => {\n const Comp = asChild ? Slot : Primitive.div;\n const density = useDensityContext();\n const { tx } = useThemeContext();\n return (\n <Comp\n {...(!asChild && { role: 'none' })}\n {...props}\n className={tx('list.item.endcap', { density }, classNames)}\n ref={forwardedRef}\n >\n {children}\n </Comp>\n );\n },\n);\n\nconst MockListItemOpenTrigger = ({\n classNames,\n ...props\n}: ThemedClassName<Omit<ComponentPropsWithoutRef<'div'>, 'children'>>) => {\n const density = useDensityContext();\n const { tx } = useThemeContext();\n return <div role='none' {...props} className={tx('list.item.openTrigger', { density }, classNames)} />;\n};\n\ntype ListItemHeadingProps = ThemedClassName<ListPrimitiveItemHeadingProps>;\n\nconst ListItemHeading = forwardRef<HTMLParagraphElement, ListItemHeadingProps>(\n ({ children, classNames, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const density = useDensityContext();\n return (\n <ListPrimitiveItemHeading\n {...props}\n className={tx('list.item.heading', { density }, classNames)}\n ref={forwardedRef}\n >\n <span>{children}</span>\n </ListPrimitiveItemHeading>\n );\n },\n);\n\ntype ListItemOpenTriggerProps = ThemedClassName<ListPrimitiveItemOpenTriggerProps>;\n\nconst ListItemOpenTrigger = forwardRef<HTMLButtonElement, ListItemOpenTriggerProps>(\n ({ __listItemScope, classNames, children, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const density = useDensityContext();\n const { open } = useListItemContext(LIST_ITEM_NAME, __listItemScope);\n return (\n <ListPrimitiveItemOpenTrigger\n {...props}\n className={tx('list.item.openTrigger', { density }, classNames)}\n ref={forwardedRef}\n >\n {children || (\n <Icon\n size={3}\n icon={open ? 'ph--caret-down--bold' : 'ph--caret-right--bold'}\n classNames={tx('list.item.openTriggerIcon', {})}\n />\n )}\n </ListPrimitiveItemOpenTrigger>\n );\n },\n);\n\ntype ListItemRootProps = ThemedClassName<ListPrimitiveItemProps>;\n\nconst ListItemRoot = forwardRef<HTMLLIElement, ListItemRootProps>(\n ({ classNames, children, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const density = useDensityContext();\n return (\n <ListPrimitiveItem\n {...props}\n className={tx('list.item.root', { density, collapsible: props.collapsible }, classNames)}\n ref={forwardedRef}\n >\n {children}\n </ListPrimitiveItem>\n );\n },\n);\n\nexport const ListItem: {\n Root: ForwardRefExoticComponent<ListItemRootProps>;\n Endcap: ForwardRefExoticComponent<ListItemEndcapProps>;\n Heading: ForwardRefExoticComponent<ListItemHeadingProps>;\n OpenTrigger: ForwardRefExoticComponent<ListItemOpenTriggerProps>;\n CollapsibleContent: ForwardRefExoticComponent<ListItemCollapsibleContentProps>;\n MockOpenTrigger: FC<ThemedClassName<Omit<ComponentPropsWithoutRef<'div'>, 'children'>>>;\n DropIndicator: typeof ListDropIndicator;\n} = {\n Root: ListItemRoot,\n Endcap: ListItemEndcap,\n Heading: ListItemHeading,\n OpenTrigger: ListItemOpenTrigger,\n CollapsibleContent: ListItemCollapsibleContent,\n MockOpenTrigger: MockListItemOpenTrigger,\n DropIndicator: ListDropIndicator,\n};\n\nexport { List, useListContext, useListItemContext, LIST_NAME, LIST_ITEM_NAME };\n\nexport type {\n ListProps,\n ListScopedProps,\n ListItemRootProps,\n ListItemScopedProps,\n ListItemEndcapProps,\n ListItemHeadingProps,\n ListItemOpenTriggerProps,\n ListItemCollapsibleContentProps,\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { type Edge } from '@atlaskit/pragmatic-drag-and-drop-hitbox/types';\nimport React, { type CSSProperties, type HTMLAttributes } from 'react';\n\ntype Orientation = 'horizontal' | 'vertical';\n\nconst edgeToOrientationMap: Record<Edge, Orientation> = {\n top: 'horizontal',\n bottom: 'horizontal',\n left: 'vertical',\n right: 'vertical',\n};\n\nconst orientationStyles: Record<Orientation, HTMLAttributes<HTMLElement>['className']> = {\n horizontal:\n 'h-(--line-thickness) left-[calc(var(--line-inset)+var(--terminal-radius))] right-(--line-inset) before:left-(--terminal-inset)',\n vertical:\n 'w-(--line-thickness) top-[calc(var(--line-inset)+var(--terminal-radius))] bottom-(--line-inset) before:top-(--terminal-inset)',\n};\n\nconst edgeStyles: Record<Edge, HTMLAttributes<HTMLElement>['className']> = {\n top: 'top-(--line-offset) before:top-(--offset-terminal)',\n right: 'right-(--line-offset) before:right-(--offset-terminal)',\n bottom: 'bottom-(--line-offset) before:bottom-(--offset-terminal)',\n left: 'left-(--line-offset) before:left-(--offset-terminal)',\n};\n\nconst strokeSize = 2;\nconst terminalSize = 8;\nconst offsetToAlignTerminalWithLine = (strokeSize - terminalSize) / 2;\n\nexport type DropIndicatorProps = {\n edge: Edge;\n gap?: number;\n terminalInset?: number;\n lineInset?: number;\n};\n\n/**\n * This is a tailwind port of `@atlaskit/pragmatic-drag-and-drop-react-drop-indicator/box`\n */\nexport const ListDropIndicator = ({\n edge,\n gap = 0,\n lineInset = 0,\n terminalInset = lineInset - terminalSize,\n}: DropIndicatorProps) => {\n const orientation = edgeToOrientationMap[edge];\n\n return (\n <div\n role='none'\n style={\n {\n '--line-thickness': `${strokeSize}px`,\n '--line-offset': `calc(-0.5 * (${gap}px + ${strokeSize}px))`,\n '--line-inset': `${lineInset}px`,\n '--terminal-size': `${terminalSize}px`,\n '--terminal-radius': `${terminalSize / 2}px`,\n '--terminal-inset': `${terminalInset}px`,\n '--offset-terminal': `${offsetToAlignTerminalWithLine}px`,\n } as CSSProperties\n }\n className={`absolute z-10 pointer-events-none bg-accent-surface before:content-[''] before:w-(--terminal-size) before:h-(--terminal-size) box-border before:absolute before:border-[length:--line-thickness] before:border-solid before:border-accent-surface before:rounded-full ${orientationStyles[orientation]} ${edgeStyles[edge]}`}\n />\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React, { type ComponentPropsWithoutRef, type FC, type ForwardRefExoticComponent, forwardRef } from 'react';\n\nimport { type ThemedClassName } from '../../util';\nimport {\n LIST_ITEM_NAME,\n List,\n ListItem,\n type ListItemCollapsibleContentProps,\n type ListItemHeadingProps,\n type ListItemOpenTriggerProps,\n type ListItemRootProps,\n type ListProps,\n type ListScopedProps,\n useListItemContext,\n} from './List';\nimport { TreeDropIndicator } from './TreeDropIndicator';\n\ntype TreeRootProps = ListProps;\n\ntype TreeItemProps = ListItemRootProps;\n\nconst TreeRoot = forwardRef<HTMLOListElement, TreeRootProps>((props, forwardedRef) => {\n return <List {...props} ref={forwardedRef} />;\n});\n\ntype TreeBranchProps = TreeRootProps;\n\nconst TreeBranch = forwardRef<HTMLOListElement, ListScopedProps<TreeBranchProps>>(\n ({ __listScope, ...props }, forwardedRef) => {\n const { headingId } = useListItemContext(LIST_ITEM_NAME, __listScope);\n return <List {...props} aria-labelledby={headingId} ref={forwardedRef} />;\n },\n);\n\nconst TreeItemRoot = forwardRef<HTMLLIElement, ListItemRootProps>((props, forwardedRef) => {\n return <ListItem.Root role='treeitem' {...props} ref={forwardedRef} />;\n});\n\ntype TreeItemHeadingProps = ListItemHeadingProps;\n\nconst TreeItemHeading = ListItem.Heading;\n\ntype TreeItemOpenTriggerProps = ListItemOpenTriggerProps;\n\nconst TreeItemOpenTrigger = ListItem.OpenTrigger;\n\nconst MockTreeItemOpenTrigger = ListItem.MockOpenTrigger;\n\ntype TreeItemBodyProps = ListItemCollapsibleContentProps;\n\nconst TreeItemBody: ForwardRefExoticComponent<TreeItemBodyProps> = ListItem.CollapsibleContent;\n\nexport const Tree = { Root: TreeRoot, Branch: TreeBranch };\nexport const TreeItem: {\n Root: ForwardRefExoticComponent<TreeItemProps>;\n Heading: ForwardRefExoticComponent<TreeItemHeadingProps>;\n Body: ForwardRefExoticComponent<TreeItemBodyProps>;\n OpenTrigger: ForwardRefExoticComponent<TreeItemOpenTriggerProps>;\n MockOpenTrigger: FC<ThemedClassName<Omit<ComponentPropsWithoutRef<'div'>, 'children'>>>;\n DropIndicator: typeof TreeDropIndicator;\n} = {\n Root: TreeItemRoot,\n Heading: TreeItemHeading,\n Body: TreeItemBody,\n OpenTrigger: TreeItemOpenTrigger,\n MockOpenTrigger: MockTreeItemOpenTrigger,\n DropIndicator: TreeDropIndicator,\n};\n\nexport type { TreeRootProps, TreeItemProps, TreeItemHeadingProps, TreeItemBodyProps, TreeItemOpenTriggerProps };\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { type Instruction } from '@atlaskit/pragmatic-drag-and-drop-hitbox/tree-item';\nimport React, { type CSSProperties, type HTMLAttributes } from 'react';\n\n// Tree item hitbox\n// https://github.com/atlassian/pragmatic-drag-and-drop/blob/main/packages/hitbox/constellation/index/about.mdx#tree-item\n\ntype InstructionType = Exclude<Instruction, { type: 'instruction-blocked' }>['type'];\ntype Orientation = 'sibling' | 'child';\n\nconst edgeToOrientationMap: Record<InstructionType, Orientation> = {\n 'reorder-above': 'sibling',\n 'reorder-below': 'sibling',\n 'make-child': 'child',\n reparent: 'child',\n};\n\nconst orientationStyles: Record<Orientation, HTMLAttributes<HTMLElement>['className']> = {\n // TODO(wittjosiah): Stop using left/right here.\n sibling:\n 'h-(--line-thickness) left-(--horizontal-indent) right-0 bg-accent-surface before:left-(--negative-terminal-size)',\n child: 'inset-0 border-[length:var(--line-thickness)] before:invisible',\n};\n\nconst instructionStyles: Record<InstructionType, HTMLAttributes<HTMLElement>['className']> = {\n 'reorder-above': 'top-(--line-offset) before:top-(--offset-terminal)',\n 'reorder-below': 'bottom-(--line-offset) before:bottom-(--offset-terminal)',\n 'make-child': 'border-accent-surface',\n // TODO(wittjosiah): This is not occurring in the current implementation.\n reparent: '',\n};\n\nconst strokeSize = 2;\nconst terminalSize = 8;\nconst offsetToAlignTerminalWithLine = (strokeSize - terminalSize) / 2;\n\nexport type DropIndicatorProps = {\n instruction: Instruction;\n gap?: number;\n};\n\nexport const TreeDropIndicator = ({ instruction, gap = 0 }: DropIndicatorProps) => {\n const lineOffset = `calc(-0.5 * (${gap}px + ${strokeSize}px))`;\n const isBlocked = instruction.type === 'instruction-blocked';\n const desiredInstruction = isBlocked ? instruction.desired : instruction;\n const orientation = edgeToOrientationMap[desiredInstruction.type];\n if (isBlocked) {\n return null;\n }\n\n return (\n <div\n style={\n {\n '--line-thickness': `${strokeSize}px`,\n '--line-offset': `${lineOffset}`,\n '--terminal-size': `${terminalSize}px`,\n '--terminal-radius': `${terminalSize / 2}px`,\n '--negative-terminal-size': `-${terminalSize}px`,\n '--offset-terminal': `${offsetToAlignTerminalWithLine}px`,\n '--horizontal-indent': `${desiredInstruction.currentLevel * desiredInstruction.indentPerLevel + 4}px`,\n } as CSSProperties\n }\n className={`absolute z-10 pointer-events-none before:w-(--terminal-size) before:h-(--terminal-size) box-border before:absolute before:border-[length:--line-thickness] before:border-solid before:border-accent-surface before:rounded-full ${orientationStyles[orientation]} ${instructionStyles[desiredInstruction.type]}`}\n ></div>\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { useFocusFinders } from '@fluentui/react-tabster';\nimport { type Scope, createContextScope } from '@radix-ui/react-context';\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slot } from '@radix-ui/react-slot';\nimport { useControllableState } from '@radix-ui/react-use-controllable-state';\nimport React, {\n type CSSProperties,\n type ComponentPropsWithRef,\n type KeyboardEvent,\n forwardRef,\n useCallback,\n} from 'react';\n\nimport { composable, composableProps } from '@dxos/ui-theme';\n\nimport { useThemeContext } from '../../hooks';\nimport { type ThemedClassName } from '../../util';\n\n// TODO(thure): https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Roles/treegrid_role\n\nconst TREEGRID_ROW_NAME = 'TreegridRow';\n\ntype TreegridRowScopedProps<P> = P & { __treegridRowScope?: Scope };\n\nconst [createTreegridRowContext, createTreegridRowScope] = createContextScope(TREEGRID_ROW_NAME, []);\n\ntype TreegridRowContextValue = {\n open?: boolean;\n onOpenChange?: (nextOpen: boolean) => void;\n};\n\nconst [TreegridRowProvider, useTreegridRowContext] =\n createTreegridRowContext<TreegridRowContextValue>(TREEGRID_ROW_NAME);\n\n// TODO(burdon): Replace with functions.\nexport const TREEGRID_PATH_SEPARATOR = '~';\nexport const TREEGRID_PARENT_OF_SEPARATOR = ' ';\n\ntype TreegridRootProps = ThemedClassName<ComponentPropsWithRef<typeof Primitive.div>> & {\n gridTemplateColumns: CSSProperties['gridTemplateColumns'];\n asChild?: boolean;\n};\n\nconst TreegridRoot = composable<HTMLDivElement, TreegridRootProps>(\n ({ asChild, classNames, children, style, gridTemplateColumns, onKeyDown: onKeyDownProp, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const { className, role: _role, ...rest } = composableProps<HTMLDivElement>(props, { classNames });\n const Comp = asChild ? Slot : Primitive.div;\n const { findFirstFocusable } = useFocusFinders();\n\n const handleKeyDown = useCallback(\n (event: KeyboardEvent<HTMLDivElement>) => {\n switch (event.key) {\n case 'ArrowDown':\n case 'ArrowUp': {\n const direction = event.key === 'ArrowDown' ? 'down' : 'up';\n const target = event.target as HTMLElement;\n\n // Find ancestor with data-arrow-keys containing the relevant direction.\n const ancestorWithArrowKeys = target.closest(`[data-arrow-keys*=\"${direction}\"], [data-arrow-keys=\"all\"]`);\n\n // If no ancestor with data-arrow-keys found, proceed with row navigation.\n if (!ancestorWithArrowKeys) {\n // Find the closest row\n const currentRow = target.closest('[role=\"row\"]');\n if (currentRow) {\n // Find the treegrid container.\n const treegrid = currentRow.closest('[role=\"treegrid\"]');\n if (treegrid) {\n // Get all rows in the treegrid.\n const rows = Array.from(treegrid.querySelectorAll('[role=\"row\"]'));\n const currentIndex = rows.indexOf(currentRow as Element);\n\n // Find next or previous row.\n const nextIndex = direction === 'down' ? currentIndex + 1 : currentIndex - 1;\n const targetRow = rows[nextIndex];\n\n if (targetRow) {\n // Focus the first focusable element in the target row.\n const firstFocusable = findFirstFocusable(targetRow as HTMLElement);\n if (firstFocusable) {\n event.preventDefault();\n firstFocusable.focus();\n }\n }\n }\n }\n }\n break;\n }\n }\n onKeyDownProp?.(event);\n },\n [findFirstFocusable, onKeyDownProp],\n );\n\n return (\n <Comp\n role='treegrid'\n {...rest}\n className={tx('treegrid.root', {}, className)}\n style={{ ...style, gridTemplateColumns }}\n onKeyDown={handleKeyDown}\n ref={forwardedRef}\n >\n {children}\n </Comp>\n );\n },\n);\n\ntype TreegridRowProps = ThemedClassName<ComponentPropsWithRef<typeof Primitive.div>> & {\n id: string;\n asChild?: boolean;\n parentOf?: string;\n defaultOpen?: boolean;\n open?: boolean;\n onOpenChange?(open: boolean): void;\n};\n\nconst TreegridRow = forwardRef<HTMLDivElement, TreegridRowScopedProps<TreegridRowProps>>(\n (\n {\n __treegridRowScope,\n asChild,\n classNames,\n children,\n id,\n parentOf,\n open: propsOpen,\n defaultOpen,\n onOpenChange: propsOnOpenChange,\n ...props\n },\n forwardedRef,\n ) => {\n const { tx } = useThemeContext();\n const Comp = asChild ? Slot : Primitive.div;\n const pathParts = id.split(TREEGRID_PATH_SEPARATOR);\n const level = pathParts.length - 1;\n const [open, onOpenChange] = useControllableState({\n prop: propsOpen,\n onChange: propsOnOpenChange,\n defaultProp: defaultOpen,\n });\n\n return (\n <TreegridRowProvider open={open} onOpenChange={onOpenChange} scope={__treegridRowScope}>\n <Comp\n role='row'\n aria-level={level}\n className={tx('treegrid.row', { level }, classNames)}\n {...(parentOf && { 'aria-expanded': open, 'aria-owns': parentOf })}\n {...props}\n id={id}\n ref={forwardedRef}\n >\n {children}\n </Comp>\n </TreegridRowProvider>\n );\n },\n);\n\ntype TreegridCellProps = ThemedClassName<ComponentPropsWithRef<typeof Primitive.div>> & { indent?: boolean };\n\nconst TreegridCell = forwardRef<HTMLDivElement, TreegridCellProps>(\n ({ classNames, children, indent, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return (\n <div role='gridcell' className={tx('treegrid.cell', { indent }, classNames)} {...props} ref={forwardedRef}>\n {children}\n </div>\n );\n },\n);\n\nexport type { TreegridRootProps, TreegridRowProps };\n\nexport const Treegrid = {\n Root: TreegridRoot,\n Row: TreegridRow,\n Cell: TreegridCell,\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { useFocusableGroup } from '@fluentui/react-tabster';\nimport { createContext } from '@radix-ui/react-context';\nimport { DialogContent, Root as DialogRoot, DialogTitle } from '@radix-ui/react-dialog';\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slot } from '@radix-ui/react-slot';\nimport { useControllableState } from '@radix-ui/react-use-controllable-state';\nimport React, {\n type ComponentPropsWithRef,\n type ComponentPropsWithoutRef,\n type Dispatch,\n type KeyboardEvent,\n type PropsWithChildren,\n type SetStateAction,\n forwardRef,\n useCallback,\n useEffect,\n useRef,\n useState,\n} from 'react';\n\nimport { addEventListener } from '@dxos/async';\nimport { log } from '@dxos/log';\nimport { useForwardedRef, useMediaQuery } from '@dxos/react-hooks';\nimport { type MainStyleProps, osTranslations } from '@dxos/ui-theme';\n\nimport { useThemeContext } from '../../hooks';\nimport { type ThemedClassName } from '../../util';\nimport { type Label, toLocalizedString, useTranslation } from '../ThemeProvider';\nimport { useSwipeToDismiss } from './useSwipeToDismiss';\n\nconst MAIN_NAME = 'Main';\nconst MAIN_ROOT_NAME = 'MainRoot';\nconst MAIN_OVERLAY_NAME = 'MainOverlay';\nconst NAVIGATION_SIDEBAR_NAME = 'NavigationSidebar';\nconst COMPLEMENTARY_SIDEBAR_NAME = 'ComplementarySidebar';\n\nconst handleOpenAutoFocus = (event: Event) => {\n !document.body.hasAttribute('data-w-keyboard') && event.preventDefault();\n};\n\n//\n// Landmark\n//\n\nconst landmarkAttr = 'data-main-landmark';\n\n/**\n * Facilitates moving focus between landmarks.\n * Ref https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Roles/landmark_role\n */\nconst useLandmarkMover = (propsOnKeyDown: ComponentPropsWithoutRef<'div'>['onKeyDown'], landmark: string) => {\n const handleKeyDown = useCallback(\n (event: KeyboardEvent<HTMLDivElement>) => {\n const target = event.target as HTMLDivElement;\n if (event.target === event.currentTarget && event.key === 'Tab' && target.hasAttribute(landmarkAttr)) {\n event.preventDefault();\n const landmarks = Array.from(document.querySelectorAll(`[${landmarkAttr}]:not([inert])`))\n .map((el) => (el.hasAttribute(landmarkAttr) ? parseInt(el.getAttribute(landmarkAttr)!) : NaN))\n .sort();\n const l = landmarks.length;\n const cursor = landmarks.indexOf(parseInt(target.getAttribute(landmarkAttr)!));\n const nextLandmark = landmarks[(cursor + l + (event.getModifierState('Shift') ? -1 : 1)) % l];\n (document.querySelector(`[${landmarkAttr}=\"${nextLandmark}\"]`) as HTMLDivElement | null)?.focus();\n }\n propsOnKeyDown?.(event);\n },\n [propsOnKeyDown],\n );\n\n // TODO(thure): This was disconnected once before in #8818;\n // if this should change again to support the browser extension, please ensure the change doesn’t break web, desktop and mobile.\n const focusableGroupAttrs = useFocusableGroup({ tabBehavior: 'limited', ignoreDefaultKeydown: { Tab: true } });\n\n return {\n [landmarkAttr]: landmark,\n tabIndex: 0,\n onKeyDown: handleKeyDown,\n ...focusableGroupAttrs,\n };\n};\n\n//\n// Context\n//\n\n// TODO(burdon): Define collapsed state.\ntype SidebarState = 'expanded' | 'collapsed' | 'closed';\n\ntype MainContextValue = {\n resizing: boolean;\n\n // Navigation\n navigationSidebarState: SidebarState;\n setNavigationSidebarState: Dispatch<SetStateAction<SidebarState | undefined>>;\n\n // Complementary\n complementarySidebarState: SidebarState;\n setComplementarySidebarState: Dispatch<SetStateAction<SidebarState | undefined>>;\n};\n\nconst [MainProvider, useMainContext] = createContext<MainContextValue>(MAIN_NAME, {\n resizing: false,\n\n navigationSidebarState: 'closed',\n setNavigationSidebarState: (_nextState) => {\n log.warn('Not initialized');\n },\n\n complementarySidebarState: 'closed',\n setComplementarySidebarState: (_nextState) => {\n log.warn('Not initialized');\n },\n});\n\nconst useSidebars = (consumerName: string) => {\n const {\n navigationSidebarState,\n setNavigationSidebarState,\n\n complementarySidebarState,\n setComplementarySidebarState,\n } = useMainContext(consumerName);\n\n return {\n navigationSidebarState,\n setNavigationSidebarState,\n toggleNavigationSidebar: useCallback(\n () => setNavigationSidebarState(navigationSidebarState === 'expanded' ? 'closed' : 'expanded'),\n [navigationSidebarState, setNavigationSidebarState],\n ),\n openNavigationSidebar: useCallback(() => setNavigationSidebarState('expanded'), []),\n collapseNavigationSidebar: useCallback(() => setNavigationSidebarState('collapsed'), []),\n closeNavigationSidebar: useCallback(() => setNavigationSidebarState('closed'), []),\n\n complementarySidebarState,\n setComplementarySidebarState,\n toggleComplementarySidebar: useCallback(\n () => setComplementarySidebarState(complementarySidebarState === 'expanded' ? 'closed' : 'expanded'),\n [complementarySidebarState, setComplementarySidebarState],\n ),\n openComplementarySidebar: useCallback(() => setComplementarySidebarState('expanded'), []),\n collapseComplementarySidebar: useCallback(() => setComplementarySidebarState('collapsed'), []),\n closeComplementarySidebar: useCallback(() => setComplementarySidebarState('closed'), []),\n };\n};\n\n//\n// Root\n//\n\ntype MainRootProps = PropsWithChildren<{\n navigationSidebarState?: SidebarState;\n defaultNavigationSidebarState?: SidebarState;\n onNavigationSidebarStateChange?: (nextState: SidebarState) => void;\n\n complementarySidebarState?: SidebarState;\n defaultComplementarySidebarState?: SidebarState;\n onComplementarySidebarStateChange?: (nextState: SidebarState) => void;\n}>;\n\nconst MainRoot = ({\n navigationSidebarState: propsNavigationSidebarState,\n defaultNavigationSidebarState = 'closed',\n onNavigationSidebarStateChange,\n\n complementarySidebarState: propsComplementarySidebarState,\n defaultComplementarySidebarState = 'closed',\n onComplementarySidebarStateChange,\n\n children,\n ...props\n}: MainRootProps) => {\n const [isLg] = useMediaQuery('lg');\n const [navigationSidebarState = isLg ? 'expanded' : 'collapsed', setNavigationSidebarState] =\n useControllableState<SidebarState>({\n prop: propsNavigationSidebarState,\n defaultProp: defaultNavigationSidebarState,\n onChange: onNavigationSidebarStateChange,\n });\n const [complementarySidebarState = isLg ? 'expanded' : 'collapsed', setComplementarySidebarState] =\n useControllableState<SidebarState>({\n prop: propsComplementarySidebarState,\n defaultProp: defaultComplementarySidebarState,\n onChange: onComplementarySidebarStateChange,\n });\n\n const [resizing, setResizing] = useState(false);\n const resizeInterval = useRef<ReturnType<typeof setTimeout> | null>(null);\n useEffect(\n () =>\n addEventListener(window, 'resize', () => {\n setResizing(true);\n if (resizeInterval.current) {\n clearTimeout(resizeInterval.current);\n }\n\n resizeInterval.current = setTimeout(() => {\n setResizing(false);\n resizeInterval.current = null;\n }, 3_000);\n }),\n [],\n );\n\n return (\n <MainProvider\n {...props}\n {...{\n navigationSidebarState,\n setNavigationSidebarState,\n complementarySidebarState,\n setComplementarySidebarState,\n }}\n resizing={resizing}\n >\n {children}\n </MainProvider>\n );\n};\n\nMainRoot.displayName = MAIN_ROOT_NAME;\n\n//\n// Overlay\n//\n\ntype MainOverlayProps = ThemedClassName<Omit<ComponentPropsWithRef<typeof Primitive.div>, 'children' | 'onClick'>>;\n\nconst MainOverlay = forwardRef<HTMLDivElement, MainOverlayProps>(({ classNames, ...props }, forwardedRef) => {\n const [isLg] = useMediaQuery('lg');\n const { navigationSidebarState, setNavigationSidebarState, complementarySidebarState, setComplementarySidebarState } =\n useMainContext(MAIN_OVERLAY_NAME);\n const { tx } = useThemeContext();\n return (\n <div\n {...props}\n onClick={() => {\n setNavigationSidebarState('collapsed');\n setComplementarySidebarState('collapsed');\n }}\n className={tx(\n 'main.overlay',\n {\n isLg,\n inlineStartSidebarOpen: navigationSidebarState,\n inlineEndSidebarOpen: complementarySidebarState,\n },\n classNames,\n )}\n data-state={navigationSidebarState === 'expanded' || complementarySidebarState === 'expanded' ? 'open' : 'closed'}\n aria-hidden='true'\n ref={forwardedRef}\n />\n );\n});\n\nMainOverlay.displayName = MAIN_OVERLAY_NAME;\n\n//\n// Sidebar\n//\n\ntype MainSidebarProps = ThemedClassName<ComponentPropsWithRef<typeof DialogContent>> & {\n swipeToDismiss?: boolean;\n state?: SidebarState;\n resizing?: boolean;\n onStateChange?: (nextState: SidebarState) => void;\n side: 'w-start' | 'w-end';\n label: Label;\n};\n\nconst MainSidebar = forwardRef<HTMLDivElement, MainSidebarProps>(\n (\n { classNames, children, swipeToDismiss, onOpenAutoFocus, state, resizing, onStateChange, side, label, ...props },\n forwardedRef,\n ) => {\n const [isLg] = useMediaQuery('lg');\n const { tx } = useThemeContext();\n const { t } = useTranslation(osTranslations);\n const ref = useForwardedRef(forwardedRef);\n const noopRef = useRef(null);\n\n useSwipeToDismiss(swipeToDismiss ? ref : noopRef, {\n onDismiss: () => onStateChange?.('closed'),\n });\n\n // NOTE(thure): This is a workaround for something further down the tree grabbing focus on Escape. Adding this\n // intervention to `Tabs.Root` or `Tabs.Tabpenel` instances is somehow ineffectual.\n const handleKeyDown = useCallback(\n (event: KeyboardEvent<HTMLDivElement>) => {\n const focusGroupParent = (event.target as HTMLElement).closest('[data-tabster]');\n if (event.key === 'Escape' && focusGroupParent) {\n event.preventDefault();\n event.stopPropagation();\n (focusGroupParent as HTMLElement).focus();\n }\n props.onKeyDown?.(event);\n },\n [props.onKeyDown],\n );\n\n const Root = isLg ? Primitive.div : DialogContent;\n\n return (\n <DialogRoot open={state !== 'closed'} aria-label={toLocalizedString(label, t)} modal={false}>\n {!isLg && <DialogTitle className='sr-only'>{toLocalizedString(label, t)}</DialogTitle>}\n <Root\n {...(!isLg && { forceMount: true, tabIndex: -1, onOpenAutoFocus: onOpenAutoFocus ?? handleOpenAutoFocus })}\n {...(state === 'closed' && { inert: true })}\n {...props}\n data-side={side === 'w-end' ? 'ie' : 'is'}\n data-state={state}\n data-resizing={resizing ? 'true' : 'false'}\n className={tx('main.sidebar', {}, classNames)}\n onKeyDownCapture={handleKeyDown}\n ref={ref}\n >\n {children}\n </Root>\n </DialogRoot>\n );\n },\n);\n\n//\n// Navigation Sidebar\n//\n\ntype MainNavigationSidebarProps = Omit<MainSidebarProps, 'expanded' | 'side'>;\n\nconst MainNavigationSidebar = forwardRef<HTMLDivElement, MainNavigationSidebarProps>((props, forwardedRef) => {\n const { navigationSidebarState, setNavigationSidebarState, resizing } = useMainContext(NAVIGATION_SIDEBAR_NAME);\n const mover = useLandmarkMover(props.onKeyDown, '0');\n\n return (\n <MainSidebar\n {...mover}\n {...props}\n state={navigationSidebarState}\n onStateChange={setNavigationSidebarState}\n resizing={resizing}\n side='w-start'\n ref={forwardedRef}\n />\n );\n});\n\nMainNavigationSidebar.displayName = NAVIGATION_SIDEBAR_NAME;\n\n//\n// Complementary Sidebar\n//\n\ntype MainComplementarySidebarProps = Omit<MainSidebarProps, 'expanded' | 'side'>;\n\nconst MainComplementarySidebar = forwardRef<HTMLDivElement, MainComplementarySidebarProps>((props, forwardedRef) => {\n const { complementarySidebarState, setComplementarySidebarState, resizing } =\n useMainContext(COMPLEMENTARY_SIDEBAR_NAME);\n const mover = useLandmarkMover(props.onKeyDown, '2');\n\n return (\n <MainSidebar\n {...mover}\n {...props}\n state={complementarySidebarState}\n onStateChange={setComplementarySidebarState}\n resizing={resizing}\n side='w-end'\n ref={forwardedRef}\n />\n );\n});\n\nMainComplementarySidebar.displayName = COMPLEMENTARY_SIDEBAR_NAME;\n\n//\n// Content\n//\n\ntype MainContentProps = ThemedClassName<\n ComponentPropsWithRef<typeof Primitive.div> &\n MainStyleProps & {\n asChild?: boolean;\n }\n>;\n\nconst MainContent = forwardRef<HTMLDivElement, MainContentProps>(\n ({ asChild, classNames, bounce, handlesFocus, children, role, ...props }: MainContentProps, forwardedRef) => {\n const { navigationSidebarState, complementarySidebarState } = useMainContext(MAIN_NAME);\n const { tx } = useThemeContext();\n const Comp = asChild ? Slot : role ? Primitive.div : 'main';\n const mover = useLandmarkMover(props.onKeyDown, '1');\n\n return (\n <Comp\n {...(handlesFocus && { ...mover })}\n {...props}\n role={role}\n data-sidebar-left-state={navigationSidebarState}\n data-sidebar-right-state={complementarySidebarState}\n data-handles-focus={handlesFocus}\n className={tx('main.content', { bounce, handlesFocus }, classNames)}\n ref={forwardedRef}\n >\n {children}\n </Comp>\n );\n },\n);\n\nMainContent.displayName = MAIN_NAME;\n\n//\n// Main\n//\n\nexport const Main = {\n Root: MainRoot,\n Overlay: MainOverlay,\n Content: MainContent,\n NavigationSidebar: MainNavigationSidebar,\n ComplementarySidebar: MainComplementarySidebar,\n};\n\nexport { useMainContext, useSidebars, useLandmarkMover };\n\nexport type { MainRootProps, MainOverlayProps, MainContentProps, MainNavigationSidebarProps, SidebarState };\n", "//\n// Copyright 2023 DXOS.org\n//\n\n// This implementation is based upon https://github.com/hosembafer/react-swipe-to-dismiss, commit d88deafe910a6bd1400cf8fa90459a76cf4f71d3\n\nimport { type RefObject, useCallback, useEffect, useState } from 'react';\n\nenum MotionState {\n IDLE,\n DEBOUNCING,\n FOLLOWING,\n}\n\ntype Options = Partial<{\n onDismiss: () => void;\n dismissThreshold: number;\n debounceThreshold: number;\n side: 'inline-start' | 'inline-end';\n offset: number;\n}>;\n\nexport const useSwipeToDismiss = (\n ref: RefObject<HTMLElement | null>,\n { onDismiss, dismissThreshold = 64, debounceThreshold = 8, offset = 0 /* side = 'inline-start' */ }: Options,\n) => {\n const $root = ref.current;\n // todo(thure): Implement other sides.\n // const dK = direction === 'inline-start' ? 1 : -1;\n\n const [motionState, setMotionState] = useState<MotionState>(MotionState.IDLE);\n const [gestureStartX, setGestureStartX] = useState(0);\n\n const setIdle = useCallback(() => {\n setMotionState(MotionState.IDLE);\n $root?.style.removeProperty('inset-inline-start');\n $root?.style.setProperty('transition-duration', '200ms');\n }, [$root]);\n\n const setFollowing = useCallback(() => {\n setMotionState(MotionState.FOLLOWING);\n $root?.style.setProperty('transition-duration', '0ms');\n }, [$root]);\n\n const handlePointerDown = useCallback(\n ({ screenX }: PointerEvent) => {\n if (motionState === MotionState.IDLE) {\n setMotionState(MotionState.DEBOUNCING);\n setGestureStartX(screenX);\n }\n },\n [motionState],\n );\n\n const handlePointerMove = useCallback(\n ({ screenX }: PointerEvent) => {\n if ($root) {\n const delta = Math.min(screenX - gestureStartX, 0);\n switch (motionState) {\n case MotionState.FOLLOWING:\n if (Math.abs(delta) > dismissThreshold) {\n setIdle();\n onDismiss?.();\n } else {\n $root.style.setProperty('inset-inline-start', `${offset + delta}px`);\n }\n break;\n case MotionState.DEBOUNCING:\n if (Math.abs(delta) > debounceThreshold) {\n setFollowing();\n }\n break;\n }\n }\n },\n [$root, motionState, gestureStartX],\n );\n\n const handlePointerUp = useCallback(() => {\n setIdle();\n }, [setIdle]);\n\n useEffect(() => {\n $root?.addEventListener('pointerdown', handlePointerDown);\n return () => {\n $root?.removeEventListener('pointerdown', handlePointerDown);\n };\n }, [$root, handlePointerDown]);\n\n useEffect(() => {\n $root && document.documentElement.addEventListener('pointermove', handlePointerMove);\n return () => {\n document.documentElement.removeEventListener('pointermove', handlePointerMove);\n };\n }, [$root, handlePointerMove]);\n\n useEffect(() => {\n $root && document.documentElement.addEventListener('pointerup', handlePointerUp);\n return () => {\n document.documentElement.removeEventListener('pointerup', handlePointerUp);\n };\n }, [$root, handlePointerUp]);\n};\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { createContext } from '@radix-ui/react-context';\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slot } from '@radix-ui/react-slot';\nimport React, { type ComponentPropsWithRef, forwardRef } from 'react';\n\nimport { useId } from '@dxos/react-hooks';\nimport { type Elevation, type MessageValence } from '@dxos/ui-types';\n\nimport { useElevationContext, useThemeContext } from '../../hooks';\nimport { type ThemedClassName } from '../../util';\nimport { Icon } from '../Icon';\n\nconst messageIcons: Record<MessageValence, string> = {\n success: 'ph--check-circle--duotone',\n info: 'ph--info--duotone',\n warning: 'ph--warning--duotone',\n error: 'ph--warning-circle--duotone',\n neutral: 'ph--info--duotone',\n};\n\ntype MessageRootProps = ThemedClassName<ComponentPropsWithRef<typeof Primitive.div>> & {\n valence?: MessageValence;\n elevation?: Elevation;\n asChild?: boolean;\n titleId?: string;\n descriptionId?: string;\n};\n\ntype MessageContextValue = { titleId?: string; descriptionId: string; valence: MessageValence };\n\nconst MESSAGE_NAME = 'Message';\n\nconst [MessageProvider, useMessageContext] = createContext<MessageContextValue>(MESSAGE_NAME);\n\n//\n// Root\n//\n\nconst MessageRoot = forwardRef<HTMLDivElement, MessageRootProps>(\n (\n {\n asChild,\n valence = 'neutral',\n elevation: propsElevation,\n classNames,\n titleId: propsTitleId,\n descriptionId: propsDescriptionId,\n children,\n ...props\n },\n forwardedRef,\n ) => {\n const { tx } = useThemeContext();\n const titleId = useId('message__title', propsTitleId);\n const descriptionId = useId('message__description', propsDescriptionId);\n const elevation = useElevationContext(propsElevation);\n const Comp = asChild ? Slot : Primitive.div;\n\n return (\n <MessageProvider {...{ titleId, descriptionId, valence }}>\n <Comp\n role={valence === 'neutral' ? 'paragraph' : 'alert'}\n {...props}\n className={tx('message.root', { valence, elevation }, classNames)}\n aria-labelledby={titleId}\n aria-describedby={descriptionId}\n ref={forwardedRef}\n >\n {children}\n </Comp>\n </MessageProvider>\n );\n },\n);\n\nMessageRoot.displayName = MESSAGE_NAME;\n\n//\n// Title\n//\n\ntype MessageTitleProps = Omit<ThemedClassName<ComponentPropsWithRef<typeof Primitive.h2>>, 'id'> & {\n asChild?: boolean;\n icon?: string;\n};\n\nconst MESSAGE_TITLE_NAME = 'MessageTitle';\n\nconst MessageTitle = forwardRef<HTMLHeadingElement, MessageTitleProps>(\n ({ asChild, classNames, children, icon: iconProp, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const { titleId, valence } = useMessageContext(MESSAGE_TITLE_NAME);\n const Comp = asChild ? Slot : Primitive.h2;\n const icon = iconProp ?? messageIcons[valence];\n return (\n <Comp {...props} className={tx('message.header', {}, classNames)} id={titleId} ref={forwardedRef}>\n {!icon && valence === 'neutral' ? <div /> : <Icon icon={icon} classNames={tx('message.icon', { valence })} />}\n <span className={tx('message.title', {}, classNames)}>{children}</span>\n </Comp>\n );\n },\n);\n\nMessageTitle.displayName = MESSAGE_TITLE_NAME;\n\n//\n// Content\n//\n\ntype MessageContentProps = Omit<ThemedClassName<ComponentPropsWithRef<typeof Primitive.h2>>, 'id'> & {\n asChild?: boolean;\n};\n\nconst MESSAGE_CONTENT_NAME = 'MessageContent';\n\nconst MessageContent = forwardRef<HTMLParagraphElement, MessageContentProps>(\n ({ asChild, classNames, children, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const { descriptionId } = useMessageContext(MESSAGE_CONTENT_NAME);\n const Comp = asChild ? Slot : Primitive.p;\n return (\n <Comp {...props} className={tx('message.content', {}, classNames)} id={descriptionId} ref={forwardedRef}>\n {children}\n </Comp>\n );\n },\n);\n\nMessageContent.displayName = MESSAGE_CONTENT_NAME;\n\n//\n// Message\n//\n\nexport const Message = {\n Root: MessageRoot,\n Title: MessageTitle,\n Content: MessageContent,\n};\n\nexport const Callout = Message;\n\nexport type { MessageRootProps, MessageTitleProps, MessageContentProps };\n\nexport { messageIcons };\n", "//\n// Copyright 2023 DXOS.org\n//\n\n// This is based upon `@radix-ui/react-popover` fetched Oct 25, 2024 at https://github.com/radix-ui/primitives at commit 374c7d7.\n\nimport { composeEventHandlers } from '@radix-ui/primitive';\nimport { useComposedRefs } from '@radix-ui/react-compose-refs';\nimport { createContextScope } from '@radix-ui/react-context';\nimport { type Scope } from '@radix-ui/react-context';\nimport { DismissableLayer } from '@radix-ui/react-dismissable-layer';\nimport { useFocusGuards } from '@radix-ui/react-focus-guards';\nimport { FocusScope } from '@radix-ui/react-focus-scope';\nimport { useId } from '@radix-ui/react-id';\nimport * as PopperPrimitive from '@radix-ui/react-popper';\nimport { createPopperScope } from '@radix-ui/react-popper';\nimport { Portal as PortalPrimitive } from '@radix-ui/react-portal';\nimport { Presence } from '@radix-ui/react-presence';\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slot } from '@radix-ui/react-slot';\nimport { useControllableState } from '@radix-ui/react-use-controllable-state';\nimport { hideOthers } from 'aria-hidden';\nimport React, {\n type ComponentPropsWithRef,\n type ComponentPropsWithoutRef,\n type ComponentRef,\n type FC,\n type ReactNode,\n type RefObject,\n forwardRef,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from 'react';\nimport { RemoveScroll } from 'react-remove-scroll';\n\nimport { useSafeCollisionPadding, useElevationContext, useThemeContext } from '../../hooks';\nimport { type ThemedClassName } from '../../util';\n\n//\n// Context\n//\n\ntype ScopedProps<P> = P & { __scopePopover?: Scope };\n\nconst POPOVER_NAME = 'Popover';\n\nconst [createPopoverContext, createPopoverScope] = createContextScope(POPOVER_NAME, [createPopperScope]);\n\nconst usePopperScope = createPopperScope();\n\ntype PopoverContextValue = {\n triggerRef: RefObject<HTMLButtonElement>;\n contentId: string;\n hasCustomAnchor: boolean;\n modal: boolean;\n open: boolean;\n onOpenChange(open: boolean): void;\n onOpenToggle(): void;\n onCustomAnchorAdd(): void;\n onCustomAnchorRemove(): void;\n};\n\nconst [PopoverProvider, usePopoverContext] = createPopoverContext<PopoverContextValue>(POPOVER_NAME);\n\n//\n// PopoverRoot\n//\n\ntype PopoverRootProps = {\n children?: ReactNode;\n open?: boolean;\n defaultOpen?: boolean;\n onOpenChange?: (open: boolean) => void;\n modal?: boolean;\n};\n\nconst PopoverRoot: FC<PopoverRootProps> = (props: ScopedProps<PopoverRootProps>) => {\n const { __scopePopover, children, open: openProp, defaultOpen, onOpenChange, modal = false } = props;\n const popperScope = usePopperScope(__scopePopover);\n const triggerRef = useRef<HTMLButtonElement>(null);\n const [hasCustomAnchor, setHasCustomAnchor] = useState(false);\n const [open = false, setOpen] = useControllableState({\n prop: openProp,\n defaultProp: defaultOpen,\n onChange: onOpenChange,\n });\n\n return (\n <PopperPrimitive.Root {...popperScope}>\n <PopoverProvider\n scope={__scopePopover}\n contentId={useId()}\n triggerRef={triggerRef as RefObject<HTMLButtonElement>}\n open={open}\n onOpenChange={setOpen}\n onOpenToggle={useCallback(() => setOpen((prevOpen) => !prevOpen), [setOpen])}\n hasCustomAnchor={hasCustomAnchor}\n onCustomAnchorAdd={useCallback(() => setHasCustomAnchor(true), [])}\n onCustomAnchorRemove={useCallback(() => setHasCustomAnchor(false), [])}\n modal={modal}\n >\n {children}\n </PopoverProvider>\n </PopperPrimitive.Root>\n );\n};\n\nPopoverRoot.displayName = POPOVER_NAME;\n\n//\n// PopoverAnchor\n//\n\nconst ANCHOR_NAME = 'PopoverAnchor';\n\ntype PopoverAnchorElement = ComponentRef<typeof PopperPrimitive.Anchor>;\ntype PopperAnchorProps = ComponentPropsWithoutRef<typeof PopperPrimitive.Anchor>;\ntype PopoverAnchorProps = PopperAnchorProps;\n\nconst PopoverAnchor = forwardRef<PopoverAnchorElement, PopoverAnchorProps>(\n (props: ScopedProps<PopoverAnchorProps>, forwardedRef) => {\n const { __scopePopover, ...anchorProps } = props;\n const context = usePopoverContext(ANCHOR_NAME, __scopePopover);\n const popperScope = usePopperScope(__scopePopover);\n const { onCustomAnchorAdd, onCustomAnchorRemove } = context;\n\n useEffect(() => {\n onCustomAnchorAdd();\n return () => onCustomAnchorRemove();\n }, [onCustomAnchorAdd, onCustomAnchorRemove]);\n\n return <PopperPrimitive.Anchor {...popperScope} {...anchorProps} ref={forwardedRef} />;\n },\n);\n\nPopoverAnchor.displayName = ANCHOR_NAME;\n\n//\n// PopoverTrigger\n//\n\nconst TRIGGER_NAME = 'PopoverTrigger';\n\ntype PopoverTriggerElement = ComponentRef<typeof Primitive.button>;\ntype PrimitiveButtonProps = ComponentPropsWithoutRef<typeof Primitive.button>;\ntype PopoverTriggerProps = PrimitiveButtonProps & {\n asChild?: boolean;\n};\n\nconst PopoverTrigger = forwardRef<PopoverTriggerElement, PopoverTriggerProps>(\n (props: ScopedProps<PopoverTriggerProps>, forwardedRef) => {\n const { __scopePopover, asChild, ...triggerProps } = props;\n const context = usePopoverContext(TRIGGER_NAME, __scopePopover);\n const popperScope = usePopperScope(__scopePopover);\n const composedTriggerRef = useComposedRefs(forwardedRef, context.triggerRef);\n const Comp = asChild ? Slot : Primitive.button;\n\n const trigger = (\n <Comp\n type='button'\n aria-haspopup='dialog'\n aria-expanded={context.open}\n aria-controls={context.contentId}\n data-state={getState(context.open)}\n {...triggerProps}\n ref={composedTriggerRef}\n onClick={composeEventHandlers(props.onClick, context.onOpenToggle)}\n />\n );\n\n return context.hasCustomAnchor ? (\n trigger\n ) : (\n <PopperPrimitive.Anchor asChild {...popperScope}>\n {trigger}\n </PopperPrimitive.Anchor>\n );\n },\n);\n\nPopoverTrigger.displayName = TRIGGER_NAME;\n\n//\n// PopoverVirtualTrigger\n//\n\nconst VIRTUAL_TRIGGER_NAME = 'PopoverVirtualTrigger';\n\ntype PopoverVirtualTriggerProps = {\n virtualRef: RefObject<PopoverTriggerElement | null>;\n};\n\nconst PopoverVirtualTrigger = (props: ScopedProps<PopoverVirtualTriggerProps>) => {\n const { __scopePopover, virtualRef } = props;\n const context = usePopoverContext(VIRTUAL_TRIGGER_NAME, __scopePopover);\n const popperScope = usePopperScope(__scopePopover);\n useEffect(() => {\n if (virtualRef.current) {\n context.triggerRef.current = virtualRef.current;\n }\n });\n return <PopperPrimitive.Anchor {...popperScope} virtualRef={virtualRef as RefObject<PopoverTriggerElement>} />;\n};\n\nPopoverVirtualTrigger.displayName = VIRTUAL_TRIGGER_NAME;\n\n//\n// PopoverPortal\n//\n\nconst PORTAL_NAME = 'PopoverPortal';\n\ntype PortalContextValue = { forceMount?: true };\nconst [PortalProvider, usePortalContext] = createPopoverContext<PortalContextValue>(PORTAL_NAME, {\n forceMount: undefined,\n});\n\ntype PortalProps = ComponentPropsWithoutRef<typeof PortalPrimitive>;\ntype PopoverPortalProps = {\n children?: ReactNode;\n /**\n * Specify a container element to portal the content into.\n */\n container?: PortalProps['container'];\n /**\n * Used to force mounting when more control is needed. Useful when\n * controlling animation with React animation libraries.\n */\n forceMount?: true;\n};\n\nconst PopoverPortal = (props: ScopedProps<PopoverPortalProps>) => {\n const { __scopePopover, forceMount, children, container } = props;\n const context = usePopoverContext(PORTAL_NAME, __scopePopover);\n return (\n <PortalProvider scope={__scopePopover} forceMount={forceMount}>\n <Presence present={forceMount || context.open}>\n <PortalPrimitive asChild container={container}>\n {children}\n </PortalPrimitive>\n </Presence>\n </PortalProvider>\n );\n};\n\nPopoverPortal.displayName = PORTAL_NAME;\n\n//\n// PopoverContent\n//\n\nconst CONTENT_NAME = 'PopoverContent';\n\ntype PopoverContentProps = ThemedClassName<PopoverContentTypeProps> & {\n /**\n * Used to force mounting when more control is needed. Useful when\n * controlling animation with React animation libraries.\n */\n forceMount?: boolean;\n};\n\nconst PopoverContent = forwardRef<PopoverContentTypeElement, PopoverContentProps>(\n (props: ScopedProps<PopoverContentProps>, forwardedRef) => {\n const portalContext = usePortalContext(CONTENT_NAME, props.__scopePopover);\n const { forceMount = portalContext.forceMount, ...contentProps } = props;\n const context = usePopoverContext(CONTENT_NAME, props.__scopePopover);\n\n return (\n <Presence present={forceMount || context.open}>\n {context.modal ? (\n <PopoverContentModal {...contentProps} ref={forwardedRef} />\n ) : (\n <PopoverContentNonModal {...contentProps} ref={forwardedRef} />\n )}\n </Presence>\n );\n },\n);\n\nPopoverContent.displayName = CONTENT_NAME;\n\ntype PopoverContentTypeElement = PopoverContentImplElement;\nexport interface PopoverContentTypeProps extends Omit<\n PopoverContentImplProps,\n 'trapFocus' | 'disableOutsidePointerEvents'\n> {}\n\nconst PopoverContentModal = forwardRef<PopoverContentTypeElement, PopoverContentTypeProps>(\n (props: ScopedProps<PopoverContentTypeProps>, forwardedRef) => {\n const context = usePopoverContext(CONTENT_NAME, props.__scopePopover);\n const contentRef = useRef<HTMLDivElement>(null);\n const composedRefs = useComposedRefs(forwardedRef, contentRef);\n const isRightClickOutsideRef = useRef(false);\n\n // aria-hide everything except the content (better supported equivalent to setting aria-modal)\n useEffect(() => {\n const content = contentRef.current;\n if (content) {\n return hideOthers(content);\n }\n }, []);\n\n return (\n <RemoveScroll as={Slot} allowPinchZoom>\n <PopoverContentImpl\n {...props}\n ref={composedRefs}\n // Make sure we're not trapping once it's been closed (closed !== unmounted when animating out).\n trapFocus={context.open}\n disableOutsidePointerEvents\n onCloseAutoFocus={composeEventHandlers(props.onCloseAutoFocus, (event) => {\n event.preventDefault();\n if (!isRightClickOutsideRef.current) {\n context.triggerRef.current?.focus();\n }\n })}\n onPointerDownOutside={composeEventHandlers(\n props.onPointerDownOutside,\n (event) => {\n const originalEvent = event.detail.originalEvent;\n const ctrlLeftClick = originalEvent.button === 0 && originalEvent.ctrlKey === true;\n const isRightClick = originalEvent.button === 2 || ctrlLeftClick;\n\n isRightClickOutsideRef.current = isRightClick;\n },\n { checkForDefaultPrevented: false },\n )}\n // When focus is trapped, a `focusout` event may still happen.\n // We make sure we don't trigger our `onDismiss` in such case.\n onFocusOutside={composeEventHandlers(props.onFocusOutside, (event) => event.preventDefault(), {\n checkForDefaultPrevented: false,\n })}\n />\n </RemoveScroll>\n );\n },\n);\n\nconst PopoverContentNonModal = forwardRef<PopoverContentTypeElement, PopoverContentTypeProps>(\n (props: ScopedProps<PopoverContentTypeProps>, forwardedRef) => {\n const context = usePopoverContext(CONTENT_NAME, props.__scopePopover);\n const hasInteractedOutsideRef = useRef(false);\n const hasPointerDownOutsideRef = useRef(false);\n\n return (\n <PopoverContentImpl\n {...props}\n ref={forwardedRef}\n trapFocus={false}\n disableOutsidePointerEvents={false}\n onCloseAutoFocus={(event) => {\n props.onCloseAutoFocus?.(event);\n\n if (!event.defaultPrevented) {\n if (!hasInteractedOutsideRef.current) {\n context.triggerRef.current?.focus();\n }\n // Always prevent auto focus because we either focus manually or want user agent focus\n event.preventDefault();\n }\n\n hasInteractedOutsideRef.current = false;\n hasPointerDownOutsideRef.current = false;\n }}\n onInteractOutside={(event) => {\n props.onInteractOutside?.(event);\n\n if (!event.defaultPrevented) {\n hasInteractedOutsideRef.current = true;\n if (event.detail.originalEvent.type === 'pointerdown') {\n hasPointerDownOutsideRef.current = true;\n }\n }\n\n // Prevent dismissing when clicking the trigger.\n // As the trigger is already setup to close, without doing so would\n // cause it to close and immediately open.\n const target = event.target as HTMLElement;\n const targetIsTrigger = context.triggerRef.current?.contains(target);\n if (targetIsTrigger) {\n event.preventDefault();\n }\n\n // On Safari if the trigger is inside a container with tabIndex={0}, when clicked\n // we will get the pointer down outside event on the trigger, but then a subsequent\n // focus outside event on the container, we ignore any focus outside event when we've\n // already had a pointer down outside event.\n if (event.detail.originalEvent.type === 'focusin' && hasPointerDownOutsideRef.current) {\n event.preventDefault();\n }\n }}\n />\n );\n },\n);\n\ntype PopoverContentImplElement = ComponentRef<typeof PopperPrimitive.Content>;\ntype FocusScopeProps = ComponentPropsWithoutRef<typeof FocusScope>;\ntype DismissableLayerProps = ComponentPropsWithoutRef<typeof DismissableLayer>;\ntype PopperContentProps = ThemedClassName<ComponentPropsWithoutRef<typeof PopperPrimitive.Content>>;\n\ntype PopoverContentImplProps = Omit<PopperContentProps, 'onPlaced'> &\n Omit<DismissableLayerProps, 'onDismiss'> & {\n /**\n * Whether focus should be trapped within the `Popover`\n * (default: false)\n */\n trapFocus?: FocusScopeProps['trapped'];\n\n /**\n * Event handler called when auto-focusing on open.\n * Can be prevented.\n */\n onOpenAutoFocus?: FocusScopeProps['onMountAutoFocus'];\n\n /**\n * Event handler called when auto-focusing on close.\n * Can be prevented.\n */\n onCloseAutoFocus?: FocusScopeProps['onUnmountAutoFocus'];\n };\n\nconst PopoverContentImpl = forwardRef<PopoverContentImplElement, PopoverContentImplProps>(\n (props: ScopedProps<PopoverContentImplProps>, forwardedRef) => {\n const {\n __scopePopover,\n trapFocus,\n onOpenAutoFocus,\n onCloseAutoFocus,\n disableOutsidePointerEvents,\n onEscapeKeyDown,\n onPointerDownOutside,\n onFocusOutside,\n onInteractOutside,\n collisionPadding = 8,\n collisionBoundary,\n classNames,\n ...contentProps\n } = props;\n const context = usePopoverContext(CONTENT_NAME, __scopePopover);\n const popperScope = usePopperScope(__scopePopover);\n const { tx } = useThemeContext();\n const elevation = useElevationContext();\n const safeCollisionPadding = useSafeCollisionPadding(collisionPadding);\n\n // Make sure the whole tree has focus guards as our `Popover` may be the last element in the DOM (because of the `Portal`)\n useFocusGuards();\n\n // Check for the closest annotated collision boundary in the DOM tree.\n const computedCollisionBoundary = useMemo(() => {\n const closestBoundary = context.triggerRef.current?.closest(\n '[data-popover-collision-boundary]',\n ) as HTMLElement | null;\n return closestBoundary\n ? Array.isArray(collisionBoundary)\n ? [closestBoundary, ...collisionBoundary]\n : collisionBoundary\n ? [closestBoundary, collisionBoundary]\n : [closestBoundary]\n : collisionBoundary;\n }, [context.open, collisionBoundary, context.triggerRef.current]);\n\n return (\n <FocusScope\n asChild\n loop\n trapped={trapFocus}\n onMountAutoFocus={onOpenAutoFocus}\n onUnmountAutoFocus={onCloseAutoFocus}\n >\n <DismissableLayer\n asChild\n disableOutsidePointerEvents={disableOutsidePointerEvents}\n onInteractOutside={onInteractOutside}\n onEscapeKeyDown={onEscapeKeyDown}\n onPointerDownOutside={onPointerDownOutside}\n onFocusOutside={onFocusOutside}\n onDismiss={() => context.onOpenChange(false)}\n >\n <PopperPrimitive.Content\n data-state={getState(context.open)}\n role='dialog'\n id={context.contentId}\n {...popperScope}\n {...contentProps}\n collisionPadding={safeCollisionPadding}\n collisionBoundary={computedCollisionBoundary}\n className={tx('popover.content', { elevation }, classNames)}\n ref={forwardedRef}\n style={{\n ...contentProps.style,\n // Re-namespace exposed content custom properties.\n ...{\n '--radix-popover-content-transform-origin': 'var(--radix-popper-transform-origin)',\n '--radix-popover-content-available-width': 'var(--radix-popper-available-width)',\n '--radix-popover-content-available-height': 'var(--radix-popper-available-height)',\n '--radix-popover-trigger-width': 'var(--radix-popper-anchor-width)',\n '--radix-popover-trigger-height': 'var(--radix-popper-anchor-height)',\n },\n }}\n />\n </DismissableLayer>\n </FocusScope>\n );\n },\n);\n\n//\n// PopoverClose\n//\n\nconst CLOSE_NAME = 'PopoverClose';\n\ntype PopoverCloseElement = ComponentRef<typeof Primitive.button>;\ntype PopoverCloseProps = PrimitiveButtonProps;\n\nconst PopoverClose = forwardRef<PopoverCloseElement, PopoverCloseProps>(\n (props: ScopedProps<PopoverCloseProps>, forwardedRef) => {\n const { __scopePopover, ...closeProps } = props;\n const context = usePopoverContext(CLOSE_NAME, __scopePopover);\n return (\n <Primitive.button\n type='button'\n {...closeProps}\n ref={forwardedRef}\n onClick={composeEventHandlers(props.onClick, () => context.onOpenChange(false))}\n />\n );\n },\n);\n\nPopoverClose.displayName = CLOSE_NAME;\n\n//\n// PopoverArrow\n//\n\nconst ARROW_NAME = 'PopoverArrow';\n\ntype PopoverArrowElement = ComponentRef<typeof PopperPrimitive.Arrow>;\ntype PopperArrowProps = ThemedClassName<ComponentPropsWithoutRef<typeof PopperPrimitive.Arrow>>;\ntype PopoverArrowProps = PopperArrowProps;\n\nconst PopoverArrow = forwardRef<PopoverArrowElement, PopoverArrowProps>(\n (props: ScopedProps<PopoverArrowProps>, forwardedRef) => {\n const { __scopePopover, classNames, ...arrowProps } = props;\n const popperScope = usePopperScope(__scopePopover);\n const { tx } = useThemeContext();\n return (\n <PopperPrimitive.Arrow\n {...popperScope}\n {...arrowProps}\n className={tx('popover.arrow', {}, classNames)}\n ref={forwardedRef}\n />\n );\n },\n);\n\nPopoverArrow.displayName = ARROW_NAME;\n\n//\n// PopoverViewport\n//\n\ntype PopoverViewportProps = ThemedClassName<ComponentPropsWithRef<typeof Primitive.div>> & {\n asChild?: boolean;\n constrainInline?: boolean;\n constrainBlock?: boolean;\n};\n\nconst PopoverViewport = forwardRef<HTMLDivElement, PopoverViewportProps>(\n ({ classNames, asChild, constrainInline = true, constrainBlock = true, children, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const Comp = asChild ? Slot : Primitive.div;\n return (\n <Comp\n {...props}\n className={tx('popover.viewport', { constrainInline, constrainBlock }, classNames)}\n ref={forwardedRef}\n >\n {children}\n </Comp>\n );\n },\n);\n\nconst getState = (open: boolean) => (open ? 'open' : 'closed');\n\ntype PopoverContentInteractOutsideEvent = Parameters<NonNullable<PopoverContentProps['onInteractOutside']>>[0];\n\n//\n// Popver\n//\n\nexport const Popover = {\n Root: PopoverRoot,\n Anchor: PopoverAnchor,\n Trigger: PopoverTrigger,\n VirtualTrigger: PopoverVirtualTrigger,\n Portal: PopoverPortal,\n Content: PopoverContent,\n Close: PopoverClose,\n Arrow: PopoverArrow,\n Viewport: PopoverViewport,\n};\n\nexport { createPopoverScope };\n\nexport type {\n PopoverRootProps,\n PopoverAnchorProps,\n PopoverTriggerProps,\n PopoverVirtualTriggerProps,\n PopoverPortalProps,\n PopoverContentProps,\n PopoverCloseProps,\n PopoverArrowProps,\n PopoverViewportProps,\n PopoverContentInteractOutsideEvent,\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React, { type ComponentPropsWithRef, forwardRef } from 'react';\n\nimport { type StatusStyleProps } from '@dxos/ui-theme';\n\nimport { useThemeContext } from '../../hooks';\nimport { type ThemedClassName } from '../../util';\n\ntype StatusProps = ThemedClassName<\n ComponentPropsWithRef<'span'> &\n StatusStyleProps & {\n progress?: number;\n }\n>;\n\nconst Status = forwardRef<HTMLSpanElement, StatusProps>(\n ({ classNames, children, progress = 0, indeterminate, variant, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return (\n <span\n role='status'\n {...props}\n className={tx('status.root', { indeterminate, variant }, classNames)}\n ref={forwardedRef}\n >\n <span\n role='none'\n className={tx('status.bar', { indeterminate, variant }, classNames)}\n {...(!indeterminate && { style: { width: `${Math.round(progress * 100)}%` } })}\n />\n {children}\n </span>\n );\n },\n);\n\nexport { Status };\n\nexport type { StatusProps };\n", "//\n// Copyright 2026 DXOS.org\n//\n\nimport { createContext } from '@radix-ui/react-context';\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slot } from '@radix-ui/react-slot';\nimport React, { CSSProperties, useMemo } from 'react';\n\nimport { composableProps, scrollbar, slottable } from '@dxos/ui-theme';\nimport { type AllowedAxis, type SlottableProps } from '@dxos/ui-types';\n\nimport { useThemeContext } from '../../hooks';\n\n//\n// Context\n//\n\nconst SCROLLAREA_NAME = 'ScrollArea';\n\ntype ScrollAreaContextType = {\n /** Orientation of scrollbars. */\n orientation: AllowedAxis;\n /** Hide scrollbars when not scrolling. */\n autoHide: boolean;\n /** Apply padding to opposite side of scrollbar. */\n centered?: boolean;\n /** Apply padding. */\n padding: boolean;\n /** Use thin scrollbars. */\n thin: boolean;\n /** Enable snap scrolling. */\n snap: boolean;\n};\n\nconst [ScrollAreaProvider, useScrollAreaContext] = createContext<ScrollAreaContextType>(SCROLLAREA_NAME);\n\n//\n// Root\n//\n\nconst SCROLLAREA_ROOT_NAME = 'ScrollArea.Root';\n\ntype ScrollAreaRootProps = Partial<ScrollAreaContextType>;\n\n/**\n * ScrollArea provides native scrollbars with custom styling.\n */\nconst ScrollAreaRoot = slottable<HTMLDivElement, ScrollAreaRootProps>(\n (\n {\n children,\n asChild,\n orientation = 'vertical',\n autoHide = true,\n centered = false,\n padding = false,\n thin = false,\n snap = false,\n ...props\n },\n forwardedRef,\n ) => {\n const { tx } = useThemeContext();\n const { className, ...rest } = composableProps(props);\n const Comp = asChild ? Slot : Primitive.div;\n const options = useMemo(\n () => ({ orientation, autoHide, centered, padding, thin, snap }),\n [orientation, autoHide, centered, padding, thin, snap],\n );\n\n return (\n <ScrollAreaProvider {...options}>\n <Comp {...rest} className={tx('scrollArea.root', options, className)} ref={forwardedRef}>\n {children}\n </Comp>\n </ScrollAreaProvider>\n );\n },\n);\n\nScrollAreaRoot.displayName = SCROLLAREA_ROOT_NAME;\n\n//\n// Viewport\n//\n\nconst SCROLLAREA_VIEWPORT_NAME = 'ScrollArea.Viewport';\n\ntype ScrollAreaViewportProps = SlottableProps;\n\nconst ScrollAreaViewport = slottable<HTMLDivElement>(({ children, asChild, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const options = useScrollAreaContext(SCROLLAREA_VIEWPORT_NAME);\n const density = options.thin ? scrollbar.thin : scrollbar.coarse;\n const { className, ...rest } = composableProps(props);\n const { style, ...restWithoutStyle } = rest as { style?: CSSProperties; [key: string]: any };\n const Comp = asChild ? Slot : Primitive.div;\n\n return (\n <Comp\n {...restWithoutStyle}\n style={\n {\n '--scroll-width': `${density.size}px`,\n '--scroll-padding': `${density.padding}px`,\n ...style,\n } as CSSProperties\n }\n className={tx('scrollArea.viewport', options, className)}\n ref={forwardedRef}\n >\n {children}\n </Comp>\n );\n});\n\nScrollAreaViewport.displayName = SCROLLAREA_VIEWPORT_NAME;\n\n//\n// ScrollArea\n//\n\nexport const ScrollArea = {\n Root: ScrollAreaRoot,\n Viewport: ScrollAreaViewport,\n};\n\nexport type { ScrollAreaRootProps, ScrollAreaViewportProps };\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { createContext } from '@radix-ui/react-context';\nimport React, {\n type PropsWithChildren,\n type RefObject,\n forwardRef,\n useCallback,\n useEffect,\n useImperativeHandle,\n useMemo,\n useRef,\n useState,\n} from 'react';\n\nimport { addEventListener, combine } from '@dxos/async';\nimport { invariant } from '@dxos/invariant';\nimport { useMergeRefs } from '@dxos/react-hooks';\nimport { composable, composableProps, slottable } from '@dxos/ui-theme';\nimport { mx } from '@dxos/ui-theme';\nimport { type SlottableProps } from '@dxos/ui-types';\n\nimport { type ThemedClassName } from '../../util';\nimport { IconButton } from '../Button';\nimport { ScrollArea, type ScrollAreaRootProps } from '../ScrollArea';\n\nconst isBottom = (el: HTMLElement | null) => {\n return !!(el && el.scrollHeight - el.scrollTop === el.clientHeight);\n};\n\nexport interface ScrollController {\n viewport: HTMLDivElement | null;\n scrollToTop: (behavior?: ScrollBehavior) => void;\n scrollToBottom: (behavior?: ScrollBehavior) => void;\n}\n\ntype ScrollContainerContextValue = {\n controller?: ScrollController;\n pinned?: boolean;\n overflow?: boolean;\n /** Called by Viewport to register/unregister the scroll element. */\n setViewport: (el: HTMLDivElement | null) => void;\n /** Called by Viewport on wheel events to update pinned state. */\n setPinned: (value: boolean) => void;\n /** Called by Viewport on scroll events to update overflow state. */\n setOverflow: (value: boolean) => void;\n};\n\nconst [ScrollContainerProvider, useScrollContainerContext] =\n createContext<ScrollContainerContextValue>('ScrollContainer');\n\n//\n// Root\n//\n\ntype RootProps = PropsWithChildren<{\n pin?: boolean;\n behavior?: ScrollBehavior;\n}>;\n\n/**\n * Headless scroll container that provides context for scroll state.\n * Render ScrollContainer.Content and ScrollContainer.Viewport as children.\n */\nconst Root = forwardRef<ScrollController, RootProps>(\n ({ children, pin, behavior: behaviorProp = 'smooth' }, forwardedRef) => {\n const scrollerRef = useRef<HTMLDivElement | null>(null);\n const autoScrollRef = useRef(false);\n const [pinned, setPinned] = useState(pin);\n const [overflow, setOverflow] = useState(false);\n\n const timeoutRef = useRef<NodeJS.Timeout>(undefined);\n const scrollToBottom = useCallback(\n (behavior: ScrollBehavior = behaviorProp) => {\n if (scrollerRef.current) {\n if (behavior !== 'instant') {\n // Temporarily hide scrollbar to prevent flickering during smooth scroll.\n // For instant scrolling we skip this — there's no animation to hide,\n // and adding the class changes element size which re-fires the ResizeObserver.\n autoScrollRef.current = true;\n scrollerRef.current.classList.add('scrollbar-none');\n clearTimeout(timeoutRef.current);\n timeoutRef.current = setTimeout(() => {\n scrollerRef.current?.classList.remove('scrollbar-none');\n autoScrollRef.current = false;\n }, 500);\n }\n\n scrollerRef.current.scrollTo({\n top: scrollerRef.current.scrollHeight,\n behavior,\n });\n\n setPinned(true);\n }\n },\n [behaviorProp],\n );\n\n const controller = useMemo<ScrollController>(\n () => ({\n get viewport() {\n return scrollerRef.current;\n },\n scrollToTop: () => {\n invariant(scrollerRef.current);\n scrollerRef.current.scrollTo({ top: 0, behavior: 'smooth' });\n setPinned(false);\n },\n scrollToBottom: (behavior = 'smooth' as ScrollBehavior) => {\n scrollToBottom(behavior);\n },\n }),\n [scrollToBottom],\n );\n\n // Scroll controller imperative ref.\n useImperativeHandle(forwardedRef, () => controller, [controller]);\n\n // Called by Viewport when the scroll element mounts/unmounts.\n const setViewport = useCallback((el: HTMLDivElement | null) => {\n scrollerRef.current = el;\n }, []);\n\n return (\n <ScrollContainerProvider\n pinned={pinned}\n overflow={overflow}\n controller={controller}\n setViewport={setViewport}\n setPinned={setPinned}\n setOverflow={setOverflow}\n >\n {children}\n </ScrollContainerProvider>\n );\n },\n);\n\nRoot.displayName = 'ScrollContainer.Root';\n\n//\n// Content\n//\n\ntype ContentProps = Pick<ScrollAreaRootProps, 'thin' | 'padding' | 'centered'>;\n\n/**\n * Composable wrapper around ScrollArea.Root.\n * Provides the DOM structure for the scroll container.\n */\nconst Content = composable<HTMLDivElement, ContentProps>(\n ({ children, thin, padding, centered, ...props }, forwardedRef) => {\n return (\n <ScrollArea.Root\n {...composableProps(props, { classNames: 'relative' })}\n thin={thin}\n padding={padding}\n centered={centered}\n ref={forwardedRef}\n >\n {children}\n </ScrollArea.Root>\n );\n },\n);\n\nContent.displayName = 'ScrollContainer.Content';\n\n//\n// Viewport\n//\n\nconst VIEWPORT_NAME = 'ScrollContainer.Viewport';\n\ntype ViewportProps = SlottableProps;\n\nconst Viewport = slottable<HTMLDivElement, ViewportProps>(({ children, asChild, ...props }, forwardedRef) => {\n const scrollerRef = useRef<HTMLDivElement>(null);\n const mergedRef = useMergeRefs([forwardedRef, scrollerRef]);\n const { setViewport, setPinned, setOverflow } = useScrollContainerContext(VIEWPORT_NAME);\n\n // Register the scroll element with Root and set up wheel/scroll listeners.\n useEffect(() => {\n const el = scrollerRef.current;\n if (!el) {\n return;\n }\n\n setViewport(el);\n\n return combine(\n addEventListener(el, 'wheel', () => setPinned(isBottom(el))),\n addEventListener(el, 'scroll', () => setOverflow((el.scrollTop ?? 0) > 0)),\n () => setViewport(null),\n );\n }, [setViewport, setPinned, setOverflow]);\n\n return (\n <>\n <ScrollArea.Viewport asChild={asChild} {...composableProps(props)} ref={mergedRef}>\n {children}\n </ScrollArea.Viewport>\n <PinEffect scrollerRef={scrollerRef} />\n </>\n );\n});\n\nViewport.displayName = VIEWPORT_NAME;\n\n/**\n * Isolated component that consumes pinned/controller from context.\n * Kept separate so that Viewport does not re-render when pinned changes.\n */\nconst PIN_EFFECT_NAME = 'ScrollContainer.PinEffect';\n\nconst PinEffect = ({ scrollerRef }: { scrollerRef: RefObject<HTMLDivElement | null> }) => {\n const { pinned, controller } = useScrollContainerContext(PIN_EFFECT_NAME);\n\n // Pin scroll to bottom when content changes.\n useEffect(() => {\n const viewport = scrollerRef.current;\n if (!pinned || !viewport) {\n return;\n }\n\n // Scroll instantly so we don't visually jump while content is being added.\n controller?.scrollToBottom('instant');\n\n // Setup resize observer on content children to detect size changes (e.g. streaming).\n // We observe children rather than the viewport itself, because the viewport's size\n // stays fixed — only its content grows.\n // Use instant scroll in the callback — smooth scrolling adds/removes the\n // scrollbar-none class, which changes the element size and re-fires the\n // observer, creating an infinite loop.\n const resizeObserver = new ResizeObserver(() => controller?.scrollToBottom('smooth'));\n Array.from(viewport.children).forEach((child) => {\n resizeObserver.observe(child);\n });\n\n // Watch for added/removed children.\n const mutationObserver = new MutationObserver((mutations) => {\n mutations.forEach((mutation) => {\n mutation.addedNodes.forEach((node) => {\n if (node instanceof Element) {\n resizeObserver.observe(node);\n }\n });\n });\n\n controller?.scrollToBottom('smooth');\n });\n mutationObserver.observe(viewport, { childList: true });\n\n return () => {\n resizeObserver.disconnect();\n mutationObserver.disconnect();\n };\n }, [pinned, controller, scrollerRef]);\n\n return null;\n};\n\n//\n// Fade\n//\n\nconst FADE_NAME = 'ScrollContainer.Fade';\n\ntype FadeProps = {};\n\nconst Fade = () => {\n const { overflow } = useScrollContainerContext(FADE_NAME);\n\n return (\n <div\n role='none'\n data-visible={overflow}\n className={mx(\n // NOTE: Gradients may not be visible with dark reader extensions.\n 'z-10 absolute top-0 inset-x-0 h-24 w-full',\n 'opacity-0 duration-200 transition-opacity data-[visible=\"true\"]:opacity-100',\n 'bg-gradient-to-b from-(--surface-bg) to-transparent pointer-events-none',\n )}\n />\n );\n};\n\nFade.displayName = FADE_NAME;\n\n//\n// ScrollDownButton\n//\n\nconst SCROLL_DOWN_BUTTON_NAME = 'ScrollContainer.ScrollDownButton';\n\ntype ScrollDownButtonProps = ThemedClassName;\n\nconst ScrollDownButton = ({ classNames }: ScrollDownButtonProps) => {\n const { pinned, controller } = useScrollContainerContext(SCROLL_DOWN_BUTTON_NAME);\n\n return (\n <div\n role='none'\n className={mx(\n 'absolute bottom-2 right-4 opacity-100 transition-opacity duration-300',\n pinned && 'opacity-0',\n classNames,\n )}\n >\n <IconButton\n variant='primary'\n icon='ph--arrow-down--regular'\n iconOnly\n size={4}\n label='Scroll down'\n onClick={() => controller?.scrollToBottom()}\n />\n </div>\n );\n};\n\nScrollDownButton.displayName = SCROLL_DOWN_BUTTON_NAME;\n\n//\n// ScrollContainer\n//\n\nexport { useScrollContainerContext };\n\nexport const ScrollContainer = {\n Root,\n Content,\n Viewport,\n Fade,\n ScrollDownButton,\n};\n\nexport type {\n RootProps as ScrollContainerRootProps,\n ContentProps as ScrollContainerContentProps,\n ViewportProps as ScrollContainerViewportProps,\n FadeProps as ScrollContainerFadeProps,\n ScrollDownButtonProps as ScrollContainerScrollDownButtonProps,\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport * as SelectPrimitive from '@radix-ui/react-select';\nimport React, { forwardRef } from 'react';\n\nimport { useElevationContext, useThemeContext } from '../../hooks';\nimport { useSafeCollisionPadding } from '../../hooks/useSafeCollisionPadding';\nimport { type ThemedClassName } from '../../util';\nimport { Button, type ButtonProps } from '../Button';\nimport { Icon } from '../Icon';\n\ntype SelectRootProps = SelectPrimitive.SelectProps;\n\nconst SelectRoot = SelectPrimitive.Root;\n\ntype SelectTriggerProps = SelectPrimitive.SelectTriggerProps;\n\nconst SelectTrigger = SelectPrimitive.Trigger;\n\ntype SelectValueProps = SelectPrimitive.SelectValueProps;\n\nconst SelectValue = SelectPrimitive.Value;\n\ntype SelectIconProps = SelectPrimitive.SelectIconProps;\n\nconst SelectIcon = SelectPrimitive.Icon;\n\ntype SelectPortalProps = SelectPrimitive.SelectPortalProps;\n\nconst SelectPortal = SelectPrimitive.Portal;\n\ntype SelectTriggerButtonProps = Omit<ButtonProps, 'children'> & Pick<SelectValueProps, 'placeholder' | 'children'>;\n\nconst SelectTriggerButton = forwardRef<HTMLButtonElement, SelectTriggerButtonProps>(\n ({ children, placeholder, ...props }, forwardedRef) => {\n return (\n <SelectPrimitive.Trigger asChild ref={forwardedRef}>\n <Button {...props}>\n <SelectPrimitive.Value placeholder={placeholder}>{children}</SelectPrimitive.Value>\n <span className='w-1 flex-1' />\n <SelectPrimitive.Icon asChild>\n <Icon size={3} icon='ph--caret-down--bold' />\n </SelectPrimitive.Icon>\n </Button>\n </SelectPrimitive.Trigger>\n );\n },\n);\n\ntype SelectContentProps = ThemedClassName<SelectPrimitive.SelectContentProps>;\n\nconst SelectContent = forwardRef<HTMLDivElement, SelectContentProps>(\n ({ classNames, children, collisionPadding = 8, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const elevation = useElevationContext();\n const safeCollisionPadding = useSafeCollisionPadding(collisionPadding);\n return (\n <SelectPrimitive.Content\n {...props}\n data-arrow-keys='up down'\n collisionPadding={safeCollisionPadding}\n className={tx('select.content', { elevation }, classNames)}\n position='popper'\n ref={forwardedRef}\n >\n {children}\n </SelectPrimitive.Content>\n );\n },\n);\n\ntype SelectScrollUpButtonProps = ThemedClassName<SelectPrimitive.SelectScrollUpButtonProps>;\n\nconst SelectScrollUpButton = forwardRef<HTMLDivElement, SelectScrollUpButtonProps>(\n ({ classNames, children, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return (\n <SelectPrimitive.SelectScrollUpButton\n {...props}\n className={tx('select.scrollButton', {}, classNames)}\n ref={forwardedRef}\n >\n {children ?? <Icon size={3} icon='ph--caret-up--bold' />}\n </SelectPrimitive.SelectScrollUpButton>\n );\n },\n);\n\ntype SelectScrollDownButtonProps = ThemedClassName<SelectPrimitive.SelectScrollDownButtonProps>;\n\nconst SelectScrollDownButton = forwardRef<HTMLDivElement, SelectScrollDownButtonProps>(\n ({ classNames, children, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return (\n <SelectPrimitive.SelectScrollDownButton\n {...props}\n className={tx('select.scrollButton', {}, classNames)}\n ref={forwardedRef}\n >\n {children ?? <Icon size={3} icon='ph--caret-down--bold' />}\n </SelectPrimitive.SelectScrollDownButton>\n );\n },\n);\n\ntype SelectViewportProps = ThemedClassName<SelectPrimitive.SelectViewportProps>;\n\nconst SelectViewport = forwardRef<HTMLDivElement, SelectViewportProps>(\n ({ classNames, children, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return (\n <SelectPrimitive.SelectViewport {...props} className={tx('select.viewport', {}, classNames)} ref={forwardedRef}>\n {children}\n </SelectPrimitive.SelectViewport>\n );\n },\n);\n\ntype SelectItemProps = ThemedClassName<SelectPrimitive.SelectItemProps>;\n\nconst SelectItem = forwardRef<HTMLDivElement, SelectItemProps>(({ classNames, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return <SelectPrimitive.Item {...props} className={tx('select.item', {}, classNames)} ref={forwardedRef} />;\n});\n\ntype SelectItemTextProps = SelectPrimitive.SelectItemTextProps;\n\nconst SelectItemText = SelectPrimitive.ItemText;\n\ntype SelectItemIndicatorProps = ThemedClassName<SelectPrimitive.SelectItemIndicatorProps>;\n\nconst SelectItemIndicator = forwardRef<HTMLDivElement, SelectItemIndicatorProps>(\n ({ classNames, children, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return (\n <SelectPrimitive.ItemIndicator\n {...props}\n className={tx('select.itemIndicator', {}, classNames)}\n ref={forwardedRef}\n >\n {children}\n </SelectPrimitive.ItemIndicator>\n );\n },\n);\n\ntype SelectOptionProps = SelectItemProps;\n\n// TODO(burdon): Option to show icon on left/right.\nconst SelectOption = forwardRef<HTMLDivElement, SelectItemProps>(({ children, classNames, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return (\n <SelectPrimitive.Item {...props} className={tx('select.item', {}, classNames)} ref={forwardedRef}>\n <SelectPrimitive.ItemText>{children}</SelectPrimitive.ItemText>\n <span className='grow w-1' />\n {/* <SelectPrimitive.ItemIndicator className={tx('select.itemIndicator', 'option__indicator', {})}> */}\n <Icon icon='ph--check--regular' />\n {/* </SelectPrimitive.ItemIndicator> */}\n </SelectPrimitive.Item>\n );\n});\n\ntype SelectGroupProps = SelectPrimitive.SelectGroupProps;\n\nconst SelectGroup = SelectPrimitive.Group;\n\ntype SelectLabelProps = SelectPrimitive.SelectLabelProps;\n\nconst SelectLabel = SelectPrimitive.Label;\n\ntype SelectSeparatorProps = ThemedClassName<SelectPrimitive.SelectSeparatorProps>;\n\nconst SelectSeparator = forwardRef<HTMLDivElement, SelectSeparatorProps>(({ classNames, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return <SelectPrimitive.Separator {...props} className={tx('select.separator', {}, classNames)} ref={forwardedRef} />;\n});\n\ntype SelectArrowProps = ThemedClassName<SelectPrimitive.SelectArrowProps>;\n\nconst SelectArrow = forwardRef<SVGSVGElement, SelectArrowProps>(({ classNames, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return <SelectPrimitive.Arrow {...props} className={tx('select.arrow', {}, classNames)} ref={forwardedRef} />;\n});\n\nexport const Select = {\n Root: SelectRoot,\n Trigger: SelectTrigger,\n TriggerButton: SelectTriggerButton,\n Value: SelectValue,\n Icon: SelectIcon,\n Portal: SelectPortal,\n Content: SelectContent,\n ScrollUpButton: SelectScrollUpButton,\n ScrollDownButton: SelectScrollDownButton,\n Viewport: SelectViewport,\n Item: SelectItem,\n ItemText: SelectItemText,\n ItemIndicator: SelectItemIndicator,\n Option: SelectOption,\n Group: SelectGroup,\n Label: SelectLabel,\n Separator: SelectSeparator,\n Arrow: SelectArrow,\n};\n\nexport type {\n SelectRootProps,\n SelectTriggerProps,\n SelectTriggerButtonProps,\n SelectValueProps,\n SelectIconProps,\n SelectPortalProps,\n SelectContentProps,\n SelectScrollUpButtonProps,\n SelectScrollDownButtonProps,\n SelectViewportProps,\n SelectItemProps,\n SelectItemTextProps,\n SelectItemIndicatorProps,\n SelectOptionProps,\n SelectGroupProps,\n SelectLabelProps,\n SelectSeparatorProps,\n SelectArrowProps,\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { type ComponentPropsWithRef, forwardRef } from 'react';\n\nimport { useThemeContext } from '../../hooks';\nimport { type ThemedClassName } from '../../util';\n\ntype SkeletonProps = ThemedClassName<ComponentPropsWithRef<'div'>> & {\n variant?: 'default' | 'circle' | 'text';\n};\n\n/**\n * A skeleton loading component that displays a placeholder while content is loading.\n */\nconst Skeleton = forwardRef<HTMLDivElement, SkeletonProps>(\n ({ classNames, variant = 'default', ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return <div {...props} className={tx('skeleton.root', { variant }, classNames)} ref={forwardedRef} />;\n },\n);\n\nexport { Skeleton };\n\nexport type { SkeletonProps };\n", "//\n// Copyright 2026 DXOS.org\n//\n\nimport { createContextScope } from '@radix-ui/react-context';\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slot } from '@radix-ui/react-slot';\nimport React from 'react';\n\nimport { composableProps, slottable } from '@dxos/ui-theme';\n\nimport { useThemeContext } from '../../hooks';\nimport { ThemedClassName } from '../../util';\n\ntype ScopedProps<P> = P & { __scopeSplitter?: any };\n\n// TODO(burdon): Generalize horizontal/vertical and change to start/end.\ntype Mode = 'top' | 'bottom' | 'split';\n\ntype SplitterContextValue = {\n mode: Mode;\n ratio?: number;\n transition: number;\n};\n\nconst SPLITTER_NAME = 'Splitter';\n\nconst [createSplitterContext, createSplitterScope] = createContextScope(SPLITTER_NAME);\n\nconst [SplitterProvider, useSplitterContext] = createSplitterContext<SplitterContextValue>(SPLITTER_NAME);\n\n//\n// Root\n//\n\nconst ROOT_NAME = 'Splitter.Root';\n\ntype RootOwnProps = Partial<SplitterContextValue>;\n\ntype RootProps = RootOwnProps;\n\nconst Root = slottable<HTMLDivElement, RootOwnProps>(\n ({ asChild, mode = 'top', ratio = 0.5, transition = 250, children, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const { __scopeSplitter, ...rest } = props as ScopedProps<typeof props>;\n const { className, ...restProps } = composableProps(rest);\n const Comp = asChild ? Slot : Primitive.div;\n\n return (\n <SplitterProvider scope={__scopeSplitter} mode={mode} ratio={ratio} transition={transition}>\n <Comp {...restProps} ref={forwardedRef} className={tx('splitter.root', {}, className)}>\n {children}\n </Comp>\n </SplitterProvider>\n );\n },\n);\n\nRoot.displayName = ROOT_NAME;\n\n//\n// Panel\n//\n\nconst PANEL_NAME = 'Splitter.Panel';\n\ntype PanelOwnProps = ThemedClassName<{\n position: 'top' | 'bottom';\n}>;\n\ntype PanelProps = PanelOwnProps;\n\nconst Panel = slottable<HTMLDivElement, PanelOwnProps>(\n ({ classNames, asChild, children, position, style, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const { __scopeSplitter, ...rest } = props as ScopedProps<typeof props>;\n const Comp = asChild ? Slot : Primitive.div;\n const { mode, ratio = 0.5, transition } = useSplitterContext(PANEL_NAME, __scopeSplitter);\n const { className, ...restProps } = composableProps(rest);\n\n // Calculate position and height based on mode and ratio.\n const isTopPanel = position === 'top';\n const topOffset = isTopPanel ? '0%' : mode === 'top' ? '100%' : mode === 'bottom' ? '0%' : `${ratio * 100}%`;\n const height = isTopPanel\n ? mode === 'top'\n ? '100%'\n : mode === 'bottom'\n ? '0%'\n : `${ratio * 100}%`\n : mode === 'bottom'\n ? '100%'\n : mode === 'top'\n ? '0%'\n : `${(1 - ratio) * 100}%`;\n\n return (\n <Comp\n {...restProps}\n ref={forwardedRef}\n className={tx('splitter.panel', {}, className)}\n style={{\n top: topOffset,\n height,\n transition: `top ${transition}ms, height ${transition}ms ease-out`,\n ...style,\n }}\n >\n {children}\n </Comp>\n );\n },\n);\n\nPanel.displayName = PANEL_NAME;\n\n//\n// Splitter\n//\n\nconst Splitter = {\n Root,\n Panel,\n};\n\nexport { Splitter, createSplitterScope };\n\nexport type { Mode as SplitterMode, RootProps as SplitterRootProps, PanelProps as SplitterPanelProps };\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slot } from '@radix-ui/react-slot';\nimport React, { type ComponentPropsWithRef, forwardRef } from 'react';\n\nimport { type ChromaticPalette, type MessageValence, type NeutralPalette } from '@dxos/ui-types';\n\nimport { useThemeContext } from '../../hooks';\nimport { type ThemedClassName } from '../../util';\n\nexport type TagProps = ThemedClassName<ComponentPropsWithRef<typeof Primitive.span>> & {\n palette?: NeutralPalette | ChromaticPalette | MessageValence;\n asChild?: boolean;\n};\n\nexport const Tag = forwardRef<HTMLSpanElement, TagProps>(\n ({ asChild, palette = 'neutral', classNames, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const Comp = asChild ? Slot : Primitive.span;\n return (\n <Comp {...props} className={tx('tag.root', { palette }, classNames)} data-hue={palette} ref={forwardedRef} />\n );\n },\n);\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { Primitive } from '@radix-ui/react-primitive';\nimport { Slot } from '@radix-ui/react-slot';\nimport * as ToastPrimitive from '@radix-ui/react-toast';\nimport React, { type ComponentPropsWithRef, type FunctionComponent, forwardRef } from 'react';\n\nimport { useThemeContext } from '../../hooks';\nimport { type ThemedClassName } from '../../util';\nimport { ElevationProvider } from '../ElevationProvider';\n\ntype ToastProviderProps = ToastPrimitive.ToastProviderProps;\n\nconst ToastProvider: FunctionComponent<ToastProviderProps> = ToastPrimitive.Provider;\n\ntype ToastViewportProps = ThemedClassName<ToastPrimitive.ToastViewportProps>;\n\nconst ToastViewport = forwardRef<HTMLOListElement, ToastViewportProps>(({ classNames, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return <ToastPrimitive.Viewport {...props} className={tx('toast.viewport', {}, classNames)} ref={forwardedRef} />;\n});\n\ntype ToastRootProps = ThemedClassName<ToastPrimitive.ToastProps>;\n\nconst ToastRoot = forwardRef<HTMLLIElement, ToastRootProps>(({ classNames, children, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n return (\n <ToastPrimitive.Root {...props} className={tx('toast.root', {}, classNames)} ref={forwardedRef}>\n <ElevationProvider elevation='toast'>{children}</ElevationProvider>\n </ToastPrimitive.Root>\n );\n});\n\ntype ToastBodyProps = ThemedClassName<ComponentPropsWithRef<typeof Primitive.div>>;\n\nconst ToastBody = forwardRef<HTMLDivElement, ToastBodyProps>(({ asChild, classNames, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const Comp = asChild ? Slot : Primitive.div;\n return <Comp {...props} className={tx('toast.body', {}, classNames)} ref={forwardedRef} />;\n});\n\ntype ToastTitleProps = ThemedClassName<ToastPrimitive.ToastTitleProps>;\n\nconst ToastTitle = forwardRef<HTMLHeadingElement, ToastTitleProps>(\n ({ asChild, classNames, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const Comp = asChild ? Slot : ToastPrimitive.Title;\n return <Comp {...props} className={tx('toast.title', {}, classNames)} ref={forwardedRef} />;\n },\n);\n\ntype ToastDescriptionProps = ThemedClassName<ToastPrimitive.ToastDescriptionProps>;\n\nconst ToastDescription = forwardRef<HTMLParagraphElement, ToastDescriptionProps>(\n ({ asChild, classNames, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const Comp = asChild ? Slot : ToastPrimitive.Description;\n return <Comp {...props} className={tx('toast.description', {}, classNames)} ref={forwardedRef} />;\n },\n);\n\ntype ToastActionsProps = ThemedClassName<ComponentPropsWithRef<typeof Primitive.div>>;\n\nconst ToastActions = forwardRef<HTMLDivElement, ToastActionsProps>(\n ({ asChild, classNames, ...props }, forwardedRef) => {\n const { tx } = useThemeContext();\n const Comp = asChild ? Slot : Primitive.div;\n return <Comp {...props} className={tx('toast.actions', {}, classNames)} ref={forwardedRef} />;\n },\n);\n\ntype ToastActionProps = ToastPrimitive.ToastActionProps;\n\nconst ToastAction: FunctionComponent<ToastActionProps> = ToastPrimitive.Action;\n\ntype ToastCloseProps = ToastPrimitive.ToastCloseProps;\n\nconst ToastClose: FunctionComponent<ToastCloseProps> = ToastPrimitive.Close;\n\nexport const Toast = {\n Provider: ToastProvider,\n Viewport: ToastViewport,\n Root: ToastRoot,\n Body: ToastBody,\n Title: ToastTitle,\n Description: ToastDescription,\n Actions: ToastActions,\n Action: ToastAction,\n Close: ToastClose,\n};\n\nexport type {\n ToastProviderProps,\n ToastViewportProps,\n ToastRootProps,\n ToastBodyProps,\n ToastTitleProps,\n ToastDescriptionProps,\n ToastActionsProps,\n ToastActionProps,\n ToastCloseProps,\n};\n"],
5
+ "mappings": "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",
6
+ "names": ["Trans", "isLabel", "toLocalizedString", "useContext", "useDensityContext", "densityProp", "density", "useContext", "DensityContext", "ICONS_URL", "useIconHref", "icon", "noCache", "useThemeContext", "url", "Date", "getMinutes", "undefined", "useMemo", "propIsNumber", "prop", "Number", "isFinite", "propsIsRecord", "safePadding", "propsPadding", "side", "useSafeCollisionPadding", "collisionPadding", "safeAreaPadding", "useThemeContext", "useMemo", "top", "right", "bottom", "left", "useContext", "useTranslationsContext", "useContext", "TranslationsContext", "useCallback", "useState", "useViewportResize", "useVisualViewport", "deps", "width", "setWidth", "useState", "height", "setHeight", "handleResize", "useCallback", "window", "visualViewport", "useViewportResize", "useCallback", "useEffect", "useMemo", "useState", "getDocumentElementFontSize", "parseFloat", "getComputedStyle", "document", "documentElement", "fontSize", "usePx", "rem", "setFontSize", "useState", "updateFontSize", "useCallback", "useEffect", "resizeObserver", "ResizeObserver", "observe", "mediaQueryList", "window", "matchMedia", "handleMediaChange", "addEventListener", "addListener", "disconnect", "removeEventListener", "removeListener", "useMemo", "createContext", "Primitive", "Slot", "React", "forwardRef", "DxAvatar", "useId", "mx", "AVATAR_NAME", "AvatarProvider", "useAvatarContext", "createContext", "AvatarRoot", "children", "labelId", "propsLabelId", "descriptionId", "propsDescriptionId", "useId", "AvatarContent", "forwardRef", "icon", "classNames", "props", "forwardedRef", "href", "useIconHref", "DxAvatar", "aria-labelledby", "aria-describedby", "rootClassName", "mx", "ref", "AvatarLabel", "asChild", "srOnly", "Comp", "Slot", "Primitive", "span", "tx", "useThemeContext", "id", "className", "AvatarDescription", "Avatar", "Root", "Content", "Label", "Description", "Primitive", "Slot", "React", "forwardRef", "React", "forwardRef", "memo", "Icon", "memo", "forwardRef", "icon", "classNames", "size", "props", "forwardedRef", "tx", "useThemeContext", "href", "useIconHref", "React", "svg", "className", "ref", "use", "Primitive", "Slot", "React", "forwardRef", "Link", "forwardRef", "asChild", "variant", "classNames", "props", "forwardedRef", "tx", "useThemeContext", "Comp", "Slot", "Primitive", "a", "React", "className", "ref", "BreadcrumbRoot", "forwardRef", "asChild", "classNames", "props", "forwardedRef", "tx", "useThemeContext", "Comp", "Slot", "Primitive", "div", "React", "role", "className", "ref", "BreadcrumbList", "ol", "BreadcrumbListItem", "li", "BreadcrumbLink", "Link", "BreadcrumbCurrent", "aria-current", "BreadcrumbSeparator", "children", "span", "aria-hidden", "Icon", "icon", "Breadcrumb", "Root", "List", "ListItem", "Current", "Separator", "createContext", "Primitive", "Slot", "React", "forwardRef", "memo", "BUTTON_GROUP_NAME", "BUTTON_NAME", "ButtonGroupProvider", "useButtonGroupContext", "createContext", "inGroup", "Button", "memo", "forwardRef", "classNames", "children", "density", "densityProp", "elevation", "elevationProp", "variant", "asChild", "props", "ref", "tx", "useThemeContext", "useElevationContext", "useDensityContext", "Comp", "Slot", "Primitive", "button", "React", "data-variant", "data-density", "data-props", "className", "disabled", "displayName", "ButtonGroup", "propsElevation", "forwardedRef", "div", "role", "React", "forwardRef", "IconButton", "forwardRef", "props", "forwardedRef", "iconOnly", "React", "IconOnlyButton", "ref", "LabelledIconButton", "noTooltip", "tooltipSide", "Tooltip", "Trigger", "asChild", "content", "label", "side", "size", "icon", "iconEnd", "iconClassNames", "caretDown", "_", "classNames", "tx", "useThemeContext", "Button", "Icon", "span", "className", "undefined", "TogglePrimitive", "React", "forwardRef", "Toggle", "forwardRef", "defaultPressed", "pressed", "onPressedChange", "props", "forwardedRef", "React", "Root", "asChild", "Button", "ref", "ToggleGroupPrimitive", "React", "forwardRef", "ToggleGroup", "forwardRef", "classNames", "children", "props", "forwardedRef", "React", "Root", "asChild", "ButtonGroup", "ref", "ToggleGroupItem", "variant", "elevation", "density", "Item", "Button", "ToggleGroupIconItem", "label", "icon", "size", "IconButton", "Primitive", "Slot", "DOMPurify", "React", "createContext", "forwardRef", "useContext", "useMemo", "composable", "composableProps", "iconSize", "mx", "slottable", "Primitive", "Slot", "React", "composableProps", "slottable", "COLUMN_ROOT_NAME", "gutterSizes", "xs", "sm", "md", "lg", "ColumnRoot", "slottable", "children", "asChild", "role", "gutter", "props", "forwardedRef", "className", "rest", "composableProps", "Comp", "Slot", "Primitive", "div", "tx", "useThemeContext", "gutterSize", "React", "style", "gridTemplateColumns", "join", "ref", "displayName", "COLUMN_ROW_NAME", "ColumnRow", "fullWidth", "center", "COLUMN_CONTENT_NAME", "ColumnContent", "COLUMN_VIEWPORT_NAME", "ColumnViewport", "ScrollArea", "Root", "orientation", "padding", "Viewport", "Column", "Content", "Row", "Primitive", "Slot", "React", "composableProps", "mx", "slottable", "Container", "slottable", "children", "asChild", "props", "forwardedRef", "className", "rest", "composableProps", "Comp", "Slot", "Primitive", "div", "React", "mx", "ref", "Primitive", "Slot", "React", "composableProps", "mx", "slottable", "Flex", "slottable", "children", "asChild", "column", "grow", "props", "forwardedRef", "className", "rest", "composableProps", "Comp", "Slot", "Primitive", "div", "React", "ref", "mx", "React", "composable", "composableProps", "mx", "Grid", "composable", "children", "style", "role", "cols", "rows", "grow", "props", "forwardedRef", "className", "rest", "composableProps", "React", "div", "ref", "mx", "gridTemplateColumns", "undefined", "gridTemplateRows", "Primitive", "Slot", "React", "composableProps", "slottable", "GRID_TEMPLATE_ROWS", "GRID_TEMPLATE_AREAS", "PanelRoot", "slottable", "children", "asChild", "role", "style", "props", "forwardedRef", "className", "rest", "composableProps", "Comp", "Slot", "Primitive", "div", "tx", "useThemeContext", "React", "gridTemplateRows", "gridTemplateAreas", "ref", "displayName", "PanelToolbar", "size", "data-slot", "PanelContent", "PanelStatusbar", "Panel", "Root", "Toolbar", "Content", "Statusbar", "React", "useCallback", "useRef", "useState", "mx", "cache", "Map", "Image", "classNames", "src", "alt", "crossOrigin", "sampleSize", "contrast", "crossOriginState", "setCrossOriginState", "useState", "dominantColor", "setDominantColor", "undefined", "imageLoaded", "setImageLoaded", "canvasRef", "useRef", "handleImageError", "handleImageLoad", "useCallback", "target", "rgb", "get", "img", "current", "color", "extractDominantColor", "set", "React", "div", "className", "mx", "style", "backgroundColor", "canvas", "ref", "display", "aria-hidden", "background", "transition", "opacity", "onError", "onLoad", "ctx", "getContext", "width", "height", "drawImage", "imageData", "getImageData", "pixels", "data", "isTransparent", "r", "g", "b", "totalWeight", "cornerSize", "Math", "floor", "y", "x", "isInTopLeft", "isInTopRight", "isInBottomLeft", "isInBottomRight", "i", "red", "green", "blue", "alpha", "max", "min", "saturation", "weight", "round", "threshold", "edgeTransparentPixels", "edgePixels", "topIndex", "bottomIndex", "leftIndex", "rightIndex", "Primitive", "Slot", "ToolbarPrimitive", "React", "forwardRef", "useTranslation", "composable", "composableProps", "slottable", "translationKey", "translations", "ContextMenuPrimitive", "Primitive", "Slot", "React", "forwardRef", "ContextMenuRoot", "ContextMenu", "ContextMenuTrigger", "Trigger", "ContextMenuPortal", "Portal", "ContextMenuContent", "forwardRef", "classNames", "children", "collisionPadding", "props", "forwardedRef", "tx", "useThemeContext", "elevation", "useElevationContext", "safeCollisionPadding", "useSafeCollisionPadding", "React", "Content", "data-arrow-keys", "className", "ref", "ContextMenuViewport", "asChild", "Comp", "Slot", "Primitive", "div", "ContextMenuArrow", "Arrow", "ContextMenuGroup", "Group", "ContextMenuItemIndicator", "ItemIndicator", "ContextMenuItem", "Item", "ContextMenuCheckboxItem", "CheckboxItem", "ContextMenuSeparator", "Separator", "ContextMenuGroupLabel", "Label", "Root", "Viewport", "GroupLabel", "composeEventHandlers", "composeRefs", "createContextScope", "useId", "MenuPrimitive", "createMenuScope", "Primitive", "Slot", "useControllableState", "React", "forwardRef", "useCallback", "useEffect", "useMemo", "useRef", "DROPDOWN_MENU_NAME", "createDropdownMenuContext", "createDropdownMenuScope", "createContextScope", "createMenuScope", "useMenuScope", "DropdownMenuProvider", "useDropdownMenuContext", "DropdownMenuRoot", "__scopeDropdownMenu", "children", "dir", "modal", "open", "openProp", "defaultOpen", "onOpenChange", "menuScope", "triggerRef", "useRef", "setOpen", "useControllableState", "prop", "defaultProp", "onChange", "React", "scope", "triggerId", "useId", "contentId", "onOpenToggle", "useCallback", "prevOpen", "Root", "displayName", "TRIGGER_NAME", "DropdownMenuTrigger", "forwardRef", "props", "forwardedRef", "disabled", "triggerProps", "context", "Anchor", "asChild", "Primitive", "button", "type", "id", "aria-haspopup", "aria-expanded", "aria-controls", "undefined", "data-state", "data-disabled", "ref", "composeRefs", "data-arrow-keys", "onPointerDown", "composeEventHandlers", "event", "ctrlKey", "preventDefault", "onKeyDown", "includes", "key", "VIRTUAL_TRIGGER_NAME", "DropdownMenuVirtualTrigger", "virtualRef", "useEffect", "current", "PORTAL_NAME", "DropdownMenuPortal", "portalProps", "Portal", "DropdownMenuViewport", "classNames", "tx", "useThemeContext", "Comp", "Slot", "div", "className", "CONTENT_NAME", "DropdownMenuContent", "collisionPadding", "collisionBoundary", "contentProps", "elevation", "useElevationContext", "hasInteractedOutsideRef", "safeCollisionPadding", "useSafeCollisionPadding", "computedCollisionBoundary", "useMemo", "closestBoundary", "closest", "Array", "isArray", "Content", "aria-labelledby", "onCloseAutoFocus", "focus", "onInteractOutside", "originalEvent", "detail", "ctrlLeftClick", "isRightClick", "style", "GROUP_NAME", "DropdownMenuGroup", "groupProps", "Group", "LABEL_NAME", "DropdownMenuGroupLabel", "labelProps", "Label", "ITEM_NAME", "DropdownMenuItem", "itemProps", "Item", "CHECKBOX_ITEM_NAME", "DropdownMenuCheckboxItem", "checkboxItemProps", "CheckboxItem", "RADIO_GROUP_NAME", "DropdownMenuRadioGroup", "radioGroupProps", "RadioGroup", "RADIO_ITEM_NAME", "DropdownMenuRadioItem", "INDICATOR_NAME", "DropdownMenuItemIndicator", "itemIndicatorProps", "ItemIndicator", "SEPARATOR_NAME", "DropdownMenuSeparator", "separatorProps", "Separator", "ARROW_NAME", "DropdownMenuArrow", "arrowProps", "Arrow", "DropdownMenuSub", "Sub", "SUB_TRIGGER_NAME", "DropdownMenuSubTrigger", "subTriggerProps", "SubTrigger", "SUB_CONTENT_NAME", "DropdownMenuSubContent", "subContentProps", "SubContent", "DropdownMenu", "Trigger", "VirtualTrigger", "Viewport", "GroupLabel", "RadioItem", "useDropdownMenuMenuScope", "SeparatorPrimitive", "React", "forwardRef", "Separator", "forwardRef", "classNames", "orientation", "subdued", "props", "forwardedRef", "tx", "useThemeContext", "React", "Root", "className", "ref", "ToolbarRoot", "composable", "children", "density", "disabled", "layoutManaged", "orientation", "props", "forwardedRef", "className", "role", "rest", "composableProps", "tx", "useThemeContext", "React", "Root", "data-arrow-keys", "ref", "ToolbarText", "slottable", "asChild", "Comp", "Slot", "Primitive", "div", "ToolbarButton", "forwardRef", "Button", "ToolbarIconButton", "IconButton", "noTooltip", "ToolbarToggle", "Toggle", "ToolbarLink", "Link", "ToolbarToggleGroup", "classNames", "elevation", "ButtonGroup", "ToolbarToggleGroupItem", "variant", "ToolbarToggleItem", "ToolbarToggleGroupIconItem", "icon", "label", "iconOnly", "ToolbarSeparator", "Separator", "ToolbarDragHandle", "testId", "t", "useTranslation", "translationKey", "data-testid", "tabIndex", "ToolbarCloseIconButton", "onClick", "ToolbarMenu", "context", "items", "DropdownMenu", "Trigger", "length", "Portal", "Content", "Viewport", "map", "onSelect", "index", "Item", "key", "Arrow", "Toolbar", "Text", "ToggleGroup", "ToggleGroupItem", "ToggleGroupIconItem", "DragHandle", "CloseIconButton", "Menu", "CardContext", "createContext", "CARD_ROOT_NAME", "CardRoot", "slottable", "children", "id", "asChild", "role", "border", "fullWidth", "density", "props", "forwardedRef", "className", "rest", "composableProps", "Comp", "Slot", "Primitive", "div", "tx", "useThemeContext", "React", "ref", "Column", "Root", "gutter", "displayName", "CARD_TOOLBAR_NAME", "CardToolbar", "composable", "classNames", "Toolbar", "style", "iconSize", "CARD_DRAG_HANDLE_NAME", "CardDragHandle", "forwardRef", "CardIconBlock", "padding", "DragHandle", "CARD_CLOSE_ICON_BUTTON_NAME", "CloseIconButton", "CARD_MENU_NAME", "CardMenu", "context", "items", "menuItems", "useContext", "combinedItems", "Menu", "CARD_ICON_NAME", "CardIcon", "Icon", "CARD_ICON_BLOCK_NAME", "CARD_TITLE_NAME", "CardTitle", "CARD_CONTENT_NAME", "CardContent", "CARD_ROW_NAME", "CardRow", "icon", "Row", "size", "CARD_SECTION_NAME", "CardSection", "mx", "CARD_HEADING_NAME", "CardHeading", "variant", "CARD_TEXT_NAME", "CardText", "truncate", "span", "CARD_HTML_NAME", "CardHtml", "html", "sanitized", "useMemo", "DOMPurify", "sanitize", "dangerouslySetInnerHTML", "__html", "CARD_POSTER_NAME", "CardPoster", "aspect", "image", "Image", "src", "alt", "aria-label", "CARD_ACTION_NAME", "CardAction", "actionIcon", "label", "onClick", "Button", "undefined", "CARD_LINK_NAME", "CardLink", "href", "a", "data-variant", "target", "rel", "Card", "ToolbarIconButton", "IconButton", "ToolbarSeparator", "Separator", "IconBlock", "Title", "Content", "Section", "Heading", "Text", "Html", "Poster", "Action", "Link", "React", "createContext", "useCallback", "useContext", "useState", "ClipboardContext", "createContext", "textValue", "setTextValue", "_", "useClipboard", "useContext", "ClipboardProvider", "children", "setInternalTextValue", "useState", "useCallback", "nextValue", "navigator", "clipboard", "writeText", "React", "Provider", "value", "React", "mx", "osTranslations", "inactiveLabelStyles", "CopyButton", "classNames", "value", "size", "props", "t", "useTranslation", "osTranslations", "textValue", "setTextValue", "useClipboard", "isCopied", "React", "Button", "onClick", "data-testid", "div", "role", "className", "mx", "span", "Icon", "icon", "CopyButtonIconOnly", "__scopeTooltip", "variant", "label", "onOpen", "useTooltipContext", "IconButton", "iconOnly", "then", "Clipboard", "Button", "CopyButton", "IconButton", "CopyButtonIconOnly", "Provider", "ClipboardProvider", "createContext", "DialogPrimitive", "React", "forwardRef", "useTranslation", "osTranslations", "slottable", "DialogRoot", "props", "React", "ElevationProvider", "elevation", "Root", "aria-describedby", "undefined", "DialogTrigger", "Trigger", "DialogPortal", "Portal", "DIALOG_OVERLAY_NAME", "OverlayLayoutProvider", "useOverlayLayoutContext", "createContext", "DialogOverlay", "forwardRef", "classNames", "children", "blockAlign", "forwardedRef", "tx", "useThemeContext", "Overlay", "data-block-align", "className", "ref", "inOverlayLayout", "displayName", "DIALOG_CONTENT_NAME", "DialogContent", "size", "propsInOverlayLayout", "Content", "Column", "gutter", "DialogHeader", "Row", "center", "DialogCloseIconButton", "label", "t", "useTranslation", "osTranslations", "IconButton", "icon", "iconOnly", "variant", "DialogBody", "slottable", "asChild", "DialogTitle", "srOnly", "Title", "DialogDescription", "Description", "DialogActionBar", "div", "DialogClose", "Close", "Dialog", "Header", "Body", "ActionBar", "CloseIconButton", "AlertDialogPrimitive", "createContext", "React", "forwardRef", "AlertDialogRoot", "props", "React", "ElevationProvider", "elevation", "Root", "AlertDialogTrigger", "Trigger", "AlertDialogPortal", "Portal", "AlertDialogCancel", "Cancel", "AlertDialogAction", "Action", "ALERT_DIALOG_OVERLAY_NAME", "ALERT_DIALOG_CONTENT_NAME", "OverlayLayoutProvider", "useOverlayLayoutContext", "createContext", "inOverlayLayout", "AlertDialogOverlay", "forwardRef", "classNames", "children", "blockAlign", "forwardedRef", "tx", "useThemeContext", "Overlay", "data-block-align", "className", "ref", "displayName", "AlertDialogContent", "size", "Content", "aria-describedby", "undefined", "Column", "gutter", "AlertDialogTitle", "srOnly", "Title", "AlertDialogDescription", "Description", "AlertDialog", "Header", "Dialog", "Body", "ActionBar", "CloseIconButton", "ErrorBoundary", "React", "safeStringify", "ErrorStackParser", "React", "mx", "ErrorStack", "error", "frames", "ErrorStackParser", "parse", "React", "div", "className", "map", "frame", "i", "isLast", "length", "local", "fileName", "parseLocalFrame", "lineNumber", "columnNumber", "undefined", "name", "functionName", "key", "mx", "a", "href", "span", "fileUrl", "line", "col", "pathname", "URL", "startsWith", "localPath", "slice", "split", "pop", "ErrorFallback", "children", "error", "title", "data", "isDev", "process", "message", "Error", "String", "React", "div", "role", "data-testid", "className", "h1", "p", "Section", "onClick", "text", "stack", "navigator", "clipboard", "writeText", "ErrorStack", "JSON", "stringify", "undefined", "pre", "safeStringify", "button", "type", "h2", "useEffect", "useState", "ThrowError", "delay", "props", "error", "setError", "useState", "useEffect", "t", "setTimeout", "generator", "clearTimeout", "Error", "useArrowNavigationGroup", "useFocusableGroup", "useMergedTabsterAttributes_unstable", "useComposedRefs", "Primitive", "Slot", "React", "createContext", "useCallback", "useContext", "useRef", "useState", "composableProps", "slottable", "FOCUS_STATE_ATTR", "FocusContext", "createContext", "useFocus", "useContext", "Group", "slottable", "children", "asChild", "orientation", "border", "props", "forwardedRef", "Comp", "Slot", "Primitive", "div", "tx", "useThemeContext", "rootRef", "useRef", "focusableGroupAttrs", "useFocusableGroup", "tabBehavior", "arrowNavigationAttrs", "useArrowNavigationGroup", "axis", "memorizeCurrent", "tabsterAttrs", "useMergedTabsterAttributes_unstable", "state", "setState", "useState", "groupHasFocus", "setGroupHasFocus", "handleFocusIn", "useCallback", "handleFocusOut", "event", "related", "relatedTarget", "current", "contains", "className", "rest", "composableProps", "React", "Provider", "value", "setFocus", "tabIndex", "onBlur", "onFocus", "ref", "useComposedRefs", "Item", "onCurrentChange", "onClick", "ignoreDefaultKeydown", "Enter", "focused", "setFocused", "handleClick", "handleKeyDown", "key", "handleFocus", "handleBlur", "isCurrent", "aria-current", "undefined", "onKeyDown", "Focus", "CheckboxPrimitive", "useControllableState", "React", "forwardRef", "DescriptionAndValidation", "DescriptionAndValidationPrimitive", "Description", "DescriptionPrimitive", "INPUT_NAME", "InputRoot", "Label", "LabelPrimitive", "PinInput", "PinInputPrimitive", "TextArea", "TextAreaPrimitive", "TextInput", "TextInputPrimitive", "Validation", "ValidationPrimitive", "useInputContext", "mx", "Label", "forwardRef", "classNames", "children", "srOnly", "props", "forwardedRef", "tx", "useThemeContext", "React", "LabelPrimitive", "className", "ref", "Description", "DescriptionPrimitive", "Validation", "__inputScope", "validationValence", "useInputContext", "INPUT_NAME", "ValidationPrimitive", "DescriptionAndValidation", "DescriptionAndValidationPrimitive", "PinInput", "density", "propsDensity", "elevation", "propsElevation", "hasIosKeyboard", "useDensityContext", "useElevationContext", "PinInputPrimitive", "autoFocus", "disabled", "segmentClassName", "TextInput", "variant", "noAutoFill", "TextInputPrimitive", "TextArea", "TextAreaPrimitive", "Checkbox", "checked", "propsChecked", "defaultChecked", "propsDefaultChecked", "onCheckedChange", "propsOnCheckedChange", "size", "useControllableState", "prop", "defaultProp", "onChange", "id", "descriptionId", "errorMessageId", "Root", "Icon", "icon", "Switch", "input", "type", "mx", "event", "target", "aria-describedby", "Input", "InputRoot", "Primitive", "Slot", "React", "forwardRef", "LIST_ITEM_NAME", "LIST_NAME", "ListItemCollapsibleContent", "List", "ListPrimitive", "ListItem", "ListPrimitiveItem", "ListItemHeading", "ListPrimitiveItemHeading", "ListItemOpenTrigger", "ListPrimitiveItemOpenTrigger", "useListContext", "useListItemContext", "composable", "composableProps", "React", "edgeToOrientationMap", "top", "bottom", "left", "right", "orientationStyles", "horizontal", "vertical", "edgeStyles", "strokeSize", "terminalSize", "offsetToAlignTerminalWithLine", "ListDropIndicator", "edge", "gap", "lineInset", "terminalInset", "orientation", "React", "div", "role", "style", "className", "List", "composable", "children", "props", "forwardedRef", "tx", "useThemeContext", "density", "useDensityContext", "className", "rest", "composableProps", "React", "DensityProvider", "ListPrimitive", "ref", "ListItemEndcap", "forwardRef", "classNames", "asChild", "Comp", "Slot", "Primitive", "div", "role", "MockListItemOpenTrigger", "ListItemHeading", "ListPrimitiveItemHeading", "span", "ListItemOpenTrigger", "__listItemScope", "open", "useListItemContext", "LIST_ITEM_NAME", "ListPrimitiveItemOpenTrigger", "Icon", "size", "icon", "ListItemRoot", "ListPrimitiveItem", "collapsible", "ListItem", "Root", "Endcap", "Heading", "OpenTrigger", "CollapsibleContent", "ListItemCollapsibleContent", "MockOpenTrigger", "DropIndicator", "ListDropIndicator", "React", "forwardRef", "React", "edgeToOrientationMap", "reparent", "orientationStyles", "sibling", "child", "instructionStyles", "strokeSize", "terminalSize", "offsetToAlignTerminalWithLine", "TreeDropIndicator", "instruction", "gap", "lineOffset", "isBlocked", "type", "desiredInstruction", "desired", "orientation", "React", "div", "style", "currentLevel", "indentPerLevel", "className", "TreeRoot", "forwardRef", "props", "forwardedRef", "React", "List", "ref", "TreeBranch", "__listScope", "headingId", "useListItemContext", "LIST_ITEM_NAME", "aria-labelledby", "TreeItemRoot", "ListItem", "Root", "role", "TreeItemHeading", "Heading", "TreeItemOpenTrigger", "OpenTrigger", "MockTreeItemOpenTrigger", "MockOpenTrigger", "TreeItemBody", "CollapsibleContent", "Tree", "Branch", "TreeItem", "Body", "DropIndicator", "TreeDropIndicator", "useFocusFinders", "createContextScope", "Primitive", "Slot", "useControllableState", "React", "forwardRef", "useCallback", "composable", "composableProps", "TREEGRID_ROW_NAME", "createTreegridRowContext", "createTreegridRowScope", "createContextScope", "TreegridRowProvider", "useTreegridRowContext", "TREEGRID_PATH_SEPARATOR", "TREEGRID_PARENT_OF_SEPARATOR", "TreegridRoot", "composable", "asChild", "classNames", "children", "style", "gridTemplateColumns", "onKeyDown", "onKeyDownProp", "props", "forwardedRef", "tx", "useThemeContext", "className", "role", "_role", "rest", "composableProps", "Comp", "Slot", "Primitive", "div", "findFirstFocusable", "useFocusFinders", "handleKeyDown", "useCallback", "event", "key", "direction", "target", "ancestorWithArrowKeys", "closest", "currentRow", "treegrid", "rows", "Array", "from", "querySelectorAll", "currentIndex", "indexOf", "nextIndex", "targetRow", "firstFocusable", "preventDefault", "focus", "React", "ref", "TreegridRow", "forwardRef", "__treegridRowScope", "id", "parentOf", "open", "propsOpen", "defaultOpen", "onOpenChange", "propsOnOpenChange", "pathParts", "split", "level", "length", "useControllableState", "prop", "onChange", "defaultProp", "scope", "aria-level", "TreegridCell", "indent", "Treegrid", "Root", "Row", "Cell", "useFocusableGroup", "createContext", "DialogContent", "Root", "DialogRoot", "DialogTitle", "Primitive", "Slot", "useControllableState", "React", "forwardRef", "useCallback", "useEffect", "useRef", "useState", "addEventListener", "log", "useForwardedRef", "useMediaQuery", "osTranslations", "useCallback", "useEffect", "useState", "useSwipeToDismiss", "ref", "onDismiss", "dismissThreshold", "debounceThreshold", "offset", "$root", "current", "motionState", "setMotionState", "useState", "gestureStartX", "setGestureStartX", "setIdle", "useCallback", "style", "removeProperty", "setProperty", "setFollowing", "handlePointerDown", "screenX", "handlePointerMove", "delta", "Math", "min", "abs", "handlePointerUp", "useEffect", "addEventListener", "removeEventListener", "document", "documentElement", "MAIN_NAME", "MAIN_ROOT_NAME", "MAIN_OVERLAY_NAME", "NAVIGATION_SIDEBAR_NAME", "COMPLEMENTARY_SIDEBAR_NAME", "handleOpenAutoFocus", "event", "document", "body", "hasAttribute", "preventDefault", "landmarkAttr", "useLandmarkMover", "propsOnKeyDown", "landmark", "handleKeyDown", "useCallback", "target", "currentTarget", "key", "landmarks", "Array", "from", "querySelectorAll", "map", "el", "parseInt", "getAttribute", "NaN", "sort", "l", "length", "cursor", "indexOf", "nextLandmark", "getModifierState", "querySelector", "focus", "focusableGroupAttrs", "useFocusableGroup", "tabBehavior", "ignoreDefaultKeydown", "Tab", "tabIndex", "onKeyDown", "MainProvider", "useMainContext", "createContext", "resizing", "navigationSidebarState", "setNavigationSidebarState", "_nextState", "log", "warn", "complementarySidebarState", "setComplementarySidebarState", "useSidebars", "consumerName", "toggleNavigationSidebar", "openNavigationSidebar", "collapseNavigationSidebar", "closeNavigationSidebar", "toggleComplementarySidebar", "openComplementarySidebar", "collapseComplementarySidebar", "closeComplementarySidebar", "MainRoot", "propsNavigationSidebarState", "defaultNavigationSidebarState", "onNavigationSidebarStateChange", "propsComplementarySidebarState", "defaultComplementarySidebarState", "onComplementarySidebarStateChange", "children", "props", "isLg", "useMediaQuery", "useControllableState", "prop", "defaultProp", "onChange", "setResizing", "useState", "resizeInterval", "useRef", "useEffect", "addEventListener", "window", "current", "clearTimeout", "setTimeout", "React", "displayName", "MainOverlay", "forwardRef", "classNames", "forwardedRef", "tx", "useThemeContext", "div", "onClick", "className", "inlineStartSidebarOpen", "inlineEndSidebarOpen", "data-state", "aria-hidden", "ref", "MainSidebar", "swipeToDismiss", "onOpenAutoFocus", "state", "onStateChange", "side", "label", "t", "useTranslation", "osTranslations", "useForwardedRef", "noopRef", "useSwipeToDismiss", "onDismiss", "focusGroupParent", "closest", "stopPropagation", "Root", "Primitive", "DialogContent", "DialogRoot", "open", "aria-label", "toLocalizedString", "modal", "DialogTitle", "forceMount", "inert", "data-side", "data-resizing", "onKeyDownCapture", "MainNavigationSidebar", "mover", "MainComplementarySidebar", "MainContent", "asChild", "bounce", "handlesFocus", "role", "Comp", "Slot", "data-sidebar-left-state", "data-sidebar-right-state", "data-handles-focus", "Main", "Overlay", "Content", "NavigationSidebar", "ComplementarySidebar", "createContext", "Primitive", "Slot", "React", "forwardRef", "useId", "messageIcons", "success", "info", "warning", "error", "neutral", "MESSAGE_NAME", "MessageProvider", "useMessageContext", "createContext", "MessageRoot", "forwardRef", "asChild", "valence", "elevation", "propsElevation", "classNames", "titleId", "propsTitleId", "descriptionId", "propsDescriptionId", "children", "props", "forwardedRef", "tx", "useThemeContext", "useId", "useElevationContext", "Comp", "Slot", "Primitive", "div", "React", "role", "className", "aria-labelledby", "aria-describedby", "ref", "displayName", "MESSAGE_TITLE_NAME", "MessageTitle", "icon", "iconProp", "h2", "id", "Icon", "span", "MESSAGE_CONTENT_NAME", "MessageContent", "p", "Message", "Root", "Title", "Content", "Callout", "composeEventHandlers", "useComposedRefs", "createContextScope", "DismissableLayer", "useFocusGuards", "FocusScope", "useId", "PopperPrimitive", "createPopperScope", "Portal", "PortalPrimitive", "Presence", "Primitive", "Slot", "useControllableState", "hideOthers", "React", "forwardRef", "useCallback", "useEffect", "useMemo", "useRef", "useState", "RemoveScroll", "POPOVER_NAME", "createPopoverContext", "createPopoverScope", "createContextScope", "createPopperScope", "usePopperScope", "PopoverProvider", "usePopoverContext", "PopoverRoot", "props", "__scopePopover", "children", "open", "openProp", "defaultOpen", "onOpenChange", "modal", "popperScope", "triggerRef", "useRef", "hasCustomAnchor", "setHasCustomAnchor", "useState", "setOpen", "useControllableState", "prop", "defaultProp", "onChange", "React", "Root", "scope", "contentId", "useId", "onOpenToggle", "useCallback", "prevOpen", "onCustomAnchorAdd", "onCustomAnchorRemove", "displayName", "ANCHOR_NAME", "PopoverAnchor", "forwardRef", "forwardedRef", "anchorProps", "context", "useEffect", "Anchor", "ref", "TRIGGER_NAME", "PopoverTrigger", "asChild", "triggerProps", "composedTriggerRef", "useComposedRefs", "Comp", "Slot", "Primitive", "button", "trigger", "type", "aria-haspopup", "aria-expanded", "aria-controls", "data-state", "getState", "onClick", "composeEventHandlers", "VIRTUAL_TRIGGER_NAME", "PopoverVirtualTrigger", "virtualRef", "current", "PORTAL_NAME", "PortalProvider", "usePortalContext", "forceMount", "undefined", "PopoverPortal", "container", "Presence", "present", "PortalPrimitive", "CONTENT_NAME", "PopoverContent", "portalContext", "contentProps", "PopoverContentModal", "PopoverContentNonModal", "contentRef", "composedRefs", "isRightClickOutsideRef", "content", "hideOthers", "RemoveScroll", "as", "allowPinchZoom", "PopoverContentImpl", "trapFocus", "disableOutsidePointerEvents", "onCloseAutoFocus", "event", "preventDefault", "focus", "onPointerDownOutside", "originalEvent", "detail", "ctrlLeftClick", "ctrlKey", "isRightClick", "checkForDefaultPrevented", "onFocusOutside", "hasInteractedOutsideRef", "hasPointerDownOutsideRef", "defaultPrevented", "onInteractOutside", "target", "targetIsTrigger", "contains", "onOpenAutoFocus", "onEscapeKeyDown", "collisionPadding", "collisionBoundary", "classNames", "tx", "useThemeContext", "elevation", "useElevationContext", "safeCollisionPadding", "useSafeCollisionPadding", "useFocusGuards", "computedCollisionBoundary", "useMemo", "closestBoundary", "closest", "Array", "isArray", "FocusScope", "loop", "trapped", "onMountAutoFocus", "onUnmountAutoFocus", "DismissableLayer", "onDismiss", "Content", "role", "id", "className", "style", "CLOSE_NAME", "PopoverClose", "closeProps", "ARROW_NAME", "PopoverArrow", "arrowProps", "Arrow", "PopoverViewport", "constrainInline", "constrainBlock", "div", "Popover", "Trigger", "VirtualTrigger", "Portal", "Close", "Viewport", "React", "forwardRef", "Status", "forwardRef", "classNames", "children", "progress", "indeterminate", "variant", "props", "forwardedRef", "tx", "useThemeContext", "React", "span", "role", "className", "ref", "style", "width", "Math", "round", "createContext", "Primitive", "Slot", "React", "useMemo", "composableProps", "scrollbar", "slottable", "SCROLLAREA_NAME", "ScrollAreaProvider", "useScrollAreaContext", "createContext", "SCROLLAREA_ROOT_NAME", "ScrollAreaRoot", "slottable", "children", "asChild", "orientation", "autoHide", "centered", "padding", "thin", "snap", "props", "forwardedRef", "tx", "useThemeContext", "className", "rest", "composableProps", "Comp", "Slot", "Primitive", "div", "options", "useMemo", "React", "ref", "displayName", "SCROLLAREA_VIEWPORT_NAME", "ScrollAreaViewport", "density", "scrollbar", "coarse", "style", "restWithoutStyle", "size", "ScrollArea", "Root", "Viewport", "createContext", "React", "forwardRef", "useCallback", "useEffect", "useImperativeHandle", "useMemo", "useRef", "useState", "addEventListener", "combine", "invariant", "useMergeRefs", "composable", "composableProps", "slottable", "mx", "isBottom", "el", "scrollHeight", "scrollTop", "clientHeight", "ScrollContainerProvider", "useScrollContainerContext", "createContext", "Root", "forwardRef", "children", "pin", "behavior", "behaviorProp", "forwardedRef", "scrollerRef", "useRef", "autoScrollRef", "pinned", "setPinned", "useState", "overflow", "setOverflow", "timeoutRef", "undefined", "scrollToBottom", "useCallback", "current", "classList", "add", "clearTimeout", "setTimeout", "remove", "scrollTo", "top", "controller", "useMemo", "viewport", "scrollToTop", "invariant", "useImperativeHandle", "setViewport", "React", "displayName", "Content", "composable", "thin", "padding", "centered", "props", "ScrollArea", "composableProps", "classNames", "ref", "VIEWPORT_NAME", "Viewport", "slottable", "asChild", "mergedRef", "useMergeRefs", "useEffect", "combine", "addEventListener", "PinEffect", "PIN_EFFECT_NAME", "resizeObserver", "ResizeObserver", "Array", "from", "forEach", "child", "observe", "mutationObserver", "MutationObserver", "mutations", "mutation", "addedNodes", "node", "Element", "childList", "disconnect", "FADE_NAME", "Fade", "div", "role", "data-visible", "className", "mx", "SCROLL_DOWN_BUTTON_NAME", "ScrollDownButton", "IconButton", "variant", "icon", "iconOnly", "size", "label", "onClick", "ScrollContainer", "Root", "Content", "Viewport", "Fade", "ScrollDownButton", "SelectPrimitive", "React", "forwardRef", "SelectRoot", "Root", "SelectTrigger", "Trigger", "SelectValue", "Value", "SelectIcon", "Icon", "SelectPortal", "Portal", "SelectTriggerButton", "forwardRef", "children", "placeholder", "props", "forwardedRef", "React", "asChild", "ref", "Button", "span", "className", "size", "icon", "SelectContent", "classNames", "collisionPadding", "tx", "useThemeContext", "elevation", "useElevationContext", "safeCollisionPadding", "useSafeCollisionPadding", "Content", "data-arrow-keys", "position", "SelectScrollUpButton", "SelectScrollDownButton", "SelectViewport", "SelectItem", "Item", "SelectItemText", "ItemText", "SelectItemIndicator", "ItemIndicator", "SelectOption", "SelectGroup", "Group", "SelectLabel", "Label", "SelectSeparator", "Separator", "SelectArrow", "Arrow", "Select", "TriggerButton", "ScrollUpButton", "ScrollDownButton", "Viewport", "Option", "React", "forwardRef", "Skeleton", "forwardRef", "classNames", "variant", "props", "forwardedRef", "tx", "useThemeContext", "React", "div", "className", "ref", "createContextScope", "Primitive", "Slot", "React", "composableProps", "slottable", "SPLITTER_NAME", "createSplitterContext", "createSplitterScope", "createContextScope", "SplitterProvider", "useSplitterContext", "ROOT_NAME", "Root", "slottable", "asChild", "mode", "ratio", "transition", "children", "props", "forwardedRef", "tx", "useThemeContext", "__scopeSplitter", "rest", "className", "restProps", "composableProps", "Comp", "Slot", "Primitive", "div", "React", "scope", "ref", "displayName", "PANEL_NAME", "Panel", "classNames", "position", "style", "isTopPanel", "topOffset", "height", "top", "Splitter", "Primitive", "Slot", "React", "forwardRef", "Tag", "forwardRef", "asChild", "palette", "classNames", "props", "forwardedRef", "tx", "useThemeContext", "Comp", "Slot", "Primitive", "span", "React", "className", "data-hue", "ref", "Primitive", "Slot", "ToastPrimitive", "React", "forwardRef", "ToastProvider", "Provider", "ToastViewport", "forwardRef", "classNames", "props", "forwardedRef", "tx", "useThemeContext", "React", "Viewport", "className", "ref", "ToastRoot", "children", "Root", "ElevationProvider", "elevation", "ToastBody", "asChild", "Comp", "Slot", "Primitive", "div", "ToastTitle", "Title", "ToastDescription", "Description", "ToastActions", "ToastAction", "Action", "ToastClose", "Close", "Toast", "Body", "Actions"]
7
7
  }