@getmicdrop/svelte-components 5.10.0 → 5.10.3

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.
Files changed (233) hide show
  1. package/dist/calendar/AboutShow/AboutShow.svelte +172 -172
  2. package/dist/calendar/Calendar/MiniMonthCalendar.svelte +782 -782
  3. package/dist/calendar/FAQs/FAQs.svelte +75 -75
  4. package/dist/calendar/MonthSwitcher/MonthSwitcher.svelte +126 -126
  5. package/dist/calendar/OrderSummary/OrderSummary.svelte +367 -367
  6. package/dist/calendar/PublicCard/PublicCard.svelte +146 -146
  7. package/dist/calendar/ShowCard/ShowCard.svelte +157 -157
  8. package/dist/calendar/ShowTimeCard/ShowTimeCard.svelte +61 -61
  9. package/dist/components/Heading.svelte +60 -60
  10. package/dist/components/Layout/AppShell.svelte +104 -104
  11. package/dist/components/Layout/ContentSection.svelte +80 -80
  12. package/dist/components/Layout/Grid.svelte +4 -4
  13. package/dist/components/Layout/Heading.svelte +81 -81
  14. package/dist/components/Layout/PageContainer.svelte +69 -69
  15. package/dist/components/Layout/Responsive.svelte +75 -75
  16. package/dist/components/Layout/Section.svelte +80 -80
  17. package/dist/components/Layout/ShowOnDesktop.svelte +37 -37
  18. package/dist/components/Layout/ShowOnMobile.svelte +37 -37
  19. package/dist/components/Layout/Sidebar.svelte +108 -108
  20. package/dist/components/Layout/Stack.spec.js +1 -1
  21. package/dist/components/Layout/Stack.svelte +6 -6
  22. package/dist/components/Layout/Text.svelte +87 -87
  23. package/dist/components/Layout/TwoColumn.svelte +108 -108
  24. package/dist/components/Text.svelte +53 -53
  25. package/dist/constants/validation.js +91 -91
  26. package/dist/constants/validation.spec.js +64 -64
  27. package/dist/datetime/__tests__/format.test.js +1 -1
  28. package/dist/datetime/__tests__/parse.test.js +1 -1
  29. package/dist/datetime/__tests__/timezone.test.js +1 -1
  30. package/dist/datetime/parse.js +1 -1
  31. package/dist/forms/createFormStore.svelte.js +1 -0
  32. package/dist/index.js +51 -51
  33. package/dist/patterns/data/DataGrid.svelte +45 -45
  34. package/dist/patterns/data/DataList.svelte +24 -24
  35. package/dist/patterns/data/DataTable.svelte +36 -36
  36. package/dist/patterns/forms/FormActions.spec.js +95 -95
  37. package/dist/patterns/forms/FormActions.stories.svelte +97 -97
  38. package/dist/patterns/forms/FormActions.svelte +46 -46
  39. package/dist/patterns/forms/FormGrid.svelte +33 -33
  40. package/dist/patterns/forms/FormSection.svelte +32 -32
  41. package/dist/patterns/forms/FormValidationSummary.stories.svelte +83 -83
  42. package/dist/patterns/forms/FormValidationSummary.svelte +74 -74
  43. package/dist/patterns/layout/Sidebar.svelte +39 -39
  44. package/dist/patterns/layout/index.js +29 -29
  45. package/dist/patterns/navigation/BottomNav.stories.svelte +117 -117
  46. package/dist/patterns/navigation/BottomNav.svelte +74 -74
  47. package/dist/patterns/navigation/Header.stories.svelte +77 -77
  48. package/dist/patterns/navigation/Header.svelte +255 -255
  49. package/dist/patterns/page/PageHeader.svelte +18 -18
  50. package/dist/patterns/page/PageLayout.svelte +40 -40
  51. package/dist/patterns/page/PageLoader.spec.js +57 -57
  52. package/dist/patterns/page/PageLoader.stories.svelte +137 -137
  53. package/dist/patterns/page/PageLoader.svelte +24 -24
  54. package/dist/patterns/page/SectionHeader.svelte +29 -29
  55. package/dist/presets/badges.js +112 -112
  56. package/dist/presets/buttons.js +76 -76
  57. package/dist/presets/index.js +9 -9
  58. package/dist/primitives/Accordion/Accordion.stories.svelte +75 -75
  59. package/dist/primitives/Accordion/Accordion.svelte +42 -42
  60. package/dist/primitives/Accordion/AccordionItem.svelte +95 -95
  61. package/dist/primitives/Alert/Alert.spec.js +173 -173
  62. package/dist/primitives/Alert/Alert.stories.svelte +88 -88
  63. package/dist/primitives/Alert/Alert.svelte +27 -27
  64. package/dist/primitives/Avatar/Avatar.stories.svelte +94 -94
  65. package/dist/primitives/Avatar/Avatar.svelte +66 -66
  66. package/dist/primitives/Badges/Badge.spec.js +144 -144
  67. package/dist/primitives/Badges/Badge.stories.svelte +86 -86
  68. package/dist/primitives/Badges/Badge.svelte +99 -99
  69. package/dist/primitives/BottomSheet/BottomSheet.spec.js +136 -136
  70. package/dist/primitives/BottomSheet/BottomSheet.stories.svelte +83 -83
  71. package/dist/primitives/BottomSheet/BottomSheet.svelte +100 -100
  72. package/dist/primitives/Breadcrumb/Breadcrumb.spec.js +122 -122
  73. package/dist/primitives/Breadcrumb/Breadcrumb.stories.svelte +23 -23
  74. package/dist/primitives/Breadcrumb/Breadcrumb.svelte +98 -98
  75. package/dist/primitives/Button/Button.spec.js +223 -223
  76. package/dist/primitives/Button/Button.stories.svelte +76 -76
  77. package/dist/primitives/Button/Button.svelte +283 -283
  78. package/dist/primitives/Button/ButtonGroup.svelte +50 -50
  79. package/dist/primitives/Button/ButtonSaveDemo.spec.js +146 -146
  80. package/dist/primitives/Button/ButtonSaveDemo.svelte +25 -25
  81. package/dist/primitives/Button/ButtonVariantShowcase.svelte +129 -129
  82. package/dist/primitives/Card.spec.js +49 -49
  83. package/dist/primitives/Card.stories.svelte +22 -22
  84. package/dist/primitives/Card.svelte +28 -28
  85. package/dist/primitives/Checkbox/Checkbox.stories.svelte +84 -84
  86. package/dist/primitives/Checkbox/Checkbox.svelte +88 -88
  87. package/dist/primitives/DarkModeToggle.spec.js +390 -390
  88. package/dist/primitives/DarkModeToggle.stories.svelte +57 -57
  89. package/dist/primitives/DarkModeToggle.svelte +136 -136
  90. package/dist/primitives/Drawer/Drawer.stories.svelte +80 -80
  91. package/dist/primitives/Drawer/Drawer.svelte +120 -120
  92. package/dist/primitives/Dropdown/Dropdown.stories.svelte +137 -137
  93. package/dist/primitives/Dropdown/Dropdown.svelte +170 -170
  94. package/dist/primitives/Dropdown/DropdownDivider.svelte +9 -9
  95. package/dist/primitives/Dropdown/DropdownItem.svelte +80 -80
  96. package/dist/primitives/Helper/Helper.svelte +33 -33
  97. package/dist/primitives/Icons/ArrowLeft.svelte +8 -8
  98. package/dist/primitives/Icons/ArrowRight.svelte +8 -8
  99. package/dist/primitives/Icons/Availability.svelte +14 -14
  100. package/dist/primitives/Icons/Back.svelte +14 -14
  101. package/dist/primitives/Icons/CheckCircle.svelte +6 -6
  102. package/dist/primitives/Icons/CheckCircleOutline.svelte +15 -15
  103. package/dist/primitives/Icons/ChevronLeft.svelte +4 -4
  104. package/dist/primitives/Icons/ChevronRight.svelte +4 -4
  105. package/dist/primitives/Icons/Copy.svelte +15 -15
  106. package/dist/primitives/Icons/Cross.svelte +5 -5
  107. package/dist/primitives/Icons/DownArrow.svelte +8 -8
  108. package/dist/primitives/Icons/ErrorCircle.svelte +6 -6
  109. package/dist/primitives/Icons/FacebookIcon.svelte +2 -2
  110. package/dist/primitives/Icons/Home.svelte +15 -15
  111. package/dist/primitives/Icons/Icon.spec.js +169 -169
  112. package/dist/primitives/Icons/Icon.stories.svelte +100 -100
  113. package/dist/primitives/Icons/Icon.svelte +52 -52
  114. package/dist/primitives/Icons/IconGallery.stories.svelte +235 -235
  115. package/dist/primitives/Icons/Info.svelte +7 -7
  116. package/dist/primitives/Icons/InstagramIcon.svelte +4 -4
  117. package/dist/primitives/Icons/LogoInstagram.svelte +2 -2
  118. package/dist/primitives/Icons/Message.svelte +15 -15
  119. package/dist/primitives/Icons/MoonIcon.svelte +5 -5
  120. package/dist/primitives/Icons/More.svelte +21 -21
  121. package/dist/primitives/Icons/MoreHori.spec.js +61 -61
  122. package/dist/primitives/Icons/MoreHori.svelte +22 -22
  123. package/dist/primitives/Icons/Notification.svelte +14 -14
  124. package/dist/primitives/Icons/Payment.svelte +14 -14
  125. package/dist/primitives/Icons/Profile.svelte +21 -21
  126. package/dist/primitives/Icons/Reload.svelte +29 -29
  127. package/dist/primitives/Icons/Shows.svelte +21 -21
  128. package/dist/primitives/Icons/Signout.svelte +21 -21
  129. package/dist/primitives/Icons/SunIcon.svelte +8 -8
  130. package/dist/primitives/Icons/TiktokIcon.svelte +2 -2
  131. package/dist/primitives/Icons/TwitterIcon.svelte +2 -2
  132. package/dist/primitives/Icons/WarningIcon.spec.js +18 -18
  133. package/dist/primitives/Icons/WarningIcon.svelte +5 -5
  134. package/dist/primitives/Input/Input.spec.js +573 -573
  135. package/dist/primitives/Input/Input.stories.svelte +139 -139
  136. package/dist/primitives/Input/Input.svelte +423 -423
  137. package/dist/primitives/Input/Select.spec.js +218 -218
  138. package/dist/primitives/Input/Select.stories.svelte +112 -112
  139. package/dist/primitives/Input/Select.svelte +252 -252
  140. package/dist/primitives/Input/Textarea.stories.svelte +137 -137
  141. package/dist/primitives/Input/Textarea.svelte +105 -105
  142. package/dist/primitives/Label/Label.svelte +37 -37
  143. package/dist/primitives/Modal/Modal.spec.js +99 -99
  144. package/dist/primitives/Modal/Modal.stories.svelte +86 -86
  145. package/dist/primitives/Modal/Modal.svelte +157 -157
  146. package/dist/primitives/Pagination/Pagination.stories.svelte +76 -76
  147. package/dist/primitives/Pagination/Pagination.svelte +261 -261
  148. package/dist/primitives/Radio/Radio.stories.svelte +80 -80
  149. package/dist/primitives/Radio/Radio.svelte +67 -67
  150. package/dist/primitives/Skeleton/CardPlaceholder.svelte +87 -87
  151. package/dist/primitives/Skeleton/ImagePlaceholder.svelte +59 -59
  152. package/dist/primitives/Skeleton/ListPlaceholder.svelte +76 -76
  153. package/dist/primitives/Skeleton/Skeleton.stories.svelte +151 -151
  154. package/dist/primitives/Skeleton/Skeleton.svelte +26 -26
  155. package/dist/primitives/Spinner/Spinner.spec.js +71 -71
  156. package/dist/primitives/Spinner/Spinner.stories.svelte +29 -29
  157. package/dist/primitives/Spinner/Spinner.svelte +20 -20
  158. package/dist/primitives/Tabs/TabItem.svelte +49 -49
  159. package/dist/primitives/Tabs/Tabs.stories.svelte +112 -112
  160. package/dist/primitives/Tabs/Tabs.svelte +137 -137
  161. package/dist/primitives/Toggle.spec.js +146 -146
  162. package/dist/primitives/Toggle.stories.svelte +92 -92
  163. package/dist/primitives/Toggle.svelte +131 -132
  164. package/dist/primitives/Tooltip/Tooltip.svelte +83 -83
  165. package/dist/primitives/Typography/Typography.svelte +53 -53
  166. package/dist/primitives/ValidationError.spec.js +103 -103
  167. package/dist/primitives/ValidationError.stories.svelte +69 -69
  168. package/dist/primitives/ValidationError.svelte +29 -29
  169. package/dist/primitives/index.js +92 -92
  170. package/dist/recipes/CropImage/CropImage.spec.js +208 -208
  171. package/dist/recipes/CropImage/CropImage.stories.svelte +104 -104
  172. package/dist/recipes/CropImage/CropImage.svelte +219 -219
  173. package/dist/recipes/ImageUploader/ImageUploader.stories.svelte +125 -125
  174. package/dist/recipes/ImageUploader/ImageUploader.svelte +970 -970
  175. package/dist/recipes/Toaster/Toaster.stories.svelte +62 -62
  176. package/dist/recipes/feedback/EmptyState/EmptyState.svelte +1 -1
  177. package/dist/recipes/feedback/ErrorDisplay.spec.js +69 -69
  178. package/dist/recipes/feedback/ErrorDisplay.stories.svelte +101 -101
  179. package/dist/recipes/feedback/ErrorDisplay.svelte +1 -1
  180. package/dist/recipes/feedback/StatusIndicator/StatusIndicator.spec.js +133 -133
  181. package/dist/recipes/feedback/StatusIndicator/StatusIndicator.svelte +157 -157
  182. package/dist/recipes/fields/CheckboxField.svelte +85 -85
  183. package/dist/recipes/fields/FormField.svelte +58 -58
  184. package/dist/recipes/fields/RadioGroup.svelte +95 -95
  185. package/dist/recipes/fields/SelectField.svelte +80 -80
  186. package/dist/recipes/fields/TextareaField.svelte +97 -97
  187. package/dist/recipes/fields/ToggleField.svelte +60 -60
  188. package/dist/recipes/fields/index.js +7 -7
  189. package/dist/recipes/inputs/MultiSelect.spec.js +260 -260
  190. package/dist/recipes/inputs/MultiSelect.stories.svelte +133 -133
  191. package/dist/recipes/inputs/MultiSelect.svelte +283 -283
  192. package/dist/recipes/inputs/OTPInput.spec.js +251 -251
  193. package/dist/recipes/inputs/OTPInput.stories.svelte +162 -162
  194. package/dist/recipes/inputs/OTPInput.svelte +117 -117
  195. package/dist/recipes/inputs/PasswordInput.svelte +22 -22
  196. package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.svelte +131 -117
  197. package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.svelte.d.ts.map +1 -1
  198. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.stories.svelte +123 -123
  199. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte +344 -344
  200. package/dist/recipes/inputs/Search.svelte +102 -102
  201. package/dist/recipes/inputs/SelectDropdown.svelte +171 -171
  202. package/dist/recipes/modals/AlertModal.svelte +130 -130
  203. package/dist/recipes/modals/ConfirmationModal.spec.js +206 -206
  204. package/dist/recipes/modals/ConfirmationModal.stories.svelte +119 -119
  205. package/dist/recipes/modals/ConfirmationModal.svelte +152 -152
  206. package/dist/recipes/modals/InputModal.svelte +182 -182
  207. package/dist/recipes/modals/ModalStateManager.spec.js +100 -100
  208. package/dist/recipes/modals/ModalStateManager.svelte +77 -77
  209. package/dist/recipes/modals/ModalTestWrapper.svelte +65 -65
  210. package/dist/recipes/modals/StatusModal.svelte +206 -206
  211. package/dist/services/EventService.js +75 -75
  212. package/dist/services/EventService.spec.js +217 -217
  213. package/dist/services/ShowService.spec.js +345 -345
  214. package/dist/stores/toaster.js +13 -13
  215. package/dist/stories/ButtonAuditReview.stories.svelte +14 -14
  216. package/dist/stories/ButtonAuditReview.svelte +427 -427
  217. package/dist/stories/PatternsGallery.stories.svelte +19 -19
  218. package/dist/stories/PatternsGallery.svelte +206 -206
  219. package/dist/stories/PrimitivesGallery.stories.svelte +19 -19
  220. package/dist/stories/PrimitivesGallery.svelte +752 -752
  221. package/dist/stories/RecipesGallery.stories.svelte +19 -19
  222. package/dist/stories/RecipesGallery.svelte +471 -471
  223. package/dist/stories/button-audit-manifest.json +11186 -11186
  224. package/dist/tailwind/preset.cjs +82 -82
  225. package/dist/telemetry.js +405 -405
  226. package/dist/telemetry.spec.js +1169 -1169
  227. package/dist/tokens/tokens.css +87 -87
  228. package/dist/tokens/typography-base.css +163 -163
  229. package/dist/tokens/utilities.css +353 -353
  230. package/dist/utils/apiConfig.spec.js +219 -219
  231. package/dist/utils/transitions.js +4 -4
  232. package/dist/utils/utils.js +693 -693
  233. package/package.json +297 -297
