@getmicdrop/svelte-components 5.17.0 → 5.17.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 (391) hide show
  1. package/dist/calendar/AboutShow/AboutShow.svelte +187 -187
  2. package/dist/calendar/Calendar/MiniMonthCalendar.svelte +782 -782
  3. package/dist/calendar/FAQs/FAQs.svelte +77 -77
  4. package/dist/calendar/MonthSwitcher/MonthSwitcher.svelte +126 -126
  5. package/dist/calendar/OrderSummary/OrderSummary.svelte +457 -457
  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.spec.d.ts +2 -0
  10. package/dist/components/Heading.spec.d.ts.map +1 -0
  11. package/dist/components/Heading.spec.js +89 -0
  12. package/dist/components/Heading.svelte +60 -60
  13. package/dist/components/Layout/AppShell.svelte +104 -104
  14. package/dist/components/Layout/ContentSection.svelte +80 -80
  15. package/dist/components/Layout/Grid.svelte +4 -4
  16. package/dist/components/Layout/Heading.svelte +81 -81
  17. package/dist/components/Layout/PageContainer.svelte +69 -69
  18. package/dist/components/Layout/Responsive.svelte +75 -75
  19. package/dist/components/Layout/Section.svelte +80 -80
  20. package/dist/components/Layout/ShowOnDesktop.svelte +37 -37
  21. package/dist/components/Layout/ShowOnMobile.svelte +37 -37
  22. package/dist/components/Layout/Sidebar.svelte +108 -108
  23. package/dist/components/Layout/Stack.spec.js +1 -1
  24. package/dist/components/Layout/Stack.svelte +6 -6
  25. package/dist/components/Layout/Text.svelte +87 -87
  26. package/dist/components/Layout/TwoColumn.svelte +108 -108
  27. package/dist/components/Layout/__tests__/AppShell.test.js +140 -0
  28. package/dist/components/Text.spec.d.ts +2 -0
  29. package/dist/components/Text.spec.d.ts.map +1 -0
  30. package/dist/components/Text.spec.js +89 -0
  31. package/dist/components/Text.svelte +53 -53
  32. package/dist/constants/validation.js +91 -91
  33. package/dist/constants/validation.spec.js +64 -64
  34. package/dist/datetime/__tests__/format.test.js +1 -1
  35. package/dist/datetime/__tests__/parse.test.js +1 -1
  36. package/dist/datetime/__tests__/timezone.test.js +1 -1
  37. package/dist/datetime/parse.js +1 -1
  38. package/dist/datetime/timezone.d.ts.map +1 -1
  39. package/dist/datetime/timezone.js +1 -2
  40. package/dist/forms/createFormStore.svelte.d.ts +1 -1
  41. package/dist/forms/createFormStore.svelte.d.ts.map +1 -1
  42. package/dist/forms/createFormStore.svelte.js +1 -0
  43. package/dist/forms/createFormStore.svelte.spec.d.ts +2 -0
  44. package/dist/forms/createFormStore.svelte.spec.d.ts.map +1 -0
  45. package/dist/forms/createFormStore.svelte.spec.js +388 -0
  46. package/dist/index.js +57 -57
  47. package/dist/index.spec.js +369 -369
  48. package/dist/patterns/chat/ChatActivityNotice.spec.d.ts +2 -0
  49. package/dist/patterns/chat/ChatActivityNotice.spec.d.ts.map +1 -0
  50. package/dist/patterns/chat/ChatActivityNotice.spec.js +59 -0
  51. package/dist/patterns/chat/ChatActivityNotice.svelte +41 -41
  52. package/dist/patterns/chat/ChatBubble.spec.d.ts +2 -0
  53. package/dist/patterns/chat/ChatBubble.spec.d.ts.map +1 -0
  54. package/dist/patterns/chat/ChatBubble.spec.js +91 -0
  55. package/dist/patterns/chat/ChatBubble.svelte +95 -95
  56. package/dist/patterns/chat/ChatContainer.spec.d.ts +2 -0
  57. package/dist/patterns/chat/ChatContainer.spec.d.ts.map +1 -0
  58. package/dist/patterns/chat/ChatContainer.spec.js +30 -0
  59. package/dist/patterns/chat/ChatContainer.svelte +46 -46
  60. package/dist/patterns/chat/ChatDateDivider.spec.d.ts +2 -0
  61. package/dist/patterns/chat/ChatDateDivider.spec.d.ts.map +1 -0
  62. package/dist/patterns/chat/ChatDateDivider.spec.js +30 -0
  63. package/dist/patterns/chat/ChatDateDivider.svelte +27 -27
  64. package/dist/patterns/chat/ChatInvitationBubble.spec.d.ts +2 -0
  65. package/dist/patterns/chat/ChatInvitationBubble.spec.d.ts.map +1 -0
  66. package/dist/patterns/chat/ChatInvitationBubble.spec.js +46 -0
  67. package/dist/patterns/chat/ChatInvitationBubble.svelte +37 -37
  68. package/dist/patterns/chat/ChatInvitationNotice.spec.d.ts +2 -0
  69. package/dist/patterns/chat/ChatInvitationNotice.spec.d.ts.map +1 -0
  70. package/dist/patterns/chat/ChatInvitationNotice.spec.js +32 -0
  71. package/dist/patterns/chat/ChatInvitationNotice.svelte +27 -27
  72. package/dist/patterns/chat/ChatMessageGroup.spec.d.ts +2 -0
  73. package/dist/patterns/chat/ChatMessageGroup.spec.d.ts.map +1 -0
  74. package/dist/patterns/chat/ChatMessageGroup.spec.js +58 -0
  75. package/dist/patterns/chat/ChatMessageGroup.svelte +57 -57
  76. package/dist/patterns/chat/ChatSlotUpdate.spec.d.ts +2 -0
  77. package/dist/patterns/chat/ChatSlotUpdate.spec.d.ts.map +1 -0
  78. package/dist/patterns/chat/ChatSlotUpdate.spec.js +65 -0
  79. package/dist/patterns/chat/ChatSlotUpdate.svelte +46 -46
  80. package/dist/patterns/chat/ChatStatusBadge.spec.d.ts +2 -0
  81. package/dist/patterns/chat/ChatStatusBadge.spec.d.ts.map +1 -0
  82. package/dist/patterns/chat/ChatStatusBadge.spec.js +79 -0
  83. package/dist/patterns/chat/ChatStatusBadge.svelte +91 -91
  84. package/dist/patterns/chat/ChatStatusTransition.spec.d.ts +2 -0
  85. package/dist/patterns/chat/ChatStatusTransition.spec.d.ts.map +1 -0
  86. package/dist/patterns/chat/ChatStatusTransition.spec.js +81 -0
  87. package/dist/patterns/chat/ChatStatusTransition.svelte +64 -64
  88. package/dist/patterns/chat/ChatTextBubble.spec.d.ts +2 -0
  89. package/dist/patterns/chat/ChatTextBubble.spec.d.ts.map +1 -0
  90. package/dist/patterns/chat/ChatTextBubble.spec.js +35 -0
  91. package/dist/patterns/chat/ChatTextBubble.svelte +41 -41
  92. package/dist/patterns/chat/index.js +22 -22
  93. package/dist/patterns/data/DataGrid.svelte +45 -45
  94. package/dist/patterns/data/DataList.svelte +24 -24
  95. package/dist/patterns/data/DataTable.spec.js +61 -0
  96. package/dist/patterns/data/DataTable.svelte +36 -36
  97. package/dist/patterns/forms/FormActions.spec.js +95 -95
  98. package/dist/patterns/forms/FormActions.stories.svelte +97 -97
  99. package/dist/patterns/forms/FormActions.svelte +46 -46
  100. package/dist/patterns/forms/FormGrid.spec.js +34 -0
  101. package/dist/patterns/forms/FormGrid.svelte +33 -33
  102. package/dist/patterns/forms/FormSection.svelte +32 -32
  103. package/dist/patterns/forms/FormValidationSummary.stories.svelte +83 -83
  104. package/dist/patterns/forms/FormValidationSummary.svelte +74 -74
  105. package/dist/patterns/index.js +21 -21
  106. package/dist/patterns/layout/Sidebar.spec.js +240 -1
  107. package/dist/patterns/layout/Sidebar.svelte +39 -39
  108. package/dist/patterns/layout/SidebarTestWrapper.svelte +34 -0
  109. package/dist/patterns/layout/SidebarTestWrapper.svelte.d.ts +23 -0
  110. package/dist/patterns/layout/SidebarTestWrapper.svelte.d.ts.map +1 -0
  111. package/dist/patterns/layout/index.js +29 -29
  112. package/dist/patterns/navigation/BottomNav.stories.svelte +117 -117
  113. package/dist/patterns/navigation/BottomNav.svelte +74 -74
  114. package/dist/patterns/navigation/Header.spec.js +123 -0
  115. package/dist/patterns/navigation/Header.stories.svelte +77 -77
  116. package/dist/patterns/navigation/Header.svelte +251 -251
  117. package/dist/patterns/page/PageHeader.svelte +18 -18
  118. package/dist/patterns/page/PageLayout.svelte +40 -40
  119. package/dist/patterns/page/PageLoader.spec.js +57 -57
  120. package/dist/patterns/page/PageLoader.stories.svelte +137 -137
  121. package/dist/patterns/page/PageLoader.svelte +24 -24
  122. package/dist/patterns/page/SectionHeader.svelte +29 -29
  123. package/dist/presets/badges.js +112 -112
  124. package/dist/presets/buttons.js +76 -76
  125. package/dist/presets/index.js +9 -9
  126. package/dist/primitives/Accordion/Accordion.spec.js +112 -2
  127. package/dist/primitives/Accordion/Accordion.stories.svelte +75 -75
  128. package/dist/primitives/Accordion/Accordion.svelte +42 -42
  129. package/dist/primitives/Accordion/AccordionItem.svelte +95 -95
  130. package/dist/primitives/Accordion/AccordionToggleWrapper.test.svelte +28 -0
  131. package/dist/primitives/Accordion/AccordionToggleWrapper.test.svelte.d.ts +7 -0
  132. package/dist/primitives/Accordion/AccordionToggleWrapper.test.svelte.d.ts.map +1 -0
  133. package/dist/primitives/Alert/Alert.spec.js +173 -173
  134. package/dist/primitives/Alert/Alert.stories.svelte +88 -88
  135. package/dist/primitives/Alert/Alert.svelte +27 -27
  136. package/dist/primitives/Avatar/Avatar.spec.js +23 -0
  137. package/dist/primitives/Avatar/Avatar.stories.svelte +94 -94
  138. package/dist/primitives/Avatar/Avatar.svelte +66 -66
  139. package/dist/primitives/AvatarButton/AvatarButton.svelte +57 -57
  140. package/dist/primitives/Badges/Badge.spec.js +144 -144
  141. package/dist/primitives/Badges/Badge.stories.svelte +86 -86
  142. package/dist/primitives/Badges/Badge.svelte +99 -99
  143. package/dist/primitives/BottomSheet/BottomSheet.spec.js +238 -136
  144. package/dist/primitives/BottomSheet/BottomSheet.stories.svelte +83 -83
  145. package/dist/primitives/BottomSheet/BottomSheet.svelte +115 -115
  146. package/dist/primitives/BottomSheet/BottomSheetWithActions.test.svelte +20 -0
  147. package/dist/primitives/BottomSheet/BottomSheetWithActions.test.svelte.d.ts +10 -0
  148. package/dist/primitives/BottomSheet/BottomSheetWithActions.test.svelte.d.ts.map +1 -0
  149. package/dist/primitives/Breadcrumb/Breadcrumb.spec.js +123 -123
  150. package/dist/primitives/Breadcrumb/Breadcrumb.stories.svelte +23 -23
  151. package/dist/primitives/Breadcrumb/Breadcrumb.svelte +99 -99
  152. package/dist/primitives/Button/Button.spec.js +225 -225
  153. package/dist/primitives/Button/Button.stories.svelte +76 -76
  154. package/dist/primitives/Button/Button.svelte +278 -278
  155. package/dist/primitives/Button/ButtonGroup.spec.d.ts +2 -0
  156. package/dist/primitives/Button/ButtonGroup.spec.d.ts.map +1 -0
  157. package/dist/primitives/Button/ButtonGroup.spec.js +44 -0
  158. package/dist/primitives/Button/ButtonGroup.svelte +50 -50
  159. package/dist/primitives/Button/ButtonSaveDemo.spec.js +146 -146
  160. package/dist/primitives/Button/ButtonSaveDemo.svelte +25 -25
  161. package/dist/primitives/Button/ButtonVariantShowcase.svelte +129 -129
  162. package/dist/primitives/Card.spec.js +49 -49
  163. package/dist/primitives/Card.stories.svelte +22 -22
  164. package/dist/primitives/Card.svelte +28 -28
  165. package/dist/primitives/CardAction/CardAction.svelte +68 -68
  166. package/dist/primitives/Checkbox/Checkbox.spec.js +32 -0
  167. package/dist/primitives/Checkbox/Checkbox.stories.svelte +84 -84
  168. package/dist/primitives/Checkbox/Checkbox.svelte +88 -88
  169. package/dist/primitives/DarkModeToggle.spec.js +390 -390
  170. package/dist/primitives/DarkModeToggle.stories.svelte +57 -57
  171. package/dist/primitives/DarkModeToggle.svelte +136 -136
  172. package/dist/primitives/Drawer/Drawer.spec.js +437 -0
  173. package/dist/primitives/Drawer/Drawer.stories.svelte +80 -80
  174. package/dist/primitives/Drawer/Drawer.svelte +224 -224
  175. package/dist/primitives/Drawer/DrawerTestWrapper.svelte +86 -0
  176. package/dist/primitives/Drawer/DrawerTestWrapper.svelte.d.ts +26 -0
  177. package/dist/primitives/Drawer/DrawerTestWrapper.svelte.d.ts.map +1 -0
  178. package/dist/primitives/Dropdown/Dropdown.spec.js +116 -0
  179. package/dist/primitives/Dropdown/Dropdown.stories.svelte +137 -137
  180. package/dist/primitives/Dropdown/Dropdown.svelte +170 -170
  181. package/dist/primitives/Dropdown/DropdownDivider.spec.d.ts +2 -0
  182. package/dist/primitives/Dropdown/DropdownDivider.spec.d.ts.map +1 -0
  183. package/dist/primitives/Dropdown/DropdownDivider.spec.js +30 -0
  184. package/dist/primitives/Dropdown/DropdownDivider.svelte +9 -9
  185. package/dist/primitives/Dropdown/DropdownItem.spec.js +155 -1
  186. package/dist/primitives/Dropdown/DropdownItem.svelte +80 -80
  187. package/dist/primitives/Dropdown/DropdownItemTestWrapper.svelte +43 -0
  188. package/dist/primitives/Dropdown/DropdownItemTestWrapper.svelte.d.ts +17 -0
  189. package/dist/primitives/Dropdown/DropdownItemTestWrapper.svelte.d.ts.map +1 -0
  190. package/dist/primitives/Helper/Helper.spec.d.ts +2 -0
  191. package/dist/primitives/Helper/Helper.spec.d.ts.map +1 -0
  192. package/dist/primitives/Helper/Helper.spec.js +57 -0
  193. package/dist/primitives/Helper/Helper.svelte +33 -33
  194. package/dist/primitives/Icons/ArrowLeft.svelte +8 -8
  195. package/dist/primitives/Icons/ArrowRight.svelte +8 -8
  196. package/dist/primitives/Icons/Availability.svelte +14 -14
  197. package/dist/primitives/Icons/Back.svelte +14 -14
  198. package/dist/primitives/Icons/CheckCircle.svelte +6 -6
  199. package/dist/primitives/Icons/CheckCircleOutline.svelte +15 -15
  200. package/dist/primitives/Icons/ChevronLeft.svelte +4 -4
  201. package/dist/primitives/Icons/ChevronRight.svelte +4 -4
  202. package/dist/primitives/Icons/Copy.svelte +15 -15
  203. package/dist/primitives/Icons/Cross.svelte +5 -5
  204. package/dist/primitives/Icons/DownArrow.svelte +8 -8
  205. package/dist/primitives/Icons/ErrorCircle.svelte +6 -6
  206. package/dist/primitives/Icons/FacebookIcon.svelte +2 -2
  207. package/dist/primitives/Icons/Home.svelte +15 -15
  208. package/dist/primitives/Icons/Icon.spec.js +169 -169
  209. package/dist/primitives/Icons/Icon.stories.svelte +100 -100
  210. package/dist/primitives/Icons/Icon.svelte +52 -52
  211. package/dist/primitives/Icons/IconGallery.stories.svelte +235 -235
  212. package/dist/primitives/Icons/Info.svelte +7 -7
  213. package/dist/primitives/Icons/InstagramIcon.svelte +4 -4
  214. package/dist/primitives/Icons/LogoInstagram.svelte +2 -2
  215. package/dist/primitives/Icons/Message.svelte +15 -15
  216. package/dist/primitives/Icons/MoonIcon.svelte +5 -5
  217. package/dist/primitives/Icons/More.svelte +21 -21
  218. package/dist/primitives/Icons/MoreHori.spec.js +61 -61
  219. package/dist/primitives/Icons/MoreHori.svelte +22 -22
  220. package/dist/primitives/Icons/Notification.svelte +14 -14
  221. package/dist/primitives/Icons/Payment.svelte +14 -14
  222. package/dist/primitives/Icons/Profile.svelte +21 -21
  223. package/dist/primitives/Icons/Reload.svelte +29 -29
  224. package/dist/primitives/Icons/Shows.svelte +21 -21
  225. package/dist/primitives/Icons/Signout.svelte +21 -21
  226. package/dist/primitives/Icons/SunIcon.svelte +8 -8
  227. package/dist/primitives/Icons/TiktokIcon.svelte +2 -2
  228. package/dist/primitives/Icons/TwitterIcon.svelte +2 -2
  229. package/dist/primitives/Icons/WarningIcon.spec.js +18 -18
  230. package/dist/primitives/Icons/WarningIcon.svelte +5 -5
  231. package/dist/primitives/Input/Input.spec.js +1235 -573
  232. package/dist/primitives/Input/Input.stories.svelte +139 -139
  233. package/dist/primitives/Input/Input.svelte +423 -423
  234. package/dist/primitives/Input/Select.spec.js +632 -218
  235. package/dist/primitives/Input/Select.stories.svelte +112 -112
  236. package/dist/primitives/Input/Select.svelte +252 -252
  237. package/dist/primitives/Input/Textarea.stories.svelte +137 -137
  238. package/dist/primitives/Input/Textarea.svelte +105 -105
  239. package/dist/primitives/Label/Label.spec.js +9 -0
  240. package/dist/primitives/Label/Label.svelte +37 -37
  241. package/dist/primitives/LandingButton/LandingButton.spec.d.ts +2 -0
  242. package/dist/primitives/LandingButton/LandingButton.spec.d.ts.map +1 -0
  243. package/dist/primitives/LandingButton/LandingButton.spec.js +61 -0
  244. package/dist/primitives/LandingButton/LandingButton.svelte +92 -92
  245. package/dist/primitives/MenuItem/MenuItem.spec.d.ts +2 -0
  246. package/dist/primitives/MenuItem/MenuItem.spec.d.ts.map +1 -0
  247. package/dist/primitives/MenuItem/MenuItem.spec.js +130 -0
  248. package/dist/primitives/MenuItem/MenuItem.svelte +85 -85
  249. package/dist/primitives/Modal/Modal.spec.js +314 -99
  250. package/dist/primitives/Modal/Modal.stories.svelte +86 -86
  251. package/dist/primitives/Modal/Modal.svelte +181 -181
  252. package/dist/primitives/NavItem/NavItem.spec.d.ts +2 -0
  253. package/dist/primitives/NavItem/NavItem.spec.d.ts.map +1 -0
  254. package/dist/primitives/NavItem/NavItem.spec.js +97 -0
  255. package/dist/primitives/NavItem/NavItem.svelte +75 -75
  256. package/dist/primitives/Pagination/Pagination.stories.svelte +76 -76
  257. package/dist/primitives/Pagination/Pagination.svelte +261 -261
  258. package/dist/primitives/Radio/Radio.stories.svelte +80 -80
  259. package/dist/primitives/Radio/Radio.svelte +67 -67
  260. package/dist/primitives/SearchResultItem/SearchResultItem.spec.d.ts +2 -0
  261. package/dist/primitives/SearchResultItem/SearchResultItem.spec.d.ts.map +1 -0
  262. package/dist/primitives/SearchResultItem/SearchResultItem.spec.js +78 -0
  263. package/dist/primitives/SearchResultItem/SearchResultItem.svelte +109 -109
  264. package/dist/primitives/SidebarToggle/SidebarToggle.spec.d.ts +2 -0
  265. package/dist/primitives/SidebarToggle/SidebarToggle.spec.d.ts.map +1 -0
  266. package/dist/primitives/SidebarToggle/SidebarToggle.spec.js +61 -0
  267. package/dist/primitives/SidebarToggle/SidebarToggle.svelte +55 -55
  268. package/dist/primitives/Skeleton/CardPlaceholder.svelte +87 -87
  269. package/dist/primitives/Skeleton/ImagePlaceholder.svelte +59 -59
  270. package/dist/primitives/Skeleton/ListPlaceholder.svelte +76 -76
  271. package/dist/primitives/Skeleton/Skeleton.stories.svelte +151 -151
  272. package/dist/primitives/Skeleton/Skeleton.svelte +26 -26
  273. package/dist/primitives/Spinner/Spinner.spec.js +84 -71
  274. package/dist/primitives/Spinner/Spinner.stories.svelte +29 -29
  275. package/dist/primitives/Spinner/Spinner.svelte +20 -20
  276. package/dist/primitives/Tabs/TabItem.svelte +49 -49
  277. package/dist/primitives/Tabs/Tabs.stories.svelte +112 -112
  278. package/dist/primitives/Tabs/Tabs.svelte +137 -137
  279. package/dist/primitives/Toggle.spec.js +221 -146
  280. package/dist/primitives/Toggle.stories.svelte +92 -92
  281. package/dist/primitives/Toggle.svelte +141 -141
  282. package/dist/primitives/ToggleTestWrapper.svelte +30 -0
  283. package/dist/primitives/ToggleTestWrapper.svelte.d.ts +29 -0
  284. package/dist/primitives/ToggleTestWrapper.svelte.d.ts.map +1 -0
  285. package/dist/primitives/Tooltip/Tooltip.spec.d.ts +2 -0
  286. package/dist/primitives/Tooltip/Tooltip.spec.d.ts.map +1 -0
  287. package/dist/primitives/Tooltip/Tooltip.spec.js +126 -0
  288. package/dist/primitives/Tooltip/Tooltip.svelte +83 -83
  289. package/dist/primitives/Typography/Typography.svelte +53 -53
  290. package/dist/primitives/ValidationError.spec.js +103 -103
  291. package/dist/primitives/ValidationError.stories.svelte +69 -69
  292. package/dist/primitives/ValidationError.svelte +29 -29
  293. package/dist/primitives/index.js +113 -113
  294. package/dist/recipes/CropImage/CropImage.spec.js +208 -208
  295. package/dist/recipes/CropImage/CropImage.stories.svelte +104 -104
  296. package/dist/recipes/CropImage/CropImage.svelte +241 -241
  297. package/dist/recipes/ImageUploader/ImageUploader.stories.svelte +125 -125
  298. package/dist/recipes/ImageUploader/ImageUploader.svelte +992 -992
  299. package/dist/recipes/SuperLogin/SuperLogin.spec.js +21 -21
  300. package/dist/recipes/SuperLogin/SuperLogin.svelte +4 -4
  301. package/dist/recipes/Toaster/Toaster.stories.svelte +62 -62
  302. package/dist/recipes/feedback/EmptyState/EmptyState.svelte +1 -1
  303. package/dist/recipes/feedback/ErrorDisplay.spec.js +69 -69
  304. package/dist/recipes/feedback/ErrorDisplay.stories.svelte +101 -101
  305. package/dist/recipes/feedback/ErrorDisplay.svelte +1 -1
  306. package/dist/recipes/feedback/StatusIndicator/StatusIndicator.spec.js +133 -133
  307. package/dist/recipes/feedback/StatusIndicator/StatusIndicator.svelte +157 -157
  308. package/dist/recipes/fields/CheckboxField.svelte +85 -85
  309. package/dist/recipes/fields/FormField.svelte +58 -58
  310. package/dist/recipes/fields/RadioGroup.svelte +95 -95
  311. package/dist/recipes/fields/SelectField.svelte +82 -82
  312. package/dist/recipes/fields/TextareaField.svelte +97 -97
  313. package/dist/recipes/fields/ToggleField.svelte +60 -60
  314. package/dist/recipes/fields/index.js +7 -7
  315. package/dist/recipes/inputs/MultiSelect.spec.js +263 -263
  316. package/dist/recipes/inputs/MultiSelect.stories.svelte +133 -133
  317. package/dist/recipes/inputs/MultiSelect.svelte +283 -283
  318. package/dist/recipes/inputs/OTPInput.spec.js +251 -251
  319. package/dist/recipes/inputs/OTPInput.stories.svelte +162 -162
  320. package/dist/recipes/inputs/OTPInput.svelte +117 -117
  321. package/dist/recipes/inputs/PasswordInput.svelte +22 -22
  322. package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.svelte +131 -131
  323. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.spec.js +19 -19
  324. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.stories.svelte +123 -123
  325. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte +336 -339
  326. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte.d.ts.map +1 -1
  327. package/dist/recipes/inputs/Search.spec.js +66 -2
  328. package/dist/recipes/inputs/Search.svelte +102 -102
  329. package/dist/recipes/inputs/index.js +7 -7
  330. package/dist/recipes/modals/AlertModal.svelte +130 -130
  331. package/dist/recipes/modals/ConfirmationModal.spec.js +396 -206
  332. package/dist/recipes/modals/ConfirmationModal.stories.svelte +119 -119
  333. package/dist/recipes/modals/ConfirmationModal.svelte +162 -162
  334. package/dist/recipes/modals/InputModal.svelte +182 -182
  335. package/dist/recipes/modals/ModalStateManager.spec.js +100 -100
  336. package/dist/recipes/modals/ModalStateManager.svelte +77 -77
  337. package/dist/recipes/modals/ModalTestWrapper.svelte +65 -65
  338. package/dist/recipes/modals/StatusModal.svelte +206 -206
  339. package/dist/services/EventService.d.ts +1 -1
  340. package/dist/services/EventService.d.ts.map +1 -1
  341. package/dist/services/EventService.js +79 -75
  342. package/dist/services/EventService.spec.js +217 -217
  343. package/dist/services/ShowService.js +144 -143
  344. package/dist/services/ShowService.spec.js +345 -345
  345. package/dist/stores/auth.svelte.spec.d.ts +2 -0
  346. package/dist/stores/auth.svelte.spec.d.ts.map +1 -0
  347. package/dist/stores/auth.svelte.spec.js +112 -0
  348. package/dist/stores/formDataStore.svelte.spec.d.ts +2 -0
  349. package/dist/stores/formDataStore.svelte.spec.d.ts.map +1 -0
  350. package/dist/stores/formDataStore.svelte.spec.js +150 -0
  351. package/dist/stores/formSave.svelte.spec.d.ts +2 -0
  352. package/dist/stores/formSave.svelte.spec.d.ts.map +1 -0
  353. package/dist/stores/formSave.svelte.spec.js +196 -0
  354. package/dist/stores/navigation.spec.d.ts +2 -0
  355. package/dist/stores/navigation.spec.d.ts.map +1 -0
  356. package/dist/stores/navigation.spec.js +53 -0
  357. package/dist/stores/toaster.js +13 -13
  358. package/dist/stories/ButtonAuditReview.stories.svelte +14 -14
  359. package/dist/stories/ButtonAuditReview.svelte +427 -427
  360. package/dist/stories/PatternsGallery.stories.svelte +19 -19
  361. package/dist/stories/PatternsGallery.svelte +206 -206
  362. package/dist/stories/PrimitivesGallery.stories.svelte +19 -19
  363. package/dist/stories/PrimitivesGallery.svelte +756 -756
  364. package/dist/stories/RecipesGallery.stories.svelte +19 -19
  365. package/dist/stories/RecipesGallery.svelte +454 -454
  366. package/dist/stories/button-audit-manifest.json +11186 -11186
  367. package/dist/tailwind/preset.cjs +82 -82
  368. package/dist/telemetry.d.ts.map +1 -1
  369. package/dist/telemetry.js +402 -405
  370. package/dist/telemetry.server.js +212 -212
  371. package/dist/telemetry.server.spec.js +437 -438
  372. package/dist/telemetry.spec.js +1168 -1169
  373. package/dist/tokens/tokens.css +87 -87
  374. package/dist/tokens/typography-base.css +163 -163
  375. package/dist/tokens/utilities.css +353 -353
  376. package/dist/utils/apiConfig.js +117 -120
  377. package/dist/utils/apiConfig.spec.js +219 -219
  378. package/dist/utils/greetings.js +187 -187
  379. package/dist/utils/haptic.spec.d.ts +2 -0
  380. package/dist/utils/haptic.spec.d.ts.map +1 -0
  381. package/dist/utils/haptic.spec.js +153 -0
  382. package/dist/utils/imageOptimizer.spec.d.ts +2 -0
  383. package/dist/utils/imageOptimizer.spec.d.ts.map +1 -0
  384. package/dist/utils/imageOptimizer.spec.js +201 -0
  385. package/dist/utils/imageValidation.js +121 -121
  386. package/dist/utils/logger.spec.d.ts +2 -0
  387. package/dist/utils/logger.spec.d.ts.map +1 -0
  388. package/dist/utils/logger.spec.js +95 -0
  389. package/dist/utils/transitions.js +4 -4
  390. package/dist/utils/utils.js +693 -693
  391. package/package.json +292 -294
