@getmicdrop/svelte-components 5.19.0 → 5.20.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/base.css +18 -0
- package/dist/calendar/AboutShow/AboutShow.svelte +191 -191
- package/dist/calendar/Calendar/MiniMonthCalendar.svelte +803 -801
- package/dist/calendar/Calendar/MiniMonthCalendar.svelte.d.ts.map +1 -1
- package/dist/calendar/FAQs/FAQs.svelte +88 -88
- package/dist/calendar/MonthSwitcher/MonthSwitcher.svelte +140 -140
- package/dist/calendar/OrderSummary/OrderSummary.svelte +461 -461
- package/dist/calendar/PublicCard/PublicCard.svelte +164 -164
- package/dist/calendar/ShowCard/ShowCard.svelte +180 -180
- 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 -60
- package/dist/components/Heading.svelte.d.ts +1 -0
- package/dist/components/Heading.svelte.d.ts.map +1 -1
- 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.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/Text.spec.js +89 -89
- package/dist/components/Text.svelte +64 -53
- package/dist/components/Text.svelte.d.ts +2 -1
- package/dist/components/Text.svelte.d.ts.map +1 -1
- package/dist/config.js +151 -151
- package/dist/config.spec.js +29 -29
- package/dist/constants/formOptions.d.ts +2 -5
- package/dist/constants/formOptions.d.ts.map +1 -1
- package/dist/constants/formOptions.js +48 -48
- package/dist/constants/formOptions.spec.js +2 -7
- 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 +0 -1
- package/dist/forms/createFormStore.svelte.spec.js +0 -1
- package/dist/index.d.ts +6 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +85 -66
- 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.svelte +24 -24
- 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.svelte +33 -32
- package/dist/patterns/forms/FormSection.svelte.d.ts +2 -0
- package/dist/patterns/forms/FormSection.svelte.d.ts.map +1 -1
- 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.stories.svelte +77 -77
- package/dist/patterns/navigation/Header.svelte +263 -263
- package/dist/patterns/navigation/index.js +3 -3
- package/dist/patterns/page/PageHeader.svelte +49 -49
- 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.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/index.js +9 -9
- package/dist/primitives/Accordion/Accordion.stories.svelte +75 -75
- package/dist/primitives/Accordion/Accordion.svelte +62 -62
- 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.stories.svelte +94 -94
- 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 +123 -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.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 +4 -15
- 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.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.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.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/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.stories.svelte +137 -137
- package/dist/primitives/Input/Textarea.svelte +105 -105
- 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.svelte +113 -113
- package/dist/primitives/Pagination/DotIndicator.svelte +66 -0
- package/dist/primitives/Pagination/DotIndicator.svelte.d.ts +18 -0
- package/dist/primitives/Pagination/DotIndicator.svelte.d.ts.map +1 -0
- package/dist/primitives/Pagination/Pagination.stories.svelte +76 -76
- package/dist/primitives/Pagination/Pagination.svelte +275 -275
- 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.svelte +96 -96
- package/dist/primitives/Skeleton/ImagePlaceholder.svelte +68 -68
- package/dist/primitives/Skeleton/ListPlaceholder.svelte +85 -85
- package/dist/primitives/Skeleton/Skeleton.stories.svelte +151 -151
- package/dist/primitives/Skeleton/Skeleton.svelte +55 -55
- package/dist/primitives/Spinner/Spinner.spec.js +84 -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.stories.svelte +112 -112
- package/dist/primitives/Tabs/Tabs.svelte +137 -137
- package/dist/primitives/Toggle.spec.js +221 -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.d.ts +1 -0
- package/dist/primitives/index.js +114 -113
- 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.stories.svelte +125 -125
- package/dist/recipes/ImageUploader/ImageUploader.svelte +994 -994
- 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.svelte +85 -85
- package/dist/recipes/fields/FormField.svelte +58 -58
- package/dist/recipes/fields/RadioGroup.svelte +95 -95
- package/dist/recipes/fields/SelectField.svelte +82 -82
- package/dist/recipes/fields/TextareaField.svelte +101 -101
- 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.svelte +130 -130
- package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.svelte +142 -142
- package/dist/recipes/inputs/PhoneInput.svelte +254 -254
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.stories.svelte +170 -170
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte +349 -349
- 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.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 -0
- package/dist/recipes/modals/FeedbackModal.svelte.d.ts +24 -0
- package/dist/recipes/modals/FeedbackModal.svelte.d.ts.map +1 -0
- 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.svelte +216 -216
- package/dist/recipes/modals/index.d.ts +1 -0
- package/dist/recipes/modals/index.js +8 -7
- package/dist/schemas/common.js +1 -1
- package/dist/schemas/event.js +1 -1
- package/dist/schemas/order.js +0 -1
- package/dist/schemas/performer.js +1 -1
- package/dist/schemas/promo.js +2 -2
- package/dist/schemas/ticket.js +1 -1
- package/dist/schemas/user.js +1 -2
- 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/ButtonAuditReview.stories.svelte +14 -14
- package/dist/stories/ButtonAuditReview.svelte +427 -427
- package/dist/stories/PatternsGallery.stories.svelte +19 -19
- package/dist/stories/PatternsGallery.svelte +399 -399
- 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 +87 -82
- package/dist/tailwind/preset.d.cts +2 -0
- package/dist/tailwind/preset.d.cts.map +1 -1
- package/dist/telemetry.js +402 -402
- package/dist/telemetry.server.js +212 -212
- package/dist/telemetry.server.spec.js +437 -437
- package/dist/telemetry.spec.js +1173 -1173
- package/dist/tokens/__tests__/spacing.test.js +2 -2
- package/dist/tokens/__tests__/variants.test.js +12 -4
- package/dist/tokens/base-resets.css +124 -0
- package/dist/tokens/spacing.d.ts +2 -0
- package/dist/tokens/spacing.d.ts.map +1 -1
- package/dist/tokens/spacing.js +1 -0
- package/dist/tokens/tokens.css +87 -87
- package/dist/tokens/typography-base.css +163 -163
- package/dist/tokens/utilities.css +430 -353
- package/dist/tokens/variants.d.ts +4 -4
- package/dist/tokens/variants.js +4 -4
- package/dist/utils/__tests__/auth.test.js +431 -431
- package/dist/utils/apiConfig.d.ts +29 -29
- package/dist/utils/apiConfig.js +117 -117
- package/dist/utils/apiConfig.spec.js +226 -219
- package/dist/utils/auth.d.ts +46 -46
- package/dist/utils/auth.js +195 -195
- package/dist/utils/clickOutside.d.ts +4 -0
- package/dist/utils/clickOutside.d.ts.map +1 -0
- package/dist/utils/clickOutside.js +13 -0
- package/dist/utils/feedbackContext.d.ts +24 -0
- package/dist/utils/feedbackContext.d.ts.map +1 -0
- package/dist/utils/feedbackContext.js +19 -0
- package/dist/utils/fetchHelpers.d.ts.map +1 -1
- package/dist/utils/fetchHelpers.js +1 -0
- package/dist/utils/focusTrap.d.ts +20 -0
- package/dist/utils/focusTrap.d.ts.map +1 -0
- package/dist/utils/focusTrap.js +130 -0
- package/dist/utils/formatters.js +1 -1
- 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/logger.d.ts +25 -1
- package/dist/utils/logger.d.ts.map +1 -1
- package/dist/utils/logger.js +59 -1
- package/dist/utils/logger.spec.js +99 -1
- 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.d.ts +99 -1
- package/dist/utils/transitions.d.ts.map +1 -1
- package/dist/utils/transitions.js +148 -6
- 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 +310 -301
|
@@ -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-gray-500');
|
|
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-blue-600');
|
|
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-gray-500');
|
|
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-blue-600');
|
|
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-gray-500 hover:text-blue-600 dark:text-gray-400 dark:hover:text-blue-500';
|
|
39
|
-
const activeClasses = 'text-blue-600 dark:text-blue-500';
|
|
40
|
-
const disabledClasses = 'text-gray-400 cursor-not-allowed dark:text-gray-500';
|
|
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-gray-500 hover:text-blue-600 dark:text-gray-400 dark:hover:text-blue-500';
|
|
39
|
+
const activeClasses = 'text-blue-600 dark:text-blue-500';
|
|
40
|
+
const disabledClasses = 'text-gray-400 cursor-not-allowed dark:text-gray-500';
|
|
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,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-gray-100, border-gray-300, outer corners rounded
|
|
8
|
-
* - Display: bg-gray-50, border-gray-300
|
|
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-gray-100 border border-gray-300 transition-colors dark:bg-gray-700 dark:border-gray-600";
|
|
59
|
-
const buttonHover = "hover:bg-gray-200 dark:hover:bg-gray-600";
|
|
60
|
-
const buttonDisabled = "disabled:opacity-50 disabled:cursor-not-allowed disabled:hover:bg-gray-100 dark:disabled:hover:bg-gray-700";
|
|
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-gray-500 text-sm bg-gray-50 border-y border-gray-300 -mx-px dark:bg-gray-800 dark:text-gray-400 dark:border-gray-600";
|
|
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-gray-800 dark:text-white" 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-gray-800 dark:text-white" 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>
|
|
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-gray-100, border-gray-300, outer corners rounded
|
|
8
|
+
* - Display: bg-gray-50, border-gray-300
|
|
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-gray-100 border border-gray-300 transition-colors dark:bg-gray-700 dark:border-gray-600";
|
|
59
|
+
const buttonHover = "hover:bg-gray-200 dark:hover:bg-gray-600";
|
|
60
|
+
const buttonDisabled = "disabled:opacity-50 disabled:cursor-not-allowed disabled:hover:bg-gray-100 dark:disabled:hover:bg-gray-700";
|
|
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-gray-500 text-sm bg-gray-50 border-y border-gray-300 -mx-px dark:bg-gray-800 dark:text-gray-400 dark:border-gray-600";
|
|
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-gray-800 dark:text-white" 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-gray-800 dark:text-white" 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>
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
interface Props {
|
|
3
|
+
/** Total number of items */
|
|
4
|
+
count: number;
|
|
5
|
+
/** Currently active index (0-based) */
|
|
6
|
+
activeIndex?: number;
|
|
7
|
+
/** Dot size */
|
|
8
|
+
size?: 'sm' | 'md' | 'lg';
|
|
9
|
+
/** Color scheme */
|
|
10
|
+
variant?: 'light' | 'dark';
|
|
11
|
+
/** Called when a dot is clicked */
|
|
12
|
+
onselect?: (index: number) => void;
|
|
13
|
+
/** Additional CSS classes on the container */
|
|
14
|
+
class?: string;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
let {
|
|
18
|
+
count,
|
|
19
|
+
activeIndex = 0,
|
|
20
|
+
size = 'md',
|
|
21
|
+
variant = 'dark',
|
|
22
|
+
onselect,
|
|
23
|
+
class: className = '',
|
|
24
|
+
}: Props = $props();
|
|
25
|
+
|
|
26
|
+
const sizeClasses: Record<string, { dot: string; active: string }> = {
|
|
27
|
+
sm: { dot: 'h-1.5 w-1.5', active: 'scale-125' },
|
|
28
|
+
md: { dot: 'h-2.5 w-2.5', active: 'scale-125' },
|
|
29
|
+
lg: { dot: 'h-3 w-3', active: 'scale-125' },
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
const variantClasses: Record<string, { active: string; inactive: string; hover: string }> = {
|
|
33
|
+
light: {
|
|
34
|
+
active: 'bg-white',
|
|
35
|
+
inactive: 'bg-white/30',
|
|
36
|
+
hover: 'hover:bg-white/50',
|
|
37
|
+
},
|
|
38
|
+
dark: {
|
|
39
|
+
active: 'bg-gray-900 dark:bg-white',
|
|
40
|
+
inactive: 'bg-gray-300 dark:bg-gray-600',
|
|
41
|
+
hover: 'hover:bg-gray-400 dark:hover:bg-gray-500',
|
|
42
|
+
},
|
|
43
|
+
};
|
|
44
|
+
|
|
45
|
+
let sizeConfig = $derived(sizeClasses[size] || sizeClasses.md);
|
|
46
|
+
let variantConfig = $derived(variantClasses[variant] || variantClasses.dark);
|
|
47
|
+
</script>
|
|
48
|
+
|
|
49
|
+
<div
|
|
50
|
+
class="flex items-center gap-2 {className}"
|
|
51
|
+
role="tablist"
|
|
52
|
+
aria-label="Item selector"
|
|
53
|
+
>
|
|
54
|
+
{#each { length: count } as _, i}
|
|
55
|
+
<button
|
|
56
|
+
type="button"
|
|
57
|
+
class="rounded-full transition-all {sizeConfig.dot} {i === activeIndex
|
|
58
|
+
? `${sizeConfig.active} ${variantConfig.active}`
|
|
59
|
+
: `${variantConfig.inactive} ${variantConfig.hover}`}"
|
|
60
|
+
role="tab"
|
|
61
|
+
aria-selected={i === activeIndex}
|
|
62
|
+
aria-label="Item {i + 1} of {count}"
|
|
63
|
+
onclick={() => onselect?.(i)}
|
|
64
|
+
></button>
|
|
65
|
+
{/each}
|
|
66
|
+
</div>
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
interface Props {
|
|
2
|
+
/** Total number of items */
|
|
3
|
+
count: number;
|
|
4
|
+
/** Currently active index (0-based) */
|
|
5
|
+
activeIndex?: number;
|
|
6
|
+
/** Dot size */
|
|
7
|
+
size?: 'sm' | 'md' | 'lg';
|
|
8
|
+
/** Color scheme */
|
|
9
|
+
variant?: 'light' | 'dark';
|
|
10
|
+
/** Called when a dot is clicked */
|
|
11
|
+
onselect?: (index: number) => void;
|
|
12
|
+
/** Additional CSS classes on the container */
|
|
13
|
+
class?: string;
|
|
14
|
+
}
|
|
15
|
+
declare const DotIndicator: import("svelte").Component<Props, {}, "">;
|
|
16
|
+
type DotIndicator = ReturnType<typeof DotIndicator>;
|
|
17
|
+
export default DotIndicator;
|
|
18
|
+
//# sourceMappingURL=DotIndicator.svelte.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DotIndicator.svelte.d.ts","sourceRoot":"","sources":["../../../src/lib/primitives/Pagination/DotIndicator.svelte.ts"],"names":[],"mappings":"AAGE,UAAU,KAAK;IACb,4BAA4B;IAC5B,KAAK,EAAE,MAAM,CAAC;IACd,uCAAuC;IACvC,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,eAAe;IACf,IAAI,CAAC,EAAE,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC;IAC1B,mBAAmB;IACnB,OAAO,CAAC,EAAE,OAAO,GAAG,MAAM,CAAC;IAC3B,mCAAmC;IACnC,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,8CAA8C;IAC9C,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AA8CH,QAAA,MAAM,YAAY,2CAAwC,CAAC;AAC3D,KAAK,YAAY,GAAG,UAAU,CAAC,OAAO,YAAY,CAAC,CAAC;AACpD,eAAe,YAAY,CAAC"}
|