@blenx-dev/components 0.0.1 → 0.0.3

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/{dist/components → components}/Accordion/accordion.css.js +2 -2
  2. package/{dist/components → components}/Accordion/accordion.js +1 -1
  3. package/{dist/components → components}/Alert/alert.css.js +2 -2
  4. package/{dist/components → components}/Alert/alert.js +1 -1
  5. package/{dist/components → components}/AlertDialog/alert-dialog.css.js +2 -2
  6. package/{dist/components → components}/AlertDialog/alert-dialog.js +1 -1
  7. package/{dist/components → components}/Autocomplete/autocomplete.css.js +2 -2
  8. package/{dist/components → components}/Autocomplete/autocomplete.js +1 -1
  9. package/{dist/components → components}/Avatar/avatar.css.js +3 -3
  10. package/{dist/components → components}/Avatar/avatar.js +1 -1
  11. package/{dist/components → components}/Badge/badge.css.js +3 -3
  12. package/{dist/components → components}/Badge/badge.js +1 -1
  13. package/{dist/components → components}/Box/box.css.js +1 -1
  14. package/{dist/components → components}/Box/box.js +1 -1
  15. package/{dist/components → components}/Breadcrumbs/breadcrumbs.css.js +1 -1
  16. package/{dist/components → components}/Breadcrumbs/breadcrumbs.js +1 -1
  17. package/{dist/components → components}/Button/button.css.js +3 -3
  18. package/{dist/components → components}/Button/button.js +1 -1
  19. package/{dist/components → components}/Calendar/calendar.css.js +2 -2
  20. package/{dist/components → components}/Calendar/calendar.js +1 -1
  21. package/{dist/components → components}/Checkbox/checkbox.css.js +2 -2
  22. package/{dist/components → components}/Checkbox/checkbox.js +1 -1
  23. package/{dist/components → components}/Combobox/combobox.css.js +2 -2
  24. package/{dist/components → components}/Combobox/combobox.js +1 -1
  25. package/{dist/components → components}/Command/command.css.js +2 -2
  26. package/{dist/components → components}/Command/command.js +1 -1
  27. package/{dist/components → components}/Container/container.css.js +1 -1
  28. package/{dist/components → components}/Container/container.js +1 -1
  29. package/{dist/components → components}/Dialog/dialog.css.js +2 -2
  30. package/{dist/components → components}/Dialog/dialog.js +1 -1
  31. package/{dist/components → components}/Drawer/drawer.css.js +2 -2
  32. package/{dist/components → components}/Drawer/drawer.js +1 -1
  33. package/{dist/components → components}/Field/field.css.js +2 -2
  34. package/{dist/components → components}/Field/field.js +1 -1
  35. package/{dist/components → components}/Grid/grid.js +1 -1
  36. package/{dist/components → components}/Icon/icon.js +1 -1
  37. package/{dist/components → components}/IconButton/icon-button.js +1 -1
  38. package/{dist/components → components}/Input/input.css.js +2 -2
  39. package/{dist/components → components}/Input/input.js +1 -1
  40. package/{dist/components → components}/InputGroup/input-group.css.js +2 -2
  41. package/{dist/components → components}/InputGroup/input-group.js +1 -1
  42. package/{dist/components → components}/Menu/menu.css.js +2 -2
  43. package/{dist/components → components}/Menu/menu.js +1 -1
  44. package/{dist/components → components}/OTPField/otp-field.css.js +3 -3
  45. package/{dist/components → components}/OTPField/otp-field.js +1 -1
  46. package/{dist/components → components}/Popover/popover.css.js +2 -2
  47. package/{dist/components → components}/Popover/popover.js +1 -1
  48. package/{dist/components → components}/Progress/progress.css.js +2 -2
  49. package/{dist/components → components}/Progress/progress.js +1 -1
  50. package/{dist/components → components}/Radio/radio.css.js +2 -2
  51. package/{dist/components → components}/Radio/radio.js +1 -1
  52. package/{dist/components → components}/ScrollArea/scroll-area.css.js +2 -2
  53. package/{dist/components → components}/ScrollArea/scroll-area.js +1 -1
  54. package/{dist/components → components}/Select/select.css.js +2 -2
  55. package/{dist/components → components}/Select/select.js +1 -1
  56. package/{dist/components → components}/Separator/separator.css.js +3 -3
  57. package/{dist/components → components}/Separator/separator.js +1 -1
  58. package/{dist/components → components}/Sheet/sheet.css.js +2 -2
  59. package/{dist/components → components}/Sheet/sheet.js +1 -1
  60. package/{dist/components → components}/Slider/slider.css.js +2 -2
  61. package/{dist/components → components}/Slider/slider.js +1 -1
  62. package/{dist/components → components}/Spinner/spinner.js +1 -1
  63. package/{dist/components → components}/Splitter/splitter.css.js +2 -2
  64. package/{dist/components → components}/Splitter/splitter.js +1 -1
  65. package/{dist/components → components}/Stack/stack.css.js +3 -3
  66. package/{dist/components → components}/Stack/stack.js +1 -1
  67. package/{dist/components → components}/Surface/surface.css.js +2 -2
  68. package/{dist/components → components}/Surface/surface.js +1 -1
  69. package/{dist/components → components}/Switch/switch.css.js +2 -2
  70. package/{dist/components → components}/Switch/switch.js +1 -1
  71. package/{dist/components → components}/Table/table.css.js +2 -2
  72. package/{dist/components → components}/Table/table.js +1 -1
  73. package/{dist/components → components}/Tabs/tabs.css.js +2 -2
  74. package/{dist/components → components}/Tabs/tabs.js +1 -1
  75. package/{dist/components → components}/Text/text.css.js +3 -3
  76. package/{dist/components → components}/Text/text.js +1 -1
  77. package/{dist/components → components}/Textarea/textarea.css.js +1 -1
  78. package/{dist/components → components}/Textarea/textarea.js +1 -1
  79. package/{dist/components → components}/Toggle/toggle.css.js +3 -3
  80. package/{dist/components → components}/Toggle/toggle.js +1 -1
  81. package/{dist/components → components}/ToggleGroup/toggle-group.css.js +2 -2
  82. package/{dist/components → components}/ToggleGroup/toggle-group.js +1 -1
  83. package/package.json +209 -38
  84. package/{dist/utils → utils}/sprinkles.css.js +2 -2
  85. package/.turbo/turbo-check-types.log +0 -1
  86. package/MIGRATION-PLAN.md +0 -423
  87. package/TASKS.md +0 -192
  88. package/blenx-dev-ui-0.0.0.tgz +0 -0
  89. package/dist/node_modules/.bun/@vanilla-extract_recipes@0.5.7_19e937df7e0b57ed/node_modules/@vanilla-extract/recipes/dist/createRuntimeFn-62c9670f.esm.js +0 -89
  90. 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 +0 -8
  91. package/dist/node_modules/.bun/@vanilla-extract_sprinkles@1.6.5_19e937df7e0b57ed/node_modules/@vanilla-extract/sprinkles/dist/createSprinkles-74286718.esm.js +0 -141
  92. package/dist/node_modules/.bun/clsx@2.1.1/node_modules/clsx/dist/clsx.js +0 -16
  93. package/dist/package.json +0 -233
  94. package/dist/src/components/Accordion/accordion.demo.d.ts +0 -5
  95. package/dist/src/components/Alert/alert.demo.d.ts +0 -6
  96. package/dist/src/components/AlertDialog/alert-dialog.demo.d.ts +0 -5
  97. package/dist/src/components/AlertDialog/alert-dialog.doc.d.ts +0 -1
  98. package/dist/src/components/Avatar/avatar.doc.d.ts +0 -2
  99. package/dist/src/components/Badge/badge.demo.d.ts +0 -5
  100. package/dist/src/components/Badge/badge.doc.d.ts +0 -1
  101. package/dist/src/components/Box/box.doc.d.ts +0 -1
  102. package/dist/src/components/Breadcrumbs/breadcrumbs.doc.d.ts +0 -2
  103. package/dist/src/components/Button/button.demo.d.ts +0 -5
  104. package/dist/src/components/Calendar/calendar.doc.d.ts +0 -1
  105. package/dist/src/components/Card/card.demo.d.ts +0 -8
  106. package/dist/src/components/Card/card.doc.d.ts +0 -2
  107. package/dist/src/components/ColorPicker/color-picker.doc.d.ts +0 -1
  108. package/dist/src/components/ColorSwatch/color-swatch.doc.d.ts +0 -2
  109. package/dist/src/components/Command/command.demo.d.ts +0 -6
  110. package/dist/src/components/Command/command.doc.d.ts +0 -3
  111. package/dist/src/components/Container/container.doc.d.ts +0 -1
  112. package/dist/src/components/DatePicker/date-picker.doc.d.ts +0 -1
  113. package/dist/src/components/Dialog/dialog.demo.d.ts +0 -5
  114. package/dist/src/components/Dialog/dialog.doc.d.ts +0 -1
  115. package/dist/src/components/Drawer/drawer.demo.d.ts +0 -5
  116. package/dist/src/components/Drawer/drawer.doc.d.ts +0 -2
  117. package/dist/src/components/Field/field.doc.d.ts +0 -1
  118. package/dist/src/components/Grid/grid.doc.d.ts +0 -1
  119. package/dist/src/components/Icon/icon.demo.d.ts +0 -5
  120. package/dist/src/components/IconButton/icon-button.demo.d.ts +0 -5
  121. package/dist/src/components/Input/input.demo.d.ts +0 -5
  122. package/dist/src/components/Input/input.doc.d.ts +0 -2
  123. package/dist/src/components/InputGroup/input-group.demo.d.ts +0 -5
  124. package/dist/src/components/Menu/menu.demo.d.ts +0 -5
  125. package/dist/src/components/OTPField/otp-field.demo.d.ts +0 -6
  126. package/dist/src/components/Popover/popover.demo.d.ts +0 -5
  127. package/dist/src/components/ScrollArea/scroll-area.doc.d.ts +0 -2
  128. package/dist/src/components/SegmentedControl/segmented-control.doc.d.ts +0 -1
  129. package/dist/src/components/Select/select.demo.d.ts +0 -5
  130. package/dist/src/components/Select/select.doc.d.ts +0 -2
  131. package/dist/src/components/Separator/separator.doc.d.ts +0 -4
  132. package/dist/src/components/Sheet/sheet.demo.d.ts +0 -5
  133. package/dist/src/components/Spinner/spinner.demo.d.ts +0 -1
  134. package/dist/src/components/Stack/stack.doc.d.ts +0 -3
  135. package/dist/src/components/Surface/surface.doc.d.ts +0 -2
  136. package/dist/src/components/Switch/switch.demo.d.ts +0 -5
  137. package/dist/src/components/Switch/switch.doc.d.ts +0 -2
  138. package/dist/src/components/Table/table.demo.d.ts +0 -5
  139. package/dist/src/components/Tabs/tabs.demo.d.ts +0 -5
  140. package/dist/src/components/Tabs/tabs.doc.d.ts +0 -3
  141. package/dist/src/components/Text/text.doc.d.ts +0 -4
  142. package/dist/src/components/Textarea/textarea.doc.d.ts +0 -2
  143. package/dist/src/components/Toggle/toggle.doc.d.ts +0 -1
  144. package/dist/src/components/ToggleGroup/toggle-group.doc.d.ts +0 -3
  145. package/dist/src/demos/accordion.demo.d.ts +0 -5
  146. package/package.build.json +0 -39
  147. package/scripts/generate-api.ts +0 -183
  148. package/scripts/generate-package.ts +0 -99
  149. package/src/DataTable/data-table-column-toggle.tsx +0 -73
  150. package/src/DataTable/data-table-empty.tsx +0 -27
  151. package/src/DataTable/data-table-error.tsx +0 -25
  152. package/src/DataTable/data-table-infinite-loader.tsx +0 -73
  153. package/src/DataTable/data-table-loading.tsx +0 -67
  154. package/src/DataTable/data-table-pagination.tsx +0 -80
  155. package/src/DataTable/data-table-toolbar.tsx +0 -62
  156. package/src/DataTable/data-table.css.ts +0 -421
  157. package/src/DataTable/data-table.tsx +0 -507
  158. package/src/DataTable/index.ts +0 -24
  159. package/src/DataTable/registry-meta.json +0 -66
  160. package/src/DataTable/types.ts +0 -169
  161. package/src/DataTable/use-infinite-scroll.ts +0 -67
  162. package/src/components/Accordion/accordion.css.ts +0 -93
  163. package/src/components/Accordion/accordion.demo.tsx +0 -42
  164. package/src/components/Accordion/accordion.tsx +0 -87
  165. package/src/components/Accordion/docs-meta.json +0 -13
  166. package/src/components/Accordion/index.ts +0 -8
  167. package/src/components/Accordion/registry-meta.json +0 -19
  168. package/src/components/Alert/alert.css.ts +0 -29
  169. package/src/components/Alert/alert.demo.tsx +0 -34
  170. package/src/components/Alert/alert.tsx +0 -40
  171. package/src/components/Alert/docs-meta.json +0 -12
  172. package/src/components/Alert/index.ts +0 -1
  173. package/src/components/Alert/registry-meta.json +0 -20
  174. package/src/components/AlertDialog/alert-dialog.css.ts +0 -146
  175. package/src/components/AlertDialog/alert-dialog.demo.tsx +0 -59
  176. package/src/components/AlertDialog/alert-dialog.doc.tsx +0 -31
  177. package/src/components/AlertDialog/alert-dialog.tsx +0 -197
  178. package/src/components/AlertDialog/docs-meta.json +0 -14
  179. package/src/components/AlertDialog/index.ts +0 -1
  180. package/src/components/AlertDialog/registry-meta.json +0 -20
  181. package/src/components/Autocomplete/autocomplete.css.ts +0 -168
  182. package/src/components/Autocomplete/autocomplete.tsx +0 -226
  183. package/src/components/Autocomplete/docs-meta.json +0 -9
  184. package/src/components/Autocomplete/index.ts +0 -1
  185. package/src/components/Autocomplete/registry-meta.json +0 -20
  186. package/src/components/Avatar/avatar.css.ts +0 -72
  187. package/src/components/Avatar/avatar.doc.tsx +0 -32
  188. package/src/components/Avatar/avatar.tsx +0 -49
  189. package/src/components/Avatar/docs-meta.json +0 -9
  190. package/src/components/Avatar/index.ts +0 -1
  191. package/src/components/Avatar/registry-meta.json +0 -19
  192. package/src/components/Badge/badge.css.ts +0 -40
  193. package/src/components/Badge/badge.demo.tsx +0 -18
  194. package/src/components/Badge/badge.doc.tsx +0 -12
  195. package/src/components/Badge/badge.tsx +0 -13
  196. package/src/components/Badge/docs-meta.json +0 -9
  197. package/src/components/Badge/index.ts +0 -1
  198. package/src/components/Badge/registry-meta.json +0 -19
  199. package/src/components/Box/box.css.ts +0 -7
  200. package/src/components/Box/box.doc.tsx +0 -19
  201. package/src/components/Box/box.tsx +0 -21
  202. package/src/components/Box/docs-meta.json +0 -9
  203. package/src/components/Box/index.ts +0 -1
  204. package/src/components/Box/registry-meta.json +0 -14
  205. package/src/components/Breadcrumbs/breadcrumbs.css.ts +0 -72
  206. package/src/components/Breadcrumbs/breadcrumbs.doc.tsx +0 -61
  207. package/src/components/Breadcrumbs/breadcrumbs.tsx +0 -79
  208. package/src/components/Breadcrumbs/docs-meta.json +0 -12
  209. package/src/components/Breadcrumbs/index.ts +0 -9
  210. package/src/components/Breadcrumbs/registry-meta.json +0 -19
  211. package/src/components/Button/button.css.ts +0 -209
  212. package/src/components/Button/button.demo.tsx +0 -119
  213. package/src/components/Button/button.tsx +0 -55
  214. package/src/components/Button/docs-meta.json +0 -13
  215. package/src/components/Button/index.ts +0 -1
  216. package/src/components/Button/registry-meta.json +0 -20
  217. package/src/components/Calendar/calendar.css.ts +0 -188
  218. package/src/components/Calendar/calendar.doc.tsx +0 -10
  219. package/src/components/Calendar/calendar.tsx +0 -143
  220. package/src/components/Calendar/docs-meta.json +0 -9
  221. package/src/components/Calendar/index.ts +0 -1
  222. package/src/components/Calendar/registry-meta.json +0 -20
  223. package/src/components/Card/card.demo.tsx +0 -177
  224. package/src/components/Card/card.doc.tsx +0 -47
  225. package/src/components/Card/card.tsx +0 -32
  226. package/src/components/Card/docs-meta.json +0 -9
  227. package/src/components/Card/index.ts +0 -1
  228. package/src/components/Card/registry-meta.json +0 -15
  229. package/src/components/Checkbox/checkbox.css.ts +0 -77
  230. package/src/components/Checkbox/checkbox.tsx +0 -94
  231. package/src/components/Checkbox/docs-meta.json +0 -13
  232. package/src/components/Checkbox/index.ts +0 -1
  233. package/src/components/Checkbox/registry-meta.json +0 -19
  234. package/src/components/CloseButton/close-button.css.ts +0 -11
  235. package/src/components/CloseButton/close-button.tsx +0 -15
  236. package/src/components/CloseButton/index.ts +0 -2
  237. package/src/components/CloseButton/registry-meta.json +0 -15
  238. package/src/components/ColorPicker/color-picker.doc.tsx +0 -12
  239. package/src/components/ColorPicker/color-picker.tsx +0 -123
  240. package/src/components/ColorPicker/docs-meta.json +0 -9
  241. package/src/components/ColorPicker/index.ts +0 -1
  242. package/src/components/ColorPicker/registry-meta.json +0 -15
  243. package/src/components/ColorSwatch/color-swatch.doc.tsx +0 -25
  244. package/src/components/ColorSwatch/color-swatch.tsx +0 -21
  245. package/src/components/ColorSwatch/docs-meta.json +0 -9
  246. package/src/components/ColorSwatch/index.ts +0 -1
  247. package/src/components/ColorSwatch/registry-meta.json +0 -20
  248. package/src/components/Combobox/combobox.css.ts +0 -334
  249. package/src/components/Combobox/combobox.tsx +0 -350
  250. package/src/components/Combobox/docs-meta.json +0 -9
  251. package/src/components/Combobox/index.ts +0 -1
  252. package/src/components/Combobox/registry-meta.json +0 -20
  253. package/src/components/Command/command.css.ts +0 -131
  254. package/src/components/Command/command.demo.tsx +0 -110
  255. package/src/components/Command/command.doc.tsx +0 -100
  256. package/src/components/Command/command.tsx +0 -413
  257. package/src/components/Command/docs-meta.json +0 -21
  258. package/src/components/Command/index.ts +0 -7
  259. package/src/components/Command/registry-meta.json +0 -20
  260. package/src/components/Container/container.css.ts +0 -40
  261. package/src/components/Container/container.doc.tsx +0 -28
  262. package/src/components/Container/container.tsx +0 -24
  263. package/src/components/Container/docs-meta.json +0 -9
  264. package/src/components/Container/index.ts +0 -1
  265. package/src/components/Container/registry-meta.json +0 -20
  266. package/src/components/CopyButton/copy-button.css.ts +0 -11
  267. package/src/components/CopyButton/copy-button.tsx +0 -45
  268. package/src/components/CopyButton/index.ts +0 -2
  269. package/src/components/CopyButton/registry-meta.json +0 -15
  270. package/src/components/DatePicker/date-picker.doc.tsx +0 -12
  271. package/src/components/DatePicker/date-picker.tsx +0 -75
  272. package/src/components/DatePicker/docs-meta.json +0 -9
  273. package/src/components/DatePicker/index.ts +0 -1
  274. package/src/components/DatePicker/registry-meta.json +0 -15
  275. package/src/components/Dialog/dialog.css.ts +0 -155
  276. package/src/components/Dialog/dialog.demo.tsx +0 -39
  277. package/src/components/Dialog/dialog.doc.tsx +0 -33
  278. package/src/components/Dialog/dialog.tsx +0 -186
  279. package/src/components/Dialog/docs-meta.json +0 -13
  280. package/src/components/Dialog/index.ts +0 -1
  281. package/src/components/Dialog/registry-meta.json +0 -20
  282. package/src/components/Drawer/docs-meta.json +0 -9
  283. package/src/components/Drawer/drawer.css.ts +0 -412
  284. package/src/components/Drawer/drawer.demo.tsx +0 -58
  285. package/src/components/Drawer/drawer.doc.tsx +0 -49
  286. package/src/components/Drawer/drawer.tsx +0 -574
  287. package/src/components/Drawer/index.ts +0 -1
  288. package/src/components/Drawer/registry-meta.json +0 -20
  289. package/src/components/Field/docs-meta.json +0 -9
  290. package/src/components/Field/field.css.ts +0 -35
  291. package/src/components/Field/field.doc.tsx +0 -19
  292. package/src/components/Field/field.tsx +0 -101
  293. package/src/components/Field/index.ts +0 -1
  294. package/src/components/Field/registry-meta.json +0 -20
  295. package/src/components/Grid/docs-meta.json +0 -9
  296. package/src/components/Grid/grid.css.ts +0 -12
  297. package/src/components/Grid/grid.doc.tsx +0 -148
  298. package/src/components/Grid/grid.tsx +0 -57
  299. package/src/components/Grid/index.ts +0 -1
  300. package/src/components/Grid/registry-meta.json +0 -20
  301. package/src/components/Icon/docs-meta.json +0 -13
  302. package/src/components/Icon/icon.css.ts +0 -10
  303. package/src/components/Icon/icon.demo.tsx +0 -97
  304. package/src/components/Icon/icon.tsx +0 -15
  305. package/src/components/Icon/index.ts +0 -1
  306. package/src/components/Icon/registry-meta.json +0 -20
  307. package/src/components/IconButton/docs-meta.json +0 -13
  308. package/src/components/IconButton/icon-button.css.ts +0 -6
  309. package/src/components/IconButton/icon-button.demo.tsx +0 -102
  310. package/src/components/IconButton/icon-button.tsx +0 -11
  311. package/src/components/IconButton/index.ts +0 -2
  312. package/src/components/IconButton/registry-meta.json +0 -15
  313. package/src/components/Input/docs-meta.json +0 -9
  314. package/src/components/Input/index.ts +0 -1
  315. package/src/components/Input/input.css.ts +0 -73
  316. package/src/components/Input/input.demo.tsx +0 -24
  317. package/src/components/Input/input.doc.tsx +0 -25
  318. package/src/components/Input/input.tsx +0 -50
  319. package/src/components/Input/registry-meta.json +0 -19
  320. package/src/components/InputGroup/docs-meta.json +0 -9
  321. package/src/components/InputGroup/index.ts +0 -1
  322. package/src/components/InputGroup/input-group.css.ts +0 -157
  323. package/src/components/InputGroup/input-group.demo.tsx +0 -53
  324. package/src/components/InputGroup/input-group.tsx +0 -133
  325. package/src/components/InputGroup/registry-meta.json +0 -19
  326. package/src/components/Menu/docs-meta.json +0 -13
  327. package/src/components/Menu/index.ts +0 -1
  328. package/src/components/Menu/menu.css.ts +0 -128
  329. package/src/components/Menu/menu.demo.tsx +0 -40
  330. package/src/components/Menu/menu.tsx +0 -115
  331. package/src/components/Menu/registry-meta.json +0 -19
  332. package/src/components/OTPField/docs-meta.json +0 -9
  333. package/src/components/OTPField/index.ts +0 -1
  334. package/src/components/OTPField/otp-field.css.ts +0 -55
  335. package/src/components/OTPField/otp-field.demo.tsx +0 -57
  336. package/src/components/OTPField/otp-field.tsx +0 -46
  337. package/src/components/OTPField/registry-meta.json +0 -19
  338. package/src/components/Popover/docs-meta.json +0 -13
  339. package/src/components/Popover/index.ts +0 -1
  340. package/src/components/Popover/popover.css.ts +0 -82
  341. package/src/components/Popover/popover.demo.tsx +0 -34
  342. package/src/components/Popover/popover.tsx +0 -113
  343. package/src/components/Popover/registry-meta.json +0 -19
  344. package/src/components/Progress/docs-meta.json +0 -12
  345. package/src/components/Progress/index.ts +0 -7
  346. package/src/components/Progress/progress.css.ts +0 -38
  347. package/src/components/Progress/progress.tsx +0 -62
  348. package/src/components/Progress/registry-meta.json +0 -19
  349. package/src/components/Radio/docs-meta.json +0 -13
  350. package/src/components/Radio/index.ts +0 -1
  351. package/src/components/Radio/radio.css.ts +0 -73
  352. package/src/components/Radio/radio.tsx +0 -49
  353. package/src/components/Radio/registry-meta.json +0 -19
  354. package/src/components/ScrollArea/docs-meta.json +0 -9
  355. package/src/components/ScrollArea/index.ts +0 -1
  356. package/src/components/ScrollArea/registry-meta.json +0 -19
  357. package/src/components/ScrollArea/scroll-area.css.ts +0 -80
  358. package/src/components/ScrollArea/scroll-area.doc.tsx +0 -44
  359. package/src/components/ScrollArea/scroll-area.tsx +0 -96
  360. package/src/components/SegmentedControl/docs-meta.json +0 -9
  361. package/src/components/SegmentedControl/index.ts +0 -1
  362. package/src/components/SegmentedControl/registry-meta.json +0 -15
  363. package/src/components/SegmentedControl/segmented-control.doc.tsx +0 -28
  364. package/src/components/SegmentedControl/segmented-control.tsx +0 -42
  365. package/src/components/Select/docs-meta.json +0 -13
  366. package/src/components/Select/index.ts +0 -1
  367. package/src/components/Select/registry-meta.json +0 -20
  368. package/src/components/Select/select.css.ts +0 -183
  369. package/src/components/Select/select.demo.tsx +0 -35
  370. package/src/components/Select/select.doc.tsx +0 -65
  371. package/src/components/Select/select.tsx +0 -165
  372. package/src/components/Separator/docs-meta.json +0 -12
  373. package/src/components/Separator/index.ts +0 -1
  374. package/src/components/Separator/registry-meta.json +0 -20
  375. package/src/components/Separator/separator.css.ts +0 -60
  376. package/src/components/Separator/separator.doc.tsx +0 -44
  377. package/src/components/Separator/separator.tsx +0 -34
  378. package/src/components/Sheet/docs-meta.json +0 -13
  379. package/src/components/Sheet/index.ts +0 -1
  380. package/src/components/Sheet/registry-meta.json +0 -20
  381. package/src/components/Sheet/sheet.css.ts +0 -192
  382. package/src/components/Sheet/sheet.demo.tsx +0 -53
  383. package/src/components/Sheet/sheet.tsx +0 -213
  384. package/src/components/Slider/docs-meta.json +0 -13
  385. package/src/components/Slider/index.ts +0 -1
  386. package/src/components/Slider/registry-meta.json +0 -19
  387. package/src/components/Slider/slider.css.ts +0 -82
  388. package/src/components/Slider/slider.tsx +0 -100
  389. package/src/components/Spinner/docs-meta.json +0 -12
  390. package/src/components/Spinner/index.ts +0 -1
  391. package/src/components/Spinner/registry-meta.json +0 -19
  392. package/src/components/Spinner/spinner.css.ts +0 -17
  393. package/src/components/Spinner/spinner.demo.tsx +0 -13
  394. package/src/components/Spinner/spinner.tsx +0 -15
  395. package/src/components/Splitter/docs-meta.json +0 -9
  396. package/src/components/Splitter/index.ts +0 -1
  397. package/src/components/Splitter/registry-meta.json +0 -19
  398. package/src/components/Splitter/splitter.css.ts +0 -70
  399. package/src/components/Splitter/splitter.tsx +0 -521
  400. package/src/components/Stack/docs-meta.json +0 -9
  401. package/src/components/Stack/index.ts +0 -1
  402. package/src/components/Stack/registry-meta.json +0 -20
  403. package/src/components/Stack/stack.css.ts +0 -42
  404. package/src/components/Stack/stack.doc.tsx +0 -57
  405. package/src/components/Stack/stack.tsx +0 -32
  406. package/src/components/Surface/docs-meta.json +0 -9
  407. package/src/components/Surface/index.ts +0 -1
  408. package/src/components/Surface/registry-meta.json +0 -20
  409. package/src/components/Surface/surface.css.ts +0 -40
  410. package/src/components/Surface/surface.doc.tsx +0 -32
  411. package/src/components/Surface/surface.tsx +0 -19
  412. package/src/components/Switch/docs-meta.json +0 -13
  413. package/src/components/Switch/index.ts +0 -1
  414. package/src/components/Switch/registry-meta.json +0 -20
  415. package/src/components/Switch/switch.css.ts +0 -47
  416. package/src/components/Switch/switch.demo.tsx +0 -26
  417. package/src/components/Switch/switch.doc.tsx +0 -25
  418. package/src/components/Switch/switch.tsx +0 -25
  419. package/src/components/Table/docs-meta.json +0 -12
  420. package/src/components/Table/index.ts +0 -2
  421. package/src/components/Table/registry-meta.json +0 -19
  422. package/src/components/Table/table.css.ts +0 -72
  423. package/src/components/Table/table.demo.tsx +0 -58
  424. package/src/components/Table/table.tsx +0 -116
  425. package/src/components/Tabs/docs-meta.json +0 -13
  426. package/src/components/Tabs/index.ts +0 -1
  427. package/src/components/Tabs/registry-meta.json +0 -19
  428. package/src/components/Tabs/tabs.css.ts +0 -259
  429. package/src/components/Tabs/tabs.demo.tsx +0 -33
  430. package/src/components/Tabs/tabs.doc.tsx +0 -62
  431. package/src/components/Tabs/tabs.tsx +0 -119
  432. package/src/components/Text/docs-meta.json +0 -9
  433. package/src/components/Text/index.ts +0 -2
  434. package/src/components/Text/registry-meta.json +0 -19
  435. package/src/components/Text/text.css.ts +0 -167
  436. package/src/components/Text/text.doc.tsx +0 -53
  437. package/src/components/Text/text.tsx +0 -64
  438. package/src/components/Textarea/docs-meta.json +0 -9
  439. package/src/components/Textarea/index.ts +0 -1
  440. package/src/components/Textarea/registry-meta.json +0 -19
  441. package/src/components/Textarea/textarea.css.ts +0 -66
  442. package/src/components/Textarea/textarea.doc.tsx +0 -23
  443. package/src/components/Textarea/textarea.tsx +0 -48
  444. package/src/components/Toggle/docs-meta.json +0 -12
  445. package/src/components/Toggle/index.ts +0 -1
  446. package/src/components/Toggle/registry-meta.json +0 -19
  447. package/src/components/Toggle/toggle.css.ts +0 -101
  448. package/src/components/Toggle/toggle.doc.tsx +0 -24
  449. package/src/components/Toggle/toggle.tsx +0 -60
  450. package/src/components/ToggleGroup/docs-meta.json +0 -9
  451. package/src/components/ToggleGroup/index.ts +0 -1
  452. package/src/components/ToggleGroup/registry-meta.json +0 -20
  453. package/src/components/ToggleGroup/toggle-group.css.ts +0 -77
  454. package/src/components/ToggleGroup/toggle-group.doc.tsx +0 -38
  455. package/src/components/ToggleGroup/toggle-group.tsx +0 -131
  456. package/src/components/index.ts +0 -53
  457. package/src/demos/accordion.demo.tsx +0 -41
  458. package/src/index.ts +0 -3
  459. package/src/utils/heights.ts +0 -16
  460. package/src/utils/sprinkles.css.ts +0 -251
  461. package/src/utils/types.ts +0 -20
  462. package/src/utils/ve-style.utils.ts +0 -24
  463. package/tsconfig.build.json +0 -14
  464. package/tsconfig.json +0 -10
  465. package/vite.config.ts +0 -47
  466. /package/{dist/assets → assets}/components.css +0 -0
  467. /package/{dist/components → components}/Card/card.js +0 -0
  468. /package/{dist/components → components}/CloseButton/close-button.css.js +0 -0
  469. /package/{dist/components → components}/CloseButton/close-button.js +0 -0
  470. /package/{dist/components → components}/CloseButton/index.js +0 -0
  471. /package/{dist/components → components}/ColorPicker/color-picker.js +0 -0
  472. /package/{dist/components → components}/ColorSwatch/color-swatch.js +0 -0
  473. /package/{dist/components → components}/CopyButton/copy-button.css.js +0 -0
  474. /package/{dist/components → components}/CopyButton/copy-button.js +0 -0
  475. /package/{dist/components → components}/CopyButton/index.js +0 -0
  476. /package/{dist/components → components}/Grid/grid.css.js +0 -0
  477. /package/{dist/components → components}/Icon/icon.css.js +0 -0
  478. /package/{dist/components → components}/IconButton/icon-button.css.js +0 -0
  479. /package/{dist/components → components}/IconButton/index.js +0 -0
  480. /package/{dist/components → components}/SegmentedControl/segmented-control.js +0 -0
  481. /package/{dist/components → components}/Spinner/spinner.css.js +0 -0
  482. /package/{dist/components → components}/Text/index.js +0 -0
  483. /package/{dist/components → components}/index.js +0 -0
  484. /package/{dist/index.js → index.js} +0 -0
  485. /package/{dist/src → src}/DataTable/data-table-column-toggle.d.ts +0 -0
  486. /package/{dist/src → src}/DataTable/data-table-empty.d.ts +0 -0
  487. /package/{dist/src → src}/DataTable/data-table-error.d.ts +0 -0
  488. /package/{dist/src → src}/DataTable/data-table-infinite-loader.d.ts +0 -0
  489. /package/{dist/src → src}/DataTable/data-table-loading.d.ts +0 -0
  490. /package/{dist/src → src}/DataTable/data-table-pagination.d.ts +0 -0
  491. /package/{dist/src → src}/DataTable/data-table-toolbar.d.ts +0 -0
  492. /package/{dist/src → src}/DataTable/data-table.css.d.ts +0 -0
  493. /package/{dist/src → src}/DataTable/data-table.d.ts +0 -0
  494. /package/{dist/src → src}/DataTable/index.d.ts +0 -0
  495. /package/{dist/src → src}/DataTable/types.d.ts +0 -0
  496. /package/{dist/src → src}/DataTable/use-infinite-scroll.d.ts +0 -0
  497. /package/{dist/src → src}/components/Accordion/accordion.css.d.ts +0 -0
  498. /package/{dist/src → src}/components/Accordion/accordion.d.ts +0 -0
  499. /package/{dist/src → src}/components/Accordion/index.d.ts +0 -0
  500. /package/{dist/src → src}/components/Alert/alert.css.d.ts +0 -0
  501. /package/{dist/src → src}/components/Alert/alert.d.ts +0 -0
  502. /package/{dist/src → src}/components/Alert/index.d.ts +0 -0
  503. /package/{dist/src → src}/components/AlertDialog/alert-dialog.css.d.ts +0 -0
  504. /package/{dist/src → src}/components/AlertDialog/alert-dialog.d.ts +0 -0
  505. /package/{dist/src → src}/components/AlertDialog/index.d.ts +0 -0
  506. /package/{dist/src → src}/components/Autocomplete/autocomplete.css.d.ts +0 -0
  507. /package/{dist/src → src}/components/Autocomplete/autocomplete.d.ts +0 -0
  508. /package/{dist/src → src}/components/Autocomplete/index.d.ts +0 -0
  509. /package/{dist/src → src}/components/Avatar/avatar.css.d.ts +0 -0
  510. /package/{dist/src → src}/components/Avatar/avatar.d.ts +0 -0
  511. /package/{dist/src → src}/components/Avatar/index.d.ts +0 -0
  512. /package/{dist/src → src}/components/Badge/badge.css.d.ts +0 -0
  513. /package/{dist/src → src}/components/Badge/badge.d.ts +0 -0
  514. /package/{dist/src → src}/components/Badge/index.d.ts +0 -0
  515. /package/{dist/src → src}/components/Box/box.css.d.ts +0 -0
  516. /package/{dist/src → src}/components/Box/box.d.ts +0 -0
  517. /package/{dist/src → src}/components/Box/index.d.ts +0 -0
  518. /package/{dist/src → src}/components/Breadcrumbs/breadcrumbs.css.d.ts +0 -0
  519. /package/{dist/src → src}/components/Breadcrumbs/breadcrumbs.d.ts +0 -0
  520. /package/{dist/src → src}/components/Breadcrumbs/index.d.ts +0 -0
  521. /package/{dist/src → src}/components/Button/button.css.d.ts +0 -0
  522. /package/{dist/src → src}/components/Button/button.d.ts +0 -0
  523. /package/{dist/src → src}/components/Button/index.d.ts +0 -0
  524. /package/{dist/src → src}/components/Calendar/calendar.css.d.ts +0 -0
  525. /package/{dist/src → src}/components/Calendar/calendar.d.ts +0 -0
  526. /package/{dist/src → src}/components/Calendar/index.d.ts +0 -0
  527. /package/{dist/src → src}/components/Card/card.d.ts +0 -0
  528. /package/{dist/src → src}/components/Card/index.d.ts +0 -0
  529. /package/{dist/src → src}/components/Checkbox/checkbox.css.d.ts +0 -0
  530. /package/{dist/src → src}/components/Checkbox/checkbox.d.ts +0 -0
  531. /package/{dist/src → src}/components/Checkbox/index.d.ts +0 -0
  532. /package/{dist/src → src}/components/CloseButton/close-button.css.d.ts +0 -0
  533. /package/{dist/src → src}/components/CloseButton/close-button.d.ts +0 -0
  534. /package/{dist/src → src}/components/CloseButton/index.d.ts +0 -0
  535. /package/{dist/src → src}/components/ColorPicker/color-picker.d.ts +0 -0
  536. /package/{dist/src → src}/components/ColorPicker/index.d.ts +0 -0
  537. /package/{dist/src → src}/components/ColorSwatch/color-swatch.d.ts +0 -0
  538. /package/{dist/src → src}/components/ColorSwatch/index.d.ts +0 -0
  539. /package/{dist/src → src}/components/Combobox/combobox.css.d.ts +0 -0
  540. /package/{dist/src → src}/components/Combobox/combobox.d.ts +0 -0
  541. /package/{dist/src → src}/components/Combobox/index.d.ts +0 -0
  542. /package/{dist/src → src}/components/Command/command.css.d.ts +0 -0
  543. /package/{dist/src → src}/components/Command/command.d.ts +0 -0
  544. /package/{dist/src → src}/components/Command/index.d.ts +0 -0
  545. /package/{dist/src → src}/components/Container/container.css.d.ts +0 -0
  546. /package/{dist/src → src}/components/Container/container.d.ts +0 -0
  547. /package/{dist/src → src}/components/Container/index.d.ts +0 -0
  548. /package/{dist/src → src}/components/CopyButton/copy-button.css.d.ts +0 -0
  549. /package/{dist/src → src}/components/CopyButton/copy-button.d.ts +0 -0
  550. /package/{dist/src → src}/components/CopyButton/index.d.ts +0 -0
  551. /package/{dist/src → src}/components/DatePicker/date-picker.d.ts +0 -0
  552. /package/{dist/src → src}/components/DatePicker/index.d.ts +0 -0
  553. /package/{dist/src → src}/components/Dialog/dialog.css.d.ts +0 -0
  554. /package/{dist/src → src}/components/Dialog/dialog.d.ts +0 -0
  555. /package/{dist/src → src}/components/Dialog/index.d.ts +0 -0
  556. /package/{dist/src → src}/components/Drawer/drawer.css.d.ts +0 -0
  557. /package/{dist/src → src}/components/Drawer/drawer.d.ts +0 -0
  558. /package/{dist/src → src}/components/Drawer/index.d.ts +0 -0
  559. /package/{dist/src → src}/components/Field/field.css.d.ts +0 -0
  560. /package/{dist/src → src}/components/Field/field.d.ts +0 -0
  561. /package/{dist/src → src}/components/Field/index.d.ts +0 -0
  562. /package/{dist/src → src}/components/Grid/grid.css.d.ts +0 -0
  563. /package/{dist/src → src}/components/Grid/grid.d.ts +0 -0
  564. /package/{dist/src → src}/components/Grid/index.d.ts +0 -0
  565. /package/{dist/src → src}/components/Icon/icon.css.d.ts +0 -0
  566. /package/{dist/src → src}/components/Icon/icon.d.ts +0 -0
  567. /package/{dist/src → src}/components/Icon/index.d.ts +0 -0
  568. /package/{dist/src → src}/components/IconButton/icon-button.css.d.ts +0 -0
  569. /package/{dist/src → src}/components/IconButton/icon-button.d.ts +0 -0
  570. /package/{dist/src → src}/components/IconButton/index.d.ts +0 -0
  571. /package/{dist/src → src}/components/Input/index.d.ts +0 -0
  572. /package/{dist/src → src}/components/Input/input.css.d.ts +0 -0
  573. /package/{dist/src → src}/components/Input/input.d.ts +0 -0
  574. /package/{dist/src → src}/components/InputGroup/index.d.ts +0 -0
  575. /package/{dist/src → src}/components/InputGroup/input-group.css.d.ts +0 -0
  576. /package/{dist/src → src}/components/InputGroup/input-group.d.ts +0 -0
  577. /package/{dist/src → src}/components/Menu/index.d.ts +0 -0
  578. /package/{dist/src → src}/components/Menu/menu.css.d.ts +0 -0
  579. /package/{dist/src → src}/components/Menu/menu.d.ts +0 -0
  580. /package/{dist/src → src}/components/OTPField/index.d.ts +0 -0
  581. /package/{dist/src → src}/components/OTPField/otp-field.css.d.ts +0 -0
  582. /package/{dist/src → src}/components/OTPField/otp-field.d.ts +0 -0
  583. /package/{dist/src → src}/components/Popover/index.d.ts +0 -0
  584. /package/{dist/src → src}/components/Popover/popover.css.d.ts +0 -0
  585. /package/{dist/src → src}/components/Popover/popover.d.ts +0 -0
  586. /package/{dist/src → src}/components/Progress/index.d.ts +0 -0
  587. /package/{dist/src → src}/components/Progress/progress.css.d.ts +0 -0
  588. /package/{dist/src → src}/components/Progress/progress.d.ts +0 -0
  589. /package/{dist/src → src}/components/Radio/index.d.ts +0 -0
  590. /package/{dist/src → src}/components/Radio/radio.css.d.ts +0 -0
  591. /package/{dist/src → src}/components/Radio/radio.d.ts +0 -0
  592. /package/{dist/src → src}/components/ScrollArea/index.d.ts +0 -0
  593. /package/{dist/src → src}/components/ScrollArea/scroll-area.css.d.ts +0 -0
  594. /package/{dist/src → src}/components/ScrollArea/scroll-area.d.ts +0 -0
  595. /package/{dist/src → src}/components/SegmentedControl/index.d.ts +0 -0
  596. /package/{dist/src → src}/components/SegmentedControl/segmented-control.d.ts +0 -0
  597. /package/{dist/src → src}/components/Select/index.d.ts +0 -0
  598. /package/{dist/src → src}/components/Select/select.css.d.ts +0 -0
  599. /package/{dist/src → src}/components/Select/select.d.ts +0 -0
  600. /package/{dist/src → src}/components/Separator/index.d.ts +0 -0
  601. /package/{dist/src → src}/components/Separator/separator.css.d.ts +0 -0
  602. /package/{dist/src → src}/components/Separator/separator.d.ts +0 -0
  603. /package/{dist/src → src}/components/Sheet/index.d.ts +0 -0
  604. /package/{dist/src → src}/components/Sheet/sheet.css.d.ts +0 -0
  605. /package/{dist/src → src}/components/Sheet/sheet.d.ts +0 -0
  606. /package/{dist/src → src}/components/Slider/index.d.ts +0 -0
  607. /package/{dist/src → src}/components/Slider/slider.css.d.ts +0 -0
  608. /package/{dist/src → src}/components/Slider/slider.d.ts +0 -0
  609. /package/{dist/src → src}/components/Spinner/index.d.ts +0 -0
  610. /package/{dist/src → src}/components/Spinner/spinner.css.d.ts +0 -0
  611. /package/{dist/src → src}/components/Spinner/spinner.d.ts +0 -0
  612. /package/{dist/src → src}/components/Splitter/index.d.ts +0 -0
  613. /package/{dist/src → src}/components/Splitter/splitter.css.d.ts +0 -0
  614. /package/{dist/src → src}/components/Splitter/splitter.d.ts +0 -0
  615. /package/{dist/src → src}/components/Stack/index.d.ts +0 -0
  616. /package/{dist/src → src}/components/Stack/stack.css.d.ts +0 -0
  617. /package/{dist/src → src}/components/Stack/stack.d.ts +0 -0
  618. /package/{dist/src → src}/components/Surface/index.d.ts +0 -0
  619. /package/{dist/src → src}/components/Surface/surface.css.d.ts +0 -0
  620. /package/{dist/src → src}/components/Surface/surface.d.ts +0 -0
  621. /package/{dist/src → src}/components/Switch/index.d.ts +0 -0
  622. /package/{dist/src → src}/components/Switch/switch.css.d.ts +0 -0
  623. /package/{dist/src → src}/components/Switch/switch.d.ts +0 -0
  624. /package/{dist/src → src}/components/Table/index.d.ts +0 -0
  625. /package/{dist/src → src}/components/Table/table.css.d.ts +0 -0
  626. /package/{dist/src → src}/components/Table/table.d.ts +0 -0
  627. /package/{dist/src → src}/components/Tabs/index.d.ts +0 -0
  628. /package/{dist/src → src}/components/Tabs/tabs.css.d.ts +0 -0
  629. /package/{dist/src → src}/components/Tabs/tabs.d.ts +0 -0
  630. /package/{dist/src → src}/components/Text/index.d.ts +0 -0
  631. /package/{dist/src → src}/components/Text/text.css.d.ts +0 -0
  632. /package/{dist/src → src}/components/Text/text.d.ts +0 -0
  633. /package/{dist/src → src}/components/Textarea/index.d.ts +0 -0
  634. /package/{dist/src → src}/components/Textarea/textarea.css.d.ts +0 -0
  635. /package/{dist/src → src}/components/Textarea/textarea.d.ts +0 -0
  636. /package/{dist/src → src}/components/Toggle/index.d.ts +0 -0
  637. /package/{dist/src → src}/components/Toggle/toggle.css.d.ts +0 -0
  638. /package/{dist/src → src}/components/Toggle/toggle.d.ts +0 -0
  639. /package/{dist/src → src}/components/ToggleGroup/index.d.ts +0 -0
  640. /package/{dist/src → src}/components/ToggleGroup/toggle-group.css.d.ts +0 -0
  641. /package/{dist/src → src}/components/ToggleGroup/toggle-group.d.ts +0 -0
  642. /package/{dist/src → src}/components/index.d.ts +0 -0
  643. /package/{dist/src → src}/index.d.ts +0 -0
  644. /package/{dist/src → src}/utils/heights.d.ts +0 -0
  645. /package/{dist/src → src}/utils/sprinkles.css.d.ts +0 -0
  646. /package/{dist/src → src}/utils/types.d.ts +0 -0
  647. /package/{dist/src → src}/utils/ve-style.utils.d.ts +0 -0
  648. /package/{dist/utils → utils}/ve-style.utils.js +0 -0
package/MIGRATION-PLAN.md DELETED
@@ -1,423 +0,0 @@
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 DELETED
@@ -1,192 +0,0 @@
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