@getmicdrop/svelte-components 5.4.2 → 5.5.0

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 (217) 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 +134 -134
  7. package/dist/calendar/ShowCard/ShowCard.svelte +157 -157
  8. package/dist/calendar/ShowTimeCard/ShowTimeCard.svelte +61 -61
  9. package/dist/components/Layout/Grid.svelte +4 -4
  10. package/dist/components/Layout/Section.svelte +80 -80
  11. package/dist/components/Layout/Sidebar.svelte +108 -108
  12. package/dist/components/Layout/Stack.svelte +6 -6
  13. package/dist/constants/validation.js +91 -91
  14. package/dist/constants/validation.spec.js +64 -64
  15. package/dist/index.d.ts +113 -4
  16. package/dist/index.js +226 -47
  17. package/dist/patterns/data/DataGrid.svelte +45 -45
  18. package/dist/patterns/data/DataList.svelte +24 -24
  19. package/dist/patterns/data/DataTable.svelte +36 -36
  20. package/dist/patterns/forms/FormActions.spec.js +88 -88
  21. package/dist/patterns/forms/FormActions.stories.svelte +97 -97
  22. package/dist/patterns/forms/FormActions.svelte +46 -46
  23. package/dist/patterns/forms/FormGrid.svelte +33 -33
  24. package/dist/patterns/forms/FormSection.svelte +32 -32
  25. package/dist/patterns/forms/FormValidationSummary.stories.svelte +83 -83
  26. package/dist/patterns/forms/FormValidationSummary.svelte +32 -32
  27. package/dist/patterns/layout/Sidebar.svelte +39 -39
  28. package/dist/patterns/navigation/BottomNav.stories.svelte +117 -117
  29. package/dist/patterns/navigation/BottomNav.svelte +20 -20
  30. package/dist/patterns/navigation/Header.stories.svelte +77 -77
  31. package/dist/patterns/navigation/Header.svelte +193 -193
  32. package/dist/patterns/page/PageHeader.svelte +18 -18
  33. package/dist/patterns/page/PageLayout.svelte +40 -40
  34. package/dist/patterns/page/PageLoader.spec.js +54 -54
  35. package/dist/patterns/page/PageLoader.stories.svelte +137 -137
  36. package/dist/patterns/page/PageLoader.svelte +24 -24
  37. package/dist/patterns/page/SectionHeader.svelte +29 -29
  38. package/dist/presets/badges.js +112 -112
  39. package/dist/presets/buttons.js +76 -76
  40. package/dist/presets/index.js +9 -9
  41. package/dist/primitives/Accordion/Accordion.stories.svelte +75 -75
  42. package/dist/primitives/Accordion/Accordion.svelte +42 -42
  43. package/dist/primitives/Accordion/AccordionItem.svelte +95 -95
  44. package/dist/primitives/Alert/Alert.spec.js +170 -170
  45. package/dist/primitives/Alert/Alert.stories.svelte +88 -88
  46. package/dist/primitives/Alert/Alert.svelte +27 -27
  47. package/dist/primitives/Avatar/Avatar.stories.svelte +94 -94
  48. package/dist/primitives/Avatar/Avatar.svelte +66 -66
  49. package/dist/primitives/Badges/Badge.spec.js +103 -103
  50. package/dist/primitives/Badges/Badge.stories.svelte +86 -86
  51. package/dist/primitives/Badges/Badge.svelte +79 -79
  52. package/dist/primitives/BottomSheet/BottomSheet.spec.js +127 -127
  53. package/dist/primitives/BottomSheet/BottomSheet.stories.svelte +83 -83
  54. package/dist/primitives/BottomSheet/BottomSheet.svelte +100 -100
  55. package/dist/primitives/Breadcrumb/Breadcrumb.spec.js +120 -120
  56. package/dist/primitives/Breadcrumb/Breadcrumb.stories.svelte +23 -23
  57. package/dist/primitives/Breadcrumb/Breadcrumb.svelte +89 -89
  58. package/dist/primitives/Button/Button.spec.js +211 -211
  59. package/dist/primitives/Button/Button.stories.svelte +76 -76
  60. package/dist/primitives/Button/Button.svelte +270 -269
  61. package/dist/primitives/Button/Button.svelte.d.ts.map +1 -1
  62. package/dist/primitives/Button/ButtonSaveDemo.spec.js +48 -48
  63. package/dist/primitives/Button/ButtonSaveDemo.svelte +25 -25
  64. package/dist/primitives/Button/ButtonVariantShowcase.svelte +129 -129
  65. package/dist/primitives/Card.spec.js +49 -49
  66. package/dist/primitives/Card.stories.svelte +22 -22
  67. package/dist/primitives/Card.svelte +28 -28
  68. package/dist/primitives/Checkbox/Checkbox.stories.svelte +84 -84
  69. package/dist/primitives/Checkbox/Checkbox.svelte +88 -88
  70. package/dist/primitives/DarkModeToggle.spec.js +357 -357
  71. package/dist/primitives/DarkModeToggle.stories.svelte +57 -57
  72. package/dist/primitives/DarkModeToggle.svelte +136 -136
  73. package/dist/primitives/Drawer/Drawer.stories.svelte +80 -80
  74. package/dist/primitives/Drawer/Drawer.svelte +120 -120
  75. package/dist/primitives/Dropdown/Dropdown.stories.svelte +137 -137
  76. package/dist/primitives/Dropdown/Dropdown.svelte +14 -14
  77. package/dist/primitives/Dropdown/DropdownItem.svelte +80 -80
  78. package/dist/primitives/Icons/ArrowLeft.svelte +8 -8
  79. package/dist/primitives/Icons/ArrowRight.svelte +8 -8
  80. package/dist/primitives/Icons/Availability.svelte +14 -14
  81. package/dist/primitives/Icons/Back.svelte +14 -14
  82. package/dist/primitives/Icons/CheckCircle.svelte +6 -6
  83. package/dist/primitives/Icons/CheckCircleOutline.svelte +15 -15
  84. package/dist/primitives/Icons/ChevronLeft.svelte +4 -4
  85. package/dist/primitives/Icons/ChevronRight.svelte +4 -4
  86. package/dist/primitives/Icons/Copy.svelte +15 -15
  87. package/dist/primitives/Icons/Cross.svelte +5 -5
  88. package/dist/primitives/Icons/DownArrow.svelte +8 -8
  89. package/dist/primitives/Icons/ErrorCircle.svelte +6 -6
  90. package/dist/primitives/Icons/FacebookIcon.svelte +2 -2
  91. package/dist/primitives/Icons/Home.svelte +15 -15
  92. package/dist/primitives/Icons/Icon.spec.js +169 -169
  93. package/dist/primitives/Icons/Icon.stories.svelte +100 -100
  94. package/dist/primitives/Icons/Icon.svelte +52 -52
  95. package/dist/primitives/Icons/IconGallery.stories.svelte +235 -235
  96. package/dist/primitives/Icons/Info.svelte +7 -7
  97. package/dist/primitives/Icons/InstagramIcon.svelte +4 -4
  98. package/dist/primitives/Icons/LogoInstagram.svelte +2 -2
  99. package/dist/primitives/Icons/Message.svelte +15 -15
  100. package/dist/primitives/Icons/MoonIcon.svelte +5 -5
  101. package/dist/primitives/Icons/More.svelte +21 -21
  102. package/dist/primitives/Icons/MoreHori.spec.js +61 -61
  103. package/dist/primitives/Icons/MoreHori.svelte +22 -22
  104. package/dist/primitives/Icons/Notification.svelte +14 -14
  105. package/dist/primitives/Icons/Payment.svelte +14 -14
  106. package/dist/primitives/Icons/Profile.svelte +21 -21
  107. package/dist/primitives/Icons/Reload.svelte +29 -29
  108. package/dist/primitives/Icons/Shows.svelte +21 -21
  109. package/dist/primitives/Icons/Signout.svelte +21 -21
  110. package/dist/primitives/Icons/SunIcon.svelte +8 -8
  111. package/dist/primitives/Icons/TiktokIcon.svelte +2 -2
  112. package/dist/primitives/Icons/TwitterIcon.svelte +2 -2
  113. package/dist/primitives/Icons/WarningIcon.spec.js +18 -18
  114. package/dist/primitives/Icons/WarningIcon.svelte +5 -5
  115. package/dist/primitives/Input/Input.spec.js +573 -573
  116. package/dist/primitives/Input/Input.stories.svelte +139 -139
  117. package/dist/primitives/Input/Input.svelte +391 -391
  118. package/dist/primitives/Input/Select.spec.js +218 -218
  119. package/dist/primitives/Input/Select.stories.svelte +112 -112
  120. package/dist/primitives/Input/Select.svelte +128 -128
  121. package/dist/primitives/Input/Textarea.stories.svelte +137 -137
  122. package/dist/primitives/Input/Textarea.svelte +35 -35
  123. package/dist/primitives/Label/Label.svelte +37 -37
  124. package/dist/primitives/Modal/Modal.spec.js +95 -95
  125. package/dist/primitives/Modal/Modal.stories.svelte +86 -86
  126. package/dist/primitives/Modal/Modal.svelte +158 -158
  127. package/dist/primitives/NumberInput/NumberInput.svelte +106 -0
  128. package/dist/primitives/NumberInput/NumberInput.svelte.d.ts +23 -0
  129. package/dist/primitives/NumberInput/NumberInput.svelte.d.ts.map +1 -0
  130. package/dist/primitives/NumberInput/index.d.ts +2 -0
  131. package/dist/primitives/NumberInput/index.d.ts.map +1 -0
  132. package/dist/primitives/NumberInput/index.js +1 -0
  133. package/dist/primitives/Pagination/Pagination.stories.svelte +76 -76
  134. package/dist/primitives/Pagination/Pagination.svelte +261 -261
  135. package/dist/primitives/Radio/Radio.stories.svelte +80 -80
  136. package/dist/primitives/Radio/Radio.svelte +67 -67
  137. package/dist/primitives/Skeleton/CardPlaceholder.svelte +87 -87
  138. package/dist/primitives/Skeleton/ImagePlaceholder.svelte +59 -59
  139. package/dist/primitives/Skeleton/ListPlaceholder.svelte +76 -76
  140. package/dist/primitives/Skeleton/Skeleton.stories.svelte +151 -151
  141. package/dist/primitives/Skeleton/Skeleton.svelte +26 -26
  142. package/dist/primitives/Spinner/Spinner.spec.js +75 -75
  143. package/dist/primitives/Spinner/Spinner.stories.svelte +29 -29
  144. package/dist/primitives/Spinner/Spinner.svelte +20 -20
  145. package/dist/primitives/Tabs/TabItem.svelte +49 -49
  146. package/dist/primitives/Tabs/Tabs.stories.svelte +112 -112
  147. package/dist/primitives/Tabs/Tabs.svelte +123 -123
  148. package/dist/primitives/Toggle.spec.js +127 -127
  149. package/dist/primitives/Toggle.stories.svelte +92 -92
  150. package/dist/primitives/Toggle.svelte +71 -71
  151. package/dist/primitives/Typography/Typography.svelte +53 -53
  152. package/dist/primitives/ValidationError.spec.js +103 -103
  153. package/dist/primitives/ValidationError.stories.svelte +69 -69
  154. package/dist/primitives/ValidationError.svelte +29 -29
  155. package/dist/recipes/CropImage/CropImage.spec.js +216 -216
  156. package/dist/recipes/CropImage/CropImage.stories.svelte +104 -104
  157. package/dist/recipes/CropImage/CropImage.svelte +238 -238
  158. package/dist/recipes/ImageUploader/ImageUploader.stories.svelte +125 -125
  159. package/dist/recipes/ImageUploader/ImageUploader.svelte +804 -804
  160. package/dist/recipes/Toaster/Toaster.stories.svelte +62 -62
  161. package/dist/recipes/feedback/EmptyState/EmptyState.svelte +1 -1
  162. package/dist/recipes/feedback/ErrorDisplay.spec.js +69 -69
  163. package/dist/recipes/feedback/ErrorDisplay.stories.svelte +101 -101
  164. package/dist/recipes/feedback/ErrorDisplay.svelte +1 -1
  165. package/dist/recipes/feedback/StatusIndicator/StatusIndicator.spec.js +129 -129
  166. package/dist/recipes/feedback/StatusIndicator/StatusIndicator.svelte +157 -157
  167. package/dist/recipes/fields/CheckboxField.svelte +85 -85
  168. package/dist/recipes/fields/FormField.svelte +58 -58
  169. package/dist/recipes/fields/RadioGroup.svelte +95 -95
  170. package/dist/recipes/fields/SelectField.svelte +80 -80
  171. package/dist/recipes/fields/TextareaField.svelte +97 -97
  172. package/dist/recipes/fields/ToggleField.svelte +60 -60
  173. package/dist/recipes/fields/index.js +7 -7
  174. package/dist/recipes/inputs/MultiSelect.spec.js +257 -257
  175. package/dist/recipes/inputs/MultiSelect.stories.svelte +133 -133
  176. package/dist/recipes/inputs/MultiSelect.svelte +249 -276
  177. package/dist/recipes/inputs/MultiSelect.svelte.d.ts +28 -17
  178. package/dist/recipes/inputs/MultiSelect.svelte.d.ts.map +1 -1
  179. package/dist/recipes/inputs/OTPInput.spec.js +238 -238
  180. package/dist/recipes/inputs/OTPInput.stories.svelte +162 -162
  181. package/dist/recipes/inputs/OTPInput.svelte +29 -29
  182. package/dist/recipes/inputs/PasswordInput.svelte +22 -22
  183. package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.spec.js +173 -173
  184. package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.svelte +42 -42
  185. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.spec.js +300 -300
  186. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.stories.svelte +123 -123
  187. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte +326 -326
  188. package/dist/recipes/inputs/Search.svelte +37 -37
  189. package/dist/recipes/inputs/SelectDropdown.svelte +57 -57
  190. package/dist/recipes/modals/AlertModal.svelte +130 -130
  191. package/dist/recipes/modals/ConfirmationModal.spec.js +191 -191
  192. package/dist/recipes/modals/ConfirmationModal.stories.svelte +119 -119
  193. package/dist/recipes/modals/ConfirmationModal.svelte +152 -152
  194. package/dist/recipes/modals/InputModal.svelte +182 -182
  195. package/dist/recipes/modals/ModalStateManager.spec.js +100 -100
  196. package/dist/recipes/modals/ModalStateManager.svelte +77 -77
  197. package/dist/recipes/modals/ModalTestWrapper.svelte +65 -65
  198. package/dist/recipes/modals/StatusModal.svelte +206 -206
  199. package/dist/services/EventService.js +75 -75
  200. package/dist/services/EventService.spec.js +217 -217
  201. package/dist/services/ShowService.spec.js +342 -342
  202. package/dist/stores/auth.js +36 -36
  203. package/dist/stores/auth.spec.js +139 -139
  204. package/dist/stores/toaster.js +13 -13
  205. package/dist/stories/ButtonAuditReview.stories.svelte +14 -14
  206. package/dist/stories/ButtonAuditReview.svelte +427 -427
  207. package/dist/stories/PatternsGallery.stories.svelte +19 -19
  208. package/dist/stories/PatternsGallery.svelte +206 -206
  209. package/dist/stories/PrimitivesGallery.stories.svelte +19 -19
  210. package/dist/stories/PrimitivesGallery.svelte +725 -725
  211. package/dist/stories/RecipesGallery.stories.svelte +19 -19
  212. package/dist/stories/RecipesGallery.svelte +271 -271
  213. package/dist/stories/button-audit-manifest.json +11186 -11186
  214. package/dist/tailwind/preset.cjs +82 -82
  215. package/dist/tokens/tokens.css +87 -87
  216. package/dist/utils/utils.js +354 -354
  217. package/package.json +283 -283
