@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,7 +1,7 @@
|
|
|
1
|
-
// Field recipes - Label + Input + Error compositions
|
|
2
|
-
export { default as CheckboxField } from './CheckboxField.svelte';
|
|
3
|
-
export { default as FormField } from './FormField.svelte';
|
|
4
|
-
export { default as RadioGroup } from './RadioGroup.svelte';
|
|
5
|
-
export { default as SelectField } from './SelectField.svelte';
|
|
6
|
-
export { default as TextareaField } from './TextareaField.svelte';
|
|
7
|
-
export { default as ToggleField } from './ToggleField.svelte';
|
|
1
|
+
// Field recipes - Label + Input + Error compositions
|
|
2
|
+
export { default as CheckboxField } from './CheckboxField.svelte';
|
|
3
|
+
export { default as FormField } from './FormField.svelte';
|
|
4
|
+
export { default as RadioGroup } from './RadioGroup.svelte';
|
|
5
|
+
export { default as SelectField } from './SelectField.svelte';
|
|
6
|
+
export { default as TextareaField } from './TextareaField.svelte';
|
|
7
|
+
export { default as ToggleField } from './ToggleField.svelte';
|
package/dist/recipes/index.js
CHANGED
|
@@ -1,24 +1,24 @@
|
|
|
1
|
-
// =============================================================================
|
|
2
|
-
// RECIPES - Domain-agnostic compositions (Layer 2)
|
|
3
|
-
// =============================================================================
|
|
4
|
-
|
|
5
|
-
// CropImage
|
|
6
|
-
export { default as CropImage } from './CropImage/CropImage.svelte';
|
|
7
|
-
|
|
8
|
-
// ImageUploader
|
|
9
|
-
export { default as ImageUploader } from './ImageUploader/ImageUploader.svelte';
|
|
10
|
-
|
|
11
|
-
// Feedback - re-export from feedback/index.js
|
|
12
|
-
export * from './feedback/index.js';
|
|
13
|
-
|
|
14
|
-
// Inputs - re-export from inputs/index.js
|
|
15
|
-
export * from './inputs/index.js';
|
|
16
|
-
|
|
17
|
-
// Modals - re-export from modals/index.js
|
|
18
|
-
export * from './modals/index.js';
|
|
19
|
-
|
|
20
|
-
// SuperLogin - re-export from SuperLogin/index.js
|
|
21
|
-
export * from './SuperLogin/index.js';
|
|
22
|
-
|
|
23
|
-
// Fields - re-export from fields/index.js
|
|
24
|
-
export * from './fields/index.js';
|
|
1
|
+
// =============================================================================
|
|
2
|
+
// RECIPES - Domain-agnostic compositions (Layer 2)
|
|
3
|
+
// =============================================================================
|
|
4
|
+
|
|
5
|
+
// CropImage
|
|
6
|
+
export { default as CropImage } from './CropImage/CropImage.svelte';
|
|
7
|
+
|
|
8
|
+
// ImageUploader
|
|
9
|
+
export { default as ImageUploader } from './ImageUploader/ImageUploader.svelte';
|
|
10
|
+
|
|
11
|
+
// Feedback - re-export from feedback/index.js
|
|
12
|
+
export * from './feedback/index.js';
|
|
13
|
+
|
|
14
|
+
// Inputs - re-export from inputs/index.js
|
|
15
|
+
export * from './inputs/index.js';
|
|
16
|
+
|
|
17
|
+
// Modals - re-export from modals/index.js
|
|
18
|
+
export * from './modals/index.js';
|
|
19
|
+
|
|
20
|
+
// SuperLogin - re-export from SuperLogin/index.js
|
|
21
|
+
export * from './SuperLogin/index.js';
|
|
22
|
+
|
|
23
|
+
// Fields - re-export from fields/index.js
|
|
24
|
+
export * from './fields/index.js';
|
|
@@ -1,263 +1,263 @@
|
|
|
1
|
-
import { render, screen, fireEvent } from "@testing-library/svelte";
|
|
2
|
-
import userEvent from "@testing-library/user-event";
|
|
3
|
-
import { expect, describe, test, vi } from "vitest";
|
|
4
|
-
import MultiSelect from "./MultiSelect.svelte";
|
|
5
|
-
|
|
6
|
-
// Mock transitions to be instant for testing
|
|
7
|
-
vi.mock('../../utils/transitions.js', () => ({
|
|
8
|
-
bloom: () => ({ duration: 0, delay: 0, css: () => '' }),
|
|
9
|
-
safeSlide: () => ({ duration: 0, delay: 0, css: () => '' }),
|
|
10
|
-
}));
|
|
11
|
-
|
|
12
|
-
const sampleItems = [
|
|
13
|
-
{ name: "Option 1", value: "opt1" },
|
|
14
|
-
{ name: "Option 2", value: "opt2" },
|
|
15
|
-
{ name: "Option 3", value: "opt3" },
|
|
16
|
-
{ name: "Option 4", value: "opt4" },
|
|
17
|
-
];
|
|
18
|
-
|
|
19
|
-
function setupTest(args = {}) {
|
|
20
|
-
const user = userEvent.setup();
|
|
21
|
-
const { component } = render(MultiSelect, {
|
|
22
|
-
props: {
|
|
23
|
-
items: sampleItems,
|
|
24
|
-
...args,
|
|
25
|
-
},
|
|
26
|
-
});
|
|
27
|
-
return { user, component };
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
describe("MultiSelect Component Tests", () => {
|
|
31
|
-
test("Renders multiselect with label", () => {
|
|
32
|
-
setupTest({
|
|
33
|
-
label: "Test Label",
|
|
34
|
-
id: "test-multiselect",
|
|
35
|
-
});
|
|
36
|
-
expect(screen.getByText("Test Label")).toBeInTheDocument();
|
|
37
|
-
});
|
|
38
|
-
|
|
39
|
-
test("Shows placeholder when no value selected", () => {
|
|
40
|
-
setupTest({
|
|
41
|
-
placeholder: "Select options",
|
|
42
|
-
});
|
|
43
|
-
expect(screen.getByText("Select options")).toBeInTheDocument();
|
|
44
|
-
});
|
|
45
|
-
|
|
46
|
-
test("Opens dropdown on click", async () => {
|
|
47
|
-
const { user } = setupTest();
|
|
48
|
-
const trigger = screen.getByRole("combobox");
|
|
49
|
-
|
|
50
|
-
await user.click(trigger);
|
|
51
|
-
|
|
52
|
-
expect(screen.getByRole("listbox")).toBeInTheDocument();
|
|
53
|
-
expect(screen.getByText("Option 1")).toBeInTheDocument();
|
|
54
|
-
expect(screen.getByText("Option 2")).toBeInTheDocument();
|
|
55
|
-
});
|
|
56
|
-
|
|
57
|
-
test("Selects multiple items", async () => {
|
|
58
|
-
const { user } = setupTest();
|
|
59
|
-
const trigger = screen.getByRole("combobox");
|
|
60
|
-
|
|
61
|
-
await user.click(trigger);
|
|
62
|
-
// Click on options in dropdown
|
|
63
|
-
const options = screen.getAllByRole("option");
|
|
64
|
-
await user.click(options[0]); // Option 1
|
|
65
|
-
await user.click(options[2]); // Option 3
|
|
66
|
-
|
|
67
|
-
// Both tags should be visible (may have duplicates due to dropdown still open)
|
|
68
|
-
expect(screen.getAllByText("Option 1").length).toBeGreaterThanOrEqual(1);
|
|
69
|
-
expect(screen.getAllByText("Option 3").length).toBeGreaterThanOrEqual(1);
|
|
70
|
-
});
|
|
71
|
-
|
|
72
|
-
test("Dropdown stays open after selection", async () => {
|
|
73
|
-
const { user } = setupTest();
|
|
74
|
-
const trigger = screen.getByRole("combobox");
|
|
75
|
-
|
|
76
|
-
await user.click(trigger);
|
|
77
|
-
await user.click(screen.getByText("Option 1"));
|
|
78
|
-
|
|
79
|
-
// Dropdown should still be open for multi-select
|
|
80
|
-
expect(screen.getByRole("listbox")).toBeInTheDocument();
|
|
81
|
-
});
|
|
82
|
-
|
|
83
|
-
test("Shows selected values as tags", () => {
|
|
84
|
-
setupTest({
|
|
85
|
-
value: ["opt1", "opt2"],
|
|
86
|
-
});
|
|
87
|
-
expect(screen.getByText("Option 1")).toBeInTheDocument();
|
|
88
|
-
expect(screen.getByText("Option 2")).toBeInTheDocument();
|
|
89
|
-
});
|
|
90
|
-
|
|
91
|
-
test("Removes item when clicking tag remove button", async () => {
|
|
92
|
-
const { user } = setupTest({
|
|
93
|
-
value: ["opt1", "opt2"],
|
|
94
|
-
});
|
|
95
|
-
|
|
96
|
-
// Find the remove button for Option 1
|
|
97
|
-
const removeButtons = screen.getAllByRole("button", { name: /remove/i });
|
|
98
|
-
await user.click(removeButtons[0]);
|
|
99
|
-
|
|
100
|
-
// Option 1 should be removed, Option 2 should remain
|
|
101
|
-
expect(screen.queryByText("Option 1")).not.toBeInTheDocument();
|
|
102
|
-
expect(screen.getByText("Option 2")).toBeInTheDocument();
|
|
103
|
-
});
|
|
104
|
-
|
|
105
|
-
test("Clears all selections when clicking clear button", async () => {
|
|
106
|
-
const { user } = setupTest({
|
|
107
|
-
value: ["opt1", "opt2", "opt3"],
|
|
108
|
-
placeholder: "Select options",
|
|
109
|
-
});
|
|
110
|
-
|
|
111
|
-
const clearButton = screen.getByRole("button", { name: /clear all/i });
|
|
112
|
-
await user.click(clearButton);
|
|
113
|
-
|
|
114
|
-
expect(screen.getByText("Select options")).toBeInTheDocument();
|
|
115
|
-
expect(screen.queryByText("Option 1")).not.toBeInTheDocument();
|
|
116
|
-
});
|
|
117
|
-
|
|
118
|
-
test("Hides clear button when hideClear is true", () => {
|
|
119
|
-
setupTest({
|
|
120
|
-
value: ["opt1"],
|
|
121
|
-
hideClear: true,
|
|
122
|
-
});
|
|
123
|
-
expect(screen.queryByRole("button", { name: /clear all/i })).not.toBeInTheDocument();
|
|
124
|
-
});
|
|
125
|
-
|
|
126
|
-
test("Dispatches change event on selection", async () => {
|
|
127
|
-
const changeSpy = vi.fn();
|
|
128
|
-
const { user } = setupTest({
|
|
129
|
-
onchange: changeSpy,
|
|
130
|
-
});
|
|
131
|
-
|
|
132
|
-
const trigger = screen.getByRole("combobox");
|
|
133
|
-
await user.click(trigger);
|
|
134
|
-
await user.click(screen.getByText("Option 2"));
|
|
135
|
-
|
|
136
|
-
expect(changeSpy).toHaveBeenCalled();
|
|
137
|
-
expect(changeSpy.mock.calls[0][0].value).toContain("opt2");
|
|
138
|
-
});
|
|
139
|
-
|
|
140
|
-
test("Shows required indicator when required", () => {
|
|
141
|
-
setupTest({
|
|
142
|
-
label: "Required Field",
|
|
143
|
-
required: true,
|
|
144
|
-
});
|
|
145
|
-
expect(screen.getByText("*")).toBeInTheDocument();
|
|
146
|
-
});
|
|
147
|
-
|
|
148
|
-
test("Displays error state", () => {
|
|
149
|
-
setupTest({
|
|
150
|
-
error: "Please select at least one option",
|
|
151
|
-
});
|
|
152
|
-
expect(screen.getByText("Please select at least one option")).toBeInTheDocument();
|
|
153
|
-
});
|
|
154
|
-
|
|
155
|
-
test("Disables multiselect when disabled prop is true", async () => {
|
|
156
|
-
const { user } = setupTest({
|
|
157
|
-
disabled: true,
|
|
158
|
-
});
|
|
159
|
-
const trigger = screen.getByRole("combobox");
|
|
160
|
-
|
|
161
|
-
expect(trigger).toHaveAttribute("aria-disabled", "true");
|
|
162
|
-
await user.click(trigger);
|
|
163
|
-
expect(screen.queryByRole("listbox")).not.toBeInTheDocument();
|
|
164
|
-
});
|
|
165
|
-
|
|
166
|
-
test("Navigates options with keyboard", async () => {
|
|
167
|
-
const { user } = setupTest();
|
|
168
|
-
const trigger = screen.getByRole("combobox");
|
|
169
|
-
|
|
170
|
-
await user.click(trigger);
|
|
171
|
-
await user.keyboard("{ArrowDown}");
|
|
172
|
-
await user.keyboard("{Enter}");
|
|
173
|
-
|
|
174
|
-
// First option should be selected
|
|
175
|
-
expect(screen.getByText("Option 1")).toBeInTheDocument();
|
|
176
|
-
});
|
|
177
|
-
|
|
178
|
-
test("Closes dropdown on Escape key", async () => {
|
|
179
|
-
const { user } = setupTest();
|
|
180
|
-
const trigger = screen.getByRole("combobox");
|
|
181
|
-
|
|
182
|
-
await user.click(trigger);
|
|
183
|
-
expect(screen.getByRole("listbox")).toBeInTheDocument();
|
|
184
|
-
|
|
185
|
-
await user.keyboard("{Escape}");
|
|
186
|
-
expect(screen.queryByRole("listbox")).not.toBeInTheDocument();
|
|
187
|
-
});
|
|
188
|
-
|
|
189
|
-
test("Toggles item off when clicking selected item", async () => {
|
|
190
|
-
const { user } = setupTest({
|
|
191
|
-
value: ["opt1"],
|
|
192
|
-
placeholder: "Select options",
|
|
193
|
-
});
|
|
194
|
-
const trigger = screen.getByRole("combobox");
|
|
195
|
-
|
|
196
|
-
await user.click(trigger);
|
|
197
|
-
|
|
198
|
-
// Click Option 1 to deselect it
|
|
199
|
-
const option1 = screen.getByRole("option", { name: /option 1/i });
|
|
200
|
-
await user.click(option1);
|
|
201
|
-
|
|
202
|
-
// Should show placeholder now
|
|
203
|
-
expect(screen.getByText("Select options")).toBeInTheDocument();
|
|
204
|
-
});
|
|
205
|
-
|
|
206
|
-
test("Applies animate focus class by default", () => {
|
|
207
|
-
setupTest();
|
|
208
|
-
const trigger = screen.getByRole("combobox");
|
|
209
|
-
expect(trigger).toHaveClass("multiselect-animate-focus");
|
|
210
|
-
});
|
|
211
|
-
|
|
212
|
-
test("Does not apply animate focus when disabled", () => {
|
|
213
|
-
setupTest({
|
|
214
|
-
animateFocus: false,
|
|
215
|
-
});
|
|
216
|
-
const trigger = screen.getByRole("combobox");
|
|
217
|
-
expect(trigger).not.toHaveClass("multiselect-animate-focus");
|
|
218
|
-
});
|
|
219
|
-
|
|
220
|
-
test("Shows checkbox for each option", async () => {
|
|
221
|
-
const { user } = setupTest();
|
|
222
|
-
const trigger = screen.getByRole("combobox");
|
|
223
|
-
|
|
224
|
-
await user.click(trigger);
|
|
225
|
-
|
|
226
|
-
// Each option should have a checkbox element
|
|
227
|
-
const options = screen.getAllByRole("option");
|
|
228
|
-
options.forEach(option => {
|
|
229
|
-
expect(option.querySelector(".multiselect-checkbox")).toBeInTheDocument();
|
|
230
|
-
});
|
|
231
|
-
});
|
|
232
|
-
|
|
233
|
-
test("Shows checked checkbox for selected items", async () => {
|
|
234
|
-
const { user } = setupTest({
|
|
235
|
-
value: ["opt1"],
|
|
236
|
-
});
|
|
237
|
-
const trigger = screen.getByRole("combobox");
|
|
238
|
-
|
|
239
|
-
await user.click(trigger);
|
|
240
|
-
|
|
241
|
-
const selectedOption = screen.getByRole("option", { name: /option 1/i });
|
|
242
|
-
expect(selectedOption.querySelector(".multiselect-checkbox-checked")).toBeInTheDocument();
|
|
243
|
-
});
|
|
244
|
-
|
|
245
|
-
test("Sets aria-multiselectable on listbox", async () => {
|
|
246
|
-
const { user } = setupTest();
|
|
247
|
-
const trigger = screen.getByRole("combobox");
|
|
248
|
-
|
|
249
|
-
await user.click(trigger);
|
|
250
|
-
|
|
251
|
-
const listbox = screen.getByRole("listbox");
|
|
252
|
-
expect(listbox).toHaveAttribute("aria-multiselectable", "true");
|
|
253
|
-
});
|
|
254
|
-
|
|
255
|
-
test("Initializes empty value as array", () => {
|
|
256
|
-
setupTest({
|
|
257
|
-
value: null,
|
|
258
|
-
placeholder: "Select options",
|
|
259
|
-
});
|
|
260
|
-
// Should not crash and show placeholder
|
|
261
|
-
expect(screen.getByText("Select options")).toBeInTheDocument();
|
|
262
|
-
});
|
|
263
|
-
});
|
|
1
|
+
import { render, screen, fireEvent } from "@testing-library/svelte";
|
|
2
|
+
import userEvent from "@testing-library/user-event";
|
|
3
|
+
import { expect, describe, test, vi } from "vitest";
|
|
4
|
+
import MultiSelect from "./MultiSelect.svelte";
|
|
5
|
+
|
|
6
|
+
// Mock transitions to be instant for testing
|
|
7
|
+
vi.mock('../../utils/transitions.js', () => ({
|
|
8
|
+
bloom: () => ({ duration: 0, delay: 0, css: () => '' }),
|
|
9
|
+
safeSlide: () => ({ duration: 0, delay: 0, css: () => '' }),
|
|
10
|
+
}));
|
|
11
|
+
|
|
12
|
+
const sampleItems = [
|
|
13
|
+
{ name: "Option 1", value: "opt1" },
|
|
14
|
+
{ name: "Option 2", value: "opt2" },
|
|
15
|
+
{ name: "Option 3", value: "opt3" },
|
|
16
|
+
{ name: "Option 4", value: "opt4" },
|
|
17
|
+
];
|
|
18
|
+
|
|
19
|
+
function setupTest(args = {}) {
|
|
20
|
+
const user = userEvent.setup();
|
|
21
|
+
const { component } = render(MultiSelect, {
|
|
22
|
+
props: {
|
|
23
|
+
items: sampleItems,
|
|
24
|
+
...args,
|
|
25
|
+
},
|
|
26
|
+
});
|
|
27
|
+
return { user, component };
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
describe("MultiSelect Component Tests", () => {
|
|
31
|
+
test("Renders multiselect with label", () => {
|
|
32
|
+
setupTest({
|
|
33
|
+
label: "Test Label",
|
|
34
|
+
id: "test-multiselect",
|
|
35
|
+
});
|
|
36
|
+
expect(screen.getByText("Test Label")).toBeInTheDocument();
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
test("Shows placeholder when no value selected", () => {
|
|
40
|
+
setupTest({
|
|
41
|
+
placeholder: "Select options",
|
|
42
|
+
});
|
|
43
|
+
expect(screen.getByText("Select options")).toBeInTheDocument();
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
test("Opens dropdown on click", async () => {
|
|
47
|
+
const { user } = setupTest();
|
|
48
|
+
const trigger = screen.getByRole("combobox");
|
|
49
|
+
|
|
50
|
+
await user.click(trigger);
|
|
51
|
+
|
|
52
|
+
expect(screen.getByRole("listbox")).toBeInTheDocument();
|
|
53
|
+
expect(screen.getByText("Option 1")).toBeInTheDocument();
|
|
54
|
+
expect(screen.getByText("Option 2")).toBeInTheDocument();
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
test("Selects multiple items", async () => {
|
|
58
|
+
const { user } = setupTest();
|
|
59
|
+
const trigger = screen.getByRole("combobox");
|
|
60
|
+
|
|
61
|
+
await user.click(trigger);
|
|
62
|
+
// Click on options in dropdown
|
|
63
|
+
const options = screen.getAllByRole("option");
|
|
64
|
+
await user.click(options[0]); // Option 1
|
|
65
|
+
await user.click(options[2]); // Option 3
|
|
66
|
+
|
|
67
|
+
// Both tags should be visible (may have duplicates due to dropdown still open)
|
|
68
|
+
expect(screen.getAllByText("Option 1").length).toBeGreaterThanOrEqual(1);
|
|
69
|
+
expect(screen.getAllByText("Option 3").length).toBeGreaterThanOrEqual(1);
|
|
70
|
+
});
|
|
71
|
+
|
|
72
|
+
test("Dropdown stays open after selection", async () => {
|
|
73
|
+
const { user } = setupTest();
|
|
74
|
+
const trigger = screen.getByRole("combobox");
|
|
75
|
+
|
|
76
|
+
await user.click(trigger);
|
|
77
|
+
await user.click(screen.getByText("Option 1"));
|
|
78
|
+
|
|
79
|
+
// Dropdown should still be open for multi-select
|
|
80
|
+
expect(screen.getByRole("listbox")).toBeInTheDocument();
|
|
81
|
+
});
|
|
82
|
+
|
|
83
|
+
test("Shows selected values as tags", () => {
|
|
84
|
+
setupTest({
|
|
85
|
+
value: ["opt1", "opt2"],
|
|
86
|
+
});
|
|
87
|
+
expect(screen.getByText("Option 1")).toBeInTheDocument();
|
|
88
|
+
expect(screen.getByText("Option 2")).toBeInTheDocument();
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
test("Removes item when clicking tag remove button", async () => {
|
|
92
|
+
const { user } = setupTest({
|
|
93
|
+
value: ["opt1", "opt2"],
|
|
94
|
+
});
|
|
95
|
+
|
|
96
|
+
// Find the remove button for Option 1
|
|
97
|
+
const removeButtons = screen.getAllByRole("button", { name: /remove/i });
|
|
98
|
+
await user.click(removeButtons[0]);
|
|
99
|
+
|
|
100
|
+
// Option 1 should be removed, Option 2 should remain
|
|
101
|
+
expect(screen.queryByText("Option 1")).not.toBeInTheDocument();
|
|
102
|
+
expect(screen.getByText("Option 2")).toBeInTheDocument();
|
|
103
|
+
});
|
|
104
|
+
|
|
105
|
+
test("Clears all selections when clicking clear button", async () => {
|
|
106
|
+
const { user } = setupTest({
|
|
107
|
+
value: ["opt1", "opt2", "opt3"],
|
|
108
|
+
placeholder: "Select options",
|
|
109
|
+
});
|
|
110
|
+
|
|
111
|
+
const clearButton = screen.getByRole("button", { name: /clear all/i });
|
|
112
|
+
await user.click(clearButton);
|
|
113
|
+
|
|
114
|
+
expect(screen.getByText("Select options")).toBeInTheDocument();
|
|
115
|
+
expect(screen.queryByText("Option 1")).not.toBeInTheDocument();
|
|
116
|
+
});
|
|
117
|
+
|
|
118
|
+
test("Hides clear button when hideClear is true", () => {
|
|
119
|
+
setupTest({
|
|
120
|
+
value: ["opt1"],
|
|
121
|
+
hideClear: true,
|
|
122
|
+
});
|
|
123
|
+
expect(screen.queryByRole("button", { name: /clear all/i })).not.toBeInTheDocument();
|
|
124
|
+
});
|
|
125
|
+
|
|
126
|
+
test("Dispatches change event on selection", async () => {
|
|
127
|
+
const changeSpy = vi.fn();
|
|
128
|
+
const { user } = setupTest({
|
|
129
|
+
onchange: changeSpy,
|
|
130
|
+
});
|
|
131
|
+
|
|
132
|
+
const trigger = screen.getByRole("combobox");
|
|
133
|
+
await user.click(trigger);
|
|
134
|
+
await user.click(screen.getByText("Option 2"));
|
|
135
|
+
|
|
136
|
+
expect(changeSpy).toHaveBeenCalled();
|
|
137
|
+
expect(changeSpy.mock.calls[0][0].value).toContain("opt2");
|
|
138
|
+
});
|
|
139
|
+
|
|
140
|
+
test("Shows required indicator when required", () => {
|
|
141
|
+
setupTest({
|
|
142
|
+
label: "Required Field",
|
|
143
|
+
required: true,
|
|
144
|
+
});
|
|
145
|
+
expect(screen.getByText("*")).toBeInTheDocument();
|
|
146
|
+
});
|
|
147
|
+
|
|
148
|
+
test("Displays error state", () => {
|
|
149
|
+
setupTest({
|
|
150
|
+
error: "Please select at least one option",
|
|
151
|
+
});
|
|
152
|
+
expect(screen.getByText("Please select at least one option")).toBeInTheDocument();
|
|
153
|
+
});
|
|
154
|
+
|
|
155
|
+
test("Disables multiselect when disabled prop is true", async () => {
|
|
156
|
+
const { user } = setupTest({
|
|
157
|
+
disabled: true,
|
|
158
|
+
});
|
|
159
|
+
const trigger = screen.getByRole("combobox");
|
|
160
|
+
|
|
161
|
+
expect(trigger).toHaveAttribute("aria-disabled", "true");
|
|
162
|
+
await user.click(trigger);
|
|
163
|
+
expect(screen.queryByRole("listbox")).not.toBeInTheDocument();
|
|
164
|
+
});
|
|
165
|
+
|
|
166
|
+
test("Navigates options with keyboard", async () => {
|
|
167
|
+
const { user } = setupTest();
|
|
168
|
+
const trigger = screen.getByRole("combobox");
|
|
169
|
+
|
|
170
|
+
await user.click(trigger);
|
|
171
|
+
await user.keyboard("{ArrowDown}");
|
|
172
|
+
await user.keyboard("{Enter}");
|
|
173
|
+
|
|
174
|
+
// First option should be selected
|
|
175
|
+
expect(screen.getByText("Option 1")).toBeInTheDocument();
|
|
176
|
+
});
|
|
177
|
+
|
|
178
|
+
test("Closes dropdown on Escape key", async () => {
|
|
179
|
+
const { user } = setupTest();
|
|
180
|
+
const trigger = screen.getByRole("combobox");
|
|
181
|
+
|
|
182
|
+
await user.click(trigger);
|
|
183
|
+
expect(screen.getByRole("listbox")).toBeInTheDocument();
|
|
184
|
+
|
|
185
|
+
await user.keyboard("{Escape}");
|
|
186
|
+
expect(screen.queryByRole("listbox")).not.toBeInTheDocument();
|
|
187
|
+
});
|
|
188
|
+
|
|
189
|
+
test("Toggles item off when clicking selected item", async () => {
|
|
190
|
+
const { user } = setupTest({
|
|
191
|
+
value: ["opt1"],
|
|
192
|
+
placeholder: "Select options",
|
|
193
|
+
});
|
|
194
|
+
const trigger = screen.getByRole("combobox");
|
|
195
|
+
|
|
196
|
+
await user.click(trigger);
|
|
197
|
+
|
|
198
|
+
// Click Option 1 to deselect it
|
|
199
|
+
const option1 = screen.getByRole("option", { name: /option 1/i });
|
|
200
|
+
await user.click(option1);
|
|
201
|
+
|
|
202
|
+
// Should show placeholder now
|
|
203
|
+
expect(screen.getByText("Select options")).toBeInTheDocument();
|
|
204
|
+
});
|
|
205
|
+
|
|
206
|
+
test("Applies animate focus class by default", () => {
|
|
207
|
+
setupTest();
|
|
208
|
+
const trigger = screen.getByRole("combobox");
|
|
209
|
+
expect(trigger).toHaveClass("multiselect-animate-focus");
|
|
210
|
+
});
|
|
211
|
+
|
|
212
|
+
test("Does not apply animate focus when disabled", () => {
|
|
213
|
+
setupTest({
|
|
214
|
+
animateFocus: false,
|
|
215
|
+
});
|
|
216
|
+
const trigger = screen.getByRole("combobox");
|
|
217
|
+
expect(trigger).not.toHaveClass("multiselect-animate-focus");
|
|
218
|
+
});
|
|
219
|
+
|
|
220
|
+
test("Shows checkbox for each option", async () => {
|
|
221
|
+
const { user } = setupTest();
|
|
222
|
+
const trigger = screen.getByRole("combobox");
|
|
223
|
+
|
|
224
|
+
await user.click(trigger);
|
|
225
|
+
|
|
226
|
+
// Each option should have a checkbox element
|
|
227
|
+
const options = screen.getAllByRole("option");
|
|
228
|
+
options.forEach(option => {
|
|
229
|
+
expect(option.querySelector(".multiselect-checkbox")).toBeInTheDocument();
|
|
230
|
+
});
|
|
231
|
+
});
|
|
232
|
+
|
|
233
|
+
test("Shows checked checkbox for selected items", async () => {
|
|
234
|
+
const { user } = setupTest({
|
|
235
|
+
value: ["opt1"],
|
|
236
|
+
});
|
|
237
|
+
const trigger = screen.getByRole("combobox");
|
|
238
|
+
|
|
239
|
+
await user.click(trigger);
|
|
240
|
+
|
|
241
|
+
const selectedOption = screen.getByRole("option", { name: /option 1/i });
|
|
242
|
+
expect(selectedOption.querySelector(".multiselect-checkbox-checked")).toBeInTheDocument();
|
|
243
|
+
});
|
|
244
|
+
|
|
245
|
+
test("Sets aria-multiselectable on listbox", async () => {
|
|
246
|
+
const { user } = setupTest();
|
|
247
|
+
const trigger = screen.getByRole("combobox");
|
|
248
|
+
|
|
249
|
+
await user.click(trigger);
|
|
250
|
+
|
|
251
|
+
const listbox = screen.getByRole("listbox");
|
|
252
|
+
expect(listbox).toHaveAttribute("aria-multiselectable", "true");
|
|
253
|
+
});
|
|
254
|
+
|
|
255
|
+
test("Initializes empty value as array", () => {
|
|
256
|
+
setupTest({
|
|
257
|
+
value: null,
|
|
258
|
+
placeholder: "Select options",
|
|
259
|
+
});
|
|
260
|
+
// Should not crash and show placeholder
|
|
261
|
+
expect(screen.getByText("Select options")).toBeInTheDocument();
|
|
262
|
+
});
|
|
263
|
+
});
|