@getmicdrop/svelte-components 5.5.5 → 5.6.1

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 (330) hide show
  1. package/dist/calendar/AboutShow/AboutShow.svelte +172 -172
  2. package/dist/calendar/Calendar/MiniMonthCalendar.svelte +782 -782
  3. package/dist/calendar/FAQs/FAQs.svelte +75 -75
  4. package/dist/calendar/MonthSwitcher/MonthSwitcher.svelte +126 -126
  5. package/dist/calendar/OrderSummary/OrderSummary.svelte +367 -367
  6. package/dist/calendar/PublicCard/PublicCard.svelte +134 -134
  7. package/dist/calendar/ShowCard/ShowCard.svelte +157 -157
  8. package/dist/calendar/ShowTimeCard/ShowTimeCard.svelte +61 -61
  9. package/dist/components/Layout/AppShell.svelte +104 -0
  10. package/dist/components/Layout/AppShell.svelte.d.ts +26 -0
  11. package/dist/components/Layout/AppShell.svelte.d.ts.map +1 -0
  12. package/dist/components/Layout/ContentSection.svelte +80 -0
  13. package/dist/components/Layout/ContentSection.svelte.d.ts +23 -0
  14. package/dist/components/Layout/ContentSection.svelte.d.ts.map +1 -0
  15. package/dist/components/Layout/Grid.svelte +4 -4
  16. package/dist/components/Layout/Heading.svelte +81 -0
  17. package/dist/components/Layout/Heading.svelte.d.ts +24 -0
  18. package/dist/components/Layout/Heading.svelte.d.ts.map +1 -0
  19. package/dist/components/Layout/PageContainer.svelte +69 -0
  20. package/dist/components/Layout/PageContainer.svelte.d.ts +23 -0
  21. package/dist/components/Layout/PageContainer.svelte.d.ts.map +1 -0
  22. package/dist/components/Layout/Responsive.svelte +75 -0
  23. package/dist/components/Layout/Responsive.svelte.d.ts +19 -0
  24. package/dist/components/Layout/Responsive.svelte.d.ts.map +1 -0
  25. package/dist/components/Layout/Section.svelte +80 -80
  26. package/dist/components/Layout/ShowOnDesktop.svelte +37 -0
  27. package/dist/components/Layout/ShowOnDesktop.svelte.d.ts +16 -0
  28. package/dist/components/Layout/ShowOnDesktop.svelte.d.ts.map +1 -0
  29. package/dist/components/Layout/ShowOnMobile.svelte +37 -0
  30. package/dist/components/Layout/ShowOnMobile.svelte.d.ts +16 -0
  31. package/dist/components/Layout/ShowOnMobile.svelte.d.ts.map +1 -0
  32. package/dist/components/Layout/Sidebar.svelte +108 -108
  33. package/dist/components/Layout/Stack.spec.js +1 -1
  34. package/dist/components/Layout/Stack.svelte +6 -6
  35. package/dist/components/Layout/Text.svelte +87 -0
  36. package/dist/components/Layout/Text.svelte.d.ts +28 -0
  37. package/dist/components/Layout/Text.svelte.d.ts.map +1 -0
  38. package/dist/components/Layout/TwoColumn.svelte +108 -0
  39. package/dist/components/Layout/TwoColumn.svelte.d.ts +28 -0
  40. package/dist/components/Layout/TwoColumn.svelte.d.ts.map +1 -0
  41. package/dist/components/Layout/__tests__/AppShell.test.d.ts +2 -0
  42. package/dist/components/Layout/__tests__/AppShell.test.d.ts.map +1 -0
  43. package/dist/components/Layout/__tests__/AppShell.test.js +95 -0
  44. package/dist/components/Layout/__tests__/ContentSection.test.d.ts +2 -0
  45. package/dist/components/Layout/__tests__/ContentSection.test.d.ts.map +1 -0
  46. package/dist/components/Layout/__tests__/ContentSection.test.js +112 -0
  47. package/dist/components/Layout/__tests__/Heading.test.d.ts +2 -0
  48. package/dist/components/Layout/__tests__/Heading.test.d.ts.map +1 -0
  49. package/dist/components/Layout/__tests__/Heading.test.js +123 -0
  50. package/dist/components/Layout/__tests__/PageContainer.test.d.ts +2 -0
  51. package/dist/components/Layout/__tests__/PageContainer.test.d.ts.map +1 -0
  52. package/dist/components/Layout/__tests__/PageContainer.test.js +133 -0
  53. package/dist/components/Layout/__tests__/Responsive.test.d.ts +2 -0
  54. package/dist/components/Layout/__tests__/Responsive.test.d.ts.map +1 -0
  55. package/dist/components/Layout/__tests__/Responsive.test.js +123 -0
  56. package/dist/components/Layout/__tests__/ShowOnDesktop.test.d.ts +2 -0
  57. package/dist/components/Layout/__tests__/ShowOnDesktop.test.d.ts.map +1 -0
  58. package/dist/components/Layout/__tests__/ShowOnDesktop.test.js +84 -0
  59. package/dist/components/Layout/__tests__/ShowOnMobile.test.d.ts +2 -0
  60. package/dist/components/Layout/__tests__/ShowOnMobile.test.d.ts.map +1 -0
  61. package/dist/components/Layout/__tests__/ShowOnMobile.test.js +80 -0
  62. package/dist/components/Layout/__tests__/Text.test.d.ts +2 -0
  63. package/dist/components/Layout/__tests__/Text.test.d.ts.map +1 -0
  64. package/dist/components/Layout/__tests__/Text.test.js +146 -0
  65. package/dist/components/Layout/__tests__/TwoColumn.test.d.ts +2 -0
  66. package/dist/components/Layout/__tests__/TwoColumn.test.d.ts.map +1 -0
  67. package/dist/components/Layout/__tests__/TwoColumn.test.js +129 -0
  68. package/dist/constants/validation.js +91 -91
  69. package/dist/constants/validation.spec.js +64 -64
  70. package/dist/datetime/__tests__/format.test.js +1 -1
  71. package/dist/datetime/__tests__/parse.test.js +1 -1
  72. package/dist/datetime/__tests__/timezone.test.js +1 -1
  73. package/dist/datetime/parse.js +1 -1
  74. package/dist/forms/createFormStore.svelte.js +1 -0
  75. package/dist/index.d.ts +1 -0
  76. package/dist/index.js +1 -0
  77. package/dist/patterns/data/DataGrid.svelte +45 -45
  78. package/dist/patterns/data/DataList.svelte +24 -24
  79. package/dist/patterns/data/DataTable.svelte +36 -36
  80. package/dist/patterns/forms/FormActions.spec.js +95 -95
  81. package/dist/patterns/forms/FormActions.stories.svelte +97 -97
  82. package/dist/patterns/forms/FormActions.svelte +46 -46
  83. package/dist/patterns/forms/FormGrid.svelte +33 -33
  84. package/dist/patterns/forms/FormSection.svelte +32 -32
  85. package/dist/patterns/forms/FormValidationSummary.stories.svelte +83 -83
  86. package/dist/patterns/forms/FormValidationSummary.svelte +74 -74
  87. package/dist/patterns/layout/Sidebar.svelte +39 -39
  88. package/dist/patterns/layout/index.d.ts +9 -0
  89. package/dist/patterns/layout/index.js +22 -0
  90. package/dist/patterns/navigation/BottomNav.stories.svelte +117 -117
  91. package/dist/patterns/navigation/BottomNav.svelte +74 -64
  92. package/dist/patterns/navigation/BottomNav.svelte.d.ts.map +1 -1
  93. package/dist/patterns/navigation/Header.stories.svelte +77 -77
  94. package/dist/patterns/navigation/Header.svelte +193 -193
  95. package/dist/patterns/page/PageHeader.svelte +18 -18
  96. package/dist/patterns/page/PageLayout.svelte +40 -40
  97. package/dist/patterns/page/PageLoader.spec.js +57 -57
  98. package/dist/patterns/page/PageLoader.stories.svelte +137 -137
  99. package/dist/patterns/page/PageLoader.svelte +24 -24
  100. package/dist/patterns/page/SectionHeader.svelte +29 -29
  101. package/dist/presets/badges.js +112 -112
  102. package/dist/presets/buttons.js +76 -76
  103. package/dist/presets/index.js +9 -9
  104. package/dist/primitives/Accordion/Accordion.stories.svelte +75 -75
  105. package/dist/primitives/Accordion/Accordion.svelte +42 -42
  106. package/dist/primitives/Accordion/AccordionItem.svelte +95 -95
  107. package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte +107 -107
  108. package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte.d.ts +2 -2
  109. package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte.d.ts.map +1 -1
  110. package/dist/primitives/Alert/Alert.spec.js +173 -173
  111. package/dist/primitives/Alert/Alert.stories.svelte +88 -88
  112. package/dist/primitives/Alert/Alert.svelte +27 -27
  113. package/dist/primitives/Avatar/Avatar.stories.svelte +94 -94
  114. package/dist/primitives/Avatar/Avatar.svelte +66 -66
  115. package/dist/primitives/Badges/Badge.spec.js +144 -144
  116. package/dist/primitives/Badges/Badge.stories.svelte +86 -86
  117. package/dist/primitives/Badges/Badge.svelte +79 -79
  118. package/dist/primitives/BottomSheet/BottomSheet.spec.js +136 -136
  119. package/dist/primitives/BottomSheet/BottomSheet.stories.svelte +83 -83
  120. package/dist/primitives/BottomSheet/BottomSheet.svelte +100 -100
  121. package/dist/primitives/Breadcrumb/Breadcrumb.spec.js +122 -122
  122. package/dist/primitives/Breadcrumb/Breadcrumb.stories.svelte +23 -23
  123. package/dist/primitives/Breadcrumb/Breadcrumb.svelte +89 -89
  124. package/dist/primitives/Button/Button.spec.js +223 -223
  125. package/dist/primitives/Button/Button.stories.svelte +76 -76
  126. package/dist/primitives/Button/Button.svelte +270 -270
  127. package/dist/primitives/Button/ButtonSaveDemo.spec.js +146 -146
  128. package/dist/primitives/Button/ButtonSaveDemo.svelte +25 -25
  129. package/dist/primitives/Button/ButtonVariantShowcase.svelte +129 -129
  130. package/dist/primitives/Card.spec.js +49 -49
  131. package/dist/primitives/Card.stories.svelte +22 -22
  132. package/dist/primitives/Card.svelte +28 -28
  133. package/dist/primitives/Checkbox/Checkbox.stories.svelte +84 -84
  134. package/dist/primitives/Checkbox/Checkbox.svelte +88 -88
  135. package/dist/primitives/DarkModeToggle.spec.js +390 -390
  136. package/dist/primitives/DarkModeToggle.stories.svelte +57 -57
  137. package/dist/primitives/DarkModeToggle.svelte +136 -136
  138. package/dist/primitives/Drawer/Drawer.stories.svelte +80 -80
  139. package/dist/primitives/Drawer/Drawer.svelte +120 -120
  140. package/dist/primitives/Dropdown/Dropdown.stories.svelte +137 -137
  141. package/dist/primitives/Dropdown/Dropdown.svelte +14 -14
  142. package/dist/primitives/Dropdown/DropdownDivider.svelte +9 -0
  143. package/dist/primitives/Dropdown/DropdownDivider.svelte.d.ts +7 -0
  144. package/dist/primitives/Dropdown/DropdownDivider.svelte.d.ts.map +1 -0
  145. package/dist/primitives/Dropdown/DropdownItem.svelte +80 -80
  146. package/dist/primitives/Helper/Helper.svelte +33 -0
  147. package/dist/primitives/Helper/Helper.svelte.d.ts +18 -0
  148. package/dist/primitives/Helper/Helper.svelte.d.ts.map +1 -0
  149. package/dist/primitives/Icons/ArrowLeft.svelte +8 -8
  150. package/dist/primitives/Icons/ArrowRight.svelte +8 -8
  151. package/dist/primitives/Icons/Availability.svelte +14 -14
  152. package/dist/primitives/Icons/Back.svelte +14 -14
  153. package/dist/primitives/Icons/CheckCircle.svelte +6 -6
  154. package/dist/primitives/Icons/CheckCircleOutline.svelte +15 -15
  155. package/dist/primitives/Icons/ChevronLeft.svelte +4 -4
  156. package/dist/primitives/Icons/ChevronRight.svelte +4 -4
  157. package/dist/primitives/Icons/Copy.svelte +15 -15
  158. package/dist/primitives/Icons/Cross.svelte +5 -5
  159. package/dist/primitives/Icons/DownArrow.svelte +8 -8
  160. package/dist/primitives/Icons/ErrorCircle.svelte +6 -6
  161. package/dist/primitives/Icons/FacebookIcon.svelte +2 -2
  162. package/dist/primitives/Icons/Home.svelte +15 -15
  163. package/dist/primitives/Icons/Icon.spec.js +169 -169
  164. package/dist/primitives/Icons/Icon.stories.svelte +100 -100
  165. package/dist/primitives/Icons/Icon.svelte +52 -52
  166. package/dist/primitives/Icons/IconGallery.stories.svelte +235 -235
  167. package/dist/primitives/Icons/Info.svelte +7 -7
  168. package/dist/primitives/Icons/InstagramIcon.svelte +4 -4
  169. package/dist/primitives/Icons/LogoInstagram.svelte +2 -2
  170. package/dist/primitives/Icons/Message.svelte +15 -15
  171. package/dist/primitives/Icons/MoonIcon.svelte +5 -5
  172. package/dist/primitives/Icons/More.svelte +21 -21
  173. package/dist/primitives/Icons/MoreHori.spec.js +61 -61
  174. package/dist/primitives/Icons/MoreHori.svelte +22 -22
  175. package/dist/primitives/Icons/Notification.svelte +14 -14
  176. package/dist/primitives/Icons/Payment.svelte +14 -14
  177. package/dist/primitives/Icons/Profile.svelte +21 -21
  178. package/dist/primitives/Icons/Reload.svelte +29 -29
  179. package/dist/primitives/Icons/Shows.svelte +21 -21
  180. package/dist/primitives/Icons/Signout.svelte +21 -21
  181. package/dist/primitives/Icons/SunIcon.svelte +8 -8
  182. package/dist/primitives/Icons/TiktokIcon.svelte +2 -2
  183. package/dist/primitives/Icons/TwitterIcon.svelte +2 -2
  184. package/dist/primitives/Icons/WarningIcon.spec.js +18 -18
  185. package/dist/primitives/Icons/WarningIcon.svelte +5 -5
  186. package/dist/primitives/Input/Input.spec.js +573 -573
  187. package/dist/primitives/Input/Input.stories.svelte +139 -139
  188. package/dist/primitives/Input/Input.svelte +1 -2
  189. package/dist/primitives/Input/Input.svelte.d.ts +2 -4
  190. package/dist/primitives/Input/Input.svelte.d.ts.map +1 -1
  191. package/dist/primitives/Input/Select.spec.js +212 -212
  192. package/dist/primitives/Input/Select.stories.svelte +112 -112
  193. package/dist/primitives/Input/Select.svelte +128 -128
  194. package/dist/primitives/Input/Textarea.stories.svelte +137 -137
  195. package/dist/primitives/Input/Textarea.svelte +35 -35
  196. package/dist/primitives/Label/Label.svelte +37 -37
  197. package/dist/primitives/Modal/Modal.spec.js +99 -99
  198. package/dist/primitives/Modal/Modal.stories.svelte +86 -86
  199. package/dist/primitives/Modal/Modal.svelte +3 -4
  200. package/dist/primitives/Modal/Modal.svelte.d.ts +6 -8
  201. package/dist/primitives/Modal/Modal.svelte.d.ts.map +1 -1
  202. package/dist/primitives/NumberInput/NumberInput.svelte +0 -1
  203. package/dist/primitives/NumberInput/NumberInput.svelte.d.ts +0 -2
  204. package/dist/primitives/NumberInput/NumberInput.svelte.d.ts.map +1 -1
  205. package/dist/primitives/Pagination/Pagination.stories.svelte +76 -76
  206. package/dist/primitives/Pagination/Pagination.svelte +261 -261
  207. package/dist/primitives/Radio/Radio.stories.svelte +80 -80
  208. package/dist/primitives/Radio/Radio.svelte +67 -67
  209. package/dist/primitives/Skeleton/CardPlaceholder.svelte +87 -87
  210. package/dist/primitives/Skeleton/ImagePlaceholder.svelte +59 -59
  211. package/dist/primitives/Skeleton/ListPlaceholder.svelte +76 -76
  212. package/dist/primitives/Skeleton/Skeleton.stories.svelte +151 -151
  213. package/dist/primitives/Skeleton/Skeleton.svelte +26 -26
  214. package/dist/primitives/Spinner/Spinner.spec.js +71 -71
  215. package/dist/primitives/Spinner/Spinner.stories.svelte +29 -29
  216. package/dist/primitives/Spinner/Spinner.svelte +20 -20
  217. package/dist/primitives/Tabs/TabItem.svelte +49 -49
  218. package/dist/primitives/Tabs/Tabs.stories.svelte +112 -112
  219. package/dist/primitives/Tabs/Tabs.svelte +123 -123
  220. package/dist/primitives/Toggle.spec.js +143 -143
  221. package/dist/primitives/Toggle.stories.svelte +92 -92
  222. package/dist/primitives/Toggle.svelte +1 -2
  223. package/dist/primitives/Toggle.svelte.d.ts +2 -4
  224. package/dist/primitives/Toggle.svelte.d.ts.map +1 -1
  225. package/dist/primitives/Tooltip/Tooltip.svelte +83 -0
  226. package/dist/primitives/Tooltip/Tooltip.svelte.d.ts +15 -0
  227. package/dist/primitives/Tooltip/Tooltip.svelte.d.ts.map +1 -0
  228. package/dist/primitives/Typography/Typography.svelte +53 -53
  229. package/dist/primitives/ValidationError.spec.js +103 -103
  230. package/dist/primitives/ValidationError.stories.svelte +69 -69
  231. package/dist/primitives/ValidationError.svelte +29 -29
  232. package/dist/primitives/index.d.ts +3 -0
  233. package/dist/primitives/index.js +91 -84
  234. package/dist/recipes/CropImage/CropImage.spec.js +208 -208
  235. package/dist/recipes/CropImage/CropImage.stories.svelte +104 -104
  236. package/dist/recipes/CropImage/CropImage.svelte +238 -238
  237. package/dist/recipes/ImageUploader/ImageUploader.spec.js +6 -5
  238. package/dist/recipes/ImageUploader/ImageUploader.stories.svelte +125 -125
  239. package/dist/recipes/ImageUploader/ImageUploader.svelte +804 -804
  240. package/dist/recipes/SuperLogin/SuperLogin.spec.js +17 -17
  241. package/dist/recipes/Toaster/Toaster.stories.svelte +62 -62
  242. package/dist/recipes/feedback/EmptyState/EmptyState.svelte +1 -1
  243. package/dist/recipes/feedback/ErrorDisplay.spec.js +69 -69
  244. package/dist/recipes/feedback/ErrorDisplay.stories.svelte +101 -101
  245. package/dist/recipes/feedback/ErrorDisplay.svelte +1 -1
  246. package/dist/recipes/feedback/StatusIndicator/StatusIndicator.spec.js +133 -133
  247. package/dist/recipes/feedback/StatusIndicator/StatusIndicator.svelte +157 -157
  248. package/dist/recipes/fields/CheckboxField.svelte +85 -85
  249. package/dist/recipes/fields/FormField.svelte +58 -58
  250. package/dist/recipes/fields/RadioGroup.svelte +95 -95
  251. package/dist/recipes/fields/SelectField.svelte +80 -80
  252. package/dist/recipes/fields/TextareaField.svelte +97 -97
  253. package/dist/recipes/fields/ToggleField.svelte +60 -60
  254. package/dist/recipes/fields/index.js +7 -7
  255. package/dist/recipes/inputs/MultiSelect.spec.js +258 -258
  256. package/dist/recipes/inputs/MultiSelect.stories.svelte +133 -133
  257. package/dist/recipes/inputs/MultiSelect.svelte +29 -8
  258. package/dist/recipes/inputs/MultiSelect.svelte.d.ts +54 -21
  259. package/dist/recipes/inputs/MultiSelect.svelte.d.ts.map +1 -1
  260. package/dist/recipes/inputs/OTPInput.spec.js +251 -251
  261. package/dist/recipes/inputs/OTPInput.stories.svelte +162 -162
  262. package/dist/recipes/inputs/OTPInput.svelte +29 -29
  263. package/dist/recipes/inputs/PasswordInput.svelte +22 -22
  264. package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.svelte +117 -117
  265. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.spec.js +9 -4
  266. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.stories.svelte +123 -123
  267. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte +30 -25
  268. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte.d.ts +12 -1
  269. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte.d.ts.map +1 -1
  270. package/dist/recipes/inputs/Search.svelte +37 -37
  271. package/dist/recipes/inputs/SelectDropdown.svelte +57 -57
  272. package/dist/recipes/modals/AlertModal.svelte +130 -130
  273. package/dist/recipes/modals/ConfirmationModal.spec.js +206 -206
  274. package/dist/recipes/modals/ConfirmationModal.stories.svelte +119 -119
  275. package/dist/recipes/modals/ConfirmationModal.svelte +152 -152
  276. package/dist/recipes/modals/InputModal.svelte +182 -182
  277. package/dist/recipes/modals/ModalStateManager.spec.js +100 -100
  278. package/dist/recipes/modals/ModalStateManager.svelte +77 -77
  279. package/dist/recipes/modals/ModalTestWrapper.svelte +65 -65
  280. package/dist/recipes/modals/StatusModal.svelte +206 -206
  281. package/dist/services/EventService.js +75 -75
  282. package/dist/services/EventService.spec.js +217 -217
  283. package/dist/services/ShowService.spec.js +345 -345
  284. package/dist/stores/auth.js +44 -36
  285. package/dist/stores/auth.spec.js +139 -139
  286. package/dist/stores/auth.svelte.d.ts +39 -0
  287. package/dist/stores/auth.svelte.d.ts.map +1 -0
  288. package/dist/stores/auth.svelte.js +60 -0
  289. package/dist/stores/formDataStore.d.ts.map +1 -1
  290. package/dist/stores/formDataStore.js +8 -0
  291. package/dist/stores/formDataStore.svelte.d.ts +47 -0
  292. package/dist/stores/formDataStore.svelte.d.ts.map +1 -0
  293. package/dist/stores/formDataStore.svelte.js +84 -0
  294. package/dist/stores/formSave.d.ts.map +1 -1
  295. package/dist/stores/formSave.js +8 -0
  296. package/dist/stores/formSave.svelte.d.ts +33 -0
  297. package/dist/stores/formSave.svelte.d.ts.map +1 -0
  298. package/dist/stores/formSave.svelte.js +113 -0
  299. package/dist/stores/navigation.d.ts.map +1 -1
  300. package/dist/stores/navigation.js +8 -0
  301. package/dist/stores/navigation.svelte.d.ts +35 -0
  302. package/dist/stores/navigation.svelte.d.ts.map +1 -0
  303. package/dist/stores/navigation.svelte.js +69 -0
  304. package/dist/stores/toaster.js +13 -13
  305. package/dist/stories/ButtonAuditReview.stories.svelte +14 -14
  306. package/dist/stories/ButtonAuditReview.svelte +427 -427
  307. package/dist/stories/PatternsGallery.stories.svelte +19 -19
  308. package/dist/stories/PatternsGallery.svelte +206 -206
  309. package/dist/stories/PrimitivesGallery.stories.svelte +19 -19
  310. package/dist/stories/PrimitivesGallery.svelte +725 -725
  311. package/dist/stories/RecipesGallery.stories.svelte +19 -19
  312. package/dist/stories/RecipesGallery.svelte +271 -271
  313. package/dist/stories/button-audit-manifest.json +11186 -11186
  314. package/dist/tailwind/preset.cjs +82 -82
  315. package/dist/telemetry.js +405 -405
  316. package/dist/telemetry.server.spec.js +11 -8
  317. package/dist/telemetry.spec.js +1169 -1144
  318. package/dist/tokens/__tests__/typography-base.test.d.ts +2 -0
  319. package/dist/tokens/__tests__/typography-base.test.d.ts.map +1 -0
  320. package/dist/tokens/__tests__/typography-base.test.js +138 -0
  321. package/dist/tokens/tokens.css +87 -87
  322. package/dist/tokens/typography-base.css +163 -0
  323. package/dist/utils/apiConfig.spec.js +219 -219
  324. package/dist/utils/imageValidation.spec.js +62 -59
  325. package/dist/utils/logger.d.ts +19 -0
  326. package/dist/utils/logger.d.ts.map +1 -0
  327. package/dist/utils/logger.js +47 -0
  328. package/dist/utils/transitions.js +62 -62
  329. package/dist/utils/utils.js +354 -354
  330. package/package.json +21 -16
