@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
|
@@ -0,0 +1,499 @@
|
|
|
1
|
+
import { render, screen, fireEvent, waitFor } from '@testing-library/svelte';
|
|
2
|
+
import { expect, describe, it, beforeEach, afterEach, vi } from 'vitest';
|
|
3
|
+
import ButtonShowcase from './ButtonShowcase.svelte';
|
|
4
|
+
|
|
5
|
+
describe('ButtonShowcase', () => {
|
|
6
|
+
let container;
|
|
7
|
+
|
|
8
|
+
beforeEach(() => {
|
|
9
|
+
// Clear dark mode class before each test
|
|
10
|
+
document.documentElement.classList.remove('dark');
|
|
11
|
+
});
|
|
12
|
+
|
|
13
|
+
afterEach(() => {
|
|
14
|
+
// Clean up after each test
|
|
15
|
+
document.documentElement.classList.remove('dark');
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
describe('Component Rendering', () => {
|
|
19
|
+
it('renders the component successfully', () => {
|
|
20
|
+
const { container } = render(ButtonShowcase);
|
|
21
|
+
expect(container).toBeTruthy();
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
it('renders the main heading', () => {
|
|
25
|
+
render(ButtonShowcase);
|
|
26
|
+
expect(screen.getByText('Button Catalog')).toBeInTheDocument();
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
it('renders the description text', () => {
|
|
30
|
+
render(ButtonShowcase);
|
|
31
|
+
expect(screen.getByText(/Real buttons as they appear in the app/)).toBeInTheDocument();
|
|
32
|
+
expect(screen.getByText(/Use these nicknames when telling Claude what button you want/)).toBeInTheDocument();
|
|
33
|
+
});
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
describe('Dark Mode Toggle', () => {
|
|
37
|
+
it('renders dark mode toggle button', () => {
|
|
38
|
+
render(ButtonShowcase);
|
|
39
|
+
const toggleButton = screen.getByText('Dark Mode');
|
|
40
|
+
expect(toggleButton).toBeInTheDocument();
|
|
41
|
+
});
|
|
42
|
+
|
|
43
|
+
it('toggles to light mode when clicked', async () => {
|
|
44
|
+
render(ButtonShowcase);
|
|
45
|
+
const toggleButton = screen.getByText('Dark Mode').closest('button');
|
|
46
|
+
|
|
47
|
+
await fireEvent.click(toggleButton);
|
|
48
|
+
|
|
49
|
+
expect(document.documentElement.classList.contains('dark')).toBe(true);
|
|
50
|
+
expect(screen.getByText('Light Mode')).toBeInTheDocument();
|
|
51
|
+
});
|
|
52
|
+
|
|
53
|
+
it('toggles back to dark mode when clicked twice', async () => {
|
|
54
|
+
render(ButtonShowcase);
|
|
55
|
+
const toggleButton = screen.getByText('Dark Mode').closest('button');
|
|
56
|
+
|
|
57
|
+
await fireEvent.click(toggleButton);
|
|
58
|
+
expect(document.documentElement.classList.contains('dark')).toBe(true);
|
|
59
|
+
|
|
60
|
+
const lightModeButton = screen.getByText('Light Mode').closest('button');
|
|
61
|
+
await fireEvent.click(lightModeButton);
|
|
62
|
+
|
|
63
|
+
expect(document.documentElement.classList.contains('dark')).toBe(false);
|
|
64
|
+
expect(screen.getByText('Dark Mode')).toBeInTheDocument();
|
|
65
|
+
});
|
|
66
|
+
});
|
|
67
|
+
|
|
68
|
+
describe('Login Page Buttons Section', () => {
|
|
69
|
+
it('renders the Login Page section heading', () => {
|
|
70
|
+
render(ButtonShowcase);
|
|
71
|
+
expect(screen.getByText('Login Page')).toBeInTheDocument();
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
it('renders login button with description', () => {
|
|
75
|
+
render(ButtonShowcase);
|
|
76
|
+
expect(screen.getAllByText('Log in').length).toBeGreaterThan(0);
|
|
77
|
+
expect(screen.getAllByText('"Login button"').length).toBeGreaterThan(0);
|
|
78
|
+
expect(screen.getByText(/Primary login action/)).toBeInTheDocument();
|
|
79
|
+
});
|
|
80
|
+
|
|
81
|
+
it('renders magic link button', () => {
|
|
82
|
+
render(ButtonShowcase);
|
|
83
|
+
expect(screen.getByText('Send me a login link')).toBeInTheDocument();
|
|
84
|
+
expect(screen.getAllByText('"Magic link button"').length).toBeGreaterThan(0);
|
|
85
|
+
});
|
|
86
|
+
|
|
87
|
+
it('renders create account button', () => {
|
|
88
|
+
render(ButtonShowcase);
|
|
89
|
+
expect(screen.getByText('Create account')).toBeInTheDocument();
|
|
90
|
+
expect(screen.getByText('"Signup button"')).toBeInTheDocument();
|
|
91
|
+
});
|
|
92
|
+
|
|
93
|
+
it('displays section location info', () => {
|
|
94
|
+
render(ButtonShowcase);
|
|
95
|
+
expect(screen.getByText('Found on: /login, /signup, /forgot-password')).toBeInTheDocument();
|
|
96
|
+
});
|
|
97
|
+
});
|
|
98
|
+
|
|
99
|
+
describe('Form Buttons Section', () => {
|
|
100
|
+
it('renders the Form Buttons section heading', () => {
|
|
101
|
+
render(ButtonShowcase);
|
|
102
|
+
expect(screen.getByText('Form Buttons (Interactive - Click to see behavior!)')).toBeInTheDocument();
|
|
103
|
+
});
|
|
104
|
+
|
|
105
|
+
it('renders Save Changes button', () => {
|
|
106
|
+
render(ButtonShowcase);
|
|
107
|
+
expect(screen.getByText('Save Changes')).toBeInTheDocument();
|
|
108
|
+
expect(screen.getAllByText('"Save button with feedback"').length).toBeGreaterThan(0);
|
|
109
|
+
});
|
|
110
|
+
|
|
111
|
+
it('shows loading state when Save Changes is clicked', async () => {
|
|
112
|
+
vi.useFakeTimers();
|
|
113
|
+
render(ButtonShowcase);
|
|
114
|
+
|
|
115
|
+
const saveButton = screen.getByText('Save Changes').closest('button');
|
|
116
|
+
await fireEvent.click(saveButton);
|
|
117
|
+
|
|
118
|
+
// Component should show loading state
|
|
119
|
+
expect(saveButton).toHaveAttribute('disabled');
|
|
120
|
+
|
|
121
|
+
vi.useRealTimers();
|
|
122
|
+
});
|
|
123
|
+
|
|
124
|
+
it('shows success state after loading completes', async () => {
|
|
125
|
+
vi.useFakeTimers();
|
|
126
|
+
render(ButtonShowcase);
|
|
127
|
+
|
|
128
|
+
const saveButton = screen.getByText('Save Changes').closest('button');
|
|
129
|
+
await fireEvent.click(saveButton);
|
|
130
|
+
|
|
131
|
+
// Fast-forward through loading (1500ms)
|
|
132
|
+
vi.advanceTimersByTime(1500);
|
|
133
|
+
await waitFor(() => {
|
|
134
|
+
expect(screen.getByText('Saved!')).toBeInTheDocument();
|
|
135
|
+
});
|
|
136
|
+
|
|
137
|
+
vi.useRealTimers();
|
|
138
|
+
});
|
|
139
|
+
|
|
140
|
+
it('renders simple save button', () => {
|
|
141
|
+
render(ButtonShowcase);
|
|
142
|
+
const saveButtons = screen.getAllByText('Save');
|
|
143
|
+
expect(saveButtons.length).toBeGreaterThan(0);
|
|
144
|
+
expect(screen.getByText('"Simple save button"')).toBeInTheDocument();
|
|
145
|
+
});
|
|
146
|
+
|
|
147
|
+
it('renders Cancel/Save pair', () => {
|
|
148
|
+
render(ButtonShowcase);
|
|
149
|
+
expect(screen.getAllByText('Cancel').length).toBeGreaterThan(0);
|
|
150
|
+
expect(screen.getAllByText('"Cancel/Save pair"').length).toBeGreaterThan(0);
|
|
151
|
+
});
|
|
152
|
+
});
|
|
153
|
+
|
|
154
|
+
describe('Modal/Dialog Buttons Section', () => {
|
|
155
|
+
it('renders the Modal section heading', () => {
|
|
156
|
+
render(ButtonShowcase);
|
|
157
|
+
expect(screen.getByText('Modal / Dialog Buttons')).toBeInTheDocument();
|
|
158
|
+
});
|
|
159
|
+
|
|
160
|
+
it('renders Confirm modal buttons', () => {
|
|
161
|
+
render(ButtonShowcase);
|
|
162
|
+
expect(screen.getAllByText('Confirm').length).toBeGreaterThan(0);
|
|
163
|
+
expect(screen.getByText('"Confirm modal"')).toBeInTheDocument();
|
|
164
|
+
});
|
|
165
|
+
|
|
166
|
+
it('renders Delete confirmation buttons', () => {
|
|
167
|
+
render(ButtonShowcase);
|
|
168
|
+
expect(screen.getAllByText('Delete').length).toBeGreaterThan(0);
|
|
169
|
+
expect(screen.getAllByText('"Delete confirmation"').length).toBeGreaterThan(0);
|
|
170
|
+
});
|
|
171
|
+
|
|
172
|
+
it('renders Remove confirmation buttons', () => {
|
|
173
|
+
render(ButtonShowcase);
|
|
174
|
+
expect(screen.getByText('No, keep it')).toBeInTheDocument();
|
|
175
|
+
expect(screen.getByText('Yes, remove')).toBeInTheDocument();
|
|
176
|
+
expect(screen.getByText('"Remove confirmation"')).toBeInTheDocument();
|
|
177
|
+
});
|
|
178
|
+
|
|
179
|
+
it('renders Done button', () => {
|
|
180
|
+
render(ButtonShowcase);
|
|
181
|
+
expect(screen.getByText('Done')).toBeInTheDocument();
|
|
182
|
+
expect(screen.getByText('"Done button"')).toBeInTheDocument();
|
|
183
|
+
});
|
|
184
|
+
});
|
|
185
|
+
|
|
186
|
+
describe('Action Buttons Section', () => {
|
|
187
|
+
it('renders the Action Buttons section heading', () => {
|
|
188
|
+
render(ButtonShowcase);
|
|
189
|
+
expect(screen.getByText('Action Buttons')).toBeInTheDocument();
|
|
190
|
+
});
|
|
191
|
+
|
|
192
|
+
it('renders Invite button', () => {
|
|
193
|
+
render(ButtonShowcase);
|
|
194
|
+
expect(screen.getByText('Invite')).toBeInTheDocument();
|
|
195
|
+
expect(screen.getByText('"Invite button"')).toBeInTheDocument();
|
|
196
|
+
});
|
|
197
|
+
|
|
198
|
+
it('shows loading and success states for Invite button', async () => {
|
|
199
|
+
vi.useFakeTimers();
|
|
200
|
+
render(ButtonShowcase);
|
|
201
|
+
|
|
202
|
+
const inviteButton = screen.getByText('Invite').closest('button');
|
|
203
|
+
await fireEvent.click(inviteButton);
|
|
204
|
+
|
|
205
|
+
expect(inviteButton).toHaveAttribute('disabled');
|
|
206
|
+
|
|
207
|
+
// Fast-forward through loading
|
|
208
|
+
vi.advanceTimersByTime(1500);
|
|
209
|
+
await waitFor(() => {
|
|
210
|
+
expect(screen.getByText('Invited!')).toBeInTheDocument();
|
|
211
|
+
});
|
|
212
|
+
|
|
213
|
+
vi.useRealTimers();
|
|
214
|
+
});
|
|
215
|
+
|
|
216
|
+
it('renders Add Performer button with icon', () => {
|
|
217
|
+
render(ButtonShowcase);
|
|
218
|
+
expect(screen.getByText('Add Performer')).toBeInTheDocument();
|
|
219
|
+
expect(screen.getAllByText('"Add button with icon"').length).toBeGreaterThan(0);
|
|
220
|
+
});
|
|
221
|
+
|
|
222
|
+
it('renders Edit button', () => {
|
|
223
|
+
render(ButtonShowcase);
|
|
224
|
+
expect(screen.getAllByText('Edit').length).toBeGreaterThan(0);
|
|
225
|
+
expect(screen.getAllByText('"Edit button"').length).toBeGreaterThan(0);
|
|
226
|
+
});
|
|
227
|
+
|
|
228
|
+
it('renders View Details button', () => {
|
|
229
|
+
render(ButtonShowcase);
|
|
230
|
+
expect(screen.getByText('View Details')).toBeInTheDocument();
|
|
231
|
+
expect(screen.getByText('"View button" or "Details button"')).toBeInTheDocument();
|
|
232
|
+
});
|
|
233
|
+
|
|
234
|
+
it('renders Back button with icon', () => {
|
|
235
|
+
render(ButtonShowcase);
|
|
236
|
+
expect(screen.getAllByText('Back').length).toBeGreaterThan(0);
|
|
237
|
+
expect(screen.getAllByText('"Back button"').length).toBeGreaterThan(0);
|
|
238
|
+
});
|
|
239
|
+
});
|
|
240
|
+
|
|
241
|
+
describe('Danger/Warning Buttons Section', () => {
|
|
242
|
+
it('renders the Danger section heading', () => {
|
|
243
|
+
render(ButtonShowcase);
|
|
244
|
+
expect(screen.getByText('Danger / Warning Buttons')).toBeInTheDocument();
|
|
245
|
+
});
|
|
246
|
+
|
|
247
|
+
it('renders solid red Delete button', () => {
|
|
248
|
+
render(ButtonShowcase);
|
|
249
|
+
expect(screen.getByText('"Delete button" (solid red)')).toBeInTheDocument();
|
|
250
|
+
});
|
|
251
|
+
|
|
252
|
+
it('renders red outline Remove button', () => {
|
|
253
|
+
render(ButtonShowcase);
|
|
254
|
+
expect(screen.getAllByText('Remove').length).toBeGreaterThan(0);
|
|
255
|
+
expect(screen.getByText('"Remove button" (red outline)')).toBeInTheDocument();
|
|
256
|
+
});
|
|
257
|
+
|
|
258
|
+
it('renders Delete Event button with icon', () => {
|
|
259
|
+
render(ButtonShowcase);
|
|
260
|
+
expect(screen.getByText('Delete Event')).toBeInTheDocument();
|
|
261
|
+
expect(screen.getByText('"Delete with icon"')).toBeInTheDocument();
|
|
262
|
+
});
|
|
263
|
+
|
|
264
|
+
it('renders Sign out button', () => {
|
|
265
|
+
render(ButtonShowcase);
|
|
266
|
+
expect(screen.getAllByText('Sign out').length).toBeGreaterThan(0);
|
|
267
|
+
expect(screen.getAllByText('"Sign out button"').length).toBeGreaterThan(0);
|
|
268
|
+
});
|
|
269
|
+
|
|
270
|
+
it('renders Cancel subscription button', () => {
|
|
271
|
+
render(ButtonShowcase);
|
|
272
|
+
expect(screen.getAllByText('Cancel subscription').length).toBeGreaterThan(0);
|
|
273
|
+
expect(screen.getByText('"Cancel subscription"')).toBeInTheDocument();
|
|
274
|
+
});
|
|
275
|
+
});
|
|
276
|
+
|
|
277
|
+
describe('Toggle/Filter Buttons Section', () => {
|
|
278
|
+
it('renders the Toggle section heading', () => {
|
|
279
|
+
render(ButtonShowcase);
|
|
280
|
+
expect(screen.getByText('Toggle / Filter Buttons')).toBeInTheDocument();
|
|
281
|
+
});
|
|
282
|
+
|
|
283
|
+
it('renders filter tabs group', () => {
|
|
284
|
+
render(ButtonShowcase);
|
|
285
|
+
expect(screen.getByText('Upcoming')).toBeInTheDocument();
|
|
286
|
+
expect(screen.getByText('Past')).toBeInTheDocument();
|
|
287
|
+
expect(screen.getAllByText('All').length).toBeGreaterThan(0);
|
|
288
|
+
expect(screen.getByText('"Filter tabs" or "Toggle group"')).toBeInTheDocument();
|
|
289
|
+
});
|
|
290
|
+
|
|
291
|
+
it('renders small filter toggles', () => {
|
|
292
|
+
render(ButtonShowcase);
|
|
293
|
+
expect(screen.getByText('Active')).toBeInTheDocument();
|
|
294
|
+
expect(screen.getByText('Inactive')).toBeInTheDocument();
|
|
295
|
+
expect(screen.getByText('"Small filter toggles"')).toBeInTheDocument();
|
|
296
|
+
});
|
|
297
|
+
});
|
|
298
|
+
|
|
299
|
+
describe('Link-Style Buttons Section', () => {
|
|
300
|
+
it('renders the Link-Style section heading', () => {
|
|
301
|
+
render(ButtonShowcase);
|
|
302
|
+
expect(screen.getByText('Link-Style Buttons')).toBeInTheDocument();
|
|
303
|
+
});
|
|
304
|
+
|
|
305
|
+
it('renders Forgot password link button', () => {
|
|
306
|
+
render(ButtonShowcase);
|
|
307
|
+
expect(screen.getByText('Forgot password?')).toBeInTheDocument();
|
|
308
|
+
expect(screen.getByText('"Link button" or "Text link"')).toBeInTheDocument();
|
|
309
|
+
});
|
|
310
|
+
|
|
311
|
+
it('renders Learn more link', () => {
|
|
312
|
+
render(ButtonShowcase);
|
|
313
|
+
expect(screen.getByText('Learn more')).toBeInTheDocument();
|
|
314
|
+
expect(screen.getByText('"Learn more link"')).toBeInTheDocument();
|
|
315
|
+
});
|
|
316
|
+
});
|
|
317
|
+
|
|
318
|
+
describe('Size Comparison Section', () => {
|
|
319
|
+
it('renders the Size Comparison section heading', () => {
|
|
320
|
+
render(ButtonShowcase);
|
|
321
|
+
expect(screen.getByText('Size Comparison')).toBeInTheDocument();
|
|
322
|
+
});
|
|
323
|
+
|
|
324
|
+
it('renders all button sizes', () => {
|
|
325
|
+
render(ButtonShowcase);
|
|
326
|
+
expect(screen.getByText('Extra Small')).toBeInTheDocument();
|
|
327
|
+
expect(screen.getByText('Small')).toBeInTheDocument();
|
|
328
|
+
expect(screen.getByText('Medium')).toBeInTheDocument();
|
|
329
|
+
expect(screen.getByText('Large')).toBeInTheDocument();
|
|
330
|
+
expect(screen.getByText('Extra Large')).toBeInTheDocument();
|
|
331
|
+
});
|
|
332
|
+
|
|
333
|
+
it('displays size descriptions', () => {
|
|
334
|
+
render(ButtonShowcase);
|
|
335
|
+
expect(screen.getByText('xs - Compact UI')).toBeInTheDocument();
|
|
336
|
+
expect(screen.getByText('sm - Table rows')).toBeInTheDocument();
|
|
337
|
+
expect(screen.getByText('md - Default')).toBeInTheDocument();
|
|
338
|
+
expect(screen.getByText('lg - Emphasis')).toBeInTheDocument();
|
|
339
|
+
expect(screen.getByText('xl - Hero buttons')).toBeInTheDocument();
|
|
340
|
+
});
|
|
341
|
+
|
|
342
|
+
it('renders full-width button examples', () => {
|
|
343
|
+
render(ButtonShowcase);
|
|
344
|
+
expect(screen.getByText('Full-width buttons (for forms)')).toBeInTheDocument();
|
|
345
|
+
expect(screen.getByText('Submit Application')).toBeInTheDocument();
|
|
346
|
+
expect(screen.getByText('xl-medium - Login/signup forms')).toBeInTheDocument();
|
|
347
|
+
expect(screen.getByText('full - Larger form submit')).toBeInTheDocument();
|
|
348
|
+
});
|
|
349
|
+
});
|
|
350
|
+
|
|
351
|
+
describe('Quick Nickname Reference Section', () => {
|
|
352
|
+
it('renders the Quick Nickname Reference section heading', () => {
|
|
353
|
+
render(ButtonShowcase);
|
|
354
|
+
expect(screen.getByText('Quick Nickname Reference')).toBeInTheDocument();
|
|
355
|
+
});
|
|
356
|
+
|
|
357
|
+
it('renders the reference table', () => {
|
|
358
|
+
render(ButtonShowcase);
|
|
359
|
+
expect(screen.getByText('Say this to Claude')).toBeInTheDocument();
|
|
360
|
+
expect(screen.getByText("You'll get")).toBeInTheDocument();
|
|
361
|
+
expect(screen.getByText("Where it's used")).toBeInTheDocument();
|
|
362
|
+
});
|
|
363
|
+
|
|
364
|
+
it('renders table rows with button nicknames', () => {
|
|
365
|
+
const { container } = render(ButtonShowcase);
|
|
366
|
+
// Check that the table exists and has content
|
|
367
|
+
const table = container.querySelector('table');
|
|
368
|
+
expect(table).toBeInTheDocument();
|
|
369
|
+
|
|
370
|
+
// Check a few key entries in the table
|
|
371
|
+
expect(screen.getAllByText('"Login button"').length).toBeGreaterThan(0);
|
|
372
|
+
expect(screen.getAllByText('"Magic link button"').length).toBeGreaterThan(0);
|
|
373
|
+
expect(screen.getAllByText('"Save button with feedback"').length).toBeGreaterThan(0);
|
|
374
|
+
});
|
|
375
|
+
|
|
376
|
+
it('displays usage context in table', () => {
|
|
377
|
+
render(ButtonShowcase);
|
|
378
|
+
expect(screen.getByText('Login page, signup')).toBeInTheDocument();
|
|
379
|
+
expect(screen.getByText('Profile, settings forms')).toBeInTheDocument();
|
|
380
|
+
expect(screen.getByText('Any form footer')).toBeInTheDocument();
|
|
381
|
+
});
|
|
382
|
+
});
|
|
383
|
+
|
|
384
|
+
describe('Layout and Structure', () => {
|
|
385
|
+
it('uses proper spacing and layout classes', () => {
|
|
386
|
+
const { container } = render(ButtonShowcase);
|
|
387
|
+
const mainDiv = container.querySelector('.p-8.space-y-12');
|
|
388
|
+
expect(mainDiv).toBeInTheDocument();
|
|
389
|
+
});
|
|
390
|
+
|
|
391
|
+
it('renders all sections with proper section tags', () => {
|
|
392
|
+
const { container } = render(ButtonShowcase);
|
|
393
|
+
const sections = container.querySelectorAll('section');
|
|
394
|
+
// Should have 9 main sections
|
|
395
|
+
expect(sections.length).toBeGreaterThanOrEqual(9);
|
|
396
|
+
});
|
|
397
|
+
|
|
398
|
+
it('has background styling for light mode', () => {
|
|
399
|
+
const { container } = render(ButtonShowcase);
|
|
400
|
+
const mainDiv = container.querySelector('.bg-gray-50');
|
|
401
|
+
expect(mainDiv).toBeInTheDocument();
|
|
402
|
+
});
|
|
403
|
+
|
|
404
|
+
it('includes dark mode styling classes', () => {
|
|
405
|
+
const { container } = render(ButtonShowcase);
|
|
406
|
+
const darkModeElements = container.querySelectorAll('.dark\\:bg-gray-900, .dark\\:text-white');
|
|
407
|
+
expect(darkModeElements.length).toBeGreaterThan(0);
|
|
408
|
+
});
|
|
409
|
+
});
|
|
410
|
+
|
|
411
|
+
describe('Interactive Features', () => {
|
|
412
|
+
it('maintains state for save button loading', async () => {
|
|
413
|
+
vi.useFakeTimers();
|
|
414
|
+
render(ButtonShowcase);
|
|
415
|
+
|
|
416
|
+
const saveButton = screen.getByText('Save Changes').closest('button');
|
|
417
|
+
|
|
418
|
+
// Initial state - not loading
|
|
419
|
+
expect(saveButton).not.toHaveAttribute('disabled');
|
|
420
|
+
|
|
421
|
+
// Click to trigger loading
|
|
422
|
+
await fireEvent.click(saveButton);
|
|
423
|
+
expect(saveButton).toHaveAttribute('disabled');
|
|
424
|
+
|
|
425
|
+
vi.useRealTimers();
|
|
426
|
+
});
|
|
427
|
+
|
|
428
|
+
it('resets success state after timeout', async () => {
|
|
429
|
+
vi.useFakeTimers();
|
|
430
|
+
render(ButtonShowcase);
|
|
431
|
+
|
|
432
|
+
const saveButton = screen.getByText('Save Changes').closest('button');
|
|
433
|
+
await fireEvent.click(saveButton);
|
|
434
|
+
|
|
435
|
+
// Fast-forward to success state
|
|
436
|
+
vi.advanceTimersByTime(1500);
|
|
437
|
+
await waitFor(() => {
|
|
438
|
+
expect(screen.getByText('Saved!')).toBeInTheDocument();
|
|
439
|
+
});
|
|
440
|
+
|
|
441
|
+
// Fast-forward through success display duration
|
|
442
|
+
vi.advanceTimersByTime(2000);
|
|
443
|
+
await waitFor(() => {
|
|
444
|
+
expect(screen.queryByText('Saved!')).not.toBeInTheDocument();
|
|
445
|
+
});
|
|
446
|
+
|
|
447
|
+
vi.useRealTimers();
|
|
448
|
+
});
|
|
449
|
+
|
|
450
|
+
it('handles multiple button interactions independently', async () => {
|
|
451
|
+
vi.useFakeTimers();
|
|
452
|
+
render(ButtonShowcase);
|
|
453
|
+
|
|
454
|
+
const saveButton = screen.getByText('Save Changes').closest('button');
|
|
455
|
+
const inviteButton = screen.getByText('Invite').closest('button');
|
|
456
|
+
|
|
457
|
+
// Click both buttons
|
|
458
|
+
await fireEvent.click(saveButton);
|
|
459
|
+
await fireEvent.click(inviteButton);
|
|
460
|
+
|
|
461
|
+
// Both should be disabled during loading
|
|
462
|
+
expect(saveButton).toHaveAttribute('disabled');
|
|
463
|
+
expect(inviteButton).toHaveAttribute('disabled');
|
|
464
|
+
|
|
465
|
+
vi.useRealTimers();
|
|
466
|
+
});
|
|
467
|
+
});
|
|
468
|
+
|
|
469
|
+
describe('Section Presence', () => {
|
|
470
|
+
it('renders all major section headings', () => {
|
|
471
|
+
render(ButtonShowcase);
|
|
472
|
+
|
|
473
|
+
const expectedSections = [
|
|
474
|
+
'Login Page',
|
|
475
|
+
'Form Buttons (Interactive - Click to see behavior!)',
|
|
476
|
+
'Modal / Dialog Buttons',
|
|
477
|
+
'Action Buttons',
|
|
478
|
+
'Danger / Warning Buttons',
|
|
479
|
+
'Toggle / Filter Buttons',
|
|
480
|
+
'Link-Style Buttons',
|
|
481
|
+
'Size Comparison',
|
|
482
|
+
'Quick Nickname Reference'
|
|
483
|
+
];
|
|
484
|
+
|
|
485
|
+
expectedSections.forEach(section => {
|
|
486
|
+
expect(screen.getByText(section)).toBeInTheDocument();
|
|
487
|
+
});
|
|
488
|
+
});
|
|
489
|
+
|
|
490
|
+
it('displays location hints for each section', () => {
|
|
491
|
+
render(ButtonShowcase);
|
|
492
|
+
|
|
493
|
+
expect(screen.getByText('Found on: /login, /signup, /forgot-password')).toBeInTheDocument();
|
|
494
|
+
expect(screen.getByText('Found on: Performer Profile, Venue Settings, any edit form')).toBeInTheDocument();
|
|
495
|
+
expect(screen.getByText('Found on: Confirmation dialogs, edit modals, delete warnings')).toBeInTheDocument();
|
|
496
|
+
expect(screen.getByText('Found on: Table rows, cards, toolbars')).toBeInTheDocument();
|
|
497
|
+
});
|
|
498
|
+
});
|
|
499
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PatternsGallery.spec.d.ts","sourceRoot":"","sources":["../../src/lib/stories/PatternsGallery.spec.js"],"names":[],"mappings":""}
|