@@ -1,46 +1,46 @@
1
- <script>
2
- import Button from "../../primitives/Button/Button.svelte";
3
-
4
- let {
5
- onCancel = () => {},
6
- onSubmit = () => {},
7
- submitLabel = "Save",
8
- cancelLabel = "Cancel",
9
- isSubmitting = false,
10
- isSuccess = false,
11
- disabled = false,
12
- showCancel = true,
13
- submitVariant = "default",
14
- cancelVariant = "alternative",
15
- submitType = "submit",
16
- className = "",
17
- } = $props();
18
- </script>
19
-
20
- <div
21
- class="w-full md:static flex bg-white dark:bg-gray-800 md:bg-transparent md:dark:bg-transparent md:rounded-b-lg items-center justify-center md:justify-end gap-4 py-5 px-4 {className}"
22
- >
23
- {#if showCancel}
24
- <Button
25
- variant={cancelVariant}
26
- type="button"
27
- size="full-md-auto"
28
- minWidth="action"
29
- onclick={onCancel}
30
- >
31
- {cancelLabel}
32
- </Button>
33
- {/if}
34
- <Button
35
- variant={submitVariant}
36
- type={submitType}
37
- size="full-md-auto"
38
- minWidth="action"
39
- loading={isSubmitting}
40
- success={isSuccess}
41
- disabled={disabled || isSubmitting}
42
- onclick={onSubmit}
43
- >
44
- {submitLabel}
45
- </Button>
46
- </div>
1
+ <script>
2
+ import Button from "../../primitives/Button/Button.svelte";
3
+
4
+ let {
5
+ onCancel = () => {},
6
+ onSubmit = () => {},
7
+ submitLabel = "Save",
8
+ cancelLabel = "Cancel",
9
+ isSubmitting = false,
10
+ isSuccess = false,
11
+ disabled = false,
12
+ showCancel = true,
13
+ submitVariant = "default",
14
+ cancelVariant = "alternative",
15
+ submitType = "submit",
16
+ className = "",
17
+ } = $props();
18
+ </script>
19
+
20
+ <div
21
+ class="w-full md:static flex bg-white dark:bg-gray-800 md:bg-transparent md:dark:bg-transparent md:rounded-b-lg items-center justify-center md:justify-end gap-4 py-5 px-4 {className}"
22
+ >
23
+ {#if showCancel}
24
+ <Button
25
+ variant={cancelVariant}
26
+ type="button"
27
+ size="full-md-auto"
28
+ minWidth="action"
29
+ onclick={onCancel}
30
+ >
31
+ {cancelLabel}
32
+ </Button>
33
+ {/if}
34
+ <Button
35
+ variant={submitVariant}
36
+ type={submitType}
37
+ size="full-md-auto"
38
+ minWidth="action"
39
+ loading={isSubmitting}
40
+ success={isSuccess}
41
+ disabled={disabled || isSubmitting}
42
+ onclick={onSubmit}
43
+ >
44
+ {submitLabel}
45
+ </Button>
46
+ </div>
@@ -1,4 +1,5 @@
1
1
  import { render, screen } from '@testing-library/svelte';
2
+ import { createRawSnippet } from 'svelte';
2
3
  import { expect, describe, test } from 'vitest';
3
4
  import FormGrid from './FormGrid.svelte';
4
5
 
@@ -123,3 +124,36 @@ describe('FormGrid Combinations', () => {
123
124
  expect(grid).toHaveClass('extra');
124
125
  });
125
126
  });
