@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,278 +1,278 @@
1
- <script lang="ts">
2
- /**
3
- * Button Component - Flowbite Native (Pure Tailwind)
4
- * Migrated to Svelte 5 runes
5
- *
6
- * Variants (Flowbite naming):
7
- * - default: Primary blue button
8
- * - alternative: Gray outline button
9
- * - outline: Blue outline button
10
- * - red: Destructive solid button
11
- * - red-outline: Destructive outline button
12
- * - ghost: Text-only button
13
- * - ghost-red: Destructive text button
14
- * - icon: Icon-only button
15
- * - toggle: Toggle/pill button
16
- * - avatar: Avatar/image trigger button (no padding, opacity hover)
17
- * - menu-item: Dropdown/sheet menu item (full width, left-aligned)
18
- * - menu-item-danger: Destructive menu item (red text)
19
- * - card: Selectable card button (bordered, for list selections)
20
- * - sidebar-toggle: Compact pill for sidebar expand/collapse
21
- * - chart-row: Leaderboard/chart list row with progress bar
22
- * - landing: Primary hero CTA (blue, shadow, rounded-xl)
23
- * - landing-secondary: Secondary hero CTA (outline, shadow, rounded-xl)
24
- *
25
- * Sizes (Flowbite native): xs, sm, md, lg, xl, landing
26
- *
27
- * Haptic Feedback:
28
- * - Automatic haptic on success state transition
29
- * - Optional haptic on click via `haptic` prop
30
- * - Variant-aware feedback intensity
31
- */
32
- import { CheckOutline } from '../Icons';
33
- import { twMerge } from 'tailwind-merge';
34
- import type { Snippet } from 'svelte';
35
- import {
36
- buttonSizes,
37
- buttonIconSizes,
38
- } from '../../tokens/sizing.js';
39
- import { triggerHaptic, getHapticForButtonVariant } from '../../utils/haptic.js';
40
-
41
- interface Props {
42
- variant?: string;
43
- size?: string;
44
- disabled?: boolean;
45
- loading?: boolean;
46
- success?: boolean;
47
- successText?: string;
48
- active?: boolean;
49
- href?: string | null;
50
- type?: 'button' | 'submit' | 'reset';
51
- /** Enable haptic feedback on click. When true, uses variant-aware haptic style. */
52
- haptic?: boolean;
53
- children?: Snippet;
54
- trailing?: Snippet;
55
- class?: string;
56
- onclick?: (e: MouseEvent) => void;
57
- [key: string]: unknown;
58
- }
59
-
60
- let {
61
- variant = "default",
62
- size = "md",
63
- disabled = false,
64
- loading = false,
65
- success = false,
66
- successText = "",
67
- active = false,
68
- href = null,
69
- type = "button",
70
- haptic = false,
71
- children,
72
- trailing,
73
- class: className = "",
74
- onclick,
75
- ...restProps
76
- }: Props = $props();
77
-
78
- // Track previous success state to detect transitions
79
- let prevSuccess = $state(false);
80
-
81
- // Trigger haptic on success state transition (QOL Bible)
82
- $effect(() => {
83
- if (success && !prevSuccess) {
84
- triggerHaptic('success');
85
- }
86
- prevSuccess = success;
87
- });
88
-
89
- // Legacy variant name mapping
90
- const variantMap: Record<string, string> = {
91
- "blue-solid": "default",
92
- "gray-outline": "alternative",
93
- "blue-outline": "outline",
94
- "red-solid": "red",
95
- "red-text": "ghost-red",
96
- "gray-text": "ghost",
97
- };
98
-
99
- // Resolve legacy names
100
- let resolvedVariant = $derived(variantMap[variant] || variant);
101
- let effectiveDisabled = $derived(disabled || loading || success);
102
-
103
- // Size classes imported from centralized tokens
104
-
105
- // Variant classes with all states in Tailwind (no focus rings - design decision)
106
- // NOTE: menu-item, avatar, nav, card, search-result, landing, sidebar-toggle, calendar-day, chart-row
107
- // have been extracted to dedicated components: MenuItem, AvatarButton, NavItem, CardAction,
108
- // SearchResultItem, LandingButton, SidebarToggle. Use those components instead.
109
- const variantClasses: Record<string, string> = {
110
- default: "text-white bg-blue-700 border border-blue-700 hover:bg-blue-800 dark:bg-blue-600 dark:hover:bg-blue-700",
111
- alternative: "text-gray-900 bg-white border border-gray-200 hover:bg-gray-100 hover:text-blue-700 dark:bg-gray-800 dark:text-white dark:border-gray-600 dark:hover:text-white dark:hover:bg-gray-700",
112
- outline: "text-blue-700 bg-transparent border border-blue-700 hover:text-white hover:bg-blue-800 dark:border-blue-500 dark:text-blue-500 dark:hover:text-white dark:hover:bg-blue-500",
113
- red: "text-white bg-red-700 border border-red-700 hover:bg-red-800 dark:bg-red-600 dark:hover:bg-red-700",
114
- "red-outline": "text-red-700 bg-transparent border border-red-700 hover:text-white hover:bg-red-800 dark:border-red-500 dark:text-red-500 dark:hover:text-white dark:hover:bg-red-600",
115
- "green-outline": "text-green-700 bg-transparent border border-green-700 hover:text-white hover:bg-green-800 dark:border-green-500 dark:text-green-500 dark:hover:text-white dark:hover:bg-green-600",
116
- ghost: "text-gray-500 bg-transparent border-transparent hover:bg-gray-100 hover:text-gray-900 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white",
117
- "ghost-red": "text-red-700 bg-transparent border-transparent hover:bg-red-100 hover:text-red-900 dark:text-red-500 dark:hover:bg-red-900/50 dark:hover:text-red-400",
118
- link: "text-blue-700 bg-transparent border-transparent hover:underline dark:text-blue-500",
119
- icon: "text-gray-500 bg-transparent border-transparent hover:bg-gray-100 dark:text-gray-400 dark:hover:bg-gray-700",
120
- toggle: "text-gray-900 bg-gray-100 border border-gray-200 hover:bg-gray-200 dark:bg-gray-700 dark:text-white dark:border-gray-600 dark:hover:bg-gray-600",
121
- success: "text-white bg-green-600 border border-green-600 hover:bg-green-700 dark:bg-green-600 dark:hover:bg-green-700",
122
- };
123
-
124
- // Active state classes for ghost and toggle
125
- // NOTE: menu-item and nav active states are now handled by MenuItem and NavItem components
126
- const activeClasses: Record<string, string> = {
127
- ghost: "text-blue-700 bg-blue-50 dark:text-white dark:bg-gray-900",
128
- toggle: "text-white bg-blue-600 border-blue-600 hover:bg-blue-700 dark:text-white dark:bg-blue-600 dark:border-blue-600 dark:hover:bg-blue-700",
129
- };
130
-
131
- // Disabled classes
132
- const disabledClasses = "bg-gray-200 border-gray-200 text-gray-400 cursor-not-allowed dark:bg-gray-700 dark:border-gray-700 dark:text-gray-500";
133
- // Disabled classes for transparent variants (link, ghost) - no background
134
- const disabledTransparentClasses = "text-gray-400 cursor-not-allowed dark:text-gray-500";
135
-
136
- let sizeClass = $derived((() => {
137
- if (resolvedVariant === "icon") return buttonIconSizes[size as keyof typeof buttonIconSizes] || buttonIconSizes.sm;
138
- if (resolvedVariant === "link") return "text-sm";
139
- return buttonSizes[size as keyof typeof buttonSizes] || buttonSizes.md;
140
- })());
141
-
142
- // Variants that should stay transparent when disabled
143
- const transparentVariants = ["link", "ghost", "ghost-red", "icon"];
144
-
145
- let variantClass = $derived((() => {
146
- if (success) return variantClasses.success;
147
- if (disabled && !loading && !success) {
148
- return transparentVariants.includes(resolvedVariant)
149
- ? disabledTransparentClasses
150
- : disabledClasses;
151
- }
152
- if (active && activeClasses[resolvedVariant]) {
153
- // When active, use ONLY active classes (they include all necessary styling)
154
- return activeClasses[resolvedVariant];
155
- }
156
- return variantClasses[resolvedVariant] || variantClasses.default;
157
- })());
158
-
159
- // Button is always centered - left-aligned variants have been extracted to dedicated components
160
- let isLeftAligned = $derived(false);
161
-
162
- // Use justify-between when there's trailing content (e.g., chevrons in nav items)
163
- let hasTrailing = $derived(typeof trailing === 'function' || trailing);
164
-
165
- // Standard buttons use rounded-lg - landing variants have been extracted to LandingButton
166
- let roundedClass = $derived("rounded-lg");
167
-
168
- // Click handler with optional haptic feedback
169
- function handleClick(e: MouseEvent) {
170
- if (haptic && !effectiveDisabled) {
171
- const hapticStyle = getHapticForButtonVariant(resolvedVariant);
172
- if (hapticStyle) {
173
- triggerHaptic(hapticStyle);
174
- }
175
- }
176
- onclick?.(e);
177
- }
178
-
179
- let buttonClasses = $derived(twMerge(
180
- "relative",
181
- isLeftAligned
182
- ? (hasTrailing ? "flex items-center justify-between" : "flex items-center justify-start")
183
- : "inline-flex items-center justify-center",
184
- roundedClass,
185
- "font-medium leading-none",
186
- "focus:outline-hidden",
187
- // Apple-style micro-interactions (only when not disabled)
188
- "transition-all duration-150 ease-out",
189
- effectiveDisabled ? "" : "active:scale-[0.97] active:opacity-90",
190
- "select-none",
191
- sizeClass,
192
- variantClass,
193
- effectiveDisabled ? "cursor-not-allowed" : "cursor-pointer",
194
- className
195
- ));
196
- </script>
197
-
198
- {#if href}
199
- <a
200
- {href}
201
- class="{buttonClasses} {loading ? 'loading-pulse' : ''}"
202
- onclick={handleClick}
203
- {...restProps}
204
- >
205
- {#if loading}
206
- <span class="shimmer-overlay"></span>
207
- {/if}
208
- <span class="inline-flex items-center gap-1.5" class:invisible={loading || success}>
209
- {#if typeof children === 'function'}{@render children()}{:else if children}{children}{/if}
210
- </span>
211
- {#if typeof trailing === 'function'}{@render trailing()}{:else if trailing}{trailing}{/if}
212
- </a>
213
- {:else}
214
- <button
215
- {type}
216
- class="{buttonClasses} {loading ? 'loading-pulse' : ''}"
217
- disabled={effectiveDisabled}
218
- onclick={handleClick}
219
- {...restProps}
220
- >
221
- {#if loading}
222
- <span class="shimmer-overlay"></span>
223
- {/if}
224
- <span class="inline-flex items-center gap-1.5" class:invisible={loading || success}>
225
- {#if typeof children === 'function'}{@render children()}{:else if children}{children}{/if}
226
- </span>
227
- {#if typeof trailing === 'function'}{@render trailing()}{:else if trailing}{trailing}{/if}
228
- {#if success}
229
- <span class="absolute inset-0 flex items-center justify-center gap-2">
230
- <CheckOutline class="w-5 h-5" />
231
- {#if successText}<span class="font-medium">{successText}</span>{/if}
232
- </span>
233
- {/if}
234
- </button>
235
- {/if}
236
-
237
- <style>
238
- .loading-pulse {
239
- animation: pulse-bg 2s ease-in-out infinite;
240
- }
241
-
242
- @keyframes pulse-bg {
243
- 0%, 100% { filter: brightness(1); }
244
- 50% { filter: brightness(1.15); }
245
- }
246
-
247
- .shimmer-overlay {
248
- position: absolute;
249
- inset: 0;
250
- overflow: hidden;
251
- border-radius: inherit;
252
- }
253
-
254
- .shimmer-overlay::after {
255
- content: '';
256
- position: absolute;
257
- top: 0;
258
- left: -100%;
259
- width: 100%;
260
- height: 100%;
261
- background: linear-gradient(
262
- 90deg,
263
- transparent 0%,
264
- rgba(255, 255, 255, 0.2) 50%,
265
- transparent 100%
266
- );
267
- animation: shimmer 1s ease-in-out infinite;
268
- }
269
-
270
- @keyframes shimmer {
271
- 0% {
272
- left: -100%;
273
- }
274
- 100% {
275
- left: 100%;
276
- }
277
- }
278
- </style>
1
+ <script lang="ts">
2
+ /**
3
+ * Button Component - Flowbite Native (Pure Tailwind)
4
+ * Migrated to Svelte 5 runes
5
+ *
6
+ * Variants (Flowbite naming):
7
+ * - default: Primary blue button
8
+ * - alternative: Gray outline button
9
+ * - outline: Blue outline button
10
+ * - red: Destructive solid button
11
+ * - red-outline: Destructive outline button
12
+ * - ghost: Text-only button
13
+ * - ghost-red: Destructive text button
14
+ * - icon: Icon-only button
15
+ * - toggle: Toggle/pill button
16
+ * - avatar: Avatar/image trigger button (no padding, opacity hover)
17
+ * - menu-item: Dropdown/sheet menu item (full width, left-aligned)
18
+ * - menu-item-danger: Destructive menu item (red text)
19
+ * - card: Selectable card button (bordered, for list selections)
20
+ * - sidebar-toggle: Compact pill for sidebar expand/collapse
21
+ * - chart-row: Leaderboard/chart list row with progress bar
22
+ * - landing: Primary hero CTA (blue, shadow, rounded-xl)
23
+ * - landing-secondary: Secondary hero CTA (outline, shadow, rounded-xl)
24
+ *
25
+ * Sizes (Flowbite native): xs, sm, md, lg, xl, landing
26
+ *
27
+ * Haptic Feedback:
28
+ * - Automatic haptic on success state transition
29
+ * - Optional haptic on click via `haptic` prop
30
+ * - Variant-aware feedback intensity
31
+ */
32
+ import { CheckOutline } from '../Icons';
33
+ import { twMerge } from 'tailwind-merge';
34
+ import type { Snippet } from 'svelte';
35
+ import {
36
+ buttonSizes,
37
+ buttonIconSizes,
38
+ } from '../../tokens/sizing.js';
39
+ import { triggerHaptic, getHapticForButtonVariant } from '../../utils/haptic.js';
40
+
41
+ interface Props {
42
+ variant?: string;
43
+ size?: string;
44
+ disabled?: boolean;
45
+ loading?: boolean;
46
+ success?: boolean;
47
+ successText?: string;
48
+ active?: boolean;
49
+ href?: string | null;
50
+ type?: 'button' | 'submit' | 'reset';
51
+ /** Enable haptic feedback on click. When true, uses variant-aware haptic style. */
52
+ haptic?: boolean;
53
+ children?: Snippet;
54
+ trailing?: Snippet;
55
+ class?: string;
56
+ onclick?: (e: MouseEvent) => void;
57
+ [key: string]: unknown;
58
+ }
59
+
60
+ let {
61
+ variant = "default",
62
+ size = "md",
63
+ disabled = false,
64
+ loading = false,
65
+ success = false,
66
+ successText = "",
67
+ active = false,
68
+ href = null,
69
+ type = "button",
70
+ haptic = false,
71
+ children,
72
+ trailing,
73
+ class: className = "",
74
+ onclick,
75
+ ...restProps
76
+ }: Props = $props();
77
+
78
+ // Track previous success state to detect transitions
79
+ let prevSuccess = $state(false);
80
+
81
+ // Trigger haptic on success state transition (QOL Bible)
82
+ $effect(() => {
83
+ if (success && !prevSuccess) {
84
+ triggerHaptic('success');
85
+ }
86
+ prevSuccess = success;
87
+ });
88
+
89
+ // Legacy variant name mapping
90
+ const variantMap: Record<string, string> = {
91
+ "blue-solid": "default",
92
+ "gray-outline": "alternative",
93
+ "blue-outline": "outline",
94
+ "red-solid": "red",
95
+ "red-text": "ghost-red",
96
+ "gray-text": "ghost",
97
+ };
98
+
99
+ // Resolve legacy names
100
+ let resolvedVariant = $derived(variantMap[variant] || variant);
101
+ let effectiveDisabled = $derived(disabled || loading || success);
102
+
103
+ // Size classes imported from centralized tokens
104
+
105
+ // Variant classes with all states in Tailwind (no focus rings - design decision)
106
+ // NOTE: menu-item, avatar, nav, card, search-result, landing, sidebar-toggle, calendar-day, chart-row
107
+ // have been extracted to dedicated components: MenuItem, AvatarButton, NavItem, CardAction,
108
+ // SearchResultItem, LandingButton, SidebarToggle. Use those components instead.
109
+ const variantClasses: Record<string, string> = {
110
+ default: "text-white bg-blue-700 border border-blue-700 hover:bg-blue-800 dark:bg-blue-600 dark:hover:bg-blue-700",
111
+ alternative: "text-gray-900 bg-white border border-gray-200 hover:bg-gray-100 hover:text-blue-700 dark:bg-gray-800 dark:text-white dark:border-gray-600 dark:hover:text-white dark:hover:bg-gray-700",
112
+ outline: "text-blue-700 bg-transparent border border-blue-700 hover:text-white hover:bg-blue-800 dark:border-blue-500 dark:text-blue-500 dark:hover:text-white dark:hover:bg-blue-500",
113
+ red: "text-white bg-red-700 border border-red-700 hover:bg-red-800 dark:bg-red-600 dark:hover:bg-red-700",
114
+ "red-outline": "text-red-700 bg-transparent border border-red-700 hover:text-white hover:bg-red-800 dark:border-red-500 dark:text-red-500 dark:hover:text-white dark:hover:bg-red-600",
115
+ "green-outline": "text-green-700 bg-transparent border border-green-700 hover:text-white hover:bg-green-800 dark:border-green-500 dark:text-green-500 dark:hover:text-white dark:hover:bg-green-600",
116
+ ghost: "text-gray-500 bg-transparent border-transparent hover:bg-gray-100 hover:text-gray-900 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white",
117
+ "ghost-red": "text-red-700 bg-transparent border-transparent hover:bg-red-100 hover:text-red-900 dark:text-red-500 dark:hover:bg-red-900/50 dark:hover:text-red-400",
118
+ link: "text-blue-700 bg-transparent border-transparent hover:underline dark:text-blue-500",
119
+ icon: "text-gray-500 bg-transparent border-transparent hover:bg-gray-100 dark:text-gray-400 dark:hover:bg-gray-700",
120
+ toggle: "text-gray-900 bg-gray-100 border border-gray-200 hover:bg-gray-200 dark:bg-gray-700 dark:text-white dark:border-gray-600 dark:hover:bg-gray-600",
121
+ success: "text-white bg-green-600 border border-green-600 hover:bg-green-700 dark:bg-green-600 dark:hover:bg-green-700",
122
+ };
123
+
124
+ // Active state classes for ghost and toggle
125
+ // NOTE: menu-item and nav active states are now handled by MenuItem and NavItem components
126
+ const activeClasses: Record<string, string> = {
127
+ ghost: "text-blue-700 bg-blue-50 dark:text-white dark:bg-gray-900",
128
+ toggle: "text-white bg-blue-600 border-blue-600 hover:bg-blue-700 dark:text-white dark:bg-blue-600 dark:border-blue-600 dark:hover:bg-blue-700",
129
+ };
130
+
131
+ // Disabled classes
132
+ const disabledClasses = "bg-gray-200 border-gray-200 text-gray-400 cursor-not-allowed dark:bg-gray-700 dark:border-gray-700 dark:text-gray-500";
133
+ // Disabled classes for transparent variants (link, ghost) - no background
134
+ const disabledTransparentClasses = "text-gray-400 cursor-not-allowed dark:text-gray-500";
135
+
136
+ let sizeClass = $derived((() => {
137
+ if (resolvedVariant === "icon") return buttonIconSizes[size as keyof typeof buttonIconSizes] || buttonIconSizes.sm;
138
+ if (resolvedVariant === "link") return "text-sm";
139
+ return buttonSizes[size as keyof typeof buttonSizes] || buttonSizes.md;
140
+ })());
141
+
142
+ // Variants that should stay transparent when disabled
143
+ const transparentVariants = ["link", "ghost", "ghost-red", "icon"];
144
+
145
+ let variantClass = $derived((() => {
146
+ if (success) return variantClasses.success;
147
+ if (disabled && !loading && !success) {
148
+ return transparentVariants.includes(resolvedVariant)
149
+ ? disabledTransparentClasses
150
+ : disabledClasses;
151
+ }
152
+ if (active && activeClasses[resolvedVariant]) {
153
+ // When active, use ONLY active classes (they include all necessary styling)
154
+ return activeClasses[resolvedVariant];
155
+ }
156
+ return variantClasses[resolvedVariant] || variantClasses.default;
157
+ })());
158
+
159
+ // Button is always centered - left-aligned variants have been extracted to dedicated components
160
+ let isLeftAligned = $derived(false);
161
+
162
+ // Use justify-between when there's trailing content (e.g., chevrons in nav items)
163
+ let hasTrailing = $derived(typeof trailing === 'function' || trailing);
164
+
165
+ // Standard buttons use rounded-lg - landing variants have been extracted to LandingButton
166
+ let roundedClass = $derived("rounded-lg");
167
+
168
+ // Click handler with optional haptic feedback
169
+ function handleClick(e: MouseEvent) {
170
+ if (haptic && !effectiveDisabled) {
171
+ const hapticStyle = getHapticForButtonVariant(resolvedVariant);
172
+ if (hapticStyle) {
173
+ triggerHaptic(hapticStyle);
174
+ }
175
+ }
176
+ onclick?.(e);
177
+ }
178
+
179
+ let buttonClasses = $derived(twMerge(
180
+ "relative",
181
+ isLeftAligned
182
+ ? (hasTrailing ? "flex items-center justify-between" : "flex items-center justify-start")
183
+ : "inline-flex items-center justify-center",
184
+ roundedClass,
185
+ "font-medium leading-none",
186
+ "focus:outline-hidden",
187
+ // Apple-style micro-interactions (only when not disabled)
188
+ "transition-all duration-150 ease-out",
189
+ effectiveDisabled ? "" : "active:scale-[0.97] active:opacity-90",
190
+ "select-none",
191
+ sizeClass,
192
+ variantClass,
193
+ effectiveDisabled ? "cursor-not-allowed" : "cursor-pointer",
194
+ className
195
+ ));
196
+ </script>
197
+
198
+ {#if href}
199
+ <a
200
+ {href}
201
+ class="{buttonClasses} {loading ? 'loading-pulse' : ''}"
202
+ onclick={handleClick}
203
+ {...restProps}
204
+ >
205
+ {#if loading}
206
+ <span class="shimmer-overlay"></span>
207
+ {/if}
208
+ <span class="inline-flex items-center gap-1.5" class:invisible={loading || success}>
209
+ {#if typeof children === 'function'}{@render children()}{:else if children}{children}{/if}
210
+ </span>
211
+ {#if typeof trailing === 'function'}{@render trailing()}{:else if trailing}{trailing}{/if}
212
+ </a>
213
+ {:else}
214
+ <button
215
+ {type}
216
+ class="{buttonClasses} {loading ? 'loading-pulse' : ''}"
217
+ disabled={effectiveDisabled}
218
+ onclick={handleClick}
219
+ {...restProps}
220
+ >
221
+ {#if loading}
222
+ <span class="shimmer-overlay"></span>
223
+ {/if}
224
+ <span class="inline-flex items-center gap-1.5" class:invisible={loading || success}>
225
+ {#if typeof children === 'function'}{@render children()}{:else if children}{children}{/if}
226
+ </span>
227
+ {#if typeof trailing === 'function'}{@render trailing()}{:else if trailing}{trailing}{/if}
228
+ {#if success}
229
+ <span class="absolute inset-0 flex items-center justify-center gap-2">
230
+ <CheckOutline class="w-5 h-5" />
231
+ {#if successText}<span class="font-medium">{successText}</span>{/if}
232
+ </span>
233
+ {/if}
234
+ </button>
235
+ {/if}
236
+
237
+ <style>
238
+ .loading-pulse {
239
+ animation: pulse-bg 2s ease-in-out infinite;
240
+ }
241
+
242
+ @keyframes pulse-bg {
243
+ 0%, 100% { filter: brightness(1); }
244
+ 50% { filter: brightness(1.15); }
245
+ }
246
+
247
+ .shimmer-overlay {
248
+ position: absolute;
249
+ inset: 0;
250
+ overflow: hidden;
251
+ border-radius: inherit;
252
+ }
253
+
254
+ .shimmer-overlay::after {
255
+ content: '';
256
+ position: absolute;
257
+ top: 0;
258
+ left: -100%;
259
+ width: 100%;
260
+ height: 100%;
261
+ background: linear-gradient(
262
+ 90deg,
263
+ transparent 0%,
264
+ rgba(255, 255, 255, 0.2) 50%,
265
+ transparent 100%
266
+ );
267
+ animation: shimmer 1s ease-in-out infinite;
268
+ }
269
+
270
+ @keyframes shimmer {
271
+ 0% {
272
+ left: -100%;
273
+ }
274
+ 100% {
275
+ left: 100%;
276
+ }
277
+ }
278
+ </style>
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=ButtonGroup.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ButtonGroup.spec.d.ts","sourceRoot":"","sources":["../../../src/lib/primitives/Button/ButtonGroup.spec.js"],"names":[],"mappings":""}
@@ -0,0 +1,44 @@
1
+ import { render } from '@testing-library/svelte';
2
+ import { createRawSnippet } from 'svelte';
3
+ import { expect, describe, test } from 'vitest';
4
+ import ButtonGroup from './ButtonGroup.svelte';
5
+
6
+ function textSnippet(text) {
7
+ return createRawSnippet(() => ({
8
+ render: () => `<span>${text}</span>`
9
+ }));
10
+ }
11
+
12
+ describe('ButtonGroup', () => {
13
+ test('renders with role="group"', () => {
14
+ const { container } = render(ButtonGroup);
15
+ expect(container.querySelector('[role="group"]')).toBeInTheDocument();
16
+ });
17
+
18
+ test('has inline-flex layout', () => {
19
+ const { container } = render(ButtonGroup);
20
+ expect(container.querySelector('.inline-flex')).toBeInTheDocument();
21
+ });
22
+
23
+ test('has rounded styling', () => {
24
+ const { container } = render(ButtonGroup);
25
+ expect(container.querySelector('[class*="rounded"]')).toBeInTheDocument();
26
+ });
27
+
28
+ test('applies custom className', () => {
29
+ const { container } = render(ButtonGroup, { props: { class: 'my-group' } });
30
+ expect(container.querySelector('.my-group')).toBeInTheDocument();
31
+ });
32
+
33
+ test('renders children content when provided', () => {
34
+ const { container } = render(ButtonGroup, {
35
+ props: { children: textSnippet('Group content') }
36
+ });
37
+ expect(container.querySelector('[role="group"]').textContent).toBe('Group content');
38
+ });
39
+
40
+ test('renders empty group when no children provided', () => {
41
+ const { container } = render(ButtonGroup);
42
+ expect(container.querySelector('[role="group"]').textContent).toBe('');
43
+ });
44
+ });