@blenx-dev/components 0.0.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 (648) hide show
  1. package/.turbo/turbo-check-types.log +1 -0
  2. package/MIGRATION-PLAN.md +423 -0
  3. package/TASKS.md +192 -0
  4. package/blenx-dev-ui-0.0.0.tgz +0 -0
  5. package/dist/assets/components.css +8407 -0
  6. package/dist/components/Accordion/accordion.css.js +13 -0
  7. package/dist/components/Accordion/accordion.js +54 -0
  8. package/dist/components/Alert/alert.css.js +17 -0
  9. package/dist/components/Alert/alert.js +38 -0
  10. package/dist/components/AlertDialog/alert-dialog.css.js +18 -0
  11. package/dist/components/AlertDialog/alert-dialog.js +117 -0
  12. package/dist/components/Autocomplete/autocomplete.css.js +28 -0
  13. package/dist/components/Autocomplete/autocomplete.js +157 -0
  14. package/dist/components/Avatar/avatar.css.js +37 -0
  15. package/dist/components/Avatar/avatar.js +28 -0
  16. package/dist/components/Badge/badge.css.js +19 -0
  17. package/dist/components/Badge/badge.js +14 -0
  18. package/dist/components/Box/box.css.js +6 -0
  19. package/dist/components/Box/box.js +18 -0
  20. package/dist/components/Breadcrumbs/breadcrumbs.css.js +13 -0
  21. package/dist/components/Breadcrumbs/breadcrumbs.js +73 -0
  22. package/dist/components/Button/button.css.js +37 -0
  23. package/dist/components/Button/button.js +28 -0
  24. package/dist/components/Calendar/calendar.css.js +23 -0
  25. package/dist/components/Calendar/calendar.js +104 -0
  26. package/dist/components/Card/card.js +46 -0
  27. package/dist/components/Checkbox/checkbox.css.js +13 -0
  28. package/dist/components/Checkbox/checkbox.js +59 -0
  29. package/dist/components/CloseButton/close-button.css.js +5 -0
  30. package/dist/components/CloseButton/close-button.js +27 -0
  31. package/dist/components/CloseButton/index.js +1 -0
  32. package/dist/components/ColorPicker/color-picker.js +103 -0
  33. package/dist/components/ColorSwatch/color-swatch.js +16 -0
  34. package/dist/components/Combobox/combobox.css.js +36 -0
  35. package/dist/components/Combobox/combobox.js +236 -0
  36. package/dist/components/Command/command.css.js +18 -0
  37. package/dist/components/Command/command.js +264 -0
  38. package/dist/components/Container/container.css.js +28 -0
  39. package/dist/components/Container/container.js +18 -0
  40. package/dist/components/CopyButton/copy-button.css.js +5 -0
  41. package/dist/components/CopyButton/copy-button.js +41 -0
  42. package/dist/components/CopyButton/index.js +1 -0
  43. package/dist/components/Dialog/dialog.css.js +19 -0
  44. package/dist/components/Dialog/dialog.js +112 -0
  45. package/dist/components/Drawer/drawer.css.js +60 -0
  46. package/dist/components/Drawer/drawer.js +307 -0
  47. package/dist/components/Field/field.css.js +11 -0
  48. package/dist/components/Field/field.js +50 -0
  49. package/dist/components/Grid/grid.css.js +19 -0
  50. package/dist/components/Grid/grid.js +31 -0
  51. package/dist/components/Icon/icon.css.js +5 -0
  52. package/dist/components/Icon/icon.js +15 -0
  53. package/dist/components/IconButton/icon-button.css.js +5 -0
  54. package/dist/components/IconButton/icon-button.js +14 -0
  55. package/dist/components/IconButton/index.js +1 -0
  56. package/dist/components/Input/input.css.js +11 -0
  57. package/dist/components/Input/input.js +31 -0
  58. package/dist/components/InputGroup/input-group.css.js +16 -0
  59. package/dist/components/InputGroup/input-group.js +70 -0
  60. package/dist/components/Menu/menu.css.js +14 -0
  61. package/dist/components/Menu/menu.js +54 -0
  62. package/dist/components/OTPField/otp-field.css.js +18 -0
  63. package/dist/components/OTPField/otp-field.js +23 -0
  64. package/dist/components/Popover/popover.css.js +13 -0
  65. package/dist/components/Popover/popover.js +89 -0
  66. package/dist/components/Progress/progress.css.js +11 -0
  67. package/dist/components/Progress/progress.js +44 -0
  68. package/dist/components/Radio/radio.css.js +12 -0
  69. package/dist/components/Radio/radio.js +32 -0
  70. package/dist/components/ScrollArea/scroll-area.css.js +15 -0
  71. package/dist/components/ScrollArea/scroll-area.js +50 -0
  72. package/dist/components/SegmentedControl/segmented-control.js +21 -0
  73. package/dist/components/Select/select.css.js +17 -0
  74. package/dist/components/Select/select.js +129 -0
  75. package/dist/components/Separator/separator.css.js +27 -0
  76. package/dist/components/Separator/separator.js +27 -0
  77. package/dist/components/Sheet/sheet.css.js +27 -0
  78. package/dist/components/Sheet/sheet.js +112 -0
  79. package/dist/components/Slider/slider.css.js +17 -0
  80. package/dist/components/Slider/slider.js +55 -0
  81. package/dist/components/Spinner/spinner.css.js +5 -0
  82. package/dist/components/Spinner/spinner.js +15 -0
  83. package/dist/components/Splitter/splitter.css.js +15 -0
  84. package/dist/components/Splitter/splitter.js +313 -0
  85. package/dist/components/Stack/stack.css.js +44 -0
  86. package/dist/components/Stack/stack.js +32 -0
  87. package/dist/components/Surface/surface.css.js +20 -0
  88. package/dist/components/Surface/surface.js +17 -0
  89. package/dist/components/Switch/switch.css.js +11 -0
  90. package/dist/components/Switch/switch.js +18 -0
  91. package/dist/components/Table/table.css.js +16 -0
  92. package/dist/components/Table/table.js +44 -0
  93. package/dist/components/Tabs/tabs.css.js +23 -0
  94. package/dist/components/Tabs/tabs.js +47 -0
  95. package/dist/components/Text/index.js +1 -0
  96. package/dist/components/Text/text.css.js +61 -0
  97. package/dist/components/Text/text.js +51 -0
  98. package/dist/components/Textarea/textarea.css.js +9 -0
  99. package/dist/components/Textarea/textarea.js +31 -0
  100. package/dist/components/Toggle/toggle.css.js +46 -0
  101. package/dist/components/Toggle/toggle.js +22 -0
  102. package/dist/components/ToggleGroup/toggle-group.css.js +13 -0
  103. package/dist/components/ToggleGroup/toggle-group.js +63 -0
  104. package/dist/components/index.js +52 -0
  105. package/dist/index.js +52 -0
  106. package/dist/node_modules/.bun/@vanilla-extract_recipes@0.5.7_19e937df7e0b57ed/node_modules/@vanilla-extract/recipes/dist/createRuntimeFn-62c9670f.esm.js +89 -0
  107. package/dist/node_modules/.bun/@vanilla-extract_sprinkles@1.6.5_19e937df7e0b57ed/node_modules/@vanilla-extract/sprinkles/createRuntimeSprinkles/dist/vanilla-extract-sprinkles-createRuntimeSprinkles.esm.js +8 -0
  108. package/dist/node_modules/.bun/@vanilla-extract_sprinkles@1.6.5_19e937df7e0b57ed/node_modules/@vanilla-extract/sprinkles/dist/createSprinkles-74286718.esm.js +141 -0
  109. package/dist/node_modules/.bun/clsx@2.1.1/node_modules/clsx/dist/clsx.js +16 -0
  110. package/dist/package.json +232 -0
  111. package/dist/src/DataTable/data-table-column-toggle.d.ts +6 -0
  112. package/dist/src/DataTable/data-table-empty.d.ts +7 -0
  113. package/dist/src/DataTable/data-table-error.d.ts +6 -0
  114. package/dist/src/DataTable/data-table-infinite-loader.d.ts +10 -0
  115. package/dist/src/DataTable/data-table-loading.d.ts +8 -0
  116. package/dist/src/DataTable/data-table-pagination.d.ts +6 -0
  117. package/dist/src/DataTable/data-table-toolbar.d.ts +13 -0
  118. package/dist/src/DataTable/data-table.css.d.ts +58 -0
  119. package/dist/src/DataTable/data-table.d.ts +2 -0
  120. package/dist/src/DataTable/index.d.ts +10 -0
  121. package/dist/src/DataTable/types.d.ts +106 -0
  122. package/dist/src/DataTable/use-infinite-scroll.d.ts +28 -0
  123. package/dist/src/components/Accordion/accordion.css.d.ts +7 -0
  124. package/dist/src/components/Accordion/accordion.d.ts +20 -0
  125. package/dist/src/components/Accordion/accordion.demo.d.ts +5 -0
  126. package/dist/src/components/Accordion/index.d.ts +1 -0
  127. package/dist/src/components/Alert/alert.css.d.ts +24 -0
  128. package/dist/src/components/Alert/alert.d.ts +13 -0
  129. package/dist/src/components/Alert/alert.demo.d.ts +6 -0
  130. package/dist/src/components/Alert/index.d.ts +1 -0
  131. package/dist/src/components/AlertDialog/alert-dialog.css.d.ts +13 -0
  132. package/dist/src/components/AlertDialog/alert-dialog.d.ts +30 -0
  133. package/dist/src/components/AlertDialog/alert-dialog.demo.d.ts +5 -0
  134. package/dist/src/components/AlertDialog/alert-dialog.doc.d.ts +1 -0
  135. package/dist/src/components/AlertDialog/index.d.ts +1 -0
  136. package/dist/src/components/Autocomplete/autocomplete.css.d.ts +23 -0
  137. package/dist/src/components/Autocomplete/autocomplete.d.ts +34 -0
  138. package/dist/src/components/Autocomplete/index.d.ts +1 -0
  139. package/dist/src/components/Avatar/avatar.css.d.ts +55 -0
  140. package/dist/src/components/Avatar/avatar.d.ts +20 -0
  141. package/dist/src/components/Avatar/avatar.doc.d.ts +2 -0
  142. package/dist/src/components/Avatar/index.d.ts +1 -0
  143. package/dist/src/components/Badge/badge.css.d.ts +24 -0
  144. package/dist/src/components/Badge/badge.d.ts +7 -0
  145. package/dist/src/components/Badge/badge.demo.d.ts +5 -0
  146. package/dist/src/components/Badge/badge.doc.d.ts +1 -0
  147. package/dist/src/components/Badge/index.d.ts +1 -0
  148. package/dist/src/components/Box/box.css.d.ts +1 -0
  149. package/dist/src/components/Box/box.d.ts +6 -0
  150. package/dist/src/components/Box/box.doc.d.ts +1 -0
  151. package/dist/src/components/Box/index.d.ts +1 -0
  152. package/dist/src/components/Breadcrumbs/breadcrumbs.css.d.ts +8 -0
  153. package/dist/src/components/Breadcrumbs/breadcrumbs.d.ts +30 -0
  154. package/dist/src/components/Breadcrumbs/breadcrumbs.doc.d.ts +2 -0
  155. package/dist/src/components/Breadcrumbs/index.d.ts +1 -0
  156. package/dist/src/components/Button/button.css.d.ts +179 -0
  157. package/dist/src/components/Button/button.d.ts +13 -0
  158. package/dist/src/components/Button/button.demo.d.ts +5 -0
  159. package/dist/src/components/Button/index.d.ts +1 -0
  160. package/dist/src/components/Calendar/calendar.css.d.ts +17 -0
  161. package/dist/src/components/Calendar/calendar.d.ts +3 -0
  162. package/dist/src/components/Calendar/calendar.doc.d.ts +1 -0
  163. package/dist/src/components/Calendar/index.d.ts +1 -0
  164. package/dist/src/components/Card/card.d.ts +12 -0
  165. package/dist/src/components/Card/card.demo.d.ts +8 -0
  166. package/dist/src/components/Card/card.doc.d.ts +2 -0
  167. package/dist/src/components/Card/index.d.ts +1 -0
  168. package/dist/src/components/Checkbox/checkbox.css.d.ts +7 -0
  169. package/dist/src/components/Checkbox/checkbox.d.ts +13 -0
  170. package/dist/src/components/Checkbox/index.d.ts +1 -0
  171. package/dist/src/components/CloseButton/close-button.css.d.ts +1 -0
  172. package/dist/src/components/CloseButton/close-button.d.ts +3 -0
  173. package/dist/src/components/CloseButton/index.d.ts +2 -0
  174. package/dist/src/components/ColorPicker/color-picker.d.ts +7 -0
  175. package/dist/src/components/ColorPicker/color-picker.doc.d.ts +1 -0
  176. package/dist/src/components/ColorPicker/index.d.ts +1 -0
  177. package/dist/src/components/ColorSwatch/color-swatch.d.ts +8 -0
  178. package/dist/src/components/ColorSwatch/color-swatch.doc.d.ts +2 -0
  179. package/dist/src/components/ColorSwatch/index.d.ts +1 -0
  180. package/dist/src/components/Combobox/combobox.css.d.ts +32 -0
  181. package/dist/src/components/Combobox/combobox.d.ts +52 -0
  182. package/dist/src/components/Combobox/index.d.ts +1 -0
  183. package/dist/src/components/Command/command.css.d.ts +12 -0
  184. package/dist/src/components/Command/command.d.ts +48 -0
  185. package/dist/src/components/Command/command.demo.d.ts +6 -0
  186. package/dist/src/components/Command/command.doc.d.ts +3 -0
  187. package/dist/src/components/Command/index.d.ts +7 -0
  188. package/dist/src/components/Container/container.css.d.ts +48 -0
  189. package/dist/src/components/Container/container.d.ts +8 -0
  190. package/dist/src/components/Container/container.doc.d.ts +1 -0
  191. package/dist/src/components/Container/index.d.ts +1 -0
  192. package/dist/src/components/CopyButton/copy-button.css.d.ts +1 -0
  193. package/dist/src/components/CopyButton/copy-button.d.ts +7 -0
  194. package/dist/src/components/CopyButton/index.d.ts +2 -0
  195. package/dist/src/components/DatePicker/date-picker.d.ts +11 -0
  196. package/dist/src/components/DatePicker/date-picker.doc.d.ts +1 -0
  197. package/dist/src/components/DatePicker/index.d.ts +1 -0
  198. package/dist/src/components/Dialog/dialog.css.d.ts +13 -0
  199. package/dist/src/components/Dialog/dialog.d.ts +32 -0
  200. package/dist/src/components/Dialog/dialog.demo.d.ts +5 -0
  201. package/dist/src/components/Dialog/dialog.doc.d.ts +1 -0
  202. package/dist/src/components/Dialog/index.d.ts +1 -0
  203. package/dist/src/components/Drawer/drawer.css.d.ts +54 -0
  204. package/dist/src/components/Drawer/drawer.d.ts +66 -0
  205. package/dist/src/components/Drawer/drawer.demo.d.ts +5 -0
  206. package/dist/src/components/Drawer/drawer.doc.d.ts +2 -0
  207. package/dist/src/components/Drawer/index.d.ts +1 -0
  208. package/dist/src/components/Field/field.css.d.ts +5 -0
  209. package/dist/src/components/Field/field.d.ts +25 -0
  210. package/dist/src/components/Field/field.doc.d.ts +1 -0
  211. package/dist/src/components/Field/index.d.ts +1 -0
  212. package/dist/src/components/Grid/grid.css.d.ts +4 -0
  213. package/dist/src/components/Grid/grid.d.ts +11 -0
  214. package/dist/src/components/Grid/grid.doc.d.ts +1 -0
  215. package/dist/src/components/Grid/index.d.ts +1 -0
  216. package/dist/src/components/Icon/icon.css.d.ts +1 -0
  217. package/dist/src/components/Icon/icon.d.ts +4 -0
  218. package/dist/src/components/Icon/icon.demo.d.ts +5 -0
  219. package/dist/src/components/Icon/index.d.ts +1 -0
  220. package/dist/src/components/IconButton/icon-button.css.d.ts +1 -0
  221. package/dist/src/components/IconButton/icon-button.d.ts +4 -0
  222. package/dist/src/components/IconButton/icon-button.demo.d.ts +5 -0
  223. package/dist/src/components/IconButton/index.d.ts +2 -0
  224. package/dist/src/components/Input/index.d.ts +1 -0
  225. package/dist/src/components/Input/input.css.d.ts +6 -0
  226. package/dist/src/components/Input/input.d.ts +19 -0
  227. package/dist/src/components/Input/input.demo.d.ts +5 -0
  228. package/dist/src/components/Input/input.doc.d.ts +2 -0
  229. package/dist/src/components/InputGroup/index.d.ts +1 -0
  230. package/dist/src/components/InputGroup/input-group.css.d.ts +10 -0
  231. package/dist/src/components/InputGroup/input-group.d.ts +25 -0
  232. package/dist/src/components/InputGroup/input-group.demo.d.ts +5 -0
  233. package/dist/src/components/Menu/index.d.ts +1 -0
  234. package/dist/src/components/Menu/menu.css.d.ts +8 -0
  235. package/dist/src/components/Menu/menu.d.ts +41 -0
  236. package/dist/src/components/Menu/menu.demo.d.ts +5 -0
  237. package/dist/src/components/OTPField/index.d.ts +1 -0
  238. package/dist/src/components/OTPField/otp-field.css.d.ts +16 -0
  239. package/dist/src/components/OTPField/otp-field.d.ts +18 -0
  240. package/dist/src/components/OTPField/otp-field.demo.d.ts +6 -0
  241. package/dist/src/components/Popover/index.d.ts +1 -0
  242. package/dist/src/components/Popover/popover.css.d.ts +7 -0
  243. package/dist/src/components/Popover/popover.d.ts +33 -0
  244. package/dist/src/components/Popover/popover.demo.d.ts +5 -0
  245. package/dist/src/components/Progress/index.d.ts +1 -0
  246. package/dist/src/components/Progress/progress.css.d.ts +5 -0
  247. package/dist/src/components/Progress/progress.d.ts +13 -0
  248. package/dist/src/components/Radio/index.d.ts +1 -0
  249. package/dist/src/components/Radio/radio.css.d.ts +6 -0
  250. package/dist/src/components/Radio/radio.d.ts +13 -0
  251. package/dist/src/components/ScrollArea/index.d.ts +1 -0
  252. package/dist/src/components/ScrollArea/scroll-area.css.d.ts +9 -0
  253. package/dist/src/components/ScrollArea/scroll-area.d.ts +19 -0
  254. package/dist/src/components/ScrollArea/scroll-area.doc.d.ts +2 -0
  255. package/dist/src/components/SegmentedControl/index.d.ts +1 -0
  256. package/dist/src/components/SegmentedControl/segmented-control.d.ts +14 -0
  257. package/dist/src/components/SegmentedControl/segmented-control.doc.d.ts +1 -0
  258. package/dist/src/components/Select/index.d.ts +1 -0
  259. package/dist/src/components/Select/select.css.d.ts +11 -0
  260. package/dist/src/components/Select/select.d.ts +54 -0
  261. package/dist/src/components/Select/select.demo.d.ts +5 -0
  262. package/dist/src/components/Select/select.doc.d.ts +2 -0
  263. package/dist/src/components/Separator/index.d.ts +1 -0
  264. package/dist/src/components/Separator/separator.css.d.ts +22 -0
  265. package/dist/src/components/Separator/separator.d.ts +13 -0
  266. package/dist/src/components/Separator/separator.doc.d.ts +4 -0
  267. package/dist/src/components/Sheet/index.d.ts +1 -0
  268. package/dist/src/components/Sheet/sheet.css.d.ts +21 -0
  269. package/dist/src/components/Sheet/sheet.d.ts +35 -0
  270. package/dist/src/components/Sheet/sheet.demo.d.ts +5 -0
  271. package/dist/src/components/Slider/index.d.ts +1 -0
  272. package/dist/src/components/Slider/slider.css.d.ts +11 -0
  273. package/dist/src/components/Slider/slider.d.ts +11 -0
  274. package/dist/src/components/Spinner/index.d.ts +1 -0
  275. package/dist/src/components/Spinner/spinner.css.d.ts +2 -0
  276. package/dist/src/components/Spinner/spinner.d.ts +8 -0
  277. package/dist/src/components/Spinner/spinner.demo.d.ts +1 -0
  278. package/dist/src/components/Splitter/index.d.ts +1 -0
  279. package/dist/src/components/Splitter/splitter.css.d.ts +11 -0
  280. package/dist/src/components/Splitter/splitter.d.ts +36 -0
  281. package/dist/src/components/Stack/index.d.ts +1 -0
  282. package/dist/src/components/Stack/stack.css.d.ts +82 -0
  283. package/dist/src/components/Stack/stack.d.ts +11 -0
  284. package/dist/src/components/Stack/stack.doc.d.ts +3 -0
  285. package/dist/src/components/Surface/index.d.ts +1 -0
  286. package/dist/src/components/Surface/surface.css.d.ts +34 -0
  287. package/dist/src/components/Surface/surface.d.ts +7 -0
  288. package/dist/src/components/Surface/surface.doc.d.ts +2 -0
  289. package/dist/src/components/Switch/index.d.ts +1 -0
  290. package/dist/src/components/Switch/switch.css.d.ts +5 -0
  291. package/dist/src/components/Switch/switch.d.ts +7 -0
  292. package/dist/src/components/Switch/switch.demo.d.ts +5 -0
  293. package/dist/src/components/Switch/switch.doc.d.ts +2 -0
  294. package/dist/src/components/Table/index.d.ts +2 -0
  295. package/dist/src/components/Table/table.css.d.ts +10 -0
  296. package/dist/src/components/Table/table.d.ts +24 -0
  297. package/dist/src/components/Table/table.demo.d.ts +5 -0
  298. package/dist/src/components/Tabs/index.d.ts +1 -0
  299. package/dist/src/components/Tabs/tabs.css.d.ts +27 -0
  300. package/dist/src/components/Tabs/tabs.d.ts +15 -0
  301. package/dist/src/components/Tabs/tabs.demo.d.ts +5 -0
  302. package/dist/src/components/Tabs/tabs.doc.d.ts +3 -0
  303. package/dist/src/components/Text/index.d.ts +2 -0
  304. package/dist/src/components/Text/text.css.d.ts +204 -0
  305. package/dist/src/components/Text/text.d.ts +9 -0
  306. package/dist/src/components/Text/text.doc.d.ts +4 -0
  307. package/dist/src/components/Textarea/index.d.ts +1 -0
  308. package/dist/src/components/Textarea/textarea.css.d.ts +4 -0
  309. package/dist/src/components/Textarea/textarea.d.ts +7 -0
  310. package/dist/src/components/Textarea/textarea.doc.d.ts +2 -0
  311. package/dist/src/components/Toggle/index.d.ts +1 -0
  312. package/dist/src/components/Toggle/toggle.css.d.ts +68 -0
  313. package/dist/src/components/Toggle/toggle.d.ts +12 -0
  314. package/dist/src/components/Toggle/toggle.doc.d.ts +1 -0
  315. package/dist/src/components/ToggleGroup/index.d.ts +1 -0
  316. package/dist/src/components/ToggleGroup/toggle-group.css.d.ts +7 -0
  317. package/dist/src/components/ToggleGroup/toggle-group.d.ts +31 -0
  318. package/dist/src/components/ToggleGroup/toggle-group.doc.d.ts +3 -0
  319. package/dist/src/components/index.d.ts +49 -0
  320. package/dist/src/demos/accordion.demo.d.ts +5 -0
  321. package/dist/src/index.d.ts +2 -0
  322. package/dist/src/utils/heights.d.ts +2 -0
  323. package/dist/src/utils/sprinkles.css.d.ts +515 -0
  324. package/dist/src/utils/types.d.ts +8 -0
  325. package/dist/src/utils/ve-style.utils.d.ts +1 -0
  326. package/dist/utils/sprinkles.css.js +5350 -0
  327. package/dist/utils/ve-style.utils.js +21 -0
  328. package/package.build.json +39 -0
  329. package/package.json +60 -0
  330. package/scripts/generate-api.ts +183 -0
  331. package/scripts/generate-package.ts +99 -0
  332. package/src/DataTable/data-table-column-toggle.tsx +73 -0
  333. package/src/DataTable/data-table-empty.tsx +27 -0
  334. package/src/DataTable/data-table-error.tsx +25 -0
  335. package/src/DataTable/data-table-infinite-loader.tsx +73 -0
  336. package/src/DataTable/data-table-loading.tsx +67 -0
  337. package/src/DataTable/data-table-pagination.tsx +80 -0
  338. package/src/DataTable/data-table-toolbar.tsx +62 -0
  339. package/src/DataTable/data-table.css.ts +421 -0
  340. package/src/DataTable/data-table.tsx +507 -0
  341. package/src/DataTable/index.ts +24 -0
  342. package/src/DataTable/registry-meta.json +66 -0
  343. package/src/DataTable/types.ts +169 -0
  344. package/src/DataTable/use-infinite-scroll.ts +67 -0
  345. package/src/components/Accordion/accordion.css.ts +93 -0
  346. package/src/components/Accordion/accordion.demo.tsx +42 -0
  347. package/src/components/Accordion/accordion.tsx +87 -0
  348. package/src/components/Accordion/docs-meta.json +13 -0
  349. package/src/components/Accordion/index.ts +8 -0
  350. package/src/components/Accordion/registry-meta.json +19 -0
  351. package/src/components/Alert/alert.css.ts +29 -0
  352. package/src/components/Alert/alert.demo.tsx +34 -0
  353. package/src/components/Alert/alert.tsx +40 -0
  354. package/src/components/Alert/docs-meta.json +12 -0
  355. package/src/components/Alert/index.ts +1 -0
  356. package/src/components/Alert/registry-meta.json +20 -0
  357. package/src/components/AlertDialog/alert-dialog.css.ts +146 -0
  358. package/src/components/AlertDialog/alert-dialog.demo.tsx +59 -0
  359. package/src/components/AlertDialog/alert-dialog.doc.tsx +31 -0
  360. package/src/components/AlertDialog/alert-dialog.tsx +197 -0
  361. package/src/components/AlertDialog/docs-meta.json +14 -0
  362. package/src/components/AlertDialog/index.ts +1 -0
  363. package/src/components/AlertDialog/registry-meta.json +20 -0
  364. package/src/components/Autocomplete/autocomplete.css.ts +168 -0
  365. package/src/components/Autocomplete/autocomplete.tsx +226 -0
  366. package/src/components/Autocomplete/docs-meta.json +9 -0
  367. package/src/components/Autocomplete/index.ts +1 -0
  368. package/src/components/Autocomplete/registry-meta.json +20 -0
  369. package/src/components/Avatar/avatar.css.ts +72 -0
  370. package/src/components/Avatar/avatar.doc.tsx +32 -0
  371. package/src/components/Avatar/avatar.tsx +49 -0
  372. package/src/components/Avatar/docs-meta.json +9 -0
  373. package/src/components/Avatar/index.ts +1 -0
  374. package/src/components/Avatar/registry-meta.json +19 -0
  375. package/src/components/Badge/badge.css.ts +40 -0
  376. package/src/components/Badge/badge.demo.tsx +18 -0
  377. package/src/components/Badge/badge.doc.tsx +12 -0
  378. package/src/components/Badge/badge.tsx +13 -0
  379. package/src/components/Badge/docs-meta.json +9 -0
  380. package/src/components/Badge/index.ts +1 -0
  381. package/src/components/Badge/registry-meta.json +19 -0
  382. package/src/components/Box/box.css.ts +7 -0
  383. package/src/components/Box/box.doc.tsx +19 -0
  384. package/src/components/Box/box.tsx +21 -0
  385. package/src/components/Box/docs-meta.json +9 -0
  386. package/src/components/Box/index.ts +1 -0
  387. package/src/components/Box/registry-meta.json +14 -0
  388. package/src/components/Breadcrumbs/breadcrumbs.css.ts +72 -0
  389. package/src/components/Breadcrumbs/breadcrumbs.doc.tsx +61 -0
  390. package/src/components/Breadcrumbs/breadcrumbs.tsx +79 -0
  391. package/src/components/Breadcrumbs/docs-meta.json +12 -0
  392. package/src/components/Breadcrumbs/index.ts +9 -0
  393. package/src/components/Breadcrumbs/registry-meta.json +19 -0
  394. package/src/components/Button/button.css.ts +209 -0
  395. package/src/components/Button/button.demo.tsx +119 -0
  396. package/src/components/Button/button.tsx +55 -0
  397. package/src/components/Button/docs-meta.json +13 -0
  398. package/src/components/Button/index.ts +1 -0
  399. package/src/components/Button/registry-meta.json +20 -0
  400. package/src/components/Calendar/calendar.css.ts +188 -0
  401. package/src/components/Calendar/calendar.doc.tsx +10 -0
  402. package/src/components/Calendar/calendar.tsx +143 -0
  403. package/src/components/Calendar/docs-meta.json +9 -0
  404. package/src/components/Calendar/index.ts +1 -0
  405. package/src/components/Calendar/registry-meta.json +20 -0
  406. package/src/components/Card/card.demo.tsx +177 -0
  407. package/src/components/Card/card.doc.tsx +47 -0
  408. package/src/components/Card/card.tsx +32 -0
  409. package/src/components/Card/docs-meta.json +9 -0
  410. package/src/components/Card/index.ts +1 -0
  411. package/src/components/Card/registry-meta.json +15 -0
  412. package/src/components/Checkbox/checkbox.css.ts +77 -0
  413. package/src/components/Checkbox/checkbox.tsx +94 -0
  414. package/src/components/Checkbox/docs-meta.json +13 -0
  415. package/src/components/Checkbox/index.ts +1 -0
  416. package/src/components/Checkbox/registry-meta.json +19 -0
  417. package/src/components/CloseButton/close-button.css.ts +11 -0
  418. package/src/components/CloseButton/close-button.tsx +15 -0
  419. package/src/components/CloseButton/index.ts +2 -0
  420. package/src/components/CloseButton/registry-meta.json +15 -0
  421. package/src/components/ColorPicker/color-picker.doc.tsx +12 -0
  422. package/src/components/ColorPicker/color-picker.tsx +123 -0
  423. package/src/components/ColorPicker/docs-meta.json +9 -0
  424. package/src/components/ColorPicker/index.ts +1 -0
  425. package/src/components/ColorPicker/registry-meta.json +15 -0
  426. package/src/components/ColorSwatch/color-swatch.doc.tsx +25 -0
  427. package/src/components/ColorSwatch/color-swatch.tsx +21 -0
  428. package/src/components/ColorSwatch/docs-meta.json +9 -0
  429. package/src/components/ColorSwatch/index.ts +1 -0
  430. package/src/components/ColorSwatch/registry-meta.json +20 -0
  431. package/src/components/Combobox/combobox.css.ts +334 -0
  432. package/src/components/Combobox/combobox.tsx +350 -0
  433. package/src/components/Combobox/docs-meta.json +9 -0
  434. package/src/components/Combobox/index.ts +1 -0
  435. package/src/components/Combobox/registry-meta.json +20 -0
  436. package/src/components/Command/command.css.ts +131 -0
  437. package/src/components/Command/command.demo.tsx +110 -0
  438. package/src/components/Command/command.doc.tsx +100 -0
  439. package/src/components/Command/command.tsx +413 -0
  440. package/src/components/Command/docs-meta.json +21 -0
  441. package/src/components/Command/index.ts +7 -0
  442. package/src/components/Command/registry-meta.json +20 -0
  443. package/src/components/Container/container.css.ts +40 -0
  444. package/src/components/Container/container.doc.tsx +28 -0
  445. package/src/components/Container/container.tsx +24 -0
  446. package/src/components/Container/docs-meta.json +9 -0
  447. package/src/components/Container/index.ts +1 -0
  448. package/src/components/Container/registry-meta.json +20 -0
  449. package/src/components/CopyButton/copy-button.css.ts +11 -0
  450. package/src/components/CopyButton/copy-button.tsx +45 -0
  451. package/src/components/CopyButton/index.ts +2 -0
  452. package/src/components/CopyButton/registry-meta.json +15 -0
  453. package/src/components/DatePicker/date-picker.doc.tsx +12 -0
  454. package/src/components/DatePicker/date-picker.tsx +75 -0
  455. package/src/components/DatePicker/docs-meta.json +9 -0
  456. package/src/components/DatePicker/index.ts +1 -0
  457. package/src/components/DatePicker/registry-meta.json +15 -0
  458. package/src/components/Dialog/dialog.css.ts +155 -0
  459. package/src/components/Dialog/dialog.demo.tsx +39 -0
  460. package/src/components/Dialog/dialog.doc.tsx +33 -0
  461. package/src/components/Dialog/dialog.tsx +186 -0
  462. package/src/components/Dialog/docs-meta.json +13 -0
  463. package/src/components/Dialog/index.ts +1 -0
  464. package/src/components/Dialog/registry-meta.json +20 -0
  465. package/src/components/Drawer/docs-meta.json +9 -0
  466. package/src/components/Drawer/drawer.css.ts +412 -0
  467. package/src/components/Drawer/drawer.demo.tsx +58 -0
  468. package/src/components/Drawer/drawer.doc.tsx +49 -0
  469. package/src/components/Drawer/drawer.tsx +574 -0
  470. package/src/components/Drawer/index.ts +1 -0
  471. package/src/components/Drawer/registry-meta.json +20 -0
  472. package/src/components/Field/docs-meta.json +9 -0
  473. package/src/components/Field/field.css.ts +35 -0
  474. package/src/components/Field/field.doc.tsx +19 -0
  475. package/src/components/Field/field.tsx +101 -0
  476. package/src/components/Field/index.ts +1 -0
  477. package/src/components/Field/registry-meta.json +20 -0
  478. package/src/components/Grid/docs-meta.json +9 -0
  479. package/src/components/Grid/grid.css.ts +12 -0
  480. package/src/components/Grid/grid.doc.tsx +148 -0
  481. package/src/components/Grid/grid.tsx +57 -0
  482. package/src/components/Grid/index.ts +1 -0
  483. package/src/components/Grid/registry-meta.json +20 -0
  484. package/src/components/Icon/docs-meta.json +13 -0
  485. package/src/components/Icon/icon.css.ts +10 -0
  486. package/src/components/Icon/icon.demo.tsx +97 -0
  487. package/src/components/Icon/icon.tsx +15 -0
  488. package/src/components/Icon/index.ts +1 -0
  489. package/src/components/Icon/registry-meta.json +20 -0
  490. package/src/components/IconButton/docs-meta.json +13 -0
  491. package/src/components/IconButton/icon-button.css.ts +6 -0
  492. package/src/components/IconButton/icon-button.demo.tsx +102 -0
  493. package/src/components/IconButton/icon-button.tsx +11 -0
  494. package/src/components/IconButton/index.ts +2 -0
  495. package/src/components/IconButton/registry-meta.json +15 -0
  496. package/src/components/Input/docs-meta.json +9 -0
  497. package/src/components/Input/index.ts +1 -0
  498. package/src/components/Input/input.css.ts +73 -0
  499. package/src/components/Input/input.demo.tsx +24 -0
  500. package/src/components/Input/input.doc.tsx +25 -0
  501. package/src/components/Input/input.tsx +50 -0
  502. package/src/components/Input/registry-meta.json +19 -0
  503. package/src/components/InputGroup/docs-meta.json +9 -0
  504. package/src/components/InputGroup/index.ts +1 -0
  505. package/src/components/InputGroup/input-group.css.ts +157 -0
  506. package/src/components/InputGroup/input-group.demo.tsx +53 -0
  507. package/src/components/InputGroup/input-group.tsx +133 -0
  508. package/src/components/InputGroup/registry-meta.json +19 -0
  509. package/src/components/Menu/docs-meta.json +13 -0
  510. package/src/components/Menu/index.ts +1 -0
  511. package/src/components/Menu/menu.css.ts +128 -0
  512. package/src/components/Menu/menu.demo.tsx +40 -0
  513. package/src/components/Menu/menu.tsx +115 -0
  514. package/src/components/Menu/registry-meta.json +19 -0
  515. package/src/components/OTPField/docs-meta.json +9 -0
  516. package/src/components/OTPField/index.ts +1 -0
  517. package/src/components/OTPField/otp-field.css.ts +55 -0
  518. package/src/components/OTPField/otp-field.demo.tsx +57 -0
  519. package/src/components/OTPField/otp-field.tsx +46 -0
  520. package/src/components/OTPField/registry-meta.json +19 -0
  521. package/src/components/Popover/docs-meta.json +13 -0
  522. package/src/components/Popover/index.ts +1 -0
  523. package/src/components/Popover/popover.css.ts +82 -0
  524. package/src/components/Popover/popover.demo.tsx +34 -0
  525. package/src/components/Popover/popover.tsx +113 -0
  526. package/src/components/Popover/registry-meta.json +19 -0
  527. package/src/components/Progress/docs-meta.json +12 -0
  528. package/src/components/Progress/index.ts +7 -0
  529. package/src/components/Progress/progress.css.ts +38 -0
  530. package/src/components/Progress/progress.tsx +62 -0
  531. package/src/components/Progress/registry-meta.json +19 -0
  532. package/src/components/Radio/docs-meta.json +13 -0
  533. package/src/components/Radio/index.ts +1 -0
  534. package/src/components/Radio/radio.css.ts +73 -0
  535. package/src/components/Radio/radio.tsx +49 -0
  536. package/src/components/Radio/registry-meta.json +19 -0
  537. package/src/components/ScrollArea/docs-meta.json +9 -0
  538. package/src/components/ScrollArea/index.ts +1 -0
  539. package/src/components/ScrollArea/registry-meta.json +19 -0
  540. package/src/components/ScrollArea/scroll-area.css.ts +80 -0
  541. package/src/components/ScrollArea/scroll-area.doc.tsx +44 -0
  542. package/src/components/ScrollArea/scroll-area.tsx +96 -0
  543. package/src/components/SegmentedControl/docs-meta.json +9 -0
  544. package/src/components/SegmentedControl/index.ts +1 -0
  545. package/src/components/SegmentedControl/registry-meta.json +15 -0
  546. package/src/components/SegmentedControl/segmented-control.doc.tsx +28 -0
  547. package/src/components/SegmentedControl/segmented-control.tsx +42 -0
  548. package/src/components/Select/docs-meta.json +13 -0
  549. package/src/components/Select/index.ts +1 -0
  550. package/src/components/Select/registry-meta.json +20 -0
  551. package/src/components/Select/select.css.ts +183 -0
  552. package/src/components/Select/select.demo.tsx +35 -0
  553. package/src/components/Select/select.doc.tsx +65 -0
  554. package/src/components/Select/select.tsx +165 -0
  555. package/src/components/Separator/docs-meta.json +12 -0
  556. package/src/components/Separator/index.ts +1 -0
  557. package/src/components/Separator/registry-meta.json +20 -0
  558. package/src/components/Separator/separator.css.ts +60 -0
  559. package/src/components/Separator/separator.doc.tsx +44 -0
  560. package/src/components/Separator/separator.tsx +34 -0
  561. package/src/components/Sheet/docs-meta.json +13 -0
  562. package/src/components/Sheet/index.ts +1 -0
  563. package/src/components/Sheet/registry-meta.json +20 -0
  564. package/src/components/Sheet/sheet.css.ts +192 -0
  565. package/src/components/Sheet/sheet.demo.tsx +53 -0
  566. package/src/components/Sheet/sheet.tsx +213 -0
  567. package/src/components/Slider/docs-meta.json +13 -0
  568. package/src/components/Slider/index.ts +1 -0
  569. package/src/components/Slider/registry-meta.json +19 -0
  570. package/src/components/Slider/slider.css.ts +82 -0
  571. package/src/components/Slider/slider.tsx +100 -0
  572. package/src/components/Spinner/docs-meta.json +12 -0
  573. package/src/components/Spinner/index.ts +1 -0
  574. package/src/components/Spinner/registry-meta.json +19 -0
  575. package/src/components/Spinner/spinner.css.ts +17 -0
  576. package/src/components/Spinner/spinner.demo.tsx +13 -0
  577. package/src/components/Spinner/spinner.tsx +15 -0
  578. package/src/components/Splitter/docs-meta.json +9 -0
  579. package/src/components/Splitter/index.ts +1 -0
  580. package/src/components/Splitter/registry-meta.json +19 -0
  581. package/src/components/Splitter/splitter.css.ts +70 -0
  582. package/src/components/Splitter/splitter.tsx +521 -0
  583. package/src/components/Stack/docs-meta.json +9 -0
  584. package/src/components/Stack/index.ts +1 -0
  585. package/src/components/Stack/registry-meta.json +20 -0
  586. package/src/components/Stack/stack.css.ts +42 -0
  587. package/src/components/Stack/stack.doc.tsx +57 -0
  588. package/src/components/Stack/stack.tsx +32 -0
  589. package/src/components/Surface/docs-meta.json +9 -0
  590. package/src/components/Surface/index.ts +1 -0
  591. package/src/components/Surface/registry-meta.json +20 -0
  592. package/src/components/Surface/surface.css.ts +40 -0
  593. package/src/components/Surface/surface.doc.tsx +32 -0
  594. package/src/components/Surface/surface.tsx +19 -0
  595. package/src/components/Switch/docs-meta.json +13 -0
  596. package/src/components/Switch/index.ts +1 -0
  597. package/src/components/Switch/registry-meta.json +20 -0
  598. package/src/components/Switch/switch.css.ts +47 -0
  599. package/src/components/Switch/switch.demo.tsx +26 -0
  600. package/src/components/Switch/switch.doc.tsx +25 -0
  601. package/src/components/Switch/switch.tsx +25 -0
  602. package/src/components/Table/docs-meta.json +12 -0
  603. package/src/components/Table/index.ts +2 -0
  604. package/src/components/Table/registry-meta.json +19 -0
  605. package/src/components/Table/table.css.ts +72 -0
  606. package/src/components/Table/table.demo.tsx +58 -0
  607. package/src/components/Table/table.tsx +116 -0
  608. package/src/components/Tabs/docs-meta.json +13 -0
  609. package/src/components/Tabs/index.ts +1 -0
  610. package/src/components/Tabs/registry-meta.json +19 -0
  611. package/src/components/Tabs/tabs.css.ts +259 -0
  612. package/src/components/Tabs/tabs.demo.tsx +33 -0
  613. package/src/components/Tabs/tabs.doc.tsx +62 -0
  614. package/src/components/Tabs/tabs.tsx +119 -0
  615. package/src/components/Text/docs-meta.json +9 -0
  616. package/src/components/Text/index.ts +2 -0
  617. package/src/components/Text/registry-meta.json +19 -0
  618. package/src/components/Text/text.css.ts +167 -0
  619. package/src/components/Text/text.doc.tsx +53 -0
  620. package/src/components/Text/text.tsx +64 -0
  621. package/src/components/Textarea/docs-meta.json +9 -0
  622. package/src/components/Textarea/index.ts +1 -0
  623. package/src/components/Textarea/registry-meta.json +19 -0
  624. package/src/components/Textarea/textarea.css.ts +66 -0
  625. package/src/components/Textarea/textarea.doc.tsx +23 -0
  626. package/src/components/Textarea/textarea.tsx +48 -0
  627. package/src/components/Toggle/docs-meta.json +12 -0
  628. package/src/components/Toggle/index.ts +1 -0
  629. package/src/components/Toggle/registry-meta.json +19 -0
  630. package/src/components/Toggle/toggle.css.ts +101 -0
  631. package/src/components/Toggle/toggle.doc.tsx +24 -0
  632. package/src/components/Toggle/toggle.tsx +60 -0
  633. package/src/components/ToggleGroup/docs-meta.json +9 -0
  634. package/src/components/ToggleGroup/index.ts +1 -0
  635. package/src/components/ToggleGroup/registry-meta.json +20 -0
  636. package/src/components/ToggleGroup/toggle-group.css.ts +77 -0
  637. package/src/components/ToggleGroup/toggle-group.doc.tsx +38 -0
  638. package/src/components/ToggleGroup/toggle-group.tsx +131 -0
  639. package/src/components/index.ts +53 -0
  640. package/src/demos/accordion.demo.tsx +41 -0
  641. package/src/index.ts +3 -0
  642. package/src/utils/heights.ts +16 -0
  643. package/src/utils/sprinkles.css.ts +251 -0
  644. package/src/utils/types.ts +20 -0
  645. package/src/utils/ve-style.utils.ts +24 -0
  646. package/tsconfig.build.json +14 -0
  647. package/tsconfig.json +10 -0
  648. package/vite.config.ts +47 -0
