@getmicdrop/svelte-components 5.5.0 → 5.5.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/calendar/AboutShow/AboutShow.svelte +172 -172
- package/dist/calendar/Calendar/MiniMonthCalendar.svelte +782 -782
- package/dist/calendar/FAQs/FAQs.svelte +75 -75
- package/dist/calendar/MonthSwitcher/MonthSwitcher.svelte +126 -126
- package/dist/calendar/OrderSummary/OrderSummary.svelte +367 -367
- package/dist/calendar/PublicCard/PublicCard.svelte +134 -134
- package/dist/calendar/ShowCard/ShowCard.svelte +157 -157
- package/dist/calendar/ShowTimeCard/ShowTimeCard.svelte +61 -61
- package/dist/components/Layout/Grid.svelte +4 -4
- package/dist/components/Layout/Section.svelte +80 -80
- package/dist/components/Layout/Sidebar.svelte +108 -108
- package/dist/components/Layout/Stack.svelte +6 -6
- package/dist/constants/validation.js +91 -91
- package/dist/constants/validation.spec.js +64 -64
- package/dist/index.d.ts +1 -1
- package/dist/index.js +226 -226
- 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 +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.stories.svelte +83 -83
- package/dist/patterns/forms/FormValidationSummary.svelte +33 -33
- package/dist/patterns/layout/Sidebar.svelte +39 -39
- package/dist/patterns/navigation/BottomNav.stories.svelte +117 -117
- package/dist/patterns/navigation/BottomNav.svelte +20 -20
- 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 +54 -54
- 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 +170 -170
- 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 +103 -103
- package/dist/primitives/Badges/Badge.stories.svelte +86 -86
- package/dist/primitives/Badges/Badge.svelte +79 -79
- 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 +270 -270
- 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 +80 -80
- package/dist/primitives/Drawer/Drawer.svelte +120 -120
- package/dist/primitives/Dropdown/Dropdown.stories.svelte +137 -137
- package/dist/primitives/Dropdown/Dropdown.svelte +14 -14
- package/dist/primitives/Dropdown/DropdownItem.svelte +80 -80
- package/dist/primitives/Icons/ArrowLeft.svelte +8 -8
- package/dist/primitives/Icons/ArrowRight.svelte +8 -8
- package/dist/primitives/Icons/Availability.svelte +14 -14
- package/dist/primitives/Icons/Back.svelte +14 -14
- package/dist/primitives/Icons/CheckCircle.svelte +6 -6
- package/dist/primitives/Icons/CheckCircleOutline.svelte +15 -15
- package/dist/primitives/Icons/ChevronLeft.svelte +4 -4
- package/dist/primitives/Icons/ChevronRight.svelte +4 -4
- package/dist/primitives/Icons/Copy.svelte +15 -15
- package/dist/primitives/Icons/Cross.svelte +5 -5
- package/dist/primitives/Icons/DownArrow.svelte +8 -8
- package/dist/primitives/Icons/ErrorCircle.svelte +6 -6
- package/dist/primitives/Icons/FacebookIcon.svelte +2 -2
- package/dist/primitives/Icons/Home.svelte +15 -15
- package/dist/primitives/Icons/Icon.spec.js +169 -169
- package/dist/primitives/Icons/Icon.stories.svelte +100 -100
- package/dist/primitives/Icons/Icon.svelte +52 -52
- package/dist/primitives/Icons/IconGallery.stories.svelte +235 -235
- package/dist/primitives/Icons/Info.svelte +7 -7
- package/dist/primitives/Icons/InstagramIcon.svelte +4 -4
- package/dist/primitives/Icons/LogoInstagram.svelte +2 -2
- package/dist/primitives/Icons/Message.svelte +15 -15
- package/dist/primitives/Icons/MoonIcon.svelte +5 -5
- package/dist/primitives/Icons/More.svelte +21 -21
- package/dist/primitives/Icons/MoreHori.spec.js +61 -61
- package/dist/primitives/Icons/MoreHori.svelte +22 -22
- package/dist/primitives/Icons/Notification.svelte +14 -14
- package/dist/primitives/Icons/Payment.svelte +14 -14
- package/dist/primitives/Icons/Profile.svelte +21 -21
- package/dist/primitives/Icons/Reload.svelte +29 -29
- package/dist/primitives/Icons/Shows.svelte +21 -21
- package/dist/primitives/Icons/Signout.svelte +21 -21
- package/dist/primitives/Icons/SunIcon.svelte +8 -8
- package/dist/primitives/Icons/TiktokIcon.svelte +2 -2
- package/dist/primitives/Icons/TwitterIcon.svelte +2 -2
- package/dist/primitives/Icons/WarningIcon.spec.js +18 -18
- package/dist/primitives/Icons/WarningIcon.svelte +5 -5
- package/dist/primitives/Input/Input.spec.js +573 -573
- package/dist/primitives/Input/Input.stories.svelte +139 -139
- package/dist/primitives/Input/Input.svelte +392 -392
- package/dist/primitives/Input/Select.spec.js +218 -218
- 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 +95 -95
- package/dist/primitives/Modal/Modal.stories.svelte +86 -86
- package/dist/primitives/Modal/Modal.svelte +158 -158
- package/dist/primitives/NumberInput/NumberInput.svelte +106 -106
- package/dist/primitives/Pagination/Pagination.stories.svelte +76 -76
- package/dist/primitives/Pagination/Pagination.svelte +261 -261
- package/dist/primitives/Radio/Radio.stories.svelte +80 -80
- package/dist/primitives/Radio/Radio.svelte +67 -67
- package/dist/primitives/Skeleton/CardPlaceholder.svelte +87 -87
- package/dist/primitives/Skeleton/ImagePlaceholder.svelte +59 -59
- package/dist/primitives/Skeleton/ListPlaceholder.svelte +76 -76
- package/dist/primitives/Skeleton/Skeleton.stories.svelte +151 -151
- package/dist/primitives/Skeleton/Skeleton.svelte +26 -26
- package/dist/primitives/Spinner/Spinner.spec.js +75 -75
- 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 +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 +69 -69
- 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 +804 -804
- package/dist/recipes/SuperLogin/SuperLogin.svelte +7 -6
- package/dist/recipes/SuperLogin/SuperLogin.svelte.d.ts.map +1 -1
- package/dist/recipes/Toaster/Toaster.stories.svelte +62 -62
- package/dist/recipes/feedback/EmptyState/EmptyState.svelte +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 +129 -129
- 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 +257 -257
- package/dist/recipes/inputs/MultiSelect.stories.svelte +133 -133
- package/dist/recipes/inputs/MultiSelect.svelte +249 -249
- package/dist/recipes/inputs/OTPInput.spec.js +238 -238
- 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.spec.js +173 -173
- package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.svelte +43 -43
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.spec.js +300 -300
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.stories.svelte +123 -123
- package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte +326 -326
- package/dist/recipes/inputs/Search.svelte +37 -37
- package/dist/recipes/inputs/SelectDropdown.svelte +57 -57
- package/dist/recipes/modals/AlertModal.svelte +130 -130
- package/dist/recipes/modals/ConfirmationModal.spec.js +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 +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/tokens/tokens.css +87 -87
- package/dist/utils/transitions.d.ts +24 -0
- package/dist/utils/transitions.d.ts.map +1 -0
- package/dist/utils/transitions.js +62 -0
- package/dist/utils/utils.js +354 -354
- package/package.json +283 -283
|
@@ -1,61 +1,61 @@
|
|
|
1
|
-
<script>
|
|
2
|
-
import { typography } from '../../tokens/typography';
|
|
3
|
-
|
|
4
|
-
let {
|
|
5
|
-
day = '',
|
|
6
|
-
date = '',
|
|
7
|
-
time = '',
|
|
8
|
-
isSelected = false,
|
|
9
|
-
onselect,
|
|
10
|
-
} = $props();
|
|
11
|
-
|
|
12
|
-
function handleCardClick() {
|
|
13
|
-
onselect?.({ date });
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
function handleKeydown(e) {
|
|
17
|
-
if (e.key === 'Enter' || e.key === ' ') {
|
|
18
|
-
e.preventDefault();
|
|
19
|
-
handleCardClick();
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
function formatHour(timeStr) {
|
|
24
|
-
if (!timeStr) return '';
|
|
25
|
-
const d = new Date(`1970-01-01T${timeStr}`);
|
|
26
|
-
if (isNaN(d.getTime())) return timeStr;
|
|
27
|
-
return d.toLocaleTimeString('en-US', {
|
|
28
|
-
hour: 'numeric',
|
|
29
|
-
minute: '2-digit',
|
|
30
|
-
hour12: true
|
|
31
|
-
});
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
function formatDate(dateStr) {
|
|
35
|
-
if (!dateStr) return '';
|
|
36
|
-
const d = new Date(dateStr);
|
|
37
|
-
if (isNaN(d.getTime())) return dateStr;
|
|
38
|
-
return d.toLocaleDateString('en-US', {
|
|
39
|
-
month: 'short',
|
|
40
|
-
day: 'numeric',
|
|
41
|
-
});
|
|
42
|
-
}
|
|
43
|
-
</script>
|
|
44
|
-
|
|
45
|
-
<div
|
|
46
|
-
class="w-full h-28 rounded-lg flex flex-col justify-center items-center gap-1.5 cursor-pointer border-2 px-1 transition-colors bg-white dark:bg-gray-800 {isSelected
|
|
47
|
-
? 'border-blue-700 dark:border-blue-500'
|
|
48
|
-
: 'border-gray-200 dark:border-gray-700 hover:border-blue-700 dark:hover:border-blue-500'}"
|
|
49
|
-
onclick={handleCardClick}
|
|
50
|
-
onkeydown={handleKeydown}
|
|
51
|
-
tabindex="0"
|
|
52
|
-
role="button"
|
|
53
|
-
aria-label={`${day} ${formatDate(date)} at ${formatHour(time)}${isSelected ? ', selected' : ''}`}
|
|
54
|
-
aria-pressed={isSelected}
|
|
55
|
-
>
|
|
56
|
-
<span class="{typography.label} text-sm {typography.textMuted}">{day}</span>
|
|
57
|
-
<span class="{typography.label} text-base {isSelected ? 'text-blue-700 dark:text-blue-500' : ''}">
|
|
58
|
-
{formatDate(date)}
|
|
59
|
-
</span>
|
|
60
|
-
<span class="{typography.label} text-sm {typography.textMuted}">{formatHour(time)}</span>
|
|
61
|
-
</div>
|
|
1
|
+
<script>
|
|
2
|
+
import { typography } from '../../tokens/typography';
|
|
3
|
+
|
|
4
|
+
let {
|
|
5
|
+
day = '',
|
|
6
|
+
date = '',
|
|
7
|
+
time = '',
|
|
8
|
+
isSelected = false,
|
|
9
|
+
onselect,
|
|
10
|
+
} = $props();
|
|
11
|
+
|
|
12
|
+
function handleCardClick() {
|
|
13
|
+
onselect?.({ date });
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
function handleKeydown(e) {
|
|
17
|
+
if (e.key === 'Enter' || e.key === ' ') {
|
|
18
|
+
e.preventDefault();
|
|
19
|
+
handleCardClick();
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
function formatHour(timeStr) {
|
|
24
|
+
if (!timeStr) return '';
|
|
25
|
+
const d = new Date(`1970-01-01T${timeStr}`);
|
|
26
|
+
if (isNaN(d.getTime())) return timeStr;
|
|
27
|
+
return d.toLocaleTimeString('en-US', {
|
|
28
|
+
hour: 'numeric',
|
|
29
|
+
minute: '2-digit',
|
|
30
|
+
hour12: true
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
function formatDate(dateStr) {
|
|
35
|
+
if (!dateStr) return '';
|
|
36
|
+
const d = new Date(dateStr);
|
|
37
|
+
if (isNaN(d.getTime())) return dateStr;
|
|
38
|
+
return d.toLocaleDateString('en-US', {
|
|
39
|
+
month: 'short',
|
|
40
|
+
day: 'numeric',
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
</script>
|
|
44
|
+
|
|
45
|
+
<div
|
|
46
|
+
class="w-full h-28 rounded-lg flex flex-col justify-center items-center gap-1.5 cursor-pointer border-2 px-1 transition-colors bg-white dark:bg-gray-800 {isSelected
|
|
47
|
+
? 'border-blue-700 dark:border-blue-500'
|
|
48
|
+
: 'border-gray-200 dark:border-gray-700 hover:border-blue-700 dark:hover:border-blue-500'}"
|
|
49
|
+
onclick={handleCardClick}
|
|
50
|
+
onkeydown={handleKeydown}
|
|
51
|
+
tabindex="0"
|
|
52
|
+
role="button"
|
|
53
|
+
aria-label={`${day} ${formatDate(date)} at ${formatHour(time)}${isSelected ? ', selected' : ''}`}
|
|
54
|
+
aria-pressed={isSelected}
|
|
55
|
+
>
|
|
56
|
+
<span class="{typography.label} text-sm {typography.textMuted}">{day}</span>
|
|
57
|
+
<span class="{typography.label} text-base {isSelected ? 'text-blue-700 dark:text-blue-500' : ''}">
|
|
58
|
+
{formatDate(date)}
|
|
59
|
+
</span>
|
|
60
|
+
<span class="{typography.label} text-sm {typography.textMuted}">{formatHour(time)}</span>
|
|
61
|
+
</div>
|
|
@@ -95,7 +95,7 @@
|
|
|
95
95
|
].filter(Boolean).join(' ')
|
|
96
96
|
);
|
|
97
97
|
</script>
|
|
98
|
-
|
|
99
|
-
<svelte:element this={as} class={classes} style={gridStyle || undefined}>
|
|
100
|
-
{@render children?.()}
|
|
101
|
-
</svelte:element>
|
|
98
|
+
|
|
99
|
+
<svelte:element this={as} class={classes} style={gridStyle || undefined}>
|
|
100
|
+
{@render children?.()}
|
|
101
|
+
</svelte:element>
|
|
@@ -1,80 +1,80 @@
|
|
|
1
|
-
<script lang="ts">
|
|
2
|
-
import type { Snippet } from 'svelte';
|
|
3
|
-
import { typography } from '../../tokens/typography';
|
|
4
|
-
|
|
5
|
-
/**
|
|
6
|
-
* Section - Semantic section wrapper with optional title
|
|
7
|
-
*
|
|
8
|
-
* Use Section to group related content with consistent spacing.
|
|
9
|
-
* Provides proper HTML5 semantics with <section> element.
|
|
10
|
-
*
|
|
11
|
-
* @example
|
|
12
|
-
* <Section title="Recent Orders">
|
|
13
|
-
* <OrdersTable />
|
|
14
|
-
* </Section>
|
|
15
|
-
*
|
|
16
|
-
* @example
|
|
17
|
-
* <Section>
|
|
18
|
-
* <Chart />
|
|
19
|
-
* </Section>
|
|
20
|
-
*/
|
|
21
|
-
|
|
22
|
-
interface Props {
|
|
23
|
-
/** Section title (optional) */
|
|
24
|
-
title?: string;
|
|
25
|
-
/** Title size */
|
|
26
|
-
titleSize?: 'sm' | 'md' | 'lg';
|
|
27
|
-
/** Gap between title and content */
|
|
28
|
-
gap?: '2' | '3' | '4' | '6';
|
|
29
|
-
/** Additional CSS classes for the section */
|
|
30
|
-
class?: string;
|
|
31
|
-
/** Additional CSS classes for the title */
|
|
32
|
-
titleClass?: string;
|
|
33
|
-
/** Child content */
|
|
34
|
-
children?: Snippet;
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
let {
|
|
38
|
-
title = '',
|
|
39
|
-
titleSize = 'md',
|
|
40
|
-
gap = '4',
|
|
41
|
-
class: className = '',
|
|
42
|
-
titleClass = '',
|
|
43
|
-
children
|
|
44
|
-
}: Props = $props();
|
|
45
|
-
|
|
46
|
-
const titleSizeMap: Record<string, string> = {
|
|
47
|
-
sm: typography.h4,
|
|
48
|
-
md: typography.h3,
|
|
49
|
-
lg: typography.h2
|
|
50
|
-
};
|
|
51
|
-
|
|
52
|
-
const gapMap: Record<string, string> = {
|
|
53
|
-
'2': 'space-y-2',
|
|
54
|
-
'3': 'space-y-3',
|
|
55
|
-
'4': 'space-y-4',
|
|
56
|
-
'6': 'space-y-6'
|
|
57
|
-
};
|
|
58
|
-
|
|
59
|
-
let sectionClasses = $derived(
|
|
60
|
-
[
|
|
61
|
-
title ? gapMap[gap] || 'space-y-4' : '',
|
|
62
|
-
className
|
|
63
|
-
].filter(Boolean).join(' ')
|
|
64
|
-
);
|
|
65
|
-
|
|
66
|
-
let titleClasses = $derived(
|
|
67
|
-
[
|
|
68
|
-
titleSizeMap[titleSize] || titleSizeMap.md,
|
|
69
|
-
titleClass
|
|
70
|
-
].filter(Boolean).join(' ')
|
|
71
|
-
);
|
|
72
|
-
</script>
|
|
73
|
-
|
|
74
|
-
<section class={sectionClasses} aria-label={title || undefined}>
|
|
75
|
-
{#if title}
|
|
76
|
-
<h2 class={titleClasses}>{title}</h2>
|
|
77
|
-
{/if}
|
|
78
|
-
|
|
79
|
-
{@render children?.()}
|
|
80
|
-
</section>
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import type { Snippet } from 'svelte';
|
|
3
|
+
import { typography } from '../../tokens/typography';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Section - Semantic section wrapper with optional title
|
|
7
|
+
*
|
|
8
|
+
* Use Section to group related content with consistent spacing.
|
|
9
|
+
* Provides proper HTML5 semantics with <section> element.
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* <Section title="Recent Orders">
|
|
13
|
+
* <OrdersTable />
|
|
14
|
+
* </Section>
|
|
15
|
+
*
|
|
16
|
+
* @example
|
|
17
|
+
* <Section>
|
|
18
|
+
* <Chart />
|
|
19
|
+
* </Section>
|
|
20
|
+
*/
|
|
21
|
+
|
|
22
|
+
interface Props {
|
|
23
|
+
/** Section title (optional) */
|
|
24
|
+
title?: string;
|
|
25
|
+
/** Title size */
|
|
26
|
+
titleSize?: 'sm' | 'md' | 'lg';
|
|
27
|
+
/** Gap between title and content */
|
|
28
|
+
gap?: '2' | '3' | '4' | '6';
|
|
29
|
+
/** Additional CSS classes for the section */
|
|
30
|
+
class?: string;
|
|
31
|
+
/** Additional CSS classes for the title */
|
|
32
|
+
titleClass?: string;
|
|
33
|
+
/** Child content */
|
|
34
|
+
children?: Snippet;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
let {
|
|
38
|
+
title = '',
|
|
39
|
+
titleSize = 'md',
|
|
40
|
+
gap = '4',
|
|
41
|
+
class: className = '',
|
|
42
|
+
titleClass = '',
|
|
43
|
+
children
|
|
44
|
+
}: Props = $props();
|
|
45
|
+
|
|
46
|
+
const titleSizeMap: Record<string, string> = {
|
|
47
|
+
sm: typography.h4,
|
|
48
|
+
md: typography.h3,
|
|
49
|
+
lg: typography.h2
|
|
50
|
+
};
|
|
51
|
+
|
|
52
|
+
const gapMap: Record<string, string> = {
|
|
53
|
+
'2': 'space-y-2',
|
|
54
|
+
'3': 'space-y-3',
|
|
55
|
+
'4': 'space-y-4',
|
|
56
|
+
'6': 'space-y-6'
|
|
57
|
+
};
|
|
58
|
+
|
|
59
|
+
let sectionClasses = $derived(
|
|
60
|
+
[
|
|
61
|
+
title ? gapMap[gap] || 'space-y-4' : '',
|
|
62
|
+
className
|
|
63
|
+
].filter(Boolean).join(' ')
|
|
64
|
+
);
|
|
65
|
+
|
|
66
|
+
let titleClasses = $derived(
|
|
67
|
+
[
|
|
68
|
+
titleSizeMap[titleSize] || titleSizeMap.md,
|
|
69
|
+
titleClass
|
|
70
|
+
].filter(Boolean).join(' ')
|
|
71
|
+
);
|
|
72
|
+
</script>
|
|
73
|
+
|
|
74
|
+
<section class={sectionClasses} aria-label={title || undefined}>
|
|
75
|
+
{#if title}
|
|
76
|
+
<h2 class={titleClasses}>{title}</h2>
|
|
77
|
+
{/if}
|
|
78
|
+
|
|
79
|
+
{@render children?.()}
|
|
80
|
+
</section>
|
|
@@ -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>
|
|
@@ -35,7 +35,7 @@
|
|
|
35
35
|
children,
|
|
36
36
|
...restProps
|
|
37
37
|
}: Props = $props();
|
|
38
|
-
|
|
38
|
+
|
|
39
39
|
let classes = $derived([
|
|
40
40
|
'flex',
|
|
41
41
|
direction === 'vertical' ? 'flex-col' : 'flex-row',
|
|
@@ -45,8 +45,8 @@
|
|
|
45
45
|
wrap ? 'flex-wrap' : '',
|
|
46
46
|
className
|
|
47
47
|
].filter(Boolean).join(' '));
|
|
48
|
-
</script>
|
|
49
|
-
|
|
50
|
-
<svelte:element this={as} class={classes} {...restProps}>
|
|
51
|
-
{#if children}{@render children()}{/if}
|
|
52
|
-
</svelte:element>
|
|
48
|
+
</script>
|
|
49
|
+
|
|
50
|
+
<svelte:element this={as} class={classes} {...restProps}>
|
|
51
|
+
{#if children}{@render children()}{/if}
|
|
52
|
+
</svelte:element>
|