@blenx-dev/components 0.0.2 → 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.
- package/package.json +209 -38
- package/.turbo/turbo-check-types.log +0 -1
- package/MIGRATION-PLAN.md +0 -423
- package/TASKS.md +0 -192
- package/blenx-dev-ui-0.0.0.tgz +0 -0
- package/dist/src/components/Accordion/accordion.demo.d.ts +0 -5
- package/dist/src/components/Alert/alert.demo.d.ts +0 -6
- package/dist/src/components/AlertDialog/alert-dialog.demo.d.ts +0 -5
- package/dist/src/components/AlertDialog/alert-dialog.doc.d.ts +0 -1
- package/dist/src/components/Avatar/avatar.doc.d.ts +0 -2
- package/dist/src/components/Badge/badge.demo.d.ts +0 -5
- package/dist/src/components/Badge/badge.doc.d.ts +0 -1
- package/dist/src/components/Box/box.doc.d.ts +0 -1
- package/dist/src/components/Breadcrumbs/breadcrumbs.doc.d.ts +0 -2
- package/dist/src/components/Button/button.demo.d.ts +0 -5
- package/dist/src/components/Calendar/calendar.doc.d.ts +0 -1
- package/dist/src/components/Card/card.demo.d.ts +0 -8
- package/dist/src/components/Card/card.doc.d.ts +0 -2
- package/dist/src/components/ColorPicker/color-picker.doc.d.ts +0 -1
- package/dist/src/components/ColorSwatch/color-swatch.doc.d.ts +0 -2
- package/dist/src/components/Command/command.demo.d.ts +0 -6
- package/dist/src/components/Command/command.doc.d.ts +0 -3
- package/dist/src/components/Container/container.doc.d.ts +0 -1
- package/dist/src/components/DatePicker/date-picker.doc.d.ts +0 -1
- package/dist/src/components/Dialog/dialog.demo.d.ts +0 -5
- package/dist/src/components/Dialog/dialog.doc.d.ts +0 -1
- package/dist/src/components/Drawer/drawer.demo.d.ts +0 -5
- package/dist/src/components/Drawer/drawer.doc.d.ts +0 -2
- package/dist/src/components/Field/field.doc.d.ts +0 -1
- package/dist/src/components/Grid/grid.doc.d.ts +0 -1
- package/dist/src/components/Icon/icon.demo.d.ts +0 -5
- package/dist/src/components/IconButton/icon-button.demo.d.ts +0 -5
- package/dist/src/components/Input/input.demo.d.ts +0 -5
- package/dist/src/components/Input/input.doc.d.ts +0 -2
- package/dist/src/components/InputGroup/input-group.demo.d.ts +0 -5
- package/dist/src/components/Menu/menu.demo.d.ts +0 -5
- package/dist/src/components/OTPField/otp-field.demo.d.ts +0 -6
- package/dist/src/components/Popover/popover.demo.d.ts +0 -5
- package/dist/src/components/ScrollArea/scroll-area.doc.d.ts +0 -2
- package/dist/src/components/SegmentedControl/segmented-control.doc.d.ts +0 -1
- package/dist/src/components/Select/select.demo.d.ts +0 -5
- package/dist/src/components/Select/select.doc.d.ts +0 -2
- package/dist/src/components/Separator/separator.doc.d.ts +0 -4
- package/dist/src/components/Sheet/sheet.demo.d.ts +0 -5
- package/dist/src/components/Spinner/spinner.demo.d.ts +0 -1
- package/dist/src/components/Stack/stack.doc.d.ts +0 -3
- package/dist/src/components/Surface/surface.doc.d.ts +0 -2
- package/dist/src/components/Switch/switch.demo.d.ts +0 -5
- package/dist/src/components/Switch/switch.doc.d.ts +0 -2
- package/dist/src/components/Table/table.demo.d.ts +0 -5
- package/dist/src/components/Tabs/tabs.demo.d.ts +0 -5
- package/dist/src/components/Tabs/tabs.doc.d.ts +0 -3
- package/dist/src/components/Text/text.doc.d.ts +0 -4
- package/dist/src/components/Textarea/textarea.doc.d.ts +0 -2
- package/dist/src/components/Toggle/toggle.doc.d.ts +0 -1
- package/dist/src/components/ToggleGroup/toggle-group.doc.d.ts +0 -3
- package/dist/src/demos/accordion.demo.d.ts +0 -5
- package/package.build.json +0 -39
- package/scripts/generate-api.ts +0 -183
- package/scripts/generate-package.ts +0 -106
- package/src/DataTable/data-table-column-toggle.tsx +0 -73
- package/src/DataTable/data-table-empty.tsx +0 -27
- package/src/DataTable/data-table-error.tsx +0 -25
- package/src/DataTable/data-table-infinite-loader.tsx +0 -73
- package/src/DataTable/data-table-loading.tsx +0 -67
- package/src/DataTable/data-table-pagination.tsx +0 -80
- package/src/DataTable/data-table-toolbar.tsx +0 -62
- package/src/DataTable/data-table.css.ts +0 -421
- package/src/DataTable/data-table.tsx +0 -507
- package/src/DataTable/index.ts +0 -24
- package/src/DataTable/registry-meta.json +0 -66
- package/src/DataTable/types.ts +0 -169
- package/src/DataTable/use-infinite-scroll.ts +0 -67
- package/src/components/Accordion/accordion.css.ts +0 -93
- package/src/components/Accordion/accordion.demo.tsx +0 -42
- package/src/components/Accordion/accordion.tsx +0 -87
- package/src/components/Accordion/docs-meta.json +0 -13
- package/src/components/Accordion/index.ts +0 -8
- package/src/components/Accordion/registry-meta.json +0 -19
- package/src/components/Alert/alert.css.ts +0 -29
- package/src/components/Alert/alert.demo.tsx +0 -34
- package/src/components/Alert/alert.tsx +0 -40
- package/src/components/Alert/docs-meta.json +0 -12
- package/src/components/Alert/index.ts +0 -1
- package/src/components/Alert/registry-meta.json +0 -20
- package/src/components/AlertDialog/alert-dialog.css.ts +0 -146
- package/src/components/AlertDialog/alert-dialog.demo.tsx +0 -59
- package/src/components/AlertDialog/alert-dialog.doc.tsx +0 -31
- package/src/components/AlertDialog/alert-dialog.tsx +0 -197
- package/src/components/AlertDialog/docs-meta.json +0 -14
- package/src/components/AlertDialog/index.ts +0 -1
- package/src/components/AlertDialog/registry-meta.json +0 -20
- package/src/components/Autocomplete/autocomplete.css.ts +0 -168
- package/src/components/Autocomplete/autocomplete.tsx +0 -226
- package/src/components/Autocomplete/docs-meta.json +0 -9
- package/src/components/Autocomplete/index.ts +0 -1
- package/src/components/Autocomplete/registry-meta.json +0 -20
- package/src/components/Avatar/avatar.css.ts +0 -72
- package/src/components/Avatar/avatar.doc.tsx +0 -32
- package/src/components/Avatar/avatar.tsx +0 -49
- package/src/components/Avatar/docs-meta.json +0 -9
- package/src/components/Avatar/index.ts +0 -1
- package/src/components/Avatar/registry-meta.json +0 -19
- package/src/components/Badge/badge.css.ts +0 -40
- package/src/components/Badge/badge.demo.tsx +0 -18
- package/src/components/Badge/badge.doc.tsx +0 -12
- package/src/components/Badge/badge.tsx +0 -13
- package/src/components/Badge/docs-meta.json +0 -9
- package/src/components/Badge/index.ts +0 -1
- package/src/components/Badge/registry-meta.json +0 -19
- package/src/components/Box/box.css.ts +0 -7
- package/src/components/Box/box.doc.tsx +0 -19
- package/src/components/Box/box.tsx +0 -21
- package/src/components/Box/docs-meta.json +0 -9
- package/src/components/Box/index.ts +0 -1
- package/src/components/Box/registry-meta.json +0 -14
- package/src/components/Breadcrumbs/breadcrumbs.css.ts +0 -72
- package/src/components/Breadcrumbs/breadcrumbs.doc.tsx +0 -61
- package/src/components/Breadcrumbs/breadcrumbs.tsx +0 -79
- package/src/components/Breadcrumbs/docs-meta.json +0 -12
- package/src/components/Breadcrumbs/index.ts +0 -9
- package/src/components/Breadcrumbs/registry-meta.json +0 -19
- package/src/components/Button/button.css.ts +0 -209
- package/src/components/Button/button.demo.tsx +0 -119
- package/src/components/Button/button.tsx +0 -55
- package/src/components/Button/docs-meta.json +0 -13
- package/src/components/Button/index.ts +0 -1
- package/src/components/Button/registry-meta.json +0 -20
- package/src/components/Calendar/calendar.css.ts +0 -188
- package/src/components/Calendar/calendar.doc.tsx +0 -10
- package/src/components/Calendar/calendar.tsx +0 -143
- package/src/components/Calendar/docs-meta.json +0 -9
- package/src/components/Calendar/index.ts +0 -1
- package/src/components/Calendar/registry-meta.json +0 -20
- package/src/components/Card/card.demo.tsx +0 -177
- package/src/components/Card/card.doc.tsx +0 -47
- package/src/components/Card/card.tsx +0 -32
- package/src/components/Card/docs-meta.json +0 -9
- package/src/components/Card/index.ts +0 -1
- package/src/components/Card/registry-meta.json +0 -15
- package/src/components/Checkbox/checkbox.css.ts +0 -77
- package/src/components/Checkbox/checkbox.tsx +0 -94
- package/src/components/Checkbox/docs-meta.json +0 -13
- package/src/components/Checkbox/index.ts +0 -1
- package/src/components/Checkbox/registry-meta.json +0 -19
- package/src/components/CloseButton/close-button.css.ts +0 -11
- package/src/components/CloseButton/close-button.tsx +0 -15
- package/src/components/CloseButton/index.ts +0 -2
- package/src/components/CloseButton/registry-meta.json +0 -15
- package/src/components/ColorPicker/color-picker.doc.tsx +0 -12
- package/src/components/ColorPicker/color-picker.tsx +0 -123
- package/src/components/ColorPicker/docs-meta.json +0 -9
- package/src/components/ColorPicker/index.ts +0 -1
- package/src/components/ColorPicker/registry-meta.json +0 -15
- package/src/components/ColorSwatch/color-swatch.doc.tsx +0 -25
- package/src/components/ColorSwatch/color-swatch.tsx +0 -21
- package/src/components/ColorSwatch/docs-meta.json +0 -9
- package/src/components/ColorSwatch/index.ts +0 -1
- package/src/components/ColorSwatch/registry-meta.json +0 -20
- package/src/components/Combobox/combobox.css.ts +0 -334
- package/src/components/Combobox/combobox.tsx +0 -350
- package/src/components/Combobox/docs-meta.json +0 -9
- package/src/components/Combobox/index.ts +0 -1
- package/src/components/Combobox/registry-meta.json +0 -20
- package/src/components/Command/command.css.ts +0 -131
- package/src/components/Command/command.demo.tsx +0 -110
- package/src/components/Command/command.doc.tsx +0 -100
- package/src/components/Command/command.tsx +0 -413
- package/src/components/Command/docs-meta.json +0 -21
- package/src/components/Command/index.ts +0 -7
- package/src/components/Command/registry-meta.json +0 -20
- package/src/components/Container/container.css.ts +0 -40
- package/src/components/Container/container.doc.tsx +0 -28
- package/src/components/Container/container.tsx +0 -24
- package/src/components/Container/docs-meta.json +0 -9
- package/src/components/Container/index.ts +0 -1
- package/src/components/Container/registry-meta.json +0 -20
- package/src/components/CopyButton/copy-button.css.ts +0 -11
- package/src/components/CopyButton/copy-button.tsx +0 -45
- package/src/components/CopyButton/index.ts +0 -2
- package/src/components/CopyButton/registry-meta.json +0 -15
- package/src/components/DatePicker/date-picker.doc.tsx +0 -12
- package/src/components/DatePicker/date-picker.tsx +0 -75
- package/src/components/DatePicker/docs-meta.json +0 -9
- package/src/components/DatePicker/index.ts +0 -1
- package/src/components/DatePicker/registry-meta.json +0 -15
- package/src/components/Dialog/dialog.css.ts +0 -155
- package/src/components/Dialog/dialog.demo.tsx +0 -39
- package/src/components/Dialog/dialog.doc.tsx +0 -33
- package/src/components/Dialog/dialog.tsx +0 -186
- package/src/components/Dialog/docs-meta.json +0 -13
- package/src/components/Dialog/index.ts +0 -1
- package/src/components/Dialog/registry-meta.json +0 -20
- package/src/components/Drawer/docs-meta.json +0 -9
- package/src/components/Drawer/drawer.css.ts +0 -412
- package/src/components/Drawer/drawer.demo.tsx +0 -58
- package/src/components/Drawer/drawer.doc.tsx +0 -49
- package/src/components/Drawer/drawer.tsx +0 -574
- package/src/components/Drawer/index.ts +0 -1
- package/src/components/Drawer/registry-meta.json +0 -20
- package/src/components/Field/docs-meta.json +0 -9
- package/src/components/Field/field.css.ts +0 -35
- package/src/components/Field/field.doc.tsx +0 -19
- package/src/components/Field/field.tsx +0 -101
- package/src/components/Field/index.ts +0 -1
- package/src/components/Field/registry-meta.json +0 -20
- package/src/components/Grid/docs-meta.json +0 -9
- package/src/components/Grid/grid.css.ts +0 -12
- package/src/components/Grid/grid.doc.tsx +0 -148
- package/src/components/Grid/grid.tsx +0 -57
- package/src/components/Grid/index.ts +0 -1
- package/src/components/Grid/registry-meta.json +0 -20
- package/src/components/Icon/docs-meta.json +0 -13
- package/src/components/Icon/icon.css.ts +0 -10
- package/src/components/Icon/icon.demo.tsx +0 -97
- package/src/components/Icon/icon.tsx +0 -15
- package/src/components/Icon/index.ts +0 -1
- package/src/components/Icon/registry-meta.json +0 -20
- package/src/components/IconButton/docs-meta.json +0 -13
- package/src/components/IconButton/icon-button.css.ts +0 -6
- package/src/components/IconButton/icon-button.demo.tsx +0 -102
- package/src/components/IconButton/icon-button.tsx +0 -11
- package/src/components/IconButton/index.ts +0 -2
- package/src/components/IconButton/registry-meta.json +0 -15
- package/src/components/Input/docs-meta.json +0 -9
- package/src/components/Input/index.ts +0 -1
- package/src/components/Input/input.css.ts +0 -73
- package/src/components/Input/input.demo.tsx +0 -24
- package/src/components/Input/input.doc.tsx +0 -25
- package/src/components/Input/input.tsx +0 -50
- package/src/components/Input/registry-meta.json +0 -19
- package/src/components/InputGroup/docs-meta.json +0 -9
- package/src/components/InputGroup/index.ts +0 -1
- package/src/components/InputGroup/input-group.css.ts +0 -157
- package/src/components/InputGroup/input-group.demo.tsx +0 -53
- package/src/components/InputGroup/input-group.tsx +0 -133
- package/src/components/InputGroup/registry-meta.json +0 -19
- package/src/components/Menu/docs-meta.json +0 -13
- package/src/components/Menu/index.ts +0 -1
- package/src/components/Menu/menu.css.ts +0 -128
- package/src/components/Menu/menu.demo.tsx +0 -40
- package/src/components/Menu/menu.tsx +0 -115
- package/src/components/Menu/registry-meta.json +0 -19
- package/src/components/OTPField/docs-meta.json +0 -9
- package/src/components/OTPField/index.ts +0 -1
- package/src/components/OTPField/otp-field.css.ts +0 -55
- package/src/components/OTPField/otp-field.demo.tsx +0 -57
- package/src/components/OTPField/otp-field.tsx +0 -46
- package/src/components/OTPField/registry-meta.json +0 -19
- package/src/components/Popover/docs-meta.json +0 -13
- package/src/components/Popover/index.ts +0 -1
- package/src/components/Popover/popover.css.ts +0 -82
- package/src/components/Popover/popover.demo.tsx +0 -34
- package/src/components/Popover/popover.tsx +0 -113
- package/src/components/Popover/registry-meta.json +0 -19
- package/src/components/Progress/docs-meta.json +0 -12
- package/src/components/Progress/index.ts +0 -7
- package/src/components/Progress/progress.css.ts +0 -38
- package/src/components/Progress/progress.tsx +0 -62
- package/src/components/Progress/registry-meta.json +0 -19
- package/src/components/Radio/docs-meta.json +0 -13
- package/src/components/Radio/index.ts +0 -1
- package/src/components/Radio/radio.css.ts +0 -73
- package/src/components/Radio/radio.tsx +0 -49
- package/src/components/Radio/registry-meta.json +0 -19
- package/src/components/ScrollArea/docs-meta.json +0 -9
- package/src/components/ScrollArea/index.ts +0 -1
- package/src/components/ScrollArea/registry-meta.json +0 -19
- package/src/components/ScrollArea/scroll-area.css.ts +0 -80
- package/src/components/ScrollArea/scroll-area.doc.tsx +0 -44
- package/src/components/ScrollArea/scroll-area.tsx +0 -96
- package/src/components/SegmentedControl/docs-meta.json +0 -9
- package/src/components/SegmentedControl/index.ts +0 -1
- package/src/components/SegmentedControl/registry-meta.json +0 -15
- package/src/components/SegmentedControl/segmented-control.doc.tsx +0 -28
- package/src/components/SegmentedControl/segmented-control.tsx +0 -42
- package/src/components/Select/docs-meta.json +0 -13
- package/src/components/Select/index.ts +0 -1
- package/src/components/Select/registry-meta.json +0 -20
- package/src/components/Select/select.css.ts +0 -183
- package/src/components/Select/select.demo.tsx +0 -35
- package/src/components/Select/select.doc.tsx +0 -65
- package/src/components/Select/select.tsx +0 -165
- package/src/components/Separator/docs-meta.json +0 -12
- package/src/components/Separator/index.ts +0 -1
- package/src/components/Separator/registry-meta.json +0 -20
- package/src/components/Separator/separator.css.ts +0 -60
- package/src/components/Separator/separator.doc.tsx +0 -44
- package/src/components/Separator/separator.tsx +0 -34
- package/src/components/Sheet/docs-meta.json +0 -13
- package/src/components/Sheet/index.ts +0 -1
- package/src/components/Sheet/registry-meta.json +0 -20
- package/src/components/Sheet/sheet.css.ts +0 -192
- package/src/components/Sheet/sheet.demo.tsx +0 -53
- package/src/components/Sheet/sheet.tsx +0 -213
- package/src/components/Slider/docs-meta.json +0 -13
- package/src/components/Slider/index.ts +0 -1
- package/src/components/Slider/registry-meta.json +0 -19
- package/src/components/Slider/slider.css.ts +0 -82
- package/src/components/Slider/slider.tsx +0 -100
- package/src/components/Spinner/docs-meta.json +0 -12
- package/src/components/Spinner/index.ts +0 -1
- package/src/components/Spinner/registry-meta.json +0 -19
- package/src/components/Spinner/spinner.css.ts +0 -17
- package/src/components/Spinner/spinner.demo.tsx +0 -13
- package/src/components/Spinner/spinner.tsx +0 -15
- package/src/components/Splitter/docs-meta.json +0 -9
- package/src/components/Splitter/index.ts +0 -1
- package/src/components/Splitter/registry-meta.json +0 -19
- package/src/components/Splitter/splitter.css.ts +0 -70
- package/src/components/Splitter/splitter.tsx +0 -521
- package/src/components/Stack/docs-meta.json +0 -9
- package/src/components/Stack/index.ts +0 -1
- package/src/components/Stack/registry-meta.json +0 -20
- package/src/components/Stack/stack.css.ts +0 -42
- package/src/components/Stack/stack.doc.tsx +0 -57
- package/src/components/Stack/stack.tsx +0 -32
- package/src/components/Surface/docs-meta.json +0 -9
- package/src/components/Surface/index.ts +0 -1
- package/src/components/Surface/registry-meta.json +0 -20
- package/src/components/Surface/surface.css.ts +0 -40
- package/src/components/Surface/surface.doc.tsx +0 -32
- package/src/components/Surface/surface.tsx +0 -19
- package/src/components/Switch/docs-meta.json +0 -13
- package/src/components/Switch/index.ts +0 -1
- package/src/components/Switch/registry-meta.json +0 -20
- package/src/components/Switch/switch.css.ts +0 -47
- package/src/components/Switch/switch.demo.tsx +0 -26
- package/src/components/Switch/switch.doc.tsx +0 -25
- package/src/components/Switch/switch.tsx +0 -25
- package/src/components/Table/docs-meta.json +0 -12
- package/src/components/Table/index.ts +0 -2
- package/src/components/Table/registry-meta.json +0 -19
- package/src/components/Table/table.css.ts +0 -72
- package/src/components/Table/table.demo.tsx +0 -58
- package/src/components/Table/table.tsx +0 -116
- package/src/components/Tabs/docs-meta.json +0 -13
- package/src/components/Tabs/index.ts +0 -1
- package/src/components/Tabs/registry-meta.json +0 -19
- package/src/components/Tabs/tabs.css.ts +0 -259
- package/src/components/Tabs/tabs.demo.tsx +0 -33
- package/src/components/Tabs/tabs.doc.tsx +0 -62
- package/src/components/Tabs/tabs.tsx +0 -119
- package/src/components/Text/docs-meta.json +0 -9
- package/src/components/Text/index.ts +0 -2
- package/src/components/Text/registry-meta.json +0 -19
- package/src/components/Text/text.css.ts +0 -167
- package/src/components/Text/text.doc.tsx +0 -53
- package/src/components/Text/text.tsx +0 -64
- package/src/components/Textarea/docs-meta.json +0 -9
- package/src/components/Textarea/index.ts +0 -1
- package/src/components/Textarea/registry-meta.json +0 -19
- package/src/components/Textarea/textarea.css.ts +0 -66
- package/src/components/Textarea/textarea.doc.tsx +0 -23
- package/src/components/Textarea/textarea.tsx +0 -48
- package/src/components/Toggle/docs-meta.json +0 -12
- package/src/components/Toggle/index.ts +0 -1
- package/src/components/Toggle/registry-meta.json +0 -19
- package/src/components/Toggle/toggle.css.ts +0 -101
- package/src/components/Toggle/toggle.doc.tsx +0 -24
- package/src/components/Toggle/toggle.tsx +0 -60
- package/src/components/ToggleGroup/docs-meta.json +0 -9
- package/src/components/ToggleGroup/index.ts +0 -1
- package/src/components/ToggleGroup/registry-meta.json +0 -20
- package/src/components/ToggleGroup/toggle-group.css.ts +0 -77
- package/src/components/ToggleGroup/toggle-group.doc.tsx +0 -38
- package/src/components/ToggleGroup/toggle-group.tsx +0 -131
- package/src/components/index.ts +0 -53
- package/src/demos/accordion.demo.tsx +0 -41
- package/src/index.ts +0 -3
- package/src/utils/heights.ts +0 -16
- package/src/utils/sprinkles.css.ts +0 -251
- package/src/utils/types.ts +0 -20
- package/src/utils/ve-style.utils.ts +0 -24
- package/tsconfig.build.json +0 -14
- package/tsconfig.json +0 -10
- package/vite.config.ts +0 -52
- /package/{dist/assets → assets}/components.css +0 -0
- /package/{dist/components → components}/Accordion/accordion.css.js +0 -0
- /package/{dist/components → components}/Accordion/accordion.js +0 -0
- /package/{dist/components → components}/Alert/alert.css.js +0 -0
- /package/{dist/components → components}/Alert/alert.js +0 -0
- /package/{dist/components → components}/AlertDialog/alert-dialog.css.js +0 -0
- /package/{dist/components → components}/AlertDialog/alert-dialog.js +0 -0
- /package/{dist/components → components}/Autocomplete/autocomplete.css.js +0 -0
- /package/{dist/components → components}/Autocomplete/autocomplete.js +0 -0
- /package/{dist/components → components}/Avatar/avatar.css.js +0 -0
- /package/{dist/components → components}/Avatar/avatar.js +0 -0
- /package/{dist/components → components}/Badge/badge.css.js +0 -0
- /package/{dist/components → components}/Badge/badge.js +0 -0
- /package/{dist/components → components}/Box/box.css.js +0 -0
- /package/{dist/components → components}/Box/box.js +0 -0
- /package/{dist/components → components}/Breadcrumbs/breadcrumbs.css.js +0 -0
- /package/{dist/components → components}/Breadcrumbs/breadcrumbs.js +0 -0
- /package/{dist/components → components}/Button/button.css.js +0 -0
- /package/{dist/components → components}/Button/button.js +0 -0
- /package/{dist/components → components}/Calendar/calendar.css.js +0 -0
- /package/{dist/components → components}/Calendar/calendar.js +0 -0
- /package/{dist/components → components}/Card/card.js +0 -0
- /package/{dist/components → components}/Checkbox/checkbox.css.js +0 -0
- /package/{dist/components → components}/Checkbox/checkbox.js +0 -0
- /package/{dist/components → components}/CloseButton/close-button.css.js +0 -0
- /package/{dist/components → components}/CloseButton/close-button.js +0 -0
- /package/{dist/components → components}/CloseButton/index.js +0 -0
- /package/{dist/components → components}/ColorPicker/color-picker.js +0 -0
- /package/{dist/components → components}/ColorSwatch/color-swatch.js +0 -0
- /package/{dist/components → components}/Combobox/combobox.css.js +0 -0
- /package/{dist/components → components}/Combobox/combobox.js +0 -0
- /package/{dist/components → components}/Command/command.css.js +0 -0
- /package/{dist/components → components}/Command/command.js +0 -0
- /package/{dist/components → components}/Container/container.css.js +0 -0
- /package/{dist/components → components}/Container/container.js +0 -0
- /package/{dist/components → components}/CopyButton/copy-button.css.js +0 -0
- /package/{dist/components → components}/CopyButton/copy-button.js +0 -0
- /package/{dist/components → components}/CopyButton/index.js +0 -0
- /package/{dist/components → components}/Dialog/dialog.css.js +0 -0
- /package/{dist/components → components}/Dialog/dialog.js +0 -0
- /package/{dist/components → components}/Drawer/drawer.css.js +0 -0
- /package/{dist/components → components}/Drawer/drawer.js +0 -0
- /package/{dist/components → components}/Field/field.css.js +0 -0
- /package/{dist/components → components}/Field/field.js +0 -0
- /package/{dist/components → components}/Grid/grid.css.js +0 -0
- /package/{dist/components → components}/Grid/grid.js +0 -0
- /package/{dist/components → components}/Icon/icon.css.js +0 -0
- /package/{dist/components → components}/Icon/icon.js +0 -0
- /package/{dist/components → components}/IconButton/icon-button.css.js +0 -0
- /package/{dist/components → components}/IconButton/icon-button.js +0 -0
- /package/{dist/components → components}/IconButton/index.js +0 -0
- /package/{dist/components → components}/Input/input.css.js +0 -0
- /package/{dist/components → components}/Input/input.js +0 -0
- /package/{dist/components → components}/InputGroup/input-group.css.js +0 -0
- /package/{dist/components → components}/InputGroup/input-group.js +0 -0
- /package/{dist/components → components}/Menu/menu.css.js +0 -0
- /package/{dist/components → components}/Menu/menu.js +0 -0
- /package/{dist/components → components}/OTPField/otp-field.css.js +0 -0
- /package/{dist/components → components}/OTPField/otp-field.js +0 -0
- /package/{dist/components → components}/Popover/popover.css.js +0 -0
- /package/{dist/components → components}/Popover/popover.js +0 -0
- /package/{dist/components → components}/Progress/progress.css.js +0 -0
- /package/{dist/components → components}/Progress/progress.js +0 -0
- /package/{dist/components → components}/Radio/radio.css.js +0 -0
- /package/{dist/components → components}/Radio/radio.js +0 -0
- /package/{dist/components → components}/ScrollArea/scroll-area.css.js +0 -0
- /package/{dist/components → components}/ScrollArea/scroll-area.js +0 -0
- /package/{dist/components → components}/SegmentedControl/segmented-control.js +0 -0
- /package/{dist/components → components}/Select/select.css.js +0 -0
- /package/{dist/components → components}/Select/select.js +0 -0
- /package/{dist/components → components}/Separator/separator.css.js +0 -0
- /package/{dist/components → components}/Separator/separator.js +0 -0
- /package/{dist/components → components}/Sheet/sheet.css.js +0 -0
- /package/{dist/components → components}/Sheet/sheet.js +0 -0
- /package/{dist/components → components}/Slider/slider.css.js +0 -0
- /package/{dist/components → components}/Slider/slider.js +0 -0
- /package/{dist/components → components}/Spinner/spinner.css.js +0 -0
- /package/{dist/components → components}/Spinner/spinner.js +0 -0
- /package/{dist/components → components}/Splitter/splitter.css.js +0 -0
- /package/{dist/components → components}/Splitter/splitter.js +0 -0
- /package/{dist/components → components}/Stack/stack.css.js +0 -0
- /package/{dist/components → components}/Stack/stack.js +0 -0
- /package/{dist/components → components}/Surface/surface.css.js +0 -0
- /package/{dist/components → components}/Surface/surface.js +0 -0
- /package/{dist/components → components}/Switch/switch.css.js +0 -0
- /package/{dist/components → components}/Switch/switch.js +0 -0
- /package/{dist/components → components}/Table/table.css.js +0 -0
- /package/{dist/components → components}/Table/table.js +0 -0
- /package/{dist/components → components}/Tabs/tabs.css.js +0 -0
- /package/{dist/components → components}/Tabs/tabs.js +0 -0
- /package/{dist/components → components}/Text/index.js +0 -0
- /package/{dist/components → components}/Text/text.css.js +0 -0
- /package/{dist/components → components}/Text/text.js +0 -0
- /package/{dist/components → components}/Textarea/textarea.css.js +0 -0
- /package/{dist/components → components}/Textarea/textarea.js +0 -0
- /package/{dist/components → components}/Toggle/toggle.css.js +0 -0
- /package/{dist/components → components}/Toggle/toggle.js +0 -0
- /package/{dist/components → components}/ToggleGroup/toggle-group.css.js +0 -0
- /package/{dist/components → components}/ToggleGroup/toggle-group.js +0 -0
- /package/{dist/components → components}/index.js +0 -0
- /package/{dist/index.js → index.js} +0 -0
- /package/{dist/src → src}/DataTable/data-table-column-toggle.d.ts +0 -0
- /package/{dist/src → src}/DataTable/data-table-empty.d.ts +0 -0
- /package/{dist/src → src}/DataTable/data-table-error.d.ts +0 -0
- /package/{dist/src → src}/DataTable/data-table-infinite-loader.d.ts +0 -0
- /package/{dist/src → src}/DataTable/data-table-loading.d.ts +0 -0
- /package/{dist/src → src}/DataTable/data-table-pagination.d.ts +0 -0
- /package/{dist/src → src}/DataTable/data-table-toolbar.d.ts +0 -0
- /package/{dist/src → src}/DataTable/data-table.css.d.ts +0 -0
- /package/{dist/src → src}/DataTable/data-table.d.ts +0 -0
- /package/{dist/src → src}/DataTable/index.d.ts +0 -0
- /package/{dist/src → src}/DataTable/types.d.ts +0 -0
- /package/{dist/src → src}/DataTable/use-infinite-scroll.d.ts +0 -0
- /package/{dist/src → src}/components/Accordion/accordion.css.d.ts +0 -0
- /package/{dist/src → src}/components/Accordion/accordion.d.ts +0 -0
- /package/{dist/src → src}/components/Accordion/index.d.ts +0 -0
- /package/{dist/src → src}/components/Alert/alert.css.d.ts +0 -0
- /package/{dist/src → src}/components/Alert/alert.d.ts +0 -0
- /package/{dist/src → src}/components/Alert/index.d.ts +0 -0
- /package/{dist/src → src}/components/AlertDialog/alert-dialog.css.d.ts +0 -0
- /package/{dist/src → src}/components/AlertDialog/alert-dialog.d.ts +0 -0
- /package/{dist/src → src}/components/AlertDialog/index.d.ts +0 -0
- /package/{dist/src → src}/components/Autocomplete/autocomplete.css.d.ts +0 -0
- /package/{dist/src → src}/components/Autocomplete/autocomplete.d.ts +0 -0
- /package/{dist/src → src}/components/Autocomplete/index.d.ts +0 -0
- /package/{dist/src → src}/components/Avatar/avatar.css.d.ts +0 -0
- /package/{dist/src → src}/components/Avatar/avatar.d.ts +0 -0
- /package/{dist/src → src}/components/Avatar/index.d.ts +0 -0
- /package/{dist/src → src}/components/Badge/badge.css.d.ts +0 -0
- /package/{dist/src → src}/components/Badge/badge.d.ts +0 -0
- /package/{dist/src → src}/components/Badge/index.d.ts +0 -0
- /package/{dist/src → src}/components/Box/box.css.d.ts +0 -0
- /package/{dist/src → src}/components/Box/box.d.ts +0 -0
- /package/{dist/src → src}/components/Box/index.d.ts +0 -0
- /package/{dist/src → src}/components/Breadcrumbs/breadcrumbs.css.d.ts +0 -0
- /package/{dist/src → src}/components/Breadcrumbs/breadcrumbs.d.ts +0 -0
- /package/{dist/src → src}/components/Breadcrumbs/index.d.ts +0 -0
- /package/{dist/src → src}/components/Button/button.css.d.ts +0 -0
- /package/{dist/src → src}/components/Button/button.d.ts +0 -0
- /package/{dist/src → src}/components/Button/index.d.ts +0 -0
- /package/{dist/src → src}/components/Calendar/calendar.css.d.ts +0 -0
- /package/{dist/src → src}/components/Calendar/calendar.d.ts +0 -0
- /package/{dist/src → src}/components/Calendar/index.d.ts +0 -0
- /package/{dist/src → src}/components/Card/card.d.ts +0 -0
- /package/{dist/src → src}/components/Card/index.d.ts +0 -0
- /package/{dist/src → src}/components/Checkbox/checkbox.css.d.ts +0 -0
- /package/{dist/src → src}/components/Checkbox/checkbox.d.ts +0 -0
- /package/{dist/src → src}/components/Checkbox/index.d.ts +0 -0
- /package/{dist/src → src}/components/CloseButton/close-button.css.d.ts +0 -0
- /package/{dist/src → src}/components/CloseButton/close-button.d.ts +0 -0
- /package/{dist/src → src}/components/CloseButton/index.d.ts +0 -0
- /package/{dist/src → src}/components/ColorPicker/color-picker.d.ts +0 -0
- /package/{dist/src → src}/components/ColorPicker/index.d.ts +0 -0
- /package/{dist/src → src}/components/ColorSwatch/color-swatch.d.ts +0 -0
- /package/{dist/src → src}/components/ColorSwatch/index.d.ts +0 -0
- /package/{dist/src → src}/components/Combobox/combobox.css.d.ts +0 -0
- /package/{dist/src → src}/components/Combobox/combobox.d.ts +0 -0
- /package/{dist/src → src}/components/Combobox/index.d.ts +0 -0
- /package/{dist/src → src}/components/Command/command.css.d.ts +0 -0
- /package/{dist/src → src}/components/Command/command.d.ts +0 -0
- /package/{dist/src → src}/components/Command/index.d.ts +0 -0
- /package/{dist/src → src}/components/Container/container.css.d.ts +0 -0
- /package/{dist/src → src}/components/Container/container.d.ts +0 -0
- /package/{dist/src → src}/components/Container/index.d.ts +0 -0
- /package/{dist/src → src}/components/CopyButton/copy-button.css.d.ts +0 -0
- /package/{dist/src → src}/components/CopyButton/copy-button.d.ts +0 -0
- /package/{dist/src → src}/components/CopyButton/index.d.ts +0 -0
- /package/{dist/src → src}/components/DatePicker/date-picker.d.ts +0 -0
- /package/{dist/src → src}/components/DatePicker/index.d.ts +0 -0
- /package/{dist/src → src}/components/Dialog/dialog.css.d.ts +0 -0
- /package/{dist/src → src}/components/Dialog/dialog.d.ts +0 -0
- /package/{dist/src → src}/components/Dialog/index.d.ts +0 -0
- /package/{dist/src → src}/components/Drawer/drawer.css.d.ts +0 -0
- /package/{dist/src → src}/components/Drawer/drawer.d.ts +0 -0
- /package/{dist/src → src}/components/Drawer/index.d.ts +0 -0
- /package/{dist/src → src}/components/Field/field.css.d.ts +0 -0
- /package/{dist/src → src}/components/Field/field.d.ts +0 -0
- /package/{dist/src → src}/components/Field/index.d.ts +0 -0
- /package/{dist/src → src}/components/Grid/grid.css.d.ts +0 -0
- /package/{dist/src → src}/components/Grid/grid.d.ts +0 -0
- /package/{dist/src → src}/components/Grid/index.d.ts +0 -0
- /package/{dist/src → src}/components/Icon/icon.css.d.ts +0 -0
- /package/{dist/src → src}/components/Icon/icon.d.ts +0 -0
- /package/{dist/src → src}/components/Icon/index.d.ts +0 -0
- /package/{dist/src → src}/components/IconButton/icon-button.css.d.ts +0 -0
- /package/{dist/src → src}/components/IconButton/icon-button.d.ts +0 -0
- /package/{dist/src → src}/components/IconButton/index.d.ts +0 -0
- /package/{dist/src → src}/components/Input/index.d.ts +0 -0
- /package/{dist/src → src}/components/Input/input.css.d.ts +0 -0
- /package/{dist/src → src}/components/Input/input.d.ts +0 -0
- /package/{dist/src → src}/components/InputGroup/index.d.ts +0 -0
- /package/{dist/src → src}/components/InputGroup/input-group.css.d.ts +0 -0
- /package/{dist/src → src}/components/InputGroup/input-group.d.ts +0 -0
- /package/{dist/src → src}/components/Menu/index.d.ts +0 -0
- /package/{dist/src → src}/components/Menu/menu.css.d.ts +0 -0
- /package/{dist/src → src}/components/Menu/menu.d.ts +0 -0
- /package/{dist/src → src}/components/OTPField/index.d.ts +0 -0
- /package/{dist/src → src}/components/OTPField/otp-field.css.d.ts +0 -0
- /package/{dist/src → src}/components/OTPField/otp-field.d.ts +0 -0
- /package/{dist/src → src}/components/Popover/index.d.ts +0 -0
- /package/{dist/src → src}/components/Popover/popover.css.d.ts +0 -0
- /package/{dist/src → src}/components/Popover/popover.d.ts +0 -0
- /package/{dist/src → src}/components/Progress/index.d.ts +0 -0
- /package/{dist/src → src}/components/Progress/progress.css.d.ts +0 -0
- /package/{dist/src → src}/components/Progress/progress.d.ts +0 -0
- /package/{dist/src → src}/components/Radio/index.d.ts +0 -0
- /package/{dist/src → src}/components/Radio/radio.css.d.ts +0 -0
- /package/{dist/src → src}/components/Radio/radio.d.ts +0 -0
- /package/{dist/src → src}/components/ScrollArea/index.d.ts +0 -0
- /package/{dist/src → src}/components/ScrollArea/scroll-area.css.d.ts +0 -0
- /package/{dist/src → src}/components/ScrollArea/scroll-area.d.ts +0 -0
- /package/{dist/src → src}/components/SegmentedControl/index.d.ts +0 -0
- /package/{dist/src → src}/components/SegmentedControl/segmented-control.d.ts +0 -0
- /package/{dist/src → src}/components/Select/index.d.ts +0 -0
- /package/{dist/src → src}/components/Select/select.css.d.ts +0 -0
- /package/{dist/src → src}/components/Select/select.d.ts +0 -0
- /package/{dist/src → src}/components/Separator/index.d.ts +0 -0
- /package/{dist/src → src}/components/Separator/separator.css.d.ts +0 -0
- /package/{dist/src → src}/components/Separator/separator.d.ts +0 -0
- /package/{dist/src → src}/components/Sheet/index.d.ts +0 -0
- /package/{dist/src → src}/components/Sheet/sheet.css.d.ts +0 -0
- /package/{dist/src → src}/components/Sheet/sheet.d.ts +0 -0
- /package/{dist/src → src}/components/Slider/index.d.ts +0 -0
- /package/{dist/src → src}/components/Slider/slider.css.d.ts +0 -0
- /package/{dist/src → src}/components/Slider/slider.d.ts +0 -0
- /package/{dist/src → src}/components/Spinner/index.d.ts +0 -0
- /package/{dist/src → src}/components/Spinner/spinner.css.d.ts +0 -0
- /package/{dist/src → src}/components/Spinner/spinner.d.ts +0 -0
- /package/{dist/src → src}/components/Splitter/index.d.ts +0 -0
- /package/{dist/src → src}/components/Splitter/splitter.css.d.ts +0 -0
- /package/{dist/src → src}/components/Splitter/splitter.d.ts +0 -0
- /package/{dist/src → src}/components/Stack/index.d.ts +0 -0
- /package/{dist/src → src}/components/Stack/stack.css.d.ts +0 -0
- /package/{dist/src → src}/components/Stack/stack.d.ts +0 -0
- /package/{dist/src → src}/components/Surface/index.d.ts +0 -0
- /package/{dist/src → src}/components/Surface/surface.css.d.ts +0 -0
- /package/{dist/src → src}/components/Surface/surface.d.ts +0 -0
- /package/{dist/src → src}/components/Switch/index.d.ts +0 -0
- /package/{dist/src → src}/components/Switch/switch.css.d.ts +0 -0
- /package/{dist/src → src}/components/Switch/switch.d.ts +0 -0
- /package/{dist/src → src}/components/Table/index.d.ts +0 -0
- /package/{dist/src → src}/components/Table/table.css.d.ts +0 -0
- /package/{dist/src → src}/components/Table/table.d.ts +0 -0
- /package/{dist/src → src}/components/Tabs/index.d.ts +0 -0
- /package/{dist/src → src}/components/Tabs/tabs.css.d.ts +0 -0
- /package/{dist/src → src}/components/Tabs/tabs.d.ts +0 -0
- /package/{dist/src → src}/components/Text/index.d.ts +0 -0
- /package/{dist/src → src}/components/Text/text.css.d.ts +0 -0
- /package/{dist/src → src}/components/Text/text.d.ts +0 -0
- /package/{dist/src → src}/components/Textarea/index.d.ts +0 -0
- /package/{dist/src → src}/components/Textarea/textarea.css.d.ts +0 -0
- /package/{dist/src → src}/components/Textarea/textarea.d.ts +0 -0
- /package/{dist/src → src}/components/Toggle/index.d.ts +0 -0
- /package/{dist/src → src}/components/Toggle/toggle.css.d.ts +0 -0
- /package/{dist/src → src}/components/Toggle/toggle.d.ts +0 -0
- /package/{dist/src → src}/components/ToggleGroup/index.d.ts +0 -0
- /package/{dist/src → src}/components/ToggleGroup/toggle-group.css.d.ts +0 -0
- /package/{dist/src → src}/components/ToggleGroup/toggle-group.d.ts +0 -0
- /package/{dist/src → src}/components/index.d.ts +0 -0
- /package/{dist/src → src}/index.d.ts +0 -0
- /package/{dist/src → src}/utils/heights.d.ts +0 -0
- /package/{dist/src → src}/utils/sprinkles.css.d.ts +0 -0
- /package/{dist/src → src}/utils/types.d.ts +0 -0
- /package/{dist/src → src}/utils/ve-style.utils.d.ts +0 -0
- /package/{dist/utils → utils}/sprinkles.css.js +0 -0
- /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.
|
package/blenx-dev-ui-0.0.0.tgz
DELETED
|
Binary file
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export declare function DefaultStory(): import("react").JSX.Element;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export declare function VariantsStory(): import("react").JSX.Element;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export declare function DefaultStory(): import("react").JSX.Element;
|