@getmicdrop/svelte-components 5.20.0 → 5.20.2
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.svelte +191 -191
- package/dist/calendar/Calendar/MiniMonthCalendar.svelte +803 -803
- package/dist/calendar/FAQs/FAQs.svelte +88 -88
- package/dist/calendar/MonthSwitcher/MonthSwitcher.svelte +140 -140
- package/dist/calendar/OrderSummary/OrderSummary.svelte +461 -461
- package/dist/calendar/PublicCard/PublicCard.svelte +164 -164
- package/dist/calendar/ShowCard/ShowCard.svelte +180 -180
- package/dist/calendar/ShowTimeCard/ShowTimeCard.svelte +80 -80
- package/dist/calendar/index.js +15 -15
- package/dist/components/Heading.spec.js +89 -89
- package/dist/components/Heading.svelte +66 -66
- package/dist/components/Layout/AppShell.svelte +104 -104
- package/dist/components/Layout/ContentSection.svelte +80 -80
- package/dist/components/Layout/Grid.svelte +101 -101
- package/dist/components/Layout/Heading.svelte +81 -81
- package/dist/components/Layout/PageContainer.svelte +69 -69
- package/dist/components/Layout/Responsive.svelte +75 -75
- package/dist/components/Layout/Section.svelte +80 -80
- package/dist/components/Layout/ShowOnDesktop.svelte +37 -37
- package/dist/components/Layout/ShowOnMobile.svelte +37 -37
- package/dist/components/Layout/Sidebar.svelte +108 -108
- package/dist/components/Layout/Stack.spec.js +1 -1
- package/dist/components/Layout/Stack.svelte +52 -52
- package/dist/components/Layout/Text.svelte +87 -87
- package/dist/components/Layout/TwoColumn.svelte +108 -108
- package/dist/components/Text.spec.js +89 -89
- package/dist/components/Text.svelte +64 -64
- package/dist/config.d.ts +13 -2
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +160 -151
- package/dist/config.spec.js +29 -29
- package/dist/constants/formOptions.js +48 -48
- package/dist/constants/validation.js +91 -91
- package/dist/constants/validation.spec.js +64 -64
- package/dist/datetime/README.md +323 -323
- package/dist/datetime/__tests__/format.test.js +1 -1
- package/dist/datetime/__tests__/parse.test.js +1 -1
- package/dist/datetime/__tests__/timezone.test.js +1 -1
- package/dist/datetime/parse.js +1 -1
- package/dist/forms/createFormStore.svelte.js +1 -0
- package/dist/forms/createFormStore.svelte.spec.js +1 -0
- package/dist/index.js +85 -85
- package/dist/index.spec.js +369 -369
- package/dist/patterns/chat/ChatActivityNotice.spec.js +59 -59
- package/dist/patterns/chat/ChatActivityNotice.svelte +41 -41
- package/dist/patterns/chat/ChatBubble.spec.js +91 -91
- package/dist/patterns/chat/ChatBubble.svelte +103 -103
- package/dist/patterns/chat/ChatContainer.spec.js +30 -30
- package/dist/patterns/chat/ChatContainer.svelte +46 -46
- package/dist/patterns/chat/ChatDateDivider.spec.js +30 -30
- package/dist/patterns/chat/ChatDateDivider.svelte +27 -27
- package/dist/patterns/chat/ChatInvitationBubble.spec.js +46 -46
- package/dist/patterns/chat/ChatInvitationBubble.svelte +46 -46
- package/dist/patterns/chat/ChatInvitationNotice.spec.js +32 -32
- package/dist/patterns/chat/ChatInvitationNotice.svelte +36 -36
- package/dist/patterns/chat/ChatMessageGroup.spec.js +58 -58
- package/dist/patterns/chat/ChatMessageGroup.svelte +57 -57
- package/dist/patterns/chat/ChatSlotUpdate.spec.js +65 -65
- package/dist/patterns/chat/ChatSlotUpdate.svelte +46 -46
- package/dist/patterns/chat/ChatStatusBadge.spec.js +79 -79
- package/dist/patterns/chat/ChatStatusBadge.svelte +91 -91
- package/dist/patterns/chat/ChatStatusTransition.spec.js +81 -81
- package/dist/patterns/chat/ChatStatusTransition.svelte +64 -64
- package/dist/patterns/chat/ChatTextBubble.spec.js +35 -35
- package/dist/patterns/chat/ChatTextBubble.svelte +41 -41
- package/dist/patterns/chat/index.js +22 -22
- package/dist/patterns/data/DataGrid.svelte +45 -45
- package/dist/patterns/data/DataList.svelte +24 -24
- package/dist/patterns/data/DataTable.svelte +45 -45
- package/dist/patterns/data/index.js +4 -4
- package/dist/patterns/forms/FormActions.spec.js +95 -95
- package/dist/patterns/forms/FormActions.stories.svelte +97 -97
- package/dist/patterns/forms/FormActions.svelte +46 -46
- package/dist/patterns/forms/FormGrid.svelte +33 -33
- package/dist/patterns/forms/FormSection.svelte +33 -33
- package/dist/patterns/forms/FormValidationSummary.stories.svelte +97 -97
- package/dist/patterns/forms/FormValidationSummary.svelte +82 -82
- package/dist/patterns/forms/index.js +5 -5
- package/dist/patterns/index.js +21 -21
- package/dist/patterns/layout/Sidebar.svelte +39 -39
- package/dist/patterns/layout/SidebarTestWrapper.svelte +34 -34
- package/dist/patterns/layout/Stack.svelte +61 -61
- package/dist/patterns/layout/index.js +29 -29
- package/dist/patterns/navigation/BottomNav.stories.svelte +117 -117
- package/dist/patterns/navigation/BottomNav.svelte +82 -82
- package/dist/patterns/navigation/Header.stories.svelte +77 -77
- package/dist/patterns/navigation/Header.svelte +263 -263
- package/dist/patterns/navigation/index.js +3 -3
- package/dist/patterns/page/PageHeader.svelte +49 -49
- package/dist/patterns/page/PageLayout.svelte +40 -40
- package/dist/patterns/page/PageLoader.spec.js +57 -57
- package/dist/patterns/page/PageLoader.stories.svelte +137 -137
- package/dist/patterns/page/PageLoader.svelte +62 -62
- package/dist/patterns/page/SectionHeader.svelte +51 -51
- package/dist/patterns/page/index.js +5 -5
- package/dist/presets/badges.js +112 -112
- package/dist/presets/buttons.js +76 -76
- package/dist/presets/index.js +9 -9
- package/dist/primitives/Accordion/Accordion.stories.svelte +75 -75
- package/dist/primitives/Accordion/Accordion.svelte +62 -62
- package/dist/primitives/Accordion/AccordionItem.svelte +103 -103
- package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte +107 -107
- package/dist/primitives/Accordion/AccordionToggleWrapper.test.svelte +28 -28
- package/dist/primitives/Alert/Alert.spec.js +173 -173
- package/dist/primitives/Alert/Alert.stories.svelte +88 -88
- package/dist/primitives/Alert/Alert.svelte +72 -72
- package/dist/primitives/Avatar/Avatar.stories.svelte +94 -94
- package/dist/primitives/Avatar/Avatar.svelte +66 -66
- package/dist/primitives/AvatarButton/AvatarButton.svelte +57 -57
- package/dist/primitives/Badges/Badge.spec.js +144 -144
- package/dist/primitives/Badges/Badge.stories.svelte +86 -86
- package/dist/primitives/Badges/Badge.svelte +99 -99
- package/dist/primitives/BottomSheet/BottomSheet.spec.js +238 -238
- package/dist/primitives/BottomSheet/BottomSheet.stories.svelte +83 -83
- package/dist/primitives/BottomSheet/BottomSheet.svelte +115 -115
- package/dist/primitives/BottomSheet/BottomSheetWithActions.test.svelte +20 -20
- package/dist/primitives/Breadcrumb/Breadcrumb.spec.js +123 -123
- package/dist/primitives/Breadcrumb/Breadcrumb.stories.svelte +23 -23
- package/dist/primitives/Breadcrumb/Breadcrumb.svelte +107 -107
- package/dist/primitives/Button/Button.spec.js +225 -225
- package/dist/primitives/Button/Button.stories.svelte +76 -76
- package/dist/primitives/Button/Button.svelte +278 -278
- package/dist/primitives/Button/ButtonGroup.spec.js +44 -44
- package/dist/primitives/Button/ButtonGroup.svelte +50 -50
- package/dist/primitives/Button/ButtonSaveDemo.spec.js +146 -146
- package/dist/primitives/Button/ButtonSaveDemo.svelte +25 -25
- package/dist/primitives/Button/ButtonVariantShowcase.svelte +129 -129
- package/dist/primitives/Card.spec.js +49 -49
- package/dist/primitives/Card.stories.svelte +22 -22
- package/dist/primitives/Card.svelte +28 -28
- package/dist/primitives/CardAction/CardAction.svelte +68 -68
- package/dist/primitives/Checkbox/Checkbox.stories.svelte +84 -84
- package/dist/primitives/Checkbox/Checkbox.svelte +88 -88
- package/dist/primitives/DarkModeToggle.spec.js +390 -390
- package/dist/primitives/DarkModeToggle.stories.svelte +57 -57
- package/dist/primitives/DarkModeToggle.svelte +147 -147
- package/dist/primitives/Drawer/Drawer.stories.svelte +100 -100
- package/dist/primitives/Drawer/Drawer.svelte +224 -224
- package/dist/primitives/Drawer/DrawerTestWrapper.svelte +86 -86
- package/dist/primitives/Dropdown/Dropdown.stories.svelte +137 -137
- package/dist/primitives/Dropdown/Dropdown.svelte +179 -179
- package/dist/primitives/Dropdown/DropdownDivider.spec.js +30 -30
- package/dist/primitives/Dropdown/DropdownDivider.svelte +9 -9
- package/dist/primitives/Dropdown/DropdownItem.svelte +80 -80
- package/dist/primitives/Dropdown/DropdownItemTestWrapper.svelte +43 -43
- package/dist/primitives/Helper/Helper.spec.js +57 -57
- package/dist/primitives/Helper/Helper.svelte +33 -33
- package/dist/primitives/Icons/ArrowLeft.svelte +21 -21
- package/dist/primitives/Icons/ArrowRight.svelte +21 -21
- package/dist/primitives/Icons/Availability.svelte +27 -27
- package/dist/primitives/Icons/Back.svelte +27 -27
- package/dist/primitives/Icons/CheckCircle.svelte +19 -19
- package/dist/primitives/Icons/CheckCircleOutline.svelte +28 -28
- package/dist/primitives/Icons/ChevronLeft.svelte +17 -17
- package/dist/primitives/Icons/ChevronRight.svelte +17 -17
- package/dist/primitives/Icons/Copy.svelte +28 -28
- package/dist/primitives/Icons/Cross.svelte +18 -18
- package/dist/primitives/Icons/DownArrow.svelte +21 -21
- package/dist/primitives/Icons/ErrorCircle.svelte +19 -19
- package/dist/primitives/Icons/FacebookIcon.svelte +15 -15
- package/dist/primitives/Icons/Home.svelte +28 -28
- package/dist/primitives/Icons/Icon.spec.js +175 -175
- package/dist/primitives/Icons/Icon.stories.svelte +100 -100
- package/dist/primitives/Icons/Icon.svelte +79 -79
- package/dist/primitives/Icons/IconGallery.stories.svelte +235 -235
- package/dist/primitives/Icons/ImageOutline.svelte +21 -21
- package/dist/primitives/Icons/Info.svelte +20 -20
- package/dist/primitives/Icons/InstagramIcon.svelte +21 -21
- package/dist/primitives/Icons/LogoInstagram.svelte +15 -15
- package/dist/primitives/Icons/Message.svelte +28 -28
- package/dist/primitives/Icons/MoonIcon.svelte +18 -18
- package/dist/primitives/Icons/More.svelte +34 -34
- package/dist/primitives/Icons/MoreHori.spec.js +67 -67
- package/dist/primitives/Icons/MoreHori.svelte +35 -35
- package/dist/primitives/Icons/Notification.svelte +27 -27
- package/dist/primitives/Icons/Payment.svelte +27 -27
- package/dist/primitives/Icons/Profile.svelte +34 -34
- package/dist/primitives/Icons/Reload.svelte +42 -42
- package/dist/primitives/Icons/Shows.svelte +34 -34
- package/dist/primitives/Icons/Signout.svelte +34 -34
- package/dist/primitives/Icons/SunIcon.svelte +21 -21
- package/dist/primitives/Icons/TiktokIcon.svelte +15 -15
- package/dist/primitives/Icons/TrashBinOutline.svelte +21 -21
- package/dist/primitives/Icons/TwitterIcon.svelte +15 -15
- package/dist/primitives/Icons/WarningIcon.spec.js +30 -30
- package/dist/primitives/Icons/WarningIcon.svelte +24 -24
- package/dist/primitives/Input/Input.spec.js +1237 -1237
- package/dist/primitives/Input/Input.stories.svelte +139 -139
- package/dist/primitives/Input/Input.svelte +444 -444
- package/dist/primitives/Input/Select.spec.js +632 -632
- package/dist/primitives/Input/Select.stories.svelte +112 -112
- package/dist/primitives/Input/Select.svelte +252 -252
- package/dist/primitives/Input/Textarea.stories.svelte +137 -137
- package/dist/primitives/Input/Textarea.svelte +105 -105
- package/dist/primitives/Label/Label.svelte +37 -37
- package/dist/primitives/LandingButton/LandingButton.spec.js +61 -61
- package/dist/primitives/LandingButton/LandingButton.svelte +92 -92
- package/dist/primitives/MenuItem/MenuItem.spec.js +130 -130
- package/dist/primitives/MenuItem/MenuItem.svelte +85 -85
- package/dist/primitives/Modal/Modal.spec.js +314 -314
- package/dist/primitives/Modal/Modal.stories.svelte +86 -86
- package/dist/primitives/Modal/Modal.svelte +181 -181
- package/dist/primitives/NavItem/NavItem.spec.js +97 -97
- package/dist/primitives/NavItem/NavItem.svelte +75 -75
- package/dist/primitives/NumberInput/NumberInput.svelte +113 -113
- package/dist/primitives/Pagination/DotIndicator.svelte +66 -66
- package/dist/primitives/Pagination/Pagination.stories.svelte +76 -76
- package/dist/primitives/Pagination/Pagination.svelte +275 -275
- package/dist/primitives/Radio/Radio.stories.svelte +80 -80
- package/dist/primitives/Radio/Radio.svelte +67 -67
- package/dist/primitives/SearchResultItem/SearchResultItem.spec.js +78 -78
- package/dist/primitives/SearchResultItem/SearchResultItem.svelte +109 -109
- package/dist/primitives/SidebarToggle/SidebarToggle.spec.js +61 -61
- package/dist/primitives/SidebarToggle/SidebarToggle.svelte +55 -55
- package/dist/primitives/Skeleton/CardPlaceholder.svelte +96 -96
- package/dist/primitives/Skeleton/ImagePlaceholder.svelte +68 -68
- package/dist/primitives/Skeleton/ListPlaceholder.svelte +85 -85
- package/dist/primitives/Skeleton/Skeleton.stories.svelte +151 -151
- package/dist/primitives/Skeleton/Skeleton.svelte +55 -55
- package/dist/primitives/Spinner/Spinner.spec.js +84 -84
- package/dist/primitives/Spinner/Spinner.stories.svelte +29 -29
- package/dist/primitives/Spinner/Spinner.svelte +52 -52
- package/dist/primitives/Tabs/TabItem.svelte +52 -52
- package/dist/primitives/Tabs/Tabs.stories.svelte +112 -112
- package/dist/primitives/Tabs/Tabs.svelte +137 -137
- package/dist/primitives/Toggle.spec.js +221 -221
- package/dist/primitives/Toggle.stories.svelte +92 -92
- package/dist/primitives/Toggle.svelte +141 -141
- package/dist/primitives/ToggleTestWrapper.svelte +30 -30
- package/dist/primitives/Tooltip/Tooltip.spec.js +126 -126
- package/dist/primitives/Tooltip/Tooltip.svelte +83 -83
- package/dist/primitives/Typography/Typography.svelte +53 -53
- package/dist/primitives/ValidationError.spec.js +103 -103
- package/dist/primitives/ValidationError.stories.svelte +112 -112
- package/dist/primitives/ValidationError.svelte +29 -29
- package/dist/primitives/index.js +114 -114
- package/dist/recipes/CropImage/CropImage.spec.js +208 -208
- package/dist/recipes/CropImage/CropImage.stories.svelte +104 -104
- package/dist/recipes/CropImage/CropImage.svelte +241 -241
- package/dist/recipes/ImageUploader/ImageUploader.stories.svelte +125 -125
- package/dist/recipes/ImageUploader/ImageUploader.svelte +994 -994
- package/dist/recipes/SuperLogin/SuperLogin.svelte +5 -4
- 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.svelte +75 -75
- package/dist/recipes/feedback/ErrorDisplay.spec.js +69 -69
- package/dist/recipes/feedback/ErrorDisplay.stories.svelte +113 -113
- package/dist/recipes/feedback/ErrorDisplay.svelte +67 -67
- package/dist/recipes/feedback/StatusIndicator/StatusIndicator.spec.js +133 -133
- package/dist/recipes/feedback/StatusIndicator/StatusIndicator.svelte +176 -176
- package/dist/recipes/feedback/index.js +4 -4
- package/dist/recipes/fields/CheckboxField.svelte +85 -85
- package/dist/recipes/fields/FormField.svelte +58 -58
- package/dist/recipes/fields/RadioGroup.svelte +95 -95
- package/dist/recipes/fields/SelectField.svelte +82 -82
- package/dist/recipes/fields/TextareaField.svelte +101 -101
- package/dist/recipes/fields/ToggleField.svelte +60 -60
- package/dist/recipes/fields/index.js +7 -7
- package/dist/recipes/index.js +24 -24
- package/dist/recipes/inputs/MultiSelect.spec.js +263 -263
- package/dist/recipes/inputs/MultiSelect.stories.svelte +133 -133
- package/dist/recipes/inputs/MultiSelect.svelte +291 -291
- package/dist/recipes/inputs/OTPInput.spec.js +251 -251
- package/dist/recipes/inputs/OTPInput.stories.svelte +162 -162
- package/dist/recipes/inputs/OTPInput.svelte +128 -128
- package/dist/recipes/inputs/PasswordInput.svelte +130 -130
- package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.svelte +142 -142
- package/dist/recipes/inputs/PhoneInput.svelte +254 -254
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.stories.svelte +170 -170
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte +349 -349
- package/dist/recipes/inputs/Search.svelte +110 -110
- package/dist/recipes/inputs/index.js +8 -8
- package/dist/recipes/inputs/phoneInput/CountrySelector.svelte +240 -240
- package/dist/recipes/modals/AlertModal.svelte +139 -139
- package/dist/recipes/modals/ConfirmationModal.spec.js +396 -396
- package/dist/recipes/modals/ConfirmationModal.stories.svelte +119 -119
- package/dist/recipes/modals/ConfirmationModal.svelte +169 -169
- package/dist/recipes/modals/FeedbackModal.svelte +205 -205
- package/dist/recipes/modals/InputModal.svelte +194 -194
- package/dist/recipes/modals/ModalStateManager.spec.js +100 -100
- package/dist/recipes/modals/ModalStateManager.svelte +77 -77
- package/dist/recipes/modals/ModalTestWrapper.svelte +65 -65
- package/dist/recipes/modals/StatusModal.svelte +216 -216
- package/dist/recipes/modals/index.js +8 -8
- package/dist/schemas/common.js +1 -1
- package/dist/schemas/event.js +1 -1
- package/dist/schemas/order.js +1 -0
- package/dist/schemas/performer.js +1 -1
- package/dist/schemas/promo.js +2 -2
- package/dist/schemas/ticket.js +1 -1
- package/dist/schemas/user.js +2 -1
- package/dist/services/show.service.d.ts +46 -46
- package/dist/stores/auth.d.ts +8 -8
- package/dist/stores/auth.svelte.spec.js +1 -1
- package/dist/stores/index.js +9 -9
- package/dist/stores/toaster.d.ts +3 -3
- package/dist/stores/toaster.js +13 -13
- package/dist/stores/toaster.spec.js +59 -59
- package/dist/stories/ButtonAuditReview.stories.svelte +14 -14
- package/dist/stories/ButtonAuditReview.svelte +427 -427
- package/dist/stories/PatternsGallery.stories.svelte +19 -19
- package/dist/stories/PatternsGallery.svelte +399 -399
- package/dist/stories/PrimitivesGallery.stories.svelte +19 -19
- package/dist/stories/PrimitivesGallery.svelte +756 -756
- package/dist/stories/RecipesGallery.stories.svelte +19 -19
- package/dist/stories/RecipesGallery.svelte +454 -454
- package/dist/stories/button-audit-manifest.json +11186 -11186
- package/dist/tailwind/preset.cjs +87 -87
- package/dist/telemetry.d.ts +5 -5
- package/dist/telemetry.d.ts.map +1 -1
- package/dist/telemetry.js +401 -402
- package/dist/telemetry.server.js +212 -212
- package/dist/telemetry.server.spec.js +437 -437
- package/dist/telemetry.spec.js +1273 -1173
- package/dist/tokens/tokens.css +87 -87
- package/dist/tokens/typography-base.css +163 -163
- package/dist/tokens/utilities.css +430 -430
- package/dist/utils/__tests__/auth.test.js +431 -431
- package/dist/utils/apiConfig.d.ts +29 -29
- package/dist/utils/apiConfig.js +142 -117
- package/dist/utils/auth.d.ts +46 -46
- package/dist/utils/auth.js +195 -195
- package/dist/utils/greetings.js +187 -187
- package/dist/utils/greetings.spec.js +337 -337
- package/dist/utils/haptic.spec.js +1 -1
- package/dist/utils/imageValidation.js +121 -121
- package/dist/utils/imageValidation.spec.js +223 -223
- package/dist/utils/logger.d.ts.map +1 -1
- package/dist/utils/logger.js +2 -1
- package/dist/utils/portal.d.ts +11 -11
- package/dist/utils/portal.js +25 -25
- package/dist/utils/portal.spec.js +143 -143
- package/dist/utils/transitions.js +16 -16
- package/dist/utils/utils/utils.d.ts +2 -2
- package/dist/utils/utils/utils.js +3 -3
- package/dist/utils/utils/utils.spec.js +698 -698
- package/dist/utils/utils.d.ts +41 -41
- package/dist/utils/utils.js +59 -59
- package/dist/utils/utils.spec.js +643 -643
- package/package.json +306 -310
- package/dist/utils/apiConfig.spec.d.ts +0 -2
- package/dist/utils/apiConfig.spec.d.ts.map +0 -1
- package/dist/utils/apiConfig.spec.js +0 -226
|
@@ -1,113 +1,113 @@
|
|
|
1
|
-
<script module>
|
|
2
|
-
import { defineMeta } from "@storybook/addon-svelte-csf";
|
|
3
|
-
|
|
4
|
-
import ErrorDisplay from './ErrorDisplay.svelte';
|
|
5
|
-
|
|
6
|
-
const { Story } = defineMeta({
|
|
7
|
-
title: 'Components/ErrorDisplay',
|
|
8
|
-
component: ErrorDisplay,
|
|
9
|
-
tags: ['autodocs'],
|
|
10
|
-
argTypes: {
|
|
11
|
-
error: {
|
|
12
|
-
control: 'text',
|
|
13
|
-
description: 'Error message to display',
|
|
14
|
-
},
|
|
15
|
-
show: {
|
|
16
|
-
control: 'boolean',
|
|
17
|
-
description: 'Controls visibility',
|
|
18
|
-
},
|
|
19
|
-
shake: {
|
|
20
|
-
control: 'boolean',
|
|
21
|
-
description: 'Enable shake animation',
|
|
22
|
-
},
|
|
23
|
-
icon: {
|
|
24
|
-
control: 'text',
|
|
25
|
-
description: 'Icon name from Icon component',
|
|
26
|
-
},
|
|
27
|
-
iconSize: {
|
|
28
|
-
control: 'text',
|
|
29
|
-
description: 'Size of the icon',
|
|
30
|
-
},
|
|
31
|
-
},
|
|
32
|
-
});
|
|
33
|
-
</script>
|
|
34
|
-
|
|
35
|
-
<script>
|
|
36
|
-
let showShakeDemo = $state(false);
|
|
37
|
-
function triggerShake() {
|
|
38
|
-
showShakeDemo = false;
|
|
39
|
-
setTimeout(() => {
|
|
40
|
-
showShakeDemo = true;
|
|
41
|
-
}, 10);
|
|
42
|
-
}
|
|
43
|
-
</script>
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
<Story
|
|
47
|
-
name="Default"
|
|
48
|
-
args={{
|
|
49
|
-
error: 'This is an error message',
|
|
50
|
-
show: true,
|
|
51
|
-
shake: false,
|
|
52
|
-
}}
|
|
53
|
-
/>
|
|
54
|
-
|
|
55
|
-
<Story
|
|
56
|
-
name="With Shake Animation"
|
|
57
|
-
args={{
|
|
58
|
-
error: 'Invalid input detected',
|
|
59
|
-
show: true,
|
|
60
|
-
shake: true,
|
|
61
|
-
}}
|
|
62
|
-
/>
|
|
63
|
-
|
|
64
|
-
<Story name="Interactive Shake">
|
|
65
|
-
<div class="space-y-4">
|
|
66
|
-
<button
|
|
67
|
-
class="px-4 py-2 bg-blue-500 text-white rounded hover:bg-primary"
|
|
68
|
-
onclick={triggerShake}
|
|
69
|
-
>
|
|
70
|
-
Trigger Error Shake
|
|
71
|
-
</button>
|
|
72
|
-
<ErrorDisplay
|
|
73
|
-
error="Form validation failed"
|
|
74
|
-
show={showShakeDemo}
|
|
75
|
-
shake={showShakeDemo}
|
|
76
|
-
/>
|
|
77
|
-
</div>
|
|
78
|
-
</Story>
|
|
79
|
-
|
|
80
|
-
<Story
|
|
81
|
-
name="Different Icons"
|
|
82
|
-
>
|
|
83
|
-
<div class="space-y-4">
|
|
84
|
-
<ErrorDisplay error="Error with default icon" />
|
|
85
|
-
<ErrorDisplay error="Warning message" icon="Warning" />
|
|
86
|
-
<ErrorDisplay error="Info message" icon="Info" />
|
|
87
|
-
</div>
|
|
88
|
-
</Story>
|
|
89
|
-
|
|
90
|
-
<Story
|
|
91
|
-
name="In Form Context"
|
|
92
|
-
>
|
|
93
|
-
<div class="max-w-md">
|
|
94
|
-
<label for="error-display-email" class="block text-sm font-medium mb-1">Email</label>
|
|
95
|
-
<input
|
|
96
|
-
id="error-display-email"
|
|
97
|
-
type="email"
|
|
98
|
-
class="w-full px-3 py-2 border border-red-500 rounded"
|
|
99
|
-
value="invalid-email"
|
|
100
|
-
/>
|
|
101
|
-
<div class="mt-1">
|
|
102
|
-
<ErrorDisplay error="Please enter a valid email address" shake={true} />
|
|
103
|
-
</div>
|
|
104
|
-
</div>
|
|
105
|
-
</Story>
|
|
106
|
-
|
|
107
|
-
<Story
|
|
108
|
-
name="Hidden State"
|
|
109
|
-
args={{
|
|
110
|
-
error: 'This error is hidden',
|
|
111
|
-
show: false,
|
|
112
|
-
}}
|
|
113
|
-
/>
|
|
1
|
+
<script module>
|
|
2
|
+
import { defineMeta } from "@storybook/addon-svelte-csf";
|
|
3
|
+
|
|
4
|
+
import ErrorDisplay from './ErrorDisplay.svelte';
|
|
5
|
+
|
|
6
|
+
const { Story } = defineMeta({
|
|
7
|
+
title: 'Components/ErrorDisplay',
|
|
8
|
+
component: ErrorDisplay,
|
|
9
|
+
tags: ['autodocs'],
|
|
10
|
+
argTypes: {
|
|
11
|
+
error: {
|
|
12
|
+
control: 'text',
|
|
13
|
+
description: 'Error message to display',
|
|
14
|
+
},
|
|
15
|
+
show: {
|
|
16
|
+
control: 'boolean',
|
|
17
|
+
description: 'Controls visibility',
|
|
18
|
+
},
|
|
19
|
+
shake: {
|
|
20
|
+
control: 'boolean',
|
|
21
|
+
description: 'Enable shake animation',
|
|
22
|
+
},
|
|
23
|
+
icon: {
|
|
24
|
+
control: 'text',
|
|
25
|
+
description: 'Icon name from Icon component',
|
|
26
|
+
},
|
|
27
|
+
iconSize: {
|
|
28
|
+
control: 'text',
|
|
29
|
+
description: 'Size of the icon',
|
|
30
|
+
},
|
|
31
|
+
},
|
|
32
|
+
});
|
|
33
|
+
</script>
|
|
34
|
+
|
|
35
|
+
<script>
|
|
36
|
+
let showShakeDemo = $state(false);
|
|
37
|
+
function triggerShake() {
|
|
38
|
+
showShakeDemo = false;
|
|
39
|
+
setTimeout(() => {
|
|
40
|
+
showShakeDemo = true;
|
|
41
|
+
}, 10);
|
|
42
|
+
}
|
|
43
|
+
</script>
|
|
44
|
+
|
|
45
|
+
|
|
46
|
+
<Story
|
|
47
|
+
name="Default"
|
|
48
|
+
args={{
|
|
49
|
+
error: 'This is an error message',
|
|
50
|
+
show: true,
|
|
51
|
+
shake: false,
|
|
52
|
+
}}
|
|
53
|
+
/>
|
|
54
|
+
|
|
55
|
+
<Story
|
|
56
|
+
name="With Shake Animation"
|
|
57
|
+
args={{
|
|
58
|
+
error: 'Invalid input detected',
|
|
59
|
+
show: true,
|
|
60
|
+
shake: true,
|
|
61
|
+
}}
|
|
62
|
+
/>
|
|
63
|
+
|
|
64
|
+
<Story name="Interactive Shake">
|
|
65
|
+
<div class="space-y-4">
|
|
66
|
+
<button
|
|
67
|
+
class="px-4 py-2 bg-blue-500 text-white rounded hover:bg-primary"
|
|
68
|
+
onclick={triggerShake}
|
|
69
|
+
>
|
|
70
|
+
Trigger Error Shake
|
|
71
|
+
</button>
|
|
72
|
+
<ErrorDisplay
|
|
73
|
+
error="Form validation failed"
|
|
74
|
+
show={showShakeDemo}
|
|
75
|
+
shake={showShakeDemo}
|
|
76
|
+
/>
|
|
77
|
+
</div>
|
|
78
|
+
</Story>
|
|
79
|
+
|
|
80
|
+
<Story
|
|
81
|
+
name="Different Icons"
|
|
82
|
+
>
|
|
83
|
+
<div class="space-y-4">
|
|
84
|
+
<ErrorDisplay error="Error with default icon" />
|
|
85
|
+
<ErrorDisplay error="Warning message" icon="Warning" />
|
|
86
|
+
<ErrorDisplay error="Info message" icon="Info" />
|
|
87
|
+
</div>
|
|
88
|
+
</Story>
|
|
89
|
+
|
|
90
|
+
<Story
|
|
91
|
+
name="In Form Context"
|
|
92
|
+
>
|
|
93
|
+
<div class="max-w-md">
|
|
94
|
+
<label for="error-display-email" class="block text-sm font-medium mb-1">Email</label>
|
|
95
|
+
<input
|
|
96
|
+
id="error-display-email"
|
|
97
|
+
type="email"
|
|
98
|
+
class="w-full px-3 py-2 border border-red-500 rounded"
|
|
99
|
+
value="invalid-email"
|
|
100
|
+
/>
|
|
101
|
+
<div class="mt-1">
|
|
102
|
+
<ErrorDisplay error="Please enter a valid email address" shake={true} />
|
|
103
|
+
</div>
|
|
104
|
+
</div>
|
|
105
|
+
</Story>
|
|
106
|
+
|
|
107
|
+
<Story
|
|
108
|
+
name="Hidden State"
|
|
109
|
+
args={{
|
|
110
|
+
error: 'This error is hidden',
|
|
111
|
+
show: false,
|
|
112
|
+
}}
|
|
113
|
+
/>
|
|
@@ -1,67 +1,67 @@
|
|
|
1
|
-
<script lang="ts">
|
|
2
|
-
import type { Snippet } from 'svelte';
|
|
3
|
-
import Icon from "../../primitives/Icons/Icon.svelte";
|
|
4
|
-
import { typography } from '../../tokens/typography';
|
|
5
|
-
|
|
6
|
-
type IconName = "Home" | "Shows" | "Availability" | "Profile" | "Payment" | "Notification" | "More" | "MoreHori" | "Info" | "ChevronLeft" | "ChevronRight" | "Signout" | "CheckCircle" | "CheckCircleOutline" | "ErrorCircle" | "ArrowLeft" | "ArrowRight" | "Back" | "DownArrow" | "Message" | "Reload" | "Copy" | "Cross";
|
|
7
|
-
|
|
8
|
-
interface Props {
|
|
9
|
-
/** Title of the error */
|
|
10
|
-
title?: string;
|
|
11
|
-
/** Error message to display */
|
|
12
|
-
error?: string;
|
|
13
|
-
/** Message (alias for error) */
|
|
14
|
-
message?: string;
|
|
15
|
-
/** Whether to show the error */
|
|
16
|
-
show?: boolean;
|
|
17
|
-
/** Whether to apply shake animation */
|
|
18
|
-
shake?: boolean;
|
|
19
|
-
/** Icon to display (from Icon component) */
|
|
20
|
-
icon?: IconName;
|
|
21
|
-
/** Size of the icon */
|
|
22
|
-
iconSize?: string;
|
|
23
|
-
/** Additional class for the container */
|
|
24
|
-
className?: string;
|
|
25
|
-
/** Optional action content (buttons, links, etc.) */
|
|
26
|
-
children?: Snippet;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
let {
|
|
30
|
-
title = '',
|
|
31
|
-
error = '',
|
|
32
|
-
message = '',
|
|
33
|
-
show = true,
|
|
34
|
-
shake = false,
|
|
35
|
-
icon = 'ErrorCircle',
|
|
36
|
-
iconSize = '16',
|
|
37
|
-
className = '',
|
|
38
|
-
children
|
|
39
|
-
}: Props = $props();
|
|
40
|
-
|
|
41
|
-
// Support both naming conventions
|
|
42
|
-
let displayMessage = $derived(error || message);
|
|
43
|
-
</script>
|
|
44
|
-
|
|
45
|
-
{#if (displayMessage || title) && show}
|
|
46
|
-
<div
|
|
47
|
-
class="flex flex-col items-center justify-center px-6 py-10 text-center {shake ? 'animate-shake' : ''} {className}"
|
|
48
|
-
>
|
|
49
|
-
<div class="w-14 h-14 rounded-full bg-red-100 dark:bg-red-900/30 flex items-center justify-center mb-4">
|
|
50
|
-
<Icon name={icon} size="28" class="text-red-600 dark:text-red-400" />
|
|
51
|
-
</div>
|
|
52
|
-
|
|
53
|
-
{#if title}
|
|
54
|
-
<h3 class={typography.h3}>{title}</h3>
|
|
55
|
-
{/if}
|
|
56
|
-
|
|
57
|
-
{#if displayMessage}
|
|
58
|
-
<p class={`${typography.smMuted} mt-1`}>{displayMessage}</p>
|
|
59
|
-
{/if}
|
|
60
|
-
|
|
61
|
-
{#if children}
|
|
62
|
-
<div class="mt-4">
|
|
63
|
-
{@render children()}
|
|
64
|
-
</div>
|
|
65
|
-
{/if}
|
|
66
|
-
</div>
|
|
67
|
-
{/if}
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import type { Snippet } from 'svelte';
|
|
3
|
+
import Icon from "../../primitives/Icons/Icon.svelte";
|
|
4
|
+
import { typography } from '../../tokens/typography';
|
|
5
|
+
|
|
6
|
+
type IconName = "Home" | "Shows" | "Availability" | "Profile" | "Payment" | "Notification" | "More" | "MoreHori" | "Info" | "ChevronLeft" | "ChevronRight" | "Signout" | "CheckCircle" | "CheckCircleOutline" | "ErrorCircle" | "ArrowLeft" | "ArrowRight" | "Back" | "DownArrow" | "Message" | "Reload" | "Copy" | "Cross";
|
|
7
|
+
|
|
8
|
+
interface Props {
|
|
9
|
+
/** Title of the error */
|
|
10
|
+
title?: string;
|
|
11
|
+
/** Error message to display */
|
|
12
|
+
error?: string;
|
|
13
|
+
/** Message (alias for error) */
|
|
14
|
+
message?: string;
|
|
15
|
+
/** Whether to show the error */
|
|
16
|
+
show?: boolean;
|
|
17
|
+
/** Whether to apply shake animation */
|
|
18
|
+
shake?: boolean;
|
|
19
|
+
/** Icon to display (from Icon component) */
|
|
20
|
+
icon?: IconName;
|
|
21
|
+
/** Size of the icon */
|
|
22
|
+
iconSize?: string;
|
|
23
|
+
/** Additional class for the container */
|
|
24
|
+
className?: string;
|
|
25
|
+
/** Optional action content (buttons, links, etc.) */
|
|
26
|
+
children?: Snippet;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
let {
|
|
30
|
+
title = '',
|
|
31
|
+
error = '',
|
|
32
|
+
message = '',
|
|
33
|
+
show = true,
|
|
34
|
+
shake = false,
|
|
35
|
+
icon = 'ErrorCircle',
|
|
36
|
+
iconSize = '16',
|
|
37
|
+
className = '',
|
|
38
|
+
children
|
|
39
|
+
}: Props = $props();
|
|
40
|
+
|
|
41
|
+
// Support both naming conventions
|
|
42
|
+
let displayMessage = $derived(error || message);
|
|
43
|
+
</script>
|
|
44
|
+
|
|
45
|
+
{#if (displayMessage || title) && show}
|
|
46
|
+
<div
|
|
47
|
+
class="flex flex-col items-center justify-center px-6 py-10 text-center {shake ? 'animate-shake' : ''} {className}"
|
|
48
|
+
>
|
|
49
|
+
<div class="w-14 h-14 rounded-full bg-red-100 dark:bg-red-900/30 flex items-center justify-center mb-4">
|
|
50
|
+
<Icon name={icon} size="28" class="text-red-600 dark:text-red-400" />
|
|
51
|
+
</div>
|
|
52
|
+
|
|
53
|
+
{#if title}
|
|
54
|
+
<h3 class={typography.h3}>{title}</h3>
|
|
55
|
+
{/if}
|
|
56
|
+
|
|
57
|
+
{#if displayMessage}
|
|
58
|
+
<p class={`${typography.smMuted} mt-1`}>{displayMessage}</p>
|
|
59
|
+
{/if}
|
|
60
|
+
|
|
61
|
+
{#if children}
|
|
62
|
+
<div class="mt-4">
|
|
63
|
+
{@render children()}
|
|
64
|
+
</div>
|
|
65
|
+
{/if}
|
|
66
|
+
</div>
|
|
67
|
+
{/if}
|
|
@@ -1,133 +1,133 @@
|
|
|
1
|
-
import { describe, it, expect } from 'vitest';
|
|
2
|
-
import { render, screen } from '@testing-library/svelte';
|
|
3
|
-
import StatusIndicator from './StatusIndicator.svelte';
|
|
4
|
-
|
|
5
|
-
describe('StatusIndicator', () => {
|
|
6
|
-
describe('idle state', () => {
|
|
7
|
-
it('renders empty container when status is idle', () => {
|
|
8
|
-
const { container } = render(StatusIndicator, { status: 'idle' });
|
|
9
|
-
// Check that no status indicators are rendered
|
|
10
|
-
expect(container.querySelector('.spinner')).toBeFalsy();
|
|
11
|
-
expect(container.querySelector('.success-circle')).toBeFalsy();
|
|
12
|
-
expect(container.querySelector('.error-circle')).toBeFalsy();
|
|
13
|
-
});
|
|
14
|
-
|
|
15
|
-
it('uses default status of idle', () => {
|
|
16
|
-
const { container } = render(StatusIndicator);
|
|
17
|
-
// Default status is idle - no status indicators should be rendered
|
|
18
|
-
expect(container.querySelector('.spinner')).toBeFalsy();
|
|
19
|
-
expect(container.querySelector('.success-circle')).toBeFalsy();
|
|
20
|
-
expect(container.querySelector('.error-circle')).toBeFalsy();
|
|
21
|
-
});
|
|
22
|
-
});
|
|
23
|
-
|
|
24
|
-
describe('loading state', () => {
|
|
25
|
-
it('renders spinner when status is loading', () => {
|
|
26
|
-
const { container } = render(StatusIndicator, { status: 'loading' });
|
|
27
|
-
const spinner = container.querySelector('.spinner');
|
|
28
|
-
expect(spinner).toBeTruthy();
|
|
29
|
-
});
|
|
30
|
-
|
|
31
|
-
it('renders spinner SVG with circles', () => {
|
|
32
|
-
const { container } = render(StatusIndicator, { status: 'loading' });
|
|
33
|
-
const spinner = container.querySelector('.spinner');
|
|
34
|
-
expect(spinner.querySelector('svg')).toBeTruthy();
|
|
35
|
-
const circles = spinner.querySelectorAll('circle');
|
|
36
|
-
expect(circles.length).toBe(2); // Background circle and animated spinner head
|
|
37
|
-
expect(spinner.querySelector('.spinner-head')).toBeTruthy();
|
|
38
|
-
});
|
|
39
|
-
|
|
40
|
-
it('applies size to spinner', () => {
|
|
41
|
-
const { container } = render(StatusIndicator, { status: 'loading', size: 64 });
|
|
42
|
-
const spinner = container.querySelector('.spinner');
|
|
43
|
-
expect(spinner.style.width).toBe('64px');
|
|
44
|
-
expect(spinner.style.height).toBe('64px');
|
|
45
|
-
});
|
|
46
|
-
});
|
|
47
|
-
|
|
48
|
-
describe('success state', () => {
|
|
49
|
-
it('renders success circle when status is success', () => {
|
|
50
|
-
const { container } = render(StatusIndicator, { status: 'success' });
|
|
51
|
-
const success = container.querySelector('.success-circle');
|
|
52
|
-
expect(success).toBeTruthy();
|
|
53
|
-
});
|
|
54
|
-
|
|
55
|
-
it('renders success SVG with circle and checkmark', () => {
|
|
56
|
-
const { container } = render(StatusIndicator, { status: 'success' });
|
|
57
|
-
const success = container.querySelector('.success-circle');
|
|
58
|
-
expect(success.querySelector('svg')).toBeTruthy();
|
|
59
|
-
expect(success.querySelector('circle')).toBeTruthy();
|
|
60
|
-
expect(success.querySelector('.checkmark')).toBeTruthy();
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
it('applies size to success circle', () => {
|
|
64
|
-
const { container } = render(StatusIndicator, { status: 'success', size: 32 });
|
|
65
|
-
const success = container.querySelector('.success-circle');
|
|
66
|
-
expect(success.style.width).toBe('32px');
|
|
67
|
-
expect(success.style.height).toBe('32px');
|
|
68
|
-
});
|
|
69
|
-
});
|
|
70
|
-
|
|
71
|
-
describe('error state', () => {
|
|
72
|
-
it('renders error circle when status is error', () => {
|
|
73
|
-
const { container } = render(StatusIndicator, { status: 'error' });
|
|
74
|
-
const error = container.querySelector('.error-circle');
|
|
75
|
-
expect(error).toBeTruthy();
|
|
76
|
-
});
|
|
77
|
-
|
|
78
|
-
it('renders error SVG with circle and X lines', () => {
|
|
79
|
-
const { container } = render(StatusIndicator, { status: 'error' });
|
|
80
|
-
const error = container.querySelector('.error-circle');
|
|
81
|
-
expect(error.querySelector('svg')).toBeTruthy();
|
|
82
|
-
expect(error.querySelector('circle')).toBeTruthy();
|
|
83
|
-
const xLines = error.querySelectorAll('.error-x');
|
|
84
|
-
expect(xLines.length).toBe(2);
|
|
85
|
-
});
|
|
86
|
-
|
|
87
|
-
it('applies size to error circle', () => {
|
|
88
|
-
const { container } = render(StatusIndicator, { status: 'error', size: 24 });
|
|
89
|
-
const error = container.querySelector('.error-circle');
|
|
90
|
-
expect(error.style.width).toBe('24px');
|
|
91
|
-
expect(error.style.height).toBe('24px');
|
|
92
|
-
});
|
|
93
|
-
});
|
|
94
|
-
|
|
95
|
-
describe('size prop', () => {
|
|
96
|
-
it('uses default size of 48px', () => {
|
|
97
|
-
const { container } = render(StatusIndicator, { status: 'loading' });
|
|
98
|
-
const spinner = container.querySelector('.spinner');
|
|
99
|
-
expect(spinner.style.width).toBe('48px');
|
|
100
|
-
expect(spinner.style.height).toBe('48px');
|
|
101
|
-
});
|
|
102
|
-
|
|
103
|
-
it('accepts custom size', () => {
|
|
104
|
-
const { container } = render(StatusIndicator, { status: 'loading', size: 100 });
|
|
105
|
-
const spinner = container.querySelector('.spinner');
|
|
106
|
-
expect(spinner.style.width).toBe('100px');
|
|
107
|
-
expect(spinner.style.height).toBe('100px');
|
|
108
|
-
});
|
|
109
|
-
});
|
|
110
|
-
|
|
111
|
-
describe('state transitions', () => {
|
|
112
|
-
it('only renders one state at a time - loading', () => {
|
|
113
|
-
const { container } = render(StatusIndicator, { status: 'loading' });
|
|
114
|
-
expect(container.querySelector('.spinner')).toBeTruthy();
|
|
115
|
-
expect(container.querySelector('.success-circle')).toBeFalsy();
|
|
116
|
-
expect(container.querySelector('.error-circle')).toBeFalsy();
|
|
117
|
-
});
|
|
118
|
-
|
|
119
|
-
it('only renders one state at a time - success', () => {
|
|
120
|
-
const { container } = render(StatusIndicator, { status: 'success' });
|
|
121
|
-
expect(container.querySelector('.spinner')).toBeFalsy();
|
|
122
|
-
expect(container.querySelector('.success-circle')).toBeTruthy();
|
|
123
|
-
expect(container.querySelector('.error-circle')).toBeFalsy();
|
|
124
|
-
});
|
|
125
|
-
|
|
126
|
-
it('only renders one state at a time - error', () => {
|
|
127
|
-
const { container } = render(StatusIndicator, { status: 'error' });
|
|
128
|
-
expect(container.querySelector('.spinner')).toBeFalsy();
|
|
129
|
-
expect(container.querySelector('.success-circle')).toBeFalsy();
|
|
130
|
-
expect(container.querySelector('.error-circle')).toBeTruthy();
|
|
131
|
-
});
|
|
132
|
-
});
|
|
133
|
-
});
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { render, screen } from '@testing-library/svelte';
|
|
3
|
+
import StatusIndicator from './StatusIndicator.svelte';
|
|
4
|
+
|
|
5
|
+
describe('StatusIndicator', () => {
|
|
6
|
+
describe('idle state', () => {
|
|
7
|
+
it('renders empty container when status is idle', () => {
|
|
8
|
+
const { container } = render(StatusIndicator, { status: 'idle' });
|
|
9
|
+
// Check that no status indicators are rendered
|
|
10
|
+
expect(container.querySelector('.spinner')).toBeFalsy();
|
|
11
|
+
expect(container.querySelector('.success-circle')).toBeFalsy();
|
|
12
|
+
expect(container.querySelector('.error-circle')).toBeFalsy();
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
it('uses default status of idle', () => {
|
|
16
|
+
const { container } = render(StatusIndicator);
|
|
17
|
+
// Default status is idle - no status indicators should be rendered
|
|
18
|
+
expect(container.querySelector('.spinner')).toBeFalsy();
|
|
19
|
+
expect(container.querySelector('.success-circle')).toBeFalsy();
|
|
20
|
+
expect(container.querySelector('.error-circle')).toBeFalsy();
|
|
21
|
+
});
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
describe('loading state', () => {
|
|
25
|
+
it('renders spinner when status is loading', () => {
|
|
26
|
+
const { container } = render(StatusIndicator, { status: 'loading' });
|
|
27
|
+
const spinner = container.querySelector('.spinner');
|
|
28
|
+
expect(spinner).toBeTruthy();
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
it('renders spinner SVG with circles', () => {
|
|
32
|
+
const { container } = render(StatusIndicator, { status: 'loading' });
|
|
33
|
+
const spinner = container.querySelector('.spinner');
|
|
34
|
+
expect(spinner.querySelector('svg')).toBeTruthy();
|
|
35
|
+
const circles = spinner.querySelectorAll('circle');
|
|
36
|
+
expect(circles.length).toBe(2); // Background circle and animated spinner head
|
|
37
|
+
expect(spinner.querySelector('.spinner-head')).toBeTruthy();
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
it('applies size to spinner', () => {
|
|
41
|
+
const { container } = render(StatusIndicator, { status: 'loading', size: 64 });
|
|
42
|
+
const spinner = container.querySelector('.spinner');
|
|
43
|
+
expect(spinner.style.width).toBe('64px');
|
|
44
|
+
expect(spinner.style.height).toBe('64px');
|
|
45
|
+
});
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
describe('success state', () => {
|
|
49
|
+
it('renders success circle when status is success', () => {
|
|
50
|
+
const { container } = render(StatusIndicator, { status: 'success' });
|
|
51
|
+
const success = container.querySelector('.success-circle');
|
|
52
|
+
expect(success).toBeTruthy();
|
|
53
|
+
});
|
|
54
|
+
|
|
55
|
+
it('renders success SVG with circle and checkmark', () => {
|
|
56
|
+
const { container } = render(StatusIndicator, { status: 'success' });
|
|
57
|
+
const success = container.querySelector('.success-circle');
|
|
58
|
+
expect(success.querySelector('svg')).toBeTruthy();
|
|
59
|
+
expect(success.querySelector('circle')).toBeTruthy();
|
|
60
|
+
expect(success.querySelector('.checkmark')).toBeTruthy();
|
|
61
|
+
});
|
|
62
|
+
|
|
63
|
+
it('applies size to success circle', () => {
|
|
64
|
+
const { container } = render(StatusIndicator, { status: 'success', size: 32 });
|
|
65
|
+
const success = container.querySelector('.success-circle');
|
|
66
|
+
expect(success.style.width).toBe('32px');
|
|
67
|
+
expect(success.style.height).toBe('32px');
|
|
68
|
+
});
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
describe('error state', () => {
|
|
72
|
+
it('renders error circle when status is error', () => {
|
|
73
|
+
const { container } = render(StatusIndicator, { status: 'error' });
|
|
74
|
+
const error = container.querySelector('.error-circle');
|
|
75
|
+
expect(error).toBeTruthy();
|
|
76
|
+
});
|
|
77
|
+
|
|
78
|
+
it('renders error SVG with circle and X lines', () => {
|
|
79
|
+
const { container } = render(StatusIndicator, { status: 'error' });
|
|
80
|
+
const error = container.querySelector('.error-circle');
|
|
81
|
+
expect(error.querySelector('svg')).toBeTruthy();
|
|
82
|
+
expect(error.querySelector('circle')).toBeTruthy();
|
|
83
|
+
const xLines = error.querySelectorAll('.error-x');
|
|
84
|
+
expect(xLines.length).toBe(2);
|
|
85
|
+
});
|
|
86
|
+
|
|
87
|
+
it('applies size to error circle', () => {
|
|
88
|
+
const { container } = render(StatusIndicator, { status: 'error', size: 24 });
|
|
89
|
+
const error = container.querySelector('.error-circle');
|
|
90
|
+
expect(error.style.width).toBe('24px');
|
|
91
|
+
expect(error.style.height).toBe('24px');
|
|
92
|
+
});
|
|
93
|
+
});
|
|
94
|
+
|
|
95
|
+
describe('size prop', () => {
|
|
96
|
+
it('uses default size of 48px', () => {
|
|
97
|
+
const { container } = render(StatusIndicator, { status: 'loading' });
|
|
98
|
+
const spinner = container.querySelector('.spinner');
|
|
99
|
+
expect(spinner.style.width).toBe('48px');
|
|
100
|
+
expect(spinner.style.height).toBe('48px');
|
|
101
|
+
});
|
|
102
|
+
|
|
103
|
+
it('accepts custom size', () => {
|
|
104
|
+
const { container } = render(StatusIndicator, { status: 'loading', size: 100 });
|
|
105
|
+
const spinner = container.querySelector('.spinner');
|
|
106
|
+
expect(spinner.style.width).toBe('100px');
|
|
107
|
+
expect(spinner.style.height).toBe('100px');
|
|
108
|
+
});
|
|
109
|
+
});
|
|
110
|
+
|
|
111
|
+
describe('state transitions', () => {
|
|
112
|
+
it('only renders one state at a time - loading', () => {
|
|
113
|
+
const { container } = render(StatusIndicator, { status: 'loading' });
|
|
114
|
+
expect(container.querySelector('.spinner')).toBeTruthy();
|
|
115
|
+
expect(container.querySelector('.success-circle')).toBeFalsy();
|
|
116
|
+
expect(container.querySelector('.error-circle')).toBeFalsy();
|
|
117
|
+
});
|
|
118
|
+
|
|
119
|
+
it('only renders one state at a time - success', () => {
|
|
120
|
+
const { container } = render(StatusIndicator, { status: 'success' });
|
|
121
|
+
expect(container.querySelector('.spinner')).toBeFalsy();
|
|
122
|
+
expect(container.querySelector('.success-circle')).toBeTruthy();
|
|
123
|
+
expect(container.querySelector('.error-circle')).toBeFalsy();
|
|
124
|
+
});
|
|
125
|
+
|
|
126
|
+
it('only renders one state at a time - error', () => {
|
|
127
|
+
const { container } = render(StatusIndicator, { status: 'error' });
|
|
128
|
+
expect(container.querySelector('.spinner')).toBeFalsy();
|
|
129
|
+
expect(container.querySelector('.success-circle')).toBeFalsy();
|
|
130
|
+
expect(container.querySelector('.error-circle')).toBeTruthy();
|
|
131
|
+
});
|
|
132
|
+
});
|
|
133
|
+
});
|