@@ -1,88 +1,88 @@
1
- <script module>
2
- import { defineMeta } from '@storybook/addon-svelte-csf';
3
- import Alert from './Alert.svelte';
4
-
5
- const { Story } = defineMeta({
6
- title: 'Primitives/Alert',
7
- component: Alert,
8
- tags: ['autodocs'],
9
- argTypes: {
10
- color: {
11
- control: 'select',
12
- options: ['info', 'success', 'warning', 'error'],
13
- },
14
- dismissible: { control: 'boolean' },
15
- },
16
- parameters: {
17
- docs: {
18
- description: {
19
- component: 'Contextual feedback messages for user actions or system states.',
20
- },
21
- },
22
- },
23
- });
24
- </script>
25
-
26
- <Story name="Info" args={{ color: 'info' }}>
27
- {#snippet template(args)}
28
- <Alert {...args}>
29
- <span class="font-medium">Info!</span> This is an informational alert with helpful information.
30
- </Alert>
31
- {/snippet}
32
- </Story>
33
-
34
- <Story name="Success" args={{ color: 'success' }}>
35
- {#snippet template(args)}
36
- <Alert {...args}>
37
- <span class="font-medium">Success!</span> Your changes have been saved successfully.
38
- </Alert>
39
- {/snippet}
40
- </Story>
41
-
42
- <Story name="Warning" args={{ color: 'warning' }}>
43
- {#snippet template(args)}
44
- <Alert {...args}>
45
- <span class="font-medium">Warning!</span> Please review this information before proceeding.
46
- </Alert>
47
- {/snippet}
48
- </Story>
49
-
50
- <Story name="Error" args={{ color: 'error' }}>
51
- {#snippet template(args)}
52
- <Alert {...args}>
53
- <span class="font-medium">Error!</span> Something went wrong. Please try again.
54
- </Alert>
55
- {/snippet}
56
- </Story>
57
-
58
- <Story name="Dismissible">
59
- {#snippet template()}
60
- <div class="space-y-4">
61
- <Alert color="info" dismissible>
62
- Click the X to dismiss this alert.
63
- </Alert>
64
- <Alert color="success" dismissible>
65
- This success alert can also be dismissed.
66
- </Alert>
67
- </div>
68
- {/snippet}
69
- </Story>
70
-
71
- <Story name="All Variants">
72
- {#snippet template()}
73
- <div class="space-y-4">
74
- <Alert color="info">
75
- <span class="font-medium">Info:</span> Just letting you know about something.
76
- </Alert>
77
- <Alert color="success">
78
- <span class="font-medium">Success:</span> Great job! Everything worked.
79
- </Alert>
80
- <Alert color="warning">
81
- <span class="font-medium">Warning:</span> Be careful about this action.
82
- </Alert>
83
- <Alert color="error">
84
- <span class="font-medium">Error:</span> Something went wrong.
85
- </Alert>
86
- </div>
87
- {/snippet}
88
- </Story>
1
+ <script module>
2
+ import { defineMeta } from '@storybook/addon-svelte-csf';
3
+ import Alert from './Alert.svelte';
4
+
5
+ const { Story } = defineMeta({
6
+ title: 'Primitives/Alert',
7
+ component: Alert,
8
+ tags: ['autodocs'],
9
+ argTypes: {
10
+ color: {
11
+ control: 'select',
12
+ options: ['info', 'success', 'warning', 'error'],
13
+ },
14
+ dismissible: { control: 'boolean' },
15
+ },
16
+ parameters: {
17
+ docs: {
18
+ description: {
19
+ component: 'Contextual feedback messages for user actions or system states.',
20
+ },
21
+ },
22
+ },
23
+ });
24
+ </script>
25
+
26
+ <Story name="Info" args={{ color: 'info' }}>
27
+ {#snippet template(args)}
28
+ <Alert {...args}>
29
+ <span class="font-medium">Info!</span> This is an informational alert with helpful information.
30
+ </Alert>
31
+ {/snippet}
32
+ </Story>
33
+
34
+ <Story name="Success" args={{ color: 'success' }}>
35
+ {#snippet template(args)}
36
+ <Alert {...args}>
37
+ <span class="font-medium">Success!</span> Your changes have been saved successfully.
38
+ </Alert>
39
+ {/snippet}
40
+ </Story>
41
+
42
+ <Story name="Warning" args={{ color: 'warning' }}>
43
+ {#snippet template(args)}
44
+ <Alert {...args}>
45
+ <span class="font-medium">Warning!</span> Please review this information before proceeding.
46
+ </Alert>
47
+ {/snippet}
48
+ </Story>
49
+
50
+ <Story name="Error" args={{ color: 'error' }}>
51
+ {#snippet template(args)}
52
+ <Alert {...args}>
53
+ <span class="font-medium">Error!</span> Something went wrong. Please try again.
54
+ </Alert>
55
+ {/snippet}
56
+ </Story>
57
+
58
+ <Story name="Dismissible">
59
+ {#snippet template()}
60
+ <div class="space-y-4">
61
+ <Alert color="info" dismissible>
62
+ Click the X to dismiss this alert.
63
+ </Alert>
64
+ <Alert color="success" dismissible>
65
+ This success alert can also be dismissed.
66
+ </Alert>
67
+ </div>
68
+ {/snippet}
69
+ </Story>
70
+
71
+ <Story name="All Variants">
72
+ {#snippet template()}
73
+ <div class="space-y-4">
74
+ <Alert color="info">
75
+ <span class="font-medium">Info:</span> Just letting you know about something.
76
+ </Alert>
77
+ <Alert color="success">
78
+ <span class="font-medium">Success:</span> Great job! Everything worked.
79
+ </Alert>
80
+ <Alert color="warning">
81
+ <span class="font-medium">Warning:</span> Be careful about this action.
82
+ </Alert>
83
+ <Alert color="error">
84
+ <span class="font-medium">Error:</span> Something went wrong.
85
+ </Alert>
86
+ </div>
87
+ {/snippet}
88
+ </Story>
@@ -29,36 +29,36 @@
29
29
 
30
30
  let alertClasses = $derived(alertColorVariants[type] || alertColorVariants.info);
31
31
  let closeButtonClasses = $derived(alertCloseButtonVariants[type] || alertCloseButtonVariants.info);
32
-
33
- function handleClose() {
34
- onClose?.();
35
- onclose?.();
36
- }
37
-
38
- let showCloseButton = $derived(onClose !== undefined || onclose !== undefined);
39
- </script>
40
-
41
- <div class="flex items-center p-4 mb-4 text-sm rounded-lg {alertClasses}" role="alert" {...restProps}>
42
- <InfoCircleOutline class="shrink-0 w-4 h-4 me-3" />
43
- <span class="sr-only">{type}</span>
44
- <div class="flex-1">
45
- {#if title}
46
- <span class="font-medium">{title}</span>
47
- {/if}
48
- {#if message}
49
- <span class:mt-1={title}>{message}</span>
50
- {/if}
51
- {#if children}{@render children()}{/if}
52
- </div>
53
- {#if showCloseButton}
32
+
33
+ function handleClose() {
34
+ onClose?.();
35
+ onclose?.();
36
+ }
37
+
38
+ let showCloseButton = $derived(onClose !== undefined || onclose !== undefined);
39
+ </script>
40
+
41
+ <div class="flex items-center p-4 mb-4 text-sm rounded-lg {alertClasses}" role="alert" {...restProps}>
42
+ <InfoCircleOutline class="shrink-0 w-4 h-4 me-3" />
43
+ <span class="sr-only">{type}</span>
44
+ <div class="flex-1">
45
+ {#if title}
46
+ <span class="font-medium">{title}</span>
47
+ {/if}
48
+ {#if message}
49
+ <span class:mt-1={title}>{message}</span>
50
+ {/if}
51
+ {#if children}{@render children()}{/if}
52
+ </div>
53
+ {#if showCloseButton}
54
54
  <button
55
55
  type="button"
56
56
  class="ms-auto -mx-1.5 -my-1.5 rounded-lg focus:ring-2 p-1.5 inline-flex items-center justify-center h-8 w-8 {closeButtonClasses}"
57
57
  aria-label="Close"
58
58
  onclick={handleClose}
59
59
  >
60
- <span class="sr-only">Close</span>
61
- <CloseOutline class="w-3 h-3" />
62
- </button>
63
- {/if}
64
- </div>
60
+ <span class="sr-only">Close</span>
61
+ <CloseOutline class="w-3 h-3" />
62
+ </button>
63
+ {/if}
64
+ </div>
@@ -1,94 +1,94 @@
1
- <script module>
2
- import { defineMeta } from '@storybook/addon-svelte-csf';
3
- import Avatar from './Avatar.svelte';
4
-
5
- const { Story } = defineMeta({
6
- title: 'Primitives/Avatar',
7
- component: Avatar,
8
- tags: ['autodocs'],
9
- argTypes: {
10
- size: {
11
- control: 'select',
12
- options: ['xs', 'sm', 'md', 'lg', 'xl'],
13
- },
14
- src: { control: 'text' },
15
- alt: { control: 'text' },
16
- initials: { control: 'text' },
17
- },
18
- parameters: {
19
- docs: {
20
- description: {
21
- component: 'User profile picture component with fallback to initials.',
22
- },
23
- },
24
- },
25
- });
26
- </script>
27
-
28
- <Story name="Default">
29
- {#snippet template()}
30
- <Avatar />
31
- {/snippet}
32
- </Story>
33
-
34
- <Story name="With Initials" args={{ initials: 'JD' }}>
35
- {#snippet template(args)}
36
- <Avatar {...args} />
37
- {/snippet}
38
- </Story>
39
-
40
- <Story name="With Image" args={{ src: 'data:image/svg+xml,' + encodeURIComponent('<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 150 150"><rect width="150" height="150" fill="#6366f1"/><circle cx="75" cy="55" r="30" fill="#fff"/><ellipse cx="75" cy="130" rx="45" ry="35" fill="#fff"/></svg>'), alt: 'User avatar' }}>
41
- {#snippet template(args)}
42
- <Avatar {...args} />
43
- {/snippet}
44
- </Story>
45
-
46
- <Story name="All Sizes">
47
- {#snippet template()}
48
- <div class="flex items-end gap-4">
49
- <div class="text-center">
50
- <Avatar size="xs" initials="XS" />
51
- <p class="text-xs text-gray-500 mt-1">xs</p>
52
- </div>
53
- <div class="text-center">
54
- <Avatar size="sm" initials="SM" />
55
- <p class="text-xs text-gray-500 mt-1">sm</p>
56
- </div>
57
- <div class="text-center">
58
- <Avatar size="md" initials="MD" />
59
- <p class="text-xs text-gray-500 mt-1">md</p>
60
- </div>
61
- <div class="text-center">
62
- <Avatar size="lg" initials="LG" />
63
- <p class="text-xs text-gray-500 mt-1">lg</p>
64
- </div>
65
- <div class="text-center">
66
- <Avatar size="xl" initials="XL" />
67
- <p class="text-xs text-gray-500 mt-1">xl</p>
68
- </div>
69
- </div>
70
- {/snippet}
71
- </Story>
72
-
73
- <Story name="Image Sizes">
74
- {#snippet template()}
75
- <div class="flex items-end gap-4">
76
- <Avatar size="xs" src="data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 150 150'%3E%3Crect width='150' height='150' fill='%236366f1'/%3E%3Ccircle cx='75' cy='55' r='30' fill='%23fff'/%3E%3Cellipse cx='75' cy='130' rx='45' ry='35' fill='%23fff'/%3E%3C/svg%3E?demo=1" />
77
- <Avatar size="sm" src="data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 150 150'%3E%3Crect width='150' height='150' fill='%236366f1'/%3E%3Ccircle cx='75' cy='55' r='30' fill='%23fff'/%3E%3Cellipse cx='75' cy='130' rx='45' ry='35' fill='%23fff'/%3E%3C/svg%3E?demo=2" />
78
- <Avatar size="md" src="data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 150 150'%3E%3Crect width='150' height='150' fill='%236366f1'/%3E%3Ccircle cx='75' cy='55' r='30' fill='%23fff'/%3E%3Cellipse cx='75' cy='130' rx='45' ry='35' fill='%23fff'/%3E%3C/svg%3E?demo=3" />
79
- <Avatar size="lg" src="data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 150 150'%3E%3Crect width='150' height='150' fill='%236366f1'/%3E%3Ccircle cx='75' cy='55' r='30' fill='%23fff'/%3E%3Cellipse cx='75' cy='130' rx='45' ry='35' fill='%23fff'/%3E%3C/svg%3E?demo=4" />
80
- <Avatar size="xl" src="data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 150 150'%3E%3Crect width='150' height='150' fill='%236366f1'/%3E%3Ccircle cx='75' cy='55' r='30' fill='%23fff'/%3E%3Cellipse cx='75' cy='130' rx='45' ry='35' fill='%23fff'/%3E%3C/svg%3E?demo=5" />
81
- </div>
82
- {/snippet}
83
- </Story>
84
-
85
- <Story name="Group">
86
- {#snippet template()}
87
- <div class="flex -space-x-4">
88
- <Avatar src="data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 150 150'%3E%3Crect width='150' height='150' fill='%236366f1'/%3E%3Ccircle cx='75' cy='55' r='30' fill='%23fff'/%3E%3Cellipse cx='75' cy='130' rx='45' ry='35' fill='%23fff'/%3E%3C/svg%3E?demo=1" class="ring-2 ring-white" />
89
- <Avatar src="data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 150 150'%3E%3Crect width='150' height='150' fill='%236366f1'/%3E%3Ccircle cx='75' cy='55' r='30' fill='%23fff'/%3E%3Cellipse cx='75' cy='130' rx='45' ry='35' fill='%23fff'/%3E%3C/svg%3E?demo=2" class="ring-2 ring-white" />
90
- <Avatar src="data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 150 150'%3E%3Crect width='150' height='150' fill='%236366f1'/%3E%3Ccircle cx='75' cy='55' r='30' fill='%23fff'/%3E%3Cellipse cx='75' cy='130' rx='45' ry='35' fill='%23fff'/%3E%3C/svg%3E?demo=3" class="ring-2 ring-white" />
91
- <Avatar initials="+5" class="ring-2 ring-white" />
92
- </div>
93
- {/snippet}
94
- </Story>
1
+ <script module>
2
+ import { defineMeta } from '@storybook/addon-svelte-csf';
3
+ import Avatar from './Avatar.svelte';
4
+
5
+ const { Story } = defineMeta({
6
+ title: 'Primitives/Avatar',
7
+ component: Avatar,
8
+ tags: ['autodocs'],
9
+ argTypes: {
10
+ size: {
11
+ control: 'select',
12
+ options: ['xs', 'sm', 'md', 'lg', 'xl'],
13
+ },
14
+ src: { control: 'text' },
15
+ alt: { control: 'text' },
16
+ initials: { control: 'text' },
17
+ },
18
+ parameters: {
19
+ docs: {
20
+ description: {
21
+ component: 'User profile picture component with fallback to initials.',
22
+ },
23
+ },
24
+ },
25
+ });
26
+ </script>
27
+
28
+ <Story name="Default">
29
+ {#snippet template()}
30
+ <Avatar />
31
+ {/snippet}
32
+ </Story>
33
+
34
+ <Story name="With Initials" args={{ initials: 'JD' }}>
35
+ {#snippet template(args)}
36
+ <Avatar {...args} />
37
+ {/snippet}
38
+ </Story>
39
+
40
+ <Story name="With Image" args={{ src: 'data:image/svg+xml,' + encodeURIComponent('<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 150 150"><rect width="150" height="150" fill="#6366f1"/><circle cx="75" cy="55" r="30" fill="#fff"/><ellipse cx="75" cy="130" rx="45" ry="35" fill="#fff"/></svg>'), alt: 'User avatar' }}>
41
+ {#snippet template(args)}
42
+ <Avatar {...args} />
43
+ {/snippet}
44
+ </Story>
45
+
46
+ <Story name="All Sizes">
47
+ {#snippet template()}
48
+ <div class="flex items-end gap-4">
49
+ <div class="text-center">
50
+ <Avatar size="xs" initials="XS" />
51
+ <p class="text-xs text-gray-500 mt-1">xs</p>
52
+ </div>
53
+ <div class="text-center">
54
+ <Avatar size="sm" initials="SM" />
55
+ <p class="text-xs text-gray-500 mt-1">sm</p>
56
+ </div>
57
+ <div class="text-center">
58
+ <Avatar size="md" initials="MD" />
59
+ <p class="text-xs text-gray-500 mt-1">md</p>
60
+ </div>
61
+ <div class="text-center">
62
+ <Avatar size="lg" initials="LG" />
63
+ <p class="text-xs text-gray-500 mt-1">lg</p>
64
+ </div>
65
+ <div class="text-center">
66
+ <Avatar size="xl" initials="XL" />
67
+ <p class="text-xs text-gray-500 mt-1">xl</p>
68
+ </div>
69
+ </div>
70
+ {/snippet}
71
+ </Story>
72
+
73
+ <Story name="Image Sizes">
74
+ {#snippet template()}
75
+ <div class="flex items-end gap-4">
76
+ <Avatar size="xs" src="data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 150 150'%3E%3Crect width='150' height='150' fill='%236366f1'/%3E%3Ccircle cx='75' cy='55' r='30' fill='%23fff'/%3E%3Cellipse cx='75' cy='130' rx='45' ry='35' fill='%23fff'/%3E%3C/svg%3E?demo=1" />
77
+ <Avatar size="sm" src="data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 150 150'%3E%3Crect width='150' height='150' fill='%236366f1'/%3E%3Ccircle cx='75' cy='55' r='30' fill='%23fff'/%3E%3Cellipse cx='75' cy='130' rx='45' ry='35' fill='%23fff'/%3E%3C/svg%3E?demo=2" />
78
+ <Avatar size="md" src="data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 150 150'%3E%3Crect width='150' height='150' fill='%236366f1'/%3E%3Ccircle cx='75' cy='55' r='30' fill='%23fff'/%3E%3Cellipse cx='75' cy='130' rx='45' ry='35' fill='%23fff'/%3E%3C/svg%3E?demo=3" />
79
+ <Avatar size="lg" src="data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 150 150'%3E%3Crect width='150' height='150' fill='%236366f1'/%3E%3Ccircle cx='75' cy='55' r='30' fill='%23fff'/%3E%3Cellipse cx='75' cy='130' rx='45' ry='35' fill='%23fff'/%3E%3C/svg%3E?demo=4" />
80
+ <Avatar size="xl" src="data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 150 150'%3E%3Crect width='150' height='150' fill='%236366f1'/%3E%3Ccircle cx='75' cy='55' r='30' fill='%23fff'/%3E%3Cellipse cx='75' cy='130' rx='45' ry='35' fill='%23fff'/%3E%3C/svg%3E?demo=5" />
81
+ </div>
82
+ {/snippet}
83
+ </Story>
84
+
85
+ <Story name="Group">
86
+ {#snippet template()}
87
+ <div class="flex -space-x-4">
88
+ <Avatar src="data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 150 150'%3E%3Crect width='150' height='150' fill='%236366f1'/%3E%3Ccircle cx='75' cy='55' r='30' fill='%23fff'/%3E%3Cellipse cx='75' cy='130' rx='45' ry='35' fill='%23fff'/%3E%3C/svg%3E?demo=1" class="ring-2 ring-white" />
89
+ <Avatar src="data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 150 150'%3E%3Crect width='150' height='150' fill='%236366f1'/%3E%3Ccircle cx='75' cy='55' r='30' fill='%23fff'/%3E%3Cellipse cx='75' cy='130' rx='45' ry='35' fill='%23fff'/%3E%3C/svg%3E?demo=2" class="ring-2 ring-white" />
90
+ <Avatar src="data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 150 150'%3E%3Crect width='150' height='150' fill='%236366f1'/%3E%3Ccircle cx='75' cy='55' r='30' fill='%23fff'/%3E%3Cellipse cx='75' cy='130' rx='45' ry='35' fill='%23fff'/%3E%3C/svg%3E?demo=3" class="ring-2 ring-white" />
91
+ <Avatar initials="+5" class="ring-2 ring-white" />
92
+ </div>
93
+ {/snippet}
94
+ </Story>
@@ -1,66 +1,66 @@
1
- <script lang="ts">
2
- /**
3
- * Avatar Component - Flowbite-style native implementation
4
- *
5
- * Displays a user avatar image with optional fallback initials
6
- */
7
-
8
- interface Props {
9
- /** Image source URL */
10
- src?: string;
11
- /** Alt text for the image */
12
- alt?: string;
13
- /** Whether to use rounded (circle) shape */
14
- rounded?: boolean;
15
- /** Size variant */
16
- size?: 'xs' | 'sm' | 'md' | 'lg' | 'xl';
17
- /** Fallback initials when no image */
18
- initials?: string;
19
- /** Additional CSS classes */
20
- class?: string;
21
- }
22
-
23
- let {
24
- src = '',
25
- alt = '',
26
- rounded = false,
27
- size = 'md',
28
- initials = '',
29
- class: className = ''
30
- }: Props = $props();
31
-
32
- // Size classes
33
- const sizeClasses: Record<string, string> = {
34
- xs: 'w-6 h-6 text-xs',
35
- sm: 'w-8 h-8 text-xs',
36
- md: 'w-10 h-10 text-sm',
37
- lg: 'w-14 h-14 text-base',
38
- xl: 'w-20 h-20 text-lg'
39
- };
40
-
41
- let sizeClass = $derived(sizeClasses[size] || sizeClasses.md);
42
- let roundedClass = $derived(rounded ? 'rounded-full' : 'rounded');
43
- </script>
44
-
45
- {#if src}
46
- <img
47
- {src}
48
- {alt}
49
- class="object-cover {sizeClass} {roundedClass} {className}"
50
- />
51
- {:else if initials}
52
- <div
53
- class="flex items-center justify-center font-medium text-gray-600 bg-gray-200 dark:bg-gray-700 dark:text-gray-300 {sizeClass} {roundedClass} {className}"
54
- >
55
- {initials}
56
- </div>
57
- {:else}
58
- <!-- Default placeholder -->
59
- <div
60
- class="flex items-center justify-center bg-gray-200 dark:bg-gray-700 {sizeClass} {roundedClass} {className}"
61
- >
62
- <svg class="w-1/2 h-1/2 text-gray-400" fill="currentColor" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg">
63
- <path fill-rule="evenodd" d="M10 9a3 3 0 100-6 3 3 0 000 6zm-7 9a7 7 0 1114 0H3z" clip-rule="evenodd"></path>
64
- </svg>
65
- </div>
66
- {/if}
1
+ <script lang="ts">
2
+ /**
3
+ * Avatar Component - Flowbite-style native implementation
4
+ *
5
+ * Displays a user avatar image with optional fallback initials
6
+ */
7
+
8
+ interface Props {
9
+ /** Image source URL */
10
+ src?: string;
11
+ /** Alt text for the image */
12
+ alt?: string;
13
+ /** Whether to use rounded (circle) shape */
14
+ rounded?: boolean;
15
+ /** Size variant */
16
+ size?: 'xs' | 'sm' | 'md' | 'lg' | 'xl';
17
+ /** Fallback initials when no image */
18
+ initials?: string;
19
+ /** Additional CSS classes */
20
+ class?: string;
21
+ }
22
+
23
+ let {
24
+ src = '',
25
+ alt = '',
26
+ rounded = false,
27
+ size = 'md',
28
+ initials = '',
29
+ class: className = ''
30
+ }: Props = $props();
31
+
32
+ // Size classes
33
+ const sizeClasses: Record<string, string> = {
34
+ xs: 'w-6 h-6 text-xs',
35
+ sm: 'w-8 h-8 text-xs',
36
+ md: 'w-10 h-10 text-sm',
37
+ lg: 'w-14 h-14 text-base',
38
+ xl: 'w-20 h-20 text-lg'
39
+ };
40
+
41
+ let sizeClass = $derived(sizeClasses[size] || sizeClasses.md);
42
+ let roundedClass = $derived(rounded ? 'rounded-full' : 'rounded');
43
+ </script>
44
+
45
+ {#if src}
46
+ <img
47
+ {src}
48
+ {alt}
49
+ class="object-cover {sizeClass} {roundedClass} {className}"
50
+ />
51
+ {:else if initials}
52
+ <div
53
+ class="flex items-center justify-center font-medium text-gray-600 bg-gray-200 dark:bg-gray-700 dark:text-gray-300 {sizeClass} {roundedClass} {className}"
54
+ >
55
+ {initials}
56
+ </div>
57
+ {:else}
58
+ <!-- Default placeholder -->
59
+ <div
60
+ class="flex items-center justify-center bg-gray-200 dark:bg-gray-700 {sizeClass} {roundedClass} {className}"
61
+ >
62
+ <svg class="w-1/2 h-1/2 text-gray-400" fill="currentColor" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg">
63
+ <path fill-rule="evenodd" d="M10 9a3 3 0 100-6 3 3 0 000 6zm-7 9a7 7 0 1114 0H3z" clip-rule="evenodd"></path>
64
+ </svg>
65
+ </div>
66
+ {/if}