@getmicdrop/svelte-components 5.17.4 → 5.19.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 (480) hide show
  1. package/dist/calendar/AboutShow/AboutShow.svelte +191 -187
  2. package/dist/calendar/AboutShow/AboutShow.svelte.d.ts +2 -2
  3. package/dist/calendar/AboutShow/AboutShow.svelte.d.ts.map +1 -1
  4. package/dist/calendar/Calendar/MiniMonthCalendar.svelte +801 -780
  5. package/dist/calendar/Calendar/MiniMonthCalendar.svelte.d.ts +4 -0
  6. package/dist/calendar/Calendar/MiniMonthCalendar.svelte.d.ts.map +1 -1
  7. package/dist/calendar/FAQs/FAQs.svelte +88 -77
  8. package/dist/calendar/FAQs/FAQs.svelte.d.ts +6 -4
  9. package/dist/calendar/FAQs/FAQs.svelte.d.ts.map +1 -1
  10. package/dist/calendar/MonthSwitcher/MonthSwitcher.svelte +140 -125
  11. package/dist/calendar/MonthSwitcher/MonthSwitcher.svelte.d.ts +2 -0
  12. package/dist/calendar/MonthSwitcher/MonthSwitcher.svelte.d.ts.map +1 -1
  13. package/dist/calendar/OrderSummary/OrderSummary.spec.js +3 -3
  14. package/dist/calendar/OrderSummary/OrderSummary.svelte +461 -457
  15. package/dist/calendar/OrderSummary/OrderSummary.svelte.d.ts +4 -2
  16. package/dist/calendar/OrderSummary/OrderSummary.svelte.d.ts.map +1 -1
  17. package/dist/calendar/PublicCard/PublicCard.svelte +164 -155
  18. package/dist/calendar/PublicCard/PublicCard.svelte.d.ts +4 -0
  19. package/dist/calendar/PublicCard/PublicCard.svelte.d.ts.map +1 -1
  20. package/dist/calendar/ShowCard/ShowCard.svelte +180 -166
  21. package/dist/calendar/ShowCard/ShowCard.svelte.d.ts +4 -0
  22. package/dist/calendar/ShowCard/ShowCard.svelte.d.ts.map +1 -1
  23. package/dist/calendar/ShowTimeCard/ShowTimeCard.svelte +80 -72
  24. package/dist/calendar/ShowTimeCard/ShowTimeCard.svelte.d.ts +4 -0
  25. package/dist/calendar/ShowTimeCard/ShowTimeCard.svelte.d.ts.map +1 -1
  26. package/dist/calendar/index.js +15 -15
  27. package/dist/components/Heading.spec.js +89 -89
  28. package/dist/components/Heading.svelte +60 -60
  29. package/dist/components/Layout/AppShell.svelte +104 -104
  30. package/dist/components/Layout/ContentSection.svelte +80 -80
  31. package/dist/components/Layout/Grid.svelte +101 -101
  32. package/dist/components/Layout/Heading.svelte +81 -81
  33. package/dist/components/Layout/PageContainer.svelte +69 -69
  34. package/dist/components/Layout/Responsive.svelte +75 -75
  35. package/dist/components/Layout/Section.svelte +80 -80
  36. package/dist/components/Layout/ShowOnDesktop.svelte +37 -37
  37. package/dist/components/Layout/ShowOnMobile.svelte +37 -37
  38. package/dist/components/Layout/Sidebar.svelte +108 -108
  39. package/dist/components/Layout/Stack.spec.js +1 -1
  40. package/dist/components/Layout/Stack.svelte +52 -52
  41. package/dist/components/Layout/Text.svelte +87 -87
  42. package/dist/components/Layout/TwoColumn.svelte +108 -108
  43. package/dist/components/Text.spec.js +89 -89
  44. package/dist/components/Text.svelte +53 -53
  45. package/dist/config.js +151 -151
  46. package/dist/config.spec.js +29 -29
  47. package/dist/constants/formOptions.js +48 -48
  48. package/dist/constants/validation.js +91 -91
  49. package/dist/constants/validation.spec.js +64 -64
  50. package/dist/datetime/README.md +323 -323
  51. package/dist/datetime/__tests__/format.test.js +1 -1
  52. package/dist/datetime/__tests__/parse.test.js +1 -1
  53. package/dist/datetime/__tests__/timezone.test.js +1 -1
  54. package/dist/datetime/parse.js +1 -1
  55. package/dist/forms/createFormStore.svelte.js +1 -0
  56. package/dist/forms/createFormStore.svelte.spec.js +1 -0
  57. package/dist/index.d.ts +1 -0
  58. package/dist/index.d.ts.map +1 -1
  59. package/dist/index.js +66 -57
  60. package/dist/index.spec.js +369 -369
  61. package/dist/patterns/chat/ChatActivityNotice.spec.js +59 -59
  62. package/dist/patterns/chat/ChatActivityNotice.svelte +41 -41
  63. package/dist/patterns/chat/ChatBubble.spec.js +91 -91
  64. package/dist/patterns/chat/ChatBubble.svelte +103 -95
  65. package/dist/patterns/chat/ChatBubble.svelte.d.ts +6 -4
  66. package/dist/patterns/chat/ChatBubble.svelte.d.ts.map +1 -1
  67. package/dist/patterns/chat/ChatContainer.spec.js +30 -30
  68. package/dist/patterns/chat/ChatContainer.svelte +46 -46
  69. package/dist/patterns/chat/ChatDateDivider.spec.js +30 -30
  70. package/dist/patterns/chat/ChatDateDivider.svelte +27 -27
  71. package/dist/patterns/chat/ChatInvitationBubble.spec.js +46 -46
  72. package/dist/patterns/chat/ChatInvitationBubble.svelte +46 -37
  73. package/dist/patterns/chat/ChatInvitationBubble.svelte.d.ts +6 -3
  74. package/dist/patterns/chat/ChatInvitationBubble.svelte.d.ts.map +1 -1
  75. package/dist/patterns/chat/ChatInvitationNotice.spec.js +32 -32
  76. package/dist/patterns/chat/ChatInvitationNotice.svelte +36 -27
  77. package/dist/patterns/chat/ChatInvitationNotice.svelte.d.ts +6 -3
  78. package/dist/patterns/chat/ChatInvitationNotice.svelte.d.ts.map +1 -1
  79. package/dist/patterns/chat/ChatMessageGroup.spec.js +58 -58
  80. package/dist/patterns/chat/ChatMessageGroup.svelte +57 -57
  81. package/dist/patterns/chat/ChatSlotUpdate.spec.js +65 -65
  82. package/dist/patterns/chat/ChatSlotUpdate.svelte +46 -46
  83. package/dist/patterns/chat/ChatStatusBadge.spec.js +79 -79
  84. package/dist/patterns/chat/ChatStatusBadge.svelte +91 -91
  85. package/dist/patterns/chat/ChatStatusTransition.spec.js +81 -81
  86. package/dist/patterns/chat/ChatStatusTransition.svelte +64 -64
  87. package/dist/patterns/chat/ChatTextBubble.spec.js +35 -35
  88. package/dist/patterns/chat/ChatTextBubble.svelte +41 -41
  89. package/dist/patterns/chat/index.js +22 -22
  90. package/dist/patterns/data/DataGrid.svelte +45 -45
  91. package/dist/patterns/data/DataList.svelte +24 -24
  92. package/dist/patterns/data/DataTable.svelte +45 -45
  93. package/dist/patterns/data/index.js +4 -4
  94. package/dist/patterns/forms/FormActions.spec.js +95 -95
  95. package/dist/patterns/forms/FormActions.stories.svelte +97 -97
  96. package/dist/patterns/forms/FormActions.svelte +46 -46
  97. package/dist/patterns/forms/FormGrid.svelte +33 -33
  98. package/dist/patterns/forms/FormSection.svelte +32 -32
  99. package/dist/patterns/forms/FormValidationSummary.stories.svelte +97 -97
  100. package/dist/patterns/forms/FormValidationSummary.svelte +82 -74
  101. package/dist/patterns/forms/FormValidationSummary.svelte.d.ts +5 -3
  102. package/dist/patterns/forms/FormValidationSummary.svelte.d.ts.map +1 -1
  103. package/dist/patterns/forms/index.js +5 -5
  104. package/dist/patterns/index.js +21 -21
  105. package/dist/patterns/layout/Sidebar.svelte +39 -39
  106. package/dist/patterns/layout/SidebarTestWrapper.svelte +34 -34
  107. package/dist/patterns/layout/SidebarTestWrapper.svelte.d.ts +1 -1
  108. package/dist/patterns/layout/Stack.svelte +61 -61
  109. package/dist/patterns/layout/index.js +29 -29
  110. package/dist/patterns/navigation/BottomNav.stories.svelte +117 -117
  111. package/dist/patterns/navigation/BottomNav.svelte +82 -74
  112. package/dist/patterns/navigation/BottomNav.svelte.d.ts +10 -9
  113. package/dist/patterns/navigation/BottomNav.svelte.d.ts.map +1 -1
  114. package/dist/patterns/navigation/Header.stories.svelte +77 -77
  115. package/dist/patterns/navigation/Header.svelte +263 -251
  116. package/dist/patterns/navigation/Header.svelte.d.ts +17 -9
  117. package/dist/patterns/navigation/Header.svelte.d.ts.map +1 -1
  118. package/dist/patterns/navigation/index.js +3 -3
  119. package/dist/patterns/page/PageHeader.svelte +49 -49
  120. package/dist/patterns/page/PageLayout.svelte +40 -40
  121. package/dist/patterns/page/PageLoader.spec.js +57 -57
  122. package/dist/patterns/page/PageLoader.stories.svelte +137 -137
  123. package/dist/patterns/page/PageLoader.svelte +62 -53
  124. package/dist/patterns/page/PageLoader.svelte.d.ts +6 -3
  125. package/dist/patterns/page/PageLoader.svelte.d.ts.map +1 -1
  126. package/dist/patterns/page/SectionHeader.svelte +51 -51
  127. package/dist/patterns/page/index.js +5 -5
  128. package/dist/presets/badges.js +112 -112
  129. package/dist/presets/buttons.js +76 -76
  130. package/dist/presets/index.js +9 -9
  131. package/dist/primitives/Accordion/Accordion.stories.svelte +75 -75
  132. package/dist/primitives/Accordion/Accordion.svelte +62 -62
  133. package/dist/primitives/Accordion/AccordionItem.svelte +103 -95
  134. package/dist/primitives/Accordion/AccordionItem.svelte.d.ts +6 -4
  135. package/dist/primitives/Accordion/AccordionItem.svelte.d.ts.map +1 -1
  136. package/dist/primitives/Accordion/AccordionItemWrapper.test.svelte +107 -107
  137. package/dist/primitives/Accordion/AccordionToggleWrapper.test.svelte +28 -28
  138. package/dist/primitives/Alert/Alert.spec.js +173 -173
  139. package/dist/primitives/Alert/Alert.stories.svelte +88 -88
  140. package/dist/primitives/Alert/Alert.svelte +72 -64
  141. package/dist/primitives/Alert/Alert.svelte.d.ts +6 -4
  142. package/dist/primitives/Alert/Alert.svelte.d.ts.map +1 -1
  143. package/dist/primitives/Avatar/Avatar.stories.svelte +94 -94
  144. package/dist/primitives/Avatar/Avatar.svelte +66 -66
  145. package/dist/primitives/AvatarButton/AvatarButton.svelte +57 -57
  146. package/dist/primitives/Badges/Badge.spec.js +144 -144
  147. package/dist/primitives/Badges/Badge.stories.svelte +86 -86
  148. package/dist/primitives/Badges/Badge.svelte +99 -99
  149. package/dist/primitives/BottomSheet/BottomSheet.spec.js +238 -238
  150. package/dist/primitives/BottomSheet/BottomSheet.stories.svelte +83 -83
  151. package/dist/primitives/BottomSheet/BottomSheet.svelte +115 -115
  152. package/dist/primitives/BottomSheet/BottomSheetWithActions.test.svelte +20 -20
  153. package/dist/primitives/Breadcrumb/Breadcrumb.spec.js +123 -123
  154. package/dist/primitives/Breadcrumb/Breadcrumb.stories.svelte +23 -23
  155. package/dist/primitives/Breadcrumb/Breadcrumb.svelte +107 -99
  156. package/dist/primitives/Breadcrumb/Breadcrumb.svelte.d.ts +13 -9
  157. package/dist/primitives/Breadcrumb/Breadcrumb.svelte.d.ts.map +1 -1
  158. package/dist/primitives/Button/Button.spec.js +225 -225
  159. package/dist/primitives/Button/Button.stories.svelte +76 -76
  160. package/dist/primitives/Button/Button.svelte +278 -278
  161. package/dist/primitives/Button/ButtonGroup.spec.js +44 -44
  162. package/dist/primitives/Button/ButtonGroup.svelte +50 -50
  163. package/dist/primitives/Button/ButtonSaveDemo.spec.js +146 -146
  164. package/dist/primitives/Button/ButtonSaveDemo.svelte +25 -25
  165. package/dist/primitives/Button/ButtonVariantShowcase.svelte +129 -129
  166. package/dist/primitives/Card.spec.js +49 -49
  167. package/dist/primitives/Card.stories.svelte +22 -22
  168. package/dist/primitives/Card.svelte +28 -28
  169. package/dist/primitives/CardAction/CardAction.svelte +68 -68
  170. package/dist/primitives/Checkbox/Checkbox.stories.svelte +84 -84
  171. package/dist/primitives/Checkbox/Checkbox.svelte +88 -88
  172. package/dist/primitives/DarkModeToggle.spec.js +390 -390
  173. package/dist/primitives/DarkModeToggle.stories.svelte +57 -57
  174. package/dist/primitives/DarkModeToggle.svelte +147 -136
  175. package/dist/primitives/DarkModeToggle.svelte.d.ts +9 -3
  176. package/dist/primitives/DarkModeToggle.svelte.d.ts.map +1 -1
  177. package/dist/primitives/Drawer/Drawer.stories.svelte +100 -100
  178. package/dist/primitives/Drawer/Drawer.svelte +224 -224
  179. package/dist/primitives/Drawer/DrawerTestWrapper.svelte +86 -86
  180. package/dist/primitives/Dropdown/Dropdown.stories.svelte +137 -137
  181. package/dist/primitives/Dropdown/Dropdown.svelte +179 -170
  182. package/dist/primitives/Dropdown/Dropdown.svelte.d.ts +7 -4
  183. package/dist/primitives/Dropdown/Dropdown.svelte.d.ts.map +1 -1
  184. package/dist/primitives/Dropdown/DropdownDivider.spec.js +30 -30
  185. package/dist/primitives/Dropdown/DropdownDivider.svelte +9 -9
  186. package/dist/primitives/Dropdown/DropdownItem.svelte +80 -80
  187. package/dist/primitives/Dropdown/DropdownItemTestWrapper.svelte +43 -43
  188. package/dist/primitives/Helper/Helper.spec.js +57 -57
  189. package/dist/primitives/Helper/Helper.svelte +33 -33
  190. package/dist/primitives/Icons/ArrowLeft.svelte +21 -21
  191. package/dist/primitives/Icons/ArrowRight.svelte +21 -21
  192. package/dist/primitives/Icons/Availability.svelte +27 -27
  193. package/dist/primitives/Icons/Back.svelte +27 -27
  194. package/dist/primitives/Icons/CheckCircle.svelte +19 -19
  195. package/dist/primitives/Icons/CheckCircleOutline.svelte +28 -28
  196. package/dist/primitives/Icons/ChevronLeft.svelte +17 -17
  197. package/dist/primitives/Icons/ChevronRight.svelte +17 -17
  198. package/dist/primitives/Icons/Copy.svelte +28 -28
  199. package/dist/primitives/Icons/Cross.svelte +18 -18
  200. package/dist/primitives/Icons/DownArrow.svelte +21 -21
  201. package/dist/primitives/Icons/ErrorCircle.svelte +19 -19
  202. package/dist/primitives/Icons/FacebookIcon.svelte +15 -15
  203. package/dist/primitives/Icons/Home.svelte +28 -28
  204. package/dist/primitives/Icons/Icon.spec.js +175 -175
  205. package/dist/primitives/Icons/Icon.stories.svelte +100 -100
  206. package/dist/primitives/Icons/Icon.svelte +79 -79
  207. package/dist/primitives/Icons/IconGallery.stories.svelte +235 -235
  208. package/dist/primitives/Icons/ImageOutline.svelte +21 -21
  209. package/dist/primitives/Icons/Info.svelte +20 -20
  210. package/dist/primitives/Icons/InstagramIcon.svelte +21 -21
  211. package/dist/primitives/Icons/LogoInstagram.svelte +15 -15
  212. package/dist/primitives/Icons/Message.svelte +28 -28
  213. package/dist/primitives/Icons/MoonIcon.svelte +18 -18
  214. package/dist/primitives/Icons/More.svelte +34 -34
  215. package/dist/primitives/Icons/MoreHori.spec.js +67 -67
  216. package/dist/primitives/Icons/MoreHori.svelte +35 -35
  217. package/dist/primitives/Icons/Notification.svelte +27 -27
  218. package/dist/primitives/Icons/Payment.svelte +27 -27
  219. package/dist/primitives/Icons/Profile.svelte +34 -34
  220. package/dist/primitives/Icons/Reload.svelte +42 -42
  221. package/dist/primitives/Icons/Shows.svelte +34 -34
  222. package/dist/primitives/Icons/Signout.svelte +34 -34
  223. package/dist/primitives/Icons/SunIcon.svelte +21 -21
  224. package/dist/primitives/Icons/TiktokIcon.svelte +15 -15
  225. package/dist/primitives/Icons/TrashBinOutline.svelte +21 -21
  226. package/dist/primitives/Icons/TwitterIcon.svelte +15 -15
  227. package/dist/primitives/Icons/WarningIcon.spec.js +30 -30
  228. package/dist/primitives/Icons/WarningIcon.svelte +24 -24
  229. package/dist/primitives/Input/Input.spec.js +1237 -1237
  230. package/dist/primitives/Input/Input.stories.svelte +139 -139
  231. package/dist/primitives/Input/Input.svelte +444 -431
  232. package/dist/primitives/Input/Input.svelte.d.ts.map +1 -1
  233. package/dist/primitives/Input/Select.spec.js +632 -632
  234. package/dist/primitives/Input/Select.stories.svelte +112 -112
  235. package/dist/primitives/Input/Select.svelte +252 -252
  236. package/dist/primitives/Input/Textarea.stories.svelte +137 -137
  237. package/dist/primitives/Input/Textarea.svelte +105 -105
  238. package/dist/primitives/Label/Label.svelte +37 -37
  239. package/dist/primitives/LandingButton/LandingButton.spec.js +61 -61
  240. package/dist/primitives/LandingButton/LandingButton.svelte +92 -92
  241. package/dist/primitives/MenuItem/MenuItem.spec.js +130 -130
  242. package/dist/primitives/MenuItem/MenuItem.svelte +85 -85
  243. package/dist/primitives/Modal/Modal.spec.js +314 -314
  244. package/dist/primitives/Modal/Modal.stories.svelte +86 -86
  245. package/dist/primitives/Modal/Modal.svelte +181 -181
  246. package/dist/primitives/NavItem/NavItem.spec.js +97 -97
  247. package/dist/primitives/NavItem/NavItem.svelte +75 -75
  248. package/dist/primitives/NumberInput/NumberInput.svelte +113 -105
  249. package/dist/primitives/NumberInput/NumberInput.svelte.d.ts.map +1 -1
  250. package/dist/primitives/Pagination/Pagination.stories.svelte +76 -76
  251. package/dist/primitives/Pagination/Pagination.svelte +275 -261
  252. package/dist/primitives/Pagination/Pagination.svelte.d.ts +14 -6
  253. package/dist/primitives/Pagination/Pagination.svelte.d.ts.map +1 -1
  254. package/dist/primitives/Radio/Radio.stories.svelte +80 -80
  255. package/dist/primitives/Radio/Radio.svelte +67 -67
  256. package/dist/primitives/SearchResultItem/SearchResultItem.spec.js +78 -78
  257. package/dist/primitives/SearchResultItem/SearchResultItem.svelte +109 -109
  258. package/dist/primitives/SidebarToggle/SidebarToggle.spec.js +61 -61
  259. package/dist/primitives/SidebarToggle/SidebarToggle.svelte +55 -55
  260. package/dist/primitives/Skeleton/CardPlaceholder.svelte +96 -87
  261. package/dist/primitives/Skeleton/CardPlaceholder.svelte.d.ts +8 -5
  262. package/dist/primitives/Skeleton/CardPlaceholder.svelte.d.ts.map +1 -1
  263. package/dist/primitives/Skeleton/ImagePlaceholder.svelte +68 -59
  264. package/dist/primitives/Skeleton/ImagePlaceholder.svelte.d.ts +8 -5
  265. package/dist/primitives/Skeleton/ImagePlaceholder.svelte.d.ts.map +1 -1
  266. package/dist/primitives/Skeleton/ListPlaceholder.svelte +85 -76
  267. package/dist/primitives/Skeleton/ListPlaceholder.svelte.d.ts +8 -5
  268. package/dist/primitives/Skeleton/ListPlaceholder.svelte.d.ts.map +1 -1
  269. package/dist/primitives/Skeleton/Skeleton.stories.svelte +151 -151
  270. package/dist/primitives/Skeleton/Skeleton.svelte +55 -46
  271. package/dist/primitives/Skeleton/Skeleton.svelte.d.ts +7 -4
  272. package/dist/primitives/Skeleton/Skeleton.svelte.d.ts.map +1 -1
  273. package/dist/primitives/Spinner/Spinner.spec.js +84 -84
  274. package/dist/primitives/Spinner/Spinner.stories.svelte +29 -29
  275. package/dist/primitives/Spinner/Spinner.svelte +52 -44
  276. package/dist/primitives/Spinner/Spinner.svelte.d.ts +6 -4
  277. package/dist/primitives/Spinner/Spinner.svelte.d.ts.map +1 -1
  278. package/dist/primitives/Tabs/TabItem.svelte +52 -52
  279. package/dist/primitives/Tabs/Tabs.stories.svelte +112 -112
  280. package/dist/primitives/Tabs/Tabs.svelte +137 -137
  281. package/dist/primitives/Toggle.spec.js +221 -221
  282. package/dist/primitives/Toggle.stories.svelte +92 -92
  283. package/dist/primitives/Toggle.svelte +141 -141
  284. package/dist/primitives/ToggleTestWrapper.svelte +30 -30
  285. package/dist/primitives/Tooltip/Tooltip.spec.js +126 -126
  286. package/dist/primitives/Tooltip/Tooltip.svelte +83 -83
  287. package/dist/primitives/Typography/Typography.svelte +53 -53
  288. package/dist/primitives/ValidationError.spec.js +103 -103
  289. package/dist/primitives/ValidationError.stories.svelte +112 -112
  290. package/dist/primitives/ValidationError.svelte +29 -29
  291. package/dist/primitives/index.js +113 -113
  292. package/dist/recipes/CropImage/CropImage.spec.js +208 -208
  293. package/dist/recipes/CropImage/CropImage.stories.svelte +104 -104
  294. package/dist/recipes/CropImage/CropImage.svelte +241 -241
  295. package/dist/recipes/ImageUploader/ImageUploader.stories.svelte +125 -125
  296. package/dist/recipes/ImageUploader/ImageUploader.svelte +994 -992
  297. package/dist/recipes/ImageUploader/ImageUploader.svelte.d.ts +1 -0
  298. package/dist/recipes/ImageUploader/ImageUploader.svelte.d.ts.map +1 -1
  299. package/dist/recipes/SuperLogin/SuperLogin.svelte +25 -23
  300. package/dist/recipes/SuperLogin/SuperLogin.svelte.d.ts.map +1 -1
  301. package/dist/recipes/Toaster/Toaster.stories.svelte +62 -62
  302. package/dist/recipes/feedback/EmptyState/EmptyState.svelte +75 -66
  303. package/dist/recipes/feedback/EmptyState/EmptyState.svelte.d.ts +7 -4
  304. package/dist/recipes/feedback/EmptyState/EmptyState.svelte.d.ts.map +1 -1
  305. package/dist/recipes/feedback/ErrorDisplay.spec.js +69 -69
  306. package/dist/recipes/feedback/ErrorDisplay.stories.svelte +113 -113
  307. package/dist/recipes/feedback/ErrorDisplay.svelte +67 -67
  308. package/dist/recipes/feedback/StatusIndicator/StatusIndicator.spec.js +133 -133
  309. package/dist/recipes/feedback/StatusIndicator/StatusIndicator.svelte +176 -176
  310. package/dist/recipes/feedback/index.js +4 -4
  311. package/dist/recipes/fields/CheckboxField.svelte +85 -85
  312. package/dist/recipes/fields/FormField.svelte +58 -58
  313. package/dist/recipes/fields/RadioGroup.svelte +95 -95
  314. package/dist/recipes/fields/SelectField.svelte +82 -82
  315. package/dist/recipes/fields/TextareaField.svelte +101 -101
  316. package/dist/recipes/fields/ToggleField.svelte +60 -60
  317. package/dist/recipes/fields/index.js +7 -7
  318. package/dist/recipes/index.js +24 -24
  319. package/dist/recipes/inputs/MultiSelect.spec.js +263 -263
  320. package/dist/recipes/inputs/MultiSelect.stories.svelte +133 -133
  321. package/dist/recipes/inputs/MultiSelect.svelte +291 -283
  322. package/dist/recipes/inputs/MultiSelect.svelte.d.ts.map +1 -1
  323. package/dist/recipes/inputs/OTPInput.spec.js +251 -251
  324. package/dist/recipes/inputs/OTPInput.stories.svelte +162 -162
  325. package/dist/recipes/inputs/OTPInput.svelte +128 -117
  326. package/dist/recipes/inputs/OTPInput.svelte.d.ts +14 -12
  327. package/dist/recipes/inputs/OTPInput.svelte.d.ts.map +1 -1
  328. package/dist/recipes/inputs/PasswordInput.svelte +130 -121
  329. package/dist/recipes/inputs/PasswordInput.svelte.d.ts +7 -4
  330. package/dist/recipes/inputs/PasswordInput.svelte.d.ts.map +1 -1
  331. package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.svelte +142 -131
  332. package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.svelte.d.ts +8 -3
  333. package/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.svelte.d.ts.map +1 -1
  334. package/dist/recipes/inputs/PhoneInput.svelte +254 -0
  335. package/dist/recipes/inputs/PhoneInput.svelte.d.ts +40 -0
  336. package/dist/recipes/inputs/PhoneInput.svelte.d.ts.map +1 -0
  337. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.stories.svelte +170 -170
  338. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte +349 -336
  339. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte.d.ts +21 -16
  340. package/dist/recipes/inputs/PlaceAutocomplete/PlaceAutocomplete.svelte.d.ts.map +1 -1
  341. package/dist/recipes/inputs/Search.svelte +110 -102
  342. package/dist/recipes/inputs/Search.svelte.d.ts +7 -5
  343. package/dist/recipes/inputs/Search.svelte.d.ts.map +1 -1
  344. package/dist/recipes/inputs/index.d.ts +1 -0
  345. package/dist/recipes/inputs/index.js +8 -7
  346. package/dist/recipes/inputs/phoneInput/CountrySelector.svelte +240 -0
  347. package/dist/recipes/inputs/phoneInput/CountrySelector.svelte.d.ts +15 -0
  348. package/dist/recipes/inputs/phoneInput/CountrySelector.svelte.d.ts.map +1 -0
  349. package/dist/recipes/inputs/phoneInput/countryData.d.ts +18 -0
  350. package/dist/recipes/inputs/phoneInput/countryData.d.ts.map +1 -0
  351. package/dist/recipes/inputs/phoneInput/countryData.js +211 -0
  352. package/dist/recipes/modals/AlertModal.svelte +139 -130
  353. package/dist/recipes/modals/AlertModal.svelte.d.ts +4 -2
  354. package/dist/recipes/modals/AlertModal.svelte.d.ts.map +1 -1
  355. package/dist/recipes/modals/ConfirmationModal.spec.js +396 -396
  356. package/dist/recipes/modals/ConfirmationModal.stories.svelte +119 -119
  357. package/dist/recipes/modals/ConfirmationModal.svelte +169 -162
  358. package/dist/recipes/modals/ConfirmationModal.svelte.d.ts +2 -0
  359. package/dist/recipes/modals/ConfirmationModal.svelte.d.ts.map +1 -1
  360. package/dist/recipes/modals/InputModal.svelte +194 -182
  361. package/dist/recipes/modals/InputModal.svelte.d.ts +6 -4
  362. package/dist/recipes/modals/InputModal.svelte.d.ts.map +1 -1
  363. package/dist/recipes/modals/ModalStateManager.spec.js +100 -100
  364. package/dist/recipes/modals/ModalStateManager.svelte +77 -77
  365. package/dist/recipes/modals/ModalTestWrapper.svelte +65 -65
  366. package/dist/recipes/modals/StatusModal.svelte +216 -206
  367. package/dist/recipes/modals/StatusModal.svelte.d.ts +4 -2
  368. package/dist/recipes/modals/StatusModal.svelte.d.ts.map +1 -1
  369. package/dist/recipes/modals/index.js +7 -7
  370. package/dist/schemas/common.js +1 -1
  371. package/dist/schemas/event.d.ts +4 -4
  372. package/dist/schemas/event.js +1 -1
  373. package/dist/schemas/order.d.ts +2 -2
  374. package/dist/schemas/order.js +1 -0
  375. package/dist/schemas/performer.js +1 -1
  376. package/dist/schemas/promo.d.ts +4 -4
  377. package/dist/schemas/promo.js +2 -2
  378. package/dist/schemas/ticket.js +1 -1
  379. package/dist/schemas/user.js +2 -1
  380. package/dist/services/event.service.d.ts +11 -0
  381. package/dist/services/event.service.d.ts.map +1 -0
  382. package/dist/services/event.service.js +64 -0
  383. package/dist/services/event.service.spec.d.ts +2 -0
  384. package/dist/services/event.service.spec.d.ts.map +1 -0
  385. package/dist/services/event.service.spec.js +168 -0
  386. package/dist/services/{ShowService.d.ts → show.service.d.ts} +47 -47
  387. package/dist/services/show.service.d.ts.map +1 -0
  388. package/dist/services/show.service.js +115 -0
  389. package/dist/services/show.service.spec.d.ts +2 -0
  390. package/dist/services/show.service.spec.d.ts.map +1 -0
  391. package/dist/services/show.service.spec.js +242 -0
  392. package/dist/stores/auth.d.ts +8 -8
  393. package/dist/stores/auth.svelte.spec.js +1 -1
  394. package/dist/stores/index.js +9 -9
  395. package/dist/stores/toaster.d.ts +3 -3
  396. package/dist/stores/toaster.js +13 -13
  397. package/dist/stores/toaster.spec.js +59 -59
  398. package/dist/stories/ButtonAuditReview.stories.svelte +14 -14
  399. package/dist/stories/ButtonAuditReview.svelte +427 -427
  400. package/dist/stories/PatternsGallery.stories.svelte +19 -19
  401. package/dist/stories/PatternsGallery.svelte +399 -399
  402. package/dist/stories/PrimitivesGallery.stories.svelte +19 -19
  403. package/dist/stories/PrimitivesGallery.svelte +756 -756
  404. package/dist/stories/RecipesGallery.stories.svelte +19 -19
  405. package/dist/stories/RecipesGallery.svelte +454 -454
  406. package/dist/stories/button-audit-manifest.json +11186 -11186
  407. package/dist/tailwind/preset.cjs +82 -82
  408. package/dist/telemetry.js +402 -402
  409. package/dist/telemetry.server.js +212 -212
  410. package/dist/telemetry.server.spec.js +437 -437
  411. package/dist/telemetry.spec.js +1173 -1173
  412. package/dist/tokens/tokens.css +87 -87
  413. package/dist/tokens/typography-base.css +163 -163
  414. package/dist/tokens/utilities.css +353 -353
  415. package/dist/utils/__tests__/auth.test.js +431 -431
  416. package/dist/utils/apiConfig.d.ts +29 -29
  417. package/dist/utils/apiConfig.js +117 -117
  418. package/dist/utils/apiConfig.spec.js +219 -219
  419. package/dist/utils/assets.d.ts +3 -0
  420. package/dist/utils/assets.d.ts.map +1 -0
  421. package/dist/utils/assets.js +3 -0
  422. package/dist/utils/auth.d.ts +46 -46
  423. package/dist/utils/auth.js +195 -195
  424. package/dist/utils/classNames.d.ts +10 -0
  425. package/dist/utils/classNames.d.ts.map +1 -0
  426. package/dist/utils/classNames.js +15 -0
  427. package/dist/utils/cookieHelpers.d.ts +40 -0
  428. package/dist/utils/cookieHelpers.d.ts.map +1 -0
  429. package/dist/utils/cookieHelpers.js +102 -0
  430. package/dist/utils/dateHelpers.d.ts +71 -0
  431. package/dist/utils/dateHelpers.d.ts.map +1 -0
  432. package/dist/utils/dateHelpers.js +253 -0
  433. package/dist/utils/eventFormatters.d.ts +9 -0
  434. package/dist/utils/eventFormatters.d.ts.map +1 -0
  435. package/dist/utils/eventFormatters.js +96 -0
  436. package/dist/utils/fetchHelpers.d.ts +17 -0
  437. package/dist/utils/fetchHelpers.d.ts.map +1 -0
  438. package/dist/utils/fetchHelpers.js +44 -0
  439. package/dist/utils/formatters.d.ts +62 -0
  440. package/dist/utils/formatters.d.ts.map +1 -1
  441. package/dist/utils/formatters.js +128 -0
  442. package/dist/utils/formatters.spec.js +128 -1
  443. package/dist/utils/greetings.js +187 -187
  444. package/dist/utils/greetings.spec.js +337 -337
  445. package/dist/utils/haptic.spec.js +1 -1
  446. package/dist/utils/imageValidation.js +121 -121
  447. package/dist/utils/imageValidation.spec.js +223 -223
  448. package/dist/utils/permissions.d.ts +9 -0
  449. package/dist/utils/permissions.d.ts.map +1 -0
  450. package/dist/utils/permissions.js +93 -0
  451. package/dist/utils/phoneUtils.d.ts +35 -0
  452. package/dist/utils/phoneUtils.d.ts.map +1 -0
  453. package/dist/utils/phoneUtils.js +104 -0
  454. package/dist/utils/portal.d.ts +11 -11
  455. package/dist/utils/portal.js +25 -25
  456. package/dist/utils/portal.spec.js +143 -143
  457. package/dist/utils/stringHelpers.d.ts +17 -0
  458. package/dist/utils/stringHelpers.d.ts.map +1 -0
  459. package/dist/utils/stringHelpers.js +38 -0
  460. package/dist/utils/transitions.js +4 -4
  461. package/dist/utils/utils/utils.d.ts +2 -73
  462. package/dist/utils/utils/utils.d.ts.map +1 -1
  463. package/dist/utils/utils/utils.js +3 -3
  464. package/dist/utils/utils/utils.spec.js +698 -698
  465. package/dist/utils/utils.d.ts +41 -98
  466. package/dist/utils/utils.d.ts.map +1 -1
  467. package/dist/utils/utils.js +59 -693
  468. package/dist/utils/utils.spec.js +643 -643
  469. package/package.json +301 -292
  470. package/dist/services/EventService.d.ts +0 -5
  471. package/dist/services/EventService.d.ts.map +0 -1
  472. package/dist/services/EventService.js +0 -79
  473. package/dist/services/EventService.spec.d.ts +0 -2
  474. package/dist/services/EventService.spec.d.ts.map +0 -1
  475. package/dist/services/EventService.spec.js +0 -217
  476. package/dist/services/ShowService.d.ts.map +0 -1
  477. package/dist/services/ShowService.js +0 -144
  478. package/dist/services/ShowService.spec.d.ts +0 -2
  479. package/dist/services/ShowService.spec.d.ts.map +0 -1
  480. package/dist/services/ShowService.spec.js +0 -345
