@dxos/react-ui 0.8.4-staging.ac66bdf99f → 0.9.0

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 (482) hide show
  1. package/LICENSE +102 -5
  2. package/README.md +1 -1
  3. package/dist/lib/browser/chunk-5SPBSIWS.mjs +33 -0
  4. package/dist/lib/browser/chunk-5SPBSIWS.mjs.map +7 -0
  5. package/dist/lib/browser/chunk-7JFD5ZHZ.mjs +1612 -0
  6. package/dist/lib/browser/chunk-7JFD5ZHZ.mjs.map +7 -0
  7. package/dist/lib/browser/index.mjs +3039 -1891
  8. package/dist/lib/browser/index.mjs.map +4 -4
  9. package/dist/lib/browser/meta.json +1 -1
  10. package/dist/lib/browser/testing/index.mjs +10 -13
  11. package/dist/lib/browser/testing/index.mjs.map +3 -3
  12. package/dist/lib/browser/translations.mjs +9 -0
  13. package/dist/lib/browser/translations.mjs.map +7 -0
  14. package/dist/lib/node-esm/chunk-FPVTVXND.mjs +35 -0
  15. package/dist/lib/node-esm/chunk-FPVTVXND.mjs.map +7 -0
  16. package/dist/lib/node-esm/chunk-TTEL2FP2.mjs +1614 -0
  17. package/dist/lib/node-esm/chunk-TTEL2FP2.mjs.map +7 -0
  18. package/dist/lib/node-esm/index.mjs +3039 -1891
  19. package/dist/lib/node-esm/index.mjs.map +4 -4
  20. package/dist/lib/node-esm/meta.json +1 -1
  21. package/dist/lib/node-esm/testing/index.mjs +10 -13
  22. package/dist/lib/node-esm/testing/index.mjs.map +3 -3
  23. package/dist/lib/node-esm/translations.mjs +10 -0
  24. package/dist/lib/node-esm/translations.mjs.map +7 -0
  25. package/dist/types/src/components/Avatars/Avatar.d.ts.map +1 -1
  26. package/dist/types/src/components/Avatars/Avatar.stories.d.ts.map +1 -1
  27. package/dist/types/src/components/Avatars/Avatar.theme.d.ts +11 -0
  28. package/dist/types/src/components/Avatars/Avatar.theme.d.ts.map +1 -0
  29. package/dist/types/src/components/Avatars/AvatarGroup.stories.d.ts.map +1 -1
  30. package/dist/types/src/components/Breadcrumb/Breadcrumb.d.ts +5 -1
  31. package/dist/types/src/components/Breadcrumb/Breadcrumb.d.ts.map +1 -1
  32. package/dist/types/src/components/Breadcrumb/Breadcrumb.stories.d.ts.map +1 -1
  33. package/dist/types/src/components/Breadcrumb/Breadcrumb.theme.d.ts +4 -0
  34. package/dist/types/src/components/Breadcrumb/Breadcrumb.theme.d.ts.map +1 -0
  35. package/dist/types/src/components/Button/Button.d.ts +1 -1
  36. package/dist/types/src/components/Button/Button.d.ts.map +1 -1
  37. package/dist/types/src/components/Button/Button.stories.d.ts +1 -1
  38. package/dist/types/src/components/Button/Button.stories.d.ts.map +1 -1
  39. package/dist/types/src/components/Button/Button.theme.d.ts +11 -0
  40. package/dist/types/src/components/Button/Button.theme.d.ts.map +1 -0
  41. package/dist/types/src/components/Button/IconButton.d.ts +1 -0
  42. package/dist/types/src/components/Button/IconButton.d.ts.map +1 -1
  43. package/dist/types/src/components/Button/IconButton.stories.d.ts +1 -0
  44. package/dist/types/src/components/Button/IconButton.stories.d.ts.map +1 -1
  45. package/dist/types/src/components/Button/IconButton.theme.d.ts +8 -0
  46. package/dist/types/src/components/Button/IconButton.theme.d.ts.map +1 -0
  47. package/dist/types/src/components/Button/Toggle.stories.d.ts.map +1 -1
  48. package/dist/types/src/components/Button/ToggleGroup.d.ts +2 -2
  49. package/dist/types/src/components/Button/ToggleGroup.stories.d.ts +2 -2
  50. package/dist/types/src/components/Button/ToggleGroup.stories.d.ts.map +1 -1
  51. package/dist/types/src/components/Calendar/Calendar.d.ts +33 -0
  52. package/dist/types/src/components/Calendar/Calendar.d.ts.map +1 -0
  53. package/dist/types/src/components/Calendar/Calendar.stories.d.ts +9 -0
  54. package/dist/types/src/components/Calendar/Calendar.stories.d.ts.map +1 -0
  55. package/dist/types/src/components/Calendar/Calendar.theme.d.ts +4 -0
  56. package/dist/types/src/components/Calendar/Calendar.theme.d.ts.map +1 -0
  57. package/dist/types/src/components/Calendar/index.d.ts +2 -0
  58. package/dist/types/src/components/Calendar/index.d.ts.map +1 -0
  59. package/dist/types/src/components/Card/Card.d.ts +63 -57
  60. package/dist/types/src/components/Card/Card.d.ts.map +1 -1
  61. package/dist/types/src/components/Card/Card.stories.d.ts +1 -0
  62. package/dist/types/src/components/Card/Card.stories.d.ts.map +1 -1
  63. package/dist/types/src/components/Card/Card.theme.d.ts +12 -0
  64. package/dist/types/src/components/Card/Card.theme.d.ts.map +1 -0
  65. package/dist/types/src/components/Carousel/Carousel.d.ts +106 -0
  66. package/dist/types/src/components/Carousel/Carousel.d.ts.map +1 -0
  67. package/dist/types/src/components/Carousel/Carousel.stories.d.ts +14 -0
  68. package/dist/types/src/components/Carousel/Carousel.stories.d.ts.map +1 -0
  69. package/dist/types/src/components/Carousel/index.d.ts +2 -0
  70. package/dist/types/src/components/Carousel/index.d.ts.map +1 -0
  71. package/dist/types/src/components/Clipboard/ClipboardProvider.d.ts.map +1 -1
  72. package/dist/types/src/components/Clipboard/CopyButton.d.ts.map +1 -1
  73. package/dist/types/src/components/Clipboard/index.d.ts +1 -1
  74. package/dist/types/src/components/Clipboard/index.d.ts.map +1 -1
  75. package/dist/types/src/{primitives → components}/Column/Column.d.ts +4 -4
  76. package/dist/types/src/components/Column/Column.d.ts.map +1 -0
  77. package/dist/types/src/components/Column/Column.stories.d.ts.map +1 -0
  78. package/dist/types/src/components/Column/Column.theme.d.ts +9 -0
  79. package/dist/types/src/components/Column/Column.theme.d.ts.map +1 -0
  80. package/dist/types/src/components/Column/index.d.ts +3 -0
  81. package/dist/types/src/components/Column/index.d.ts.map +1 -0
  82. package/dist/types/src/components/Column/withColumn.d.ts +21 -0
  83. package/dist/types/src/components/Column/withColumn.d.ts.map +1 -0
  84. package/dist/types/src/components/DatePicker/DatePicker.d.ts +72 -0
  85. package/dist/types/src/components/DatePicker/DatePicker.d.ts.map +1 -0
  86. package/dist/types/src/components/DatePicker/DatePicker.stories.d.ts +10 -0
  87. package/dist/types/src/components/DatePicker/DatePicker.stories.d.ts.map +1 -0
  88. package/dist/types/src/components/DatePicker/DatePicker.theme.d.ts +6 -0
  89. package/dist/types/src/components/DatePicker/DatePicker.theme.d.ts.map +1 -0
  90. package/dist/types/src/components/DatePicker/index.d.ts +2 -0
  91. package/dist/types/src/components/DatePicker/index.d.ts.map +1 -0
  92. package/dist/types/src/components/Dialog/AlertDialog.d.ts +20 -20
  93. package/dist/types/src/components/Dialog/AlertDialog.d.ts.map +1 -1
  94. package/dist/types/src/components/Dialog/AlertDialog.stories.d.ts.map +1 -1
  95. package/dist/types/src/components/Dialog/Dialog.d.ts +21 -19
  96. package/dist/types/src/components/Dialog/Dialog.d.ts.map +1 -1
  97. package/dist/types/src/components/Dialog/Dialog.stories.d.ts.map +1 -1
  98. package/dist/types/src/components/Dialog/Dialog.theme.d.ts +10 -0
  99. package/dist/types/src/components/Dialog/Dialog.theme.d.ts.map +1 -0
  100. package/dist/types/src/components/ErrorFallback/ErrorFallback.d.ts.map +1 -1
  101. package/dist/types/src/components/ErrorFallback/ErrorFallback.stories.d.ts.map +1 -1
  102. package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts.map +1 -1
  103. package/dist/types/src/components/ErrorFallback/ThrowError.d.ts.map +1 -1
  104. package/dist/types/src/components/Focus/Focus.d.ts +2 -2
  105. package/dist/types/src/components/Focus/Focus.d.ts.map +1 -1
  106. package/dist/types/src/components/Focus/Focus.stories.d.ts.map +1 -1
  107. package/dist/types/src/components/Focus/Focus.theme.d.ts +6 -0
  108. package/dist/types/src/components/Focus/Focus.theme.d.ts.map +1 -0
  109. package/dist/types/src/components/Icon/Icon.d.ts +1 -0
  110. package/dist/types/src/components/Icon/Icon.d.ts.map +1 -1
  111. package/dist/types/src/components/Icon/Icon.stories.d.ts +1 -1
  112. package/dist/types/src/components/Icon/Icon.stories.d.ts.map +1 -1
  113. package/dist/types/src/components/Icon/Icon.theme.d.ts +11 -0
  114. package/dist/types/src/components/Icon/Icon.theme.d.ts.map +1 -0
  115. package/dist/types/src/components/Icon/IconBlock.d.ts +15 -0
  116. package/dist/types/src/components/Icon/IconBlock.d.ts.map +1 -0
  117. package/dist/types/src/components/Icon/index.d.ts +1 -0
  118. package/dist/types/src/components/Icon/index.d.ts.map +1 -1
  119. package/dist/types/src/components/Image/Image.d.ts +8 -1
  120. package/dist/types/src/components/Image/Image.d.ts.map +1 -1
  121. package/dist/types/src/components/Image/Image.stories.d.ts +3 -2
  122. package/dist/types/src/components/Image/Image.stories.d.ts.map +1 -1
  123. package/dist/types/src/components/Input/Input.d.ts +88 -13
  124. package/dist/types/src/components/Input/Input.d.ts.map +1 -1
  125. package/dist/types/src/components/Input/Input.stories.d.ts +14 -3
  126. package/dist/types/src/components/Input/Input.stories.d.ts.map +1 -1
  127. package/dist/types/src/components/Input/Input.theme.d.ts +115 -0
  128. package/dist/types/src/components/Input/Input.theme.d.ts.map +1 -0
  129. package/dist/types/src/components/Input/SegmentedInput.d.ts +79 -0
  130. package/dist/types/src/components/Input/SegmentedInput.d.ts.map +1 -0
  131. package/dist/types/src/components/Input/constants.d.ts +2 -0
  132. package/dist/types/src/components/Input/constants.d.ts.map +1 -0
  133. package/dist/types/src/components/Input/index.d.ts +2 -0
  134. package/dist/types/src/components/Input/index.d.ts.map +1 -1
  135. package/dist/types/src/components/Link/Link.d.ts.map +1 -1
  136. package/dist/types/src/components/Link/Link.stories.d.ts.map +1 -1
  137. package/dist/types/src/components/Link/Link.theme.d.ts +6 -0
  138. package/dist/types/src/components/Link/Link.theme.d.ts.map +1 -0
  139. package/dist/types/src/components/List/List.d.ts +2 -2
  140. package/dist/types/src/components/List/List.d.ts.map +1 -1
  141. package/dist/types/src/components/List/List.stories.d.ts +1 -1
  142. package/dist/types/src/components/List/List.stories.d.ts.map +1 -1
  143. package/dist/types/src/components/List/List.theme.d.ts +7 -0
  144. package/dist/types/src/components/List/List.theme.d.ts.map +1 -0
  145. package/dist/types/src/components/List/ListDropIndicator.d.ts.map +1 -1
  146. package/dist/types/src/components/List/Tree.d.ts +2 -2
  147. package/dist/types/src/components/List/Tree.d.ts.map +1 -1
  148. package/dist/types/src/components/List/Tree.stories.d.ts.map +1 -1
  149. package/dist/types/src/components/List/TreeDropIndicator.d.ts.map +1 -1
  150. package/dist/types/src/components/List/Treegrid.d.ts +2 -2
  151. package/dist/types/src/components/List/Treegrid.d.ts.map +1 -1
  152. package/dist/types/src/components/List/Treegrid.stories.d.ts.map +1 -1
  153. package/dist/types/src/components/List/Treegrid.theme.d.ts +7 -0
  154. package/dist/types/src/components/List/Treegrid.theme.d.ts.map +1 -0
  155. package/dist/types/src/components/Main/Main.d.ts +9 -5
  156. package/dist/types/src/components/Main/Main.d.ts.map +1 -1
  157. package/dist/types/src/components/Main/Main.stories.d.ts.map +1 -1
  158. package/dist/types/src/components/Main/Main.theme.d.ts +20 -0
  159. package/dist/types/src/components/Main/Main.theme.d.ts.map +1 -0
  160. package/dist/types/src/components/Main/constants.d.ts +3 -0
  161. package/dist/types/src/components/Main/constants.d.ts.map +1 -0
  162. package/dist/types/src/components/Main/index.d.ts +1 -0
  163. package/dist/types/src/components/Main/index.d.ts.map +1 -1
  164. package/dist/types/src/components/Main/useSwipeToDismiss.d.ts.map +1 -1
  165. package/dist/types/src/components/MediaPlayer/MediaPlayer.d.ts +47 -0
  166. package/dist/types/src/components/MediaPlayer/MediaPlayer.d.ts.map +1 -0
  167. package/dist/types/src/components/MediaPlayer/MediaPlayer.stories.d.ts +16 -0
  168. package/dist/types/src/components/MediaPlayer/MediaPlayer.stories.d.ts.map +1 -0
  169. package/dist/types/src/components/MediaPlayer/index.d.ts +2 -0
  170. package/dist/types/src/components/MediaPlayer/index.d.ts.map +1 -0
  171. package/dist/types/src/components/Menu/ContextMenu.d.ts.map +1 -1
  172. package/dist/types/src/components/Menu/ContextMenu.stories.d.ts.map +1 -1
  173. package/dist/types/src/components/Menu/DropdownMenu.d.ts +11 -3
  174. package/dist/types/src/components/Menu/DropdownMenu.d.ts.map +1 -1
  175. package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts.map +1 -1
  176. package/dist/types/src/components/Menu/Menu.theme.d.ts +7 -0
  177. package/dist/types/src/components/Menu/Menu.theme.d.ts.map +1 -0
  178. package/dist/types/src/components/Message/Message.d.ts +3 -3
  179. package/dist/types/src/components/Message/Message.d.ts.map +1 -1
  180. package/dist/types/src/components/Message/Message.stories.d.ts +5 -1
  181. package/dist/types/src/components/Message/Message.stories.d.ts.map +1 -1
  182. package/dist/types/src/components/Message/Message.theme.d.ts +7 -0
  183. package/dist/types/src/components/Message/Message.theme.d.ts.map +1 -0
  184. package/dist/types/src/{primitives → components}/Panel/Panel.d.ts +5 -5
  185. package/dist/types/src/components/Panel/Panel.d.ts.map +1 -0
  186. package/dist/types/src/components/Panel/Panel.stories.d.ts.map +1 -0
  187. package/dist/types/src/components/Panel/Panel.theme.d.ts +13 -0
  188. package/dist/types/src/components/Panel/Panel.theme.d.ts.map +1 -0
  189. package/dist/types/src/components/Panel/index.d.ts.map +1 -0
  190. package/dist/types/src/components/Popover/Popover.d.ts +10 -2
  191. package/dist/types/src/components/Popover/Popover.d.ts.map +1 -1
  192. package/dist/types/src/components/Popover/Popover.stories.d.ts.map +1 -1
  193. package/dist/types/src/components/Popover/Popover.theme.d.ts +8 -0
  194. package/dist/types/src/components/Popover/Popover.theme.d.ts.map +1 -0
  195. package/dist/types/src/components/ScrollArea/ScrollArea.d.ts +2 -2
  196. package/dist/types/src/components/ScrollArea/ScrollArea.d.ts.map +1 -1
  197. package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts +2 -2
  198. package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts.map +1 -1
  199. package/dist/types/src/components/ScrollArea/ScrollArea.theme.d.ts +17 -0
  200. package/dist/types/src/components/ScrollArea/ScrollArea.theme.d.ts.map +1 -0
  201. package/dist/types/src/components/ScrollArea/index.d.ts +1 -0
  202. package/dist/types/src/components/ScrollArea/index.d.ts.map +1 -1
  203. package/dist/types/src/components/ScrollArea/scrollbar.d.ts +18 -0
  204. package/dist/types/src/components/ScrollArea/scrollbar.d.ts.map +1 -0
  205. package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts +20 -18
  206. package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts.map +1 -1
  207. package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts.map +1 -1
  208. package/dist/types/src/components/Select/Select.d.ts.map +1 -1
  209. package/dist/types/src/components/Select/Select.stories.d.ts.map +1 -1
  210. package/dist/types/src/components/Select/Select.theme.d.ts +6 -0
  211. package/dist/types/src/components/Select/Select.theme.d.ts.map +1 -0
  212. package/dist/types/src/components/Separator/Separator.theme.d.ts +7 -0
  213. package/dist/types/src/components/Separator/Separator.theme.d.ts.map +1 -0
  214. package/dist/types/src/components/Skeleton/Skeleton.stories.d.ts.map +1 -1
  215. package/dist/types/src/components/Skeleton/Skeleton.theme.d.ts +6 -0
  216. package/dist/types/src/components/Skeleton/Skeleton.theme.d.ts.map +1 -0
  217. package/dist/types/src/components/Splitter/Splitter.d.ts +6 -8
  218. package/dist/types/src/components/Splitter/Splitter.d.ts.map +1 -1
  219. package/dist/types/src/components/Splitter/Splitter.stories.d.ts.map +1 -1
  220. package/dist/types/src/components/Splitter/Splitter.theme.d.ts +4 -0
  221. package/dist/types/src/components/Splitter/Splitter.theme.d.ts.map +1 -0
  222. package/dist/types/src/components/Status/Status.d.ts +1 -1
  223. package/dist/types/src/components/Status/Status.d.ts.map +1 -1
  224. package/dist/types/src/components/Status/Status.stories.d.ts.map +1 -1
  225. package/dist/types/src/components/Status/Status.theme.d.ts +7 -0
  226. package/dist/types/src/components/Status/Status.theme.d.ts.map +1 -0
  227. package/dist/types/src/components/Tag/Tag.stories.d.ts.map +1 -1
  228. package/dist/types/src/components/Tag/Tag.theme.d.ts +6 -0
  229. package/dist/types/src/components/Tag/Tag.theme.d.ts.map +1 -0
  230. package/dist/types/src/components/Toast/Toast.d.ts +12 -9
  231. package/dist/types/src/components/Toast/Toast.d.ts.map +1 -1
  232. package/dist/types/src/components/Toast/Toast.stories.d.ts +5 -2
  233. package/dist/types/src/components/Toast/Toast.stories.d.ts.map +1 -1
  234. package/dist/types/src/components/Toast/Toast.theme.d.ts +4 -0
  235. package/dist/types/src/components/Toast/Toast.theme.d.ts.map +1 -0
  236. package/dist/types/src/components/Toolbar/Toolbar.d.ts +24 -12
  237. package/dist/types/src/components/Toolbar/Toolbar.d.ts.map +1 -1
  238. package/dist/types/src/components/Toolbar/Toolbar.stories.d.ts.map +1 -1
  239. package/dist/types/src/components/Toolbar/Toolbar.theme.d.ts +8 -0
  240. package/dist/types/src/components/Toolbar/Toolbar.theme.d.ts.map +1 -0
  241. package/dist/types/src/components/Tooltip/Tooltip.d.ts +8 -8
  242. package/dist/types/src/components/Tooltip/Tooltip.d.ts.map +1 -1
  243. package/dist/types/src/components/Tooltip/Tooltip.stories.d.ts.map +1 -1
  244. package/dist/types/src/components/Tooltip/Tooltip.theme.d.ts +6 -0
  245. package/dist/types/src/components/Tooltip/Tooltip.theme.d.ts.map +1 -0
  246. package/dist/types/src/components/Tooltip/index.d.ts +1 -0
  247. package/dist/types/src/components/Tooltip/index.d.ts.map +1 -1
  248. package/dist/types/src/components/Tooltip/tooltipContent.d.ts +4 -0
  249. package/dist/types/src/components/Tooltip/tooltipContent.d.ts.map +1 -0
  250. package/dist/types/src/components/index.d.ts +7 -4
  251. package/dist/types/src/components/index.d.ts.map +1 -1
  252. package/dist/types/src/exemplars/generics.stories.d.ts +1 -1
  253. package/dist/types/src/exemplars/generics.stories.d.ts.map +1 -1
  254. package/dist/types/src/exemplars/slot.stories.d.ts.map +1 -1
  255. package/dist/types/src/exemplars/tabster.stories.d.ts.map +1 -1
  256. package/dist/types/src/exemplars/virtualizer.stories.d.ts.map +1 -1
  257. package/dist/types/src/hooks/useDensityContext.d.ts.map +1 -1
  258. package/dist/types/src/hooks/useElevationContext.d.ts.map +1 -1
  259. package/dist/types/src/hooks/useIconHref.d.ts.map +1 -1
  260. package/dist/types/src/hooks/useSafeArea.d.ts.map +1 -1
  261. package/dist/types/src/hooks/useSafeCollisionPadding.d.ts.map +1 -1
  262. package/dist/types/src/hooks/useTranslationsContext.d.ts +1 -1
  263. package/dist/types/src/hooks/useVisualViewport.d.ts.map +1 -1
  264. package/dist/types/src/index.d.ts +1 -0
  265. package/dist/types/src/index.d.ts.map +1 -1
  266. package/dist/types/src/playground/Controls.stories.d.ts.map +1 -1
  267. package/dist/types/src/playground/Custom.stories.d.ts +1 -1
  268. package/dist/types/src/playground/Custom.stories.d.ts.map +1 -1
  269. package/dist/types/src/playground/Typography.stories.d.ts.map +1 -1
  270. package/dist/types/src/primitives/Container/Container.d.ts +1 -1
  271. package/dist/types/src/primitives/Container/Container.d.ts.map +1 -1
  272. package/dist/types/src/primitives/Container/Container.stories.d.ts.map +1 -1
  273. package/dist/types/src/{components → primitives}/DensityProvider/DensityProvider.d.ts.map +1 -1
  274. package/dist/types/src/primitives/DensityProvider/index.d.ts.map +1 -0
  275. package/dist/types/src/{components → primitives}/ElevationProvider/ElevationProvider.d.ts.map +1 -1
  276. package/dist/types/src/primitives/ElevationProvider/index.d.ts.map +1 -0
  277. package/dist/types/src/primitives/Flex/Flex.d.ts +1 -1
  278. package/dist/types/src/primitives/Flex/Flex.d.ts.map +1 -1
  279. package/dist/types/src/primitives/Flex/Flex.stories.d.ts.map +1 -1
  280. package/dist/types/src/primitives/Grid/Grid.d.ts +1 -1
  281. package/dist/types/src/primitives/Grid/Grid.d.ts.map +1 -1
  282. package/dist/types/src/primitives/Grid/Grid.stories.d.ts.map +1 -1
  283. package/dist/types/src/{components → primitives}/ThemeProvider/ThemeProvider.d.ts.map +1 -1
  284. package/dist/types/src/primitives/ThemeProvider/ThemeProvider.stories.d.ts.map +1 -0
  285. package/dist/types/src/primitives/ThemeProvider/TranslationsProvider.d.ts +128 -0
  286. package/dist/types/src/primitives/ThemeProvider/TranslationsProvider.d.ts.map +1 -0
  287. package/dist/types/src/primitives/ThemeProvider/index.d.ts +4 -0
  288. package/dist/types/src/primitives/ThemeProvider/index.d.ts.map +1 -0
  289. package/dist/types/src/primitives/index.d.ts +3 -2
  290. package/dist/types/src/primitives/index.d.ts.map +1 -1
  291. package/dist/types/src/testing/Loading.d.ts.map +1 -1
  292. package/dist/types/src/testing/decorators/withLayout.d.ts.map +1 -1
  293. package/dist/types/src/testing/decorators/withLayoutVariants.d.ts.map +1 -1
  294. package/dist/types/src/testing/decorators/withTheme.d.ts +5 -1
  295. package/dist/types/src/testing/decorators/withTheme.d.ts.map +1 -1
  296. package/dist/types/src/theme/bindTheme.d.ts +3 -0
  297. package/dist/types/src/theme/bindTheme.d.ts.map +1 -0
  298. package/dist/types/src/theme/defaultTheme.d.ts +4 -0
  299. package/dist/types/src/theme/defaultTheme.d.ts.map +1 -0
  300. package/dist/types/src/theme/index.d.ts +31 -0
  301. package/dist/types/src/theme/index.d.ts.map +1 -0
  302. package/dist/types/src/translations.d.ts +17 -3
  303. package/dist/types/src/translations.d.ts.map +1 -1
  304. package/dist/types/src/util/index.d.ts +2 -1
  305. package/dist/types/src/util/index.d.ts.map +1 -1
  306. package/dist/types/src/util/mobile.d.ts +5 -0
  307. package/dist/types/src/util/mobile.d.ts.map +1 -0
  308. package/dist/types/src/util/slots.d.ts +57 -0
  309. package/dist/types/src/util/slots.d.ts.map +1 -0
  310. package/dist/types/src/util/usePx.d.ts.map +1 -1
  311. package/dist/types/tsconfig.tsbuildinfo +1 -1
  312. package/package.json +29 -25
  313. package/src/components/Avatars/Avatar.theme.ts +93 -0
  314. package/src/components/Breadcrumb/Breadcrumb.stories.tsx +1 -1
  315. package/src/components/Breadcrumb/Breadcrumb.theme.ts +26 -0
  316. package/src/components/Breadcrumb/Breadcrumb.tsx +14 -2
  317. package/src/components/Button/Button.theme.ts +31 -0
  318. package/src/components/Button/Button.tsx +2 -2
  319. package/src/components/Button/IconButton.stories.tsx +51 -3
  320. package/src/components/Button/IconButton.theme.ts +21 -0
  321. package/src/components/Button/IconButton.tsx +3 -2
  322. package/src/components/Calendar/Calendar.stories.tsx +43 -0
  323. package/src/components/Calendar/Calendar.theme.ts +74 -0
  324. package/src/components/Calendar/Calendar.tsx +196 -0
  325. package/src/components/Calendar/index.ts +5 -0
  326. package/src/components/Card/Card.stories.tsx +43 -22
  327. package/src/components/Card/Card.theme.ts +93 -0
  328. package/src/components/Card/Card.tsx +161 -169
  329. package/src/components/Carousel/Carousel.stories.tsx +47 -0
  330. package/src/components/Carousel/Carousel.tsx +373 -0
  331. package/src/components/Carousel/index.ts +5 -0
  332. package/src/components/Clipboard/CopyButton.tsx +3 -3
  333. package/src/{primitives → components}/Column/Column.stories.tsx +1 -1
  334. package/src/components/Column/Column.theme.ts +48 -0
  335. package/src/{primitives → components}/Column/Column.tsx +2 -1
  336. package/src/{primitives → components}/Column/index.ts +1 -0
  337. package/src/components/Column/withColumn.ts +27 -0
  338. package/src/components/DatePicker/DatePicker.stories.tsx +102 -0
  339. package/src/components/DatePicker/DatePicker.theme.ts +35 -0
  340. package/src/components/DatePicker/DatePicker.tsx +279 -0
  341. package/src/components/DatePicker/index.ts +5 -0
  342. package/src/components/Dialog/AlertDialog.tsx +12 -16
  343. package/src/components/Dialog/Dialog.stories.tsx +2 -2
  344. package/src/components/Dialog/Dialog.theme.ts +61 -0
  345. package/src/components/Dialog/Dialog.tsx +46 -17
  346. package/src/components/ErrorFallback/ErrorFallback.tsx +14 -8
  347. package/src/components/ErrorFallback/ErrorStack.tsx +12 -6
  348. package/src/components/Focus/Focus.theme.ts +32 -0
  349. package/src/components/Focus/Focus.tsx +1 -1
  350. package/src/components/Icon/Icon.theme.ts +45 -0
  351. package/src/components/Icon/Icon.tsx +10 -3
  352. package/src/components/Icon/IconBlock.tsx +38 -0
  353. package/src/components/Icon/index.ts +1 -0
  354. package/src/components/Image/Image.stories.tsx +1 -1
  355. package/src/components/Image/Image.tsx +38 -9
  356. package/src/components/Input/Input.stories.tsx +132 -29
  357. package/src/components/Input/Input.theme.ts +191 -0
  358. package/src/components/Input/Input.tsx +208 -2
  359. package/src/components/Input/SegmentedInput.tsx +454 -0
  360. package/src/components/Input/constants.ts +5 -0
  361. package/src/components/Input/index.ts +2 -0
  362. package/src/components/Link/Link.theme.ts +16 -0
  363. package/src/components/Link/Link.tsx +10 -2
  364. package/src/components/List/List.stories.tsx +1 -1
  365. package/src/components/List/List.theme.ts +47 -0
  366. package/src/components/List/List.tsx +3 -3
  367. package/src/components/List/ListDropIndicator.tsx +1 -2
  368. package/src/components/List/Tree.stories.tsx +1 -1
  369. package/src/components/List/TreeDropIndicator.tsx +3 -3
  370. package/src/components/List/Treegrid.theme.ts +35 -0
  371. package/src/components/List/Treegrid.tsx +3 -4
  372. package/src/components/Main/Main.theme.ts +29 -0
  373. package/src/components/Main/Main.tsx +9 -7
  374. package/src/components/Main/constants.ts +6 -0
  375. package/src/components/Main/index.ts +1 -0
  376. package/src/components/MediaPlayer/MediaPlayer.stories.tsx +50 -0
  377. package/src/components/MediaPlayer/MediaPlayer.tsx +182 -0
  378. package/src/components/MediaPlayer/index.ts +5 -0
  379. package/src/components/Menu/ContextMenu.stories.tsx +0 -3
  380. package/src/components/Menu/DropdownMenu.stories.tsx +0 -3
  381. package/src/components/Menu/DropdownMenu.tsx +15 -15
  382. package/src/components/Menu/Menu.theme.ts +48 -0
  383. package/src/components/Message/Message.stories.tsx +43 -5
  384. package/src/components/Message/Message.theme.ts +44 -0
  385. package/src/components/Message/Message.tsx +76 -16
  386. package/src/{primitives → components}/Panel/Panel.stories.tsx +2 -3
  387. package/src/components/Panel/Panel.theme.ts +41 -0
  388. package/src/{primitives → components}/Panel/Panel.tsx +2 -1
  389. package/src/components/Popover/Popover.theme.ts +40 -0
  390. package/src/components/Popover/Popover.tsx +7 -7
  391. package/src/components/ScrollArea/ScrollArea.stories.tsx +2 -6
  392. package/src/components/ScrollArea/ScrollArea.theme.ts +107 -0
  393. package/src/components/ScrollArea/ScrollArea.tsx +3 -2
  394. package/src/components/ScrollArea/index.ts +1 -0
  395. package/src/components/ScrollArea/scrollbar.ts +21 -0
  396. package/src/components/ScrollContainer/ScrollContainer.stories.tsx +1 -1
  397. package/src/components/ScrollContainer/ScrollContainer.tsx +58 -58
  398. package/src/components/Select/Select.theme.ts +55 -0
  399. package/src/components/Select/Select.tsx +26 -10
  400. package/src/components/Separator/Separator.theme.ts +23 -0
  401. package/src/components/Skeleton/Skeleton.theme.ts +22 -0
  402. package/src/components/Splitter/Splitter.stories.tsx +1 -1
  403. package/src/components/Splitter/Splitter.theme.ts +18 -0
  404. package/src/components/Splitter/Splitter.tsx +10 -15
  405. package/src/components/Status/Status.theme.ts +31 -0
  406. package/src/components/Status/Status.tsx +1 -2
  407. package/src/components/Tag/Tag.theme.ts +22 -0
  408. package/src/components/Toast/Toast.stories.tsx +41 -20
  409. package/src/components/Toast/Toast.theme.ts +56 -0
  410. package/src/components/Toast/Toast.tsx +95 -27
  411. package/src/components/Toolbar/Toolbar.theme.ts +36 -0
  412. package/src/components/Toolbar/Toolbar.tsx +67 -15
  413. package/src/components/Tooltip/Tooltip.stories.tsx +1 -10
  414. package/src/components/Tooltip/Tooltip.theme.ts +19 -0
  415. package/src/components/Tooltip/Tooltip.tsx +18 -17
  416. package/src/components/Tooltip/index.ts +1 -0
  417. package/src/components/Tooltip/tooltipContent.ts +16 -0
  418. package/src/components/index.ts +7 -5
  419. package/src/exemplars/generics.stories.tsx +1 -2
  420. package/src/exemplars/slot.stories.tsx +5 -6
  421. package/src/exemplars/virtualizer.stories.tsx +0 -1
  422. package/src/hooks/useDensityContext.ts +1 -1
  423. package/src/hooks/useElevationContext.ts +1 -1
  424. package/src/hooks/useThemeContext.ts +1 -1
  425. package/src/hooks/useTranslationsContext.ts +1 -1
  426. package/src/index.ts +1 -0
  427. package/src/playground/Custom.stories.tsx +12 -32
  428. package/src/primitives/Container/Container.tsx +3 -1
  429. package/src/{components → primitives}/DensityProvider/DensityProvider.tsx +1 -1
  430. package/src/primitives/Flex/Flex.tsx +3 -1
  431. package/src/primitives/Grid/Grid.tsx +3 -1
  432. package/src/{components → primitives}/ThemeProvider/ThemeProvider.stories.tsx +1 -1
  433. package/src/{components → primitives}/ThemeProvider/ThemeProvider.tsx +1 -1
  434. package/src/{components → primitives}/ThemeProvider/index.ts +2 -2
  435. package/src/primitives/index.ts +4 -2
  436. package/src/testing/decorators/withLayout.tsx +7 -17
  437. package/src/testing/decorators/withLayoutVariants.tsx +1 -1
  438. package/src/testing/decorators/withTheme.tsx +21 -13
  439. package/src/theme/bindTheme.ts +13 -0
  440. package/src/theme/defaultTheme.ts +83 -0
  441. package/src/theme/index.ts +37 -0
  442. package/src/translations.ts +14 -0
  443. package/src/util/index.ts +2 -1
  444. package/src/util/mobile.ts +11 -0
  445. package/src/util/slots.ts +129 -0
  446. package/src/util/usePx.ts +4 -1
  447. package/dist/lib/browser/chunk-OCVRIJCH.mjs +0 -848
  448. package/dist/lib/browser/chunk-OCVRIJCH.mjs.map +0 -7
  449. package/dist/lib/node-esm/chunk-QUD5P3RU.mjs +0 -850
  450. package/dist/lib/node-esm/chunk-QUD5P3RU.mjs.map +0 -7
  451. package/dist/types/src/components/DensityProvider/index.d.ts.map +0 -1
  452. package/dist/types/src/components/ElevationProvider/index.d.ts.map +0 -1
  453. package/dist/types/src/components/ThemeProvider/ThemeProvider.stories.d.ts.map +0 -1
  454. package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts +0 -129
  455. package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts.map +0 -1
  456. package/dist/types/src/components/ThemeProvider/index.d.ts +0 -4
  457. package/dist/types/src/components/ThemeProvider/index.d.ts.map +0 -1
  458. package/dist/types/src/primitives/Column/Column.d.ts.map +0 -1
  459. package/dist/types/src/primitives/Column/Column.stories.d.ts.map +0 -1
  460. package/dist/types/src/primitives/Column/index.d.ts +0 -2
  461. package/dist/types/src/primitives/Column/index.d.ts.map +0 -1
  462. package/dist/types/src/primitives/Panel/Panel.d.ts.map +0 -1
  463. package/dist/types/src/primitives/Panel/Panel.stories.d.ts.map +0 -1
  464. package/dist/types/src/primitives/Panel/index.d.ts.map +0 -1
  465. package/dist/types/src/util/hasIosKeyboard.d.ts +0 -2
  466. package/dist/types/src/util/hasIosKeyboard.d.ts.map +0 -1
  467. package/src/util/hasIosKeyboard.ts +0 -8
  468. /package/dist/types/src/{primitives → components}/Column/Column.stories.d.ts +0 -0
  469. /package/dist/types/src/{primitives → components}/Panel/Panel.stories.d.ts +0 -0
  470. /package/dist/types/src/{primitives → components}/Panel/index.d.ts +0 -0
  471. /package/dist/types/src/{components → primitives}/DensityProvider/DensityProvider.d.ts +0 -0
  472. /package/dist/types/src/{components → primitives}/DensityProvider/index.d.ts +0 -0
  473. /package/dist/types/src/{components → primitives}/ElevationProvider/ElevationProvider.d.ts +0 -0
  474. /package/dist/types/src/{components → primitives}/ElevationProvider/index.d.ts +0 -0
  475. /package/dist/types/src/{components → primitives}/ThemeProvider/ThemeProvider.d.ts +0 -0
  476. /package/dist/types/src/{components → primitives}/ThemeProvider/ThemeProvider.stories.d.ts +0 -0
  477. /package/src/{primitives → components}/Column/AUDIT.md +0 -0
  478. /package/src/{primitives → components}/Panel/index.ts +0 -0
  479. /package/src/{components → primitives}/DensityProvider/index.ts +0 -0
  480. /package/src/{components → primitives}/ElevationProvider/ElevationProvider.tsx +0 -0
  481. /package/src/{components → primitives}/ElevationProvider/index.ts +0 -0
  482. /package/src/{components → primitives}/ThemeProvider/TranslationsProvider.tsx +0 -0
