@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,129 +1,129 @@
1
- <script lang="ts">
2
- import type { Snippet } from 'svelte';
3
- import { setContext } from "svelte";
4
- import { writable } from "svelte/store";
5
- import { typography } from "../../tokens/typography";
6
-
7
- interface Props {
8
- tabStyle?: 'underline' | 'pills' | 'full';
9
- contentClass?: string;
10
- activeTabValue?: string | number | undefined;
11
- class?: string;
12
- children?: Snippet;
13
- [key: string]: unknown;
14
- }
15
-
16
- let {
17
- tabStyle = "underline",
18
- contentClass = "",
19
- activeTabValue = $bindable(undefined),
20
- class: className = "",
21
- children,
22
- ...restProps
23
- }: Props = $props();
24
-
25
- // Create a store for the active tab
26
- const activeTab = writable<string | number | undefined>(activeTabValue);
27
- const tabItems = writable<Array<{ id: string | number; title: string }>>([]);
28
-
29
- // Keep activeTabValue in sync with store
30
- $effect(() => {
31
- if (activeTabValue !== undefined) {
32
- activeTab.set(activeTabValue);
33
- }
34
- });
35
-
36
- $effect(() => {
37
- const unsubscribe = activeTab.subscribe(value => {
38
- activeTabValue = value;
39
- });
40
- return unsubscribe;
41
- });
42
-
1
+ <script lang="ts">
2
+ import type { Snippet } from 'svelte';
3
+ import { setContext } from "svelte";
4
+ import { writable } from "svelte/store";
5
+ import { typography } from "../../tokens/typography";
6
+
7
+ interface Props {
8
+ tabStyle?: 'underline' | 'pills' | 'full';
9
+ contentClass?: string;
10
+ activeTabValue?: string | number | undefined;
11
+ class?: string;
12
+ children?: Snippet;
13
+ [key: string]: unknown;
14
+ }
15
+
16
+ let {
17
+ tabStyle = "underline",
18
+ contentClass = "",
19
+ activeTabValue = $bindable(undefined),
20
+ class: className = "",
21
+ children,
22
+ ...restProps
23
+ }: Props = $props();
24
+
25
+ // Create a store for the active tab
26
+ const activeTab = writable<string | number | undefined>(activeTabValue);
27
+ const tabItems = writable<Array<{ id: string | number; title: string }>>([]);
28
+
29
+ // Keep activeTabValue in sync with store
30
+ $effect(() => {
31
+ if (activeTabValue !== undefined) {
32
+ activeTab.set(activeTabValue);
33
+ }
34
+ });
35
+
36
+ $effect(() => {
37
+ const unsubscribe = activeTab.subscribe(value => {
38
+ activeTabValue = value;
39
+ });
40
+ return unsubscribe;
41
+ });
42
+
43
43
  // Provide context to TabItem children
44
44
  // Note: tabStyle is captured once at initialization - style changes require remount
