@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
@@ -1,850 +0,0 @@
1
- import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
-
3
- // src/components/DensityProvider/DensityProvider.tsx
4
- import React, { createContext } from "react";
5
- var DensityContext = /* @__PURE__ */ createContext({
6
- density: "fine"
7
- });
8
- var DensityProvider = ({ density, children }) => /* @__PURE__ */ React.createElement(DensityContext.Provider, {
9
- value: {
10
- density
11
- }
12
- }, children);
13
-
14
- // src/components/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/hooks/useElevationContext.ts
26
- import { useContext as useContext3 } from "react";
27
-
28
- // src/components/ThemeProvider/ThemeProvider.tsx
29
- import { createKeyborg } from "keyborg";
30
- import React4, { createContext as createContext4, useEffect as useEffect2, useMemo } from "react";
31
-
32
- // src/hooks/useThemeContext.ts
33
- import { useContext } from "react";
34
- import { raise } from "@dxos/debug";
35
- var useThemeContext = () => useContext(ThemeContext) ?? raise(new Error("Missing ThemeContext"));
36
-
37
- // src/hooks/useSafeArea.ts
38
- import { useCallback, useState } from "react";
39
- import { useViewportResize } from "@dxos/react-hooks";
40
- var initialSafeArea = {
41
- top: NaN,
42
- right: NaN,
43
- bottom: NaN,
44
- left: NaN
45
- };
46
- var useSafeArea = () => {
47
- const [padding, setPadding] = useState(initialSafeArea);
48
- const handleResize = useCallback(() => {
49
- setPadding({
50
- top: parseFloat(getComputedStyle(document.documentElement).getPropertyValue("--safe-area-top")),
51
- right: parseFloat(getComputedStyle(document.documentElement).getPropertyValue("--safe-area-right")),
52
- bottom: parseFloat(getComputedStyle(document.documentElement).getPropertyValue("--safe-area-bottom")),
53
- left: parseFloat(getComputedStyle(document.documentElement).getPropertyValue("--safe-area-left"))
54
- });
55
- }, []);
56
- useViewportResize(handleResize);
57
- return padding;
58
- };
59
-
60
- // src/components/ThemeProvider/TranslationsProvider.tsx
61
- import { enUS as dtLocaleEnUs } from "date-fns/locale";
62
- import i18Next from "i18next";
63
- import React3, { Suspense, createContext as createContext3, useContext as useContext2, useEffect, useState as useState2 } from "react";
64
- import { initReactI18next, useTranslation as useI18NextTranslation } from "react-i18next";
65
- var initialLng = "en-US";
66
- var initialNs = "dxos-common";
67
- var initialDtLocale = dtLocaleEnUs;
68
- var resources = {
69
- [initialLng]: {
70
- [initialNs]: {
71
- "loading translations": "Loading translations\u2026"
72
- }
73
- }
74
- };
75
- void i18Next.use(initReactI18next).init({
76
- resources,
77
- lng: initialLng,
78
- defaultNS: initialNs,
79
- interpolation: {
80
- escapeValue: false
81
- }
82
- });
83
- var TranslationsContext = /* @__PURE__ */ createContext3({
84
- appNs: initialNs,
85
- dtLocale: initialDtLocale
86
- });
87
- var useTranslation = (...args) => {
88
- const result = useI18NextTranslation(...args);
89
- const { dtLocale } = useContext2(TranslationsContext);
90
- return {
91
- ...result,
92
- dtLocale
93
- };
94
- };
95
- var TranslationsProvider = ({ fallback, resourceExtensions, children, appNs, dtLocale }) => {
96
- const [loaded, setLoaded] = useState2(false);
97
- useEffect(() => {
98
- setLoaded(false);
99
- if (resourceExtensions && resourceExtensions.length) {
100
- resourceExtensions.forEach((resource) => {
101
- Object.keys(resource).forEach((language) => {
102
- Object.keys(resource[language]).forEach((ns) => {
103
- i18Next.addResourceBundle(language, ns, resource[language][ns]);
104
- });
105
- });
106
- });
107
- }
108
- setLoaded(true);
109
- }, [
110
- resourceExtensions
111
- ]);
112
- return /* @__PURE__ */ React3.createElement(TranslationsContext.Provider, {
113
- value: {
114
- appNs: appNs ?? initialNs,
115
- dtLocale: dtLocale ?? initialDtLocale
116
- }
117
- }, /* @__PURE__ */ React3.createElement(Suspense, {
118
- fallback
119
- }, loaded ? children : fallback));
120
- };
121
-
122
- // src/util/hasIosKeyboard.ts
123
- var hasIosKeyboard = () => {
124
- return !!navigator.userAgent.match(/iP(ad|od|hone).+Safari/);
125
- };
126
-
127
- // src/components/ThemeProvider/ThemeProvider.tsx
128
- var ThemeContext = /* @__PURE__ */ createContext4(void 0);
129
- var ThemeProvider = ({ children, fallback = null, resourceExtensions, appNs, tx = (_path, _styleProps, ..._options) => void 0, themeMode = "dark", rootDensity = "fine", noCache, platform }) => {
130
- useEffect2(() => {
131
- if (document.defaultView) {
132
- const kb = createKeyborg(document.defaultView);
133
- kb.subscribe(handleInputModalityChange);
134
- return () => kb.unsubscribe(handleInputModalityChange);
135
- }
136
- }, []);
137
- const safeAreaPadding = useSafeArea();
138
- const contextValue = useMemo(() => ({
139
- tx,
140
- themeMode,
141
- hasIosKeyboard: hasIosKeyboard(),
142
- safeAreaPadding,
143
- noCache,
144
- platform
145
- }), [
146
- tx,
147
- themeMode,
148
- safeAreaPadding,
149
- noCache,
150
- platform
151
- ]);
152
- return /* @__PURE__ */ React4.createElement(ThemeContext.Provider, {
153
- value: contextValue
154
- }, /* @__PURE__ */ React4.createElement(TranslationsProvider, {
155
- fallback,
156
- resourceExtensions,
157
- appNs
158
- }, /* @__PURE__ */ React4.createElement(ElevationProvider, {
159
- elevation: "base"
160
- }, /* @__PURE__ */ React4.createElement(DensityProvider, {
161
- density: rootDensity
162
- }, children))));
163
- };
164
- var handleInputModalityChange = (isUsingKeyboard) => {
165
- if (isUsingKeyboard) {
166
- document.body.setAttribute("data-w-keyboard", "true");
167
- } else {
168
- document.body.removeAttribute("data-w-keyboard");
169
- }
170
- };
171
-
172
- // src/components/Tooltip/Tooltip.tsx
173
- import { composeEventHandlers } from "@radix-ui/primitive";
174
- import { useComposedRefs } from "@radix-ui/react-compose-refs";
175
- import { createContextScope } from "@radix-ui/react-context";
176
- import { DismissableLayer } from "@radix-ui/react-dismissable-layer";
177
- import { useId } from "@radix-ui/react-id";
178
- import * as PopperPrimitive from "@radix-ui/react-popper";
179
- import { createPopperScope } from "@radix-ui/react-popper";
180
- import { Portal as PortalPrimitive } from "@radix-ui/react-portal";
181
- import { Presence } from "@radix-ui/react-presence";
182
- import { Primitive } from "@radix-ui/react-primitive";
183
- import { Slottable } from "@radix-ui/react-slot";
184
- import { useControllableState } from "@radix-ui/react-use-controllable-state";
185
- import * as VisuallyHiddenPrimitive from "@radix-ui/react-visually-hidden";
186
- import React5, { forwardRef, useCallback as useCallback2, useEffect as useEffect3, useMemo as useMemo2, useRef, useState as useState3 } from "react";
187
- var [createTooltipContext, createTooltipScope] = createContextScope("Tooltip", [
188
- createPopperScope
189
- ]);
190
- var usePopperScope = createPopperScope();
191
- var DEFAULT_DELAY_DURATION = 700;
192
- var TOOLTIP_OPEN = "tooltip.open";
193
- var TOOLTIP_NAME = "Tooltip";
194
- var [TooltipContextProvider, useTooltipContext] = createTooltipContext(TOOLTIP_NAME);
195
- var TooltipProvider = (props) => {
196
- const { __scopeTooltip, children, open: openProp, defaultOpen = false, onOpenChange, disableHoverableContent = false, delayDuration = DEFAULT_DELAY_DURATION, skipDelayDuration = 300 } = props;
197
- const isOpenDelayedRef = useRef(true);
198
- const isPointerInTransitRef = useRef(false);
199
- const skipDelayTimerRef = useRef(0);
200
- useEffect3(() => {
201
- const skipDelayTimer = skipDelayTimerRef.current;
202
- return () => window.clearTimeout(skipDelayTimer);
203
- }, []);
204
- const popperScope = usePopperScope(__scopeTooltip);
205
- const [trigger, setTrigger] = useState3(null);
206
- const [content, setContent] = useState3("");
207
- const [side, setSide] = useState3(void 0);
208
- const triggerRef = useRef(trigger);
209
- const handleTriggerChange = useCallback2((nextTrigger) => {
210
- setTrigger(nextTrigger);
211
- triggerRef.current = nextTrigger;
212
- setContent(nextTrigger?.getAttribute("data-tooltip-content") ?? "");
213
- setSide(nextTrigger?.getAttribute("data-tooltip-side") ?? void 0);
214
- }, []);
215
- const contentId = useId();
216
- const openTimerRef = useRef(0);
217
- const wasOpenDelayedRef = useRef(false);
218
- const handleOpenChange = useCallback2((open2) => {
219
- if (open2) {
220
- window.clearTimeout(skipDelayTimerRef.current);
221
- isOpenDelayedRef.current = false;
222
- document.dispatchEvent(new CustomEvent(TOOLTIP_OPEN));
223
- } else {
224
- window.clearTimeout(skipDelayTimerRef.current);
225
- skipDelayTimerRef.current = window.setTimeout(() => isOpenDelayedRef.current = true, skipDelayDuration);
226
- }
227
- onOpenChange?.(open2);
228
- }, [
229
- skipDelayDuration,
230
- onOpenChange
231
- ]);
232
- const [open = false, setOpen] = useControllableState({
233
- prop: openProp,
234
- defaultProp: defaultOpen,
235
- onChange: handleOpenChange
236
- });
237
- const stateAttribute = useMemo2(() => {
238
- return open ? wasOpenDelayedRef.current ? "delayed-open" : "instant-open" : "closed";
239
- }, [
240
- open
241
- ]);
242
- const handleOpen = useCallback2(() => {
243
- window.clearTimeout(openTimerRef.current);
244
- openTimerRef.current = 0;
245
- wasOpenDelayedRef.current = false;
246
- setOpen(true);
247
- }, [
248
- setOpen
249
- ]);
250
- const handleClose = useCallback2(() => {
251
- window.clearTimeout(openTimerRef.current);
252
- openTimerRef.current = 0;
253
- setOpen(false);
254
- }, [
255
- setOpen
256
- ]);
257
- const handleDelayedOpen = useCallback2(() => {
258
- window.clearTimeout(openTimerRef.current);
259
- openTimerRef.current = window.setTimeout(() => {
260
- wasOpenDelayedRef.current = true;
261
- setOpen(true);
262
- openTimerRef.current = 0;
263
- }, delayDuration);
264
- }, [
265
- delayDuration,
266
- setOpen
267
- ]);
268
- useEffect3(() => {
269
- return () => {
270
- if (openTimerRef.current) {
271
- window.clearTimeout(openTimerRef.current);
272
- openTimerRef.current = 0;
273
- }
274
- };
275
- }, []);
276
- const { tx } = useThemeContext();
277
- const elevation = useElevationContext();
278
- return /* @__PURE__ */ React5.createElement(PopperPrimitive.Root, popperScope, /* @__PURE__ */ React5.createElement(TooltipContextProvider, {
279
- scope: __scopeTooltip,
280
- contentId,
281
- open,
282
- stateAttribute,
283
- trigger,
284
- onTriggerChange: handleTriggerChange,
285
- onTriggerEnter: useCallback2(() => {
286
- if (isOpenDelayedRef.current) {
287
- handleDelayedOpen();
288
- } else {
289
- handleOpen();
290
- }
291
- }, [
292
- isOpenDelayedRef,
293
- handleDelayedOpen,
294
- handleOpen
295
- ]),
296
- onTriggerLeave: useCallback2(() => {
297
- if (disableHoverableContent) {
298
- handleClose();
299
- } else {
300
- window.clearTimeout(openTimerRef.current);
301
- openTimerRef.current = 0;
302
- }
303
- }, [
304
- handleClose,
305
- disableHoverableContent
306
- ]),
307
- onOpen: handleOpen,
308
- onClose: handleClose,
309
- disableHoverableContent,
310
- isPointerInTransitRef,
311
- onPointerInTransitChange: useCallback2((inTransit) => {
312
- isPointerInTransitRef.current = inTransit;
313
- }, [])
314
- }, /* @__PURE__ */ React5.createElement(TooltipContent, {
315
- side,
316
- className: tx("tooltip.content", {
317
- elevation
318
- })
319
- }, content, /* @__PURE__ */ React5.createElement(TooltipArrow, {
320
- className: tx("tooltip.arrow")
321
- })), /* @__PURE__ */ React5.createElement(TooltipVirtualTrigger, {
322
- virtualRef: triggerRef
323
- }), children));
324
- };
325
- TooltipProvider.displayName = TOOLTIP_NAME;
326
- var TooltipVirtualTrigger = ({ virtualRef, __scopeTooltip }) => {
327
- const popperScope = usePopperScope(__scopeTooltip);
328
- return /* @__PURE__ */ React5.createElement(PopperPrimitive.Anchor, {
329
- asChild: true,
330
- ...popperScope,
331
- virtualRef
332
- });
333
- };
334
- var TRIGGER_NAME = "TooltipTrigger";
335
- var TooltipTrigger = /* @__PURE__ */ forwardRef((props, forwardedRef) => {
336
- const {
337
- __scopeTooltip,
338
- onInteract,
339
- // TODO(thure): Pass `delayDuration` into the context.
340
- delayDuration: _delayDuration,
341
- side,
342
- content,
343
- ...triggerProps
344
- } = props;
345
- const context = useTooltipContext(TRIGGER_NAME, __scopeTooltip);
346
- const ref = useRef(null);
347
- const composedRefs = useComposedRefs(forwardedRef, ref);
348
- const isPointerDownRef = useRef(false);
349
- const hasPointerMoveOpenedRef = useRef(false);
350
- const handlePointerUp = useCallback2(() => isPointerDownRef.current = false, []);
351
- useEffect3(() => {
352
- return () => document.removeEventListener("pointerup", handlePointerUp);
353
- }, [
354
- handlePointerUp
355
- ]);
356
- return /* @__PURE__ */ React5.createElement(Primitive.button, {
357
- // We purposefully avoid adding `type=button` here because tooltip triggers are also
358
- // commonly anchors and the anchor `type` attribute signifies MIME type.
359
- "aria-describedby": context.open ? context.contentId : void 0,
360
- "data-state": context.stateAttribute,
361
- "data-tooltip-content": content,
362
- "data-tooltip-side": side,
363
- ...triggerProps,
364
- ref: composedRefs,
365
- onPointerMove: composeEventHandlers(props.onPointerMove, (event) => {
366
- if (event.pointerType === "touch") {
367
- return;
368
- }
369
- if (!hasPointerMoveOpenedRef.current && !context.isPointerInTransitRef.current) {
370
- onInteract?.(event);
371
- if (event.defaultPrevented) {
372
- return;
373
- }
374
- context.onTriggerChange(ref.current);
375
- context.onTriggerEnter();
376
- hasPointerMoveOpenedRef.current = true;
377
- }
378
- }),
379
- onPointerLeave: composeEventHandlers(props.onPointerLeave, () => {
380
- context.onTriggerLeave();
381
- hasPointerMoveOpenedRef.current = false;
382
- }),
383
- onPointerDown: composeEventHandlers(props.onPointerDown, () => {
384
- if (context.open) {
385
- context.onClose();
386
- }
387
- isPointerDownRef.current = true;
388
- document.addEventListener("pointerup", handlePointerUp, {
389
- once: true
390
- });
391
- }),
392
- onFocus: props.onFocus,
393
- onBlur: composeEventHandlers(props.onBlur, context.onClose),
394
- onClick: composeEventHandlers(props.onClick, context.onClose)
395
- });
396
- });
397
- TooltipTrigger.displayName = TRIGGER_NAME;
398
- var PORTAL_NAME = "TooltipPortal";
399
- var [PortalProvider, usePortalContext] = createTooltipContext(PORTAL_NAME, {
400
- forceMount: void 0
401
- });
402
- var TooltipPortal = (props) => {
403
- const { __scopeTooltip, forceMount, children, container } = props;
404
- const context = useTooltipContext(PORTAL_NAME, __scopeTooltip);
405
- return /* @__PURE__ */ React5.createElement(PortalProvider, {
406
- scope: __scopeTooltip,
407
- forceMount
408
- }, /* @__PURE__ */ React5.createElement(Presence, {
409
- present: forceMount || context.open
410
- }, /* @__PURE__ */ React5.createElement(PortalPrimitive, {
411
- asChild: true,
412
- container
413
- }, children)));
414
- };
415
- TooltipPortal.displayName = PORTAL_NAME;
416
- var CONTENT_NAME = "TooltipContent";
417
- var TooltipContent = /* @__PURE__ */ forwardRef((props, forwardedRef) => {
418
- const portalContext = usePortalContext(CONTENT_NAME, props.__scopeTooltip);
419
- const { forceMount = portalContext.forceMount, side = "top", ...contentProps } = props;
420
- const context = useTooltipContext(CONTENT_NAME, props.__scopeTooltip);
421
- return /* @__PURE__ */ React5.createElement(Presence, {
422
- present: forceMount || context.open
423
- }, context.disableHoverableContent ? /* @__PURE__ */ React5.createElement(TooltipContentImpl, {
424
- side,
425
- ...contentProps,
426
- ref: forwardedRef
427
- }) : /* @__PURE__ */ React5.createElement(TooltipContentHoverable, {
428
- side,
429
- ...contentProps,
430
- ref: forwardedRef
431
- }));
432
- });
433
- var TooltipContentHoverable = /* @__PURE__ */ forwardRef((props, forwardedRef) => {
434
- const context = useTooltipContext(CONTENT_NAME, props.__scopeTooltip);
435
- const ref = useRef(null);
436
- const composedRefs = useComposedRefs(forwardedRef, ref);
437
- const [pointerGraceArea, setPointerGraceArea] = useState3(null);
438
- const { trigger, onClose } = context;
439
- const content = ref.current;
440
- const { onPointerInTransitChange } = context;
441
- const handleRemoveGraceArea = useCallback2(() => {
442
- setPointerGraceArea(null);
443
- onPointerInTransitChange(false);
444
- }, [
445
- onPointerInTransitChange
446
- ]);
447
- const handleCreateGraceArea = useCallback2((event, hoverTarget) => {
448
- const currentTarget = event.currentTarget;
449
- const exitPoint = {
450
- x: event.clientX,
451
- y: event.clientY
452
- };
453
- const exitSide = getExitSideFromRect(exitPoint, currentTarget.getBoundingClientRect());
454
- const paddedExitPoints = getPaddedExitPoints(exitPoint, exitSide);
455
- const hoverTargetPoints = getPointsFromRect(hoverTarget.getBoundingClientRect());
456
- const graceArea = getHull([
457
- ...paddedExitPoints,
458
- ...hoverTargetPoints
459
- ]);
460
- setPointerGraceArea(graceArea);
461
- onPointerInTransitChange(true);
462
- }, [
463
- onPointerInTransitChange
464
- ]);
465
- useEffect3(() => {
466
- return () => handleRemoveGraceArea();
467
- }, [
468
- handleRemoveGraceArea
469
- ]);
470
- useEffect3(() => {
471
- if (trigger && content) {
472
- const handleTriggerLeave = (event) => handleCreateGraceArea(event, content);
473
- const handleContentLeave = (event) => handleCreateGraceArea(event, trigger);
474
- trigger.addEventListener("pointerleave", handleTriggerLeave);
475
- content.addEventListener("pointerleave", handleContentLeave);
476
- return () => {
477
- trigger.removeEventListener("pointerleave", handleTriggerLeave);
478
- content.removeEventListener("pointerleave", handleContentLeave);
479
- };
480
- }
481
- }, [
482
- trigger,
483
- content,
484
- handleCreateGraceArea,
485
- handleRemoveGraceArea
486
- ]);
487
- useEffect3(() => {
488
- if (pointerGraceArea) {
489
- const handleTrackPointerGrace = (event) => {
490
- const target = event.target;
491
- const pointerPosition = {
492
- x: event.clientX,
493
- y: event.clientY
494
- };
495
- const hasEnteredTarget = trigger?.contains(target) || content?.contains(target);
496
- const isPointerOutsideGraceArea = !isPointInPolygon(pointerPosition, pointerGraceArea);
497
- if (hasEnteredTarget) {
498
- handleRemoveGraceArea();
499
- } else if (isPointerOutsideGraceArea) {
500
- handleRemoveGraceArea();
501
- onClose();
502
- }
503
- };
504
- document.addEventListener("pointermove", handleTrackPointerGrace);
505
- return () => document.removeEventListener("pointermove", handleTrackPointerGrace);
506
- }
507
- }, [
508
- trigger,
509
- content,
510
- pointerGraceArea,
511
- onClose,
512
- handleRemoveGraceArea
513
- ]);
514
- return /* @__PURE__ */ React5.createElement(TooltipContentImpl, {
515
- ...props,
516
- ref: composedRefs
517
- });
518
- });
519
- var [VisuallyHiddenContentContextProvider, useVisuallyHiddenContentContext] = createTooltipContext(TOOLTIP_NAME, {
520
- isInside: false
521
- });
522
- var TooltipContentImpl = /* @__PURE__ */ forwardRef((props, forwardedRef) => {
523
- const { __scopeTooltip, children, "aria-label": ariaLabel, onEscapeKeyDown, onPointerDownOutside, ...contentProps } = props;
524
- const context = useTooltipContext(CONTENT_NAME, __scopeTooltip);
525
- const popperScope = usePopperScope(__scopeTooltip);
526
- const { onClose } = context;
527
- useEffect3(() => {
528
- document.addEventListener(TOOLTIP_OPEN, onClose);
529
- return () => document.removeEventListener(TOOLTIP_OPEN, onClose);
530
- }, [
531
- onClose
532
- ]);
533
- useEffect3(() => {
534
- if (context.trigger) {
535
- const handleScroll = (event) => {
536
- const target = event.target;
537
- if (target?.contains(context.trigger)) {
538
- onClose();
539
- }
540
- };
541
- window.addEventListener("scroll", handleScroll, {
542
- capture: true
543
- });
544
- return () => window.removeEventListener("scroll", handleScroll, {
545
- capture: true
546
- });
547
- }
548
- }, [
549
- context.trigger,
550
- onClose
551
- ]);
552
- return /* @__PURE__ */ React5.createElement(DismissableLayer, {
553
- asChild: true,
554
- disableOutsidePointerEvents: false,
555
- onEscapeKeyDown,
556
- onPointerDownOutside,
557
- onFocusOutside: (event) => event.preventDefault(),
558
- onDismiss: onClose
559
- }, /* @__PURE__ */ React5.createElement(PopperPrimitive.Content, {
560
- "data-state": context.stateAttribute,
561
- ...popperScope,
562
- ...contentProps,
563
- ref: forwardedRef,
564
- style: {
565
- ...contentProps.style,
566
- // re-namespace exposed content custom properties
567
- ...{
568
- "--radix-tooltip-content-transform-origin": "var(--radix-popper-transform-origin)",
569
- "--radix-tooltip-content-available-width": "var(--radix-popper-available-width)",
570
- "--radix-tooltip-content-available-height": "var(--radix-popper-available-height)",
571
- "--radix-tooltip-trigger-width": "var(--radix-popper-anchor-width)",
572
- "--radix-tooltip-trigger-height": "var(--radix-popper-anchor-height)"
573
- }
574
- }
575
- }, /* @__PURE__ */ React5.createElement(Slottable, null, children), /* @__PURE__ */ React5.createElement(VisuallyHiddenContentContextProvider, {
576
- scope: __scopeTooltip,
577
- isInside: true
578
- }, /* @__PURE__ */ React5.createElement(VisuallyHiddenPrimitive.Root, {
579
- id: context.contentId,
580
- role: "tooltip"
581
- }, ariaLabel || children))));
582
- });
583
- TooltipContent.displayName = CONTENT_NAME;
584
- var ARROW_NAME = "TooltipArrow";
585
- var TooltipArrow = /* @__PURE__ */ forwardRef((props, forwardedRef) => {
586
- const { __scopeTooltip, ...arrowProps } = props;
587
- const popperScope = usePopperScope(__scopeTooltip);
588
- const visuallyHiddenContentContext = useVisuallyHiddenContentContext(ARROW_NAME, __scopeTooltip);
589
- return visuallyHiddenContentContext.isInside ? null : /* @__PURE__ */ React5.createElement(PopperPrimitive.Arrow, {
590
- ...popperScope,
591
- ...arrowProps,
592
- ref: forwardedRef
593
- });
594
- });
595
- TooltipArrow.displayName = ARROW_NAME;
596
- var getExitSideFromRect = (point, rect) => {
597
- const top = Math.abs(rect.top - point.y);
598
- const bottom = Math.abs(rect.bottom - point.y);
599
- const right = Math.abs(rect.right - point.x);
600
- const left = Math.abs(rect.left - point.x);
601
- switch (Math.min(top, bottom, right, left)) {
602
- case left:
603
- return "left";
604
- case right:
605
- return "right";
606
- case top:
607
- return "top";
608
- case bottom:
609
- return "bottom";
610
- default:
611
- throw new Error("unreachable");
612
- }
613
- };
614
- var getPaddedExitPoints = (exitPoint, exitSide, padding = 5) => {
615
- const paddedExitPoints = [];
616
- switch (exitSide) {
617
- case "top":
618
- paddedExitPoints.push({
619
- x: exitPoint.x - padding,
620
- y: exitPoint.y + padding
621
- }, {
622
- x: exitPoint.x + padding,
623
- y: exitPoint.y + padding
624
- });
625
- break;
626
- case "bottom":
627
- paddedExitPoints.push({
628
- x: exitPoint.x - padding,
629
- y: exitPoint.y - padding
630
- }, {
631
- x: exitPoint.x + padding,
632
- y: exitPoint.y - padding
633
- });
634
- break;
635
- case "left":
636
- paddedExitPoints.push({
637
- x: exitPoint.x + padding,
638
- y: exitPoint.y - padding
639
- }, {
640
- x: exitPoint.x + padding,
641
- y: exitPoint.y + padding
642
- });
643
- break;
644
- case "right":
645
- paddedExitPoints.push({
646
- x: exitPoint.x - padding,
647
- y: exitPoint.y - padding
648
- }, {
649
- x: exitPoint.x - padding,
650
- y: exitPoint.y + padding
651
- });
652
- break;
653
- }
654
- return paddedExitPoints;
655
- };
656
- var getPointsFromRect = (rect) => {
657
- const { top, right, bottom, left } = rect;
658
- return [
659
- {
660
- x: left,
661
- y: top
662
- },
663
- {
664
- x: right,
665
- y: top
666
- },
667
- {
668
- x: right,
669
- y: bottom
670
- },
671
- {
672
- x: left,
673
- y: bottom
674
- }
675
- ];
676
- };
677
- var isPointInPolygon = (point, polygon) => {
678
- const { x, y } = point;
679
- let inside = false;
680
- for (let i = 0, j = polygon.length - 1; i < polygon.length; j = i++) {
681
- const xi = polygon[i].x;
682
- const yi = polygon[i].y;
683
- const xj = polygon[j].x;
684
- const yj = polygon[j].y;
685
- const intersect = yi > y !== yj > y && x < (xj - xi) * (y - yi) / (yj - yi) + xi;
686
- if (intersect) {
687
- inside = !inside;
688
- }
689
- }
690
- return inside;
691
- };
692
- var getHull = (points) => {
693
- const newPoints = points.slice();
694
- newPoints.sort((a, b) => {
695
- if (a.x < b.x) {
696
- return -1;
697
- } else if (a.x > b.x) {
698
- return 1;
699
- } else if (a.y < b.y) {
700
- return -1;
701
- } else if (a.y > b.y) {
702
- return 1;
703
- } else {
704
- return 0;
705
- }
706
- });
707
- return getHullPresorted(newPoints);
708
- };
709
- var getHullPresorted = (points) => {
710
- if (points.length <= 1) {
711
- return points.slice();
712
- }
713
- const upperHull = [];
714
- for (let i = 0; i < points.length; i++) {
715
- const p = points[i];
716
- while (upperHull.length >= 2) {
717
- const q = upperHull[upperHull.length - 1];
718
- const r = upperHull[upperHull.length - 2];
719
- if ((q.x - r.x) * (p.y - r.y) >= (q.y - r.y) * (p.x - r.x)) {
720
- upperHull.pop();
721
- } else {
722
- break;
723
- }
724
- }
725
- upperHull.push(p);
726
- }
727
- upperHull.pop();
728
- const lowerHull = [];
729
- for (let i = points.length - 1; i >= 0; i--) {
730
- const p = points[i];
731
- while (lowerHull.length >= 2) {
732
- const q = lowerHull[lowerHull.length - 1];
733
- const r = lowerHull[lowerHull.length - 2];
734
- if ((q.x - r.x) * (p.y - r.y) >= (q.y - r.y) * (p.x - r.x)) {
735
- lowerHull.pop();
736
- } else {
737
- break;
738
- }
739
- }
740
- lowerHull.push(p);
741
- }
742
- lowerHull.pop();
743
- if (upperHull.length === 1 && lowerHull.length === 1 && upperHull[0].x === lowerHull[0].x && upperHull[0].y === lowerHull[0].y) {
744
- return upperHull;
745
- } else {
746
- return upperHull.concat(lowerHull);
747
- }
748
- };
749
- var Tooltip = {
750
- Provider: TooltipProvider,
751
- Trigger: TooltipTrigger
752
- };
753
-
754
- // src/components/ErrorFallback/ErrorStack.tsx
755
- import ErrorStackParser from "error-stack-parser";
756
- import React6 from "react";
757
- import { mx } from "@dxos/ui-theme";
758
- var parseCaptureOwnerStack = (stack) => {
759
- if (stack == null || stack.length === 0) {
760
- return null;
761
- }
762
- const err = new Error();
763
- err.stack = stack;
764
- try {
765
- return ErrorStackParser.parse(err);
766
- } catch {
767
- err.stack = `Error
768
- ${stack}`;
769
- try {
770
- return ErrorStackParser.parse(err);
771
- } catch {
772
- return null;
773
- }
774
- }
775
- };
776
- var ErrorStack = ({ error, frames: framesProp }) => {
777
- const frames = framesProp ?? (error ? ErrorStackParser.parse(error) : []);
778
- if (frames.length === 0) {
779
- return null;
780
- }
781
- return /* @__PURE__ */ React6.createElement("div", {
782
- className: "font-mono text-sm"
783
- }, frames.map((frame, i) => {
784
- const isLast = i === frames.length - 1;
785
- const local = frame.fileName ? parseLocalFrame(frame.fileName, frame.lineNumber, frame.columnNumber) : void 0;
786
- const name = frame.functionName ?? "<anonymous>";
787
- return /* @__PURE__ */ React6.createElement("div", {
788
- key: i,
789
- className: mx("grid grid-cols-[16px_1fr_auto_auto] items-stretch gap-x-2", local && "cursor-pointer hover:bg-hover-surface")
790
- }, /* @__PURE__ */ React6.createElement("div", {
791
- className: "relative"
792
- }, /* @__PURE__ */ React6.createElement("div", {
793
- className: mx("absolute left-1/2 -translate-x-1/2 w-px bg-neutral-500", isLast ? "top-0 h-1/2" : "inset-y-0")
794
- }), /* @__PURE__ */ React6.createElement("div", {
795
- className: "absolute top-1/2 -translate-y-1/2 left-1/2 right-0 h-px bg-neutral-500"
796
- })), local ? /* @__PURE__ */ React6.createElement("a", {
797
- href: local.href,
798
- className: "truncate self-center"
799
- }, name) : /* @__PURE__ */ React6.createElement("span", {
800
- className: "text-subdued truncate self-center"
801
- }, name), /* @__PURE__ */ React6.createElement("span", {
802
- className: "text-xs text-subdued truncate self-center"
803
- }, local?.fileName ?? ""), /* @__PURE__ */ React6.createElement("span", {
804
- className: "text-xs text-subdued text-right self-center"
805
- }, local ? `${frame.lineNumber}:${frame.columnNumber}` : ""));
806
- }));
807
- };
808
- var parseLocalFrame = (fileUrl, line, col) => {
809
- try {
810
- const { pathname } = new URL(fileUrl);
811
- if (!pathname.startsWith("/@fs/")) {
812
- return void 0;
813
- }
814
- const localPath = pathname.slice(4);
815
- return {
816
- href: `vscode://file/${localPath}:${line ?? 1}:${col ?? 1}`,
817
- fileName: pathname.split("/").pop() ?? localPath
818
- };
819
- } catch {
820
- return void 0;
821
- }
822
- };
823
-
824
- // src/hooks/useElevationContext.ts
825
- var useElevationContext = (propsElevation) => {
826
- const { elevation } = useContext3(ElevationContext);
827
- return propsElevation ?? elevation;
828
- };
829
-
830
- export {
831
- DensityContext,
832
- DensityProvider,
833
- ElevationContext,
834
- ElevationProvider,
835
- useElevationContext,
836
- useThemeContext,
837
- initialSafeArea,
838
- useSafeArea,
839
- TranslationsContext,
840
- useTranslation,
841
- hasIosKeyboard,
842
- ThemeContext,
843
- ThemeProvider,
844
- createTooltipScope,
845
- useTooltipContext,
846
- Tooltip,
847
- parseCaptureOwnerStack,
848
- ErrorStack
849
- };
850
- //# sourceMappingURL=chunk-QUD5P3RU.mjs.map