@getmicdrop/svelte-components 5.21.0 → 5.21.2
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/dist/calendar/AboutShow/AboutShow.spec.js +10 -10
- package/dist/calendar/AboutShow/AboutShow.svelte +191 -191
- package/dist/calendar/Calendar/MiniMonthCalendar.spec.js +9 -8
- package/dist/calendar/Calendar/MiniMonthCalendar.svelte +800 -803
- package/dist/calendar/Calendar/MiniMonthCalendar.svelte.d.ts.map +1 -1
- package/dist/calendar/FAQs/FAQs.spec.js +6 -6
- package/dist/calendar/FAQs/FAQs.svelte +88 -88
- package/dist/calendar/MonthSwitcher/MonthSwitcher.svelte +136 -140
- package/dist/calendar/OrderSummary/OrderSummary.svelte +461 -461
- package/dist/calendar/PublicCard/PublicCard.spec.js +3 -3
- package/dist/calendar/PublicCard/PublicCard.svelte +164 -164
- package/dist/calendar/ShowCard/ShowCard.spec.js +8 -8
- package/dist/calendar/ShowCard/ShowCard.svelte +180 -180
- package/dist/calendar/ShowTimeCard/ShowTimeCard.spec.js +4 -4
- package/dist/calendar/ShowTimeCard/ShowTimeCard.svelte +80 -80
- package/dist/calendar/index.js +15 -15
- package/dist/components/Heading.spec.js +89 -89
- package/dist/components/Heading.svelte +66 -66
- package/dist/components/Layout/AppShell.svelte +104 -104
- package/dist/components/Layout/ContentSection.svelte +80 -80
- package/dist/components/Layout/Grid.svelte +101 -101
- package/dist/components/Layout/Heading.svelte +81 -81
- package/dist/components/Layout/PageContainer.svelte +69 -69
- package/dist/components/Layout/Responsive.svelte +75 -75
- package/dist/components/Layout/Section.spec.js +4 -4
- package/dist/components/Layout/Section.svelte +80 -80
- package/dist/components/Layout/ShowOnDesktop.svelte +37 -37
- package/dist/components/Layout/ShowOnMobile.svelte +37 -37
- package/dist/components/Layout/Sidebar.svelte +108 -108
- package/dist/components/Layout/Stack.spec.js +1 -1
- package/dist/components/Layout/Stack.svelte +52 -52
- package/dist/components/Layout/Text.svelte +87 -87
- package/dist/components/Layout/TwoColumn.svelte +108 -108
- package/dist/components/Layout/__tests__/AppShell.test.js +5 -5
- package/dist/components/Layout/__tests__/ContentSection.test.js +1 -1
- package/dist/components/Layout/__tests__/Heading.test.js +3 -3
- package/dist/components/Layout/__tests__/PageContainer.test.js +4 -4
- package/dist/components/Layout/__tests__/Text.test.js +9 -9
- package/dist/components/Text.spec.js +89 -89
- package/dist/components/Text.svelte +64 -64
- package/dist/config.js +160 -160
- package/dist/config.spec.js +29 -29
- package/dist/constants/formOptions.js +48 -48
- package/dist/constants/validation.js +91 -91
- package/dist/constants/validation.spec.js +64 -64
- package/dist/datetime/README.md +323 -323
- package/dist/datetime/__tests__/format.test.js +1 -1
- package/dist/datetime/__tests__/parse.test.js +1 -1
- package/dist/datetime/__tests__/timezone.test.js +1 -1
- package/dist/datetime/parse.js +1 -1
- package/dist/forms/createFormStore.svelte.js +1 -0
- package/dist/forms/createFormStore.svelte.spec.js +1 -0
- package/dist/index.js +85 -85
- package/dist/index.spec.js +369 -369
- package/dist/patterns/chat/ChatActivityNotice.spec.js +59 -59
- package/dist/patterns/chat/ChatActivityNotice.svelte +41 -41
- package/dist/patterns/chat/ChatBubble.spec.js +91 -91
- package/dist/patterns/chat/ChatBubble.svelte +103 -103
- package/dist/patterns/chat/ChatContainer.spec.js +30 -30
- package/dist/patterns/chat/ChatContainer.svelte +46 -46
- package/dist/patterns/chat/ChatDateDivider.spec.js +30 -30
- package/dist/patterns/chat/ChatDateDivider.svelte +27 -27
- package/dist/patterns/chat/ChatInvitationBubble.spec.js +46 -46
- package/dist/patterns/chat/ChatInvitationBubble.svelte +46 -46
- package/dist/patterns/chat/ChatInvitationNotice.spec.js +32 -32
- package/dist/patterns/chat/ChatInvitationNotice.svelte +36 -36
- package/dist/patterns/chat/ChatMessageGroup.spec.js +58 -58
- package/dist/patterns/chat/ChatMessageGroup.svelte +57 -57
- package/dist/patterns/chat/ChatSlotUpdate.spec.js +65 -65
- package/dist/patterns/chat/ChatSlotUpdate.svelte +46 -46
- package/dist/patterns/chat/ChatStatusBadge.spec.js +79 -79
- package/dist/patterns/chat/ChatStatusBadge.svelte +91 -91
- package/dist/patterns/chat/ChatStatusTransition.spec.js +81 -81
- package/dist/patterns/chat/ChatStatusTransition.svelte +64 -64
- package/dist/patterns/chat/ChatTextBubble.spec.js +35 -35
- package/dist/patterns/chat/ChatTextBubble.svelte +41 -41
- package/dist/patterns/chat/index.js +22 -22
- package/dist/patterns/data/DataGrid.svelte +45 -45
- package/dist/patterns/data/DataList.spec.js +5 -5
- package/dist/patterns/data/DataList.svelte +24 -24
- package/dist/patterns/data/DataTable.spec.js +18 -18
- package/dist/patterns/data/DataTable.svelte +45 -45
- package/dist/patterns/data/index.js +4 -4
- package/dist/patterns/forms/FormActions.spec.js +95 -95
- package/dist/patterns/forms/FormActions.stories.svelte +97 -97
- package/dist/patterns/forms/FormActions.svelte +46 -46
- package/dist/patterns/forms/FormGrid.svelte +33 -33
- package/dist/patterns/forms/FormSection.spec.js +4 -4
- package/dist/patterns/forms/FormSection.svelte +33 -33
- package/dist/patterns/forms/FormValidationSummary.spec.js +2 -2
- package/dist/patterns/forms/FormValidationSummary.stories.svelte +97 -97
- package/dist/patterns/forms/FormValidationSummary.svelte +82 -82
- package/dist/patterns/forms/index.js +5 -5
- package/dist/patterns/index.js +21 -21
- package/dist/patterns/layout/Sidebar.svelte +39 -39
- package/dist/patterns/layout/SidebarTestWrapper.svelte +34 -34
- package/dist/patterns/layout/Stack.svelte +61 -61
- package/dist/patterns/layout/index.js +29 -29
- package/dist/patterns/navigation/BottomNav.stories.svelte +117 -117
- package/dist/patterns/navigation/BottomNav.svelte +82 -82
- package/dist/patterns/navigation/Header.spec.js +9 -9
- package/dist/patterns/navigation/Header.stories.svelte +77 -77
- package/dist/patterns/navigation/Header.svelte +261 -263
- package/dist/patterns/navigation/Header.svelte.d.ts.map +1 -1
- package/dist/patterns/navigation/index.js +3 -3
- package/dist/patterns/page/PageHeader.svelte +49 -49
- package/dist/patterns/page/PageLayout.spec.js +5 -5
- package/dist/patterns/page/PageLayout.svelte +40 -40
- package/dist/patterns/page/PageLoader.spec.js +57 -57
- package/dist/patterns/page/PageLoader.stories.svelte +137 -137
- package/dist/patterns/page/PageLoader.svelte +62 -62
- package/dist/patterns/page/SectionHeader.spec.js +8 -8
- package/dist/patterns/page/SectionHeader.svelte +51 -51
- package/dist/patterns/page/index.js +5 -5
- package/dist/presets/badges.js +112 -112
- package/dist/presets/buttons.js +76 -76
- package/dist/presets/buttons.spec.js +4 -4
- package/dist/presets/index.js +9 -9
- package/dist/primitives/Accordion/Accordion.spec.js +5 -5
- package/dist/primitives/Accordion/Accordion.stories.svelte +75 -75
- package/dist/primitives/Accordion/Accordion.svelte +62 -62
- package/dist/primitives/Accordion/AccordionItem.spec.js +19 -28
- package/dist/primitives/Accordion/AccordionItem.svelte +103 -103
- package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte +107 -107
- package/dist/primitives/Accordion/AccordionToggleWrapper.test.svelte +28 -28
- package/dist/primitives/Alert/Alert.spec.js +173 -173
- package/dist/primitives/Alert/Alert.stories.svelte +88 -88
- package/dist/primitives/Alert/Alert.svelte +72 -72
- package/dist/primitives/Avatar/Avatar.spec.js +11 -11
- package/dist/primitives/Avatar/Avatar.stories.svelte +95 -94
- package/dist/primitives/Avatar/Avatar.stories.svelte.d.ts.map +1 -1
- package/dist/primitives/Avatar/Avatar.svelte +66 -66
- package/dist/primitives/AvatarButton/AvatarButton.svelte +57 -57
- package/dist/primitives/Badges/Badge.spec.js +144 -144
- package/dist/primitives/Badges/Badge.stories.svelte +86 -86
- package/dist/primitives/Badges/Badge.svelte +99 -99
- package/dist/primitives/BottomSheet/BottomSheet.spec.js +238 -238
- package/dist/primitives/BottomSheet/BottomSheet.stories.svelte +83 -83
- package/dist/primitives/BottomSheet/BottomSheet.svelte +115 -115
- package/dist/primitives/BottomSheet/BottomSheetWithActions.test.svelte +20 -20
- package/dist/primitives/Breadcrumb/Breadcrumb.spec.js +125 -123
- package/dist/primitives/Breadcrumb/Breadcrumb.stories.svelte +23 -23
- package/dist/primitives/Breadcrumb/Breadcrumb.svelte +107 -107
- package/dist/primitives/Button/Button.spec.js +225 -225
- package/dist/primitives/Button/Button.stories.svelte +76 -76
- package/dist/primitives/Button/Button.svelte +278 -278
- package/dist/primitives/Button/ButtonGroup.spec.js +44 -44
- package/dist/primitives/Button/ButtonGroup.svelte +50 -50
- package/dist/primitives/Button/ButtonSaveDemo.spec.js +146 -146
- package/dist/primitives/Button/ButtonSaveDemo.svelte +25 -25
- package/dist/primitives/Button/ButtonVariantShowcase.spec.js +1 -1
- package/dist/primitives/Button/ButtonVariantShowcase.svelte +129 -129
- package/dist/primitives/Card.spec.js +49 -49
- package/dist/primitives/Card.stories.svelte +22 -22
- package/dist/primitives/Card.svelte +28 -28
- package/dist/primitives/CardAction/CardAction.svelte +68 -68
- package/dist/primitives/Checkbox/Checkbox.spec.js +16 -16
- package/dist/primitives/Checkbox/Checkbox.stories.svelte +84 -84
- package/dist/primitives/Checkbox/Checkbox.svelte +88 -88
- package/dist/primitives/DarkModeToggle.spec.js +390 -390
- package/dist/primitives/DarkModeToggle.stories.svelte +57 -57
- package/dist/primitives/DarkModeToggle.svelte +147 -147
- package/dist/primitives/Drawer/Drawer.spec.js +4 -4
- package/dist/primitives/Drawer/Drawer.stories.svelte +100 -100
- package/dist/primitives/Drawer/Drawer.svelte +224 -224
- package/dist/primitives/Drawer/DrawerTestWrapper.svelte +86 -86
- package/dist/primitives/Dropdown/Dropdown.spec.js +9 -9
- package/dist/primitives/Dropdown/Dropdown.stories.svelte +137 -137
- package/dist/primitives/Dropdown/Dropdown.svelte +179 -179
- package/dist/primitives/Dropdown/DropdownDivider.spec.js +30 -30
- package/dist/primitives/Dropdown/DropdownDivider.svelte +9 -9
- package/dist/primitives/Dropdown/DropdownItem.spec.js +8 -15
- package/dist/primitives/Dropdown/DropdownItem.svelte +80 -80
- package/dist/primitives/Dropdown/DropdownItemTestWrapper.svelte +43 -43
- package/dist/primitives/Helper/Helper.spec.js +57 -57
- package/dist/primitives/Helper/Helper.svelte +33 -33
- package/dist/primitives/Icons/ArrowLeft.svelte +21 -21
- package/dist/primitives/Icons/ArrowRight.svelte +21 -21
- package/dist/primitives/Icons/Availability.svelte +27 -27
- package/dist/primitives/Icons/Back.svelte +27 -27
- package/dist/primitives/Icons/CheckCircle.svelte +19 -19
- package/dist/primitives/Icons/CheckCircleOutline.svelte +28 -28
- package/dist/primitives/Icons/ChevronLeft.svelte +17 -17
- package/dist/primitives/Icons/ChevronRight.svelte +17 -17
- package/dist/primitives/Icons/Copy.svelte +28 -28
- package/dist/primitives/Icons/Cross.svelte +18 -18
- package/dist/primitives/Icons/DownArrow.svelte +21 -21
- package/dist/primitives/Icons/ErrorCircle.svelte +19 -19
- package/dist/primitives/Icons/FacebookIcon.svelte +15 -15
- package/dist/primitives/Icons/Home.svelte +28 -28
- package/dist/primitives/Icons/Icon.spec.js +175 -175
- package/dist/primitives/Icons/Icon.stories.svelte +100 -100
- package/dist/primitives/Icons/Icon.svelte +79 -79
- package/dist/primitives/Icons/IconGallery.stories.svelte +235 -235
- package/dist/primitives/Icons/Icons.spec.js +3 -3
- package/dist/primitives/Icons/ImageOutline.svelte +21 -21
- package/dist/primitives/Icons/Info.svelte +20 -20
- package/dist/primitives/Icons/InstagramIcon.svelte +21 -21
- package/dist/primitives/Icons/LogoInstagram.svelte +15 -15
- package/dist/primitives/Icons/Message.svelte +28 -28
- package/dist/primitives/Icons/MoonIcon.svelte +18 -18
- package/dist/primitives/Icons/More.svelte +34 -34
- package/dist/primitives/Icons/MoreHori.spec.js +67 -67
- package/dist/primitives/Icons/MoreHori.svelte +35 -35
- package/dist/primitives/Icons/Notification.svelte +27 -27
- package/dist/primitives/Icons/Payment.svelte +27 -27
- package/dist/primitives/Icons/Profile.svelte +34 -34
- package/dist/primitives/Icons/Reload.svelte +42 -42
- package/dist/primitives/Icons/Shows.svelte +34 -34
- package/dist/primitives/Icons/Signout.svelte +34 -34
- package/dist/primitives/Icons/SunIcon.svelte +21 -21
- package/dist/primitives/Icons/TiktokIcon.svelte +15 -15
- package/dist/primitives/Icons/TrashBinOutline.svelte +21 -21
- package/dist/primitives/Icons/TwitterIcon.svelte +15 -15
- package/dist/primitives/Icons/WarningIcon.spec.js +30 -30
- package/dist/primitives/Icons/WarningIcon.svelte +24 -24
- package/dist/primitives/Input/Input.spec.js +1237 -1237
- package/dist/primitives/Input/Input.stories.svelte +139 -139
- package/dist/primitives/Input/Input.svelte +444 -444
- package/dist/primitives/Input/Select.spec.js +632 -632
- package/dist/primitives/Input/Select.stories.svelte +112 -112
- package/dist/primitives/Input/Select.svelte +252 -252
- package/dist/primitives/Input/Textarea.spec.js +8 -8
- package/dist/primitives/Input/Textarea.stories.svelte +137 -137
- package/dist/primitives/Input/Textarea.svelte +105 -105
- package/dist/primitives/Label/Label.spec.js +20 -21
- package/dist/primitives/Label/Label.svelte +37 -37
- package/dist/primitives/LandingButton/LandingButton.spec.js +61 -61
- package/dist/primitives/LandingButton/LandingButton.svelte +92 -92
- package/dist/primitives/MenuItem/MenuItem.spec.js +130 -130
- package/dist/primitives/MenuItem/MenuItem.svelte +85 -85
- package/dist/primitives/Modal/Modal.spec.js +314 -314
- package/dist/primitives/Modal/Modal.stories.svelte +86 -86
- package/dist/primitives/Modal/Modal.svelte +181 -181
- package/dist/primitives/NavItem/NavItem.spec.js +97 -97
- package/dist/primitives/NavItem/NavItem.svelte +75 -75
- package/dist/primitives/NumberInput/NumberInput.spec.js +17 -17
- package/dist/primitives/NumberInput/NumberInput.svelte +113 -113
- package/dist/primitives/Pagination/DotIndicator.svelte +66 -66
- package/dist/primitives/Pagination/Pagination.spec.js +6 -6
- package/dist/primitives/Pagination/Pagination.stories.svelte +76 -76
- package/dist/primitives/Pagination/Pagination.svelte +275 -275
- package/dist/primitives/Radio/Radio.spec.js +19 -19
- package/dist/primitives/Radio/Radio.stories.svelte +80 -80
- package/dist/primitives/Radio/Radio.svelte +67 -67
- package/dist/primitives/SearchResultItem/SearchResultItem.spec.js +78 -78
- package/dist/primitives/SearchResultItem/SearchResultItem.svelte +109 -109
- package/dist/primitives/SidebarToggle/SidebarToggle.spec.js +61 -61
- package/dist/primitives/SidebarToggle/SidebarToggle.svelte +55 -55
- package/dist/primitives/Skeleton/CardPlaceholder.spec.js +1 -1
- package/dist/primitives/Skeleton/CardPlaceholder.svelte +96 -96
- package/dist/primitives/Skeleton/ImagePlaceholder.spec.js +2 -2
- package/dist/primitives/Skeleton/ImagePlaceholder.svelte +68 -68
- package/dist/primitives/Skeleton/ListPlaceholder.spec.js +2 -2
- package/dist/primitives/Skeleton/ListPlaceholder.svelte +85 -85
- package/dist/primitives/Skeleton/Skeleton.spec.js +7 -7
- package/dist/primitives/Skeleton/Skeleton.stories.svelte +151 -151
- package/dist/primitives/Skeleton/Skeleton.svelte +55 -55
- package/dist/primitives/Spinner/Spinner.spec.js +83 -84
- package/dist/primitives/Spinner/Spinner.stories.svelte +29 -29
- package/dist/primitives/Spinner/Spinner.svelte +52 -52
- package/dist/primitives/Tabs/TabItem.svelte +52 -52
- package/dist/primitives/Tabs/Tabs.spec.js +14 -14
- package/dist/primitives/Tabs/Tabs.stories.svelte +112 -112
- package/dist/primitives/Tabs/Tabs.svelte +137 -137
- package/dist/primitives/Toggle.spec.js +219 -221
- package/dist/primitives/Toggle.stories.svelte +92 -92
- package/dist/primitives/Toggle.svelte +141 -141
- package/dist/primitives/ToggleTestWrapper.svelte +30 -30
- package/dist/primitives/Tooltip/Tooltip.spec.js +126 -126
- package/dist/primitives/Tooltip/Tooltip.svelte +83 -83
- package/dist/primitives/Typography/Typography.svelte +53 -53
- package/dist/primitives/ValidationError.spec.js +103 -103
- package/dist/primitives/ValidationError.stories.svelte +112 -112
- package/dist/primitives/ValidationError.svelte +29 -29
- package/dist/primitives/index.js +114 -114
- package/dist/recipes/CropImage/CropImage.spec.js +208 -208
- package/dist/recipes/CropImage/CropImage.stories.svelte +104 -104
- package/dist/recipes/CropImage/CropImage.svelte +241 -241
- package/dist/recipes/ImageUploader/ImageUploader.spec.js +1 -1
- package/dist/recipes/ImageUploader/ImageUploader.stories.svelte +125 -125
- package/dist/recipes/ImageUploader/ImageUploader.svelte +972 -994
- package/dist/recipes/SuperLogin/SuperLogin.svelte +24 -24
- package/dist/recipes/Toaster/Toaster.stories.svelte +62 -62
- package/dist/recipes/feedback/EmptyState/EmptyState.svelte +75 -75
- package/dist/recipes/feedback/ErrorDisplay.spec.js +69 -69
- package/dist/recipes/feedback/ErrorDisplay.stories.svelte +113 -113
- package/dist/recipes/feedback/ErrorDisplay.svelte +67 -67
- package/dist/recipes/feedback/StatusIndicator/StatusIndicator.spec.js +133 -133
- package/dist/recipes/feedback/StatusIndicator/StatusIndicator.svelte +176 -176
- package/dist/recipes/feedback/index.js +4 -4
- package/dist/recipes/fields/CheckboxField.spec.js +2 -2
- package/dist/recipes/fields/CheckboxField.svelte +85 -85
- package/dist/recipes/fields/FormField.spec.js +4 -4
- package/dist/recipes/fields/FormField.svelte +58 -58
- package/dist/recipes/fields/RadioGroup.spec.js +1 -1
- package/dist/recipes/fields/RadioGroup.svelte +95 -95
- package/dist/recipes/fields/SelectField.spec.js +2 -2
- package/dist/recipes/fields/SelectField.svelte +82 -82
- package/dist/recipes/fields/TextareaField.spec.js +2 -2
- package/dist/recipes/fields/TextareaField.svelte +101 -101
- package/dist/recipes/fields/ToggleField.spec.js +2 -2
- package/dist/recipes/fields/ToggleField.svelte +60 -60
- package/dist/recipes/fields/index.js +7 -7
- package/dist/recipes/index.js +24 -24
- package/dist/recipes/inputs/MultiSelect.spec.js +263 -263
- package/dist/recipes/inputs/MultiSelect.stories.svelte +133 -133
- package/dist/recipes/inputs/MultiSelect.svelte +291 -291
- package/dist/recipes/inputs/OTPInput.spec.js +251 -251
- package/dist/recipes/inputs/OTPInput.stories.svelte +162 -162
- package/dist/recipes/inputs/OTPInput.svelte +128 -128
- package/dist/recipes/inputs/PasswordInput.spec.js +2 -2
- package/dist/recipes/inputs/PasswordInput.svelte +130 -130
- package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.spec.js +14 -14
- package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.svelte +142 -142
- package/dist/recipes/inputs/PasswordStrengthIndicator/TestWrapper.svelte +2 -2
- package/dist/recipes/inputs/PhoneInput.svelte +254 -254
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.spec.js +10 -10
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.stories.svelte +170 -170
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte +346 -349
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte.d.ts.map +1 -1
- package/dist/recipes/inputs/Search.spec.js +3 -3
- package/dist/recipes/inputs/Search.svelte +110 -110
- package/dist/recipes/inputs/index.js +8 -8
- package/dist/recipes/inputs/phoneInput/CountrySelector.svelte +240 -240
- package/dist/recipes/modals/AlertModal.spec.js +36 -36
- package/dist/recipes/modals/AlertModal.svelte +139 -139
- package/dist/recipes/modals/ConfirmationModal.spec.js +396 -396
- package/dist/recipes/modals/ConfirmationModal.stories.svelte +119 -119
- package/dist/recipes/modals/ConfirmationModal.svelte +169 -169
- package/dist/recipes/modals/FeedbackModal.svelte +205 -205
- package/dist/recipes/modals/InputModal.spec.js +17 -17
- package/dist/recipes/modals/InputModal.svelte +194 -194
- package/dist/recipes/modals/ModalStateManager.spec.js +100 -100
- package/dist/recipes/modals/ModalStateManager.svelte +77 -77
- package/dist/recipes/modals/ModalTestWrapper.svelte +65 -65
- package/dist/recipes/modals/StatusModal.spec.js +7 -7
- package/dist/recipes/modals/StatusModal.svelte +216 -216
- package/dist/recipes/modals/index.js +8 -8
- package/dist/schemas/__tests__/order.test.js +1 -1
- package/dist/schemas/auth.d.ts +107 -17
- package/dist/schemas/auth.d.ts.map +1 -1
- package/dist/schemas/common.d.ts +41 -13
- package/dist/schemas/common.d.ts.map +1 -1
- package/dist/schemas/common.js +1 -1
- package/dist/schemas/event.d.ts +147 -41
- package/dist/schemas/event.d.ts.map +1 -1
- package/dist/schemas/event.js +1 -1
- package/dist/schemas/order.d.ts +208 -51
- package/dist/schemas/order.d.ts.map +1 -1
- package/dist/schemas/order.js +1 -0
- package/dist/schemas/performer.d.ts +199 -44
- package/dist/schemas/performer.d.ts.map +1 -1
- package/dist/schemas/performer.js +1 -1
- package/dist/schemas/promo.d.ts +221 -55
- package/dist/schemas/promo.d.ts.map +1 -1
- package/dist/schemas/promo.js +2 -2
- package/dist/schemas/ticket.d.ts +187 -61
- package/dist/schemas/ticket.d.ts.map +1 -1
- package/dist/schemas/ticket.js +1 -1
- package/dist/schemas/user.d.ts +114 -54
- package/dist/schemas/user.d.ts.map +1 -1
- package/dist/schemas/user.js +2 -1
- package/dist/schemas/venue.d.ts +238 -20
- package/dist/schemas/venue.d.ts.map +1 -1
- package/dist/services/show.service.d.ts +46 -46
- package/dist/stores/auth.d.ts +8 -8
- package/dist/stores/auth.svelte.spec.js +1 -1
- package/dist/stores/index.js +9 -9
- package/dist/stores/toaster.d.ts +3 -3
- package/dist/stores/toaster.js +13 -13
- package/dist/stores/toaster.spec.js +59 -59
- package/dist/stories/ButtonAuditDashboard.spec.js +12 -12
- package/dist/stories/ButtonAuditDashboard.svelte +55 -55
- package/dist/stories/ButtonAuditReview.spec.js +8 -8
- package/dist/stories/ButtonAuditReview.stories.svelte +14 -14
- package/dist/stories/ButtonAuditReview.svelte +427 -427
- package/dist/stories/ButtonGridView.spec.js +27 -27
- package/dist/stories/ButtonGridView.svelte +22 -22
- package/dist/stories/ButtonShowcase.spec.js +4 -4
- package/dist/stories/ButtonShowcase.svelte +119 -119
- package/dist/stories/ComponentConsolidation.stories.svelte +453 -453
- package/dist/stories/DesignSystemAudit.stories.svelte +127 -127
- package/dist/stories/PatternsGallery.spec.js +3 -3
- package/dist/stories/PatternsGallery.stories.svelte +19 -19
- package/dist/stories/PatternsGallery.svelte +399 -399
- package/dist/stories/PrimitivesGallery.spec.js +9 -9
- package/dist/stories/PrimitivesGallery.stories.svelte +19 -19
- package/dist/stories/PrimitivesGallery.svelte +756 -756
- package/dist/stories/RecipesGallery.stories.svelte +19 -19
- package/dist/stories/RecipesGallery.svelte +454 -454
- package/dist/stories/button-audit-manifest.json +11186 -11186
- package/dist/tailwind/preset.cjs +107 -87
- package/dist/tailwind/preset.d.cts +16 -0
- package/dist/tailwind/preset.d.cts.map +1 -1
- package/dist/telemetry.js +401 -401
- package/dist/telemetry.server.js +212 -212
- package/dist/telemetry.server.spec.js +437 -437
- package/dist/telemetry.spec.js +1273 -1273
- package/dist/tokens/__tests__/typography-base.test.js +5 -5
- package/dist/tokens/__tests__/typography.test.js +32 -36
- package/dist/tokens/__tests__/variants.test.js +63 -78
- package/dist/tokens/tokens.css +123 -87
- package/dist/tokens/typography-base.css +163 -163
- package/dist/tokens/typography.d.ts +29 -29
- package/dist/tokens/typography.js +29 -29
- package/dist/tokens/utilities.css +418 -430
- package/dist/tokens/variants.d.ts +32 -32
- package/dist/tokens/variants.js +32 -32
- package/dist/utils/__tests__/auth.test.js +431 -431
- package/dist/utils/apiConfig.d.ts +29 -29
- package/dist/utils/apiConfig.js +142 -142
- package/dist/utils/auth.d.ts +46 -46
- package/dist/utils/auth.js +195 -195
- package/dist/utils/greetings.js +187 -187
- package/dist/utils/greetings.spec.js +337 -337
- package/dist/utils/haptic.spec.js +1 -1
- package/dist/utils/imageValidation.js +121 -121
- package/dist/utils/imageValidation.spec.js +223 -223
- package/dist/utils/portal.d.ts +11 -11
- package/dist/utils/portal.js +25 -25
- package/dist/utils/portal.spec.js +143 -143
- package/dist/utils/transitions.js +16 -16
- package/dist/utils/utils/utils.d.ts +2 -2
- package/dist/utils/utils/utils.js +3 -3
- package/dist/utils/utils/utils.spec.js +698 -698
- package/dist/utils/utils.d.ts +41 -41
- package/dist/utils/utils.js +59 -59
- package/dist/utils/utils.spec.js +643 -643
- package/package.json +306 -306
|
@@ -1,97 +1,97 @@
|
|
|
1
|
-
import { render, fireEvent } from '@testing-library/svelte';
|
|
2
|
-
import { createRawSnippet } from 'svelte';
|
|
3
|
-
import { expect, describe, test, vi } from 'vitest';
|
|
4
|
-
import NavItem from './NavItem.svelte';
|
|
5
|
-
|
|
6
|
-
function textSnippet(text) {
|
|
7
|
-
return createRawSnippet(() => ({
|
|
8
|
-
render: () => `<span>${text}</span>`
|
|
9
|
-
}));
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
describe('NavItem', () => {
|
|
13
|
-
test('renders a button by default', () => {
|
|
14
|
-
const { container } = render(NavItem);
|
|
15
|
-
expect(container.querySelector('button')).toBeInTheDocument();
|
|
16
|
-
expect(container.querySelector('a')).not.toBeInTheDocument();
|
|
17
|
-
});
|
|
18
|
-
|
|
19
|
-
test('renders an anchor when href is provided', () => {
|
|
20
|
-
const { container } = render(NavItem, { props: { href: '/home' } });
|
|
21
|
-
expect(container.querySelector('a')).toBeInTheDocument();
|
|
22
|
-
expect(container.querySelector('a')).toHaveAttribute('href', '/home');
|
|
23
|
-
expect(container.querySelector('button')).not.toBeInTheDocument();
|
|
24
|
-
});
|
|
25
|
-
|
|
26
|
-
test('button has type="button"', () => {
|
|
27
|
-
const { container } = render(NavItem);
|
|
28
|
-
expect(container.querySelector('button')).toHaveAttribute('type', 'button');
|
|
29
|
-
});
|
|
30
|
-
|
|
31
|
-
test('applies default (inactive) styling', () => {
|
|
32
|
-
const { container } = render(NavItem);
|
|
33
|
-
const button = container.querySelector('button');
|
|
34
|
-
expect(button.className).toContain('text-
|
|
35
|
-
});
|
|
36
|
-
|
|
37
|
-
test('applies active styling', () => {
|
|
38
|
-
const { container } = render(NavItem, { props: { active: true } });
|
|
39
|
-
const button = container.querySelector('button');
|
|
40
|
-
expect(button.className).toContain('text-
|
|
41
|
-
});
|
|
42
|
-
|
|
43
|
-
test('applies disabled styling', () => {
|
|
44
|
-
const { container } = render(NavItem, { props: { disabled: true } });
|
|
45
|
-
const button = container.querySelector('button');
|
|
46
|
-
expect(button).toBeDisabled();
|
|
47
|
-
expect(button.className).toContain('cursor-not-allowed');
|
|
48
|
-
});
|
|
49
|
-
|
|
50
|
-
test('onclick handler on button', async () => {
|
|
51
|
-
const onclick = vi.fn();
|
|
52
|
-
const { container } = render(NavItem, { props: { onclick } });
|
|
53
|
-
await fireEvent.click(container.querySelector('button'));
|
|
54
|
-
expect(onclick).toHaveBeenCalled();
|
|
55
|
-
});
|
|
56
|
-
|
|
57
|
-
test('onclick handler on anchor', async () => {
|
|
58
|
-
const onclick = vi.fn();
|
|
59
|
-
const { container } = render(NavItem, { props: { href: '/page', onclick } });
|
|
60
|
-
await fireEvent.click(container.querySelector('a'));
|
|
61
|
-
expect(onclick).toHaveBeenCalled();
|
|
62
|
-
});
|
|
63
|
-
|
|
64
|
-
test('applies custom className', () => {
|
|
65
|
-
const { container } = render(NavItem, { props: { class: 'my-nav' } });
|
|
66
|
-
expect(container.querySelector('.my-nav')).toBeInTheDocument();
|
|
67
|
-
});
|
|
68
|
-
|
|
69
|
-
test('renders children content in button mode', () => {
|
|
70
|
-
const { container } = render(NavItem, {
|
|
71
|
-
props: { children: textSnippet('Nav label') }
|
|
72
|
-
});
|
|
73
|
-
expect(container.querySelector('button').textContent).toBe('Nav label');
|
|
74
|
-
});
|
|
75
|
-
|
|
76
|
-
test('renders children content in anchor mode', () => {
|
|
77
|
-
const { container } = render(NavItem, {
|
|
78
|
-
props: { href: '/page', children: textSnippet('Link label') }
|
|
79
|
-
});
|
|
80
|
-
expect(container.querySelector('a').textContent).toBe('Link label');
|
|
81
|
-
});
|
|
82
|
-
|
|
83
|
-
test('renders empty button when no children provided', () => {
|
|
84
|
-
const { container } = render(NavItem);
|
|
85
|
-
expect(container.querySelector('button').textContent).toBe('');
|
|
86
|
-
});
|
|
87
|
-
|
|
88
|
-
test('renders empty anchor when no children provided', () => {
|
|
89
|
-
const { container } = render(NavItem, { props: { href: '/page' } });
|
|
90
|
-
expect(container.querySelector('a').textContent).toBe('');
|
|
91
|
-
});
|
|
92
|
-
|
|
93
|
-
test('passes through additional props', () => {
|
|
94
|
-
const { container } = render(NavItem, { props: { 'data-testid': 'my-nav-item' } });
|
|
95
|
-
expect(container.querySelector('[data-testid="my-nav-item"]')).toBeInTheDocument();
|
|
96
|
-
});
|
|
97
|
-
});
|
|
1
|
+
import { render, fireEvent } from '@testing-library/svelte';
|
|
2
|
+
import { createRawSnippet } from 'svelte';
|
|
3
|
+
import { expect, describe, test, vi } from 'vitest';
|
|
4
|
+
import NavItem from './NavItem.svelte';
|
|
5
|
+
|
|
6
|
+
function textSnippet(text) {
|
|
7
|
+
return createRawSnippet(() => ({
|
|
8
|
+
render: () => `<span>${text}</span>`
|
|
9
|
+
}));
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
describe('NavItem', () => {
|
|
13
|
+
test('renders a button by default', () => {
|
|
14
|
+
const { container } = render(NavItem);
|
|
15
|
+
expect(container.querySelector('button')).toBeInTheDocument();
|
|
16
|
+
expect(container.querySelector('a')).not.toBeInTheDocument();
|
|
17
|
+
});
|
|
18
|
+
|
|
19
|
+
test('renders an anchor when href is provided', () => {
|
|
20
|
+
const { container } = render(NavItem, { props: { href: '/home' } });
|
|
21
|
+
expect(container.querySelector('a')).toBeInTheDocument();
|
|
22
|
+
expect(container.querySelector('a')).toHaveAttribute('href', '/home');
|
|
23
|
+
expect(container.querySelector('button')).not.toBeInTheDocument();
|
|
24
|
+
});
|
|
25
|
+
|
|
26
|
+
test('button has type="button"', () => {
|
|
27
|
+
const { container } = render(NavItem);
|
|
28
|
+
expect(container.querySelector('button')).toHaveAttribute('type', 'button');
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
test('applies default (inactive) styling', () => {
|
|
32
|
+
const { container } = render(NavItem);
|
|
33
|
+
const button = container.querySelector('button');
|
|
34
|
+
expect(button.className).toContain('text-muted-foreground');
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
test('applies active styling', () => {
|
|
38
|
+
const { container } = render(NavItem, { props: { active: true } });
|
|
39
|
+
const button = container.querySelector('button');
|
|
40
|
+
expect(button.className).toContain('text-brand-primary');
|
|
41
|
+
});
|
|
42
|
+
|
|
43
|
+
test('applies disabled styling', () => {
|
|
44
|
+
const { container } = render(NavItem, { props: { disabled: true } });
|
|
45
|
+
const button = container.querySelector('button');
|
|
46
|
+
expect(button).toBeDisabled();
|
|
47
|
+
expect(button.className).toContain('cursor-not-allowed');
|
|
48
|
+
});
|
|
49
|
+
|
|
50
|
+
test('onclick handler on button', async () => {
|
|
51
|
+
const onclick = vi.fn();
|
|
52
|
+
const { container } = render(NavItem, { props: { onclick } });
|
|
53
|
+
await fireEvent.click(container.querySelector('button'));
|
|
54
|
+
expect(onclick).toHaveBeenCalled();
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
test('onclick handler on anchor', async () => {
|
|
58
|
+
const onclick = vi.fn();
|
|
59
|
+
const { container } = render(NavItem, { props: { href: '/page', onclick } });
|
|
60
|
+
await fireEvent.click(container.querySelector('a'));
|
|
61
|
+
expect(onclick).toHaveBeenCalled();
|
|
62
|
+
});
|
|
63
|
+
|
|
64
|
+
test('applies custom className', () => {
|
|
65
|
+
const { container } = render(NavItem, { props: { class: 'my-nav' } });
|
|
66
|
+
expect(container.querySelector('.my-nav')).toBeInTheDocument();
|
|
67
|
+
});
|
|
68
|
+
|
|
69
|
+
test('renders children content in button mode', () => {
|
|
70
|
+
const { container } = render(NavItem, {
|
|
71
|
+
props: { children: textSnippet('Nav label') }
|
|
72
|
+
});
|
|
73
|
+
expect(container.querySelector('button').textContent).toBe('Nav label');
|
|
74
|
+
});
|
|
75
|
+
|
|
76
|
+
test('renders children content in anchor mode', () => {
|
|
77
|
+
const { container } = render(NavItem, {
|
|
78
|
+
props: { href: '/page', children: textSnippet('Link label') }
|
|
79
|
+
});
|
|
80
|
+
expect(container.querySelector('a').textContent).toBe('Link label');
|
|
81
|
+
});
|
|
82
|
+
|
|
83
|
+
test('renders empty button when no children provided', () => {
|
|
84
|
+
const { container } = render(NavItem);
|
|
85
|
+
expect(container.querySelector('button').textContent).toBe('');
|
|
86
|
+
});
|
|
87
|
+
|
|
88
|
+
test('renders empty anchor when no children provided', () => {
|
|
89
|
+
const { container } = render(NavItem, { props: { href: '/page' } });
|
|
90
|
+
expect(container.querySelector('a').textContent).toBe('');
|
|
91
|
+
});
|
|
92
|
+
|
|
93
|
+
test('passes through additional props', () => {
|
|
94
|
+
const { container } = render(NavItem, { props: { 'data-testid': 'my-nav-item' } });
|
|
95
|
+
expect(container.querySelector('[data-testid="my-nav-item"]')).toBeInTheDocument();
|
|
96
|
+
});
|
|
97
|
+
});
|
|
@@ -1,75 +1,75 @@
|
|
|
1
|
-
<script lang="ts">
|
|
2
|
-
/**
|
|
3
|
-
* NavItem Component
|
|
4
|
-
* Bottom navigation item with vertical layout.
|
|
5
|
-
*
|
|
6
|
-
* Replaces: Button variant="nav"
|
|
7
|
-
*/
|
|
8
|
-
import { twMerge } from 'tailwind-merge';
|
|
9
|
-
import type { Snippet } from 'svelte';
|
|
10
|
-
|
|
11
|
-
interface Props {
|
|
12
|
-
/** Active/selected state */
|
|
13
|
-
active?: boolean;
|
|
14
|
-
/** Disabled state */
|
|
15
|
-
disabled?: boolean;
|
|
16
|
-
/** Link href (renders as <a> if provided) */
|
|
17
|
-
href?: string | null;
|
|
18
|
-
/** Content (icon + label) */
|
|
19
|
-
children?: Snippet;
|
|
20
|
-
/** Additional classes */
|
|
21
|
-
class?: string;
|
|
22
|
-
/** Click handler */
|
|
23
|
-
onclick?: (e: MouseEvent) => void;
|
|
24
|
-
[key: string]: unknown;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
let {
|
|
28
|
-
active = false,
|
|
29
|
-
disabled = false,
|
|
30
|
-
href = null,
|
|
31
|
-
children,
|
|
32
|
-
class: className = '',
|
|
33
|
-
onclick,
|
|
34
|
-
...restProps
|
|
35
|
-
}: Props = $props();
|
|
36
|
-
|
|
37
|
-
const baseClasses = 'flex flex-col items-center justify-center h-full py-2 bg-transparent border-transparent rounded-lg font-medium leading-none focus:outline-hidden transition-all duration-150 ease-out select-none';
|
|
38
|
-
const defaultClasses = 'text-
|
|
39
|
-
const activeClasses = 'text-
|
|
40
|
-
const disabledClasses = 'text-
|
|
41
|
-
|
|
42
|
-
let variantClass = $derived(() => {
|
|
43
|
-
if (disabled) return disabledClasses;
|
|
44
|
-
if (active) return activeClasses;
|
|
45
|
-
return defaultClasses;
|
|
46
|
-
});
|
|
47
|
-
|
|
48
|
-
let classes = $derived(twMerge(
|
|
49
|
-
baseClasses,
|
|
50
|
-
variantClass(),
|
|
51
|
-
disabled ? 'cursor-not-allowed' : 'cursor-pointer',
|
|
52
|
-
className
|
|
53
|
-
));
|
|
54
|
-
</script>
|
|
55
|
-
|
|
56
|
-
{#if href}
|
|
57
|
-
<a
|
|
58
|
-
{href}
|
|
59
|
-
class={classes}
|
|
60
|
-
{onclick}
|
|
61
|
-
{...restProps}
|
|
62
|
-
>
|
|
63
|
-
{#if typeof children === 'function'}{@render children()}{:else if children}{children}{/if}
|
|
64
|
-
</a>
|
|
65
|
-
{:else}
|
|
66
|
-
<button
|
|
67
|
-
type="button"
|
|
68
|
-
class={classes}
|
|
69
|
-
{disabled}
|
|
70
|
-
{onclick}
|
|
71
|
-
{...restProps}
|
|
72
|
-
>
|
|
73
|
-
{#if typeof children === 'function'}{@render children()}{:else if children}{children}{/if}
|
|
74
|
-
</button>
|
|
75
|
-
{/if}
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
/**
|
|
3
|
+
* NavItem Component
|
|
4
|
+
* Bottom navigation item with vertical layout.
|
|
5
|
+
*
|
|
6
|
+
* Replaces: Button variant="nav"
|
|
7
|
+
*/
|
|
8
|
+
import { twMerge } from 'tailwind-merge';
|
|
9
|
+
import type { Snippet } from 'svelte';
|
|
10
|
+
|
|
11
|
+
interface Props {
|
|
12
|
+
/** Active/selected state */
|
|
13
|
+
active?: boolean;
|
|
14
|
+
/** Disabled state */
|
|
15
|
+
disabled?: boolean;
|
|
16
|
+
/** Link href (renders as <a> if provided) */
|
|
17
|
+
href?: string | null;
|
|
18
|
+
/** Content (icon + label) */
|
|
19
|
+
children?: Snippet;
|
|
20
|
+
/** Additional classes */
|
|
21
|
+
class?: string;
|
|
22
|
+
/** Click handler */
|
|
23
|
+
onclick?: (e: MouseEvent) => void;
|
|
24
|
+
[key: string]: unknown;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
let {
|
|
28
|
+
active = false,
|
|
29
|
+
disabled = false,
|
|
30
|
+
href = null,
|
|
31
|
+
children,
|
|
32
|
+
class: className = '',
|
|
33
|
+
onclick,
|
|
34
|
+
...restProps
|
|
35
|
+
}: Props = $props();
|
|
36
|
+
|
|
37
|
+
const baseClasses = 'flex flex-col items-center justify-center h-full py-2 bg-transparent border-transparent rounded-lg font-medium leading-none focus:outline-hidden transition-all duration-150 ease-out select-none';
|
|
38
|
+
const defaultClasses = 'text-muted-foreground hover:text-brand-primary';
|
|
39
|
+
const activeClasses = 'text-brand-primary';
|
|
40
|
+
const disabledClasses = 'text-muted-foreground cursor-not-allowed';
|
|
41
|
+
|
|
42
|
+
let variantClass = $derived(() => {
|
|
43
|
+
if (disabled) return disabledClasses;
|
|
44
|
+
if (active) return activeClasses;
|
|
45
|
+
return defaultClasses;
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
let classes = $derived(twMerge(
|
|
49
|
+
baseClasses,
|
|
50
|
+
variantClass(),
|
|
51
|
+
disabled ? 'cursor-not-allowed' : 'cursor-pointer',
|
|
52
|
+
className
|
|
53
|
+
));
|
|
54
|
+
</script>
|
|
55
|
+
|
|
56
|
+
{#if href}
|
|
57
|
+
<a
|
|
58
|
+
{href}
|
|
59
|
+
class={classes}
|
|
60
|
+
{onclick}
|
|
61
|
+
{...restProps}
|
|
62
|
+
>
|
|
63
|
+
{#if typeof children === 'function'}{@render children()}{:else if children}{children}{/if}
|
|
64
|
+
</a>
|
|
65
|
+
{:else}
|
|
66
|
+
<button
|
|
67
|
+
type="button"
|
|
68
|
+
class={classes}
|
|
69
|
+
{disabled}
|
|
70
|
+
{onclick}
|
|
71
|
+
{...restProps}
|
|
72
|
+
>
|
|
73
|
+
{#if typeof children === 'function'}{@render children()}{:else if children}{children}{/if}
|
|
74
|
+
</button>
|
|
75
|
+
{/if}
|
|
@@ -146,54 +146,54 @@ describe('NumberInput Styling', () => {
|
|
|
146
146
|
expect(incrementBtn).toHaveClass('rounded-r-lg');
|
|
147
147
|
});
|
|
148
148
|
|
|
149
|
-
test('buttons have bg-
|
|
149
|
+
test('buttons have bg-muted background', () => {
|
|
150
150
|
const { container } = render(NumberInput);
|
|
151
151
|
const decrementBtn = container.querySelector('[aria-label="Decrease quantity"]');
|
|
152
|
-
expect(decrementBtn).toHaveClass('bg-
|
|
152
|
+
expect(decrementBtn).toHaveClass('bg-muted');
|
|
153
153
|
});
|
|
154
154
|
|
|
155
|
-
test('buttons have border-
|
|
155
|
+
test('buttons have border-stroke-primary border', () => {
|
|
156
156
|
const { container } = render(NumberInput);
|
|
157
157
|
const decrementBtn = container.querySelector('[aria-label="Decrease quantity"]');
|
|
158
|
-
expect(decrementBtn).toHaveClass('border-
|
|
158
|
+
expect(decrementBtn).toHaveClass('border-stroke-primary');
|
|
159
159
|
});
|
|
160
160
|
|
|
161
|
-
test('display has bg-
|
|
161
|
+
test('display has bg-bg-secondary background', () => {
|
|
162
162
|
const { container } = render(NumberInput);
|
|
163
163
|
const display = container.querySelector('span');
|
|
164
|
-
expect(display).toHaveClass('bg-
|
|
164
|
+
expect(display).toHaveClass('bg-bg-secondary');
|
|
165
165
|
});
|
|
166
166
|
|
|
167
|
-
test('display has text-
|
|
167
|
+
test('display has text-muted-foreground color', () => {
|
|
168
168
|
const { container } = render(NumberInput);
|
|
169
169
|
const display = container.querySelector('span');
|
|
170
|
-
expect(display).toHaveClass('text-
|
|
170
|
+
expect(display).toHaveClass('text-muted-foreground');
|
|
171
171
|
});
|
|
172
172
|
});
|
|
173
173
|
|
|
174
|
-
describe('NumberInput
|
|
175
|
-
test('buttons have
|
|
174
|
+
describe('NumberInput Token-Based Styling', () => {
|
|
175
|
+
test('buttons have token-based background', () => {
|
|
176
176
|
const { container } = render(NumberInput);
|
|
177
177
|
const decrementBtn = container.querySelector('[aria-label="Decrease quantity"]');
|
|
178
|
-
expect(decrementBtn).toHaveClass('
|
|
178
|
+
expect(decrementBtn).toHaveClass('bg-muted');
|
|
179
179
|
});
|
|
180
180
|
|
|
181
|
-
test('buttons have
|
|
181
|
+
test('buttons have token-based border', () => {
|
|
182
182
|
const { container } = render(NumberInput);
|
|
183
183
|
const decrementBtn = container.querySelector('[aria-label="Decrease quantity"]');
|
|
184
|
-
expect(decrementBtn).toHaveClass('
|
|
184
|
+
expect(decrementBtn).toHaveClass('border-stroke-primary');
|
|
185
185
|
});
|
|
186
186
|
|
|
187
|
-
test('display has
|
|
187
|
+
test('display has token-based background', () => {
|
|
188
188
|
const { container } = render(NumberInput);
|
|
189
189
|
const display = container.querySelector('span');
|
|
190
|
-
expect(display).toHaveClass('
|
|
190
|
+
expect(display).toHaveClass('bg-bg-secondary');
|
|
191
191
|
});
|
|
192
192
|
|
|
193
|
-
test('display has
|
|
193
|
+
test('display has token-based text color', () => {
|
|
194
194
|
const { container } = render(NumberInput);
|
|
195
195
|
const display = container.querySelector('span');
|
|
196
|
-
expect(display).toHaveClass('
|
|
196
|
+
expect(display).toHaveClass('text-muted-foreground');
|
|
197
197
|
});
|
|
198
198
|
});
|
|
199
199
|
|
|
@@ -1,113 +1,113 @@
|
|
|
1
|
-
<script>
|
|
2
|
-
/**
|
|
3
|
-
* NumberInput Component - Flowbite Native (Pure Tailwind)
|
|
4
|
-
* Quantity stepper with increment/decrement buttons
|
|
5
|
-
*
|
|
6
|
-
* Matches Figma design:
|
|
7
|
-
* - Buttons: bg-
|
|
8
|
-
* - Display: bg-
|
|
9
|
-
* - Height: 37px
|
|
10
|
-
* - Icons: 10x10px
|
|
11
|
-
*/
|
|
12
|
-
import { twMerge } from 'tailwind-merge';
|
|
13
|
-
|
|
14
|
-
const defaultLabels = {
|
|
15
|
-
decreaseQuantity: 'Decrease quantity',
|
|
16
|
-
increaseQuantity: 'Increase quantity',
|
|
17
|
-
};
|
|
18
|
-
|
|
19
|
-
/** @type {{
|
|
20
|
-
value?: number,
|
|
21
|
-
min?: number,
|
|
22
|
-
max?: number,
|
|
23
|
-
disabled?: boolean,
|
|
24
|
-
onchange?: (value: number) => void,
|
|
25
|
-
class?: string,
|
|
26
|
-
}} */
|
|
27
|
-
let {
|
|
28
|
-
value = 0,
|
|
29
|
-
min = 0,
|
|
30
|
-
max = Infinity,
|
|
31
|
-
disabled = false,
|
|
32
|
-
onchange,
|
|
33
|
-
class: className = "",
|
|
34
|
-
labels: userLabels = {},
|
|
35
|
-
...restProps
|
|
36
|
-
} = $props();
|
|
37
|
-
|
|
38
|
-
let labels = $derived({ ...defaultLabels, ...userLabels });
|
|
39
|
-
|
|
40
|
-
function increment() {
|
|
41
|
-
if (value < max && !disabled) {
|
|
42
|
-
const newValue = value + 1;
|
|
43
|
-
onchange?.(newValue);
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
function decrement() {
|
|
48
|
-
if (value > min && !disabled) {
|
|
49
|
-
const newValue = value - 1;
|
|
50
|
-
onchange?.(newValue);
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
let isMinDisabled = $derived(disabled || value <= min);
|
|
55
|
-
let isMaxDisabled = $derived(disabled || value >= max);
|
|
56
|
-
|
|
57
|
-
// Button base classes matching Figma spec
|
|
58
|
-
const buttonBase = "h-[37px] px-3 flex items-center justify-center bg-
|
|
59
|
-
const buttonHover = "hover:bg-
|
|
60
|
-
const buttonDisabled = "disabled:opacity-50 disabled:cursor-not-allowed disabled:hover:bg-
|
|
61
|
-
|
|
62
|
-
let decrementClasses = $derived(twMerge(
|
|
63
|
-
buttonBase,
|
|
64
|
-
buttonHover,
|
|
65
|
-
buttonDisabled,
|
|
66
|
-
"rounded-l-lg"
|
|
67
|
-
));
|
|
68
|
-
|
|
69
|
-
let incrementClasses = $derived(twMerge(
|
|
70
|
-
buttonBase,
|
|
71
|
-
buttonHover,
|
|
72
|
-
buttonDisabled,
|
|
73
|
-
"rounded-r-lg"
|
|
74
|
-
));
|
|
75
|
-
|
|
76
|
-
// Display classes matching Figma spec
|
|
77
|
-
const displayClasses = "h-[37px] px-4 flex items-center justify-center text-
|
|
78
|
-
|
|
79
|
-
let containerClasses = $derived(twMerge(
|
|
80
|
-
"inline-flex items-center",
|
|
81
|
-
className
|
|
82
|
-
));
|
|
83
|
-
</script>
|
|
84
|
-
|
|
85
|
-
<div class={containerClasses} {...restProps}>
|
|
86
|
-
<button
|
|
87
|
-
type="button"
|
|
88
|
-
class={decrementClasses}
|
|
89
|
-
onclick={decrement}
|
|
90
|
-
disabled={isMinDisabled}
|
|
91
|
-
aria-label={labels.decreaseQuantity}
|
|
92
|
-
>
|
|
93
|
-
<svg class="w-3 h-3 text-
|
|
94
|
-
<path stroke="currentColor" stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M1 1h16"/>
|
|
95
|
-
</svg>
|
|
96
|
-
</button>
|
|
97
|
-
|
|
98
|
-
<span class={displayClasses}>
|
|
99
|
-
{value}
|
|
100
|
-
</span>
|
|
101
|
-
|
|
102
|
-
<button
|
|
103
|
-
type="button"
|
|
104
|
-
class={incrementClasses}
|
|
105
|
-
onclick={increment}
|
|
106
|
-
disabled={isMaxDisabled}
|
|
107
|
-
aria-label={labels.increaseQuantity}
|
|
108
|
-
>
|
|
109
|
-
<svg class="w-3 h-3 text-
|
|
110
|
-
<path stroke="currentColor" stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M9 1v16M1 9h16"/>
|
|
111
|
-
</svg>
|
|
112
|
-
</button>
|
|
113
|
-
</div>
|
|
1
|
+
<script>
|
|
2
|
+
/**
|
|
3
|
+
* NumberInput Component - Flowbite Native (Pure Tailwind)
|
|
4
|
+
* Quantity stepper with increment/decrement buttons
|
|
5
|
+
*
|
|
6
|
+
* Matches Figma design:
|
|
7
|
+
* - Buttons: bg-muted, border-stroke-primary, outer corners rounded
|
|
8
|
+
* - Display: bg-bg-secondary, border-stroke-primary
|
|
9
|
+
* - Height: 37px
|
|
10
|
+
* - Icons: 10x10px
|
|
11
|
+
*/
|
|
12
|
+
import { twMerge } from 'tailwind-merge';
|
|
13
|
+
|
|
14
|
+
const defaultLabels = {
|
|
15
|
+
decreaseQuantity: 'Decrease quantity',
|
|
16
|
+
increaseQuantity: 'Increase quantity',
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
/** @type {{
|
|
20
|
+
value?: number,
|
|
21
|
+
min?: number,
|
|
22
|
+
max?: number,
|
|
23
|
+
disabled?: boolean,
|
|
24
|
+
onchange?: (value: number) => void,
|
|
25
|
+
class?: string,
|
|
26
|
+
}} */
|
|
27
|
+
let {
|
|
28
|
+
value = 0,
|
|
29
|
+
min = 0,
|
|
30
|
+
max = Infinity,
|
|
31
|
+
disabled = false,
|
|
32
|
+
onchange,
|
|
33
|
+
class: className = "",
|
|
34
|
+
labels: userLabels = {},
|
|
35
|
+
...restProps
|
|
36
|
+
} = $props();
|
|
37
|
+
|
|
38
|
+
let labels = $derived({ ...defaultLabels, ...userLabels });
|
|
39
|
+
|
|
40
|
+
function increment() {
|
|
41
|
+
if (value < max && !disabled) {
|
|
42
|
+
const newValue = value + 1;
|
|
43
|
+
onchange?.(newValue);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
function decrement() {
|
|
48
|
+
if (value > min && !disabled) {
|
|
49
|
+
const newValue = value - 1;
|
|
50
|
+
onchange?.(newValue);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
let isMinDisabled = $derived(disabled || value <= min);
|
|
55
|
+
let isMaxDisabled = $derived(disabled || value >= max);
|
|
56
|
+
|
|
57
|
+
// Button base classes matching Figma spec
|
|
58
|
+
const buttonBase = "h-[37px] px-3 flex items-center justify-center bg-muted border border-stroke-primary transition-colors";
|
|
59
|
+
const buttonHover = "hover:bg-bg-tertiary";
|
|
60
|
+
const buttonDisabled = "disabled:opacity-50 disabled:cursor-not-allowed disabled:hover:bg-muted:hover:bg-bg-secondary";
|
|
61
|
+
|
|
62
|
+
let decrementClasses = $derived(twMerge(
|
|
63
|
+
buttonBase,
|
|
64
|
+
buttonHover,
|
|
65
|
+
buttonDisabled,
|
|
66
|
+
"rounded-l-lg"
|
|
67
|
+
));
|
|
68
|
+
|
|
69
|
+
let incrementClasses = $derived(twMerge(
|
|
70
|
+
buttonBase,
|
|
71
|
+
buttonHover,
|
|
72
|
+
buttonDisabled,
|
|
73
|
+
"rounded-r-lg"
|
|
74
|
+
));
|
|
75
|
+
|
|
76
|
+
// Display classes matching Figma spec
|
|
77
|
+
const displayClasses = "h-[37px] px-4 flex items-center justify-center text-muted-foreground text-sm bg-bg-secondary border-y border-stroke-primary -mx-px";
|
|
78
|
+
|
|
79
|
+
let containerClasses = $derived(twMerge(
|
|
80
|
+
"inline-flex items-center",
|
|
81
|
+
className
|
|
82
|
+
));
|
|
83
|
+
</script>
|
|
84
|
+
|
|
85
|
+
<div class={containerClasses} {...restProps}>
|
|
86
|
+
<button
|
|
87
|
+
type="button"
|
|
88
|
+
class={decrementClasses}
|
|
89
|
+
onclick={decrement}
|
|
90
|
+
disabled={isMinDisabled}
|
|
91
|
+
aria-label={labels.decreaseQuantity}
|
|
92
|
+
>
|
|
93
|
+
<svg class="w-3 h-3 text-text-primary" fill="none" viewBox="0 0 18 2">
|
|
94
|
+
<path stroke="currentColor" stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M1 1h16"/>
|
|
95
|
+
</svg>
|
|
96
|
+
</button>
|
|
97
|
+
|
|
98
|
+
<span class={displayClasses}>
|
|
99
|
+
{value}
|
|
100
|
+
</span>
|
|
101
|
+
|
|
102
|
+
<button
|
|
103
|
+
type="button"
|
|
104
|
+
class={incrementClasses}
|
|
105
|
+
onclick={increment}
|
|
106
|
+
disabled={isMaxDisabled}
|
|
107
|
+
aria-label={labels.increaseQuantity}
|
|
108
|
+
>
|
|
109
|
+
<svg class="w-3 h-3 text-text-primary" fill="none" viewBox="0 0 18 18">
|
|
110
|
+
<path stroke="currentColor" stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M9 1v16M1 9h16"/>
|
|
111
|
+
</svg>
|
|
112
|
+
</button>
|
|
113
|
+
</div>
|