@@ -1,29 +1,29 @@
1
- <script module>
2
- import { defineMeta } from "@storybook/addon-svelte-csf";
3
-
4
- import Spinner from "./Spinner.svelte";
5
-
6
- const { Story } = defineMeta({
7
- title: "Components/Spinner",
8
- component: Spinner,
9
- });
10
-
11
- </script>
12
-
13
-
14
- <Story name="Default Spinner">
15
- <Spinner />
16
- </Story>
17
-
18
- <Story name="Spinner in Container">
19
- <div class="flex items-center justify-center h-40 bg-gray-100 dark:bg-gray-700 rounded-lg">
20
- <Spinner />
21
- </div>
22
- </Story>
23
-
24
- <Story name="Spinner with Text">
25
- <div class="flex flex-col items-center gap-4">
26
- <Spinner />
27
- <p class="text-gray-500 dark:text-gray-400">Loading data...</p>
28
- </div>
29
- </Story>
1
+ <script module>
2
+ import { defineMeta } from "@storybook/addon-svelte-csf";
3
+
4
+ import Spinner from "./Spinner.svelte";
5
+
6
+ const { Story } = defineMeta({
7
+ title: "Components/Spinner",
8
+ component: Spinner,
9
+ });
10
+
11
+ </script>
12
+
13
+
14
+ <Story name="Default Spinner">
15
+ <Spinner />
16
+ </Story>
17
+
18
+ <Story name="Spinner in Container">
19
+ <div class="flex items-center justify-center h-40 bg-gray-100 dark:bg-gray-700 rounded-lg">
20
+ <Spinner />
21
+ </div>
22
+ </Story>
23
+
24
+ <Story name="Spinner with Text">
25
+ <div class="flex flex-col items-center gap-4">
26
+ <Spinner />
27
+ <p class="text-gray-500 dark:text-gray-400">Loading data...</p>
28
+ </div>
29
+ </Story>
@@ -22,23 +22,23 @@
22
22
  let sizeClass = $derived(iconSizes[size] || iconSizes.md);
