@dxos/react-ui 0.8.4-main.ef1bc66f44 → 0.8.4-main.effb148878

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (563) hide show
  1. package/LICENSE +102 -5
  2. package/README.md +1 -1
  3. package/dist/lib/browser/chunk-FFPB5LWE.mjs +1600 -0
  4. package/dist/lib/browser/chunk-FFPB5LWE.mjs.map +7 -0
  5. package/dist/lib/browser/chunk-WU2YVQX4.mjs +32 -0
  6. package/dist/lib/browser/chunk-WU2YVQX4.mjs.map +7 -0
  7. package/dist/lib/browser/index.mjs +4422 -2412
  8. package/dist/lib/browser/index.mjs.map +4 -4
  9. package/dist/lib/browser/meta.json +1 -1
  10. package/dist/lib/browser/testing/index.mjs +77 -45
  11. package/dist/lib/browser/testing/index.mjs.map +4 -4
  12. package/dist/lib/browser/translations.mjs +9 -0
  13. package/dist/lib/browser/translations.mjs.map +7 -0
  14. package/dist/lib/node-esm/chunk-TIKGPZSG.mjs +34 -0
  15. package/dist/lib/node-esm/chunk-TIKGPZSG.mjs.map +7 -0
  16. package/dist/lib/node-esm/chunk-WOYP6QDI.mjs +1602 -0
  17. package/dist/lib/node-esm/chunk-WOYP6QDI.mjs.map +7 -0
  18. package/dist/lib/node-esm/index.mjs +4422 -2412
  19. package/dist/lib/node-esm/index.mjs.map +4 -4
  20. package/dist/lib/node-esm/meta.json +1 -1
  21. package/dist/lib/node-esm/testing/index.mjs +77 -45
  22. package/dist/lib/node-esm/testing/index.mjs.map +4 -4
  23. package/dist/lib/node-esm/translations.mjs +10 -0
  24. package/dist/lib/node-esm/translations.mjs.map +7 -0
  25. package/dist/types/src/components/Avatars/Avatar.d.ts +1 -1
  26. package/dist/types/src/components/Avatars/Avatar.d.ts.map +1 -1
  27. package/dist/types/src/components/Avatars/Avatar.stories.d.ts.map +1 -1
  28. package/dist/types/src/components/Avatars/Avatar.theme.d.ts +11 -0
  29. package/dist/types/src/components/Avatars/Avatar.theme.d.ts.map +1 -0
  30. package/dist/types/src/components/Avatars/AvatarGroup.stories.d.ts.map +1 -1
  31. package/dist/types/src/components/Breadcrumb/Breadcrumb.d.ts +5 -1
  32. package/dist/types/src/components/Breadcrumb/Breadcrumb.d.ts.map +1 -1
  33. package/dist/types/src/components/Breadcrumb/Breadcrumb.stories.d.ts.map +1 -1
  34. package/dist/types/src/components/Breadcrumb/Breadcrumb.theme.d.ts +4 -0
  35. package/dist/types/src/components/Breadcrumb/Breadcrumb.theme.d.ts.map +1 -0
  36. package/dist/types/src/components/Button/Button.d.ts +2 -2
  37. package/dist/types/src/components/Button/Button.d.ts.map +1 -1
  38. package/dist/types/src/components/Button/Button.stories.d.ts +1 -1
  39. package/dist/types/src/components/Button/Button.stories.d.ts.map +1 -1
  40. package/dist/types/src/components/Button/Button.theme.d.ts +11 -0
  41. package/dist/types/src/components/Button/Button.theme.d.ts.map +1 -0
  42. package/dist/types/src/components/Button/IconButton.d.ts +1 -0
  43. package/dist/types/src/components/Button/IconButton.d.ts.map +1 -1
  44. package/dist/types/src/components/Button/IconButton.stories.d.ts +4 -0
  45. package/dist/types/src/components/Button/IconButton.stories.d.ts.map +1 -1
  46. package/dist/types/src/components/Button/IconButton.theme.d.ts +8 -0
  47. package/dist/types/src/components/Button/IconButton.theme.d.ts.map +1 -0
  48. package/dist/types/src/components/Button/Toggle.d.ts +2 -2
  49. package/dist/types/src/components/Button/Toggle.d.ts.map +1 -1
  50. package/dist/types/src/components/Button/Toggle.stories.d.ts.map +1 -1
  51. package/dist/types/src/components/Button/ToggleGroup.d.ts +6 -6
  52. package/dist/types/src/components/Button/ToggleGroup.d.ts.map +1 -1
  53. package/dist/types/src/components/Button/ToggleGroup.stories.d.ts +2 -2
  54. package/dist/types/src/components/Button/ToggleGroup.stories.d.ts.map +1 -1
  55. package/dist/types/src/components/Calendar/Calendar.d.ts +33 -0
  56. package/dist/types/src/components/Calendar/Calendar.d.ts.map +1 -0
  57. package/dist/types/src/components/Calendar/Calendar.stories.d.ts +9 -0
  58. package/dist/types/src/components/Calendar/Calendar.stories.d.ts.map +1 -0
  59. package/dist/types/src/components/Calendar/Calendar.theme.d.ts +4 -0
  60. package/dist/types/src/components/Calendar/Calendar.theme.d.ts.map +1 -0
  61. package/dist/types/src/components/Calendar/index.d.ts +2 -0
  62. package/dist/types/src/components/Calendar/index.d.ts.map +1 -0
  63. package/dist/types/src/components/Card/Card.d.ts +135 -0
  64. package/dist/types/src/components/Card/Card.d.ts.map +1 -0
  65. package/dist/types/src/components/Card/Card.stories.d.ts +22 -0
  66. package/dist/types/src/components/Card/Card.stories.d.ts.map +1 -0
  67. package/dist/types/src/components/Card/Card.theme.d.ts +12 -0
  68. package/dist/types/src/components/Card/Card.theme.d.ts.map +1 -0
  69. package/dist/types/src/components/Card/index.d.ts +2 -0
  70. package/dist/types/src/components/Card/index.d.ts.map +1 -0
  71. package/dist/types/src/components/Carousel/Carousel.d.ts +102 -0
  72. package/dist/types/src/components/Carousel/Carousel.d.ts.map +1 -0
  73. package/dist/types/src/components/Carousel/index.d.ts +2 -0
  74. package/dist/types/src/components/Carousel/index.d.ts.map +1 -0
  75. package/dist/types/src/components/Clipboard/ClipboardProvider.d.ts.map +1 -1
  76. package/dist/types/src/components/Clipboard/CopyButton.d.ts.map +1 -1
  77. package/dist/types/src/components/Clipboard/index.d.ts +10 -1
  78. package/dist/types/src/components/Clipboard/index.d.ts.map +1 -1
  79. package/dist/types/src/components/Column/Column.d.ts +33 -0
  80. package/dist/types/src/components/Column/Column.d.ts.map +1 -0
  81. package/dist/types/src/components/Column/Column.stories.d.ts +25 -0
  82. package/dist/types/src/components/Column/Column.stories.d.ts.map +1 -0
  83. package/dist/types/src/components/Column/Column.theme.d.ts +9 -0
  84. package/dist/types/src/components/Column/Column.theme.d.ts.map +1 -0
  85. package/dist/types/src/components/Column/index.d.ts +3 -0
  86. package/dist/types/src/components/Column/index.d.ts.map +1 -0
  87. package/dist/types/src/components/Column/withColumn.d.ts +21 -0
  88. package/dist/types/src/components/Column/withColumn.d.ts.map +1 -0
  89. package/dist/types/src/components/DatePicker/DatePicker.d.ts +72 -0
  90. package/dist/types/src/components/DatePicker/DatePicker.d.ts.map +1 -0
  91. package/dist/types/src/components/DatePicker/DatePicker.stories.d.ts +10 -0
  92. package/dist/types/src/components/DatePicker/DatePicker.stories.d.ts.map +1 -0
  93. package/dist/types/src/components/DatePicker/DatePicker.theme.d.ts +6 -0
  94. package/dist/types/src/components/DatePicker/DatePicker.theme.d.ts.map +1 -0
  95. package/dist/types/src/components/DatePicker/index.d.ts +2 -0
  96. package/dist/types/src/components/DatePicker/index.d.ts.map +1 -0
  97. package/dist/types/src/components/Dialog/AlertDialog.d.ts +43 -23
  98. package/dist/types/src/components/Dialog/AlertDialog.d.ts.map +1 -1
  99. package/dist/types/src/components/Dialog/AlertDialog.stories.d.ts.map +1 -1
  100. package/dist/types/src/components/Dialog/Dialog.d.ts +52 -32
  101. package/dist/types/src/components/Dialog/Dialog.d.ts.map +1 -1
  102. package/dist/types/src/components/Dialog/Dialog.stories.d.ts +6 -8
  103. package/dist/types/src/components/Dialog/Dialog.stories.d.ts.map +1 -1
  104. package/dist/types/src/components/Dialog/Dialog.theme.d.ts +10 -0
  105. package/dist/types/src/components/Dialog/Dialog.theme.d.ts.map +1 -0
  106. package/dist/types/src/components/ErrorFallback/ErrorFallback.d.ts +11 -0
  107. package/dist/types/src/components/ErrorFallback/ErrorFallback.d.ts.map +1 -0
  108. package/dist/types/src/components/ErrorFallback/ErrorFallback.stories.d.ts +7 -0
  109. package/dist/types/src/components/ErrorFallback/ErrorFallback.stories.d.ts.map +1 -0
  110. package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts +19 -0
  111. package/dist/types/src/components/ErrorFallback/ErrorStack.d.ts.map +1 -0
  112. package/dist/types/src/components/ErrorFallback/ThrowError.d.ts +9 -0
  113. package/dist/types/src/components/ErrorFallback/ThrowError.d.ts.map +1 -0
  114. package/dist/types/src/components/ErrorFallback/index.d.ts +5 -0
  115. package/dist/types/src/components/ErrorFallback/index.d.ts.map +1 -0
  116. package/dist/types/src/components/Focus/Focus.d.ts +36 -0
  117. package/dist/types/src/components/Focus/Focus.d.ts.map +1 -0
  118. package/dist/types/src/components/Focus/Focus.stories.d.ts +9 -0
  119. package/dist/types/src/components/Focus/Focus.stories.d.ts.map +1 -0
  120. package/dist/types/src/components/Focus/Focus.theme.d.ts +6 -0
  121. package/dist/types/src/components/Focus/Focus.theme.d.ts.map +1 -0
  122. package/dist/types/src/components/Focus/index.d.ts +2 -0
  123. package/dist/types/src/components/Focus/index.d.ts.map +1 -0
  124. package/dist/types/src/components/Icon/Icon.d.ts +4 -0
  125. package/dist/types/src/components/Icon/Icon.d.ts.map +1 -1
  126. package/dist/types/src/components/Icon/Icon.stories.d.ts +11 -3
  127. package/dist/types/src/components/Icon/Icon.stories.d.ts.map +1 -1
  128. package/dist/types/src/components/Icon/Icon.theme.d.ts +6 -0
  129. package/dist/types/src/components/Icon/Icon.theme.d.ts.map +1 -0
  130. package/dist/types/src/components/Image/Image.d.ts +15 -0
  131. package/dist/types/src/components/Image/Image.d.ts.map +1 -0
  132. package/dist/types/src/components/Image/Image.stories.d.ts +34 -0
  133. package/dist/types/src/components/Image/Image.stories.d.ts.map +1 -0
  134. package/dist/types/src/components/Image/index.d.ts +2 -0
  135. package/dist/types/src/components/Image/index.d.ts.map +1 -0
  136. package/dist/types/src/components/Input/Input.d.ts +90 -19
  137. package/dist/types/src/components/Input/Input.d.ts.map +1 -1
  138. package/dist/types/src/components/Input/Input.stories.d.ts +20 -9
  139. package/dist/types/src/components/Input/Input.stories.d.ts.map +1 -1
  140. package/dist/types/src/components/Input/Input.theme.d.ts +115 -0
  141. package/dist/types/src/components/Input/Input.theme.d.ts.map +1 -0
  142. package/dist/types/src/components/Input/SegmentedInput.d.ts +79 -0
  143. package/dist/types/src/components/Input/SegmentedInput.d.ts.map +1 -0
  144. package/dist/types/src/components/Input/constants.d.ts +2 -0
  145. package/dist/types/src/components/Input/constants.d.ts.map +1 -0
  146. package/dist/types/src/components/Input/index.d.ts +2 -0
  147. package/dist/types/src/components/Input/index.d.ts.map +1 -1
  148. package/dist/types/src/components/Link/Link.d.ts.map +1 -1
  149. package/dist/types/src/components/Link/Link.stories.d.ts.map +1 -1
  150. package/dist/types/src/components/Link/Link.theme.d.ts +6 -0
  151. package/dist/types/src/components/Link/Link.theme.d.ts.map +1 -0
  152. package/dist/types/src/components/List/List.d.ts +5 -3
  153. package/dist/types/src/components/List/List.d.ts.map +1 -1
  154. package/dist/types/src/components/List/List.stories.d.ts +3 -1
  155. package/dist/types/src/components/List/List.stories.d.ts.map +1 -1
  156. package/dist/types/src/components/List/List.theme.d.ts +7 -0
  157. package/dist/types/src/components/List/List.theme.d.ts.map +1 -0
  158. package/dist/types/src/components/List/ListDropIndicator.d.ts.map +1 -1
  159. package/dist/types/src/components/List/Tree.d.ts +2 -2
  160. package/dist/types/src/components/List/Tree.d.ts.map +1 -1
  161. package/dist/types/src/components/List/Tree.stories.d.ts.map +1 -1
  162. package/dist/types/src/components/List/TreeDropIndicator.d.ts.map +1 -1
  163. package/dist/types/src/components/List/Treegrid.d.ts +5 -9
  164. package/dist/types/src/components/List/Treegrid.d.ts.map +1 -1
  165. package/dist/types/src/components/List/Treegrid.stories.d.ts.map +1 -1
  166. package/dist/types/src/components/List/Treegrid.theme.d.ts +7 -0
  167. package/dist/types/src/components/List/Treegrid.theme.d.ts.map +1 -0
  168. package/dist/types/src/components/Main/Main.d.ts +13 -9
  169. package/dist/types/src/components/Main/Main.d.ts.map +1 -1
  170. package/dist/types/src/components/Main/Main.stories.d.ts +0 -3
  171. package/dist/types/src/components/Main/Main.stories.d.ts.map +1 -1
  172. package/dist/types/src/components/Main/Main.theme.d.ts +20 -0
  173. package/dist/types/src/components/Main/Main.theme.d.ts.map +1 -0
  174. package/dist/types/src/components/Main/constants.d.ts +3 -0
  175. package/dist/types/src/components/Main/constants.d.ts.map +1 -0
  176. package/dist/types/src/components/Main/index.d.ts +1 -0
  177. package/dist/types/src/components/Main/index.d.ts.map +1 -1
  178. package/dist/types/src/components/Main/useSwipeToDismiss.d.ts.map +1 -1
  179. package/dist/types/src/components/MediaPlayer/MediaPlayer.d.ts +43 -0
  180. package/dist/types/src/components/MediaPlayer/MediaPlayer.d.ts.map +1 -0
  181. package/dist/types/src/components/MediaPlayer/MediaPlayer.stories.d.ts +16 -0
  182. package/dist/types/src/components/MediaPlayer/MediaPlayer.stories.d.ts.map +1 -0
  183. package/dist/types/src/components/MediaPlayer/index.d.ts +2 -0
  184. package/dist/types/src/components/MediaPlayer/index.d.ts.map +1 -0
  185. package/dist/types/src/components/Menu/ContextMenu.d.ts.map +1 -1
  186. package/dist/types/src/components/Menu/ContextMenu.stories.d.ts.map +1 -1
  187. package/dist/types/src/components/Menu/DropdownMenu.d.ts +58 -49
  188. package/dist/types/src/components/Menu/DropdownMenu.d.ts.map +1 -1
  189. package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts +14 -1
  190. package/dist/types/src/components/Menu/DropdownMenu.stories.d.ts.map +1 -1
  191. package/dist/types/src/components/Menu/Menu.theme.d.ts +7 -0
  192. package/dist/types/src/components/Menu/Menu.theme.d.ts.map +1 -0
  193. package/dist/types/src/components/Message/Message.d.ts +1 -1
  194. package/dist/types/src/components/Message/Message.d.ts.map +1 -1
  195. package/dist/types/src/components/Message/Message.stories.d.ts +4 -5
  196. package/dist/types/src/components/Message/Message.stories.d.ts.map +1 -1
  197. package/dist/types/src/components/Message/Message.theme.d.ts +7 -0
  198. package/dist/types/src/components/Message/Message.theme.d.ts.map +1 -0
  199. package/dist/types/src/components/Panel/Panel.d.ts +35 -0
  200. package/dist/types/src/components/Panel/Panel.d.ts.map +1 -0
  201. package/dist/types/src/components/Panel/Panel.stories.d.ts +6 -0
  202. package/dist/types/src/components/Panel/Panel.stories.d.ts.map +1 -0
  203. package/dist/types/src/components/Panel/Panel.theme.d.ts +13 -0
  204. package/dist/types/src/components/Panel/Panel.theme.d.ts.map +1 -0
  205. package/dist/types/src/components/Panel/index.d.ts +2 -0
  206. package/dist/types/src/components/Panel/index.d.ts.map +1 -0
  207. package/dist/types/src/components/Popover/Popover.d.ts +39 -22
  208. package/dist/types/src/components/Popover/Popover.d.ts.map +1 -1
  209. package/dist/types/src/components/Popover/Popover.stories.d.ts.map +1 -1
  210. package/dist/types/src/components/Popover/Popover.theme.d.ts +8 -0
  211. package/dist/types/src/components/Popover/Popover.theme.d.ts.map +1 -0
  212. package/dist/types/src/components/ScrollArea/ScrollArea.d.ts +12 -11
  213. package/dist/types/src/components/ScrollArea/ScrollArea.d.ts.map +1 -1
  214. package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts +21 -10
  215. package/dist/types/src/components/ScrollArea/ScrollArea.stories.d.ts.map +1 -1
  216. package/dist/types/src/components/ScrollArea/ScrollArea.theme.d.ts +17 -0
  217. package/dist/types/src/components/ScrollArea/ScrollArea.theme.d.ts.map +1 -0
  218. package/dist/types/src/components/ScrollArea/index.d.ts +1 -0
  219. package/dist/types/src/components/ScrollArea/index.d.ts.map +1 -1
  220. package/dist/types/src/components/ScrollArea/scrollbar.d.ts +18 -0
  221. package/dist/types/src/components/ScrollArea/scrollbar.d.ts.map +1 -0
  222. package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts +41 -18
  223. package/dist/types/src/components/ScrollContainer/ScrollContainer.d.ts.map +1 -1
  224. package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts +9 -5
  225. package/dist/types/src/components/ScrollContainer/ScrollContainer.stories.d.ts.map +1 -1
  226. package/dist/types/src/components/Select/Select.d.ts.map +1 -1
  227. package/dist/types/src/components/Select/Select.stories.d.ts +2 -2
  228. package/dist/types/src/components/Select/Select.stories.d.ts.map +1 -1
  229. package/dist/types/src/components/Select/Select.theme.d.ts +6 -0
  230. package/dist/types/src/components/Select/Select.theme.d.ts.map +1 -0
  231. package/dist/types/src/components/Separator/Separator.d.ts +3 -3
  232. package/dist/types/src/components/Separator/Separator.d.ts.map +1 -1
  233. package/dist/types/src/components/Separator/Separator.theme.d.ts +7 -0
  234. package/dist/types/src/components/Separator/Separator.theme.d.ts.map +1 -0
  235. package/dist/types/src/components/Skeleton/Skeleton.stories.d.ts.map +1 -1
  236. package/dist/types/src/components/Skeleton/Skeleton.theme.d.ts +6 -0
  237. package/dist/types/src/components/Skeleton/Skeleton.theme.d.ts.map +1 -0
  238. package/dist/types/src/components/Splitter/Splitter.d.ts +22 -16
  239. package/dist/types/src/components/Splitter/Splitter.d.ts.map +1 -1
  240. package/dist/types/src/components/Splitter/Splitter.stories.d.ts.map +1 -1
  241. package/dist/types/src/components/Splitter/Splitter.theme.d.ts +4 -0
  242. package/dist/types/src/components/Splitter/Splitter.theme.d.ts.map +1 -0
  243. package/dist/types/src/components/Status/Status.d.ts +3 -4
  244. package/dist/types/src/components/Status/Status.d.ts.map +1 -1
  245. package/dist/types/src/components/Status/Status.stories.d.ts +4 -2
  246. package/dist/types/src/components/Status/Status.stories.d.ts.map +1 -1
  247. package/dist/types/src/components/Status/Status.theme.d.ts +7 -0
  248. package/dist/types/src/components/Status/Status.theme.d.ts.map +1 -0
  249. package/dist/types/src/components/Tag/Tag.d.ts.map +1 -1
  250. package/dist/types/src/components/Tag/Tag.stories.d.ts +0 -5
  251. package/dist/types/src/components/Tag/Tag.stories.d.ts.map +1 -1
  252. package/dist/types/src/components/Tag/Tag.theme.d.ts +6 -0
  253. package/dist/types/src/components/Tag/Tag.theme.d.ts.map +1 -0
  254. package/dist/types/src/components/Toast/Toast.d.ts +15 -15
  255. package/dist/types/src/components/Toast/Toast.d.ts.map +1 -1
  256. package/dist/types/src/components/Toast/Toast.stories.d.ts.map +1 -1
  257. package/dist/types/src/components/Toast/Toast.theme.d.ts +6 -0
  258. package/dist/types/src/components/Toast/Toast.theme.d.ts.map +1 -0
  259. package/dist/types/src/components/Toolbar/Toolbar.d.ts +46 -17
  260. package/dist/types/src/components/Toolbar/Toolbar.d.ts.map +1 -1
  261. package/dist/types/src/components/Toolbar/Toolbar.stories.d.ts.map +1 -1
  262. package/dist/types/src/components/Toolbar/Toolbar.theme.d.ts +8 -0
  263. package/dist/types/src/components/Toolbar/Toolbar.theme.d.ts.map +1 -0
  264. package/dist/types/src/components/Tooltip/Tooltip.d.ts +16 -16
  265. package/dist/types/src/components/Tooltip/Tooltip.d.ts.map +1 -1
  266. package/dist/types/src/components/Tooltip/Tooltip.stories.d.ts +2 -2
  267. package/dist/types/src/components/Tooltip/Tooltip.stories.d.ts.map +1 -1
  268. package/dist/types/src/components/Tooltip/Tooltip.theme.d.ts +6 -0
  269. package/dist/types/src/components/Tooltip/Tooltip.theme.d.ts.map +1 -0
  270. package/dist/types/src/components/Tooltip/index.d.ts +1 -0
  271. package/dist/types/src/components/Tooltip/index.d.ts.map +1 -1
  272. package/dist/types/src/components/Tooltip/tooltipContent.d.ts +4 -0
  273. package/dist/types/src/components/Tooltip/tooltipContent.d.ts.map +1 -0
  274. package/dist/types/src/components/index.d.ts +11 -5
  275. package/dist/types/src/components/index.d.ts.map +1 -1
  276. package/dist/types/src/exemplars/generics.stories.d.ts +8 -6
  277. package/dist/types/src/exemplars/generics.stories.d.ts.map +1 -1
  278. package/dist/types/src/exemplars/slot.stories.d.ts +1 -0
  279. package/dist/types/src/exemplars/slot.stories.d.ts.map +1 -1
  280. package/dist/types/src/exemplars/tabster.stories.d.ts.map +1 -1
  281. package/dist/types/src/exemplars/virtualizer.stories.d.ts +11 -0
  282. package/dist/types/src/exemplars/virtualizer.stories.d.ts.map +1 -0
  283. package/dist/types/src/hooks/index.d.ts +1 -0
  284. package/dist/types/src/hooks/index.d.ts.map +1 -1
  285. package/dist/types/src/hooks/useDensityContext.d.ts +1 -1
  286. package/dist/types/src/hooks/useDensityContext.d.ts.map +1 -1
  287. package/dist/types/src/hooks/useElevationContext.d.ts.map +1 -1
  288. package/dist/types/src/hooks/useIconHref.d.ts.map +1 -1
  289. package/dist/types/src/hooks/useSafeArea.d.ts.map +1 -1
  290. package/dist/types/src/hooks/useSafeCollisionPadding.d.ts.map +1 -1
  291. package/dist/types/src/hooks/useTranslationsContext.d.ts +1 -1
  292. package/dist/types/src/hooks/useVisualViewport.d.ts.map +1 -1
  293. package/dist/types/src/index.d.ts +1 -0
  294. package/dist/types/src/index.d.ts.map +1 -1
  295. package/dist/types/src/playground/Controls.stories.d.ts.map +1 -1
  296. package/dist/types/src/playground/Custom.stories.d.ts +1 -1
  297. package/dist/types/src/playground/Custom.stories.d.ts.map +1 -1
  298. package/dist/types/src/playground/Typography.stories.d.ts.map +1 -1
  299. package/dist/types/src/primitives/Container/Container.d.ts +6 -22
  300. package/dist/types/src/primitives/Container/Container.d.ts.map +1 -1
  301. package/dist/types/src/primitives/Container/Container.stories.d.ts +2 -7
  302. package/dist/types/src/primitives/Container/Container.stories.d.ts.map +1 -1
  303. package/dist/types/src/primitives/Container/index.d.ts +0 -1
  304. package/dist/types/src/primitives/Container/index.d.ts.map +1 -1
  305. package/dist/types/src/{components → primitives}/DensityProvider/DensityProvider.d.ts.map +1 -1
  306. package/dist/types/src/primitives/DensityProvider/index.d.ts.map +1 -0
  307. package/dist/types/src/{components → primitives}/ElevationProvider/ElevationProvider.d.ts.map +1 -1
  308. package/dist/types/src/primitives/ElevationProvider/index.d.ts.map +1 -0
  309. package/dist/types/src/primitives/Flex/Flex.d.ts +8 -5
  310. package/dist/types/src/primitives/Flex/Flex.d.ts.map +1 -1
  311. package/dist/types/src/primitives/Flex/Flex.stories.d.ts +8 -0
  312. package/dist/types/src/primitives/Flex/Flex.stories.d.ts.map +1 -0
  313. package/dist/types/src/primitives/Grid/Grid.d.ts +10 -0
  314. package/dist/types/src/primitives/Grid/Grid.d.ts.map +1 -0
  315. package/dist/types/src/primitives/Grid/Grid.stories.d.ts +8 -0
  316. package/dist/types/src/primitives/Grid/Grid.stories.d.ts.map +1 -0
  317. package/dist/types/src/primitives/Grid/index.d.ts +2 -0
  318. package/dist/types/src/primitives/Grid/index.d.ts.map +1 -0
  319. package/dist/types/src/{components → primitives}/ThemeProvider/ThemeProvider.d.ts +1 -1
  320. package/dist/types/src/{components → primitives}/ThemeProvider/ThemeProvider.d.ts.map +1 -1
  321. package/dist/types/src/primitives/ThemeProvider/ThemeProvider.stories.d.ts +12 -0
  322. package/dist/types/src/primitives/ThemeProvider/ThemeProvider.stories.d.ts.map +1 -0
  323. package/dist/types/src/primitives/ThemeProvider/TranslationsProvider.d.ts +128 -0
  324. package/dist/types/src/primitives/ThemeProvider/TranslationsProvider.d.ts.map +1 -0
  325. package/dist/types/src/primitives/ThemeProvider/index.d.ts +4 -0
  326. package/dist/types/src/primitives/ThemeProvider/index.d.ts.map +1 -0
  327. package/dist/types/src/primitives/index.d.ts +4 -0
  328. package/dist/types/src/primitives/index.d.ts.map +1 -1
  329. package/dist/types/src/testing/Loading.d.ts +9 -0
  330. package/dist/types/src/testing/Loading.d.ts.map +1 -0
  331. package/dist/types/src/testing/decorators/withLayout.d.ts +1 -1
  332. package/dist/types/src/testing/decorators/withLayout.d.ts.map +1 -1
  333. package/dist/types/src/testing/decorators/withLayoutVariants.d.ts.map +1 -1
  334. package/dist/types/src/testing/decorators/withTheme.d.ts +6 -2
  335. package/dist/types/src/testing/decorators/withTheme.d.ts.map +1 -1
  336. package/dist/types/src/testing/index.d.ts +1 -0
  337. package/dist/types/src/testing/index.d.ts.map +1 -1
  338. package/dist/types/src/theme/bindTheme.d.ts +3 -0
  339. package/dist/types/src/theme/bindTheme.d.ts.map +1 -0
  340. package/dist/types/src/theme/defaultTheme.d.ts +4 -0
  341. package/dist/types/src/theme/defaultTheme.d.ts.map +1 -0
  342. package/dist/types/src/theme/index.d.ts +31 -0
  343. package/dist/types/src/theme/index.d.ts.map +1 -0
  344. package/dist/types/src/translations.d.ts +24 -0
  345. package/dist/types/src/translations.d.ts.map +1 -0
  346. package/dist/types/src/util/index.d.ts +2 -1
  347. package/dist/types/src/util/index.d.ts.map +1 -1
  348. package/dist/types/src/util/mobile.d.ts +5 -0
  349. package/dist/types/src/util/mobile.d.ts.map +1 -0
  350. package/dist/types/src/util/slots.d.ts +57 -0
  351. package/dist/types/src/util/slots.d.ts.map +1 -0
  352. package/dist/types/src/util/usePx.d.ts.map +1 -1
  353. package/dist/types/tsconfig.tsbuildinfo +1 -1
  354. package/package.json +36 -27
  355. package/src/components/Avatars/Avatar.stories.tsx +5 -7
  356. package/src/components/Avatars/Avatar.theme.ts +93 -0
  357. package/src/components/Avatars/Avatar.tsx +6 -14
  358. package/src/components/Avatars/AvatarGroup.stories.tsx +0 -1
  359. package/src/components/Breadcrumb/Breadcrumb.stories.tsx +1 -2
  360. package/src/components/Breadcrumb/Breadcrumb.theme.ts +26 -0
  361. package/src/components/Breadcrumb/Breadcrumb.tsx +25 -39
  362. package/src/components/Button/Button.stories.tsx +1 -2
  363. package/src/components/Button/Button.theme.ts +31 -0
  364. package/src/components/Button/Button.tsx +11 -25
  365. package/src/components/Button/IconButton.stories.tsx +56 -6
  366. package/src/components/Button/IconButton.theme.ts +21 -0
  367. package/src/components/Button/IconButton.tsx +3 -4
  368. package/src/components/Button/Toggle.stories.tsx +0 -1
  369. package/src/components/Button/Toggle.tsx +4 -4
  370. package/src/components/Button/ToggleGroup.stories.tsx +0 -1
  371. package/src/components/Button/ToggleGroup.tsx +12 -16
  372. package/src/components/Calendar/Calendar.stories.tsx +43 -0
  373. package/src/components/Calendar/Calendar.theme.ts +74 -0
  374. package/src/components/Calendar/Calendar.tsx +196 -0
  375. package/src/components/Calendar/index.ts +5 -0
  376. package/src/components/Card/Card.stories.tsx +172 -0
  377. package/src/components/Card/Card.theme.ts +101 -0
  378. package/src/components/Card/Card.tsx +496 -0
  379. package/src/components/Card/index.ts +5 -0
  380. package/src/components/Carousel/Carousel.tsx +371 -0
  381. package/src/components/Carousel/index.ts +5 -0
  382. package/src/components/Clipboard/CopyButton.tsx +7 -8
  383. package/src/components/Column/AUDIT.md +148 -0
  384. package/src/components/Column/Column.stories.tsx +181 -0
  385. package/src/components/Column/Column.theme.ts +48 -0
  386. package/src/components/Column/Column.tsx +165 -0
  387. package/src/components/Column/index.ts +6 -0
  388. package/src/components/Column/withColumn.ts +27 -0
  389. package/src/components/DatePicker/DatePicker.stories.tsx +102 -0
  390. package/src/components/DatePicker/DatePicker.theme.ts +35 -0
  391. package/src/components/DatePicker/DatePicker.tsx +279 -0
  392. package/src/components/DatePicker/index.ts +5 -0
  393. package/src/components/Dialog/AlertDialog.stories.tsx +14 -15
  394. package/src/components/Dialog/AlertDialog.tsx +125 -85
  395. package/src/components/Dialog/Dialog.stories.tsx +91 -15
  396. package/src/components/Dialog/Dialog.theme.ts +61 -0
  397. package/src/components/Dialog/Dialog.tsx +131 -117
  398. package/src/components/ErrorFallback/ErrorFallback.stories.tsx +45 -0
  399. package/src/components/ErrorFallback/ErrorFallback.tsx +76 -0
  400. package/src/components/ErrorFallback/ErrorStack.tsx +120 -0
  401. package/src/components/ErrorFallback/ThrowError.tsx +37 -0
  402. package/src/components/ErrorFallback/index.ts +9 -0
  403. package/src/components/Focus/AUDIT.md +43 -0
  404. package/src/components/Focus/Focus.stories.tsx +230 -0
  405. package/src/components/Focus/Focus.theme.ts +32 -0
  406. package/src/components/Focus/Focus.tsx +201 -0
  407. package/src/components/Focus/index.ts +5 -0
  408. package/src/components/Icon/Icon.stories.tsx +43 -13
  409. package/src/components/Icon/Icon.theme.ts +27 -0
  410. package/src/components/Icon/Icon.tsx +14 -3
  411. package/src/components/Image/Image.stories.tsx +86 -0
  412. package/src/components/Image/Image.tsx +246 -0
  413. package/src/components/Image/index.ts +5 -0
  414. package/src/components/Input/Input.stories.tsx +146 -64
  415. package/src/components/Input/Input.theme.ts +191 -0
  416. package/src/components/Input/Input.tsx +230 -72
  417. package/src/components/Input/SegmentedInput.tsx +453 -0
  418. package/src/components/Input/constants.ts +5 -0
  419. package/src/components/Input/index.ts +2 -0
  420. package/src/components/Link/Link.stories.tsx +0 -1
  421. package/src/components/Link/Link.theme.ts +16 -0
  422. package/src/components/Link/Link.tsx +11 -3
  423. package/src/components/List/List.stories.tsx +14 -22
  424. package/src/components/List/List.theme.ts +47 -0
  425. package/src/components/List/List.tsx +17 -21
  426. package/src/components/List/ListDropIndicator.tsx +7 -8
  427. package/src/components/List/Tree.stories.tsx +4 -5
  428. package/src/components/List/Tree.tsx +0 -1
  429. package/src/components/List/TreeDropIndicator.tsx +6 -6
  430. package/src/components/List/Treegrid.stories.tsx +27 -28
  431. package/src/components/List/Treegrid.theme.ts +35 -0
  432. package/src/components/List/Treegrid.tsx +22 -28
  433. package/src/components/Main/Main.stories.tsx +3 -7
  434. package/src/components/Main/Main.theme.ts +29 -0
  435. package/src/components/Main/Main.tsx +64 -53
  436. package/src/components/Main/constants.ts +6 -0
  437. package/src/components/Main/index.ts +1 -0
  438. package/src/components/MediaPlayer/MediaPlayer.stories.tsx +50 -0
  439. package/src/components/MediaPlayer/MediaPlayer.tsx +178 -0
  440. package/src/components/MediaPlayer/index.ts +5 -0
  441. package/src/components/Menu/ContextMenu.stories.tsx +0 -1
  442. package/src/components/Menu/ContextMenu.tsx +9 -33
  443. package/src/components/Menu/DropdownMenu.stories.tsx +0 -1
  444. package/src/components/Menu/DropdownMenu.tsx +73 -67
  445. package/src/components/Menu/Menu.theme.ts +48 -0
  446. package/src/components/Message/Message.stories.tsx +25 -11
  447. package/src/components/Message/Message.theme.ts +39 -0
  448. package/src/components/Message/Message.tsx +32 -31
  449. package/src/components/Panel/Panel.stories.tsx +67 -0
  450. package/src/components/Panel/Panel.theme.ts +42 -0
  451. package/src/components/Panel/Panel.tsx +121 -0
  452. package/src/components/Panel/index.ts +5 -0
  453. package/src/components/Popover/Popover.stories.tsx +5 -6
  454. package/src/components/Popover/Popover.theme.ts +40 -0
  455. package/src/components/Popover/Popover.tsx +69 -66
  456. package/src/components/ScrollArea/ScrollArea.stories.tsx +98 -39
  457. package/src/components/ScrollArea/ScrollArea.theme.ts +104 -0
  458. package/src/components/ScrollArea/ScrollArea.tsx +46 -33
  459. package/src/components/ScrollArea/index.ts +1 -0
  460. package/src/components/ScrollArea/scrollbar.ts +21 -0
  461. package/src/components/ScrollContainer/ScrollContainer.stories.tsx +46 -25
  462. package/src/components/ScrollContainer/ScrollContainer.tsx +215 -106
  463. package/src/components/Select/Select.stories.tsx +5 -6
  464. package/src/components/Select/Select.theme.ts +55 -0
  465. package/src/components/Select/Select.tsx +35 -35
  466. package/src/components/Separator/Separator.theme.ts +23 -0
  467. package/src/components/Separator/Separator.tsx +5 -8
  468. package/src/components/Skeleton/Skeleton.stories.tsx +12 -13
  469. package/src/components/Skeleton/Skeleton.theme.ts +22 -0
  470. package/src/components/Skeleton/Skeleton.tsx +1 -1
  471. package/src/components/Splitter/Splitter.stories.tsx +47 -37
  472. package/src/components/Splitter/Splitter.theme.ts +18 -0
  473. package/src/components/Splitter/Splitter.tsx +45 -46
  474. package/src/components/Status/Status.stories.tsx +19 -16
  475. package/src/components/Status/Status.theme.ts +31 -0
  476. package/src/components/Status/Status.tsx +9 -7
  477. package/src/components/Tag/Tag.stories.tsx +3 -9
  478. package/src/components/Tag/Tag.theme.ts +22 -0
  479. package/src/components/Tag/Tag.tsx +2 -7
  480. package/src/components/Toast/Toast.stories.tsx +0 -1
  481. package/src/components/Toast/Toast.theme.ts +52 -0
  482. package/src/components/Toast/Toast.tsx +24 -43
  483. package/src/components/Toolbar/Toolbar.stories.tsx +0 -1
  484. package/src/components/Toolbar/Toolbar.theme.ts +36 -0
  485. package/src/components/Toolbar/Toolbar.tsx +225 -30
  486. package/src/components/Tooltip/Tooltip.stories.tsx +18 -17
  487. package/src/components/Tooltip/Tooltip.theme.ts +19 -0
  488. package/src/components/Tooltip/Tooltip.tsx +36 -35
  489. package/src/components/Tooltip/index.ts +1 -0
  490. package/src/components/Tooltip/tooltipContent.ts +16 -0
  491. package/src/components/index.ts +11 -6
  492. package/src/exemplars/generics.stories.tsx +12 -16
  493. package/src/exemplars/slot.stories.tsx +68 -60
  494. package/src/exemplars/tabster.stories.tsx +5 -5
  495. package/src/exemplars/virtualizer.stories.tsx +136 -0
  496. package/src/hooks/index.ts +1 -0
  497. package/src/hooks/useDensityContext.ts +3 -3
  498. package/src/hooks/useElevationContext.ts +1 -1
  499. package/src/hooks/useThemeContext.ts +1 -1
  500. package/src/hooks/useTranslationsContext.ts +1 -1
  501. package/src/index.ts +1 -0
  502. package/src/playground/Controls.stories.tsx +0 -6
  503. package/src/playground/Custom.stories.tsx +16 -39
  504. package/src/playground/Typography.stories.tsx +1 -1
  505. package/src/primitives/Container/Container.stories.tsx +13 -51
  506. package/src/primitives/Container/Container.tsx +13 -74
  507. package/src/primitives/Container/index.ts +0 -1
  508. package/src/{components → primitives}/DensityProvider/DensityProvider.tsx +1 -1
  509. package/src/primitives/Flex/Flex.stories.tsx +57 -0
  510. package/src/primitives/Flex/Flex.tsx +21 -18
  511. package/src/primitives/Grid/Grid.stories.tsx +56 -0
  512. package/src/primitives/Grid/Grid.tsx +32 -0
  513. package/src/primitives/Grid/index.ts +5 -0
  514. package/src/primitives/ThemeProvider/ThemeProvider.stories.tsx +31 -0
  515. package/src/{components → primitives}/ThemeProvider/ThemeProvider.tsx +9 -8
  516. package/src/{components → primitives}/ThemeProvider/index.ts +2 -2
  517. package/src/primitives/index.ts +5 -0
  518. package/src/testing/Loading.tsx +47 -0
  519. package/src/testing/decorators/withLayout.tsx +15 -11
  520. package/src/testing/decorators/withLayoutVariants.tsx +19 -22
  521. package/src/testing/decorators/withTheme.tsx +23 -12
  522. package/src/testing/index.ts +2 -0
  523. package/src/theme/bindTheme.ts +13 -0
  524. package/src/theme/defaultTheme.ts +83 -0
  525. package/src/theme/index.ts +37 -0
  526. package/src/translations.ts +32 -0
  527. package/src/util/index.ts +2 -1
  528. package/src/util/mobile.ts +11 -0
  529. package/src/util/slots.ts +129 -0
  530. package/src/util/usePx.ts +5 -1
  531. package/dist/lib/browser/chunk-EJYV4HAH.mjs +0 -774
  532. package/dist/lib/browser/chunk-EJYV4HAH.mjs.map +0 -7
  533. package/dist/lib/node-esm/chunk-YTLZCZ2M.mjs +0 -776
  534. package/dist/lib/node-esm/chunk-YTLZCZ2M.mjs.map +0 -7
  535. package/dist/types/src/components/AnchoredOverflow/AnchoredOverflow.d.ts +0 -22
  536. package/dist/types/src/components/AnchoredOverflow/AnchoredOverflow.d.ts.map +0 -1
  537. package/dist/types/src/components/AnchoredOverflow/index.d.ts +0 -2
  538. package/dist/types/src/components/AnchoredOverflow/index.d.ts.map +0 -1
  539. package/dist/types/src/components/DensityProvider/index.d.ts.map +0 -1
  540. package/dist/types/src/components/ElevationProvider/index.d.ts.map +0 -1
  541. package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts +0 -129
  542. package/dist/types/src/components/ThemeProvider/TranslationsProvider.d.ts.map +0 -1
  543. package/dist/types/src/components/ThemeProvider/index.d.ts +0 -4
  544. package/dist/types/src/components/ThemeProvider/index.d.ts.map +0 -1
  545. package/dist/types/src/primitives/Container/Layout.d.ts +0 -18
  546. package/dist/types/src/primitives/Container/Layout.d.ts.map +0 -1
  547. package/dist/types/src/primitives/Container/Layout.stories.d.ts +0 -10
  548. package/dist/types/src/primitives/Container/Layout.stories.d.ts.map +0 -1
  549. package/dist/types/src/util/hasIosKeyboard.d.ts +0 -2
  550. package/dist/types/src/util/hasIosKeyboard.d.ts.map +0 -1
  551. package/src/components/AnchoredOverflow/AnchoredOverflow.tsx +0 -67
  552. package/src/components/AnchoredOverflow/index.ts +0 -5
  553. package/src/primitives/Container/Layout.stories.tsx +0 -57
  554. package/src/primitives/Container/Layout.tsx +0 -61
  555. package/src/util/hasIosKeyboard.ts +0 -8
  556. /package/dist/types/src/{components → primitives}/DensityProvider/DensityProvider.d.ts +0 -0
  557. /package/dist/types/src/{components → primitives}/DensityProvider/index.d.ts +0 -0
  558. /package/dist/types/src/{components → primitives}/ElevationProvider/ElevationProvider.d.ts +0 -0
  559. /package/dist/types/src/{components → primitives}/ElevationProvider/index.d.ts +0 -0
  560. /package/src/{components → primitives}/DensityProvider/index.ts +0 -0
  561. /package/src/{components → primitives}/ElevationProvider/ElevationProvider.tsx +0 -0
  562. /package/src/{components → primitives}/ElevationProvider/index.ts +0 -0
  563. /package/src/{components → primitives}/ThemeProvider/TranslationsProvider.tsx +0 -0