127
+
128
+ describe('FormGrid children snippet', () => {
129
+ test('renders children content inside grid', () => {
130
+ const children = createRawSnippet(() => ({
131
+ render: () => `<div class="field">Field 1</div>`
132
+ }));
133
+ const { container } = render(FormGrid, { props: { children } });
134
+ const grid = container.querySelector('.grid');
135
+ expect(grid.textContent).toContain('Field 1');
136
+ expect(grid.querySelector('.field')).toBeInTheDocument();
137
+ });
138
+
139
+ test('renders without children (optional chaining)', () => {
140
+ const { container } = render(FormGrid);
141
+ const grid = container.querySelector('.grid');
142
+ expect(grid).toBeInTheDocument();
143
+ expect(grid.children.length).toBe(0);
144
+ });
145
+ });
146
+
147
+ describe('FormGrid fallback values', () => {
148
+ test('invalid cols falls back to md:grid-cols-2', () => {
149
+ const { container } = render(FormGrid, { props: { cols: 99 } });
150
+ const grid = container.querySelector('div');
151
+ expect(grid).toHaveClass('md:grid-cols-2');
152
+ });
153
+
154
+ test('invalid gap falls back to gap-4', () => {
155
+ const { container } = render(FormGrid, { props: { gap: 99 } });
156
+ const grid = container.querySelector('div');
157
+ expect(grid).toHaveClass('gap-4');
158
+ });
159
+ });
@@ -1,33 +1,33 @@
1
- <script>
2
- let {
3
- cols = 2,
4
- gap = 4,
5
- class: className = '',
6
- children,
7
- } = $props();
8
-
9
- // Map cols to Tailwind grid classes
10
- const colsClass = {
11
- 1: 'md:grid-cols-1',
12
- 2: 'md:grid-cols-2',
13
- 3: 'md:grid-cols-3',
14
- 4: 'md:grid-cols-4'
15
- };
16
-
17
- // Map gap to Tailwind gap classes
18
- const gapClass = {
19
- 2: 'gap-2',
20
- 3: 'gap-3',
21
- 4: 'gap-4',
22
- 5: 'gap-5',
23
- 6: 'gap-6',
24
- 8: 'gap-8'
25
- };
26
-
27
- let gridCols = $derived(colsClass[cols] || colsClass[2]);
28
- let gridGap = $derived(gapClass[gap] || gapClass[4]);
29
- </script>
30
-
31
- <div class="grid grid-cols-1 {gridCols} {gridGap} {className}">
32
- {@render children?.()}
33
- </div>
1
+ <script>
2
+ let {
3
+ cols = 2,
4
+ gap = 4,
5
+ class: className = '',
6
+ children,
7
+ } = $props();
8
+
9
+ // Map cols to Tailwind grid classes
10
+ const colsClass = {
11
+ 1: 'md:grid-cols-1',
12
+ 2: 'md:grid-cols-2',
13
+ 3: 'md:grid-cols-3',
14
+ 4: 'md:grid-cols-4'
15
+ };
16
+
17
+ // Map gap to Tailwind gap classes
18
+ const gapClass = {
19
+ 2: 'gap-2',
20
+ 3: 'gap-3',
21
+ 4: 'gap-4',
22
+ 5: 'gap-5',
23
+ 6: 'gap-6',
24
+ 8: 'gap-8'
25
+ };
26
+
27
+ let gridCols = $derived(colsClass[cols] || colsClass[2]);
28
+ let gridGap = $derived(gapClass[gap] || gapClass[4]);
29
+ </script>
30
+
31
+ <div class="grid grid-cols-1 {gridCols} {gridGap} {className}">
32
+ {@render children?.()}
33
+ </div>
@@ -1,32 +1,32 @@
1
- <script>
2
- import { typography } from '../../tokens/typography';
3
-
4
- let {
5
- title = '',
6
- description = '',
7
- divider = false,
8
- class: className = '',
9
- children,
10
- } = $props();
11
- </script>
12
-
13
- <section class="space-y-4 {className}">
14
- {#if divider}
15
- <hr class="border-gray-200 dark:border-gray-700" />
16
- {/if}
17
-
18
- {#if title || description}
19
- <div class="space-y-1">
20
- {#if title}
21
- <h3 class={typography.h3}>{title}</h3>
22
- {/if}
23
- {#if description}
24
- <p class={typography.smMuted}>{description}</p>
25
- {/if}
26
- </div>
27
- {/if}
28
-
29
- <div class="space-y-4">
30
- {@render children?.()}
31
- </div>
32
- </section>
1
+ <script>
2
+ import { typography } from '../../tokens/typography';
3
+
4
+ let {
5
+ title = '',
6
+ description = '',
7
+ divider = false,
8
+ class: className = '',
9
+ children,
10
+ } = $props();
11
+ </script>
12
+
13
+ <section class="space-y-4 {className}">
14
+ {#if divider}
15
+ <hr class="border-gray-200 dark:border-gray-700" />
16
+ {/if}
17
+
18
+ {#if title || description}
19
+ <div class="space-y-1">
20
+ {#if title}
21
+ <h3 class={typography.h3}>{title}</h3>
22
+ {/if}
23
+ {#if description}
24
+ <p class={typography.smMuted}>{description}</p>
25
+ {/if}
26
+ </div>
27
+ {/if}
28
+
29
+ <div class="space-y-4">
30
+ {@render children?.()}
31
+ </div>
32
+ </section>
@@ -1,75 +1,75 @@
1
- <script module>
2
- import { defineMeta } from "@storybook/addon-svelte-csf";
3
-
4
- import FormValidationSummary from './FormValidationSummary.svelte';
5
-
6
- const { Story } = defineMeta({
7
- title: 'Components/FormValidationSummary',
8
- component: FormValidationSummary,
9
- tags: ['autodocs'],
10
- });
11
-
12
- </script>
13
-
14
- <script>
15
-
16
- const sampleErrors = {
17
- firstName: 'First name is required',
18
- email: 'Please enter a valid email address',
19
- phone: 'Phone number must be 10 digits',
20
- };
21
-
22
- const fieldLabels = {
23
- firstName: 'First Name',
24
- email: 'Email Address',
25
- phone: 'Phone Number',
26
- };
27
- </script>
28
-
29
- <Story name="Default">
30
- <FormValidationSummary
31
- errors={sampleErrors}
32
- {fieldLabels}
33
- show={true}
34
- />
35
- </Story>
36
-
37
- <Story name="Single Error">
38
- <FormValidationSummary
39
- errors={{ email: 'Email is required' }}
40
- fieldLabels={{ email: 'Email Address' }}
41
- show={true}
42
- />
43
- </Story>
44
-
45
- <Story name="Multiple Errors">
46
- <FormValidationSummary
47
- errors={{
48
- firstName: 'First name is required',
49
- lastName: 'Last name is required',
50
- email: 'Invalid email format',
51
- password: 'Password must be at least 8 characters',
52
- confirmPassword: 'Passwords do not match',
53
- }}
54
- fieldLabels={{
55
- firstName: 'First Name',
56
- lastName: 'Last Name',
57
- email: 'Email',
58
- password: 'Password',
59
- confirmPassword: 'Confirm Password',
60
- }}
61
- show={true}
62
- />
63
- </Story>
64
-
65
- <Story name="With Form">
66
- <div class="max-w-md">
67
- <FormValidationSummary
68
- errors={sampleErrors}
69
- {fieldLabels}
70
- show={true}
71
- />
72
-
1
+ <script module>
2
+ import { defineMeta } from "@storybook/addon-svelte-csf";
3
+
4
+ import FormValidationSummary from './FormValidationSummary.svelte';
5
+
6
+ const { Story } = defineMeta({
7
+ title: 'Components/FormValidationSummary',
8
+ component: FormValidationSummary,
9
+ tags: ['autodocs'],
10
+ });
11
+
12
+ </script>
13
+
14
+ <script>
15
+
16
+ const sampleErrors = {
17
+ firstName: 'First name is required',
18
+ email: 'Please enter a valid email address',
19
+ phone: 'Phone number must be 10 digits',
20
+ };
21
+
22
+ const fieldLabels = {
23
+ firstName: 'First Name',
24
+ email: 'Email Address',
25
+ phone: 'Phone Number',
26
+ };
27
+ </script>
28
+
29
+ <Story name="Default">
30
+ <FormValidationSummary
31
+ errors={sampleErrors}
32
+ {fieldLabels}
33
+ show={true}
34
+ />
35
+ </Story>
36
+
37
+ <Story name="Single Error">
38
+ <FormValidationSummary
39
+ errors={{ email: 'Email is required' }}
40
+ fieldLabels={{ email: 'Email Address' }}
41
+ show={true}
42
+ />
43
+ </Story>
44
+
45
+ <Story name="Multiple Errors">
46
+ <FormValidationSummary
47
+ errors={{
48
+ firstName: 'First name is required',
49
+ lastName: 'Last name is required',
50
+ email: 'Invalid email format',
51
+ password: 'Password must be at least 8 characters',
52
+ confirmPassword: 'Passwords do not match',
53
+ }}
54
+ fieldLabels={{
55
+ firstName: 'First Name',
56
+ lastName: 'Last Name',
57
+ email: 'Email',
58
+ password: 'Password',
59
+ confirmPassword: 'Confirm Password',
60
+ }}
61
+ show={true}
62
+ />
63
+ </Story>
64
+
65
+ <Story name="With Form">
66
+ <div class="max-w-md">
67
+ <FormValidationSummary
68
+ errors={sampleErrors}
69
+ {fieldLabels}
70
+ show={true}
71
+ />
72
+
73
73
  <div class="space-y-4 mt-4">
74
74
  <div>
75
75
  <label for="firstName" class="block text-sm font-medium mb-1">First Name</label>
@@ -84,14 +84,14 @@
84
84
  <input id="phone" type="tel" class="w-full px-3 py-2 border border-red-300 rounded" />
85
85
  </div>
86
86
  </div>
87
- </div>
88
- </Story>
89
-
90
- <Story name="Hidden State">
91
- <FormValidationSummary
92
- errors={sampleErrors}
93
- {fieldLabels}
94
- show={false}
95
- />
96
- <p class="text-sm text-gray-500 dark:text-gray-400 mt-2">The validation summary is hidden</p>
97
- </Story>
87
+ </div>
88
+ </Story>
89
+
90
+ <Story name="Hidden State">
91
+ <FormValidationSummary
92
+ errors={sampleErrors}
93
+ {fieldLabels}
94
+ show={false}
95
+ />
96
+ <p class="text-sm text-gray-500 dark:text-gray-400 mt-2">The validation summary is hidden</p>
97
+ </Story>
@@ -1,74 +1,74 @@
1
- <script lang="ts">
2
- import { safeSlide } from "../../utils/transitions.js";
3
- import { cubicOut } from "svelte/easing";
4
- import WarningIcon from "../../primitives/Icons/WarningIcon.svelte";
5
- import Button from "../../primitives/Button/Button.svelte";
6
-
7
- interface Props {
8
- errors?: Record<string, string | null | undefined>;
9
- show?: boolean;
10
- fieldLabels?: Record<string, string>;
11
- fieldIds?: Record<string, string>;
12
- }
13
-
14
- let {
15
- errors = {},
16
- show = false,
17
- fieldLabels = {},
18
- fieldIds = {},
19
- }: Props = $props();
20
-
21
- // Get list of fields with errors
22
- let errorFields = $derived(Object.entries(errors)
23
- .filter(([_, message]) => message && message.trim() !== "")
24
- .map(([key, message]) => ({
25
- key,
26
- label: fieldLabels[key] || key,
27
- message,
28
- elementId: fieldIds[key] || key
29
- })));
30
-
31
- let hasErrors = $derived(errorFields.length > 0);
32
-
33
- function scrollToField(elementId: string) {
34
- const element = document.getElementById(elementId);
35
- if (element) {
36
- element.scrollIntoView({ behavior: "smooth", block: "center" });
37
- if (element.focus) {
38
- setTimeout(() => element.focus(), 300);
39
- }
40
- }
41
- }
42
- </script>
43
-
44
- {#if show && hasErrors}
45
- <div
46
- transition:safeSlide={{ duration: 300, easing: cubicOut }}
47
- class="bg-red-50 dark:bg-red-900/20 border border-red-200 dark:border-red-800 rounded-lg p-4 mb-4"
48
- role="alert"
49
- aria-live="polite"
50
- >
51
- <div class="flex items-start gap-2">
52
- <WarningIcon class="shrink-0 text-red-600 dark:text-red-500 mt-0.5" />
53
- <div class="flex-1">
54
- <p class="text-sm font-medium text-red-800 dark:text-red-400">
55
- Please fix the following:
56
- </p>
57
- <ul class="mt-2 space-y-1">
58
- {#each errorFields as field}
59
- <li>
60
- <Button
61
- variant="link"
62
- size="sm"
63
- class="text-red-600! dark:text-red-500! hover:text-red-900! dark:hover:text-red-400!"
64
- onclick={() => scrollToField(field.elementId)}
65
- >
66
- {field.label}
67
- </Button>
68
- </li>
69
- {/each}
70
- </ul>
71
- </div>
72
- </div>
73
- </div>
74
- {/if}
1
+ <script lang="ts">
2
+ import { safeSlide } from "../../utils/transitions.js";
3
+ import { cubicOut } from "svelte/easing";
4
+ import WarningIcon from "../../primitives/Icons/WarningIcon.svelte";
5
+ import Button from "../../primitives/Button/Button.svelte";
6
+
7
+ interface Props {
8
+ errors?: Record<string, string | null | undefined>;
9
+ show?: boolean;
10
+ fieldLabels?: Record<string, string>;
11
+ fieldIds?: Record<string, string>;
12
+ }
13
+
14
+ let {
15
+ errors = {},
16
+ show = false,
17
+ fieldLabels = {},
18
+ fieldIds = {},
19
+ }: Props = $props();
20
+
21
+ // Get list of fields with errors
22
+ let errorFields = $derived(Object.entries(errors)
23
+ .filter(([_, message]) => message && message.trim() !== "")
24
+ .map(([key, message]) => ({
25
+ key,
26
+ label: fieldLabels[key] || key,
27
+ message,
28
+ elementId: fieldIds[key] || key
29
+ })));
30
+
31
+ let hasErrors = $derived(errorFields.length > 0);
32
+
33
+ function scrollToField(elementId: string) {
34
+ const element = document.getElementById(elementId);
35
+ if (element) {
36
+ element.scrollIntoView({ behavior: "smooth", block: "center" });
37
+ if (element.focus) {
38
+ setTimeout(() => element.focus(), 300);
39
+ }
40
+ }
41
+ }
42
+ </script>
43
+
44
+ {#if show && hasErrors}
45
+ <div
46
+ transition:safeSlide={{ duration: 300, easing: cubicOut }}
47
+ class="bg-red-50 dark:bg-red-900/20 border border-red-200 dark:border-red-800 rounded-lg p-4 mb-4"
48
+ role="alert"
49
+ aria-live="polite"
50
+ >
51
+ <div class="flex items-start gap-2">
52
+ <WarningIcon class="shrink-0 text-red-600 dark:text-red-500 mt-0.5" />
53
+ <div class="flex-1">
54
+ <p class="text-sm font-medium text-red-800 dark:text-red-400">
55
+ Please fix the following:
56
+ </p>
57
+ <ul class="mt-2 space-y-1">
58
+ {#each errorFields as field}
59
+ <li>
60
+ <Button
61
+ variant="link"
62
+ size="sm"
63
+ class="text-red-600! dark:text-red-500! hover:text-red-900! dark:hover:text-red-400!"
64
+ onclick={() => scrollToField(field.elementId)}
65
+ >
66
+ {field.label}
67
+ </Button>
68
+ </li>
69
+ {/each}
70
+ </ul>
71
+ </div>
72
+ </div>
73
+ </div>
74
+ {/if}
@@ -1,21 +1,21 @@
1
- // =============================================================================
2
- // PATTERNS - Layout & flow components (Layer 3)
3
- // =============================================================================
4
-
5
- // Chat - re-export from chat/index.js
6
- export * from './chat/index.js';
7
-
8
- // Forms - re-export from forms/index.js
9
- export * from './forms/index.js';
10
-
11
- // Navigation - re-export from navigation/index.js
12
- export * from './navigation/index.js';
13
-
14
- // Page - re-export from page/index.js
15
- export * from './page/index.js';
16
-
17
- // Data - re-export from data/index.js
18
- export * from './data/index.js';
19
-
20
- // Layout - re-export from layout/index.js
21
- export * from './layout/index.js';
1
+ // =============================================================================
2
+ // PATTERNS - Layout & flow components (Layer 3)
3
+ // =============================================================================
4
+
5
+ // Chat - re-export from chat/index.js
6
+ export * from './chat/index.js';
7
+
8
+ // Forms - re-export from forms/index.js
9
+ export * from './forms/index.js';
10
+
11
+ // Navigation - re-export from navigation/index.js
12
+ export * from './navigation/index.js';
13
+
14
+ // Page - re-export from page/index.js
15
+ export * from './page/index.js';
16
+
17
+ // Data - re-export from data/index.js
18
+ export * from './data/index.js';
19
+
20
+ // Layout - re-export from layout/index.js
21
+ export * from './layout/index.js';