@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,197 @@
1
+ import { render, screen } from '@testing-library/svelte';
2
+ import { expect, describe, test } from 'vitest';
3
+ import SectionHeader from './SectionHeader.svelte';
4
+
5
+ describe('SectionHeader Component', () => {
6
+ test('renders a wrapper div', () => {
7
+ const { container } = render(SectionHeader);
8
+ expect(container.querySelector('div')).toBeInTheDocument();
9
+ });
10
+
11
+ test('applies custom className', () => {
12
+ const { container } = render(SectionHeader, { props: { class: 'custom-section' } });
13
+ const wrapper = container.querySelector('div');
14
+ expect(wrapper).toHaveClass('custom-section');
15
+ });
16
+ });
17
+
18
+ describe('SectionHeader Title', () => {
19
+ test('no title renders no h2', () => {
20
+ const { container } = render(SectionHeader);
21
+ expect(container.querySelector('h2')).not.toBeInTheDocument();
22
+ });
23
+
24
+ test('title prop renders h2', () => {
25
+ render(SectionHeader, { props: { title: 'Recent Activity' } });
26
+ expect(screen.getByText('Recent Activity')).toBeInTheDocument();
27
+ });
28
+
29
+ test('title is in h2 element', () => {
30
+ const { container } = render(SectionHeader, { props: { title: 'Orders' } });
31
+ const h2 = container.querySelector('h2');
32
+ expect(h2).toBeInTheDocument();
33
+ expect(h2).toHaveTextContent('Orders');
34
+ });
35
+ });
36
+
37
+ describe('SectionHeader Description', () => {
38
+ test('no description renders no p', () => {
39
+ const { container } = render(SectionHeader);
40
+ expect(container.querySelector('p')).not.toBeInTheDocument();
41
+ });
42
+
43
+ test('description prop renders p', () => {
44
+ render(SectionHeader, { props: { description: 'View all recent orders' } });
45
+ expect(screen.getByText('View all recent orders')).toBeInTheDocument();
46
+ });
47
+
48
+ test('description p has mt-1 margin', () => {
49
+ const { container } = render(SectionHeader, { props: { description: 'Test desc' } });
50
+ const p = container.querySelector('p');
51
+ expect(p).toHaveClass('mt-1');
52
+ });
53
+ });
54
+
55
+ describe('SectionHeader Count', () => {
56
+ test('no count by default', () => {
57
+ const { container } = render(SectionHeader, { props: { title: 'Items' } });
58
+ const span = container.querySelector('span');
59
+ expect(span).not.toBeInTheDocument();
60
+ });
61
+
62
+ test('count=null renders no badge', () => {
63
+ const { container } = render(SectionHeader, { props: { title: 'Items', count: null } });
64
+ const span = container.querySelector('span');
65
+ expect(span).not.toBeInTheDocument();
66
+ });
67
+
68
+ test('count prop renders badge', () => {
69
+ render(SectionHeader, { props: { title: 'Items', count: 42 } });
70
+ expect(screen.getByText('42')).toBeInTheDocument();
71
+ });
72
+
73
+ test('count=0 still renders badge', () => {
74
+ render(SectionHeader, { props: { title: 'Items', count: 0 } });
75
+ expect(screen.getByText('0')).toBeInTheDocument();
76
+ });
77
+
78
+ test('count badge has styling classes', () => {
79
+ const { container } = render(SectionHeader, { props: { title: 'Test', count: 5 } });
80
+ const badge = container.querySelector('span');
81
+ expect(badge).toHaveClass('inline-flex');
82
+ expect(badge).toHaveClass('items-center');
83
+ expect(badge).toHaveClass('justify-center');
84
+ });
85
+
86
+ test('count badge has bg-gray-100', () => {
87
+ const { container } = render(SectionHeader, { props: { title: 'Test', count: 10 } });
88
+ const badge = container.querySelector('span');
89
+ expect(badge).toHaveClass('bg-gray-100');
90
+ });
91
+
92
+ test('count badge has rounded-full', () => {
93
+ const { container } = render(SectionHeader, { props: { title: 'Test', count: 10 } });
94
+ const badge = container.querySelector('span');
95
+ expect(badge).toHaveClass('rounded-full');
96
+ });
97
+
98
+ test('count badge has dark mode bg', () => {
99
+ const { container } = render(SectionHeader, { props: { title: 'Test', count: 10 } });
100
+ const badge = container.querySelector('span');
101
+ expect(badge).toHaveClass('dark:bg-gray-700');
102
+ });
103
+
104
+ test('count badge has padding', () => {
105
+ const { container } = render(SectionHeader, { props: { title: 'Test', count: 10 } });
106
+ const badge = container.querySelector('span');
107
+ expect(badge).toHaveClass('px-2');
108
+ expect(badge).toHaveClass('py-0.5');
109
+ });
110
+ });
111
+
112
+ describe('SectionHeader Divider', () => {
113
+ test('no divider by default', () => {
114
+ const { container } = render(SectionHeader);
115
+ expect(container.querySelector('hr')).not.toBeInTheDocument();
116
+ });
117
+
118
+ test('divider=true shows hr', () => {
119
+ const { container } = render(SectionHeader, { props: { divider: true } });
120
+ expect(container.querySelector('hr')).toBeInTheDocument();
121
+ });
122
+
123
+ test('divider=false hides hr', () => {
124
+ const { container } = render(SectionHeader, { props: { divider: false } });
125
+ expect(container.querySelector('hr')).not.toBeInTheDocument();
126
+ });
127
+
128
+ test('divider has border-gray-200', () => {
129
+ const { container } = render(SectionHeader, { props: { divider: true } });
130
+ const hr = container.querySelector('hr');
131
+ expect(hr).toHaveClass('border-gray-200');
132
+ });
133
+
134
+ test('divider has dark mode class', () => {
135
+ const { container } = render(SectionHeader, { props: { divider: true } });
136
+ const hr = container.querySelector('hr');
137
+ expect(hr).toHaveClass('dark:border-gray-700');
138
+ });
139
+
140
+ test('divider has mb-4 margin', () => {
141
+ const { container } = render(SectionHeader, { props: { divider: true } });
142
+ const hr = container.querySelector('hr');
143
+ expect(hr).toHaveClass('mb-4');
144
+ });
145
+ });
146
+
147
+ describe('SectionHeader Layout', () => {
148
+ test('has flex container for title and count', () => {
149
+ const { container } = render(SectionHeader, { props: { title: 'Test' } });
150
+ const flexDiv = container.querySelector('div.flex.items-center.justify-between');
151
+ expect(flexDiv).toBeInTheDocument();
152
+ });
153
+
154
+ test('flex container has gap-4', () => {
155
+ const { container } = render(SectionHeader, { props: { title: 'Test' } });
156
+ const flexDiv = container.querySelector('div.flex.items-center.justify-between');
157
+ expect(flexDiv).toHaveClass('gap-4');
158
+ });
159
+
160
+ test('title and count are in left flex group', () => {
161
+ const { container } = render(SectionHeader, { props: { title: 'Items', count: 5 } });
162
+ const leftGroup = container.querySelector('div.flex.items-center.gap-2');
163
+ expect(leftGroup).toBeInTheDocument();
164
+ });
165
+ });
166
+
167
+ describe('SectionHeader Combinations', () => {
168
+ test('title and description', () => {
169
+ render(SectionHeader, { props: { title: 'Products', description: 'All available products' } });
170
+ expect(screen.getByText('Products')).toBeInTheDocument();
171
+ expect(screen.getByText('All available products')).toBeInTheDocument();
172
+ });
173
+
174
+ test('title and count', () => {
175
+ render(SectionHeader, { props: { title: 'Users', count: 150 } });
176
+ expect(screen.getByText('Users')).toBeInTheDocument();
177
+ expect(screen.getByText('150')).toBeInTheDocument();
178
+ });
179
+
180
+ test('all props together', () => {
181
+ const { container } = render(SectionHeader, {
182
+ props: {
183
+ title: 'Orders',
184
+ description: 'View all orders',
185
+ count: 25,
186
+ divider: true,
187
+ class: 'mt-6'
188
+ }
189
+ });
190
+ const wrapper = container.firstElementChild;
191
+ expect(wrapper).toHaveClass('mt-6');
192
+ expect(container.querySelector('hr')).toBeInTheDocument();
193
+ expect(screen.getByText('Orders')).toBeInTheDocument();
194
+ expect(screen.getByText('View all orders')).toBeInTheDocument();
195
+ expect(screen.getByText('25')).toBeInTheDocument();
196
+ });
197
+ });
@@ -20,32 +20,32 @@
20
20
  actions,