23
23
  let colorClass = $derived(spinnerColorVariants[color] || spinnerColorVariants.blue);
24
24
  </script>
25
-
26
- <svg
27
- aria-hidden="true"
28
- class="{sizeClass} text-gray-200 animate-spin dark:text-gray-600 {colorClass} {className}"
29
- viewBox="0 0 100 101"
30
- fill="none"
31
- xmlns="http://www.w3.org/2000/svg"
32
- role="status"
33
- {...restProps}
34
- >
35
- <path
36
- d="M100 50.5908C100 78.2051 77.6142 100.591 50 100.591C22.3858 100.591 0 78.2051 0 50.5908C0 22.9766 22.3858 0.59082 50 0.59082C77.6142 0.59082 100 22.9766 100 50.5908ZM9.08144 50.5908C9.08144 73.1895 27.4013 91.5094 50 91.5094C72.5987 91.5094 90.9186 73.1895 90.9186 50.5908C90.9186 27.9921 72.5987 9.67226 50 9.67226C27.4013 9.67226 9.08144 27.9921 9.08144 50.5908Z"
37
- fill="currentColor"
38
- />
39
- <path
40
- d="M93.9676 39.0409C96.393 38.4038 97.8624 35.9116 97.0079 33.5539C95.2932 28.8227 92.871 24.3692 89.8167 20.348C85.8452 15.1192 80.8826 10.7238 75.2124 7.41289C69.5422 4.10194 63.2754 1.94025 56.7698 1.05124C51.7666 0.367541 46.6976 0.446843 41.7345 1.27873C39.2613 1.69328 37.813 4.19778 38.4501 6.62326C39.0873 9.04874 41.5694 10.4717 44.0505 10.1071C47.8511 9.54855 51.7191 9.52689 55.5402 10.0491C60.8642 10.7766 65.9928 12.5457 70.6331 15.2552C75.2735 17.9648 79.3347 21.5619 82.5849 25.841C84.9175 28.9121 86.7997 32.2913 88.1811 35.8758C89.083 38.2158 91.5421 39.6781 93.9676 39.0409Z"
41
- fill="currentFill"
42
- />
43
- </svg>
44
- <span class="sr-only">Loading...</span>
25
+
26
+ <svg
27
+ aria-hidden="true"
28
+ class="{sizeClass} text-gray-200 animate-spin dark:text-gray-600 {colorClass} {className}"
29
+ viewBox="0 0 100 101"
30
+ fill="none"
31
+ xmlns="http://www.w3.org/2000/svg"
32
+ role="status"
33
+ {...restProps}
34
+ >
35
+ <path
36
+ d="M100 50.5908C100 78.2051 77.6142 100.591 50 100.591C22.3858 100.591 0 78.2051 0 50.5908C0 22.9766 22.3858 0.59082 50 0.59082C77.6142 0.59082 100 22.9766 100 50.5908ZM9.08144 50.5908C9.08144 73.1895 27.4013 91.5094 50 91.5094C72.5987 91.5094 90.9186 73.1895 90.9186 50.5908C90.9186 27.9921 72.5987 9.67226 50 9.67226C27.4013 9.67226 9.08144 27.9921 9.08144 50.5908Z"
37
+ fill="currentColor"
38
+ />
39
+ <path
40
+ d="M93.9676 39.0409C96.393 38.4038 97.8624 35.9116 97.0079 33.5539C95.2932 28.8227 92.871 24.3692 89.8167 20.348C85.8452 15.1192 80.8826 10.7238 75.2124 7.41289C69.5422 4.10194 63.2754 1.94025 56.7698 1.05124C51.7666 0.367541 46.6976 0.446843 41.7345 1.27873C39.2613 1.69328 37.813 4.19778 38.4501 6.62326C39.0873 9.04874 41.5694 10.4717 44.0505 10.1071C47.8511 9.54855 51.7191 9.52689 55.5402 10.0491C60.8642 10.7766 65.9928 12.5457 70.6331 15.2552C75.2735 17.9648 79.3347 21.5619 82.5849 25.841C84.9175 28.9121 86.7997 32.2913 88.1811 35.8758C89.083 38.2158 91.5421 39.6781 93.9676 39.0409Z"
41
+ fill="currentFill"
42
+ />
43
+ </svg>
44
+ <span class="sr-only">Loading...</span>
@@ -1,52 +1,52 @@
1
- <script lang="ts">
2
- import type { Snippet } from 'svelte';
3
- import { getContext, onMount } from "svelte";
4
- import type { Writable } from "svelte/store";
5
-
6
- interface Props {
7
- title?: string;
8
- open?: boolean;
9
- value?: string | number | undefined;
10
- disabled?: boolean;
11
- class?: string;
12
- onclick?: () => void;
13
- children?: Snippet;
14
- [key: string]: unknown;
15
- }
16
-
17
- let {
18
- title = "",
19
- open = false,
20
- value = undefined,
21
- disabled = false,
22
- class: className = "",
23
- onclick,
24
- children,
25
- ...restProps
26
- }: Props = $props();
27
-
28
- const { activeTab, registerTab } = getContext<{
29
- activeTab: Writable<string | number | undefined>;
30
- registerTab: (id: string | number, title: string, open: boolean) => string | number;
31
- }>("tabs");
32
-
1
+ <script lang="ts">
2
+ import type { Snippet } from 'svelte';
3
+ import { getContext, onMount } from "svelte";
4
+ import type { Writable } from "svelte/store";
5
+
6
+ interface Props {
7
+ title?: string;
8
+ open?: boolean;
9
+ value?: string | number | undefined;
10
+ disabled?: boolean;
11
+ class?: string;
12
+ onclick?: () => void;
13
+ children?: Snippet;
14
+ [key: string]: unknown;
15
+ }
16
+
17
+ let {
18
+ title = "",
19
+ open = false,
20
+ value = undefined,
21
+ disabled = false,
22
+ class: className = "",
23
+ onclick,
24
+ children,
25
+ ...restProps
26
+ }: Props = $props();
27
+
28
+ const { activeTab, registerTab } = getContext<{
29
+ activeTab: Writable<string | number | undefined>;
30
+ registerTab: (id: string | number, title: string, open: boolean) => string | number;
31
+ }>("tabs");
32
+
33
33
  // Generate unique ID - uses value prop or generates random ID once
