@getmicdrop/svelte-components 5.5.5 → 5.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/calendar/AboutShow/AboutShow.svelte +172 -172
- package/dist/calendar/Calendar/MiniMonthCalendar.svelte +782 -782
- package/dist/calendar/FAQs/FAQs.svelte +75 -75
- package/dist/calendar/MonthSwitcher/MonthSwitcher.svelte +126 -126
- package/dist/calendar/OrderSummary/OrderSummary.svelte +367 -367
- package/dist/calendar/PublicCard/PublicCard.svelte +134 -134
- package/dist/calendar/ShowCard/ShowCard.svelte +157 -157
- package/dist/calendar/ShowTimeCard/ShowTimeCard.svelte +61 -61
- package/dist/components/Layout/AppShell.svelte +104 -0
- package/dist/components/Layout/AppShell.svelte.d.ts +26 -0
- package/dist/components/Layout/AppShell.svelte.d.ts.map +1 -0
- package/dist/components/Layout/ContentSection.svelte +80 -0
- package/dist/components/Layout/ContentSection.svelte.d.ts +23 -0
- package/dist/components/Layout/ContentSection.svelte.d.ts.map +1 -0
- package/dist/components/Layout/Grid.svelte +4 -4
- package/dist/components/Layout/Heading.svelte +81 -0
- package/dist/components/Layout/Heading.svelte.d.ts +24 -0
- package/dist/components/Layout/Heading.svelte.d.ts.map +1 -0
- package/dist/components/Layout/PageContainer.svelte +69 -0
- package/dist/components/Layout/PageContainer.svelte.d.ts +23 -0
- package/dist/components/Layout/PageContainer.svelte.d.ts.map +1 -0
- package/dist/components/Layout/Responsive.svelte +75 -0
- package/dist/components/Layout/Responsive.svelte.d.ts +19 -0
- package/dist/components/Layout/Responsive.svelte.d.ts.map +1 -0
- package/dist/components/Layout/Section.svelte +80 -80
- package/dist/components/Layout/ShowOnDesktop.svelte +37 -0
- package/dist/components/Layout/ShowOnDesktop.svelte.d.ts +16 -0
- package/dist/components/Layout/ShowOnDesktop.svelte.d.ts.map +1 -0
- package/dist/components/Layout/ShowOnMobile.svelte +37 -0
- package/dist/components/Layout/ShowOnMobile.svelte.d.ts +16 -0
- package/dist/components/Layout/ShowOnMobile.svelte.d.ts.map +1 -0
- package/dist/components/Layout/Sidebar.svelte +108 -108
- package/dist/components/Layout/Stack.spec.js +1 -1
- package/dist/components/Layout/Stack.svelte +6 -6
- package/dist/components/Layout/Text.svelte +87 -0
- package/dist/components/Layout/Text.svelte.d.ts +28 -0
- package/dist/components/Layout/Text.svelte.d.ts.map +1 -0
- package/dist/components/Layout/TwoColumn.svelte +108 -0
- package/dist/components/Layout/TwoColumn.svelte.d.ts +28 -0
- package/dist/components/Layout/TwoColumn.svelte.d.ts.map +1 -0
- package/dist/components/Layout/__tests__/Heading.test.d.ts +2 -0
- package/dist/components/Layout/__tests__/Heading.test.d.ts.map +1 -0
- package/dist/components/Layout/__tests__/Heading.test.js +123 -0
- package/dist/components/Layout/__tests__/ShowOnDesktop.test.d.ts +2 -0
- package/dist/components/Layout/__tests__/ShowOnDesktop.test.d.ts.map +1 -0
- package/dist/components/Layout/__tests__/ShowOnDesktop.test.js +84 -0
- package/dist/components/Layout/__tests__/ShowOnMobile.test.d.ts +2 -0
- package/dist/components/Layout/__tests__/ShowOnMobile.test.d.ts.map +1 -0
- package/dist/components/Layout/__tests__/ShowOnMobile.test.js +80 -0
- package/dist/components/Layout/__tests__/Text.test.d.ts +2 -0
- package/dist/components/Layout/__tests__/Text.test.d.ts.map +1 -0
- package/dist/components/Layout/__tests__/Text.test.js +146 -0
- package/dist/components/Layout/__tests__/TwoColumn.test.d.ts +2 -0
- package/dist/components/Layout/__tests__/TwoColumn.test.d.ts.map +1 -0
- package/dist/components/Layout/__tests__/TwoColumn.test.js +129 -0
- 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 +1 -1
- package/dist/datetime/parse.js +1 -1
- package/dist/forms/createFormStore.svelte.js +1 -0
- package/dist/index.js +40 -40
- package/dist/patterns/data/DataGrid.svelte +45 -45
- package/dist/patterns/data/DataList.svelte +24 -24
- package/dist/patterns/data/DataTable.svelte +36 -36
- 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 +32 -32
- package/dist/patterns/forms/FormValidationSummary.stories.svelte +83 -83
- package/dist/patterns/forms/FormValidationSummary.svelte +74 -74
- package/dist/patterns/layout/Sidebar.svelte +39 -39
- package/dist/patterns/layout/index.d.ts +9 -0
- package/dist/patterns/layout/index.js +22 -0
- package/dist/patterns/navigation/BottomNav.stories.svelte +117 -117
- package/dist/patterns/navigation/BottomNav.svelte +64 -64
- package/dist/patterns/navigation/Header.stories.svelte +77 -77
- package/dist/patterns/navigation/Header.svelte +193 -193
- package/dist/patterns/page/PageHeader.svelte +18 -18
- 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 +24 -24
- package/dist/patterns/page/SectionHeader.svelte +29 -29
- 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 +42 -42
- package/dist/primitives/Accordion/AccordionItem.svelte +95 -95
- package/dist/primitives/Alert/Alert.spec.js +173 -173
- package/dist/primitives/Alert/Alert.stories.svelte +88 -88
- package/dist/primitives/Alert/Alert.svelte +27 -27
- 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 -144
- 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 -136
- package/dist/primitives/BottomSheet/BottomSheet.stories.svelte +83 -83
- package/dist/primitives/BottomSheet/BottomSheet.svelte +100 -100
- package/dist/primitives/Breadcrumb/Breadcrumb.spec.js +122 -122
- 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 -223
- 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 -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/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 +136 -136
- package/dist/primitives/Drawer/Drawer.stories.svelte +80 -80
- package/dist/primitives/Drawer/Drawer.svelte +120 -120
- package/dist/primitives/Dropdown/Dropdown.stories.svelte +137 -137
- package/dist/primitives/Dropdown/Dropdown.svelte +14 -14
- 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/Input/Input.spec.js +573 -573
- package/dist/primitives/Input/Input.stories.svelte +139 -139
- package/dist/primitives/Input/Input.svelte +417 -417
- package/dist/primitives/Input/Select.spec.js +212 -212
- package/dist/primitives/Input/Select.stories.svelte +112 -112
- package/dist/primitives/Input/Select.svelte +128 -128
- package/dist/primitives/Input/Textarea.stories.svelte +137 -137
- package/dist/primitives/Input/Textarea.svelte +35 -35
- package/dist/primitives/Label/Label.svelte +37 -37
- package/dist/primitives/Modal/Modal.spec.js +99 -99
- package/dist/primitives/Modal/Modal.stories.svelte +86 -86
- package/dist/primitives/Modal/Modal.svelte +158 -158
- package/dist/primitives/NumberInput/NumberInput.svelte +106 -106
- package/dist/primitives/Pagination/Pagination.stories.svelte +76 -76
- package/dist/primitives/Pagination/Pagination.svelte +261 -261
- package/dist/primitives/Radio/Radio.stories.svelte +80 -80
- package/dist/primitives/Radio/Radio.svelte +67 -67
- package/dist/primitives/Skeleton/CardPlaceholder.svelte +87 -87
- package/dist/primitives/Skeleton/ImagePlaceholder.svelte +59 -59
- package/dist/primitives/Skeleton/ListPlaceholder.svelte +76 -76
- 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 -71
- package/dist/primitives/Spinner/Spinner.stories.svelte +29 -29
- package/dist/primitives/Spinner/Spinner.svelte +20 -20
- package/dist/primitives/Tabs/TabItem.svelte +49 -49
- package/dist/primitives/Tabs/Tabs.stories.svelte +112 -112
- package/dist/primitives/Tabs/Tabs.svelte +123 -123
- package/dist/primitives/Toggle.spec.js +143 -143
- package/dist/primitives/Toggle.stories.svelte +92 -92
- package/dist/primitives/Toggle.svelte +71 -71
- 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.js +84 -84
- package/dist/recipes/CropImage/CropImage.spec.js +208 -208
- package/dist/recipes/CropImage/CropImage.stories.svelte +104 -104
- package/dist/recipes/CropImage/CropImage.svelte +238 -238
- package/dist/recipes/ImageUploader/ImageUploader.stories.svelte +125 -125
- package/dist/recipes/ImageUploader/ImageUploader.svelte +804 -804
- package/dist/recipes/SuperLogin/SuperLogin.spec.js +17 -17
- package/dist/recipes/Toaster/Toaster.stories.svelte +62 -62
- 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 -133
- package/dist/recipes/feedback/StatusIndicator/StatusIndicator.svelte +157 -157
- 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 +80 -80
- package/dist/recipes/fields/TextareaField.svelte +97 -97
- package/dist/recipes/fields/ToggleField.svelte +60 -60
- package/dist/recipes/fields/index.js +7 -7
- package/dist/recipes/inputs/MultiSelect.spec.js +258 -258
- package/dist/recipes/inputs/MultiSelect.stories.svelte +133 -133
- package/dist/recipes/inputs/MultiSelect.svelte +256 -256
- package/dist/recipes/inputs/OTPInput.spec.js +251 -251
- package/dist/recipes/inputs/OTPInput.stories.svelte +162 -162
- package/dist/recipes/inputs/OTPInput.svelte +29 -29
- package/dist/recipes/inputs/PasswordInput.svelte +22 -22
- package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.svelte +117 -117
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.stories.svelte +123 -123
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte +326 -326
- package/dist/recipes/inputs/Search.svelte +37 -37
- package/dist/recipes/inputs/SelectDropdown.svelte +57 -57
- package/dist/recipes/modals/AlertModal.svelte +130 -130
- package/dist/recipes/modals/ConfirmationModal.spec.js +206 -206
- package/dist/recipes/modals/ConfirmationModal.stories.svelte +119 -119
- package/dist/recipes/modals/ConfirmationModal.svelte +152 -152
- 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.svelte +65 -65
- 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 -345
- 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/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 +206 -206
- package/dist/stories/PrimitivesGallery.stories.svelte +19 -19
- package/dist/stories/PrimitivesGallery.svelte +725 -725
- 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/tailwind/preset.cjs +82 -82
- package/dist/telemetry.js +405 -405
- package/dist/telemetry.spec.js +1144 -1144
- package/dist/tokens/__tests__/typography-base.test.d.ts +2 -0
- package/dist/tokens/__tests__/typography-base.test.d.ts.map +1 -0
- package/dist/tokens/__tests__/typography-base.test.js +138 -0
- package/dist/tokens/tokens.css +87 -87
- package/dist/tokens/typography-base.css +163 -0
- package/dist/utils/apiConfig.spec.js +219 -219
- package/dist/utils/transitions.js +62 -62
- package/dist/utils/utils.js +354 -354
- package/package.json +292 -291
|
@@ -1,49 +1,49 @@
|
|
|
1
|
-
<script module>
|
|
2
|
-
import { defineMeta } from "@storybook/addon-svelte-csf";
|
|
3
|
-
|
|
4
|
-
import ValidationError from './ValidationError.svelte';
|
|
5
|
-
|
|
6
|
-
const { Story } = defineMeta({
|
|
7
|
-
title: 'Components/ValidationError',
|
|
8
|
-
component: ValidationError,
|
|
9
|
-
tags: ['autodocs'],
|
|
10
|
-
argTypes: {
|
|
11
|
-
error: { control: 'text' },
|
|
12
|
-
show: { control: 'boolean' },
|
|
13
|
-
id: { control: 'text' },
|
|
14
|
-
},
|
|
15
|
-
});
|
|
16
|
-
|
|
17
|
-
</script>
|
|
18
|
-
|
|
19
|
-
<script>
|
|
20
|
-
</script>
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
<Story
|
|
24
|
-
name="Default"
|
|
25
|
-
args={{
|
|
26
|
-
error: 'This field is required',
|
|
27
|
-
show: true,
|
|
28
|
-
}}
|
|
29
|
-
/>
|
|
30
|
-
|
|
31
|
-
<Story
|
|
32
|
-
name="Email Validation"
|
|
33
|
-
args={{
|
|
34
|
-
error: 'Please enter a valid email address',
|
|
35
|
-
show: true,
|
|
36
|
-
}}
|
|
37
|
-
/>
|
|
38
|
-
|
|
39
|
-
<Story
|
|
40
|
-
name="Password Validation"
|
|
41
|
-
args={{
|
|
42
|
-
error: 'Password must be at least 8 characters',
|
|
43
|
-
show: true,
|
|
44
|
-
}}
|
|
45
|
-
/>
|
|
46
|
-
|
|
1
|
+
<script module>
|
|
2
|
+
import { defineMeta } from "@storybook/addon-svelte-csf";
|
|
3
|
+
|
|
4
|
+
import ValidationError from './ValidationError.svelte';
|
|
5
|
+
|
|
6
|
+
const { Story } = defineMeta({
|
|
7
|
+
title: 'Components/ValidationError',
|
|
8
|
+
component: ValidationError,
|
|
9
|
+
tags: ['autodocs'],
|
|
10
|
+
argTypes: {
|
|
11
|
+
error: { control: 'text' },
|
|
12
|
+
show: { control: 'boolean' },
|
|
13
|
+
id: { control: 'text' },
|
|
14
|
+
},
|
|
15
|
+
});
|
|
16
|
+
|
|
17
|
+
</script>
|
|
18
|
+
|
|
19
|
+
<script>
|
|
20
|
+
</script>
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
<Story
|
|
24
|
+
name="Default"
|
|
25
|
+
args={{
|
|
26
|
+
error: 'This field is required',
|
|
27
|
+
show: true,
|
|
28
|
+
}}
|
|
29
|
+
/>
|
|
30
|
+
|
|
31
|
+
<Story
|
|
32
|
+
name="Email Validation"
|
|
33
|
+
args={{
|
|
34
|
+
error: 'Please enter a valid email address',
|
|
35
|
+
show: true,
|
|
36
|
+
}}
|
|
37
|
+
/>
|
|
38
|
+
|
|
39
|
+
<Story
|
|
40
|
+
name="Password Validation"
|
|
41
|
+
args={{
|
|
42
|
+
error: 'Password must be at least 8 characters',
|
|
43
|
+
show: true,
|
|
44
|
+
}}
|
|
45
|
+
/>
|
|
46
|
+
|
|
47
47
|
<Story name="With Input Field">
|
|
48
48
|
<div class="max-w-md">
|
|
49
49
|
<label for="email-field" class="block text-sm font-medium mb-1">Email Address</label>
|
|
@@ -87,26 +87,26 @@
|
|
|
87
87
|
<p class="text-sm text-gray-500 dark:text-gray-400 mt-2">Validation error is hidden until field is touched</p>
|
|
88
88
|
</div>
|
|
89
89
|
</Story>
|
|
90
|
-
|
|
91
|
-
<Story name="Accessible with aria-describedby">
|
|
92
|
-
<div class="max-w-md">
|
|
93
|
-
<label for="accessible-email" class="block text-sm font-medium mb-1">Email Address</label>
|
|
94
|
-
<input
|
|
95
|
-
id="accessible-email"
|
|
96
|
-
type="email"
|
|
97
|
-
aria-describedby="email-error"
|
|
98
|
-
aria-invalid="true"
|
|
99
|
-
class="w-full px-3 py-2 border border-red-300 rounded focus:ring-red-500 focus:border-red-500"
|
|
100
|
-
value="invalid-email"
|
|
101
|
-
/>
|
|
102
|
-
<ValidationError
|
|
103
|
-
id="email-error"
|
|
104
|
-
error="Please enter a valid email address"
|
|
105
|
-
show={true}
|
|
106
|
-
/>
|
|
107
|
-
<p class="text-sm text-gray-500 mt-4">
|
|
108
|
-
This example shows proper accessibility: the input references the error via aria-describedby,
|
|
109
|
-
and the error has aria-live="assertive" for screen reader announcements.
|
|
110
|
-
</p>
|
|
111
|
-
</div>
|
|
112
|
-
</Story>
|
|
90
|
+
|
|
91
|
+
<Story name="Accessible with aria-describedby">
|
|
92
|
+
<div class="max-w-md">
|
|
93
|
+
<label for="accessible-email" class="block text-sm font-medium mb-1">Email Address</label>
|
|
94
|
+
<input
|
|
95
|
+
id="accessible-email"
|
|
96
|
+
type="email"
|
|
97
|
+
aria-describedby="email-error"
|
|
98
|
+
aria-invalid="true"
|
|
99
|
+
class="w-full px-3 py-2 border border-red-300 rounded focus:ring-red-500 focus:border-red-500"
|
|
100
|
+
value="invalid-email"
|
|
101
|
+
/>
|
|
102
|
+
<ValidationError
|
|
103
|
+
id="email-error"
|
|
104
|
+
error="Please enter a valid email address"
|
|
105
|
+
show={true}
|
|
106
|
+
/>
|
|
107
|
+
<p class="text-sm text-gray-500 mt-4">
|
|
108
|
+
This example shows proper accessibility: the input references the error via aria-describedby,
|
|
109
|
+
and the error has aria-live="assertive" for screen reader announcements.
|
|
110
|
+
</p>
|
|
111
|
+
</div>
|
|
112
|
+
</Story>
|
|
@@ -1,29 +1,29 @@
|
|
|
1
|
-
<script lang="ts">
|
|
2
|
-
import { safeSlide } from "../utils/transitions.js";
|
|
3
|
-
import { cubicOut } from "svelte/easing";
|
|
4
|
-
import WarningIcon from "./Icons/WarningIcon.svelte";
|
|
5
|
-
|
|
6
|
-
interface Props {
|
|
7
|
-
/** Error message to display */
|
|
8
|
-
error?: string;
|
|
9
|
-
/** Whether to show the error */
|
|
10
|
-
show?: boolean;
|
|
11
|
-
/** Optional ID for aria-describedby linking from input fields */
|
|
12
|
-
id?: string;
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
let { error = '', show = true, id }: Props = $props();
|
|
16
|
-
</script>
|
|
17
|
-
|
|
18
|
-
{#if error && show}
|
|
19
|
-
<div
|
|
20
|
-
transition:safeSlide={{ duration: 300, easing: cubicOut }}
|
|
21
|
-
class="flex items-start gap-1.5 text-red-600 dark:text-red-500 mt-2"
|
|
22
|
-
role="alert"
|
|
23
|
-
aria-live="assertive"
|
|
24
|
-
{id}
|
|
25
|
-
>
|
|
26
|
-
<WarningIcon class="shrink-0 mt-[1px]" />
|
|
27
|
-
<p class="text-sm leading-tight m-0">{error}</p>
|
|
28
|
-
</div>
|
|
29
|
-
{/if}
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import { safeSlide } from "../utils/transitions.js";
|
|
3
|
+
import { cubicOut } from "svelte/easing";
|
|
4
|
+
import WarningIcon from "./Icons/WarningIcon.svelte";
|
|
5
|
+
|
|
6
|
+
interface Props {
|
|
7
|
+
/** Error message to display */
|
|
8
|
+
error?: string;
|
|
9
|
+
/** Whether to show the error */
|
|
10
|
+
show?: boolean;
|
|
11
|
+
/** Optional ID for aria-describedby linking from input fields */
|
|
12
|
+
id?: string;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
let { error = '', show = true, id }: Props = $props();
|
|
16
|
+
</script>
|
|
17
|
+
|
|
18
|
+
{#if error && show}
|
|
19
|
+
<div
|
|
20
|
+
transition:safeSlide={{ duration: 300, easing: cubicOut }}
|
|
21
|
+
class="flex items-start gap-1.5 text-red-600 dark:text-red-500 mt-2"
|
|
22
|
+
role="alert"
|
|
23
|
+
aria-live="assertive"
|
|
24
|
+
{id}
|
|
25
|
+
>
|
|
26
|
+
<WarningIcon class="shrink-0 mt-[1px]" />
|
|
27
|
+
<p class="text-sm leading-tight m-0">{error}</p>
|
|
28
|
+
</div>
|
|
29
|
+
{/if}
|
package/dist/primitives/index.js
CHANGED
|
@@ -1,84 +1,84 @@
|
|
|
1
|
-
// =============================================================================
|
|
2
|
-
// PRIMITIVES - Pure visual components (Layer 1)
|
|
3
|
-
// =============================================================================
|
|
4
|
-
|
|
5
|
-
// Accordion
|
|
6
|
-
export { default as Accordion } from './Accordion/Accordion.svelte';
|
|
7
|
-
export { default as AccordionItem } from './Accordion/AccordionItem.svelte';
|
|
8
|
-
|
|
9
|
-
// Alert
|
|
10
|
-
export { default as Alert } from './Alert/Alert.svelte';
|
|
11
|
-
|
|
12
|
-
// Avatar
|
|
13
|
-
export { default as Avatar } from './Avatar/Avatar.svelte';
|
|
14
|
-
|
|
15
|
-
// Badge
|
|
16
|
-
export { default as Badge } from './Badges/Badge.svelte';
|
|
17
|
-
|
|
18
|
-
// BottomSheet
|
|
19
|
-
export { default as BottomSheet } from './BottomSheet/BottomSheet.svelte';
|
|
20
|
-
|
|
21
|
-
// Breadcrumb
|
|
22
|
-
export { default as Breadcrumb } from './Breadcrumb/Breadcrumb.svelte';
|
|
23
|
-
|
|
24
|
-
// Button
|
|
25
|
-
export { default as Button } from './Button/Button.svelte';
|
|
26
|
-
export { default as ButtonSaveDemo } from './Button/ButtonSaveDemo.svelte';
|
|
27
|
-
|
|
28
|
-
// Card
|
|
29
|
-
export { default as Card } from './Card.svelte';
|
|
30
|
-
|
|
31
|
-
// Checkbox
|
|
32
|
-
export { default as Checkbox } from './Checkbox/Checkbox.svelte';
|
|
33
|
-
|
|
34
|
-
// DarkModeToggle
|
|
35
|
-
export { default as DarkModeToggle } from './DarkModeToggle.svelte';
|
|
36
|
-
|
|
37
|
-
// Drawer
|
|
38
|
-
export { default as Drawer } from './Drawer/Drawer.svelte';
|
|
39
|
-
|
|
40
|
-
// Dropdown
|
|
41
|
-
export { default as Dropdown } from './Dropdown/Dropdown.svelte';
|
|
42
|
-
export { default as DropdownItem } from './Dropdown/DropdownItem.svelte';
|
|
43
|
-
|
|
44
|
-
// Icons - re-export from Icons/index.js
|
|
45
|
-
export * from './Icons/index.js';
|
|
46
|
-
|
|
47
|
-
// Input (primitives only - Select, Textarea are here; recipes are in recipes/inputs)
|
|
48
|
-
export { default as Input } from './Input/Input.svelte';
|
|
49
|
-
export { default as Select } from './Input/Select.svelte';
|
|
50
|
-
export { default as Textarea } from './Input/Textarea.svelte';
|
|
51
|
-
|
|
52
|
-
// Label
|
|
53
|
-
export { default as Label } from './Label/Label.svelte';
|
|
54
|
-
|
|
55
|
-
// NumberInput
|
|
56
|
-
export { default as NumberInput } from './NumberInput/NumberInput.svelte';
|
|
57
|
-
|
|
58
|
-
// Modal (base only - composite modals are in recipes/modals)
|
|
59
|
-
export { default as Modal } from './Modal/Modal.svelte';
|
|
60
|
-
|
|
61
|
-
// Pagination
|
|
62
|
-
export { default as Pagination } from './Pagination/Pagination.svelte';
|
|
63
|
-
|
|
64
|
-
// Radio
|
|
65
|
-
export { default as Radio } from './Radio/Radio.svelte';
|
|
66
|
-
|
|
67
|
-
// Skeleton - re-export from Skeleton/index.js
|
|
68
|
-
export * from './Skeleton/index.js';
|
|
69
|
-
|
|
70
|
-
// Spinner
|
|
71
|
-
export { default as Spinner } from './Spinner/Spinner.svelte';
|
|
72
|
-
|
|
73
|
-
// Tabs
|
|
74
|
-
export { default as Tabs } from './Tabs/Tabs.svelte';
|
|
75
|
-
export { default as TabItem } from './Tabs/TabItem.svelte';
|
|
76
|
-
|
|
77
|
-
// Toggle
|
|
78
|
-
export { default as Toggle } from './Toggle.svelte';
|
|
79
|
-
|
|
80
|
-
// Typography
|
|
81
|
-
export { default as Typography } from './Typography/Typography.svelte';
|
|
82
|
-
|
|
83
|
-
// ValidationError
|
|
84
|
-
export { default as ValidationError } from './ValidationError.svelte';
|
|
1
|
+
// =============================================================================
|
|
2
|
+
// PRIMITIVES - Pure visual components (Layer 1)
|
|
3
|
+
// =============================================================================
|
|
4
|
+
|
|
5
|
+
// Accordion
|
|
6
|
+
export { default as Accordion } from './Accordion/Accordion.svelte';
|
|
7
|
+
export { default as AccordionItem } from './Accordion/AccordionItem.svelte';
|
|
8
|
+
|
|
9
|
+
// Alert
|
|
10
|
+
export { default as Alert } from './Alert/Alert.svelte';
|
|
11
|
+
|
|
12
|
+
// Avatar
|
|
13
|
+
export { default as Avatar } from './Avatar/Avatar.svelte';
|
|
14
|
+
|
|
15
|
+
// Badge
|
|
16
|
+
export { default as Badge } from './Badges/Badge.svelte';
|
|
17
|
+
|
|
18
|
+
// BottomSheet
|
|
19
|
+
export { default as BottomSheet } from './BottomSheet/BottomSheet.svelte';
|
|
20
|
+
|
|
21
|
+
// Breadcrumb
|
|
22
|
+
export { default as Breadcrumb } from './Breadcrumb/Breadcrumb.svelte';
|
|
23
|
+
|
|
24
|
+
// Button
|
|
25
|
+
export { default as Button } from './Button/Button.svelte';
|
|
26
|
+
export { default as ButtonSaveDemo } from './Button/ButtonSaveDemo.svelte';
|
|
27
|
+
|
|
28
|
+
// Card
|
|
29
|
+
export { default as Card } from './Card.svelte';
|
|
30
|
+
|
|
31
|
+
// Checkbox
|
|
32
|
+
export { default as Checkbox } from './Checkbox/Checkbox.svelte';
|
|
33
|
+
|
|
34
|
+
// DarkModeToggle
|
|
35
|
+
export { default as DarkModeToggle } from './DarkModeToggle.svelte';
|
|
36
|
+
|
|
37
|
+
// Drawer
|
|
38
|
+
export { default as Drawer } from './Drawer/Drawer.svelte';
|
|
39
|
+
|
|
40
|
+
// Dropdown
|
|
41
|
+
export { default as Dropdown } from './Dropdown/Dropdown.svelte';
|
|
42
|
+
export { default as DropdownItem } from './Dropdown/DropdownItem.svelte';
|
|
43
|
+
|
|
44
|
+
// Icons - re-export from Icons/index.js
|
|
45
|
+
export * from './Icons/index.js';
|
|
46
|
+
|
|
47
|
+
// Input (primitives only - Select, Textarea are here; recipes are in recipes/inputs)
|
|
48
|
+
export { default as Input } from './Input/Input.svelte';
|
|
49
|
+
export { default as Select } from './Input/Select.svelte';
|
|
50
|
+
export { default as Textarea } from './Input/Textarea.svelte';
|
|
51
|
+
|
|
52
|
+
// Label
|
|
53
|
+
export { default as Label } from './Label/Label.svelte';
|
|
54
|
+
|
|
55
|
+
// NumberInput
|
|
56
|
+
export { default as NumberInput } from './NumberInput/NumberInput.svelte';
|
|
57
|
+
|
|
58
|
+
// Modal (base only - composite modals are in recipes/modals)
|
|
59
|
+
export { default as Modal } from './Modal/Modal.svelte';
|
|
60
|
+
|
|
61
|
+
// Pagination
|
|
62
|
+
export { default as Pagination } from './Pagination/Pagination.svelte';
|
|
63
|
+
|
|
64
|
+
// Radio
|
|
65
|
+
export { default as Radio } from './Radio/Radio.svelte';
|
|
66
|
+
|
|
67
|
+
// Skeleton - re-export from Skeleton/index.js
|
|
68
|
+
export * from './Skeleton/index.js';
|
|
69
|
+
|
|
70
|
+
// Spinner
|
|
71
|
+
export { default as Spinner } from './Spinner/Spinner.svelte';
|
|
72
|
+
|
|
73
|
+
// Tabs
|
|
74
|
+
export { default as Tabs } from './Tabs/Tabs.svelte';
|
|
75
|
+
export { default as TabItem } from './Tabs/TabItem.svelte';
|
|
76
|
+
|
|
77
|
+
// Toggle
|
|
78
|
+
export { default as Toggle } from './Toggle.svelte';
|
|
79
|
+
|
|
80
|
+
// Typography
|
|
81
|
+
export { default as Typography } from './Typography/Typography.svelte';
|
|
82
|
+
|
|
83
|
+
// ValidationError
|
|
84
|
+
export { default as ValidationError } from './ValidationError.svelte';
|