@getmicdrop/svelte-components 5.5.1 → 5.5.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/calendar/AboutShow/AboutShow.spec.d.ts +2 -0
- package/dist/calendar/AboutShow/AboutShow.spec.d.ts.map +1 -0
- package/dist/calendar/AboutShow/AboutShow.spec.js +791 -0
- package/dist/calendar/AboutShow/AboutShow.svelte +172 -172
- package/dist/calendar/Calendar/MiniMonthCalendar.spec.d.ts +2 -0
- package/dist/calendar/Calendar/MiniMonthCalendar.spec.d.ts.map +1 -0
- package/dist/calendar/Calendar/MiniMonthCalendar.spec.js +1191 -0
- package/dist/calendar/Calendar/MiniMonthCalendar.svelte +782 -782
- package/dist/calendar/FAQs/FAQs.spec.d.ts +2 -0
- package/dist/calendar/FAQs/FAQs.spec.d.ts.map +1 -0
- package/dist/calendar/FAQs/FAQs.spec.js +238 -0
- package/dist/calendar/FAQs/FAQs.svelte +75 -75
- package/dist/calendar/MonthSwitcher/MonthSwitcher.spec.d.ts +2 -0
- package/dist/calendar/MonthSwitcher/MonthSwitcher.spec.d.ts.map +1 -0
- package/dist/calendar/MonthSwitcher/MonthSwitcher.spec.js +420 -0
- package/dist/calendar/MonthSwitcher/MonthSwitcher.svelte +126 -126
- package/dist/calendar/OrderSummary/OrderSummary.spec.d.ts +2 -0
- package/dist/calendar/OrderSummary/OrderSummary.spec.d.ts.map +1 -0
- package/dist/calendar/OrderSummary/OrderSummary.spec.js +808 -0
- package/dist/calendar/OrderSummary/OrderSummary.svelte +367 -367
- package/dist/calendar/PublicCard/PublicCard.spec.d.ts +2 -0
- package/dist/calendar/PublicCard/PublicCard.spec.d.ts.map +1 -0
- package/dist/calendar/PublicCard/PublicCard.spec.js +301 -0
- package/dist/calendar/PublicCard/PublicCard.svelte +134 -134
- package/dist/calendar/ShowCard/ShowCard.spec.d.ts +2 -0
- package/dist/calendar/ShowCard/ShowCard.spec.d.ts.map +1 -0
- package/dist/calendar/ShowCard/ShowCard.spec.js +714 -0
- package/dist/calendar/ShowCard/ShowCard.svelte +157 -157
- package/dist/calendar/ShowTimeCard/ShowTimeCard.spec.d.ts +2 -0
- package/dist/calendar/ShowTimeCard/ShowTimeCard.spec.d.ts.map +1 -0
- package/dist/calendar/ShowTimeCard/ShowTimeCard.spec.js +241 -0
- package/dist/calendar/ShowTimeCard/ShowTimeCard.svelte +61 -61
- package/dist/components/Layout/Grid.svelte +4 -4
- package/dist/components/Layout/Section.spec.d.ts +2 -0
- package/dist/components/Layout/Section.spec.d.ts.map +1 -0
- package/dist/components/Layout/Section.spec.js +149 -0
- package/dist/components/Layout/Section.svelte +80 -80
- package/dist/components/Layout/Sidebar.spec.d.ts +2 -0
- package/dist/components/Layout/Sidebar.spec.d.ts.map +1 -0
- package/dist/components/Layout/Sidebar.spec.js +186 -0
- package/dist/components/Layout/Sidebar.svelte +108 -108
- package/dist/components/Layout/Stack.spec.js +3 -3
- package/dist/components/Layout/Stack.svelte +6 -6
- package/dist/constants/formOptions.spec.js +9 -5
- package/dist/constants/validation.js +91 -91
- package/dist/constants/validation.spec.js +64 -64
- 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 +124 -2
- package/dist/datetime/parse.js +1 -1
- package/dist/forms/createFieldTracker.spec.d.ts +2 -0
- package/dist/forms/createFieldTracker.spec.d.ts.map +1 -0
- package/dist/forms/createFieldTracker.spec.js +343 -0
- package/dist/forms/createFormStore.spec.d.ts +2 -0
- package/dist/forms/createFormStore.spec.d.ts.map +1 -0
- package/dist/forms/createFormStore.spec.js +689 -0
- package/dist/forms/createFormStore.svelte.js +0 -1
- package/dist/index.d.ts +5 -112
- package/dist/index.js +40 -225
- package/dist/patterns/data/DataGrid.spec.d.ts +2 -0
- package/dist/patterns/data/DataGrid.spec.d.ts.map +1 -0
- package/dist/patterns/data/DataGrid.spec.js +159 -0
- package/dist/patterns/data/DataGrid.svelte +45 -45
- package/dist/patterns/data/DataList.spec.d.ts +2 -0
- package/dist/patterns/data/DataList.spec.d.ts.map +1 -0
- package/dist/patterns/data/DataList.spec.js +158 -0
- package/dist/patterns/data/DataList.svelte +24 -24
- package/dist/patterns/data/DataTable.spec.d.ts +2 -0
- package/dist/patterns/data/DataTable.spec.d.ts.map +1 -0
- package/dist/patterns/data/DataTable.spec.js +196 -0
- package/dist/patterns/data/DataTable.svelte +36 -36
- package/dist/patterns/forms/FormActions.spec.js +95 -88
- package/dist/patterns/forms/FormActions.stories.svelte +97 -97
- package/dist/patterns/forms/FormActions.svelte +46 -46
- package/dist/patterns/forms/FormGrid.spec.d.ts +2 -0
- package/dist/patterns/forms/FormGrid.spec.d.ts.map +1 -0
- package/dist/patterns/forms/FormGrid.spec.js +125 -0
- package/dist/patterns/forms/FormGrid.svelte +33 -33
- package/dist/patterns/forms/FormSection.spec.d.ts +2 -0
- package/dist/patterns/forms/FormSection.spec.d.ts.map +1 -0
- package/dist/patterns/forms/FormSection.spec.js +153 -0
- package/dist/patterns/forms/FormSection.svelte +32 -32
- package/dist/patterns/forms/FormValidationSummary.stories.svelte +83 -83
- package/dist/patterns/forms/FormValidationSummary.svelte +33 -33
- package/dist/patterns/layout/Sidebar.spec.d.ts +2 -0
- package/dist/patterns/layout/Sidebar.spec.d.ts.map +1 -0
- package/dist/patterns/layout/Sidebar.spec.js +159 -0
- package/dist/patterns/layout/Sidebar.svelte +39 -39
- package/dist/patterns/navigation/BottomNav.stories.svelte +117 -117
- package/dist/patterns/navigation/BottomNav.svelte +20 -20
- package/dist/patterns/navigation/Header.spec.js +33 -24
- package/dist/patterns/navigation/Header.stories.svelte +77 -77
- package/dist/patterns/navigation/Header.svelte +193 -193
- package/dist/patterns/page/PageHeader.spec.d.ts +2 -0
- package/dist/patterns/page/PageHeader.spec.d.ts.map +1 -0
- package/dist/patterns/page/PageHeader.spec.js +167 -0
- package/dist/patterns/page/PageHeader.svelte +18 -18
- package/dist/patterns/page/PageLayout.spec.d.ts +2 -0
- package/dist/patterns/page/PageLayout.spec.d.ts.map +1 -0
- package/dist/patterns/page/PageLayout.spec.js +145 -0
- package/dist/patterns/page/PageLayout.svelte +40 -40
- package/dist/patterns/page/PageLoader.spec.js +57 -54
- package/dist/patterns/page/PageLoader.stories.svelte +137 -137
- package/dist/patterns/page/PageLoader.svelte +24 -24
- package/dist/patterns/page/SectionHeader.spec.d.ts +2 -0
- package/dist/patterns/page/SectionHeader.spec.d.ts.map +1 -0
- package/dist/patterns/page/SectionHeader.spec.js +197 -0
- package/dist/patterns/page/SectionHeader.svelte +29 -29
- package/dist/presets/badges.js +112 -112
- package/dist/presets/badges.spec.d.ts +2 -0
- package/dist/presets/badges.spec.d.ts.map +1 -0
- package/dist/presets/badges.spec.js +172 -0
- package/dist/presets/buttons.js +76 -76
- package/dist/presets/buttons.spec.d.ts +2 -0
- package/dist/presets/buttons.spec.d.ts.map +1 -0
- package/dist/presets/buttons.spec.js +135 -0
- package/dist/presets/index.js +9 -9
- package/dist/primitives/Accordion/Accordion.spec.d.ts +2 -0
- package/dist/primitives/Accordion/Accordion.spec.d.ts.map +1 -0
- package/dist/primitives/Accordion/Accordion.spec.js +83 -0
- package/dist/primitives/Accordion/Accordion.stories.svelte +75 -75
- package/dist/primitives/Accordion/Accordion.svelte +42 -42
- package/dist/primitives/Accordion/AccordionItem.spec.d.ts +2 -0
- package/dist/primitives/Accordion/AccordionItem.spec.d.ts.map +1 -0
- package/dist/primitives/Accordion/AccordionItem.spec.js +661 -0
- package/dist/primitives/Accordion/AccordionItem.svelte +95 -95
- package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte +107 -0
- package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte.d.ts +35 -0
- package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte.d.ts.map +1 -0
- package/dist/primitives/Alert/Alert.spec.js +173 -170
- package/dist/primitives/Alert/Alert.stories.svelte +88 -88
- package/dist/primitives/Alert/Alert.svelte +27 -27
- package/dist/primitives/Avatar/Avatar.spec.d.ts +2 -0
- package/dist/primitives/Avatar/Avatar.spec.d.ts.map +1 -0
- package/dist/primitives/Avatar/Avatar.spec.js +211 -0
- package/dist/primitives/Avatar/Avatar.stories.svelte +94 -94
- package/dist/primitives/Avatar/Avatar.svelte +66 -66
- package/dist/primitives/Badges/Badge.spec.js +144 -103
- package/dist/primitives/Badges/Badge.stories.svelte +86 -86
- package/dist/primitives/Badges/Badge.svelte +79 -79
- package/dist/primitives/BottomSheet/BottomSheet.spec.js +136 -127
- package/dist/primitives/BottomSheet/BottomSheet.stories.svelte +83 -83
- package/dist/primitives/BottomSheet/BottomSheet.svelte +100 -100
- package/dist/primitives/BottomSheet/BottomSheetWrapper.test.svelte +13 -0
- package/dist/primitives/BottomSheet/BottomSheetWrapper.test.svelte.d.ts +7 -0
- package/dist/primitives/BottomSheet/BottomSheetWrapper.test.svelte.d.ts.map +1 -0
- package/dist/primitives/Breadcrumb/Breadcrumb.spec.js +122 -120
- package/dist/primitives/Breadcrumb/Breadcrumb.stories.svelte +23 -23
- package/dist/primitives/Breadcrumb/Breadcrumb.svelte +89 -89
- package/dist/primitives/Button/Button.spec.js +223 -211
- package/dist/primitives/Button/Button.stories.svelte +76 -76
- package/dist/primitives/Button/Button.svelte +270 -270
- package/dist/primitives/Button/ButtonSaveDemo.spec.js +146 -48
- package/dist/primitives/Button/ButtonSaveDemo.svelte +25 -25
- package/dist/primitives/Button/ButtonVariantShowcase.spec.d.ts +2 -0
- package/dist/primitives/Button/ButtonVariantShowcase.spec.d.ts.map +1 -0
- package/dist/primitives/Button/ButtonVariantShowcase.spec.js +202 -0
- 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/Checkbox/Checkbox.spec.d.ts +2 -0
- package/dist/primitives/Checkbox/Checkbox.spec.d.ts.map +1 -0
- package/dist/primitives/Checkbox/Checkbox.spec.js +252 -0
- package/dist/primitives/Checkbox/Checkbox.stories.svelte +84 -84
- package/dist/primitives/Checkbox/Checkbox.svelte +88 -88
- package/dist/primitives/DarkModeToggle.spec.js +390 -357
- package/dist/primitives/DarkModeToggle.stories.svelte +57 -57
- package/dist/primitives/DarkModeToggle.svelte +136 -136
- package/dist/primitives/Drawer/Drawer.spec.d.ts +2 -0
- package/dist/primitives/Drawer/Drawer.spec.d.ts.map +1 -0
- package/dist/primitives/Drawer/Drawer.spec.js +212 -0
- package/dist/primitives/Drawer/Drawer.stories.svelte +80 -80
- package/dist/primitives/Drawer/Drawer.svelte +120 -120
- package/dist/primitives/Dropdown/Dropdown.spec.d.ts +2 -0
- package/dist/primitives/Dropdown/Dropdown.spec.d.ts.map +1 -0
- package/dist/primitives/Dropdown/Dropdown.spec.js +366 -0
- package/dist/primitives/Dropdown/Dropdown.stories.svelte +137 -137
- package/dist/primitives/Dropdown/Dropdown.svelte +14 -14
- package/dist/primitives/Dropdown/DropdownItem.spec.d.ts +2 -0
- package/dist/primitives/Dropdown/DropdownItem.spec.d.ts.map +1 -0
- package/dist/primitives/Dropdown/DropdownItem.spec.js +182 -0
- package/dist/primitives/Dropdown/DropdownItem.svelte +80 -80
- package/dist/primitives/Icons/ArrowLeft.svelte +8 -8
- package/dist/primitives/Icons/ArrowRight.svelte +8 -8
- package/dist/primitives/Icons/Availability.svelte +14 -14
- package/dist/primitives/Icons/Back.svelte +14 -14
- package/dist/primitives/Icons/CheckCircle.svelte +6 -6
- package/dist/primitives/Icons/CheckCircleOutline.svelte +15 -15
- package/dist/primitives/Icons/ChevronLeft.svelte +4 -4
- package/dist/primitives/Icons/ChevronRight.svelte +4 -4
- package/dist/primitives/Icons/Copy.svelte +15 -15
- package/dist/primitives/Icons/Cross.svelte +5 -5
- package/dist/primitives/Icons/DownArrow.svelte +8 -8
- package/dist/primitives/Icons/ErrorCircle.svelte +6 -6
- package/dist/primitives/Icons/FacebookIcon.svelte +2 -2
- package/dist/primitives/Icons/Home.svelte +15 -15
- package/dist/primitives/Icons/Icon.spec.js +169 -169
- package/dist/primitives/Icons/Icon.stories.svelte +100 -100
- package/dist/primitives/Icons/Icon.svelte +52 -52
- package/dist/primitives/Icons/IconGallery.stories.svelte +235 -235
- package/dist/primitives/Icons/Info.svelte +7 -7
- package/dist/primitives/Icons/InstagramIcon.svelte +4 -4
- package/dist/primitives/Icons/LogoInstagram.svelte +2 -2
- package/dist/primitives/Icons/Message.svelte +15 -15
- package/dist/primitives/Icons/MoonIcon.svelte +5 -5
- package/dist/primitives/Icons/More.svelte +21 -21
- package/dist/primitives/Icons/MoreHori.spec.js +61 -61
- package/dist/primitives/Icons/MoreHori.svelte +22 -22
- package/dist/primitives/Icons/Notification.svelte +14 -14
- package/dist/primitives/Icons/Payment.svelte +14 -14
- package/dist/primitives/Icons/Profile.svelte +21 -21
- package/dist/primitives/Icons/Reload.svelte +29 -29
- package/dist/primitives/Icons/Shows.svelte +21 -21
- package/dist/primitives/Icons/Signout.svelte +21 -21
- package/dist/primitives/Icons/SunIcon.svelte +8 -8
- package/dist/primitives/Icons/TiktokIcon.svelte +2 -2
- package/dist/primitives/Icons/TwitterIcon.svelte +2 -2
- package/dist/primitives/Icons/WarningIcon.spec.js +18 -18
- package/dist/primitives/Icons/WarningIcon.svelte +5 -5
- package/dist/primitives/Icons/iconTestUtils.spec.d.ts +2 -0
- package/dist/primitives/Icons/iconTestUtils.spec.d.ts.map +1 -0
- package/dist/primitives/Icons/iconTestUtils.spec.js +235 -0
- package/dist/primitives/Input/Input.spec.js +573 -573
- package/dist/primitives/Input/Input.stories.svelte +139 -139
- package/dist/primitives/Input/Input.svelte +384 -397
- package/dist/primitives/Input/Input.svelte.d.ts.map +1 -1
- package/dist/primitives/Input/Select.spec.js +212 -218
- package/dist/primitives/Input/Select.stories.svelte +112 -112
- package/dist/primitives/Input/Select.svelte +128 -128
- package/dist/primitives/Input/Textarea.spec.d.ts +2 -0
- package/dist/primitives/Input/Textarea.spec.d.ts.map +1 -0
- package/dist/primitives/Input/Textarea.spec.js +255 -0
- package/dist/primitives/Input/Textarea.stories.svelte +137 -137
- package/dist/primitives/Input/Textarea.svelte +35 -35
- package/dist/primitives/Label/Label.spec.d.ts +2 -0
- package/dist/primitives/Label/Label.spec.d.ts.map +1 -0
- package/dist/primitives/Label/Label.spec.js +157 -0
- package/dist/primitives/Label/Label.svelte +37 -37
- package/dist/primitives/Modal/Modal.spec.js +99 -95
- package/dist/primitives/Modal/Modal.stories.svelte +86 -86
- package/dist/primitives/Modal/Modal.svelte +158 -158
- package/dist/primitives/Modal/ModalTestWrapper.svelte +65 -0
- package/dist/primitives/Modal/ModalTestWrapper.svelte.d.ts +23 -0
- package/dist/primitives/Modal/ModalTestWrapper.svelte.d.ts.map +1 -0
- package/dist/primitives/NumberInput/NumberInput.spec.d.ts +2 -0
- package/dist/primitives/NumberInput/NumberInput.spec.d.ts.map +1 -0
- package/dist/primitives/NumberInput/NumberInput.spec.js +235 -0
- package/dist/primitives/NumberInput/NumberInput.svelte +106 -106
- package/dist/primitives/Pagination/Pagination.spec.d.ts +2 -0
- package/dist/primitives/Pagination/Pagination.spec.d.ts.map +1 -0
- package/dist/primitives/Pagination/Pagination.spec.js +266 -0
- package/dist/primitives/Pagination/Pagination.stories.svelte +76 -76
- package/dist/primitives/Pagination/Pagination.svelte +261 -261
- package/dist/primitives/Radio/Radio.spec.d.ts +2 -0
- package/dist/primitives/Radio/Radio.spec.d.ts.map +1 -0
- package/dist/primitives/Radio/Radio.spec.js +206 -0
- package/dist/primitives/Radio/Radio.stories.svelte +80 -80
- package/dist/primitives/Radio/Radio.svelte +67 -67
- package/dist/primitives/Skeleton/CardPlaceholder.spec.d.ts +2 -0
- package/dist/primitives/Skeleton/CardPlaceholder.spec.d.ts.map +1 -0
- package/dist/primitives/Skeleton/CardPlaceholder.spec.js +156 -0
- package/dist/primitives/Skeleton/CardPlaceholder.svelte +87 -87
- package/dist/primitives/Skeleton/ImagePlaceholder.spec.d.ts +2 -0
- package/dist/primitives/Skeleton/ImagePlaceholder.spec.d.ts.map +1 -0
- package/dist/primitives/Skeleton/ImagePlaceholder.spec.js +120 -0
- package/dist/primitives/Skeleton/ImagePlaceholder.svelte +59 -59
- package/dist/primitives/Skeleton/ListPlaceholder.spec.d.ts +2 -0
- package/dist/primitives/Skeleton/ListPlaceholder.spec.d.ts.map +1 -0
- package/dist/primitives/Skeleton/ListPlaceholder.spec.js +220 -0
- package/dist/primitives/Skeleton/ListPlaceholder.svelte +76 -76
- package/dist/primitives/Skeleton/Skeleton.spec.d.ts +2 -0
- package/dist/primitives/Skeleton/Skeleton.spec.d.ts.map +1 -0
- package/dist/primitives/Skeleton/Skeleton.spec.js +173 -0
- package/dist/primitives/Skeleton/Skeleton.stories.svelte +151 -151
- package/dist/primitives/Skeleton/Skeleton.svelte +26 -26
- package/dist/primitives/Spinner/Spinner.spec.js +71 -75
- package/dist/primitives/Spinner/Spinner.stories.svelte +29 -29
- package/dist/primitives/Spinner/Spinner.svelte +20 -20
- package/dist/primitives/Tabs/TabItem.spec.d.ts +2 -0
- package/dist/primitives/Tabs/TabItem.spec.d.ts.map +1 -0
- package/dist/primitives/Tabs/TabItem.spec.js +130 -0
- package/dist/primitives/Tabs/TabItem.svelte +49 -49
- package/dist/primitives/Tabs/Tabs.spec.d.ts +2 -0
- package/dist/primitives/Tabs/Tabs.spec.d.ts.map +1 -0
- package/dist/primitives/Tabs/Tabs.spec.js +295 -0
- package/dist/primitives/Tabs/Tabs.stories.svelte +112 -112
- package/dist/primitives/Tabs/Tabs.svelte +123 -123
- package/dist/primitives/Tabs/TabsWithItems.test.svelte +18 -0
- package/dist/primitives/Tabs/TabsWithItems.test.svelte.d.ts +16 -0
- package/dist/primitives/Tabs/TabsWithItems.test.svelte.d.ts.map +1 -0
- package/dist/primitives/Toggle.spec.js +143 -127
- package/dist/primitives/Toggle.stories.svelte +92 -92
- package/dist/primitives/Toggle.svelte +71 -71
- package/dist/primitives/Typography/Typography.spec.d.ts +2 -0
- package/dist/primitives/Typography/Typography.spec.d.ts.map +1 -0
- package/dist/primitives/Typography/Typography.spec.js +183 -0
- package/dist/primitives/Typography/Typography.svelte +53 -53
- package/dist/primitives/ValidationError.spec.js +103 -103
- package/dist/primitives/ValidationError.stories.svelte +69 -69
- package/dist/primitives/ValidationError.svelte +29 -29
- package/dist/primitives/index.d.ts +1 -0
- package/dist/primitives/index.js +3 -0
- package/dist/recipes/CropImage/CropImage.spec.js +208 -216
- package/dist/recipes/CropImage/CropImage.stories.svelte +104 -104
- package/dist/recipes/CropImage/CropImage.svelte +238 -238
- package/dist/recipes/ImageUploader/ImageUploader.spec.d.ts +2 -0
- package/dist/recipes/ImageUploader/ImageUploader.spec.d.ts.map +1 -0
- package/dist/recipes/ImageUploader/ImageUploader.spec.js +1351 -0
- package/dist/recipes/ImageUploader/ImageUploader.stories.svelte +125 -125
- package/dist/recipes/ImageUploader/ImageUploader.svelte +804 -804
- package/dist/recipes/SuperLogin/SuperLogin.spec.d.ts +2 -0
- package/dist/recipes/SuperLogin/SuperLogin.spec.d.ts.map +1 -0
- package/dist/recipes/SuperLogin/SuperLogin.spec.js +1436 -0
- package/dist/recipes/SuperLogin/SuperLogin.svelte +7 -6
- package/dist/recipes/SuperLogin/SuperLogin.svelte.d.ts.map +1 -1
- package/dist/recipes/Toaster/Toaster.stories.svelte +62 -62
- package/dist/recipes/feedback/EmptyState/EmptyState.spec.d.ts +2 -0
- package/dist/recipes/feedback/EmptyState/EmptyState.spec.d.ts.map +1 -0
- package/dist/recipes/feedback/EmptyState/EmptyState.spec.js +202 -0
- package/dist/recipes/feedback/EmptyState/EmptyState.svelte +1 -1
- package/dist/recipes/feedback/ErrorDisplay.spec.js +69 -69
- package/dist/recipes/feedback/ErrorDisplay.stories.svelte +101 -101
- package/dist/recipes/feedback/ErrorDisplay.svelte +1 -1
- package/dist/recipes/feedback/StatusIndicator/StatusIndicator.spec.js +133 -129
- package/dist/recipes/feedback/StatusIndicator/StatusIndicator.svelte +157 -157
- package/dist/recipes/fields/CheckboxField.spec.d.ts +2 -0
- package/dist/recipes/fields/CheckboxField.spec.d.ts.map +1 -0
- package/dist/recipes/fields/CheckboxField.spec.js +135 -0
- package/dist/recipes/fields/CheckboxField.svelte +85 -85
- package/dist/recipes/fields/FormField.spec.d.ts +2 -0
- package/dist/recipes/fields/FormField.spec.d.ts.map +1 -0
- package/dist/recipes/fields/FormField.spec.js +159 -0
- package/dist/recipes/fields/FormField.svelte +58 -58
- package/dist/recipes/fields/RadioGroup.spec.d.ts +2 -0
- package/dist/recipes/fields/RadioGroup.spec.d.ts.map +1 -0
- package/dist/recipes/fields/RadioGroup.spec.js +199 -0
- package/dist/recipes/fields/RadioGroup.svelte +95 -95
- package/dist/recipes/fields/SelectField.spec.d.ts +2 -0
- package/dist/recipes/fields/SelectField.spec.d.ts.map +1 -0
- package/dist/recipes/fields/SelectField.spec.js +188 -0
- package/dist/recipes/fields/SelectField.svelte +80 -80
- package/dist/recipes/fields/TextareaField.spec.d.ts +2 -0
- package/dist/recipes/fields/TextareaField.spec.d.ts.map +1 -0
- package/dist/recipes/fields/TextareaField.spec.js +205 -0
- package/dist/recipes/fields/TextareaField.svelte +97 -97
- package/dist/recipes/fields/ToggleField.spec.d.ts +2 -0
- package/dist/recipes/fields/ToggleField.spec.d.ts.map +1 -0
- package/dist/recipes/fields/ToggleField.spec.js +153 -0
- package/dist/recipes/fields/ToggleField.svelte +60 -60
- package/dist/recipes/fields/index.js +7 -7
- package/dist/recipes/inputs/MultiSelect.spec.js +258 -257
- package/dist/recipes/inputs/MultiSelect.stories.svelte +133 -133
- package/dist/recipes/inputs/MultiSelect.svelte +256 -249
- package/dist/recipes/inputs/MultiSelect.svelte.d.ts +2 -0
- package/dist/recipes/inputs/MultiSelect.svelte.d.ts.map +1 -1
- package/dist/recipes/inputs/OTPInput.spec.js +251 -238
- package/dist/recipes/inputs/OTPInput.stories.svelte +162 -162
- package/dist/recipes/inputs/OTPInput.svelte +29 -29
- package/dist/recipes/inputs/PasswordInput.spec.d.ts +2 -0
- package/dist/recipes/inputs/PasswordInput.spec.d.ts.map +1 -0
- package/dist/recipes/inputs/PasswordInput.spec.js +410 -0
- package/dist/recipes/inputs/PasswordInput.svelte +22 -22
- package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.spec.js +245 -165
- package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.svelte +43 -43
- package/dist/recipes/inputs/PasswordStrengthIndicator/TestWrapper.svelte +71 -0
- package/dist/recipes/inputs/PasswordStrengthIndicator/TestWrapper.svelte.d.ts +9 -0
- package/dist/recipes/inputs/PasswordStrengthIndicator/TestWrapper.svelte.d.ts.map +1 -0
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.spec.js +1139 -193
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.stories.svelte +123 -123
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte +326 -326
- package/dist/recipes/inputs/Search.spec.d.ts +2 -0
- package/dist/recipes/inputs/Search.spec.d.ts.map +1 -0
- package/dist/recipes/inputs/Search.spec.js +177 -0
- package/dist/recipes/inputs/Search.svelte +37 -37
- package/dist/recipes/inputs/SelectDropdown.spec.d.ts +2 -0
- package/dist/recipes/inputs/SelectDropdown.spec.d.ts.map +1 -0
- package/dist/recipes/inputs/SelectDropdown.spec.js +512 -0
- package/dist/recipes/inputs/SelectDropdown.svelte +57 -57
- package/dist/recipes/modals/AlertModal.spec.d.ts +2 -0
- package/dist/recipes/modals/AlertModal.spec.d.ts.map +1 -0
- package/dist/recipes/modals/AlertModal.spec.js +432 -0
- package/dist/recipes/modals/AlertModal.svelte +130 -130
- package/dist/recipes/modals/ConfirmationModal.spec.js +206 -191
- package/dist/recipes/modals/ConfirmationModal.stories.svelte +119 -119
- package/dist/recipes/modals/ConfirmationModal.svelte +152 -152
- package/dist/recipes/modals/InputModal.spec.d.ts +2 -0
- package/dist/recipes/modals/InputModal.spec.d.ts.map +1 -0
- package/dist/recipes/modals/InputModal.spec.js +872 -0
- package/dist/recipes/modals/InputModal.svelte +182 -182
- package/dist/recipes/modals/ModalStateManager.spec.js +100 -100
- package/dist/recipes/modals/ModalStateManager.svelte +77 -77
- package/dist/recipes/modals/ModalTestWrapper.spec.d.ts +2 -0
- package/dist/recipes/modals/ModalTestWrapper.spec.d.ts.map +1 -0
- package/dist/recipes/modals/ModalTestWrapper.spec.js +502 -0
- package/dist/recipes/modals/ModalTestWrapper.svelte +65 -65
- package/dist/recipes/modals/StatusModal.spec.d.ts +2 -0
- package/dist/recipes/modals/StatusModal.spec.d.ts.map +1 -0
- package/dist/recipes/modals/StatusModal.spec.js +599 -0
- package/dist/recipes/modals/StatusModal.svelte +206 -206
- package/dist/services/EventService.js +75 -75
- package/dist/services/EventService.spec.js +217 -217
- package/dist/services/ShowService.spec.js +345 -342
- package/dist/stores/auth.js +36 -36
- package/dist/stores/auth.spec.js +139 -139
- package/dist/stores/toaster.js +13 -13
- package/dist/stories/ButtonAuditDashboard.spec.d.ts +2 -0
- package/dist/stories/ButtonAuditDashboard.spec.d.ts.map +1 -0
- package/dist/stories/ButtonAuditDashboard.spec.js +913 -0
- package/dist/stories/ButtonAuditReview.spec.d.ts +2 -0
- package/dist/stories/ButtonAuditReview.spec.d.ts.map +1 -0
- package/dist/stories/ButtonAuditReview.spec.js +422 -0
- package/dist/stories/ButtonAuditReview.stories.svelte +14 -14
- package/dist/stories/ButtonAuditReview.svelte +427 -427
- package/dist/stories/ButtonGridView.spec.d.ts +2 -0
- package/dist/stories/ButtonGridView.spec.d.ts.map +1 -0
- package/dist/stories/ButtonGridView.spec.js +667 -0
- package/dist/stories/ButtonShowcase.spec.d.ts +2 -0
- package/dist/stories/ButtonShowcase.spec.d.ts.map +1 -0
- package/dist/stories/ButtonShowcase.spec.js +499 -0
- package/dist/stories/PatternsGallery.spec.d.ts +2 -0
- package/dist/stories/PatternsGallery.spec.d.ts.map +1 -0
- package/dist/stories/PatternsGallery.spec.js +514 -0
- package/dist/stories/PatternsGallery.stories.svelte +19 -19
- package/dist/stories/PatternsGallery.svelte +206 -206
- package/dist/stories/PrimitivesGallery.spec.d.ts +2 -0
- package/dist/stories/PrimitivesGallery.spec.d.ts.map +1 -0
- package/dist/stories/PrimitivesGallery.spec.js +813 -0
- package/dist/stories/PrimitivesGallery.stories.svelte +19 -19
- package/dist/stories/PrimitivesGallery.svelte +725 -725
- package/dist/stories/RecipesGallery.spec.d.ts +2 -0
- package/dist/stories/RecipesGallery.spec.d.ts.map +1 -0
- package/dist/stories/RecipesGallery.spec.js +299 -0
- package/dist/stories/RecipesGallery.stories.svelte +19 -19
- package/dist/stories/RecipesGallery.svelte +271 -271
- package/dist/stories/button-audit-manifest.json +11186 -11186
- package/dist/stripe/useStripeTheme.spec.d.ts +2 -0
- package/dist/stripe/useStripeTheme.spec.d.ts.map +1 -0
- package/dist/stripe/useStripeTheme.spec.js +793 -0
- package/dist/tailwind/preset.cjs +82 -82
- package/dist/telemetry.d.ts.map +1 -1
- package/dist/telemetry.js +6 -5
- package/dist/telemetry.spec.js +495 -12
- package/dist/tokens/__tests__/colors.test.d.ts +2 -0
- package/dist/tokens/__tests__/colors.test.d.ts.map +1 -0
- package/dist/tokens/__tests__/colors.test.js +152 -0
- package/dist/tokens/__tests__/radius.test.d.ts +2 -0
- package/dist/tokens/__tests__/radius.test.d.ts.map +1 -0
- package/dist/tokens/__tests__/radius.test.js +118 -0
- package/dist/tokens/__tests__/shadows.test.d.ts +2 -0
- package/dist/tokens/__tests__/shadows.test.d.ts.map +1 -0
- package/dist/tokens/__tests__/shadows.test.js +105 -0
- package/dist/tokens/__tests__/spacing.test.js +11 -8
- package/dist/tokens/__tests__/typography.test.d.ts +2 -0
- package/dist/tokens/__tests__/typography.test.d.ts.map +1 -0
- package/dist/tokens/__tests__/typography.test.js +156 -0
- package/dist/tokens/__tests__/z-index.test.d.ts +2 -0
- package/dist/tokens/__tests__/z-index.test.d.ts.map +1 -0
- package/dist/tokens/__tests__/z-index.test.js +121 -0
- package/dist/tokens/tokens.css +87 -87
- package/dist/utils/apiConfig.spec.js +102 -1
- package/dist/utils/formatters.spec.d.ts +2 -0
- package/dist/utils/formatters.spec.d.ts.map +1 -0
- package/dist/utils/formatters.spec.js +82 -0
- package/dist/utils/transitions.d.ts +24 -0
- package/dist/utils/transitions.d.ts.map +1 -0
- package/dist/utils/transitions.js +62 -0
- package/dist/utils/transitions.spec.d.ts +2 -0
- package/dist/utils/transitions.spec.d.ts.map +1 -0
- package/dist/utils/transitions.spec.js +130 -0
- package/dist/utils/utils.js +354 -354
- package/package.json +288 -283
|
@@ -1,158 +1,158 @@
|
|
|
1
|
-
<script>
|
|
2
|
-
/**
|
|
3
|
-
* Modal Component - Flowbite Native
|
|
4
|
-
* Migrated to Svelte 5 runes
|
|
5
|
-
*/
|
|
6
|
-
import { onDestroy } from "svelte";
|
|
7
|
-
import { fade, fly } from "svelte/transition";
|
|
8
|
-
import { cubicOut } from "svelte/easing";
|
|
9
|
-
import { portal } from "../../utils/portal.js";
|
|
10
|
-
|
|
11
|
-
/** @type {{
|
|
12
|
-
show?: boolean,
|
|
13
|
-
isProcessing?: boolean,
|
|
14
|
-
isSuccess?: boolean,
|
|
15
|
-
size?: 'default' | 'small' | 'large' | 'xlarge',
|
|
16
|
-
persistent?: boolean,
|
|
17
|
-
oncancel?: () => void,
|
|
18
|
-
header?: any,
|
|
19
|
-
body?: any,
|
|
20
|
-
footer?: any,
|
|
21
|
-
class?: string,
|
|
22
|
-
[key: string]: any
|
|
23
|
-
}} */
|
|
24
|
-
let {
|
|
25
|
-
show = $bindable(false),
|
|
26
|
-
isProcessing = false,
|
|
27
|
-
isSuccess = false,
|
|
28
|
-
size = "default",
|
|
29
|
-
persistent = false,
|
|
30
|
-
oncancel,
|
|
31
|
-
header,
|
|
32
|
-
body,
|
|
33
|
-
footer,
|
|
34
|
-
class: _className,
|
|
35
|
-
...restProps
|
|
36
|
-
} = $props();
|
|
37
|
-
|
|
38
|
-
// Store scroll position for iOS scroll lock
|
|
39
|
-
let scrollY = $state(0);
|
|
40
|
-
|
|
41
|
-
// Handle escape key
|
|
42
|
-
function handleKeydown(event) {
|
|
43
|
-
if (event.key === "Escape" && show && !persistent) {
|
|
44
|
-
resetModal();
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
const resetModal = () => {
|
|
49
|
-
oncancel?.();
|
|
50
|
-
show = false;
|
|
51
|
-
};
|
|
52
|
-
|
|
53
|
-
// Size classes for desktop modal (Tailwind scale)
|
|
54
|
-
const sizeClasses = {
|
|
55
|
-
default: "max-w-md",
|
|
56
|
-
small: "max-w-sm",
|
|
57
|
-
large: "max-w-xl",
|
|
58
|
-
xlarge: "max-w-2xl"
|
|
59
|
-
};
|
|
60
|
-
|
|
61
|
-
let modalSizeClass = $derived(sizeClasses[size] || sizeClasses.default);
|
|
62
|
-
|
|
63
|
-
// iOS-compatible scroll lock using position:fixed approach
|
|
64
|
-
$effect(() => {
|
|
65
|
-
if (typeof document !== "undefined") {
|
|
66
|
-
if (show) {
|
|
67
|
-
scrollY = window.scrollY;
|
|
68
|
-
document.body.style.position = "fixed";
|
|
69
|
-
document.body.style.top = `-${scrollY}px`;
|
|
70
|
-
document.body.style.left = "0";
|
|
71
|
-
document.body.style.right = "0";
|
|
72
|
-
document.body.style.overflow = "hidden";
|
|
73
|
-
} else {
|
|
74
|
-
document.body.style.position = "";
|
|
75
|
-
document.body.style.top = "";
|
|
76
|
-
document.body.style.left = "";
|
|
77
|
-
document.body.style.right = "";
|
|
78
|
-
document.body.style.overflow = "";
|
|
79
|
-
window.scrollTo(0, scrollY);
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
});
|
|
83
|
-
|
|
84
|
-
onDestroy(() => {
|
|
85
|
-
if (typeof document !== "undefined") {
|
|
86
|
-
document.body.style.position = "";
|
|
87
|
-
document.body.style.top = "";
|
|
88
|
-
document.body.style.left = "";
|
|
89
|
-
document.body.style.right = "";
|
|
90
|
-
document.body.style.overflow = "";
|
|
91
|
-
}
|
|
92
|
-
});
|
|
93
|
-
</script>
|
|
94
|
-
|
|
95
|
-
<svelte:window onkeydown={handleKeydown} />
|
|
96
|
-
|
|
97
|
-
{#if show}
|
|
98
|
-
<!-- svelte-ignore a11y_click_events_have_key_events -->
|
|
99
|
-
<!-- svelte-ignore a11y_no_static_element_interactions -->
|
|
100
|
-
<div
|
|
101
|
-
class="fixed inset-0 flex bg-black/50 z-50 items-end justify-center md:items-center md:p-4 touch-none overscroll-none"
|
|
102
|
-
onmousedown={(e) => {
|
|
103
|
-
// Only track direct clicks on backdrop, not drags that end on backdrop
|
|
104
|
-
if (e.target === e.currentTarget && !persistent) {
|
|
105
|
-
e.currentTarget.dataset.clickStartedOnBackdrop = 'true';
|
|
106
|
-
}
|
|
107
|
-
}}
|
|
108
|
-
onmouseup={(e) => {
|
|
109
|
-
// Only close if both mousedown and mouseup were on the backdrop
|
|
110
|
-
if (e.target === e.currentTarget && e.currentTarget.dataset.clickStartedOnBackdrop === 'true' && !persistent) {
|
|
111
|
-
resetModal();
|
|
112
|
-
}
|
|
113
|
-
delete e.currentTarget.dataset.clickStartedOnBackdrop;
|
|
114
|
-
}}
|
|
115
|
-
transition:fade={{ duration: 300 }}
|
|
116
|
-
role="dialog"
|
|
117
|
-
aria-modal="true"
|
|
118
|
-
use:portal
|
|
119
|
-
{...restProps}
|
|
120
|
-
>
|
|
121
|
-
<!-- Mobile: Bottom sheet -->
|
|
122
|
-
<!-- svelte-ignore a11y_click_events_have_key_events -->
|
|
123
|
-
<!-- svelte-ignore a11y_no_static_element_interactions -->
|
|
124
|
-
<div
|
|
125
|
-
class="md:hidden bg-white dark:bg-gray-800 rounded-t-3xl w-full max-h-[90vh] max-h-[90dvh] overflow-hidden flex flex-col shadow-[0_-10px_40px_rgba(0,0,0,0.15)] touch-pan-y overscroll-contain"
|
|
126
|
-
onclick={(e) => e.stopPropagation()}
|
|
127
|
-
transition:fly={{ y: 300, duration: 300, easing: cubicOut }}
|
|
128
|
-
>
|
|
129
|
-
<!-- Handle bar -->
|
|
130
|
-
<div class="flex justify-center pt-3 pb-1 shrink-0">
|
|
131
|
-
<div class="w-10 h-1 bg-gray-300 dark:bg-gray-600 rounded-sm"></div>
|
|
132
|
-
</div>
|
|
133
|
-
|
|
134
|
-
<div class="p-6 pb-[calc(5rem+env(safe-area-inset-bottom,0px))] overflow-y-auto flex-1">
|
|
135
|
-
{#if header}{@render header()}{/if}
|
|
136
|
-
{#if body}{@render body()}{/if}
|
|
137
|
-
<div class="w-full flex flex-col gap-3 mt-6 empty:hidden empty:mt-0">
|
|
138
|
-
{#if footer}{@render footer()}{/if}
|
|
139
|
-
</div>
|
|
140
|
-
</div>
|
|
141
|
-
</div>
|
|
142
|
-
|
|
143
|
-
<!-- Desktop: Centered modal -->
|
|
144
|
-
<!-- svelte-ignore a11y_click_events_have_key_events -->
|
|
145
|
-
<!-- svelte-ignore a11y_no_static_element_interactions -->
|
|
146
|
-
<div
|
|
147
|
-
class="hidden md:block bg-white dark:bg-gray-800 p-6 rounded-lg {modalSizeClass} w-full max-h-[calc(100vh-4rem)] overflow-y-auto shadow-2xl"
|
|
148
|
-
onclick={(e) => e.stopPropagation()}
|
|
149
|
-
transition:fly={{ y: 20, duration: 200 }}
|
|
150
|
-
>
|
|
151
|
-
{#if header}{@render header()}{/if}
|
|
152
|
-
{#if body}{@render body()}{/if}
|
|
153
|
-
<div class="w-full flex flex-col md:flex-row md:justify-end gap-3 mt-6 empty:hidden empty:mt-0">
|
|
154
|
-
{#if footer}{@render footer()}{/if}
|
|
155
|
-
</div>
|
|
156
|
-
</div>
|
|
157
|
-
</div>
|
|
158
|
-
{/if}
|
|
1
|
+
<script>
|
|
2
|
+
/**
|
|
3
|
+
* Modal Component - Flowbite Native
|
|
4
|
+
* Migrated to Svelte 5 runes
|
|
5
|
+
*/
|
|
6
|
+
import { onDestroy } from "svelte";
|
|
7
|
+
import { fade, fly } from "svelte/transition";
|
|
8
|
+
import { cubicOut } from "svelte/easing";
|
|
9
|
+
import { portal } from "../../utils/portal.js";
|
|
10
|
+
|
|
11
|
+
/** @type {{
|
|
12
|
+
show?: boolean,
|
|
13
|
+
isProcessing?: boolean,
|
|
14
|
+
isSuccess?: boolean,
|
|
15
|
+
size?: 'default' | 'small' | 'large' | 'xlarge',
|
|
16
|
+
persistent?: boolean,
|
|
17
|
+
oncancel?: () => void,
|
|
18
|
+
header?: any,
|
|
19
|
+
body?: any,
|
|
20
|
+
footer?: any,
|
|
21
|
+
class?: string,
|
|
22
|
+
[key: string]: any
|
|
23
|
+
}} */
|
|
24
|
+
let {
|
|
25
|
+
show = $bindable(false),
|
|
26
|
+
isProcessing = false,
|
|
27
|
+
isSuccess = false,
|
|
28
|
+
size = "default",
|
|
29
|
+
persistent = false,
|
|
30
|
+
oncancel,
|
|
31
|
+
header,
|
|
32
|
+
body,
|
|
33
|
+
footer,
|
|
34
|
+
class: _className,
|
|
35
|
+
...restProps
|
|
36
|
+
} = $props();
|
|
37
|
+
|
|
38
|
+
// Store scroll position for iOS scroll lock
|
|
39
|
+
let scrollY = $state(0);
|
|
40
|
+
|
|
41
|
+
// Handle escape key
|
|
42
|
+
function handleKeydown(event) {
|
|
43
|
+
if (event.key === "Escape" && show && !persistent) {
|
|
44
|
+
resetModal();
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
const resetModal = () => {
|
|
49
|
+
oncancel?.();
|
|
50
|
+
show = false;
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
// Size classes for desktop modal (Tailwind scale)
|
|
54
|
+
const sizeClasses = {
|
|
55
|
+
default: "max-w-md",
|
|
56
|
+
small: "max-w-sm",
|
|
57
|
+
large: "max-w-xl",
|
|
58
|
+
xlarge: "max-w-2xl"
|
|
59
|
+
};
|
|
60
|
+
|
|
61
|
+
let modalSizeClass = $derived(sizeClasses[size] || sizeClasses.default);
|
|
62
|
+
|
|
63
|
+
// iOS-compatible scroll lock using position:fixed approach
|
|
64
|
+
$effect(() => {
|
|
65
|
+
if (typeof document !== "undefined") {
|
|
66
|
+
if (show) {
|
|
67
|
+
scrollY = window.scrollY;
|
|
68
|
+
document.body.style.position = "fixed";
|
|
69
|
+
document.body.style.top = `-${scrollY}px`;
|
|
70
|
+
document.body.style.left = "0";
|
|
71
|
+
document.body.style.right = "0";
|
|
72
|
+
document.body.style.overflow = "hidden";
|
|
73
|
+
} else {
|
|
74
|
+
document.body.style.position = "";
|
|
75
|
+
document.body.style.top = "";
|
|
76
|
+
document.body.style.left = "";
|
|
77
|
+
document.body.style.right = "";
|
|
78
|
+
document.body.style.overflow = "";
|
|
79
|
+
window.scrollTo(0, scrollY);
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
});
|
|
83
|
+
|
|
84
|
+
onDestroy(() => {
|
|
85
|
+
if (typeof document !== "undefined") {
|
|
86
|
+
document.body.style.position = "";
|
|
87
|
+
document.body.style.top = "";
|
|
88
|
+
document.body.style.left = "";
|
|
89
|
+
document.body.style.right = "";
|
|
90
|
+
document.body.style.overflow = "";
|
|
91
|
+
}
|
|
92
|
+
});
|
|
93
|
+
</script>
|
|
94
|
+
|
|
95
|
+
<svelte:window onkeydown={handleKeydown} />
|
|
96
|
+
|
|
97
|
+
{#if show}
|
|
98
|
+
<!-- svelte-ignore a11y_click_events_have_key_events -->
|
|
99
|
+
<!-- svelte-ignore a11y_no_static_element_interactions -->
|
|
100
|
+
<div
|
|
101
|
+
class="fixed inset-0 flex bg-black/50 z-50 items-end justify-center md:items-center md:p-4 touch-none overscroll-none"
|
|
102
|
+
onmousedown={(e) => {
|
|
103
|
+
// Only track direct clicks on backdrop, not drags that end on backdrop
|
|
104
|
+
if (e.target === e.currentTarget && !persistent) {
|
|
105
|
+
e.currentTarget.dataset.clickStartedOnBackdrop = 'true';
|
|
106
|
+
}
|
|
107
|
+
}}
|
|
108
|
+
onmouseup={(e) => {
|
|
109
|
+
// Only close if both mousedown and mouseup were on the backdrop
|
|
110
|
+
if (e.target === e.currentTarget && e.currentTarget.dataset.clickStartedOnBackdrop === 'true' && !persistent) {
|
|
111
|
+
resetModal();
|
|
112
|
+
}
|
|
113
|
+
delete e.currentTarget.dataset.clickStartedOnBackdrop;
|
|
114
|
+
}}
|
|
115
|
+
transition:fade={{ duration: 300 }}
|
|
116
|
+
role="dialog"
|
|
117
|
+
aria-modal="true"
|
|
118
|
+
use:portal
|
|
119
|
+
{...restProps}
|
|
120
|
+
>
|
|
121
|
+
<!-- Mobile: Bottom sheet -->
|
|
122
|
+
<!-- svelte-ignore a11y_click_events_have_key_events -->
|
|
123
|
+
<!-- svelte-ignore a11y_no_static_element_interactions -->
|
|
124
|
+
<div
|
|
125
|
+
class="md:hidden bg-white dark:bg-gray-800 rounded-t-3xl w-full max-h-[90vh] max-h-[90dvh] overflow-hidden flex flex-col shadow-[0_-10px_40px_rgba(0,0,0,0.15)] touch-pan-y overscroll-contain"
|
|
126
|
+
onclick={(e) => e.stopPropagation()}
|
|
127
|
+
transition:fly={{ y: 300, duration: 300, easing: cubicOut }}
|
|
128
|
+
>
|
|
129
|
+
<!-- Handle bar -->
|
|
130
|
+
<div class="flex justify-center pt-3 pb-1 shrink-0">
|
|
131
|
+
<div class="w-10 h-1 bg-gray-300 dark:bg-gray-600 rounded-sm"></div>
|
|
132
|
+
</div>
|
|
133
|
+
|
|
134
|
+
<div class="p-6 pb-[calc(5rem+env(safe-area-inset-bottom,0px))] overflow-y-auto flex-1">
|
|
135
|
+
{#if header}{@render header()}{/if}
|
|
136
|
+
{#if body}{@render body()}{/if}
|
|
137
|
+
<div class="w-full flex flex-col gap-3 mt-6 empty:hidden empty:mt-0">
|
|
138
|
+
{#if footer}{@render footer()}{/if}
|
|
139
|
+
</div>
|
|
140
|
+
</div>
|
|
141
|
+
</div>
|
|
142
|
+
|
|
143
|
+
<!-- Desktop: Centered modal -->
|
|
144
|
+
<!-- svelte-ignore a11y_click_events_have_key_events -->
|
|
145
|
+
<!-- svelte-ignore a11y_no_static_element_interactions -->
|
|
146
|
+
<div
|
|
147
|
+
class="hidden md:block bg-white dark:bg-gray-800 p-6 rounded-lg {modalSizeClass} w-full max-h-[calc(100vh-4rem)] overflow-y-auto shadow-2xl"
|
|
148
|
+
onclick={(e) => e.stopPropagation()}
|
|
149
|
+
transition:fly={{ y: 20, duration: 200 }}
|
|
150
|
+
>
|
|
151
|
+
{#if header}{@render header()}{/if}
|
|
152
|
+
{#if body}{@render body()}{/if}
|
|
153
|
+
<div class="w-full flex flex-col md:flex-row md:justify-end gap-3 mt-6 empty:hidden empty:mt-0">
|
|
154
|
+
{#if footer}{@render footer()}{/if}
|
|
155
|
+
</div>
|
|
156
|
+
</div>
|
|
157
|
+
</div>
|
|
158
|
+
{/if}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import type { Snippet } from 'svelte';
|
|
3
|
+
import Modal from "./Modal.svelte";
|
|
4
|
+
import Button from "../Button/Button.svelte";
|
|
5
|
+
|
|
6
|
+
interface Props {
|
|
7
|
+
/** Whether the modal is visible */
|
|
8
|
+
show?: boolean;
|
|
9
|
+
/** Modal title */
|
|
10
|
+
title?: string;
|
|
11
|
+
/** Modal description */
|
|
12
|
+
description?: string;
|
|
13
|
+
/** Warning text */
|
|
14
|
+
warningText?: string;
|
|
15
|
+
/** Callback when modal is cancelled */
|
|
16
|
+
oncancel?: () => void;
|
|
17
|
+
/** Custom header snippet */
|
|
18
|
+
customHeader?: Snippet;
|
|
19
|
+
/** Custom body snippet */
|
|
20
|
+
customBody?: Snippet;
|
|
21
|
+
/** Custom footer snippet */
|
|
22
|
+
customFooter?: Snippet;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
let {
|
|
26
|
+
show = $bindable(false),
|
|
27
|
+
title = '',
|
|
28
|
+
description = '',
|
|
29
|
+
warningText = '',
|
|
30
|
+
oncancel,
|
|
31
|
+
customHeader,
|
|
32
|
+
customBody,
|
|
33
|
+
customFooter
|
|
34
|
+
}: Props = $props();
|
|
35
|
+
</script>
|
|
36
|
+
|
|
37
|
+
<Modal bind:show {oncancel}>
|
|
38
|
+
{#snippet header()}
|
|
39
|
+
{#if customHeader}
|
|
40
|
+
{@render customHeader()}
|
|
41
|
+
{:else}
|
|
42
|
+
{title}
|
|
43
|
+
{/if}
|
|
44
|
+
{/snippet}
|
|
45
|
+
|
|
46
|
+
{#snippet body()}
|
|
47
|
+
{#if customBody}
|
|
48
|
+
{@render customBody()}
|
|
49
|
+
{:else}
|
|
50
|
+
{description}
|
|
51
|
+
{#if warningText}
|
|
52
|
+
<br /> {warningText}
|
|
53
|
+
{/if}
|
|
54
|
+
{/if}
|
|
55
|
+
{/snippet}
|
|
56
|
+
|
|
57
|
+
{#snippet footer()}
|
|
58
|
+
{#if customFooter}
|
|
59
|
+
{@render customFooter()}
|
|
60
|
+
{:else}
|
|
61
|
+
<Button variant="alternative">Cancel</Button>
|
|
62
|
+
<Button variant="default">Confirm</Button>
|
|
63
|
+
{/if}
|
|
64
|
+
{/snippet}
|
|
65
|
+
</Modal>
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import type { Snippet } from 'svelte';
|
|
2
|
+
interface Props {
|
|
3
|
+
/** Whether the modal is visible */
|
|
4
|
+
show?: boolean;
|
|
5
|
+
/** Modal title */
|
|
6
|
+
title?: string;
|
|
7
|
+
/** Modal description */
|
|
8
|
+
description?: string;
|
|
9
|
+
/** Warning text */
|
|
10
|
+
warningText?: string;
|
|
11
|
+
/** Callback when modal is cancelled */
|
|
12
|
+
oncancel?: () => void;
|
|
13
|
+
/** Custom header snippet */
|
|
14
|
+
customHeader?: Snippet;
|
|
15
|
+
/** Custom body snippet */
|
|
16
|
+
customBody?: Snippet;
|
|
17
|
+
/** Custom footer snippet */
|
|
18
|
+
customFooter?: Snippet;
|
|
19
|
+
}
|
|
20
|
+
declare const ModalTestWrapper: import("svelte").Component<Props, {}, "show">;
|
|
21
|
+
type ModalTestWrapper = ReturnType<typeof ModalTestWrapper>;
|
|
22
|
+
export default ModalTestWrapper;
|
|
23
|
+
//# sourceMappingURL=ModalTestWrapper.svelte.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ModalTestWrapper.svelte.d.ts","sourceRoot":"","sources":["../../../src/lib/primitives/Modal/ModalTestWrapper.svelte.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,QAAQ,CAAC;AAKpC,UAAU,KAAK;IACb,mCAAmC;IACnC,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,kBAAkB;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,wBAAwB;IACxB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,mBAAmB;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,uCAAuC;IACvC,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAC;IACtB,4BAA4B;IAC5B,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,0BAA0B;IAC1B,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,4BAA4B;IAC5B,YAAY,CAAC,EAAE,OAAO,CAAC;CACxB;AAmDH,QAAA,MAAM,gBAAgB,+CAAwC,CAAC;AAC/D,KAAK,gBAAgB,GAAG,UAAU,CAAC,OAAO,gBAAgB,CAAC,CAAC;AAC5D,eAAe,gBAAgB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NumberInput.spec.d.ts","sourceRoot":"","sources":["../../../src/lib/primitives/NumberInput/NumberInput.spec.js"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,235 @@
|
|
|
1
|
+
import { render, screen } from '@testing-library/svelte';
|
|
2
|
+
import userEvent from '@testing-library/user-event';
|
|
3
|
+
import { expect, describe, test, vi } from 'vitest';
|
|
4
|
+
import NumberInput from './NumberInput.svelte';
|
|
5
|
+
|
|
6
|
+
describe('NumberInput Component', () => {
|
|
7
|
+
test('renders a container div', () => {
|
|
8
|
+
const { container } = render(NumberInput);
|
|
9
|
+
expect(container.querySelector('div')).toBeInTheDocument();
|
|
10
|
+
});
|
|
11
|
+
|
|
12
|
+
test('renders increment and decrement buttons', () => {
|
|
13
|
+
const { container } = render(NumberInput);
|
|
14
|
+
expect(container.querySelector('[aria-label="Decrease quantity"]')).toBeInTheDocument();
|
|
15
|
+
expect(container.querySelector('[aria-label="Increase quantity"]')).toBeInTheDocument();
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
test('displays the current value', () => {
|
|
19
|
+
render(NumberInput, { props: { value: 5 } });
|
|
20
|
+
expect(screen.getByText('5')).toBeInTheDocument();
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
test('applies custom className', () => {
|
|
24
|
+
const { container } = render(NumberInput, { props: { class: 'custom-number-input' } });
|
|
25
|
+
const wrapper = container.querySelector('div');
|
|
26
|
+
expect(wrapper).toHaveClass('custom-number-input');
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
test('passes through additional props', () => {
|
|
30
|
+
const { container } = render(NumberInput, { props: { 'data-testid': 'my-number-input' } });
|
|
31
|
+
expect(container.querySelector('[data-testid="my-number-input"]')).toBeInTheDocument();
|
|
32
|
+
});
|
|
33
|
+
});
|
|
34
|
+
|
|
35
|
+
describe('NumberInput Props', () => {
|
|
36
|
+
test('value defaults to 0', () => {
|
|
37
|
+
render(NumberInput);
|
|
38
|
+
expect(screen.getByText('0')).toBeInTheDocument();
|
|
39
|
+
});
|
|
40
|
+
|
|
41
|
+
test('min defaults to 0', () => {
|
|
42
|
+
const { container } = render(NumberInput, { props: { value: 0 } });
|
|
43
|
+
const decrementBtn = container.querySelector('[aria-label="Decrease quantity"]');
|
|
44
|
+
expect(decrementBtn).toBeDisabled();
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
test('max defaults to Infinity', () => {
|
|
48
|
+
const { container } = render(NumberInput, { props: { value: 9999 } });
|
|
49
|
+
const incrementBtn = container.querySelector('[aria-label="Increase quantity"]');
|
|
50
|
+
expect(incrementBtn).not.toBeDisabled();
|
|
51
|
+
});
|
|
52
|
+
|
|
53
|
+
test('disabled prop disables both buttons', () => {
|
|
54
|
+
const { container } = render(NumberInput, { props: { disabled: true, value: 5 } });
|
|
55
|
+
const decrementBtn = container.querySelector('[aria-label="Decrease quantity"]');
|
|
56
|
+
const incrementBtn = container.querySelector('[aria-label="Increase quantity"]');
|
|
57
|
+
expect(decrementBtn).toBeDisabled();
|
|
58
|
+
expect(incrementBtn).toBeDisabled();
|
|
59
|
+
});
|
|
60
|
+
});
|
|
61
|
+
|
|
62
|
+
describe('NumberInput Increment/Decrement', () => {
|
|
63
|
+
test('clicking increment calls onchange with value + 1', async () => {
|
|
64
|
+
const user = userEvent.setup();
|
|
65
|
+
const onchange = vi.fn();
|
|
66
|
+
const { container } = render(NumberInput, { props: { value: 5, onchange } });
|
|
67
|
+
|
|
68
|
+
const incrementBtn = container.querySelector('[aria-label="Increase quantity"]');
|
|
69
|
+
await user.click(incrementBtn);
|
|
70
|
+
expect(onchange).toHaveBeenCalledWith(6);
|
|
71
|
+
});
|
|
72
|
+
|
|
73
|
+
test('clicking decrement calls onchange with value - 1', async () => {
|
|
74
|
+
const user = userEvent.setup();
|
|
75
|
+
const onchange = vi.fn();
|
|
76
|
+
const { container } = render(NumberInput, { props: { value: 5, onchange } });
|
|
77
|
+
|
|
78
|
+
const decrementBtn = container.querySelector('[aria-label="Decrease quantity"]');
|
|
79
|
+
await user.click(decrementBtn);
|
|
80
|
+
expect(onchange).toHaveBeenCalledWith(4);
|
|
81
|
+
});
|
|
82
|
+
|
|
83
|
+
test('decrement is disabled at min value', () => {
|
|
84
|
+
const { container } = render(NumberInput, { props: { value: 0, min: 0 } });
|
|
85
|
+
const decrementBtn = container.querySelector('[aria-label="Decrease quantity"]');
|
|
86
|
+
expect(decrementBtn).toBeDisabled();
|
|
87
|
+
});
|
|
88
|
+
|
|
89
|
+
test('increment is disabled at max value', () => {
|
|
90
|
+
const { container } = render(NumberInput, { props: { value: 10, max: 10 } });
|
|
91
|
+
const incrementBtn = container.querySelector('[aria-label="Increase quantity"]');
|
|
92
|
+
expect(incrementBtn).toBeDisabled();
|
|
93
|
+
});
|
|
94
|
+
|
|
95
|
+
test('does not increment past max', async () => {
|
|
96
|
+
const user = userEvent.setup();
|
|
97
|
+
const onchange = vi.fn();
|
|
98
|
+
const { container } = render(NumberInput, { props: { value: 10, max: 10, onchange } });
|
|
99
|
+
|
|
100
|
+
const incrementBtn = container.querySelector('[aria-label="Increase quantity"]');
|
|
101
|
+
await user.click(incrementBtn);
|
|
102
|
+
expect(onchange).not.toHaveBeenCalled();
|
|
103
|
+
});
|
|
104
|
+
|
|
105
|
+
test('does not decrement below min', async () => {
|
|
106
|
+
const user = userEvent.setup();
|
|
107
|
+
const onchange = vi.fn();
|
|
108
|
+
const { container } = render(NumberInput, { props: { value: 0, min: 0, onchange } });
|
|
109
|
+
|
|
110
|
+
const decrementBtn = container.querySelector('[aria-label="Decrease quantity"]');
|
|
111
|
+
await user.click(decrementBtn);
|
|
112
|
+
expect(onchange).not.toHaveBeenCalled();
|
|
113
|
+
});
|
|
114
|
+
});
|
|
115
|
+
|
|
116
|
+
describe('NumberInput Styling', () => {
|
|
117
|
+
test('container has inline-flex class', () => {
|
|
118
|
+
const { container } = render(NumberInput);
|
|
119
|
+
const wrapper = container.querySelector('div');
|
|
120
|
+
expect(wrapper).toHaveClass('inline-flex');
|
|
121
|
+
});
|
|
122
|
+
|
|
123
|
+
test('container has items-center class', () => {
|
|
124
|
+
const { container } = render(NumberInput);
|
|
125
|
+
const wrapper = container.querySelector('div');
|
|
126
|
+
expect(wrapper).toHaveClass('items-center');
|
|
127
|
+
});
|
|
128
|
+
|
|
129
|
+
test('buttons have type="button"', () => {
|
|
130
|
+
const { container } = render(NumberInput);
|
|
131
|
+
const buttons = container.querySelectorAll('button');
|
|
132
|
+
buttons.forEach(btn => {
|
|
133
|
+
expect(btn).toHaveAttribute('type', 'button');
|
|
134
|
+
});
|
|
135
|
+
});
|
|
136
|
+
|
|
137
|
+
test('decrement button has rounded-l-lg', () => {
|
|
138
|
+
const { container } = render(NumberInput);
|
|
139
|
+
const decrementBtn = container.querySelector('[aria-label="Decrease quantity"]');
|
|
140
|
+
expect(decrementBtn).toHaveClass('rounded-l-lg');
|
|
141
|
+
});
|
|
142
|
+
|
|
143
|
+
test('increment button has rounded-r-lg', () => {
|
|
144
|
+
const { container } = render(NumberInput);
|
|
145
|
+
const incrementBtn = container.querySelector('[aria-label="Increase quantity"]');
|
|
146
|
+
expect(incrementBtn).toHaveClass('rounded-r-lg');
|
|
147
|
+
});
|
|
148
|
+
|
|
149
|
+
test('buttons have bg-gray-100 background', () => {
|
|
150
|
+
const { container } = render(NumberInput);
|
|
151
|
+
const decrementBtn = container.querySelector('[aria-label="Decrease quantity"]');
|
|
152
|
+
expect(decrementBtn).toHaveClass('bg-gray-100');
|
|
153
|
+
});
|
|
154
|
+
|
|
155
|
+
test('buttons have border-gray-300 border', () => {
|
|
156
|
+
const { container } = render(NumberInput);
|
|
157
|
+
const decrementBtn = container.querySelector('[aria-label="Decrease quantity"]');
|
|
158
|
+
expect(decrementBtn).toHaveClass('border-gray-300');
|
|
159
|
+
});
|
|
160
|
+
|
|
161
|
+
test('display has bg-gray-50 background', () => {
|
|
162
|
+
const { container } = render(NumberInput);
|
|
163
|
+
const display = container.querySelector('span');
|
|
164
|
+
expect(display).toHaveClass('bg-gray-50');
|
|
165
|
+
});
|
|
166
|
+
|
|
167
|
+
test('display has text-gray-500 color', () => {
|
|
168
|
+
const { container } = render(NumberInput);
|
|
169
|
+
const display = container.querySelector('span');
|
|
170
|
+
expect(display).toHaveClass('text-gray-500');
|
|
171
|
+
});
|
|
172
|
+
});
|
|
173
|
+
|
|
174
|
+
describe('NumberInput Dark Mode', () => {
|
|
175
|
+
test('buttons have dark mode background', () => {
|
|
176
|
+
const { container } = render(NumberInput);
|
|
177
|
+
const decrementBtn = container.querySelector('[aria-label="Decrease quantity"]');
|
|
178
|
+
expect(decrementBtn).toHaveClass('dark:bg-gray-700');
|
|
179
|
+
});
|
|
180
|
+
|
|
181
|
+
test('buttons have dark mode border', () => {
|
|
182
|
+
const { container } = render(NumberInput);
|
|
183
|
+
const decrementBtn = container.querySelector('[aria-label="Decrease quantity"]');
|
|
184
|
+
expect(decrementBtn).toHaveClass('dark:border-gray-600');
|
|
185
|
+
});
|
|
186
|
+
|
|
187
|
+
test('display has dark mode background', () => {
|
|
188
|
+
const { container } = render(NumberInput);
|
|
189
|
+
const display = container.querySelector('span');
|
|
190
|
+
expect(display).toHaveClass('dark:bg-gray-800');
|
|
191
|
+
});
|
|
192
|
+
|
|
193
|
+
test('display has dark mode text color', () => {
|
|
194
|
+
const { container } = render(NumberInput);
|
|
195
|
+
const display = container.querySelector('span');
|
|
196
|
+
expect(display).toHaveClass('dark:text-gray-400');
|
|
197
|
+
});
|
|
198
|
+
});
|
|
199
|
+
|
|
200
|
+
describe('NumberInput Icons', () => {
|
|
201
|
+
test('decrement button has minus icon', () => {
|
|
202
|
+
const { container } = render(NumberInput);
|
|
203
|
+
const decrementBtn = container.querySelector('[aria-label="Decrease quantity"]');
|
|
204
|
+
expect(decrementBtn.querySelector('svg')).toBeInTheDocument();
|
|
205
|
+
});
|
|
206
|
+
|
|
207
|
+
test('increment button has plus icon', () => {
|
|
208
|
+
const { container } = render(NumberInput);
|
|
209
|
+
const incrementBtn = container.querySelector('[aria-label="Increase quantity"]');
|
|
210
|
+
expect(incrementBtn.querySelector('svg')).toBeInTheDocument();
|
|
211
|
+
});
|
|
212
|
+
|
|
213
|
+
test('icons have w-3 h-3 size', () => {
|
|
214
|
+
const { container } = render(NumberInput);
|
|
215
|
+
const svgs = container.querySelectorAll('svg');
|
|
216
|
+
svgs.forEach(svg => {
|
|
217
|
+
expect(svg).toHaveClass('w-3');
|
|
218
|
+
expect(svg).toHaveClass('h-3');
|
|
219
|
+
});
|
|
220
|
+
});
|
|
221
|
+
});
|
|
222
|
+
|
|
223
|
+
describe('NumberInput Accessibility', () => {
|
|
224
|
+
test('decrement button has aria-label', () => {
|
|
225
|
+
const { container } = render(NumberInput);
|
|
226
|
+
const decrementBtn = container.querySelector('[aria-label="Decrease quantity"]');
|
|
227
|
+
expect(decrementBtn).toHaveAttribute('aria-label', 'Decrease quantity');
|
|
228
|
+
});
|
|
229
|
+
|
|
230
|
+
test('increment button has aria-label', () => {
|
|
231
|
+
const { container } = render(NumberInput);
|
|
232
|
+
const incrementBtn = container.querySelector('[aria-label="Increase quantity"]');
|
|
233
|
+
expect(incrementBtn).toHaveAttribute('aria-label', 'Increase quantity');
|
|
234
|
+
});
|
|
235
|
+
});
|