@@ -1,323 +1,323 @@
1
- # DateTime Module
2
-
3
- Centralized date/time handling for the MicDrop platform. This module eliminates timezone bugs by enforcing consistent patterns across the application.
4
-
5
- ## Golden Rules
6
-
7
- 1. **Backend is King** - All API requests send/receive UTC ISO strings (`2023-12-25T20:00:00Z`)
8
- 2. **Display is Local** - All UI components receive UTC strings + Timezone ID
9
- 3. **No `new Date()` in components** - Use these helpers instead
10
- 4. **Timezone is always required** - Every function requires explicit timezone parameter
11
-
12
- ## Quick Start
13
-
14
- ```typescript
15
- import * as datetime from '$lib/datetime';
16
-
17
- // Get timezone from venue (throws if missing)
18
- const tz = datetime.getVenueTimezone(venue);
19
-
20
- // Format for display
21
- const time = datetime.formatEventTime(event.startTime, tz); // "7:00 PM"
22
- const date = datetime.formatEventDate(event.startTime, tz); // "Dec 25, 2023"
23
- const full = datetime.formatEventDateTime(event.startTime, tz); // "Dec 25, 2023 at 7:00 PM"
24
-
25
- // Parse form input to UTC for API
26
- const utc = datetime.combineDateAndTime('2023-12-25', '19:00', tz);
27
-
28
- // Parse API response for form
29
- const { date, time } = datetime.parseDateTimeFromAPI(event.startTime, tz);
30
- ```
31
-
32
- ## Module Structure
33
-
34
- ```
35
- src/lib/datetime/
36
- ├── index.ts # Clean exports
37
- ├── types.ts # Type definitions
38
- ├── constants.ts # Duration constants, format strings
39
- ├── timezone.ts # Timezone utilities
40
- ├── format.ts # Formatting functions
41
- ├── parse.ts # Parsing functions
42
- ├── __tests__/ # Comprehensive tests
43
- │ ├── timezone.test.ts
44
- │ ├── format.test.ts
45
- │ ├── parse.test.ts
46
- │ └── integration.test.ts
47
- └── README.md # This file
48
- ```
49
-
50
- ## API Reference
51
-
52
- ### Timezone Utilities
53
-
54
- ```typescript
55
- // Validate timezone
56
- isValidTimezone('America/Los_Angeles'); // true
57
- isValidTimezone('PST'); // false (abbreviations not valid)
58
-
59
- // Get venue timezone (throws if missing)
60
- const tz = getVenueTimezone(venue);
61
-
62
- // Get user's browser timezone
63
- const userTz = getUserTimezone();
64
-
65
- // Get timezone offset string
66
- getTimezoneOffset('America/Los_Angeles'); // "PST (UTC-8)"
67
-
68
- // Normalize legacy timezone abbreviations
69
- normalizeTimezone('PST'); // "America/Los_Angeles"
70
-
71
- // Check if DST is active
72
- isDST('America/Los_Angeles', new Date()); // true/false
73
- ```
74
-
75
- ### Format Functions
76
-
77
- All format functions require timezone - no defaults!
78
-
79
- ```typescript
80
- // Time only
81
- formatEventTime('2023-12-26T03:00:00Z', 'America/Los_Angeles');
82
- // "7:00 PM"
83
-
84
- // Date only
85
- formatEventDate('2023-12-26T03:00:00Z', 'America/Los_Angeles');
86
- // "Dec 25, 2023"
87
-
88
- // Full datetime
89
- formatEventDateTime('2023-12-26T03:00:00Z', 'America/Los_Angeles');
90
- // "Dec 25, 2023 at 7:00 PM"
91
-
92
- // Time range
93
- formatTimeRange(startUtc, endUtc, 'America/Los_Angeles');
94
- // "7:00 PM - 10:00 PM"
95
-
96
- // Date range
97
- formatDateRange(startUtc, endUtc, 'America/Los_Angeles');
98
- // "Dec 25 - 27, 2023"
99
-
100
- // Relative time
101
- formatRelativeTime(utcIso, 'America/Los_Angeles');
102
- // "2 hours ago" or "in 3 days"
103
-
104
- // Date parts
105
- getDateParts('2023-12-25T20:00:00Z', 'America/Los_Angeles');
106
- // { day: 'Mon', month: 'Dec', date: 25, year: 2023 }
107
-
108
- // Get hour (0-23)
109
- getHourInTimezone('2023-12-25T20:00:00Z', 'America/Los_Angeles');
110
- // 12
111
-
112
- // Get date string
113
- getDateInTimezone('2023-12-25T20:00:00Z', 'America/Los_Angeles');
114
- // "2023-12-25"
115
- ```
116
-
117
- ### Parse Functions
118
-
119
- ```typescript
120
- // Local datetime to UTC
121
- parseLocalToUTC('2023-12-25T19:00:00', 'America/Los_Angeles');
122
- // "2023-12-26T03:00:00.000Z"
123
-
124
- // UTC to local datetime
125
- parseUTCToLocal('2023-12-26T03:00:00Z', 'America/Los_Angeles');
126
- // "2023-12-25T19:00:00"
127
-
128
- // Combine date and time
129
- combineDateAndTime('2023-12-25', '19:00', 'America/Los_Angeles');
130
- // "2023-12-26T03:00:00.000Z"
131
-
132
- // Parse API response for form
133
- parseDateTimeFromAPI('2023-12-26T03:00:00Z', 'America/Los_Angeles');
134
- // { date: '2023-12-25', time: '19:00' }
135
-
136
- // Start of day in UTC
137
- parseStartOfDay('2023-12-25', 'America/Los_Angeles');
138
- // "2023-12-25T08:00:00.000Z"
139
-
140
- // End of day in UTC
141
- parseEndOfDay('2023-12-25', 'America/Los_Angeles');
142
- // "2023-12-26T07:59:59.000Z"
143
- ```
144
-
145
- ### Next-Day Time Handling
146
-
147
- For overnight events (e.g., 10 PM - 2 AM):
148
-
149
- ```typescript
150
- // Check for next-day prefix
151
- isNextDayTime('+1_02:00'); // true
152
- isNextDayTime('14:00'); // false
153
-
154
- // Strip prefix
155
- stripNextDayPrefix('+1_02:00'); // '02:00'
156
-
157
- // Convert to minutes
158
- parseTimeToMinutes('22:00'); // 1320
159
- parseTimeToMinutes('+1_02:00'); // 1560 (26 hours)
160
-
161
- // Convert back
162
- minutesToTimeString(1320); // '22:00'
163
- minutesToTimeString(1560, true); // '+1_02:00'
164
- ```
165
-
166
- ### Constants
167
-
168
- ```typescript
169
- import {
170
- DURATIONS,
171
- DATE_FORMATS,
172
- EVENT_DEFAULTS,
173
- COMMON_US_TIMEZONES,
174
- } from '$lib/datetime';
175
-
176
- // Durations in milliseconds
177
- DURATIONS.MINUTE; // 60000
178
- DURATIONS.HOUR; // 3600000
179
- DURATIONS.DAY; // 86400000
180
-
181
- // Event defaults
182
- EVENT_DEFAULTS.DEFAULT_DURATION_MINUTES; // 120
183
- EVENT_DEFAULTS.MIN_DURATION_MINUTES; // 15
184
- EVENT_DEFAULTS.DEFAULT_DOORS_BEFORE_MINUTES; // 30
185
-
186
- // Common US timezones for selects
187
- COMMON_US_TIMEZONES;
188
- // [{ id: 'America/Los_Angeles', label: 'Pacific Time (PT)', abbr: 'PT' }, ...]
189
- ```
190
-
191
- ## Common Patterns
192
-
193
- ### Event Form
194
-
195
- ```typescript
196
- // Populating form from API response
197
- function populateForm(event: Event) {
198
- const tz = datetime.getVenueTimezone(event.venue);
199
- const start = datetime.parseDateTimeFromAPI(event.startTime, tz);
200
- const end = datetime.parseDateTimeFromAPI(event.endTime, tz);
201
-
202
- return {
203
- date: start.date,
204
- startTime: start.time,
205
- endTime: end.time,
206
- };
207
- }
208
-
209
- // Submitting form to API
210
- function submitForm(form: FormData, venue: Venue) {
211
- const tz = datetime.getVenueTimezone(venue);
212
-
213
- return {
214
- startTime: datetime.combineDateAndTime(form.date, form.startTime, tz),
215
- endTime: datetime.combineDateAndTime(form.date, form.endTime, tz),
216
- };
217
- }
218
- ```
219
-
220
- ### Calendar Display
221
-
222
- ```typescript
223
- // Display events in venue timezone
224
- function renderEvent(event: Event, venue: Venue) {
225
- const tz = datetime.getVenueTimezone(venue);
226
-
227
- return {
228
- time: datetime.formatEventTime(event.startTime, tz),
229
- date: datetime.formatEventDate(event.startTime, tz),
230
- dateRange: datetime.formatTimeRange(event.startTime, event.endTime, tz),
231
- dateParts: datetime.getDateParts(event.startTime, tz),
232
- };
233
- }
234
- ```
235
-
236
- ### Grouping Events by Date
237
-
238
- ```typescript
239
- function groupByDate(events: Event[], timezone: TimezoneId) {
240
- const groups: Record<string, Event[]> = {};
241
-
242
- for (const event of events) {
243
- const dateKey = datetime.getDateInTimezone(event.startTime, timezone);
244
- groups[dateKey] = groups[dateKey] || [];
245
- groups[dateKey].push(event);
246
- }
247
-
248
- return groups;
249
- }
250
- ```
251
-
252
- ## Error Handling
253
-
254
- All functions throw `DateTimeError` for invalid inputs:
255
-
256
- ```typescript
257
- import { DateTimeError, DateTimeErrorCode } from '$lib/datetime';
258
-
259
- try {
260
- const tz = datetime.getVenueTimezone(venue);
261
- } catch (e) {
262
- if (e instanceof DateTimeError) {
263
- console.error(e.code); // DateTimeErrorCode.MISSING_TIMEZONE
264
- console.error(e.message); // "Venue timezone is required"
265
- console.error(e.details); // { venue: {...} }
266
- }
267
- }
268
- ```
269
-
270
- Error codes:
271
-
272
- - `INVALID_TIMEZONE` - Timezone string is not a valid IANA identifier
273
- - `INVALID_ISO_STRING` - ISO date string is malformed
274
- - `INVALID_DATE` - Date string is invalid
275
- - `INVALID_TIME` - Time string is invalid
276
- - `MISSING_TIMEZONE` - Required timezone is missing
277
- - `PARSE_ERROR` - General parsing error
278
-
279
- ## Migration from Legacy Code
280
-
281
- ### From `src/lib/utils/timezone.js`
282
-
283
- ```typescript
284
- // Before
285
- import { localToUTC, utcToLocal, formatForDisplay } from '$lib/utils/timezone';
286
-
287
- // After
288
- import {
289
- parseLocalToUTC,
290
- parseUTCToLocal,
291
- formatEventDateTime,
292
- } from '$lib/datetime';
293
- ```
294
-
295
- ### From `src/lib/utils/utils.js`
296
-
297
- ```typescript
298
- // Before
299
- import { formatDateTime, formatTimeRange, getDay } from '$lib/utils/utils';
300
-
301
- // After
302
- import {
303
- formatEventDateTime,
304
- formatTimeRange,
305
- formatDayOfWeek,
306
- } from '$lib/datetime';
307
- ```
308
-
309
- ## Testing
310
-
311
- Run tests:
312
-
313
- ```bash
314
- npm run test -- src/lib/datetime
315
- ```
316
-
317
- Run with coverage:
318
-
319
- ```bash
320
- npm run test:coverage -- src/lib/datetime
321
- ```
322
-
323
- Target: 100% coverage for this critical module.
1
+ # DateTime Module
2
+
3
+ Centralized date/time handling for the MicDrop platform. This module eliminates timezone bugs by enforcing consistent patterns across the application.
4
+
5
+ ## Golden Rules
6
+
7
+ 1. **Backend is King** - All API requests send/receive UTC ISO strings (`2023-12-25T20:00:00Z`)
8
+ 2. **Display is Local** - All UI components receive UTC strings + Timezone ID
9
+ 3. **No `new Date()` in components** - Use these helpers instead
10
+ 4. **Timezone is always required** - Every function requires explicit timezone parameter
11
+
12
+ ## Quick Start
13
+
14
+ ```typescript
15
+ import * as datetime from '$lib/datetime';
16
+
17
+ // Get timezone from venue (throws if missing)
18
+ const tz = datetime.getVenueTimezone(venue);
19
+
20
+ // Format for display
21
+ const time = datetime.formatEventTime(event.startTime, tz); // "7:00 PM"
22
+ const date = datetime.formatEventDate(event.startTime, tz); // "Dec 25, 2023"
23
+ const full = datetime.formatEventDateTime(event.startTime, tz); // "Dec 25, 2023 at 7:00 PM"
24
+
25
+ // Parse form input to UTC for API
26
+ const utc = datetime.combineDateAndTime('2023-12-25', '19:00', tz);
27
+
28
+ // Parse API response for form
29
+ const { date, time } = datetime.parseDateTimeFromAPI(event.startTime, tz);
30
+ ```
31
+
32
+ ## Module Structure
33
+
34
+ ```
35
+ src/lib/datetime/
36
+ ├── index.ts # Clean exports
37
+ ├── types.ts # Type definitions
38
+ ├── constants.ts # Duration constants, format strings
39
+ ├── timezone.ts # Timezone utilities
40
+ ├── format.ts # Formatting functions
41
+ ├── parse.ts # Parsing functions
42
+ ├── __tests__/ # Comprehensive tests
43
+ │ ├── timezone.test.ts
44
+ │ ├── format.test.ts
45
+ │ ├── parse.test.ts
46
+ │ └── integration.test.ts
47
+ └── README.md # This file
48
+ ```
49
+
50
+ ## API Reference
51
+
52
+ ### Timezone Utilities
53
+
54
+ ```typescript
55
+ // Validate timezone
56
+ isValidTimezone('America/Los_Angeles'); // true
57
+ isValidTimezone('PST'); // false (abbreviations not valid)
58
+
59
+ // Get venue timezone (throws if missing)
60
+ const tz = getVenueTimezone(venue);
61
+
62
+ // Get user's browser timezone
63
+ const userTz = getUserTimezone();
64
+
65
+ // Get timezone offset string
66
+ getTimezoneOffset('America/Los_Angeles'); // "PST (UTC-8)"
67
+
68
+ // Normalize legacy timezone abbreviations
69
+ normalizeTimezone('PST'); // "America/Los_Angeles"
70
+
71
+ // Check if DST is active
72
+ isDST('America/Los_Angeles', new Date()); // true/false
73
+ ```
74
+
75
+ ### Format Functions
76
+
77
+ All format functions require timezone - no defaults!
78
+
79
+ ```typescript
80
+ // Time only
81
+ formatEventTime('2023-12-26T03:00:00Z', 'America/Los_Angeles');
82
+ // "7:00 PM"
83
+
84
+ // Date only
85
+ formatEventDate('2023-12-26T03:00:00Z', 'America/Los_Angeles');
86
+ // "Dec 25, 2023"
87
+
88
+ // Full datetime
89
+ formatEventDateTime('2023-12-26T03:00:00Z', 'America/Los_Angeles');
90
+ // "Dec 25, 2023 at 7:00 PM"
91
+
92
+ // Time range
93
+ formatTimeRange(startUtc, endUtc, 'America/Los_Angeles');
94
+ // "7:00 PM - 10:00 PM"
95
+
96
+ // Date range
97
+ formatDateRange(startUtc, endUtc, 'America/Los_Angeles');
98
+ // "Dec 25 - 27, 2023"
99
+
100
+ // Relative time
101
+ formatRelativeTime(utcIso, 'America/Los_Angeles');
102
+ // "2 hours ago" or "in 3 days"
103
+
104
+ // Date parts
105
+ getDateParts('2023-12-25T20:00:00Z', 'America/Los_Angeles');
106
+ // { day: 'Mon', month: 'Dec', date: 25, year: 2023 }
107
+
108
+ // Get hour (0-23)
109
+ getHourInTimezone('2023-12-25T20:00:00Z', 'America/Los_Angeles');
110
+ // 12
111
+
112
+ // Get date string
113
+ getDateInTimezone('2023-12-25T20:00:00Z', 'America/Los_Angeles');
114
+ // "2023-12-25"
115
+ ```
116
+
117
+ ### Parse Functions
118
+
119
+ ```typescript
120
+ // Local datetime to UTC
121
+ parseLocalToUTC('2023-12-25T19:00:00', 'America/Los_Angeles');
122
+ // "2023-12-26T03:00:00.000Z"
123
+
124
+ // UTC to local datetime
125
+ parseUTCToLocal('2023-12-26T03:00:00Z', 'America/Los_Angeles');
126
+ // "2023-12-25T19:00:00"
127
+
128
+ // Combine date and time
129
+ combineDateAndTime('2023-12-25', '19:00', 'America/Los_Angeles');
130
+ // "2023-12-26T03:00:00.000Z"
131
+
132
+ // Parse API response for form
133
+ parseDateTimeFromAPI('2023-12-26T03:00:00Z', 'America/Los_Angeles');
134
+ // { date: '2023-12-25', time: '19:00' }
135
+
136
+ // Start of day in UTC
137
+ parseStartOfDay('2023-12-25', 'America/Los_Angeles');
138
+ // "2023-12-25T08:00:00.000Z"
139
+
140
+ // End of day in UTC
141
+ parseEndOfDay('2023-12-25', 'America/Los_Angeles');
142
+ // "2023-12-26T07:59:59.000Z"
143
+ ```
144
+
145
+ ### Next-Day Time Handling
146
+
147
+ For overnight events (e.g., 10 PM - 2 AM):
148
+
149
+ ```typescript
150
+ // Check for next-day prefix
151
+ isNextDayTime('+1_02:00'); // true
152
+ isNextDayTime('14:00'); // false
153
+
154
+ // Strip prefix
155
+ stripNextDayPrefix('+1_02:00'); // '02:00'
156
+
157
+ // Convert to minutes
158
+ parseTimeToMinutes('22:00'); // 1320
159
+ parseTimeToMinutes('+1_02:00'); // 1560 (26 hours)
160
+
161
+ // Convert back
162
+ minutesToTimeString(1320); // '22:00'
163
+ minutesToTimeString(1560, true); // '+1_02:00'
164
+ ```
165
+
166
+ ### Constants
167
+
168
+ ```typescript
169
+ import {
170
+ DURATIONS,
171
+ DATE_FORMATS,
172
+ EVENT_DEFAULTS,
173
+ COMMON_US_TIMEZONES,
174
+ } from '$lib/datetime';
175
+
176
+ // Durations in milliseconds
177
+ DURATIONS.MINUTE; // 60000
178
+ DURATIONS.HOUR; // 3600000
179
+ DURATIONS.DAY; // 86400000
180
+
181
+ // Event defaults
182
+ EVENT_DEFAULTS.DEFAULT_DURATION_MINUTES; // 120
183
+ EVENT_DEFAULTS.MIN_DURATION_MINUTES; // 15
184
+ EVENT_DEFAULTS.DEFAULT_DOORS_BEFORE_MINUTES; // 30
185
+
186
+ // Common US timezones for selects
187
+ COMMON_US_TIMEZONES;
188
+ // [{ id: 'America/Los_Angeles', label: 'Pacific Time (PT)', abbr: 'PT' }, ...]
189
+ ```
190
+
191
+ ## Common Patterns
192
+
193
+ ### Event Form
194
+
195
+ ```typescript
196
+ // Populating form from API response
197
+ function populateForm(event: Event) {
198
+ const tz = datetime.getVenueTimezone(event.venue);
199
+ const start = datetime.parseDateTimeFromAPI(event.startTime, tz);
200
+ const end = datetime.parseDateTimeFromAPI(event.endTime, tz);
201
+
202
+ return {
203
+ date: start.date,
204
+ startTime: start.time,
205
+ endTime: end.time,
206
+ };
207
+ }
208
+
209
+ // Submitting form to API
210
+ function submitForm(form: FormData, venue: Venue) {
211
+ const tz = datetime.getVenueTimezone(venue);
212
+
213
+ return {
214
+ startTime: datetime.combineDateAndTime(form.date, form.startTime, tz),
215
+ endTime: datetime.combineDateAndTime(form.date, form.endTime, tz),
216
+ };
217
+ }
218
+ ```
219
+
220
+ ### Calendar Display
221
+
222
+ ```typescript
223
+ // Display events in venue timezone
224
+ function renderEvent(event: Event, venue: Venue) {
225
+ const tz = datetime.getVenueTimezone(venue);
226
+
227
+ return {
228
+ time: datetime.formatEventTime(event.startTime, tz),
229
+ date: datetime.formatEventDate(event.startTime, tz),
230
+ dateRange: datetime.formatTimeRange(event.startTime, event.endTime, tz),
231
+ dateParts: datetime.getDateParts(event.startTime, tz),
232
+ };
233
+ }
234
+ ```
235
+
236
+ ### Grouping Events by Date
237
+
238
+ ```typescript
239
+ function groupByDate(events: Event[], timezone: TimezoneId) {
240
+ const groups: Record<string, Event[]> = {};
241
+
242
+ for (const event of events) {
243
+ const dateKey = datetime.getDateInTimezone(event.startTime, timezone);
244
+ groups[dateKey] = groups[dateKey] || [];
245
+ groups[dateKey].push(event);
246
+ }
247
+
248
+ return groups;
249
+ }
250
+ ```
251
+
252
+ ## Error Handling
253
+
254
+ All functions throw `DateTimeError` for invalid inputs:
255
+
256
+ ```typescript
257
+ import { DateTimeError, DateTimeErrorCode } from '$lib/datetime';
258
+
259
+ try {
260
+ const tz = datetime.getVenueTimezone(venue);
261
+ } catch (e) {
262
+ if (e instanceof DateTimeError) {
263
+ console.error(e.code); // DateTimeErrorCode.MISSING_TIMEZONE
264
+ console.error(e.message); // "Venue timezone is required"
265
+ console.error(e.details); // { venue: {...} }
266
+ }
267
+ }
268
+ ```
269
+
270
+ Error codes:
271
+
272
+ - `INVALID_TIMEZONE` - Timezone string is not a valid IANA identifier
273
+ - `INVALID_ISO_STRING` - ISO date string is malformed
274
+ - `INVALID_DATE` - Date string is invalid
275
+ - `INVALID_TIME` - Time string is invalid
276
+ - `MISSING_TIMEZONE` - Required timezone is missing
277
+ - `PARSE_ERROR` - General parsing error
278
+
279
+ ## Migration from Legacy Code
280
+
281
+ ### From `src/lib/utils/timezone.js`
282
+
283
+ ```typescript
284
+ // Before
285
+ import { localToUTC, utcToLocal, formatForDisplay } from '$lib/utils/timezone';
286
+
287
+ // After
288
+ import {
289
+ parseLocalToUTC,
290
+ parseUTCToLocal,
291
+ formatEventDateTime,
292
+ } from '$lib/datetime';
293
+ ```
294
+
295
+ ### From `src/lib/utils/utils.js`
296
+
297
+ ```typescript
298
+ // Before
299
+ import { formatDateTime, formatTimeRange, getDay } from '$lib/utils/utils';
300
+
301
+ // After
302
+ import {
303
+ formatEventDateTime,
304
+ formatTimeRange,
305
+ formatDayOfWeek,
306
+ } from '$lib/datetime';
307
+ ```
308
+
309
+ ## Testing
310
+
311
+ Run tests:
312
+
313
+ ```bash
314
+ npm run test -- src/lib/datetime
315
+ ```
316
+
317
+ Run with coverage:
318
+
319
+ ```bash
320
+ npm run test:coverage -- src/lib/datetime
321
+ ```
322
+
323
+ Target: 100% coverage for this critical module.
@@ -1,6 +1,6 @@
1
1
  import { afterEach, beforeEach, describe, expect, it, vi } from 'vitest';