@@ -0,0 +1 @@
1
+ $ tsc --noEmit
@@ -0,0 +1,423 @@
1
+ # Migration Plan: StyleX → Vanilla-Extract
2
+
3
+ ## Strategy
4
+
5
+ **Hybrid approach:** Shared sprinkles for Box, Stack, Grid layout components. All other components use `recipe()`, `style()`, and `globalStyle()` individually.
6
+
7
+ **Incremental — one component at a time.** The existing StyleX build (`@stylexjs/unplugin` Vite plugin) remains active throughout. A VE theme bridge (`contract.css.ts`) provides CSS variable references that piggyback on the StyleX theme values at runtime.
8
+
9
+ **Theme and vars are migrated last.** No VE theme implementation until all components use VE.
10
+
11
+ ---
12
+
13
+ ## Prerequisites
14
+
15
+ - `@vanilla-extract/css`, `@vanilla-extract/recipes`, `@vanilla-extract/sprinkles` — already in `package.json` dependencies
16
+ - `@vanilla-extract/vite-plugin` — already in `devDependencies`
17
+ - `clsx` — already in `dependencies`
18
+
19
+ ---
20
+
21
+ ## Phase 0 — Foundation
22
+
23
+ ### 0.1 Add VE Vite plugin
24
+
25
+ **File:** `vite.config.ts`
26
+ **Action:** Add `@vanilla-extract/vite-plugin` alongside the existing stylex plugin. Both run in parallel during migration.
27
+
28
+ ### 0.2 Create VE theme bridge
29
+
30
+ **File:** `src/theme/contract.css.ts`
31
+ **Action:** `createGlobalThemeContract()` mirroring the StyleX contract variable names. No value assignment — this is just a reference layer so VE files can use `theme.primary` (resolves to `var(--primary)`) which the StyleX theme still defines at runtime.
32
+
33
+ ```ts
34
+ import { createGlobalThemeContract } from "@vanilla-extract/css";
35
+
36
+ export const theme = createGlobalThemeContract({
37
+ primary: "primary",
38
+ primarySubtle: "primary-subtle",
39
+ secondary: "secondary",
40
+ primaryHover: "primary-hover",
41
+ contentPrimary: "content-primary",
42
+ contentSecondary: "content-secondary",
43
+ contentDisabled: "content-disabled",
44
+ contentAccent: "content-accent",
45
+ contentOnPrimary: "content-on-primary",
46
+ surface: "surface",
47
+ surfaceSubtle: "surface-subtle",
48
+ surfaceRaised: "surface-raised",
49
+ surfaceHover: "surface-hover",
50
+ surfaceOverlay: "surface-overlay",
51
+ border: "border",
52
+ borderSubtle: "border-subtle",
53
+ borderStrong: "border-strong",
54
+ borderRadius: "border-radius",
55
+ background: "background",
56
+ backgroundSubtle: "background-subtle",
57
+ sentimentPositive: "sentiment-positive",
58
+ sentimentPositiveSubtle: "sentiment-positive-subtle",
59
+ sentimentPositiveHover: "sentiment-positive-hover",
60
+ sentimentWarning: "sentiment-warning",
61
+ sentimentWarningSubtle: "sentiment-warning-subtle",
62
+ sentimentWarningHover: "sentiment-warning-hover",
63
+ sentimentNegative: "sentiment-negative",
64
+ sentimentNegativeSubtle: "sentiment-negative-subtle",
65
+ sentimentNegativeHover: "sentiment-negative-hover",
66
+ sentimentInfo: "sentiment-info",
67
+ sentimentInfoSubtle: "sentiment-info-subtle",
68
+ sentimentInfoHover: "sentiment-info-hover",
69
+ focusRing: "focus-ring",
70
+ shadowSm: "shadow-sm",
71
+ shadowMd: "shadow-md",
72
+ shadowLg: "shadow-lg",
73
+ shadowXl: "shadow-xl",
74
+ fontSize: "font-size",
75
+ hoverOverlay: "hover-overlay",
76
+ hoverOverlaySoft: "hover-overlay-soft",
77
+ });
78
+ ```
79
+
80
+ ### 0.3 Create VE tokens
81
+
82
+ **File:** `src/theme/tokens.css.ts`
83
+ **Action:** Convert StyleX token constants to plain exported objects and VE vars where appropriate.
84
+
85
+ ```ts
86
+ // Border radius — can use createGlobalThemeContract or plain object
87
+ export const borderRadius = {
88
+ xsmall: "2px",
89
+ small: "4px",
90
+ medium: "8px",
91
+ large: "12px",
92
+ xlarge: "16px",
93
+ xxlarge: "24px",
94
+ full: "999px",
95
+ } as const;
96
+
97
+ export const fonts = { ... } as const;
98
+ export const fontSize = { ... } as const;
99
+ export const fontWeight = { ... } as const;
100
+ export const lineHeight = { ... } as const;
101
+ export const letterSpacing = { ... } as const;
102
+ export const spacing = { ... } as const;
103
+ export const borderWidth = { ... } as const;
104
+ export const duration = { ... } as const;
105
+ export const easing = { ... } as const;
106
+
107
+ // Primitive styles → style({}) exports
108
+ // Media queries → plain objects
109
+ export const mediaQueries = { sm: "screen and (min-width: 640px)", ... } as const;
110
+ export const zIndex = { base: 0, raised: 100, ... } as const;
111
+ ```
112
+
113
+ ### 0.4 Create shared sprinkles config
114
+
115
+ **File:** `src/utils/sprinkles.css.ts`
116
+ **Action:** Consolidate Box layout/spacing/color/flex/position utilities from `box.css.ts`, `base.styles.ts`, and `layout.styles.ts` into one central sprinkles config. This is used by Box, Stack, and Grid.
117
+
118
+ **Conditions:** `mobile` (no query), `tablet` (min-width: 768px), `desktop` (min-width: 1280px)
119
+
120
+ **Property groups:**
121
+
122
+ - **layout:** width, maxWidth, height, maxHeight, borderRadius
123
+ - **responsiveSpacing:** padding (all directions), margin (all directions), gap with responsive conditions
124
+ - **color:** color, backgroundColor, borderColor
125
+ - **flex:** flex, flexGrow, flexShrink, display, justifyContent, alignItems
126
+ - **position:** zIndex, position, top/bottom/left/right, overflow
127
+
128
+ ### 0.5 Create type utilities
129
+
130
+ **File:** `src/utils/types.ts` (replaces `stylex.utils.ts`)
131
+ **Action:** Create a types-only file with Base UI prop types, removing any `@stylexjs/stylex` import.
132
+
133
+ ```ts
134
+ import type { useRender } from "@base-ui/react/use-render";
135
+
136
+ export type PropsWithClassName<T> = Omit<T, "className" | "style"> & {
137
+ className?: string;
138
+ style?: React.CSSProperties;
139
+ };
140
+ export type _BaseDivProps = PropsWithClassName<useRender.ComponentProps<"div">>;
141
+ ```
142
+
143
+ ---
144
+
145
+ ## Phase 1 — Layout Components (shared sprinkles)
146
+
147
+ Components use the shared sprinkles config directly.
148
+
149
+ | # | Component | Action | VE API |
150
+ | --- | ------------- | ------------------------------------------------------------------------- | ------------------------- |
151
+ | 1.1 | **Box** | Delete `box.styles.ts` (already has `box.css.ts` with sprinkles) | sprinkles |
152
+ | 1.2 | **Container** | Delete `container.styles.ts` (already has `container.css.ts` with recipe) | recipe |
153
+ | 1.3 | **Stack** | `stack.styles.ts` → `stack.css.ts`; update `stack.tsx` | recipe + shared sprinkles |
154
+ | 1.4 | **Grid** | `grid.styles.ts` → `grid.css.ts`; update `grid.tsx` | recipe + shared sprinkles |
155
+
156
+ ### 1.3 Stack
157
+
158
+ - StyleX: orientation (horizontal/vertical), spacing, wrap, inline, align, justify, distribution
159
+ - VE: `recipe()` for orientation/spacing variants + shared sprinkles for align/justify/wrap
160
+
161
+ ### 1.4 Grid
162
+
163
+ - StyleX: columns, rows, gap, areas
164
+ - VE: `recipe()` for column/row variants + shared sprinkles for gap
165
+
166
+ ---
167
+
168
+ ## Phase 2 — Simple Variant Components
169
+
170
+ No pseudo-classes or minimal pseudo-classes. Pure variant-based styling → `recipe()`.
171
+
172
+ | # | Component | Variants | Pseudo-elements | VE API |
173
+ | --- | -------------- | -------------------------------------------------- | ---------------- | ----------------------------------- |
174
+ | 2.1 | **Badge** | variant (default/primary/secondary/danger/success) | none | `recipe()` |
175
+ | 2.2 | **Switch** | checked, disabled | `:focus-visible` | `recipe()` + `style({ selectors })` |
176
+ | 2.3 | **Spinner** | size (small/medium/large) | none | `recipe()` |
177
+ | 2.4 | **Separator** | orientation (horizontal/vertical) | none | `recipe()` |
178
+ | 2.5 | **Icon** | size (small/medium/large/xlarge) | none | `recipe()` |
179
+ | 2.6 | **Progress** | — | none | `style()` |
180
+ | 2.7 | **Slider** | orientation | none | `style()` |
181
+ | 2.8 | **Splitter** | orientation | none | `style()` |
182
+ | 2.9 | **ScrollArea** | — | `:hover` | `style({ selectors })` |
183
+
184
+ ---
185
+
186
+ ## Phase 3 — Medium Complexity Components
187
+
188
+ Multiple variants, pseudo-classes, and/or compound sub-elements.
189
+
190
+ | # | Component | Key features | VE API |
191
+ | ---- | --------------- | ---------------------------------------------------------------------------------------------------------- | ----------------------------------- |
192
+ | 3.1 | **Button** | 3 variant axes (intent/variant/size), `:hover`, `:disabled`, `button-intents.stylex.ts` with `createVar()` | `recipe()` + `createVar()` |
193
+ | 3.2 | **Text** | 12+ typography variants, color/weight/align sub-styles | `recipe()` + exported style blocks |
194
+ | 3.3 | **Avatar** | Size variants, fallback state | `recipe()` |
195
+ | 3.4 | **Card** | Variant (elevated/outlined), padding | `recipe()` |
196
+ | 3.5 | **Surface** | Variant (raised/subtle), padding | `recipe()` |
197
+ | 3.6 | **Alert** | Variant (info/success/warning/error), icon | `recipe()` |
198
+ | 3.7 | **Field** | Form field layout, error/label states | `recipe()` |
199
+ | 3.8 | **Input** | Size variant, `:focus`, `:disabled`, `[data-*]` | `style()` + `globalStyle()` |
200
+ | 3.9 | **Textarea** | Same as Input | `style()` + `globalStyle()` |
201
+ | 3.10 | **InputGroup** | Slot layout (addon, button) | `style()` |
202
+ | 3.11 | **OTPField** | Digit slots, `:focus` | `style()` |
203
+ | 3.12 | **Checkbox** | Checked/indeterminate, `:focus-visible`, `:disabled` | `recipe()` + `style({ selectors })` |
204
+ | 3.13 | **Radio** | Checked state, `:focus-visible`, `:disabled` | `recipe()` + `style({ selectors })` |
205
+ | 3.14 | **Toggle** | Pressed state, `:hover`, `:focus-visible` | `recipe()` + `style({ selectors })` |
206
+ | 3.15 | **ToggleGroup** | Orientation, variant | `recipe()` |
207
+ | 3.16 | **ColorSwatch** | Color display, checkerboard | `style()` |
208
+ | 3.17 | **Breadcrumbs** | Separator, link states | `recipe()` |
209
+ | 3.18 | **Table** | Row/header/cell styles | `style()` + `globalStyle()` |
210
+
211
+ ### Key Pattern: Button
212
+
213
+ - `button-intents.stylex.ts` (`stylex.defineVars`) → `createVar()` for each intent slot
214
+ - 3 recipe variant groups: `intent` (primary/neutral/success/warning/danger/info/mono), `variant` (solid/soft/outline/ghost/link), `size` (xsmall/small/icon/medium/large)
215
+ - `:hover`, `:disabled` → `style({ selectors: { "&:hover:not(:disabled)": {}, "&:disabled": {} } })`
216
+
217
+ ### Key Pattern: Text
218
+
219
+ - `/text-variants.css.ts` (or inline in `text.css.ts`):
220
+ - `recipe()` with `variant` (h1–h6, body1–4, caption, creatorNote, p, div, code) + `size` override
221
+ - Separate style blocks for `textTransform`, `textAlign`, `textWeight`, `color`
222
+
223
+ ---
224
+
225
+ ## Phase 4 — Complex Interactive Components
226
+
227
+ Data-attribute selectors, parent selectors, compound compositions.
228
+
229
+ | # | Component | Selectors | VE API |
230
+ | ---- | ---------------- | ----------------------------------------------------------------------------------------- | --------------------------- |
231
+ | 4.1 | **Accordion** | `[data-panel-open] &` (parent selector), `:focus-visible`, `:hover` | `style()` + `globalStyle()` |
232
+ | 4.2 | **Tabs** | `:hover`, `:focus-visible`, indicator animation | `recipe()` + `style()` |
233
+ | 4.3 | **Select** | `[data-placeholder]`, `[data-highlighted]`, `[data-selected]`, `[data-disabled]` (nested) | `style()` + `globalStyle()` |
234
+ | 4.4 | **Menu** | data attributes, hover states | `style()` + `globalStyle()` |
235
+ | 4.5 | **Combobox** | Similar to Select + Input | `style()` + `globalStyle()` |
236
+ | 4.6 | **Command** | Command palette, data attributes, `:hover` | `style()` + `globalStyle()` |
237
+ | 4.7 | **Autocomplete** | Input + suggestions | `style()` + `globalStyle()` |
238
+ | 4.8 | **Calendar** | Date grid, selected/today/disabled | `style()` + `globalStyle()` |
239
+ | 4.9 | **ColorPicker** | Swatches, sliders | `style()` |
240
+ | 4.10 | **DatePicker** | Combines Calendar + Popover | `style()` |
241
+
242
+ ### Key Pattern: Parent selector workaround
243
+
244
+ StyleX `[data-panel-open] &` → VE `globalStyle()`:
245
+
246
+ ```ts
247
+ globalStyle(`[data-panel-open] .${triggerIcon}`, {
248
+ transform: "rotate(180deg)",
249
+ });
250
+ ```
251
+
252
+ ### Key Pattern: Nested data-attribute selectors (Select)
253
+
254
+ ```ts
255
+ // VE globalStyle for scoping
256
+ globalStyle(`${item}[data-selected]`, { ... });
257
+ globalStyle(`${item}[data-highlighted]`, { ... });
258
+ globalStyle(`${item}[data-selected]:hover`, { ... });
259
+ ```
260
+
261
+ ---
262
+
263
+ ## Phase 5 — Layout-Heavy Components
264
+
265
+ Complex animations, pseudo-elements, `:has()` selectors, media query overrides.
266
+
267
+ | # | Component | Key challenges | VE API |
268
+ | --- | --------------- | --------------------------------------------------------------------------------------------------- | --------------------------- |
269
+ | 5.1 | **Dialog** | `::before`, `:has()`, `@media`, `data-[starting/ending]-style`, `--nested-dialogs` | `style()` + `globalStyle()` |
270
+ | 5.2 | **Sheet** | 21 styles, directional variants, `prefers-reduced-motion`, `data-starting/ending-style`, `::before` | `style()` + `globalStyle()` |
271
+ | 5.3 | **Drawer** | 54 styles (largest), directional/side variants, swipe area, menu items, `:has()` | `style()` + `globalStyle()` |
272
+ | 5.4 | **AlertDialog** | 14 styles, same patterns as Dialog, `@media (max-width: 768px)` | `style()` + `globalStyle()` |
273
+ | 5.5 | **Popover** | Arrow positioning, animations | `style()` |
274
+
275
+ ### Key Pattern: `::before` pseudo-element
276
+
277
+ ```ts
278
+ export const popup = style({
279
+ // ...
280
+ selectors: {
281
+ "&::before": {
282
+ content: '""',
283
+ pointerEvents: "none",
284
+ position: "absolute",
285
+ inset: 0,
286
+ borderRadius: "calc(16px - 1px)",
287
+ boxShadow: "0 1px 0 rgba(0, 0, 0, 0.04), inset 0 0 0 1px rgba(255, 255, 255, 0.02)",
288
+ },
289
+ },
290
+ });
291
+ ```
292
+
293
+ ### Key Pattern: `:has()` selectors
294
+
295
+ ```ts
296
+ globalStyle(`${panel}:has([data-slot='dialog-popup']:has([data-slot='dialog-header']))`, {
297
+ paddingTop: spacing.xsmall,
298
+ });
299
+ ```
300
+
301
+ ### Key Pattern: Enter/exit animations
302
+
303
+ ```ts
304
+ globalStyle(`${backdrop}[data-starting-style]`, { opacity: 0 });
305
+ globalStyle(`${backdrop}[data-ending-style]`, { opacity: 0 });
306
+ ```
307
+
308
+ ---
309
+
310
+ ## Phase 6 — Components Without `styles.ts`
311
+
312
+ These have no dedicated style file. Check for inline `stylex.create()` usage.
313
+
314
+ | # | Component | Action |
315
+ | --- | -------------------- | ------------------------------------------------------------------------------- |
316
+ | 6.1 | **IconButton** | `icon-button.tsx` has inline `stylex.create({ base })` — convert to `style({})` |
317
+ | 6.2 | **CloseButton** | Wraps IconButton; no styles to migrate |
318
+ | 6.3 | **CopyButton** | Wraps IconButton with `variant="ghost"`; no styles to migrate |
319
+ | 6.4 | **SegmentedControl** | Check for inline stylex; likely none |
320
+ | 6.5 | **ColorPicker** | Check for inline stylex; uses react-colorful |
321
+ | 6.6 | **DatePicker** | Commented out in barrel; skip |
322
+ | 6.7 | **ColorPicker** | — |
323
+
324
+ ---
325
+
326
+ ## Phase 7 — Cleanup
327
+
328
+ | # | Task | Details |
329
+ | --- | -------------------------------------------------- | ----------------------------------------------------------------------- |
330
+ | 7.1 | Delete `stylex.utils.ts` | Replaced by `types.ts` |
331
+ | 7.2 | Delete all `*.styles.ts` files | 44 component files + 2 util files (should all be gone after Phases 1–5) |
332
+ | 7.3 | Delete `button-intents.stylex.ts` | Converted in Phase 3.1 |
333
+ | 7.4 | Remove `@stylexjs/stylex` from remaining TSX files | Verify no remaining stylex imports in components |
334
+
335
+ ---
336
+
337
+ ## Phase 8 — Theme + Vars Migration (Final)
338
+
339
+ Only after all components are on VE. The bridge (`contract.css.ts`) becomes the real contract.
340
+
341
+ | # | Task | Details |
342
+ | --- | -------------------------------------------- | ----------------------------------------------------------------------------------- |
343
+ | 8.1 | Update `contract.css.ts` | Add `createGlobalTheme(":root", theme, { ...values... })` for light and dark themes |
344
+ | 8.2 | Convert `tokens.stylex.ts` | Replace with VE version (already created in 0.3) |
345
+ | 8.3 | Remove `contract.stylex.ts` | No longer needed |
346
+ | 8.4 | Remove `tokens.stylex.ts` | No longer needed |
347
+ | 8.5 | Remove `theme.stylex.ts` | No longer needed |
348
+ | 8.6 | Remove `@stylexjs/unplugin` from vite config | Only VE plugin remains |
349
+ | 8.7 | Update package.json | Remove `@stylexjs/stylex` if it was a direct dep |
350
+
351
+ ---
352
+
353
+ ## Per-Component Conversion Template
354
+
355
+ Each component in Phases 1–5 follows these sub-steps:
356
+
357
+ ```
358
+ 1. Read `component.styles.ts` — catalog all style keys, pseudo-classes, selectors, media queries
359
+ 2. Create `component.css.ts` — convert to recipe/style/globalStyle as appropriate
360
+ 3. Read `component.tsx` — understand style application pattern:
361
+ a. stylex.props() spread → clsx(classes)
362
+ b. stylex.props().className extraction → clsx(classes)
363
+ c. useRender + mergeProps → clsx + manual style merge
364
+ 4. Update `component.tsx`:
365
+ a. Remove `import * as stylex from "@stylexjs/stylex"`
366
+ b. Change `import { ... } from "./component.styles"` → `import { ... } from "./component.css"`
367
+ c. Replace `stylex.props(a, b, c)` with `clsx(a, b, c)`
368
+ d. Replace `stylex.props(...).className ?? ""` with `clsx(...)`
369
+ e. Replace `keyof typeof styleObj` with `RecipeVariants<typeof recipe>`
370
+ f. Replace `style: StyleXStyles` with `style?: React.CSSProperties`
371
+ 5. Delete `component.styles.ts`
372
+ 6. Run `npm run check-types` to verify
373
+ ```
374
+
375
+ ---
376
+
377
+ ## Dependency Order
378
+
379
+ ```
380
+ contract.css.ts (VE bridge)
381
+
382
+ utils/sprinkles.css.ts
383
+
384
+ Box → Container
385
+
386
+ Stack → Grid
387
+
388
+ Simple (Badge, Switch, Spinner...)
389
+
390
+ Medium (Button, Text, Card...)
391
+
392
+ Complex (Accordion, Tabs, Select...)
393
+
394
+ Layout-heavy (Dialog, Sheet, Drawer...)
395
+
396
+ Theme migration (final)
397
+ ```
398
+
399
+ Components in each phase can be migrated in any order within their phase. Lower phases don't depend on higher ones.
400
+
401
+ ---
402
+
403
+ ## StyleX → Vanilla-Extract Cheat Sheet
404
+
405
+ | StyleX | Vanilla-Extract |
406
+ | -------------------------------------- | ---------------------------------------------------------- |
407
+ | `stylex.props(a, b, c)` | `clsx(a, b, c)` |
408
+ | `stylex.create({ root: {} })` | `export const root = style({})` |
409
+ | `":hover"` as key | `selectors: { "&:hover": {} }` |
410
+ | `":hover:not(:disabled)"` | `selectors: { "&:hover:not(:disabled)": {} }` |
411
+ | `"[data-foo]"` as key | `selectors: { "&[data-foo]": {} }` |
412
+ | `"[data-foo] &"` (parent selector) | `globalStyle(\`[data-foo] .${className}\`, {})` |
413
+ | `"::before"` as key | `selectors: { "&::before": {} }` |
414
+ | Multi-value with `@media` | Nested `"@media"` in style block |
415
+ | `prefers-reduced-motion` | `"@media (prefers-reduced-motion: reduce)"` |
416
+ | `stylex.defineVars({ x: "" })` | `createGlobalThemeContract({ x: "x" })` |
417
+ | `stylex.defineConsts({ x: val })` | `export const x = val` (plain export) |
418
+ | `keyof typeof styleObj` | `RecipeVariants<typeof recipe>` |
419
+ | `theme.primary` (stylex var) | `theme.primary` (VE contract reference → `var(--primary)`) |
420
+ | `fontSize.spacing.xxsmall` (dependent) | `fontSize.xxsmall` (direct value) |
421
+ | `[intentTokens.solidBg]` (dynamic) | `createVar()` — scoped CSS variable |
422
+ | `style: StyleXStyles` | `style?: React.CSSProperties` |
423
+ | `PropsWithStylex<T>` | `T & { style?: React.CSSProperties; className?: string }` |
package/TASKS.md ADDED
@@ -0,0 +1,192 @@
1
+ # Migration Tasks: StyleX → Vanilla-Extract
2
+
3
+ Per-component task breakdown, grouped by similarity. Each ✅ marks one file to convert.
4
+
5
+ ---
6
+
7
+ ## GUIDELINES
8
+
9
+ - DO NOT CHECK FOR TYPES
10
+ - DO NOT FIX RUN TIME TYPESCRIPT ISSUES.
11
+ - IGNORE ANY TYPE WARNINGS
12
+
13
+ ## Group A: Foundation (do first)
14
+
15
+ - [ ] **A1** — Add `@vanilla-extract/vite-plugin` to `vite.config.ts` alongside stylex plugin
16
+ - [ ] **A2** — Create `src/theme/contract.css.ts` (VE theme bridge via `createGlobalThemeContract`)
17
+ - [ ] **A3** — Create `src/theme/tokens.css.ts` (convert StyleX token constants to plain objects)
18
+ - [ ] **A4** — Create `src/utils/sprinkles.css.ts` (shared sprinkles for Box/Stack/Grid)
19
+ - [ ] **A5** — Create `src/utils/types.ts` (replace `stylex.utils.ts` with plain React.CSSProperties types)
20
+
21
+ ---
22
+
23
+ ## Group B: Layout — shared sprinkles
24
+
25
+ - [ ] **B1** — **Box**: delete `box.styles.ts` (already has `box.css.ts`)
26
+ - [ ] **B2** — **Container**: delete `container.styles.ts` (already has `container.css.ts`)
27
+ - [ ] **B3** — **Stack**: `stack.styles.ts` → `stack.css.ts`; update `stack.tsx`
28
+ - [ ] **B4** — **Grid**: `grid.styles.ts` → `grid.css.ts`; update `grid.tsx`
29
+
30
+ ---
31
+
32
+ ## Group C: Simple recipe components
33
+
34
+ No pseudo-classes. Pure variant slices → `recipe()`.
35
+
36
+ - [ ] **C1** — **Badge**: `badge.styles.ts` → `badge.css.ts`; update `badge.tsx`
37
+ - [ ] **C2** — **Spinner**: `spinner.styles.ts` → `spinner.css.ts`; update `spinner.tsx`
38
+ - [ ] **C3** — **Separator**: `separator.styles.ts` → `separator.css.ts`; update `separator.tsx`
39
+ - [ ] **C4** — **Icon**: `icon.styles.ts` → `icon.css.ts`; update `icon.tsx`
40
+ - [ ] **C5** — **Progress**: `progress.styles.ts` → `progress.css.ts`; update `progress.tsx`
41
+
42
+ ---
43
+
44
+ ## Group D: Display/card components
45
+
46
+ Variant-based with minimal pseudo-classes.
47
+
48
+ - [ ] **D1** — **Card**: `card.styles.ts` → `card.css.ts`; update `card.tsx`
49
+ - [ ] **D2** — **Surface**: `surface.styles.ts` → `surface.css.ts`; update `surface.tsx`
50
+ - [ ] **D3** — **Alert**: `alert.styles.ts` → `alert.css.ts`; update `alert.tsx`
51
+ - [ ] **D4** — **Avatar**: `avatar.styles.ts` → `avatar.css.ts`; update `avatar.tsx`
52
+ - [ ] **D5** — **ColorSwatch**: `color-swatch.styles.ts` → `color-swatch.css.ts`; update `color-swatch.tsx`
53
+ - [ ] **D6** — **Breadcrumbs**: `breadcrumbs.styles.ts` → `breadcrumbs.css.ts`; update `breadcrumbs.tsx`
54
+ - [ ] **D7** — **Table**: `table.styles.ts` → `table.css.ts`; update `table.tsx`
55
+
56
+ ---
57
+
58
+ ## Group E: Toggle/check components
59
+
60
+ State-driven (checked/disabled/pressed) with `:focus-visible`, `:hover`.
61
+
62
+ - [ ] **E1** — **Switch**: `switch.styles.ts` → `switch.css.ts`; update `switch.tsx`
63
+ - [ ] **E2** — **Checkbox**: `checkbox.styles.ts` → `checkbox.css.ts`; update `checkbox.tsx`
64
+ - [ ] **E3** — **Radio**: `radio.styles.ts` → `radio.css.ts`; update `radio.tsx`
65
+ - [ ] **E4** — **Toggle**: `toggle.styles.ts` → `toggle.css.ts`; update `toggle.tsx`
66
+ - [ ] **E5** — **ToggleGroup**: `toggle-group.styles.ts` → `toggle-group.css.ts`; update `toggle-group.tsx`
67
+
68
+ ---
69
+
70
+ ## Group F: Form input components
71
+
72
+ `[data-*]` attributes, `:focus`, `:disabled` selectors. `globalStyle()` needed.
73
+
74
+ - [ ] **F1** — **Input**: `input.styles.ts` → `input.css.ts`; update `input.tsx`
75
+ - [ ] **F2** — **Textarea**: `textarea.styles.ts` → `textarea.css.ts`; update `textarea.tsx`
76
+ - [ ] **F3** — **InputGroup**: `input-group.styles.ts` → `input-group.css.ts`; update `input-group.tsx`
77
+ - [ ] **F4** — **OTPField**: `otp-field.styles.ts` → `otp-field.css.ts`; update `otp-field.tsx`
78
+ - [ ] **F5** — **Field**: `field.styles.ts` → `field.css.ts`; update `field.tsx`
79
+
80
+ ---
81
+
82
+ ## Group G: Compound interactive components
83
+
84
+ Multiple sub-elements, `[data-*]` attributes, nested selectors.
85
+
86
+ - [ ] **G1** — **Select**: `select.styles.ts` → `select.css.ts`; update `select.tsx`
87
+ - [ ] **G2** — **Combobox**: `combobox.styles.ts` → `combobox.css.ts`; update `combobox.tsx`
88
+ - [ ] **G3** — **Autocomplete**: `autocomplete.styles.ts` → `autocomplete.css.ts`; update `autocomplete.tsx`
89
+ - [ ] **G4** — **Menu**: `menu.styles.ts` → `menu.css.ts`; update `menu.tsx`
90
+
91
+ ---
92
+
93
+ ## Group H: Typography
94
+
95
+ - [ ] **H1** — **Text**: `text.styles.ts` → `text.css.ts`; update `text.tsx`
96
+
97
+ ---
98
+
99
+ ## Group I: Button family
100
+
101
+ Button is the most complex — 3 variant axes + `createVar()` for intent tokens. IconButton/CloseButton/CopyButton wrap Button.
102
+
103
+ - [ ] **I1** — **Button**: `button.styles.ts` → `button.css.ts`; `button-intents.stylex.ts` → inlined `createVar()` in `button.css.ts`; update `button.tsx`
104
+ - [ ] **I2** — **IconButton**: inline `stylex.create()` in `icon-button.tsx` → `style({})`
105
+ - [ ] **I3** — **CloseButton**: no styles; verify no inline stylex
106
+ - [ ] **I4** — **CopyButton**: no styles; verify no inline stylex
107
+
108
+ ---
109
+
110
+ ## Group J: Accordion + Tabs
111
+
112
+ Compound sub-components, state-driven styles, parent selectors.
113
+
114
+ - [ ] **J1** — **Accordion**: `accordion.styles.ts` → `accordion.css.ts`; update `accordion.tsx` (handle `[data-panel-open] &` parent selector via `globalStyle`)
115
+ - [ ] **J2** — **Tabs**: `tabs.styles.ts` → `tabs.css.ts`; update `tabs.tsx`
116
+
117
+ ---
118
+
119
+ ## Group K: Overlay/dialog components
120
+
121
+ Complex animations, `::before`, `:has()`, `@media`, `prefers-reduced-motion`, `data-starting/ending-style`.
122
+
123
+ - [ ] **K1** — **Dialog**: `dialog.styles.ts` → `dialog.css.ts`; update `dialog.tsx`
124
+ - [ ] **K2** — **Sheet**: `sheet.styles.ts` → `sheet.css.ts`; update `sheet.tsx`
125
+ - [ ] **K3** — **AlertDialog**: `alert-dialog.styles.ts` → `alert-dialog.css.ts`; update `alert-dialog.tsx`
126
+ - [ ] **K4** — **Drawer**: `drawer.styles.ts` → `drawer.css.ts`; update `drawer.tsx`
127
+ - [ ] **K5** — **Popover**: `popover.styles.ts` → `popover.css.ts`; update `popover.tsx`
128
+ - [ ] **K6** — **ScrollArea**: `scroll-area.styles.ts` → `scroll-area.css.ts`; update `scroll-area.tsx`
129
+
130
+ ---
131
+
132
+ ## Group L: Command palette
133
+
134
+ - [ ] **L1** — **Command**: `command.styles.ts` → `command.css.ts`; update `command.tsx`
135
+
136
+ ---
137
+
138
+ ## Group M: Pickers (no styles.ts)
139
+
140
+ Check for inline stylex usage; convert if found.
141
+
142
+ - [ ] **M1** — **ColorPicker**: check `color-picker.tsx` for inline stylex
143
+ - [ ] **M2** — **DatePicker**: check `date-picker.tsx` for inline stylex (commented out in barrel — skip if no usage)
144
+ - [ ] **M3** — **Calendar**: `calendar.styles.ts` → `calendar.css.ts`; update `calendar.tsx`
145
+ - [ ] **M4** — **SegmentedControl**: check `segmented-control.tsx` for inline stylex
146
+
147
+ ---
148
+
149
+ ## Group N: Misc remaining
150
+
151
+ - [ ] **N1** — **Slider**: `slider.styles.ts` → `slider.css.ts`; update `slider.tsx`
152
+ - [ ] **N2** — **Splitter**: `splitter.styles.ts` → `splitter.css.ts`; update `splitter.tsx`
153
+
154
+ ---
155
+
156
+ ## Group O: Cleanup (after all components done)
157
+
158
+ - [ ] **O1** — Delete `stylex.utils.ts`
159
+ - [ ] **O2** — Verify no remaining `*.styles.ts` or `*.stylex.ts` files exist in `src/components/`
160
+ - [ ] **O3** — Remove `@stylexjs/stylex` from remaining TSX imports
161
+ - [ ] **O4** — Update `src/utils/base.styles.ts` and `src/utils/layout.styles.ts` (absorbed into sprinkles; delete if empty)
162
+
163
+ ---
164
+
165
+ ## Group P: Theme migration (final — only after all above)
166
+
167
+ - [ ] **P1** — Update `contract.css.ts`: add `createGlobalTheme(":root", theme, {...})` for light theme values
168
+ - [ ] **P2** — Create dark theme implementation (maps same contract to dark values)
169
+ - [ ] **P3** — Remove `contract.stylex.ts`
170
+ - [ ] **P4** — Remove `tokens.stylex.ts`
171
+ - [ ] **P5** — Remove `theme.stylex.ts`
172
+ - [ ] **P6** — Remove `@stylexjs/unplugin` from `vite.config.ts`
173
+ - [ ] **P7** — Remove `@stylexjs` dependencies from package.json
174
+
175
+ ---
176
+
177
+ ## Execution order
178
+
179
+ ```
180
+ A1–A5 (foundation)
181
+ └─ B1–B4 (layout)
182
+ └─ C1–C5, D1–D7, E1–E5 (simple — any order within this tier)
183
+ └─ F1–F5, G1–G4, H1 (form + compound — any order)
184
+ └─ I1–I4 (button family)
185
+ └─ J1–J2 (accordion/tabs)
186
+ └─ K1–K6, L1 (overlays — any order)
187
+ └─ M1–M4, N1–N2 (pickers + misc)
188
+ └─ O1–O4 (cleanup)
189
+ └─ P1–P7 (theme final)
190
+ ```
191
+
192
+ Components within the same tier are independent — can be done in parallel or any order.
Binary file