@@ -0,0 +1,16 @@
1
+ //
2
+ // Copyright 2023 DXOS.org
3
+ //
4
+
5
+ import { mx, surfaceShadow, surfaceZIndex } from '@dxos/ui-theme';
6
+ import { type ComponentFunction } from '@dxos/ui-types';
7
+
8
+ import { type TooltipStyleProps } from './Tooltip.theme';
9
+
10
+ export const tooltipContent: ComponentFunction<TooltipStyleProps> = ({ elevation }, ...etc) =>
11
+ mx(
12
+ 'inline-flex items-center p-1 max-w-64 text-sm bg-inverse-surface text-inverse-foreground rounded-sm',
13
+ surfaceShadow({ elevation: 'positioned' }),
14
+ surfaceZIndex({ elevation, level: 'tooltip' }),
15
+ ...etc,
16
+ );
@@ -2,32 +2,37 @@
2
2
  // Copyright 2022 DXOS.org
3
3
  //
4
4
 
5
- export * from './AnchoredOverflow';
6
5
  export * from './Avatars';
7
6
  export * from './Breadcrumb';
8
7
  export * from './Button';
8
+ export * from './Calendar';
9
+ export * from './Card';
10
+ export * from './Carousel';
9
11
  export * from './Clipboard';
12
+ export * from './Column';
13
+ export * from './DatePicker';
10
14
  export * from './Dialog';
