@getmicdrop/svelte-components 5.3.12 → 5.3.13
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 +145 -145
- package/dist/calendar/ShowCard/ShowCard.svelte +157 -157
- package/dist/calendar/ShowTimeCard/ShowTimeCard.svelte +61 -61
- package/dist/components/Layout/Grid.svelte +109 -109
- package/dist/components/Layout/Section.svelte +80 -80
- package/dist/components/Layout/Sidebar.svelte +108 -108
- package/dist/components/Layout/Stack.svelte +90 -90
- package/dist/constants/formOptions.js +26 -26
- package/dist/constants/validation.js +91 -91
- package/dist/constants/validation.spec.js +64 -64
- package/dist/datetime/__tests__/format.test.d.ts +2 -0
- package/dist/datetime/__tests__/format.test.d.ts.map +1 -0
- package/dist/datetime/__tests__/format.test.js +268 -0
- package/dist/datetime/__tests__/integration.test.d.ts +2 -0
- package/dist/datetime/__tests__/integration.test.d.ts.map +1 -0
- package/dist/datetime/__tests__/integration.test.js +243 -0
- package/dist/datetime/__tests__/parse.test.d.ts +2 -0
- package/dist/datetime/__tests__/parse.test.d.ts.map +1 -0
- package/dist/datetime/__tests__/parse.test.js +261 -0
- package/dist/datetime/__tests__/timezone.test.d.ts +2 -0
- package/dist/datetime/__tests__/timezone.test.d.ts.map +1 -0
- package/dist/datetime/__tests__/timezone.test.js +214 -0
- package/dist/datetime/constants.d.ts +133 -0
- package/dist/datetime/constants.d.ts.map +1 -0
- package/dist/datetime/constants.js +112 -0
- package/dist/datetime/format.d.ts +158 -0
- package/dist/datetime/format.d.ts.map +1 -0
- package/dist/datetime/format.js +315 -0
- package/dist/datetime/index.d.ts +42 -0
- package/dist/datetime/index.d.ts.map +1 -0
- package/dist/datetime/index.js +44 -0
- package/dist/datetime/parse.d.ts +149 -0
- package/dist/datetime/parse.d.ts.map +1 -0
- package/dist/datetime/parse.js +276 -0
- package/dist/datetime/timezone.d.ts +95 -0
- package/dist/datetime/timezone.d.ts.map +1 -0
- package/dist/datetime/timezone.js +241 -0
- package/dist/datetime/types.d.ts +105 -0
- package/dist/datetime/types.d.ts.map +1 -0
- package/dist/datetime/types.js +31 -0
- package/dist/index.d.ts +10 -0
- package/dist/index.js +232 -218
- package/dist/patterns/data/DataGrid.svelte +45 -45
- package/dist/patterns/data/DataList.svelte +24 -24
- package/dist/patterns/data/DataTable.svelte +40 -40
- package/dist/patterns/forms/FormActions.spec.js +88 -88
- 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.spec.js +203 -203
- package/dist/patterns/forms/FormValidationSummary.stories.svelte +97 -97
- package/dist/patterns/forms/FormValidationSummary.svelte +67 -67
- package/dist/patterns/layout/Grid.svelte +35 -35
- package/dist/patterns/layout/Sidebar.svelte +39 -39
- package/dist/patterns/layout/Stack.svelte +45 -45
- package/dist/patterns/navigation/BottomNav.spec.js +130 -130
- package/dist/patterns/navigation/BottomNav.stories.svelte +117 -117
- package/dist/patterns/navigation/BottomNav.svelte +54 -54
- package/dist/patterns/navigation/Header.spec.js +203 -203
- package/dist/patterns/navigation/Header.stories.svelte +77 -77
- package/dist/patterns/navigation/Header.svelte +240 -240
- package/dist/patterns/page/PageHeader.svelte +36 -36
- package/dist/patterns/page/PageLayout.svelte +40 -40
- package/dist/patterns/page/PageLoader.spec.js +54 -54
- package/dist/patterns/page/PageLoader.stories.svelte +137 -137
- package/dist/patterns/page/PageLoader.svelte +41 -41
- package/dist/patterns/page/SectionHeader.svelte +41 -41
- 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 +61 -61
- package/dist/primitives/Accordion/AccordionItem.svelte +95 -95
- package/dist/primitives/Alert/Alert.spec.js +170 -170
- package/dist/primitives/Alert/Alert.stories.svelte +88 -88
- package/dist/primitives/Alert/Alert.svelte +65 -65
- package/dist/primitives/Avatar/Avatar.stories.svelte +94 -94
- package/dist/primitives/Avatar/Avatar.svelte +66 -66
- package/dist/primitives/Badges/Badge.spec.js +103 -103
- package/dist/primitives/Badges/Badge.stories.svelte +86 -86
- package/dist/primitives/Badges/Badge.svelte +142 -142
- package/dist/primitives/BottomSheet/BottomSheet.spec.js +127 -127
- package/dist/primitives/BottomSheet/BottomSheet.stories.svelte +83 -83
- package/dist/primitives/BottomSheet/BottomSheet.svelte +100 -100
- package/dist/primitives/Breadcrumb/Breadcrumb.spec.js +120 -120
- package/dist/primitives/Breadcrumb/Breadcrumb.stories.svelte +23 -23
- package/dist/primitives/Breadcrumb/Breadcrumb.svelte +89 -89
- package/dist/primitives/Button/Button.spec.js +211 -211
- package/dist/primitives/Button/Button.stories.svelte +76 -76
- package/dist/primitives/Button/Button.svelte +301 -301
- package/dist/primitives/Button/ButtonSaveDemo.spec.js +48 -48
- 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 +357 -357
- package/dist/primitives/DarkModeToggle.stories.svelte +57 -57
- package/dist/primitives/DarkModeToggle.svelte +136 -136
- package/dist/primitives/Drawer/Drawer.stories.svelte +100 -100
- package/dist/primitives/Drawer/Drawer.svelte +214 -214
- package/dist/primitives/Dropdown/Dropdown.stories.svelte +137 -137
- package/dist/primitives/Dropdown/Dropdown.svelte +148 -148
- package/dist/primitives/Dropdown/DropdownItem.svelte +80 -80
- package/dist/primitives/Icons/ArrowLeft.svelte +20 -20
- package/dist/primitives/Icons/ArrowRight.svelte +20 -20
- package/dist/primitives/Icons/Availability.svelte +26 -26
- package/dist/primitives/Icons/Back.svelte +26 -26
- package/dist/primitives/Icons/CheckCircle.svelte +18 -18
- package/dist/primitives/Icons/CheckCircleOutline.svelte +27 -27
- package/dist/primitives/Icons/ChevronLeft.svelte +16 -16
- package/dist/primitives/Icons/ChevronRight.svelte +16 -16
- package/dist/primitives/Icons/Copy.svelte +27 -27
- package/dist/primitives/Icons/Cross.svelte +17 -17
- package/dist/primitives/Icons/DownArrow.svelte +20 -20
- package/dist/primitives/Icons/ErrorCircle.svelte +18 -18
- package/dist/primitives/Icons/FacebookIcon.svelte +13 -13
- package/dist/primitives/Icons/Home.svelte +27 -27
- package/dist/primitives/Icons/Icon.spec.js +175 -175
- package/dist/primitives/Icons/Icon.stories.svelte +100 -100
- package/dist/primitives/Icons/Icon.svelte +63 -63
- package/dist/primitives/Icons/IconGallery.stories.svelte +235 -235
- package/dist/primitives/Icons/ImageOutline.svelte +19 -19
- package/dist/primitives/Icons/Info.svelte +19 -19
- package/dist/primitives/Icons/InstagramIcon.svelte +19 -19
- package/dist/primitives/Icons/LogoInstagram.svelte +15 -15
- package/dist/primitives/Icons/Message.svelte +27 -27
- package/dist/primitives/Icons/MoonIcon.svelte +16 -16
- package/dist/primitives/Icons/More.svelte +33 -33
- package/dist/primitives/Icons/MoreHori.spec.js +67 -67
- package/dist/primitives/Icons/MoreHori.svelte +34 -34
- package/dist/primitives/Icons/Notification.svelte +26 -26
- package/dist/primitives/Icons/Payment.svelte +26 -26
- package/dist/primitives/Icons/Profile.svelte +33 -33
- package/dist/primitives/Icons/Reload.svelte +41 -41
- package/dist/primitives/Icons/Shows.svelte +33 -33
- package/dist/primitives/Icons/Signout.svelte +33 -33
- package/dist/primitives/Icons/SunIcon.svelte +19 -19
- package/dist/primitives/Icons/TiktokIcon.svelte +13 -13
- package/dist/primitives/Icons/TrashBinOutline.svelte +19 -19
- package/dist/primitives/Icons/TwitterIcon.svelte +13 -13
- package/dist/primitives/Icons/WarningIcon.spec.js +30 -30
- package/dist/primitives/Icons/WarningIcon.svelte +24 -24
- package/dist/primitives/Input/Input.spec.js +573 -573
- package/dist/primitives/Input/Input.stories.svelte +139 -139
- package/dist/primitives/Input/Input.svelte +444 -444
- package/dist/primitives/Input/Select.spec.js +218 -218
- package/dist/primitives/Input/Select.stories.svelte +112 -112
- package/dist/primitives/Input/Select.svelte +232 -232
- package/dist/primitives/Input/Textarea.stories.svelte +137 -137
- package/dist/primitives/Input/Textarea.svelte +79 -79
- package/dist/primitives/Label/Label.svelte +37 -37
- package/dist/primitives/Modal/Modal.spec.js +95 -95
- package/dist/primitives/Modal/Modal.stories.svelte +86 -86
- package/dist/primitives/Modal/Modal.svelte +158 -158
- 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 +52 -52
- package/dist/primitives/Spinner/Spinner.spec.js +75 -75
- package/dist/primitives/Spinner/Spinner.stories.svelte +29 -29
- package/dist/primitives/Spinner/Spinner.svelte +57 -57
- package/dist/primitives/Tabs/TabItem.svelte +51 -51
- package/dist/primitives/Tabs/Tabs.stories.svelte +112 -112
- package/dist/primitives/Tabs/Tabs.svelte +128 -128
- package/dist/primitives/Toggle.spec.js +127 -127
- 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 +111 -111
- package/dist/primitives/ValidationError.svelte +29 -29
- package/dist/recipes/CropImage/CropImage.spec.js +216 -216
- 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 +980 -980
- package/dist/recipes/Toaster/Toaster.stories.svelte +62 -62
- package/dist/recipes/feedback/EmptyState/EmptyState.svelte +47 -47
- package/dist/recipes/feedback/ErrorDisplay.spec.js +69 -69
- package/dist/recipes/feedback/ErrorDisplay.stories.svelte +112 -112
- package/dist/recipes/feedback/ErrorDisplay.svelte +38 -38
- package/dist/recipes/feedback/StatusIndicator/StatusIndicator.spec.js +129 -129
- package/dist/recipes/feedback/StatusIndicator/StatusIndicator.svelte +167 -167
- package/dist/recipes/fields/CheckboxField.svelte +85 -85
- package/dist/recipes/fields/FormField.svelte +58 -58
- package/dist/recipes/fields/RadioGroup.svelte +95 -95
- package/dist/recipes/fields/SelectField.svelte +82 -82
- package/dist/recipes/fields/TextareaField.svelte +101 -101
- package/dist/recipes/fields/ToggleField.svelte +60 -60
- package/dist/recipes/fields/index.js +7 -7
- package/dist/recipes/inputs/MultiSelect.spec.js +257 -257
- package/dist/recipes/inputs/MultiSelect.stories.svelte +133 -133
- package/dist/recipes/inputs/MultiSelect.svelte +244 -244
- package/dist/recipes/inputs/OTPInput.spec.js +238 -238
- package/dist/recipes/inputs/OTPInput.stories.svelte +162 -162
- package/dist/recipes/inputs/OTPInput.svelte +102 -102
- package/dist/recipes/inputs/PasswordInput.svelte +100 -100
- package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.spec.js +173 -173
- package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.svelte +108 -108
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.spec.js +300 -300
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.stories.svelte +165 -165
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte +337 -337
- package/dist/recipes/inputs/Search.svelte +85 -85
- package/dist/recipes/inputs/SelectDropdown.svelte +161 -161
- package/dist/recipes/modals/AlertModal.svelte +130 -130
- package/dist/recipes/modals/ConfirmationModal.spec.js +191 -191
- 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 +342 -342
- package/dist/stores/auth.js +93 -6
- package/dist/stores/auth.spec.js +310 -2
- 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 +388 -388
- package/dist/stories/PrimitivesGallery.stories.svelte +19 -19
- package/dist/stories/PrimitivesGallery.svelte +752 -752
- package/dist/stories/RecipesGallery.stories.svelte +19 -19
- package/dist/stories/RecipesGallery.svelte +441 -441
- package/dist/stories/button-audit-manifest.json +11186 -11186
- package/dist/tailwind/preset.cjs +82 -82
- package/dist/telemetry.js +357 -357
- package/dist/tokens/tokens.css +87 -87
- package/dist/utils/apiConfig.js +49 -49
- package/dist/utils/utils.js +9 -1
- package/package.json +233 -191
|
@@ -1,108 +1,108 @@
|
|
|
1
|
-
<script lang="ts">
|
|
2
|
-
import type { Snippet } from 'svelte';
|
|
3
|
-
|
|
4
|
-
/**
|
|
5
|
-
* Sidebar - Main content with sidebar layout
|
|
6
|
-
*
|
|
7
|
-
* Use Sidebar for pages that have a main content area plus a sidebar.
|
|
8
|
-
* Common patterns: dashboard stats on right, filters on left, etc.
|
|
9
|
-
*
|
|
10
|
-
* @example
|
|
11
|
-
* <Sidebar sidebar={sidebarContent}>
|
|
12
|
-
* <div>Main content here</div>
|
|
13
|
-
* </Sidebar>
|
|
14
|
-
*
|
|
15
|
-
* {#snippet sidebarContent()}
|
|
16
|
-
* <StatsCard />
|
|
17
|
-
* {/snippet}
|
|
18
|
-
*
|
|
19
|
-
* @example
|
|
20
|
-
* <Sidebar sidebarPosition="left" sidebarWidth="narrow" sidebar={filters}>
|
|
21
|
-
* <Table />
|
|
22
|
-
* </Sidebar>
|
|
23
|
-
*/
|
|
24
|
-
|
|
25
|
-
interface Props {
|
|
26
|
-
/**
|
|
27
|
-
* Sidebar width preset
|
|
28
|
-
* - narrow: ~25% (col-span-3 of 12)
|
|
29
|
-
* - medium: ~30% (col-span-4 of 12)
|
|
30
|
-
* - wide: ~40% (col-span-5 of 12)
|
|
31
|
-
*/
|
|
32
|
-
sidebarWidth?: 'narrow' | 'medium' | 'wide';
|
|
33
|
-
/** Sidebar position */
|
|
34
|
-
sidebarPosition?: 'left' | 'right';
|
|
35
|
-
/** Gap between main and sidebar */
|
|
36
|
-
gap?: '4' | '6' | '8';
|
|
37
|
-
/** Stack vertically on mobile */
|
|
38
|
-
stackOnMobile?: boolean;
|
|
39
|
-
/** Additional CSS classes */
|
|
40
|
-
class?: string;
|
|
41
|
-
/** Main content */
|
|
42
|
-
children?: Snippet;
|
|
43
|
-
/** Sidebar content (named snippet) */
|
|
44
|
-
sidebar?: Snippet;
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
let {
|
|
48
|
-
sidebarWidth = 'medium',
|
|
49
|
-
sidebarPosition = 'right',
|
|
50
|
-
gap = '6',
|
|
51
|
-
stackOnMobile = true,
|
|
52
|
-
class: className = '',
|
|
53
|
-
children,
|
|
54
|
-
sidebar
|
|
55
|
-
}: Props = $props();
|
|
56
|
-
|
|
57
|
-
const gapMap: Record<string, string> = {
|
|
58
|
-
'4': 'gap-4',
|
|
59
|
-
'6': 'gap-6',
|
|
60
|
-
'8': 'gap-8'
|
|
61
|
-
};
|
|
62
|
-
|
|
63
|
-
// Using 12-column grid for flexibility
|
|
64
|
-
// Main content gets remaining columns
|
|
65
|
-
const sidebarWidthMap: Record<string, { sidebar: string; main: string }> = {
|
|
66
|
-
narrow: { sidebar: 'lg:col-span-3', main: 'lg:col-span-9' },
|
|
67
|
-
medium: { sidebar: 'lg:col-span-4', main: 'lg:col-span-8' },
|
|
68
|
-
wide: { sidebar: 'lg:col-span-5', main: 'lg:col-span-7' }
|
|
69
|
-
};
|
|
70
|
-
|
|
71
|
-
let widthConfig = $derived(sidebarWidthMap[sidebarWidth] || sidebarWidthMap.medium);
|
|
72
|
-
|
|
73
|
-
let containerClasses = $derived(
|
|
74
|
-
[
|
|
75
|
-
'grid',
|
|
76
|
-
stackOnMobile ? 'grid-cols-1' : '',
|
|
77
|
-
'lg:grid-cols-12',
|
|
78
|
-
gapMap[gap] || 'gap-6',
|
|
79
|
-
className
|
|
80
|
-
].filter(Boolean).join(' ')
|
|
81
|
-
);
|
|
82
|
-
|
|
83
|
-
let mainClasses = $derived(
|
|
84
|
-
[
|
|
85
|
-
'col-span-1',
|
|
86
|
-
widthConfig.main,
|
|
87
|
-
sidebarPosition === 'left' ? 'lg:order-2' : 'lg:order-1'
|
|
88
|
-
].filter(Boolean).join(' ')
|
|
89
|
-
);
|
|
90
|
-
|
|
91
|
-
let sidebarClasses = $derived(
|
|
92
|
-
[
|
|
93
|
-
'col-span-1',
|
|
94
|
-
widthConfig.sidebar,
|
|
95
|
-
sidebarPosition === 'left' ? 'lg:order-1' : 'lg:order-2'
|
|
96
|
-
].filter(Boolean).join(' ')
|
|
97
|
-
);
|
|
98
|
-
</script>
|
|
99
|
-
|
|
100
|
-
<div class={containerClasses}>
|
|
101
|
-
<div class={mainClasses}>
|
|
102
|
-
{@render children?.()}
|
|
103
|
-
</div>
|
|
104
|
-
|
|
105
|
-
<aside class={sidebarClasses}>
|
|
106
|
-
{@render sidebar?.()}
|
|
107
|
-
</aside>
|
|
108
|
-
</div>
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import type { Snippet } from 'svelte';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Sidebar - Main content with sidebar layout
|
|
6
|
+
*
|
|
7
|
+
* Use Sidebar for pages that have a main content area plus a sidebar.
|
|
8
|
+
* Common patterns: dashboard stats on right, filters on left, etc.
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* <Sidebar sidebar={sidebarContent}>
|
|
12
|
+
* <div>Main content here</div>
|
|
13
|
+
* </Sidebar>
|
|
14
|
+
*
|
|
15
|
+
* {#snippet sidebarContent()}
|
|
16
|
+
* <StatsCard />
|
|
17
|
+
* {/snippet}
|
|
18
|
+
*
|
|
19
|
+
* @example
|
|
20
|
+
* <Sidebar sidebarPosition="left" sidebarWidth="narrow" sidebar={filters}>
|
|
21
|
+
* <Table />
|
|
22
|
+
* </Sidebar>
|
|
23
|
+
*/
|
|
24
|
+
|
|
25
|
+
interface Props {
|
|
26
|
+
/**
|
|
27
|
+
* Sidebar width preset
|
|
28
|
+
* - narrow: ~25% (col-span-3 of 12)
|
|
29
|
+
* - medium: ~30% (col-span-4 of 12)
|
|
30
|
+
* - wide: ~40% (col-span-5 of 12)
|
|
31
|
+
*/
|
|
32
|
+
sidebarWidth?: 'narrow' | 'medium' | 'wide';
|
|
33
|
+
/** Sidebar position */
|
|
34
|
+
sidebarPosition?: 'left' | 'right';
|
|
35
|
+
/** Gap between main and sidebar */
|
|
36
|
+
gap?: '4' | '6' | '8';
|
|
37
|
+
/** Stack vertically on mobile */
|
|
38
|
+
stackOnMobile?: boolean;
|
|
39
|
+
/** Additional CSS classes */
|
|
40
|
+
class?: string;
|
|
41
|
+
/** Main content */
|
|
42
|
+
children?: Snippet;
|
|
43
|
+
/** Sidebar content (named snippet) */
|
|
44
|
+
sidebar?: Snippet;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
let {
|
|
48
|
+
sidebarWidth = 'medium',
|
|
49
|
+
sidebarPosition = 'right',
|
|
50
|
+
gap = '6',
|
|
51
|
+
stackOnMobile = true,
|
|
52
|
+
class: className = '',
|
|
53
|
+
children,
|
|
54
|
+
sidebar
|
|
55
|
+
}: Props = $props();
|
|
56
|
+
|
|
57
|
+
const gapMap: Record<string, string> = {
|
|
58
|
+
'4': 'gap-4',
|
|
59
|
+
'6': 'gap-6',
|
|
60
|
+
'8': 'gap-8'
|
|
61
|
+
};
|
|
62
|
+
|
|
63
|
+
// Using 12-column grid for flexibility
|
|
64
|
+
// Main content gets remaining columns
|
|
65
|
+
const sidebarWidthMap: Record<string, { sidebar: string; main: string }> = {
|
|
66
|
+
narrow: { sidebar: 'lg:col-span-3', main: 'lg:col-span-9' },
|
|
67
|
+
medium: { sidebar: 'lg:col-span-4', main: 'lg:col-span-8' },
|
|
68
|
+
wide: { sidebar: 'lg:col-span-5', main: 'lg:col-span-7' }
|
|
69
|
+
};
|
|
70
|
+
|
|
71
|
+
let widthConfig = $derived(sidebarWidthMap[sidebarWidth] || sidebarWidthMap.medium);
|
|
72
|
+
|
|
73
|
+
let containerClasses = $derived(
|
|
74
|
+
[
|
|
75
|
+
'grid',
|
|
76
|
+
stackOnMobile ? 'grid-cols-1' : '',
|
|
77
|
+
'lg:grid-cols-12',
|
|
78
|
+
gapMap[gap] || 'gap-6',
|
|
79
|
+
className
|
|
80
|
+
].filter(Boolean).join(' ')
|
|
81
|
+
);
|
|
82
|
+
|
|
83
|
+
let mainClasses = $derived(
|
|
84
|
+
[
|
|
85
|
+
'col-span-1',
|
|
86
|
+
widthConfig.main,
|
|
87
|
+
sidebarPosition === 'left' ? 'lg:order-2' : 'lg:order-1'
|
|
88
|
+
].filter(Boolean).join(' ')
|
|
89
|
+
);
|
|
90
|
+
|
|
91
|
+
let sidebarClasses = $derived(
|
|
92
|
+
[
|
|
93
|
+
'col-span-1',
|
|
94
|
+
widthConfig.sidebar,
|
|
95
|
+
sidebarPosition === 'left' ? 'lg:order-1' : 'lg:order-2'
|
|
96
|
+
].filter(Boolean).join(' ')
|
|
97
|
+
);
|
|
98
|
+
</script>
|
|
99
|
+
|
|
100
|
+
<div class={containerClasses}>
|
|
101
|
+
<div class={mainClasses}>
|
|
102
|
+
{@render children?.()}
|
|
103
|
+
</div>
|
|
104
|
+
|
|
105
|
+
<aside class={sidebarClasses}>
|
|
106
|
+
{@render sidebar?.()}
|
|
107
|
+
</aside>
|
|
108
|
+
</div>
|
|
@@ -1,90 +1,90 @@
|
|
|
1
|
-
<script lang="ts">
|
|
2
|
-
import type { Snippet } from 'svelte';
|
|
3
|
-
|
|
4
|
-
type GapValue = 'tight' | 'compact' | 'item' | 'group' | 'content' | 'section' | 'layout' | 'page' | '0' | '1' | '1.5' | '2' | '3' | '4' | '6' | '8' | '12' | '16';
|
|
5
|
-
type Direction = 'vertical' | 'horizontal';
|
|
6
|
-
type Align = 'start' | 'center' | 'end' | 'stretch' | 'baseline';
|
|
7
|
-
type Justify = 'start' | 'center' | 'end' | 'between' | 'around' | 'evenly';
|
|
8
|
-
type ElementType = 'div' | 'section' | 'article' | 'aside' | 'main' | 'nav' | 'ul' | 'ol';
|
|
9
|
-
|
|
10
|
-
interface Props {
|
|
11
|
-
gap?: GapValue;
|
|
12
|
-
direction?: Direction;
|
|
13
|
-
align?: Align;
|
|
14
|
-
justify?: Justify;
|
|
15
|
-
wrap?: boolean;
|
|
16
|
-
as?: ElementType;
|
|
17
|
-
class?: string;
|
|
18
|
-
children?: Snippet;
|
|
19
|
-
[key: string]: unknown;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
let {
|
|
23
|
-
gap = '4',
|
|
24
|
-
direction = 'vertical',
|
|
25
|
-
align,
|
|
26
|
-
justify,
|
|
27
|
-
wrap = false,
|
|
28
|
-
as = 'div',
|
|
29
|
-
class: className = '',
|
|
30
|
-
children,
|
|
31
|
-
...restProps
|
|
32
|
-
}: Props = $props();
|
|
33
|
-
|
|
34
|
-
const semanticGapMap: Record<string, string> = {
|
|
35
|
-
'tight': 'gap-1',
|
|
36
|
-
'compact': 'gap-1.5',
|
|
37
|
-
'item': 'gap-2',
|
|
38
|
-
'group': 'gap-3',
|
|
39
|
-
'content': 'gap-4',
|
|
40
|
-
'section': 'gap-6',
|
|
41
|
-
'layout': 'gap-8',
|
|
42
|
-
'page': 'gap-12',
|
|
43
|
-
};
|
|
44
|
-
|
|
45
|
-
const numericGapMap: Record<string, string> = {
|
|
46
|
-
'0': 'gap-0',
|
|
47
|
-
'1': 'gap-1',
|
|
48
|
-
'1.5': 'gap-1.5',
|
|
49
|
-
'2': 'gap-2',
|
|
50
|
-
'3': 'gap-3',
|
|
51
|
-
'4': 'gap-4',
|
|
52
|
-
'6': 'gap-6',
|
|
53
|
-
'8': 'gap-8',
|
|
54
|
-
'12': 'gap-12',
|
|
55
|
-
'16': 'gap-16'
|
|
56
|
-
};
|
|
57
|
-
|
|
58
|
-
const gapMap = { ...numericGapMap, ...semanticGapMap };
|
|
59
|
-
|
|
60
|
-
const alignMap: Record<string, string> = {
|
|
61
|
-
start: 'items-start',
|
|
62
|
-
center: 'items-center',
|
|
63
|
-
end: 'items-end',
|
|
64
|
-
stretch: 'items-stretch',
|
|
65
|
-
baseline: 'items-baseline'
|
|
66
|
-
};
|
|
67
|
-
|
|
68
|
-
const justifyMap: Record<string, string> = {
|
|
69
|
-
start: 'justify-start',
|
|
70
|
-
center: 'justify-center',
|
|
71
|
-
end: 'justify-end',
|
|
72
|
-
between: 'justify-between',
|
|
73
|
-
around: 'justify-around',
|
|
74
|
-
evenly: 'justify-evenly'
|
|
75
|
-
};
|
|
76
|
-
|
|
77
|
-
let classes = $derived([
|
|
78
|
-
'flex',
|
|
79
|
-
direction === 'vertical' ? 'flex-col' : 'flex-row',
|
|
80
|
-
gapMap[gap] || 'gap-4',
|
|
81
|
-
align ? alignMap[align] : '',
|
|
82
|
-
justify ? justifyMap[justify] : '',
|
|
83
|
-
wrap ? 'flex-wrap' : '',
|
|
84
|
-
className
|
|
85
|
-
].filter(Boolean).join(' '));
|
|
86
|
-
</script>
|
|
87
|
-
|
|
88
|
-
<svelte:element this={as} class={classes} {...restProps}>
|
|
89
|
-
{#if children}{@render children()}{/if}
|
|
90
|
-
</svelte:element>
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import type { Snippet } from 'svelte';
|
|
3
|
+
|
|
4
|
+
type GapValue = 'tight' | 'compact' | 'item' | 'group' | 'content' | 'section' | 'layout' | 'page' | '0' | '1' | '1.5' | '2' | '3' | '4' | '6' | '8' | '12' | '16';
|
|
5
|
+
type Direction = 'vertical' | 'horizontal';
|
|
6
|
+
type Align = 'start' | 'center' | 'end' | 'stretch' | 'baseline';
|
|
7
|
+
type Justify = 'start' | 'center' | 'end' | 'between' | 'around' | 'evenly';
|
|
8
|
+
type ElementType = 'div' | 'section' | 'article' | 'aside' | 'main' | 'nav' | 'ul' | 'ol';
|
|
9
|
+
|
|
10
|
+
interface Props {
|
|
11
|
+
gap?: GapValue;
|
|
12
|
+
direction?: Direction;
|
|
13
|
+
align?: Align;
|
|
14
|
+
justify?: Justify;
|
|
15
|
+
wrap?: boolean;
|
|
16
|
+
as?: ElementType;
|
|
17
|
+
class?: string;
|
|
18
|
+
children?: Snippet;
|
|
19
|
+
[key: string]: unknown;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
let {
|
|
23
|
+
gap = '4',
|
|
24
|
+
direction = 'vertical',
|
|
25
|
+
align,
|
|
26
|
+
justify,
|
|
27
|
+
wrap = false,
|
|
28
|
+
as = 'div',
|
|
29
|
+
class: className = '',
|
|
30
|
+
children,
|
|
31
|
+
...restProps
|
|
32
|
+
}: Props = $props();
|
|
33
|
+
|
|
34
|
+
const semanticGapMap: Record<string, string> = {
|
|
35
|
+
'tight': 'gap-1',
|
|
36
|
+
'compact': 'gap-1.5',
|
|
37
|
+
'item': 'gap-2',
|
|
38
|
+
'group': 'gap-3',
|
|
39
|
+
'content': 'gap-4',
|
|
40
|
+
'section': 'gap-6',
|
|
41
|
+
'layout': 'gap-8',
|
|
42
|
+
'page': 'gap-12',
|
|
43
|
+
};
|
|
44
|
+
|
|
45
|
+
const numericGapMap: Record<string, string> = {
|
|
46
|
+
'0': 'gap-0',
|
|
47
|
+
'1': 'gap-1',
|
|
48
|
+
'1.5': 'gap-1.5',
|
|
49
|
+
'2': 'gap-2',
|
|
50
|
+
'3': 'gap-3',
|
|
51
|
+
'4': 'gap-4',
|
|
52
|
+
'6': 'gap-6',
|
|
53
|
+
'8': 'gap-8',
|
|
54
|
+
'12': 'gap-12',
|
|
55
|
+
'16': 'gap-16'
|
|
56
|
+
};
|
|
57
|
+
|
|
58
|
+
const gapMap = { ...numericGapMap, ...semanticGapMap };
|
|
59
|
+
|
|
60
|
+
const alignMap: Record<string, string> = {
|
|
61
|
+
start: 'items-start',
|
|
62
|
+
center: 'items-center',
|
|
63
|
+
end: 'items-end',
|
|
64
|
+
stretch: 'items-stretch',
|
|
65
|
+
baseline: 'items-baseline'
|
|
66
|
+
};
|
|
67
|
+
|
|
68
|
+
const justifyMap: Record<string, string> = {
|
|
69
|
+
start: 'justify-start',
|
|
70
|
+
center: 'justify-center',
|
|
71
|
+
end: 'justify-end',
|
|
72
|
+
between: 'justify-between',
|
|
73
|
+
around: 'justify-around',
|
|
74
|
+
evenly: 'justify-evenly'
|
|
75
|
+
};
|
|
76
|
+
|
|
77
|
+
let classes = $derived([
|
|
78
|
+
'flex',
|
|
79
|
+
direction === 'vertical' ? 'flex-col' : 'flex-row',
|
|
80
|
+
gapMap[gap] || 'gap-4',
|
|
81
|
+
align ? alignMap[align] : '',
|
|
82
|
+
justify ? justifyMap[justify] : '',
|
|
83
|
+
wrap ? 'flex-wrap' : '',
|
|
84
|
+
className
|
|
85
|
+
].filter(Boolean).join(' '));
|
|
86
|
+
</script>
|
|
87
|
+
|
|
88
|
+
<svelte:element this={as} class={classes} {...restProps}>
|
|
89
|
+
{#if children}{@render children()}{/if}
|
|
90
|
+
</svelte:element>
|
|
@@ -1,26 +1,26 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Form options for dropdowns used across the performers portal.
|
|
3
|
-
* Use these with Select and MultiSelect components instead of
|
|
4
|
-
* creating wrapper components like GenderInput or EthnicityDropdown.
|
|
5
|
-
*
|
|
6
|
-
* Example:
|
|
7
|
-
* import { GENDER_OPTIONS } from './formOptions';
|
|
8
|
-
* <Select items={GENDER_OPTIONS} label="Gender" />
|
|
9
|
-
*/
|
|
10
|
-
|
|
11
|
-
export const GENDER_OPTIONS = [
|
|
12
|
-
{ name: "Male", value: 1 },
|
|
13
|
-
{ name: "Female", value: 2 },
|
|
14
|
-
{ name: "Non-binary", value: 3 },
|
|
15
|
-
{ name: "Rather not say", value: null },
|
|
16
|
-
];
|
|
17
|
-
|
|
18
|
-
export const ETHNICITY_OPTIONS = [
|
|
19
|
-
{ name: "American Indian or Alaska Native", value: 0 },
|
|
20
|
-
{ name: "Asian", value: 1 },
|
|
21
|
-
{ name: "Black or African American", value: 2 },
|
|
22
|
-
{ name: "Hispanic or Latino", value: 3 },
|
|
23
|
-
{ name: "Middle Eastern or North African", value: 4 },
|
|
24
|
-
{ name: "Native Hawaiian or Pacific Islander", value: 5 },
|
|
25
|
-
{ name: "White", value: 6 },
|
|
26
|
-
];
|
|
1
|
+
/**
|
|
2
|
+
* Form options for dropdowns used across the performers portal.
|
|
3
|
+
* Use these with Select and MultiSelect components instead of
|
|
4
|
+
* creating wrapper components like GenderInput or EthnicityDropdown.
|
|
5
|
+
*
|
|
6
|
+
* Example:
|
|
7
|
+
* import { GENDER_OPTIONS } from './formOptions';
|
|
8
|
+
* <Select items={GENDER_OPTIONS} label="Gender" />
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
export const GENDER_OPTIONS = [
|
|
12
|
+
{ name: "Male", value: 1 },
|
|
13
|
+
{ name: "Female", value: 2 },
|
|
14
|
+
{ name: "Non-binary", value: 3 },
|
|
15
|
+
{ name: "Rather not say", value: null },
|
|
16
|
+
];
|
|
17
|
+
|
|
18
|
+
export const ETHNICITY_OPTIONS = [
|
|
19
|
+
{ name: "American Indian or Alaska Native", value: 0 },
|
|
20
|
+
{ name: "Asian", value: 1 },
|
|
21
|
+
{ name: "Black or African American", value: 2 },
|
|
22
|
+
{ name: "Hispanic or Latino", value: 3 },
|
|
23
|
+
{ name: "Middle Eastern or North African", value: 4 },
|
|
24
|
+
{ name: "Native Hawaiian or Pacific Islander", value: 5 },
|
|
25
|
+
{ name: "White", value: 6 },
|
|
26
|
+
];
|
|
@@ -1,91 +1,91 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Validation Constants
|
|
3
|
-
*
|
|
4
|
-
* Shared validation rules and defaults for event, ticket, and promo code validation.
|
|
5
|
-
* Used by micdrop-frontend, venue-calendar-npm, and other apps.
|
|
6
|
-
*
|
|
7
|
-
* @example
|
|
8
|
-
* import { MIN_EVENT_DURATION_MINS, DEFAULT_EVENT_DURATION_MINS } from '@getmicdrop/svelte-components';
|
|
9
|
-
*/
|
|
10
|
-
|
|
11
|
-
// ============================================================================
|
|
12
|
-
// Event Time Constants
|
|
13
|
-
// ============================================================================
|
|
14
|
-
|
|
15
|
-
/** Minimum event duration in minutes (validation constraint) */
|
|
16
|
-
export const MIN_EVENT_DURATION_MINS = 15;
|
|
17
|
-
|
|
18
|
-
/** Maximum event duration in minutes (24 hours) */
|
|
19
|
-
export const MAX_EVENT_DURATION_MINS = 1440;
|
|
20
|
-
|
|
21
|
-
/** Default event duration in minutes (used when auto-filling end time) */
|
|
22
|
-
export const DEFAULT_EVENT_DURATION_MINS = 90;
|
|
23
|
-
|
|
24
|
-
/** Default time doors open before event start in minutes (used when auto-filling) */
|
|
25
|
-
export const DEFAULT_DOORS_BEFORE_START_MINS = 30;
|
|
26
|
-
|
|
27
|
-
// ============================================================================
|
|
28
|
-
// Ticket Constants
|
|
29
|
-
// ============================================================================
|
|
30
|
-
|
|
31
|
-
/** Maximum tickets per order limit */
|
|
32
|
-
export const MAX_TICKETS_PER_ORDER = 100;
|
|
33
|
-
|
|
34
|
-
/** Minimum tickets per order limit */
|
|
35
|
-
export const MIN_TICKETS_PER_ORDER = 0;
|
|
36
|
-
|
|
37
|
-
// ============================================================================
|
|
38
|
-
// Promo Code Constants
|
|
39
|
-
// ============================================================================
|
|
40
|
-
|
|
41
|
-
/** Maximum percentage discount */
|
|
42
|
-
export const MAX_PERCENTAGE_DISCOUNT = 100;
|
|
43
|
-
|
|
44
|
-
// ============================================================================
|
|
45
|
-
// Error Codes
|
|
46
|
-
// ============================================================================
|
|
47
|
-
|
|
48
|
-
export const ErrorCodes = {
|
|
49
|
-
// Event errors
|
|
50
|
-
EVENT_DURATION_TOO_SHORT: 'EVENT_DURATION_TOO_SHORT',
|
|
51
|
-
EVENT_DURATION_TOO_LONG: 'EVENT_DURATION_TOO_LONG',
|
|
52
|
-
EVENT_END_BEFORE_START: 'EVENT_END_BEFORE_START',
|
|
53
|
-
EVENT_DOORS_SAME_AS_START: 'EVENT_DOORS_SAME_AS_START',
|
|
54
|
-
EVENT_DOORS_TOO_CLOSE: 'EVENT_DOORS_TOO_CLOSE',
|
|
55
|
-
EVENT_INVALID_TIME_FORMAT: 'EVENT_INVALID_TIME_FORMAT',
|
|
56
|
-
|
|
57
|
-
// Price/quantity errors
|
|
58
|
-
PRICE_REQUIRED: 'PRICE_REQUIRED',
|
|
59
|
-
PRICE_MUST_BE_POSITIVE: 'PRICE_MUST_BE_POSITIVE',
|
|
60
|
-
PRICE_INVALID_FORMAT: 'PRICE_INVALID_FORMAT',
|
|
61
|
-
QUANTITY_REQUIRED: 'QUANTITY_REQUIRED',
|
|
62
|
-
QUANTITY_MUST_BE_POSITIVE: 'QUANTITY_MUST_BE_POSITIVE',
|
|
63
|
-
QUANTITY_INVALID_FORMAT: 'QUANTITY_INVALID_FORMAT',
|
|
64
|
-
|
|
65
|
-
// Ticket limit errors
|
|
66
|
-
MIN_TICKETS_REQUIRED: 'MIN_TICKETS_REQUIRED',
|
|
67
|
-
MIN_TICKETS_EXCEEDS_MAX_ALLOWED: 'MIN_TICKETS_EXCEEDS_MAX_ALLOWED',
|
|
68
|
-
MAX_TICKETS_EXCEEDS_MAX_ALLOWED: 'MAX_TICKETS_EXCEEDS_MAX_ALLOWED',
|
|
69
|
-
MIN_EXCEEDS_MAX: 'MIN_EXCEEDS_MAX',
|
|
70
|
-
|
|
71
|
-
// Sales window errors
|
|
72
|
-
SALES_BEGIN_AFTER_EVENT_END: 'SALES_BEGIN_AFTER_EVENT_END',
|
|
73
|
-
SALES_END_AFTER_EVENT_END: 'SALES_END_AFTER_EVENT_END',
|
|
74
|
-
SALES_END_BEFORE_BEGIN: 'SALES_END_BEFORE_BEGIN',
|
|
75
|
-
|
|
76
|
-
// Capacity errors
|
|
77
|
-
CAPACITY_EXCEEDED: 'CAPACITY_EXCEEDED',
|
|
78
|
-
|
|
79
|
-
// Promo code errors
|
|
80
|
-
PROMO_NAME_REQUIRED: 'PROMO_NAME_REQUIRED',
|
|
81
|
-
PROMO_NAME_COLLISION: 'PROMO_NAME_COLLISION',
|
|
82
|
-
PROMO_END_BEFORE_START: 'PROMO_END_BEFORE_START',
|
|
83
|
-
PROMO_DISCOUNT_REQUIRED: 'PROMO_DISCOUNT_REQUIRED',
|
|
84
|
-
PROMO_BOTH_DISCOUNT_TYPES: 'PROMO_BOTH_DISCOUNT_TYPES',
|
|
85
|
-
PROMO_PERCENT_EXCEEDS_100: 'PROMO_PERCENT_EXCEEDS_100',
|
|
86
|
-
PROMO_LIMIT_REQUIRED: 'PROMO_LIMIT_REQUIRED',
|
|
87
|
-
|
|
88
|
-
// Warning codes
|
|
89
|
-
PROMO_EXTENDS_PAST_EVENT: 'PROMO_EXTENDS_PAST_EVENT',
|
|
90
|
-
SALES_CLOSE_TO_EVENT: 'SALES_CLOSE_TO_EVENT',
|
|
91
|
-
};
|
|
1
|
+
/**
|
|
2
|
+
* Validation Constants
|
|
3
|
+
*
|
|
4
|
+
* Shared validation rules and defaults for event, ticket, and promo code validation.
|
|
5
|
+
* Used by micdrop-frontend, venue-calendar-npm, and other apps.
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* import { MIN_EVENT_DURATION_MINS, DEFAULT_EVENT_DURATION_MINS } from '@getmicdrop/svelte-components';
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
// ============================================================================
|
|
12
|
+
// Event Time Constants
|
|
13
|
+
// ============================================================================
|
|
14
|
+
|
|
15
|
+
/** Minimum event duration in minutes (validation constraint) */
|
|
16
|
+
export const MIN_EVENT_DURATION_MINS = 15;
|
|
17
|
+
|
|
18
|
+
/** Maximum event duration in minutes (24 hours) */
|
|
19
|
+
export const MAX_EVENT_DURATION_MINS = 1440;
|
|
20
|
+
|
|
21
|
+
/** Default event duration in minutes (used when auto-filling end time) */
|
|
22
|
+
export const DEFAULT_EVENT_DURATION_MINS = 90;
|
|
23
|
+
|
|
24
|
+
/** Default time doors open before event start in minutes (used when auto-filling) */
|
|
25
|
+
export const DEFAULT_DOORS_BEFORE_START_MINS = 30;
|
|
26
|
+
|
|
27
|
+
// ============================================================================
|
|
28
|
+
// Ticket Constants
|
|
29
|
+
// ============================================================================
|
|
30
|
+
|
|
31
|
+
/** Maximum tickets per order limit */
|
|
32
|
+
export const MAX_TICKETS_PER_ORDER = 100;
|
|
33
|
+
|
|
34
|
+
/** Minimum tickets per order limit */
|
|
35
|
+
export const MIN_TICKETS_PER_ORDER = 0;
|
|
36
|
+
|
|
37
|
+
// ============================================================================
|
|
38
|
+
// Promo Code Constants
|
|
39
|
+
// ============================================================================
|
|
40
|
+
|
|
41
|
+
/** Maximum percentage discount */
|
|
42
|
+
export const MAX_PERCENTAGE_DISCOUNT = 100;
|
|
43
|
+
|
|
44
|
+
// ============================================================================
|
|
45
|
+
// Error Codes
|
|
46
|
+
// ============================================================================
|
|
47
|
+
|
|
48
|
+
export const ErrorCodes = {
|
|
49
|
+
// Event errors
|
|
50
|
+
EVENT_DURATION_TOO_SHORT: 'EVENT_DURATION_TOO_SHORT',
|
|
51
|
+
EVENT_DURATION_TOO_LONG: 'EVENT_DURATION_TOO_LONG',
|
|
52
|
+
EVENT_END_BEFORE_START: 'EVENT_END_BEFORE_START',
|
|
53
|
+
EVENT_DOORS_SAME_AS_START: 'EVENT_DOORS_SAME_AS_START',
|
|
54
|
+
EVENT_DOORS_TOO_CLOSE: 'EVENT_DOORS_TOO_CLOSE',
|
|
55
|
+
EVENT_INVALID_TIME_FORMAT: 'EVENT_INVALID_TIME_FORMAT',
|
|
56
|
+
|
|
57
|
+
// Price/quantity errors
|
|
58
|
+
PRICE_REQUIRED: 'PRICE_REQUIRED',
|
|
59
|
+
PRICE_MUST_BE_POSITIVE: 'PRICE_MUST_BE_POSITIVE',
|
|
60
|
+
PRICE_INVALID_FORMAT: 'PRICE_INVALID_FORMAT',
|
|
61
|
+
QUANTITY_REQUIRED: 'QUANTITY_REQUIRED',
|
|
62
|
+
QUANTITY_MUST_BE_POSITIVE: 'QUANTITY_MUST_BE_POSITIVE',
|
|
63
|
+
QUANTITY_INVALID_FORMAT: 'QUANTITY_INVALID_FORMAT',
|
|
64
|
+
|
|
65
|
+
// Ticket limit errors
|
|
66
|
+
MIN_TICKETS_REQUIRED: 'MIN_TICKETS_REQUIRED',
|
|
67
|
+
MIN_TICKETS_EXCEEDS_MAX_ALLOWED: 'MIN_TICKETS_EXCEEDS_MAX_ALLOWED',
|
|
68
|
+
MAX_TICKETS_EXCEEDS_MAX_ALLOWED: 'MAX_TICKETS_EXCEEDS_MAX_ALLOWED',
|
|
69
|
+
MIN_EXCEEDS_MAX: 'MIN_EXCEEDS_MAX',
|
|
70
|
+
|
|
71
|
+
// Sales window errors
|
|
72
|
+
SALES_BEGIN_AFTER_EVENT_END: 'SALES_BEGIN_AFTER_EVENT_END',
|
|
73
|
+
SALES_END_AFTER_EVENT_END: 'SALES_END_AFTER_EVENT_END',
|
|
74
|
+
SALES_END_BEFORE_BEGIN: 'SALES_END_BEFORE_BEGIN',
|
|
75
|
+
|
|
76
|
+
// Capacity errors
|
|
77
|
+
CAPACITY_EXCEEDED: 'CAPACITY_EXCEEDED',
|
|
78
|
+
|
|
79
|
+
// Promo code errors
|
|
80
|
+
PROMO_NAME_REQUIRED: 'PROMO_NAME_REQUIRED',
|
|
81
|
+
PROMO_NAME_COLLISION: 'PROMO_NAME_COLLISION',
|
|
82
|
+
PROMO_END_BEFORE_START: 'PROMO_END_BEFORE_START',
|
|
83
|
+
PROMO_DISCOUNT_REQUIRED: 'PROMO_DISCOUNT_REQUIRED',
|
|
84
|
+
PROMO_BOTH_DISCOUNT_TYPES: 'PROMO_BOTH_DISCOUNT_TYPES',
|
|
85
|
+
PROMO_PERCENT_EXCEEDS_100: 'PROMO_PERCENT_EXCEEDS_100',
|
|
86
|
+
PROMO_LIMIT_REQUIRED: 'PROMO_LIMIT_REQUIRED',
|
|
87
|
+
|
|
88
|
+
// Warning codes
|
|
89
|
+
PROMO_EXTENDS_PAST_EVENT: 'PROMO_EXTENDS_PAST_EVENT',
|
|
90
|
+
SALES_CLOSE_TO_EVENT: 'SALES_CLOSE_TO_EVENT',
|
|
91
|
+
};
|