@getmicdrop/svelte-components 5.5.1 → 5.5.5

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 (472) hide show
  1. package/dist/calendar/AboutShow/AboutShow.spec.d.ts +2 -0
  2. package/dist/calendar/AboutShow/AboutShow.spec.d.ts.map +1 -0
  3. package/dist/calendar/AboutShow/AboutShow.spec.js +791 -0
  4. package/dist/calendar/AboutShow/AboutShow.svelte +172 -172
  5. package/dist/calendar/Calendar/MiniMonthCalendar.spec.d.ts +2 -0
  6. package/dist/calendar/Calendar/MiniMonthCalendar.spec.d.ts.map +1 -0
  7. package/dist/calendar/Calendar/MiniMonthCalendar.spec.js +1191 -0
  8. package/dist/calendar/Calendar/MiniMonthCalendar.svelte +782 -782
  9. package/dist/calendar/FAQs/FAQs.spec.d.ts +2 -0
  10. package/dist/calendar/FAQs/FAQs.spec.d.ts.map +1 -0
  11. package/dist/calendar/FAQs/FAQs.spec.js +238 -0
  12. package/dist/calendar/FAQs/FAQs.svelte +75 -75
  13. package/dist/calendar/MonthSwitcher/MonthSwitcher.spec.d.ts +2 -0
  14. package/dist/calendar/MonthSwitcher/MonthSwitcher.spec.d.ts.map +1 -0
  15. package/dist/calendar/MonthSwitcher/MonthSwitcher.spec.js +420 -0
  16. package/dist/calendar/MonthSwitcher/MonthSwitcher.svelte +126 -126
  17. package/dist/calendar/OrderSummary/OrderSummary.spec.d.ts +2 -0
  18. package/dist/calendar/OrderSummary/OrderSummary.spec.d.ts.map +1 -0
  19. package/dist/calendar/OrderSummary/OrderSummary.spec.js +808 -0
  20. package/dist/calendar/OrderSummary/OrderSummary.svelte +367 -367
  21. package/dist/calendar/PublicCard/PublicCard.spec.d.ts +2 -0
  22. package/dist/calendar/PublicCard/PublicCard.spec.d.ts.map +1 -0
  23. package/dist/calendar/PublicCard/PublicCard.spec.js +301 -0
  24. package/dist/calendar/PublicCard/PublicCard.svelte +134 -134
  25. package/dist/calendar/ShowCard/ShowCard.spec.d.ts +2 -0
  26. package/dist/calendar/ShowCard/ShowCard.spec.d.ts.map +1 -0
  27. package/dist/calendar/ShowCard/ShowCard.spec.js +714 -0
  28. package/dist/calendar/ShowCard/ShowCard.svelte +157 -157
  29. package/dist/calendar/ShowTimeCard/ShowTimeCard.spec.d.ts +2 -0
  30. package/dist/calendar/ShowTimeCard/ShowTimeCard.spec.d.ts.map +1 -0
  31. package/dist/calendar/ShowTimeCard/ShowTimeCard.spec.js +241 -0
  32. package/dist/calendar/ShowTimeCard/ShowTimeCard.svelte +61 -61
  33. package/dist/components/Layout/Grid.svelte +4 -4
  34. package/dist/components/Layout/Section.spec.d.ts +2 -0
  35. package/dist/components/Layout/Section.spec.d.ts.map +1 -0
  36. package/dist/components/Layout/Section.spec.js +149 -0
  37. package/dist/components/Layout/Section.svelte +80 -80
  38. package/dist/components/Layout/Sidebar.spec.d.ts +2 -0
  39. package/dist/components/Layout/Sidebar.spec.d.ts.map +1 -0
  40. package/dist/components/Layout/Sidebar.spec.js +186 -0
  41. package/dist/components/Layout/Sidebar.svelte +108 -108
  42. package/dist/components/Layout/Stack.spec.js +3 -3
  43. package/dist/components/Layout/Stack.svelte +6 -6
  44. package/dist/constants/formOptions.spec.js +9 -5
  45. package/dist/constants/validation.js +91 -91
  46. package/dist/constants/validation.spec.js +64 -64
  47. package/dist/datetime/__tests__/format.test.js +1 -1
  48. package/dist/datetime/__tests__/parse.test.js +1 -1
  49. package/dist/datetime/__tests__/timezone.test.js +124 -2
  50. package/dist/datetime/parse.js +1 -1
  51. package/dist/forms/createFieldTracker.spec.d.ts +2 -0
  52. package/dist/forms/createFieldTracker.spec.d.ts.map +1 -0
  53. package/dist/forms/createFieldTracker.spec.js +343 -0
  54. package/dist/forms/createFormStore.spec.d.ts +2 -0
  55. package/dist/forms/createFormStore.spec.d.ts.map +1 -0
  56. package/dist/forms/createFormStore.spec.js +689 -0
  57. package/dist/forms/createFormStore.svelte.js +0 -1
  58. package/dist/index.d.ts +5 -112
  59. package/dist/index.js +40 -225
  60. package/dist/patterns/data/DataGrid.spec.d.ts +2 -0
  61. package/dist/patterns/data/DataGrid.spec.d.ts.map +1 -0
  62. package/dist/patterns/data/DataGrid.spec.js +159 -0
  63. package/dist/patterns/data/DataGrid.svelte +45 -45
  64. package/dist/patterns/data/DataList.spec.d.ts +2 -0
  65. package/dist/patterns/data/DataList.spec.d.ts.map +1 -0
  66. package/dist/patterns/data/DataList.spec.js +158 -0
  67. package/dist/patterns/data/DataList.svelte +24 -24
  68. package/dist/patterns/data/DataTable.spec.d.ts +2 -0
  69. package/dist/patterns/data/DataTable.spec.d.ts.map +1 -0
  70. package/dist/patterns/data/DataTable.spec.js +196 -0
  71. package/dist/patterns/data/DataTable.svelte +36 -36
  72. package/dist/patterns/forms/FormActions.spec.js +95 -88
  73. package/dist/patterns/forms/FormActions.stories.svelte +97 -97
  74. package/dist/patterns/forms/FormActions.svelte +46 -46
  75. package/dist/patterns/forms/FormGrid.spec.d.ts +2 -0
  76. package/dist/patterns/forms/FormGrid.spec.d.ts.map +1 -0
  77. package/dist/patterns/forms/FormGrid.spec.js +125 -0
  78. package/dist/patterns/forms/FormGrid.svelte +33 -33
  79. package/dist/patterns/forms/FormSection.spec.d.ts +2 -0
  80. package/dist/patterns/forms/FormSection.spec.d.ts.map +1 -0
  81. package/dist/patterns/forms/FormSection.spec.js +153 -0
  82. package/dist/patterns/forms/FormSection.svelte +32 -32
  83. package/dist/patterns/forms/FormValidationSummary.stories.svelte +83 -83
  84. package/dist/patterns/forms/FormValidationSummary.svelte +33 -33
  85. package/dist/patterns/layout/Sidebar.spec.d.ts +2 -0
  86. package/dist/patterns/layout/Sidebar.spec.d.ts.map +1 -0
  87. package/dist/patterns/layout/Sidebar.spec.js +159 -0
  88. package/dist/patterns/layout/Sidebar.svelte +39 -39
  89. package/dist/patterns/navigation/BottomNav.stories.svelte +117 -117
  90. package/dist/patterns/navigation/BottomNav.svelte +20 -20
  91. package/dist/patterns/navigation/Header.spec.js +33 -24
  92. package/dist/patterns/navigation/Header.stories.svelte +77 -77
  93. package/dist/patterns/navigation/Header.svelte +193 -193
  94. package/dist/patterns/page/PageHeader.spec.d.ts +2 -0
  95. package/dist/patterns/page/PageHeader.spec.d.ts.map +1 -0
  96. package/dist/patterns/page/PageHeader.spec.js +167 -0
  97. package/dist/patterns/page/PageHeader.svelte +18 -18
  98. package/dist/patterns/page/PageLayout.spec.d.ts +2 -0
  99. package/dist/patterns/page/PageLayout.spec.d.ts.map +1 -0
  100. package/dist/patterns/page/PageLayout.spec.js +145 -0
  101. package/dist/patterns/page/PageLayout.svelte +40 -40
  102. package/dist/patterns/page/PageLoader.spec.js +57 -54
  103. package/dist/patterns/page/PageLoader.stories.svelte +137 -137
  104. package/dist/patterns/page/PageLoader.svelte +24 -24
  105. package/dist/patterns/page/SectionHeader.spec.d.ts +2 -0
  106. package/dist/patterns/page/SectionHeader.spec.d.ts.map +1 -0
  107. package/dist/patterns/page/SectionHeader.spec.js +197 -0
  108. package/dist/patterns/page/SectionHeader.svelte +29 -29
  109. package/dist/presets/badges.js +112 -112
  110. package/dist/presets/badges.spec.d.ts +2 -0
  111. package/dist/presets/badges.spec.d.ts.map +1 -0
  112. package/dist/presets/badges.spec.js +172 -0
  113. package/dist/presets/buttons.js +76 -76
  114. package/dist/presets/buttons.spec.d.ts +2 -0
  115. package/dist/presets/buttons.spec.d.ts.map +1 -0
  116. package/dist/presets/buttons.spec.js +135 -0
  117. package/dist/presets/index.js +9 -9
  118. package/dist/primitives/Accordion/Accordion.spec.d.ts +2 -0
  119. package/dist/primitives/Accordion/Accordion.spec.d.ts.map +1 -0
  120. package/dist/primitives/Accordion/Accordion.spec.js +83 -0
  121. package/dist/primitives/Accordion/Accordion.stories.svelte +75 -75
  122. package/dist/primitives/Accordion/Accordion.svelte +42 -42
  123. package/dist/primitives/Accordion/AccordionItem.spec.d.ts +2 -0
  124. package/dist/primitives/Accordion/AccordionItem.spec.d.ts.map +1 -0
  125. package/dist/primitives/Accordion/AccordionItem.spec.js +661 -0
  126. package/dist/primitives/Accordion/AccordionItem.svelte +95 -95
  127. package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte +107 -0
  128. package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte.d.ts +35 -0
  129. package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte.d.ts.map +1 -0
  130. package/dist/primitives/Alert/Alert.spec.js +173 -170
  131. package/dist/primitives/Alert/Alert.stories.svelte +88 -88
  132. package/dist/primitives/Alert/Alert.svelte +27 -27
  133. package/dist/primitives/Avatar/Avatar.spec.d.ts +2 -0
  134. package/dist/primitives/Avatar/Avatar.spec.d.ts.map +1 -0
  135. package/dist/primitives/Avatar/Avatar.spec.js +211 -0
  136. package/dist/primitives/Avatar/Avatar.stories.svelte +94 -94
  137. package/dist/primitives/Avatar/Avatar.svelte +66 -66
  138. package/dist/primitives/Badges/Badge.spec.js +144 -103
  139. package/dist/primitives/Badges/Badge.stories.svelte +86 -86
  140. package/dist/primitives/Badges/Badge.svelte +79 -79
  141. package/dist/primitives/BottomSheet/BottomSheet.spec.js +136 -127
  142. package/dist/primitives/BottomSheet/BottomSheet.stories.svelte +83 -83
  143. package/dist/primitives/BottomSheet/BottomSheet.svelte +100 -100
  144. package/dist/primitives/BottomSheet/BottomSheetWrapper.test.svelte +13 -0
  145. package/dist/primitives/BottomSheet/BottomSheetWrapper.test.svelte.d.ts +7 -0
  146. package/dist/primitives/BottomSheet/BottomSheetWrapper.test.svelte.d.ts.map +1 -0
  147. package/dist/primitives/Breadcrumb/Breadcrumb.spec.js +122 -120
  148. package/dist/primitives/Breadcrumb/Breadcrumb.stories.svelte +23 -23
  149. package/dist/primitives/Breadcrumb/Breadcrumb.svelte +89 -89
  150. package/dist/primitives/Button/Button.spec.js +223 -211
  151. package/dist/primitives/Button/Button.stories.svelte +76 -76
  152. package/dist/primitives/Button/Button.svelte +270 -270
  153. package/dist/primitives/Button/ButtonSaveDemo.spec.js +146 -48
  154. package/dist/primitives/Button/ButtonSaveDemo.svelte +25 -25
  155. package/dist/primitives/Button/ButtonVariantShowcase.spec.d.ts +2 -0
  156. package/dist/primitives/Button/ButtonVariantShowcase.spec.d.ts.map +1 -0
  157. package/dist/primitives/Button/ButtonVariantShowcase.spec.js +202 -0
  158. package/dist/primitives/Button/ButtonVariantShowcase.svelte +129 -129
  159. package/dist/primitives/Card.spec.js +49 -49
  160. package/dist/primitives/Card.stories.svelte +22 -22
  161. package/dist/primitives/Card.svelte +28 -28
  162. package/dist/primitives/Checkbox/Checkbox.spec.d.ts +2 -0
  163. package/dist/primitives/Checkbox/Checkbox.spec.d.ts.map +1 -0
  164. package/dist/primitives/Checkbox/Checkbox.spec.js +252 -0
  165. package/dist/primitives/Checkbox/Checkbox.stories.svelte +84 -84
  166. package/dist/primitives/Checkbox/Checkbox.svelte +88 -88
  167. package/dist/primitives/DarkModeToggle.spec.js +390 -357
  168. package/dist/primitives/DarkModeToggle.stories.svelte +57 -57
  169. package/dist/primitives/DarkModeToggle.svelte +136 -136
  170. package/dist/primitives/Drawer/Drawer.spec.d.ts +2 -0
  171. package/dist/primitives/Drawer/Drawer.spec.d.ts.map +1 -0
  172. package/dist/primitives/Drawer/Drawer.spec.js +212 -0
  173. package/dist/primitives/Drawer/Drawer.stories.svelte +80 -80
  174. package/dist/primitives/Drawer/Drawer.svelte +120 -120
  175. package/dist/primitives/Dropdown/Dropdown.spec.d.ts +2 -0
  176. package/dist/primitives/Dropdown/Dropdown.spec.d.ts.map +1 -0
  177. package/dist/primitives/Dropdown/Dropdown.spec.js +366 -0
  178. package/dist/primitives/Dropdown/Dropdown.stories.svelte +137 -137
  179. package/dist/primitives/Dropdown/Dropdown.svelte +14 -14
  180. package/dist/primitives/Dropdown/DropdownItem.spec.d.ts +2 -0
  181. package/dist/primitives/Dropdown/DropdownItem.spec.d.ts.map +1 -0
  182. package/dist/primitives/Dropdown/DropdownItem.spec.js +182 -0
  183. package/dist/primitives/Dropdown/DropdownItem.svelte +80 -80
  184. package/dist/primitives/Icons/ArrowLeft.svelte +8 -8
  185. package/dist/primitives/Icons/ArrowRight.svelte +8 -8
  186. package/dist/primitives/Icons/Availability.svelte +14 -14
  187. package/dist/primitives/Icons/Back.svelte +14 -14
  188. package/dist/primitives/Icons/CheckCircle.svelte +6 -6
  189. package/dist/primitives/Icons/CheckCircleOutline.svelte +15 -15
  190. package/dist/primitives/Icons/ChevronLeft.svelte +4 -4
  191. package/dist/primitives/Icons/ChevronRight.svelte +4 -4
  192. package/dist/primitives/Icons/Copy.svelte +15 -15
  193. package/dist/primitives/Icons/Cross.svelte +5 -5
  194. package/dist/primitives/Icons/DownArrow.svelte +8 -8
  195. package/dist/primitives/Icons/ErrorCircle.svelte +6 -6
  196. package/dist/primitives/Icons/FacebookIcon.svelte +2 -2
  197. package/dist/primitives/Icons/Home.svelte +15 -15
  198. package/dist/primitives/Icons/Icon.spec.js +169 -169
  199. package/dist/primitives/Icons/Icon.stories.svelte +100 -100
  200. package/dist/primitives/Icons/Icon.svelte +52 -52
  201. package/dist/primitives/Icons/IconGallery.stories.svelte +235 -235
  202. package/dist/primitives/Icons/Info.svelte +7 -7
  203. package/dist/primitives/Icons/InstagramIcon.svelte +4 -4
  204. package/dist/primitives/Icons/LogoInstagram.svelte +2 -2
  205. package/dist/primitives/Icons/Message.svelte +15 -15
  206. package/dist/primitives/Icons/MoonIcon.svelte +5 -5
  207. package/dist/primitives/Icons/More.svelte +21 -21
  208. package/dist/primitives/Icons/MoreHori.spec.js +61 -61
  209. package/dist/primitives/Icons/MoreHori.svelte +22 -22
  210. package/dist/primitives/Icons/Notification.svelte +14 -14
  211. package/dist/primitives/Icons/Payment.svelte +14 -14
  212. package/dist/primitives/Icons/Profile.svelte +21 -21
  213. package/dist/primitives/Icons/Reload.svelte +29 -29
  214. package/dist/primitives/Icons/Shows.svelte +21 -21
  215. package/dist/primitives/Icons/Signout.svelte +21 -21
  216. package/dist/primitives/Icons/SunIcon.svelte +8 -8
  217. package/dist/primitives/Icons/TiktokIcon.svelte +2 -2
  218. package/dist/primitives/Icons/TwitterIcon.svelte +2 -2
  219. package/dist/primitives/Icons/WarningIcon.spec.js +18 -18
  220. package/dist/primitives/Icons/WarningIcon.svelte +5 -5
  221. package/dist/primitives/Icons/iconTestUtils.spec.d.ts +2 -0
  222. package/dist/primitives/Icons/iconTestUtils.spec.d.ts.map +1 -0
  223. package/dist/primitives/Icons/iconTestUtils.spec.js +235 -0
  224. package/dist/primitives/Input/Input.spec.js +573 -573
  225. package/dist/primitives/Input/Input.stories.svelte +139 -139
  226. package/dist/primitives/Input/Input.svelte +384 -397
  227. package/dist/primitives/Input/Input.svelte.d.ts.map +1 -1
  228. package/dist/primitives/Input/Select.spec.js +212 -218
  229. package/dist/primitives/Input/Select.stories.svelte +112 -112
  230. package/dist/primitives/Input/Select.svelte +128 -128
  231. package/dist/primitives/Input/Textarea.spec.d.ts +2 -0
  232. package/dist/primitives/Input/Textarea.spec.d.ts.map +1 -0
  233. package/dist/primitives/Input/Textarea.spec.js +255 -0
  234. package/dist/primitives/Input/Textarea.stories.svelte +137 -137
  235. package/dist/primitives/Input/Textarea.svelte +35 -35
  236. package/dist/primitives/Label/Label.spec.d.ts +2 -0
  237. package/dist/primitives/Label/Label.spec.d.ts.map +1 -0
  238. package/dist/primitives/Label/Label.spec.js +157 -0
  239. package/dist/primitives/Label/Label.svelte +37 -37
  240. package/dist/primitives/Modal/Modal.spec.js +99 -95
  241. package/dist/primitives/Modal/Modal.stories.svelte +86 -86
  242. package/dist/primitives/Modal/Modal.svelte +158 -158
  243. package/dist/primitives/Modal/ModalTestWrapper.svelte +65 -0
  244. package/dist/primitives/Modal/ModalTestWrapper.svelte.d.ts +23 -0
  245. package/dist/primitives/Modal/ModalTestWrapper.svelte.d.ts.map +1 -0
  246. package/dist/primitives/NumberInput/NumberInput.spec.d.ts +2 -0
  247. package/dist/primitives/NumberInput/NumberInput.spec.d.ts.map +1 -0
  248. package/dist/primitives/NumberInput/NumberInput.spec.js +235 -0
  249. package/dist/primitives/NumberInput/NumberInput.svelte +106 -106
  250. package/dist/primitives/Pagination/Pagination.spec.d.ts +2 -0
  251. package/dist/primitives/Pagination/Pagination.spec.d.ts.map +1 -0
  252. package/dist/primitives/Pagination/Pagination.spec.js +266 -0
  253. package/dist/primitives/Pagination/Pagination.stories.svelte +76 -76
  254. package/dist/primitives/Pagination/Pagination.svelte +261 -261
  255. package/dist/primitives/Radio/Radio.spec.d.ts +2 -0
  256. package/dist/primitives/Radio/Radio.spec.d.ts.map +1 -0
  257. package/dist/primitives/Radio/Radio.spec.js +206 -0
  258. package/dist/primitives/Radio/Radio.stories.svelte +80 -80
  259. package/dist/primitives/Radio/Radio.svelte +67 -67
  260. package/dist/primitives/Skeleton/CardPlaceholder.spec.d.ts +2 -0
  261. package/dist/primitives/Skeleton/CardPlaceholder.spec.d.ts.map +1 -0
  262. package/dist/primitives/Skeleton/CardPlaceholder.spec.js +156 -0
  263. package/dist/primitives/Skeleton/CardPlaceholder.svelte +87 -87
  264. package/dist/primitives/Skeleton/ImagePlaceholder.spec.d.ts +2 -0
  265. package/dist/primitives/Skeleton/ImagePlaceholder.spec.d.ts.map +1 -0
  266. package/dist/primitives/Skeleton/ImagePlaceholder.spec.js +120 -0
  267. package/dist/primitives/Skeleton/ImagePlaceholder.svelte +59 -59
  268. package/dist/primitives/Skeleton/ListPlaceholder.spec.d.ts +2 -0
  269. package/dist/primitives/Skeleton/ListPlaceholder.spec.d.ts.map +1 -0
  270. package/dist/primitives/Skeleton/ListPlaceholder.spec.js +220 -0
  271. package/dist/primitives/Skeleton/ListPlaceholder.svelte +76 -76
  272. package/dist/primitives/Skeleton/Skeleton.spec.d.ts +2 -0
  273. package/dist/primitives/Skeleton/Skeleton.spec.d.ts.map +1 -0
  274. package/dist/primitives/Skeleton/Skeleton.spec.js +173 -0
  275. package/dist/primitives/Skeleton/Skeleton.stories.svelte +151 -151
  276. package/dist/primitives/Skeleton/Skeleton.svelte +26 -26
  277. package/dist/primitives/Spinner/Spinner.spec.js +71 -75
  278. package/dist/primitives/Spinner/Spinner.stories.svelte +29 -29
  279. package/dist/primitives/Spinner/Spinner.svelte +20 -20
  280. package/dist/primitives/Tabs/TabItem.spec.d.ts +2 -0
  281. package/dist/primitives/Tabs/TabItem.spec.d.ts.map +1 -0
  282. package/dist/primitives/Tabs/TabItem.spec.js +130 -0
  283. package/dist/primitives/Tabs/TabItem.svelte +49 -49
  284. package/dist/primitives/Tabs/Tabs.spec.d.ts +2 -0
  285. package/dist/primitives/Tabs/Tabs.spec.d.ts.map +1 -0
  286. package/dist/primitives/Tabs/Tabs.spec.js +295 -0
  287. package/dist/primitives/Tabs/Tabs.stories.svelte +112 -112
  288. package/dist/primitives/Tabs/Tabs.svelte +123 -123
  289. package/dist/primitives/Tabs/TabsWithItems.test.svelte +18 -0
  290. package/dist/primitives/Tabs/TabsWithItems.test.svelte.d.ts +16 -0
  291. package/dist/primitives/Tabs/TabsWithItems.test.svelte.d.ts.map +1 -0
  292. package/dist/primitives/Toggle.spec.js +143 -127
  293. package/dist/primitives/Toggle.stories.svelte +92 -92
  294. package/dist/primitives/Toggle.svelte +71 -71
  295. package/dist/primitives/Typography/Typography.spec.d.ts +2 -0
  296. package/dist/primitives/Typography/Typography.spec.d.ts.map +1 -0
  297. package/dist/primitives/Typography/Typography.spec.js +183 -0
  298. package/dist/primitives/Typography/Typography.svelte +53 -53
  299. package/dist/primitives/ValidationError.spec.js +103 -103
  300. package/dist/primitives/ValidationError.stories.svelte +69 -69
  301. package/dist/primitives/ValidationError.svelte +29 -29
  302. package/dist/primitives/index.d.ts +1 -0
  303. package/dist/primitives/index.js +3 -0
  304. package/dist/recipes/CropImage/CropImage.spec.js +208 -216
  305. package/dist/recipes/CropImage/CropImage.stories.svelte +104 -104
  306. package/dist/recipes/CropImage/CropImage.svelte +238 -238
  307. package/dist/recipes/ImageUploader/ImageUploader.spec.d.ts +2 -0
  308. package/dist/recipes/ImageUploader/ImageUploader.spec.d.ts.map +1 -0
  309. package/dist/recipes/ImageUploader/ImageUploader.spec.js +1351 -0
  310. package/dist/recipes/ImageUploader/ImageUploader.stories.svelte +125 -125
  311. package/dist/recipes/ImageUploader/ImageUploader.svelte +804 -804
  312. package/dist/recipes/SuperLogin/SuperLogin.spec.d.ts +2 -0
  313. package/dist/recipes/SuperLogin/SuperLogin.spec.d.ts.map +1 -0
  314. package/dist/recipes/SuperLogin/SuperLogin.spec.js +1436 -0
  315. package/dist/recipes/SuperLogin/SuperLogin.svelte +7 -6
  316. package/dist/recipes/SuperLogin/SuperLogin.svelte.d.ts.map +1 -1
  317. package/dist/recipes/Toaster/Toaster.stories.svelte +62 -62
  318. package/dist/recipes/feedback/EmptyState/EmptyState.spec.d.ts +2 -0
  319. package/dist/recipes/feedback/EmptyState/EmptyState.spec.d.ts.map +1 -0
  320. package/dist/recipes/feedback/EmptyState/EmptyState.spec.js +202 -0
  321. package/dist/recipes/feedback/EmptyState/EmptyState.svelte +1 -1
  322. package/dist/recipes/feedback/ErrorDisplay.spec.js +69 -69
  323. package/dist/recipes/feedback/ErrorDisplay.stories.svelte +101 -101
  324. package/dist/recipes/feedback/ErrorDisplay.svelte +1 -1
  325. package/dist/recipes/feedback/StatusIndicator/StatusIndicator.spec.js +133 -129
  326. package/dist/recipes/feedback/StatusIndicator/StatusIndicator.svelte +157 -157
  327. package/dist/recipes/fields/CheckboxField.spec.d.ts +2 -0
  328. package/dist/recipes/fields/CheckboxField.spec.d.ts.map +1 -0
  329. package/dist/recipes/fields/CheckboxField.spec.js +135 -0
  330. package/dist/recipes/fields/CheckboxField.svelte +85 -85
  331. package/dist/recipes/fields/FormField.spec.d.ts +2 -0
  332. package/dist/recipes/fields/FormField.spec.d.ts.map +1 -0
  333. package/dist/recipes/fields/FormField.spec.js +159 -0
  334. package/dist/recipes/fields/FormField.svelte +58 -58
  335. package/dist/recipes/fields/RadioGroup.spec.d.ts +2 -0
  336. package/dist/recipes/fields/RadioGroup.spec.d.ts.map +1 -0
  337. package/dist/recipes/fields/RadioGroup.spec.js +199 -0
  338. package/dist/recipes/fields/RadioGroup.svelte +95 -95
  339. package/dist/recipes/fields/SelectField.spec.d.ts +2 -0
  340. package/dist/recipes/fields/SelectField.spec.d.ts.map +1 -0
  341. package/dist/recipes/fields/SelectField.spec.js +188 -0
  342. package/dist/recipes/fields/SelectField.svelte +80 -80
  343. package/dist/recipes/fields/TextareaField.spec.d.ts +2 -0
  344. package/dist/recipes/fields/TextareaField.spec.d.ts.map +1 -0
  345. package/dist/recipes/fields/TextareaField.spec.js +205 -0
  346. package/dist/recipes/fields/TextareaField.svelte +97 -97
  347. package/dist/recipes/fields/ToggleField.spec.d.ts +2 -0
  348. package/dist/recipes/fields/ToggleField.spec.d.ts.map +1 -0
  349. package/dist/recipes/fields/ToggleField.spec.js +153 -0
  350. package/dist/recipes/fields/ToggleField.svelte +60 -60
  351. package/dist/recipes/fields/index.js +7 -7
  352. package/dist/recipes/inputs/MultiSelect.spec.js +258 -257
  353. package/dist/recipes/inputs/MultiSelect.stories.svelte +133 -133
  354. package/dist/recipes/inputs/MultiSelect.svelte +256 -249
  355. package/dist/recipes/inputs/MultiSelect.svelte.d.ts +2 -0
  356. package/dist/recipes/inputs/MultiSelect.svelte.d.ts.map +1 -1
  357. package/dist/recipes/inputs/OTPInput.spec.js +251 -238
  358. package/dist/recipes/inputs/OTPInput.stories.svelte +162 -162
  359. package/dist/recipes/inputs/OTPInput.svelte +29 -29
  360. package/dist/recipes/inputs/PasswordInput.spec.d.ts +2 -0
  361. package/dist/recipes/inputs/PasswordInput.spec.d.ts.map +1 -0
  362. package/dist/recipes/inputs/PasswordInput.spec.js +410 -0
  363. package/dist/recipes/inputs/PasswordInput.svelte +22 -22
  364. package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.spec.js +245 -165
  365. package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.svelte +43 -43
  366. package/dist/recipes/inputs/PasswordStrengthIndicator/TestWrapper.svelte +71 -0
  367. package/dist/recipes/inputs/PasswordStrengthIndicator/TestWrapper.svelte.d.ts +9 -0
  368. package/dist/recipes/inputs/PasswordStrengthIndicator/TestWrapper.svelte.d.ts.map +1 -0
  369. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.spec.js +1139 -193
  370. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.stories.svelte +123 -123
  371. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte +326 -326
  372. package/dist/recipes/inputs/Search.spec.d.ts +2 -0
  373. package/dist/recipes/inputs/Search.spec.d.ts.map +1 -0
  374. package/dist/recipes/inputs/Search.spec.js +177 -0
  375. package/dist/recipes/inputs/Search.svelte +37 -37
  376. package/dist/recipes/inputs/SelectDropdown.spec.d.ts +2 -0
  377. package/dist/recipes/inputs/SelectDropdown.spec.d.ts.map +1 -0
  378. package/dist/recipes/inputs/SelectDropdown.spec.js +512 -0
  379. package/dist/recipes/inputs/SelectDropdown.svelte +57 -57
  380. package/dist/recipes/modals/AlertModal.spec.d.ts +2 -0
  381. package/dist/recipes/modals/AlertModal.spec.d.ts.map +1 -0
  382. package/dist/recipes/modals/AlertModal.spec.js +432 -0
  383. package/dist/recipes/modals/AlertModal.svelte +130 -130
  384. package/dist/recipes/modals/ConfirmationModal.spec.js +206 -191
  385. package/dist/recipes/modals/ConfirmationModal.stories.svelte +119 -119
  386. package/dist/recipes/modals/ConfirmationModal.svelte +152 -152
  387. package/dist/recipes/modals/InputModal.spec.d.ts +2 -0
  388. package/dist/recipes/modals/InputModal.spec.d.ts.map +1 -0
  389. package/dist/recipes/modals/InputModal.spec.js +872 -0
  390. package/dist/recipes/modals/InputModal.svelte +182 -182
  391. package/dist/recipes/modals/ModalStateManager.spec.js +100 -100
  392. package/dist/recipes/modals/ModalStateManager.svelte +77 -77
  393. package/dist/recipes/modals/ModalTestWrapper.spec.d.ts +2 -0
  394. package/dist/recipes/modals/ModalTestWrapper.spec.d.ts.map +1 -0
  395. package/dist/recipes/modals/ModalTestWrapper.spec.js +502 -0
  396. package/dist/recipes/modals/ModalTestWrapper.svelte +65 -65
  397. package/dist/recipes/modals/StatusModal.spec.d.ts +2 -0
  398. package/dist/recipes/modals/StatusModal.spec.d.ts.map +1 -0
  399. package/dist/recipes/modals/StatusModal.spec.js +599 -0
  400. package/dist/recipes/modals/StatusModal.svelte +206 -206
  401. package/dist/services/EventService.js +75 -75
  402. package/dist/services/EventService.spec.js +217 -217
  403. package/dist/services/ShowService.spec.js +345 -342
  404. package/dist/stores/auth.js +36 -36
  405. package/dist/stores/auth.spec.js +139 -139
  406. package/dist/stores/toaster.js +13 -13
  407. package/dist/stories/ButtonAuditDashboard.spec.d.ts +2 -0
  408. package/dist/stories/ButtonAuditDashboard.spec.d.ts.map +1 -0
  409. package/dist/stories/ButtonAuditDashboard.spec.js +913 -0
  410. package/dist/stories/ButtonAuditReview.spec.d.ts +2 -0
  411. package/dist/stories/ButtonAuditReview.spec.d.ts.map +1 -0
  412. package/dist/stories/ButtonAuditReview.spec.js +422 -0
  413. package/dist/stories/ButtonAuditReview.stories.svelte +14 -14
  414. package/dist/stories/ButtonAuditReview.svelte +427 -427
  415. package/dist/stories/ButtonGridView.spec.d.ts +2 -0
  416. package/dist/stories/ButtonGridView.spec.d.ts.map +1 -0
  417. package/dist/stories/ButtonGridView.spec.js +667 -0
  418. package/dist/stories/ButtonShowcase.spec.d.ts +2 -0
  419. package/dist/stories/ButtonShowcase.spec.d.ts.map +1 -0
  420. package/dist/stories/ButtonShowcase.spec.js +499 -0
  421. package/dist/stories/PatternsGallery.spec.d.ts +2 -0
  422. package/dist/stories/PatternsGallery.spec.d.ts.map +1 -0
  423. package/dist/stories/PatternsGallery.spec.js +514 -0
  424. package/dist/stories/PatternsGallery.stories.svelte +19 -19
  425. package/dist/stories/PatternsGallery.svelte +206 -206
  426. package/dist/stories/PrimitivesGallery.spec.d.ts +2 -0
  427. package/dist/stories/PrimitivesGallery.spec.d.ts.map +1 -0
  428. package/dist/stories/PrimitivesGallery.spec.js +813 -0
  429. package/dist/stories/PrimitivesGallery.stories.svelte +19 -19
  430. package/dist/stories/PrimitivesGallery.svelte +725 -725
  431. package/dist/stories/RecipesGallery.spec.d.ts +2 -0
  432. package/dist/stories/RecipesGallery.spec.d.ts.map +1 -0
  433. package/dist/stories/RecipesGallery.spec.js +299 -0
  434. package/dist/stories/RecipesGallery.stories.svelte +19 -19
  435. package/dist/stories/RecipesGallery.svelte +271 -271
  436. package/dist/stories/button-audit-manifest.json +11186 -11186
  437. package/dist/stripe/useStripeTheme.spec.d.ts +2 -0
  438. package/dist/stripe/useStripeTheme.spec.d.ts.map +1 -0
  439. package/dist/stripe/useStripeTheme.spec.js +793 -0
  440. package/dist/tailwind/preset.cjs +82 -82
  441. package/dist/telemetry.d.ts.map +1 -1
  442. package/dist/telemetry.js +6 -5
  443. package/dist/telemetry.spec.js +495 -12
  444. package/dist/tokens/__tests__/colors.test.d.ts +2 -0
  445. package/dist/tokens/__tests__/colors.test.d.ts.map +1 -0
  446. package/dist/tokens/__tests__/colors.test.js +152 -0
  447. package/dist/tokens/__tests__/radius.test.d.ts +2 -0
  448. package/dist/tokens/__tests__/radius.test.d.ts.map +1 -0
  449. package/dist/tokens/__tests__/radius.test.js +118 -0
  450. package/dist/tokens/__tests__/shadows.test.d.ts +2 -0
  451. package/dist/tokens/__tests__/shadows.test.d.ts.map +1 -0
  452. package/dist/tokens/__tests__/shadows.test.js +105 -0
  453. package/dist/tokens/__tests__/spacing.test.js +11 -8
  454. package/dist/tokens/__tests__/typography.test.d.ts +2 -0
  455. package/dist/tokens/__tests__/typography.test.d.ts.map +1 -0
  456. package/dist/tokens/__tests__/typography.test.js +156 -0
  457. package/dist/tokens/__tests__/z-index.test.d.ts +2 -0
  458. package/dist/tokens/__tests__/z-index.test.d.ts.map +1 -0
  459. package/dist/tokens/__tests__/z-index.test.js +121 -0
  460. package/dist/tokens/tokens.css +87 -87
  461. package/dist/utils/apiConfig.spec.js +102 -1
  462. package/dist/utils/formatters.spec.d.ts +2 -0
  463. package/dist/utils/formatters.spec.d.ts.map +1 -0
  464. package/dist/utils/formatters.spec.js +82 -0
  465. package/dist/utils/transitions.d.ts +24 -0
  466. package/dist/utils/transitions.d.ts.map +1 -0
  467. package/dist/utils/transitions.js +62 -0
  468. package/dist/utils/transitions.spec.d.ts +2 -0
  469. package/dist/utils/transitions.spec.d.ts.map +1 -0
  470. package/dist/utils/transitions.spec.js +130 -0
  471. package/dist/utils/utils.js +354 -354
  472. package/package.json +288 -283
