@getmicdrop/svelte-components 5.6.1 → 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/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 -1
- package/dist/index.js +10 -1
- 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 -74
- 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/DropdownDivider.svelte +9 -9
- package/dist/primitives/Dropdown/DropdownItem.svelte +80 -80
- package/dist/primitives/Helper/Helper.svelte +33 -33
- 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/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/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/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 +69 -69
- package/dist/primitives/ValidationError.svelte +29 -29
- package/dist/primitives/index.js +91 -91
- 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/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/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/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 -44
- package/dist/stores/auth.spec.js +139 -139
- package/dist/stores/formDataStore.d.ts.map +1 -1
- package/dist/stores/formDataStore.js +0 -8
- package/dist/stores/formSave.d.ts.map +1 -1
- package/dist/stores/formSave.js +0 -8
- package/dist/stores/navigation.d.ts.map +1 -1
- package/dist/stores/navigation.js +0 -8
- 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 +1169 -1169
- 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/transitions.js +62 -62
- package/dist/utils/utils.js +354 -354
- package/package.json +1 -1
- package/dist/stores/auth.svelte.d.ts +0 -39
- package/dist/stores/auth.svelte.d.ts.map +0 -1
- package/dist/stores/auth.svelte.js +0 -60
- package/dist/stores/formDataStore.svelte.d.ts +0 -47
- package/dist/stores/formDataStore.svelte.d.ts.map +0 -1
- package/dist/stores/formDataStore.svelte.js +0 -84
- package/dist/stores/formSave.svelte.d.ts +0 -33
- package/dist/stores/formSave.svelte.d.ts.map +0 -1
- package/dist/stores/formSave.svelte.js +0 -113
- package/dist/stores/navigation.svelte.d.ts +0 -35
- package/dist/stores/navigation.svelte.d.ts.map +0 -1
- package/dist/stores/navigation.svelte.js +0 -69
|
@@ -1,100 +1,100 @@
|
|
|
1
|
-
import { render, screen } from "@testing-library/svelte";
|
|
2
|
-
import userEvent from "@testing-library/user-event";
|
|
3
|
-
import { expect, describe, test, vi } from "vitest";
|
|
4
|
-
import ModalStateManager from "./ModalStateManager.svelte";
|
|
5
|
-
|
|
6
|
-
describe("ModalStateManager Component Tests", () => {
|
|
7
|
-
test("Shows processing state when isProcessing is true", () => {
|
|
8
|
-
render(ModalStateManager, {
|
|
9
|
-
props: { isProcessing: true, isSuccess: false },
|
|
10
|
-
});
|
|
11
|
-
expect(screen.getByText("Processing your request")).toBeInTheDocument();
|
|
12
|
-
});
|
|
13
|
-
|
|
14
|
-
test("Shows custom processing message", () => {
|
|
15
|
-
render(ModalStateManager, {
|
|
16
|
-
props: {
|
|
17
|
-
isProcessing: true,
|
|
18
|
-
isSuccess: false,
|
|
19
|
-
processingMessage: "Please wait...",
|
|
20
|
-
},
|
|
21
|
-
});
|
|
22
|
-
expect(screen.getByText("Please wait...")).toBeInTheDocument();
|
|
23
|
-
});
|
|
24
|
-
|
|
25
|
-
test("Shows success state when isSuccess is true", () => {
|
|
26
|
-
render(ModalStateManager, {
|
|
27
|
-
props: { isProcessing: false, isSuccess: true, successTitle: "Done!" },
|
|
28
|
-
});
|
|
29
|
-
expect(screen.getByText("Done!")).toBeInTheDocument();
|
|
30
|
-
});
|
|
31
|
-
|
|
32
|
-
test("Shows success message when provided", () => {
|
|
33
|
-
render(ModalStateManager, {
|
|
34
|
-
props: {
|
|
35
|
-
isProcessing: false,
|
|
36
|
-
isSuccess: true,
|
|
37
|
-
successTitle: "Success",
|
|
38
|
-
successMessage: "Your action was completed.",
|
|
39
|
-
},
|
|
40
|
-
});
|
|
41
|
-
expect(screen.getByText("Your action was completed.")).toBeInTheDocument();
|
|
42
|
-
});
|
|
43
|
-
|
|
44
|
-
test("Shows continue button in success state", () => {
|
|
45
|
-
render(ModalStateManager, {
|
|
46
|
-
props: { isProcessing: false, isSuccess: true },
|
|
47
|
-
});
|
|
48
|
-
expect(screen.getByText("Continue")).toBeInTheDocument();
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
test("Uses custom success button text", () => {
|
|
52
|
-
render(ModalStateManager, {
|
|
53
|
-
props: {
|
|
54
|
-
isProcessing: false,
|
|
55
|
-
isSuccess: true,
|
|
56
|
-
successButtonText: "Close",
|
|
57
|
-
},
|
|
58
|
-
});
|
|
59
|
-
expect(screen.getByText("Close")).toBeInTheDocument();
|
|
60
|
-
});
|
|
61
|
-
|
|
62
|
-
test("Calls onSuccessClose when success button clicked", async () => {
|
|
63
|
-
const user = userEvent.setup();
|
|
64
|
-
const onSuccessClose = vi.fn();
|
|
65
|
-
|
|
66
|
-
render(ModalStateManager, {
|
|
67
|
-
props: { isProcessing: false, isSuccess: true, onSuccessClose },
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
await user.click(screen.getByText("Continue"));
|
|
71
|
-
expect(onSuccessClose).toHaveBeenCalledTimes(1);
|
|
72
|
-
});
|
|
73
|
-
|
|
74
|
-
test("Processing state shows spinner animation", () => {
|
|
75
|
-
const { container } = render(ModalStateManager, {
|
|
76
|
-
props: { isProcessing: true, isSuccess: false },
|
|
77
|
-
});
|
|
78
|
-
const spinner = container.querySelector(".animate-spin");
|
|
79
|
-
expect(spinner).toBeInTheDocument();
|
|
80
|
-
});
|
|
81
|
-
|
|
82
|
-
test("Processing state has orange background", () => {
|
|
83
|
-
const { container } = render(ModalStateManager, {
|
|
84
|
-
props: { isProcessing: true, isSuccess: false },
|
|
85
|
-
});
|
|
86
|
-
const spinnerBg = container.querySelector(".bg-orange-300");
|
|
87
|
-
expect(spinnerBg).toBeInTheDocument();
|
|
88
|
-
});
|
|
89
|
-
|
|
90
|
-
test("Success state priority over processing", () => {
|
|
91
|
-
// When both are true, success should show
|
|
92
|
-
render(ModalStateManager, {
|
|
93
|
-
props: { isProcessing: true, isSuccess: true, successTitle: "Complete" },
|
|
94
|
-
});
|
|
95
|
-
expect(screen.getByText("Complete")).toBeInTheDocument();
|
|
96
|
-
expect(
|
|
97
|
-
screen.queryByText("Processing your request")
|
|
98
|
-
).not.toBeInTheDocument();
|
|
99
|
-
});
|
|
100
|
-
});
|
|
1
|
+
import { render, screen } from "@testing-library/svelte";
|
|
2
|
+
import userEvent from "@testing-library/user-event";
|
|
3
|
+
import { expect, describe, test, vi } from "vitest";
|
|
4
|
+
import ModalStateManager from "./ModalStateManager.svelte";
|
|
5
|
+
|
|
6
|
+
describe("ModalStateManager Component Tests", () => {
|
|
7
|
+
test("Shows processing state when isProcessing is true", () => {
|
|
8
|
+
render(ModalStateManager, {
|
|
9
|
+
props: { isProcessing: true, isSuccess: false },
|
|
10
|
+
});
|
|
11
|
+
expect(screen.getByText("Processing your request")).toBeInTheDocument();
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
test("Shows custom processing message", () => {
|
|
15
|
+
render(ModalStateManager, {
|
|
16
|
+
props: {
|
|
17
|
+
isProcessing: true,
|
|
18
|
+
isSuccess: false,
|
|
19
|
+
processingMessage: "Please wait...",
|
|
20
|
+
},
|
|
21
|
+
});
|
|
22
|
+
expect(screen.getByText("Please wait...")).toBeInTheDocument();
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
test("Shows success state when isSuccess is true", () => {
|
|
26
|
+
render(ModalStateManager, {
|
|
27
|
+
props: { isProcessing: false, isSuccess: true, successTitle: "Done!" },
|
|
28
|
+
});
|
|
29
|
+
expect(screen.getByText("Done!")).toBeInTheDocument();
|
|
30
|
+
});
|
|
31
|
+
|
|
32
|
+
test("Shows success message when provided", () => {
|
|
33
|
+
render(ModalStateManager, {
|
|
34
|
+
props: {
|
|
35
|
+
isProcessing: false,
|
|
36
|
+
isSuccess: true,
|
|
37
|
+
successTitle: "Success",
|
|
38
|
+
successMessage: "Your action was completed.",
|
|
39
|
+
},
|
|
40
|
+
});
|
|
41
|
+
expect(screen.getByText("Your action was completed.")).toBeInTheDocument();
|
|
42
|
+
});
|
|
43
|
+
|
|
44
|
+
test("Shows continue button in success state", () => {
|
|
45
|
+
render(ModalStateManager, {
|
|
46
|
+
props: { isProcessing: false, isSuccess: true },
|
|
47
|
+
});
|
|
48
|
+
expect(screen.getByText("Continue")).toBeInTheDocument();
|
|
49
|
+
});
|
|
50
|
+
|
|
51
|
+
test("Uses custom success button text", () => {
|
|
52
|
+
render(ModalStateManager, {
|
|
53
|
+
props: {
|
|
54
|
+
isProcessing: false,
|
|
55
|
+
isSuccess: true,
|
|
56
|
+
successButtonText: "Close",
|
|
57
|
+
},
|
|
58
|
+
});
|
|
59
|
+
expect(screen.getByText("Close")).toBeInTheDocument();
|
|
60
|
+
});
|
|
61
|
+
|
|
62
|
+
test("Calls onSuccessClose when success button clicked", async () => {
|
|
63
|
+
const user = userEvent.setup();
|
|
64
|
+
const onSuccessClose = vi.fn();
|
|
65
|
+
|
|
66
|
+
render(ModalStateManager, {
|
|
67
|
+
props: { isProcessing: false, isSuccess: true, onSuccessClose },
|
|
68
|
+
});
|
|
69
|
+
|
|
70
|
+
await user.click(screen.getByText("Continue"));
|
|
71
|
+
expect(onSuccessClose).toHaveBeenCalledTimes(1);
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
test("Processing state shows spinner animation", () => {
|
|
75
|
+
const { container } = render(ModalStateManager, {
|
|
76
|
+
props: { isProcessing: true, isSuccess: false },
|
|
77
|
+
});
|
|
78
|
+
const spinner = container.querySelector(".animate-spin");
|
|
79
|
+
expect(spinner).toBeInTheDocument();
|
|
80
|
+
});
|
|
81
|
+
|
|
82
|
+
test("Processing state has orange background", () => {
|
|
83
|
+
const { container } = render(ModalStateManager, {
|
|
84
|
+
props: { isProcessing: true, isSuccess: false },
|
|
85
|
+
});
|
|
86
|
+
const spinnerBg = container.querySelector(".bg-orange-300");
|
|
87
|
+
expect(spinnerBg).toBeInTheDocument();
|
|
88
|
+
});
|
|
89
|
+
|
|
90
|
+
test("Success state priority over processing", () => {
|
|
91
|
+
// When both are true, success should show
|
|
92
|
+
render(ModalStateManager, {
|
|
93
|
+
props: { isProcessing: true, isSuccess: true, successTitle: "Complete" },
|
|
94
|
+
});
|
|
95
|
+
expect(screen.getByText("Complete")).toBeInTheDocument();
|
|
96
|
+
expect(
|
|
97
|
+
screen.queryByText("Processing your request")
|
|
98
|
+
).not.toBeInTheDocument();
|
|
99
|
+
});
|
|
100
|
+
});
|
|
@@ -1,77 +1,77 @@
|
|
|
1
|
-
<script lang="ts">
|
|
2
|
-
import type { Snippet } from 'svelte';
|
|
3
|
-
import Icon from "../../primitives/Icons/Icon.svelte";
|
|
4
|
-
import Button from "../../primitives/Button/Button.svelte";
|
|
5
|
-
import { typography } from '../../tokens/typography';
|
|
6
|
-
|
|
7
|
-
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";
|
|
8
|
-
|
|
9
|
-
interface Props {
|
|
10
|
-
/** Whether the modal is currently processing an action */
|
|
11
|
-
isProcessing?: boolean;
|
|
12
|
-
/** Whether the action completed successfully */
|
|
13
|
-
isSuccess?: boolean;
|
|
14
|
-
/** Icon to show on success (from Icon component) */
|
|
15
|
-
successIcon?: IconName;
|
|
16
|
-
/** Title to show on success */
|
|
17
|
-
successTitle?: string;
|
|
18
|
-
/** Optional message to show on success */
|
|
19
|
-
successMessage?: string;
|
|
20
|
-
/** Text to show while processing */
|
|
21
|
-
processingMessage?: string;
|
|
22
|
-
/** Button text for the success state */
|
|
23
|
-
successButtonText?: string;
|
|
24
|
-
/** Callback when success button is clicked */
|
|
25
|
-
onSuccessClose?: () => void;
|
|
26
|
-
/** Custom success icon color class */
|
|
27
|
-
successIconColor?: string;
|
|
28
|
-
/** Custom processing icon color class */
|
|
29
|
-
processingIconBgColor?: string;
|
|
30
|
-
/** Child content (normal state) */
|
|
31
|
-
children?: Snippet;
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
let {
|
|
35
|
-
isProcessing = false,
|
|
36
|
-
isSuccess = false,
|
|
37
|
-
successIcon = "CheckCircle",
|
|
38
|
-
successTitle = "Success",
|
|
39
|
-
successMessage = "",
|
|
40
|
-
processingMessage = "Processing your request",
|
|
41
|
-
successButtonText = "Continue",
|
|
42
|
-
onSuccessClose = () => {},
|
|
43
|
-
successIconColor = "text-green-600",
|
|
44
|
-
processingIconBgColor = "bg-orange-300",
|
|
45
|
-
children
|
|
46
|
-
}: Props = $props();
|
|
47
|
-
</script>
|
|
48
|
-
|
|
49
|
-
{#if isProcessing && !isSuccess}
|
|
50
|
-
<div class="py-6 px-4 flex flex-col items-center justify-center gap-4">
|
|
51
|
-
<div
|
|
52
|
-
class="w-12 h-12 {processingIconBgColor} rounded-full flex items-center justify-center"
|
|
53
|
-
>
|
|
54
|
-
<span class="animate-spin">
|
|
55
|
-
<Icon name="Reload" size="20" />
|
|
56
|
-
</span>
|
|
57
|
-
</div>
|
|
58
|
-
<p class={`${typography.body} text-center font-medium`}>{processingMessage}</p>
|
|
59
|
-
</div>
|
|
60
|
-
{:else if isSuccess}
|
|
61
|
-
<div class="py-6 px-4 flex flex-col items-center justify-center gap-4">
|
|
62
|
-
<div class={successIconColor}>
|
|
63
|
-
<Icon name={successIcon} size="48" />
|
|
64
|
-
</div>
|
|
65
|
-
<h2 class={`${typography.h2} text-center`}>
|
|
66
|
-
{successTitle}
|
|
67
|
-
</h2>
|
|
68
|
-
{#if successMessage}
|
|
69
|
-
<p class={`${typography.smMuted} text-center`}>{successMessage}</p>
|
|
70
|
-
{/if}
|
|
71
|
-
<Button variant="default" size="full" onclick={onSuccessClose}>
|
|
72
|
-
{successButtonText}
|
|
73
|
-
</Button>
|
|
74
|
-
</div>
|
|
75
|
-
{:else}
|
|
76
|
-
{@render children?.()}
|
|
77
|
-
{/if}
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import type { Snippet } from 'svelte';
|
|
3
|
+
import Icon from "../../primitives/Icons/Icon.svelte";
|
|
4
|
+
import Button from "../../primitives/Button/Button.svelte";
|
|
5
|
+
import { typography } from '../../tokens/typography';
|
|
6
|
+
|
|
7
|
+
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";
|
|
8
|
+
|
|
9
|
+
interface Props {
|
|
10
|
+
/** Whether the modal is currently processing an action */
|
|
11
|
+
isProcessing?: boolean;
|
|
12
|
+
/** Whether the action completed successfully */
|
|
13
|
+
isSuccess?: boolean;
|
|
14
|
+
/** Icon to show on success (from Icon component) */
|
|
15
|
+
successIcon?: IconName;
|
|
16
|
+
/** Title to show on success */
|
|
17
|
+
successTitle?: string;
|
|
18
|
+
/** Optional message to show on success */
|
|
19
|
+
successMessage?: string;
|
|
20
|
+
/** Text to show while processing */
|
|
21
|
+
processingMessage?: string;
|
|
22
|
+
/** Button text for the success state */
|
|
23
|
+
successButtonText?: string;
|
|
24
|
+
/** Callback when success button is clicked */
|
|
25
|
+
onSuccessClose?: () => void;
|
|
26
|
+
/** Custom success icon color class */
|
|
27
|
+
successIconColor?: string;
|
|
28
|
+
/** Custom processing icon color class */
|
|
29
|
+
processingIconBgColor?: string;
|
|
30
|
+
/** Child content (normal state) */
|
|
31
|
+
children?: Snippet;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
let {
|
|
35
|
+
isProcessing = false,
|
|
36
|
+
isSuccess = false,
|
|
37
|
+
successIcon = "CheckCircle",
|
|
38
|
+
successTitle = "Success",
|
|
39
|
+
successMessage = "",
|
|
40
|
+
processingMessage = "Processing your request",
|
|
41
|
+
successButtonText = "Continue",
|
|
42
|
+
onSuccessClose = () => {},
|
|
43
|
+
successIconColor = "text-green-600",
|
|
44
|
+
processingIconBgColor = "bg-orange-300",
|
|
45
|
+
children
|
|
46
|
+
}: Props = $props();
|
|
47
|
+
</script>
|
|
48
|
+
|
|
49
|
+
{#if isProcessing && !isSuccess}
|
|
50
|
+
<div class="py-6 px-4 flex flex-col items-center justify-center gap-4">
|
|
51
|
+
<div
|
|
52
|
+
class="w-12 h-12 {processingIconBgColor} rounded-full flex items-center justify-center"
|
|
53
|
+
>
|
|
54
|
+
<span class="animate-spin">
|
|
55
|
+
<Icon name="Reload" size="20" />
|
|
56
|
+
</span>
|
|
57
|
+
</div>
|
|
58
|
+
<p class={`${typography.body} text-center font-medium`}>{processingMessage}</p>
|
|
59
|
+
</div>
|
|
60
|
+
{:else if isSuccess}
|
|
61
|
+
<div class="py-6 px-4 flex flex-col items-center justify-center gap-4">
|
|
62
|
+
<div class={successIconColor}>
|
|
63
|
+
<Icon name={successIcon} size="48" />
|
|
64
|
+
</div>
|
|
65
|
+
<h2 class={`${typography.h2} text-center`}>
|
|
66
|
+
{successTitle}
|
|
67
|
+
</h2>
|
|
68
|
+
{#if successMessage}
|
|
69
|
+
<p class={`${typography.smMuted} text-center`}>{successMessage}</p>
|
|
70
|
+
{/if}
|
|
71
|
+
<Button variant="default" size="full" onclick={onSuccessClose}>
|
|
72
|
+
{successButtonText}
|
|
73
|
+
</Button>
|
|
74
|
+
</div>
|
|
75
|
+
{:else}
|
|
76
|
+
{@render children?.()}
|
|
77
|
+
{/if}
|
|
@@ -1,65 +1,65 @@
|
|
|
1
|
-
<script lang="ts">
|
|
2
|
-
import type { Snippet } from 'svelte';
|
|
3
|
-
import Modal from "../../primitives/Modal/Modal.svelte";
|
|
4
|
-
import Button from "../../primitives/Button/Button.svelte";
|
|
5
|
-
|
|
6
|
-
interface Props {
|
|
7
|
-
/** Whether the modal is visible */
|
|
8
|
-
show?: boolean;
|
|
9
|
-
/** Modal title */
|
|
10
|
-
title?: string;
|
|
11
|
-
/** Modal description */
|
|
12
|
-
description?: string;
|
|
13
|
-
/** Warning text */
|
|
14
|
-
warningText?: string;
|
|
15
|
-
/** Callback when modal is cancelled */
|
|
16
|
-
oncancel?: () => void;
|
|
17
|
-
/** Header content */
|
|
18
|
-
header?: Snippet;
|
|
19
|
-
/** Body content */
|
|
20
|
-
body?: Snippet;
|
|
21
|
-
/** Footer content */
|
|
22
|
-
footer?: Snippet;
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
let {
|
|
26
|
-
show = $bindable(false),
|
|
27
|
-
title = '',
|
|
28
|
-
description = '',
|
|
29
|
-
warningText = '',
|
|
30
|
-
oncancel,
|
|
31
|
-
header,
|
|
32
|
-
body,
|
|
33
|
-
footer
|
|
34
|
-
}: Props = $props();
|
|
35
|
-
</script>
|
|
36
|
-
|
|
37
|
-
<Modal bind:show oncancel={oncancel}>
|
|
38
|
-
{#snippet headerSnippet()}
|
|
39
|
-
{#if header}
|
|
40
|
-
{@render header()}
|
|
41
|
-
{:else}
|
|
42
|
-
{title}
|
|
43
|
-
{/if}
|
|
44
|
-
{/snippet}
|
|
45
|
-
|
|
46
|
-
{#snippet bodySnippet()}
|
|
47
|
-
{#if body}
|
|
48
|
-
{@render body()}
|
|
49
|
-
{:else}
|
|
50
|
-
{description}
|
|
51
|
-
{#if warningText}
|
|
52
|
-
<br /> {warningText}
|
|
53
|
-
{/if}
|
|
54
|
-
{/if}
|
|
55
|
-
{/snippet}
|
|
56
|
-
|
|
57
|
-
{#snippet footerSnippet()}
|
|
58
|
-
{#if footer}
|
|
59
|
-
{@render footer()}
|
|
60
|
-
{:else}
|
|
61
|
-
<Button variant="alternative">Cancel</Button>
|
|
62
|
-
<Button variant="default">Confirm</Button>
|
|
63
|
-
{/if}
|
|
64
|
-
{/snippet}
|
|
65
|
-
</Modal>
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import type { Snippet } from 'svelte';
|
|
3
|
+
import Modal from "../../primitives/Modal/Modal.svelte";
|
|
4
|
+
import Button from "../../primitives/Button/Button.svelte";
|
|
5
|
+
|
|
6
|
+
interface Props {
|
|
7
|
+
/** Whether the modal is visible */
|
|
8
|
+
show?: boolean;
|
|
9
|
+
/** Modal title */
|
|
10
|
+
title?: string;
|
|
11
|
+
/** Modal description */
|
|
12
|
+
description?: string;
|
|
13
|
+
/** Warning text */
|
|
14
|
+
warningText?: string;
|
|
15
|
+
/** Callback when modal is cancelled */
|
|
16
|
+
oncancel?: () => void;
|
|
17
|
+
/** Header content */
|
|
18
|
+
header?: Snippet;
|
|
19
|
+
/** Body content */
|
|
20
|
+
body?: Snippet;
|
|
21
|
+
/** Footer content */
|
|
22
|
+
footer?: Snippet;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
let {
|
|
26
|
+
show = $bindable(false),
|
|
27
|
+
title = '',
|
|
28
|
+
description = '',
|
|
29
|
+
warningText = '',
|
|
30
|
+
oncancel,
|
|
31
|
+
header,
|
|
32
|
+
body,
|
|
33
|
+
footer
|
|
34
|
+
}: Props = $props();
|
|
35
|
+
</script>
|
|
36
|
+
|
|
37
|
+
<Modal bind:show oncancel={oncancel}>
|
|
38
|
+
{#snippet headerSnippet()}
|
|
39
|
+
{#if header}
|
|
40
|
+
{@render header()}
|
|
41
|
+
{:else}
|
|
42
|
+
{title}
|
|
43
|
+
{/if}
|
|
44
|
+
{/snippet}
|
|
45
|
+
|
|
46
|
+
{#snippet bodySnippet()}
|
|
47
|
+
{#if body}
|
|
48
|
+
{@render body()}
|
|
49
|
+
{:else}
|
|
50
|
+
{description}
|
|
51
|
+
{#if warningText}
|
|
52
|
+
<br /> {warningText}
|
|
53
|
+
{/if}
|
|
54
|
+
{/if}
|
|
55
|
+
{/snippet}
|
|
56
|
+
|
|
57
|
+
{#snippet footerSnippet()}
|
|
58
|
+
{#if footer}
|
|
59
|
+
{@render footer()}
|
|
60
|
+
{:else}
|
|
61
|
+
<Button variant="alternative">Cancel</Button>
|
|
62
|
+
<Button variant="default">Confirm</Button>
|
|
63
|
+
{/if}
|
|
64
|
+
{/snippet}
|
|
65
|
+
</Modal>
|