@getmicdrop/svelte-components 5.5.4 → 5.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (512) 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/AppShell.svelte +104 -0
  34. package/dist/components/Layout/AppShell.svelte.d.ts +26 -0
  35. package/dist/components/Layout/AppShell.svelte.d.ts.map +1 -0
  36. package/dist/components/Layout/ContentSection.svelte +80 -0
  37. package/dist/components/Layout/ContentSection.svelte.d.ts +23 -0
  38. package/dist/components/Layout/ContentSection.svelte.d.ts.map +1 -0
  39. package/dist/components/Layout/Grid.svelte +4 -4
  40. package/dist/components/Layout/Heading.svelte +81 -0
  41. package/dist/components/Layout/Heading.svelte.d.ts +24 -0
  42. package/dist/components/Layout/Heading.svelte.d.ts.map +1 -0
  43. package/dist/components/Layout/PageContainer.svelte +69 -0
  44. package/dist/components/Layout/PageContainer.svelte.d.ts +23 -0
  45. package/dist/components/Layout/PageContainer.svelte.d.ts.map +1 -0
  46. package/dist/components/Layout/Responsive.svelte +75 -0
  47. package/dist/components/Layout/Responsive.svelte.d.ts +19 -0
  48. package/dist/components/Layout/Responsive.svelte.d.ts.map +1 -0
  49. package/dist/components/Layout/Section.spec.d.ts +2 -0
  50. package/dist/components/Layout/Section.spec.d.ts.map +1 -0
  51. package/dist/components/Layout/Section.spec.js +149 -0
  52. package/dist/components/Layout/Section.svelte +80 -80
  53. package/dist/components/Layout/ShowOnDesktop.svelte +37 -0
  54. package/dist/components/Layout/ShowOnDesktop.svelte.d.ts +16 -0
  55. package/dist/components/Layout/ShowOnDesktop.svelte.d.ts.map +1 -0
  56. package/dist/components/Layout/ShowOnMobile.svelte +37 -0
  57. package/dist/components/Layout/ShowOnMobile.svelte.d.ts +16 -0
  58. package/dist/components/Layout/ShowOnMobile.svelte.d.ts.map +1 -0
  59. package/dist/components/Layout/Sidebar.spec.d.ts +2 -0
  60. package/dist/components/Layout/Sidebar.spec.d.ts.map +1 -0
  61. package/dist/components/Layout/Sidebar.spec.js +186 -0
  62. package/dist/components/Layout/Sidebar.svelte +108 -108
  63. package/dist/components/Layout/Stack.spec.js +2 -2
  64. package/dist/components/Layout/Stack.svelte +6 -6
  65. package/dist/components/Layout/Text.svelte +87 -0
  66. package/dist/components/Layout/Text.svelte.d.ts +28 -0
  67. package/dist/components/Layout/Text.svelte.d.ts.map +1 -0
  68. package/dist/components/Layout/TwoColumn.svelte +108 -0
  69. package/dist/components/Layout/TwoColumn.svelte.d.ts +28 -0
  70. package/dist/components/Layout/TwoColumn.svelte.d.ts.map +1 -0
  71. package/dist/components/Layout/__tests__/Heading.test.d.ts +2 -0
  72. package/dist/components/Layout/__tests__/Heading.test.d.ts.map +1 -0
  73. package/dist/components/Layout/__tests__/Heading.test.js +123 -0
  74. package/dist/components/Layout/__tests__/ShowOnDesktop.test.d.ts +2 -0
  75. package/dist/components/Layout/__tests__/ShowOnDesktop.test.d.ts.map +1 -0
  76. package/dist/components/Layout/__tests__/ShowOnDesktop.test.js +84 -0
  77. package/dist/components/Layout/__tests__/ShowOnMobile.test.d.ts +2 -0
  78. package/dist/components/Layout/__tests__/ShowOnMobile.test.d.ts.map +1 -0
  79. package/dist/components/Layout/__tests__/ShowOnMobile.test.js +80 -0
  80. package/dist/components/Layout/__tests__/Text.test.d.ts +2 -0
  81. package/dist/components/Layout/__tests__/Text.test.d.ts.map +1 -0
  82. package/dist/components/Layout/__tests__/Text.test.js +146 -0
  83. package/dist/components/Layout/__tests__/TwoColumn.test.d.ts +2 -0
  84. package/dist/components/Layout/__tests__/TwoColumn.test.d.ts.map +1 -0
  85. package/dist/components/Layout/__tests__/TwoColumn.test.js +129 -0
  86. package/dist/constants/formOptions.spec.js +9 -5
  87. package/dist/constants/validation.js +91 -91
  88. package/dist/constants/validation.spec.js +64 -64
  89. package/dist/datetime/__tests__/timezone.test.js +123 -1
  90. package/dist/forms/createFieldTracker.spec.d.ts +2 -0
  91. package/dist/forms/createFieldTracker.spec.d.ts.map +1 -0
  92. package/dist/forms/createFieldTracker.spec.js +343 -0
  93. package/dist/forms/createFormStore.spec.d.ts +2 -0
  94. package/dist/forms/createFormStore.spec.d.ts.map +1 -0
  95. package/dist/forms/createFormStore.spec.js +689 -0
  96. package/dist/index.d.ts +4 -112
  97. package/dist/index.js +40 -226
  98. package/dist/patterns/data/DataGrid.spec.d.ts +2 -0
  99. package/dist/patterns/data/DataGrid.spec.d.ts.map +1 -0
  100. package/dist/patterns/data/DataGrid.spec.js +159 -0
  101. package/dist/patterns/data/DataGrid.svelte +45 -45
  102. package/dist/patterns/data/DataList.spec.d.ts +2 -0
  103. package/dist/patterns/data/DataList.spec.d.ts.map +1 -0
  104. package/dist/patterns/data/DataList.spec.js +158 -0
  105. package/dist/patterns/data/DataList.svelte +24 -24
  106. package/dist/patterns/data/DataTable.spec.d.ts +2 -0
  107. package/dist/patterns/data/DataTable.spec.d.ts.map +1 -0
  108. package/dist/patterns/data/DataTable.spec.js +196 -0
  109. package/dist/patterns/data/DataTable.svelte +36 -36
  110. package/dist/patterns/forms/FormActions.spec.js +95 -88
  111. package/dist/patterns/forms/FormActions.stories.svelte +97 -97
  112. package/dist/patterns/forms/FormActions.svelte +46 -46
  113. package/dist/patterns/forms/FormGrid.spec.d.ts +2 -0
  114. package/dist/patterns/forms/FormGrid.spec.d.ts.map +1 -0
  115. package/dist/patterns/forms/FormGrid.spec.js +125 -0
  116. package/dist/patterns/forms/FormGrid.svelte +33 -33
  117. package/dist/patterns/forms/FormSection.spec.d.ts +2 -0
  118. package/dist/patterns/forms/FormSection.spec.d.ts.map +1 -0
  119. package/dist/patterns/forms/FormSection.spec.js +153 -0
  120. package/dist/patterns/forms/FormSection.svelte +32 -32
  121. package/dist/patterns/forms/FormValidationSummary.stories.svelte +83 -83
  122. package/dist/patterns/forms/FormValidationSummary.svelte +74 -74
  123. package/dist/patterns/layout/Sidebar.spec.d.ts +2 -0
  124. package/dist/patterns/layout/Sidebar.spec.d.ts.map +1 -0
  125. package/dist/patterns/layout/Sidebar.spec.js +159 -0
  126. package/dist/patterns/layout/Sidebar.svelte +39 -39
  127. package/dist/patterns/layout/index.d.ts +9 -0
  128. package/dist/patterns/layout/index.js +22 -0
  129. package/dist/patterns/navigation/BottomNav.stories.svelte +117 -117
  130. package/dist/patterns/navigation/BottomNav.svelte +64 -64
  131. package/dist/patterns/navigation/Header.spec.js +33 -24
  132. package/dist/patterns/navigation/Header.stories.svelte +77 -77
  133. package/dist/patterns/navigation/Header.svelte +193 -193
  134. package/dist/patterns/page/PageHeader.spec.d.ts +2 -0
  135. package/dist/patterns/page/PageHeader.spec.d.ts.map +1 -0
  136. package/dist/patterns/page/PageHeader.spec.js +167 -0
  137. package/dist/patterns/page/PageHeader.svelte +18 -18
  138. package/dist/patterns/page/PageLayout.spec.d.ts +2 -0
  139. package/dist/patterns/page/PageLayout.spec.d.ts.map +1 -0
  140. package/dist/patterns/page/PageLayout.spec.js +145 -0
  141. package/dist/patterns/page/PageLayout.svelte +40 -40
  142. package/dist/patterns/page/PageLoader.spec.js +57 -54
  143. package/dist/patterns/page/PageLoader.stories.svelte +137 -137
  144. package/dist/patterns/page/PageLoader.svelte +24 -24
  145. package/dist/patterns/page/SectionHeader.spec.d.ts +2 -0
  146. package/dist/patterns/page/SectionHeader.spec.d.ts.map +1 -0
  147. package/dist/patterns/page/SectionHeader.spec.js +197 -0
  148. package/dist/patterns/page/SectionHeader.svelte +29 -29
  149. package/dist/presets/badges.js +112 -112
  150. package/dist/presets/badges.spec.d.ts +2 -0
  151. package/dist/presets/badges.spec.d.ts.map +1 -0
  152. package/dist/presets/badges.spec.js +172 -0
  153. package/dist/presets/buttons.js +76 -76
  154. package/dist/presets/buttons.spec.d.ts +2 -0
  155. package/dist/presets/buttons.spec.d.ts.map +1 -0
  156. package/dist/presets/buttons.spec.js +135 -0
  157. package/dist/presets/index.js +9 -9
  158. package/dist/primitives/Accordion/Accordion.spec.d.ts +2 -0
  159. package/dist/primitives/Accordion/Accordion.spec.d.ts.map +1 -0
  160. package/dist/primitives/Accordion/Accordion.spec.js +83 -0
  161. package/dist/primitives/Accordion/Accordion.stories.svelte +75 -75
  162. package/dist/primitives/Accordion/Accordion.svelte +42 -42
  163. package/dist/primitives/Accordion/AccordionItem.spec.d.ts +2 -0
  164. package/dist/primitives/Accordion/AccordionItem.spec.d.ts.map +1 -0
  165. package/dist/primitives/Accordion/AccordionItem.spec.js +661 -0
  166. package/dist/primitives/Accordion/AccordionItem.svelte +95 -95
  167. package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte +107 -0
  168. package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte.d.ts +35 -0
  169. package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte.d.ts.map +1 -0
  170. package/dist/primitives/Alert/Alert.spec.js +173 -170
  171. package/dist/primitives/Alert/Alert.stories.svelte +88 -88
  172. package/dist/primitives/Alert/Alert.svelte +27 -27
  173. package/dist/primitives/Avatar/Avatar.spec.d.ts +2 -0
  174. package/dist/primitives/Avatar/Avatar.spec.d.ts.map +1 -0
  175. package/dist/primitives/Avatar/Avatar.spec.js +211 -0
  176. package/dist/primitives/Avatar/Avatar.stories.svelte +94 -94
  177. package/dist/primitives/Avatar/Avatar.svelte +66 -66
  178. package/dist/primitives/Badges/Badge.spec.js +144 -103
  179. package/dist/primitives/Badges/Badge.stories.svelte +86 -86
  180. package/dist/primitives/Badges/Badge.svelte +79 -79
  181. package/dist/primitives/BottomSheet/BottomSheet.spec.js +136 -127
  182. package/dist/primitives/BottomSheet/BottomSheet.stories.svelte +83 -83
  183. package/dist/primitives/BottomSheet/BottomSheet.svelte +100 -100
  184. package/dist/primitives/BottomSheet/BottomSheetWrapper.test.svelte +13 -0
  185. package/dist/primitives/BottomSheet/BottomSheetWrapper.test.svelte.d.ts +7 -0
  186. package/dist/primitives/BottomSheet/BottomSheetWrapper.test.svelte.d.ts.map +1 -0
  187. package/dist/primitives/Breadcrumb/Breadcrumb.spec.js +122 -120
  188. package/dist/primitives/Breadcrumb/Breadcrumb.stories.svelte +23 -23
  189. package/dist/primitives/Breadcrumb/Breadcrumb.svelte +89 -89
  190. package/dist/primitives/Button/Button.spec.js +223 -211
  191. package/dist/primitives/Button/Button.stories.svelte +76 -76
  192. package/dist/primitives/Button/Button.svelte +270 -270
  193. package/dist/primitives/Button/ButtonSaveDemo.spec.js +146 -48
  194. package/dist/primitives/Button/ButtonSaveDemo.svelte +25 -25
  195. package/dist/primitives/Button/ButtonVariantShowcase.spec.d.ts +2 -0
  196. package/dist/primitives/Button/ButtonVariantShowcase.spec.d.ts.map +1 -0
  197. package/dist/primitives/Button/ButtonVariantShowcase.spec.js +202 -0
  198. package/dist/primitives/Button/ButtonVariantShowcase.svelte +129 -129
  199. package/dist/primitives/Card.spec.js +49 -49
  200. package/dist/primitives/Card.stories.svelte +22 -22
  201. package/dist/primitives/Card.svelte +28 -28
  202. package/dist/primitives/Checkbox/Checkbox.spec.d.ts +2 -0
  203. package/dist/primitives/Checkbox/Checkbox.spec.d.ts.map +1 -0
  204. package/dist/primitives/Checkbox/Checkbox.spec.js +252 -0
  205. package/dist/primitives/Checkbox/Checkbox.stories.svelte +84 -84
  206. package/dist/primitives/Checkbox/Checkbox.svelte +88 -88
  207. package/dist/primitives/DarkModeToggle.spec.js +390 -357
  208. package/dist/primitives/DarkModeToggle.stories.svelte +57 -57
  209. package/dist/primitives/DarkModeToggle.svelte +136 -136
  210. package/dist/primitives/Drawer/Drawer.spec.d.ts +2 -0
  211. package/dist/primitives/Drawer/Drawer.spec.d.ts.map +1 -0
  212. package/dist/primitives/Drawer/Drawer.spec.js +212 -0
  213. package/dist/primitives/Drawer/Drawer.stories.svelte +80 -80
  214. package/dist/primitives/Drawer/Drawer.svelte +120 -120
  215. package/dist/primitives/Dropdown/Dropdown.spec.d.ts +2 -0
  216. package/dist/primitives/Dropdown/Dropdown.spec.d.ts.map +1 -0
  217. package/dist/primitives/Dropdown/Dropdown.spec.js +366 -0
  218. package/dist/primitives/Dropdown/Dropdown.stories.svelte +137 -137
  219. package/dist/primitives/Dropdown/Dropdown.svelte +14 -14
  220. package/dist/primitives/Dropdown/DropdownItem.spec.d.ts +2 -0
  221. package/dist/primitives/Dropdown/DropdownItem.spec.d.ts.map +1 -0
  222. package/dist/primitives/Dropdown/DropdownItem.spec.js +182 -0
  223. package/dist/primitives/Dropdown/DropdownItem.svelte +80 -80
  224. package/dist/primitives/Icons/ArrowLeft.svelte +8 -8
  225. package/dist/primitives/Icons/ArrowRight.svelte +8 -8
  226. package/dist/primitives/Icons/Availability.svelte +14 -14
  227. package/dist/primitives/Icons/Back.svelte +14 -14
  228. package/dist/primitives/Icons/CheckCircle.svelte +6 -6
  229. package/dist/primitives/Icons/CheckCircleOutline.svelte +15 -15
  230. package/dist/primitives/Icons/ChevronLeft.svelte +4 -4
  231. package/dist/primitives/Icons/ChevronRight.svelte +4 -4
  232. package/dist/primitives/Icons/Copy.svelte +15 -15
  233. package/dist/primitives/Icons/Cross.svelte +5 -5
  234. package/dist/primitives/Icons/DownArrow.svelte +8 -8
  235. package/dist/primitives/Icons/ErrorCircle.svelte +6 -6
  236. package/dist/primitives/Icons/FacebookIcon.svelte +2 -2
  237. package/dist/primitives/Icons/Home.svelte +15 -15
  238. package/dist/primitives/Icons/Icon.spec.js +169 -169
  239. package/dist/primitives/Icons/Icon.stories.svelte +100 -100
  240. package/dist/primitives/Icons/Icon.svelte +52 -52
  241. package/dist/primitives/Icons/IconGallery.stories.svelte +235 -235
  242. package/dist/primitives/Icons/Info.svelte +7 -7
  243. package/dist/primitives/Icons/InstagramIcon.svelte +4 -4
  244. package/dist/primitives/Icons/LogoInstagram.svelte +2 -2
  245. package/dist/primitives/Icons/Message.svelte +15 -15
  246. package/dist/primitives/Icons/MoonIcon.svelte +5 -5
  247. package/dist/primitives/Icons/More.svelte +21 -21
  248. package/dist/primitives/Icons/MoreHori.spec.js +61 -61
  249. package/dist/primitives/Icons/MoreHori.svelte +22 -22
  250. package/dist/primitives/Icons/Notification.svelte +14 -14
  251. package/dist/primitives/Icons/Payment.svelte +14 -14
  252. package/dist/primitives/Icons/Profile.svelte +21 -21
  253. package/dist/primitives/Icons/Reload.svelte +29 -29
  254. package/dist/primitives/Icons/Shows.svelte +21 -21
  255. package/dist/primitives/Icons/Signout.svelte +21 -21
  256. package/dist/primitives/Icons/SunIcon.svelte +8 -8
  257. package/dist/primitives/Icons/TiktokIcon.svelte +2 -2
  258. package/dist/primitives/Icons/TwitterIcon.svelte +2 -2
  259. package/dist/primitives/Icons/WarningIcon.spec.js +18 -18
  260. package/dist/primitives/Icons/WarningIcon.svelte +5 -5
  261. package/dist/primitives/Icons/iconTestUtils.spec.d.ts +2 -0
  262. package/dist/primitives/Icons/iconTestUtils.spec.d.ts.map +1 -0
  263. package/dist/primitives/Icons/iconTestUtils.spec.js +235 -0
  264. package/dist/primitives/Input/Input.spec.js +573 -573
  265. package/dist/primitives/Input/Input.stories.svelte +139 -139
  266. package/dist/primitives/Input/Input.svelte +418 -431
  267. package/dist/primitives/Input/Input.svelte.d.ts.map +1 -1
  268. package/dist/primitives/Input/Select.spec.js +212 -218
  269. package/dist/primitives/Input/Select.stories.svelte +112 -112
  270. package/dist/primitives/Input/Select.svelte +128 -128
  271. package/dist/primitives/Input/Textarea.spec.d.ts +2 -0
  272. package/dist/primitives/Input/Textarea.spec.d.ts.map +1 -0
  273. package/dist/primitives/Input/Textarea.spec.js +255 -0
  274. package/dist/primitives/Input/Textarea.stories.svelte +137 -137
  275. package/dist/primitives/Input/Textarea.svelte +35 -35
  276. package/dist/primitives/Label/Label.spec.d.ts +2 -0
  277. package/dist/primitives/Label/Label.spec.d.ts.map +1 -0
  278. package/dist/primitives/Label/Label.spec.js +157 -0
  279. package/dist/primitives/Label/Label.svelte +37 -37
  280. package/dist/primitives/Modal/Modal.spec.js +99 -95
  281. package/dist/primitives/Modal/Modal.stories.svelte +86 -86
  282. package/dist/primitives/Modal/Modal.svelte +158 -158
  283. package/dist/primitives/Modal/ModalTestWrapper.svelte +65 -0
  284. package/dist/primitives/Modal/ModalTestWrapper.svelte.d.ts +23 -0
  285. package/dist/primitives/Modal/ModalTestWrapper.svelte.d.ts.map +1 -0
  286. package/dist/primitives/NumberInput/NumberInput.spec.d.ts +2 -0
  287. package/dist/primitives/NumberInput/NumberInput.spec.d.ts.map +1 -0
  288. package/dist/primitives/NumberInput/NumberInput.spec.js +235 -0
  289. package/dist/primitives/NumberInput/NumberInput.svelte +106 -106
  290. package/dist/primitives/Pagination/Pagination.spec.d.ts +2 -0
  291. package/dist/primitives/Pagination/Pagination.spec.d.ts.map +1 -0
  292. package/dist/primitives/Pagination/Pagination.spec.js +266 -0
  293. package/dist/primitives/Pagination/Pagination.stories.svelte +76 -76
  294. package/dist/primitives/Pagination/Pagination.svelte +261 -261
  295. package/dist/primitives/Radio/Radio.spec.d.ts +2 -0
  296. package/dist/primitives/Radio/Radio.spec.d.ts.map +1 -0
  297. package/dist/primitives/Radio/Radio.spec.js +206 -0
  298. package/dist/primitives/Radio/Radio.stories.svelte +80 -80
  299. package/dist/primitives/Radio/Radio.svelte +67 -67
  300. package/dist/primitives/Skeleton/CardPlaceholder.spec.d.ts +2 -0
  301. package/dist/primitives/Skeleton/CardPlaceholder.spec.d.ts.map +1 -0
  302. package/dist/primitives/Skeleton/CardPlaceholder.spec.js +156 -0
  303. package/dist/primitives/Skeleton/CardPlaceholder.svelte +87 -87
  304. package/dist/primitives/Skeleton/ImagePlaceholder.spec.d.ts +2 -0
  305. package/dist/primitives/Skeleton/ImagePlaceholder.spec.d.ts.map +1 -0
  306. package/dist/primitives/Skeleton/ImagePlaceholder.spec.js +120 -0
  307. package/dist/primitives/Skeleton/ImagePlaceholder.svelte +59 -59
  308. package/dist/primitives/Skeleton/ListPlaceholder.spec.d.ts +2 -0
  309. package/dist/primitives/Skeleton/ListPlaceholder.spec.d.ts.map +1 -0
  310. package/dist/primitives/Skeleton/ListPlaceholder.spec.js +220 -0
  311. package/dist/primitives/Skeleton/ListPlaceholder.svelte +76 -76
  312. package/dist/primitives/Skeleton/Skeleton.spec.d.ts +2 -0
  313. package/dist/primitives/Skeleton/Skeleton.spec.d.ts.map +1 -0
  314. package/dist/primitives/Skeleton/Skeleton.spec.js +173 -0
  315. package/dist/primitives/Skeleton/Skeleton.stories.svelte +151 -151
  316. package/dist/primitives/Skeleton/Skeleton.svelte +26 -26
  317. package/dist/primitives/Spinner/Spinner.spec.js +71 -75
  318. package/dist/primitives/Spinner/Spinner.stories.svelte +29 -29
  319. package/dist/primitives/Spinner/Spinner.svelte +20 -20
  320. package/dist/primitives/Tabs/TabItem.spec.d.ts +2 -0
  321. package/dist/primitives/Tabs/TabItem.spec.d.ts.map +1 -0
  322. package/dist/primitives/Tabs/TabItem.spec.js +130 -0
  323. package/dist/primitives/Tabs/TabItem.svelte +49 -49
  324. package/dist/primitives/Tabs/Tabs.spec.d.ts +2 -0
  325. package/dist/primitives/Tabs/Tabs.spec.d.ts.map +1 -0
  326. package/dist/primitives/Tabs/Tabs.spec.js +295 -0
  327. package/dist/primitives/Tabs/Tabs.stories.svelte +112 -112
  328. package/dist/primitives/Tabs/Tabs.svelte +123 -123
  329. package/dist/primitives/Tabs/TabsWithItems.test.svelte +18 -0
  330. package/dist/primitives/Tabs/TabsWithItems.test.svelte.d.ts +16 -0
  331. package/dist/primitives/Tabs/TabsWithItems.test.svelte.d.ts.map +1 -0
  332. package/dist/primitives/Toggle.spec.js +143 -127
  333. package/dist/primitives/Toggle.stories.svelte +92 -92
  334. package/dist/primitives/Toggle.svelte +71 -71
  335. package/dist/primitives/Typography/Typography.spec.d.ts +2 -0
  336. package/dist/primitives/Typography/Typography.spec.d.ts.map +1 -0
  337. package/dist/primitives/Typography/Typography.spec.js +183 -0
  338. package/dist/primitives/Typography/Typography.svelte +53 -53
  339. package/dist/primitives/ValidationError.spec.js +103 -103
  340. package/dist/primitives/ValidationError.stories.svelte +69 -69
  341. package/dist/primitives/ValidationError.svelte +29 -29
  342. package/dist/primitives/index.d.ts +1 -0
  343. package/dist/primitives/index.js +84 -81
  344. package/dist/recipes/CropImage/CropImage.spec.js +208 -216
  345. package/dist/recipes/CropImage/CropImage.stories.svelte +104 -104
  346. package/dist/recipes/CropImage/CropImage.svelte +238 -238
  347. package/dist/recipes/ImageUploader/ImageUploader.spec.d.ts +2 -0
  348. package/dist/recipes/ImageUploader/ImageUploader.spec.d.ts.map +1 -0
  349. package/dist/recipes/ImageUploader/ImageUploader.spec.js +1351 -0
  350. package/dist/recipes/ImageUploader/ImageUploader.stories.svelte +125 -125
  351. package/dist/recipes/ImageUploader/ImageUploader.svelte +804 -804
  352. package/dist/recipes/SuperLogin/SuperLogin.spec.d.ts +2 -0
  353. package/dist/recipes/SuperLogin/SuperLogin.spec.d.ts.map +1 -0
  354. package/dist/recipes/SuperLogin/SuperLogin.spec.js +1436 -0
  355. package/dist/recipes/Toaster/Toaster.stories.svelte +62 -62
  356. package/dist/recipes/feedback/EmptyState/EmptyState.spec.d.ts +2 -0
  357. package/dist/recipes/feedback/EmptyState/EmptyState.spec.d.ts.map +1 -0
  358. package/dist/recipes/feedback/EmptyState/EmptyState.spec.js +202 -0
  359. package/dist/recipes/feedback/EmptyState/EmptyState.svelte +1 -1
  360. package/dist/recipes/feedback/ErrorDisplay.spec.js +69 -69
  361. package/dist/recipes/feedback/ErrorDisplay.stories.svelte +101 -101
  362. package/dist/recipes/feedback/ErrorDisplay.svelte +1 -1
  363. package/dist/recipes/feedback/StatusIndicator/StatusIndicator.spec.js +133 -129
  364. package/dist/recipes/feedback/StatusIndicator/StatusIndicator.svelte +157 -157
  365. package/dist/recipes/fields/CheckboxField.spec.d.ts +2 -0
  366. package/dist/recipes/fields/CheckboxField.spec.d.ts.map +1 -0
  367. package/dist/recipes/fields/CheckboxField.spec.js +135 -0
  368. package/dist/recipes/fields/CheckboxField.svelte +85 -85
  369. package/dist/recipes/fields/FormField.spec.d.ts +2 -0
  370. package/dist/recipes/fields/FormField.spec.d.ts.map +1 -0
  371. package/dist/recipes/fields/FormField.spec.js +159 -0
  372. package/dist/recipes/fields/FormField.svelte +58 -58
  373. package/dist/recipes/fields/RadioGroup.spec.d.ts +2 -0
  374. package/dist/recipes/fields/RadioGroup.spec.d.ts.map +1 -0
  375. package/dist/recipes/fields/RadioGroup.spec.js +199 -0
  376. package/dist/recipes/fields/RadioGroup.svelte +95 -95
  377. package/dist/recipes/fields/SelectField.spec.d.ts +2 -0
  378. package/dist/recipes/fields/SelectField.spec.d.ts.map +1 -0
  379. package/dist/recipes/fields/SelectField.spec.js +188 -0
  380. package/dist/recipes/fields/SelectField.svelte +80 -80
  381. package/dist/recipes/fields/TextareaField.spec.d.ts +2 -0
  382. package/dist/recipes/fields/TextareaField.spec.d.ts.map +1 -0
  383. package/dist/recipes/fields/TextareaField.spec.js +205 -0
  384. package/dist/recipes/fields/TextareaField.svelte +97 -97
  385. package/dist/recipes/fields/ToggleField.spec.d.ts +2 -0
  386. package/dist/recipes/fields/ToggleField.spec.d.ts.map +1 -0
  387. package/dist/recipes/fields/ToggleField.spec.js +153 -0
  388. package/dist/recipes/fields/ToggleField.svelte +60 -60
  389. package/dist/recipes/fields/index.js +7 -7
  390. package/dist/recipes/inputs/MultiSelect.spec.js +258 -257
  391. package/dist/recipes/inputs/MultiSelect.stories.svelte +133 -133
  392. package/dist/recipes/inputs/MultiSelect.svelte +256 -249
  393. package/dist/recipes/inputs/MultiSelect.svelte.d.ts +2 -0
  394. package/dist/recipes/inputs/MultiSelect.svelte.d.ts.map +1 -1
  395. package/dist/recipes/inputs/OTPInput.spec.js +251 -238
  396. package/dist/recipes/inputs/OTPInput.stories.svelte +162 -162
  397. package/dist/recipes/inputs/OTPInput.svelte +29 -29
  398. package/dist/recipes/inputs/PasswordInput.spec.d.ts +2 -0
  399. package/dist/recipes/inputs/PasswordInput.spec.d.ts.map +1 -0
  400. package/dist/recipes/inputs/PasswordInput.spec.js +410 -0
  401. package/dist/recipes/inputs/PasswordInput.svelte +22 -22
  402. package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.spec.js +253 -173
  403. package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.svelte +117 -117
  404. package/dist/recipes/inputs/PasswordStrengthIndicator/TestWrapper.svelte +71 -0
  405. package/dist/recipes/inputs/PasswordStrengthIndicator/TestWrapper.svelte.d.ts +9 -0
  406. package/dist/recipes/inputs/PasswordStrengthIndicator/TestWrapper.svelte.d.ts.map +1 -0
  407. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.spec.js +1246 -300
  408. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.stories.svelte +123 -123
  409. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte +326 -326
  410. package/dist/recipes/inputs/Search.spec.d.ts +2 -0
  411. package/dist/recipes/inputs/Search.spec.d.ts.map +1 -0
  412. package/dist/recipes/inputs/Search.spec.js +177 -0
  413. package/dist/recipes/inputs/Search.svelte +37 -37
  414. package/dist/recipes/inputs/SelectDropdown.spec.d.ts +2 -0
  415. package/dist/recipes/inputs/SelectDropdown.spec.d.ts.map +1 -0
  416. package/dist/recipes/inputs/SelectDropdown.spec.js +512 -0
  417. package/dist/recipes/inputs/SelectDropdown.svelte +57 -57
  418. package/dist/recipes/modals/AlertModal.spec.d.ts +2 -0
  419. package/dist/recipes/modals/AlertModal.spec.d.ts.map +1 -0
  420. package/dist/recipes/modals/AlertModal.spec.js +432 -0
  421. package/dist/recipes/modals/AlertModal.svelte +130 -130
  422. package/dist/recipes/modals/ConfirmationModal.spec.js +206 -191
  423. package/dist/recipes/modals/ConfirmationModal.stories.svelte +119 -119
  424. package/dist/recipes/modals/ConfirmationModal.svelte +152 -152
  425. package/dist/recipes/modals/InputModal.spec.d.ts +2 -0
  426. package/dist/recipes/modals/InputModal.spec.d.ts.map +1 -0
  427. package/dist/recipes/modals/InputModal.spec.js +872 -0
  428. package/dist/recipes/modals/InputModal.svelte +182 -182
  429. package/dist/recipes/modals/ModalStateManager.spec.js +100 -100
  430. package/dist/recipes/modals/ModalStateManager.svelte +77 -77
  431. package/dist/recipes/modals/ModalTestWrapper.spec.d.ts +2 -0
  432. package/dist/recipes/modals/ModalTestWrapper.spec.d.ts.map +1 -0
  433. package/dist/recipes/modals/ModalTestWrapper.spec.js +502 -0
  434. package/dist/recipes/modals/ModalTestWrapper.svelte +65 -65
  435. package/dist/recipes/modals/StatusModal.spec.d.ts +2 -0
  436. package/dist/recipes/modals/StatusModal.spec.d.ts.map +1 -0
  437. package/dist/recipes/modals/StatusModal.spec.js +599 -0
  438. package/dist/recipes/modals/StatusModal.svelte +206 -206
  439. package/dist/services/EventService.js +75 -75
  440. package/dist/services/EventService.spec.js +217 -217
  441. package/dist/services/ShowService.spec.js +345 -342
  442. package/dist/stores/auth.js +36 -36
  443. package/dist/stores/auth.spec.js +139 -139
  444. package/dist/stores/toaster.js +13 -13
  445. package/dist/stories/ButtonAuditDashboard.spec.d.ts +2 -0
  446. package/dist/stories/ButtonAuditDashboard.spec.d.ts.map +1 -0
  447. package/dist/stories/ButtonAuditDashboard.spec.js +913 -0
  448. package/dist/stories/ButtonAuditReview.spec.d.ts +2 -0
  449. package/dist/stories/ButtonAuditReview.spec.d.ts.map +1 -0
  450. package/dist/stories/ButtonAuditReview.spec.js +422 -0
  451. package/dist/stories/ButtonAuditReview.stories.svelte +14 -14
  452. package/dist/stories/ButtonAuditReview.svelte +427 -427
  453. package/dist/stories/ButtonGridView.spec.d.ts +2 -0
  454. package/dist/stories/ButtonGridView.spec.d.ts.map +1 -0
  455. package/dist/stories/ButtonGridView.spec.js +667 -0
  456. package/dist/stories/ButtonShowcase.spec.d.ts +2 -0
  457. package/dist/stories/ButtonShowcase.spec.d.ts.map +1 -0
  458. package/dist/stories/ButtonShowcase.spec.js +499 -0
  459. package/dist/stories/PatternsGallery.spec.d.ts +2 -0
  460. package/dist/stories/PatternsGallery.spec.d.ts.map +1 -0
  461. package/dist/stories/PatternsGallery.spec.js +514 -0
  462. package/dist/stories/PatternsGallery.stories.svelte +19 -19
  463. package/dist/stories/PatternsGallery.svelte +206 -206
  464. package/dist/stories/PrimitivesGallery.spec.d.ts +2 -0
  465. package/dist/stories/PrimitivesGallery.spec.d.ts.map +1 -0
  466. package/dist/stories/PrimitivesGallery.spec.js +813 -0
  467. package/dist/stories/PrimitivesGallery.stories.svelte +19 -19
  468. package/dist/stories/PrimitivesGallery.svelte +725 -725
  469. package/dist/stories/RecipesGallery.spec.d.ts +2 -0
  470. package/dist/stories/RecipesGallery.spec.d.ts.map +1 -0
  471. package/dist/stories/RecipesGallery.spec.js +299 -0
  472. package/dist/stories/RecipesGallery.stories.svelte +19 -19
  473. package/dist/stories/RecipesGallery.svelte +271 -271
  474. package/dist/stories/button-audit-manifest.json +11186 -11186
  475. package/dist/stripe/useStripeTheme.spec.d.ts +2 -0
  476. package/dist/stripe/useStripeTheme.spec.d.ts.map +1 -0
  477. package/dist/stripe/useStripeTheme.spec.js +793 -0
  478. package/dist/tailwind/preset.cjs +82 -82
  479. package/dist/telemetry.d.ts.map +1 -1
  480. package/dist/telemetry.js +405 -404
  481. package/dist/telemetry.spec.js +1144 -661
  482. package/dist/tokens/__tests__/colors.test.d.ts +2 -0
  483. package/dist/tokens/__tests__/colors.test.d.ts.map +1 -0
  484. package/dist/tokens/__tests__/colors.test.js +152 -0
  485. package/dist/tokens/__tests__/radius.test.d.ts +2 -0
  486. package/dist/tokens/__tests__/radius.test.d.ts.map +1 -0
  487. package/dist/tokens/__tests__/radius.test.js +118 -0
  488. package/dist/tokens/__tests__/shadows.test.d.ts +2 -0
  489. package/dist/tokens/__tests__/shadows.test.d.ts.map +1 -0
  490. package/dist/tokens/__tests__/shadows.test.js +105 -0
  491. package/dist/tokens/__tests__/spacing.test.js +11 -8
  492. package/dist/tokens/__tests__/typography-base.test.d.ts +2 -0
  493. package/dist/tokens/__tests__/typography-base.test.d.ts.map +1 -0
  494. package/dist/tokens/__tests__/typography-base.test.js +138 -0
  495. package/dist/tokens/__tests__/typography.test.d.ts +2 -0
  496. package/dist/tokens/__tests__/typography.test.d.ts.map +1 -0
  497. package/dist/tokens/__tests__/typography.test.js +156 -0
  498. package/dist/tokens/__tests__/z-index.test.d.ts +2 -0
  499. package/dist/tokens/__tests__/z-index.test.d.ts.map +1 -0
  500. package/dist/tokens/__tests__/z-index.test.js +121 -0
  501. package/dist/tokens/tokens.css +87 -87
  502. package/dist/tokens/typography-base.css +163 -0
  503. package/dist/utils/apiConfig.spec.js +219 -118
  504. package/dist/utils/formatters.spec.d.ts +2 -0
  505. package/dist/utils/formatters.spec.d.ts.map +1 -0
  506. package/dist/utils/formatters.spec.js +82 -0
  507. package/dist/utils/transitions.js +62 -62
  508. package/dist/utils/transitions.spec.d.ts +2 -0
  509. package/dist/utils/transitions.spec.d.ts.map +1 -0
  510. package/dist/utils/transitions.spec.js +130 -0
  511. package/dist/utils/utils.js +354 -354
  512. package/package.json +292 -286