21
21
  }: Props = $props();
22
22
  </script>
23
-
24
- <div class={className}>
25
- {#if divider}
26
- <hr class="border-gray-200 dark:border-gray-700 mb-4" />
27
- {/if}
28
-
29
- <div class="flex items-center justify-between gap-4">
30
- <div class="flex items-center gap-2">
31
- {#if title}
32
- <h2 class={typography.h3}>{title}</h2>
33
- {/if}
34
- {#if count !== null}
35
- <span class={`inline-flex items-center justify-center px-2 py-0.5 ${typography.xsMuted} bg-gray-100 dark:bg-gray-700 rounded-full`}>
36
- {count}
37
- </span>
38
- {/if}
39
- </div>
40
-
41
- {#if actions}
42
- <div class="flex items-center gap-2">
43
- {@render actions()}
44
- </div>
45
- {/if}
46
- </div>
47
-
48
- {#if description}
49
- <p class={`mt-1 ${typography.smMuted}`}>{description}</p>
50
- {/if}
51
- </div>
23
+
24
+ <div class={className}>
25
+ {#if divider}
26
+ <hr class="border-gray-200 dark:border-gray-700 mb-4" />
27
+ {/if}
28
+
29
+ <div class="flex items-center justify-between gap-4">
30
+ <div class="flex items-center gap-2">
31
+ {#if title}
32
+ <h2 class={typography.h3}>{title}</h2>
33
+ {/if}
34
+ {#if count !== null}
35
+ <span class={`inline-flex items-center justify-center px-2 py-0.5 ${typography.xsMuted} bg-gray-100 dark:bg-gray-700 rounded-full`}>
36
+ {count}
37
+ </span>
38
+ {/if}
39
+ </div>
40
+
41
+ {#if actions}
42
+ <div class="flex items-center gap-2">
43
+ {@render actions()}
44
+ </div>
45
+ {/if}
46
+ </div>
47
+
48
+ {#if description}
49
+ <p class={`mt-1 ${typography.smMuted}`}>{description}</p>
50
+ {/if}
51
+ </div>
@@ -1,112 +1,112 @@
1
- /**
2
- * Badge Presets - Domain-to-Color Mappings
3
- *
4
- * These presets provide a migration path for apps that were using
5
- * domain-specific badge variants (host, headliner, etc.).
6
- *
7
- * Usage:
8
- * import { ROLE_BADGE_VARIANTS, ENTITY_BADGE_VARIANTS } from '@getmicdrop/svelte-components/presets/badges';
9
- * <Badge variant={ROLE_BADGE_VARIANTS[role]}>{role}</Badge>
10
- *
11
- * Note: For app-specific customization, apps should define their own
12
- * mappings in their constants files (e.g., $lib/constants/position.ts).
13
- */
14
-
15
- /**
16
- * Role/Position badge color mappings
17
- * Maps performer roles to Flowbite color variants
18
- */
19
- export const ROLE_BADGE_VARIANTS = {
20
- Host: 'red',
21
- Headliner: 'purple',
22
- Feature: 'blue',
23
- 'Special Guest': 'green',
24
- Opener: 'orange',
25
- Guest: 'gray',
26
- Teacher: 'yellow',
27
- Assistant: 'indigo',
28
- };
29
-
30
- /**
31
- * Entity type badge color mappings
32
- * Maps entity types to Flowbite color variants
33
- */
34
- export const ENTITY_BADGE_VARIANTS = {
35
- event: 'blue',
36
- venue: 'green',
37
- user: 'purple',
38
- order: 'orange',
39
- performer: 'pink',
40
- };
41
-
42
- /**
43
- * Status badge semantic mappings
44
- * Maps status strings to semantic variants
45
- */
46
- export const STATUS_BADGE_VARIANTS = {
47
- // Success states
48
- Completed: 'success',
49
- Active: 'success',
50
- Confirmed: 'success',
51
- 'On Sale': 'success',
52
- Live: 'success',
53
- Enabled: 'success',
54
- Yes: 'success',
55
- Redeemed: 'success',
56
- Online: 'success',
57
-
58
- // Warning states
59
- Pending: 'warning',
60
- Scheduled: 'warning',
61
- Paused: 'warning',
62
- Ended: 'warning',
63
- Refunded: 'warning',
64
- 'Partially refunded': 'warning',
65
- Pinned: 'warning',
66
- 'Usage Limit Reached': 'warning',
67
-
68
- // Error states
69
- Cancelled: 'error',
70
- Canceled: 'error',
71
- Declined: 'error',
72
- 'No show': 'error',
73
- Expired: 'error',
74
- 'Sales closed': 'error',
75
-
76
- // Info states
77
- 'In Progress': 'info',
78
- Invited: 'info',
79
-
80
- // Neutral states
81
- Draft: 'neutral',
82
- Offline: 'neutral',
83
- Disabled: 'neutral',
84
- No: 'neutral',
85
- };
86
-
87
- /**
88
- * Get badge variant for a role
89
- * @param {string} role - The role name
90
- * @returns {string} Flowbite color variant
91
- */
92
- export function getRoleBadgeVariant(role) {
93
- return ROLE_BADGE_VARIANTS[role] || 'gray';
94
- }
95
-
96
- /**
97
- * Get badge variant for an entity type
98
- * @param {string} entityType - The entity type
99
- * @returns {string} Flowbite color variant
100
- */
101
- export function getEntityBadgeVariant(entityType) {
102
- return ENTITY_BADGE_VARIANTS[entityType] || 'gray';
103
- }
104
-
105
- /**
106
- * Get badge variant for a status
107
- * @param {string} status - The status string
108
- * @returns {string} Semantic variant
109
- */
110
- export function getStatusBadgeVariant(status) {
111
- return STATUS_BADGE_VARIANTS[status] || 'neutral';
112
- }
1
+ /**
2
+ * Badge Presets - Domain-to-Color Mappings
3
+ *
4
+ * These presets provide a migration path for apps that were using
5
+ * domain-specific badge variants (host, headliner, etc.).
6
+ *
7
+ * Usage:
8
+ * import { ROLE_BADGE_VARIANTS, ENTITY_BADGE_VARIANTS } from '@getmicdrop/svelte-components/presets/badges';
9
+ * <Badge variant={ROLE_BADGE_VARIANTS[role]}>{role}</Badge>
10
+ *
11
+ * Note: For app-specific customization, apps should define their own
12
+ * mappings in their constants files (e.g., $lib/constants/position.ts).
13
+ */
14
+
15
+ /**
16
+ * Role/Position badge color mappings
17
+ * Maps performer roles to Flowbite color variants
18
+ */
19
+ export const ROLE_BADGE_VARIANTS = {
20
+ Host: 'red',
21
+ Headliner: 'purple',
22
+ Feature: 'blue',
23
+ 'Special Guest': 'green',
24
+ Opener: 'orange',
25
+ Guest: 'gray',
26
+ Teacher: 'yellow',
27
+ Assistant: 'indigo',
28
+ };
29
+
30
+ /**
31
+ * Entity type badge color mappings
32
+ * Maps entity types to Flowbite color variants
33
+ */
34
+ export const ENTITY_BADGE_VARIANTS = {
35
+ event: 'blue',
36
+ venue: 'green',
37
+ user: 'purple',
38
+ order: 'orange',
39
+ performer: 'pink',
40
+ };
41
+
42
+ /**
43
+ * Status badge semantic mappings
44
+ * Maps status strings to semantic variants
45
+ */
46
+ export const STATUS_BADGE_VARIANTS = {
47
+ // Success states
48
+ Completed: 'success',
49
+ Active: 'success',
50
+ Confirmed: 'success',
51
+ 'On Sale': 'success',
52
+ Live: 'success',
53
+ Enabled: 'success',
54
+ Yes: 'success',
55
+ Redeemed: 'success',
56
+ Online: 'success',
57
+
58
+ // Warning states
59
+ Pending: 'warning',
60
+ Scheduled: 'warning',
61
+ Paused: 'warning',
62
+ Ended: 'warning',
63
+ Refunded: 'warning',
64
+ 'Partially refunded': 'warning',
65
+ Pinned: 'warning',
66
+ 'Usage Limit Reached': 'warning',
67
+
68
+ // Error states
69
+ Cancelled: 'error',
70
+ Canceled: 'error',
71
+ Declined: 'error',
72
+ 'No show': 'error',
73
+ Expired: 'error',
74
+ 'Sales closed': 'error',
75
+
76
+ // Info states
77
+ 'In Progress': 'info',
78
+ Invited: 'info',
79
+
80
+ // Neutral states
81
+ Draft: 'neutral',
82
+ Offline: 'neutral',
83
+ Disabled: 'neutral',
84
+ No: 'neutral',
85
+ };
86
+
87
+ /**
88
+ * Get badge variant for a role
89
+ * @param {string} role - The role name
90
+ * @returns {string} Flowbite color variant
91
+ */
92
+ export function getRoleBadgeVariant(role) {
93
+ return ROLE_BADGE_VARIANTS[role] || 'gray';
94
+ }
95
+
96
+ /**
97
+ * Get badge variant for an entity type
98
+ * @param {string} entityType - The entity type
99
+ * @returns {string} Flowbite color variant
100
+ */
101
+ export function getEntityBadgeVariant(entityType) {
102
+ return ENTITY_BADGE_VARIANTS[entityType] || 'gray';
103
+ }
104
+
105
+ /**
106
+ * Get badge variant for a status
107
+ * @param {string} status - The status string
108
+ * @returns {string} Semantic variant
109
+ */
110
+ export function getStatusBadgeVariant(status) {
111
+ return STATUS_BADGE_VARIANTS[status] || 'neutral';
112
+ }
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=badges.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"badges.spec.d.ts","sourceRoot":"","sources":["../../src/lib/presets/badges.spec.js"],"names":[],"mappings":""}
@@ -0,0 +1,172 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import {
3
+ ROLE_BADGE_VARIANTS,
4
+ ENTITY_BADGE_VARIANTS,
5
+ STATUS_BADGE_VARIANTS,
6
+ getRoleBadgeVariant,
7
+ getEntityBadgeVariant,
8
+ getStatusBadgeVariant,
9
+ } from './badges.js';
10
+
11
+ describe('Role Badge Variants', () => {
12
+ it('maps Host to red', () => {
13
+ expect(ROLE_BADGE_VARIANTS.Host).toBe('red');
14
+ });
15
+
16
+ it('maps Headliner to purple', () => {
17
+ expect(ROLE_BADGE_VARIANTS.Headliner).toBe('purple');
18
+ });
19
+
20
+ it('maps Feature to blue', () => {
21
+ expect(ROLE_BADGE_VARIANTS.Feature).toBe('blue');
22
+ });
23
+
24
+ it('maps Special Guest to green', () => {
25
+ expect(ROLE_BADGE_VARIANTS['Special Guest']).toBe('green');
26
+ });
27
+
28
+ it('maps Opener to orange', () => {
29
+ expect(ROLE_BADGE_VARIANTS.Opener).toBe('orange');
30
+ });
31
+
32
+ it('maps Guest to gray', () => {
33
+ expect(ROLE_BADGE_VARIANTS.Guest).toBe('gray');
34
+ });
35
+
36
+ it('maps Teacher to yellow', () => {
37
+ expect(ROLE_BADGE_VARIANTS.Teacher).toBe('yellow');
38
+ });
39
+
40
+ it('maps Assistant to indigo', () => {
41
+ expect(ROLE_BADGE_VARIANTS.Assistant).toBe('indigo');
42
+ });
43
+ });
44
+
45
+ describe('Entity Badge Variants', () => {
46
+ it('maps event to blue', () => {
47
+ expect(ENTITY_BADGE_VARIANTS.event).toBe('blue');
48
+ });
49
+
50
+ it('maps venue to green', () => {
51
+ expect(ENTITY_BADGE_VARIANTS.venue).toBe('green');
52
+ });
53
+
54
+ it('maps user to purple', () => {
55
+ expect(ENTITY_BADGE_VARIANTS.user).toBe('purple');
56
+ });
57
+
58
+ it('maps order to orange', () => {
59
+ expect(ENTITY_BADGE_VARIANTS.order).toBe('orange');
60
+ });
61
+
62
+ it('maps performer to pink', () => {
63
+ expect(ENTITY_BADGE_VARIANTS.performer).toBe('pink');
64
+ });
65
+ });
66
+
67
+ describe('Status Badge Variants', () => {
68
+ describe('Success States', () => {
69
+ const successStatuses = [
70
+ 'Completed', 'Active', 'Confirmed', 'On Sale',
71
+ 'Live', 'Enabled', 'Yes', 'Redeemed', 'Online'
72
+ ];
73
+
74
+ successStatuses.forEach(status => {
75
+ it(`maps ${status} to success`, () => {
76
+ expect(STATUS_BADGE_VARIANTS[status]).toBe('success');
77
+ });
78
+ });
79
+ });
80
+
81
+ describe('Warning States', () => {
82
+ const warningStatuses = [
83
+ 'Pending', 'Scheduled', 'Paused', 'Ended',
84
+ 'Refunded', 'Partially refunded', 'Pinned', 'Usage Limit Reached'
85
+ ];
86
+
87
+ warningStatuses.forEach(status => {
88
+ it(`maps ${status} to warning`, () => {
89
+ expect(STATUS_BADGE_VARIANTS[status]).toBe('warning');
90
+ });
91
+ });
92
+ });
93
+
94
+ describe('Error States', () => {
95
+ const errorStatuses = [
96
+ 'Cancelled', 'Canceled', 'Declined', 'No show',
97
+ 'Expired', 'Sales closed'
98
+ ];
99
+
100
+ errorStatuses.forEach(status => {
101
+ it(`maps ${status} to error`, () => {
102
+ expect(STATUS_BADGE_VARIANTS[status]).toBe('error');
103
+ });
104
+ });
105
+ });
106
+
107
+ describe('Info States', () => {
108
+ it('maps In Progress to info', () => {
109
+ expect(STATUS_BADGE_VARIANTS['In Progress']).toBe('info');
110
+ });
111
+
112
+ it('maps Invited to info', () => {
113
+ expect(STATUS_BADGE_VARIANTS.Invited).toBe('info');
114
+ });
115
+ });
116
+
117
+ describe('Neutral States', () => {
118
+ const neutralStatuses = ['Draft', 'Offline', 'Disabled', 'No'];
119
+
120
+ neutralStatuses.forEach(status => {
121
+ it(`maps ${status} to neutral`, () => {
122
+ expect(STATUS_BADGE_VARIANTS[status]).toBe('neutral');
123
+ });
124
+ });
125
+ });
126
+ });
127
+
128
+ describe('getRoleBadgeVariant', () => {
129
+ it('returns correct variant for known role', () => {
130
+ expect(getRoleBadgeVariant('Host')).toBe('red');
131
+ expect(getRoleBadgeVariant('Headliner')).toBe('purple');
132
+ });
133
+
134
+ it('returns gray for unknown role', () => {
135
+ expect(getRoleBadgeVariant('Unknown')).toBe('gray');
136
+ });
137
+
138
+ it('returns gray for undefined role', () => {
139
+ expect(getRoleBadgeVariant(undefined)).toBe('gray');
140
+ });
141
+ });
142
+
143
+ describe('getEntityBadgeVariant', () => {
144
+ it('returns correct variant for known entity', () => {
145
+ expect(getEntityBadgeVariant('event')).toBe('blue');
146
+ expect(getEntityBadgeVariant('venue')).toBe('green');
147
+ });
148
+
149
+ it('returns gray for unknown entity', () => {
150
+ expect(getEntityBadgeVariant('unknown')).toBe('gray');
151
+ });
152
+
153
+ it('returns gray for undefined entity', () => {
154
+ expect(getEntityBadgeVariant(undefined)).toBe('gray');
155
+ });
156
+ });
157
+
158
+ describe('getStatusBadgeVariant', () => {
159
+ it('returns correct variant for known status', () => {
160
+ expect(getStatusBadgeVariant('Completed')).toBe('success');
161
+ expect(getStatusBadgeVariant('Pending')).toBe('warning');
162
+ expect(getStatusBadgeVariant('Cancelled')).toBe('error');
163
+ });
164
+
165
+ it('returns neutral for unknown status', () => {
166
+ expect(getStatusBadgeVariant('Unknown')).toBe('neutral');
167
+ });
168
+
169
+ it('returns neutral for undefined status', () => {
170
+ expect(getStatusBadgeVariant(undefined)).toBe('neutral');
171
+ });
172
+ });