@@ -1,261 +1,261 @@
1
- <script lang="ts">
2
- import type { Snippet } from 'svelte';
3
- import { ChevronLeftOutline, ChevronRightOutline } from "../Icons";
4
- import { typography } from "../../tokens/typography";
5
-
6
- interface Props {
7
- currentPage?: number;
8
- totalPages?: number;
9
- maxVisible?: number;
10
- showPrevNext?: boolean;
11
- showIcons?: boolean;
12
- previousLabel?: string;
13
- nextLabel?: string;
14
- variant?: 'default' | 'table';
15
- size?: 'sm' | 'md' | 'lg';
16
- totalItems?: number;
17
- perPage?: number;
18
- class?: string;
19
- onchange?: (detail: { page: number }) => void;
20
- onPageChange?: (page: number) => void;
21
- prev?: Snippet;
22
- next?: Snippet;
23
- [key: string]: unknown;
24
- }
25
-
26
- let {
27
- currentPage = $bindable(1),
28
- totalPages = 1,
29
- maxVisible = 5,
30
- showPrevNext = true,
31
- showIcons = undefined,
32
- previousLabel = undefined,
33
- nextLabel = undefined,
34
- variant = 'default',
35
- size = 'md',
36
- totalItems = 0,
37
- perPage = 10,
38
- class: className = "",
39
- onchange,
40
- onPageChange,
41
- prev,
42
- next,
43
- ...restProps
44
- }: Props = $props();
45
-
46
- // Support flowbite's showIcons prop
47
- let effectiveShowPrevNext = $derived(showIcons !== undefined ? showIcons : showPrevNext);
48
-
49
- // Calculate showing range for table variant
50
- let startItem = $derived(totalItems > 0 ? (currentPage - 1) * perPage + 1 : 0);
51
- let endItem = $derived(Math.min(currentPage * perPage, totalItems));
52
-
53
- // Size-based classes
54
- let sizeClasses = $derived({
55
- sm: 'h-8 px-3 text-sm',
56
- md: 'h-9 px-3 text-sm',
57
- lg: 'h-10 px-4 text-base'
58
- }[size]);
59
-
60
- let pageSizeClasses = $derived({
61
- sm: 'h-8 w-8 text-sm',
62
- md: 'h-9 w-9 text-sm',
63
- lg: 'h-10 w-10 text-base'
64
- }[size]);
65
-
66
- function goToPage(page: number) {
67
- if (page >= 1 && page <= totalPages && page !== currentPage) {
68
- currentPage = page;
69
- onchange?.({ page });
70
- // Also dispatch flowbite-style event
71
- onPageChange?.(page);
72
- }
73
- }
74
-
75
- function previous() {
76
- goToPage(currentPage - 1);
77
- }
78
-
79
- function nextPage() {
80
- goToPage(currentPage + 1);
81
- }
82
-
83
- // Calculate which page numbers to show
84
- let visiblePages = $derived.by(() => {
85
- const pages = [];
86
- let start = Math.max(1, currentPage - Math.floor(maxVisible / 2));
87
- let end = Math.min(totalPages, start + maxVisible - 1);
88
-
89
- // Adjust start if we're near the end
90
- if (end - start + 1 < maxVisible) {
91
- start = Math.max(1, end - maxVisible + 1);
92
- }
93
-
94
- for (let i = start; i <= end; i++) {
95
- pages.push(i);
96
- }
97
-
98
- return pages;
99
- });
100
-
101
- let showStartEllipsis = $derived(visiblePages[0] > 1);
102
- let showEndEllipsis = $derived(visiblePages[visiblePages.length - 1] < totalPages);
103
-
104
- // Base button classes (Flowbite connected style)
105
- const baseButtonClasses = "flex items-center justify-center leading-tight font-medium border border-gray-300 bg-white text-gray-500 hover:bg-gray-100 hover:text-gray-700 dark:bg-gray-800 dark:border-gray-700 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white";
106
-
107
- // Active state classes (Flowbite style)
108
- const activeClasses = "flex items-center justify-center leading-tight font-medium border border-gray-300 bg-blue-50 text-blue-600 hover:bg-blue-100 hover:text-blue-700 dark:bg-gray-700 dark:border-gray-700 dark:text-white";
109
-
110
- // Disabled state classes
111
- const disabledClasses = "cursor-not-allowed opacity-50";
112
- </script>
113
-
114
- {#if variant === 'table'}
115
- <div class="flex flex-col items-center gap-3 sm:flex-row sm:justify-between {className}" {...restProps}>
116
- <span class={`${typography.sm} text-gray-700 dark:text-gray-400`}>
117
- Showing <span class={`font-semibold ${typography.sm}`}>{startItem}</span> to <span class={`font-semibold ${typography.sm}`}>{endItem}</span> of <span class={`font-semibold ${typography.sm}`}>{totalItems}</span> entries
118
- </span>
119
- <nav class="inline-flex -space-x-px rtl:space-x-reverse" aria-label="Pagination">
120
- {#if effectiveShowPrevNext}
121
- <button
122
- type="button"
123
- class="{baseButtonClasses} {sizeClasses} rounded-s-lg {currentPage === 1 ? disabledClasses : ''}"
124
- disabled={currentPage === 1}
125
- onclick={previous}
126
- aria-label="Previous page"
127
- >
128
- {#if prev}
129
- {@render prev()}
130
- {:else if previousLabel}
131
- {previousLabel}
132
- {:else}
133
- <span aria-hidden="true"><ChevronLeftOutline class="h-4 w-4 rtl:rotate-180" /></span>
134
- {/if}
135
- </button>
136
- {/if}
137
-
138
- {#if showStartEllipsis}
139
- <button
140
- type="button"
141
- class="{baseButtonClasses} {pageSizeClasses} {!effectiveShowPrevNext ? 'rounded-s-lg' : ''}"
142
- onclick={() => goToPage(1)}
143
- >
144
- 1
145
- </button>
146
- <span class="{baseButtonClasses} {pageSizeClasses} cursor-default">...</span>
147
- {/if}
148
-
149
- {#each visiblePages as page, index}
150
- <button
151
- type="button"
152
- class="{page === currentPage ? activeClasses : baseButtonClasses} {pageSizeClasses} {!effectiveShowPrevNext && !showStartEllipsis && index === 0 ? 'rounded-s-lg' : ''} {!effectiveShowPrevNext && !showEndEllipsis && index === visiblePages.length - 1 ? 'rounded-e-lg' : ''}"
153
- onclick={() => goToPage(page)}
154
- aria-current={page === currentPage ? "page" : undefined}
155
- >
156
- {page}
157
- </button>
158
- {/each}
159
-
160
- {#if showEndEllipsis}
161
- <span class="{baseButtonClasses} {pageSizeClasses} cursor-default">...</span>
162
- <button
163
- type="button"
164
- class="{baseButtonClasses} {pageSizeClasses} {!effectiveShowPrevNext ? 'rounded-e-lg' : ''}"
165
- onclick={() => goToPage(totalPages)}
166
- >
167
- {totalPages}
168
- </button>
169
- {/if}
170
-
171
- {#if effectiveShowPrevNext}
172
- <button
173
- type="button"
174
- class="{baseButtonClasses} {sizeClasses} rounded-e-lg {currentPage === totalPages ? disabledClasses : ''}"
175
- disabled={currentPage === totalPages}
176
- onclick={nextPage}
177
- aria-label="Next page"
178
- >
179
- {#if next}
180
- {@render next()}
181
- {:else if nextLabel}
182
- {nextLabel}
183
- {:else}
184
- <span aria-hidden="true"><ChevronRightOutline class="h-4 w-4 rtl:rotate-180" /></span>
185
- {/if}
186
- </button>
187
- {/if}
188
- </nav>
189
- </div>
190
- {:else}
191
- <nav class="inline-flex -space-x-px rtl:space-x-reverse text-sm {className}" aria-label="Pagination" {...restProps}>
192
- {#if effectiveShowPrevNext}
193
- <button
194
- type="button"
195
- class="{baseButtonClasses} {sizeClasses} rounded-s-lg {currentPage === 1 ? disabledClasses : ''}"
196
- disabled={currentPage === 1}
197
- onclick={previous}
198
- aria-label="Previous page"
199
- >
200
- {#if prev}
201
- {@render prev()}
202
- {:else if previousLabel}
203
- {previousLabel}
204
- {:else}
205
- <span aria-hidden="true"><ChevronLeftOutline class="h-4 w-4 rtl:rotate-180" /></span>
206
- {/if}
207
- </button>
208
- {/if}
209
-
210
- {#if showStartEllipsis}
211
- <button
212
- type="button"
213
- class="{baseButtonClasses} {pageSizeClasses} {!effectiveShowPrevNext ? 'rounded-s-lg' : ''}"
214
- onclick={() => goToPage(1)}
215
- >
216
- 1
217
- </button>
218
- <span class="{baseButtonClasses} {pageSizeClasses} cursor-default">...</span>
219
- {/if}
220
-
221
- {#each visiblePages as page, index}
222
- <button
223
- type="button"
224
- class="{page === currentPage ? activeClasses : baseButtonClasses} {pageSizeClasses} {!effectiveShowPrevNext && !showStartEllipsis && index === 0 ? 'rounded-s-lg' : ''} {!effectiveShowPrevNext && !showEndEllipsis && index === visiblePages.length - 1 ? 'rounded-e-lg' : ''}"
225
- onclick={() => goToPage(page)}
226
- aria-current={page === currentPage ? "page" : undefined}
227
- >
228
- {page}
229
- </button>
230
- {/each}
231
-
232
- {#if showEndEllipsis}
233
- <span class="{baseButtonClasses} {pageSizeClasses} cursor-default">...</span>
234
- <button
235
- type="button"
236
- class="{baseButtonClasses} {pageSizeClasses} {!effectiveShowPrevNext ? 'rounded-e-lg' : ''}"
237
- onclick={() => goToPage(totalPages)}
238
- >
239
- {totalPages}
240
- </button>
241
- {/if}
242
-
243
- {#if effectiveShowPrevNext}
244
- <button
245
- type="button"
246
- class="{baseButtonClasses} {sizeClasses} rounded-e-lg {currentPage === totalPages ? disabledClasses : ''}"
247
- disabled={currentPage === totalPages}
248
- onclick={nextPage}
249
- aria-label="Next page"
250
- >
251
- {#if next}
252
- {@render next()}
253
- {:else if nextLabel}
254
- {nextLabel}
255
- {:else}
256
- <span aria-hidden="true"><ChevronRightOutline class="h-4 w-4 rtl:rotate-180" /></span>
257
- {/if}
258
- </button>
259
- {/if}
260
- </nav>
261
- {/if}
1
+ <script lang="ts">
2
+ import type { Snippet } from 'svelte';
3
+ import { ChevronLeftOutline, ChevronRightOutline } from "../Icons";
4
+ import { typography } from "../../tokens/typography";
5
+
6
+ interface Props {
7
+ currentPage?: number;
8
+ totalPages?: number;
9
+ maxVisible?: number;
10
+ showPrevNext?: boolean;
11
+ showIcons?: boolean;
12
+ previousLabel?: string;
13
+ nextLabel?: string;
14
+ variant?: 'default' | 'table';
15
+ size?: 'sm' | 'md' | 'lg';
16
+ totalItems?: number;
17
+ perPage?: number;
18
+ class?: string;
19
+ onchange?: (detail: { page: number }) => void;
20
+ onPageChange?: (page: number) => void;
21
+ prev?: Snippet;
22
+ next?: Snippet;
23
+ [key: string]: unknown;
24
+ }
25
+
26
+ let {
27
+ currentPage = $bindable(1),
28
+ totalPages = 1,
29
+ maxVisible = 5,
30
+ showPrevNext = true,
31
+ showIcons = undefined,
32
+ previousLabel = undefined,
33
+ nextLabel = undefined,
34
+ variant = 'default',
35
+ size = 'md',
36
+ totalItems = 0,
37
+ perPage = 10,
38
+ class: className = "",
39
+ onchange,
40
+ onPageChange,
41
+ prev,
42
+ next,
43
+ ...restProps
44
+ }: Props = $props();
45
+
46
+ // Support flowbite's showIcons prop
47
+ let effectiveShowPrevNext = $derived(showIcons !== undefined ? showIcons : showPrevNext);
48
+
49
+ // Calculate showing range for table variant
50
+ let startItem = $derived(totalItems > 0 ? (currentPage - 1) * perPage + 1 : 0);
51
+ let endItem = $derived(Math.min(currentPage * perPage, totalItems));
52
+
53
+ // Size-based classes
54
+ let sizeClasses = $derived({
55
+ sm: 'h-8 px-3 text-sm',
56
+ md: 'h-9 px-3 text-sm',
57
+ lg: 'h-10 px-4 text-base'
58
+ }[size]);
59
+
60
+ let pageSizeClasses = $derived({
61
+ sm: 'h-8 w-8 text-sm',
62
+ md: 'h-9 w-9 text-sm',
63
+ lg: 'h-10 w-10 text-base'
64
+ }[size]);
65
+
66
+ function goToPage(page: number) {
67
+ if (page >= 1 && page <= totalPages && page !== currentPage) {
68
+ currentPage = page;
69
+ onchange?.({ page });
70
+ // Also dispatch flowbite-style event
71
+ onPageChange?.(page);
72
+ }
73
+ }
74
+
75
+ function previous() {
76
+ goToPage(currentPage - 1);
77
+ }
78
+
79
+ function nextPage() {
80
+ goToPage(currentPage + 1);
81
+ }
82
+
83
+ // Calculate which page numbers to show
84
+ let visiblePages = $derived.by(() => {
85
+ const pages = [];
86
+ let start = Math.max(1, currentPage - Math.floor(maxVisible / 2));
87
+ let end = Math.min(totalPages, start + maxVisible - 1);
88
+
89
+ // Adjust start if we're near the end
90
+ if (end - start + 1 < maxVisible) {
91
+ start = Math.max(1, end - maxVisible + 1);
92
+ }
93
+
94
+ for (let i = start; i <= end; i++) {
95
+ pages.push(i);
96
+ }
97
+
98
+ return pages;
99
+ });
100
+
101
+ let showStartEllipsis = $derived(visiblePages[0] > 1);
102
+ let showEndEllipsis = $derived(visiblePages[visiblePages.length - 1] < totalPages);
103
+
104
+ // Base button classes (Flowbite connected style)
105
+ const baseButtonClasses = "flex items-center justify-center leading-tight font-medium border border-gray-300 bg-white text-gray-500 hover:bg-gray-100 hover:text-gray-700 dark:bg-gray-800 dark:border-gray-700 dark:text-gray-400 dark:hover:bg-gray-700 dark:hover:text-white";
106
+
107
+ // Active state classes (Flowbite style)
108
+ const activeClasses = "flex items-center justify-center leading-tight font-medium border border-gray-300 bg-blue-50 text-blue-600 hover:bg-blue-100 hover:text-blue-700 dark:bg-gray-700 dark:border-gray-700 dark:text-white";
109
+
110
+ // Disabled state classes
111
+ const disabledClasses = "cursor-not-allowed opacity-50";
112
+ </script>
113
+
114
+ {#if variant === 'table'}
115
+ <div class="flex flex-col items-center gap-3 sm:flex-row sm:justify-between {className}" {...restProps}>
116
+ <span class={`${typography.sm} text-gray-700 dark:text-gray-400`}>
117
+ Showing <span class={`font-semibold ${typography.sm}`}>{startItem}</span> to <span class={`font-semibold ${typography.sm}`}>{endItem}</span> of <span class={`font-semibold ${typography.sm}`}>{totalItems}</span> entries
118
+ </span>
119
+ <nav class="inline-flex -space-x-px rtl:space-x-reverse" aria-label="Pagination">
120
+ {#if effectiveShowPrevNext}
121
+ <button
122
+ type="button"
123
+ class="{baseButtonClasses} {sizeClasses} rounded-s-lg {currentPage === 1 ? disabledClasses : ''}"
124
+ disabled={currentPage === 1}
125
+ onclick={previous}
126
+ aria-label="Previous page"
127
+ >
128
+ {#if prev}
129
+ {@render prev()}
130
+ {:else if previousLabel}
131
+ {previousLabel}
132
+ {:else}
133
+ <span aria-hidden="true"><ChevronLeftOutline class="h-4 w-4 rtl:rotate-180" /></span>
134
+ {/if}
135
+ </button>
136
+ {/if}
137
+
138
+ {#if showStartEllipsis}
139
+ <button
140
+ type="button"
141
+ class="{baseButtonClasses} {pageSizeClasses} {!effectiveShowPrevNext ? 'rounded-s-lg' : ''}"
142
+ onclick={() => goToPage(1)}
143
+ >
144
+ 1
145
+ </button>
146
+ <span class="{baseButtonClasses} {pageSizeClasses} cursor-default">...</span>
147
+ {/if}
148
+
149
+ {#each visiblePages as page, index}
150
+ <button
151
+ type="button"
152
+ class="{page === currentPage ? activeClasses : baseButtonClasses} {pageSizeClasses} {!effectiveShowPrevNext && !showStartEllipsis && index === 0 ? 'rounded-s-lg' : ''} {!effectiveShowPrevNext && !showEndEllipsis && index === visiblePages.length - 1 ? 'rounded-e-lg' : ''}"
153
+ onclick={() => goToPage(page)}
154
+ aria-current={page === currentPage ? "page" : undefined}
155
+ >
156
+ {page}
157
+ </button>
158
+ {/each}
159
+
160
+ {#if showEndEllipsis}
161
+ <span class="{baseButtonClasses} {pageSizeClasses} cursor-default">...</span>
162
+ <button
163
+ type="button"
164
+ class="{baseButtonClasses} {pageSizeClasses} {!effectiveShowPrevNext ? 'rounded-e-lg' : ''}"
165
+ onclick={() => goToPage(totalPages)}
166
+ >
167
+ {totalPages}
168
+ </button>
169
+ {/if}
170
+
171
+ {#if effectiveShowPrevNext}
172
+ <button
173
+ type="button"
174
+ class="{baseButtonClasses} {sizeClasses} rounded-e-lg {currentPage === totalPages ? disabledClasses : ''}"
175
+ disabled={currentPage === totalPages}
176
+ onclick={nextPage}
177
+ aria-label="Next page"
178
+ >
179
+ {#if next}
180
+ {@render next()}
181
+ {:else if nextLabel}
182
+ {nextLabel}
183
+ {:else}
184
+ <span aria-hidden="true"><ChevronRightOutline class="h-4 w-4 rtl:rotate-180" /></span>
185
+ {/if}
186
+ </button>
187
+ {/if}
188
+ </nav>
189
+ </div>
190
+ {:else}
191
+ <nav class="inline-flex -space-x-px rtl:space-x-reverse text-sm {className}" aria-label="Pagination" {...restProps}>
192
+ {#if effectiveShowPrevNext}
193
+ <button
194
+ type="button"
195
+ class="{baseButtonClasses} {sizeClasses} rounded-s-lg {currentPage === 1 ? disabledClasses : ''}"
196
+ disabled={currentPage === 1}
197
+ onclick={previous}
198
+ aria-label="Previous page"
199
+ >
200
+ {#if prev}
201
+ {@render prev()}
202
+ {:else if previousLabel}
203
+ {previousLabel}
204
+ {:else}
205
+ <span aria-hidden="true"><ChevronLeftOutline class="h-4 w-4 rtl:rotate-180" /></span>
206
+ {/if}
207
+ </button>
208
+ {/if}
209
+
210
+ {#if showStartEllipsis}
211
+ <button
212
+ type="button"
213
+ class="{baseButtonClasses} {pageSizeClasses} {!effectiveShowPrevNext ? 'rounded-s-lg' : ''}"
214
+ onclick={() => goToPage(1)}
215
+ >
216
+ 1
217
+ </button>
218
+ <span class="{baseButtonClasses} {pageSizeClasses} cursor-default">...</span>
219
+ {/if}
220
+
221
+ {#each visiblePages as page, index}
222
+ <button
223
+ type="button"
224
+ class="{page === currentPage ? activeClasses : baseButtonClasses} {pageSizeClasses} {!effectiveShowPrevNext && !showStartEllipsis && index === 0 ? 'rounded-s-lg' : ''} {!effectiveShowPrevNext && !showEndEllipsis && index === visiblePages.length - 1 ? 'rounded-e-lg' : ''}"
225
+ onclick={() => goToPage(page)}
226
+ aria-current={page === currentPage ? "page" : undefined}
227
+ >
228
+ {page}
229
+ </button>
230
+ {/each}
231
+
232
+ {#if showEndEllipsis}
233
+ <span class="{baseButtonClasses} {pageSizeClasses} cursor-default">...</span>
234
+ <button
235
+ type="button"
236
+ class="{baseButtonClasses} {pageSizeClasses} {!effectiveShowPrevNext ? 'rounded-e-lg' : ''}"
237
+ onclick={() => goToPage(totalPages)}
238
+ >
239
+ {totalPages}
240
+ </button>
241
+ {/if}
242
+
243
+ {#if effectiveShowPrevNext}
244
+ <button
245
+ type="button"
246
+ class="{baseButtonClasses} {sizeClasses} rounded-e-lg {currentPage === totalPages ? disabledClasses : ''}"
247
+ disabled={currentPage === totalPages}
248
+ onclick={nextPage}
249
+ aria-label="Next page"
250
+ >
251
+ {#if next}
252
+ {@render next()}
253
+ {:else if nextLabel}
254
+ {nextLabel}
255
+ {:else}
256
+ <span aria-hidden="true"><ChevronRightOutline class="h-4 w-4 rtl:rotate-180" /></span>
257
+ {/if}
258
+ </button>
259
+ {/if}
260
+ </nav>
261
+ {/if}