@@ -0,0 +1,512 @@
1
+ import { render, screen, fireEvent, waitFor } from "@testing-library/svelte";
2
+ import userEvent from "@testing-library/user-event";
3
+ import { expect, describe, test, vi, beforeEach } from "vitest";
4
+ import SelectDropdown from "./SelectDropdown.svelte";
5
+
6
+ const sampleOptions = [
7
+ { label: "Option 1", value: "opt1" },
8
+ { label: "Option 2", value: "opt2" },
9
+ { label: "Option 3", value: "opt3" },
10
+ { label: "Option 4", value: "opt4" },
11
+ ];
12
+
13
+ function setupTest(args = {}) {
14
+ const user = userEvent.setup();
15
+ const { component, container } = render(SelectDropdown, {
16
+ props: {
17
+ options: sampleOptions,
18
+ ...args,
19
+ },
20
+ });
21
+ return { user, component, container };
22
+ }
23
+
24
+ describe("SelectDropdown Component Tests", () => {
25
+ beforeEach(() => {
26
+ // Clear any existing event listeners
27
+ document.body.innerHTML = "";
28
+ });
29
+
30
+ test("Renders with default placeholder", () => {
31
+ setupTest();
32
+ expect(screen.getByRole("button", { name: /select/i })).toBeInTheDocument();
33
+ expect(screen.getByText("Select")).toBeInTheDocument();
34
+ });
35
+
36
+ test("Renders with custom placeholder", () => {
37
+ setupTest({ placeholder: "Choose an option" });
38
+ expect(screen.getByText("Choose an option")).toBeInTheDocument();
39
+ });
40
+
41
+ test("Shows selected option label", () => {
42
+ setupTest({ selected: sampleOptions[0] });
43
+ expect(screen.getByText("Option 1")).toBeInTheDocument();
44
+ });
45
+
46
+ test("Opens dropdown on click", async () => {
47
+ const { user } = setupTest();
48
+ const trigger = screen.getByRole("button");
49
+
50
+ await user.click(trigger);
51
+
52
+ expect(screen.getByRole("listbox")).toBeInTheDocument();
53
+ expect(screen.getByText("Option 1")).toBeInTheDocument();
54
+ expect(screen.getByText("Option 2")).toBeInTheDocument();
55
+ expect(screen.getByText("Option 3")).toBeInTheDocument();
56
+ expect(screen.getByText("Option 4")).toBeInTheDocument();
57
+ });
58
+
59
+ test("Displays all options in dropdown", async () => {
60
+ const { user } = setupTest();
61
+ const trigger = screen.getByRole("button");
62
+
63
+ await user.click(trigger);
64
+
65
+ const options = screen.getAllByRole("option");
66
+ expect(options).toHaveLength(4);
67
+ });
68
+
69
+ test("Selects option on click", async () => {
70
+ const { user } = setupTest();
71
+ const trigger = screen.getByRole("button");
72
+
73
+ await user.click(trigger);
74
+ const option2 = screen.getByRole("option", { name: "Option 2" });
75
+ await user.click(option2);
76
+
77
+ // Should show selected option in trigger
78
+ expect(screen.getByText("Option 2")).toBeInTheDocument();
79
+ });
80
+
81
+ test("Closes dropdown after selection", async () => {
82
+ const { user } = setupTest();
83
+ const trigger = screen.getByRole("button");
84
+
85
+ await user.click(trigger);
86
+ const option1 = screen.getByRole("option", { name: "Option 1" });
87
+ await user.click(option1);
88
+
89
+ // Dropdown should be closed
90
+ expect(screen.queryByRole("listbox")).not.toBeInTheDocument();
91
+ });
92
+
93
+ test("Calls onselect callback when option is selected", async () => {
94
+ const onSelectSpy = vi.fn();
95
+ const { user } = setupTest({ onselect: onSelectSpy });
96
+ const trigger = screen.getByRole("button");
97
+
98
+ await user.click(trigger);
99
+ const option2 = screen.getByRole("option", { name: "Option 2" });
100
+ await user.click(option2);
101
+
102
+ expect(onSelectSpy).toHaveBeenCalledWith(sampleOptions[1]);
103
+ });
104
+
105
+ test("Does not open dropdown when disabled", async () => {
106
+ const { user } = setupTest({ disabled: true });
107
+ const trigger = screen.getByRole("button");
108
+
109
+ expect(trigger).toBeDisabled();
110
+ await user.click(trigger);
111
+
112
+ expect(screen.queryByRole("listbox")).not.toBeInTheDocument();
113
+ });
114
+
115
+ test("Applies disabled styles when disabled", () => {
116
+ setupTest({ disabled: true });
117
+ const trigger = screen.getByRole("button");
118
+
119
+ expect(trigger).toHaveClass("opacity-50");
120
+ expect(trigger).toHaveClass("cursor-not-allowed");
121
+ });
122
+
123
+ test("Applies custom className", () => {
124
+ const { container } = setupTest({ class: "custom-class" });
125
+ const dropdown = container.querySelector(".relative");
126
+
127
+ expect(dropdown).toHaveClass("custom-class");
128
+ });
129
+
130
+ test("Closes dropdown on Escape key", async () => {
131
+ const { user } = setupTest();
132
+ const trigger = screen.getByRole("button");
133
+
134
+ await user.click(trigger);
135
+ expect(screen.getByRole("listbox")).toBeInTheDocument();
136
+
137
+ await user.keyboard("{Escape}");
138
+ expect(screen.queryByRole("listbox")).not.toBeInTheDocument();
139
+ });
140
+
141
+ test("Navigates options with ArrowDown key", async () => {
142
+ const { user } = setupTest();
143
+ const trigger = screen.getByRole("button");
144
+
145
+ await user.click(trigger);
146
+ await waitFor(() => expect(screen.getByRole("listbox")).toBeInTheDocument());
147
+
148
+ const options = screen.getAllByRole("option");
149
+ await user.keyboard("{ArrowDown}");
150
+
151
+ // First option should receive focus
152
+ expect(options[0]).toHaveFocus();
153
+
154
+ await user.keyboard("{ArrowDown}");
155
+ // Second option should receive focus
156
+ expect(options[1]).toHaveFocus();
157
+ });
158
+
159
+ test("Navigates options with ArrowUp key", async () => {
160
+ const { user } = setupTest();
161
+ const trigger = screen.getByRole("button");
162
+
163
+ await user.click(trigger);
164
+ await waitFor(() => expect(screen.getByRole("listbox")).toBeInTheDocument());
165
+
166
+ const options = screen.getAllByRole("option");
167
+ await user.keyboard("{ArrowUp}");
168
+
169
+ // Should wrap to last option
170
+ expect(options[3]).toHaveFocus();
171
+
172
+ await user.keyboard("{ArrowUp}");
173
+ // Should move to third option
174
+ expect(options[2]).toHaveFocus();
175
+ });
176
+
177
+ test("Navigates to first option with Home key", async () => {
178
+ const { user } = setupTest();
179
+ const trigger = screen.getByRole("button");
180
+
181
+ await user.click(trigger);
182
+ await waitFor(() => expect(screen.getByRole("listbox")).toBeInTheDocument());
183
+
184
+ const options = screen.getAllByRole("option");
185
+ await user.keyboard("{ArrowDown}");
186
+ await user.keyboard("{ArrowDown}");
187
+ await user.keyboard("{Home}");
188
+
189
+ expect(options[0]).toHaveFocus();
190
+ });
191
+
192
+ test("Navigates to last option with End key", async () => {
193
+ const { user } = setupTest();
194
+ const trigger = screen.getByRole("button");
195
+
196
+ await user.click(trigger);
197
+ await waitFor(() => expect(screen.getByRole("listbox")).toBeInTheDocument());
198
+
199
+ const options = screen.getAllByRole("option");
200
+ await user.keyboard("{End}");
201
+
202
+ expect(options[3]).toHaveFocus();
203
+ });
204
+
205
+ test("Closes dropdown on Tab key", async () => {
206
+ const { user } = setupTest();
207
+ const trigger = screen.getByRole("button");
208
+
209
+ await user.click(trigger);
210
+ expect(screen.getByRole("listbox")).toBeInTheDocument();
211
+
212
+ await user.keyboard("{Tab}");
213
+ expect(screen.queryByRole("listbox")).not.toBeInTheDocument();
214
+ });
215
+
216
+ test("Returns focus to trigger after Escape", async () => {
217
+ const { user } = setupTest();
218
+ const trigger = screen.getByRole("button");
219
+
220
+ await user.click(trigger);
221
+ await user.keyboard("{Escape}");
222
+
223
+ expect(trigger).toHaveFocus();
224
+ });
225
+
226
+ test("Returns focus to trigger after selection", async () => {
227
+ const { user } = setupTest();
228
+ const trigger = screen.getByRole("button");
229
+
230
+ await user.click(trigger);
231
+ const option1 = screen.getByRole("option", { name: "Option 1" });
232
+ await user.click(option1);
233
+
234
+ await waitFor(() => expect(trigger).toHaveFocus());
235
+ });
236
+
237
+ test("Closes dropdown when clicking outside", async () => {
238
+ const { user } = setupTest();
239
+ const trigger = screen.getByRole("button");
240
+
241
+ await user.click(trigger);
242
+ expect(screen.getByRole("listbox")).toBeInTheDocument();
243
+
244
+ // Click outside the dropdown
245
+ await user.click(document.body);
246
+
247
+ await waitFor(() => {
248
+ expect(screen.queryByRole("listbox")).not.toBeInTheDocument();
249
+ });
250
+ });
251
+
252
+ test("Does not close dropdown when clicking inside container", async () => {
253
+ const { user } = setupTest();
254
+ const trigger = screen.getByRole("button");
255
+
256
+ await user.click(trigger);
257
+ expect(screen.getByRole("listbox")).toBeInTheDocument();
258
+
259
+ // Click on the trigger again
260
+ await user.click(trigger);
261
+
262
+ // Should toggle closed
263
+ expect(screen.queryByRole("listbox")).not.toBeInTheDocument();
264
+ });
265
+
266
+ test("Highlights selected option in dropdown", async () => {
267
+ const { user } = setupTest({ selected: sampleOptions[1] });
268
+ const trigger = screen.getByRole("button");
269
+
270
+ await user.click(trigger);
271
+
272
+ const selectedOption = screen.getByRole("option", { name: "Option 2" });
273
+ expect(selectedOption).toHaveAttribute("aria-selected", "true");
274
+ expect(selectedOption).toHaveClass("bg-blue-50");
275
+ });
276
+
277
+ test("Toggles dropdown on successive clicks", async () => {
278
+ const { user } = setupTest();
279
+ const trigger = screen.getByRole("button");
280
+
281
+ // Open
282
+ await user.click(trigger);
283
+ expect(screen.getByRole("listbox")).toBeInTheDocument();
284
+
285
+ // Close
286
+ await user.click(trigger);
287
+ expect(screen.queryByRole("listbox")).not.toBeInTheDocument();
288
+
289
+ // Open again
290
+ await user.click(trigger);
291
+ expect(screen.getByRole("listbox")).toBeInTheDocument();
292
+ });
293
+
294
+ test("Sets aria-haspopup attribute on trigger", () => {
295
+ setupTest();
296
+ const trigger = screen.getByRole("button");
297
+
298
+ expect(trigger).toHaveAttribute("aria-haspopup", "listbox");
299
+ });
300
+
301
+ test("Sets aria-expanded based on dropdown state", async () => {
302
+ const { user } = setupTest();
303
+ const trigger = screen.getByRole("button");
304
+
305
+ expect(trigger).toHaveAttribute("aria-expanded", "false");
306
+
307
+ await user.click(trigger);
308
+ expect(trigger).toHaveAttribute("aria-expanded", "true");
309
+
310
+ await user.click(trigger);
311
+ expect(trigger).toHaveAttribute("aria-expanded", "false");
312
+ });
313
+
314
+ test("Rotates chevron icon when dropdown is open", async () => {
315
+ const { user, container } = setupTest();
316
+ const trigger = screen.getByRole("button");
317
+
318
+ const chevron = container.querySelector("svg");
319
+ expect(chevron).not.toHaveClass("rotate-180");
320
+
321
+ await user.click(trigger);
322
+ expect(chevron).toHaveClass("rotate-180");
323
+ });
324
+
325
+ test("Handles empty options array", () => {
326
+ setupTest({ options: [] });
327
+ expect(screen.getByRole("button")).toBeInTheDocument();
328
+ });
329
+
330
+ test("Updates displayed value when selected prop changes", async () => {
331
+ const { container } = render(SelectDropdown, {
332
+ props: {
333
+ options: sampleOptions,
334
+ selected: sampleOptions[0],
335
+ },
336
+ });
337
+
338
+ expect(screen.getByText("Option 1")).toBeInTheDocument();
339
+
340
+ // Re-render with new selected prop (Svelte 5 compatible approach)
341
+ container.innerHTML = "";
342
+ render(SelectDropdown, {
343
+ props: {
344
+ options: sampleOptions,
345
+ selected: sampleOptions[2],
346
+ },
347
+ target: container,
348
+ });
349
+
350
+ await waitFor(() => {
351
+ expect(screen.getByText("Option 3")).toBeInTheDocument();
352
+ });
353
+ });
354
+
355
+ test("Shows all options even when one is selected", async () => {
356
+ const { user } = setupTest({ selected: sampleOptions[0] });
357
+ const trigger = screen.getByRole("button");
358
+
359
+ await user.click(trigger);
360
+
361
+ const options = screen.getAllByRole("option");
362
+ expect(options).toHaveLength(4);
363
+ });
364
+
365
+ test("Does not interfere with keyboard events outside dropdown", async () => {
366
+ const { user } = setupTest();
367
+ const trigger = screen.getByRole("button");
368
+
369
+ // Don't open dropdown
370
+ await user.keyboard("{ArrowDown}");
371
+
372
+ // Dropdown should not open
373
+ expect(screen.queryByRole("listbox")).not.toBeInTheDocument();
374
+ });
375
+
376
+ test("Wraps focus correctly with ArrowDown", async () => {
377
+ const { user } = setupTest();
378
+ const trigger = screen.getByRole("button");
379
+
380
+ await user.click(trigger);
381
+ await waitFor(() => expect(screen.getByRole("listbox")).toBeInTheDocument());
382
+
383
+ const options = screen.getAllByRole("option");
384
+
385
+ // Navigate to last item
386
+ await user.keyboard("{End}");
387
+ expect(options[3]).toHaveFocus();
388
+
389
+ // Press ArrowDown - should wrap to first
390
+ await user.keyboard("{ArrowDown}");
391
+ expect(options[0]).toHaveFocus();
392
+ });
393
+
394
+ test("Wraps focus correctly with ArrowUp", async () => {
395
+ const { user } = setupTest();
396
+ const trigger = screen.getByRole("button");
397
+
398
+ await user.click(trigger);
399
+ await waitFor(() => expect(screen.getByRole("listbox")).toBeInTheDocument());
400
+
401
+ const options = screen.getAllByRole("option");
402
+
403
+ // First option
404
+ await user.keyboard("{Home}");
405
+ expect(options[0]).toHaveFocus();
406
+
407
+ // Press ArrowUp - should wrap to last
408
+ await user.keyboard("{ArrowUp}");
409
+ expect(options[3]).toHaveFocus();
410
+ });
411
+
412
+ test("Applies correct styling classes to dropdown menu", async () => {
413
+ const { user } = setupTest();
414
+ const trigger = screen.getByRole("button");
415
+
416
+ await user.click(trigger);
417
+
418
+ const menu = screen.getByRole("listbox");
419
+ expect(menu).toHaveClass("absolute");
420
+ expect(menu).toHaveClass("z-10");
421
+ expect(menu).toHaveClass("rounded-lg");
422
+ expect(menu).toHaveClass("shadow-lg");
423
+ });
424
+
425
+ test("Truncates long selected option labels", () => {
426
+ setupTest({
427
+ selected: { label: "Very long option name that should be truncated", value: "long" },
428
+ });
429
+ const span = screen.getByText("Very long option name that should be truncated");
430
+ expect(span).toHaveClass("truncate");
431
+ });
432
+
433
+ test("Allows null selected value", () => {
434
+ setupTest({ selected: null });
435
+ expect(screen.getByText("Select")).toBeInTheDocument();
436
+ });
437
+
438
+ test("Handles option selection with Enter key", async () => {
439
+ const onSelectSpy = vi.fn();
440
+ const { user } = setupTest({ onselect: onSelectSpy });
441
+ const trigger = screen.getByRole("button");
442
+
443
+ await user.click(trigger);
444
+ await waitFor(() => expect(screen.getByRole("listbox")).toBeInTheDocument());
445
+
446
+ await user.keyboard("{ArrowDown}");
447
+ const options = screen.getAllByRole("option");
448
+
449
+ // Simulate Enter key on focused option
450
+ await fireEvent.click(options[0]);
451
+
452
+ expect(onSelectSpy).toHaveBeenCalledWith(sampleOptions[0]);
453
+ });
454
+
455
+ test("Maintains dropdown position with max-height scroll", async () => {
456
+ const manyOptions = Array.from({ length: 20 }, (_, i) => ({
457
+ label: `Option ${i + 1}`,
458
+ value: `opt${i + 1}`,
459
+ }));
460
+
461
+ const { user } = setupTest({ options: manyOptions });
462
+ const trigger = screen.getByRole("button");
463
+
464
+ await user.click(trigger);
465
+
466
+ const menu = screen.getByRole("listbox");
467
+ expect(menu).toHaveClass("max-h-60");
468
+ expect(menu).toHaveClass("overflow-y-auto");
469
+ });
470
+
471
+ test("Initializes focusedIndex to -1 when opening dropdown", async () => {
472
+ const { user } = setupTest();
473
+ const trigger = screen.getByRole("button");
474
+
475
+ await user.click(trigger);
476
+
477
+ // No option should be focused initially
478
+ const options = screen.getAllByRole("option");
479
+ options.forEach(option => {
480
+ expect(option).not.toHaveFocus();
481
+ });
482
+ });
483
+
484
+ test("Opens and closes dropdown instances independently", async () => {
485
+ const { user: user1 } = setupTest({ placeholder: "Dropdown 1" });
486
+ const { user: user2 } = setupTest({ placeholder: "Dropdown 2" });
487
+
488
+ const trigger1 = screen.getByRole("button", { name: "Dropdown 1" });
489
+ const trigger2 = screen.getByRole("button", { name: "Dropdown 2" });
490
+
491
+ // Open first dropdown
492
+ await user1.click(trigger1);
493
+ expect(screen.getAllByRole("listbox")).toHaveLength(1);
494
+
495
+ // Opening second dropdown closes first (click-outside behavior)
496
+ await user2.click(trigger2);
497
+
498
+ // Should have exactly one listbox open (the second one)
499
+ const listboxes = screen.getAllByRole("listbox");
500
+ expect(listboxes).toHaveLength(1);
501
+ });
502
+
503
+ test("Maintains proper z-index for dropdown overlay", async () => {
504
+ const { user } = setupTest();
505
+ const trigger = screen.getByRole("button");
506
+
507
+ await user.click(trigger);
508
+
509
+ const menu = screen.getByRole("listbox");
510
+ expect(menu).toHaveClass("z-10");
511
+ });
512
+ });
@@ -24,7 +24,7 @@
24
24
  disabled = false,