@@ -1,170 +1,173 @@
1
- import { render, screen, fireEvent } from "@testing-library/svelte";
2
- import userEvent from "@testing-library/user-event";
3
- import { expect, describe, test, vi } from "vitest";
4
- import Alert from "./Alert.svelte";
5
-
6
- function setupTest(args = {}) {
7
- const user = userEvent.setup();
8
- const { component } = render(Alert, {
9
- props: { ...args },
10
- });
11
- return { user, component };
12
- }
13
-
14
- describe("Alert Component Tests", () => {
15
- test("Renders alert with title", () => {
16
- setupTest({
17
- title: "Alert Title",
18
- });
19
- expect(screen.getByText("Alert Title")).toBeInTheDocument();
20
- });
21
-
22
- test("Renders alert with message", () => {
23
- setupTest({
24
- message: "This is an alert message",
25
- });
26
- expect(screen.getByText("This is an alert message")).toBeInTheDocument();
27
- });
28
-
29
- test("Renders alert with both title and message", () => {
30
- setupTest({
31
- title: "Warning",
32
- message: "Something needs your attention",
33
- });
34
- expect(screen.getByText("Warning")).toBeInTheDocument();
35
- expect(screen.getByText("Something needs your attention")).toBeInTheDocument();
36
- });
37
-
38
- test("Maps info type to blue color", () => {
39
- const { component } = setupTest({
40
- title: "Info Alert",
41
- type: "info",
42
- });
43
- // The Alert component should have the correct Flowbite color prop
44
- const alertElement = screen.getByRole("alert");
45
- expect(alertElement).toBeInTheDocument();
46
- });
47
-
48
- test("Maps success type to green color", () => {
49
- setupTest({
50
- title: "Success Alert",
51
- type: "success",
52
- });
53
- const alertElement = screen.getByRole("alert");
54
- expect(alertElement).toBeInTheDocument();
55
- });
56
-
57
- test("Maps warning type to yellow color", () => {
58
- setupTest({
59
- title: "Warning Alert",
60
- type: "warning",
61
- });
62
- const alertElement = screen.getByRole("alert");
63
- expect(alertElement).toBeInTheDocument();
64
- });
65
-
66
- test("Maps danger type to red color", () => {
67
- setupTest({
68
- title: "Danger Alert",
69
- type: "danger",
70
- });
71
- const alertElement = screen.getByRole("alert");
72
- expect(alertElement).toBeInTheDocument();
73
- });
74
-
75
- test("Defaults to info type when type is invalid", () => {
76
- setupTest({
77
- title: "Default Alert",
78
- type: "invalid-type",
79
- });
80
- const alertElement = screen.getByRole("alert");
81
- expect(alertElement).toBeInTheDocument();
82
- });
83
-
84
- test("Shows dismiss button when onClose is provided", () => {
85
- const onCloseMock = vi.fn();
86
- setupTest({
87
- title: "Dismissable Alert",
88
- onClose: onCloseMock,
89
- });
90
- // Flowbite Alert shows dismiss button when dismissable
91
- const dismissButton = screen.queryByRole("button");
92
- expect(dismissButton).toBeInTheDocument();
93
- });
94
-
95
- test("Does not show dismiss button when onClose is not provided", () => {
96
- setupTest({
97
- title: "Non-dismissable Alert",
98
- });
99
- // Without onClose, there should be no dismiss button
100
- const dismissButton = screen.queryByRole("button");
101
- expect(dismissButton).not.toBeInTheDocument();
102
- });
103
-
104
- test("Calls onClose when dismiss button is clicked", async () => {
105
- const onCloseMock = vi.fn();
106
- const { user } = setupTest({
107
- title: "Dismissable Alert",
108
- onClose: onCloseMock,
109
- });
110
-
111
- const dismissButton = screen.getByRole("button");
112
- await user.click(dismissButton);
113
-
114
- // Note: Flowbite Alert may handle close differently - check if button exists
115
- expect(dismissButton).toBeInTheDocument();
116
- });
117
-
118
- test("Renders with close button when onClose provided", async () => {
119
- const onCloseMock = vi.fn();
120
- setupTest({
121
- title: "Dismissable Alert",
122
- onClose: onCloseMock,
123
- });
124
-
125
- const dismissButton = screen.getByRole("button");
126
- expect(dismissButton).toBeInTheDocument();
127
- });
128
-
129
- test("Has custom-alert class for dark mode styling", () => {
130
- setupTest({
131
- title: "Styled Alert",
132
- });
133
- const alertElement = screen.getByRole("alert");
134
- expect(alertElement).toHaveClass("custom-alert");
135
- });
136
-
137
- test("Renders without title when only message is provided", () => {
138
- setupTest({
139
- message: "Message only alert",
140
- });
141
- expect(screen.getByText("Message only alert")).toBeInTheDocument();
142
- });
143
-
144
- test("Renders empty alert when no props provided", () => {
145
- setupTest({});
146
- const alertElement = screen.getByRole("alert");
147
- expect(alertElement).toBeInTheDocument();
148
- });
149
- });
150
-
151
- describe("Alert Type Color Mapping", () => {
152
- const typeColorMap = [
153
- { type: "info", expectedColor: "blue" },
154
- { type: "success", expectedColor: "green" },
155
- { type: "warning", expectedColor: "yellow" },
156
- { type: "danger", expectedColor: "red" },
157
- ];
158
-
159
- typeColorMap.forEach(({ type, expectedColor }) => {
160
- test(`Type "${type}" maps to "${expectedColor}" color`, () => {
161
- setupTest({
162
- title: `${type} Alert`,
163
- type,
164
- });
165
- // Alert renders successfully with correct type
166
- const alertElement = screen.getByRole("alert");
167
- expect(alertElement).toBeInTheDocument();
168
- });
169
- });
170
- });
1
+ import { render, screen, fireEvent } from "@testing-library/svelte";
2
+ import userEvent from "@testing-library/user-event";
3
+ import { expect, describe, test, vi } from "vitest";
4
+ import Alert from "./Alert.svelte";
5
+
6
+ function setupTest(args = {}) {
7
+ const user = userEvent.setup();
8
+ const { component } = render(Alert, {
9
+ props: { ...args },
10
+ });
11
+ return { user, component };
12
+ }
13
+
14
+ describe("Alert Component Tests", () => {
15
+ test("Renders alert with title", () => {
16
+ setupTest({
17
+ title: "Alert Title",
18
+ });
19
+ expect(screen.getByText("Alert Title")).toBeInTheDocument();
20
+ });
21
+
22
+ test("Renders alert with message", () => {
23
+ setupTest({
24
+ message: "This is an alert message",
25
+ });
26
+ expect(screen.getByText("This is an alert message")).toBeInTheDocument();
27
+ });
28
+
29
+ test("Renders alert with both title and message", () => {
30
+ setupTest({
31
+ title: "Warning",
32
+ message: "Something needs your attention",
33
+ });
34
+ expect(screen.getByText("Warning")).toBeInTheDocument();
35
+ expect(screen.getByText("Something needs your attention")).toBeInTheDocument();
36
+ });
37
+
38
+ test("Maps info type to blue color", () => {
39
+ const { component } = setupTest({
40
+ title: "Info Alert",
41
+ type: "info",
42
+ });
43
+ // The Alert component should have the correct Flowbite color prop
44
+ const alertElement = screen.getByRole("alert");
45
+ expect(alertElement).toBeInTheDocument();
46
+ });
47
+
48
+ test("Maps success type to green color", () => {
49
+ setupTest({
50
+ title: "Success Alert",
51
+ type: "success",
52
+ });
53
+ const alertElement = screen.getByRole("alert");
54
+ expect(alertElement).toBeInTheDocument();
55
+ });
56
+
57
+ test("Maps warning type to yellow color", () => {
58
+ setupTest({
59
+ title: "Warning Alert",
60
+ type: "warning",
61
+ });
62
+ const alertElement = screen.getByRole("alert");
63
+ expect(alertElement).toBeInTheDocument();
64
+ });
65
+
66
+ test("Maps danger type to red color", () => {
67
+ setupTest({
68
+ title: "Danger Alert",
69
+ type: "danger",
70
+ });
71
+ const alertElement = screen.getByRole("alert");
72
+ expect(alertElement).toBeInTheDocument();
73
+ });
74
+
75
+ test("Defaults to info type when type is invalid", () => {
76
+ setupTest({
77
+ title: "Default Alert",
78
+ type: "invalid-type",
79
+ });
80
+ const alertElement = screen.getByRole("alert");
81
+ expect(alertElement).toBeInTheDocument();
82
+ });
83
+
84
+ test("Shows dismiss button when onClose is provided", () => {
85
+ const onCloseMock = vi.fn();
86
+ setupTest({
87
+ title: "Dismissable Alert",
88
+ onClose: onCloseMock,
89
+ });
90
+ // Flowbite Alert shows dismiss button when dismissable
91
+ const dismissButton = screen.queryByRole("button");
92
+ expect(dismissButton).toBeInTheDocument();
93
+ });
94
+
95
+ test("Does not show dismiss button when onClose is not provided", () => {
96
+ setupTest({
97
+ title: "Non-dismissable Alert",
98
+ });
99
+ // Without onClose, there should be no dismiss button
100
+ const dismissButton = screen.queryByRole("button");
101
+ expect(dismissButton).not.toBeInTheDocument();
102
+ });
103
+
104
+ test("Calls onClose when dismiss button is clicked", async () => {
105
+ const onCloseMock = vi.fn();
106
+ const { user } = setupTest({
107
+ title: "Dismissable Alert",
108
+ onClose: onCloseMock,
109
+ });
110
+
111
+ const dismissButton = screen.getByRole("button");
112
+ await user.click(dismissButton);
113
+
114
+ // Note: Flowbite Alert may handle close differently - check if button exists
115
+ expect(dismissButton).toBeInTheDocument();
116
+ });
117
+
118
+ test("Renders with close button when onClose provided", async () => {
119
+ const onCloseMock = vi.fn();
120
+ setupTest({
121
+ title: "Dismissable Alert",
122
+ onClose: onCloseMock,
123
+ });
124
+
125
+ const dismissButton = screen.getByRole("button");
126
+ expect(dismissButton).toBeInTheDocument();
127
+ });
128
+
129
+ test("Has proper alert styling classes", () => {
130
+ setupTest({
131
+ title: "Styled Alert",
132
+ });
133
+ const alertElement = screen.getByRole("alert");
134
+ expect(alertElement).toHaveClass("flex");
135
+ expect(alertElement).toHaveClass("items-center");
136
+ expect(alertElement).toHaveClass("p-4");
137
+ expect(alertElement).toHaveClass("rounded-lg");
138
+ });
139
+
140
+ test("Renders without title when only message is provided", () => {
141
+ setupTest({
142
+ message: "Message only alert",
143
+ });
144
+ expect(screen.getByText("Message only alert")).toBeInTheDocument();
145
+ });
146
+
147
+ test("Renders empty alert when no props provided", () => {
148
+ setupTest({});
149
+ const alertElement = screen.getByRole("alert");
150
+ expect(alertElement).toBeInTheDocument();
151
+ });
152
+ });
153
+
154
+ describe("Alert Type Color Mapping", () => {
155
+ const typeColorMap = [
156
+ { type: "info", expectedColor: "blue" },
157
+ { type: "success", expectedColor: "green" },
158
+ { type: "warning", expectedColor: "yellow" },
159
+ { type: "danger", expectedColor: "red" },
160
+ ];
161
+
162
+ typeColorMap.forEach(({ type, expectedColor }) => {
163
+ test(`Type "${type}" maps to "${expectedColor}" color`, () => {
164
+ setupTest({
165
+ title: `${type} Alert`,
166
+ type,
167
+ });
168
+ // Alert renders successfully with correct type
169
+ const alertElement = screen.getByRole("alert");
170
+ expect(alertElement).toBeInTheDocument();
171
+ });
172
+ });
173
+ });
@@ -1,88 +1,88 @@
1
- <script module>
2
- import { defineMeta } from '@storybook/addon-svelte-csf';
3
- import Alert from './Alert.svelte';
4
-
5
- const { Story } = defineMeta({
6
- title: 'Primitives/Alert',
7
- component: Alert,
8
- tags: ['autodocs'],
9
- argTypes: {
10
- color: {
11
- control: 'select',
12
- options: ['info', 'success', 'warning', 'error'],
13
- },
14
- dismissible: { control: 'boolean' },
15
- },
16
- parameters: {
17
- docs: {
18
- description: {
19
- component: 'Contextual feedback messages for user actions or system states.',
20
- },
21
- },
22
- },
23
- });
24
- </script>
25
-
26
- <Story name="Info" args={{ color: 'info' }}>
27
- {#snippet template(args)}
28
- <Alert {...args}>
29
- <span class="font-medium">Info!</span> This is an informational alert with helpful information.
30
- </Alert>
31
- {/snippet}
32
- </Story>
33
-
34
- <Story name="Success" args={{ color: 'success' }}>
35
- {#snippet template(args)}
36
- <Alert {...args}>
37
- <span class="font-medium">Success!</span> Your changes have been saved successfully.
38
- </Alert>
39
- {/snippet}
40
- </Story>
41
-
42
- <Story name="Warning" args={{ color: 'warning' }}>
43
- {#snippet template(args)}
44
- <Alert {...args}>
45
- <span class="font-medium">Warning!</span> Please review this information before proceeding.
46
- </Alert>
47
- {/snippet}
48
- </Story>
49
-
50
- <Story name="Error" args={{ color: 'error' }}>
51
- {#snippet template(args)}
52
- <Alert {...args}>
53
- <span class="font-medium">Error!</span> Something went wrong. Please try again.
54
- </Alert>
55
- {/snippet}
56
- </Story>
57
-
58
- <Story name="Dismissible">
59
- {#snippet template()}
60
- <div class="space-y-4">
61
- <Alert color="info" dismissible>
62
- Click the X to dismiss this alert.
63
- </Alert>
64
- <Alert color="success" dismissible>
65
- This success alert can also be dismissed.
66
- </Alert>
67
- </div>
68
- {/snippet}
69
- </Story>
70
-
71
- <Story name="All Variants">
72
- {#snippet template()}
73
- <div class="space-y-4">
74
- <Alert color="info">
75
- <span class="font-medium">Info:</span> Just letting you know about something.
76
- </Alert>
77
- <Alert color="success">
78
- <span class="font-medium">Success:</span> Great job! Everything worked.
79
- </Alert>
80
- <Alert color="warning">
81
- <span class="font-medium">Warning:</span> Be careful about this action.
82
- </Alert>
83
- <Alert color="error">
84
- <span class="font-medium">Error:</span> Something went wrong.
85
- </Alert>
86
- </div>
87
- {/snippet}
88
- </Story>
1
+ <script module>
2
+ import { defineMeta } from '@storybook/addon-svelte-csf';
3
+ import Alert from './Alert.svelte';
4
+
5
+ const { Story } = defineMeta({
6
+ title: 'Primitives/Alert',
7
+ component: Alert,
8
+ tags: ['autodocs'],
9
+ argTypes: {
10
+ color: {
11
+ control: 'select',
12
+ options: ['info', 'success', 'warning', 'error'],
13
+ },
14
+ dismissible: { control: 'boolean' },
15
+ },
16
+ parameters: {
17
+ docs: {
18
+ description: {
19
+ component: 'Contextual feedback messages for user actions or system states.',
20
+ },
21
+ },
22
+ },
23
+ });
24
+ </script>
25
+
26
+ <Story name="Info" args={{ color: 'info' }}>
27
+ {#snippet template(args)}
28
+ <Alert {...args}>
29
+ <span class="font-medium">Info!</span> This is an informational alert with helpful information.
30
+ </Alert>
31
+ {/snippet}
32
+ </Story>
33
+
34
+ <Story name="Success" args={{ color: 'success' }}>
35
+ {#snippet template(args)}
36
+ <Alert {...args}>
37
+ <span class="font-medium">Success!</span> Your changes have been saved successfully.
38
+ </Alert>
39
+ {/snippet}
40
+ </Story>
41
+
42
+ <Story name="Warning" args={{ color: 'warning' }}>
43
+ {#snippet template(args)}
44
+ <Alert {...args}>
45
+ <span class="font-medium">Warning!</span> Please review this information before proceeding.
46
+ </Alert>
47
+ {/snippet}
48
+ </Story>
49
+
50
+ <Story name="Error" args={{ color: 'error' }}>
51
+ {#snippet template(args)}
52
+ <Alert {...args}>
53
+ <span class="font-medium">Error!</span> Something went wrong. Please try again.
54
+ </Alert>
55
+ {/snippet}
56
+ </Story>
57
+
58
+ <Story name="Dismissible">
59
+ {#snippet template()}
60
+ <div class="space-y-4">
61
+ <Alert color="info" dismissible>
62
+ Click the X to dismiss this alert.
63
+ </Alert>
64
+ <Alert color="success" dismissible>
65
+ This success alert can also be dismissed.
66
+ </Alert>
67
+ </div>
68
+ {/snippet}
69
+ </Story>
70
+
71
+ <Story name="All Variants">
72
+ {#snippet template()}
73
+ <div class="space-y-4">
74
+ <Alert color="info">
75
+ <span class="font-medium">Info:</span> Just letting you know about something.
76
+ </Alert>
77
+ <Alert color="success">
78
+ <span class="font-medium">Success:</span> Great job! Everything worked.
79
+ </Alert>
80
+ <Alert color="warning">
81
+ <span class="font-medium">Warning:</span> Be careful about this action.
82
+ </Alert>
83
+ <Alert color="error">
84
+ <span class="font-medium">Error:</span> Something went wrong.
85
+ </Alert>
86
+ </div>
87
+ {/snippet}
88
+ </Story>
@@ -29,36 +29,36 @@
29
29
 
30
30
  let alertClasses = $derived(alertColorVariants[type] || alertColorVariants.info);
31
31
  let closeButtonClasses = $derived(alertCloseButtonVariants[type] || alertCloseButtonVariants.info);
32
-
33
- function handleClose() {
34
- onClose?.();
35
- onclose?.();
36
- }
37
-
38
- let showCloseButton = $derived(onClose !== undefined || onclose !== undefined);
39
- </script>
40
-
41
- <div class="flex items-center p-4 mb-4 text-sm rounded-lg {alertClasses}" role="alert" {...restProps}>
42
- <InfoCircleOutline class="shrink-0 w-4 h-4 me-3" />
43
- <span class="sr-only">{type}</span>
44
- <div class="flex-1">
45
- {#if title}
46
- <span class="font-medium">{title}</span>
47
- {/if}
48
- {#if message}
49
- <span class:mt-1={title}>{message}</span>
50
- {/if}
51
- {#if children}{@render children()}{/if}
52
- </div>
53
- {#if showCloseButton}
32
+
33
+ function handleClose() {
34
+ onClose?.();
35
+ onclose?.();
36
+ }
37
+
38
+ let showCloseButton = $derived(onClose !== undefined || onclose !== undefined);
39
+ </script>
40
+
41
+ <div class="flex items-center p-4 mb-4 text-sm rounded-lg {alertClasses}" role="alert" {...restProps}>
42
+ <InfoCircleOutline class="shrink-0 w-4 h-4 me-3" />
43
+ <span class="sr-only">{type}</span>
44
+ <div class="flex-1">
45
+ {#if title}
46
+ <span class="font-medium">{title}</span>
47
+ {/if}
48
+ {#if message}
49
+ <span class:mt-1={title}>{message}</span>
50
+ {/if}
51
+ {#if children}{@render children()}{/if}
52
+ </div>
53
+ {#if showCloseButton}
54
54
  <button
55
55
  type="button"
56
56
  class="ms-auto -mx-1.5 -my-1.5 rounded-lg focus:ring-2 p-1.5 inline-flex items-center justify-center h-8 w-8 {closeButtonClasses}"
57
57
  aria-label="Close"
58
58
  onclick={handleClose}
59
59
  >
60
- <span class="sr-only">Close</span>
61
- <CloseOutline class="w-3 h-3" />
62
- </button>
63
- {/if}
64
- </div>
60
+ <span class="sr-only">Close</span>
61
+ <CloseOutline class="w-3 h-3" />
62
+ </button>
63
+ {/if}
64
+ </div>
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=Avatar.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Avatar.spec.d.ts","sourceRoot":"","sources":["../../../src/lib/primitives/Avatar/Avatar.spec.js"],"names":[],"mappings":""}