@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
@@ -1,127 +1,136 @@
1
- import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
2
- import { render, fireEvent } from '@testing-library/svelte';
3
- import BottomSheet from './BottomSheet.svelte';
4
-
5
- describe('BottomSheet Component', () => {
6
- beforeEach(() => {
7
- // Reset body overflow
8
- document.body.style.overflow = '';
9
- });
10
-
11
- afterEach(() => {
12
- document.body.style.overflow = '';
13
- });
14
-
15
- it('does not render when show is false', () => {
16
- const { container } = render(BottomSheet, { props: { show: false } });
17
- const backdrop = container.querySelector('.bottom-sheet-backdrop');
18
- expect(backdrop).toBeFalsy();
19
- });
20
-
21
- it('renders when show is true', () => {
22
- const { container } = render(BottomSheet, { props: { show: true } });
23
- const backdrop = container.querySelector('.bottom-sheet-backdrop');
24
- expect(backdrop).toBeTruthy();
25
- });
26
-
27
- it('renders title when provided', () => {
28
- const { getByText } = render(BottomSheet, {
29
- props: { show: true, title: 'Test Title' },
30
- });
31
- expect(getByText('Test Title')).toBeTruthy();
32
- });
33
-
34
- it('does not render title when not provided', () => {
35
- const { container } = render(BottomSheet, { props: { show: true } });
36
- const header = container.querySelector('.bottom-sheet__header');
37
- expect(header).toBeFalsy();
38
- });
39
-
40
- it('locks body scroll when shown', async () => {
41
- render(BottomSheet, { props: { show: true } });
42
- // Wait for reactive update
43
- await new Promise((resolve) => setTimeout(resolve, 10));
44
- expect(document.body.style.overflow).toBe('hidden');
45
- });
46
-
47
- it('unlocks body scroll when hidden', async () => {
48
- const { component } = render(BottomSheet, { props: { show: true } });
49
- await new Promise((resolve) => setTimeout(resolve, 10));
50
-
51
- component.$set({ show: false });
52
- await new Promise((resolve) => setTimeout(resolve, 10));
53
-
54
- expect(document.body.style.overflow).toBe('');
55
- });
56
-
57
- it('dispatches close event on backdrop click', async () => {
58
- const { container, component } = render(BottomSheet, { props: { show: true } });
59
- const backdrop = container.querySelector('.bottom-sheet-backdrop');
60
-
61
- let closeCalled = false;
62
- component.$on('close', () => {
63
- closeCalled = true;
64
- });
65
-
66
- await fireEvent.click(backdrop);
67
- expect(closeCalled).toBe(true);
68
- });
69
-
70
- it('does not dispatch close when clicking sheet content', async () => {
71
- const { container, component } = render(BottomSheet, { props: { show: true } });
72
- const sheet = container.querySelector('.bottom-sheet');
73
-
74
- let closeCalled = false;
75
- component.$on('close', () => {
76
- closeCalled = true;
77
- });
78
-
79
- await fireEvent.click(sheet);
80
- expect(closeCalled).toBe(false);
81
- });
82
-
83
- it('dispatches close event on Escape key', async () => {
84
- const { component } = render(BottomSheet, { props: { show: true } });
85
-
86
- let closeCalled = false;
87
- component.$on('close', () => {
88
- closeCalled = true;
89
- });
90
-
91
- await fireEvent.keyDown(window, { key: 'Escape' });
92
- expect(closeCalled).toBe(true);
93
- });
94
-
95
- it('does not dispatch close on Escape when not shown', async () => {
96
- const { component } = render(BottomSheet, { props: { show: false } });
97
-
98
- let closeCalled = false;
99
- component.$on('close', () => {
100
- closeCalled = true;
101
- });
102
-
103
- await fireEvent.keyDown(window, { key: 'Escape' });
104
- expect(closeCalled).toBe(false);
105
- });
106
-
107
- it('has handle bar element', () => {
108
- const { container } = render(BottomSheet, { props: { show: true } });
109
- const handle = container.querySelector('.bottom-sheet__handle');
110
- expect(handle).toBeTruthy();
111
- });
112
-
113
- it('has content area for slot content', () => {
114
- const { container } = render(BottomSheet, { props: { show: true } });
115
- const content = container.querySelector('.bottom-sheet__content');
116
- expect(content).toBeTruthy();
117
- });
118
-
119
- it('cleans up body overflow on destroy', () => {
120
- const { component } = render(BottomSheet, { props: { show: true } });
121
- document.body.style.overflow = 'hidden';
122
-
123
- component.$destroy();
124
-
125
- expect(document.body.style.overflow).toBe('');
126
- });
127
- });
1
+ import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
2
+ import { render, fireEvent, cleanup } from '@testing-library/svelte';
3
+ import BottomSheet from './BottomSheet.svelte';
4
+ import BottomSheetWrapper from './BottomSheetWrapper.test.svelte';
5
+
6
+ describe('BottomSheet Component', () => {
7
+ beforeEach(() => {
8
+ // Reset body overflow
9
+ document.body.style.overflow = '';
10
+ });
11
+
12
+ afterEach(() => {
13
+ document.body.style.overflow = '';
14
+ cleanup();
15
+ });
16
+
17
+ it('does not render when show is false', () => {
18
+ const { container } = render(BottomSheet, { props: { show: false } });
19
+ const backdrop = container.querySelector('.fixed.inset-0');
20
+ expect(backdrop).toBeFalsy();
21
+ });
22
+
23
+ it('renders when show is true', () => {
24
+ const { container } = render(BottomSheet, { props: { show: true } });
25
+ const backdrop = container.querySelector('.fixed.inset-0');
26
+ expect(backdrop).toBeTruthy();
27
+ });
28
+
29
+ it('renders title when provided', () => {
30
+ const { getByText } = render(BottomSheet, {
31
+ props: { show: true, title: 'Test Title' },
32
+ });
33
+ expect(getByText('Test Title')).toBeTruthy();
34
+ });
35
+
36
+ it('does not render title when not provided', () => {
37
+ const { container } = render(BottomSheet, { props: { show: true } });
38
+ const title = container.querySelector('h3');
39
+ expect(title).toBeFalsy();
40
+ });
41
+
42
+ it('locks body scroll when shown', async () => {
43
+ render(BottomSheet, { props: { show: true } });
44
+ // Wait for reactive update
45
+ await new Promise((resolve) => setTimeout(resolve, 10));
46
+ expect(document.body.style.overflow).toBe('hidden');
47
+ });
48
+
49
+ it('unlocks body scroll when hidden', async () => {
50
+ const { rerender } = render(BottomSheetWrapper, { props: { show: true } });
51
+ await new Promise((resolve) => setTimeout(resolve, 10));
52
+ expect(document.body.style.overflow).toBe('hidden');
53
+
54
+ await rerender({ show: false });
55
+ await new Promise((resolve) => setTimeout(resolve, 10));
56
+
57
+ expect(document.body.style.overflow).toBe('');
58
+ });
59
+
60
+ it('dispatches close event on backdrop click', async () => {
61
+ let closeCalled = false;
62
+ const onclose = () => {
63
+ closeCalled = true;
64
+ };
65
+
66
+ const { container } = render(BottomSheet, {
67
+ props: { show: true, onclose }
68
+ });
69
+ const backdrop = container.querySelector('.fixed.inset-0');
70
+
71
+ await fireEvent.click(backdrop);
72
+ expect(closeCalled).toBe(true);
73
+ });
74
+
75
+ it('does not dispatch close when clicking sheet content', async () => {
76
+ let closeCalled = false;
77
+ const onclose = () => {
78
+ closeCalled = true;
79
+ };
80
+
81
+ const { container } = render(BottomSheet, {
82
+ props: { show: true, onclose }
83
+ });
84
+ const sheet = container.querySelector('.bg-white, .dark\\:bg-gray-800');
85
+
86
+ await fireEvent.click(sheet);
87
+ expect(closeCalled).toBe(false);
88
+ });
89
+
90
+ it('dispatches close event on Escape key', async () => {
91
+ let closeCalled = false;
92
+ const onclose = () => {
93
+ closeCalled = true;
94
+ };
95
+
96
+ render(BottomSheet, { props: { show: true, onclose } });
97
+
98
+ await fireEvent.keyDown(window, { key: 'Escape' });
99
+ expect(closeCalled).toBe(true);
100
+ });
101
+
102
+ it('does not dispatch close on Escape when not shown', async () => {
103
+ let closeCalled = false;
104
+ const onclose = () => {
105
+ closeCalled = true;
106
+ };
107
+
108
+ render(BottomSheet, { props: { show: false, onclose } });
109
+
110
+ await fireEvent.keyDown(window, { key: 'Escape' });
111
+ expect(closeCalled).toBe(false);
112
+ });
113
+
114
+ it('has handle bar element', () => {
115
+ const { container } = render(BottomSheet, { props: { show: true } });
116
+ // The handle is the gray bar with rounded corners
117
+ const handle = container.querySelector('.w-10.h-1.bg-gray-300');
118
+ expect(handle).toBeTruthy();
119
+ });
120
+
121
+ it('has content area for slot content', () => {
122
+ const { container } = render(BottomSheet, { props: { show: true } });
123
+ // The content area has overflow-y-auto class
124
+ const content = container.querySelector('.overflow-y-auto');
125
+ expect(content).toBeTruthy();
126
+ });
127
+
128
+ it('cleans up body overflow on destroy', () => {
129
+ document.body.style.overflow = 'hidden';
130
+ const { unmount } = render(BottomSheet, { props: { show: true } });
131
+
132
+ unmount();
133
+
134
+ expect(document.body.style.overflow).toBe('');
135
+ });
136
+ });
@@ -1,83 +1,83 @@
1
- <script module>
2
- import { defineMeta } from "@storybook/addon-svelte-csf";
3
-
4
- import BottomSheet from './BottomSheet.svelte';
5
-
6
- const { Story } = defineMeta({
7
- title: 'Components/BottomSheet',
8
- component: BottomSheet,
9
- tags: ['autodocs'],
10
- argTypes: {
11
- show: {
12
- control: 'boolean',
13
- description: 'Controls visibility of the bottom sheet',
14
- },
15
- title: {
16
- control: 'text',
17
- description: 'Optional title displayed at the top',
18
- },
19
- },
20
- });
21
- </script>
22
-
23
- <script>
24
- import Button from '../Button/Button.svelte';
25
-
26
- let showBasic = $state(false);
27
- let showWithActions = $state(false);
28
- let showWithTitle = $state(false);
29
- </script>
30
-
31
-
32
- <Story
33
- name="Default"
34
- args={{
35
- title: '',
36
- }}
37
- />
38
-
39
- <Story name="With Title">
40
- <Button onclick={() => (showWithTitle = true)}>Open With Title</Button>
41
- <BottomSheet
42
- show={showWithTitle}
43
- title="Bottom Sheet Title"
44
- onclose={() => (showWithTitle = false)}
45
- >
46
- <p>This bottom sheet has a title at the top.</p>
47
- <p>The title helps provide context for the sheet's purpose.</p>
48
- </BottomSheet>
49
- </Story>
50
-
51
- <Story name="With Actions">
52
- <Button onclick={() => (showWithActions = true)}>Open With Actions</Button>
53
- <BottomSheet
54
- show={showWithActions}
55
- title="Confirm Action"
56
- onclose={() => (showWithActions = false)}
57
- >
58
- <p>Are you sure you want to proceed with this action?</p>
59
- {#snippet actions()}
60
- <Button variant="alternative" onclick={() => (showWithActions = false)}>
61
- Cancel
62
- </Button>
63
- <Button variant="default" onclick={() => (showWithActions = false)}>
64
- Confirm
65
- </Button>
66
- {/snippet}
67
- </BottomSheet>
68
- </Story>
69
-
70
- <Story name="Long Content">
71
- <Button onclick={() => showBasic = true}>Open With Long Content</Button>
72
- <BottomSheet
73
- show={showBasic}
74
- title="Privacy Policy"
75
- onclose={() => (showBasic = false)}
76
- >
77
- <div>
78
- {#each Array(20) as _, i}
79
- <p>This is paragraph {i + 1} of the long content. The sheet is scrollable when content exceeds the viewport.</p>
80
- {/each}
81
- </div>
82
- </BottomSheet>
83
- </Story>
1
+ <script module>
2
+ import { defineMeta } from "@storybook/addon-svelte-csf";
3
+
4
+ import BottomSheet from './BottomSheet.svelte';
5
+
6
+ const { Story } = defineMeta({
7
+ title: 'Components/BottomSheet',
8
+ component: BottomSheet,
9
+ tags: ['autodocs'],
10
+ argTypes: {
11
+ show: {
12
+ control: 'boolean',
13
+ description: 'Controls visibility of the bottom sheet',
14
+ },
15
+ title: {
16
+ control: 'text',
17
+ description: 'Optional title displayed at the top',
18
+ },
19
+ },
20
+ });
21
+ </script>
22
+
23
+ <script>
24
+ import Button from '../Button/Button.svelte';
25
+
26
+ let showBasic = $state(false);
27
+ let showWithActions = $state(false);
28
+ let showWithTitle = $state(false);
29
+ </script>
30
+
31
+
32
+ <Story
33
+ name="Default"
34
+ args={{
35
+ title: '',
36
+ }}
37
+ />
38
+
39
+ <Story name="With Title">
40
+ <Button onclick={() => (showWithTitle = true)}>Open With Title</Button>
41
+ <BottomSheet
42
+ show={showWithTitle}
43
+ title="Bottom Sheet Title"
44
+ onclose={() => (showWithTitle = false)}
45
+ >
46
+ <p>This bottom sheet has a title at the top.</p>
47
+ <p>The title helps provide context for the sheet's purpose.</p>
48
+ </BottomSheet>
49
+ </Story>
50
+
51
+ <Story name="With Actions">
52
+ <Button onclick={() => (showWithActions = true)}>Open With Actions</Button>
53
+ <BottomSheet
54
+ show={showWithActions}
55
+ title="Confirm Action"
56
+ onclose={() => (showWithActions = false)}
57
+ >
58
+ <p>Are you sure you want to proceed with this action?</p>
59
+ {#snippet actions()}
60
+ <Button variant="alternative" onclick={() => (showWithActions = false)}>
61
+ Cancel
62
+ </Button>
63
+ <Button variant="default" onclick={() => (showWithActions = false)}>
64
+ Confirm
65
+ </Button>
66
+ {/snippet}
67
+ </BottomSheet>
68
+ </Story>
69
+
70
+ <Story name="Long Content">
71
+ <Button onclick={() => showBasic = true}>Open With Long Content</Button>
72
+ <BottomSheet
73
+ show={showBasic}
74
+ title="Privacy Policy"
75
+ onclose={() => (showBasic = false)}
76
+ >
77
+ <div>
78
+ {#each Array(20) as _, i}
79
+ <p>This is paragraph {i + 1} of the long content. The sheet is scrollable when content exceeds the viewport.</p>
80
+ {/each}
81
+ </div>
82
+ </BottomSheet>
83
+ </Story>
@@ -1,100 +1,100 @@
1
- <script lang="ts">
2
- import { onDestroy } from "svelte";
3
- import { fly, fade } from "svelte/transition";
4
- import { cubicOut } from "svelte/easing";
5
- import type { Snippet } from 'svelte';
6
- import { typography } from "../../tokens/typography";
7
-
8
- interface Props {
9
- /** Whether the bottom sheet is visible */
10
- show?: boolean;
11
- /** Title displayed in the header */
12
- title?: string;
13
- /** Callback when the sheet should close */
14
- onclose?: () => void;
15
- /** Main content */
16
- children?: Snippet;
17
- /** Actions slot (footer buttons) */
18
- actions?: Snippet;
19
- }
20
-
21
- let {
22
- show = false,
23
- title = '',
24
- onclose,
25
- children,
26
- actions
27
- }: Props = $props();
28
-
29
- function close() {
30
- onclose?.();
31
- }
32
-
33
- function handleBackdropClick(e: MouseEvent) {
34
- if (e.target === e.currentTarget) {
35
- close();
36
- }
37
- }
38
-
39
- function handleKeydown(e: KeyboardEvent) {
40
- if (e.key === "Escape" && show) {
41
- close();
42
- }
43
- }
44
-
45
- $effect(() => {
46
- if (typeof document !== "undefined") {
47
- if (show) {
48
- document.body.style.overflow = "hidden";
49
- } else {
50
- document.body.style.overflow = "";
51
- }
52
- }
53
- });
54
-
55
- onDestroy(() => {
56
- if (typeof document !== "undefined") {
57
- document.body.style.overflow = "";
58
- }
59
- });
60
- </script>
61
-
62
- <svelte:window onkeydown={handleKeydown} />
63
-
64
- {#if show}
65
- <!-- svelte-ignore a11y_click_events_have_key_events -->
66
- <!-- svelte-ignore a11y_no_static_element_interactions -->
67
- <div
68
- class="fixed inset-0 z-50 flex items-end md:items-center md:justify-center bg-gray-900/50 dark:bg-gray-900/80"
69
- onclick={handleBackdropClick}
70
- transition:fade={{ duration: 200 }}
71
- >
72
- <!-- svelte-ignore a11y_click_events_have_key_events -->
73
- <!-- svelte-ignore a11y_no_static_element_interactions -->
74
- <div
75
- class="w-full max-h-[90dvh] md:max-w-lg md:max-h-[80vh] md:m-4 bg-white dark:bg-gray-800 rounded-t-xl md:rounded-lg shadow-xl flex flex-col overflow-hidden"
76
- onclick={(e) => e.stopPropagation()}
77
- transition:fly={{ y: 300, duration: 300, easing: cubicOut }}
78
- >
79
- <div class="flex justify-center pt-3 pb-2 shrink-0 md:hidden">
80
- <div class="w-10 h-1 bg-gray-300 dark:bg-gray-600 rounded-full"></div>
81
- </div>
82
-
83
- {#if title}
84
- <div class="px-6 pb-4 border-b border-gray-200 dark:border-gray-700 shrink-0">
85
- <h3 class={typography.h3}>{title}</h3>
86
- </div>
87
- {/if}
88
-
89
- <div class="flex-1 overflow-y-auto overscroll-contain p-4 px-6">
90
- {@render children?.()}
91
- </div>
92
-
93
- {#if actions}
94
- <div class="px-6 py-4 border-t border-gray-200 dark:border-gray-700 shrink-0 flex flex-col gap-3">
95
- {@render actions?.()}
96
- </div>
97
- {/if}
98
- </div>
99
- </div>
100
- {/if}
1
+ <script lang="ts">
2
+ import { onDestroy } from "svelte";
3
+ import { fly, fade } from "svelte/transition";
4
+ import { cubicOut } from "svelte/easing";
5
+ import type { Snippet } from 'svelte';
6
+ import { typography } from "../../tokens/typography";
7
+
8
+ interface Props {
9
+ /** Whether the bottom sheet is visible */
10
+ show?: boolean;
11
+ /** Title displayed in the header */
12
+ title?: string;
13
+ /** Callback when the sheet should close */
14
+ onclose?: () => void;
15
+ /** Main content */
16
+ children?: Snippet;
17
+ /** Actions slot (footer buttons) */
18
+ actions?: Snippet;
19
+ }
20
+
21
+ let {
22
+ show = false,
23
+ title = '',
24
+ onclose,
25
+ children,
26
+ actions
27
+ }: Props = $props();
28
+
29
+ function close() {
30
+ onclose?.();
31
+ }
32
+
33
+ function handleBackdropClick(e: MouseEvent) {
34
+ if (e.target === e.currentTarget) {
35
+ close();
36
+ }
37
+ }
38
+
39
+ function handleKeydown(e: KeyboardEvent) {
40
+ if (e.key === "Escape" && show) {
41
+ close();
42
+ }
43
+ }
44
+
45
+ $effect(() => {
46
+ if (typeof document !== "undefined") {
47
+ if (show) {
48
+ document.body.style.overflow = "hidden";
49
+ } else {
50
+ document.body.style.overflow = "";
51
+ }
52
+ }
53
+ });
54
+
55
+ onDestroy(() => {
56
+ if (typeof document !== "undefined") {
57
+ document.body.style.overflow = "";
58
+ }
59
+ });
60
+ </script>
61
+
62
+ <svelte:window onkeydown={handleKeydown} />
63
+
64
+ {#if show}
65
+ <!-- svelte-ignore a11y_click_events_have_key_events -->
66
+ <!-- svelte-ignore a11y_no_static_element_interactions -->
67
+ <div
68
+ class="fixed inset-0 z-50 flex items-end md:items-center md:justify-center bg-gray-900/50 dark:bg-gray-900/80"
69
+ onclick={handleBackdropClick}
70
+ transition:fade={{ duration: 200 }}
71
+ >
72
+ <!-- svelte-ignore a11y_click_events_have_key_events -->
73
+ <!-- svelte-ignore a11y_no_static_element_interactions -->
74
+ <div
75
+ class="w-full max-h-[90dvh] md:max-w-lg md:max-h-[80vh] md:m-4 bg-white dark:bg-gray-800 rounded-t-xl md:rounded-lg shadow-xl flex flex-col overflow-hidden"
76
+ onclick={(e) => e.stopPropagation()}
77
+ transition:fly={{ y: 300, duration: 300, easing: cubicOut }}
78
+ >
79
+ <div class="flex justify-center pt-3 pb-2 shrink-0 md:hidden">
80
+ <div class="w-10 h-1 bg-gray-300 dark:bg-gray-600 rounded-full"></div>
81
+ </div>
82
+
83
+ {#if title}
84
+ <div class="px-6 pb-4 border-b border-gray-200 dark:border-gray-700 shrink-0">
85
+ <h3 class={typography.h3}>{title}</h3>
86
+ </div>
87
+ {/if}
88
+
89
+ <div class="flex-1 overflow-y-auto overscroll-contain p-4 px-6">
90
+ {@render children?.()}
91
+ </div>
92
+
93
+ {#if actions}
94
+ <div class="px-6 py-4 border-t border-gray-200 dark:border-gray-700 shrink-0 flex flex-col gap-3">
95
+ {@render actions?.()}
96
+ </div>
97
+ {/if}
98
+ </div>
99
+ </div>
100
+ {/if}
@@ -0,0 +1,13 @@
1
+ <script lang="ts">
2
+ import BottomSheet from './BottomSheet.svelte';
3
+
4
+ interface Props {
5
+ show?: boolean;
6
+ }
7
+
8
+ let { show = false }: Props = $props();
9
+ </script>
10
+
11
+ <BottomSheet {show}>
12
+ <div>Test content</div>
13
+ </BottomSheet>
@@ -0,0 +1,7 @@
1
+ interface Props {
2
+ show?: boolean;
3
+ }
4
+ declare const BottomSheetWrapper: import("svelte").Component<Props, {}, "">;
5
+ type BottomSheetWrapper = ReturnType<typeof BottomSheetWrapper>;
6
+ export default BottomSheetWrapper;
7
+ //# sourceMappingURL=BottomSheetWrapper.test.svelte.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BottomSheetWrapper.test.svelte.d.ts","sourceRoot":"","sources":["../../../src/lib/primitives/BottomSheet/BottomSheetWrapper.test.svelte.ts"],"names":[],"mappings":"AAME,UAAU,KAAK;IACb,IAAI,CAAC,EAAE,OAAO,CAAC;CAChB;AAcH,QAAA,MAAM,kBAAkB,2CAAwC,CAAC;AACjE,KAAK,kBAAkB,GAAG,UAAU,CAAC,OAAO,kBAAkB,CAAC,CAAC;AAChE,eAAe,kBAAkB,CAAC"}