2
2
  import { formatCleanTimeRange, formatDateRange, formatDayOfWeek, formatEventDate, formatEventDateTime, formatEventTime, formatHour, formatMonth, formatNotificationTime, formatRelativeTime, formatTimeRange, getDateInTimezone, getDateParts, getHourInTimezone, isToday, } from '../format';
3
- import { DateTimeError } from '../types';
3
+ import { DateTimeError, DateTimeErrorCode } from '../types';
4
4
  describe('format utilities', () => {
5
5
  describe('formatEventTime', () => {
6
6
  it('formats time in specified timezone', () => {
@@ -1,6 +1,6 @@
1
1
  import { describe, expect, it } from 'vitest';
2
2
  import { combineDateAndTime, formatDateTimeForAPI, isNextDayTime, minutesToTimeString, parseDateTimeFromAPI, parseEndOfDay, parseLocalToUTC, parseStartOfDay, parseTimeToMinutes, parseUTCToLocal, stripNextDayPrefix, } from '../parse';
3
- import { DateTimeError } from '../types';
3
+ import { DateTimeError, DateTimeErrorCode } from '../types';
4
4
  describe('parse utilities', () => {
5
5
  describe('parseLocalToUTC', () => {
6
6
  it('converts local datetime to UTC', () => {
@@ -1,4 +1,4 @@
1
- import { describe, expect, it } from 'vitest';
1
+ import { beforeEach, describe, expect, it, vi } from 'vitest';
2
2
  import { getTimezoneDisplayName, getTimezoneOffset, getUserTimezone, getVenueTimezone, isDST, isValidTimezone, normalizeTimezone, getIANATimezone, isValidIANATimezone, getAllTimezones, formatTimezoneForDisplay, getTimezoneOptions, getCommonUSTimezoneOptions, } from '../timezone';
3
3
  import { DateTimeError, DateTimeErrorCode } from '../types';
4
4
  describe('timezone utilities', () => {