@@ -0,0 +1,1614 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+
3
+ // src/primitives/DensityProvider/DensityProvider.tsx
4
+ import React, { createContext } from "react";
5
+ var DensityContext = /* @__PURE__ */ createContext({
6
+ density: "md"
7
+ });
8
+ var DensityProvider = ({ density, children }) => /* @__PURE__ */ React.createElement(DensityContext.Provider, {
9
+ value: {
10
+ density
11
+ }
12
+ }, children);
13
+
14
+ // src/primitives/ElevationProvider/ElevationProvider.tsx
15
+ import React2, { createContext as createContext2 } from "react";
16
+ var ElevationContext = /* @__PURE__ */ createContext2({
17
+ elevation: "base"
18
+ });
19
+ var ElevationProvider = ({ elevation, children }) => /* @__PURE__ */ React2.createElement(ElevationContext.Provider, {
20
+ value: {
21
+ elevation
22
+ }
23
+ }, children);
24
+
25
+ // src/util/mobile.ts
26
+ var hasIosKeyboard = () => {
27
+ return !!navigator.userAgent.match(/iP(ad|od|hone).+Safari/);
28
+ };
29
+
30
+ // src/primitives/ThemeProvider/TranslationsProvider.tsx
31
+ import { enUS as dtLocaleEnUs } from "date-fns/locale";
32
+ import i18Next from "i18next";
33
+ import React3, { Suspense, createContext as createContext3, useContext, useEffect, useState } from "react";
34
+ import { initReactI18next, useTranslation as useI18NextTranslation } from "react-i18next";
35
+ var initialLng = "en-US";
36
+ var initialNs = "dxos-common";
37
+ var initialDtLocale = dtLocaleEnUs;
38
+ var resources = {
39
+ [initialLng]: {
40
+ [initialNs]: {
41
+ "loading translations": "Loading translations\u2026"
42
+ }
43
+ }
44
+ };
45
+ void i18Next.use(initReactI18next).init({
46
+ resources,
47
+ lng: initialLng,
48
+ defaultNS: initialNs,
49
+ interpolation: {
50
+ escapeValue: false
51
+ }
52
+ });
53
+ var TranslationsContext = /* @__PURE__ */ createContext3({
54
+ appNs: initialNs,
55
+ dtLocale: initialDtLocale
56
+ });
57
+ var useTranslation = (...args) => {
58
+ const result = useI18NextTranslation(...args);
59
+ const { dtLocale } = useContext(TranslationsContext);
60
+ return {
61
+ ...result,
62
+ dtLocale
63
+ };
64
+ };
65
+ var TranslationsProvider = ({ fallback, resourceExtensions, children, appNs, dtLocale }) => {
66
+ const [loaded, setLoaded] = useState(false);
67
+ useEffect(() => {
68
+ setLoaded(false);
69
+ if (resourceExtensions && resourceExtensions.length) {
70
+ resourceExtensions.forEach((resource) => {
71
+ Object.keys(resource).forEach((language) => {
72
+ Object.keys(resource[language]).forEach((ns) => {
73
+ i18Next.addResourceBundle(language, ns, resource[language][ns]);
74
+ });
75
+ });
76
+ });
77
+ }
78
+ setLoaded(true);
79
+ }, [
80
+ resourceExtensions
81
+ ]);
82
+ return /* @__PURE__ */ React3.createElement(TranslationsContext.Provider, {
83
+ value: {
84
+ appNs: appNs ?? initialNs,
85
+ dtLocale: dtLocale ?? initialDtLocale
86
+ }
87
+ }, /* @__PURE__ */ React3.createElement(Suspense, {
88
+ fallback
89
+ }, loaded ? children : fallback));
90
+ };
91
+
92
+ // src/primitives/ThemeProvider/ThemeProvider.tsx
93
+ import { createKeyborg } from "keyborg";
94
+ import React4, { createContext as createContext4, useEffect as useEffect2, useMemo } from "react";
95
+
96
+ // src/hooks/useElevationContext.ts
97
+ import { useContext as useContext2 } from "react";
98
+ var useElevationContext = (propsElevation) => {
99
+ const { elevation } = useContext2(ElevationContext);
100
+ return propsElevation ?? elevation;
101
+ };
102
+
103
+ // src/hooks/useThemeContext.ts
104
+ import { useContext as useContext3 } from "react";
105
+ import { raise } from "@dxos/debug";
106
+ var useThemeContext = () => useContext3(ThemeContext) ?? raise(new Error("Missing ThemeContext"));
107
+
108
+ // src/hooks/useSafeArea.ts
109
+ import { useCallback, useState as useState2 } from "react";
110
+ import { useViewportResize } from "@dxos/react-hooks";
111
+ var initialSafeArea = {
112
+ top: NaN,
113
+ right: NaN,
114
+ bottom: NaN,
115
+ left: NaN
116
+ };
117
+ var useSafeArea = () => {
118
+ const [padding2, setPadding] = useState2(initialSafeArea);
119
+ const handleResize = useCallback(() => {
120
+ setPadding({
121
+ top: parseFloat(getComputedStyle(document.documentElement).getPropertyValue("--safe-area-top")),
122
+ right: parseFloat(getComputedStyle(document.documentElement).getPropertyValue("--safe-area-right")),
123
+ bottom: parseFloat(getComputedStyle(document.documentElement).getPropertyValue("--safe-area-bottom")),
124
+ left: parseFloat(getComputedStyle(document.documentElement).getPropertyValue("--safe-area-left"))
125
+ });
126
+ }, []);
127
+ useViewportResize(handleResize);
128
+ return padding2;
129
+ };
130
+
131
+ // src/primitives/ThemeProvider/ThemeProvider.tsx
132
+ var ThemeContext = /* @__PURE__ */ createContext4(void 0);
133
+ var ThemeProvider = ({ children, fallback = null, resourceExtensions, appNs, tx = (_path, _styleProps, ..._options) => void 0, themeMode = "dark", rootDensity = "md", noCache, platform }) => {
134
+ useEffect2(() => {
135
+ if (document.defaultView) {
136
+ const kb = createKeyborg(document.defaultView);
137
+ kb.subscribe(handleInputModalityChange);
138
+ return () => kb.unsubscribe(handleInputModalityChange);
139
+ }
140
+ }, []);
141
+ const safeAreaPadding = useSafeArea();
142
+ const contextValue = useMemo(() => ({
143
+ tx,
144
+ themeMode,
145
+ hasIosKeyboard: hasIosKeyboard(),
146
+ safeAreaPadding,
147
+ noCache,
148
+ platform
149
+ }), [
150
+ tx,
151
+ themeMode,
152
+ safeAreaPadding,
153
+ noCache,
154
+ platform
155
+ ]);
156
+ return /* @__PURE__ */ React4.createElement(ThemeContext.Provider, {
157
+ value: contextValue
158
+ }, /* @__PURE__ */ React4.createElement(TranslationsProvider, {
159
+ fallback,
160
+ resourceExtensions,
161
+ appNs
162
+ }, /* @__PURE__ */ React4.createElement(ElevationProvider, {
163
+ elevation: "base"
164
+ }, /* @__PURE__ */ React4.createElement(DensityProvider, {
165
+ density: rootDensity
166
+ }, children))));
167
+ };
168
+ var handleInputModalityChange = (isUsingKeyboard) => {
169
+ if (isUsingKeyboard) {
170
+ document.body.setAttribute("data-w-keyboard", "true");
171
+ } else {
172
+ document.body.removeAttribute("data-w-keyboard");
173
+ }
174
+ };
175
+
176
+ // src/components/Tooltip/Tooltip.tsx
177
+ import { composeEventHandlers } from "@radix-ui/primitive";
178
+ import { useComposedRefs } from "@radix-ui/react-compose-refs";
179
+ import { createContextScope } from "@radix-ui/react-context";
180
+ import { DismissableLayer } from "@radix-ui/react-dismissable-layer";
181
+ import { useId } from "@radix-ui/react-id";
182
+ import * as PopperPrimitive from "@radix-ui/react-popper";
183
+ import { createPopperScope } from "@radix-ui/react-popper";
184
+ import { Portal as PortalPrimitive } from "@radix-ui/react-portal";
185
+ import { Presence } from "@radix-ui/react-presence";
186
+ import { Primitive } from "@radix-ui/react-primitive";
187
+ import { Slottable } from "@radix-ui/react-slot";
188
+ import { useControllableState } from "@radix-ui/react-use-controllable-state";
189
+ import * as VisuallyHiddenPrimitive from "@radix-ui/react-visually-hidden";
190
+ import React5, { forwardRef, useCallback as useCallback2, useEffect as useEffect3, useMemo as useMemo2, useRef, useState as useState3 } from "react";
191
+ var [createTooltipContext, createTooltipScope] = createContextScope("Tooltip", [
192
+ createPopperScope
193
+ ]);
194
+ var usePopperScope = createPopperScope();
195
+ var DEFAULT_DELAY_DURATION = 700;
196
+ var TOOLTIP_OPEN = "tooltip.open";
197
+ var TOOLTIP_NAME = "Tooltip";
198
+ var [TooltipContextProvider, useTooltipContext] = createTooltipContext(TOOLTIP_NAME);
199
+ var TooltipProvider = (props) => {
200
+ const { __scopeTooltip, children, open: openProp, defaultOpen = false, onOpenChange, disableHoverableContent = false, delayDuration = DEFAULT_DELAY_DURATION, skipDelayDuration = 300 } = props;
201
+ const isOpenDelayedRef = useRef(true);
202
+ const isPointerInTransitRef = useRef(false);
203
+ const skipDelayTimerRef = useRef(0);
204
+ useEffect3(() => {
205
+ const skipDelayTimer = skipDelayTimerRef.current;
206
+ return () => window.clearTimeout(skipDelayTimer);
207
+ }, []);
208
+ const popperScope = usePopperScope(__scopeTooltip);
209
+ const [trigger2, setTrigger] = useState3(null);
210
+ const [content9, setContent] = useState3(null);
211
+ const [side, setSide] = useState3(void 0);
212
+ const triggerRef = useRef(trigger2);
213
+ const handleTriggerChange = useCallback2((nextTrigger, nextContent, nextSide) => {
214
+ setTrigger(nextTrigger);
215
+ triggerRef.current = nextTrigger;
216
+ setContent(nextContent ?? null);
217
+ setSide(nextSide);
218
+ }, []);
219
+ const contentId = useId();
220
+ const openTimerRef = useRef(0);
221
+ const wasOpenDelayedRef = useRef(false);
222
+ const handleOpenChange = useCallback2((open2) => {
223
+ if (open2) {
224
+ window.clearTimeout(skipDelayTimerRef.current);
225
+ isOpenDelayedRef.current = false;
226
+ document.dispatchEvent(new CustomEvent(TOOLTIP_OPEN));
227
+ } else {
228
+ window.clearTimeout(skipDelayTimerRef.current);
229
+ skipDelayTimerRef.current = window.setTimeout(() => isOpenDelayedRef.current = true, skipDelayDuration);
230
+ }
231
+ onOpenChange?.(open2);
232
+ }, [
233
+ skipDelayDuration,
234
+ onOpenChange
235
+ ]);
236
+ const [open = false, setOpen] = useControllableState({
237
+ prop: openProp,
238
+ defaultProp: defaultOpen,
239
+ onChange: handleOpenChange
240
+ });
241
+ const stateAttribute = useMemo2(() => {
242
+ return open ? wasOpenDelayedRef.current ? "delayed-open" : "instant-open" : "closed";
243
+ }, [
244
+ open
245
+ ]);
246
+ const handleOpen = useCallback2(() => {
247
+ window.clearTimeout(openTimerRef.current);
248
+ openTimerRef.current = 0;
249
+ wasOpenDelayedRef.current = false;
250
+ setOpen(true);
251
+ }, [
252
+ setOpen
253
+ ]);
254
+ const handleClose = useCallback2(() => {
255
+ window.clearTimeout(openTimerRef.current);
256
+ openTimerRef.current = 0;
257
+ setOpen(false);
258
+ }, [
259
+ setOpen
260
+ ]);
261
+ const handleDelayedOpen = useCallback2(() => {
262
+ window.clearTimeout(openTimerRef.current);
263
+ openTimerRef.current = window.setTimeout(() => {
264
+ wasOpenDelayedRef.current = true;
265
+ setOpen(true);
266
+ openTimerRef.current = 0;
267
+ }, delayDuration);
268
+ }, [
269
+ delayDuration,
270
+ setOpen
271
+ ]);
272
+ useEffect3(() => {
273
+ return () => {
274
+ if (openTimerRef.current) {
275
+ window.clearTimeout(openTimerRef.current);
276
+ openTimerRef.current = 0;
277
+ }
278
+ };
279
+ }, []);
280
+ const { tx } = useThemeContext();
281
+ const elevation = useElevationContext();
282
+ return /* @__PURE__ */ React5.createElement(PopperPrimitive.Root, popperScope, /* @__PURE__ */ React5.createElement(TooltipContextProvider, {
283
+ scope: __scopeTooltip,
284
+ contentId,
285
+ open,
286
+ stateAttribute,
287
+ trigger: trigger2,
288
+ onTriggerChange: handleTriggerChange,
289
+ onTriggerEnter: useCallback2(() => {
290
+ if (isOpenDelayedRef.current) {
291
+ handleDelayedOpen();
292
+ } else {
293
+ handleOpen();
294
+ }
295
+ }, [
296
+ isOpenDelayedRef,
297
+ handleDelayedOpen,
298
+ handleOpen
299
+ ]),
300
+ onTriggerLeave: useCallback2(() => {
301
+ if (disableHoverableContent) {
302
+ handleClose();
303
+ } else {
304
+ window.clearTimeout(openTimerRef.current);
305
+ openTimerRef.current = 0;
306
+ }
307
+ }, [
308
+ handleClose,
309
+ disableHoverableContent
310
+ ]),
311
+ onOpen: handleOpen,
312
+ onClose: handleClose,
313
+ disableHoverableContent,
314
+ isPointerInTransitRef,
315
+ onPointerInTransitChange: useCallback2((inTransit) => {
316
+ isPointerInTransitRef.current = inTransit;
317
+ }, [])
318
+ }, /* @__PURE__ */ React5.createElement(TooltipContent, {
319
+ side,
320
+ className: tx("tooltip.content", {
321
+ elevation
322
+ })
323
+ }, content9, /* @__PURE__ */ React5.createElement(TooltipArrow, {
324
+ className: tx("tooltip.arrow")
325
+ })), /* @__PURE__ */ React5.createElement(TooltipVirtualTrigger, {
326
+ virtualRef: triggerRef
327
+ }), children));
328
+ };
329
+ TooltipProvider.displayName = TOOLTIP_NAME;
330
+ var TooltipVirtualTrigger = ({ virtualRef, __scopeTooltip }) => {
331
+ const popperScope = usePopperScope(__scopeTooltip);
332
+ return /* @__PURE__ */ React5.createElement(PopperPrimitive.Anchor, {
333
+ asChild: true,
334
+ ...popperScope,
335
+ virtualRef
336
+ });
337
+ };
338
+ var TRIGGER_NAME = "Tooltip.Trigger";
339
+ var TooltipTrigger = /* @__PURE__ */ forwardRef((props, forwardedRef) => {
340
+ const {
341
+ __scopeTooltip,
342
+ onInteract,
343
+ // TODO(thure): Pass `delayDuration` into the context.
344
+ delayDuration: _delayDuration,
345
+ side,
346
+ content: content9,
347
+ ...triggerProps
348
+ } = props;
349
+ const context = useTooltipContext(TRIGGER_NAME, __scopeTooltip);
350
+ const ref = useRef(null);
351
+ const composedRefs = useComposedRefs(forwardedRef, ref);
352
+ const isPointerDownRef = useRef(false);
353
+ const hasPointerMoveOpenedRef = useRef(false);
354
+ const handlePointerUp = useCallback2(() => isPointerDownRef.current = false, []);
355
+ useEffect3(() => {
356
+ return () => document.removeEventListener("pointerup", handlePointerUp);
357
+ }, [
358
+ handlePointerUp
359
+ ]);
360
+ return /* @__PURE__ */ React5.createElement(Primitive.button, {
361
+ // We purposefully avoid adding `type=button` here because tooltip triggers are also
362
+ // commonly anchors and the anchor `type` attribute signifies MIME type.
363
+ "aria-describedby": context.open ? context.contentId : void 0,
364
+ "data-state": context.stateAttribute,
365
+ ...triggerProps,
366
+ ref: composedRefs,
367
+ onPointerMove: composeEventHandlers(props.onPointerMove, (event) => {
368
+ if (event.pointerType === "touch") {
369
+ return;
370
+ }
371
+ if (!hasPointerMoveOpenedRef.current && !context.isPointerInTransitRef.current) {
372
+ onInteract?.(event);
373
+ if (event.defaultPrevented) {
374
+ return;
375
+ }
376
+ context.onTriggerChange(ref.current, content9, side);
377
+ context.onTriggerEnter();
378
+ hasPointerMoveOpenedRef.current = true;
379
+ }
380
+ }),
381
+ onPointerLeave: composeEventHandlers(props.onPointerLeave, () => {
382
+ context.onTriggerLeave();
383
+ hasPointerMoveOpenedRef.current = false;
384
+ }),
385
+ onPointerDown: composeEventHandlers(props.onPointerDown, () => {
386
+ if (context.open) {
387
+ context.onClose();
388
+ }
389
+ isPointerDownRef.current = true;
390
+ document.addEventListener("pointerup", handlePointerUp, {
391
+ once: true
392
+ });
393
+ }),
394
+ onFocus: props.onFocus,
395
+ onBlur: composeEventHandlers(props.onBlur, context.onClose),
396
+ onClick: composeEventHandlers(props.onClick, context.onClose)
397
+ });
398
+ });
399
+ TooltipTrigger.displayName = TRIGGER_NAME;
400
+ var PORTAL_NAME = "Tooltip.Portal";
401
+ var [PortalProvider, usePortalContext] = createTooltipContext(PORTAL_NAME, {
402
+ forceMount: void 0
403
+ });
404
+ var TooltipPortal = (props) => {
405
+ const { __scopeTooltip, forceMount, children, container } = props;
406
+ const context = useTooltipContext(PORTAL_NAME, __scopeTooltip);
407
+ return /* @__PURE__ */ React5.createElement(PortalProvider, {
408
+ scope: __scopeTooltip,
409
+ forceMount
410
+ }, /* @__PURE__ */ React5.createElement(Presence, {
411
+ present: forceMount || context.open
412
+ }, /* @__PURE__ */ React5.createElement(PortalPrimitive, {
413
+ asChild: true,
414
+ container
415
+ }, children)));
416
+ };
417
+ TooltipPortal.displayName = PORTAL_NAME;
418
+ var CONTENT_NAME = "Tooltip.Content";
419
+ var TooltipContent = /* @__PURE__ */ forwardRef((props, forwardedRef) => {
420
+ const portalContext = usePortalContext(CONTENT_NAME, props.__scopeTooltip);
421
+ const { forceMount = portalContext.forceMount, side = "top", ...contentProps } = props;
422
+ const context = useTooltipContext(CONTENT_NAME, props.__scopeTooltip);
423
+ return /* @__PURE__ */ React5.createElement(Presence, {
424
+ present: forceMount || context.open
425
+ }, context.disableHoverableContent ? /* @__PURE__ */ React5.createElement(TooltipContentImpl, {
426
+ side,
427
+ ...contentProps,
428
+ ref: forwardedRef
429
+ }) : /* @__PURE__ */ React5.createElement(TooltipContentHoverable, {
430
+ side,
431
+ ...contentProps,
432
+ ref: forwardedRef
433
+ }));
434
+ });
435
+ var TooltipContentHoverable = /* @__PURE__ */ forwardRef((props, forwardedRef) => {
436
+ const context = useTooltipContext(CONTENT_NAME, props.__scopeTooltip);
437
+ const ref = useRef(null);
438
+ const composedRefs = useComposedRefs(forwardedRef, ref);
439
+ const [pointerGraceArea, setPointerGraceArea] = useState3(null);
440
+ const { trigger: trigger2, onClose } = context;
441
+ const content9 = ref.current;
442
+ const { onPointerInTransitChange } = context;
443
+ const handleRemoveGraceArea = useCallback2(() => {
444
+ setPointerGraceArea(null);
445
+ onPointerInTransitChange(false);
446
+ }, [
447
+ onPointerInTransitChange
448
+ ]);
449
+ const handleCreateGraceArea = useCallback2((event, hoverTarget) => {
450
+ const currentTarget = event.currentTarget;
451
+ const exitPoint = {
452
+ x: event.clientX,
453
+ y: event.clientY
454
+ };
455
+ const exitSide = getExitSideFromRect(exitPoint, currentTarget.getBoundingClientRect());
456
+ const paddedExitPoints = getPaddedExitPoints(exitPoint, exitSide);
457
+ const hoverTargetPoints = getPointsFromRect(hoverTarget.getBoundingClientRect());
458
+ const graceArea = getHull([
459
+ ...paddedExitPoints,
460
+ ...hoverTargetPoints
461
+ ]);
462
+ setPointerGraceArea(graceArea);
463
+ onPointerInTransitChange(true);
464
+ }, [
465
+ onPointerInTransitChange
466
+ ]);
467
+ useEffect3(() => {
468
+ return () => handleRemoveGraceArea();
469
+ }, [
470
+ handleRemoveGraceArea
471
+ ]);
472
+ useEffect3(() => {
473
+ if (trigger2 && content9) {
474
+ const handleTriggerLeave = (event) => handleCreateGraceArea(event, content9);
475
+ const handleContentLeave = (event) => handleCreateGraceArea(event, trigger2);
476
+ trigger2.addEventListener("pointerleave", handleTriggerLeave);
477
+ content9.addEventListener("pointerleave", handleContentLeave);
478
+ return () => {
479
+ trigger2.removeEventListener("pointerleave", handleTriggerLeave);
480
+ content9.removeEventListener("pointerleave", handleContentLeave);
481
+ };
482
+ }
483
+ }, [
484
+ trigger2,
485
+ content9,
486
+ handleCreateGraceArea,
487
+ handleRemoveGraceArea
488
+ ]);
489
+ useEffect3(() => {
490
+ if (pointerGraceArea) {
491
+ const handleTrackPointerGrace = (event) => {
492
+ const target = event.target;
493
+ const pointerPosition = {
494
+ x: event.clientX,
495
+ y: event.clientY
496
+ };
497
+ const hasEnteredTarget = trigger2?.contains(target) || content9?.contains(target);
498
+ const isPointerOutsideGraceArea = !isPointInPolygon(pointerPosition, pointerGraceArea);
499
+ if (hasEnteredTarget) {
500
+ handleRemoveGraceArea();
501
+ } else if (isPointerOutsideGraceArea) {
502
+ handleRemoveGraceArea();
503
+ onClose();
504
+ }
505
+ };
506
+ document.addEventListener("pointermove", handleTrackPointerGrace);
507
+ return () => document.removeEventListener("pointermove", handleTrackPointerGrace);
508
+ }
509
+ }, [
510
+ trigger2,
511
+ content9,
512
+ pointerGraceArea,
513
+ onClose,
514
+ handleRemoveGraceArea
515
+ ]);
516
+ return /* @__PURE__ */ React5.createElement(TooltipContentImpl, {
517
+ ...props,
518
+ ref: composedRefs
519
+ });
520
+ });
521
+ var [VisuallyHiddenContentContextProvider, useVisuallyHiddenContentContext] = createTooltipContext(TOOLTIP_NAME, {
522
+ isInside: false
523
+ });
524
+ var TooltipContentImpl = /* @__PURE__ */ forwardRef((props, forwardedRef) => {
525
+ const { __scopeTooltip, children, "aria-label": ariaLabel, onEscapeKeyDown, onPointerDownOutside, ...contentProps } = props;
526
+ const context = useTooltipContext(CONTENT_NAME, __scopeTooltip);
527
+ const popperScope = usePopperScope(__scopeTooltip);
528
+ const { onClose } = context;
529
+ useEffect3(() => {
530
+ document.addEventListener(TOOLTIP_OPEN, onClose);
531
+ return () => document.removeEventListener(TOOLTIP_OPEN, onClose);
532
+ }, [
533
+ onClose
534
+ ]);
535
+ useEffect3(() => {
536
+ if (context.trigger) {
537
+ const handleScroll = (event) => {
538
+ const target = event.target;
539
+ if (target?.contains(context.trigger)) {
540
+ onClose();
541
+ }
542
+ };
543
+ window.addEventListener("scroll", handleScroll, {
544
+ capture: true
545
+ });
546
+ return () => window.removeEventListener("scroll", handleScroll, {
547
+ capture: true
548
+ });
549
+ }
550
+ }, [
551
+ context.trigger,
552
+ onClose
553
+ ]);
554
+ return /* @__PURE__ */ React5.createElement(DismissableLayer, {
555
+ asChild: true,
556
+ disableOutsidePointerEvents: false,
557
+ onEscapeKeyDown,
558
+ onPointerDownOutside,
559
+ onFocusOutside: (event) => event.preventDefault(),
560
+ onDismiss: onClose
561
+ }, /* @__PURE__ */ React5.createElement(PopperPrimitive.Content, {
562
+ "data-state": context.stateAttribute,
563
+ ...popperScope,
564
+ ...contentProps,
565
+ ref: forwardedRef,
566
+ style: {
567
+ ...contentProps.style,
568
+ // re-namespace exposed content custom properties
569
+ ...{
570
+ "--radix-tooltip-content-transform-origin": "var(--radix-popper-transform-origin)",
571
+ "--radix-tooltip-content-available-width": "var(--radix-popper-available-width)",
572
+ "--radix-tooltip-content-available-height": "var(--radix-popper-available-height)",
573
+ "--radix-tooltip-trigger-width": "var(--radix-popper-anchor-width)",
574
+ "--radix-tooltip-trigger-height": "var(--radix-popper-anchor-height)"
575
+ }
576
+ }
577
+ }, /* @__PURE__ */ React5.createElement(Slottable, null, children), /* @__PURE__ */ React5.createElement(VisuallyHiddenContentContextProvider, {
578
+ scope: __scopeTooltip,
579
+ isInside: true
580
+ }, /* @__PURE__ */ React5.createElement(VisuallyHiddenPrimitive.Root, {
581
+ id: context.contentId,
582
+ role: "tooltip"
583
+ }, ariaLabel || children))));
584
+ });
585
+ TooltipContent.displayName = CONTENT_NAME;
586
+ var ARROW_NAME = "Tooltip.Arrow";
587
+ var TooltipArrow = /* @__PURE__ */ forwardRef((props, forwardedRef) => {
588
+ const { __scopeTooltip, ...arrowProps } = props;
589
+ const popperScope = usePopperScope(__scopeTooltip);
590
+ const visuallyHiddenContentContext = useVisuallyHiddenContentContext(ARROW_NAME, __scopeTooltip);
591
+ return visuallyHiddenContentContext.isInside ? null : /* @__PURE__ */ React5.createElement(PopperPrimitive.Arrow, {
592
+ ...popperScope,
593
+ ...arrowProps,
594
+ ref: forwardedRef
595
+ });
596
+ });
597
+ TooltipArrow.displayName = ARROW_NAME;
598
+ var getExitSideFromRect = (point, rect) => {
599
+ const top = Math.abs(rect.top - point.y);
600
+ const bottom = Math.abs(rect.bottom - point.y);
601
+ const right = Math.abs(rect.right - point.x);
602
+ const left = Math.abs(rect.left - point.x);
603
+ switch (Math.min(top, bottom, right, left)) {
604
+ case left:
605
+ return "left";
606
+ case right:
607
+ return "right";
608
+ case top:
609
+ return "top";
610
+ case bottom:
611
+ return "bottom";
612
+ default:
613
+ throw new Error("unreachable");
614
+ }
615
+ };
616
+ var getPaddedExitPoints = (exitPoint, exitSide, padding2 = 5) => {
617
+ const paddedExitPoints = [];
618
+ switch (exitSide) {
619
+ case "top":
620
+ paddedExitPoints.push({
621
+ x: exitPoint.x - padding2,
622
+ y: exitPoint.y + padding2
623
+ }, {
624
+ x: exitPoint.x + padding2,
625
+ y: exitPoint.y + padding2
626
+ });
627
+ break;
628
+ case "bottom":
629
+ paddedExitPoints.push({
630
+ x: exitPoint.x - padding2,
631
+ y: exitPoint.y - padding2
632
+ }, {
633
+ x: exitPoint.x + padding2,
634
+ y: exitPoint.y - padding2
635
+ });
636
+ break;
637
+ case "left":
638
+ paddedExitPoints.push({
639
+ x: exitPoint.x + padding2,
640
+ y: exitPoint.y - padding2
641
+ }, {
642
+ x: exitPoint.x + padding2,
643
+ y: exitPoint.y + padding2
644
+ });
645
+ break;
646
+ case "right":
647
+ paddedExitPoints.push({
648
+ x: exitPoint.x - padding2,
649
+ y: exitPoint.y - padding2
650
+ }, {
651
+ x: exitPoint.x - padding2,
652
+ y: exitPoint.y + padding2
653
+ });
654
+ break;
655
+ }
656
+ return paddedExitPoints;
657
+ };
658
+ var getPointsFromRect = (rect) => {
659
+ const { top, right, bottom, left } = rect;
660
+ return [
661
+ {
662
+ x: left,
663
+ y: top
664
+ },
665
+ {
666
+ x: right,
667
+ y: top
668
+ },
669
+ {
670
+ x: right,
671
+ y: bottom
672
+ },
673
+ {
674
+ x: left,
675
+ y: bottom
676
+ }
677
+ ];
678
+ };
679
+ var isPointInPolygon = (point, polygon) => {
680
+ const { x, y } = point;
681
+ let inside = false;
682
+ for (let i = 0, j = polygon.length - 1; i < polygon.length; j = i++) {
683
+ const xi = polygon[i].x;
684
+ const yi = polygon[i].y;
685
+ const xj = polygon[j].x;
686
+ const yj = polygon[j].y;
687
+ const intersect = yi > y !== yj > y && x < (xj - xi) * (y - yi) / (yj - yi) + xi;
688
+ if (intersect) {
689
+ inside = !inside;
690
+ }
691
+ }
692
+ return inside;
693
+ };
694
+ var getHull = (points) => {
695
+ const newPoints = points.slice();
696
+ newPoints.sort((a, b) => {
697
+ if (a.x < b.x) {
698
+ return -1;
699
+ } else if (a.x > b.x) {
700
+ return 1;
701
+ } else if (a.y < b.y) {
702
+ return -1;
703
+ } else if (a.y > b.y) {
704
+ return 1;
705
+ } else {
706
+ return 0;
707
+ }
708
+ });
709
+ return getHullPresorted(newPoints);
710
+ };
711
+ var getHullPresorted = (points) => {
712
+ if (points.length <= 1) {
713
+ return points.slice();
714
+ }
715
+ const upperHull = [];
716
+ for (let i = 0; i < points.length; i++) {
717
+ const p = points[i];
718
+ while (upperHull.length >= 2) {
719
+ const q = upperHull[upperHull.length - 1];
720
+ const r = upperHull[upperHull.length - 2];
721
+ if ((q.x - r.x) * (p.y - r.y) >= (q.y - r.y) * (p.x - r.x)) {
722
+ upperHull.pop();
723
+ } else {
724
+ break;
725
+ }
726
+ }
727
+ upperHull.push(p);
728
+ }
729
+ upperHull.pop();
730
+ const lowerHull = [];
731
+ for (let i = points.length - 1; i >= 0; i--) {
732
+ const p = points[i];
733
+ while (lowerHull.length >= 2) {
734
+ const q = lowerHull[lowerHull.length - 1];
735
+ const r = lowerHull[lowerHull.length - 2];
736
+ if ((q.x - r.x) * (p.y - r.y) >= (q.y - r.y) * (p.x - r.x)) {
737
+ lowerHull.pop();
738
+ } else {
739
+ break;
740
+ }
741
+ }
742
+ lowerHull.push(p);
743
+ }
744
+ lowerHull.pop();
745
+ if (upperHull.length === 1 && lowerHull.length === 1 && upperHull[0].x === lowerHull[0].x && upperHull[0].y === lowerHull[0].y) {
746
+ return upperHull;
747
+ } else {
748
+ return upperHull.concat(lowerHull);
749
+ }
750
+ };
751
+ var Tooltip = {
752
+ Provider: TooltipProvider,
753
+ Trigger: TooltipTrigger
754
+ };
755
+
756
+ // src/components/Tooltip/tooltipContent.ts
757
+ import { mx, surfaceShadow, surfaceZIndex } from "@dxos/ui-theme";
758
+ var tooltipContent = ({ elevation }, ...etc) => mx("inline-flex items-center p-1 max-w-64 text-sm bg-inverse-surface text-inverse-fg rounded-sm", surfaceShadow({
759
+ elevation: "positioned"
760
+ }), surfaceZIndex({
761
+ elevation,
762
+ level: "tooltip"
763
+ }), ...etc);
764
+
765
+ // src/components/Column/withColumn.ts
766
+ var withColumn = {
767
+ /** Centers element in the Column grid via --dx-col. No-op outside Column or inside ScrollArea. */
768
+ center: () => "[grid-column:var(--dx-col,auto)]",
769
+ /** Propagates the Column grid to children via subgrid. No-op outside Column.
770
+ * Direct children default to center column unless they are a dx-container (ScrollArea). */
771
+ propagate: () => "[.dx-column-root_&]:col-span-full [.dx-column-root_&]:grid [.dx-column-root_&]:grid-cols-subgrid [.dx-column-root_&]:[&>*:not(.dx-container)]:[grid-column:var(--dx-col,auto)]",
772
+ /** Resets --dx-col after consuming --gutter. Applied by ScrollArea.Viewport. */
773
+ consumed: () => "[--dx-col:auto]"
774
+ };
775
+
776
+ // src/components/ErrorFallback/ErrorStack.tsx
777
+ import ErrorStackParser from "error-stack-parser";
778
+ import React6 from "react";
779
+ import { mx as mx2 } from "@dxos/ui-theme";
780
+ var parseCaptureOwnerStack = (stack) => {
781
+ if (stack == null || stack.length === 0) {
782
+ return null;
783
+ }
784
+ const err = new Error();
785
+ err.stack = stack;
786
+ try {
787
+ return ErrorStackParser.parse(err);
788
+ } catch {
789
+ err.stack = `Error
790
+ ${stack}`;
791
+ try {
792
+ return ErrorStackParser.parse(err);
793
+ } catch {
794
+ return null;
795
+ }
796
+ }
797
+ };
798
+ var ErrorStack = ({ error, frames: framesProp }) => {
799
+ const frames = framesProp ?? (error ? ErrorStackParser.parse(error) : []);
800
+ if (frames.length === 0) {
801
+ return null;
802
+ }
803
+ return /* @__PURE__ */ React6.createElement("div", {
804
+ className: "font-mono text-sm"
805
+ }, frames.map((frame2, i) => {
806
+ const isLast = i === frames.length - 1;
807
+ const local = frame2.fileName ? parseLocalFrame(frame2.fileName, frame2.lineNumber, frame2.columnNumber) : void 0;
808
+ const functionName = frame2.functionName ?? "<anonymous>";
809
+ return /* @__PURE__ */ React6.createElement("div", {
810
+ key: i,
811
+ className: mx2("grid grid-cols-[16px_1fr_auto_auto] items-stretch gap-x-2", local && "cursor-pointer hover:bg-hover-surface")
812
+ }, /* @__PURE__ */ React6.createElement("div", {
813
+ className: "relative"
814
+ }, /* @__PURE__ */ React6.createElement("div", {
815
+ className: mx2("absolute left-1/2 -translate-x-1/2 w-px bg-neutral-500", isLast ? "top-0 h-1/2" : "inset-y-0")
816
+ }), /* @__PURE__ */ React6.createElement("div", {
817
+ className: "absolute top-1/2 -translate-y-1/2 left-1/2 right-0 h-px bg-neutral-500"
818
+ })), local ? /* @__PURE__ */ React6.createElement("a", {
819
+ href: local.href,
820
+ className: "truncate self-center"
821
+ }, functionName) : /* @__PURE__ */ React6.createElement("span", {
822
+ className: "text-subdued truncate self-center"
823
+ }, functionName), /* @__PURE__ */ React6.createElement("span", {
824
+ className: "text-xs text-subdued truncate self-center truncate"
825
+ }, local?.fileName ?? ""), /* @__PURE__ */ React6.createElement("span", {
826
+ className: "text-xs text-subdued text-right self-center"
827
+ }, local ? `${frame2.lineNumber}:${frame2.columnNumber}` : ""));
828
+ }));
829
+ };
830
+ var parseLocalFrame = (fileUrl, line, col) => {
831
+ try {
832
+ const { pathname } = new URL(fileUrl);
833
+ if (!pathname.startsWith("/@fs/")) {
834
+ return void 0;
835
+ }
836
+ const FILE_PREFIX = "/@fs";
837
+ const localPath = pathname.slice(FILE_PREFIX.length);
838
+ const PKG_PREFIX = "/packages/";
839
+ const i = localPath.indexOf(PKG_PREFIX);
840
+ const path = i === -1 ? localPath : localPath.substring(i + PKG_PREFIX.length);
841
+ return {
842
+ href: `vscode://file/${localPath}:${line ?? 1}:${col ?? 1}`,
843
+ fileName: path
844
+ };
845
+ } catch {
846
+ return void 0;
847
+ }
848
+ };
849
+
850
+ // src/components/Input/constants.ts
851
+ var inputTextLabel = "py-1 text-sm text-description";
852
+
853
+ // src/components/Main/constants.ts
854
+ var mainPaddingTransitions = "dx-main-content-padding-transitions";
855
+ var mainIntrinsicSize = "dx-main-intrinsic-size";
856
+
857
+ // src/theme/bindTheme.ts
858
+ import { getDeep } from "@dxos/util";
859
+ var bindTheme = (theme) => {
860
+ return (path, styleProps, ...etc) => {
861
+ const result = getDeep(theme, path.split("."));
862
+ return typeof result === "function" ? result(styleProps ?? {}, ...etc) : void 0;
863
+ };
864
+ };
865
+
866
+ // src/components/Avatars/Avatar.theme.ts
867
+ import { mx as mx3, getSize, getHeight } from "@dxos/ui-theme";
868
+ var root = ({ size = 10, inGroup }, ...etc) => mx3("relative inline-flex shrink-0", getSize(size), inGroup && (size === "px" || size <= 3 ? "-mr-1" : "-mr-2"), ...etc);
869
+ var label = ({ srOnly }, ...etc) => mx3(srOnly && "sr-only", ...etc);
870
+ var description = ({ srOnly }, ...etc) => mx3("text-description", srOnly && "sr-only", ...etc);
871
+ var frame = ({ variant }, ...etc) => mx3("h-full w-full bg-(--surface-bg)", variant === "circle" ? "rounded-full" : "rounded-sm", ...etc);
872
+ var statusIcon = ({ status, size = 3 }, ...etc) => mx3("absolute bottom-0 end-0", getSize(size), status === "inactive" ? "text-amber-400 dark:text-amber-300" : status === "active" ? "text-emerald-400 dark:text-emerald-300" : "text-neutral-400 dark:text-neutral-300", ...etc);
873
+ var ring = ({ status, variant, animation }, ...etc) => mx3("absolute inset-0 border-2", variant === "circle" ? "rounded-full" : "rounded-sm", status === "current" ? "border-primary-400 dark:border-primary-500" : status === "active" ? "border-emerald-400 dark:border-emerald-400" : status === "error" ? "border-rose-400 dark:border-rose-500" : status === "warning" ? "border-amber-400 dark:border-amber-500" : status === "inactive" ? "border-separator" : status === "internal" ? "border-fuchsia-600" : "border-[color:var(--surface-bg)]", animation === "pulse" ? "animate-halo-pulse" : "", ...etc);
874
+ var fallbackText = (_props, ...etc) => mx3("fill-white", ...etc);
875
+ var group = (_props, ...etc) => mx3("inline-flex items-center", ...etc);
876
+ var groupLabel = ({ size, srOnly }, ...etc) => mx3(srOnly ? "sr-only" : "rounded-full truncate text-sm leading-none py-1 px-2 relative z-[1] flex items-center justify-center", size && getHeight(size), ...etc);
877
+ var groupDescription = ({ srOnly }, ...etc) => mx3(srOnly ? "sr-only" : "text-description", ...etc);
878
+ var avatarTheme = {
879
+ root,
880
+ label,
881
+ description,
882
+ statusIcon,
883
+ frame,
884
+ ring,
885
+ fallbackText,
886
+ group,
887
+ groupLabel,
888
+ groupDescription
889
+ };
890
+
891
+ // src/components/Breadcrumb/Breadcrumb.theme.ts
892
+ import { mx as mx4 } from "@dxos/ui-theme";
893
+ var root2 = (_props, ...etc) => mx4("shrink-0 flex items-center", ...etc);
894
+ var list = (_props, ...etc) => mx4("contents", ...etc);
895
+ var listItem = (_props, ...etc) => mx4("contents", ...etc);
896
+ var current = (_props, ...etc) => mx4(...etc);
897
+ var separator = (_props, ...etc) => mx4("opacity-50", ...etc);
898
+ var breadcrumbTheme = {
899
+ root: root2,
900
+ list,
901
+ listItem,
902
+ current,
903
+ separator
904
+ };
905
+
906
+ // src/components/Button/Button.theme.ts
907
+ import { mx as mx5 } from "@dxos/ui-theme";
908
+ var root3 = (_props, ...etc) => {
909
+ return mx5("dx-button dx-focus-ring group gap-1 [&_span]:truncate", ...etc);
910
+ };
911
+ var group2 = (_props, ...etc) => {
912
+ return mx5("inline-flex rounded-xs [&>:first-child]:rounded-w-sm [&>:last-child]:rounded-ie-sm [&>button]:relative", ...etc);
913
+ };
914
+ var buttonTheme = {
915
+ root: root3,
916
+ group: group2
917
+ };
918
+
919
+ // src/components/Button/IconButton.theme.ts
920
+ import { mx as mx6 } from "@dxos/ui-theme";
921
+ var root4 = ({ iconOnly, square }, ...etc) => {
922
+ return mx6("px-1.5", !iconOnly && "gap-1.5", square && "aspect-square", ...etc);
923
+ };
924
+ var iconButtonTheme = {
925
+ root: root4
926
+ };
927
+
928
+ // src/components/Card/Card.theme.ts
929
+ import { mx as mx7 } from "@dxos/ui-theme";
930
+ var root5 = ({ border, fullWidth }, ...etc) => mx7("dx-card dx-card-min-width dx-card-max-width min-h-(--dx-rail-item) group/card relative overflow-hidden", "bg-card-surface", border && "border border-subdued-separator rounded-sm dx-focus-ring-group-y-indicator", fullWidth && "max-w-none!", ...etc);
931
+ var header = (_, ...etc) => mx7("dx-card__header dx-density-md bg-transparent p-0! gap-0! col-span-3 grid! grid-cols-subgrid! shadow-none [contain:none]", ...etc);
932
+ var title = (_props, ...etc) => mx7("dx-card__title grow truncate", ...etc);
933
+ var body = (_props, ...etc) => mx7("dx-card__body contents pb-1 last:pb-0", ...etc);
934
+ var text = ({ variant = "default", truncate: _truncate }, ...etc) => mx7("dx-card__text items-center overflow-hidden", variant === "default" && "py-1", variant === "description" && "py-1.5 text-description", ...etc);
935
+ var textSpan = ({ variant = "default", truncate }, ...etc) => mx7(variant === "description" && "text-sm text-description line-clamp-3", truncate && "truncate", ...etc);
936
+ var poster = (_props, ...etc) => mx7("dx-card__poster col-span-3 max-h-[200px]", ...etc);
937
+ var posterIcon = (_props, ...etc) => mx7("dx-card__poster-icon col-span-3 grid place-items-center bg-input-surface text-subdued max-h-[200px]", ...etc);
938
+ var action = (_props, ...etc) => mx7("dx-card__acztion col-span-3 !grid grid-cols-subgrid p-0! w-full text-start overflow-hidden", ...etc);
939
+ var actionLabel = (_props, ...etc) => mx7("dx-card__action-label min-w-0 flex-1 truncate", ...etc);
940
+ var link = (_props, ...etc) => mx7("dx-card__link col-span-3 !grid grid-cols-subgrid group p-0! dx-button dx-focus-ring min-h-1!", ...etc);
941
+ var linkLabel = (_props, ...etc) => mx7("dx-card__link-label min-w-0 flex-1 truncate", ...etc);
942
+ var row = ({ fullWidth }, ...etc) => mx7("dx-card__row", fullWidth ? "col-span-full" : "col-span-3 grid grid-cols-subgrid", ...etc);
943
+ var section = (_props, ...etc) => mx7("dx-card__section col-span-full grid grid-cols-subgrid", ...etc);
944
+ var sectionTitle = (_props, ...etc) => mx7("dx-card__section-title col-start-2 col-span-full py-2 text-xs text-description font-medium uppercase", ...etc);
945
+ var cardTheme = {
946
+ root: root5,
947
+ header,
948
+ title,
949
+ body,
950
+ row,
951
+ section,
952
+ "section-title": sectionTitle,
953
+ text,
954
+ "text-span": textSpan,
955
+ poster,
956
+ "poster-icon": posterIcon,
957
+ action,
958
+ "action-label": actionLabel,
959
+ link,
960
+ "link-label": linkLabel
961
+ };
962
+
963
+ // src/components/Column/Column.theme.ts
964
+ import { mx as mx8 } from "@dxos/ui-theme";
965
+ var root6 = (_, ...etc) => {
966
+ return mx8("dx-column-root grid", ...etc);
967
+ };
968
+ var row2 = (_, ...etc) => {
969
+ return mx8("col-span-3 grid grid-cols-subgrid", ...etc);
970
+ };
971
+ var bleed = (_, ...etc) => {
972
+ return mx8("col-span-full grid grid-cols-subgrid min-h-0", ...etc);
973
+ };
974
+ var center = (_, ...etc) => {
975
+ return mx8(withColumn.center(), "min-h-0", ...etc);
976
+ };
977
+ var columnTheme = {
978
+ root: root6,
979
+ row: row2,
980
+ bleed,
981
+ center
982
+ };
983
+
984
+ // src/components/Dialog/Dialog.theme.ts
985
+ import { mx as mx9 } from "@dxos/ui-theme";
986
+ var sizeMap = {
987
+ sm: "md:max-w-[24rem]",
988
+ md: "md:max-w-[32rem]!",
989
+ lg: "md:max-w-[40rem]!",
990
+ xl: "md:max-w-[60rem]!"
991
+ };
992
+ var overlay = (_props, ...etc) => mx9("dx-dialog__overlay", ...etc);
993
+ var content = ({ inOverlayLayout, size = "md" }, ...etc) => {
994
+ return mx9("@container", "dx-dialog__content dx-focus-ring dx-modal-surface py-4", !inOverlayLayout && "fixed z-50 top-[50%] left-[50%] -translate-x-[50%] -translate-y-[50%]", sizeMap[size], ...etc);
995
+ };
996
+ var header2 = (_props, ...etc) => mx9("dx-dialog__header flex pb-4 items-center justify-between", withColumn.center(), ...etc);
997
+ var body2 = (_props, ...etc) => mx9("dx-dialog__body dx-expander", withColumn.propagate(), ...etc);
998
+ var actionBar = (_props, ...etc) => mx9("dx-dialog__actionbar flex items-center pt-4 gap-2", withColumn.center(), ...etc);
999
+ var title2 = ({ srOnly }, ...etc) => mx9("dx-dialog__title", srOnly && "sr-only", ...etc);
1000
+ var description2 = ({ srOnly }, ...etc) => mx9("dx-dialog__description", "text-description", srOnly && "sr-only", ...etc);
1001
+ var dialogTheme = {
1002
+ overlay,
1003
+ content,
1004
+ header: header2,
1005
+ body: body2,
1006
+ actionbar: actionBar,
1007
+ title: title2,
1008
+ description: description2
1009
+ };
1010
+
1011
+ // src/components/Focus/Focus.theme.ts
1012
+ import { mx as mx10 } from "@dxos/ui-theme";
1013
+ var ring2 = ({ border }, ...etc) => mx10("dx-ring-pseudo outline-hidden", "focus:after:ring-focus-ring-subtle", "data-[focus-state=active]:after:ring-focus-ring-subtle", "data-[focus-state=error]:after:ring-rose-500", border && "border border-separator", ...etc);
1014
+ var focusTheme = {
1015
+ group: ring2,
1016
+ item: ring2
1017
+ };
1018
+
1019
+ // src/components/Icon/Icon.theme.ts
1020
+ import { getSize as getSize2, mx as mx11 } from "@dxos/ui-theme";
1021
+ var root7 = ({ size }, etc) => {
1022
+ return mx11("shrink-0 text-[var(--icons-color,currentColor)]", size ? getSize2(size) : "[width:var(--icon-size,var(--dx-default-icons-size))] [height:var(--icon-size,var(--dx-default-icons-size))]", etc);
1023
+ };
1024
+ var block = ({ compact, square }, ...etc) => mx11("grid place-items-center [&>img]:max-w-[1.5rem]", square ? "aspect-square" : "w-[var(--dx-rail-item)]", compact ? "" : "h-[var(--dx-rail-item)]", ...etc);
1025
+ var iconTheme = {
1026
+ root: root7,
1027
+ block
1028
+ };
1029
+
1030
+ // src/components/Input/Input.theme.ts
1031
+ import { densityDimensions, staticDisabled } from "@dxos/ui-theme";
1032
+ import { getSize as getSize3, getHeight as getHeight2, getWidth, mx as mx12, snapSize, sizeValue, textValence } from "@dxos/ui-theme";
1033
+ var textInputSurfaceFocus = "transition-colors bg-input-surface focus:bg-focus-surface border border-separator focus:border-separator";
1034
+ var textInputSurfaceHover = "hover:bg-focus-surface";
1035
+ var booleanInputSurface = "shadow-inner transition-colors bg-un-accent aria-checked:bg-accent-bg aria-[checked=mixed]:bg-accent-bg";
1036
+ var booleanInputSurfaceHover = "hover:bg-un-accent-hover hover:aria-checked:bg-accent-bg-hover hover:aria-[checked=mixed]:bg-accent-bg-hover";
1037
+ var valence = (valence2) => {
1038
+ switch (valence2) {
1039
+ case "success":
1040
+ return "shadow-emerald-500/50 dark:shadow-emerald-600/50";
1041
+ case "info":
1042
+ return "shadow-cyan-500/50 dark:shadow-cyan-600/50";
1043
+ case "warning":
1044
+ return "shadow-amber-500/50 dark:shadow-amber-600/50";
1045
+ case "error":
1046
+ return "shadow-rose-500/50 dark:shadow-rose-600/50";
1047
+ }
1048
+ };
1049
+ var sharedSubduedInputStyles = (props) => [
1050
+ '[[data-drag-autoscroll="active"]_&]:pointer-events-none',
1051
+ "py-0 w-full bg-transparent text-current placeholder-placeholder",
1052
+ "dx-focus-subdued",
1053
+ densityDimensions(props.density),
1054
+ props.disabled && staticDisabled
1055
+ ];
1056
+ var sharedDefaultInputStyles = (props) => [
1057
+ '[[data-drag-autoscroll="active"]_&]:pointer-events-none',
1058
+ "py-0 w-full text-base-fg rounded-xs placeholder-placeholder",
1059
+ textInputSurfaceFocus,
1060
+ densityDimensions(props.density),
1061
+ props.disabled ? staticDisabled : textInputSurfaceHover
1062
+ ];
1063
+ var sharedStaticInputStyles = (props) => [
1064
+ '[[data-drag-autoscroll="active"]_&]:pointer-events-none',
1065
+ "py-0 w-full text-base-fg rounded-xs placeholder-placeholder",
1066
+ textInputSurfaceFocus,
1067
+ textInputSurfaceHover,
1068
+ props.focused && "bg-attention-surface",
1069
+ valence(props.validationValence),
1070
+ props.disabled && staticDisabled,
1071
+ props.focused && "dx-focus-static"
1072
+ ];
1073
+ var input = (props, ...etc) => props.variant === "subdued" ? mx12(...sharedSubduedInputStyles(props), ...etc) : props.variant === "static" ? mx12(...sharedStaticInputStyles(props), ...etc) : mx12(...sharedDefaultInputStyles(props), !props.disabled && "dx-focus-ring", valence(props.validationValence), ...etc);
1074
+ var textArea = (props, ...etc) => input(props, ...etc);
1075
+ var checkbox = ({ size = 5 }, ...etc) => mx12("dx-checkbox dx-focus-ring", getSize3(size), ...etc);
1076
+ var checkboxIndicator = ({ size = 5, checked }, ...etc) => mx12(getSize3(snapSize(sizeValue(size) * 0.65, 4)), !checked && "invisible", ...etc);
1077
+ var switchRoot = ({ size = 5, disabled }, ...etc) => mx12(
1078
+ getHeight2(size),
1079
+ getWidth(snapSize(sizeValue(size) * 1.75, 9)),
1080
+ booleanInputSurface,
1081
+ !disabled && booleanInputSurfaceHover,
1082
+ // TODO(burdon): Added m-1 margin to make 40px width to align with 40px icon button.
1083
+ "cursor-pointer shrink-0 rounded-full px-1 mx-1 relative",
1084
+ "dx-focus-ring",
1085
+ ...etc
1086
+ );
1087
+ var switchThumb = ({ size = 5 }, ...etc) => mx12(getSize3(size === "px" ? "px" : size - 2), "block bg-white rounded-full transition-transform duration-100 will-change-transform data-[state=checked]:translate-x-[100%]", ...etc);
1088
+ var withSegmentsInput = (props, ...etc) => mx12("font-mono selection:bg-transparent mx-auto", props.density === "lg" ? "text-lg" : props.density === "sm" ? "text-sm" : props.density === "xs" ? "text-xs" : "text-base pointer-fine:text-sm", props.disabled && "cursor-not-allowed", ...etc);
1089
+ var segment = (props, ...etc) => mx12("flex items-center justify-center font-mono", props.density === "lg" ? "size-12 rounded-xs" : props.density === "sm" ? "size-7 rounded-xs" : props.density === "xs" ? "size-6 rounded-xs" : "size-10 pointer-fine:size-8 rounded-xs", "bg-input-surface text-base-fg transition-colors border border-separator", "data-[focused]:bg-attention-surface data-[focused]:border-focus-ring-subtle", "data-[focused]:ring-2 data-[focused]:ring-offset-0 data-[focused]:ring-focus-ring-subtle", valence(props.validationValence), props.disabled && staticDisabled, ...etc);
1090
+ var label2 = (props, ...etc) => mx12("block", inputTextLabel, props.srOnly && "sr-only", ...etc);
1091
+ var description3 = (props, ...etc) => mx12("text-description", props.srOnly && "sr-only", ...etc);
1092
+ var descriptionAndValidation = (props, ...etc) => mx12("leading-none my-1.5", props.srOnly && "sr-only", ...etc);
1093
+ var validation = (props, ...etc) => mx12(inputTextLabel, props.srOnly ? "sr-only" : textValence(props.validationValence), ...etc);
1094
+ var triggerIcon = (_p, ...etc) => mx12("shrink-0 inline-flex items-center justify-center size-7 rounded-xs", "bg-input-surface text-subdued hover:text-base-fg hover:bg-hover-surface", "dx-focus-ring", ...etc);
1095
+ var inputTheme = {
1096
+ input,
1097
+ textArea,
1098
+ inputWithSegments: withSegmentsInput,
1099
+ segment,
1100
+ checkbox,
1101
+ checkboxIndicator,
1102
+ label: label2,
1103
+ description: description3,
1104
+ switch: switchRoot,
1105
+ switchThumb,
1106
+ validation,
1107
+ descriptionAndValidation,
1108
+ triggerIcon
1109
+ };
1110
+
1111
+ // src/components/Link/Link.theme.ts
1112
+ import { mx as mx13 } from "@dxos/ui-theme";
1113
+ var root8 = ({ variant }, ...etc) => mx13("dx-link", ...etc);
1114
+ var linkTheme = {
1115
+ root: root8
1116
+ };
1117
+
1118
+ // src/components/List/List.theme.ts
1119
+ import { densityBlockSize, ghostHover } from "@dxos/ui-theme";
1120
+ import { getSize as getSize4, mx as mx14 } from "@dxos/ui-theme";
1121
+ var root9 = (_, ...etc) => mx14(...etc);
1122
+ var item = ({ collapsible }, ...etc) => mx14(!collapsible && "flex", ...etc);
1123
+ var itemEndcap = ({ density }, ...etc) => mx14(density === "lg" ? getSize4(10) : density === "sm" ? getSize4(7) : density === "xs" ? getSize4(6) : getSize4(8), "shrink-0 flex items-center justify-center", ...etc);
1124
+ var itemHeading = ({ density }, ...etc) => mx14(densityBlockSize(density), "flex items-center overflow-hidden [&>span]:truncate", ...etc);
1125
+ var itemDragHandleIcon = (_props, ...etc) => mx14(getSize4(5), "mt-2.5", ...etc);
1126
+ var itemOpenTrigger = ({ density }, ...etc) => mx14("w-5 rounded-sm flex justify-center items-center", densityBlockSize(density), ghostHover, "dx-focus-ring", ...etc);
1127
+ var itemOpenTriggerIcon = (_props, ...etc) => {
1128
+ return mx14(getSize4(5), ...etc);
1129
+ };
1130
+ var listTheme = {
1131
+ root: root9,
1132
+ item: {
1133
+ root: item,
1134
+ endcap: itemEndcap,
1135
+ heading: itemHeading,
1136
+ dragHandleIcon: itemDragHandleIcon,
1137
+ openTrigger: itemOpenTrigger,
1138
+ openTriggerIcon: itemOpenTriggerIcon
1139
+ }
1140
+ };
1141
+
1142
+ // src/components/List/Treegrid.theme.ts
1143
+ import { mx as mx15 } from "@dxos/ui-theme";
1144
+ var levelStyles = /* @__PURE__ */ new Map([
1145
+ [
1146
+ 1,
1147
+ "[&>.indent:first-of-type]:pl-0 font-medium"
1148
+ ],
1149
+ [
1150
+ 2,
1151
+ "[&>.indent:first-of-type]:pl-0"
1152
+ ],
1153
+ [
1154
+ 3,
1155
+ "[&>.indent:first-of-type]:pl-1"
1156
+ ],
1157
+ [
1158
+ 4,
1159
+ "[&>.indent:first-of-type]:pl-2"
1160
+ ],
1161
+ [
1162
+ 5,
1163
+ "[&>.indent:first-of-type]:pl-3"
1164
+ ],
1165
+ [
1166
+ 6,
1167
+ "[&>.indent:first-of-type]:pl-4"
1168
+ ],
1169
+ [
1170
+ 7,
1171
+ "[&>.indent:first-of-type]:pl-5"
1172
+ ],
1173
+ [
1174
+ 8,
1175
+ "[&>.indent:first-of-type]:pl-6"
1176
+ ]
1177
+ ]);
1178
+ var root10 = (_, ...etc) => mx15("grid", ...etc);
1179
+ var row3 = ({ level = 1 }, ...etc) => mx15(levelStyles.get(Math.min(Math.max(Math.round(level), 1), 8)), ...etc);
1180
+ var cell = ({ indent }, ...etc) => mx15(indent && "indent", ...etc);
1181
+ var treegridTheme = {
1182
+ root: root10,
1183
+ row: row3,
1184
+ cell
1185
+ };
1186
+
1187
+ // src/components/Main/Main.theme.ts
1188
+ import { mx as mx16 } from "@dxos/ui-theme";
1189
+ var padding = "dx-main-content-padding";
1190
+ var content2 = ({ bounce }, ...etc) => mx16(padding, mainPaddingTransitions, bounce && "dx-main-bounce-layout", "dx-focus-ring-main", ...etc);
1191
+ var sidebar = (_, ...etc) => mx16("dx-main-sidebar", "dx-focus-ring-inset-over-all", ...etc);
1192
+ var overlay2 = (_, ...etc) => mx16("dx-main-overlay", ...etc);
1193
+ var mainTheme = {
1194
+ content: content2,
1195
+ sidebar,
1196
+ overlay: overlay2
1197
+ };
1198
+
1199
+ // src/components/Menu/Menu.theme.ts
1200
+ import { dataDisabled } from "@dxos/ui-theme";
1201
+ import { mx as mx17, surfaceShadow as surfaceShadow2, surfaceZIndex as surfaceZIndex2 } from "@dxos/ui-theme";
1202
+ var content3 = ({ elevation }, ...etc) => mx17("dx-popover-surface w-48 rounded-sm md:w-56 border border-separator", surfaceZIndex2({
1203
+ elevation,
1204
+ level: "menu"
1205
+ }), surfaceShadow2({
1206
+ elevation: "positioned"
1207
+ }), ...etc);
1208
+ var viewport = (_props, ...etc) => mx17("rounded-sm p-1 max-h-[var(--radix-dropdown-menu-content-available-height)] overflow-y-auto", ...etc);
1209
+ var item2 = (_props, ...etc) => mx17("flex cursor-pointer select-none items-center gap-2 rounded-xs px-2 py-2 text-sm", "hover:bg-hover-surface data-[highlighted]:bg-hover-surface", "dx-focus-subdued", dataDisabled, ...etc);
1210
+ var separator2 = (_props, ...etc) => mx17("my-1 mx-2 h-px bg-separator", ...etc);
1211
+ var groupLabel2 = (_props, ...etc) => mx17("text-description", "select-none px-2 py-2", ...etc);
1212
+ var arrow = (_props, ...etc) => mx17("fill-separator", ...etc);
1213
+ var menuTheme = {
1214
+ content: content3,
1215
+ viewport,
1216
+ item: item2,
1217
+ separator: separator2,
1218
+ groupLabel: groupLabel2,
1219
+ arrow
1220
+ };
1221
+
1222
+ // src/components/Message/Message.theme.ts
1223
+ import { mx as mx18, messageValence } from "@dxos/ui-theme";
1224
+ var root11 = ({ valence: valence2 }, etc) => {
1225
+ return mx18("p-1 rounded-sm", messageValence(valence2), etc);
1226
+ };
1227
+ var header3 = (_, etc) => {
1228
+ return mx18("items-center", etc);
1229
+ };
1230
+ var title3 = (_, etc) => {
1231
+ return mx18("col-start-2 overflow-hidden truncate", etc);
1232
+ };
1233
+ var icon = (_, etc) => {
1234
+ return mx18("col-start-1 grid place-items-center", etc);
1235
+ };
1236
+ var close = (_, etc) => {
1237
+ return mx18("col-start-3", etc);
1238
+ };
1239
+ var content4 = (_, etc) => {
1240
+ return mx18("col-start-2 flex flex-col first:font-medium pb-1.5", etc);
1241
+ };
1242
+ var messageTheme = {
1243
+ root: root11,
1244
+ header: header3,
1245
+ icon,
1246
+ title: title3,
1247
+ close,
1248
+ content: content4
1249
+ };
1250
+
1251
+ // src/components/Panel/Panel.theme.ts
1252
+ import { mx as mx19 } from "@dxos/ui-theme";
1253
+ var sizes = {
1254
+ lg: "h-(--dx-topbar-size)",
1255
+ md: "h-(--dx-toolbar-size)",
1256
+ sm: "h-(--dx-statusbar-size)"
1257
+ };
1258
+ var root12 = (_, ...etc) => mx19(
1259
+ "dx-container grid grid-cols-[100%] overflow-hidden",
1260
+ // Add uncategorized children to content slot.
1261
+ "[&>*:not([data-slot])]:[grid-area:content]",
1262
+ ...etc
1263
+ );
1264
+ var toolbar = ({ size = "md" }, ...etc) => mx19("[grid-area:toolbar]", "shrink-0", sizes[size], ...etc);
1265
+ var content5 = (_, ...etc) => mx19("[grid-area:content] min-h-0", ...etc);
1266
+ var statusbar = ({ size = "md" }, ...etc) => mx19("[grid-area:statusbar]", "shrink-0", sizes[size], ...etc);
1267
+ var panelTheme = {
1268
+ root: root12,
1269
+ toolbar,
1270
+ content: content5,
1271
+ statusbar
1272
+ };
1273
+
1274
+ // src/components/Popover/Popover.theme.ts
1275
+ import { mx as mx20, surfaceShadow as surfaceShadow3, surfaceZIndex as surfaceZIndex3 } from "@dxos/ui-theme";
1276
+ var content6 = ({ elevation }, ...etc) => mx20("dx-popover-surface border border-separator rounded-sm", surfaceShadow3({
1277
+ elevation: "positioned"
1278
+ }), surfaceZIndex3({
1279
+ elevation,
1280
+ level: "menu"
1281
+ }), "dx-focus-ring", ...etc);
1282
+ var viewport2 = ({ constrainBlock, constrainInline }, ...etc) => mx20("grid grid-rows-[1fr] min-h-0 min-w-popover-min-width", (constrainBlock || constrainInline) && "overflow-hidden", constrainBlock && "max-h-(--radix-popover-content-available-height)", constrainBlock && "max-h-[min(var(--radix-popover-content-available-height),calc(100dvh-var(--spacing-screen-border)*2))]", constrainInline && "max-w-(--radix-popover-content-available-width)", ...etc);
1283
+ var arrow2 = (_props, ...etc) => mx20("fill-separator", ...etc);
1284
+ var popoverTheme = {
1285
+ content: content6,
1286
+ viewport: viewport2,
1287
+ arrow: arrow2
1288
+ };
1289
+
1290
+ // src/components/ScrollArea/ScrollArea.theme.ts
1291
+ import { mx as mx21 } from "@dxos/ui-theme";
1292
+ var root13 = ({ orientation }, ...etc) => mx21(
1293
+ // Expand
1294
+ "dx-container",
1295
+ orientation === "vertical" && "group/scroll-v flex flex-col",
1296
+ orientation === "horizontal" && "group/scroll-h flex",
1297
+ // `flex flex-col` is required (as in `vertical`) so the viewport's `flex-1 min-h-0` can
1298
+ // bound its height; without it the viewport grows to content height and only scrolls
1299
+ // horizontally (the root clips the vertical overflow instead of scrolling it).
1300
+ orientation === "all" && "group/scroll-all flex flex-col",
1301
+ // Apply col-span-full only when inside a Column.Root grid (detected via dx-column-root marker).
1302
+ "[.dx-column-root_&]:col-span-full",
1303
+ ...etc
1304
+ );
1305
+ var viewport3 = ({ orientation, centered, padding: padding2, snap, autoHide }, ...etc) => {
1306
+ return mx21(
1307
+ "flex-1 min-h-0 w-full",
1308
+ // Reset --dx-col so nested components don't try to grid-position themselves.
1309
+ // ScrollArea has already consumed --gutter for padding.
1310
+ withColumn.consumed(),
1311
+ orientation === "vertical" && "overflow-y-scroll",
1312
+ orientation === "horizontal" && "flex overflow-x-scroll overscroll-x-contain",
1313
+ orientation === "all" && "overflow-scroll",
1314
+ "[&::-webkit-scrollbar-corner]:bg-transparent",
1315
+ "[&::-webkit-scrollbar-track]:bg-transparent",
1316
+ "[&::-webkit-scrollbar-thumb]:rounded-none",
1317
+ "[&::-webkit-scrollbar]:w-[var(--scroll-width)] [&::-webkit-scrollbar]:h-[var(--scroll-width)]",
1318
+ // If contained within Column.Root grid the gutter is set by that component (--gutter CSS variable).
1319
+ // If centered, left padding compensates for scrollbar width so content is visually centered.
1320
+ (orientation === "vertical" || orientation === "all") && (padding2 ? [
1321
+ centered ? "pl-[var(--gutter,calc(var(--scroll-width)+var(--scroll-padding)))]" : "pl-[var(--gutter,0)]",
1322
+ "pr-[calc(var(--gutter,calc(var(--scroll-width)+var(--scroll-padding)))-var(--scroll-width))]"
1323
+ ] : centered && "pl-[var(--scroll-width)]"),
1324
+ (orientation === "horizontal" || orientation === "all") && (padding2 ? [
1325
+ centered && "pt-[calc(var(--scroll-width)+var(--scroll-padding))]",
1326
+ "pb-[var(--scroll-padding)]"
1327
+ ] : centered && "pt-[var(--scroll-width)]"),
1328
+ snap && [
1329
+ orientation === "vertical" && "snap-y snap-mandatory",
1330
+ orientation === "horizontal" && "snap-x snap-mandatory",
1331
+ orientation === "all" && "snap-both snap-mandatory"
1332
+ ],
1333
+ autoHide ? [
1334
+ orientation === "vertical" && "group-hover/scroll-v:[&::-webkit-scrollbar-thumb]:bg-scrollbar-thumb",
1335
+ orientation === "horizontal" && "group-hover/scroll-h:[&::-webkit-scrollbar-thumb]:bg-scrollbar-thumb",
1336
+ orientation === "all" && "group-hover/scroll-all:[&::-webkit-scrollbar-thumb]:bg-scrollbar-thumb"
1337
+ ] : [
1338
+ orientation === "vertical" && "[&::-webkit-scrollbar-thumb]:bg-scrollbar-thumb",
1339
+ orientation === "horizontal" && "[&::-webkit-scrollbar-thumb]:bg-scrollbar-thumb",
1340
+ orientation === "all" && "[&::-webkit-scrollbar-thumb]:bg-scrollbar-thumb"
1341
+ ],
1342
+ ...etc
1343
+ );
1344
+ };
1345
+ var scrollAreaTheme = {
1346
+ root: root13,
1347
+ viewport: viewport3
1348
+ };
1349
+
1350
+ // src/components/Select/Select.theme.ts
1351
+ import { mx as mx22, surfaceShadow as surfaceShadow4, surfaceZIndex as surfaceZIndex4 } from "@dxos/ui-theme";
1352
+ var content7 = ({ elevation }, ...etc) => {
1353
+ return mx22("dx-modal-surface rounded-sm border border-separator", "min-w-(--radix-select-trigger-width) max-h-(--radix-select-content-available-height)", surfaceShadow4({
1354
+ elevation: "positioned"
1355
+ }), surfaceZIndex4({
1356
+ elevation,
1357
+ level: "menu"
1358
+ }), ...etc);
1359
+ };
1360
+ var triggerButton = (_props, ...etc) => mx22("grid grid-cols-[1fr_auto] [&>span]:text-left", ...etc);
1361
+ var viewport4 = (_props, ...etc) => mx22(...etc);
1362
+ var item3 = (_props, ...etc) => mx22("flex items-center min-h-[2rem] px-2.5 py-1 gap-2", "text-base-fg leading-none select-none outline-hidden", "[&>svg]:invisible [&[data-state=checked]>svg]:visible", "dx-highlighted", ...etc);
1363
+ var itemIndicator = (_props, ...etc) => mx22("items-center", ...etc);
1364
+ var arrow3 = (_props, ...etc) => mx22("fill-separator", ...etc);
1365
+ var separator3 = (_props, ...etc) => mx22("self-stretch border-b my-1 border-separator", ...etc);
1366
+ var scrollButton = (_props, ...etc) => mx22("dx-modal-surface flex items-center justify-center cursor-default h-6 w-full", ...etc);
1367
+ var selectTheme = {
1368
+ content: content7,
1369
+ triggerButton,
1370
+ viewport: viewport4,
1371
+ item: item3,
1372
+ itemIndicator,
1373
+ arrow: arrow3,
1374
+ separator: separator3,
1375
+ scrollButton
1376
+ };
1377
+
1378
+ // src/components/Separator/Separator.theme.ts
1379
+ import { mx as mx23 } from "@dxos/ui-theme";
1380
+ var root14 = ({ orientation, subdued }, ...etc) => mx23("self-stretch", orientation === "vertical" ? "border-e mx-1" : "border-b my-1", subdued ? "border-subdued-separator" : "border-separator", ...etc);
1381
+ var separatorTheme = {
1382
+ root: root14
1383
+ };
1384
+
1385
+ // src/components/Skeleton/Skeleton.theme.ts
1386
+ import { mx as mx24 } from "@dxos/ui-theme";
1387
+ var root15 = ({ variant = "default" }, ...etc) => mx24("animate-pulse bg-neutral-300 dark:bg-neutral-700 rounded-md", variant === "circle" && "rounded-full", variant === "text" && "rounded-sm", ...etc);
1388
+ var skeletonTheme = {
1389
+ root: root15
1390
+ };
1391
+
1392
+ // src/components/Splitter/Splitter.theme.ts
1393
+ import { mx as mx25 } from "@dxos/ui-theme";
1394
+ var root16 = (_props, ...etc) => mx25("relative h-full overflow-hidden", ...etc);
1395
+ var panel = (_props, ...etc) => mx25("absolute inset-x-0 flex flex-col overflow-hidden", ...etc);
1396
+ var splitterTheme = {
1397
+ root: root16,
1398
+ panel
1399
+ };
1400
+
1401
+ // src/components/Status/Status.theme.ts
1402
+ import { mx as mx26 } from "@dxos/ui-theme";
1403
+ var root17 = ({ variant = "default" }, ...etc) => mx26("h-1 relative rounded-full overflow-hidden", variant === "main-bottom" ? "w-full block" : "inline-20 inline-block bg-base-surface", ...etc);
1404
+ var bar = ({ variant = "default", indeterminate }, ...etc) => mx26("absolute inset-y-0 block rounded-full", variant === "main-bottom" ? "bg-composer-300" : "bg-un-accent", indeterminate ? "animate-progress-indeterminate" : "start-0", ...etc);
1405
+ var statusTheme = {
1406
+ root: root17,
1407
+ bar
1408
+ };
1409
+
1410
+ // src/components/Tag/Tag.theme.ts
1411
+ import { mx as mx27 } from "@dxos/ui-theme";
1412
+ var root18 = (_, ...etc) => mx27("dx-tag", ...etc);
1413
+ var tagTheme = {
1414
+ root: root18
1415
+ };
1416
+
1417
+ // src/components/Toast/Toast.theme.ts
1418
+ import { mx as mx28, surfaceShadow as surfaceShadow5 } from "@dxos/ui-theme";
1419
+ var viewport5 = (_props, ...etc) => mx28(
1420
+ // TODO(burdon): block-end should take into account status bar.
1421
+ "z-40 fixed bottom-[calc(env(safe-area-inset-bottom)+1rem)] inset-start-[calc(env(safe-area-inset-left)+1rem)] inset-end-[calc(env(safe-area-inset-right)+1rem)] w-auto md:end-[calc(env(safe-area-inset-right)+1rem)] md:left-auto md:w-full md:max-w-sm",
1422
+ "rounded-md flex flex-col gap-2",
1423
+ ...etc
1424
+ );
1425
+ var root19 = (_props, ...etc) => mx28("dx-popover-surface rounded-md p-1", surfaceShadow5({
1426
+ elevation: "toast"
1427
+ }), "radix-state-open:animate-toast-slide-in-bottom md:radix-state-open:animate-toast-slide-in-right", "radix-state-closed:animate-toast-hide", "radix-swipe-end:animate-toast-swipe-out", "translate-x-radix-toast-swipe-move-x", "radix-swipe-cancel:translate-x-0 radix-swipe-cancel:duration-200 radix-swipe-cancel:ease-[ease]", "dx-focus-ring", ...etc);
1428
+ var grid = (_props, ...etc) => mx28("gap-y-1 pbe-1", ...etc);
1429
+ var header4 = (_props, ...etc) => mx28("items-center", ...etc);
1430
+ var icon2 = (_props, ...etc) => mx28("col-start-1 grid place-items-center", ...etc);
1431
+ var title4 = (_props, ...etc) => mx28("col-start-2 truncate font-medium", ...etc);
1432
+ var close2 = (_props, ...etc) => mx28("col-start-3", ...etc);
1433
+ var description4 = (_props, ...etc) => mx28("col-start-2 overflow-hidden text-description", ...etc);
1434
+ var actions = (_props, ...etc) => mx28("flex gap-2 mbs-1", ...etc);
1435
+ var toastTheme = {
1436
+ viewport: viewport5,
1437
+ root: root19,
1438
+ grid,
1439
+ header: header4,
1440
+ icon: icon2,
1441
+ title: title4,
1442
+ close: close2,
1443
+ description: description4,
1444
+ actions
1445
+ };
1446
+
1447
+ // src/components/Toolbar/Toolbar.theme.ts
1448
+ import { mx as mx29 } from "@dxos/ui-theme";
1449
+ var layout = "w-full shrink-0 flex flex-nowrap p-1 gap-1 items-center overflow-x-auto scrollbar-none dx-contain-layout";
1450
+ var root20 = ({ density, disabled, layoutManaged }, ...etc) => {
1451
+ return mx29("bg-toolbar-surface dx-toolbar shadow-sm", density === "lg" && "h-(--dx-rail-size) px-3!", density === "sm" && "h-7 px-2!", density === "xs" && "h-6 px-1!", disabled && "*:opacity-20", !layoutManaged && layout, ...etc);
1452
+ };
1453
+ var text2 = (_, ...etc) => {
1454
+ return mx29("px-2 grow truncate items-center", ...etc);
1455
+ };
1456
+ var toolbarTheme = {
1457
+ root: root20,
1458
+ text: text2
1459
+ };
1460
+
1461
+ // src/components/Tooltip/Tooltip.theme.ts
1462
+ import { mx as mx30 } from "@dxos/ui-theme";
1463
+ var arrow4 = (_props, ...etc) => mx30("fill-inverse-surface", ...etc);
1464
+ var tooltipTheme = {
1465
+ content: tooltipContent,
1466
+ arrow: arrow4
1467
+ };
1468
+
1469
+ // src/components/Calendar/Calendar.theme.ts
1470
+ import { mx as mx31 } from "@dxos/ui-theme";
1471
+ var root21 = (_p, ...etc) => mx31("relative w-fit h-fit self-start p-2 select-none bg-group-surface text-base-fg", ...etc);
1472
+ var nav = (_p, ...etc) => mx31("flex items-center justify-between pb-1", ...etc);
1473
+ var caption_label = (_p, ...etc) => mx31("flex-1 text-center text-sm font-medium", ...etc);
1474
+ var button_previous = (_p, ...etc) => mx31("h-7 w-7 inline-flex items-center justify-center rounded-sm shrink-0", "text-description hover:bg-hover-surface", "data-[disabled]:opacity-50 data-[disabled]:cursor-not-allowed", ...etc);
1475
+ var button_next = (_p, ...etc) => mx31("h-7 w-7 inline-flex items-center justify-center rounded-sm shrink-0", "text-description hover:bg-hover-surface", "data-[disabled]:opacity-50 data-[disabled]:cursor-not-allowed", ...etc);
1476
+ var month_grid = (_p, ...etc) => mx31("w-full border-collapse", ...etc);
1477
+ var weekdays = (_p, ...etc) => mx31("", ...etc);
1478
+ var weekday = (_p, ...etc) => mx31("w-9 h-7 text-xs font-thin text-description", ...etc);
1479
+ var day = (_p, ...etc) => mx31(
1480
+ "relative w-9 h-9 p-0 text-center text-sm rounded-sm inline-flex items-center justify-center cursor-pointer",
1481
+ "outline-none",
1482
+ "data-[hovered]:bg-hover-surface",
1483
+ "data-[focus-visible]:outline-2 data-[focus-visible]:outline-primary-500",
1484
+ "data-[selected]:bg-primary-500 data-[selected]:text-primary-fg data-[selected]:hover:bg-primary-500",
1485
+ "data-[outside-month]:text-description/40",
1486
+ "data-[disabled]:text-description/40 data-[disabled]:cursor-not-allowed data-[disabled]:hover:bg-transparent",
1487
+ "data-[unavailable]:line-through data-[unavailable]:text-description/50 data-[unavailable]:cursor-not-allowed",
1488
+ // Range selection visual layer.
1489
+ "data-[selection-start]:rounded-l-sm data-[selection-end]:rounded-r-sm",
1490
+ "data-[selection-start]:bg-primary-500 data-[selection-end]:bg-primary-500",
1491
+ ...etc
1492
+ );
1493
+ var calendarTheme = {
1494
+ root: root21,
1495
+ nav,
1496
+ caption_label,
1497
+ button_previous,
1498
+ button_next,
1499
+ month_grid,
1500
+ weekdays,
1501
+ weekday,
1502
+ day
1503
+ };
1504
+
1505
+ // src/components/DatePicker/DatePicker.theme.ts
1506
+ import { mx as mx32 } from "@dxos/ui-theme";
1507
+ var trigger = ({ hasValue }, ...etc) => mx32("inline-flex w-fit items-center gap-2 px-2 rounded-sm border border-separator", "bg-input-surface text-base-fg", "hover:bg-hover-surface focus-visible:outline-2 focus-visible:outline-primary-500", !hasValue && "text-description", ...etc);
1508
+ var content8 = (_p, ...etc) => mx32("flex flex-col gap-2 p-2", ...etc);
1509
+ var timeField = (_p, ...etc) => mx32("flex items-center gap-2 px-2 py-1", "[&_input]:bg-input-surface [&_input]:border [&_input]:border-separator", "[&_input]:rounded-sm [&_input]:px-2 [&_input]:py-1", ...etc);
1510
+ var datePickerTheme = {
1511
+ trigger,
1512
+ content: content8,
1513
+ timeField
1514
+ };
1515
+
1516
+ // src/theme/defaultTheme.ts
1517
+ var defaultTheme = {
1518
+ themeName: () => "default",
1519
+ //
1520
+ // Primitives
1521
+ //
1522
+ column: columnTheme,
1523
+ panel: panelTheme,
1524
+ //
1525
+ // Components
1526
+ //
1527
+ avatar: avatarTheme,
1528
+ breadcrumb: breadcrumbTheme,
1529
+ button: buttonTheme,
1530
+ calendar: calendarTheme,
1531
+ card: cardTheme,
1532
+ datePicker: datePickerTheme,
1533
+ dialog: dialogTheme,
1534
+ focus: focusTheme,
1535
+ icon: iconTheme,
1536
+ iconButton: iconButtonTheme,
1537
+ input: inputTheme,
1538
+ link: linkTheme,
1539
+ list: listTheme,
1540
+ main: mainTheme,
1541
+ message: messageTheme,
1542
+ menu: menuTheme,
1543
+ popover: popoverTheme,
1544
+ scrollArea: scrollAreaTheme,
1545
+ select: selectTheme,
1546
+ separator: separatorTheme,
1547
+ skeleton: skeletonTheme,
1548
+ splitter: splitterTheme,
1549
+ status: statusTheme,
1550
+ tag: tagTheme,
1551
+ toast: toastTheme,
1552
+ toolbar: toolbarTheme,
1553
+ tooltip: tooltipTheme,
1554
+ treegrid: treegridTheme
1555
+ };
1556
+ var defaultTx = bindTheme(defaultTheme);
1557
+
1558
+ export {
1559
+ DensityContext,
1560
+ DensityProvider,
1561
+ ElevationContext,
1562
+ ElevationProvider,
1563
+ hasIosKeyboard,
1564
+ TranslationsContext,
1565
+ useTranslation,
1566
+ ThemeContext,
1567
+ ThemeProvider,
1568
+ useElevationContext,
1569
+ useThemeContext,
1570
+ initialSafeArea,
1571
+ useSafeArea,
1572
+ createTooltipScope,
1573
+ useTooltipContext,
1574
+ Tooltip,
1575
+ tooltipContent,
1576
+ withColumn,
1577
+ parseCaptureOwnerStack,
1578
+ ErrorStack,
1579
+ inputTextLabel,
1580
+ mainPaddingTransitions,
1581
+ mainIntrinsicSize,
1582
+ bindTheme,
1583
+ avatarTheme,
1584
+ breadcrumbTheme,
1585
+ buttonTheme,
1586
+ iconButtonTheme,
1587
+ cardTheme,
1588
+ columnTheme,
1589
+ dialogTheme,
1590
+ focusTheme,
1591
+ iconTheme,
1592
+ inputTheme,
1593
+ linkTheme,
1594
+ listTheme,
1595
+ treegridTheme,
1596
+ mainTheme,
1597
+ menuTheme,
1598
+ messageTheme,
1599
+ panelTheme,
1600
+ popoverTheme,
1601
+ scrollAreaTheme,
1602
+ selectTheme,
1603
+ separatorTheme,
1604
+ skeletonTheme,
1605
+ splitterTheme,
1606
+ statusTheme,
1607
+ tagTheme,
1608
+ toastTheme,
1609
+ toolbarTheme,
1610
+ tooltipTheme,
1611
+ defaultTheme,
1612
+ defaultTx
1613
+ };
1614
+ //# sourceMappingURL=chunk-TTEL2FP2.mjs.map