34
34
  const generatedId = `tab-${Math.random().toString(36).substring(2, 9)}`;
35
35
  let tabId = $derived(value ?? generatedId);
36
-
37
- onMount(() => {
38
- registerTab(tabId, title, open);
39
- });
40
-
41
- let isActive = $derived($activeTab === tabId);
42
-
43
- function handleClick() {
44
- onclick?.();
45
- }
46
- </script>
47
-
48
- {#if isActive}
49
- <div class={className} role="tabpanel" onclick={handleClick} {...restProps}>
50
- {#if children}{@render children()}{/if}
51
- </div>
52
- {/if}
36
+
37
+ onMount(() => {
38
+ registerTab(tabId, title, open);
39
+ });
40
+
41
+ let isActive = $derived($activeTab === tabId);
42
+
43
+ function handleClick() {
44
+ onclick?.();
45
+ }
46
+ </script>
47
+
48
+ {#if isActive}
49
+ <div class={className} role="tabpanel" onclick={handleClick} {...restProps}>
50
+ {#if children}{@render children()}{/if}
51
+ </div>
52
+ {/if}
@@ -1,112 +1,112 @@
1
- <script module>
2
- import { defineMeta } from '@storybook/addon-svelte-csf';
3
- import Tabs from './Tabs.svelte';
4
- import TabItem from './TabItem.svelte';
5
-
6
- const { Story } = defineMeta({
7
- title: 'Primitives/Tabs',
8
- component: Tabs,
9
- tags: ['autodocs'],
10
- parameters: {
11
- docs: {
12
- description: {
13
- component: 'Tabbed content navigation component. Use TabItem children for each tab panel.',
14
- },
15
- },
16
- },
17
- });
18
-
19
- let activeTab = $state(0);
20
- </script>
21
-
22
- <Story name="Default">
23
- {#snippet template()}
24
- <Tabs>
25
- <TabItem title="Profile">
26
- <div class="p-4">
27
- <h3 class="font-medium mb-2">Profile Settings</h3>
28
- <p class="text-gray-600">Manage your profile information and preferences.</p>
29
- </div>
30
- </TabItem>
31
- <TabItem title="Account">
32
- <div class="p-4">
33
- <h3 class="font-medium mb-2">Account Settings</h3>
34
- <p class="text-gray-600">Manage your account security and billing.</p>
35
- </div>
36
- </TabItem>
37
- <TabItem title="Notifications">
38
- <div class="p-4">
39
- <h3 class="font-medium mb-2">Notification Settings</h3>
40
- <p class="text-gray-600">Configure how you receive notifications.</p>
41
- </div>
42
- </TabItem>
43
- </Tabs>
44
- {/snippet}
45
- </Story>
46
-
47
- <Story name="Controlled">
48
- {#snippet template()}
49
- <div>
50
- <p class="text-sm text-gray-500 mb-4">Active tab: {activeTab}</p>
51
- <Tabs bind:activeTab={activeTab}>
52
- <TabItem title="Tab 1">
53
- <div class="p-4">Content for Tab 1</div>
54
- </TabItem>
55
- <TabItem title="Tab 2">
56
- <div class="p-4">Content for Tab 2</div>
57
- </TabItem>
58
- <TabItem title="Tab 3">
59
- <div class="p-4">Content for Tab 3</div>
60
- </TabItem>
61
- </Tabs>
62
- <div class="mt-4 flex gap-2">
63
- <button
64
- class="px-3 py-1 bg-gray-200 rounded text-sm"
65
- onclick={() => activeTab = 0}
66
- >Go to Tab 1</button>
67
- <button
68
- class="px-3 py-1 bg-gray-200 rounded text-sm"
69
- onclick={() => activeTab = 2}
70
- >Go to Tab 3</button>
71
- </div>
72
- </div>
73
- {/snippet}
74
- </Story>
75
-
76
- <Story name="With Icons">
77
- {#snippet template()}
78
- <Tabs>
79
- <TabItem title="🏠 Home">
80
- <div class="p-4">Home tab content</div>
81
- </TabItem>
82
- <TabItem title="⚙️ Settings">
83
- <div class="p-4">Settings tab content</div>
84
- </TabItem>
85
- <TabItem title="👤 Profile">
86
- <div class="p-4">Profile tab content</div>
87
- </TabItem>
88
- </Tabs>
89
- {/snippet}
90
- </Story>
91
-
92
- <Story name="Many Tabs">
93
- {#snippet template()}
94
- <Tabs>
95
- <TabItem title="Overview">
96
- <div class="p-4">Overview content</div>
97
- </TabItem>
98
- <TabItem title="Analytics">
99
- <div class="p-4">Analytics content</div>
100
- </TabItem>
101
- <TabItem title="Reports">
102
- <div class="p-4">Reports content</div>
103
- </TabItem>
104
- <TabItem title="Notifications">
105
- <div class="p-4">Notifications content</div>
106
- </TabItem>
107
- <TabItem title="Settings">
108
- <div class="p-4">Settings content</div>
109
- </TabItem>
110
- </Tabs>
111
- {/snippet}
112
- </Story>
1
+ <script module>
2
+ import { defineMeta } from '@storybook/addon-svelte-csf';
3
+ import Tabs from './Tabs.svelte';
4
+ import TabItem from './TabItem.svelte';
5
+
6
+ const { Story } = defineMeta({
7
+ title: 'Primitives/Tabs',
8
+ component: Tabs,
9
+ tags: ['autodocs'],
10
+ parameters: {
11
+ docs: {
12
+ description: {
13
+ component: 'Tabbed content navigation component. Use TabItem children for each tab panel.',
14
+ },
15
+ },
16
+ },
17
+ });
18
+
19
+ let activeTab = $state(0);
20
+ </script>
21
+
22
+ <Story name="Default">
23
+ {#snippet template()}
24
+ <Tabs>
25
+ <TabItem title="Profile">
26
+ <div class="p-4">
27
+ <h3 class="font-medium mb-2">Profile Settings</h3>
28
+ <p class="text-gray-600">Manage your profile information and preferences.</p>
29
+ </div>
30
+ </TabItem>
31
+ <TabItem title="Account">
32
+ <div class="p-4">
33
+ <h3 class="font-medium mb-2">Account Settings</h3>
34
+ <p class="text-gray-600">Manage your account security and billing.</p>
35
+ </div>
36
+ </TabItem>
37
+ <TabItem title="Notifications">
38
+ <div class="p-4">
39
+ <h3 class="font-medium mb-2">Notification Settings</h3>
40
+ <p class="text-gray-600">Configure how you receive notifications.</p>
41
+ </div>
42
+ </TabItem>
43
+ </Tabs>
44
+ {/snippet}
45
+ </Story>
46
+
47
+ <Story name="Controlled">
48
+ {#snippet template()}
49
+ <div>
50
+ <p class="text-sm text-gray-500 mb-4">Active tab: {activeTab}</p>
51
+ <Tabs bind:activeTab={activeTab}>
52
+ <TabItem title="Tab 1">
53
+ <div class="p-4">Content for Tab 1</div>
54
+ </TabItem>
55
+ <TabItem title="Tab 2">
56
+ <div class="p-4">Content for Tab 2</div>
57
+ </TabItem>
58
+ <TabItem title="Tab 3">
59
+ <div class="p-4">Content for Tab 3</div>
60
+ </TabItem>
61
+ </Tabs>
62
+ <div class="mt-4 flex gap-2">
63
+ <button
64
+ class="px-3 py-1 bg-gray-200 rounded text-sm"
65
+ onclick={() => activeTab = 0}
66
+ >Go to Tab 1</button>
67
+ <button
68
+ class="px-3 py-1 bg-gray-200 rounded text-sm"
69
+ onclick={() => activeTab = 2}
70
+ >Go to Tab 3</button>
71
+ </div>
72
+ </div>
73
+ {/snippet}
74
+ </Story>
75
+
76
+ <Story name="With Icons">
77
+ {#snippet template()}
78
+ <Tabs>
79
+ <TabItem title="🏠 Home">
80
+ <div class="p-4">Home tab content</div>
81
+ </TabItem>
82
+ <TabItem title="⚙️ Settings">
83
+ <div class="p-4">Settings tab content</div>
84
+ </TabItem>
85
+ <TabItem title="👤 Profile">
86
+ <div class="p-4">Profile tab content</div>
87
+ </TabItem>
88
+ </Tabs>
89
+ {/snippet}
90
+ </Story>
91
+
92
+ <Story name="Many Tabs">
93
+ {#snippet template()}
94
+ <Tabs>
95
+ <TabItem title="Overview">
96
+ <div class="p-4">Overview content</div>
97
+ </TabItem>
98
+ <TabItem title="Analytics">
99
+ <div class="p-4">Analytics content</div>
100
+ </TabItem>
101
+ <TabItem title="Reports">
102
+ <div class="p-4">Reports content</div>
103
+ </TabItem>
104
+ <TabItem title="Notifications">
105
+ <div class="p-4">Notifications content</div>
106
+ </TabItem>
107
+ <TabItem title="Settings">
108
+ <div class="p-4">Settings content</div>
109
+ </TabItem>
110
+ </Tabs>
111
+ {/snippet}
112
+ </Story>