15
+ export * from './ErrorFallback';
16
+ export * from './Focus';
11
17
  export * from './Icon';
18
+ export * from './Image';
12
19
  export * from './Input';
13
20
  export * from './Link';
14
21
  export * from './List';
15
22
  export * from './Main';
23
+ export * from './MediaPlayer';
16
24
  export * from './Menu';
17
25
  export * from './Message';
26
+ export * from './Panel';
18
27
  export * from './Popover';
19
- export * from './Status';
20
28
  export * from './ScrollArea';
21
29
  export * from './ScrollContainer';
22
30
  export * from './Select';
23
31
  export * from './Separator';
24
32
  export * from './Skeleton';
25
33
  export * from './Splitter';
34
+ export * from './Status';
26
35
  export * from './Tag';
27
36
  export * from './Toast';
28
37
  export * from './Toolbar';
29
38
  export * from './Tooltip';
30
-
31
- export * from './DensityProvider';
32
- export * from './ElevationProvider';
33
- export * from './ThemeProvider';
@@ -3,13 +3,15 @@
3
3
  //
4
4
 
5
5
  import { type Meta, type StoryObj } from '@storybook/react-vite';
6
- import React, { type ReactElement, type Ref, forwardRef } from 'react';
7
-
8
- import { type SlottableProps } from '@dxos/ui-types';
6
+ import React from 'react';
9
7
 
