@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,141 +1,141 @@
|
|
|
1
|
-
<script>
|
|
2
|
-
/**
|
|
3
|
-
* Toggle Component - Flowbite Native
|
|
4
|
-
* Migrated to Svelte 5 runes
|
|
5
|
-
*
|
|
6
|
-
* Note: Uses CSS style block for pseudo-element styling instead of Tailwind
|
|
7
|
-
* after: classes, because Tailwind v4 doesn't generate after: classes from
|
|
8
|
-
* node_modules when this component is consumed by other apps.
|
|
9
|
-
*
|
|
10
|
-
* Haptic Feedback:
|
|
11
|
-
* - Selection haptic on state change (very light, tactile confirmation)
|
|
12
|
-
*/
|
|
13
|
-
import { triggerHaptic } from '../utils/haptic.js';
|
|
14
|
-
|
|
15
|
-
/** @type {{
|
|
16
|
-
checked?: boolean,
|
|
17
|
-
disabled?: boolean,
|
|
18
|
-
size?: 'sm' | 'md' | 'lg',
|
|
19
|
-
haptic?: boolean,
|
|
20
|
-
class?: string,
|
|
21
|
-
onchange?: (detail: { checked: boolean }) => void,
|
|
22
|
-
children?: import('svelte').Snippet,
|
|
23
|
-
}} */
|
|
24
|
-
let {
|
|
25
|
-
checked = $bindable(false),
|
|
26
|
-
disabled = false,
|
|
27
|
-
size = 'md',
|
|
28
|
-
haptic = true,
|
|
29
|
-
class: className = '',
|
|
30
|
-
onchange,
|
|
31
|
-
children,
|
|
32
|
-
...restProps
|
|
33
|
-
} = $props();
|
|
34
|
-
|
|
35
|
-
function handleChange(event) {
|
|
36
|
-
checked = event.target.checked;
|
|
37
|
-
// Haptic feedback on toggle change (QOL Bible)
|
|
38
|
-
if (haptic && !disabled) {
|
|
39
|
-
triggerHaptic('selection');
|
|
40
|
-
}
|
|
41
|
-
onchange?.({ checked });
|
|
42
|
-
}
|
|
43
|
-
</script>
|
|
44
|
-
|
|
45
|
-
<label class="inline-flex items-center {disabled ? 'cursor-not-allowed opacity-50' : 'cursor-pointer'} {className}" {...restProps}>
|
|
46
|
-
<input
|
|
47
|
-
type="checkbox"
|
|
48
|
-
bind:checked
|
|
49
|
-
{disabled}
|
|
50
|
-
onchange={handleChange}
|
|
51
|
-
class="sr-only peer"
|
|
52
|
-
/>
|
|
53
|
-
<div
|
|
54
|
-
class="toggle-track toggle-{size} relative bg-gray-200 peer-focus:outline-hidden peer-focus:ring-4 peer-focus:ring-blue-300 dark:peer-focus:ring-blue-800 rounded-full peer dark:bg-gray-700 peer-checked:bg-blue-600"
|
|
55
|
-
role="switch"
|
|
56
|
-
aria-checked={checked}
|
|
57
|
-
></div>
|
|
58
|
-
{#if children}
|
|
59
|
-
<span class="ms-3 text-sm font-medium text-gray-900 dark:text-gray-300">
|
|
60
|
-
{#if typeof children === 'function'}{@render children()}{:else}{children}{/if}
|
|
61
|
-
</span>
|
|
62
|
-
{/if}
|
|
63
|
-
</label>
|
|
64
|
-
|
|
65
|
-
<style>
|
|
66
|
-
/*
|
|
67
|
-
* Toggle track sizes (replaces Tailwind w-* h-* classes)
|
|
68
|
-
* Using CSS instead of Tailwind because these need to work in consuming apps
|
|
69
|
-
*/
|
|
70
|
-
.toggle-sm {
|
|
71
|
-
width: 2.25rem; /* w-9 = 36px */
|
|
72
|
-
height: 1.25rem; /* h-5 = 20px */
|
|
73
|
-
}
|
|
74
|
-
.toggle-md {
|
|
75
|
-
width: 2.75rem; /* w-11 = 44px */
|
|
76
|
-
height: 1.5rem; /* h-6 = 24px */
|
|
77
|
-
}
|
|
78
|
-
.toggle-lg {
|
|
79
|
-
width: 3.5rem; /* w-14 = 56px */
|
|
80
|
-
height: 1.75rem; /* h-7 = 28px */
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
/*
|
|
84
|
-
* Toggle thumb (the white circle) - uses ::after pseudo-element
|
|
85
|
-
* Tailwind v4 doesn't generate after: classes from node_modules,
|
|
86
|
-
* so we use explicit CSS here.
|
|
87
|
-
*/
|
|
88
|
-
.toggle-track::after {
|
|
89
|
-
content: '';
|
|
90
|
-
position: absolute;
|
|
91
|
-
background-color: white;
|
|
92
|
-
border: 1px solid #d1d5db; /* gray-300 */
|
|
93
|
-
border-radius: 9999px;
|
|
94
|
-
transition: all 150ms;
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
/* Thumb sizes for each toggle size */
|
|
98
|
-
.toggle-sm::after {
|
|
99
|
-
width: 1rem; /* 16px */
|
|
100
|
-
height: 1rem;
|
|
101
|
-
top: 0.125rem; /* 2px */
|
|
102
|
-
inset-inline-start: 0.125rem;
|
|
103
|
-
}
|
|
104
|
-
.toggle-md::after {
|
|
105
|
-
width: 1.25rem; /* 20px */
|
|
106
|
-
height: 1.25rem;
|
|
107
|
-
top: 0.125rem;
|
|
108
|
-
inset-inline-start: 0.125rem;
|
|
109
|
-
}
|
|
110
|
-
.toggle-lg::after {
|
|
111
|
-
width: 1.5rem; /* 24px */
|
|
112
|
-
height: 1.5rem;
|
|
113
|
-
top: 0.125rem;
|
|
114
|
-
inset-inline-start: 0.125rem;
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
/* Checked state - move thumb to the right */
|
|
118
|
-
:global(input.peer:checked) + .toggle-sm::after {
|
|
119
|
-
transform: translateX(1rem); /* 16px */
|
|
120
|
-
border-color: white;
|
|
121
|
-
}
|
|
122
|
-
:global(input.peer:checked) + .toggle-md::after {
|
|
123
|
-
transform: translateX(1.25rem); /* 20px */
|
|
124
|
-
border-color: white;
|
|
125
|
-
}
|
|
126
|
-
:global(input.peer:checked) + .toggle-lg::after {
|
|
127
|
-
transform: translateX(1.5rem); /* 24px */
|
|
128
|
-
border-color: white;
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
/* RTL support - translate in opposite direction */
|
|
132
|
-
:global([dir="rtl"]) :global(input.peer:checked) + .toggle-sm::after {
|
|
133
|
-
transform: translateX(-1rem);
|
|
134
|
-
}
|
|
135
|
-
:global([dir="rtl"]) :global(input.peer:checked) + .toggle-md::after {
|
|
136
|
-
transform: translateX(-1.25rem);
|
|
137
|
-
}
|
|
138
|
-
:global([dir="rtl"]) :global(input.peer:checked) + .toggle-lg::after {
|
|
139
|
-
transform: translateX(-1.5rem);
|
|
140
|
-
}
|
|
141
|
-
</style>
|
|
1
|
+
<script>
|
|
2
|
+
/**
|
|
3
|
+
* Toggle Component - Flowbite Native
|
|
4
|
+
* Migrated to Svelte 5 runes
|
|
5
|
+
*
|
|
6
|
+
* Note: Uses CSS style block for pseudo-element styling instead of Tailwind
|
|
7
|
+
* after: classes, because Tailwind v4 doesn't generate after: classes from
|
|
8
|
+
* node_modules when this component is consumed by other apps.
|
|
9
|
+
*
|
|
10
|
+
* Haptic Feedback:
|
|
11
|
+
* - Selection haptic on state change (very light, tactile confirmation)
|
|
12
|
+
*/
|
|
13
|
+
import { triggerHaptic } from '../utils/haptic.js';
|
|
14
|
+
|
|
15
|
+
/** @type {{
|
|
16
|
+
checked?: boolean,
|
|
17
|
+
disabled?: boolean,
|
|
18
|
+
size?: 'sm' | 'md' | 'lg',
|
|
19
|
+
haptic?: boolean,
|
|
20
|
+
class?: string,
|
|
21
|
+
onchange?: (detail: { checked: boolean }) => void,
|
|
22
|
+
children?: import('svelte').Snippet,
|
|
23
|
+
}} */
|
|
24
|
+
let {
|
|
25
|
+
checked = $bindable(false),
|
|
26
|
+
disabled = false,
|
|
27
|
+
size = 'md',
|
|
28
|
+
haptic = true,
|
|
29
|
+
class: className = '',
|
|
30
|
+
onchange,
|
|
31
|
+
children,
|
|
32
|
+
...restProps
|
|
33
|
+
} = $props();
|
|
34
|
+
|
|
35
|
+
function handleChange(event) {
|
|
36
|
+
checked = event.target.checked;
|
|
37
|
+
// Haptic feedback on toggle change (QOL Bible)
|
|
38
|
+
if (haptic && !disabled) {
|
|
39
|
+
triggerHaptic('selection');
|
|
40
|
+
}
|
|
41
|
+
onchange?.({ checked });
|
|
42
|
+
}
|
|
43
|
+
</script>
|
|
44
|
+
|
|
45
|
+
<label class="inline-flex items-center {disabled ? 'cursor-not-allowed opacity-50' : 'cursor-pointer'} {className}" {...restProps}>
|
|
46
|
+
<input
|
|
47
|
+
type="checkbox"
|
|
48
|
+
bind:checked
|
|
49
|
+
{disabled}
|
|
50
|
+
onchange={handleChange}
|
|
51
|
+
class="sr-only peer"
|
|
52
|
+
/>
|
|
53
|
+
<div
|
|
54
|
+
class="toggle-track toggle-{size} relative bg-gray-200 peer-focus:outline-hidden peer-focus:ring-4 peer-focus:ring-blue-300 dark:peer-focus:ring-blue-800 rounded-full peer dark:bg-gray-700 peer-checked:bg-blue-600"
|
|
55
|
+
role="switch"
|
|
56
|
+
aria-checked={checked}
|
|
57
|
+
></div>
|
|
58
|
+
{#if children}
|
|
59
|
+
<span class="ms-3 text-sm font-medium text-gray-900 dark:text-gray-300">
|
|
60
|
+
{#if typeof children === 'function'}{@render children()}{:else}{children}{/if}
|
|
61
|
+
</span>
|
|
62
|
+
{/if}
|
|
63
|
+
</label>
|
|
64
|
+
|
|
65
|
+
<style>
|
|
66
|
+
/*
|
|
67
|
+
* Toggle track sizes (replaces Tailwind w-* h-* classes)
|
|
68
|
+
* Using CSS instead of Tailwind because these need to work in consuming apps
|
|
69
|
+
*/
|
|
70
|
+
.toggle-sm {
|
|
71
|
+
width: 2.25rem; /* w-9 = 36px */
|
|
72
|
+
height: 1.25rem; /* h-5 = 20px */
|
|
73
|
+
}
|
|
74
|
+
.toggle-md {
|
|
75
|
+
width: 2.75rem; /* w-11 = 44px */
|
|
76
|
+
height: 1.5rem; /* h-6 = 24px */
|
|
77
|
+
}
|
|
78
|
+
.toggle-lg {
|
|
79
|
+
width: 3.5rem; /* w-14 = 56px */
|
|
80
|
+
height: 1.75rem; /* h-7 = 28px */
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
/*
|
|
84
|
+
* Toggle thumb (the white circle) - uses ::after pseudo-element
|
|
85
|
+
* Tailwind v4 doesn't generate after: classes from node_modules,
|
|
86
|
+
* so we use explicit CSS here.
|
|
87
|
+
*/
|
|
88
|
+
.toggle-track::after {
|
|
89
|
+
content: '';
|
|
90
|
+
position: absolute;
|
|
91
|
+
background-color: white;
|
|
92
|
+
border: 1px solid #d1d5db; /* gray-300 */
|
|
93
|
+
border-radius: 9999px;
|
|
94
|
+
transition: all 150ms;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
/* Thumb sizes for each toggle size */
|
|
98
|
+
.toggle-sm::after {
|
|
99
|
+
width: 1rem; /* 16px */
|
|
100
|
+
height: 1rem;
|
|
101
|
+
top: 0.125rem; /* 2px */
|
|
102
|
+
inset-inline-start: 0.125rem;
|
|
103
|
+
}
|
|
104
|
+
.toggle-md::after {
|
|
105
|
+
width: 1.25rem; /* 20px */
|
|
106
|
+
height: 1.25rem;
|
|
107
|
+
top: 0.125rem;
|
|
108
|
+
inset-inline-start: 0.125rem;
|
|
109
|
+
}
|
|
110
|
+
.toggle-lg::after {
|
|
111
|
+
width: 1.5rem; /* 24px */
|
|
112
|
+
height: 1.5rem;
|
|
113
|
+
top: 0.125rem;
|
|
114
|
+
inset-inline-start: 0.125rem;
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
/* Checked state - move thumb to the right */
|
|
118
|
+
:global(input.peer:checked) + .toggle-sm::after {
|
|
119
|
+
transform: translateX(1rem); /* 16px */
|
|
120
|
+
border-color: white;
|
|
121
|
+
}
|
|
122
|
+
:global(input.peer:checked) + .toggle-md::after {
|
|
123
|
+
transform: translateX(1.25rem); /* 20px */
|
|
124
|
+
border-color: white;
|
|
125
|
+
}
|
|
126
|
+
:global(input.peer:checked) + .toggle-lg::after {
|
|
127
|
+
transform: translateX(1.5rem); /* 24px */
|
|
128
|
+
border-color: white;
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
/* RTL support - translate in opposite direction */
|
|
132
|
+
:global([dir="rtl"]) :global(input.peer:checked) + .toggle-sm::after {
|
|
133
|
+
transform: translateX(-1rem);
|
|
134
|
+
}
|
|
135
|
+
:global([dir="rtl"]) :global(input.peer:checked) + .toggle-md::after {
|
|
136
|
+
transform: translateX(-1.25rem);
|
|
137
|
+
}
|
|
138
|
+
:global([dir="rtl"]) :global(input.peer:checked) + .toggle-lg::after {
|
|
139
|
+
transform: translateX(-1.5rem);
|
|
140
|
+
}
|
|
141
|
+
</style>
|
|
@@ -1,30 +1,30 @@
|
|
|
1
|
-
<script>
|
|
2
|
-
import Toggle from "./Toggle.svelte";
|
|
3
|
-
|
|
4
|
-
/** @type {{
|
|
5
|
-
checked?: boolean,
|
|
6
|
-
disabled?: boolean,
|
|
7
|
-
size?: 'sm' | 'md' | 'lg',
|
|
8
|
-
haptic?: boolean,
|
|
9
|
-
class?: string,
|
|
10
|
-
onchange?: (detail: { checked: boolean }) => void,
|
|
11
|
-
label?: string,
|
|
12
|
-
showLabel?: boolean,
|
|
13
|
-
}} */
|
|
14
|
-
let {
|
|
15
|
-
checked = $bindable(false),
|
|
16
|
-
disabled = false,
|
|
17
|
-
size = 'md',
|
|
18
|
-
haptic = true,
|
|
19
|
-
class: className = '',
|
|
20
|
-
onchange,
|
|
21
|
-
label = 'Toggle Label',
|
|
22
|
-
showLabel = false,
|
|
23
|
-
} = $props();
|
|
24
|
-
</script>
|
|
25
|
-
|
|
26
|
-
<Toggle bind:checked {disabled} {size} {haptic} class={className} {onchange}>
|
|
27
|
-
{#if showLabel}
|
|
28
|
-
<span>{label}</span>
|
|
29
|
-
{/if}
|
|
30
|
-
</Toggle>
|
|
1
|
+
<script>
|
|
2
|
+
import Toggle from "./Toggle.svelte";
|
|
3
|
+
|
|
4
|
+
/** @type {{
|
|
5
|
+
checked?: boolean,
|
|
6
|
+
disabled?: boolean,
|
|
7
|
+
size?: 'sm' | 'md' | 'lg',
|
|
8
|
+
haptic?: boolean,
|
|
9
|
+
class?: string,
|
|
10
|
+
onchange?: (detail: { checked: boolean }) => void,
|
|
11
|
+
label?: string,
|
|
12
|
+
showLabel?: boolean,
|
|
13
|
+
}} */
|
|
14
|
+
let {
|
|
15
|
+
checked = $bindable(false),
|
|
16
|
+
disabled = false,
|
|
17
|
+
size = 'md',
|
|
18
|
+
haptic = true,
|
|
19
|
+
class: className = '',
|
|
20
|
+
onchange,
|
|
21
|
+
label = 'Toggle Label',
|
|
22
|
+
showLabel = false,
|
|
23
|
+
} = $props();
|
|
24
|
+
</script>
|
|
25
|
+
|
|
26
|
+
<Toggle bind:checked {disabled} {size} {haptic} class={className} {onchange}>
|
|
27
|
+
{#if showLabel}
|
|
28
|
+
<span>{label}</span>
|
|
29
|
+
{/if}
|
|
30
|
+
</Toggle>
|
|
@@ -1,126 +1,126 @@
|
|
|
1
|
-
import { render, fireEvent } from '@testing-library/svelte';
|
|
2
|
-
import { createRawSnippet } from 'svelte';
|
|
3
|
-
import { expect, describe, test } from 'vitest';
|
|
4
|
-
import Tooltip from './Tooltip.svelte';
|
|
5
|
-
|
|
6
|
-
function textSnippet(text) {
|
|
7
|
-
return createRawSnippet(() => ({
|
|
8
|
-
render: () => `<span>${text}</span>`
|
|
9
|
-
}));
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
describe('Tooltip', () => {
|
|
13
|
-
test('renders wrapper div with role tooltip', () => {
|
|
14
|
-
const { container } = render(Tooltip, { props: { content: 'Help text' } });
|
|
15
|
-
expect(container.querySelector('[role="tooltip"]')).toBeInTheDocument();
|
|
16
|
-
});
|
|
17
|
-
|
|
18
|
-
test('tooltip popup is hidden by default', () => {
|
|
19
|
-
const { container } = render(Tooltip, { props: { content: 'Help text' } });
|
|
20
|
-
expect(container.querySelector('.z-50')).not.toBeInTheDocument();
|
|
21
|
-
});
|
|
22
|
-
|
|
23
|
-
test('shows tooltip on mouseenter', async () => {
|
|
24
|
-
const { container } = render(Tooltip, { props: { content: 'Help text' } });
|
|
25
|
-
const wrapper = container.querySelector('[role="tooltip"]');
|
|
26
|
-
await fireEvent.mouseEnter(wrapper);
|
|
27
|
-
expect(container.textContent).toContain('Help text');
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
test('mouseenter then mouseleave fires handlers', async () => {
|
|
31
|
-
const { container } = render(Tooltip, { props: { content: 'Help text' } });
|
|
32
|
-
const wrapper = container.querySelector('[role="tooltip"]');
|
|
33
|
-
await fireEvent.mouseEnter(wrapper);
|
|
34
|
-
expect(container.querySelector('.z-50')).toBeInTheDocument();
|
|
35
|
-
// mouseleave triggers hide; transition may keep element but handler fires
|
|
36
|
-
await fireEvent.mouseLeave(wrapper);
|
|
37
|
-
expect(wrapper).toBeInTheDocument();
|
|
38
|
-
});
|
|
39
|
-
|
|
40
|
-
test('shows tooltip on focus', async () => {
|
|
41
|
-
const { container } = render(Tooltip, { props: { content: 'Focus text' } });
|
|
42
|
-
const wrapper = container.querySelector('[role="tooltip"]');
|
|
43
|
-
await fireEvent.focus(wrapper);
|
|
44
|
-
expect(container.textContent).toContain('Focus text');
|
|
45
|
-
});
|
|
46
|
-
|
|
47
|
-
test('blur fires hide handler', async () => {
|
|
48
|
-
const { container } = render(Tooltip, { props: { content: 'Blur text' } });
|
|
49
|
-
const wrapper = container.querySelector('[role="tooltip"]');
|
|
50
|
-
await fireEvent.focus(wrapper);
|
|
51
|
-
expect(container.querySelector('.z-50')).toBeInTheDocument();
|
|
52
|
-
await fireEvent.blur(wrapper);
|
|
53
|
-
// Handler is invoked, wrapper still in DOM
|
|
54
|
-
expect(wrapper).toBeInTheDocument();
|
|
55
|
-
});
|
|
56
|
-
|
|
57
|
-
test('does not show tooltip when content is empty', async () => {
|
|
58
|
-
const { container } = render(Tooltip, { props: { content: '' } });
|
|
59
|
-
const wrapper = container.querySelector('[role="tooltip"]');
|
|
60
|
-
await fireEvent.mouseEnter(wrapper);
|
|
61
|
-
expect(container.querySelector('.z-50')).not.toBeInTheDocument();
|
|
62
|
-
});
|
|
63
|
-
|
|
64
|
-
test('applies custom className to tooltip popup', async () => {
|
|
65
|
-
const { container } = render(Tooltip, { props: { content: 'Test', class: 'my-tip' } });
|
|
66
|
-
const wrapper = container.querySelector('[role="tooltip"]');
|
|
67
|
-
await fireEvent.mouseEnter(wrapper);
|
|
68
|
-
expect(container.querySelector('.my-tip')).toBeInTheDocument();
|
|
69
|
-
});
|
|
70
|
-
|
|
71
|
-
test('has relative inline-block wrapper', () => {
|
|
72
|
-
const { container } = render(Tooltip, { props: { content: 'Text' } });
|
|
73
|
-
expect(container.querySelector('.relative.inline-block')).toBeInTheDocument();
|
|
74
|
-
});
|
|
75
|
-
|
|
76
|
-
test('tooltip has arrow element', async () => {
|
|
77
|
-
const { container } = render(Tooltip, { props: { content: 'Arrow test' } });
|
|
78
|
-
await fireEvent.mouseEnter(container.querySelector('[role="tooltip"]'));
|
|
79
|
-
expect(container.querySelector('.border-4')).toBeInTheDocument();
|
|
80
|
-
});
|
|
81
|
-
|
|
82
|
-
test('renders children trigger content when provided', () => {
|
|
83
|
-
const { container } = render(Tooltip, {
|
|
84
|
-
props: { content: 'Tip text', children: textSnippet('Hover me') }
|
|
85
|
-
});
|
|
86
|
-
const wrapper = container.querySelector('[role="tooltip"]');
|
|
87
|
-
expect(wrapper.textContent).toContain('Hover me');
|
|
88
|
-
});
|
|
89
|
-
|
|
90
|
-
test('renders empty trigger area when no children provided', () => {
|
|
91
|
-
const { container } = render(Tooltip, { props: { content: 'Tip text' } });
|
|
92
|
-
const wrapper = container.querySelector('[role="tooltip"]');
|
|
93
|
-
// Whitespace may be present from template formatting
|
|
94
|
-
expect(wrapper.textContent.trim()).toBe('');
|
|
95
|
-
});
|
|
96
|
-
|
|
97
|
-
test('placement bottom applies correct positioning', async () => {
|
|
98
|
-
const { container } = render(Tooltip, {
|
|
99
|
-
props: { content: 'Bottom tip', placement: 'bottom' }
|
|
100
|
-
});
|
|
101
|
-
const wrapper = container.querySelector('[role="tooltip"]');
|
|
102
|
-
await fireEvent.mouseEnter(wrapper);
|
|
103
|
-
const popup = container.querySelector('.z-50');
|
|
104
|
-
expect(popup.className).toContain('top-full');
|
|
105
|
-
});
|
|
106
|
-
|
|
107
|
-
test('placement left applies correct positioning', async () => {
|
|
108
|
-
const { container } = render(Tooltip, {
|
|
109
|
-
props: { content: 'Left tip', placement: 'left' }
|
|
110
|
-
});
|
|
111
|
-
const wrapper = container.querySelector('[role="tooltip"]');
|
|
112
|
-
await fireEvent.mouseEnter(wrapper);
|
|
113
|
-
const popup = container.querySelector('.z-50');
|
|
114
|
-
expect(popup.className).toContain('right-full');
|
|
115
|
-
});
|
|
116
|
-
|
|
117
|
-
test('placement right applies correct positioning', async () => {
|
|
118
|
-
const { container } = render(Tooltip, {
|
|
119
|
-
props: { content: 'Right tip', placement: 'right' }
|
|
120
|
-
});
|
|
121
|
-
const wrapper = container.querySelector('[role="tooltip"]');
|
|
122
|
-
await fireEvent.mouseEnter(wrapper);
|
|
123
|
-
const popup = container.querySelector('.z-50');
|
|
124
|
-
expect(popup.className).toContain('left-full');
|
|
125
|
-
});
|
|
126
|
-
});
|
|
1
|
+
import { render, fireEvent } from '@testing-library/svelte';
|
|
2
|
+
import { createRawSnippet } from 'svelte';
|
|
3
|
+
import { expect, describe, test } from 'vitest';
|
|
4
|
+
import Tooltip from './Tooltip.svelte';
|
|
5
|
+
|
|
6
|
+
function textSnippet(text) {
|
|
7
|
+
return createRawSnippet(() => ({
|
|
8
|
+
render: () => `<span>${text}</span>`
|
|
9
|
+
}));
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
describe('Tooltip', () => {
|
|
13
|
+
test('renders wrapper div with role tooltip', () => {
|
|
14
|
+
const { container } = render(Tooltip, { props: { content: 'Help text' } });
|
|
15
|
+
expect(container.querySelector('[role="tooltip"]')).toBeInTheDocument();
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
test('tooltip popup is hidden by default', () => {
|
|
19
|
+
const { container } = render(Tooltip, { props: { content: 'Help text' } });
|
|
20
|
+
expect(container.querySelector('.z-50')).not.toBeInTheDocument();
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
test('shows tooltip on mouseenter', async () => {
|
|
24
|
+
const { container } = render(Tooltip, { props: { content: 'Help text' } });
|
|
25
|
+
const wrapper = container.querySelector('[role="tooltip"]');
|
|
26
|
+
await fireEvent.mouseEnter(wrapper);
|
|
27
|
+
expect(container.textContent).toContain('Help text');
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
test('mouseenter then mouseleave fires handlers', async () => {
|
|
31
|
+
const { container } = render(Tooltip, { props: { content: 'Help text' } });
|
|
32
|
+
const wrapper = container.querySelector('[role="tooltip"]');
|
|
33
|
+
await fireEvent.mouseEnter(wrapper);
|
|
34
|
+
expect(container.querySelector('.z-50')).toBeInTheDocument();
|
|
35
|
+
// mouseleave triggers hide; transition may keep element but handler fires
|
|
36
|
+
await fireEvent.mouseLeave(wrapper);
|
|
37
|
+
expect(wrapper).toBeInTheDocument();
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
test('shows tooltip on focus', async () => {
|
|
41
|
+
const { container } = render(Tooltip, { props: { content: 'Focus text' } });
|
|
42
|
+
const wrapper = container.querySelector('[role="tooltip"]');
|
|
43
|
+
await fireEvent.focus(wrapper);
|
|
44
|
+
expect(container.textContent).toContain('Focus text');
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
test('blur fires hide handler', async () => {
|
|
48
|
+
const { container } = render(Tooltip, { props: { content: 'Blur text' } });
|
|
49
|
+
const wrapper = container.querySelector('[role="tooltip"]');
|
|
50
|
+
await fireEvent.focus(wrapper);
|
|
51
|
+
expect(container.querySelector('.z-50')).toBeInTheDocument();
|
|
52
|
+
await fireEvent.blur(wrapper);
|
|
53
|
+
// Handler is invoked, wrapper still in DOM
|
|
54
|
+
expect(wrapper).toBeInTheDocument();
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
test('does not show tooltip when content is empty', async () => {
|
|
58
|
+
const { container } = render(Tooltip, { props: { content: '' } });
|
|
59
|
+
const wrapper = container.querySelector('[role="tooltip"]');
|
|
60
|
+
await fireEvent.mouseEnter(wrapper);
|
|
61
|
+
expect(container.querySelector('.z-50')).not.toBeInTheDocument();
|
|
62
|
+
});
|
|
63
|
+
|
|
64
|
+
test('applies custom className to tooltip popup', async () => {
|
|
65
|
+
const { container } = render(Tooltip, { props: { content: 'Test', class: 'my-tip' } });
|
|
66
|
+
const wrapper = container.querySelector('[role="tooltip"]');
|
|
67
|
+
await fireEvent.mouseEnter(wrapper);
|
|
68
|
+
expect(container.querySelector('.my-tip')).toBeInTheDocument();
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
test('has relative inline-block wrapper', () => {
|
|
72
|
+
const { container } = render(Tooltip, { props: { content: 'Text' } });
|
|
73
|
+
expect(container.querySelector('.relative.inline-block')).toBeInTheDocument();
|
|
74
|
+
});
|
|
75
|
+
|
|
76
|
+
test('tooltip has arrow element', async () => {
|
|
77
|
+
const { container } = render(Tooltip, { props: { content: 'Arrow test' } });
|
|
78
|
+
await fireEvent.mouseEnter(container.querySelector('[role="tooltip"]'));
|
|
79
|
+
expect(container.querySelector('.border-4')).toBeInTheDocument();
|
|
80
|
+
});
|
|
81
|
+
|
|
82
|
+
test('renders children trigger content when provided', () => {
|
|
83
|
+
const { container } = render(Tooltip, {
|
|
84
|
+
props: { content: 'Tip text', children: textSnippet('Hover me') }
|
|
85
|
+
});
|
|
86
|
+
const wrapper = container.querySelector('[role="tooltip"]');
|
|
87
|
+
expect(wrapper.textContent).toContain('Hover me');
|
|
88
|
+
});
|
|
89
|
+
|
|
90
|
+
test('renders empty trigger area when no children provided', () => {
|
|
91
|
+
const { container } = render(Tooltip, { props: { content: 'Tip text' } });
|
|
92
|
+
const wrapper = container.querySelector('[role="tooltip"]');
|
|
93
|
+
// Whitespace may be present from template formatting
|
|
94
|
+
expect(wrapper.textContent.trim()).toBe('');
|
|
95
|
+
});
|
|
96
|
+
|
|
97
|
+
test('placement bottom applies correct positioning', async () => {
|
|
98
|
+
const { container } = render(Tooltip, {
|
|
99
|
+
props: { content: 'Bottom tip', placement: 'bottom' }
|
|
100
|
+
});
|
|
101
|
+
const wrapper = container.querySelector('[role="tooltip"]');
|
|
102
|
+
await fireEvent.mouseEnter(wrapper);
|
|
103
|
+
const popup = container.querySelector('.z-50');
|
|
104
|
+
expect(popup.className).toContain('top-full');
|
|
105
|
+
});
|
|
106
|
+
|
|
107
|
+
test('placement left applies correct positioning', async () => {
|
|
108
|
+
const { container } = render(Tooltip, {
|
|
109
|
+
props: { content: 'Left tip', placement: 'left' }
|
|
110
|
+
});
|
|
111
|
+
const wrapper = container.querySelector('[role="tooltip"]');
|
|
112
|
+
await fireEvent.mouseEnter(wrapper);
|
|
113
|
+
const popup = container.querySelector('.z-50');
|
|
114
|
+
expect(popup.className).toContain('right-full');
|
|
115
|
+
});
|
|
116
|
+
|
|
117
|
+
test('placement right applies correct positioning', async () => {
|
|
118
|
+
const { container } = render(Tooltip, {
|
|
119
|
+
props: { content: 'Right tip', placement: 'right' }
|
|
120
|
+
});
|
|
121
|
+
const wrapper = container.querySelector('[role="tooltip"]');
|
|
122
|
+
await fireEvent.mouseEnter(wrapper);
|
|
123
|
+
const popup = container.querySelector('.z-50');
|
|
124
|
+
expect(popup.className).toContain('left-full');
|
|
125
|
+
});
|
|
126
|
+
});
|