45
45
  setContext("tabs", {
46
46
  activeTab,
47
47
  tabItems,
48
48
  get tabStyle() { return tabStyle; },
49
- registerTab: (id: string | number, title: string, open: boolean) => {
50
- tabItems.update(items => {
51
- // Avoid duplicates
52
- if (items.find(item => item.id === id)) return items;
53
- return [...items, { id, title }];
54
- });
55
- // If this tab has open prop and no active tab set, make it active
56
- let currentActive: string | number | undefined;
57
- activeTab.subscribe(v => currentActive = v)();
58
- if (open && currentActive === undefined) {
59
- activeTab.set(id);
60
- }
61
- return id;
62
- },
63
- setActiveTab: (id: string | number) => {
64
- activeTab.set(id);
65
- }
66
- });
67
-
68
- // Ensure first tab is selected if none selected
69
- $effect(() => {
70
- const items = $tabItems;
71
- const active = $activeTab;
72
- if (items.length > 0 && active === undefined) {
73
- activeTab.set(items[0].id);
74
- }
75
- });
76
-
77
- // Tab list classes by style
78
- const tabListClasses = {
79
- underline: `flex flex-wrap -mb-px ${typography.sm} font-medium text-center border-b border-gray-200 dark:border-gray-700 overflow-x-auto scrollbar-none`,
80
- pills: `flex flex-wrap ${typography.smMuted} font-medium text-center gap-2`,
81
- full: `flex flex-wrap ${typography.smMuted} font-medium text-center divide-x divide-gray-200 dark:divide-gray-700 rounded-lg shadow overflow-hidden`
82
- };
83
-
84
- // Tab button classes by style
85
- function getTabClasses(isActive: boolean) {
86
- const base = "inline-flex items-center justify-center whitespace-nowrap transition-colors focus:outline-none";
87
-
88
- switch (tabStyle) {
89
- case 'underline':
90
- return isActive
91
- ? `${base} p-4 text-blue-600 border-b-2 border-blue-600 rounded-t-lg active dark:text-blue-500 dark:border-blue-500`
92
- : `${base} p-4 border-b-2 border-transparent rounded-t-lg hover:text-gray-600 hover:border-gray-300 dark:hover:text-gray-300`;
93
- case 'pills':
94
- return isActive
95
- ? `${base} px-4 py-3 text-white bg-blue-600 rounded-lg active`
96
- : `${base} px-4 py-3 rounded-lg hover:text-gray-900 hover:bg-gray-100 dark:hover:bg-gray-800 dark:hover:text-white`;
97
- case 'full':
98
- return isActive
99
- ? `${base} w-full p-4 text-gray-900 bg-gray-100 dark:bg-gray-700 dark:text-white`
100
- : `${base} w-full p-4 bg-white hover:text-gray-700 hover:bg-gray-50 dark:bg-gray-800 dark:hover:text-white dark:hover:bg-gray-700`;
101
- default:
102
- return base;
103
- }
104
- }
105
-
106
- let tabListClass = $derived(tabListClasses[tabStyle] || tabListClasses.underline);
107
- </script>
108
-
109
- <div class="flex flex-col {className}" {...restProps}>
110
- <ul class="{tabListClass}" role="tablist">
111
- {#each $tabItems as tab (tab.id)}
112
- <li class={tabStyle === 'underline' ? 'me-2' : ''} role="presentation">
113
- <button
114
- type="button"
115
- role="tab"
116
- class={getTabClasses($activeTab === tab.id)}
117
- aria-selected={$activeTab === tab.id}
118
- tabindex={$activeTab === tab.id ? 0 : -1}
119
- onclick={() => activeTab.set(tab.id)}
120
- >
121
- {tab.title}
122
- </button>
123
- </li>
124
- {/each}
125
- </ul>
126
- <div class="pt-4 {contentClass}">
127
- {#if children}{@render children()}{/if}
128
- </div>
129
- </div>
49
+ registerTab: (id: string | number, title: string, open: boolean) => {
50
+ tabItems.update(items => {
51
+ // Avoid duplicates
52
+ if (items.find(item => item.id === id)) return items;
53
+ return [...items, { id, title }];
54
+ });
55
+ // If this tab has open prop and no active tab set, make it active
56
+ let currentActive: string | number | undefined;
57
+ activeTab.subscribe(v => currentActive = v)();
58
+ if (open && currentActive === undefined) {
59
+ activeTab.set(id);
60
+ }
61
+ return id;
62
+ },
63
+ setActiveTab: (id: string | number) => {
64
+ activeTab.set(id);
65
+ }
66
+ });
67
+
68
+ // Ensure first tab is selected if none selected
69
+ $effect(() => {
70
+ const items = $tabItems;
71
+ const active = $activeTab;
72
+ if (items.length > 0 && active === undefined) {
73
+ activeTab.set(items[0].id);
74
+ }
75
+ });
76
+
77
+ // Tab list classes by style
78
+ const tabListClasses = {
79
+ underline: `flex flex-wrap -mb-px ${typography.sm} font-medium text-center border-b border-gray-200 dark:border-gray-700 overflow-x-auto scrollbar-none`,
80
+ pills: `flex flex-wrap ${typography.smMuted} font-medium text-center gap-2`,
81
+ full: `flex flex-wrap ${typography.smMuted} font-medium text-center divide-x divide-gray-200 dark:divide-gray-700 rounded-lg shadow overflow-hidden`
82
+ };
83
+
84
+ // Tab button classes by style
85
+ function getTabClasses(isActive: boolean) {
86
+ const base = "inline-flex items-center justify-center whitespace-nowrap transition-colors focus:outline-none";
87
+
88
+ switch (tabStyle) {
89
+ case 'underline':
90
+ return isActive
91
+ ? `${base} p-4 text-blue-600 border-b-2 border-blue-600 rounded-t-lg active dark:text-blue-500 dark:border-blue-500`
92
+ : `${base} p-4 border-b-2 border-transparent rounded-t-lg hover:text-gray-600 hover:border-gray-300 dark:hover:text-gray-300`;
93
+ case 'pills':
94
+ return isActive
95
+ ? `${base} px-4 py-3 text-white bg-blue-600 rounded-lg active`
96
+ : `${base} px-4 py-3 rounded-lg hover:text-gray-900 hover:bg-gray-100 dark:hover:bg-gray-800 dark:hover:text-white`;
97
+ case 'full':
98
+ return isActive
99
+ ? `${base} w-full p-4 text-gray-900 bg-gray-100 dark:bg-gray-700 dark:text-white`
100
+ : `${base} w-full p-4 bg-white hover:text-gray-700 hover:bg-gray-50 dark:bg-gray-800 dark:hover:text-white dark:hover:bg-gray-700`;
101
+ default:
102
+ return base;
103
+ }
104
+ }
105
+
106
+ let tabListClass = $derived(tabListClasses[tabStyle] || tabListClasses.underline);
107
+ </script>
108
+
109
+ <div class="flex flex-col {className}" {...restProps}>
110
+ <ul class="{tabListClass}" role="tablist">
111
+ {#each $tabItems as tab (tab.id)}
112
+ <li class={tabStyle === 'underline' ? 'me-2' : ''} role="presentation">
113
+ <button
114
+ type="button"
115
+ role="tab"
116
+ class={getTabClasses($activeTab === tab.id)}
117
+ aria-selected={$activeTab === tab.id}
118
+ tabindex={$activeTab === tab.id ? 0 : -1}
119
+ onclick={() => activeTab.set(tab.id)}
120
+ >
121
+ {tab.title}
122
+ </button>
123
+ </li>
124
+ {/each}
125
+ </ul>
126
+ <div class="pt-4 {contentClass}">
127
+ {#if children}{@render children()}{/if}
128
+ </div>
129
+ </div>
@@ -0,0 +1,18 @@
1
+ <script>
2
+ import Tabs from './Tabs.svelte';
3
+ import TabItem from './TabItem.svelte';
4
+
5
+ let { activeTabValue = $bindable(), tabStyle = 'underline', withOpen = false } = $props();
6
+ </script>
7
+
8
+ <Tabs bind:activeTabValue {tabStyle}>
9
+ <TabItem title="First Tab" value="tab1" open={withOpen}>
10
+ <div data-testid="tab1-content">First Tab Content</div>
11
+ </TabItem>
12
+ <TabItem title="Second Tab" value="tab2">
13
+ <div data-testid="tab2-content">Second Tab Content</div>
14
+ </TabItem>
15
+ <TabItem title="Third Tab" value="tab3">
16
+ <div data-testid="tab3-content">Third Tab Content</div>
17
+ </TabItem>
18
+ </Tabs>
@@ -0,0 +1,16 @@
1
+ export default TabsWithItems;
2
+ type TabsWithItems = {
3
+ $on?(type: string, callback: (e: any) => void): () => void;
4
+ $set?(props: Partial<$$ComponentProps>): void;
5
+ };
6
+ declare const TabsWithItems: import("svelte").Component<{
7
+ activeTabValue?: any;
8
+ tabStyle?: string;
9
+ withOpen?: boolean;
10
+ }, {}, "activeTabValue">;
11
+ type $$ComponentProps = {
12
+ activeTabValue?: any;
13
+ tabStyle?: string;
14
+ withOpen?: boolean;
15
+ };
16
+ //# sourceMappingURL=TabsWithItems.test.svelte.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TabsWithItems.test.svelte.d.ts","sourceRoot":"","sources":["../../../src/lib/primitives/Tabs/TabsWithItems.test.svelte.js"],"names":[],"mappings":";;;;;AA2BA;qBAjBsC,GAAG;eAAa,MAAM;eAAa,OAAO;yBAiBpB;wBAjBzC;IAAE,cAAc,CAAC,EAAE,GAAG,CAAC;IAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAAC,QAAQ,CAAC,EAAE,OAAO,CAAA;CAAE"}
@@ -1,127 +1,143 @@
1
- import { describe, it, expect, vi } from 'vitest';
2
- import { render, fireEvent } from '@testing-library/svelte';
3
- import Toggle from './Toggle.svelte';
4
-
5
- describe('Toggle Component', () => {
6
- it('renders a toggle button', () => {
7
- const { container } = render(Toggle);
8
- const button = container.querySelector('button');
9
- expect(button).toBeTruthy();
10
- expect(button.getAttribute('role')).toBe('switch');
11
- });
12
-
13
- it('has aria-checked false by default', () => {
14
- const { container } = render(Toggle);
15
- const button = container.querySelector('button');
16
- expect(button.getAttribute('aria-checked')).toBe('false');
17
- });
18
-
19
- it('has aria-checked true when checked', () => {
20
- const { container } = render(Toggle, { props: { checked: true } });
21
- const button = container.querySelector('button');
22
- expect(button.getAttribute('aria-checked')).toBe('true');
23
- });
24
-
25
- it('toggles checked state on click', async () => {
26
- const onchange = vi.fn();
27
- const { container } = render(Toggle, { props: { onchange } });
28
- const button = container.querySelector('button');
29
-
30
- await fireEvent.click(button);
31
-
32
- expect(onchange).toHaveBeenCalledWith({ checked: true });
33
- expect(button.getAttribute('aria-checked')).toBe('true');
34
- });
35
-
36
- it('toggles from checked to unchecked on click', async () => {
37
- const onchange = vi.fn();
38
- const { container } = render(Toggle, { props: { checked: true, onchange } });
39
- const button = container.querySelector('button');
40
-
41
- await fireEvent.click(button);
42
-
43
- expect(onchange).toHaveBeenCalledWith({ checked: false });
44
- expect(button.getAttribute('aria-checked')).toBe('false');
45
- });
46
-
47
- it('does not toggle when disabled', async () => {
48
- const onchange = vi.fn();
49
- const { container } = render(Toggle, { props: { disabled: true, onchange } });
50
- const button = container.querySelector('button');
51
-
52
- await fireEvent.click(button);
53
-
54
- expect(onchange).not.toHaveBeenCalled();
55
- expect(button.getAttribute('aria-checked')).toBe('false');
56
- });
57
-
58
- it('has toggle-checked class when checked', () => {
59
- const { container } = render(Toggle, { props: { checked: true } });
60
- const button = container.querySelector('button');
61
- expect(button.classList.contains('toggle-checked')).toBe(true);
62
- });
63
-
64
- it('does not have toggle-checked class when unchecked', () => {
65
- const { container } = render(Toggle, { props: { checked: false } });
66
- const button = container.querySelector('button');
67
- expect(button.classList.contains('toggle-checked')).toBe(false);
68
- });
69
-
70
- it('has toggle-disabled class when disabled', () => {
71
- const { container } = render(Toggle, { props: { disabled: true } });
72
- const button = container.querySelector('button');
73
- expect(button.classList.contains('toggle-disabled')).toBe(true);
74
- });
75
-
76
- it('has toggle-thumb element', () => {
77
- const { container } = render(Toggle);
78
- const thumb = container.querySelector('.toggle-thumb');
79
- expect(thumb).toBeTruthy();
80
- });
81
-
82
- it('toggles on Enter key press', async () => {
83
- const onchange = vi.fn();
84
- const { container } = render(Toggle, { props: { onchange } });
85
- const button = container.querySelector('button');
86
-
87
- await fireEvent.keyDown(button, { key: 'Enter' });
88
-
89
- expect(onchange).toHaveBeenCalledWith({ checked: true });
90
- });
91
-
92
- it('toggles on Space key press', async () => {
93
- const onchange = vi.fn();
94
- const { container } = render(Toggle, { props: { onchange } });
95
- const button = container.querySelector('button');
96
-
97
- await fireEvent.keyDown(button, { key: ' ' });
98
-
99
- expect(onchange).toHaveBeenCalledWith({ checked: true });
100
- });
101
-
102
- it('does not toggle on other key press', async () => {
103
- const onchange = vi.fn();
104
- const { container } = render(Toggle, { props: { onchange } });
105
- const button = container.querySelector('button');
106
-
107
- await fireEvent.keyDown(button, { key: 'Tab' });
108
-
109
- expect(onchange).not.toHaveBeenCalled();
110
- });
111
-
112
- it('does not toggle on keypress when disabled', async () => {
113
- const onchange = vi.fn();
114
- const { container } = render(Toggle, { props: { disabled: true, onchange } });
115
- const button = container.querySelector('button');
116
-
117
- await fireEvent.keyDown(button, { key: 'Enter' });
118
-
119
- expect(onchange).not.toHaveBeenCalled();
120
- });
121
-
122
- it('has type="button" attribute', () => {
123
- const { container } = render(Toggle);
124
- const button = container.querySelector('button');
125
- expect(button.getAttribute('type')).toBe('button');
126
- });
127
- });
1
+ import { describe, it, expect, vi } from 'vitest';
2
+ import { render, fireEvent } from '@testing-library/svelte';
3
+ import Toggle from './Toggle.svelte';
4
+
5
+ describe('Toggle Component', () => {
6
+ it('renders a toggle with label element', () => {
7
+ const { container } = render(Toggle);
8
+ const label = container.querySelector('label');
9
+ expect(label).toBeTruthy();
10
+ expect(label).toHaveClass('inline-flex');
11
+ expect(label).toHaveClass('items-center');
12
+ });
13
+
14
+ it('renders a hidden checkbox input', () => {
15
+ const { container } = render(Toggle);
16
+ const input = container.querySelector('input[type="checkbox"]');
17
+ expect(input).toBeTruthy();
18
+ expect(input).toHaveClass('sr-only');
19
+ expect(input).toHaveClass('peer');
20
+ });
21
+
22
+ it('renders switch element with role switch', () => {
23
+ const { container } = render(Toggle);
24
+ const switchEl = container.querySelector('[role="switch"]');
25
+ expect(switchEl).toBeTruthy();
26
+ });
27
+
28
+ it('has aria-checked false by default', () => {
29
+ const { container } = render(Toggle);
30
+ const switchEl = container.querySelector('[role="switch"]');
31
+ expect(switchEl.getAttribute('aria-checked')).toBe('false');
32
+ });
33
+
34
+ it('has aria-checked true when checked', () => {
35
+ const { container } = render(Toggle, { checked: true });
36
+ const switchEl = container.querySelector('[role="switch"]');
37
+ expect(switchEl.getAttribute('aria-checked')).toBe('true');
38
+ });
39
+
40
+ it('checkbox reflects checked state', () => {
41
+ const { container } = render(Toggle, { checked: true });
42
+ const input = container.querySelector('input[type="checkbox"]');
43
+ expect(input.checked).toBe(true);
44
+ });
45
+
46
+ it('checkbox reflects unchecked state', () => {
47
+ const { container } = render(Toggle, { checked: false });
48
+ const input = container.querySelector('input[type="checkbox"]');
49
+ expect(input.checked).toBe(false);
50
+ });
51
+
52
+ it('toggles checked state on change', async () => {
53
+ const onchange = vi.fn();
54
+ const { container } = render(Toggle, { onchange });
55
+ const input = container.querySelector('input[type="checkbox"]');
56
+
57
+ await fireEvent.click(input);
58
+
59
+ expect(onchange).toHaveBeenCalledWith({ checked: true });
60
+ });
61
+
62
+ it('toggles from checked to unchecked', async () => {
63
+ const onchange = vi.fn();
64
+ const { container } = render(Toggle, { checked: true, onchange });
65
+ const input = container.querySelector('input[type="checkbox"]');
66
+
67
+ await fireEvent.click(input);
68
+
69
+ expect(onchange).toHaveBeenCalledWith({ checked: false });
70
+ });
71
+
72
+ it('has disabled attribute when disabled', () => {
73
+ const { container } = render(Toggle, { disabled: true });
74
+ const input = container.querySelector('input[type="checkbox"]');
75
+ expect(input.disabled).toBe(true);
76
+ });
77
+
78
+ it('has disabled styling on label when disabled', () => {
79
+ const { container } = render(Toggle, { disabled: true });
80
+ const label = container.querySelector('label');
81
+ expect(label).toHaveClass('cursor-not-allowed');
82
+ expect(label).toHaveClass('opacity-50');
83
+ });
84
+
85
+ it('has pointer cursor when not disabled', () => {
86
+ const { container } = render(Toggle, { disabled: false });
87
+ const label = container.querySelector('label');
88
+ expect(label).toHaveClass('cursor-pointer');
89
+ });
90
+
91
+ it('has switch element with rounded-full class', () => {
92
+ const { container } = render(Toggle);
93
+ const switchEl = container.querySelector('[role="switch"]');
94
+ expect(switchEl).toHaveClass('rounded-full');
95
+ });
96
+
97
+ it('has default md size track dimensions', () => {
98
+ const { container } = render(Toggle, { size: 'md' });
99
+ const switchEl = container.querySelector('[role="switch"]');
100
+ expect(switchEl).toHaveClass('w-11');
101
+ expect(switchEl).toHaveClass('h-6');
102
+ });
103
+
104
+ it('has sm size track dimensions', () => {
105
+ const { container } = render(Toggle, { size: 'sm' });
106
+ const switchEl = container.querySelector('[role="switch"]');
107
+ expect(switchEl).toHaveClass('w-9');
108
+ expect(switchEl).toHaveClass('h-5');
109
+ });
110
+
111
+ it('has lg size track dimensions', () => {
112
+ const { container } = render(Toggle, { size: 'lg' });
113
+ const switchEl = container.querySelector('[role="switch"]');
114
+ expect(switchEl).toHaveClass('w-14');
115
+ expect(switchEl).toHaveClass('h-7');
116
+ });
117
+
118
+ it('has dark mode classes', () => {
119
+ const { container } = render(Toggle);
120
+ const switchEl = container.querySelector('[role="switch"]');
121
+ expect(switchEl).toHaveClass('dark:bg-gray-700');
122
+ expect(switchEl).toHaveClass('dark:peer-focus:ring-blue-800');
123
+ });
124
+
125
+ it('accepts custom class', () => {
126
+ const { container } = render(Toggle, { class: 'custom-class' });
127
+ const label = container.querySelector('label');
128
+ expect(label).toHaveClass('custom-class');
129
+ });
130
+
131
+ it('has peer focus ring classes', () => {
132
+ const { container } = render(Toggle);
133
+ const switchEl = container.querySelector('[role="switch"]');
134
+ expect(switchEl).toHaveClass('peer-focus:ring-4');
135
+ expect(switchEl).toHaveClass('peer-focus:ring-blue-300');
136
+ });
137
+
138
+ it('has blue background when checked', () => {
139
+ const { container } = render(Toggle);
140
+ const switchEl = container.querySelector('[role="switch"]');
141
+ expect(switchEl).toHaveClass('peer-checked:bg-blue-600');
142
+ });
143
+ });