10
8
  import { withTheme } from '../testing';
9
+ import { slottable } from '../util';
11
10
 
12
- const ComponentInner = forwardRef<HTMLDivElement, ComponentProps>(({ children, ...props }, forwardedRef) => {
11
+ /**
12
+ * Generic component pattern using the slottable factory.
13
+ */
14
+ const Component = slottable<HTMLDivElement>(({ children, ...props }, forwardedRef) => {
13
15
  return (
14
16
  <div {...props} ref={forwardedRef}>
15
17
  {children}
@@ -17,20 +19,10 @@ const ComponentInner = forwardRef<HTMLDivElement, ComponentProps>(({ children, .
17
19
  );
18
20
  });
19
21
 
20
- ComponentInner.displayName = 'Component';
21
-
22
- /**
23
- * Generic component pattern.
24
- */
25
- type ComponentProps<P extends HTMLElement = any> = SlottableProps<P>;
26
-
27
- const Component = ComponentInner as <P extends HTMLElement>(
28
- props: SlottableProps<P> & { ref?: Ref<P> },
29
- ) => ReactElement;
30
-
31
22
  const meta = {
32
23
  title: 'ui/react-ui-core/exemplars/generics',
33
24
  component: Component,
25
+ render: (props) => <Component {...props} />,
34
26
  decorators: [withTheme()],
35
27
  parameters: {
36
28
  layout: 'centered',
@@ -41,4 +33,8 @@ export default meta;
41
33
 
42
34
  type Story = StoryObj<typeof meta>;
43
35
 
44
- export const Single: Story = {};
36
+ export const Default: Story = {
37
+ args: {
38
+ children: 'Hello',
39
+ },
40
+ };
@@ -2,85 +2,65 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
+ import { Primitive } from '@radix-ui/react-primitive';
5
6
  import { Slot } from '@radix-ui/react-slot';
6
7
  import { type Meta, type StoryObj } from '@storybook/react-vite';
7
- import React, { type PropsWithChildren, forwardRef } from 'react';
8
+ import React, { PropsWithChildren } from 'react';
8
9
 
9
10
  import { mx } from '@dxos/ui-theme';
10
- import { type SlottableClassName, type SlottableProps, type ThemedClassName } from '@dxos/ui-types';
11
11
 
12
12
  import { withTheme } from '../testing';
13
+ import { composable, composableProps, slottable } from '../util';
14
+ import { ThemedClassName } from '../util';
13
15
 
14
16
  /**
15
- * Composition
16
- *
17
+ * Radix-style composition.
17
18
  * All Radix primitive parts that render a DOM element accept an asChild prop.
18
- * When asChild is set to true, Radix will not render a default DOM element, instead cloning the part's child and passing it the props and behavior required to make it functional.
19
+ * When asChild is set to true, Radix will not render a default DOM element,
20
+ * instead cloning the part's child and passing it the props and behavior required to make it functional.
19
21
  * https://www.radix-ui.com/primitives/docs/guides/composition
20
22
  */
21
23
 
22
- // Outer primitive (like Tooltip.Trigger or Focus.Group).
23
- const Outer = forwardRef<HTMLDivElement, SlottableProps<HTMLDivElement>>(
24
- ({ children, className, classNames, asChild, ...props }, forwardedRef) => {
25
- const Root = asChild ? Slot : 'div';
24
+ const Outer = slottable<HTMLDivElement, { priority?: number }>(
25
+ ({ children, asChild, priority, ...props }, forwardedRef) => {
26
+ const Comp = asChild ? Slot : Primitive.div;
26
27
  return (
27
- <Root {...props} className={mx(className, classNames)} data-outer='true' ref={forwardedRef}>
28
+ <Comp
29
+ {...composableProps<HTMLDivElement>(props, { classNames: 'p-2 border border-red-500 rounded' })}
30
+ ref={forwardedRef}
31
+ >
28
32
  {children}
29
- </Root>
33
+ </Comp>
30
34
  );
31
35
  },
32
36
  );
33
37
 
34
- // Middle primitive (like Dialog.Trigger or Mosaic.Cell).
35
- const Middle = forwardRef<HTMLDivElement, SlottableProps<HTMLDivElement>>(
36
- ({ children, className, classNames, asChild, ...props }, forwardedRef) => {
37
- const Root = asChild ? Slot : 'div';
38
- return (
39
- <Root {...props} className={mx(className, classNames)} data-middle='true' ref={forwardedRef}>
40
- {children}
41
- </Root>
42
- );
43
- },
44
- );
45
-
46
- // Leaf component (like Card.Root).
47
- const Leaf = forwardRef<HTMLButtonElement, SlottableClassName<PropsWithChildren>>(
48
- ({ className, classNames, children, ...props }, forwardedRef) => {
49
- return (
50
- <button {...props} className={mx('p-2 outline-none border rounded', className, classNames)} ref={forwardedRef}>
51
- {children}
52
- </button>
53
- );
54
- },
55
- );
56
-
57
- // Test 1: Single asChild.
58
- const TestSingle = ({ classNames, ...props }: ThemedClassName<{ role?: string }>) => (
59
- <Outer asChild {...props} className={mx('p-2', classNames)}>
60
- <Leaf>Single asChild</Leaf>
61
- </Outer>
62
- );
38
+ const Middle = slottable<HTMLDivElement>(({ children, asChild, ...props }, forwardedRef) => {
39
+ const Comp = asChild ? Slot : Primitive.div;
40
+ return (
41
+ <Comp
42
+ {...composableProps<HTMLDivElement>(props, { classNames: 'p-2 border border-red-500 rounded' })}
43
+ ref={forwardedRef}
44
+ >
45
+ {children}
46
+ </Comp>
47
+ );
48
+ });
63
49
 
64
- // Test 2: Nested asChild.
65
- const TestNested = ({ classNames, ...props }: ThemedClassName<{ role?: string }>) => {
50
+ const Leaf = composable<HTMLButtonElement>(({ children, ...props }, forwardedRef) => {
66
51
  return (
67
- <Outer asChild {...props} className={mx('p-2', classNames)}>
68
- <Middle asChild>
69
- <Leaf>Nested asChild</Leaf>
70
- </Middle>
71
- </Outer>
52
+ <button
53
+ {...composableProps<HTMLButtonElement>(props, { classNames: 'p-2 border border-red-500 rounded' })}
54
+ ref={forwardedRef}
55
+ >
56
+ {children}
57
+ </button>
72
58
  );
73
- };
59
+ });
74
60
 
75
- // Test 3: Complex.
76
- const TestInner = ({ classNames, ...props }: ThemedClassName<{ role?: string }>) => (
77
- <Outer asChild {...props} className={mx('p-2', classNames)}>
78
- <Middle asChild>
79
- <Leaf>
80
- <div role='none'>Leaf</div>
81
- </Leaf>
82
- </Middle>
83
- </Outer>
61
+ /** This isn't a valid child for a `slottable` component. */
62
+ const Simple = ({ children, classNames }: ThemedClassName<PropsWithChildren>) => (
63
+ <div className={mx(classNames)}>{children}</div>
84
64
  );
85
65
 
86
66
  const meta = {
@@ -96,13 +76,41 @@ export default meta;
96
76
  type Story = StoryObj<typeof meta>;
97
77
 
98
78
  export const Single: Story = {
99
- render: () => <TestSingle role='listitem' classNames='border-red-500' />,
79
+ render: () => (
80
+ <Outer asChild role='article' classNames='border-green-500' priority={1}>
81
+ <Leaf>Single asChild (non-compliant — see console)</Leaf>
82
+ </Outer>
83
+ ),
100
84
  };
101
85
 
102
86
  export const Nested: Story = {
103
- render: () => <TestNested role='listitem' classNames='border-green-500' />,
87
+ render: () => (
88
+ <Outer asChild role='article' classNames='border-blue-500'>
89
+ <Middle asChild>
90
+ <Leaf>Nested asChild</Leaf>
91
+ </Middle>
92
+ </Outer>
93
+ ),
104
94
  };
105
95
 
106
96
  export const Inner: Story = {
107
- render: () => <TestInner role='listitem' classNames='border-blue-500' />,
97
+ render: () => (
98
+ <Outer asChild role='article' classNames='border-orange-500'>
99
+ <Middle asChild>
100
+ <Leaf>
101
+ <div>Leaf</div>
102
+ </Leaf>
103
+ </Middle>
104
+ </Outer>
105
+ ),
106
+ };
107
+
108
+ export const Error: Story = {
109
+ render: () => (
110
+ <Outer asChild role='none' classNames='p-2 border border-green-500 rounded'>
111
+ <Middle asChild>
112
+ <Simple>Simple</Simple>
113
+ </Middle>
114
+ </Outer>
115
+ ),
108
116
  };
@@ -21,14 +21,14 @@ import { mx } from '@dxos/ui-theme';
21
21
  // TODO(burdon): Prevent tab out of app.
22
22
 
23
23
  const border =
24
- 'rounded-sm outline-none border border-subduedSeparator focus:border-primary-500 focus-within:border-rose-500';
24
+ 'rounded-xs outline-hidden border border-subdued-separator focus:border-primary-500 focus-within:border-rose-500';
25
25
 
26
26
  const Board = forwardRef<HTMLDivElement, { columns: string[][] }>(({ columns }, ref) => {
27
27
  const arrowNavigationAttrs = useArrowNavigationGroup({ axis: 'horizontal', memorizeCurrent: true, tabbable: true });
28
28
 
29
29
  return (
30
- <div ref={ref} tabIndex={0} {...arrowNavigationAttrs} className='flex bs-full is-full overflow-hidden'>
31
- <div className={mx('flex bs-full overflow-x-auto p-4 gap-4')}>
30
+ <div ref={ref} tabIndex={0} {...arrowNavigationAttrs} className='flex h-full w-full overflow-hidden'>
31
+ <div className={mx('flex h-full overflow-x-auto p-4 gap-4')}>
32
32
  {columns.map((column) => (
33
33
  <Column key={column[0]} items={column} />
34
34
  ))}
@@ -43,7 +43,7 @@ const Column = forwardRef<HTMLDivElement, { items: string[] }>(({ items }, ref)
43
43
  const tabsterAttrs = useMergedTabsterAttributes_unstable(focusableGroupAttrs, arrowNavigationAttrs);
44
44
 
45
45
  return (
46
- <ScrollArea.Root tabIndex={0} orientation='vertical' classNames={mx('shrink-0 bs-full is-[25rem]', border)}>
46
+ <ScrollArea.Root orientation='vertical' classNames={mx('w-[25rem]', border)}>
47
47
  <ScrollArea.Viewport {...tabsterAttrs} classNames='p-4 gap-4' ref={ref}>
48
48
  {items.map((item) => (
49
49
  <Item key={item} value={item} />
@@ -61,7 +61,7 @@ const Item = forwardRef<HTMLDivElement, { value: string }>(({ value }, ref) => {
61
61
  ref={ref}
62
62
  tabIndex={0}
63
63
  {...focusableGroupAttrs}
64
- className={mx('flex shrink-0 is-full gap-4 p-4 items-center', border)}
64
+ className={mx('flex shrink-0 w-full gap-4 p-4 items-center', border)}
65
65
  >
66
66
  <Input.Root>
67
67
  <Input.Checkbox />
@@ -0,0 +1,136 @@
1
+ //
2
+ // Copyright 2023 DXOS.org
3
+ //
4
+
5
+ import { type Meta } from '@storybook/react-vite';
6
+ import { useVirtualizer } from '@tanstack/react-virtual';
7
+ import React, { useEffect, useMemo, useRef, useState } from 'react';
8
+
9
+ import { random } from '@dxos/random';
10
+ import { Panel, ScrollArea, Toolbar } from '@dxos/react-ui';
11
+ import { withLayout, withTheme } from '@dxos/react-ui/testing';
12
+
13
+ random.seed(999);
14
+
15
+ type TestItem = {
16
+ name: string;
17
+ };
18
+
19
+ const meta: Meta = {
20
+ title: 'ui/react-ui-core/exemplars/virtualizer',
21
+ decorators: [withLayout({ layout: 'column' }), withTheme()],
22
+ parameters: {
23
+ layout: 'fullscreen',
24
+ },
25
+ };
26
+
27
+ export default meta;
28
+
29
+ const NUM_ITEMS = 500;
30
+
31
+ /**
32
+ * https://tanstack.com/virtual/latest/docs/introduction
33
+ */
34
+ export const Default = {
35
+ render: () => {
36
+ const [index, setIndex] = useState(0);
37
+ const items = useMemo<TestItem[]>(
38
+ () =>
39
+ Array.from({ length: NUM_ITEMS }, () => ({
40
+ name: random.lorem.paragraph(),
41
+ })),
42
+ [],
43
+ );
44
+
45
+ const parentRef = useRef(null);
46
+ const [viewport, setViewport] = useState<HTMLElement | null>(null);
47
+ const virtualizer = useVirtualizer({
48
+ getScrollElement: () => viewport,
49
+ estimateSize: () => 40,
50
+ count: items.length,
51
+ gap: 8,
52
+ });
53
+
54
+ useEffect(() => {
55
+ virtualizer.scrollToIndex(index, { align: 'start' });
56
+ }, [virtualizer, index]);
57
+
58
+ const virtualItems = virtualizer.getVirtualItems();
59
+
60
+ return (
61
+ <Panel.Root>
62
+ <Panel.Toolbar asChild>
63
+ <ScrollToolbar items={items} index={index} setIndex={setIndex} />
64
+ </Panel.Toolbar>
65
+ <Panel.Content asChild>
66
+ <ScrollArea.Root orientation='vertical' centered>
67
+ <ScrollArea.Viewport classNames='p-2' ref={setViewport}>
68
+ <div
69
+ style={{
70
+ position: 'relative',
71
+ height: virtualizer.getTotalSize(),
72
+ width: '100%',
73
+ }}
74
+ ref={parentRef}
75
+ >
76
+ {virtualItems.map((virtualItem) => (
77
+ <div
78
+ key={virtualItem.key}
79
+ role='list'
80
+ className='grid grid-cols-[3rem_1fr] overflow-hidden border border-separator rounded-xs'
81
+ style={{
82
+ position: 'absolute',
83
+ top: 0,
84
+ left: 0,
85
+ width: '100%',
86
+ transform: `translateY(${virtualItem.start}px)`,
87
+ }}
88
+ data-index={virtualItem.index}
89
+ ref={virtualizer.measureElement}
90
+ >
91
+ <div className='p-1'>{virtualItem.index + 1}</div>
92
+ <div className='p-1'>{items[virtualItem.index].name}</div>
93
+ </div>
94
+ ))}
95
+ </div>
96
+ </ScrollArea.Viewport>
97
+ </ScrollArea.Root>
98
+ </Panel.Content>
99
+ </Panel.Root>
100
+ );
101
+ },
102
+ };
103
+
104
+ const ScrollToolbar = ({
105
+ items,
106
+ index,
107
+ setIndex,
108
+ }: {
109
+ items: any[];
110
+ index: number;
111
+ setIndex: (index: number) => void;
112
+ }) => {
113
+ return (
114
+ <Toolbar.Root classNames='grid grid-cols-3'>
115
+ <div />
116
+ <div className='flex justify-center gap-1'>
117
+ <Toolbar.IconButton icon='ph--arrow-line-left--regular' iconOnly label='start' onClick={() => setIndex(0)} />
118
+ <Toolbar.IconButton
119
+ icon='ph--arrows-out-line-horizontal--regular'
120
+ iconOnly
121
+ label='random'
122
+ onClick={() => setIndex(Math.floor(Math.random() * items.length))}
123
+ />
124
+ <Toolbar.IconButton
125
+ icon='ph--arrow-line-right--regular'
126
+ iconOnly
127
+ label='end'
128
+ onClick={() => setIndex(items.length - 1)}
129
+ />
130
+ </div>
131
+ <div className='p-1 text-right'>
132
+ {index + 1}/{items.length}
133
+ </div>
134
+ </Toolbar.Root>
135
+ );
136
+ };
@@ -6,6 +6,7 @@ export * from './useDensityContext';
6
6
  export * from './useElevationContext';
7
7
  export * from './useIconHref';
8
8
  export * from './useSafeArea';
9
+ export * from './useSafeCollisionPadding';
9
10
  export * from './useTranslationsContext';
10
11
  export * from './useThemeContext';
11
12
  export * from './useVisualViewport';
@@ -6,9 +6,9 @@ import { useContext } from 'react';
6
6
 
7
7
  import { type Density } from '@dxos/ui-types';
8
8
 
9
- import { DensityContext } from '../components';
9
+ import { DensityContext } from '../primitives';
10
10
 
11
- export const useDensityContext = (propsDensity?: Density) => {
11
+ export const useDensityContext = (densityProp?: Density): Density | undefined => {
12
12
  const { density } = useContext(DensityContext);
13
- return propsDensity ?? density;
13
+ return densityProp ?? density;
14
14
  };
@@ -6,7 +6,7 @@ import { useContext } from 'react';
6
6
 
7
7
  import { type Elevation } from '@dxos/ui-types';
8
8
 
9
- import { ElevationContext } from '../components';
9
+ import { ElevationContext } from '../primitives';
10
10
 
11
11
  export const useElevationContext = (propsElevation?: Elevation) => {
12
12
  const { elevation } = useContext(ElevationContext);
@@ -6,6 +6,6 @@ import { useContext } from 'react';
6
6
 
7
7
  import { raise } from '@dxos/debug';
8
8
 
9
- import { ThemeContext } from '../components';
9
+ import { ThemeContext } from '../primitives';
10
10
 
11
11
  export const useThemeContext = () => useContext(ThemeContext) ?? raise(new Error('Missing ThemeContext'));
@@ -4,6 +4,6 @@
4
4
 
5
5
  import { useContext } from 'react';
6
6
 
7
- import { TranslationsContext } from '../components/ThemeProvider/TranslationsProvider';
7
+ import { TranslationsContext } from '../primitives';
8
8
 
9
9
  export const useTranslationsContext = () => useContext(TranslationsContext);
package/src/index.ts CHANGED
@@ -11,4 +11,5 @@ export * from '@dxos/ui-types';
11
11
  export * from './components';
12
12
  export * from './hooks';
13
13
  export * from './primitives';
14
+ export * from './theme';
14
15
  export * from './util';
@@ -31,9 +31,6 @@ const DefaultStory = () => {
31
31
  </Select.Content>
32
32
  </Select.Portal>
33
33
  </Select.Root>
34
- {/* TODO(burdon): Highlight is cyan. */}
35
- {/* TODO(burdon): Show vertical divider by default. */}
36
- {/* TODO(burdon): Icon sizes should adapt to density. */}
37
34
  <Toolbar.ToggleGroup type='multiple'>
38
35
  <Toolbar.ToggleGroupItem value='a'>
39
36
  <Icon icon='ph--text-b--regular' />
@@ -45,7 +42,6 @@ const DefaultStory = () => {
45
42
  <Icon icon='ph--text-underline--regular' />
46
43
  </Toolbar.ToggleGroupItem>
47
44
  </Toolbar.ToggleGroup>
48
- {/* TODO(burdon): Highlight isn't shown. */}
49
45
  <Toolbar.ToggleGroup type='single' defaultValue='a'>
50
46
  <Toolbar.ToggleGroupItem value='a'>
51
47
  <Icon icon='ph--file-ts--regular' />
@@ -59,11 +55,9 @@ const DefaultStory = () => {
59
55
  <Icon icon='ph--bug--regular' />
60
56
  </Toggle>
61
57
  </Toolbar.Button>
62
- {/* TODO(burdon): Should not be 'is-full' by default. */}
63
58
  <Input.Root>
64
59
  <Input.TextInput placeholder='Enter text...' />
65
60
  </Input.Root>
66
- {/* TODO(burdon): Checkbox collapsed. */}
67
61
  <Input.Root>
68
62
  <Input.Checkbox checked={checked} onCheckedChange={(value) => setChecked(!!value)} />
69
63
  <Input.Label>Checkbox</Input.Label>
@@ -12,91 +12,68 @@ const DefaultStory = ({ children, ...args }: Omit<ButtonProps, 'ref'>) => {
12
12
  return (
13
13
  <Tooltip.Provider>
14
14
  <div className='flex flex-col gap-6'>
15
- {/* Large */}
15
+ {/* Large (40px) */}
16
16
  <div className='grid grid-cols-3 gap-4'>
17
17
  <div className='flex justify-center'>
18
- <Button {...args} density='coarse'>
18
+ <Button {...args} density='lg'>
19
19
  {children}
20
20
  </Button>
21
21
  </div>
22
22
  <div className='flex justify-center'>
23
- <IconButton {...args} label='Test' icon='ph--atom--regular' size={7} density='coarse' />
23
+ <IconButton {...args} label='Test' icon='ph--circle--regular' density='lg' />
24
24
  </div>
25
25
  <div className='flex justify-center'>
26
- <IconButton
27
- {...args}
28
- label='Test'
29
- icon='ph--atom--regular'
30
- iconOnly
31
- size={7}
32
- density='coarse'
33
- classNames='pli-1.5'
34
- />
26
+ <IconButton {...args} label='Test' icon='ph--circle--regular' iconOnly density='lg' classNames='px-1.5' />
35
27
  </div>
36
28
  </div>
37
29
 
38
- {/* Medium */}
30
+ {/* Medium (32px, default) */}
39
31
  <div className='grid grid-cols-3 gap-4'>
40
32
  <div className='flex justify-center'>
41
- <Button {...args} density='fine'>
33
+ <Button {...args} density='md'>
42
34
  {children}
43
35
  </Button>
44
36
  </div>
45
37
  <div className='flex justify-center'>
46
- <IconButton {...args} label='Test' icon='ph--atom--regular' density='fine' classNames='pli-2' />
38
+ <IconButton {...args} label='Test' icon='ph--circle--regular' density='md' classNames='px-2' />
47
39
  </div>
48
40
  <div className='flex justify-center'>
49
41
  <IconButton
50
42
  {...args}
51
43
  label='Test'
52
- icon='ph--atom--regular'
44
+ icon='ph--circle--regular'
53
45
  iconOnly
54
- density='fine'
55
- classNames='plb-1 pli-1.5'
46
+ density='md'
47
+ classNames='py-1 px-1.5'
56
48
  />
57
49
  </div>
58
50
  </div>
59
51
 
60
- {/* Small */}
52
+ {/* Small (28px) */}
61
53
  <div className='grid grid-cols-3 gap-4'>
62
54
  <div className='flex justify-center'>
63
- <Button {...args} density='fine' classNames={'!h-[24px] !text-[14px] p-0 pli-1.5 min-bs-0'}>
55
+ <Button {...args} density='sm'>
64
56
  {children}
65
57
  </Button>
66
58
  </div>
67
59
  <div className='flex justify-center'>
68
- <IconButton
69
- {...args}
70
- label='Test'
71
- icon='ph--atom--regular'
72
- density='fine'
73
- size={4}
74
- classNames={'!h-[24px] !text-[14px] p-1 min-bs-0 gap-0.5'}
75
- />
60
+ <IconButton {...args} label='Test' icon='ph--circle--regular' density='sm' />
76
61
  </div>
77
62
  <div className='flex justify-center'>
78
- <IconButton
79
- {...args}
80
- label='Test'
81
- icon='ph--atom--regular'
82
- iconOnly
83
- density='fine'
84
- size={4}
85
- classNames={'!h-[24px] !text-[14px] p-1 min-bs-0'}
86
- />
63
+ <IconButton {...args} label='Test' icon='ph--circle--regular' iconOnly density='sm' />
87
64
  </div>
88
65
  </div>
89
66
 
90
67
  {/* TODO(burdon): Full variant with max width. */}
91
68
  <div className='flex justify-center'>
92
- <Button classNames='is-full max-is-[15rem] rounded' variant='default'>
69
+ <Button classNames='w-full max-w-[15rem] rounded-sm' variant='default'>
93
70
  Test
94
71
  </Button>
95
72
  </div>
96
73
  <div className='flex justify-center'>
97
74
  {/* TODO(burdon): Option to have button on RHS. Default size for icon should be 5 for this (medium) density. */}
98
75
  <IconButton
99
- classNames='is-full max-is-[15rem] rounded'
76
+ classNames='w-full max-w-[15rem] rounded-sm'
100
77
  variant='primary'
101
78
  icon='ph--arrows-clockwise--regular'
102
79
  label='Test'
@@ -9,7 +9,7 @@ import { withTheme } from '../testing';
9
9
 
10
10
  const DefaultStory = () => {
11
11
  return (
12
- <div className='mli-auto p-8 max-is-[60rem] space-b-4'>
12
+ <div className='mx-auto p-8 max-w-[60rem] space-b-4'>
13
13
  <h1 className='text-4xl font-medium'>
14
14
  Việc <span className='italic'>thừa</span> nhận{' '}
15
15
  <span className='font-mono bg-neutral-500/10'>