@qijenchen/design-system 0.1.0-beta.6 → 0.1.0-beta.61
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/CLAUDE.md +200 -0
- package/README.md +155 -0
- package/cli-init.mjs +90 -0
- package/dist/components/Accordion/accordion.d.ts.map +1 -1
- package/dist/components/Accordion/accordion.js +3 -0
- package/dist/components/Accordion/accordion.js.map +1 -1
- package/dist/components/Accordion/index.d.ts +2 -0
- package/dist/components/Accordion/index.d.ts.map +1 -0
- package/dist/components/Accordion/index.js +9 -0
- package/dist/components/Accordion/index.js.map +1 -0
- package/dist/components/Alert/alert.d.ts +1 -1
- package/dist/components/Alert/index.d.ts +2 -0
- package/dist/components/Alert/index.d.ts.map +1 -0
- package/dist/components/Alert/index.js +7 -0
- package/dist/components/Alert/index.js.map +1 -0
- package/dist/components/AppShell/app-shell.d.ts.map +1 -1
- package/dist/components/AppShell/app-shell.js +5 -5
- package/dist/components/AppShell/app-shell.js.map +1 -1
- package/dist/components/AppShell/index.d.ts +2 -0
- package/dist/components/AppShell/index.d.ts.map +1 -0
- package/dist/components/AppShell/index.js +7 -0
- package/dist/components/AppShell/index.js.map +1 -0
- package/dist/components/AspectRatio/aspect-ratio.d.ts +1 -1
- package/dist/components/AspectRatio/aspect-ratio.d.ts.map +1 -1
- package/dist/components/AspectRatio/aspect-ratio.js +4 -2
- package/dist/components/AspectRatio/aspect-ratio.js.map +1 -1
- package/dist/components/AspectRatio/index.d.ts +2 -0
- package/dist/components/AspectRatio/index.d.ts.map +1 -0
- package/dist/components/AspectRatio/index.js +6 -0
- package/dist/components/AspectRatio/index.js.map +1 -0
- package/dist/components/Avatar/avatar.d.ts +6 -5
- package/dist/components/Avatar/avatar.d.ts.map +1 -1
- package/dist/components/Avatar/avatar.js +8 -20
- package/dist/components/Avatar/avatar.js.map +1 -1
- package/dist/components/Avatar/index.d.ts +2 -0
- package/dist/components/Avatar/index.d.ts.map +1 -0
- package/dist/components/Avatar/index.js +6 -0
- package/dist/components/Avatar/index.js.map +1 -0
- package/dist/components/Badge/badge.d.ts +19 -7
- package/dist/components/Badge/badge.d.ts.map +1 -1
- package/dist/components/Badge/badge.js +5 -4
- package/dist/components/Badge/badge.js.map +1 -1
- package/dist/components/Badge/index.d.ts +2 -0
- package/dist/components/Badge/index.d.ts.map +1 -0
- package/dist/components/Badge/index.js +7 -0
- package/dist/components/Badge/index.js.map +1 -0
- package/dist/components/Breadcrumb/breadcrumb.d.ts +1 -1
- package/dist/components/Breadcrumb/breadcrumb.d.ts.map +1 -1
- package/dist/components/Breadcrumb/breadcrumb.js +16 -21
- package/dist/components/Breadcrumb/breadcrumb.js.map +1 -1
- package/dist/components/Breadcrumb/index.d.ts +2 -0
- package/dist/components/Breadcrumb/index.d.ts.map +1 -0
- package/dist/components/Breadcrumb/index.js +12 -0
- package/dist/components/Breadcrumb/index.js.map +1 -0
- package/dist/components/BulkActionBar/bulk-action-bar.d.ts +2 -2
- package/dist/components/BulkActionBar/bulk-action-bar.d.ts.map +1 -1
- package/dist/components/BulkActionBar/bulk-action-bar.js +2 -2
- package/dist/components/BulkActionBar/bulk-action-bar.js.map +1 -1
- package/dist/components/BulkActionBar/index.d.ts +2 -0
- package/dist/components/BulkActionBar/index.d.ts.map +1 -0
- package/dist/components/BulkActionBar/index.js +7 -0
- package/dist/components/BulkActionBar/index.js.map +1 -0
- package/dist/components/Button/button.d.ts +2 -2
- package/dist/components/Button/button.d.ts.map +1 -1
- package/dist/components/Button/button.js +9 -7
- package/dist/components/Button/button.js.map +1 -1
- package/dist/components/Button/index.d.ts +2 -0
- package/dist/components/Button/index.d.ts.map +1 -0
- package/dist/components/Button/index.js +8 -0
- package/dist/components/Button/index.js.map +1 -0
- package/dist/components/Calendar/calendar.d.ts +8 -4
- package/dist/components/Calendar/calendar.d.ts.map +1 -1
- package/dist/components/Calendar/calendar.js +14 -13
- package/dist/components/Calendar/calendar.js.map +1 -1
- package/dist/components/Calendar/index.d.ts +2 -0
- package/dist/components/Calendar/index.d.ts.map +1 -0
- package/dist/components/Calendar/index.js +6 -0
- package/dist/components/Calendar/index.js.map +1 -0
- package/dist/components/Carousel/carousel.d.ts.map +1 -1
- package/dist/components/Carousel/carousel.js +6 -3
- package/dist/components/Carousel/carousel.js.map +1 -1
- package/dist/components/Carousel/index.d.ts +2 -0
- package/dist/components/Carousel/index.d.ts.map +1 -0
- package/dist/components/Carousel/index.js +11 -0
- package/dist/components/Carousel/index.js.map +1 -0
- package/dist/components/Chart/chart.d.ts +1 -1
- package/dist/components/Chart/chart.d.ts.map +1 -1
- package/dist/components/Chart/chart.js +3 -1
- package/dist/components/Chart/chart.js.map +1 -1
- package/dist/components/Chart/index.d.ts +2 -0
- package/dist/components/Chart/index.d.ts.map +1 -0
- package/dist/components/Chart/index.js +11 -0
- package/dist/components/Chart/index.js.map +1 -0
- package/dist/components/Checkbox/checkbox.d.ts +4 -4
- package/dist/components/Checkbox/checkbox.d.ts.map +1 -1
- package/dist/components/Checkbox/checkbox.js +17 -13
- package/dist/components/Checkbox/checkbox.js.map +1 -1
- package/dist/components/Checkbox/index.d.ts +2 -0
- package/dist/components/Checkbox/index.d.ts.map +1 -0
- package/dist/components/Checkbox/index.js +7 -0
- package/dist/components/Checkbox/index.js.map +1 -0
- package/dist/components/Chip/chip.d.ts +4 -4
- package/dist/components/Chip/chip.js +1 -1
- package/dist/components/Chip/chip.js.map +1 -1
- package/dist/components/Chip/index.d.ts +2 -0
- package/dist/components/Chip/index.d.ts.map +1 -0
- package/dist/components/Chip/index.js +8 -0
- package/dist/components/Chip/index.js.map +1 -0
- package/dist/components/CircularProgress/circular-progress.d.ts +1 -2
- package/dist/components/CircularProgress/circular-progress.d.ts.map +1 -1
- package/dist/components/CircularProgress/circular-progress.js +2 -2
- package/dist/components/CircularProgress/circular-progress.js.map +1 -1
- package/dist/components/CircularProgress/index.d.ts +2 -0
- package/dist/components/CircularProgress/index.d.ts.map +1 -0
- package/dist/components/CircularProgress/index.js +6 -0
- package/dist/components/CircularProgress/index.js.map +1 -0
- package/dist/components/Coachmark/coachmark-story-helpers.d.ts +22 -0
- package/dist/components/Coachmark/coachmark-story-helpers.d.ts.map +1 -0
- package/dist/components/Coachmark/coachmark.d.ts.map +1 -1
- package/dist/components/Coachmark/coachmark.js +7 -3
- package/dist/components/Coachmark/coachmark.js.map +1 -1
- package/dist/components/Coachmark/index.d.ts +2 -0
- package/dist/components/Coachmark/index.d.ts.map +1 -0
- package/dist/components/Coachmark/index.js +6 -0
- package/dist/components/Coachmark/index.js.map +1 -0
- package/dist/components/Combobox/combobox.d.ts +17 -8
- package/dist/components/Combobox/combobox.d.ts.map +1 -1
- package/dist/components/Combobox/combobox.js +46 -18
- package/dist/components/Combobox/combobox.js.map +1 -1
- package/dist/components/Combobox/index.d.ts +2 -0
- package/dist/components/Combobox/index.d.ts.map +1 -0
- package/dist/components/Combobox/index.js +6 -0
- package/dist/components/Combobox/index.js.map +1 -0
- package/dist/components/Command/index.d.ts +2 -0
- package/dist/components/Command/index.d.ts.map +1 -0
- package/dist/components/Command/index.js +14 -0
- package/dist/components/Command/index.js.map +1 -0
- package/dist/components/DataTable/cell-registry.d.ts.map +1 -1
- package/dist/components/DataTable/cell-registry.js +4 -3
- package/dist/components/DataTable/cell-registry.js.map +1 -1
- package/dist/components/DataTable/data-table.d.ts +2 -2
- package/dist/components/DataTable/data-table.d.ts.map +1 -1
- package/dist/components/DataTable/data-table.js +12 -5
- package/dist/components/DataTable/data-table.js.map +1 -1
- package/dist/components/DataTable/filter-operators.d.ts +1 -1
- package/dist/components/DataTable/filter-tree.d.ts +1 -1
- package/dist/components/DataTable/index.d.ts +2 -0
- package/dist/components/DataTable/index.d.ts.map +1 -0
- package/dist/components/DataTable/index.js +8 -0
- package/dist/components/DataTable/index.js.map +1 -0
- package/dist/components/DateGrid/date-grid.d.ts +14 -14
- package/dist/components/DateGrid/date-grid.js +1 -1
- package/dist/components/DateGrid/date-grid.js.map +1 -1
- package/dist/components/DateGrid/index.d.ts +2 -0
- package/dist/components/DateGrid/index.d.ts.map +1 -0
- package/dist/components/DateGrid/index.js +6 -0
- package/dist/components/DateGrid/index.js.map +1 -0
- package/dist/components/DatePicker/date-picker.d.ts +2 -2
- package/dist/components/DatePicker/date-picker.d.ts.map +1 -1
- package/dist/components/DatePicker/date-picker.js +23 -14
- package/dist/components/DatePicker/date-picker.js.map +1 -1
- package/dist/components/DatePicker/index.d.ts +2 -0
- package/dist/components/DatePicker/index.d.ts.map +1 -0
- package/dist/components/DatePicker/index.js +8 -0
- package/dist/components/DatePicker/index.js.map +1 -0
- package/dist/components/DescriptionList/description-list.d.ts +2 -2
- package/dist/components/DescriptionList/description-list.js +2 -1
- package/dist/components/DescriptionList/description-list.js.map +1 -1
- package/dist/components/DescriptionList/index.d.ts +2 -0
- package/dist/components/DescriptionList/index.d.ts.map +1 -0
- package/dist/components/DescriptionList/index.js +7 -0
- package/dist/components/DescriptionList/index.js.map +1 -0
- package/dist/components/Dialog/dialog.d.ts +1 -1
- package/dist/components/Dialog/dialog.js.map +1 -1
- package/dist/components/Dialog/index.d.ts +2 -0
- package/dist/components/Dialog/index.d.ts.map +1 -0
- package/dist/components/Dialog/index.js +16 -0
- package/dist/components/Dialog/index.js.map +1 -0
- package/dist/components/DropdownMenu/dropdown-menu.d.ts +4 -3
- package/dist/components/DropdownMenu/dropdown-menu.d.ts.map +1 -1
- package/dist/components/DropdownMenu/dropdown-menu.js +4 -3
- package/dist/components/DropdownMenu/dropdown-menu.js.map +1 -1
- package/dist/components/DropdownMenu/index.d.ts +2 -0
- package/dist/components/DropdownMenu/index.d.ts.map +1 -0
- package/dist/components/DropdownMenu/index.js +21 -0
- package/dist/components/DropdownMenu/index.js.map +1 -0
- package/dist/components/Empty/empty.d.ts +8 -2
- package/dist/components/Empty/empty.d.ts.map +1 -1
- package/dist/components/Empty/empty.js +6 -6
- package/dist/components/Empty/empty.js.map +1 -1
- package/dist/components/Empty/index.d.ts +2 -0
- package/dist/components/Empty/index.d.ts.map +1 -0
- package/dist/components/Empty/index.js +6 -0
- package/dist/components/Empty/index.js.map +1 -0
- package/dist/components/Field/field-context.d.ts +49 -0
- package/dist/components/Field/field-context.d.ts.map +1 -1
- package/dist/components/Field/field-context.js +42 -0
- package/dist/components/Field/field-context.js.map +1 -1
- package/dist/components/Field/field-types.js.map +1 -1
- package/dist/components/Field/field.d.ts +2 -2
- package/dist/components/Field/field.js.map +1 -1
- package/dist/components/Field/index.d.ts +2 -0
- package/dist/components/Field/index.d.ts.map +1 -0
- package/dist/components/Field/index.js +10 -0
- package/dist/components/Field/index.js.map +1 -0
- package/dist/components/FieldControlGroup/field-control-group.d.ts +6 -6
- package/dist/components/FieldControlGroup/field-control-group.d.ts.map +1 -1
- package/dist/components/FieldControlGroup/field-control-group.js.map +1 -1
- package/dist/components/FieldControlGroup/index.d.ts +2 -0
- package/dist/components/FieldControlGroup/index.d.ts.map +1 -0
- package/dist/components/FieldControlGroup/index.js +6 -0
- package/dist/components/FieldControlGroup/index.js.map +1 -0
- package/dist/components/FileItem/file-item.d.ts +12 -2
- package/dist/components/FileItem/file-item.d.ts.map +1 -1
- package/dist/components/FileItem/file-item.js +20 -6
- package/dist/components/FileItem/file-item.js.map +1 -1
- package/dist/components/FileItem/index.d.ts +2 -0
- package/dist/components/FileItem/index.d.ts.map +1 -0
- package/dist/components/FileItem/index.js +6 -0
- package/dist/components/FileItem/index.js.map +1 -0
- package/dist/components/FileUpload/file-upload.d.ts +24 -12
- package/dist/components/FileUpload/file-upload.d.ts.map +1 -1
- package/dist/components/FileUpload/file-upload.js +57 -17
- package/dist/components/FileUpload/file-upload.js.map +1 -1
- package/dist/components/FileUpload/index.d.ts +2 -0
- package/dist/components/FileUpload/index.d.ts.map +1 -0
- package/dist/components/FileUpload/index.js +6 -0
- package/dist/components/FileUpload/index.js.map +1 -0
- package/dist/components/FileViewer/file-viewer.d.ts +1 -1
- package/dist/components/FileViewer/file-viewer.d.ts.map +1 -1
- package/dist/components/FileViewer/file-viewer.js +2 -3
- package/dist/components/FileViewer/file-viewer.js.map +1 -1
- package/dist/components/FileViewer/index.d.ts +2 -0
- package/dist/components/FileViewer/index.d.ts.map +1 -0
- package/dist/components/FileViewer/index.js +7 -0
- package/dist/components/FileViewer/index.js.map +1 -0
- package/dist/components/HoverCard/hover-card.d.ts +2 -2
- package/dist/components/HoverCard/hover-card.js +2 -2
- package/dist/components/HoverCard/hover-card.js.map +1 -1
- package/dist/components/HoverCard/index.d.ts +2 -0
- package/dist/components/HoverCard/index.d.ts.map +1 -0
- package/dist/components/HoverCard/index.js +8 -0
- package/dist/components/HoverCard/index.js.map +1 -0
- package/dist/components/Input/index.d.ts +2 -0
- package/dist/components/Input/index.d.ts.map +1 -0
- package/dist/components/Input/index.js +6 -0
- package/dist/components/Input/index.js.map +1 -0
- package/dist/components/Input/input.d.ts +8 -5
- package/dist/components/Input/input.d.ts.map +1 -1
- package/dist/components/Input/input.js +10 -8
- package/dist/components/Input/input.js.map +1 -1
- package/dist/components/LinkInput/index.d.ts +2 -0
- package/dist/components/LinkInput/index.d.ts.map +1 -0
- package/dist/components/LinkInput/index.js +6 -0
- package/dist/components/LinkInput/index.js.map +1 -0
- package/dist/components/LinkInput/link-input.d.ts +2 -2
- package/dist/components/LinkInput/link-input.d.ts.map +1 -1
- package/dist/components/LinkInput/link-input.js +8 -8
- package/dist/components/LinkInput/link-input.js.map +1 -1
- package/dist/components/Menu/index.d.ts +2 -0
- package/dist/components/Menu/index.d.ts.map +1 -0
- package/dist/components/Menu/index.js +9 -0
- package/dist/components/Menu/index.js.map +1 -0
- package/dist/components/Menu/menu-item.d.ts +2 -2
- package/dist/components/Menu/menu-item.d.ts.map +1 -1
- package/dist/components/Menu/menu-item.js +2 -1
- package/dist/components/Menu/menu-item.js.map +1 -1
- package/dist/components/Notice/index.d.ts +2 -0
- package/dist/components/Notice/index.d.ts.map +1 -0
- package/dist/components/Notice/index.js +8 -0
- package/dist/components/Notice/index.js.map +1 -0
- package/dist/components/Notice/notice.d.ts +2 -2
- package/dist/components/Notice/notice.d.ts.map +1 -1
- package/dist/components/Notice/notice.js +4 -3
- package/dist/components/Notice/notice.js.map +1 -1
- package/dist/components/NumberInput/index.d.ts +2 -0
- package/dist/components/NumberInput/index.d.ts.map +1 -0
- package/dist/components/NumberInput/index.js +7 -0
- package/dist/components/NumberInput/index.js.map +1 -0
- package/dist/components/NumberInput/number-input.d.ts +3 -3
- package/dist/components/NumberInput/number-input.d.ts.map +1 -1
- package/dist/components/NumberInput/number-input.js +8 -7
- package/dist/components/NumberInput/number-input.js.map +1 -1
- package/dist/components/OverflowIndicator/index.d.ts +2 -0
- package/dist/components/OverflowIndicator/index.d.ts.map +1 -0
- package/dist/components/OverflowIndicator/index.js +6 -0
- package/dist/components/OverflowIndicator/index.js.map +1 -0
- package/dist/components/OverflowIndicator/overflow-indicator.d.ts.map +1 -1
- package/dist/components/OverflowIndicator/overflow-indicator.js +9 -2
- package/dist/components/OverflowIndicator/overflow-indicator.js.map +1 -1
- package/dist/components/PeoplePicker/index.d.ts +2 -0
- package/dist/components/PeoplePicker/index.d.ts.map +1 -0
- package/dist/components/PeoplePicker/index.js +9 -0
- package/dist/components/PeoplePicker/index.js.map +1 -0
- package/dist/components/PeoplePicker/people-picker-helpers.d.ts +1 -1
- package/dist/components/PeoplePicker/people-picker-helpers.d.ts.map +1 -1
- package/dist/components/PeoplePicker/people-picker-helpers.js +2 -2
- package/dist/components/PeoplePicker/people-picker-helpers.js.map +1 -1
- package/dist/components/PeoplePicker/people-picker.d.ts +1 -1
- package/dist/components/PeoplePicker/people-picker.d.ts.map +1 -1
- package/dist/components/PeoplePicker/people-picker.js +14 -14
- package/dist/components/PeoplePicker/people-picker.js.map +1 -1
- package/dist/components/PeoplePicker/person-display.d.ts +7 -7
- package/dist/components/PeoplePicker/person-display.d.ts.map +1 -1
- package/dist/components/PeoplePicker/person-display.js +8 -8
- package/dist/components/PeoplePicker/person-display.js.map +1 -1
- package/dist/components/Popover/index.d.ts +2 -0
- package/dist/components/Popover/index.d.ts.map +1 -0
- package/dist/components/Popover/index.js +14 -0
- package/dist/components/Popover/index.js.map +1 -0
- package/dist/components/Popover/popover.js +3 -2
- package/dist/components/Popover/popover.js.map +1 -1
- package/dist/components/ProfileCard/index.d.ts +2 -0
- package/dist/components/ProfileCard/index.d.ts.map +1 -0
- package/dist/components/ProfileCard/index.js +8 -0
- package/dist/components/ProfileCard/index.js.map +1 -0
- package/dist/components/{NameCard/name-card.d.ts → ProfileCard/profile-card.d.ts} +19 -18
- package/dist/components/ProfileCard/profile-card.d.ts.map +1 -0
- package/dist/components/{NameCard/name-card.js → ProfileCard/profile-card.js} +9 -9
- package/dist/components/ProfileCard/profile-card.js.map +1 -0
- package/dist/components/ProgressBar/index.d.ts +2 -0
- package/dist/components/ProgressBar/index.d.ts.map +1 -0
- package/dist/components/ProgressBar/index.js +6 -0
- package/dist/components/ProgressBar/index.js.map +1 -0
- package/dist/components/ProgressBar/progress-bar.d.ts +2 -2
- package/dist/components/ProgressBar/progress-bar.js +3 -3
- package/dist/components/ProgressBar/progress-bar.js.map +1 -1
- package/dist/components/RadioGroup/index.d.ts +2 -0
- package/dist/components/RadioGroup/index.d.ts.map +1 -0
- package/dist/components/RadioGroup/index.js +8 -0
- package/dist/components/RadioGroup/index.js.map +1 -0
- package/dist/components/RadioGroup/radio-group.d.ts +6 -6
- package/dist/components/RadioGroup/radio-group.d.ts.map +1 -1
- package/dist/components/RadioGroup/radio-group.js +17 -18
- package/dist/components/RadioGroup/radio-group.js.map +1 -1
- package/dist/components/Rating/index.d.ts +2 -0
- package/dist/components/Rating/index.d.ts.map +1 -0
- package/dist/components/Rating/index.js +6 -0
- package/dist/components/Rating/index.js.map +1 -0
- package/dist/components/Rating/rating.d.ts +6 -2
- package/dist/components/Rating/rating.d.ts.map +1 -1
- package/dist/components/Rating/rating.js +7 -6
- package/dist/components/Rating/rating.js.map +1 -1
- package/dist/components/ScrollArea/index.d.ts +2 -0
- package/dist/components/ScrollArea/index.d.ts.map +1 -0
- package/dist/components/ScrollArea/index.js +7 -0
- package/dist/components/ScrollArea/index.js.map +1 -0
- package/dist/components/ScrollArea/scroll-area.d.ts +1 -1
- package/dist/components/ScrollArea/scroll-area.js +1 -1
- package/dist/components/ScrollArea/scroll-area.js.map +1 -1
- package/dist/components/SegmentedControl/index.d.ts +2 -0
- package/dist/components/SegmentedControl/index.d.ts.map +1 -0
- package/dist/components/SegmentedControl/index.js +9 -0
- package/dist/components/SegmentedControl/index.js.map +1 -0
- package/dist/components/SegmentedControl/segmented-control.d.ts +2 -2
- package/dist/components/SegmentedControl/segmented-control.d.ts.map +1 -1
- package/dist/components/SegmentedControl/segmented-control.js +8 -10
- package/dist/components/SegmentedControl/segmented-control.js.map +1 -1
- package/dist/components/Select/index.d.ts +2 -0
- package/dist/components/Select/index.d.ts.map +1 -0
- package/dist/components/Select/index.js +6 -0
- package/dist/components/Select/index.js.map +1 -0
- package/dist/components/Select/select.d.ts +2 -2
- package/dist/components/Select/select.d.ts.map +1 -1
- package/dist/components/Select/select.js +14 -12
- package/dist/components/Select/select.js.map +1 -1
- package/dist/components/SelectMenu/index.d.ts +2 -0
- package/dist/components/SelectMenu/index.d.ts.map +1 -0
- package/dist/components/SelectMenu/index.js +6 -0
- package/dist/components/SelectMenu/index.js.map +1 -0
- package/dist/components/SelectMenu/select-menu.d.ts +7 -6
- package/dist/components/SelectMenu/select-menu.d.ts.map +1 -1
- package/dist/components/SelectMenu/select-menu.js +6 -1
- package/dist/components/SelectMenu/select-menu.js.map +1 -1
- package/dist/components/SelectionControl/index.d.ts +2 -0
- package/dist/components/SelectionControl/index.d.ts.map +1 -0
- package/dist/components/SelectionControl/index.js +7 -0
- package/dist/components/SelectionControl/index.js.map +1 -0
- package/dist/components/SelectionControl/selection-item.d.ts +1 -1
- package/dist/components/Separator/index.d.ts +2 -0
- package/dist/components/Separator/index.d.ts.map +1 -0
- package/dist/components/Separator/index.js +6 -0
- package/dist/components/Separator/index.js.map +1 -0
- package/dist/components/Separator/separator.d.ts +2 -2
- package/dist/components/Separator/separator.js +4 -3
- package/dist/components/Separator/separator.js.map +1 -1
- package/dist/components/Sheet/index.d.ts +2 -0
- package/dist/components/Sheet/index.d.ts.map +1 -0
- package/dist/components/Sheet/index.js +17 -0
- package/dist/components/Sheet/index.js.map +1 -0
- package/dist/components/Sheet/sheet.d.ts +1 -1
- package/dist/components/Sheet/sheet.js.map +1 -1
- package/dist/components/Sidebar/index.d.ts +2 -0
- package/dist/components/Sidebar/index.d.ts.map +1 -0
- package/dist/components/Sidebar/index.js +24 -0
- package/dist/components/Sidebar/index.js.map +1 -0
- package/dist/components/Sidebar/sidebar.d.ts +5 -5
- package/dist/components/Sidebar/sidebar.d.ts.map +1 -1
- package/dist/components/Sidebar/sidebar.js +6 -3
- package/dist/components/Sidebar/sidebar.js.map +1 -1
- package/dist/components/Skeleton/index.d.ts +2 -0
- package/dist/components/Skeleton/index.d.ts.map +1 -0
- package/dist/components/Skeleton/index.js +6 -0
- package/dist/components/Skeleton/index.js.map +1 -0
- package/dist/components/Slider/index.d.ts +2 -0
- package/dist/components/Slider/index.d.ts.map +1 -0
- package/dist/components/Slider/index.js +7 -0
- package/dist/components/Slider/index.js.map +1 -0
- package/dist/components/Slider/slider.d.ts +4 -4
- package/dist/components/Slider/slider.d.ts.map +1 -1
- package/dist/components/Slider/slider.js +10 -4
- package/dist/components/Slider/slider.js.map +1 -1
- package/dist/components/Steps/index.d.ts +2 -0
- package/dist/components/Steps/index.d.ts.map +1 -0
- package/dist/components/Steps/index.js +12 -0
- package/dist/components/Steps/index.js.map +1 -0
- package/dist/components/Steps/steps.d.ts +1 -1
- package/dist/components/Steps/steps.d.ts.map +1 -1
- package/dist/components/Steps/steps.js +28 -14
- package/dist/components/Steps/steps.js.map +1 -1
- package/dist/components/Switch/index.d.ts +2 -0
- package/dist/components/Switch/index.d.ts.map +1 -0
- package/dist/components/Switch/index.js +7 -0
- package/dist/components/Switch/index.js.map +1 -0
- package/dist/components/Switch/switch.d.ts +3 -3
- package/dist/components/Switch/switch.d.ts.map +1 -1
- package/dist/components/Switch/switch.js +14 -10
- package/dist/components/Switch/switch.js.map +1 -1
- package/dist/components/Tabs/index.d.ts +2 -0
- package/dist/components/Tabs/index.d.ts.map +1 -0
- package/dist/components/Tabs/index.js +10 -0
- package/dist/components/Tabs/index.js.map +1 -0
- package/dist/components/Tabs/tabs.d.ts +5 -5
- package/dist/components/Tabs/tabs.d.ts.map +1 -1
- package/dist/components/Tabs/tabs.js +4 -3
- package/dist/components/Tabs/tabs.js.map +1 -1
- package/dist/components/Tag/index.d.ts +2 -0
- package/dist/components/Tag/index.d.ts.map +1 -0
- package/dist/components/Tag/index.js +7 -0
- package/dist/components/Tag/index.js.map +1 -0
- package/dist/components/Tag/tag.d.ts +35 -23
- package/dist/components/Tag/tag.d.ts.map +1 -1
- package/dist/components/Tag/tag.js +38 -43
- package/dist/components/Tag/tag.js.map +1 -1
- package/dist/components/Textarea/index.d.ts +2 -0
- package/dist/components/Textarea/index.d.ts.map +1 -0
- package/dist/components/Textarea/index.js +7 -0
- package/dist/components/Textarea/index.js.map +1 -0
- package/dist/components/Textarea/textarea.d.ts +5 -10
- package/dist/components/Textarea/textarea.d.ts.map +1 -1
- package/dist/components/Textarea/textarea.js +11 -9
- package/dist/components/Textarea/textarea.js.map +1 -1
- package/dist/components/TimePicker/index.d.ts +2 -0
- package/dist/components/TimePicker/index.d.ts.map +1 -0
- package/dist/components/TimePicker/index.js +6 -0
- package/dist/components/TimePicker/index.js.map +1 -0
- package/dist/components/TimePicker/time-picker.d.ts +4 -3
- package/dist/components/TimePicker/time-picker.d.ts.map +1 -1
- package/dist/components/TimePicker/time-picker.js +18 -9
- package/dist/components/TimePicker/time-picker.js.map +1 -1
- package/dist/components/Toast/index.d.ts +2 -0
- package/dist/components/Toast/index.d.ts.map +1 -0
- package/dist/components/Toast/index.js +7 -0
- package/dist/components/Toast/index.js.map +1 -0
- package/dist/components/Toast/toast.d.ts +2 -2
- package/dist/components/Toast/toast.js +2 -2
- package/dist/components/Toast/toast.js.map +1 -1
- package/dist/components/Tooltip/index.d.ts +2 -0
- package/dist/components/Tooltip/index.d.ts.map +1 -0
- package/dist/components/Tooltip/index.js +9 -0
- package/dist/components/Tooltip/index.js.map +1 -0
- package/dist/components/Tooltip/tooltip.d.ts.map +1 -1
- package/dist/components/Tooltip/tooltip.js +1 -0
- package/dist/components/Tooltip/tooltip.js.map +1 -1
- package/dist/components/TreeView/index.d.ts +2 -0
- package/dist/components/TreeView/index.d.ts.map +1 -0
- package/dist/components/TreeView/index.js +8 -0
- package/dist/components/TreeView/index.js.map +1 -0
- package/dist/components/TreeView/tree-view.d.ts +8 -8
- package/dist/components/TreeView/tree-view.d.ts.map +1 -1
- package/dist/components/TreeView/tree-view.js +35 -8
- package/dist/components/TreeView/tree-view.js.map +1 -1
- package/dist/hooks/use-overflow-items.d.ts +10 -6
- package/dist/hooks/use-overflow-items.d.ts.map +1 -1
- package/dist/hooks/use-overflow-items.js.map +1 -1
- package/dist/index.d.ts +57 -67
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +27 -59
- package/dist/index.js.map +1 -1
- package/dist/lib/i18n/i18n-context.d.ts +3 -3
- package/dist/lib/utils.d.ts.map +1 -1
- package/dist/lib/utils.js +3 -1
- package/dist/lib/utils.js.map +1 -1
- package/dist/patterns/element-anatomy/index.d.ts +2 -0
- package/dist/patterns/element-anatomy/index.d.ts.map +1 -0
- package/dist/patterns/element-anatomy/index.js +20 -0
- package/dist/patterns/element-anatomy/index.js.map +1 -0
- package/dist/patterns/element-anatomy/item-anatomy.d.ts +9 -5
- package/dist/patterns/element-anatomy/item-anatomy.d.ts.map +1 -1
- package/dist/patterns/element-anatomy/item-anatomy.js +1 -1
- package/dist/patterns/element-anatomy/item-anatomy.js.map +1 -1
- package/dist/patterns/header-canonical/chrome-header.d.ts +10 -2
- package/dist/patterns/header-canonical/chrome-header.d.ts.map +1 -1
- package/dist/patterns/header-canonical/chrome-header.js +4 -2
- package/dist/patterns/header-canonical/chrome-header.js.map +1 -1
- package/dist/patterns/header-canonical/index.d.ts +2 -0
- package/dist/patterns/header-canonical/index.d.ts.map +1 -0
- package/dist/patterns/header-canonical/index.js +6 -0
- package/dist/patterns/header-canonical/index.js.map +1 -0
- package/dist/patterns/horizontal-overflow/horizontal-overflow.d.ts +1 -1
- package/dist/patterns/horizontal-overflow/index.d.ts +2 -0
- package/dist/patterns/horizontal-overflow/index.d.ts.map +1 -0
- package/dist/patterns/horizontal-overflow/index.js +14 -0
- package/dist/patterns/horizontal-overflow/index.js.map +1 -0
- package/dist/patterns/overlay-surface/index.d.ts +2 -0
- package/dist/patterns/overlay-surface/index.d.ts.map +1 -0
- package/dist/patterns/overlay-surface/index.js +7 -0
- package/dist/patterns/overlay-surface/index.js.map +1 -0
- package/dist/patterns/overlay-surface/overlay-surface.d.ts.map +1 -1
- package/dist/patterns/overlay-surface/overlay-surface.js +2 -1
- package/dist/patterns/overlay-surface/overlay-surface.js.map +1 -1
- package/dist/patterns/resize-handle/index.d.ts +2 -0
- package/dist/patterns/resize-handle/index.d.ts.map +1 -0
- package/dist/patterns/resize-handle/index.js +5 -0
- package/dist/patterns/resize-handle/index.js.map +1 -0
- package/dist/story-governance/category-matrix.d.ts +35 -0
- package/dist/story-governance/category-matrix.d.ts.map +1 -0
- package/dist/tokens/categorical-color.d.ts +60 -0
- package/dist/tokens/categorical-color.d.ts.map +1 -0
- package/dist/tokens/categorical-color.js +110 -0
- package/dist/tokens/categorical-color.js.map +1 -0
- package/dist/tokens/motion/motion.d.ts +1 -1
- package/dist/tokens/motion/motion.d.ts.map +1 -1
- package/dist/tokens/motion/motion.js.map +1 -1
- package/dist/tokens/uiSize/icon-size.d.ts +4 -5
- package/dist/tokens/uiSize/icon-size.d.ts.map +1 -1
- package/ds-canonical/commands/README.md +26 -0
- package/ds-canonical/commands/gov-status.md +79 -0
- package/ds-canonical/hooks/README.md +145 -0
- package/ds-canonical/hooks/_log-fire.sh +44 -0
- package/ds-canonical/hooks/auto_regen_ds_barrel.sh +58 -0
- package/ds-canonical/hooks/block_prototype_imports.py +111 -0
- package/ds-canonical/hooks/check_addon_subdir_ship.sh +76 -0
- package/ds-canonical/hooks/check_audit_post_report_validator.sh +136 -0
- package/ds-canonical/hooks/check_audit_sample_escape.sh +73 -0
- package/ds-canonical/hooks/check_benchmark_citation.sh +106 -0
- package/ds-canonical/hooks/check_canonical_propagation.sh +189 -0
- package/ds-canonical/hooks/check_chrome_header_avatar_canonical.sh +87 -0
- package/ds-canonical/hooks/check_codex_brief_invariants.sh +115 -0
- package/ds-canonical/hooks/check_codex_collab_5step.sh +108 -0
- package/ds-canonical/hooks/check_consumer_app_story_title.sh +81 -0
- package/ds-canonical/hooks/check_consumer_ds_primitive_misuse.sh +120 -0
- package/ds-canonical/hooks/check_consumer_no_ds_catalog.sh +101 -0
- package/ds-canonical/hooks/check_consumer_story_baseline.sh +76 -0
- package/ds-canonical/hooks/check_data_table_size_num_to_meta_width.sh +68 -0
- package/ds-canonical/hooks/check_datatable_invariants.sh +117 -0
- package/ds-canonical/hooks/check_dim_count_drift.sh +72 -0
- package/ds-canonical/hooks/check_ds_anchor_preflight.sh +132 -0
- package/ds-canonical/hooks/check_escape_marker_abuse.sh +126 -0
- package/ds-canonical/hooks/check_field_controls_contracts.sh +110 -0
- package/ds-canonical/hooks/check_field_family_invariants.sh +240 -0
- package/ds-canonical/hooks/check_file_size_budget.sh +60 -0
- package/ds-canonical/hooks/check_fork_user_plugin_install.sh +79 -0
- package/ds-canonical/hooks/check_full_story_visual_interaction_sweep.sh +71 -0
- package/ds-canonical/hooks/check_item_list_gap.sh +54 -0
- package/ds-canonical/hooks/check_layout_space_magic_numbers.sh +96 -0
- package/ds-canonical/hooks/check_main_branch_workbench.sh +93 -0
- package/ds-canonical/hooks/check_naming_and_abstraction.sh +165 -0
- package/ds-canonical/hooks/check_opacity_token_usage.sh +149 -0
- package/ds-canonical/hooks/check_orphan_ds_css.sh +66 -0
- package/ds-canonical/hooks/check_overlay_open_focus_escape_probe.sh +75 -0
- package/ds-canonical/hooks/check_pattern_invariants.sh +196 -0
- package/ds-canonical/hooks/check_peoplepicker_ssot_drift.sh +56 -0
- package/ds-canonical/hooks/check_pixel_quantified_audit.sh +53 -0
- package/ds-canonical/hooks/check_plugin_freshness.sh +68 -0
- package/ds-canonical/hooks/check_post_main_ssot_propagate.sh +90 -0
- package/ds-canonical/hooks/check_propose_cite_required.sh +88 -0
- package/ds-canonical/hooks/check_propose_plain_chinese.sh +74 -0
- package/ds-canonical/hooks/check_propose_pre_grep_verify.sh +70 -0
- package/ds-canonical/hooks/check_propose_without_benchmark.sh +63 -0
- package/ds-canonical/hooks/check_select_all_canonical.sh +58 -0
- package/ds-canonical/hooks/check_sidebar_menu_button_implicit_wrap.sh +86 -0
- package/ds-canonical/hooks/check_solo_workflow.sh +307 -0
- package/ds-canonical/hooks/check_spec_class_drift.sh +88 -0
- package/ds-canonical/hooks/check_story_invariants.sh +668 -0
- package/ds-canonical/hooks/check_storybook_addon_preset_cjs.sh +87 -0
- package/ds-canonical/hooks/check_substantive_edit_approval_preflight.sh +110 -0
- package/ds-canonical/hooks/check_tailwind_wildcard_in_docs.sh +73 -0
- package/ds-canonical/hooks/check_wrapper_primitive_schema_drift.sh +104 -0
- package/ds-canonical/hooks/chrome_header_dispatcher.sh +56 -0
- package/ds-canonical/hooks/enforce_home_charter.sh +44 -0
- package/ds-canonical/hooks/inject_deploy_url_after_push.sh +238 -0
- package/ds-canonical/hooks/inject_pending_self_audit.sh +248 -0
- package/ds-canonical/hooks/lib/_app_shell_primary_header_consistency.sh +70 -0
- package/ds-canonical/hooks/lib/_approval_re.sh +33 -0
- package/ds-canonical/hooks/lib/_chrome_header_handcraft.sh +75 -0
- package/ds-canonical/hooks/lib/_code_quality.sh +73 -0
- package/ds-canonical/hooks/lib/_cva_default_sync.sh +69 -0
- package/ds-canonical/hooks/lib/_governance_coverage_check.sh +49 -0
- package/ds-canonical/hooks/lib/_hardcoded_strings.sh +163 -0
- package/ds-canonical/hooks/lib/_header_with_tabs_border.sh +87 -0
- package/ds-canonical/hooks/lib/_layout_space_canonical.sh +56 -0
- package/ds-canonical/hooks/lib/_overlay_handcraft.sh +141 -0
- package/ds-canonical/hooks/lib/_person_data_richness.sh +42 -0
- package/ds-canonical/hooks/lib/_story_compile_drift.sh +48 -0
- package/ds-canonical/hooks/lib/_tab_lg_chrome_header_equal.sh +70 -0
- package/ds-canonical/hooks/lib/_token_hygiene.sh +96 -0
- package/ds-canonical/hooks/log_governance_fires.sh +50 -0
- package/ds-canonical/hooks/log_skill_invokes.sh +41 -0
- package/ds-canonical/hooks/post_edit_dispatcher.sh +62 -0
- package/ds-canonical/hooks/retired/check_anatomy_section_numbering.sh +106 -0
- package/ds-canonical/hooks/retired/check_avatar_hovercard.sh +90 -0
- package/ds-canonical/hooks/retired/check_button_icon_literal.sh.retired-2026-04-28 +38 -0
- package/ds-canonical/hooks/retired/check_container_breathing.sh +142 -0
- package/ds-canonical/hooks/retired/check_governance_compliance.sh +61 -0
- package/ds-canonical/hooks/retired/check_icon_only_padding_formula.sh +104 -0
- package/ds-canonical/hooks/retired/check_item_content_primitive.sh +150 -0
- package/ds-canonical/hooks/retired/check_item_list_gap.sh +153 -0
- package/ds-canonical/hooks/retired/check_sideoffset_canonical.sh +65 -0
- package/ds-canonical/hooks/retired/check_spec_iteration_tag.sh +87 -0
- package/ds-canonical/hooks/retired/check_ssot_consultation.sh +88 -0
- package/ds-canonical/hooks/retired/check_sync_update.sh +20 -0
- package/ds-canonical/hooks/retired/check_third_party_dom_verified.sh +95 -0
- package/ds-canonical/hooks/retired/enforce_home_charter.sh +125 -0
- package/ds-canonical/hooks/retired/post_edit_canonical_interrogate.sh +109 -0
- package/ds-canonical/hooks/retired/pre_edit_spec_check.sh +68 -0
- package/ds-canonical/hooks/retired/pre_new_component_spec.sh +39 -0
- package/ds-canonical/hooks/retired/pre_write_subsumption_check.sh +112 -0
- package/ds-canonical/hooks/retired/stop_meta_self_audit.sh.retired-2026-05-13 +76 -0
- package/ds-canonical/hooks/retired/tests/test_check_anatomy_section_numbering.sh +14 -0
- package/ds-canonical/hooks/retired/tests/test_check_avatar_hovercard.sh +15 -0
- package/ds-canonical/hooks/retired/tests/test_check_container_breathing.sh +15 -0
- package/ds-canonical/hooks/retired/tests/test_check_governance_compliance.sh +15 -0
- package/ds-canonical/hooks/retired/tests/test_check_icon_only_padding_formula.sh +79 -0
- package/ds-canonical/hooks/retired/tests/test_check_item_content_primitive.sh +15 -0
- package/ds-canonical/hooks/retired/tests/test_check_item_list_gap.sh +163 -0
- package/ds-canonical/hooks/retired/tests/test_check_sideoffset_canonical.sh +15 -0
- package/ds-canonical/hooks/retired/tests/test_check_spec_iteration_tag.sh +15 -0
- package/ds-canonical/hooks/retired/tests/test_check_ssot_consultation.sh +15 -0
- package/ds-canonical/hooks/retired/tests/test_check_sync_update.sh +14 -0
- package/ds-canonical/hooks/retired/tests/test_check_third_party_dom_verified.sh +15 -0
- package/ds-canonical/hooks/retired/tests/test_enforce_home_charter.sh +15 -0
- package/ds-canonical/hooks/retired/tests/test_pre_edit_spec_check.sh +15 -0
- package/ds-canonical/hooks/retired/tests/test_pre_new_component_spec.sh +15 -0
- package/ds-canonical/hooks/retired/tests/test_pre_write_subsumption_check.sh +63 -0
- package/ds-canonical/hooks/session_start_governance_check.sh +305 -0
- package/ds-canonical/hooks/stop_passive_logging.sh +322 -0
- package/ds-canonical/hooks/stop_self_audit.sh +516 -0
- package/ds-canonical/hooks/tests/KNOWN-BROKEN.md +15 -0
- package/ds-canonical/hooks/tests/run-all.sh +76 -0
- package/ds-canonical/hooks/tests/test_auto_regen_ds_barrel.sh +180 -0
- package/ds-canonical/hooks/tests/test_block_prototype_imports.sh +143 -0
- package/ds-canonical/hooks/tests/test_check_addon_subdir_ship.sh +170 -0
- package/ds-canonical/hooks/tests/test_check_app_shell_primary_header_consistency.sh +140 -0
- package/ds-canonical/hooks/tests/test_check_audit_post_report_validator.sh +127 -0
- package/ds-canonical/hooks/tests/test_check_audit_sample_escape.sh +93 -0
- package/ds-canonical/hooks/tests/test_check_benchmark_citation.sh +115 -0
- package/ds-canonical/hooks/tests/test_check_canonical_propagation.sh +133 -0
- package/ds-canonical/hooks/tests/test_check_chrome_header_avatar_canonical.sh +198 -0
- package/ds-canonical/hooks/tests/test_check_chrome_header_handcraft.sh +146 -0
- package/ds-canonical/hooks/tests/test_check_code_quality.sh +15 -0
- package/ds-canonical/hooks/tests/test_check_codex_brief_invariants.sh +208 -0
- package/ds-canonical/hooks/tests/test_check_codex_collab_5step.sh +96 -0
- package/ds-canonical/hooks/tests/test_check_consumer_app_story_title.sh +163 -0
- package/ds-canonical/hooks/tests/test_check_consumer_ds_primitive_misuse.sh +238 -0
- package/ds-canonical/hooks/tests/test_check_consumer_no_ds_catalog.sh +211 -0
- package/ds-canonical/hooks/tests/test_check_consumer_story_baseline.sh +200 -0
- package/ds-canonical/hooks/tests/test_check_cva_default_sync.sh +15 -0
- package/ds-canonical/hooks/tests/test_check_data_table_size_num_to_meta_width.sh +52 -0
- package/ds-canonical/hooks/tests/test_check_datatable_invariants.sh +122 -0
- package/ds-canonical/hooks/tests/test_check_dim_count_drift.sh +98 -0
- package/ds-canonical/hooks/tests/test_check_ds_anchor_preflight.sh +104 -0
- package/ds-canonical/hooks/tests/test_check_escape_marker_abuse.sh +192 -0
- package/ds-canonical/hooks/tests/test_check_field_controls_contracts.sh +126 -0
- package/ds-canonical/hooks/tests/test_check_field_family_invariants.sh +203 -0
- package/ds-canonical/hooks/tests/test_check_file_size_budget.sh +32 -0
- package/ds-canonical/hooks/tests/test_check_fork_user_plugin_install.sh +45 -0
- package/ds-canonical/hooks/tests/test_check_full_story_visual_interaction_sweep.sh +190 -0
- package/ds-canonical/hooks/tests/test_check_hardcoded_strings.sh +14 -0
- package/ds-canonical/hooks/tests/test_check_header_with_tabs_border.sh +110 -0
- package/ds-canonical/hooks/tests/test_check_item_list_gap.sh +44 -0
- package/ds-canonical/hooks/tests/test_check_layout_space_canonical.sh +73 -0
- package/ds-canonical/hooks/tests/test_check_layout_space_magic_numbers.sh +206 -0
- package/ds-canonical/hooks/tests/test_check_main_branch_workbench.sh +147 -0
- package/ds-canonical/hooks/tests/test_check_naming_and_abstraction.sh +136 -0
- package/ds-canonical/hooks/tests/test_check_opacity_token_usage.sh +110 -0
- package/ds-canonical/hooks/tests/test_check_orphan_ds_css.sh +212 -0
- package/ds-canonical/hooks/tests/test_check_overlay_handcraft.sh +126 -0
- package/ds-canonical/hooks/tests/test_check_overlay_open_focus_escape_probe.sh +191 -0
- package/ds-canonical/hooks/tests/test_check_pattern_invariants.sh +148 -0
- package/ds-canonical/hooks/tests/test_check_peoplepicker_ssot_drift.sh +108 -0
- package/ds-canonical/hooks/tests/test_check_person_data_richness.sh +58 -0
- package/ds-canonical/hooks/tests/test_check_pixel_quantified_audit.sh +142 -0
- package/ds-canonical/hooks/tests/test_check_propose_cite_required.sh +180 -0
- package/ds-canonical/hooks/tests/test_check_propose_plain_chinese.sh +126 -0
- package/ds-canonical/hooks/tests/test_check_propose_pre_grep_verify.sh +117 -0
- package/ds-canonical/hooks/tests/test_check_propose_without_benchmark.sh +55 -0
- package/ds-canonical/hooks/tests/test_check_select_all_canonical.sh +125 -0
- package/ds-canonical/hooks/tests/test_check_sidebar_menu_button_implicit_wrap.sh +224 -0
- package/ds-canonical/hooks/tests/test_check_solo_workflow.sh +201 -0
- package/ds-canonical/hooks/tests/test_check_spec_class_drift.sh +135 -0
- package/ds-canonical/hooks/tests/test_check_story_anatomy.sh.broken +197 -0
- package/ds-canonical/hooks/tests/test_check_story_category.sh.broken +187 -0
- package/ds-canonical/hooks/tests/test_check_story_compile_drift.sh +15 -0
- package/ds-canonical/hooks/tests/test_check_story_invariants.sh +354 -0
- package/ds-canonical/hooks/tests/test_check_story_name_jargon.sh.broken +53 -0
- package/ds-canonical/hooks/tests/test_check_story_slot_split.sh +156 -0
- package/ds-canonical/hooks/tests/test_check_storybook_addon_preset_cjs.sh +199 -0
- package/ds-canonical/hooks/tests/test_check_substantive_edit_approval_preflight.sh +176 -0
- package/ds-canonical/hooks/tests/test_check_tab_lg_chrome_header_equal.sh +141 -0
- package/ds-canonical/hooks/tests/test_check_tailwind_wildcard_in_docs.sh +182 -0
- package/ds-canonical/hooks/tests/test_check_token_hygiene.sh +21 -0
- package/ds-canonical/hooks/tests/test_check_wrapper_primitive_schema_drift.sh +169 -0
- package/ds-canonical/hooks/tests/test_enforce_home_charter.sh +77 -0
- package/ds-canonical/hooks/tests/test_inject_deploy_url_after_push.sh +193 -0
- package/ds-canonical/hooks/tests/test_inject_pending_self_audit.sh +125 -0
- package/ds-canonical/hooks/tests/test_log_governance_fires.sh +10 -0
- package/ds-canonical/hooks/tests/test_log_skill_invokes.sh +7 -0
- package/ds-canonical/hooks/tests/test_post_edit_dispatcher.sh +108 -0
- package/ds-canonical/hooks/tests/test_session_start_governance_check.sh +154 -0
- package/ds-canonical/hooks/tests/test_stop_capture_metrics.sh +95 -0
- package/ds-canonical/hooks/tests/test_stop_governance_drift_check.sh.broken +125 -0
- package/ds-canonical/hooks/tests/test_stop_harvest_corrections.sh +10 -0
- package/ds-canonical/hooks/tests/test_stop_passive_logging.sh +100 -0
- package/ds-canonical/hooks/tests/test_stop_self_audit.sh +98 -0
- package/ds-canonical/hooks/tests/test_stop_tsc_sanity.sh +10 -0
- package/ds-canonical/references/README.md +46 -0
- package/ds-canonical/references/audit-coverage-vs-24-checklist.md +74 -0
- package/ds-canonical/references/build-ui-canonicals.md +72 -0
- package/ds-canonical/references/composition-fidelity.md +47 -0
- package/ds-canonical/references/cva-patterns.md +41 -0
- package/ds-canonical/references/drag-canonical.md +331 -0
- package/ds-canonical/references/item-anatomy-recipe.md +225 -0
- package/ds-canonical/references/naming-conventions.md +56 -0
- package/ds-canonical/references/principle-dim-map.json +513 -0
- package/ds-canonical/references/props-naming.md +45 -0
- package/ds-canonical/references/scenario-definition.md +146 -0
- package/ds-canonical/references/spec-rules.md +58 -0
- package/ds-canonical/references/ssot-consultation.md +63 -0
- package/ds-canonical/references/ssot-index.md +40 -0
- package/ds-canonical/references/story-baseline-registry.json +79 -0
- package/ds-canonical/references/structural-token-retention.md +42 -0
- package/ds-canonical/references/tailwind-gotchas.md +87 -0
- package/ds-canonical/references/ui-dev-rules.md +60 -0
- package/ds-canonical/rules/README.md +34 -0
- package/ds-canonical/rules/meta-patterns.md +87 -0
- package/ds-canonical/rules/self-verify.md +56 -0
- package/ds-canonical/rules/spec-rules.md +25 -0
- package/ds-canonical/rules/story-rules.md +65 -0
- package/ds-canonical/rules/ui-development.md +92 -0
- package/ds-canonical/skills/README.md +88 -0
- package/ds-canonical/skills/bug-fix-rhythm/SKILL.md +181 -0
- package/ds-canonical/skills/code-quality-audit/SKILL.md +63 -0
- package/ds-canonical/skills/codex-collab/SKILL.md +249 -0
- package/ds-canonical/skills/codex-collab/references/brief-template.md +48 -0
- package/ds-canonical/skills/codex-collab/references/transport.md +58 -0
- package/ds-canonical/skills/codify-corrections/SKILL.md +184 -0
- package/ds-canonical/skills/codify-principle/SKILL.md +151 -0
- package/ds-canonical/skills/component-quality-gate/SKILL.md +102 -0
- package/ds-canonical/skills/component-quality-gate/references/checklist.md +79 -0
- package/ds-canonical/skills/deep-audit-cross-codex/SKILL.md +242 -0
- package/ds-canonical/skills/deep-audit-cross-codex/references/phase-a-workflow.md +123 -0
- package/ds-canonical/skills/deep-audit-cross-codex/references/phase-b-codex-brief.md +186 -0
- package/ds-canonical/skills/deep-audit-cross-codex/references/skill-relationships-antipatterns-benchmarks.md +30 -0
- package/ds-canonical/skills/deep-audit-cross-codex/references/triage-rubric.md +69 -0
- package/ds-canonical/skills/deep-audit-cross-codex/references/upstream-directives-r-mapping.md +33 -0
- package/ds-canonical/skills/delivery-handoff/SKILL.md +229 -0
- package/ds-canonical/skills/delivery-handoff/references/flow-diagram.md +180 -0
- package/ds-canonical/skills/delivery-handoff/references/handoff-template.md +177 -0
- package/ds-canonical/skills/delivery-handoff/references/inventory-checklist.md +196 -0
- package/ds-canonical/skills/design-system-audit/SKILL.md +384 -0
- package/ds-canonical/skills/design-system-audit/references/audit-prompts.md +1324 -0
- package/ds-canonical/skills/design-system-audit/references/checkpoints.md +240 -0
- package/ds-canonical/skills/design-system-audit/references/historical-bugs.md +240 -0
- package/ds-canonical/skills/design-system-audit/references/principle-audit-protocol.md +378 -0
- package/ds-canonical/skills/design-system-audit/references/rule-placement.md +175 -0
- package/ds-canonical/skills/ensure-canonical/SKILL.md +196 -0
- package/ds-canonical/skills/governance-health/SKILL.md +147 -0
- package/ds-canonical/skills/knowledge-prune/SKILL.md +250 -0
- package/ds-canonical/skills/knowledge-prune/references/phase-z-cross-repo-ssot-propagation.md +11 -0
- package/ds-canonical/skills/knowledge-prune/references/prune-dimensions-d5-d10.md +55 -0
- package/ds-canonical/skills/knowledge-prune/references/world-class-prune-alignment.md +7 -0
- package/ds-canonical/skills/new-component/SKILL.md +170 -0
- package/ds-canonical/skills/new-component/references/new-component-checklist.md +85 -0
- package/ds-canonical/skills/performance-audit/SKILL.md +107 -0
- package/ds-canonical/skills/product-ui-audit/SKILL.md +230 -0
- package/ds-canonical/skills/product-ui-audit/references/audit-checks.md +246 -0
- package/ds-canonical/skills/product-ui-audit/references/common-misuses.md +329 -0
- package/ds-canonical/skills/product-ui-audit/references/report-template.md +159 -0
- package/ds-canonical/skills/propose-options/SKILL.md +177 -0
- package/ds-canonical/skills/prototype/SKILL.md +244 -0
- package/ds-canonical/skills/prototype/references/audit-checks.md +37 -0
- package/ds-canonical/skills/prototype/references/benchmark-sources.md +94 -0
- package/ds-canonical/skills/prototype/references/checkpoints.md +191 -0
- package/ds-canonical/skills/prototype/references/evaluation-matrix.md +141 -0
- package/ds-canonical/skills/prototype/references/ooux-template.md +198 -0
- package/ds-canonical/skills/prototype/references/proposal-template.md +229 -0
- package/ds-canonical/skills/scan-similar-bugs/SKILL.md +198 -0
- package/ds-canonical/skills/story-auto-compile-migrate/SKILL.md +159 -0
- package/ds-canonical/skills/story-writing/SKILL.md +122 -0
- package/ds-canonical/skills/story-writing/references/anatomy-standard.md +217 -0
- package/ds-canonical/skills/story-writing/references/category-templates.md +174 -0
- package/ds-canonical/skills/story-writing/references/example-selection.md +70 -0
- package/ds-canonical/skills/story-writing/references/self-check.md +20 -0
- package/ds-canonical/skills/ux-audit/SKILL.md +130 -0
- package/ds-canonical/skills/visual-audit/SKILL.md +245 -0
- package/ds-canonical/skills/visual-audit/output/.gitkeep +0 -0
- package/ds-canonical/skills/visual-audit/references/audit-architecture.md +100 -0
- package/ds-canonical/skills/visual-audit/references/visual-checklist.md +297 -0
- package/ds-canonical/skills/visual-audit/references/world-class-benchmarks.md +198 -0
- package/ds-canonical/templates/_README.md +23 -0
- package/ds-canonical/templates/dashboard-app.tsx +151 -0
- package/ds-story-manifest.json +1689 -0
- package/llms-full.txt +405 -0
- package/llms.txt +70 -0
- package/package.json +33 -13
- package/src/components/Accordion/accordion.anatomy.stories.tsx +496 -0
- package/src/components/Accordion/accordion.principles.stories.tsx +360 -0
- package/src/components/Accordion/accordion.spec.md +114 -0
- package/src/components/Accordion/accordion.stories.tsx +190 -0
- package/src/components/Accordion/accordion.tsx +3 -0
- package/src/components/Accordion/index.ts +5 -0
- package/src/components/Alert/alert.anatomy.stories.tsx +238 -0
- package/src/components/Alert/alert.principles.stories.tsx +220 -0
- package/src/components/Alert/alert.spec.md +197 -0
- package/src/components/Alert/alert.stories.tsx +139 -0
- package/src/components/Alert/index.ts +5 -0
- package/src/components/AppShell/_demo-helpers.tsx +5 -5
- package/src/components/AppShell/app-shell.anatomy.stories.tsx +176 -0
- package/src/components/AppShell/app-shell.principles.stories.tsx +81 -0
- package/src/components/AppShell/app-shell.spec.md +330 -0
- package/src/components/AppShell/app-shell.stories.tsx +435 -0
- package/src/components/AppShell/app-shell.tsx +9 -4
- package/src/components/AppShell/index.ts +5 -0
- package/src/components/AspectRatio/aspect-ratio.anatomy.stories.tsx +208 -0
- package/src/components/AspectRatio/aspect-ratio.principles.stories.tsx +303 -0
- package/src/components/AspectRatio/aspect-ratio.spec.md +134 -0
- package/src/components/AspectRatio/aspect-ratio.stories.tsx +170 -0
- package/src/components/AspectRatio/aspect-ratio.tsx +4 -2
- package/src/components/AspectRatio/index.ts +5 -0
- package/src/components/Avatar/avatar.anatomy.stories.tsx +701 -0
- package/src/components/Avatar/avatar.principles.stories.tsx +245 -0
- package/src/components/Avatar/avatar.spec.md +339 -0
- package/src/components/Avatar/avatar.stories.tsx +135 -0
- package/src/components/Avatar/avatar.tsx +37 -43
- package/src/components/Avatar/index.ts +5 -0
- package/src/components/Badge/badge.anatomy.stories.tsx +591 -0
- package/src/components/Badge/badge.principles.stories.tsx +391 -0
- package/src/components/Badge/badge.spec.md +389 -0
- package/src/components/Badge/badge.stories.tsx +80 -0
- package/src/components/Badge/badge.tsx +33 -12
- package/src/components/Badge/index.ts +5 -0
- package/src/components/Breadcrumb/breadcrumb.anatomy.stories.tsx +458 -0
- package/src/components/Breadcrumb/breadcrumb.principles.stories.tsx +340 -0
- package/src/components/Breadcrumb/breadcrumb.spec.md +258 -0
- package/src/components/Breadcrumb/breadcrumb.stories.tsx +332 -0
- package/src/components/Breadcrumb/breadcrumb.tsx +27 -17
- package/src/components/Breadcrumb/index.ts +5 -0
- package/src/components/BulkActionBar/bulk-action-bar.anatomy.stories.tsx +224 -0
- package/src/components/BulkActionBar/bulk-action-bar.principles.stories.tsx +242 -0
- package/src/components/BulkActionBar/bulk-action-bar.spec.md +210 -0
- package/src/components/BulkActionBar/bulk-action-bar.stories.tsx +136 -0
- package/src/components/BulkActionBar/bulk-action-bar.tsx +8 -7
- package/src/components/BulkActionBar/index.ts +5 -0
- package/src/components/Button/button.anatomy.stories.tsx +710 -0
- package/src/components/Button/button.principles.stories.tsx +370 -0
- package/src/components/Button/button.spec.md +461 -0
- package/src/components/Button/button.stories.tsx +362 -0
- package/src/components/Button/button.tsx +15 -9
- package/src/components/Button/index.ts +5 -0
- package/src/components/Calendar/calendar.anatomy.stories.tsx +218 -0
- package/src/components/Calendar/calendar.principles.stories.tsx +143 -0
- package/src/components/Calendar/calendar.spec.md +244 -0
- package/src/components/Calendar/calendar.stories.tsx +88 -0
- package/src/components/Calendar/calendar.tsx +29 -19
- package/src/components/Calendar/index.ts +5 -0
- package/src/components/Carousel/carousel.anatomy.stories.tsx +516 -0
- package/src/components/Carousel/carousel.principles.stories.tsx +330 -0
- package/src/components/Carousel/carousel.spec.md +253 -0
- package/src/components/Carousel/carousel.stories.tsx +121 -0
- package/src/components/Carousel/carousel.tsx +7 -3
- package/src/components/Carousel/index.ts +5 -0
- package/src/components/Chart/chart.anatomy.stories.tsx +307 -0
- package/src/components/Chart/chart.principles.stories.tsx +436 -0
- package/src/components/Chart/chart.spec.md +155 -0
- package/src/components/Chart/chart.stories.tsx +268 -0
- package/src/components/Chart/chart.tsx +4 -1
- package/src/components/Chart/index.ts +5 -0
- package/src/components/Checkbox/checkbox.anatomy.stories.tsx +626 -0
- package/src/components/Checkbox/checkbox.principles.stories.tsx +213 -0
- package/src/components/Checkbox/checkbox.spec.md +344 -0
- package/src/components/Checkbox/checkbox.stories.tsx +114 -0
- package/src/components/Checkbox/checkbox.tsx +25 -20
- package/src/components/Checkbox/index.ts +5 -0
- package/src/components/Chip/chip.anatomy.stories.tsx +422 -0
- package/src/components/Chip/chip.principles.stories.tsx +222 -0
- package/src/components/Chip/chip.spec.md +238 -0
- package/src/components/Chip/chip.stories.tsx +88 -0
- package/src/components/Chip/chip.tsx +4 -4
- package/src/components/Chip/index.ts +5 -0
- package/src/components/CircularProgress/circular-progress.anatomy.stories.tsx +176 -0
- package/src/components/CircularProgress/circular-progress.principles.stories.tsx +258 -0
- package/src/components/CircularProgress/circular-progress.spec.md +268 -0
- package/src/components/CircularProgress/circular-progress.stories.tsx +160 -0
- package/src/components/CircularProgress/circular-progress.tsx +3 -4
- package/src/components/CircularProgress/index.ts +5 -0
- package/src/components/Coachmark/coachmark-story-helpers.tsx +39 -0
- package/src/components/Coachmark/coachmark.anatomy.stories.tsx +356 -0
- package/src/components/Coachmark/coachmark.principles.stories.tsx +369 -0
- package/src/components/Coachmark/coachmark.spec.md +230 -0
- package/src/components/Coachmark/coachmark.stories.tsx +214 -0
- package/src/components/Coachmark/coachmark.tsx +12 -3
- package/src/components/Coachmark/index.ts +5 -0
- package/src/components/Combobox/combobox.anatomy.stories.tsx +919 -0
- package/src/components/Combobox/combobox.principles.stories.tsx +239 -0
- package/src/components/Combobox/combobox.spec.md +184 -0
- package/src/components/Combobox/combobox.stories.tsx +184 -0
- package/src/components/Combobox/combobox.tsx +54 -27
- package/src/components/Combobox/index.ts +5 -0
- package/src/components/Command/command.anatomy.stories.tsx +105 -0
- package/src/components/Command/command.principles.stories.tsx +88 -0
- package/src/components/Command/command.spec.md +171 -0
- package/src/components/Command/command.stories.tsx +280 -0
- package/src/components/Command/index.ts +5 -0
- package/src/components/DataTable/cell-registry.tsx +13 -4
- package/src/components/DataTable/data-table-filter-panel.tsx +2 -2
- package/src/components/DataTable/data-table.anatomy.stories.tsx +517 -0
- package/src/components/DataTable/data-table.principles.stories.tsx +265 -0
- package/src/components/DataTable/data-table.spec.md +528 -0
- package/src/components/DataTable/data-table.stories.tsx +1892 -0
- package/src/components/DataTable/data-table.tsx +16 -9
- package/src/components/DataTable/filter-operators.spec.md +275 -0
- package/src/components/DataTable/filter-operators.ts +1 -1
- package/src/components/DataTable/filter-tree.ts +2 -2
- package/src/components/DataTable/index.ts +5 -0
- package/src/components/DateGrid/date-grid.anatomy.stories.tsx +583 -0
- package/src/components/DateGrid/date-grid.principles.stories.tsx +338 -0
- package/src/components/DateGrid/date-grid.spec.md +215 -0
- package/src/components/DateGrid/date-grid.stories.tsx +195 -0
- package/src/components/DateGrid/date-grid.tsx +15 -15
- package/src/components/DateGrid/index.ts +5 -0
- package/src/components/DatePicker/date-picker.anatomy.stories.tsx +952 -0
- package/src/components/DatePicker/date-picker.principles.stories.tsx +205 -0
- package/src/components/DatePicker/date-picker.spec.md +333 -0
- package/src/components/DatePicker/date-picker.stories.tsx +353 -0
- package/src/components/DatePicker/date-picker.tsx +29 -14
- package/src/components/DatePicker/index.ts +5 -0
- package/src/components/DescriptionList/description-list.anatomy.stories.tsx +252 -0
- package/src/components/DescriptionList/description-list.principles.stories.tsx +323 -0
- package/src/components/DescriptionList/description-list.spec.md +214 -0
- package/src/components/DescriptionList/description-list.stories.tsx +128 -0
- package/src/components/DescriptionList/description-list.tsx +2 -2
- package/src/components/DescriptionList/index.ts +5 -0
- package/src/components/Dialog/dialog.anatomy.stories.tsx +484 -0
- package/src/components/Dialog/dialog.principles.stories.tsx +313 -0
- package/src/components/Dialog/dialog.spec.md +201 -0
- package/src/components/Dialog/dialog.stories.tsx +500 -0
- package/src/components/Dialog/dialog.tsx +4 -4
- package/src/components/Dialog/index.ts +5 -0
- package/src/components/DropdownMenu/dropdown-menu.anatomy.stories.tsx +969 -0
- package/src/components/DropdownMenu/dropdown-menu.principles.stories.tsx +340 -0
- package/src/components/DropdownMenu/dropdown-menu.spec.md +265 -0
- package/src/components/DropdownMenu/dropdown-menu.stories.tsx +288 -0
- package/src/components/DropdownMenu/dropdown-menu.tsx +14 -5
- package/src/components/DropdownMenu/index.ts +5 -0
- package/src/components/Empty/empty.anatomy.stories.tsx +275 -0
- package/src/components/Empty/empty.principles.stories.tsx +314 -0
- package/src/components/Empty/empty.spec.md +215 -0
- package/src/components/Empty/empty.stories.tsx +80 -0
- package/src/components/Empty/empty.tsx +13 -6
- package/src/components/Empty/index.ts +5 -0
- package/src/components/Field/field-context.ts +98 -0
- package/src/components/Field/field-controls.spec.md +366 -0
- package/src/components/Field/field-types.ts +1 -1
- package/src/components/Field/field.anatomy.stories.tsx +541 -0
- package/src/components/Field/field.principles.stories.tsx +277 -0
- package/src/components/Field/field.spec.md +438 -0
- package/src/components/Field/field.stories.tsx +598 -0
- package/src/components/Field/field.tsx +2 -2
- package/src/components/Field/form-validation.spec.md +150 -0
- package/src/components/Field/index.ts +5 -0
- package/src/components/FieldControlGroup/field-control-group.anatomy.stories.tsx +117 -0
- package/src/components/FieldControlGroup/field-control-group.principles.stories.tsx +117 -0
- package/src/components/FieldControlGroup/field-control-group.spec.md +179 -0
- package/src/components/FieldControlGroup/field-control-group.stories.tsx +161 -0
- package/src/components/FieldControlGroup/field-control-group.tsx +5 -5
- package/src/components/FieldControlGroup/index.ts +5 -0
- package/src/components/FileItem/file-item.anatomy.stories.tsx +354 -0
- package/src/components/FileItem/file-item.principles.stories.tsx +275 -0
- package/src/components/FileItem/file-item.spec.md +491 -0
- package/src/components/FileItem/file-item.stories.tsx +265 -0
- package/src/components/FileItem/file-item.tsx +37 -13
- package/src/components/FileItem/index.ts +5 -0
- package/src/components/FileUpload/file-upload.anatomy.stories.tsx +444 -0
- package/src/components/FileUpload/file-upload.principles.stories.tsx +314 -0
- package/src/components/FileUpload/file-upload.spec.md +134 -0
- package/src/components/FileUpload/file-upload.stories.tsx +167 -0
- package/src/components/FileUpload/file-upload.tsx +75 -26
- package/src/components/FileUpload/index.ts +5 -0
- package/src/components/FileViewer/file-viewer.anatomy.stories.tsx +1122 -0
- package/src/components/FileViewer/file-viewer.principles.stories.tsx +636 -0
- package/src/components/FileViewer/file-viewer.spec.md +380 -0
- package/src/components/FileViewer/file-viewer.stories.tsx +407 -0
- package/src/components/FileViewer/file-viewer.tsx +10 -9
- package/src/components/FileViewer/index.ts +5 -0
- package/src/components/HoverCard/hover-card.anatomy.stories.tsx +145 -0
- package/src/components/HoverCard/hover-card.principles.stories.tsx +222 -0
- package/src/components/HoverCard/hover-card.spec.md +157 -0
- package/src/components/HoverCard/hover-card.stories.tsx +304 -0
- package/src/components/HoverCard/hover-card.tsx +3 -3
- package/src/components/HoverCard/index.ts +5 -0
- package/src/components/Input/index.ts +5 -0
- package/src/components/Input/input.anatomy.stories.tsx +763 -0
- package/src/components/Input/input.principles.stories.tsx +292 -0
- package/src/components/Input/input.spec.md +195 -0
- package/src/components/Input/input.stories.tsx +133 -0
- package/src/components/Input/input.tsx +17 -14
- package/src/components/LinkInput/index.ts +5 -0
- package/src/components/LinkInput/link-input.anatomy.stories.tsx +746 -0
- package/src/components/LinkInput/link-input.principles.stories.tsx +182 -0
- package/src/components/LinkInput/link-input.spec.md +131 -0
- package/src/components/LinkInput/link-input.stories.tsx +132 -0
- package/src/components/LinkInput/link-input.tsx +9 -8
- package/src/components/Menu/index.ts +5 -0
- package/src/components/Menu/menu-item.anatomy.stories.tsx +780 -0
- package/src/components/Menu/menu-item.principles.stories.tsx +81 -0
- package/src/components/Menu/menu-item.spec.md +292 -0
- package/src/components/Menu/menu-item.stories.tsx +214 -0
- package/src/components/Menu/menu-item.tsx +1 -0
- package/src/components/Notice/index.ts +5 -0
- package/src/components/Notice/notice.anatomy.stories.tsx +610 -0
- package/src/components/Notice/notice.principles.stories.tsx +102 -0
- package/src/components/Notice/notice.spec.md +151 -0
- package/src/components/Notice/notice.stories.tsx +257 -0
- package/src/components/Notice/notice.tsx +3 -2
- package/src/components/NumberInput/index.ts +5 -0
- package/src/components/NumberInput/number-input.anatomy.stories.tsx +786 -0
- package/src/components/NumberInput/number-input.principles.stories.tsx +221 -0
- package/src/components/NumberInput/number-input.spec.md +125 -0
- package/src/components/NumberInput/number-input.stories.tsx +142 -0
- package/src/components/NumberInput/number-input.tsx +9 -10
- package/src/components/OverflowIndicator/index.ts +5 -0
- package/src/components/OverflowIndicator/overflow-indicator.anatomy.stories.tsx +548 -0
- package/src/components/OverflowIndicator/overflow-indicator.principles.stories.tsx +80 -0
- package/src/components/OverflowIndicator/overflow-indicator.spec.md +119 -0
- package/src/components/OverflowIndicator/overflow-indicator.stories.tsx +274 -0
- package/src/components/OverflowIndicator/overflow-indicator.tsx +9 -2
- package/src/components/PeoplePicker/index.ts +5 -0
- package/src/components/PeoplePicker/people-picker-helpers.ts +5 -5
- package/src/components/PeoplePicker/people-picker.anatomy.stories.tsx +418 -0
- package/src/components/PeoplePicker/people-picker.principles.stories.tsx +192 -0
- package/src/components/PeoplePicker/people-picker.spec.md +278 -0
- package/src/components/PeoplePicker/people-picker.stories.tsx +163 -0
- package/src/components/PeoplePicker/people-picker.tsx +15 -14
- package/src/components/PeoplePicker/person-display.tsx +26 -26
- package/src/components/Popover/index.ts +5 -0
- package/src/components/Popover/popover.anatomy.stories.tsx +277 -0
- package/src/components/Popover/popover.principles.stories.tsx +293 -0
- package/src/components/Popover/popover.spec.md +200 -0
- package/src/components/Popover/popover.stories.tsx +116 -0
- package/src/components/Popover/popover.tsx +2 -2
- package/src/components/ProfileCard/index.ts +5 -0
- package/src/components/ProfileCard/profile-card.anatomy.stories.tsx +504 -0
- package/src/components/ProfileCard/profile-card.principles.stories.tsx +221 -0
- package/src/components/ProfileCard/profile-card.spec.md +171 -0
- package/src/components/ProfileCard/profile-card.stories.tsx +53 -0
- package/src/components/{NameCard/name-card.tsx → ProfileCard/profile-card.tsx} +25 -24
- package/src/components/ProgressBar/index.ts +5 -0
- package/src/components/ProgressBar/progress-bar.anatomy.stories.tsx +438 -0
- package/src/components/ProgressBar/progress-bar.principles.stories.tsx +337 -0
- package/src/components/ProgressBar/progress-bar.spec.md +232 -0
- package/src/components/ProgressBar/progress-bar.stories.tsx +119 -0
- package/src/components/ProgressBar/progress-bar.tsx +4 -4
- package/src/components/RadioGroup/index.ts +5 -0
- package/src/components/RadioGroup/radio-group.anatomy.stories.tsx +678 -0
- package/src/components/RadioGroup/radio-group.principles.stories.tsx +170 -0
- package/src/components/RadioGroup/radio-group.spec.md +141 -0
- package/src/components/RadioGroup/radio-group.stories.tsx +101 -0
- package/src/components/RadioGroup/radio-group.tsx +41 -41
- package/src/components/Rating/index.ts +5 -0
- package/src/components/Rating/rating.anatomy.stories.tsx +494 -0
- package/src/components/Rating/rating.principles.stories.tsx +293 -0
- package/src/components/Rating/rating.spec.md +208 -0
- package/src/components/Rating/rating.stories.tsx +133 -0
- package/src/components/Rating/rating.tsx +23 -12
- package/src/components/ScrollArea/index.ts +5 -0
- package/src/components/ScrollArea/scroll-area.anatomy.stories.tsx +431 -0
- package/src/components/ScrollArea/scroll-area.principles.stories.tsx +337 -0
- package/src/components/ScrollArea/scroll-area.spec.md +145 -0
- package/src/components/ScrollArea/scroll-area.stories.tsx +193 -0
- package/src/components/ScrollArea/scroll-area.tsx +1 -1
- package/src/components/SegmentedControl/index.ts +5 -0
- package/src/components/SegmentedControl/segmented-control.anatomy.stories.tsx +295 -0
- package/src/components/SegmentedControl/segmented-control.principles.stories.tsx +281 -0
- package/src/components/SegmentedControl/segmented-control.spec.md +296 -0
- package/src/components/SegmentedControl/segmented-control.stories.tsx +33 -0
- package/src/components/SegmentedControl/segmented-control.tsx +9 -10
- package/src/components/Select/index.ts +5 -0
- package/src/components/Select/select.anatomy.stories.tsx +827 -0
- package/src/components/Select/select.principles.stories.tsx +311 -0
- package/src/components/Select/select.spec.md +311 -0
- package/src/components/Select/select.stories.tsx +198 -0
- package/src/components/Select/select.tsx +17 -11
- package/src/components/SelectMenu/index.ts +5 -0
- package/src/components/SelectMenu/select-menu.anatomy.stories.tsx +811 -0
- package/src/components/SelectMenu/select-menu.principles.stories.tsx +107 -0
- package/src/components/SelectMenu/select-menu.spec.md +222 -0
- package/src/components/SelectMenu/select-menu.stories.tsx +148 -0
- package/src/components/SelectMenu/select-menu.tsx +20 -6
- package/src/components/SelectionControl/index.ts +5 -0
- package/src/components/SelectionControl/selection-item.anatomy.stories.tsx +571 -0
- package/src/components/SelectionControl/selection-item.principles.stories.tsx +77 -0
- package/src/components/SelectionControl/selection-item.spec.md +130 -0
- package/src/components/SelectionControl/selection-item.stories.tsx +137 -0
- package/src/components/Separator/index.ts +5 -0
- package/src/components/Separator/separator.anatomy.stories.tsx +125 -0
- package/src/components/Separator/separator.principles.stories.tsx +141 -0
- package/src/components/Separator/separator.spec.md +109 -0
- package/src/components/Separator/separator.stories.tsx +127 -0
- package/src/components/Separator/separator.tsx +2 -2
- package/src/components/Sheet/index.ts +5 -0
- package/src/components/Sheet/sheet.anatomy.stories.tsx +268 -0
- package/src/components/Sheet/sheet.principles.stories.tsx +370 -0
- package/src/components/Sheet/sheet.spec.md +148 -0
- package/src/components/Sheet/sheet.stories.tsx +168 -0
- package/src/components/Sheet/sheet.tsx +1 -1
- package/src/components/Sidebar/index.ts +5 -0
- package/src/components/Sidebar/sidebar.anatomy.stories.tsx +763 -0
- package/src/components/Sidebar/sidebar.principles.stories.tsx +505 -0
- package/src/components/Sidebar/sidebar.spec.md +711 -0
- package/src/components/Sidebar/sidebar.stories.tsx +482 -0
- package/src/components/Sidebar/sidebar.tsx +5 -2
- package/src/components/Skeleton/index.ts +5 -0
- package/src/components/Skeleton/skeleton.anatomy.stories.tsx +145 -0
- package/src/components/Skeleton/skeleton.principles.stories.tsx +221 -0
- package/src/components/Skeleton/skeleton.spec.md +104 -0
- package/src/components/Skeleton/skeleton.stories.tsx +129 -0
- package/src/components/Slider/index.ts +5 -0
- package/src/components/Slider/slider.anatomy.stories.tsx +235 -0
- package/src/components/Slider/slider.principles.stories.tsx +250 -0
- package/src/components/Slider/slider.spec.md +353 -0
- package/src/components/Slider/slider.stories.tsx +115 -0
- package/src/components/Slider/slider.tsx +26 -5
- package/src/components/Steps/index.ts +5 -0
- package/src/components/Steps/steps.anatomy.stories.tsx +448 -0
- package/src/components/Steps/steps.principles.stories.tsx +303 -0
- package/src/components/Steps/steps.spec.md +473 -0
- package/src/components/Steps/steps.stories.tsx +370 -0
- package/src/components/Steps/steps.tsx +28 -11
- package/src/components/Switch/index.ts +5 -0
- package/src/components/Switch/switch.anatomy.stories.tsx +227 -0
- package/src/components/Switch/switch.principles.stories.tsx +174 -0
- package/src/components/Switch/switch.spec.md +221 -0
- package/src/components/Switch/switch.stories.tsx +107 -0
- package/src/components/Switch/switch.tsx +22 -18
- package/src/components/Tabs/index.ts +5 -0
- package/src/components/Tabs/tabs.anatomy.stories.tsx +414 -0
- package/src/components/Tabs/tabs.principles.stories.tsx +257 -0
- package/src/components/Tabs/tabs.spec.md +316 -0
- package/src/components/Tabs/tabs.stories.tsx +155 -0
- package/src/components/Tabs/tabs.tsx +6 -5
- package/src/components/Tag/index.ts +5 -0
- package/src/components/Tag/tag.anatomy.stories.tsx +664 -0
- package/src/components/Tag/tag.principles.stories.tsx +270 -0
- package/src/components/Tag/tag.spec.md +304 -0
- package/src/components/Tag/tag.stories.tsx +69 -0
- package/src/components/Tag/tag.tsx +52 -56
- package/src/components/Textarea/index.ts +5 -0
- package/src/components/Textarea/textarea.anatomy.stories.tsx +304 -0
- package/src/components/Textarea/textarea.principles.stories.tsx +175 -0
- package/src/components/Textarea/textarea.spec.md +150 -0
- package/src/components/Textarea/textarea.stories.tsx +53 -0
- package/src/components/Textarea/textarea.tsx +16 -14
- package/src/components/TimePicker/index.ts +5 -0
- package/src/components/TimePicker/time-picker.anatomy.stories.tsx +275 -0
- package/src/components/TimePicker/time-picker.principles.stories.tsx +140 -0
- package/src/components/TimePicker/time-picker.spec.md +270 -0
- package/src/components/TimePicker/time-picker.stories.tsx +193 -0
- package/src/components/TimePicker/time-picker.tsx +29 -12
- package/src/components/Toast/index.ts +5 -0
- package/src/components/Toast/toast.anatomy.stories.tsx +324 -0
- package/src/components/Toast/toast.principles.stories.tsx +217 -0
- package/src/components/Toast/toast.spec.md +178 -0
- package/src/components/Toast/toast.stories.tsx +119 -0
- package/src/components/Toast/toast.tsx +1 -1
- package/src/components/Tooltip/index.ts +5 -0
- package/src/components/Tooltip/tooltip.anatomy.stories.tsx +413 -0
- package/src/components/Tooltip/tooltip.principles.stories.tsx +204 -0
- package/src/components/Tooltip/tooltip.spec.md +139 -0
- package/src/components/Tooltip/tooltip.stories.tsx +116 -0
- package/src/components/Tooltip/tooltip.tsx +1 -0
- package/src/components/TreeView/index.ts +5 -0
- package/src/components/TreeView/tree-view.anatomy.stories.tsx +410 -0
- package/src/components/TreeView/tree-view.principles.stories.tsx +190 -0
- package/src/components/TreeView/tree-view.spec.md +388 -0
- package/src/components/TreeView/tree-view.stories.tsx +297 -0
- package/src/components/TreeView/tree-view.tsx +49 -16
- package/src/hooks/use-overflow-items.ts +10 -6
- package/src/index.ts +73 -69
- package/src/lib/utils.ts +2 -1
- package/src/patterns/README.md +15 -11
- package/src/patterns/action-bar/action-bar.spec.md +458 -0
- package/src/patterns/action-bar/action-bar.stories.tsx +612 -0
- package/src/patterns/element-anatomy/element-anatomy.spec.md +215 -0
- package/src/patterns/element-anatomy/index.ts +5 -0
- package/src/patterns/element-anatomy/inline-action.spec.md +320 -0
- package/src/patterns/element-anatomy/item-anatomy.spec.md +1042 -0
- package/src/patterns/element-anatomy/item-anatomy.stories.tsx +1622 -0
- package/src/patterns/element-anatomy/item-anatomy.tsx +6 -2
- package/src/patterns/header-canonical/chrome-header.tsx +13 -3
- package/src/patterns/header-canonical/header-canonical.css +2 -2
- package/src/patterns/header-canonical/header-canonical.spec.md +310 -0
- package/src/patterns/header-canonical/header-canonical.stories.tsx +150 -0
- package/src/patterns/header-canonical/index.ts +5 -0
- package/src/patterns/horizontal-overflow/horizontal-overflow.spec.md +201 -0
- package/src/patterns/horizontal-overflow/index.ts +5 -0
- package/src/patterns/overlay-surface/index.ts +5 -0
- package/src/patterns/overlay-surface/overlay-surface.spec.md +435 -0
- package/src/patterns/overlay-surface/overlay-surface.tsx +4 -2
- package/src/patterns/resize-handle/index.ts +5 -0
- package/src/patterns/resize-handle/resize-handle.spec.md +111 -0
- package/src/patterns/resize-handle/resize-handle.stories.tsx +71 -0
- package/src/story-governance/category-matrix.ts +55 -0
- package/src/styles/base.css +85 -0
- package/src/styles/tokens.css +11 -0
- package/src/tokens/README.md +2 -0
- package/src/tokens/categorical-color.ts +164 -0
- package/src/tokens/color/color.spec.md +790 -0
- package/src/tokens/color/color.stories.tsx +363 -0
- package/src/tokens/color/primitives.css +7 -0
- package/src/tokens/color/semantic.css +20 -11
- package/src/tokens/density/density.spec.md +127 -0
- package/src/tokens/density/density.stories.tsx +240 -0
- package/src/tokens/elevation/elevation.spec.md +79 -0
- package/src/tokens/elevation/elevation.stories.tsx +98 -0
- package/src/tokens/layoutSpace/layoutSpace.css +1 -1
- package/src/tokens/layoutSpace/layoutSpace.spec.md +313 -0
- package/src/tokens/layoutSpace/layoutSpace.stories.tsx +75 -0
- package/src/tokens/motion/motion.css +2 -2
- package/src/tokens/motion/motion.spec.md +97 -0
- package/src/tokens/motion/motion.ts +1 -1
- package/src/tokens/opacity/opacity.spec.md +84 -0
- package/src/tokens/opacity/opacity.stories.tsx +69 -0
- package/src/tokens/orphan-tokens.spec.md +117 -0
- package/src/tokens/radius/radius.spec.md +128 -0
- package/src/tokens/radius/radius.stories.tsx +86 -0
- package/src/tokens/token-system.spec.md +243 -0
- package/src/tokens/typography/typography.spec.md +208 -0
- package/src/tokens/typography/typography.stories.tsx +133 -0
- package/src/tokens/uiSize/icon-size.ts +1 -2
- package/src/tokens/uiSize/uiSize.css +16 -0
- package/src/tokens/uiSize/uiSize.spec.md +439 -0
- package/dist/components/NameCard/name-card.d.ts.map +0 -1
- package/dist/components/NameCard/name-card.js.map +0 -1
- /package/dist/{style.css → react-day-picker.css} +0 -0
|
@@ -0,0 +1,780 @@
|
|
|
1
|
+
// @anatomy-rationale:
|
|
2
|
+
// StateBehavior covered by ColorMatrix「State 色彩對照」段(default / hover /
|
|
3
|
+
// selected / disabled,單選 × 多選 = 8 組合)+ Header 子段。Menu item
|
|
4
|
+
// 狀態本身就是色彩變化(bg / text / icon / desc 四 token),分到獨立 5.
|
|
5
|
+
// 會與 ColorMatrix 重複。
|
|
6
|
+
import type { Meta } from '@storybook/react'
|
|
7
|
+
import { useState, useEffect } from 'react'
|
|
8
|
+
import { Mail, Bell, FileText } from 'lucide-react'
|
|
9
|
+
import { MenuItem, MenuGroup } from './menu-item'
|
|
10
|
+
import { Tag } from '@/design-system/components/Tag/tag'
|
|
11
|
+
// Avatar is now passed as AvatarData (data object), rendered internally by MenuItem
|
|
12
|
+
|
|
13
|
+
const meta: Meta = {
|
|
14
|
+
title: 'Design System/Internal/Menu/設計規格',
|
|
15
|
+
tags: ['!dev'],
|
|
16
|
+
parameters: { layout: 'padded' },
|
|
17
|
+
}
|
|
18
|
+
export default meta
|
|
19
|
+
|
|
20
|
+
/* ═══════════════════════════════════════════════════════════════════════════
|
|
21
|
+
Types & Data
|
|
22
|
+
═══════════════════════════════════════════════════════════════════════════ */
|
|
23
|
+
|
|
24
|
+
type SizeKey = 'sm' | 'md' | 'lg'
|
|
25
|
+
type StateKey = 'default' | 'hover' | 'selected' | 'disabled'
|
|
26
|
+
type ModeKey = 'single' | 'multi'
|
|
27
|
+
type ColorSpec = { bg: string; text: string; icon: string; desc: string }
|
|
28
|
+
|
|
29
|
+
const SIZES: SizeKey[] = ['sm', 'md', 'lg']
|
|
30
|
+
const STATES: StateKey[] = ['default', 'hover', 'selected', 'disabled']
|
|
31
|
+
|
|
32
|
+
/** 單選 token map */
|
|
33
|
+
const SINGLE_TOKEN_MAP: Record<StateKey, ColorSpec> = {
|
|
34
|
+
default: { bg: 'transparent', text: '--foreground', icon: '--foreground', desc: '--fg-secondary' },
|
|
35
|
+
hover: { bg: '--neutral-hover', text: '--foreground', icon: '--foreground', desc: '--fg-secondary' },
|
|
36
|
+
selected: { bg: '--neutral-selected',text: '--foreground', icon: '--foreground', desc: '--fg-secondary' },
|
|
37
|
+
disabled: { bg: 'transparent', text: '--fg-disabled',icon: '--fg-disabled', desc: '--fg-disabled' },
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
/** 多選 token map */
|
|
41
|
+
const MULTI_TOKEN_MAP: Record<StateKey, ColorSpec> = {
|
|
42
|
+
default: { bg: 'transparent', text: '--foreground', icon: '--foreground', desc: '--fg-secondary' },
|
|
43
|
+
hover: { bg: '--neutral-hover', text: '--foreground', icon: '--foreground', desc: '--fg-secondary' },
|
|
44
|
+
selected: { bg: 'transparent', text: '--foreground', icon: '--foreground', desc: '--fg-secondary' },
|
|
45
|
+
disabled: { bg: 'transparent', text: '--fg-disabled',icon: '--fg-disabled', desc: '--fg-disabled' },
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
interface SizeSpec {
|
|
49
|
+
heightToken: string
|
|
50
|
+
labelFont: string; labelSize: string
|
|
51
|
+
descFont: string; descSize: string
|
|
52
|
+
icon: number
|
|
53
|
+
checkbox: string
|
|
54
|
+
avatarInline: number; avatarBlock: number
|
|
55
|
+
py: string
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
const SIZE_SPECS: Record<SizeKey, SizeSpec> = {
|
|
59
|
+
sm: {
|
|
60
|
+
heightToken: '--field-height-sm',
|
|
61
|
+
labelFont: 'text-body leading-compact', labelSize: '14px × 1.3',
|
|
62
|
+
descFont: 'text-caption', descSize: '12px × 1.3',
|
|
63
|
+
icon: 16, checkbox: 'sm (16px)',
|
|
64
|
+
avatarInline: 20, avatarBlock: 32,
|
|
65
|
+
py: 'calc((var(--field-height-sm) − 一行文字高度) / 2)',
|
|
66
|
+
},
|
|
67
|
+
md: {
|
|
68
|
+
heightToken: '--field-height-md',
|
|
69
|
+
labelFont: 'text-body leading-compact', labelSize: '14px × 1.3',
|
|
70
|
+
descFont: 'text-caption', descSize: '12px × 1.3',
|
|
71
|
+
icon: 16, checkbox: 'md (16px)',
|
|
72
|
+
avatarInline: 24, avatarBlock: 32,
|
|
73
|
+
py: 'calc((var(--field-height-md) − 一行文字高度) / 2)',
|
|
74
|
+
},
|
|
75
|
+
lg: {
|
|
76
|
+
heightToken: '--field-height-lg',
|
|
77
|
+
labelFont: 'text-body-lg leading-compact', labelSize: '16px × 1.3',
|
|
78
|
+
descFont: 'text-body leading-compact', descSize: '14px × 1.3',
|
|
79
|
+
icon: 20, checkbox: 'lg (20px)',
|
|
80
|
+
avatarInline: 24, avatarBlock: 40,
|
|
81
|
+
py: 'calc((var(--field-height-lg) − 一行文字高度) / 2)',
|
|
82
|
+
},
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
/* ═══════════════════════════════════════════════════════════════════════════
|
|
86
|
+
Shared UI
|
|
87
|
+
|
|
88
|
+
NOTE: Kept local (not imported from `_anatomy/anatomy-utils`) because the
|
|
89
|
+
Button-family inspector layout diverges visually from the 通用 helpers:
|
|
90
|
+
H3 `text-h6 font-semibold` (not `text-body font-bold mb-2`), Desc has no
|
|
91
|
+
bottom margin, Th/Td use `p-2 border-b border-divider` row style, and
|
|
92
|
+
Swatch defaults to `size="md"` for inline token chips.
|
|
93
|
+
═══════════════════════════════════════════════════════════════════════════ */
|
|
94
|
+
|
|
95
|
+
const H3 = ({ children }: { children: React.ReactNode }) => (
|
|
96
|
+
<h3 className="text-h6 font-semibold text-foreground">{children}</h3>
|
|
97
|
+
)
|
|
98
|
+
const Desc = ({ children }: { children: React.ReactNode }) => (
|
|
99
|
+
<p className="text-caption text-fg-muted max-w-[720px]">{children}</p>
|
|
100
|
+
)
|
|
101
|
+
const Th = ({ children }: { children: React.ReactNode }) => (
|
|
102
|
+
<th className="text-left p-2 border-b border-divider text-fg-muted font-medium text-caption whitespace-nowrap">{children}</th>
|
|
103
|
+
)
|
|
104
|
+
const Td = ({ children, mono }: { children: React.ReactNode; mono?: boolean }) => (
|
|
105
|
+
<td className={`p-2 border-b border-divider align-top whitespace-nowrap text-caption ${mono ? 'font-mono' : ''}`}>{children}</td>
|
|
106
|
+
)
|
|
107
|
+
const TkVal = ({ token, value }: { token: string; value?: string }) => (
|
|
108
|
+
<div className="flex flex-col gap-0.5">
|
|
109
|
+
<span className="font-mono text-[12px] text-fg-secondary">{token}</span>
|
|
110
|
+
{value && <span className="font-mono text-[10px] text-fg-muted">{value}</span>}
|
|
111
|
+
</div>
|
|
112
|
+
)
|
|
113
|
+
|
|
114
|
+
const Swatch = ({ value, size = 'md' }: { value: string; size?: 'sm' | 'md' }) => {
|
|
115
|
+
const s = size === 'sm' ? 'w-3 h-3' : 'w-4 h-4'
|
|
116
|
+
if (value === 'transparent') {
|
|
117
|
+
return <span className={`${s} rounded-md shrink-0 border border-border`}
|
|
118
|
+
style={{ backgroundImage: 'linear-gradient(45deg,#ddd 25%,transparent 25%,transparent 75%,#ddd 75%),linear-gradient(45deg,#ddd 25%,transparent 25%,transparent 75%,#ddd 75%)', backgroundSize: '6px 6px', backgroundPosition: '0 0,3px 3px' }} />
|
|
119
|
+
}
|
|
120
|
+
return <span className={`${s} rounded-md shrink-0 border border-black/10`} style={{ backgroundColor: `var(${value})` }} />
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
const TokenAnnotation = ({ colors }: { colors: ColorSpec }) => (
|
|
124
|
+
<div className="flex flex-col gap-0.5 mt-2">
|
|
125
|
+
{([['bg', 'bg'], ['text', 'label'], ['icon', 'icon'], ['desc', 'desc']] as const).map(([key, label]) => (
|
|
126
|
+
<span key={key} className="inline-flex items-center gap-1 text-[10px]">
|
|
127
|
+
<Swatch value={colors[key]} size="sm" />
|
|
128
|
+
<span className="text-fg-muted w-7 shrink-0">{label}</span>
|
|
129
|
+
<span className="font-mono text-fg-secondary">{colors[key]}</span>
|
|
130
|
+
</span>
|
|
131
|
+
))}
|
|
132
|
+
</div>
|
|
133
|
+
)
|
|
134
|
+
|
|
135
|
+
const Tab = ({ active, onClick, disabled, children }: { active: boolean; onClick: () => void; disabled?: boolean; children: React.ReactNode }) => {
|
|
136
|
+
if (disabled) return <span className="px-2.5 py-1 text-[12px] font-mono rounded-md text-fg-disabled bg-neutral-hover cursor-not-allowed">{children}</span>
|
|
137
|
+
return (
|
|
138
|
+
<button type="button" onClick={onClick}
|
|
139
|
+
className={`px-2.5 py-1 text-[12px] font-mono rounded-md cursor-pointer transition-colors ${
|
|
140
|
+
active ? 'bg-primary text-white font-semibold' : 'bg-neutral-hover text-fg-secondary hover:bg-neutral-active'
|
|
141
|
+
}`}>
|
|
142
|
+
{children}
|
|
143
|
+
</button>
|
|
144
|
+
)
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
const PropRow = ({ label, dot, children }: { label: string; dot?: string; children: React.ReactNode }) => (
|
|
148
|
+
<div className="flex items-start gap-3 py-2 border-b border-divider last:border-b-0">
|
|
149
|
+
<span className="text-[11px] text-fg-muted font-medium w-[80px] shrink-0 pt-0.5 flex items-center gap-1.5">
|
|
150
|
+
{dot && <span className="w-2 h-2 rounded-full shrink-0" style={{ backgroundColor: dot }} />}
|
|
151
|
+
{label}
|
|
152
|
+
</span>
|
|
153
|
+
<div className="flex-1 text-[12px] font-mono text-fg-secondary">{children}</div>
|
|
154
|
+
</div>
|
|
155
|
+
)
|
|
156
|
+
|
|
157
|
+
const TokenValue = ({ value }: { value: string }) => (
|
|
158
|
+
<span className="inline-flex items-center gap-2"><Swatch value={value} /><span>{value}</span></span>
|
|
159
|
+
)
|
|
160
|
+
|
|
161
|
+
/* ── Blueprint zone colors ── */
|
|
162
|
+
const Z = {
|
|
163
|
+
pad: { bg: 'rgba(194,225,154,0.6)', border: 'rgba(139,179,91,0.9)', text: '#5a7a2e' },
|
|
164
|
+
prefix: { bg: 'rgba(166,208,245,0.6)', border: 'rgba(80,145,210,0.9)', text: '#2d6a9f' },
|
|
165
|
+
gap: { bg: 'rgba(253,218,158,0.6)', border: 'rgba(218,165,60,0.9)', text: '#8a6010' },
|
|
166
|
+
content: { bg: 'rgba(199,178,230,0.6)', border: 'rgba(138,103,190,0.9)', text: '#6035a8' },
|
|
167
|
+
suffix: { bg: 'rgba(251,191,206,0.6)', border: 'rgba(220,110,140,0.9)', text: '#a33060' },
|
|
168
|
+
dim: { text: '#d04040' },
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
/** Horizontal zone block */
|
|
172
|
+
const BpZoneH = ({ w, color, label, sub }: { w: number; color: { bg: string; border: string; text: string }; label: string; sub?: string }) => (
|
|
173
|
+
<div className="flex flex-col items-center justify-center shrink-0 gap-0.5"
|
|
174
|
+
style={{ width: w, height: '100%', background: color.bg, borderLeft: `1.5px dashed ${color.border}`, borderRight: `1.5px dashed ${color.border}` }}>
|
|
175
|
+
<span className="text-[10px] font-mono font-bold leading-none" style={{ color: color.text }}>{label}</span>
|
|
176
|
+
{sub && <span className="text-[9px] font-mono leading-none opacity-70" style={{ color: color.text }}>{sub}</span>}
|
|
177
|
+
</div>
|
|
178
|
+
)
|
|
179
|
+
|
|
180
|
+
/** Vertical zone block (full width, fixed height) */
|
|
181
|
+
const BpZoneV = ({ h, color, label, sub }: { h: number; color: { bg: string; border: string; text: string }; label: string; sub?: string }) => (
|
|
182
|
+
<div className="flex items-center justify-center gap-1.5"
|
|
183
|
+
style={{ height: h, width: '100%', background: color.bg, borderTop: `1.5px dashed ${color.border}`, borderBottom: `1.5px dashed ${color.border}` }}>
|
|
184
|
+
<span className="text-[10px] font-mono font-bold leading-none" style={{ color: color.text }}>{label}</span>
|
|
185
|
+
{sub && <span className="text-[9px] font-mono leading-none opacity-70" style={{ color: color.text }}>{sub}</span>}
|
|
186
|
+
</div>
|
|
187
|
+
)
|
|
188
|
+
|
|
189
|
+
const MenuContainer = ({ children, width = 320 }: { children: React.ReactNode; width?: number }) => (
|
|
190
|
+
<div className="rounded-lg bg-surface-raised border border-border overflow-hidden"
|
|
191
|
+
style={{ boxShadow: 'var(--elevation-200)', width }}>
|
|
192
|
+
{children}
|
|
193
|
+
</div>
|
|
194
|
+
)
|
|
195
|
+
|
|
196
|
+
|
|
197
|
+
/* ═══════════════════════════════════════════════════════════════════════════
|
|
198
|
+
1. 元件總覽
|
|
199
|
+
═══════════════════════════════════════════════════════════════════════════ */
|
|
200
|
+
|
|
201
|
+
export const Overview = {
|
|
202
|
+
name: '元件總覽',
|
|
203
|
+
render: () => (
|
|
204
|
+
<div className="flex flex-col gap-8">
|
|
205
|
+
{/* Anatomy */}
|
|
206
|
+
<div className="flex flex-col gap-4">
|
|
207
|
+
<div className="flex flex-col gap-1">
|
|
208
|
+
<H3>結構(Anatomy)</H3>
|
|
209
|
+
<Desc>三個區域:prefix(checkbox + icon 或 avatar)、content(label + description)、suffix(tag)。prefix 內 checkbox 和 icon/avatar 由對齊容器統一管理。</Desc>
|
|
210
|
+
</div>
|
|
211
|
+
<div className="flex flex-col gap-4">
|
|
212
|
+
{/* Full structure */}
|
|
213
|
+
<div className="flex flex-col gap-2 items-start">
|
|
214
|
+
<span className="text-[11px] text-fg-muted font-medium">完整結構</span>
|
|
215
|
+
<div className="inline-flex items-center border-2 border-dashed border-primary/30 rounded-md px-3 py-2.5 gap-2">
|
|
216
|
+
{[
|
|
217
|
+
{ name: 'checkbox', color: 'warning' },
|
|
218
|
+
{ name: 'startIcon | avatar', color: 'info' },
|
|
219
|
+
{ name: 'label', color: 'success' },
|
|
220
|
+
{ name: 'description', color: 'magenta' },
|
|
221
|
+
{ name: 'tag', color: 'warning' },
|
|
222
|
+
].map((s) => (
|
|
223
|
+
<span key={s.name} className="rounded px-2 py-1 text-[11px] font-mono border border-dashed"
|
|
224
|
+
style={{ borderColor: `var(--${s.color})`, backgroundColor: `var(--${s.color}-subtle)`, color: `var(--${s.color})` }}>{s.name}</span>
|
|
225
|
+
))}
|
|
226
|
+
</div>
|
|
227
|
+
<span className="text-[10px] text-fg-muted font-mono">
|
|
228
|
+
prefix: [checkbox?] [startIcon? | avatar?] · content: [label + description?] · suffix: [tag?]
|
|
229
|
+
</span>
|
|
230
|
+
</div>
|
|
231
|
+
|
|
232
|
+
{/* Prefix alignment modes */}
|
|
233
|
+
<div className="flex gap-8">
|
|
234
|
+
<div className="flex flex-col gap-2 items-start">
|
|
235
|
+
<span className="text-[11px] text-fg-muted font-medium">Inline 對齊(prefix ≤ 24px)</span>
|
|
236
|
+
<div className="inline-flex items-center border-2 border-dashed border-primary/30 rounded-md px-3 py-2.5 gap-2">
|
|
237
|
+
<span className="rounded px-2 py-1 text-[11px] font-mono border border-dashed"
|
|
238
|
+
style={{ borderColor: 'var(--info)', backgroundColor: 'var(--info-subtle)', color: 'var(--info)' }}>icon 16px</span>
|
|
239
|
+
<div className="flex flex-col gap-0.5">
|
|
240
|
+
<span className="rounded px-2 py-1 text-[11px] font-mono border border-dashed"
|
|
241
|
+
style={{ borderColor: 'var(--success)', backgroundColor: 'var(--success-subtle)', color: 'var(--success)' }}>label</span>
|
|
242
|
+
<span className="rounded px-2 py-1 text-[11px] font-mono border border-dashed"
|
|
243
|
+
style={{ borderColor: 'var(--color-magenta-6)', backgroundColor: 'var(--color-magenta-1)', color: 'var(--color-magenta-6)' }}>description</span>
|
|
244
|
+
</div>
|
|
245
|
+
</div>
|
|
246
|
+
<span className="text-[10px] text-fg-muted font-mono">prefix 容器高度 = 一行文字高度,對齊第一行 label</span>
|
|
247
|
+
</div>
|
|
248
|
+
<div className="flex flex-col gap-2 items-start">
|
|
249
|
+
<span className="text-[11px] text-fg-muted font-medium">Block 對齊(avatar > 24px + description)</span>
|
|
250
|
+
<div className="inline-flex items-center border-2 border-dashed border-primary/30 rounded-md px-3 py-2.5 gap-2">
|
|
251
|
+
<span className="rounded px-2 py-1 text-[11px] font-mono border border-dashed"
|
|
252
|
+
style={{ borderColor: 'var(--info)', backgroundColor: 'var(--info-subtle)', color: 'var(--info)' }}>avatar 32px</span>
|
|
253
|
+
<div className="flex flex-col gap-0.5">
|
|
254
|
+
<span className="rounded px-2 py-1 text-[11px] font-mono border border-dashed"
|
|
255
|
+
style={{ borderColor: 'var(--success)', backgroundColor: 'var(--success-subtle)', color: 'var(--success)' }}>label</span>
|
|
256
|
+
<span className="rounded px-2 py-1 text-[11px] font-mono border border-dashed"
|
|
257
|
+
style={{ borderColor: 'var(--color-magenta-6)', backgroundColor: 'var(--color-magenta-1)', color: 'var(--color-magenta-6)' }}>description</span>
|
|
258
|
+
</div>
|
|
259
|
+
</div>
|
|
260
|
+
<span className="text-[10px] text-fg-muted font-mono">prefix 容器高度 = label行高 + 2px + desc行高,對齊文字塊中心</span>
|
|
261
|
+
</div>
|
|
262
|
+
</div>
|
|
263
|
+
</div>
|
|
264
|
+
</div>
|
|
265
|
+
|
|
266
|
+
{/* Props */}
|
|
267
|
+
<div className="flex flex-col gap-3">
|
|
268
|
+
<H3>Props</H3>
|
|
269
|
+
<div className="overflow-x-auto">
|
|
270
|
+
<table className="text-caption border-collapse">
|
|
271
|
+
<thead><tr><Th>Prop</Th><Th>Type</Th><Th>Default</Th><Th>說明</Th></tr></thead>
|
|
272
|
+
<tbody>
|
|
273
|
+
{[
|
|
274
|
+
['children', 'ReactNode', '(required)', 'Label 文字'],
|
|
275
|
+
['description', 'ReactNode', '—', '次要說明,顯示在 label 下方'],
|
|
276
|
+
['startIcon', 'LucideIcon', '—', '左側 icon,與 avatar 互斥'],
|
|
277
|
+
['avatar', 'AvatarData', '—', '左側頭像資料({ src?, alt, color? }),元件內部渲染 Avatar。與 startIcon 互斥'],
|
|
278
|
+
['checkbox', 'boolean', 'false', '顯示 checkbox(多選模式)'],
|
|
279
|
+
['checked', "boolean | 'indeterminate'", 'false', 'checkbox 選中狀態'],
|
|
280
|
+
['selected', 'boolean', 'false', '單選選中(bg-neutral-selected 背景)'],
|
|
281
|
+
['tag', 'ReactNode', '—', '後綴 Tag,靠右對齊'],
|
|
282
|
+
['disabled', 'boolean', 'false', '停用:文字 / startIcon 套 fg-disabled,checkbox 用 disabled 樣式,tag / endContent 套 opacity-disabled,avatar 不變'],
|
|
283
|
+
['header', 'boolean', 'false', '群組標題,不可選不可 hover'],
|
|
284
|
+
['size', "'sm' | 'md' | 'lg'", "'md'", '尺寸,對齊 field-height token'],
|
|
285
|
+
['endContent', 'ReactNode', '—', '後綴自訂內容(DropdownMenu 的 badge/endIcon/shortcut 經由此注入)'],
|
|
286
|
+
['labelMaxLines', "number | 'none'", '1', `標籤最大行數,'none' 不截斷`],
|
|
287
|
+
['descMaxLines', "number | 'none'", '1', `描述最大行數,'none' 不截斷`],
|
|
288
|
+
].map(([p, t, d, desc]) => (
|
|
289
|
+
<tr key={p}><Td mono>{p}</Td><Td mono>{t}</Td><Td mono>{d}</Td><Td>{desc}</Td></tr>
|
|
290
|
+
))}
|
|
291
|
+
</tbody>
|
|
292
|
+
</table>
|
|
293
|
+
</div>
|
|
294
|
+
</div>
|
|
295
|
+
</div>
|
|
296
|
+
),
|
|
297
|
+
}
|
|
298
|
+
|
|
299
|
+
/* ═══════════════════════════════════════════════════════════════════════════
|
|
300
|
+
2. 元件檢閱器
|
|
301
|
+
═══════════════════════════════════════════════════════════════════════════ */
|
|
302
|
+
|
|
303
|
+
const InspectorInner = () => {
|
|
304
|
+
const [size, setSize] = useState<SizeKey>('md')
|
|
305
|
+
const [mode, setMode] = useState<ModeKey>('single')
|
|
306
|
+
const [selected, setSelected] = useState(false)
|
|
307
|
+
const [disabled, setDisabled] = useState(false)
|
|
308
|
+
const [hasIcon, setHasIcon] = useState(true)
|
|
309
|
+
const [hasAvatar, setHasAvatar] = useState(false)
|
|
310
|
+
const [hasDesc, setHasDesc] = useState(false)
|
|
311
|
+
const [hasTag, setHasTag] = useState(false)
|
|
312
|
+
|
|
313
|
+
// avatar and icon are mutually exclusive
|
|
314
|
+
useEffect(() => { if (hasAvatar) setHasIcon(false) }, [hasAvatar])
|
|
315
|
+
useEffect(() => { if (hasIcon) setHasAvatar(false) }, [hasIcon])
|
|
316
|
+
|
|
317
|
+
const s = SIZE_SPECS[size]
|
|
318
|
+
const isMulti = mode === 'multi'
|
|
319
|
+
const stateKey: StateKey = disabled ? 'disabled' : selected ? 'selected' : 'default'
|
|
320
|
+
const colors = isMulti ? MULTI_TOKEN_MAP[stateKey] : SINGLE_TOKEN_MAP[stateKey]
|
|
321
|
+
const avatarPx = hasAvatar ? (hasDesc ? s.avatarBlock : s.avatarInline) : 0
|
|
322
|
+
const prefixAlign = avatarPx > 24 && hasDesc ? 'block' : 'inline'
|
|
323
|
+
const hasPrefix = isMulti || hasIcon || hasAvatar
|
|
324
|
+
|
|
325
|
+
return (
|
|
326
|
+
<div className="flex flex-col gap-6">
|
|
327
|
+
{/* Controls */}
|
|
328
|
+
<div className="flex flex-col gap-2.5">
|
|
329
|
+
<div className="flex items-center gap-2">
|
|
330
|
+
<span className="text-[11px] text-fg-muted w-20 shrink-0">Size</span>
|
|
331
|
+
<div className="flex gap-1.5">
|
|
332
|
+
{SIZES.map((sz) => <Tab key={sz} active={size === sz} onClick={() => setSize(sz)}>{sz}</Tab>)}
|
|
333
|
+
</div>
|
|
334
|
+
</div>
|
|
335
|
+
<div className="flex items-center gap-2">
|
|
336
|
+
<span className="text-[11px] text-fg-muted w-20 shrink-0">Mode</span>
|
|
337
|
+
<div className="flex gap-1.5">
|
|
338
|
+
<Tab active={mode === 'single'} onClick={() => setMode('single')}>single</Tab>
|
|
339
|
+
<Tab active={mode === 'multi'} onClick={() => setMode('multi')}>multi</Tab>
|
|
340
|
+
</div>
|
|
341
|
+
</div>
|
|
342
|
+
<div className="flex items-center gap-2">
|
|
343
|
+
<span className="text-[11px] text-fg-muted w-20 shrink-0">selected</span>
|
|
344
|
+
<div className="flex gap-1.5">
|
|
345
|
+
<Tab active={!selected} onClick={() => setSelected(false)}>off</Tab>
|
|
346
|
+
<Tab active={selected} onClick={() => setSelected(true)}>on</Tab>
|
|
347
|
+
</div>
|
|
348
|
+
</div>
|
|
349
|
+
<div className="flex items-center gap-2">
|
|
350
|
+
<span className="text-[11px] text-fg-muted w-20 shrink-0">disabled</span>
|
|
351
|
+
<div className="flex gap-1.5">
|
|
352
|
+
<Tab active={!disabled} onClick={() => setDisabled(false)}>off</Tab>
|
|
353
|
+
<Tab active={disabled} onClick={() => setDisabled(true)}>on</Tab>
|
|
354
|
+
</div>
|
|
355
|
+
</div>
|
|
356
|
+
<div className="flex items-center gap-2">
|
|
357
|
+
<span className="text-[11px] text-fg-muted w-20 shrink-0">startIcon</span>
|
|
358
|
+
<div className="flex gap-1.5">
|
|
359
|
+
<Tab active={!hasIcon} onClick={() => setHasIcon(false)}>off</Tab>
|
|
360
|
+
<Tab active={hasIcon} onClick={() => setHasIcon(true)} disabled={hasAvatar}>on</Tab>
|
|
361
|
+
</div>
|
|
362
|
+
</div>
|
|
363
|
+
<div className="flex items-center gap-2">
|
|
364
|
+
<span className="text-[11px] text-fg-muted w-20 shrink-0">avatar</span>
|
|
365
|
+
<div className="flex gap-1.5">
|
|
366
|
+
<Tab active={!hasAvatar} onClick={() => setHasAvatar(false)}>off</Tab>
|
|
367
|
+
<Tab active={hasAvatar} onClick={() => setHasAvatar(true)} disabled={hasIcon}>on</Tab>
|
|
368
|
+
</div>
|
|
369
|
+
</div>
|
|
370
|
+
<div className="flex items-center gap-2">
|
|
371
|
+
<span className="text-[11px] text-fg-muted w-20 shrink-0">description</span>
|
|
372
|
+
<div className="flex gap-1.5">
|
|
373
|
+
<Tab active={!hasDesc} onClick={() => setHasDesc(false)}>off</Tab>
|
|
374
|
+
<Tab active={hasDesc} onClick={() => setHasDesc(true)}>on</Tab>
|
|
375
|
+
</div>
|
|
376
|
+
</div>
|
|
377
|
+
<div className="flex items-center gap-2">
|
|
378
|
+
<span className="text-[11px] text-fg-muted w-20 shrink-0">tag</span>
|
|
379
|
+
<div className="flex gap-1.5">
|
|
380
|
+
<Tab active={!hasTag} onClick={() => setHasTag(false)}>off</Tab>
|
|
381
|
+
<Tab active={hasTag} onClick={() => setHasTag(true)}>on</Tab>
|
|
382
|
+
</div>
|
|
383
|
+
</div>
|
|
384
|
+
</div>
|
|
385
|
+
|
|
386
|
+
{/* Preview + Panel */}
|
|
387
|
+
<div className="flex gap-6 items-start">
|
|
388
|
+
{/* Left: preview + blueprint */}
|
|
389
|
+
<div className="flex flex-col gap-5 min-w-[360px]">
|
|
390
|
+
<div className="px-4 py-6 rounded-lg bg-canvas border border-divider flex items-center justify-center">
|
|
391
|
+
<MenuContainer width={340}>
|
|
392
|
+
<MenuGroup>
|
|
393
|
+
<MenuItem
|
|
394
|
+
size={size}
|
|
395
|
+
startIcon={hasIcon ? Mail : undefined}
|
|
396
|
+
avatar={hasAvatar ? { alt: "Alice", color: "indigo" as const } : undefined}
|
|
397
|
+
description={hasDesc ? '每日摘要信件到信箱' : undefined}
|
|
398
|
+
checkbox={isMulti}
|
|
399
|
+
checked={isMulti ? selected : undefined}
|
|
400
|
+
selected={!isMulti ? selected : undefined}
|
|
401
|
+
disabled={disabled}
|
|
402
|
+
tag={hasTag ? <Tag size={size} color="neutral">標籤</Tag> : undefined}
|
|
403
|
+
>
|
|
404
|
+
電子郵件通知
|
|
405
|
+
</MenuItem>
|
|
406
|
+
</MenuGroup>
|
|
407
|
+
</MenuContainer>
|
|
408
|
+
</div>
|
|
409
|
+
|
|
410
|
+
{/* 2D Blueprint */}
|
|
411
|
+
<div className="flex flex-col gap-2">
|
|
412
|
+
{/* Legend */}
|
|
413
|
+
<div className="flex items-center gap-4 text-[10px] flex-wrap">
|
|
414
|
+
{[
|
|
415
|
+
{ c: Z.pad, l: '內距' },
|
|
416
|
+
...(hasPrefix ? [{ c: Z.prefix, l: 'Prefix' }] : []),
|
|
417
|
+
{ c: Z.gap, l: '間距' },
|
|
418
|
+
{ c: Z.content, l: 'Content' },
|
|
419
|
+
...(hasTag ? [{ c: Z.suffix, l: 'Suffix' }] : []),
|
|
420
|
+
].map(({ c, l }) => (
|
|
421
|
+
<span key={l} className="inline-flex items-center gap-1">
|
|
422
|
+
<span className="w-2.5 h-2.5 rounded-md" style={{ background: c.bg, border: `1px dashed ${c.border}` }} />
|
|
423
|
+
<span className="font-medium" style={{ color: c.text }}>{l}</span>
|
|
424
|
+
</span>
|
|
425
|
+
))}
|
|
426
|
+
</div>
|
|
427
|
+
|
|
428
|
+
{/* Blueprint rows: top padding → content row → bottom padding */}
|
|
429
|
+
<div className="flex items-start gap-0">
|
|
430
|
+
<div className="flex flex-col rounded-md overflow-hidden" style={{ outline: `2px solid ${Z.dim.text}22` }}>
|
|
431
|
+
{/* Top padding-y */}
|
|
432
|
+
<BpZoneV h={20} color={Z.pad} label="padding-y" sub={s.py} />
|
|
433
|
+
{/* Horizontal content row */}
|
|
434
|
+
<div className="flex items-center" style={{ height: 44 }}>
|
|
435
|
+
{/* Left padding-x */}
|
|
436
|
+
<BpZoneH w={40} color={Z.pad} label="px-3" sub="12px" />
|
|
437
|
+
{/* Prefix */}
|
|
438
|
+
{hasPrefix && (
|
|
439
|
+
<>
|
|
440
|
+
<BpZoneH w={isMulti ? 50 : 44} color={Z.prefix}
|
|
441
|
+
label={isMulti && hasIcon ? 'CB+Icon' : isMulti ? 'Checkbox' : hasIcon ? `${s.icon}px` : hasAvatar ? `${avatarPx}px` : '—'}
|
|
442
|
+
sub={isMulti && hasIcon ? `${s.checkbox}+${s.icon}px` : isMulti ? s.checkbox : hasIcon ? 'icon' : hasAvatar ? 'avatar' : ''} />
|
|
443
|
+
<BpZoneH w={28} color={Z.gap} label="gap-2" sub="8px" />
|
|
444
|
+
</>
|
|
445
|
+
)}
|
|
446
|
+
{/* Content */}
|
|
447
|
+
<BpZoneH w={hasDesc ? 80 : 64} color={Z.content}
|
|
448
|
+
label={hasDesc ? 'Label+Desc' : 'Label'}
|
|
449
|
+
sub={s.labelFont} />
|
|
450
|
+
{/* Suffix */}
|
|
451
|
+
{hasTag && (
|
|
452
|
+
<>
|
|
453
|
+
<BpZoneH w={28} color={Z.gap} label="gap-2" sub="8px" />
|
|
454
|
+
<BpZoneH w={36} color={Z.suffix} label="Tag" sub="suffix" />
|
|
455
|
+
</>
|
|
456
|
+
)}
|
|
457
|
+
{/* Right padding-x */}
|
|
458
|
+
<BpZoneH w={40} color={Z.pad} label="px-3" sub="12px" />
|
|
459
|
+
</div>
|
|
460
|
+
{/* Bottom padding-y */}
|
|
461
|
+
<BpZoneV h={20} color={Z.pad} label="padding-y" sub={s.py} />
|
|
462
|
+
</div>
|
|
463
|
+
|
|
464
|
+
{/* Height dimension line */}
|
|
465
|
+
<div className="ml-3 flex items-center" style={{ height: 84 }}>
|
|
466
|
+
<svg width="10" height="84" className="shrink-0">
|
|
467
|
+
<line x1="5" y1="2" x2="5" y2="82" stroke={Z.dim.text} strokeWidth="1" />
|
|
468
|
+
<line x1="1" y1="2" x2="9" y2="2" stroke={Z.dim.text} strokeWidth="1.5" />
|
|
469
|
+
<line x1="1" y1="82" x2="9" y2="82" stroke={Z.dim.text} strokeWidth="1.5" />
|
|
470
|
+
</svg>
|
|
471
|
+
<div className="ml-1.5"><TkVal token={s.heightToken} /></div>
|
|
472
|
+
</div>
|
|
473
|
+
</div>
|
|
474
|
+
<p className="text-[10px] text-fg-muted">寬度為示意比例,實際由內容決定</p>
|
|
475
|
+
</div>
|
|
476
|
+
</div>
|
|
477
|
+
|
|
478
|
+
{/* Right: inspect panel */}
|
|
479
|
+
<div className="w-[300px] shrink-0 border border-divider rounded-lg bg-surface overflow-hidden">
|
|
480
|
+
<div className="px-4 py-2.5 border-b border-divider bg-neutral-hover">
|
|
481
|
+
<span className="text-[12px] font-semibold text-foreground">Inspect</span>
|
|
482
|
+
</div>
|
|
483
|
+
|
|
484
|
+
{/* COLOR */}
|
|
485
|
+
<div className="px-4 py-1">
|
|
486
|
+
<div className="py-2 border-b border-divider"><span className="text-[10px] font-semibold text-fg-muted uppercase tracking-wider">Color</span></div>
|
|
487
|
+
<PropRow label="Background"><TokenValue value={colors.bg} /></PropRow>
|
|
488
|
+
<PropRow label="Label"><TokenValue value={colors.text} /></PropRow>
|
|
489
|
+
<PropRow label="Prefix icon"><TokenValue value={colors.icon} /></PropRow>
|
|
490
|
+
{hasDesc && <PropRow label="Description"><TokenValue value={colors.desc} /></PropRow>}
|
|
491
|
+
</div>
|
|
492
|
+
|
|
493
|
+
{/* LAYOUT */}
|
|
494
|
+
<div className="px-4 py-1">
|
|
495
|
+
<div className="py-2 border-b border-divider"><span className="text-[10px] font-semibold text-fg-muted uppercase tracking-wider">Layout</span></div>
|
|
496
|
+
<PropRow label="單行高度"><TkVal token={s.heightToken} /></PropRow>
|
|
497
|
+
<PropRow label="padding-y"><TkVal token={s.py} /></PropRow>
|
|
498
|
+
<PropRow label="padding-x"><TkVal token="px-3" value="12px" /></PropRow>
|
|
499
|
+
<PropRow label="元素間距"><TkVal token="gap-2" value="8px" /></PropRow>
|
|
500
|
+
<PropRow label="Prefix align">
|
|
501
|
+
{prefixAlign === 'inline'
|
|
502
|
+
? <TkVal token="一行文字高度" value="對齊第一行 label" />
|
|
503
|
+
: <TkVal token="label行高 + 2px + desc行高" value="對齊文字塊中心" />
|
|
504
|
+
}
|
|
505
|
+
</PropRow>
|
|
506
|
+
{hasIcon && <PropRow label="Icon">{s.icon}px</PropRow>}
|
|
507
|
+
{hasAvatar && <PropRow label="Avatar">{avatarPx}px ({prefixAlign})</PropRow>}
|
|
508
|
+
{isMulti && <PropRow label="Checkbox">{s.checkbox}</PropRow>}
|
|
509
|
+
</div>
|
|
510
|
+
|
|
511
|
+
{/* TYPOGRAPHY */}
|
|
512
|
+
<div className="px-4 py-1">
|
|
513
|
+
<div className="py-2 border-b border-divider"><span className="text-[10px] font-semibold text-fg-muted uppercase tracking-wider">Typography</span></div>
|
|
514
|
+
<PropRow label="Label"><TkVal token={s.labelFont} value={s.labelSize} /></PropRow>
|
|
515
|
+
{hasDesc && <PropRow label="Description"><TkVal token={s.descFont} value={s.descSize} /></PropRow>}
|
|
516
|
+
{hasDesc && <PropRow label="Label-Desc 間距"><TkVal token={size === 'lg' ? '--item-gap-label-desc-scanning-lg' : '--item-gap-label-desc-scanning'} value="2px" /></PropRow>}
|
|
517
|
+
</div>
|
|
518
|
+
|
|
519
|
+
{/* SELECTION */}
|
|
520
|
+
<div className="px-4 py-1 pb-3">
|
|
521
|
+
<div className="py-2 border-b border-divider"><span className="text-[10px] font-semibold text-fg-muted uppercase tracking-wider">Selection</span></div>
|
|
522
|
+
<PropRow label="模式">{isMulti ? 'Checkbox 勾選' : 'bg-neutral-selected 背景'}</PropRow>
|
|
523
|
+
<PropRow label="選後行為">{isMulti ? '不關閉浮層' : '關閉浮層'}</PropRow>
|
|
524
|
+
</div>
|
|
525
|
+
</div>
|
|
526
|
+
</div>
|
|
527
|
+
</div>
|
|
528
|
+
)
|
|
529
|
+
}
|
|
530
|
+
|
|
531
|
+
export const Inspector = {
|
|
532
|
+
name: '元件檢閱器',
|
|
533
|
+
render: () => (
|
|
534
|
+
<div className="flex flex-col gap-4">
|
|
535
|
+
<div className="flex flex-col gap-1">
|
|
536
|
+
<H3>元件檢閱器</H3>
|
|
537
|
+
<Desc>選擇任意組合,即時查看所有 token。開發只需確認 token 正確——theme / density 的值解析由系統處理。</Desc>
|
|
538
|
+
</div>
|
|
539
|
+
<InspectorInner />
|
|
540
|
+
</div>
|
|
541
|
+
),
|
|
542
|
+
}
|
|
543
|
+
|
|
544
|
+
/* ═══════════════════════════════════════════════════════════════════════════
|
|
545
|
+
3. 色彩對照表
|
|
546
|
+
═══════════════════════════════════════════════════════════════════════════ */
|
|
547
|
+
|
|
548
|
+
export const ColorMatrix = {
|
|
549
|
+
name: '色彩對照表',
|
|
550
|
+
render: () => (
|
|
551
|
+
<div className="flex flex-col gap-8">
|
|
552
|
+
<div className="flex flex-col gap-1">
|
|
553
|
+
<H3>State 色彩對照</H3>
|
|
554
|
+
<Desc>單選用 bg-neutral-selected 背景指示選中,多選用 Checkbox 勾選——背景不變。disabled 時所有元素統一 fg-disabled。色塊即時渲染,切 dark mode 自動更新。</Desc>
|
|
555
|
+
</div>
|
|
556
|
+
|
|
557
|
+
{/* Single-select */}
|
|
558
|
+
<div className="flex flex-col gap-3">
|
|
559
|
+
<span className="text-caption font-medium text-fg-secondary">單選(selected = bg-neutral-selected)</span>
|
|
560
|
+
<div className="overflow-x-auto">
|
|
561
|
+
<table className="border-collapse">
|
|
562
|
+
<thead><tr><Th>State</Th><Th>預覽</Th><Th>Token</Th></tr></thead>
|
|
563
|
+
<tbody>
|
|
564
|
+
{STATES.map((st) => (
|
|
565
|
+
<tr key={st}>
|
|
566
|
+
<Td mono>{st}</Td>
|
|
567
|
+
<td className="p-3 border-b border-divider align-top min-w-[280px]">
|
|
568
|
+
<MenuContainer width={260}>
|
|
569
|
+
<MenuGroup>
|
|
570
|
+
<MenuItem
|
|
571
|
+
size="md"
|
|
572
|
+
startIcon={Mail}
|
|
573
|
+
selected={st === 'selected'}
|
|
574
|
+
disabled={st === 'disabled'}
|
|
575
|
+
description="摘要通知"
|
|
576
|
+
>
|
|
577
|
+
電子郵件
|
|
578
|
+
</MenuItem>
|
|
579
|
+
</MenuGroup>
|
|
580
|
+
</MenuContainer>
|
|
581
|
+
</td>
|
|
582
|
+
<td className="p-3 border-b border-divider align-top min-w-[200px]">
|
|
583
|
+
<TokenAnnotation colors={SINGLE_TOKEN_MAP[st]} />
|
|
584
|
+
</td>
|
|
585
|
+
</tr>
|
|
586
|
+
))}
|
|
587
|
+
</tbody>
|
|
588
|
+
</table>
|
|
589
|
+
</div>
|
|
590
|
+
</div>
|
|
591
|
+
|
|
592
|
+
{/* Multi-select */}
|
|
593
|
+
<div className="flex flex-col gap-3">
|
|
594
|
+
<span className="text-caption font-medium text-fg-secondary">多選(selected = checkbox 勾選,背景不變)</span>
|
|
595
|
+
<div className="overflow-x-auto">
|
|
596
|
+
<table className="border-collapse">
|
|
597
|
+
<thead><tr><Th>State</Th><Th>預覽</Th><Th>Token</Th></tr></thead>
|
|
598
|
+
<tbody>
|
|
599
|
+
{STATES.map((st) => (
|
|
600
|
+
<tr key={st}>
|
|
601
|
+
<Td mono>{st}</Td>
|
|
602
|
+
<td className="p-3 border-b border-divider align-top min-w-[280px]">
|
|
603
|
+
<MenuContainer width={260}>
|
|
604
|
+
<MenuGroup>
|
|
605
|
+
<MenuItem
|
|
606
|
+
size="md"
|
|
607
|
+
startIcon={Mail}
|
|
608
|
+
checkbox
|
|
609
|
+
checked={st === 'selected'}
|
|
610
|
+
disabled={st === 'disabled'}
|
|
611
|
+
description="摘要通知"
|
|
612
|
+
>
|
|
613
|
+
電子郵件
|
|
614
|
+
</MenuItem>
|
|
615
|
+
</MenuGroup>
|
|
616
|
+
</MenuContainer>
|
|
617
|
+
</td>
|
|
618
|
+
<td className="p-3 border-b border-divider align-top min-w-[200px]">
|
|
619
|
+
<TokenAnnotation colors={MULTI_TOKEN_MAP[st]} />
|
|
620
|
+
</td>
|
|
621
|
+
</tr>
|
|
622
|
+
))}
|
|
623
|
+
</tbody>
|
|
624
|
+
</table>
|
|
625
|
+
</div>
|
|
626
|
+
</div>
|
|
627
|
+
|
|
628
|
+
{/* Header */}
|
|
629
|
+
<div className="flex flex-col gap-3">
|
|
630
|
+
<span className="text-caption font-medium text-fg-secondary">Header(群組標題)</span>
|
|
631
|
+
<div className="flex items-start gap-4">
|
|
632
|
+
<MenuContainer width={260}>
|
|
633
|
+
<MenuGroup>
|
|
634
|
+
<MenuItem size="md" header>群組標題</MenuItem>
|
|
635
|
+
<MenuItem size="md" startIcon={FileText}>一般選項</MenuItem>
|
|
636
|
+
</MenuGroup>
|
|
637
|
+
</MenuContainer>
|
|
638
|
+
<div className="flex flex-col gap-0.5">
|
|
639
|
+
<span className="inline-flex items-center gap-1 text-[10px]">
|
|
640
|
+
<span className="text-fg-muted w-7 shrink-0">text</span>
|
|
641
|
+
<span className="font-mono text-fg-secondary">--fg-muted + font-medium</span>
|
|
642
|
+
</span>
|
|
643
|
+
<span className="inline-flex items-center gap-1 text-[10px]">
|
|
644
|
+
<span className="text-fg-muted w-7 shrink-0">互動</span>
|
|
645
|
+
<span className="font-mono text-fg-secondary">pointer-events-none</span>
|
|
646
|
+
</span>
|
|
647
|
+
</div>
|
|
648
|
+
</div>
|
|
649
|
+
</div>
|
|
650
|
+
</div>
|
|
651
|
+
),
|
|
652
|
+
}
|
|
653
|
+
|
|
654
|
+
/* ═══════════════════════════════════════════════════════════════════════════
|
|
655
|
+
4. 尺寸對照表
|
|
656
|
+
═══════════════════════════════════════════════════════════════════════════ */
|
|
657
|
+
|
|
658
|
+
export const SizeMatrix = {
|
|
659
|
+
name: '尺寸對照表',
|
|
660
|
+
render: () => (
|
|
661
|
+
<div className="flex flex-col gap-8">
|
|
662
|
+
<div className="flex flex-col gap-1">
|
|
663
|
+
<H3>Size Token 對照</H3>
|
|
664
|
+
<Desc>每個 size 對應的 token 一覽。density 切換由系統自動處理 field-height 值。</Desc>
|
|
665
|
+
</div>
|
|
666
|
+
|
|
667
|
+
{/* Token comparison table */}
|
|
668
|
+
<div className="overflow-x-auto">
|
|
669
|
+
<table className="border-collapse text-caption">
|
|
670
|
+
<thead><tr>
|
|
671
|
+
<Th>屬性</Th>
|
|
672
|
+
{SIZES.map((sz) => <Th key={sz}>{sz}{sz === 'md' ? '(預設)' : ''}</Th>)}
|
|
673
|
+
</tr></thead>
|
|
674
|
+
<tbody>
|
|
675
|
+
<tr>
|
|
676
|
+
<Td>單行高度</Td>
|
|
677
|
+
{SIZES.map((sz) => <Td key={sz} mono><TkVal token={SIZE_SPECS[sz].heightToken} /></Td>)}
|
|
678
|
+
</tr>
|
|
679
|
+
<tr>
|
|
680
|
+
<Td>padding-y</Td>
|
|
681
|
+
{SIZES.map((sz) => <Td key={sz} mono><span className="text-fg-secondary text-[11px]">(field-height − 一行文字高度) / 2</span></Td>)}
|
|
682
|
+
</tr>
|
|
683
|
+
<tr>
|
|
684
|
+
<Td>padding-x</Td>
|
|
685
|
+
{SIZES.map(() => <Td mono><TkVal token="px-3" value="12px" /></Td>)}
|
|
686
|
+
</tr>
|
|
687
|
+
<tr>
|
|
688
|
+
<Td>Label 字體</Td>
|
|
689
|
+
{SIZES.map((sz) => <Td key={sz} mono><TkVal token={SIZE_SPECS[sz].labelFont} value={SIZE_SPECS[sz].labelSize} /></Td>)}
|
|
690
|
+
</tr>
|
|
691
|
+
<tr>
|
|
692
|
+
<Td>Description 字體</Td>
|
|
693
|
+
{SIZES.map((sz) => <Td key={sz} mono><TkVal token={SIZE_SPECS[sz].descFont} value={SIZE_SPECS[sz].descSize} /></Td>)}
|
|
694
|
+
</tr>
|
|
695
|
+
<tr>
|
|
696
|
+
<Td>Icon</Td>
|
|
697
|
+
{SIZES.map((sz) => <Td key={sz} mono>{SIZE_SPECS[sz].icon}px</Td>)}
|
|
698
|
+
</tr>
|
|
699
|
+
<tr>
|
|
700
|
+
<Td>Checkbox</Td>
|
|
701
|
+
{SIZES.map((sz) => <Td key={sz} mono>{SIZE_SPECS[sz].checkbox}</Td>)}
|
|
702
|
+
</tr>
|
|
703
|
+
</tbody>
|
|
704
|
+
</table>
|
|
705
|
+
</div>
|
|
706
|
+
|
|
707
|
+
{/* Avatar sizing */}
|
|
708
|
+
<div className="flex flex-col gap-3">
|
|
709
|
+
<H3>Avatar 尺寸——24px 閾值</H3>
|
|
710
|
+
<Desc>
|
|
711
|
+
avatar 尺寸由 description 決定。無 description 時使用 inline 尺寸(對齊 Tag 高度,≤ 24px),有 description 時使用 block 尺寸(floor8(label行高 + 2px + desc行高),> 24px)。24px 是物理限制——16px icon 在 24px 圓內可辨識,更小則不行。
|
|
712
|
+
</Desc>
|
|
713
|
+
<div className="overflow-x-auto">
|
|
714
|
+
<table className="border-collapse text-caption">
|
|
715
|
+
<thead><tr>
|
|
716
|
+
<Th>Avatar 模式</Th>
|
|
717
|
+
{SIZES.map((sz) => <Th key={sz}>{sz}</Th>)}
|
|
718
|
+
<Th>Prefix 對齊</Th>
|
|
719
|
+
</tr></thead>
|
|
720
|
+
<tbody>
|
|
721
|
+
<tr>
|
|
722
|
+
<Td>inline(無 description)</Td>
|
|
723
|
+
{SIZES.map((sz) => <Td key={sz} mono>{SIZE_SPECS[sz].avatarInline}px</Td>)}
|
|
724
|
+
<Td mono>一行文字高度</Td>
|
|
725
|
+
</tr>
|
|
726
|
+
<tr>
|
|
727
|
+
<Td>block(有 description)</Td>
|
|
728
|
+
{SIZES.map((sz) => <Td key={sz} mono>{SIZE_SPECS[sz].avatarBlock}px</Td>)}
|
|
729
|
+
<Td mono>label行高 + 2px + desc行高</Td>
|
|
730
|
+
</tr>
|
|
731
|
+
</tbody>
|
|
732
|
+
</table>
|
|
733
|
+
</div>
|
|
734
|
+
</div>
|
|
735
|
+
|
|
736
|
+
{/* Visual preview per size */}
|
|
737
|
+
<div className="flex flex-col gap-4">
|
|
738
|
+
<span className="text-caption font-medium text-fg-secondary">預覽</span>
|
|
739
|
+
<div className="flex flex-col gap-6">
|
|
740
|
+
{SIZES.map((sz) => (
|
|
741
|
+
<div key={sz} className="flex flex-col gap-1">
|
|
742
|
+
<span className="text-caption text-fg-muted font-mono">{sz}{sz === 'md' ? '(預設)' : ''}</span>
|
|
743
|
+
<MenuContainer width={380}>
|
|
744
|
+
<MenuGroup>
|
|
745
|
+
<MenuItem size={sz} startIcon={Mail} description="每日摘要信件">
|
|
746
|
+
電子郵件通知
|
|
747
|
+
</MenuItem>
|
|
748
|
+
<MenuItem size={sz} avatar={{ alt: "Alice", color: "indigo" as const }}>
|
|
749
|
+
Alice Chen
|
|
750
|
+
</MenuItem>
|
|
751
|
+
<MenuItem size={sz} avatar={{ alt: "Bob", color: "magenta" as const }} description="工程部門">
|
|
752
|
+
Bob Wang
|
|
753
|
+
</MenuItem>
|
|
754
|
+
<MenuItem size={sz} checkbox checked={true} startIcon={Bell}>
|
|
755
|
+
推播通知
|
|
756
|
+
</MenuItem>
|
|
757
|
+
<MenuItem size={sz} tag={<Tag size={sz} color="neutral">Admin</Tag>}>
|
|
758
|
+
權限標記
|
|
759
|
+
</MenuItem>
|
|
760
|
+
</MenuGroup>
|
|
761
|
+
</MenuContainer>
|
|
762
|
+
</div>
|
|
763
|
+
))}
|
|
764
|
+
</div>
|
|
765
|
+
</div>
|
|
766
|
+
</div>
|
|
767
|
+
),
|
|
768
|
+
}
|
|
769
|
+
|
|
770
|
+
// ── Accessibility ─────────────────────────────────────────────────────────
|
|
771
|
+
// 2026-05-17 ship per audit Dim 13(story-rules.md 6-canonical 含 Accessibility)
|
|
772
|
+
export const Accessibility = {
|
|
773
|
+
name: '無障礙',
|
|
774
|
+
render: () => (
|
|
775
|
+
<div className="max-w-3xl text-body text-fg-secondary">
|
|
776
|
+
<h3 className="text-h5 text-foreground mb-2">無障礙設計</h3>
|
|
777
|
+
<p className="whitespace-pre-line">{"MenuItem 只負責單行的視覺排版,本身不接管鍵盤與焦點。真正的鍵盤導覽(上下鍵切換、Enter 選取、Esc 關閉)與焦點管理由外層的選單元件(SelectMenu / DropdownMenu)負責——MenuItem 不重複實作這些行為。\n\n 語意 role :在 listbox 語境(SelectMenu / Combobox)MenuItem 預設渲染為 role=\"option\";在 menu 語境(DropdownMenu)外層會把每個 item 覆蓋為 role=\"presentation\",由 Radix parent 持有 role=\"menuitem\" 語意。哪一項目前被聚焦與選取由外層選單決定。\n\n 焦點外觀 :聚焦時以 bg-neutral-hover 背景高亮標示被聚焦的選項(cva base 為 outline-none + focus-visible:bg-neutral-hover),對齊 menu/listbox option 的 active-highlight 慣例,而非畫 outline ring。\n\n 驗證 :Storybook a11y addon 面板應 0 critical violation;整個選單用鍵盤即可完整操作(無需滑鼠);文字對比 ≥ 4.5:1、介面元素對比 ≥ 3:1(WCAG AA)。"}</p>
|
|
778
|
+
</div>
|
|
779
|
+
),
|
|
780
|
+
}
|