25
25
  onselect,
26
26
  }: Props = $props();
27
-
27
+
28
28
  let isOpen = $state(false);
29
29
  let triggerRef = $state<HTMLButtonElement>();
30
30
  let menuRef = $state<HTMLDivElement>();
@@ -111,59 +111,59 @@
111
111
  break;
112
112
  }
113
113
  }
114
-
115
- $effect(() => {
116
- if (typeof window !== "undefined") {
117
- // Use mousedown for click-outside to capture before click completes
118
- document.addEventListener("mousedown", handleClickOutside, true);
119
- document.addEventListener("keydown", handleKeyDown);
120
- return () => {
121
- document.removeEventListener("mousedown", handleClickOutside, true);
122
- document.removeEventListener("keydown", handleKeyDown);
123
- };
124
- }
125
- });
126
- </script>
127
-
128
- <div bind:this={containerRef} class="relative inline-block text-left {className}">
129
- <button
130
- bind:this={triggerRef}
131
- type="button"
132
- class="inline-flex items-center justify-between w-full px-4 py-2.5 text-sm font-medium text-gray-900 bg-white border border-gray-300 rounded-lg hover:bg-gray-100 focus:ring-4 focus:outline-none focus:ring-blue-300 dark:bg-gray-700 dark:text-white dark:border-gray-600 dark:hover:bg-gray-600 dark:focus:ring-blue-800 {disabled ? 'opacity-50 cursor-not-allowed' : ''}"
133
- onclick={toggleDropdown}
134
- aria-haspopup="listbox"
135
- aria-expanded={isOpen}
136
- aria-label={placeholder}
137
- {disabled}
138
- >
139
- <span class="truncate">
140
- {selected?.label || placeholder}
141
- </span>
142
- <ChevronDownOutline class="w-4 h-4 ml-2 transition-transform duration-200 {isOpen ? 'rotate-180' : ''}" />
143
- </button>
144
-
145
- {#if isOpen}
146
- <div
147
- bind:this={menuRef}
148
- class="absolute z-10 mt-1 w-full bg-white divide-y divide-gray-100 rounded-lg shadow-lg dark:bg-gray-700 dark:divide-gray-600 max-h-60 overflow-y-auto"
149
- role="listbox"
150
- aria-label={placeholder}
151
- >
152
- <ul class="py-2 text-sm text-gray-700 dark:text-gray-200">
153
- {#each options as option}
154
- <li>
155
- <button
156
- type="button"
157
- class="block w-full text-left px-4 py-2 hover:bg-gray-100 dark:hover:bg-gray-600 dark:hover:text-white {selected?.value === option.value ? 'bg-blue-50 text-blue-700 dark:bg-gray-600 dark:text-white' : ''}"
158
- onclick={() => selectOption(option)}
159
- role="option"
160
- aria-selected={selected?.value === option.value}
161
- >
162
- {option.label}
163
- </button>
164
- </li>
165
- {/each}
166
- </ul>
167
- </div>
168
- {/if}
169
- </div>
114
+
115
+ $effect(() => {
116
+ if (typeof window !== "undefined") {
117
+ // Use mousedown for click-outside to capture before click completes
118
+ document.addEventListener("mousedown", handleClickOutside, true);
119
+ document.addEventListener("keydown", handleKeyDown);
120
+ return () => {
121
+ document.removeEventListener("mousedown", handleClickOutside, true);
122
+ document.removeEventListener("keydown", handleKeyDown);
123
+ };
124
+ }
125
+ });
126
+ </script>
127
+
128
+ <div bind:this={containerRef} class="relative inline-block text-left {className}">
129
+ <button
130
+ bind:this={triggerRef}
131
+ type="button"
132
+ class="inline-flex items-center justify-between w-full px-4 py-2.5 text-sm font-medium text-gray-900 bg-white border border-gray-300 rounded-lg hover:bg-gray-100 focus:ring-4 focus:outline-none focus:ring-blue-300 dark:bg-gray-700 dark:text-white dark:border-gray-600 dark:hover:bg-gray-600 dark:focus:ring-blue-800 {disabled ? 'opacity-50 cursor-not-allowed' : ''}"
133
+ onclick={toggleDropdown}
134
+ aria-haspopup="listbox"
135
+ aria-expanded={isOpen}
136
+ aria-label={placeholder}
137
+ {disabled}
138
+ >
139
+ <span class="truncate">
140
+ {selected?.label || placeholder}
141
+ </span>
142
+ <ChevronDownOutline class="w-4 h-4 ml-2 transition-transform duration-200 {isOpen ? 'rotate-180' : ''}" />
143
+ </button>
144
+
145
+ {#if isOpen}
146
+ <div
147
+ bind:this={menuRef}
148
+ class="absolute z-10 mt-1 w-full bg-white divide-y divide-gray-100 rounded-lg shadow-lg dark:bg-gray-700 dark:divide-gray-600 max-h-60 overflow-y-auto"
149
+ role="listbox"
150
+ aria-label={placeholder}
151
+ >
152
+ <ul class="py-2 text-sm text-gray-700 dark:text-gray-200">
153
+ {#each options as option}
154
+ <li>
155
+ <button
156
+ type="button"
157
+ class="block w-full text-left px-4 py-2 hover:bg-gray-100 dark:hover:bg-gray-600 dark:hover:text-white {selected?.value === option.value ? 'bg-blue-50 text-blue-700 dark:bg-gray-600 dark:text-white' : ''}"
158
+ onclick={() => selectOption(option)}
159
+ role="option"
160
+ aria-selected={selected?.value === option.value}
161
+ >
162
+ {option.label}
163
+ </button>
164
+ </li>
165
+ {/each}
166
+ </ul>
167
+ </div>
168
+ {/if}
169
+ </div>
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=AlertModal.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AlertModal.spec.d.ts","sourceRoot":"","sources":["../../../src/lib/recipes/modals/AlertModal.spec.js"],"names":[],"mappings":""}