@getmicdrop/svelte-components 5.6.0 → 5.7.1
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/Heading.svelte +57 -0
- package/dist/components/Heading.svelte.d.ts +12 -0
- package/dist/components/Heading.svelte.d.ts.map +1 -0
- package/dist/components/Layout/AppShell.svelte +104 -104
- package/dist/components/Layout/ContentSection.svelte +80 -80
- package/dist/components/Layout/Grid.svelte +4 -4
- 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 +6 -6
- package/dist/components/Layout/Text.svelte +87 -87
- package/dist/components/Layout/TwoColumn.svelte +108 -108
- package/dist/components/Layout/__tests__/AppShell.test.d.ts +2 -0
- package/dist/components/Layout/__tests__/AppShell.test.d.ts.map +1 -0
- package/dist/components/Layout/__tests__/AppShell.test.js +95 -0
- package/dist/components/Layout/__tests__/ContentSection.test.d.ts +2 -0
- package/dist/components/Layout/__tests__/ContentSection.test.d.ts.map +1 -0
- package/dist/components/Layout/__tests__/ContentSection.test.js +112 -0
- package/dist/components/Layout/__tests__/PageContainer.test.d.ts +2 -0
- package/dist/components/Layout/__tests__/PageContainer.test.d.ts.map +1 -0
- package/dist/components/Layout/__tests__/PageContainer.test.js +133 -0
- package/dist/components/Layout/__tests__/Responsive.test.d.ts +2 -0
- package/dist/components/Layout/__tests__/Responsive.test.d.ts.map +1 -0
- package/dist/components/Layout/__tests__/Responsive.test.js +123 -0
- package/dist/components/Layout/index.d.ts +11 -0
- package/dist/components/Layout/index.d.ts.map +1 -0
- package/dist/components/Layout/index.js +14 -0
- package/dist/components/Text.svelte +40 -0
- package/dist/components/Text.svelte.d.ts +11 -0
- package/dist/components/Text.svelte.d.ts.map +1 -0
- package/dist/components/index.d.ts +4 -0
- package/dist/components/index.d.ts.map +1 -0
- package/dist/components/index.js +12 -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 +0 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.js +50 -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/navigation/BottomNav.stories.svelte +117 -117
- package/dist/patterns/navigation/BottomNav.svelte +74 -64
- package/dist/patterns/navigation/BottomNav.svelte.d.ts.map +1 -1
- 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/Accordion/AccordionItemWrapper.test.svelte +107 -107
- package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte.d.ts +2 -2
- package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte.d.ts.map +1 -1
- 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/DropdownDivider.svelte +9 -0
- package/dist/primitives/Dropdown/DropdownDivider.svelte.d.ts +7 -0
- package/dist/primitives/Dropdown/DropdownDivider.svelte.d.ts.map +1 -0
- package/dist/primitives/Dropdown/DropdownItem.svelte +80 -80
- package/dist/primitives/Helper/Helper.svelte +33 -0
- package/dist/primitives/Helper/Helper.svelte.d.ts +18 -0
- package/dist/primitives/Helper/Helper.svelte.d.ts.map +1 -0
- 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 +416 -417
- package/dist/primitives/Input/Input.svelte.d.ts +2 -4
- package/dist/primitives/Input/Input.svelte.d.ts.map +1 -1
- 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 +157 -158
- package/dist/primitives/Modal/Modal.svelte.d.ts +6 -8
- package/dist/primitives/Modal/Modal.svelte.d.ts.map +1 -1
- package/dist/primitives/NumberInput/NumberInput.svelte +105 -106
- package/dist/primitives/NumberInput/NumberInput.svelte.d.ts +0 -2
- package/dist/primitives/NumberInput/NumberInput.svelte.d.ts.map +1 -1
- 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 +70 -71
- package/dist/primitives/Toggle.svelte.d.ts +2 -4
- package/dist/primitives/Toggle.svelte.d.ts.map +1 -1
- package/dist/primitives/Tooltip/Tooltip.svelte +83 -0
- package/dist/primitives/Tooltip/Tooltip.svelte.d.ts +15 -0
- package/dist/primitives/Tooltip/Tooltip.svelte.d.ts.map +1 -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 +3 -0
- package/dist/primitives/index.js +91 -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.spec.js +6 -5
- package/dist/recipes/ImageUploader/ImageUploader.stories.svelte +125 -125
- package/dist/recipes/ImageUploader/ImageUploader.svelte +804 -804
- 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 +277 -256
- package/dist/recipes/inputs/MultiSelect.svelte.d.ts +54 -21
- package/dist/recipes/inputs/MultiSelect.svelte.d.ts.map +1 -1
- 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.spec.js +9 -4
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.stories.svelte +123 -123
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte +332 -327
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte.d.ts +12 -1
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte.d.ts.map +1 -1
- 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.server.spec.js +11 -8
- package/dist/telemetry.spec.js +1169 -1144
- package/dist/tokens/tokens.css +87 -87
- package/dist/tokens/typography-base.css +163 -163
- package/dist/utils/apiConfig.spec.js +219 -219
- package/dist/utils/imageValidation.spec.js +62 -59
- package/dist/utils/logger.d.ts +19 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +47 -0
- package/dist/utils/transitions.js +62 -62
- package/dist/utils/utils.js +354 -354
- package/package.json +296 -292
|
@@ -1,103 +1,103 @@
|
|
|
1
|
-
import { describe, it, expect } from 'vitest';
|
|
2
|
-
import { render } from '@testing-library/svelte';
|
|
3
|
-
import ValidationError from './ValidationError.svelte';
|
|
4
|
-
|
|
5
|
-
describe('ValidationError Component', () => {
|
|
6
|
-
it('renders error message when error prop is provided', () => {
|
|
7
|
-
const { container, getByText } = render(ValidationError, {
|
|
8
|
-
props: { error: 'This field is required' },
|
|
9
|
-
});
|
|
10
|
-
expect(getByText('This field is required')).toBeTruthy();
|
|
11
|
-
});
|
|
12
|
-
|
|
13
|
-
it('does not render when error is empty', () => {
|
|
14
|
-
const { container } = render(ValidationError, {
|
|
15
|
-
props: { error: '' },
|
|
16
|
-
});
|
|
17
|
-
const alert = container.querySelector('[role="alert"]');
|
|
18
|
-
expect(alert).toBeFalsy();
|
|
19
|
-
});
|
|
20
|
-
|
|
21
|
-
it('does not render when show is false', () => {
|
|
22
|
-
const { container } = render(ValidationError, {
|
|
23
|
-
props: { error: 'Error message', show: false },
|
|
24
|
-
});
|
|
25
|
-
const alert = container.querySelector('[role="alert"]');
|
|
26
|
-
expect(alert).toBeFalsy();
|
|
27
|
-
});
|
|
28
|
-
|
|
29
|
-
it('has role="alert" attribute', () => {
|
|
30
|
-
const { container } = render(ValidationError, {
|
|
31
|
-
props: { error: 'Error message' },
|
|
32
|
-
});
|
|
33
|
-
const alert = container.querySelector('[role="alert"]');
|
|
34
|
-
expect(alert).toBeTruthy();
|
|
35
|
-
});
|
|
36
|
-
|
|
37
|
-
it('has red text styling', () => {
|
|
38
|
-
const { container } = render(ValidationError, {
|
|
39
|
-
props: { error: 'Error message' },
|
|
40
|
-
});
|
|
41
|
-
const alert = container.querySelector('[role="alert"]');
|
|
42
|
-
expect(alert.classList.contains('text-red-600')).toBe(true);
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
it('renders WarningIcon', () => {
|
|
46
|
-
const { container } = render(ValidationError, {
|
|
47
|
-
props: { error: 'Error message' },
|
|
48
|
-
});
|
|
49
|
-
// The WarningIcon should render an SVG
|
|
50
|
-
const svg = container.querySelector('svg');
|
|
51
|
-
expect(svg).toBeTruthy();
|
|
52
|
-
});
|
|
53
|
-
|
|
54
|
-
it('renders error text in a paragraph', () => {
|
|
55
|
-
const { container } = render(ValidationError, {
|
|
56
|
-
props: { error: 'Custom error text' },
|
|
57
|
-
});
|
|
58
|
-
const paragraph = container.querySelector('p');
|
|
59
|
-
expect(paragraph).toBeTruthy();
|
|
60
|
-
expect(paragraph.textContent).toBe('Custom error text');
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
it('shows when show is true and error exists', () => {
|
|
64
|
-
const { container } = render(ValidationError, {
|
|
65
|
-
props: { error: 'Error message', show: true },
|
|
66
|
-
});
|
|
67
|
-
const alert = container.querySelector('[role="alert"]');
|
|
68
|
-
expect(alert).toBeTruthy();
|
|
69
|
-
});
|
|
70
|
-
|
|
71
|
-
it('renders with flex layout', () => {
|
|
72
|
-
const { container } = render(ValidationError, {
|
|
73
|
-
props: { error: 'Error message' },
|
|
74
|
-
});
|
|
75
|
-
const alert = container.querySelector('[role="alert"]');
|
|
76
|
-
expect(alert.classList.contains('flex')).toBe(true);
|
|
77
|
-
expect(alert.classList.contains('items-start')).toBe(true);
|
|
78
|
-
});
|
|
79
|
-
|
|
80
|
-
it('has aria-live="assertive" for screen reader announcements', () => {
|
|
81
|
-
const { container } = render(ValidationError, {
|
|
82
|
-
props: { error: 'Error message' },
|
|
83
|
-
});
|
|
84
|
-
const alert = container.querySelector('[role="alert"]');
|
|
85
|
-
expect(alert.getAttribute('aria-live')).toBe('assertive');
|
|
86
|
-
});
|
|
87
|
-
|
|
88
|
-
it('renders with id when provided', () => {
|
|
89
|
-
const { container } = render(ValidationError, {
|
|
90
|
-
props: { error: 'Error message', id: 'my-error-id' },
|
|
91
|
-
});
|
|
92
|
-
const alert = container.querySelector('[role="alert"]');
|
|
93
|
-
expect(alert.getAttribute('id')).toBe('my-error-id');
|
|
94
|
-
});
|
|
95
|
-
|
|
96
|
-
it('does not render id when not provided', () => {
|
|
97
|
-
const { container } = render(ValidationError, {
|
|
98
|
-
props: { error: 'Error message' },
|
|
99
|
-
});
|
|
100
|
-
const alert = container.querySelector('[role="alert"]');
|
|
101
|
-
expect(alert.getAttribute('id')).toBeFalsy();
|
|
102
|
-
});
|
|
103
|
-
});
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { render } from '@testing-library/svelte';
|
|
3
|
+
import ValidationError from './ValidationError.svelte';
|
|
4
|
+
|
|
5
|
+
describe('ValidationError Component', () => {
|
|
6
|
+
it('renders error message when error prop is provided', () => {
|
|
7
|
+
const { container, getByText } = render(ValidationError, {
|
|
8
|
+
props: { error: 'This field is required' },
|
|
9
|
+
});
|
|
10
|
+
expect(getByText('This field is required')).toBeTruthy();
|
|
11
|
+
});
|
|
12
|
+
|
|
13
|
+
it('does not render when error is empty', () => {
|
|
14
|
+
const { container } = render(ValidationError, {
|
|
15
|
+
props: { error: '' },
|
|
16
|
+
});
|
|
17
|
+
const alert = container.querySelector('[role="alert"]');
|
|
18
|
+
expect(alert).toBeFalsy();
|
|
19
|
+
});
|
|
20
|
+
|
|
21
|
+
it('does not render when show is false', () => {
|
|
22
|
+
const { container } = render(ValidationError, {
|
|
23
|
+
props: { error: 'Error message', show: false },
|
|
24
|
+
});
|
|
25
|
+
const alert = container.querySelector('[role="alert"]');
|
|
26
|
+
expect(alert).toBeFalsy();
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
it('has role="alert" attribute', () => {
|
|
30
|
+
const { container } = render(ValidationError, {
|
|
31
|
+
props: { error: 'Error message' },
|
|
32
|
+
});
|
|
33
|
+
const alert = container.querySelector('[role="alert"]');
|
|
34
|
+
expect(alert).toBeTruthy();
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
it('has red text styling', () => {
|
|
38
|
+
const { container } = render(ValidationError, {
|
|
39
|
+
props: { error: 'Error message' },
|
|
40
|
+
});
|
|
41
|
+
const alert = container.querySelector('[role="alert"]');
|
|
42
|
+
expect(alert.classList.contains('text-red-600')).toBe(true);
|
|
43
|
+
});
|
|
44
|
+
|
|
45
|
+
it('renders WarningIcon', () => {
|
|
46
|
+
const { container } = render(ValidationError, {
|
|
47
|
+
props: { error: 'Error message' },
|
|
48
|
+
});
|
|
49
|
+
// The WarningIcon should render an SVG
|
|
50
|
+
const svg = container.querySelector('svg');
|
|
51
|
+
expect(svg).toBeTruthy();
|
|
52
|
+
});
|
|
53
|
+
|
|
54
|
+
it('renders error text in a paragraph', () => {
|
|
55
|
+
const { container } = render(ValidationError, {
|
|
56
|
+
props: { error: 'Custom error text' },
|
|
57
|
+
});
|
|
58
|
+
const paragraph = container.querySelector('p');
|
|
59
|
+
expect(paragraph).toBeTruthy();
|
|
60
|
+
expect(paragraph.textContent).toBe('Custom error text');
|
|
61
|
+
});
|
|
62
|
+
|
|
63
|
+
it('shows when show is true and error exists', () => {
|
|
64
|
+
const { container } = render(ValidationError, {
|
|
65
|
+
props: { error: 'Error message', show: true },
|
|
66
|
+
});
|
|
67
|
+
const alert = container.querySelector('[role="alert"]');
|
|
68
|
+
expect(alert).toBeTruthy();
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
it('renders with flex layout', () => {
|
|
72
|
+
const { container } = render(ValidationError, {
|
|
73
|
+
props: { error: 'Error message' },
|
|
74
|
+
});
|
|
75
|
+
const alert = container.querySelector('[role="alert"]');
|
|
76
|
+
expect(alert.classList.contains('flex')).toBe(true);
|
|
77
|
+
expect(alert.classList.contains('items-start')).toBe(true);
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
it('has aria-live="assertive" for screen reader announcements', () => {
|
|
81
|
+
const { container } = render(ValidationError, {
|
|
82
|
+
props: { error: 'Error message' },
|
|
83
|
+
});
|
|
84
|
+
const alert = container.querySelector('[role="alert"]');
|
|
85
|
+
expect(alert.getAttribute('aria-live')).toBe('assertive');
|
|
86
|
+
});
|
|
87
|
+
|
|
88
|
+
it('renders with id when provided', () => {
|
|
89
|
+
const { container } = render(ValidationError, {
|
|
90
|
+
props: { error: 'Error message', id: 'my-error-id' },
|
|
91
|
+
});
|
|
92
|
+
const alert = container.querySelector('[role="alert"]');
|
|
93
|
+
expect(alert.getAttribute('id')).toBe('my-error-id');
|
|
94
|
+
});
|
|
95
|
+
|
|
96
|
+
it('does not render id when not provided', () => {
|
|
97
|
+
const { container } = render(ValidationError, {
|
|
98
|
+
props: { error: 'Error message' },
|
|
99
|
+
});
|
|
100
|
+
const alert = container.querySelector('[role="alert"]');
|
|
101
|
+
expect(alert.getAttribute('id')).toBeFalsy();
|
|
102
|
+
});
|
|
103
|
+
});
|
|
@@ -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}
|
|
@@ -13,6 +13,8 @@ export { default as DarkModeToggle } from "./DarkModeToggle.svelte";
|
|
|
13
13
|
export { default as Drawer } from "./Drawer/Drawer.svelte";
|
|
14
14
|
export { default as Dropdown } from "./Dropdown/Dropdown.svelte";
|
|
15
15
|
export { default as DropdownItem } from "./Dropdown/DropdownItem.svelte";
|
|
16
|
+
export { default as DropdownDivider } from "./Dropdown/DropdownDivider.svelte";
|
|
17
|
+
export { default as Helper } from "./Helper/Helper.svelte";
|
|
16
18
|
export * from "./Icons/index.js";
|
|
17
19
|
export * from "./Skeleton/index.js";
|
|
18
20
|
export { default as Input } from "./Input/Input.svelte";
|
|
@@ -27,6 +29,7 @@ export { default as Spinner } from "./Spinner/Spinner.svelte";
|
|
|
27
29
|
export { default as Tabs } from "./Tabs/Tabs.svelte";
|
|
28
30
|
export { default as TabItem } from "./Tabs/TabItem.svelte";
|
|
29
31
|
export { default as Toggle } from "./Toggle.svelte";
|
|
32
|
+
export { default as Tooltip } from "./Tooltip/Tooltip.svelte";
|
|
30
33
|
export { default as Typography } from "./Typography/Typography.svelte";
|
|
31
34
|
export { default as ValidationError } from "./ValidationError.svelte";
|
|
32
35
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/primitives/index.js
CHANGED
|
@@ -1,84 +1,91 @@
|
|
|
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
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
export
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
export { default as
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
export { default as
|
|
76
|
-
|
|
77
|
-
//
|
|
78
|
-
export { default as
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
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
|
+
export { default as DropdownDivider } from './Dropdown/DropdownDivider.svelte';
|
|
44
|
+
|
|
45
|
+
// Helper
|
|
46
|
+
export { default as Helper } from './Helper/Helper.svelte';
|
|
47
|
+
|
|
48
|
+
// Icons - re-export from Icons/index.js
|
|
49
|
+
export * from './Icons/index.js';
|
|
50
|
+
|
|
51
|
+
// Input (primitives only - Select, Textarea are here; recipes are in recipes/inputs)
|
|
52
|
+
export { default as Input } from './Input/Input.svelte';
|
|
53
|
+
export { default as Select } from './Input/Select.svelte';
|
|
54
|
+
export { default as Textarea } from './Input/Textarea.svelte';
|
|
55
|
+
|
|
56
|
+
// Label
|
|
57
|
+
export { default as Label } from './Label/Label.svelte';
|
|
58
|
+
|
|
59
|
+
// NumberInput
|
|
60
|
+
export { default as NumberInput } from './NumberInput/NumberInput.svelte';
|
|
61
|
+
|
|
62
|
+
// Modal (base only - composite modals are in recipes/modals)
|
|
63
|
+
export { default as Modal } from './Modal/Modal.svelte';
|
|
64
|
+
|
|
65
|
+
// Pagination
|
|
66
|
+
export { default as Pagination } from './Pagination/Pagination.svelte';
|
|
67
|
+
|
|
68
|
+
// Radio
|
|
69
|
+
export { default as Radio } from './Radio/Radio.svelte';
|
|
70
|
+
|
|
71
|
+
// Skeleton - re-export from Skeleton/index.js
|
|
72
|
+
export * from './Skeleton/index.js';
|
|
73
|
+
|
|
74
|
+
// Spinner
|
|
75
|
+
export { default as Spinner } from './Spinner/Spinner.svelte';
|
|
76
|
+
|
|
77
|
+
// Tabs
|
|
78
|
+
export { default as Tabs } from './Tabs/Tabs.svelte';
|
|
79
|
+
export { default as TabItem } from './Tabs/TabItem.svelte';
|
|
80
|
+
|
|
81
|
+
// Toggle
|
|
82
|
+
export { default as Toggle } from './Toggle.svelte';
|
|
83
|
+
|
|
84
|
+
// Tooltip
|
|
85
|
+
export { default as Tooltip } from './Tooltip/Tooltip.svelte';
|
|
86
|
+
|
|
87
|
+
// Typography
|
|
88
|
+
export { default as Typography } from './Typography/Typography.svelte';
|
|
89
|
+
|
|
90
|
+
// ValidationError
|
|
91
|
+
export { default as ValidationError } from './ValidationError.svelte';
|