@arc-ui/components 12.0.0-alpha.0 → 12.0.0-beta.10

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 (739) hide show
  1. package/dist/Alert/Alert.cjs.js +9 -14
  2. package/dist/Alert/Alert.esm.js +8 -13
  3. package/dist/Alert/styles.css +1 -0
  4. package/dist/Align/Align.cjs.js +6 -7
  5. package/dist/Align/Align.esm.js +1 -2
  6. package/dist/Align/styles.css +1 -0
  7. package/dist/AppButton/AppButton.cjs.js +74 -0
  8. package/dist/AppButton/AppButton.esm.js +66 -0
  9. package/dist/AppButton/package.json +7 -0
  10. package/dist/AppButton/styles.css +1 -0
  11. package/dist/Avatar/Avatar.cjs.js +17 -0
  12. package/dist/Avatar/Avatar.esm.js +9 -0
  13. package/dist/Avatar/package.json +7 -0
  14. package/dist/Avatar/styles.css +1 -0
  15. package/dist/AvatarGroup/AvatarGroup.cjs.js +37 -0
  16. package/dist/AvatarGroup/AvatarGroup.esm.js +29 -0
  17. package/dist/AvatarGroup/package.json +7 -0
  18. package/dist/AvatarGroup/styles.css +1 -0
  19. package/dist/Badge/Badge.cjs.js +5 -28
  20. package/dist/Badge/Badge.esm.js +4 -27
  21. package/dist/Badge/styles.css +1 -0
  22. package/dist/Banner/Banner.cjs.js +21 -0
  23. package/dist/Banner/Banner.esm.js +13 -0
  24. package/dist/Banner/package.json +7 -0
  25. package/dist/Banner/styles.css +1 -0
  26. package/dist/BannerWithTabs/BannerWithTabs.cjs.js +62 -0
  27. package/dist/BannerWithTabs/BannerWithTabs.esm.js +54 -0
  28. package/dist/BannerWithTabs/package.json +7 -0
  29. package/dist/BannerWithTabs/styles.css +1 -0
  30. package/dist/Box/Box.cjs.js +6 -25
  31. package/dist/Box/Box.esm.js +5 -24
  32. package/dist/Box/styles.css +1 -0
  33. package/dist/BrandLogo/BrandLogo.cjs.js +3 -4
  34. package/dist/BrandLogo/BrandLogo.esm.js +3 -4
  35. package/dist/BrandLogo/styles.css +1 -0
  36. package/dist/Breadcrumbs/Breadcrumbs.cjs.js +7 -6
  37. package/dist/Breadcrumbs/Breadcrumbs.esm.js +7 -6
  38. package/dist/Breadcrumbs/styles.css +1 -0
  39. package/dist/Button/Button.cjs.js +5 -6
  40. package/dist/Button/Button.esm.js +5 -6
  41. package/dist/Button/styles.css +1 -0
  42. package/dist/ButtonV2/ButtonV2.cjs.js +15 -0
  43. package/dist/ButtonV2/ButtonV2.esm.js +7 -0
  44. package/dist/ButtonV2/package.json +7 -0
  45. package/dist/ButtonV2/styles.css +1 -0
  46. package/dist/Calendar/Calendar.cjs.js +21 -0
  47. package/dist/Calendar/Calendar.esm.js +13 -0
  48. package/dist/Calendar/package.json +7 -0
  49. package/dist/Calendar/styles.css +1 -0
  50. package/dist/CardFooter/CardFooter.cjs.js +17 -0
  51. package/dist/CardFooter/CardFooter.esm.js +9 -0
  52. package/dist/CardFooter/package.json +7 -0
  53. package/dist/CardFooter/styles.css +1 -0
  54. package/dist/CardHeading/CardHeading.cjs.js +14 -0
  55. package/dist/CardHeading/CardHeading.esm.js +6 -0
  56. package/dist/CardHeading/package.json +7 -0
  57. package/dist/CardHeading/styles.css +1 -0
  58. package/dist/Carousel/Carousel.cjs.js +1921 -0
  59. package/dist/Carousel/Carousel.esm.js +1913 -0
  60. package/dist/Carousel/package.json +7 -0
  61. package/dist/Carousel/styles.css +1 -0
  62. package/dist/Checkbox/Checkbox.cjs.js +8 -8
  63. package/dist/Checkbox/Checkbox.esm.js +8 -8
  64. package/dist/Checkbox/styles.css +1 -0
  65. package/dist/Columns/Columns.cjs.js +2 -3
  66. package/dist/Columns/Columns.esm.js +2 -3
  67. package/dist/Columns/styles.css +1 -0
  68. package/dist/ConditionalWrapper/ConditionalWrapper.cjs.js +10 -0
  69. package/dist/ConditionalWrapper/ConditionalWrapper.esm.js +2 -0
  70. package/dist/ConditionalWrapper/package.json +7 -0
  71. package/dist/ContentSwitcher/ContentSwitcher.cjs.js +20 -0
  72. package/dist/ContentSwitcher/ContentSwitcher.esm.js +12 -0
  73. package/dist/ContentSwitcher/package.json +7 -0
  74. package/dist/ContentSwitcher/styles.css +1 -0
  75. package/dist/ContentSwitcherDropdown/ContentSwitcherDropdown.cjs.js +23 -0
  76. package/dist/ContentSwitcherDropdown/ContentSwitcherDropdown.esm.js +15 -0
  77. package/dist/ContentSwitcherDropdown/package.json +7 -0
  78. package/dist/ContentSwitcherDropdown/styles.css +1 -0
  79. package/dist/DatePicker/DatePicker.cjs.js +36 -0
  80. package/dist/DatePicker/DatePicker.esm.js +23 -0
  81. package/dist/DatePicker/package.json +7 -0
  82. package/dist/DatePicker/styles.css +1 -0
  83. package/dist/Disclosure/Disclosure.cjs.js +13 -11
  84. package/dist/Disclosure/Disclosure.esm.js +11 -9
  85. package/dist/Disclosure/styles.css +1 -0
  86. package/dist/DisclosureMini/DisclosureMini.cjs.js +5 -6
  87. package/dist/DisclosureMini/DisclosureMini.esm.js +5 -6
  88. package/dist/DisclosureMini/styles.css +1 -0
  89. package/dist/Download/Download.cjs.js +16 -0
  90. package/dist/Download/Download.esm.js +8 -0
  91. package/dist/Download/package.json +7 -0
  92. package/dist/Download/styles.css +1 -0
  93. package/dist/Elevation/Elevation.cjs.js +4 -4
  94. package/dist/Elevation/Elevation.esm.js +1 -1
  95. package/dist/Elevation/styles.css +1 -0
  96. package/dist/Filter/Filter.cjs.js +4 -3
  97. package/dist/Filter/Filter.esm.js +4 -3
  98. package/dist/Filter/styles.css +1 -0
  99. package/dist/FormControl/FormControl.cjs.js +7 -7
  100. package/dist/FormControl/FormControl.esm.js +7 -7
  101. package/dist/FormControl/styles.css +1 -0
  102. package/dist/Grid/Grid.cjs.js +12 -0
  103. package/dist/Grid/Grid.esm.js +4 -0
  104. package/dist/Grid/package.json +7 -0
  105. package/dist/Grid/styles.css +1 -0
  106. package/dist/Group/Group.cjs.js +3 -3
  107. package/dist/Group/Group.esm.js +3 -3
  108. package/dist/Group/styles.css +1 -0
  109. package/dist/Heading/Heading.cjs.js +3 -4
  110. package/dist/Heading/Heading.esm.js +3 -4
  111. package/dist/Heading/styles.css +1 -0
  112. package/dist/HeroBanner/HeroBanner.cjs.js +28 -0
  113. package/dist/HeroBanner/HeroBanner.esm.js +20 -0
  114. package/dist/HeroBanner/package.json +7 -0
  115. package/dist/HeroButton/HeroButton.cjs.js +15 -0
  116. package/dist/HeroButton/HeroButton.esm.js +7 -0
  117. package/dist/HeroButton/package.json +7 -0
  118. package/dist/HeroButton/styles.css +1 -0
  119. package/dist/Hidden/Hidden.cjs.js +24 -0
  120. package/dist/Hidden/Hidden.esm.js +16 -0
  121. package/dist/Hidden/package.json +7 -0
  122. package/dist/Hidden/styles.css +1 -0
  123. package/dist/Icon/Icon.cjs.js +3 -4
  124. package/dist/Icon/Icon.esm.js +3 -4
  125. package/dist/Icon/styles.css +1 -0
  126. package/dist/Image/Image.cjs.js +2 -3
  127. package/dist/Image/Image.esm.js +2 -3
  128. package/dist/Image/styles.css +1 -0
  129. package/dist/ImpactCard/ImpactCard.cjs.js +43 -0
  130. package/dist/ImpactCard/ImpactCard.esm.js +35 -0
  131. package/dist/ImpactCard/package.json +7 -0
  132. package/dist/ImpactCard/styles.css +1 -0
  133. package/dist/InformationCard/InformationCard.cjs.js +60 -0
  134. package/dist/InformationCard/InformationCard.esm.js +52 -0
  135. package/dist/InformationCard/package.json +7 -0
  136. package/dist/InformationCard/styles.css +1 -0
  137. package/dist/Link/Link.cjs.js +75 -0
  138. package/dist/Link/Link.esm.js +67 -0
  139. package/dist/Link/package.json +7 -0
  140. package/dist/Link/styles.css +1 -0
  141. package/dist/Markup/Markup.cjs.js +5 -5
  142. package/dist/Markup/Markup.esm.js +2 -2
  143. package/dist/Markup/styles.css +1 -0
  144. package/dist/MediaCard/MediaCard.cjs.js +26 -0
  145. package/dist/MediaCard/MediaCard.esm.js +18 -0
  146. package/dist/MediaCard/package.json +7 -0
  147. package/dist/MediaCard/styles.css +1 -0
  148. package/dist/Modal/Modal.cjs.js +341 -547
  149. package/dist/Modal/Modal.esm.js +323 -547
  150. package/dist/Modal/styles.css +1 -0
  151. package/dist/PageBanner/PageBanner.cjs.js +28 -0
  152. package/dist/PageBanner/PageBanner.esm.js +20 -0
  153. package/dist/PageBanner/package.json +7 -0
  154. package/dist/Pagination/Pagination.cjs.js +8 -12
  155. package/dist/Pagination/Pagination.esm.js +6 -10
  156. package/dist/Pagination/styles.css +1 -0
  157. package/dist/PaginationSimple/PaginationSimple.cjs.js +91 -26
  158. package/dist/PaginationSimple/PaginationSimple.esm.js +90 -25
  159. package/dist/PaginationSimple/styles.css +1 -0
  160. package/dist/Poster/Poster.cjs.js +4 -5
  161. package/dist/Poster/Poster.esm.js +4 -5
  162. package/dist/Poster/styles.css +1 -0
  163. package/dist/ProgressBar/ProgressBar.cjs.js +19 -17
  164. package/dist/ProgressBar/ProgressBar.esm.js +16 -14
  165. package/dist/ProgressBar/styles.css +1 -0
  166. package/dist/ProgressStepper/ProgressStepper.cjs.js +5 -7
  167. package/dist/ProgressStepper/ProgressStepper.esm.js +5 -7
  168. package/dist/ProgressStepper/styles.css +1 -0
  169. package/dist/RadioGroup/RadioGroup.cjs.js +9 -8
  170. package/dist/RadioGroup/RadioGroup.esm.js +8 -8
  171. package/dist/RadioGroup/styles.css +1 -0
  172. package/dist/Rule/Rule.cjs.js +14 -4
  173. package/dist/Rule/Rule.esm.js +15 -5
  174. package/dist/Rule/styles.css +1 -0
  175. package/dist/ScrollToTop/ScrollToTop.cjs.js +27 -10
  176. package/dist/ScrollToTop/ScrollToTop.esm.js +24 -7
  177. package/dist/ScrollToTop/styles.css +1 -0
  178. package/dist/Section/Section.cjs.js +2 -2
  179. package/dist/Section/Section.esm.js +2 -2
  180. package/dist/Section/styles.css +1 -0
  181. package/dist/Select/Select.cjs.js +52 -1726
  182. package/dist/Select/Select.esm.js +53 -1708
  183. package/dist/Select/styles.css +1 -0
  184. package/dist/SiteFooter/SiteFooter.cjs.js +9 -33
  185. package/dist/SiteFooter/SiteFooter.esm.js +9 -33
  186. package/dist/SiteFooter/styles.css +1 -0
  187. package/dist/SiteHeaderV2/SiteHeaderV2.cjs.js +24 -0
  188. package/dist/SiteHeaderV2/SiteHeaderV2.esm.js +16 -0
  189. package/dist/SiteHeaderV2/package.json +7 -0
  190. package/dist/SiteHeaderV2/styles.css +1 -0
  191. package/dist/SkipLink/SkipLink.cjs.js +24 -0
  192. package/dist/SkipLink/SkipLink.esm.js +16 -0
  193. package/dist/SkipLink/package.json +7 -0
  194. package/dist/SkipLink/styles.css +1 -0
  195. package/dist/Spinner/Spinner.cjs.js +12 -0
  196. package/dist/Spinner/Spinner.esm.js +4 -0
  197. package/dist/Spinner/package.json +7 -0
  198. package/dist/Spinner/styles.css +1 -0
  199. package/dist/Surface/Surface.cjs.js +2 -2
  200. package/dist/Surface/Surface.esm.js +2 -2
  201. package/dist/Surface/styles.css +1 -0
  202. package/dist/Switch/Switch.cjs.js +26 -73
  203. package/dist/Switch/Switch.esm.js +16 -63
  204. package/dist/Switch/styles.css +1 -0
  205. package/dist/Tabs/Tabs.cjs.js +9 -10
  206. package/dist/Tabs/Tabs.esm.js +9 -10
  207. package/dist/Tabs/styles.css +1 -0
  208. package/dist/Tag/Tag.cjs.js +51 -17
  209. package/dist/Tag/Tag.esm.js +50 -16
  210. package/dist/Tag/styles.css +1 -0
  211. package/dist/Text/Text.cjs.js +3 -4
  212. package/dist/Text/Text.esm.js +3 -4
  213. package/dist/Text/styles.css +1 -0
  214. package/dist/TextArea/TextArea.cjs.js +70 -45
  215. package/dist/TextArea/TextArea.esm.js +70 -45
  216. package/dist/TextArea/styles.css +1 -0
  217. package/dist/TextInput/TextInput.cjs.js +8 -9
  218. package/dist/TextInput/TextInput.esm.js +8 -9
  219. package/dist/TextInput/styles.css +1 -0
  220. package/dist/Theme/Theme.cjs.js +16 -4
  221. package/dist/Theme/Theme.esm.js +16 -4
  222. package/dist/Theme/styles.css +1 -0
  223. package/dist/ThemeIcon/ThemeIcon.cjs.js +13 -0
  224. package/dist/ThemeIcon/ThemeIcon.esm.js +5 -0
  225. package/dist/ThemeIcon/package.json +7 -0
  226. package/dist/ThemeIcon/styles.css +1 -0
  227. package/dist/Toast/Toast.cjs.js +8 -9
  228. package/dist/Toast/Toast.esm.js +8 -9
  229. package/dist/Toast/styles.css +1 -0
  230. package/dist/Truncate/Truncate.cjs.js +3 -3
  231. package/dist/Truncate/Truncate.esm.js +3 -3
  232. package/dist/Truncate/styles.css +1 -0
  233. package/dist/TypographyCard/TypographyCard.cjs.js +40 -0
  234. package/dist/TypographyCard/TypographyCard.esm.js +32 -0
  235. package/dist/TypographyCard/package.json +7 -0
  236. package/dist/TypographyCard/styles.css +1 -0
  237. package/dist/UniversalHeader/UniversalHeader.cjs.js +3 -3
  238. package/dist/UniversalHeader/UniversalHeader.esm.js +3 -3
  239. package/dist/UniversalHeader/styles.css +1 -0
  240. package/dist/VerticalSpace/VerticalSpace.cjs.js +2 -2
  241. package/dist/VerticalSpace/VerticalSpace.esm.js +2 -2
  242. package/dist/VerticalSpace/styles.css +1 -0
  243. package/dist/VideoPlayer/VideoPlayer.cjs.js +3025 -0
  244. package/dist/VideoPlayer/VideoPlayer.esm.js +3017 -0
  245. package/dist/VideoPlayer/package.json +7 -0
  246. package/dist/VideoPlayer/styles.css +1 -0
  247. package/dist/Visible/Visible.cjs.js +24 -0
  248. package/dist/Visible/Visible.esm.js +16 -0
  249. package/dist/Visible/package.json +7 -0
  250. package/dist/Visible/styles.css +1 -0
  251. package/dist/VisuallyHidden/VisuallyHidden.cjs.js +2 -1
  252. package/dist/VisuallyHidden/VisuallyHidden.esm.js +2 -1
  253. package/dist/VisuallyHidden/styles.css +1 -0
  254. package/dist/_shared/cjs/Avatar-d37e7dee.js +48 -0
  255. package/dist/_shared/cjs/Badge-e5e57c0d.js +17 -0
  256. package/dist/_shared/cjs/Banner-a28364b4.js +66 -0
  257. package/dist/_shared/cjs/Box-a8f42d4f.js +29 -0
  258. package/dist/_shared/cjs/{BrandLogo-aea340c8.js → BrandLogo-5aef900a.js} +6 -7
  259. package/dist/_shared/cjs/{Breadcrumbs-f3385e2e.js → Breadcrumbs-edf76698.js} +18 -17
  260. package/dist/_shared/cjs/BtIconArrowRight.esm-6053bb79.js +30 -0
  261. package/dist/_shared/cjs/BtIconChevronRight2Px.esm-2e4d117e.js +44 -0
  262. package/dist/_shared/cjs/BtIconChevronRightMid.esm-3e8d18a9.js +28 -0
  263. package/dist/_shared/cjs/BtIconPlayFill.esm-b8997cfc.js +30 -0
  264. package/dist/_shared/cjs/{Button-5c958ce9.js → Button-82df14c9.js} +11 -12
  265. package/dist/_shared/cjs/ButtonV2-0679b44b.js +53 -0
  266. package/dist/_shared/cjs/Calendar-d2511ee9.js +1927 -0
  267. package/dist/_shared/cjs/CardFooter-facb09e6.js +79 -0
  268. package/dist/_shared/cjs/CardHeading-a7d8d472.js +16 -0
  269. package/dist/_shared/cjs/Checkbox-d34c19c4.js +70 -0
  270. package/dist/_shared/cjs/{Columns-ae4f8cef.js → Columns-e5f9406b.js} +8 -16
  271. package/dist/_shared/cjs/Combination-06cc56d0.js +1203 -0
  272. package/dist/_shared/cjs/ConditionalWrapper-bf944594.js +14 -0
  273. package/dist/_shared/cjs/ContentSwitcher-df2381c9.js +99 -0
  274. package/dist/_shared/cjs/ContentSwitcherDropdown-91856b98.js +64 -0
  275. package/dist/_shared/cjs/DatePicker-3abcf361.js +939 -0
  276. package/dist/_shared/cjs/{DisclosureMini-145105a4.js → DisclosureMini-64a1c682.js} +10 -13
  277. package/dist/_shared/cjs/Download-45dc0d20.js +43 -0
  278. package/dist/_shared/cjs/{Filter-1bde635c.js → Filter-c93d809e.js} +32 -24
  279. package/dist/_shared/cjs/{FormControl-30f2330f.js → FormControl-09c28bbb.js} +31 -16
  280. package/dist/_shared/cjs/Grid-102905c8.js +45 -0
  281. package/dist/_shared/cjs/{Group-0429741a.js → Group-33f84a2f.js} +8 -15
  282. package/dist/_shared/cjs/{Heading-27cba320.js → Heading-b4b65724.js} +8 -8
  283. package/dist/_shared/cjs/HeroButton-db55ff2a.js +126 -0
  284. package/dist/_shared/cjs/Icon-5dd78f2b.js +47 -0
  285. package/dist/_shared/cjs/Image-bb696c61.js +55 -0
  286. package/dist/_shared/cjs/MediaCard-158890b3.js +65 -0
  287. package/dist/_shared/cjs/{Poster-499b78da.js → Poster-11d2f8af.js} +13 -14
  288. package/dist/_shared/cjs/Preview-0bf3f6e8.js +167 -0
  289. package/dist/_shared/cjs/ProgressStepper-65294193.js +97 -0
  290. package/dist/_shared/cjs/RadioGroup-4fe1c546.js +85 -0
  291. package/dist/_shared/cjs/{Section-59804166.js → Section-4415d756.js} +4 -4
  292. package/dist/_shared/cjs/{SiteFooter-0638c27c.js → SiteFooter-e741eb87.js} +13 -12
  293. package/dist/_shared/cjs/SiteHeaderV2-e0ae0718.js +654 -0
  294. package/dist/_shared/cjs/Spinner-0f578e7f.js +24 -0
  295. package/dist/_shared/cjs/Surface-ca708a8c.js +175 -0
  296. package/dist/_shared/cjs/Tabs-a587b50f.js +90 -0
  297. package/dist/_shared/cjs/{Text-606ca3a2.js → Text-1b3e4fb6.js} +7 -7
  298. package/dist/_shared/cjs/TextInput-5e533805.js +103 -0
  299. package/dist/_shared/cjs/{ThemeIcon-9534f091.js → ThemeIcon-cf6ddb34.js} +6 -7
  300. package/dist/_shared/cjs/{Toast-6d4021d7.js → Toast-e088fa5d.js} +282 -44
  301. package/dist/_shared/cjs/UniversalHeader-de415648.js +29 -0
  302. package/dist/_shared/cjs/{VerticalSpace-dc53bb70.js → VerticalSpace-a5cf4d4e.js} +8 -8
  303. package/dist/_shared/cjs/VisuallyHidden-c691ea4d.js +18 -0
  304. package/dist/_shared/cjs/_commonjsHelpers-56412ec5.js +21 -0
  305. package/dist/_shared/cjs/{index-38d3848e.js → component-aa9fcdbb.js} +154 -435
  306. package/dist/_shared/cjs/{debounce-123468fb.js → debounce-a74c28cf.js} +2 -2
  307. package/dist/_shared/cjs/floating-ui.react-dom-08b8b87c.js +1908 -0
  308. package/dist/_shared/cjs/{Tabs-ade6d6b6.js → index-1e7a1fce.js} +20 -109
  309. package/dist/_shared/cjs/index-28fbfd5b.js +2206 -0
  310. package/dist/_shared/cjs/index-2bf59363.js +44 -0
  311. package/dist/_shared/cjs/index-527f962b.js +131 -0
  312. package/dist/_shared/cjs/index-568ebc78.js +2204 -0
  313. package/dist/_shared/cjs/{index.module-7d7228b3.js → index-76f7dd53.js} +32 -34
  314. package/dist/_shared/cjs/{index-d75774a9.js → index-879e71ee.js} +8 -1
  315. package/dist/_shared/cjs/index-ba3141f5.js +72 -0
  316. package/dist/_shared/cjs/{index-23b4f49f.js → index-dbc843d3.js} +1 -1
  317. package/dist/_shared/cjs/index.es-0c2c97f4.js +355 -0
  318. package/dist/_shared/cjs/index.es-0f681622.js +13 -0
  319. package/dist/_shared/cjs/{index.es-77def0c9.js → use-media-query-d34c83b9.js} +0 -9
  320. package/dist/_shared/esm/Avatar-f9df2686.js +42 -0
  321. package/dist/_shared/esm/Badge-ec093004.js +11 -0
  322. package/dist/_shared/esm/Banner-1b709fc7.js +60 -0
  323. package/dist/_shared/esm/Box-0516cf8c.js +23 -0
  324. package/dist/_shared/esm/{BrandLogo-1af78f76.js → BrandLogo-640e58ed.js} +2 -3
  325. package/dist/_shared/esm/{Breadcrumbs-c4b65cff.js → Breadcrumbs-58ab8ba0.js} +16 -15
  326. package/dist/_shared/esm/BtIconArrowRight.esm-93da96bb.js +24 -0
  327. package/dist/_shared/esm/BtIconChevronRight2Px.esm-c939e317.js +37 -0
  328. package/dist/_shared/esm/BtIconChevronRightMid.esm-4764708f.js +22 -0
  329. package/dist/_shared/esm/BtIconPlayFill.esm-05fc0344.js +24 -0
  330. package/dist/_shared/esm/{Button-c3348ed8.js → Button-6d09ead2.js} +5 -6
  331. package/dist/_shared/esm/ButtonV2-b35cea64.js +47 -0
  332. package/dist/_shared/esm/Calendar-d56cdead.js +1918 -0
  333. package/dist/_shared/esm/CardFooter-97261b1c.js +73 -0
  334. package/dist/_shared/esm/CardHeading-4e020d2e.js +10 -0
  335. package/dist/_shared/esm/Checkbox-a687c6cd.js +64 -0
  336. package/dist/_shared/esm/{Columns-d96b7425.js → Columns-767e7860.js} +2 -10
  337. package/dist/_shared/esm/Combination-71be1a15.js +1163 -0
  338. package/dist/_shared/esm/ConditionalWrapper-b85979de.js +8 -0
  339. package/dist/_shared/esm/ContentSwitcher-bc952e2f.js +93 -0
  340. package/dist/_shared/esm/ContentSwitcherDropdown-1675387e.js +58 -0
  341. package/dist/_shared/esm/DatePicker-dd060b1c.js +910 -0
  342. package/dist/_shared/esm/{DisclosureMini-bf95a9db.js → DisclosureMini-9caa350c.js} +8 -11
  343. package/dist/_shared/esm/Download-07f5e3dd.js +37 -0
  344. package/dist/_shared/esm/{Filter-58a42358.js → Filter-284297be.js} +29 -21
  345. package/dist/_shared/esm/{FormControl-433228f5.js → FormControl-350bb1c8.js} +29 -14
  346. package/dist/_shared/esm/Grid-5d1afe1a.js +39 -0
  347. package/dist/_shared/esm/{Group-73fdb896.js → Group-64dee285.js} +3 -10
  348. package/dist/_shared/esm/{Heading-d16e0e53.js → Heading-e83f0d49.js} +5 -5
  349. package/dist/_shared/esm/HeroButton-32fec849.js +120 -0
  350. package/dist/_shared/esm/Icon-6fef56b3.js +41 -0
  351. package/dist/_shared/esm/{Image-12fbd327.js → Image-45c7760b.js} +14 -5
  352. package/dist/_shared/esm/MediaCard-38c7a943.js +59 -0
  353. package/dist/_shared/esm/{Poster-699dc89b.js → Poster-f248e28b.js} +6 -7
  354. package/dist/_shared/esm/Preview-43b2a75d.js +161 -0
  355. package/dist/_shared/esm/ProgressStepper-9bb4706f.js +91 -0
  356. package/dist/_shared/esm/RadioGroup-84c7ca35.js +78 -0
  357. package/dist/_shared/esm/{Section-73781b56.js → Section-3ab74edb.js} +1 -1
  358. package/dist/_shared/esm/{SiteFooter-d21da7ab.js → SiteFooter-7317b40e.js} +9 -8
  359. package/dist/_shared/esm/SiteHeaderV2-6d4af7e5.js +648 -0
  360. package/dist/_shared/esm/Spinner-7c6f320f.js +18 -0
  361. package/dist/_shared/esm/Surface-201aa0d6.js +165 -0
  362. package/dist/_shared/esm/Tabs-ab8e189d.js +84 -0
  363. package/dist/_shared/esm/{Text-14f586ac.js → Text-dc3f9cb5.js} +5 -5
  364. package/dist/_shared/esm/TextInput-0707edc3.js +96 -0
  365. package/dist/_shared/esm/{ThemeIcon-eab5a4d0.js → ThemeIcon-69de5351.js} +2 -3
  366. package/dist/_shared/esm/{Toast-dce2d01e.js → Toast-e3ab54f9.js} +260 -23
  367. package/dist/_shared/esm/{UniversalHeader-b4c1577c.js → UniversalHeader-15169a0d.js} +9 -14
  368. package/dist/_shared/esm/{VerticalSpace-43cd9138.js → VerticalSpace-4b6b7468.js} +5 -5
  369. package/dist/_shared/esm/VisuallyHidden-59f004f5.js +12 -0
  370. package/dist/_shared/esm/_commonjsHelpers-0109d574.js +18 -0
  371. package/dist/_shared/esm/{index-ffd720d0.js → component-4448135f.js} +144 -432
  372. package/dist/_shared/esm/{debounce-6fed6b84.js → debounce-c8e41002.js} +1 -1
  373. package/dist/_shared/esm/floating-ui.react-dom-1bb71aae.js +1878 -0
  374. package/dist/_shared/esm/index-0ae42785.js +2169 -0
  375. package/dist/_shared/esm/{index-3147c5b0.js → index-13458236.js} +9 -2
  376. package/dist/_shared/esm/{index-65264b4e.js → index-2403936c.js} +1 -1
  377. package/dist/_shared/esm/index-6bdce6c5.js +69 -0
  378. package/dist/_shared/esm/index-7868cc59.js +129 -0
  379. package/dist/_shared/esm/{index.module-50b2c98a.js → index-7f23bb37.js} +28 -30
  380. package/dist/_shared/esm/index-a41a5e50.js +41 -0
  381. package/dist/_shared/esm/{Tabs-39d24a7d.js → index-b051f161.js} +6 -94
  382. package/dist/_shared/esm/index-ce6dee84.js +2197 -0
  383. package/dist/_shared/esm/index.es-be971b8d.js +9 -0
  384. package/dist/_shared/esm/index.es-fc59ba8f.js +348 -0
  385. package/dist/_shared/esm/{index.es-00cb3bcb.js → use-media-query-d3622da8.js} +1 -8
  386. package/dist/index.es.js +18793 -37648
  387. package/dist/index.es.js.map +1 -1
  388. package/dist/index.js +18806 -37643
  389. package/dist/index.js.map +1 -1
  390. package/dist/styles.css +9 -38
  391. package/dist/types/components/Alert/Alert.d.ts +1 -1
  392. package/dist/types/components/AppButton/AppButton.d.ts +9 -0
  393. package/dist/types/components/AppButton/icons/AppStore.d.ts +2 -0
  394. package/dist/types/components/AppButton/icons/GooglePlay.d.ts +2 -0
  395. package/dist/types/components/AppButton/index.d.ts +1 -0
  396. package/dist/types/components/Avatar/Avatar.d.ts +14 -0
  397. package/dist/types/components/Avatar/components/AvatarContent/AvatarContent.d.ts +9 -0
  398. package/dist/types/components/Avatar/index.d.ts +1 -0
  399. package/dist/types/components/Avatar/types/avatar-icon-size.d.ts +1 -0
  400. package/dist/types/components/Avatar/types/avatar-image.d.ts +2 -0
  401. package/dist/types/components/Avatar/types/avatar-size.d.ts +1 -0
  402. package/dist/types/components/Avatar/types/avatar-text-size.d.ts +2 -0
  403. package/dist/types/components/AvatarGroup/AvatarGroup.d.ts +14 -0
  404. package/dist/types/components/AvatarGroup/index.d.ts +1 -0
  405. package/dist/types/components/AvatarGroup/types/group-avatar.d.ts +2 -0
  406. package/dist/types/components/AvatarGroup/utils/get-avatars.d.ts +2 -0
  407. package/dist/types/components/Badge/Badge.d.ts +1 -9
  408. package/dist/types/components/Banner/Banner.d.ts +68 -0
  409. package/dist/types/components/Banner/index.d.ts +1 -0
  410. package/dist/types/components/BannerWithTabs/BannerWithTabs.d.ts +17 -0
  411. package/dist/types/components/BannerWithTabs/index.d.ts +1 -0
  412. package/dist/types/components/Box/Box.d.ts +4 -0
  413. package/dist/types/components/Button/Button.d.ts +1 -1
  414. package/dist/types/components/ButtonV2/ButtonV2.d.ts +79 -0
  415. package/dist/types/components/ButtonV2/index.d.ts +1 -0
  416. package/dist/types/components/Calendar/Calendar.d.ts +50 -0
  417. package/dist/types/components/Calendar/Calendar.provider.d.ts +21 -0
  418. package/dist/types/components/Calendar/components/CalendarDateSelect/CalendarDateSelect.d.ts +15 -0
  419. package/dist/types/components/Calendar/components/CalendarDateSelect/index.d.ts +1 -0
  420. package/dist/types/components/Calendar/components/CalendarDayGrid/CalendarDayGrid.d.ts +6 -0
  421. package/dist/types/components/Calendar/components/CalendarDayGrid/index.d.ts +1 -0
  422. package/dist/types/components/Calendar/components/CalendarDayNumber/CalendarDayNumber.d.ts +8 -0
  423. package/dist/types/components/Calendar/components/CalendarDayNumber/index.d.ts +1 -0
  424. package/dist/types/components/Calendar/components/CalendarDoubleMonthView/CalendarDoubleMonthView.d.ts +9 -0
  425. package/dist/types/components/Calendar/components/CalendarDoubleMonthView/index.d.ts +1 -0
  426. package/dist/types/components/Calendar/components/CalendarFooter/CalendarFooter.d.ts +6 -0
  427. package/dist/types/components/Calendar/components/CalendarFooter/index.d.ts +1 -0
  428. package/dist/types/components/Calendar/components/CalendarMonthView/CalendarMonthView.d.ts +9 -0
  429. package/dist/types/components/Calendar/components/CalendarMonthView/index.d.ts +1 -0
  430. package/dist/types/components/Calendar/components/CalendarMonthYearView/CalendarMonthYearView.d.ts +11 -0
  431. package/dist/types/components/Calendar/components/CalendarMonthYearView/index.d.ts +1 -0
  432. package/dist/types/components/Calendar/components/CalendarNavButton/CalendarNavButton.d.ts +10 -0
  433. package/dist/types/components/Calendar/components/CalendarNavButton/index.d.ts +1 -0
  434. package/dist/types/components/Calendar/components/CalendarWrapper/CalendarWrapper.d.ts +5 -0
  435. package/dist/types/components/Calendar/components/CalendarWrapper/index.d.ts +1 -0
  436. package/dist/types/components/Calendar/components/index.d.ts +6 -0
  437. package/dist/types/components/Calendar/constants/day-names.d.ts +5 -0
  438. package/dist/types/components/Calendar/constants/index.d.ts +1 -0
  439. package/dist/types/components/Calendar/helpers/contains-date.d.ts +1 -0
  440. package/dist/types/components/Calendar/helpers/contains-date.test.d.ts +1 -0
  441. package/dist/types/components/Calendar/helpers/date-without-time.d.ts +1 -0
  442. package/dist/types/components/Calendar/helpers/date-without-time.test.d.ts +1 -0
  443. package/dist/types/components/Calendar/helpers/get-calendar-type.d.ts +2 -0
  444. package/dist/types/components/Calendar/helpers/get-calendar-type.test.d.ts +1 -0
  445. package/dist/types/components/Calendar/helpers/get-dates-in-month.d.ts +1 -0
  446. package/dist/types/components/Calendar/helpers/get-dates-in-month.test.d.ts +1 -0
  447. package/dist/types/components/Calendar/helpers/get-double-month-display-range.d.ts +1 -0
  448. package/dist/types/components/Calendar/helpers/get-double-month-display-range.test.d.ts +1 -0
  449. package/dist/types/components/Calendar/helpers/get-focus-date.d.ts +5 -0
  450. package/dist/types/components/Calendar/helpers/get-focus-date.test.d.ts +1 -0
  451. package/dist/types/components/Calendar/helpers/get-highlighted-range.d.ts +6 -0
  452. package/dist/types/components/Calendar/helpers/get-highlighted-range.test.d.ts +1 -0
  453. package/dist/types/components/Calendar/helpers/get-keydown-date.d.ts +6 -0
  454. package/dist/types/components/Calendar/helpers/get-keydown-date.test.d.ts +1 -0
  455. package/dist/types/components/Calendar/helpers/index.d.ts +13 -0
  456. package/dist/types/components/Calendar/helpers/is-day.d.ts +2 -0
  457. package/dist/types/components/Calendar/helpers/is-day.test.d.ts +1 -0
  458. package/dist/types/components/Calendar/helpers/is-disabled-date.d.ts +1 -0
  459. package/dist/types/components/Calendar/helpers/is-disabled-date.test.d.ts +1 -0
  460. package/dist/types/components/Calendar/helpers/is-month-after-max-date.d.ts +1 -0
  461. package/dist/types/components/Calendar/helpers/is-month-after-max-date.test.d.ts +1 -0
  462. package/dist/types/components/Calendar/helpers/is-month-before-min-date.d.ts +1 -0
  463. package/dist/types/components/Calendar/helpers/is-month-before-min-date.test.d.ts +1 -0
  464. package/dist/types/components/Calendar/helpers/process-selected-range.d.ts +9 -0
  465. package/dist/types/components/Calendar/helpers/process-selected-range.test.d.ts +1 -0
  466. package/dist/types/components/Calendar/index.d.ts +2 -0
  467. package/dist/types/components/Calendar/state/handlers/calendar-keydown-handler.d.ts +3 -0
  468. package/dist/types/components/Calendar/state/handlers/day-grid-leave-handler.d.ts +3 -0
  469. package/dist/types/components/Calendar/state/handlers/day-number-select-handler.d.ts +3 -0
  470. package/dist/types/components/Calendar/state/handlers/default-handler.d.ts +2 -0
  471. package/dist/types/components/Calendar/state/handlers/dropdown-change-month-handler.d.ts +3 -0
  472. package/dist/types/components/Calendar/state/handlers/dropdown-change-year-handler.d.ts +3 -0
  473. package/dist/types/components/Calendar/state/handlers/highlight-range-handler.d.ts +3 -0
  474. package/dist/types/components/Calendar/state/handlers/index.d.ts +12 -0
  475. package/dist/types/components/Calendar/state/handlers/range-select-handler.d.ts +3 -0
  476. package/dist/types/components/Calendar/state/handlers/show-next-double-month-handler.d.ts +3 -0
  477. package/dist/types/components/Calendar/state/handlers/show-next-month-handler.d.ts +3 -0
  478. package/dist/types/components/Calendar/state/handlers/show-previous-double-month-handler.d.ts +3 -0
  479. package/dist/types/components/Calendar/state/handlers/show-previous-month-handler.d.ts +3 -0
  480. package/dist/types/components/Calendar/state/index.d.ts +2 -0
  481. package/dist/types/components/Calendar/state/reducer.d.ts +3 -0
  482. package/dist/types/components/Calendar/state/reducer.test.d.ts +1 -0
  483. package/dist/types/components/Calendar/state/types/actions.d.ts +81 -0
  484. package/dist/types/components/Calendar/state/types/state-handler.d.ts +3 -0
  485. package/dist/types/components/Calendar/state/types/state.d.ts +5 -0
  486. package/dist/types/components/Calendar/types/calendar-type.d.ts +1 -0
  487. package/dist/types/components/Calendar/types/date-select-value.d.ts +2 -0
  488. package/dist/types/components/Calendar/types/index.d.ts +6 -0
  489. package/dist/types/components/Calendar/types/key-names.d.ts +13 -0
  490. package/dist/types/components/Calendar/types/range-selection.d.ts +10 -0
  491. package/dist/types/components/Calendar/types/selection-type.d.ts +1 -0
  492. package/dist/types/components/Calendar/types/week-days.d.ts +18 -0
  493. package/dist/types/components/CardFooter/CardFooter.d.ts +11 -0
  494. package/dist/types/components/CardFooter/index.d.ts +1 -0
  495. package/dist/types/components/CardHeading/CardHeading.d.ts +19 -0
  496. package/dist/types/components/CardHeading/index.d.ts +1 -0
  497. package/dist/types/components/Carousel/Carousel.d.ts +34 -0
  498. package/dist/types/components/Carousel/components/DotButton.d.ts +10 -0
  499. package/dist/types/components/Carousel/constants/breakpoints.d.ts +5 -0
  500. package/dist/types/components/Carousel/helpers/get-options.d.ts +3 -0
  501. package/dist/types/components/Carousel/helpers/get-slide-width.d.ts +12 -0
  502. package/dist/types/components/Carousel/index.d.ts +1 -0
  503. package/dist/types/components/Carousel/types/breakpoints.d.ts +1 -0
  504. package/dist/types/components/Carousel/types/keynames.d.ts +5 -0
  505. package/dist/types/components/Carousel/types/responsive.d.ts +3 -0
  506. package/dist/types/components/Carousel/types/screen-sizes.d.ts +2 -0
  507. package/dist/types/components/Carousel/types/slide-config.d.ts +5 -0
  508. package/dist/types/components/Checkbox/Checkbox.d.ts +8 -5
  509. package/dist/types/components/ConditionalWrapper/ConditionalWrapper.d.ts +7 -0
  510. package/dist/types/components/ConditionalWrapper/index.d.ts +1 -0
  511. package/dist/types/components/ContentSwitcher/ContentSwitcher.d.ts +32 -0
  512. package/dist/types/components/ContentSwitcher/ContentSwitcherContent/ContentSwitcherContent.d.ts +12 -0
  513. package/dist/types/components/ContentSwitcher/ContentSwitcherContent/index.d.ts +1 -0
  514. package/dist/types/components/ContentSwitcher/ContentSwitcherList/ContentSwitcherList.d.ts +24 -0
  515. package/dist/types/components/ContentSwitcher/ContentSwitcherList/index.d.ts +1 -0
  516. package/dist/types/components/ContentSwitcher/ContentSwitcherTab/ContentSwitcherTab.d.ts +17 -0
  517. package/dist/types/components/ContentSwitcher/ContentSwitcherTab/index.d.ts +1 -0
  518. package/dist/types/components/ContentSwitcher/index.d.ts +1 -0
  519. package/dist/types/components/ContentSwitcherDropdown/ContentSwitcherDropdown.d.ts +57 -0
  520. package/dist/types/components/ContentSwitcherDropdown/index.d.ts +1 -0
  521. package/dist/types/components/DatePicker/DatePicker.d.ts +20 -0
  522. package/dist/types/components/DatePicker/constants/date-format.d.ts +1 -0
  523. package/dist/types/components/DatePicker/constants/index.d.ts +1 -0
  524. package/dist/types/components/DatePicker/helpers/convert-date-string-to-date.d.ts +1 -0
  525. package/dist/types/components/DatePicker/helpers/convert-date-string-to-date.test.d.ts +1 -0
  526. package/dist/types/components/DatePicker/helpers/convert-range-string-to-dates.d.ts +1 -0
  527. package/dist/types/components/DatePicker/helpers/convert-range-string-to-dates.test.d.ts +1 -0
  528. package/dist/types/components/DatePicker/helpers/format-date.d.ts +1 -0
  529. package/dist/types/components/DatePicker/helpers/format-date.test.d.ts +1 -0
  530. package/dist/types/components/DatePicker/helpers/index.d.ts +8 -0
  531. package/dist/types/components/DatePicker/helpers/is-date-valid.d.ts +1 -0
  532. package/dist/types/components/DatePicker/helpers/is-date-valid.test.d.ts +1 -0
  533. package/dist/types/components/DatePicker/helpers/is-disabled-date.d.ts +1 -0
  534. package/dist/types/components/DatePicker/helpers/is-disabled-date.test.d.ts +1 -0
  535. package/dist/types/components/DatePicker/helpers/is-range-valid.d.ts +1 -0
  536. package/dist/types/components/DatePicker/helpers/is-range-valid.test.d.ts +1 -0
  537. package/dist/types/components/DatePicker/helpers/parse-date-string.d.ts +5 -0
  538. package/dist/types/components/DatePicker/helpers/parse-date-string.test.d.ts +1 -0
  539. package/dist/types/components/DatePicker/helpers/parse-range-string.d.ts +14 -0
  540. package/dist/types/components/DatePicker/helpers/parse-range-string.test.d.ts +1 -0
  541. package/dist/types/components/DatePicker/index.d.ts +6 -0
  542. package/dist/types/components/Disclosure/Disclosure.d.ts +1 -2
  543. package/dist/types/components/Disclosure/index.d.ts +1 -1
  544. package/dist/types/components/DisclosureMini/DisclosureMini.d.ts +1 -2
  545. package/dist/types/components/Download/Download.d.ts +41 -0
  546. package/dist/types/components/Download/index.d.ts +1 -0
  547. package/dist/types/components/Filter/Filter.d.ts +1 -1
  548. package/dist/types/components/Filter/FilterItems/FilterItems.d.ts +4 -0
  549. package/dist/types/components/FormControl/FormControl.d.ts +5 -1
  550. package/dist/types/components/Grid/Grid.constants.d.ts +1 -0
  551. package/dist/types/components/Grid/Grid.d.ts +28 -0
  552. package/dist/types/components/Grid/Grid.types.d.ts +10 -0
  553. package/dist/types/components/Grid/components/Col/Col.d.ts +10 -0
  554. package/dist/types/components/Grid/components/Col/index.d.ts +1 -0
  555. package/dist/types/components/Grid/components/Row/Row.d.ts +10 -0
  556. package/dist/types/components/Grid/components/Row/index.d.ts +1 -0
  557. package/dist/types/components/Grid/index.d.ts +2 -0
  558. package/dist/types/components/Heading/Heading.d.ts +4 -0
  559. package/dist/types/components/Heading/index.d.ts +1 -1
  560. package/dist/types/components/HeroBanner/HeroBanner.d.ts +5 -0
  561. package/dist/types/components/HeroBanner/index.d.ts +1 -0
  562. package/dist/types/components/HeroButton/HeroButton.d.ts +66 -0
  563. package/dist/types/components/HeroButton/index.d.ts +1 -0
  564. package/dist/types/components/Hidden/Hidden.d.ts +11 -0
  565. package/dist/types/components/Hidden/index.d.ts +1 -0
  566. package/dist/types/components/Icon/Icon.d.ts +6 -2
  567. package/dist/types/components/Image/Image.d.ts +4 -0
  568. package/dist/types/components/ImpactCard/ImpactCard.d.ts +58 -0
  569. package/dist/types/components/ImpactCard/index.d.ts +1 -0
  570. package/dist/types/components/InformationCard/InformationCard.d.ts +62 -0
  571. package/dist/types/components/InformationCard/index.d.ts +1 -0
  572. package/dist/types/components/Link/Link.d.ts +52 -0
  573. package/dist/types/components/Link/index.d.ts +1 -0
  574. package/dist/types/components/MediaCard/MediaCard.d.ts +27 -28
  575. package/dist/types/components/MediaCard/index.d.ts +1 -1
  576. package/dist/types/components/MediaCard/types/index.d.ts +2 -0
  577. package/dist/types/components/MediaCard/types/media-card-image.d.ts +4 -0
  578. package/dist/types/components/MediaCard/types/media-card-video.d.ts +4 -0
  579. package/dist/types/components/Modal/Modal.d.ts +3 -3
  580. package/dist/types/components/PageBanner/PageBanner.d.ts +5 -0
  581. package/dist/types/components/PageBanner/index.d.ts +1 -0
  582. package/dist/types/components/Pagination/Pagination.d.ts +1 -1
  583. package/dist/types/components/PaginationSimple/PaginationSimple.d.ts +26 -10
  584. package/dist/types/components/Poster/Poster.d.ts +1 -1
  585. package/dist/types/components/ProgressBar/ProgressBar.d.ts +4 -0
  586. package/dist/types/components/ProgressStepper/ProgressStepper.d.ts +2 -2
  587. package/dist/types/components/ProgressStepper/ProgressStepperItem/ProgressStepperItem.d.ts +3 -7
  588. package/dist/types/components/ProgressStepper/ProgressStepperItem/icons/Complete.d.ts +2 -0
  589. package/dist/types/components/ProgressStepper/ProgressStepperItem/icons/Current.d.ts +2 -0
  590. package/dist/types/components/ProgressStepper/ProgressStepperItem/icons/Error.d.ts +2 -0
  591. package/dist/types/components/ProgressStepper/ProgressStepperItem/icons/Warning.d.ts +2 -0
  592. package/dist/types/components/RadioGroup/RadioButton/RadioButton.d.ts +17 -23
  593. package/dist/types/components/RadioGroup/RadioButtonGroupInput/RadioButtonGroupInput.d.ts +36 -0
  594. package/dist/types/components/RadioGroup/RadioButtonGroupInput/index.d.ts +1 -0
  595. package/dist/types/components/RadioGroup/RadioGroup.d.ts +11 -3
  596. package/dist/types/components/RadioGroup/context.d.ts +1 -1
  597. package/dist/types/components/RadioGroup/index.d.ts +1 -0
  598. package/dist/types/components/Rule/Rule.d.ts +2 -1
  599. package/dist/types/components/Select/Select.d.ts +53 -0
  600. package/dist/types/components/SiteFooter/index.d.ts +0 -1
  601. package/dist/types/components/SiteHeaderV2/SiteHeaderV2.d.ts +82 -0
  602. package/dist/types/components/{SiteHeader → SiteHeaderV2}/components/BackButton/BackButton.d.ts +1 -0
  603. package/dist/types/components/{SiteHeader → SiteHeaderV2}/components/Column/Column.d.ts +1 -1
  604. package/dist/types/components/SiteHeaderV2/components/HorizontalPanel/HorizontalPanel.d.ts +13 -0
  605. package/dist/types/components/SiteHeaderV2/components/HorizontalPanel/index.d.ts +1 -0
  606. package/dist/types/components/{SiteHeader → SiteHeaderV2}/components/ItemGroup/ItemGroup.d.ts +1 -0
  607. package/dist/types/components/SiteHeaderV2/components/ItemGroup/index.d.ts +1 -0
  608. package/dist/types/components/{SiteHeader → SiteHeaderV2}/components/NavItem/NavItem.d.ts +5 -6
  609. package/dist/types/components/{SiteHeader → SiteHeaderV2}/components/NavItem/NavItemWithSubNav.d.ts +13 -4
  610. package/dist/types/components/SiteHeaderV2/components/NavItem/index.d.ts +2 -0
  611. package/dist/types/components/{SiteHeader → SiteHeaderV2}/components/NodeItem/NodeItem.d.ts +1 -1
  612. package/dist/types/components/{SiteHeader → SiteHeaderV2}/components/Panel/Panel.d.ts +8 -2
  613. package/dist/types/components/{SiteHeader → SiteHeaderV2}/components/SubNavItem/SubNavItem.d.ts +5 -7
  614. package/dist/types/components/SiteHeaderV2/components/SubNavItem/index.d.ts +1 -0
  615. package/dist/types/components/SiteHeaderV2/components/VerticalDivider/VerticalDivider.d.ts +2 -0
  616. package/dist/types/components/SiteHeaderV2/components/VerticalDivider/index.d.ts +1 -0
  617. package/dist/types/components/SiteHeaderV2/index.d.ts +1 -0
  618. package/dist/types/components/SkipLink/SkipLink.d.ts +12 -0
  619. package/dist/types/components/SkipLink/SkipLinkItem/SkipLinkItem.d.ts +16 -0
  620. package/dist/types/components/SkipLink/index.d.ts +1 -0
  621. package/dist/types/components/Spinner/Spinner.d.ts +16 -0
  622. package/dist/types/components/Spinner/index.d.ts +1 -0
  623. package/dist/types/components/Surface/Surface.d.ts +7 -3
  624. package/dist/types/components/Switch/Switch.d.ts +6 -2
  625. package/dist/types/components/Tabs/Tabs.d.ts +1 -0
  626. package/dist/types/components/Tabs/TabsList/TabsList.d.ts +5 -0
  627. package/dist/types/components/Tag/Tag.d.ts +5 -1
  628. package/dist/types/components/Text/Text.d.ts +4 -0
  629. package/dist/types/components/TextArea/TextArea.d.ts +17 -0
  630. package/dist/types/components/TextInput/TextInput.d.ts +46 -6
  631. package/dist/types/components/Theme/Theme.d.ts +11 -3
  632. package/dist/types/components/Theme/index.d.ts +1 -1
  633. package/dist/types/components/ThemeIcon/icon-names.d.ts +1 -1
  634. package/dist/types/components/Toast/Toast.d.ts +1 -1
  635. package/dist/types/components/Truncate/Truncate.d.ts +1 -1
  636. package/dist/types/components/TypographyCard/TypographyCard.d.ts +58 -0
  637. package/dist/types/components/TypographyCard/index.d.ts +1 -0
  638. package/dist/types/components/UniversalHeader/UniversalHeader.d.ts +4 -0
  639. package/dist/types/components/VideoPlayer/VideoPlayer.d.ts +27 -0
  640. package/dist/types/components/VideoPlayer/index.d.ts +1 -0
  641. package/dist/types/components/Visible/Visible.d.ts +11 -0
  642. package/dist/types/components/Visible/index.d.ts +1 -0
  643. package/dist/types/components/VisuallyHidden/VisuallyHidden.d.ts +1 -1
  644. package/dist/types/components/index.d.ts +24 -5
  645. package/dist/types/helpers/get-theme-img.d.ts +6 -0
  646. package/dist/types/helpers/index.d.ts +1 -2
  647. package/dist/types/hooks/index.d.ts +2 -4
  648. package/dist/types/hooks/private/index.d.ts +5 -0
  649. package/dist/types/hooks/private/use-aria-describedby/index.d.ts +1 -0
  650. package/dist/types/hooks/private/use-interaction-mode/index.d.ts +1 -0
  651. package/dist/types/hooks/private/use-numeric-input/index.d.ts +1 -0
  652. package/dist/types/hooks/{use-numeric-input.d.ts → private/use-numeric-input/use-numeric-input.d.ts} +3 -3
  653. package/dist/types/hooks/private/use-pagination/index.d.ts +1 -0
  654. package/dist/types/hooks/private/use-theme-element/index.d.ts +1 -0
  655. package/dist/types/hooks/public/index.d.ts +1 -0
  656. package/dist/types/hooks/public/use-media-query/index.d.ts +1 -0
  657. package/dist/types/hooks/{use-media-query.d.ts → public/use-media-query/use-media-query.d.ts} +1 -1
  658. package/dist/types/index.d.ts +1 -0
  659. package/dist/types/styles.d.ts +29 -6
  660. package/dist/types/types/auto-complete-types.d.ts +1 -0
  661. package/dist/use-media-query/package.json +7 -0
  662. package/dist/use-media-query/use-media-query.cjs.js +10 -0
  663. package/dist/use-media-query/use-media-query.esm.js +2 -0
  664. package/package.json +64 -40
  665. package/dist/Base/Base.cjs.js +0 -11
  666. package/dist/Base/Base.esm.js +0 -3
  667. package/dist/Base/package.json +0 -7
  668. package/dist/Card/Card.cjs.js +0 -18
  669. package/dist/Card/Card.esm.js +0 -10
  670. package/dist/Card/package.json +0 -7
  671. package/dist/Clock/Clock.cjs.js +0 -43
  672. package/dist/Clock/Clock.esm.js +0 -34
  673. package/dist/Clock/package.json +0 -7
  674. package/dist/SiteHeader/SiteHeader.cjs.js +0 -22
  675. package/dist/SiteHeader/SiteHeader.esm.js +0 -13
  676. package/dist/SiteHeader/package.json +0 -7
  677. package/dist/_shared/cjs/Base-f5a86eed.js +0 -22
  678. package/dist/_shared/cjs/Card-eb1c20c1.js +0 -121
  679. package/dist/_shared/cjs/Checkbox-5f14bb0d.js +0 -61
  680. package/dist/_shared/cjs/Icon-a47b6c0a.js +0 -33
  681. package/dist/_shared/cjs/Image-e873b8fc.js +0 -46
  682. package/dist/_shared/cjs/ProgressStepper-74ee1eec.js +0 -88
  683. package/dist/_shared/cjs/RadioGroup-9bc96f6a.js +0 -69
  684. package/dist/_shared/cjs/SiteHeader.rehydrator-42c4a0e0.js +0 -670
  685. package/dist/_shared/cjs/Surface-038db6e1.js +0 -57
  686. package/dist/_shared/cjs/TextInput-a5f72f6f.js +0 -81
  687. package/dist/_shared/cjs/UniversalHeader-5e43d320.js +0 -34
  688. package/dist/_shared/cjs/VisuallyHidden-e2c8b291.js +0 -17
  689. package/dist/_shared/cjs/extends-8c5e4b48.js +0 -18
  690. package/dist/_shared/cjs/filter-data-attrs-1c9a530c.js +0 -227
  691. package/dist/_shared/cjs/index-4aa11039.js +0 -490
  692. package/dist/_shared/cjs/index-4dd46cbe.js +0 -289
  693. package/dist/_shared/cjs/suffix-modifier-64dcd338.js +0 -19
  694. package/dist/_shared/esm/Base-f200653c.js +0 -15
  695. package/dist/_shared/esm/Card-45e8e10a.js +0 -115
  696. package/dist/_shared/esm/Checkbox-2a623386.js +0 -55
  697. package/dist/_shared/esm/Icon-9ecaaeab.js +0 -27
  698. package/dist/_shared/esm/ProgressStepper-5de34269.js +0 -82
  699. package/dist/_shared/esm/RadioGroup-002a32ba.js +0 -63
  700. package/dist/_shared/esm/SiteHeader.rehydrator-97900e11.js +0 -663
  701. package/dist/_shared/esm/Surface-0ca6817d.js +0 -48
  702. package/dist/_shared/esm/TextInput-28f18769.js +0 -75
  703. package/dist/_shared/esm/VisuallyHidden-b9eebf71.js +0 -11
  704. package/dist/_shared/esm/extends-8cc61aad.js +0 -16
  705. package/dist/_shared/esm/filter-data-attrs-ea8f4ed4.js +0 -220
  706. package/dist/_shared/esm/index-4f8d3888.js +0 -280
  707. package/dist/_shared/esm/index-87a828b8.js +0 -479
  708. package/dist/_shared/esm/suffix-modifier-3d548e45.js +0 -17
  709. package/dist/types/components/Base/Base.d.ts +0 -16
  710. package/dist/types/components/Base/index.d.ts +0 -1
  711. package/dist/types/components/Card/Card.d.ts +0 -128
  712. package/dist/types/components/Card/index.d.ts +0 -1
  713. package/dist/types/components/Clock/Clock.d.ts +0 -12
  714. package/dist/types/components/Clock/Clock.rehydrator.d.ts +0 -2
  715. package/dist/types/components/Clock/index.d.ts +0 -2
  716. package/dist/types/components/MediaCard/MediaCard.stories-wip.d.ts +0 -15
  717. package/dist/types/components/SiteFooter/SiteFooter.rehydrator.d.ts +0 -2
  718. package/dist/types/components/SiteHeader/SiteHeader.d.ts +0 -75
  719. package/dist/types/components/SiteHeader/SiteHeader.rehydrator.d.ts +0 -8
  720. package/dist/types/components/SiteHeader/components/ItemGroup/ItemGroup.rehydrator.d.ts +0 -2
  721. package/dist/types/components/SiteHeader/components/ItemGroup/index.d.ts +0 -2
  722. package/dist/types/components/SiteHeader/components/NavItem/NavItem.rehydrator.d.ts +0 -2
  723. package/dist/types/components/SiteHeader/components/NavItem/NavItemWithSubNav.rehydrator.d.ts +0 -2
  724. package/dist/types/components/SiteHeader/components/NavItem/index.d.ts +0 -4
  725. package/dist/types/components/SiteHeader/components/SubNavItem/SubNavItem.rehydrator.d.ts +0 -2
  726. package/dist/types/components/SiteHeader/components/SubNavItem/index.d.ts +0 -2
  727. package/dist/types/components/SiteHeader/index.d.ts +0 -2
  728. package/dist/types/helpers/filter-data-attrs.d.ts +0 -1
  729. package/dist/types/helpers/suffix-modifier.d.ts +0 -9
  730. /package/dist/types/components/{SiteHeader → SiteHeaderV2}/components/BackButton/index.d.ts +0 -0
  731. /package/dist/types/components/{SiteHeader → SiteHeaderV2}/components/Column/index.d.ts +0 -0
  732. /package/dist/types/components/{SiteHeader → SiteHeaderV2}/components/Item/Item.d.ts +0 -0
  733. /package/dist/types/components/{SiteHeader → SiteHeaderV2}/components/Item/index.d.ts +0 -0
  734. /package/dist/types/components/{SiteHeader → SiteHeaderV2}/components/MenuButton/MenuButton.d.ts +0 -0
  735. /package/dist/types/components/{SiteHeader → SiteHeaderV2}/components/MenuButton/index.d.ts +0 -0
  736. /package/dist/types/components/{SiteHeader → SiteHeaderV2}/components/Panel/index.d.ts +0 -0
  737. /package/dist/types/hooks/{use-aria-describedby.d.ts → private/use-aria-describedby/use-aria-describedby.d.ts} +0 -0
  738. /package/dist/types/hooks/{use-interaction-mode.d.ts → private/use-interaction-mode/use-interaction-mode.d.ts} +0 -0
  739. /package/dist/types/hooks/{use-pagination.d.ts → private/use-pagination/use-pagination.d.ts} +0 -0
@@ -0,0 +1,1927 @@
1
+ 'use strict';
2
+
3
+ var index_es = require('./index.es-0c2c97f4.js');
4
+ var React = require('react');
5
+ var index = require('./index-28fbfd5b.js');
6
+ var index_es$1 = require('./index.es-0f681622.js');
7
+ var useMediaQuery = require('./use-media-query-d34c83b9.js');
8
+ var index$1 = require('./index-9947ac13.js');
9
+ var Text = require('./Text-1b3e4fb6.js');
10
+ var VisuallyHidden = require('./VisuallyHidden-c691ea4d.js');
11
+ var Surface = require('./Surface-ca708a8c.js');
12
+ var Heading = require('./Heading-b4b65724.js');
13
+ var BtIconChevronRightMid_esm = require('./BtIconChevronRightMid.esm-3e8d18a9.js');
14
+ var Icon = require('./Icon-5dd78f2b.js');
15
+
16
+ function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
17
+
18
+ var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
19
+
20
+ /**
21
+ * @name addMonths
22
+ * @category Month Helpers
23
+ * @summary Add the specified number of months to the given date.
24
+ *
25
+ * @description
26
+ * Add the specified number of months to the given date.
27
+ *
28
+ * @param {Date|Number} date - the date to be changed
29
+ * @param {Number} amount - the amount of months to be added. Positive decimals will be rounded using `Math.floor`, decimals less than zero will be rounded using `Math.ceil`.
30
+ * @returns {Date} the new date with the months added
31
+ * @throws {TypeError} 2 arguments required
32
+ *
33
+ * @example
34
+ * // Add 5 months to 1 September 2014:
35
+ * const result = addMonths(new Date(2014, 8, 1), 5)
36
+ * //=> Sun Feb 01 2015 00:00:00
37
+ */
38
+ function addMonths(dirtyDate, dirtyAmount) {
39
+ index.requiredArgs(2, arguments);
40
+ var date = index.toDate(dirtyDate);
41
+ var amount = index.toInteger(dirtyAmount);
42
+ if (isNaN(amount)) {
43
+ return new Date(NaN);
44
+ }
45
+ if (!amount) {
46
+ // If 0 months, no-op to avoid changing times in the hour before end of DST
47
+ return date;
48
+ }
49
+ var dayOfMonth = date.getDate();
50
+
51
+ // The JS Date object supports date math by accepting out-of-bounds values for
52
+ // month, day, etc. For example, new Date(2020, 0, 0) returns 31 Dec 2019 and
53
+ // new Date(2020, 13, 1) returns 1 Feb 2021. This is *almost* the behavior we
54
+ // want except that dates will wrap around the end of a month, meaning that
55
+ // new Date(2020, 13, 31) will return 3 Mar 2021 not 28 Feb 2021 as desired. So
56
+ // we'll default to the end of the desired month by adding 1 to the desired
57
+ // month and using a date of 0 to back up one day to the end of the desired
58
+ // month.
59
+ var endOfDesiredMonth = new Date(date.getTime());
60
+ endOfDesiredMonth.setMonth(date.getMonth() + amount + 1, 0);
61
+ var daysInMonth = endOfDesiredMonth.getDate();
62
+ if (dayOfMonth >= daysInMonth) {
63
+ // If we're already at the end of the month, then this is the correct date
64
+ // and we're done.
65
+ return endOfDesiredMonth;
66
+ } else {
67
+ // Otherwise, we now know that setting the original day-of-month value won't
68
+ // cause an overflow, so set the desired day-of-month. Note that we can't
69
+ // just set the date of `endOfDesiredMonth` because that object may have had
70
+ // its time changed in the unusual case where where a DST transition was on
71
+ // the last day of the month and its local time was in the hour skipped or
72
+ // repeated next to a DST transition. So we use `date` instead which is
73
+ // guaranteed to still have the original time.
74
+ date.setFullYear(endOfDesiredMonth.getFullYear(), endOfDesiredMonth.getMonth(), dayOfMonth);
75
+ return date;
76
+ }
77
+ }
78
+
79
+ /**
80
+ * @name subMonths
81
+ * @category Month Helpers
82
+ * @summary Subtract the specified number of months from the given date.
83
+ *
84
+ * @description
85
+ * Subtract the specified number of months from the given date.
86
+ *
87
+ * @param {Date|Number} date - the date to be changed
88
+ * @param {Number} amount - the amount of months to be subtracted. Positive decimals will be rounded using `Math.floor`, decimals less than zero will be rounded using `Math.ceil`.
89
+ * @returns {Date} the new date with the months subtracted
90
+ * @throws {TypeError} 2 arguments required
91
+ *
92
+ * @example
93
+ * // Subtract 5 months from 1 February 2015:
94
+ * const result = subMonths(new Date(2015, 1, 1), 5)
95
+ * //=> Mon Sep 01 2014 00:00:00
96
+ */
97
+ function subMonths(dirtyDate, dirtyAmount) {
98
+ index.requiredArgs(2, arguments);
99
+ var amount = index.toInteger(dirtyAmount);
100
+ return addMonths(dirtyDate, -amount);
101
+ }
102
+
103
+ /**
104
+ * @name startOfMonth
105
+ * @category Month Helpers
106
+ * @summary Return the start of a month for the given date.
107
+ *
108
+ * @description
109
+ * Return the start of a month for the given date.
110
+ * The result will be in the local timezone.
111
+ *
112
+ * @param {Date|Number} date - the original date
113
+ * @returns {Date} the start of a month
114
+ * @throws {TypeError} 1 argument required
115
+ *
116
+ * @example
117
+ * // The start of a month for 2 September 2014 11:55:00:
118
+ * const result = startOfMonth(new Date(2014, 8, 2, 11, 55, 0))
119
+ * //=> Mon Sep 01 2014 00:00:00
120
+ */
121
+ function startOfMonth(dirtyDate) {
122
+ index.requiredArgs(1, arguments);
123
+ var date = index.toDate(dirtyDate);
124
+ date.setDate(1);
125
+ date.setHours(0, 0, 0, 0);
126
+ return date;
127
+ }
128
+
129
+ var containsDate = function (dates, compareDate) {
130
+ return dates.map(function (date) { return date.getTime(); }).includes(compareDate.getTime());
131
+ };
132
+
133
+ /**
134
+ * @name getMonth
135
+ * @category Month Helpers
136
+ * @summary Get the month of the given date.
137
+ *
138
+ * @description
139
+ * Get the month of the given date.
140
+ *
141
+ * @param {Date|Number} date - the given date
142
+ * @returns {Number} the month
143
+ * @throws {TypeError} 1 argument required
144
+ *
145
+ * @example
146
+ * // Which month is 29 February 2012?
147
+ * const result = getMonth(new Date(2012, 1, 29))
148
+ * //=> 1
149
+ */
150
+ function getMonth(dirtyDate) {
151
+ index.requiredArgs(1, arguments);
152
+ var date = index.toDate(dirtyDate);
153
+ var month = date.getMonth();
154
+ return month;
155
+ }
156
+
157
+ /**
158
+ * @name getYear
159
+ * @category Year Helpers
160
+ * @summary Get the year of the given date.
161
+ *
162
+ * @description
163
+ * Get the year of the given date.
164
+ *
165
+ * @param {Date|Number} date - the given date
166
+ * @returns {Number} the year
167
+ * @throws {TypeError} 1 argument required
168
+ *
169
+ * @example
170
+ * // Which year is 2 July 2014?
171
+ * const result = getYear(new Date(2014, 6, 2))
172
+ * //=> 2014
173
+ */
174
+ function getYear(dirtyDate) {
175
+ index.requiredArgs(1, arguments);
176
+ return index.toDate(dirtyDate).getFullYear();
177
+ }
178
+
179
+ /**
180
+ * @name getDaysInMonth
181
+ * @category Month Helpers
182
+ * @summary Get the number of days in a month of the given date.
183
+ *
184
+ * @description
185
+ * Get the number of days in a month of the given date.
186
+ *
187
+ * @param {Date|Number} date - the given date
188
+ * @returns {Number} the number of days in a month
189
+ * @throws {TypeError} 1 argument required
190
+ *
191
+ * @example
192
+ * // How many days are in February 2000?
193
+ * const result = getDaysInMonth(new Date(2000, 1))
194
+ * //=> 29
195
+ */
196
+ function getDaysInMonth(dirtyDate) {
197
+ index.requiredArgs(1, arguments);
198
+ var date = index.toDate(dirtyDate);
199
+ var year = date.getFullYear();
200
+ var monthIndex = date.getMonth();
201
+ var lastDayOfMonth = new Date(0);
202
+ lastDayOfMonth.setFullYear(year, monthIndex + 1, 0);
203
+ lastDayOfMonth.setHours(0, 0, 0, 0);
204
+ return lastDayOfMonth.getDate();
205
+ }
206
+
207
+ /**
208
+ * @name setMonth
209
+ * @category Month Helpers
210
+ * @summary Set the month to the given date.
211
+ *
212
+ * @description
213
+ * Set the month to the given date.
214
+ *
215
+ * @param {Date|Number} date - the date to be changed
216
+ * @param {Number} month - the month of the new date
217
+ * @returns {Date} the new date with the month set
218
+ * @throws {TypeError} 2 arguments required
219
+ *
220
+ * @example
221
+ * // Set February to 1 September 2014:
222
+ * const result = setMonth(new Date(2014, 8, 1), 1)
223
+ * //=> Sat Feb 01 2014 00:00:00
224
+ */
225
+ function setMonth(dirtyDate, dirtyMonth) {
226
+ index.requiredArgs(2, arguments);
227
+ var date = index.toDate(dirtyDate);
228
+ var month = index.toInteger(dirtyMonth);
229
+ var year = date.getFullYear();
230
+ var day = date.getDate();
231
+ var dateWithDesiredMonth = new Date(0);
232
+ dateWithDesiredMonth.setFullYear(year, month, 15);
233
+ dateWithDesiredMonth.setHours(0, 0, 0, 0);
234
+ var daysInMonth = getDaysInMonth(dateWithDesiredMonth);
235
+ // Set the last day of the new month
236
+ // if the original date was the last day of the longer month
237
+ date.setMonth(month, Math.min(day, daysInMonth));
238
+ return date;
239
+ }
240
+
241
+ /**
242
+ * @name set
243
+ * @category Common Helpers
244
+ * @summary Set date values to a given date.
245
+ *
246
+ * @description
247
+ * Set date values to a given date.
248
+ *
249
+ * Sets time values to date from object `values`.
250
+ * A value is not set if it is undefined or null or doesn't exist in `values`.
251
+ *
252
+ * Note about bundle size: `set` does not internally use `setX` functions from date-fns but instead opts
253
+ * to use native `Date#setX` methods. If you use this function, you may not want to include the
254
+ * other `setX` functions that date-fns provides if you are concerned about the bundle size.
255
+ *
256
+ * @param {Date|Number} date - the date to be changed
257
+ * @param {Object} values - an object with options
258
+ * @param {Number} [values.year] - the number of years to be set
259
+ * @param {Number} [values.month] - the number of months to be set
260
+ * @param {Number} [values.date] - the number of days to be set
261
+ * @param {Number} [values.hours] - the number of hours to be set
262
+ * @param {Number} [values.minutes] - the number of minutes to be set
263
+ * @param {Number} [values.seconds] - the number of seconds to be set
264
+ * @param {Number} [values.milliseconds] - the number of milliseconds to be set
265
+ * @returns {Date} the new date with options set
266
+ * @throws {TypeError} 2 arguments required
267
+ * @throws {RangeError} `values` must be an object
268
+ *
269
+ * @example
270
+ * // Transform 1 September 2014 into 20 October 2015 in a single line:
271
+ * const result = set(new Date(2014, 8, 20), { year: 2015, month: 9, date: 20 })
272
+ * //=> Tue Oct 20 2015 00:00:00
273
+ *
274
+ * @example
275
+ * // Set 12 PM to 1 September 2014 01:23:45 to 1 September 2014 12:00:00:
276
+ * const result = set(new Date(2014, 8, 1, 1, 23, 45), { hours: 12 })
277
+ * //=> Mon Sep 01 2014 12:23:45
278
+ */
279
+ function set(dirtyDate, values) {
280
+ index.requiredArgs(2, arguments);
281
+ if (index._typeof(values) !== 'object' || values === null) {
282
+ throw new RangeError('values parameter must be an object');
283
+ }
284
+ var date = index.toDate(dirtyDate);
285
+
286
+ // Check if date is Invalid Date because Date.prototype.setFullYear ignores the value of Invalid Date
287
+ if (isNaN(date.getTime())) {
288
+ return new Date(NaN);
289
+ }
290
+ if (values.year != null) {
291
+ date.setFullYear(values.year);
292
+ }
293
+ if (values.month != null) {
294
+ date = setMonth(date, values.month);
295
+ }
296
+ if (values.date != null) {
297
+ date.setDate(index.toInteger(values.date));
298
+ }
299
+ if (values.hours != null) {
300
+ date.setHours(index.toInteger(values.hours));
301
+ }
302
+ if (values.minutes != null) {
303
+ date.setMinutes(index.toInteger(values.minutes));
304
+ }
305
+ if (values.seconds != null) {
306
+ date.setSeconds(index.toInteger(values.seconds));
307
+ }
308
+ if (values.milliseconds != null) {
309
+ date.setMilliseconds(index.toInteger(values.milliseconds));
310
+ }
311
+ return date;
312
+ }
313
+
314
+ var dateWithoutTime = function (date) {
315
+ return set(new Date(date), {
316
+ hours: 0,
317
+ minutes: 0,
318
+ milliseconds: 0,
319
+ seconds: 0
320
+ });
321
+ };
322
+
323
+ var getDatesInMonth = function (date) {
324
+ var dateYear = getYear(date);
325
+ var dateMonth = getMonth(date);
326
+ return Array.from({ length: getDaysInMonth(date) }, function (_, i) {
327
+ return dateWithoutTime(new Date(dateYear, dateMonth, i + 1));
328
+ });
329
+ };
330
+
331
+ /**
332
+ * @name getDay
333
+ * @category Weekday Helpers
334
+ * @summary Get the day of the week of the given date.
335
+ *
336
+ * @description
337
+ * Get the day of the week of the given date.
338
+ *
339
+ * @param {Date|Number} date - the given date
340
+ * @returns {0|1|2|3|4|5|6} the day of week, 0 represents Sunday
341
+ * @throws {TypeError} 1 argument required
342
+ *
343
+ * @example
344
+ * // Which day of the week is 29 February 2012?
345
+ * const result = getDay(new Date(2012, 1, 29))
346
+ * //=> 3
347
+ */
348
+ function getDay(dirtyDate) {
349
+ index.requiredArgs(1, arguments);
350
+ var date = index.toDate(dirtyDate);
351
+ var day = date.getDay();
352
+ return day;
353
+ }
354
+
355
+ var WeekDaysAbbr;
356
+ (function (WeekDaysAbbr) {
357
+ WeekDaysAbbr["MON"] = "Mon";
358
+ WeekDaysAbbr["TUE"] = "Tue";
359
+ WeekDaysAbbr["WED"] = "Wed";
360
+ WeekDaysAbbr["THUR"] = "Thur";
361
+ WeekDaysAbbr["FRI"] = "Fri";
362
+ WeekDaysAbbr["SAT"] = "Sat";
363
+ WeekDaysAbbr["SUN"] = "Sun";
364
+ })(WeekDaysAbbr || (WeekDaysAbbr = {}));
365
+ var WeekDays;
366
+ (function (WeekDays) {
367
+ WeekDays["MONDAY"] = "Monday";
368
+ WeekDays["TUESDAY"] = "Tuesday";
369
+ WeekDays["WEDNESDAY"] = "Wednesday";
370
+ WeekDays["THURSDAY"] = "Thursday";
371
+ WeekDays["FRIDAY"] = "Friday";
372
+ WeekDays["SATURDAY"] = "Saturday";
373
+ WeekDays["SUNDAY"] = "Sunday";
374
+ })(WeekDays || (WeekDays = {}));
375
+
376
+ var isDay = function (date, day) {
377
+ var _a;
378
+ var dayMap = (_a = {},
379
+ _a[WeekDays.MONDAY] = 1,
380
+ _a[WeekDays.TUESDAY] = 2,
381
+ _a[WeekDays.WEDNESDAY] = 3,
382
+ _a[WeekDays.THURSDAY] = 4,
383
+ _a[WeekDays.FRIDAY] = 5,
384
+ _a[WeekDays.SATURDAY] = 6,
385
+ _a[WeekDays.SUNDAY] = 0,
386
+ _a);
387
+ return getDay(date) === dayMap[day];
388
+ };
389
+
390
+ /**
391
+ * @name isBefore
392
+ * @category Common Helpers
393
+ * @summary Is the first date before the second one?
394
+ *
395
+ * @description
396
+ * Is the first date before the second one?
397
+ *
398
+ * @param {Date|Number} date - the date that should be before the other one to return true
399
+ * @param {Date|Number} dateToCompare - the date to compare with
400
+ * @returns {Boolean} the first date is before the second date
401
+ * @throws {TypeError} 2 arguments required
402
+ *
403
+ * @example
404
+ * // Is 10 July 1989 before 11 February 1987?
405
+ * const result = isBefore(new Date(1989, 6, 10), new Date(1987, 1, 11))
406
+ * //=> false
407
+ */
408
+ function isBefore(dirtyDate, dirtyDateToCompare) {
409
+ index.requiredArgs(2, arguments);
410
+ var date = index.toDate(dirtyDate);
411
+ var dateToCompare = index.toDate(dirtyDateToCompare);
412
+ return date.getTime() < dateToCompare.getTime();
413
+ }
414
+
415
+ /**
416
+ * @name isAfter
417
+ * @category Common Helpers
418
+ * @summary Is the first date after the second one?
419
+ *
420
+ * @description
421
+ * Is the first date after the second one?
422
+ *
423
+ * @param {Date|Number} date - the date that should be after the other one to return true
424
+ * @param {Date|Number} dateToCompare - the date to compare with
425
+ * @returns {Boolean} the first date is after the second date
426
+ * @throws {TypeError} 2 arguments required
427
+ *
428
+ * @example
429
+ * // Is 10 July 1989 after 11 February 1987?
430
+ * const result = isAfter(new Date(1989, 6, 10), new Date(1987, 1, 11))
431
+ * //=> true
432
+ */
433
+ function isAfter(dirtyDate, dirtyDateToCompare) {
434
+ index.requiredArgs(2, arguments);
435
+ var date = index.toDate(dirtyDate);
436
+ var dateToCompare = index.toDate(dirtyDateToCompare);
437
+ return date.getTime() > dateToCompare.getTime();
438
+ }
439
+
440
+ var isDisabledDate = function (date, disabledDates, minDate, maxDate) {
441
+ return ((minDate && isBefore(date, minDate)) ||
442
+ (maxDate && isAfter(date, maxDate)) ||
443
+ (disabledDates && containsDate(disabledDates, date)));
444
+ };
445
+
446
+ var isMonthBeforeMinDate = function (month, minDate) {
447
+ return getDatesInMonth(month).every(function (date) {
448
+ return isBefore(date, minDate);
449
+ });
450
+ };
451
+
452
+ var isMonthAfterMaxDate = function (date, maxDate) {
453
+ return getDatesInMonth(date).every(function (date) {
454
+ return isAfter(date, maxDate);
455
+ });
456
+ };
457
+
458
+ /**
459
+ * @name compareAsc
460
+ * @category Common Helpers
461
+ * @summary Compare the two dates and return -1, 0 or 1.
462
+ *
463
+ * @description
464
+ * Compare the two dates and return 1 if the first date is after the second,
465
+ * -1 if the first date is before the second or 0 if dates are equal.
466
+ *
467
+ * @param {Date|Number} dateLeft - the first date to compare
468
+ * @param {Date|Number} dateRight - the second date to compare
469
+ * @returns {Number} the result of the comparison
470
+ * @throws {TypeError} 2 arguments required
471
+ *
472
+ * @example
473
+ * // Compare 11 February 1987 and 10 July 1989:
474
+ * const result = compareAsc(new Date(1987, 1, 11), new Date(1989, 6, 10))
475
+ * //=> -1
476
+ *
477
+ * @example
478
+ * // Sort the array of dates:
479
+ * const result = [
480
+ * new Date(1995, 6, 2),
481
+ * new Date(1987, 1, 11),
482
+ * new Date(1989, 6, 10)
483
+ * ].sort(compareAsc)
484
+ * //=> [
485
+ * // Wed Feb 11 1987 00:00:00,
486
+ * // Mon Jul 10 1989 00:00:00,
487
+ * // Sun Jul 02 1995 00:00:00
488
+ * // ]
489
+ */
490
+ function compareAsc(dirtyDateLeft, dirtyDateRight) {
491
+ index.requiredArgs(2, arguments);
492
+ var dateLeft = index.toDate(dirtyDateLeft);
493
+ var dateRight = index.toDate(dirtyDateRight);
494
+ var diff = dateLeft.getTime() - dateRight.getTime();
495
+ if (diff < 0) {
496
+ return -1;
497
+ } else if (diff > 0) {
498
+ return 1;
499
+ // Return 0 if diff is 0; return NaN if diff is NaN
500
+ } else {
501
+ return diff;
502
+ }
503
+ }
504
+
505
+ /**
506
+ * @name eachDayOfInterval
507
+ * @category Interval Helpers
508
+ * @summary Return the array of dates within the specified time interval.
509
+ *
510
+ * @description
511
+ * Return the array of dates within the specified time interval.
512
+ *
513
+ * @param {Interval} interval - the interval. See [Interval]{@link https://date-fns.org/docs/Interval}
514
+ * @param {Object} [options] - an object with options.
515
+ * @param {Number} [options.step=1] - the step to increment by. The value should be more than 1.
516
+ * @returns {Date[]} the array with starts of days from the day of the interval start to the day of the interval end
517
+ * @throws {TypeError} 1 argument required
518
+ * @throws {RangeError} `options.step` must be a number greater than 1
519
+ * @throws {RangeError} The start of an interval cannot be after its end
520
+ * @throws {RangeError} Date in interval cannot be `Invalid Date`
521
+ *
522
+ * @example
523
+ * // Each day between 6 October 2014 and 10 October 2014:
524
+ * const result = eachDayOfInterval({
525
+ * start: new Date(2014, 9, 6),
526
+ * end: new Date(2014, 9, 10)
527
+ * })
528
+ * //=> [
529
+ * // Mon Oct 06 2014 00:00:00,
530
+ * // Tue Oct 07 2014 00:00:00,
531
+ * // Wed Oct 08 2014 00:00:00,
532
+ * // Thu Oct 09 2014 00:00:00,
533
+ * // Fri Oct 10 2014 00:00:00
534
+ * // ]
535
+ */
536
+ function eachDayOfInterval(dirtyInterval, options) {
537
+ var _options$step;
538
+ index.requiredArgs(1, arguments);
539
+ var interval = dirtyInterval || {};
540
+ var startDate = index.toDate(interval.start);
541
+ var endDate = index.toDate(interval.end);
542
+ var endTime = endDate.getTime();
543
+
544
+ // Throw an exception if start date is after end date or if any date is `Invalid Date`
545
+ if (!(startDate.getTime() <= endTime)) {
546
+ throw new RangeError('Invalid interval');
547
+ }
548
+ var dates = [];
549
+ var currentDate = startDate;
550
+ currentDate.setHours(0, 0, 0, 0);
551
+ var step = Number((_options$step = options === null || options === void 0 ? void 0 : options.step) !== null && _options$step !== void 0 ? _options$step : 1);
552
+ if (step < 1 || isNaN(step)) throw new RangeError('`options.step` must be a number greater than 1');
553
+ while (currentDate.getTime() <= endTime) {
554
+ dates.push(index.toDate(currentDate));
555
+ currentDate.setDate(currentDate.getDate() + step);
556
+ currentDate.setHours(0, 0, 0, 0);
557
+ }
558
+ return dates;
559
+ }
560
+
561
+ var processSelectedRange = function (_a) {
562
+ var range = _a.range, value = _a.value, disabledDates = _a.disabledDates;
563
+ var exisitingRange = range.filter(function (date) { return Boolean(date); });
564
+ var newRange = index_es.__spreadArray(index_es.__spreadArray([], (exisitingRange.length === 2 ? [] : exisitingRange), true), [
565
+ value,
566
+ ], false).sort(compareAsc);
567
+ var isSelectionComplete = newRange.length === 2;
568
+ var allDaysInRange = isSelectionComplete
569
+ ? eachDayOfInterval({
570
+ start: newRange[0],
571
+ end: newRange[1]
572
+ })
573
+ : [];
574
+ var rangeOnChangeValue = {
575
+ dates: allDaysInRange.map(function (date) { return ({
576
+ value: date,
577
+ disabled: disabledDates ? containsDate(disabledDates, date) : false
578
+ }); }),
579
+ selectedDate: value,
580
+ start: newRange[0],
581
+ end: newRange[1],
582
+ isSelectionComplete: isSelectionComplete
583
+ };
584
+ return {
585
+ rangeValue: newRange,
586
+ rangeOnChangeValue: rangeOnChangeValue
587
+ };
588
+ };
589
+
590
+ var getCalendarType = function (type, isDesktop) {
591
+ if (type === "double" && !isDesktop) {
592
+ return "month";
593
+ }
594
+ if (type === "double" && isDesktop) {
595
+ return "double";
596
+ }
597
+ return type;
598
+ };
599
+
600
+ var getDoubleMonthDisplayRange = function (date) {
601
+ var firstMonth = getMonth(date) % 2 !== 0 ? subMonths(date, 1) : date;
602
+ var secondMonth = addMonths(firstMonth, 1);
603
+ return [firstMonth, secondMonth];
604
+ };
605
+
606
+ var getFocusDate = function (_a) {
607
+ var minDate = _a.minDate, maxDate = _a.maxDate, date = _a.date;
608
+ var isFocusDateBeforeMinDate = minDate && isBefore(date, minDate);
609
+ var isFocusDateAfterMaxDate = maxDate && isAfter(date, maxDate);
610
+ if (isFocusDateBeforeMinDate) {
611
+ return minDate;
612
+ }
613
+ if (isFocusDateAfterMaxDate) {
614
+ return maxDate;
615
+ }
616
+ return date;
617
+ };
618
+
619
+ var getHighlightRange = function (_a) {
620
+ var date = _a.date, minDate = _a.minDate, maxDate = _a.maxDate, range = _a.range;
621
+ var existingRange = range.filter(function (date) { return Boolean(date); });
622
+ if (existingRange.filter(function (date) { return Boolean(date); }).length === 1) {
623
+ var isDateBeforeMinDate = minDate && isBefore(date, minDate);
624
+ var isDateAfterMaxDate = maxDate && isAfter(date, maxDate);
625
+ if (isDateBeforeMinDate) {
626
+ return [minDate, existingRange[0]].sort(compareAsc);
627
+ }
628
+ if (isDateAfterMaxDate) {
629
+ return [maxDate, existingRange[0]].sort(compareAsc);
630
+ }
631
+ return [date, existingRange[0]].sort(compareAsc);
632
+ }
633
+ return existingRange;
634
+ };
635
+
636
+ /**
637
+ * @name addDays
638
+ * @category Day Helpers
639
+ * @summary Add the specified number of days to the given date.
640
+ *
641
+ * @description
642
+ * Add the specified number of days to the given date.
643
+ *
644
+ * @param {Date|Number} date - the date to be changed
645
+ * @param {Number} amount - the amount of days to be added. Positive decimals will be rounded using `Math.floor`, decimals less than zero will be rounded using `Math.ceil`.
646
+ * @returns {Date} - the new date with the days added
647
+ * @throws {TypeError} - 2 arguments required
648
+ *
649
+ * @example
650
+ * // Add 10 days to 1 September 2014:
651
+ * const result = addDays(new Date(2014, 8, 1), 10)
652
+ * //=> Thu Sep 11 2014 00:00:00
653
+ */
654
+ function addDays(dirtyDate, dirtyAmount) {
655
+ index.requiredArgs(2, arguments);
656
+ var date = index.toDate(dirtyDate);
657
+ var amount = index.toInteger(dirtyAmount);
658
+ if (isNaN(amount)) {
659
+ return new Date(NaN);
660
+ }
661
+ if (!amount) {
662
+ // If 0 days, no-op to avoid changing times in the hour before end of DST
663
+ return date;
664
+ }
665
+ date.setDate(date.getDate() + amount);
666
+ return date;
667
+ }
668
+
669
+ /**
670
+ * @name addWeeks
671
+ * @category Week Helpers
672
+ * @summary Add the specified number of weeks to the given date.
673
+ *
674
+ * @description
675
+ * Add the specified number of week to the given date.
676
+ *
677
+ * @param {Date|Number} date - the date to be changed
678
+ * @param {Number} amount - the amount of weeks to be added. Positive decimals will be rounded using `Math.floor`, decimals less than zero will be rounded using `Math.ceil`.
679
+ * @returns {Date} the new date with the weeks added
680
+ * @throws {TypeError} 2 arguments required
681
+ *
682
+ * @example
683
+ * // Add 4 weeks to 1 September 2014:
684
+ * const result = addWeeks(new Date(2014, 8, 1), 4)
685
+ * //=> Mon Sep 29 2014 00:00:00
686
+ */
687
+ function addWeeks(dirtyDate, dirtyAmount) {
688
+ index.requiredArgs(2, arguments);
689
+ var amount = index.toInteger(dirtyAmount);
690
+ var days = amount * 7;
691
+ return addDays(dirtyDate, days);
692
+ }
693
+
694
+ /**
695
+ * @name subDays
696
+ * @category Day Helpers
697
+ * @summary Subtract the specified number of days from the given date.
698
+ *
699
+ * @description
700
+ * Subtract the specified number of days from the given date.
701
+ *
702
+ * @param {Date|Number} date - the date to be changed
703
+ * @param {Number} amount - the amount of days to be subtracted. Positive decimals will be rounded using `Math.floor`, decimals less than zero will be rounded using `Math.ceil`.
704
+ * @returns {Date} the new date with the days subtracted
705
+ * @throws {TypeError} 2 arguments required
706
+ *
707
+ * @example
708
+ * // Subtract 10 days from 1 September 2014:
709
+ * const result = subDays(new Date(2014, 8, 1), 10)
710
+ * //=> Fri Aug 22 2014 00:00:00
711
+ */
712
+ function subDays(dirtyDate, dirtyAmount) {
713
+ index.requiredArgs(2, arguments);
714
+ var amount = index.toInteger(dirtyAmount);
715
+ return addDays(dirtyDate, -amount);
716
+ }
717
+
718
+ /**
719
+ * @name startOfWeek
720
+ * @category Week Helpers
721
+ * @summary Return the start of a week for the given date.
722
+ *
723
+ * @description
724
+ * Return the start of a week for the given date.
725
+ * The result will be in the local timezone.
726
+ *
727
+ * @param {Date|Number} date - the original date
728
+ * @param {Object} [options] - an object with options.
729
+ * @param {Locale} [options.locale=defaultLocale] - the locale object. See [Locale]{@link https://date-fns.org/docs/Locale}
730
+ * @param {0|1|2|3|4|5|6} [options.weekStartsOn=0] - the index of the first day of the week (0 - Sunday)
731
+ * @returns {Date} the start of a week
732
+ * @throws {TypeError} 1 argument required
733
+ * @throws {RangeError} `options.weekStartsOn` must be between 0 and 6
734
+ *
735
+ * @example
736
+ * // The start of a week for 2 September 2014 11:55:00:
737
+ * const result = startOfWeek(new Date(2014, 8, 2, 11, 55, 0))
738
+ * //=> Sun Aug 31 2014 00:00:00
739
+ *
740
+ * @example
741
+ * // If the week starts on Monday, the start of the week for 2 September 2014 11:55:00:
742
+ * const result = startOfWeek(new Date(2014, 8, 2, 11, 55, 0), { weekStartsOn: 1 })
743
+ * //=> Mon Sep 01 2014 00:00:00
744
+ */
745
+ function startOfWeek(dirtyDate, options) {
746
+ var _ref, _ref2, _ref3, _options$weekStartsOn, _options$locale, _options$locale$optio, _defaultOptions$local, _defaultOptions$local2;
747
+ index.requiredArgs(1, arguments);
748
+ var defaultOptions = index.getDefaultOptions();
749
+ var weekStartsOn = index.toInteger((_ref = (_ref2 = (_ref3 = (_options$weekStartsOn = options === null || options === void 0 ? void 0 : options.weekStartsOn) !== null && _options$weekStartsOn !== void 0 ? _options$weekStartsOn : options === null || options === void 0 ? void 0 : (_options$locale = options.locale) === null || _options$locale === void 0 ? void 0 : (_options$locale$optio = _options$locale.options) === null || _options$locale$optio === void 0 ? void 0 : _options$locale$optio.weekStartsOn) !== null && _ref3 !== void 0 ? _ref3 : defaultOptions.weekStartsOn) !== null && _ref2 !== void 0 ? _ref2 : (_defaultOptions$local = defaultOptions.locale) === null || _defaultOptions$local === void 0 ? void 0 : (_defaultOptions$local2 = _defaultOptions$local.options) === null || _defaultOptions$local2 === void 0 ? void 0 : _defaultOptions$local2.weekStartsOn) !== null && _ref !== void 0 ? _ref : 0);
750
+
751
+ // Test if weekStartsOn is between 0 and 6 _and_ is not NaN
752
+ if (!(weekStartsOn >= 0 && weekStartsOn <= 6)) {
753
+ throw new RangeError('weekStartsOn must be between 0 and 6 inclusively');
754
+ }
755
+ var date = index.toDate(dirtyDate);
756
+ var day = date.getDay();
757
+ var diff = (day < weekStartsOn ? 7 : 0) + day - weekStartsOn;
758
+ date.setDate(date.getDate() - diff);
759
+ date.setHours(0, 0, 0, 0);
760
+ return date;
761
+ }
762
+
763
+ /**
764
+ * @name endOfWeek
765
+ * @category Week Helpers
766
+ * @summary Return the end of a week for the given date.
767
+ *
768
+ * @description
769
+ * Return the end of a week for the given date.
770
+ * The result will be in the local timezone.
771
+ *
772
+ * @param {Date|Number} date - the original date
773
+ * @param {Object} [options] - an object with options.
774
+ * @param {Locale} [options.locale=defaultLocale] - the locale object. See [Locale]{@link https://date-fns.org/docs/Locale}
775
+ * @param {0|1|2|3|4|5|6} [options.weekStartsOn=0] - the index of the first day of the week (0 - Sunday)
776
+ * @returns {Date} the end of a week
777
+ * @throws {TypeError} 1 argument required
778
+ * @throws {RangeError} `options.weekStartsOn` must be between 0 and 6
779
+ *
780
+ * @example
781
+ * // The end of a week for 2 September 2014 11:55:00:
782
+ * const result = endOfWeek(new Date(2014, 8, 2, 11, 55, 0))
783
+ * //=> Sat Sep 06 2014 23:59:59.999
784
+ *
785
+ * @example
786
+ * // If the week starts on Monday, the end of the week for 2 September 2014 11:55:00:
787
+ * const result = endOfWeek(new Date(2014, 8, 2, 11, 55, 0), { weekStartsOn: 1 })
788
+ * //=> Sun Sep 07 2014 23:59:59.999
789
+ */
790
+ function endOfWeek(dirtyDate, options) {
791
+ var _ref, _ref2, _ref3, _options$weekStartsOn, _options$locale, _options$locale$optio, _defaultOptions$local, _defaultOptions$local2;
792
+ index.requiredArgs(1, arguments);
793
+ var defaultOptions = index.getDefaultOptions();
794
+ var weekStartsOn = index.toInteger((_ref = (_ref2 = (_ref3 = (_options$weekStartsOn = options === null || options === void 0 ? void 0 : options.weekStartsOn) !== null && _options$weekStartsOn !== void 0 ? _options$weekStartsOn : options === null || options === void 0 ? void 0 : (_options$locale = options.locale) === null || _options$locale === void 0 ? void 0 : (_options$locale$optio = _options$locale.options) === null || _options$locale$optio === void 0 ? void 0 : _options$locale$optio.weekStartsOn) !== null && _ref3 !== void 0 ? _ref3 : defaultOptions.weekStartsOn) !== null && _ref2 !== void 0 ? _ref2 : (_defaultOptions$local = defaultOptions.locale) === null || _defaultOptions$local === void 0 ? void 0 : (_defaultOptions$local2 = _defaultOptions$local.options) === null || _defaultOptions$local2 === void 0 ? void 0 : _defaultOptions$local2.weekStartsOn) !== null && _ref !== void 0 ? _ref : 0);
795
+
796
+ // Test if weekStartsOn is between 0 and 6 _and_ is not NaN
797
+ if (!(weekStartsOn >= 0 && weekStartsOn <= 6)) {
798
+ throw new RangeError('weekStartsOn must be between 0 and 6 inclusively');
799
+ }
800
+ var date = index.toDate(dirtyDate);
801
+ var day = date.getDay();
802
+ var diff = (day < weekStartsOn ? -7 : 0) + 6 - (day - weekStartsOn);
803
+ date.setDate(date.getDate() + diff);
804
+ date.setHours(23, 59, 59, 999);
805
+ return date;
806
+ }
807
+
808
+ /**
809
+ * @name subWeeks
810
+ * @category Week Helpers
811
+ * @summary Subtract the specified number of weeks from the given date.
812
+ *
813
+ * @description
814
+ * Subtract the specified number of weeks from the given date.
815
+ *
816
+ * @param {Date|Number} date - the date to be changed
817
+ * @param {Number} amount - the amount of weeks to be subtracted. Positive decimals will be rounded using `Math.floor`, decimals less than zero will be rounded using `Math.ceil`.
818
+ * @returns {Date} the new date with the weeks subtracted
819
+ * @throws {TypeError} 2 arguments required
820
+ *
821
+ * @example
822
+ * // Subtract 4 weeks from 1 September 2014:
823
+ * const result = subWeeks(new Date(2014, 8, 1), 4)
824
+ * //=> Mon Aug 04 2014 00:00:00
825
+ */
826
+ function subWeeks(dirtyDate, dirtyAmount) {
827
+ index.requiredArgs(2, arguments);
828
+ var amount = index.toInteger(dirtyAmount);
829
+ return addWeeks(dirtyDate, -amount);
830
+ }
831
+
832
+ /**
833
+ * @name addYears
834
+ * @category Year Helpers
835
+ * @summary Add the specified number of years to the given date.
836
+ *
837
+ * @description
838
+ * Add the specified number of years to the given date.
839
+ *
840
+ * @param {Date|Number} date - the date to be changed
841
+ * @param {Number} amount - the amount of years to be added. Positive decimals will be rounded using `Math.floor`, decimals less than zero will be rounded using `Math.ceil`.
842
+ * @returns {Date} the new date with the years added
843
+ * @throws {TypeError} 2 arguments required
844
+ *
845
+ * @example
846
+ * // Add 5 years to 1 September 2014:
847
+ * const result = addYears(new Date(2014, 8, 1), 5)
848
+ * //=> Sun Sep 01 2019 00:00:00
849
+ */
850
+ function addYears(dirtyDate, dirtyAmount) {
851
+ index.requiredArgs(2, arguments);
852
+ var amount = index.toInteger(dirtyAmount);
853
+ return addMonths(dirtyDate, amount * 12);
854
+ }
855
+
856
+ /**
857
+ * @name subYears
858
+ * @category Year Helpers
859
+ * @summary Subtract the specified number of years from the given date.
860
+ *
861
+ * @description
862
+ * Subtract the specified number of years from the given date.
863
+ *
864
+ * @param {Date|Number} date - the date to be changed
865
+ * @param {Number} amount - the amount of years to be subtracted. Positive decimals will be rounded using `Math.floor`, decimals less than zero will be rounded using `Math.ceil`.
866
+ * @returns {Date} the new date with the years subtracted
867
+ * @throws {TypeError} 2 arguments required
868
+ *
869
+ * @example
870
+ * // Subtract 5 years from 1 September 2014:
871
+ * const result = subYears(new Date(2014, 8, 1), 5)
872
+ * //=> Tue Sep 01 2009 00:00:00
873
+ */
874
+ function subYears(dirtyDate, dirtyAmount) {
875
+ index.requiredArgs(2, arguments);
876
+ var amount = index.toInteger(dirtyAmount);
877
+ return addYears(dirtyDate, -amount);
878
+ }
879
+
880
+ var KeyNames;
881
+ (function (KeyNames) {
882
+ KeyNames["ArrowUp"] = "ArrowUp";
883
+ KeyNames["ArrowDown"] = "ArrowDown";
884
+ KeyNames["ArrowLeft"] = "ArrowLeft";
885
+ KeyNames["ArrowRight"] = "ArrowRight";
886
+ KeyNames["Home"] = "Home";
887
+ KeyNames["End"] = "End";
888
+ KeyNames["PageUp"] = "PageUp";
889
+ KeyNames["PageDown"] = "PageDown";
890
+ KeyNames["Tab"] = "Tab";
891
+ KeyNames["Enter"] = "Enter";
892
+ KeyNames["Space"] = " ";
893
+ })(KeyNames || (KeyNames = {}));
894
+
895
+ var getKeyDownDate = function (_a) {
896
+ var key = _a.key, shiftKey = _a.shiftKey, focusDate = _a.focusDate;
897
+ switch (key) {
898
+ case KeyNames.ArrowDown:
899
+ return addWeeks(focusDate, 1);
900
+ case KeyNames.ArrowLeft:
901
+ return subDays(focusDate, 1);
902
+ case KeyNames.ArrowRight:
903
+ return addDays(focusDate, 1);
904
+ case KeyNames.ArrowUp:
905
+ return subWeeks(focusDate, 1);
906
+ case KeyNames.Home:
907
+ return dateWithoutTime(startOfWeek(focusDate, { weekStartsOn: 1 }));
908
+ case KeyNames.End:
909
+ return dateWithoutTime(endOfWeek(focusDate, { weekStartsOn: 1 }));
910
+ case KeyNames.PageUp:
911
+ return shiftKey ? subYears(focusDate, 1) : subMonths(focusDate, 1);
912
+ case KeyNames.PageDown:
913
+ return shiftKey ? addYears(focusDate, 1) : addMonths(focusDate, 1);
914
+ default:
915
+ return focusDate;
916
+ }
917
+ };
918
+
919
+ /**
920
+ * @name endOfDay
921
+ * @category Day Helpers
922
+ * @summary Return the end of a day for the given date.
923
+ *
924
+ * @description
925
+ * Return the end of a day for the given date.
926
+ * The result will be in the local timezone.
927
+ *
928
+ * @param {Date|Number} date - the original date
929
+ * @returns {Date} the end of a day
930
+ * @throws {TypeError} 1 argument required
931
+ *
932
+ * @example
933
+ * // The end of a day for 2 September 2014 11:55:00:
934
+ * const result = endOfDay(new Date(2014, 8, 2, 11, 55, 0))
935
+ * //=> Tue Sep 02 2014 23:59:59.999
936
+ */
937
+ function endOfDay(dirtyDate) {
938
+ index.requiredArgs(1, arguments);
939
+ var date = index.toDate(dirtyDate);
940
+ date.setHours(23, 59, 59, 999);
941
+ return date;
942
+ }
943
+
944
+ /**
945
+ * @name endOfMonth
946
+ * @category Month Helpers
947
+ * @summary Return the end of a month for the given date.
948
+ *
949
+ * @description
950
+ * Return the end of a month for the given date.
951
+ * The result will be in the local timezone.
952
+ *
953
+ * @param {Date|Number} date - the original date
954
+ * @returns {Date} the end of a month
955
+ * @throws {TypeError} 1 argument required
956
+ *
957
+ * @example
958
+ * // The end of a month for 2 September 2014 11:55:00:
959
+ * const result = endOfMonth(new Date(2014, 8, 2, 11, 55, 0))
960
+ * //=> Tue Sep 30 2014 23:59:59.999
961
+ */
962
+ function endOfMonth(dirtyDate) {
963
+ index.requiredArgs(1, arguments);
964
+ var date = index.toDate(dirtyDate);
965
+ var month = date.getMonth();
966
+ date.setFullYear(date.getFullYear(), month + 1, 0);
967
+ date.setHours(23, 59, 59, 999);
968
+ return date;
969
+ }
970
+
971
+ /**
972
+ * @name isLastDayOfMonth
973
+ * @category Month Helpers
974
+ * @summary Is the given date the last day of a month?
975
+ *
976
+ * @description
977
+ * Is the given date the last day of a month?
978
+ *
979
+ * @param {Date|Number} date - the date to check
980
+ * @returns {Boolean} the date is the last day of a month
981
+ * @throws {TypeError} 1 argument required
982
+ *
983
+ * @example
984
+ * // Is 28 February 2014 the last day of a month?
985
+ * const result = isLastDayOfMonth(new Date(2014, 1, 28))
986
+ * //=> true
987
+ */
988
+ function isLastDayOfMonth(dirtyDate) {
989
+ index.requiredArgs(1, arguments);
990
+ var date = index.toDate(dirtyDate);
991
+ return endOfDay(date).getTime() === endOfMonth(date).getTime();
992
+ }
993
+
994
+ /**
995
+ * @name isFirstDayOfMonth
996
+ * @category Month Helpers
997
+ * @summary Is the given date the first day of a month?
998
+ *
999
+ * @description
1000
+ * Is the given date the first day of a month?
1001
+ *
1002
+ * @param {Date|Number} date - the date to check
1003
+ * @returns {Boolean} the date is the first day of a month
1004
+ * @throws {TypeError} 1 argument required
1005
+ *
1006
+ * @example
1007
+ * // Is 1 September 2014 the first day of a month?
1008
+ * const result = isFirstDayOfMonth(new Date(2014, 8, 1))
1009
+ * //=> true
1010
+ */
1011
+ function isFirstDayOfMonth(dirtyDate) {
1012
+ index.requiredArgs(1, arguments);
1013
+ return index.toDate(dirtyDate).getDate() === 1;
1014
+ }
1015
+
1016
+ /**
1017
+ * @name getDate
1018
+ * @category Day Helpers
1019
+ * @summary Get the day of the month of the given date.
1020
+ *
1021
+ * @description
1022
+ * Get the day of the month of the given date.
1023
+ *
1024
+ * @param {Date|Number} date - the given date
1025
+ * @returns {Number} the day of month
1026
+ * @throws {TypeError} 1 argument required
1027
+ *
1028
+ * @example
1029
+ * // Which day of the month is 29 February 2012?
1030
+ * const result = getDate(new Date(2012, 1, 29))
1031
+ * //=> 29
1032
+ */
1033
+ function getDate(dirtyDate) {
1034
+ index.requiredArgs(1, arguments);
1035
+ var date = index.toDate(dirtyDate);
1036
+ var dayOfMonth = date.getDate();
1037
+ return dayOfMonth;
1038
+ }
1039
+
1040
+ /**
1041
+ * @name isEqual
1042
+ * @category Common Helpers
1043
+ * @summary Are the given dates equal?
1044
+ *
1045
+ * @description
1046
+ * Are the given dates equal?
1047
+ *
1048
+ * @param {Date|Number} dateLeft - the first date to compare
1049
+ * @param {Date|Number} dateRight - the second date to compare
1050
+ * @returns {Boolean} the dates are equal
1051
+ * @throws {TypeError} 2 arguments required
1052
+ *
1053
+ * @example
1054
+ * // Are 2 July 2014 06:30:45.000 and 2 July 2014 06:30:45.500 equal?
1055
+ * const result = isEqual(
1056
+ * new Date(2014, 6, 2, 6, 30, 45, 0),
1057
+ * new Date(2014, 6, 2, 6, 30, 45, 500)
1058
+ * )
1059
+ * //=> false
1060
+ */
1061
+ function isEqual(dirtyLeftDate, dirtyRightDate) {
1062
+ index.requiredArgs(2, arguments);
1063
+ var dateLeft = index.toDate(dirtyLeftDate);
1064
+ var dateRight = index.toDate(dirtyRightDate);
1065
+ return dateLeft.getTime() === dateRight.getTime();
1066
+ }
1067
+
1068
+ var ArcCalendarContext = React.createContext(null);
1069
+
1070
+ var CalendarDayNumber = React.forwardRef(function (_a, autoFocusRef) {
1071
+ var date = _a.date, shouldRender = _a.shouldRender, isFocusWithinDayGrid = _a.isFocusWithinDayGrid;
1072
+ var context = React.useContext(ArcCalendarContext);
1073
+ var isFocusDate = context && isEqual(date, context.focusDate);
1074
+ var tableCellRef = React.useCallback(function (el) {
1075
+ if (el && isFocusDate && isFocusWithinDayGrid) {
1076
+ el.focus();
1077
+ }
1078
+ }, [isFocusDate, isFocusWithinDayGrid]);
1079
+ if (!context) {
1080
+ return null;
1081
+ }
1082
+ var handleRefs = function (el) {
1083
+ tableCellRef(el);
1084
+ if (autoFocusRef && typeof autoFocusRef === "function") {
1085
+ autoFocusRef(el);
1086
+ }
1087
+ };
1088
+ var disabledDates = context.disabledDates, selectedDate = context.selectedDate, selectionType = context.selectionType, selectedRange = context.selectedRange, highlightedRange = context.highlightedRange, todayDate = context.todayDate, onDayNumberClick = context.onDayNumberClick, onDayNumberHover = context.onDayNumberHover, minDate = context.minDate, maxDate = context.maxDate;
1089
+ var highlightedRangeStart = highlightedRange[0];
1090
+ var highlightedRangeEnd = highlightedRange[1];
1091
+ var isSelectedDate = selectionType === "single"
1092
+ ? isEqual(date, selectedDate)
1093
+ : selectedRange.length &&
1094
+ containsDate(selectedRange.filter(function (date) { return Boolean(date); }), date);
1095
+ var isTodayDate = isEqual(date, todayDate);
1096
+ var dateIsWithinHighlightedRange = selectionType === "range" &&
1097
+ highlightedRange.length === 2 &&
1098
+ !isAfter(date, highlightedRangeEnd) &&
1099
+ !isBefore(date, highlightedRangeStart);
1100
+ var isRoundedLeft = selectionType === "range" &&
1101
+ (isDay(date, WeekDays.MONDAY) ||
1102
+ isFirstDayOfMonth(date) ||
1103
+ isEqual(date, highlightedRangeStart));
1104
+ var isRoundedRight = selectionType === "range" &&
1105
+ (isDay(date, WeekDays.SUNDAY) ||
1106
+ isLastDayOfMonth(date) ||
1107
+ isEqual(date, highlightedRangeEnd));
1108
+ var conditionalClasses = {
1109
+ "arc-CalendarDayNumber--selected": isSelectedDate,
1110
+ "arc-CalendarDayNumber--todayDate": isTodayDate,
1111
+ "arc-CalendarDayNumber--hightlightedRange": dateIsWithinHighlightedRange,
1112
+ "arc-CalendarDayNumber--hightlightedRangeRoundedLeft": isRoundedLeft,
1113
+ "arc-CalendarDayNumber--hightlightedRangeRoundedRight": isRoundedRight
1114
+ };
1115
+ var isAriaSelected = isSelectedDate ||
1116
+ (dateIsWithinHighlightedRange && selectedRange.length === 2);
1117
+ var tableCellProps = {
1118
+ className: index$1.classNames("arc-CalendarDayNumber", conditionalClasses),
1119
+ tabIndex: isFocusDate && shouldRender ? 0 : -1,
1120
+ "aria-current": isTodayDate ? "date" : undefined,
1121
+ "aria-selected": isAriaSelected,
1122
+ "aria-disabled": isDisabledDate(date, disabledDates, minDate, maxDate),
1123
+ onClick: onDayNumberClick(date),
1124
+ onMouseEnter: onDayNumberHover(date)
1125
+ };
1126
+ return (React__default["default"].createElement("td", index_es.__assign({ ref: handleRefs, "data-date": date.getTime() }, (shouldRender ? tableCellProps : {}), { role: "gridcell" }), shouldRender && (React__default["default"].createElement(React__default["default"].Fragment, null,
1127
+ React__default["default"].createElement(VisuallyHidden.VisuallyHidden, null, index.format(date, "MMMM do, yyyy")),
1128
+ React__default["default"].createElement("div", { className: "arc-CalendarDayNumber-buttonOuter" },
1129
+ React__default["default"].createElement("div", { className: "arc-CalendarDayNumber-buttonInner" },
1130
+ React__default["default"].createElement(Text.Text, { size: "s" },
1131
+ React__default["default"].createElement("span", { "aria-hidden": true }, getDate(date)))))))));
1132
+ });
1133
+
1134
+ const BtIconChevronDownMid = (props) =>
1135
+ /*#__PURE__*/ React__default["default"].createElement(
1136
+ "svg",
1137
+ Object.assign(
1138
+ {
1139
+ viewBox: "0 0 32 32",
1140
+ fill: "none",
1141
+ xmlns: "http://www.w3.org/2000/svg",
1142
+ },
1143
+ props,
1144
+ ),
1145
+ /*#__PURE__*/ React__default["default"].createElement("path", {
1146
+ fillRule: "evenodd",
1147
+ clipRule: "evenodd",
1148
+ d: "M16.0001 18.0909L21.7041 12.3935C21.9566 12.1415 22.2987 12 22.6554 12C23.0121 12 23.3543 12.1415 23.6068 12.3935C23.7316 12.5181 23.8306 12.6661 23.8982 12.829C23.9657 12.9919 24.0005 13.1665 24.0005 13.3429C24.0005 13.5192 23.9657 13.6938 23.8982 13.8567C23.8306 14.0196 23.7316 14.1676 23.6068 14.2922L16.9508 20.9402C16.6983 21.1918 16.3565 21.3331 16.0001 21.3331C15.6437 21.3331 15.3018 21.1918 15.0494 20.9402L8.39342 14.2922C8.26861 14.1676 8.16959 14.0196 8.10202 13.8567C8.03446 13.6938 7.99969 13.5192 7.99969 13.3429C7.99969 13.1665 8.03446 12.9919 8.10202 12.829C8.16959 12.6661 8.26861 12.5181 8.39342 12.3935C8.6459 12.1415 8.98804 12 9.34475 12C9.70147 12 10.0436 12.1415 10.2961 12.3935L16.0001 18.0909Z",
1149
+ fill: "currentColor",
1150
+ }),
1151
+ );
1152
+
1153
+ var CalendarDateSelect = function (_a) {
1154
+ var ariaLabel = _a.ariaLabel, onChange = _a.onChange, name = _a.name, value = _a.value, displayValue = _a.displayValue, options = _a.options;
1155
+ return (React__default["default"].createElement("div", { className: "arc-CalendarDateSelect-wrapper" },
1156
+ React__default["default"].createElement("select", { "aria-label": ariaLabel, onChange: onChange, className: "arc-CalendarDateSelect", value: value, name: name }, options.map(function (_a) {
1157
+ var text = _a.text, value = _a.value;
1158
+ return (React__default["default"].createElement("option", { className: "arc-CalendarDateSelect-option", key: "arc-calendar-year-select-".concat(value), value: value }, text));
1159
+ })),
1160
+ React__default["default"].createElement("div", { "aria-hidden": true, className: "arc-CalendarDateSelect-label" },
1161
+ React__default["default"].createElement(Heading.Heading, { size: "s" }, displayValue || value),
1162
+ React__default["default"].createElement("div", { className: "arc-CalendarDateSelect-icon" },
1163
+ React__default["default"].createElement(Icon.Icon, { size: 24, icon: BtIconChevronDownMid })))));
1164
+ };
1165
+
1166
+ /**
1167
+ * @name isSameMonth
1168
+ * @category Month Helpers
1169
+ * @summary Are the given dates in the same month (and year)?
1170
+ *
1171
+ * @description
1172
+ * Are the given dates in the same month (and year)?
1173
+ *
1174
+ * @param {Date|Number} dateLeft - the first date to check
1175
+ * @param {Date|Number} dateRight - the second date to check
1176
+ * @returns {Boolean} the dates are in the same month (and year)
1177
+ * @throws {TypeError} 2 arguments required
1178
+ *
1179
+ * @example
1180
+ * // Are 2 September 2014 and 25 September 2014 in the same month?
1181
+ * const result = isSameMonth(new Date(2014, 8, 2), new Date(2014, 8, 25))
1182
+ * //=> true
1183
+ *
1184
+ * @example
1185
+ * // Are 2 September 2014 and 25 September 2015 in the same month?
1186
+ * const result = isSameMonth(new Date(2014, 8, 2), new Date(2015, 8, 25))
1187
+ * //=> false
1188
+ */
1189
+ function isSameMonth(dirtyDateLeft, dirtyDateRight) {
1190
+ index.requiredArgs(2, arguments);
1191
+ var dateLeft = index.toDate(dirtyDateLeft);
1192
+ var dateRight = index.toDate(dirtyDateRight);
1193
+ return dateLeft.getFullYear() === dateRight.getFullYear() && dateLeft.getMonth() === dateRight.getMonth();
1194
+ }
1195
+
1196
+ /**
1197
+ * @name eachWeekOfInterval
1198
+ * @category Interval Helpers
1199
+ * @summary Return the array of weeks within the specified time interval.
1200
+ *
1201
+ * @description
1202
+ * Return the array of weeks within the specified time interval.
1203
+ *
1204
+ * @param {Interval} interval - the interval. See [Interval]{@link https://date-fns.org/docs/Interval}
1205
+ * @param {Object} [options] - an object with options.
1206
+ * @param {Locale} [options.locale=defaultLocale] - the locale object. See [Locale]{@link https://date-fns.org/docs/Locale}
1207
+ * @param {0|1|2|3|4|5|6} [options.weekStartsOn=0] - the index of the first day of the week (0 - Sunday)
1208
+ * @returns {Date[]} the array with starts of weeks from the week of the interval start to the week of the interval end
1209
+ * @throws {TypeError} 1 argument required
1210
+ * @throws {RangeError} `options.weekStartsOn` must be 0, 1, ..., 6
1211
+ * @throws {RangeError} The start of an interval cannot be after its end
1212
+ * @throws {RangeError} Date in interval cannot be `Invalid Date`
1213
+ *
1214
+ * @example
1215
+ * // Each week within interval 6 October 2014 - 23 November 2014:
1216
+ * const result = eachWeekOfInterval({
1217
+ * start: new Date(2014, 9, 6),
1218
+ * end: new Date(2014, 10, 23)
1219
+ * })
1220
+ * //=> [
1221
+ * // Sun Oct 05 2014 00:00:00,
1222
+ * // Sun Oct 12 2014 00:00:00,
1223
+ * // Sun Oct 19 2014 00:00:00,
1224
+ * // Sun Oct 26 2014 00:00:00,
1225
+ * // Sun Nov 02 2014 00:00:00,
1226
+ * // Sun Nov 09 2014 00:00:00,
1227
+ * // Sun Nov 16 2014 00:00:00,
1228
+ * // Sun Nov 23 2014 00:00:00
1229
+ * // ]
1230
+ */
1231
+ function eachWeekOfInterval(dirtyInterval, options) {
1232
+ index.requiredArgs(1, arguments);
1233
+ var interval = dirtyInterval || {};
1234
+ var startDate = index.toDate(interval.start);
1235
+ var endDate = index.toDate(interval.end);
1236
+ var endTime = endDate.getTime();
1237
+
1238
+ // Throw an exception if start date is after end date or if any date is `Invalid Date`
1239
+ if (!(startDate.getTime() <= endTime)) {
1240
+ throw new RangeError('Invalid interval');
1241
+ }
1242
+ var startDateWeek = startOfWeek(startDate, options);
1243
+ var endDateWeek = startOfWeek(endDate, options);
1244
+
1245
+ // Some timezones switch DST at midnight, making start of day unreliable in these timezones, 3pm is a safe bet
1246
+ startDateWeek.setHours(15);
1247
+ endDateWeek.setHours(15);
1248
+ endTime = endDateWeek.getTime();
1249
+ var weeks = [];
1250
+ var currentWeek = startDateWeek;
1251
+ while (currentWeek.getTime() <= endTime) {
1252
+ currentWeek.setHours(0);
1253
+ weeks.push(index.toDate(currentWeek));
1254
+ currentWeek = addWeeks(currentWeek, 1);
1255
+ currentWeek.setHours(15);
1256
+ }
1257
+ return weeks;
1258
+ }
1259
+
1260
+ var DAY_NAMES = [
1261
+ {
1262
+ value: WeekDays.MONDAY,
1263
+ displayValue: WeekDaysAbbr.MON
1264
+ },
1265
+ {
1266
+ value: WeekDays.TUESDAY,
1267
+ displayValue: WeekDaysAbbr.TUE
1268
+ },
1269
+ {
1270
+ value: WeekDays.WEDNESDAY,
1271
+ displayValue: WeekDaysAbbr.WED
1272
+ },
1273
+ {
1274
+ value: WeekDays.THURSDAY,
1275
+ displayValue: WeekDaysAbbr.THUR
1276
+ },
1277
+ {
1278
+ value: WeekDays.FRIDAY,
1279
+ displayValue: WeekDaysAbbr.FRI
1280
+ },
1281
+ {
1282
+ value: WeekDays.SATURDAY,
1283
+ displayValue: WeekDaysAbbr.SAT
1284
+ },
1285
+ {
1286
+ value: WeekDays.SUNDAY,
1287
+ displayValue: WeekDaysAbbr.SUN
1288
+ },
1289
+ ];
1290
+
1291
+ var CalendarDayGrid = function (_a) {
1292
+ var displayRange = _a.displayRange;
1293
+ var hasAutoFocused = React.useRef(false);
1294
+ var dayNumberGridRef = React.useRef(null);
1295
+ var context = React.useContext(ArcCalendarContext);
1296
+ var autoFocusRef = React.useCallback(function (el) {
1297
+ if (el &&
1298
+ el.tabIndex === 0 &&
1299
+ (context === null || context === void 0 ? void 0 : context.autoFocusOnMount) &&
1300
+ !hasAutoFocused.current) {
1301
+ el.focus();
1302
+ }
1303
+ if (document.activeElement === el) {
1304
+ hasAutoFocused.current = true;
1305
+ }
1306
+ }, [context === null || context === void 0 ? void 0 : context.autoFocusOnMount]);
1307
+ if (!context) {
1308
+ return null;
1309
+ }
1310
+ var onKeyboardNavigate = context.onKeyboardNavigate, onDayNumberClick = context.onDayNumberClick, onDayGridLeave = context.onDayGridLeave;
1311
+ var isFocusWithinDayGrid = Boolean(dayNumberGridRef &&
1312
+ dayNumberGridRef.current &&
1313
+ dayNumberGridRef.current.contains(document.activeElement));
1314
+ var handleKeyDown = function (e) {
1315
+ var key = e.key;
1316
+ var newDate = e.target.getAttribute("data-date");
1317
+ if (key === KeyNames.Tab) {
1318
+ return;
1319
+ }
1320
+ if (Object.values(KeyNames).includes(key)) {
1321
+ e.preventDefault();
1322
+ }
1323
+ if ([KeyNames.Space, KeyNames.Enter].includes(key) && newDate) {
1324
+ onDayNumberClick(dateWithoutTime(new Date(parseInt(newDate))))();
1325
+ }
1326
+ else {
1327
+ onKeyboardNavigate(e.key, e.shiftKey);
1328
+ }
1329
+ };
1330
+ var getWeeksInMonth = function (month) {
1331
+ return eachWeekOfInterval({ start: startOfMonth(month), end: endOfMonth(month) }, { weekStartsOn: 1 }).map(function (week) { return eachDayOfInterval({ start: week, end: addDays(week, 6) }); });
1332
+ };
1333
+ return (React__default["default"].createElement("div", { ref: dayNumberGridRef, onMouseLeave: onDayGridLeave, className: index$1.classNames("arc-CalendarDayGrid", {
1334
+ "arc-CalendarDayGrid--dual": displayRange.length > 1
1335
+ }) }, displayRange.map(function (month) { return (React__default["default"].createElement("div", { key: month.getTime(), className: "arc-CalendarDayGrid-month" },
1336
+ React__default["default"].createElement("table", { className: "arc-CalendarDayGrid-table" },
1337
+ React__default["default"].createElement("thead", null,
1338
+ React__default["default"].createElement("tr", null, DAY_NAMES.map(function (dayName) { return (React__default["default"].createElement("th", { key: "".concat(month.getTime(), "-").concat(dayName.displayValue) },
1339
+ React__default["default"].createElement(Text.Text, { key: dayName.displayValue, size: "s" },
1340
+ React__default["default"].createElement("b", { "aria-hidden": true }, dayName.displayValue)),
1341
+ React__default["default"].createElement(VisuallyHidden.VisuallyHidden, null, dayName.value))); }))),
1342
+ React__default["default"].createElement("tbody", { onKeyDown: handleKeyDown }, getWeeksInMonth(month).map(function (week, i) { return (React__default["default"].createElement("tr", { key: "".concat(month.getTime(), "-week-").concat(i) }, week.map(function (day) { return (React__default["default"].createElement(CalendarDayNumber, { ref: autoFocusRef, shouldRender: isSameMonth(month, day), key: day.getTime(), date: day, isFocusWithinDayGrid: isFocusWithinDayGrid })); }))); }))))); })));
1343
+ };
1344
+
1345
+ const BtIconChevronLeftMid = (props) =>
1346
+ /*#__PURE__*/ React__default["default"].createElement(
1347
+ "svg",
1348
+ Object.assign(
1349
+ {
1350
+ viewBox: "0 0 16 16",
1351
+ fill: "none",
1352
+ xmlns: "http://www.w3.org/2000/svg",
1353
+ },
1354
+ props,
1355
+ ),
1356
+ /*#__PURE__*/ React__default["default"].createElement("path", {
1357
+ fillRule: "evenodd",
1358
+ clipRule: "evenodd",
1359
+ d: "M7.62107 8.00023L10.4697 10.8522C10.5957 10.9785 10.6665 11.1495 10.6665 11.3279C10.6665 11.5063 10.5957 11.6773 10.4697 11.8036C10.4074 11.866 10.3335 11.9155 10.252 11.9493C10.1706 11.983 10.0833 12.0004 9.99507 12.0004C9.9069 12.0004 9.81959 11.983 9.73814 11.9493C9.65669 11.9155 9.5827 11.866 9.52041 11.8036L6.19641 8.47556C6.07061 8.34935 5.99998 8.17842 5.99998 8.00023C5.99998 7.82203 6.07061 7.6511 6.19641 7.52489L9.52041 4.19689C9.5827 4.13449 9.65669 4.08498 9.73814 4.0512C9.81959 4.01741 9.9069 4.00003 9.99507 4.00003C10.0832 4.00003 10.1706 4.01741 10.252 4.0512C10.3335 4.08498 10.4074 4.13449 10.4697 4.19689C10.5957 4.32313 10.6665 4.4942 10.6665 4.67256C10.6665 4.85092 10.5957 5.02199 10.4697 5.14823L7.62107 8.00023Z",
1360
+ fill: "currentColor",
1361
+ }),
1362
+ );
1363
+
1364
+ var CalendarNavButton = function (_a) {
1365
+ var isDisabled = _a.isDisabled, onClick = _a.onClick, direction = _a.direction, ariaLabel = _a.ariaLabel;
1366
+ var icons = {
1367
+ previous: BtIconChevronLeftMid,
1368
+ next: BtIconChevronRightMid_esm.BtIconChevronRightMid
1369
+ };
1370
+ return (React__default["default"].createElement("button", { "aria-label": ariaLabel, disabled: isDisabled, onClick: onClick, type: "button", className: index$1.classNames("arc-CalendarNavButton", {
1371
+ "arc-CalendarNavButton--previous": direction === "previous",
1372
+ "arc-CalendarNavButton--next": direction === "next"
1373
+ }) },
1374
+ React__default["default"].createElement(Icon.Icon, { size: 32, icon: icons[direction] })));
1375
+ };
1376
+
1377
+ var CalendarDoubleMonthView = function (_a) {
1378
+ var isPreviousMonthDisabled = _a.isPreviousMonthDisabled, isNextMonthDisabled = _a.isNextMonthDisabled, onNextMonthClick = _a.onNextMonthClick, onPreviousMonthClick = _a.onPreviousMonthClick;
1379
+ var context = React.useContext(ArcCalendarContext);
1380
+ if (!context) {
1381
+ return null;
1382
+ }
1383
+ var displayDate = context.displayDate;
1384
+ var displayRange = getDoubleMonthDisplayRange(displayDate);
1385
+ var getAriaLabel = function (date) {
1386
+ var months = getDoubleMonthDisplayRange(date);
1387
+ return "show ".concat(index.format(months[0], "MMMM yyyy"), " to ").concat(index.format(months[1], "MMMM yyyy"));
1388
+ };
1389
+ return (React__default["default"].createElement(React__default["default"].Fragment, null,
1390
+ React__default["default"].createElement(VisuallyHidden.VisuallyHidden, null,
1391
+ React__default["default"].createElement(Heading.Heading, { level: "2" },
1392
+ React__default["default"].createElement("span", { "aria-live": "polite" },
1393
+ "showing ",
1394
+ index.format(displayRange[0], "MMMM yyyy"),
1395
+ " to",
1396
+ " ",
1397
+ index.format(displayRange[1], "MMMM yyyy")))),
1398
+ React__default["default"].createElement("div", { className: "arc-CalendarDoubleMonthView-header" },
1399
+ React__default["default"].createElement("div", { className: "arc-CalendarDoubleMonthView-headerMonth" },
1400
+ React__default["default"].createElement("div", { className: "arc-CalendarDoubleMonthView-headerMonthItem" },
1401
+ React__default["default"].createElement(CalendarNavButton, { ariaLabel: getAriaLabel(subMonths(displayDate, 2)), direction: "previous", isDisabled: isPreviousMonthDisabled, onClick: onPreviousMonthClick })),
1402
+ React__default["default"].createElement("div", { "aria-hidden": true, className: "arc-CalendarDoubleMonthView-headerMonthItem" },
1403
+ React__default["default"].createElement(Heading.Heading, { level: "2", size: "s" }, index.format(displayRange[0], "MMM yyyy")))),
1404
+ React__default["default"].createElement("div", { className: "arc-CalendarDoubleMonthView-headerMonth" },
1405
+ React__default["default"].createElement("div", { "aria-hidden": true, className: "arc-CalendarDoubleMonthView-headerMonthItem" },
1406
+ React__default["default"].createElement(Heading.Heading, { level: "2", size: "s" }, index.format(displayRange[1], "MMM yyyy"))),
1407
+ React__default["default"].createElement("div", { className: "arc-CalendarDoubleMonthView-headerMonthItem" },
1408
+ React__default["default"].createElement(CalendarNavButton, { ariaLabel: getAriaLabel(addMonths(displayDate, 2)), direction: "next", isDisabled: isNextMonthDisabled, onClick: onNextMonthClick })))),
1409
+ React__default["default"].createElement(CalendarDayGrid, { displayRange: displayRange })));
1410
+ };
1411
+
1412
+ var CalendarMonthView = function (_a) {
1413
+ var isPreviousMonthDisabled = _a.isPreviousMonthDisabled, isNextMonthDisabled = _a.isNextMonthDisabled, onNextMonthClick = _a.onNextMonthClick, onPreviousMonthClick = _a.onPreviousMonthClick;
1414
+ var context = React.useContext(ArcCalendarContext);
1415
+ if (!context) {
1416
+ return null;
1417
+ }
1418
+ var displayDate = context.displayDate;
1419
+ return (React__default["default"].createElement(React__default["default"].Fragment, null,
1420
+ React__default["default"].createElement("div", { className: "arc-CalendarMonthView-header" },
1421
+ React__default["default"].createElement(CalendarNavButton, { ariaLabel: "Show ".concat(index.format(subMonths(displayDate, 1), "MMMM yyyy")), direction: "previous", isDisabled: isPreviousMonthDisabled, onClick: onPreviousMonthClick }),
1422
+ React__default["default"].createElement("div", { className: "arc-CalendarMonthView-headingContainer" },
1423
+ React__default["default"].createElement(VisuallyHidden.VisuallyHidden, null,
1424
+ React__default["default"].createElement(Heading.Heading, { level: "2" },
1425
+ React__default["default"].createElement("span", { "aria-live": "polite" },
1426
+ "showing ",
1427
+ index.format(displayDate, "MMMM yyyy")))),
1428
+ React__default["default"].createElement("div", { "aria-hidden": true },
1429
+ React__default["default"].createElement(Heading.Heading, { size: "s", level: "2" }, index.format(displayDate, "MMM yyyy")))),
1430
+ React__default["default"].createElement(CalendarNavButton, { direction: "next", ariaLabel: "Show ".concat(index.format(addMonths(displayDate, 1), "MMMM yyyy")), isDisabled: isNextMonthDisabled, onClick: onNextMonthClick })),
1431
+ React__default["default"].createElement(CalendarDayGrid, { displayRange: [displayDate] })));
1432
+ };
1433
+
1434
+ var CalendarMonthYearView = function (_a) {
1435
+ var isPreviousMonthDisabled = _a.isPreviousMonthDisabled, isNextMonthDisabled = _a.isNextMonthDisabled, onMonthChange = _a.onMonthChange, onYearChange = _a.onYearChange, onNextMonthClick = _a.onNextMonthClick, onPreviousMonthClick = _a.onPreviousMonthClick;
1436
+ var context = React.useContext(ArcCalendarContext);
1437
+ if (!context) {
1438
+ return null;
1439
+ }
1440
+ var displayDate = context.displayDate, minDate = context.minDate, maxDate = context.maxDate;
1441
+ var monthOptions = Array.from({ length: 12 })
1442
+ .map(function (_, i) { return ({
1443
+ value: i,
1444
+ text: index.format(new Date(2023, i, 1), "MMMM")
1445
+ }); })
1446
+ .filter(function (_a) {
1447
+ var value = _a.value;
1448
+ var currentDateYear = getYear(displayDate);
1449
+ var date = dateWithoutTime(new Date(currentDateYear, value, 1));
1450
+ return ((!minDate || !isMonthBeforeMinDate(date, minDate)) &&
1451
+ (!maxDate || !isMonthAfterMaxDate(date, maxDate)));
1452
+ });
1453
+ var yearOptions = Array.from({ length: 21 }, function (_, i) {
1454
+ var value = getYear(displayDate) - 10 + i;
1455
+ return {
1456
+ value: value,
1457
+ text: value
1458
+ };
1459
+ }).filter(function (_a) {
1460
+ var value = _a.value;
1461
+ return ((minDate ? value >= getYear(minDate) : true) &&
1462
+ (maxDate ? value <= getYear(maxDate) : true));
1463
+ });
1464
+ return (React__default["default"].createElement(React__default["default"].Fragment, null,
1465
+ React__default["default"].createElement("div", { className: "arc-CalendarMonthYearView-header" },
1466
+ React__default["default"].createElement(VisuallyHidden.VisuallyHidden, null,
1467
+ React__default["default"].createElement(Heading.Heading, { level: "2" },
1468
+ React__default["default"].createElement("span", { "aria-live": "polite" },
1469
+ "showing ",
1470
+ index.format(displayDate, "MMMM yyyy")))),
1471
+ React__default["default"].createElement("div", { className: "arc-CalendarMonthYearView-selectWrapper" },
1472
+ React__default["default"].createElement("div", null,
1473
+ React__default["default"].createElement(CalendarDateSelect, { options: monthOptions, ariaLabel: "month", onChange: function (e) { return onMonthChange(parseInt(e.target.value)); }, name: "arc-CalendarMonthYearView-monthSelect", displayValue: index.format(displayDate, "MMM"), value: "".concat(getMonth(displayDate)) })),
1474
+ React__default["default"].createElement("div", { className: "arc-CalendarMonthYearView-yearSelectContainer" },
1475
+ React__default["default"].createElement(CalendarDateSelect, { options: yearOptions, ariaLabel: "year", onChange: function (e) { return onYearChange(parseInt(e.target.value)); }, name: "arc-CalendarMonthYearView-yearSelect", value: getYear(displayDate) }))),
1476
+ React__default["default"].createElement("div", { className: "arc-CalendarMonthYearView-navButtonContainer" },
1477
+ React__default["default"].createElement(CalendarNavButton, { direction: "previous", ariaLabel: "Show ".concat(index.format(subMonths(displayDate, 1), "MMMM yyyy")), isDisabled: isPreviousMonthDisabled, onClick: onPreviousMonthClick }),
1478
+ React__default["default"].createElement(CalendarNavButton, { direction: "next", ariaLabel: "Show ".concat(index.format(addMonths(displayDate, 1), "MMMM yyyy")), isDisabled: isNextMonthDisabled, onClick: onNextMonthClick }))),
1479
+ React__default["default"].createElement(CalendarDayGrid, { displayRange: [displayDate] })));
1480
+ };
1481
+
1482
+ var showPreviousMonthHandler = function (payload, state) {
1483
+ return index_es.__assign(index_es.__assign({}, state), { focusDate: getFocusDate({
1484
+ date: subMonths(state.focusDate, 1),
1485
+ minDate: payload.minDate
1486
+ }), displayDate: subMonths(state.displayDate, 1) });
1487
+ };
1488
+
1489
+ var showNextMonthHandler = function (payload, state) {
1490
+ return index_es.__assign(index_es.__assign({}, state), { focusDate: getFocusDate({
1491
+ date: addMonths(state.focusDate, 1),
1492
+ maxDate: payload.maxDate
1493
+ }), displayDate: addMonths(state.displayDate, 1) });
1494
+ };
1495
+
1496
+ var showPreviousDoubleMonthHandler = function (payload, state) {
1497
+ return index_es.__assign(index_es.__assign({}, state), { focusDate: getFocusDate({
1498
+ date: subMonths(state.focusDate, 2),
1499
+ minDate: payload.minDate
1500
+ }), displayDate: subMonths(state.displayDate, 2) });
1501
+ };
1502
+
1503
+ var showNextDoubleMonthHandler = function (payload, state) {
1504
+ return index_es.__assign(index_es.__assign({}, state), { focusDate: getFocusDate({
1505
+ date: addMonths(state.focusDate, 2),
1506
+ maxDate: payload.maxDate
1507
+ }), displayDate: addMonths(state.displayDate, 2) });
1508
+ };
1509
+
1510
+ var rangeSelectHandler = function (payload, state) {
1511
+ return index_es.__assign(index_es.__assign({}, state), { focusDate: payload.date, highlightedRange: payload.range });
1512
+ };
1513
+
1514
+ var highlightRangeHandler = function (payload, state) {
1515
+ return index_es.__assign(index_es.__assign({}, state), { highlightedRange: getHighlightRange({
1516
+ date: payload.date,
1517
+ range: payload.range,
1518
+ minDate: payload.minDate,
1519
+ maxDate: payload.maxDate
1520
+ }) });
1521
+ };
1522
+
1523
+ var dayNumberSelectHandler = function (payload, state) {
1524
+ return index_es.__assign(index_es.__assign({}, state), { focusDate: payload });
1525
+ };
1526
+
1527
+ var dayGridLeaveHandler = function (payload, state) {
1528
+ if (payload.selectionType === "range" &&
1529
+ payload.range.filter(function (date) { return Boolean(date); }).length === 1) {
1530
+ return index_es.__assign(index_es.__assign({}, state), { highlightedRange: [] });
1531
+ }
1532
+ return index_es.__assign({}, state);
1533
+ };
1534
+
1535
+ var dropDownChangeYearHandler = function (payload, state) {
1536
+ var year = payload.year, minDate = payload.minDate, maxDate = payload.maxDate;
1537
+ var yearsToAdd = year - getYear(state.displayDate);
1538
+ var newDisplayDate = addYears(state.displayDate, yearsToAdd);
1539
+ var focusDate = getFocusDate({
1540
+ date: addYears(state.focusDate, yearsToAdd),
1541
+ minDate: payload.minDate,
1542
+ maxDate: payload.maxDate
1543
+ });
1544
+ if (minDate && isBefore(newDisplayDate, minDate)) {
1545
+ return index_es.__assign(index_es.__assign({}, state), { focusDate: focusDate, displayDate: minDate });
1546
+ }
1547
+ if (maxDate && isAfter(newDisplayDate, maxDate)) {
1548
+ return index_es.__assign(index_es.__assign({}, state), { focusDate: focusDate, displayDate: maxDate });
1549
+ }
1550
+ return index_es.__assign(index_es.__assign({}, state), { focusDate: focusDate, displayDate: newDisplayDate });
1551
+ };
1552
+
1553
+ var dropDownChangeMonthHandler = function (payload, state) {
1554
+ return index_es.__assign(index_es.__assign({}, state), { focusDate: getFocusDate({
1555
+ date: setMonth(state.focusDate, payload.month),
1556
+ minDate: payload.minDate,
1557
+ maxDate: payload.maxDate
1558
+ }), displayDate: setMonth(state.displayDate, payload.month) });
1559
+ };
1560
+
1561
+ /**
1562
+ * @name isWithinInterval
1563
+ * @category Interval Helpers
1564
+ * @summary Is the given date within the interval?
1565
+ *
1566
+ * @description
1567
+ * Is the given date within the interval? (Including start and end.)
1568
+ *
1569
+ * @param {Date|Number} date - the date to check
1570
+ * @param {Interval} interval - the interval to check
1571
+ * @returns {Boolean} the date is within the interval
1572
+ * @throws {TypeError} 2 arguments required
1573
+ * @throws {RangeError} The start of an interval cannot be after its end
1574
+ * @throws {RangeError} Date in interval cannot be `Invalid Date`
1575
+ *
1576
+ * @example
1577
+ * // For the date within the interval:
1578
+ * isWithinInterval(new Date(2014, 0, 3), {
1579
+ * start: new Date(2014, 0, 1),
1580
+ * end: new Date(2014, 0, 7)
1581
+ * })
1582
+ * //=> true
1583
+ *
1584
+ * @example
1585
+ * // For the date outside of the interval:
1586
+ * isWithinInterval(new Date(2014, 0, 10), {
1587
+ * start: new Date(2014, 0, 1),
1588
+ * end: new Date(2014, 0, 7)
1589
+ * })
1590
+ * //=> false
1591
+ *
1592
+ * @example
1593
+ * // For date equal to interval start:
1594
+ * isWithinInterval(date, { start, end: date }) // => true
1595
+ *
1596
+ * @example
1597
+ * // For date equal to interval end:
1598
+ * isWithinInterval(date, { start: date, end }) // => true
1599
+ */
1600
+ function isWithinInterval(dirtyDate, interval) {
1601
+ index.requiredArgs(2, arguments);
1602
+ var time = index.toDate(dirtyDate).getTime();
1603
+ var startTime = index.toDate(interval.start).getTime();
1604
+ var endTime = index.toDate(interval.end).getTime();
1605
+
1606
+ // Throw an exception if start date is after end date or if any date is `Invalid Date`
1607
+ if (!(startTime <= endTime)) {
1608
+ throw new RangeError('Invalid interval');
1609
+ }
1610
+ return time >= startTime && time <= endTime;
1611
+ }
1612
+
1613
+ /**
1614
+ * @name setYear
1615
+ * @category Year Helpers
1616
+ * @summary Set the year to the given date.
1617
+ *
1618
+ * @description
1619
+ * Set the year to the given date.
1620
+ *
1621
+ * @param {Date|Number} date - the date to be changed
1622
+ * @param {Number} year - the year of the new date
1623
+ * @returns {Date} the new date with the year set
1624
+ * @throws {TypeError} 2 arguments required
1625
+ *
1626
+ * @example
1627
+ * // Set year 2013 to 1 September 2014:
1628
+ * const result = setYear(new Date(2014, 8, 1), 2013)
1629
+ * //=> Sun Sep 01 2013 00:00:00
1630
+ */
1631
+ function setYear(dirtyDate, dirtyYear) {
1632
+ index.requiredArgs(2, arguments);
1633
+ var date = index.toDate(dirtyDate);
1634
+ var year = index.toInteger(dirtyYear);
1635
+
1636
+ // Check if date is Invalid Date because Date.prototype.setFullYear ignores the value of Invalid Date
1637
+ if (isNaN(date.getTime())) {
1638
+ return new Date(NaN);
1639
+ }
1640
+ date.setFullYear(year);
1641
+ return date;
1642
+ }
1643
+
1644
+ var calendarKeydownHandler = function (payload, state) {
1645
+ var displayDate = state.displayDate, focusDate = state.focusDate, highlightedRange = state.highlightedRange;
1646
+ var minDate = payload.minDate, maxDate = payload.maxDate, calendarType = payload.calendarType, key = payload.key, shiftKey = payload.shiftKey, range = payload.range, selectionType = payload.selectionType;
1647
+ var isNavigatingByYear = shiftKey && [KeyNames.PageUp, KeyNames.PageDown].includes(key);
1648
+ var keyDownDate = getKeyDownDate({
1649
+ focusDate: focusDate,
1650
+ key: key,
1651
+ shiftKey: shiftKey
1652
+ });
1653
+ var newFocusDate = getFocusDate({
1654
+ minDate: minDate,
1655
+ maxDate: maxDate,
1656
+ date: keyDownDate
1657
+ });
1658
+ var newHighlightedRange = selectionType === "range"
1659
+ ? getHighlightRange({
1660
+ date: keyDownDate,
1661
+ range: range,
1662
+ minDate: minDate,
1663
+ maxDate: maxDate
1664
+ })
1665
+ : highlightedRange;
1666
+ var focusDateIsMinOrMax = (maxDate && isEqual(newFocusDate, maxDate)) ||
1667
+ (minDate && isEqual(newFocusDate, minDate));
1668
+ var _a = getDoubleMonthDisplayRange(displayDate), doubleMonthFirstMonth = _a[0], doubleMonthSecondMonth = _a[1];
1669
+ var doubleMonthVisibleRange = {
1670
+ start: startOfMonth(doubleMonthFirstMonth),
1671
+ end: endOfMonth(doubleMonthSecondMonth)
1672
+ };
1673
+ var singleMonthVisibleRange = {
1674
+ start: startOfMonth(displayDate),
1675
+ end: endOfMonth(displayDate)
1676
+ };
1677
+ var isNewFocusDateVisible = isWithinInterval(newFocusDate, calendarType === "double"
1678
+ ? doubleMonthVisibleRange
1679
+ : singleMonthVisibleRange);
1680
+ var commonState = index_es.__assign(index_es.__assign({}, state), { focusDate: newFocusDate, highlightedRange: newHighlightedRange });
1681
+ if (!isNewFocusDateVisible &&
1682
+ !focusDateIsMinOrMax &&
1683
+ isNavigatingByYear &&
1684
+ calendarType === "double") {
1685
+ return index_es.__assign(index_es.__assign({}, commonState), { displayDate: setYear(displayDate, getYear(newFocusDate)) });
1686
+ }
1687
+ if (!isNewFocusDateVisible) {
1688
+ return index_es.__assign(index_es.__assign({}, commonState), { displayDate: startOfMonth(newFocusDate) });
1689
+ }
1690
+ return commonState;
1691
+ };
1692
+
1693
+ var defaultHandler = function (state) {
1694
+ return index_es.__assign({}, state);
1695
+ };
1696
+
1697
+ var reducer = function (state, action) {
1698
+ switch (action.type) {
1699
+ case "DAY_NUMBER_SELECT":
1700
+ return dayNumberSelectHandler(action.payload, state);
1701
+ case "RANGE_SELECT":
1702
+ return rangeSelectHandler(action.payload, state);
1703
+ case "HIGHLIGHT_RANGE":
1704
+ return highlightRangeHandler(action.payload, state);
1705
+ case "DAY_GRID_LEAVE":
1706
+ return dayGridLeaveHandler(action.payload, state);
1707
+ case "SHOW_PREVIOUS_MONTH":
1708
+ return showPreviousMonthHandler(action.payload, state);
1709
+ case "SHOW_NEXT_MONTH":
1710
+ return showNextMonthHandler(action.payload, state);
1711
+ case "SHOW_PREVIOUS_DOUBLE_MONTH":
1712
+ return showPreviousDoubleMonthHandler(action.payload, state);
1713
+ case "SHOW_NEXT_DOUBLE_MONTH":
1714
+ return showNextDoubleMonthHandler(action.payload, state);
1715
+ case "DROPDOWN_CHANGE_YEAR":
1716
+ return dropDownChangeYearHandler(action.payload, state);
1717
+ case "DROPDOWN_CHANGE_MONTH":
1718
+ return dropDownChangeMonthHandler(action.payload, state);
1719
+ case "CALENDAR_KEYDOWN":
1720
+ return calendarKeydownHandler(action.payload, state);
1721
+ default:
1722
+ return defaultHandler(state);
1723
+ }
1724
+ };
1725
+
1726
+ var CalendarFooter = function (_a) {
1727
+ var onCancelClick = _a.onCancelClick;
1728
+ return (React__default["default"].createElement("div", { className: "arc-CalendarFooter" },
1729
+ React__default["default"].createElement("button", { type: "button", className: "arc-CalendarFooter-button", onClick: onCancelClick }, "Cancel")));
1730
+ };
1731
+
1732
+ var CalendarWrapper = function (_a) {
1733
+ var children = _a.children;
1734
+ return (React__default["default"].createElement("div", { className: "arc-CalendarWrapper" },
1735
+ React__default["default"].createElement(Surface.Surface, { background: "light-white" },
1736
+ React__default["default"].createElement("div", { className: "arc-CalendarWrapper-inner" }, children))));
1737
+ };
1738
+
1739
+ /** Use `Calendar` to clearly present available dates and allowing users to choose a way to enter information. */
1740
+ var Calendar = function (_a) {
1741
+ var _b = _a.type, type = _b === void 0 ? "month" : _b, _c = _a.selectionType, selectionType = _c === void 0 ? "single" : _c, _d = _a.autoFocusOnMount, autoFocusOnMount = _d === void 0 ? false : _d, _e = _a.selectedRange, rawSelectedRange = _e === void 0 ? [] : _e, _f = _a.selectedDate, rawSelectedDate = _f === void 0 ? new Date() : _f, rawDisabledDates = _a.disabledDates, rawMinDate = _a.minDate, rawMaxDate = _a.maxDate, onCancelClick = _a.onCancelClick, onDateSelect = _a.onDateSelect, onRangeSelect = _a.onRangeSelect, props = index_es.__rest(_a, ["type", "selectionType", "autoFocusOnMount", "selectedRange", "selectedDate", "disabledDates", "minDate", "maxDate", "onCancelClick", "onDateSelect", "onRangeSelect"]);
1742
+ var todayDate = dateWithoutTime(new Date());
1743
+ var selectedDate = dateWithoutTime(rawSelectedDate);
1744
+ var selectedRange = rawSelectedRange
1745
+ .filter(function (rangeDate) { return Boolean(rangeDate); })
1746
+ .map(function (rangeDate) { return dateWithoutTime(rangeDate); });
1747
+ var _g = React.useState(false), isClientLoaded = _g[0], setIsClientLoaded = _g[1];
1748
+ var _h = React.useReducer(reducer, {
1749
+ displayDate: selectionType === "single"
1750
+ ? startOfMonth(selectedDate)
1751
+ : startOfMonth(selectedRange[0] || todayDate),
1752
+ focusDate: selectionType === "single"
1753
+ ? selectedDate
1754
+ : selectedRange[0] || todayDate,
1755
+ highlightedRange: selectedRange
1756
+ }), _j = _h[0], displayDate = _j.displayDate, focusDate = _j.focusDate, highlightedRange = _j.highlightedRange, dispatch = _h[1];
1757
+ var isMinWidthArcBreakpointM = useMediaQuery.useMediaQuery("(min-width: ".concat(index_es$1.SemSizeBreakpointsM, ")"));
1758
+ React.useEffect(function () {
1759
+ setIsClientLoaded(true);
1760
+ }, []);
1761
+ var disabledDates = rawDisabledDates === null || rawDisabledDates === void 0 ? void 0 : rawDisabledDates.map(function (date) { return dateWithoutTime(date); });
1762
+ var minDate = rawMinDate && dateWithoutTime(rawMinDate);
1763
+ var maxDate = rawMaxDate && dateWithoutTime(rawMaxDate);
1764
+ var calendarType = getCalendarType(type, isMinWidthArcBreakpointM);
1765
+ var doubleMonthDisplayRange = getDoubleMonthDisplayRange(displayDate);
1766
+ var isPreviousMonthDisabled = minDate
1767
+ ? isMonthBeforeMinDate(subMonths(displayDate, 1), minDate)
1768
+ : false;
1769
+ var isNextMonthDisabled = maxDate
1770
+ ? isMonthAfterMaxDate(addMonths(displayDate, 1), maxDate)
1771
+ : false;
1772
+ var isDoubleMonthPreviousDisabled = minDate
1773
+ ? isMonthBeforeMinDate(subMonths(doubleMonthDisplayRange[0], 1), minDate)
1774
+ : false;
1775
+ var isDoubleMonthNextDisabled = maxDate
1776
+ ? isMonthAfterMaxDate(addMonths(doubleMonthDisplayRange[1], 1), maxDate)
1777
+ : false;
1778
+ var setDateRange = function (value) {
1779
+ var _a = processSelectedRange({
1780
+ value: value,
1781
+ range: selectedRange,
1782
+ disabledDates: disabledDates
1783
+ }), rangeOnChangeValue = _a.rangeOnChangeValue, rangeValue = _a.rangeValue;
1784
+ dispatch({
1785
+ type: "RANGE_SELECT",
1786
+ payload: {
1787
+ date: value,
1788
+ range: rangeValue
1789
+ }
1790
+ });
1791
+ onRangeSelect && onRangeSelect(rangeOnChangeValue);
1792
+ };
1793
+ var setNewDate = function (value) {
1794
+ dispatch({
1795
+ type: "DAY_NUMBER_SELECT",
1796
+ payload: value
1797
+ });
1798
+ onDateSelect && onDateSelect(value);
1799
+ };
1800
+ var onDayNumberHover = function (date) { return function () {
1801
+ selectionType === "range" &&
1802
+ dispatch({
1803
+ type: "HIGHLIGHT_RANGE",
1804
+ payload: {
1805
+ date: date,
1806
+ minDate: minDate,
1807
+ maxDate: maxDate,
1808
+ range: selectedRange
1809
+ }
1810
+ });
1811
+ }; };
1812
+ var handleDateSelection = function (date) {
1813
+ var isDisabled = isDisabledDate(date, disabledDates, minDate, maxDate);
1814
+ if (isDisabled)
1815
+ return;
1816
+ selectionType === "single" ? setNewDate(date) : setDateRange(date);
1817
+ };
1818
+ var onDayNumberClick = function (date) { return function () {
1819
+ handleDateSelection(date);
1820
+ }; };
1821
+ var onCancelButtonClick = function () {
1822
+ onCancelClick && onCancelClick();
1823
+ };
1824
+ var onDayGridLeave = function () {
1825
+ dispatch({
1826
+ type: "DAY_GRID_LEAVE",
1827
+ payload: {
1828
+ selectionType: selectionType,
1829
+ range: selectedRange
1830
+ }
1831
+ });
1832
+ };
1833
+ var onPreviousMonthClick = function () {
1834
+ dispatch({
1835
+ type: "SHOW_PREVIOUS_MONTH",
1836
+ payload: {
1837
+ minDate: minDate
1838
+ }
1839
+ });
1840
+ };
1841
+ var onNextMonthClick = function () {
1842
+ dispatch({
1843
+ type: "SHOW_NEXT_MONTH",
1844
+ payload: {
1845
+ maxDate: maxDate
1846
+ }
1847
+ });
1848
+ };
1849
+ var onDoubleViewPreviousClick = function () {
1850
+ dispatch({
1851
+ type: "SHOW_PREVIOUS_DOUBLE_MONTH",
1852
+ payload: {
1853
+ minDate: minDate
1854
+ }
1855
+ });
1856
+ };
1857
+ var onDoubleViewNextClick = function () {
1858
+ dispatch({
1859
+ type: "SHOW_NEXT_DOUBLE_MONTH",
1860
+ payload: {
1861
+ maxDate: maxDate
1862
+ }
1863
+ });
1864
+ };
1865
+ var onYearChange = function (year) {
1866
+ dispatch({
1867
+ type: "DROPDOWN_CHANGE_YEAR",
1868
+ payload: {
1869
+ year: year,
1870
+ minDate: minDate,
1871
+ maxDate: maxDate
1872
+ }
1873
+ });
1874
+ };
1875
+ var onMonthChange = function (month) {
1876
+ dispatch({
1877
+ type: "DROPDOWN_CHANGE_MONTH",
1878
+ payload: {
1879
+ month: month,
1880
+ minDate: minDate,
1881
+ maxDate: maxDate
1882
+ }
1883
+ });
1884
+ };
1885
+ var onKeyboardNavigate = function (key, shiftKey) {
1886
+ dispatch({
1887
+ type: "CALENDAR_KEYDOWN",
1888
+ payload: {
1889
+ minDate: minDate,
1890
+ maxDate: maxDate,
1891
+ selectionType: selectionType,
1892
+ calendarType: calendarType,
1893
+ key: key,
1894
+ shiftKey: shiftKey,
1895
+ range: selectedRange
1896
+ }
1897
+ });
1898
+ };
1899
+ return (React__default["default"].createElement(ArcCalendarContext.Provider, index_es.__assign({ value: {
1900
+ minDate: minDate,
1901
+ maxDate: maxDate,
1902
+ focusDate: focusDate,
1903
+ todayDate: todayDate,
1904
+ displayDate: displayDate,
1905
+ onDayGridLeave: onDayGridLeave,
1906
+ disabledDates: disabledDates,
1907
+ selectedDate: selectedDate,
1908
+ selectionType: selectionType,
1909
+ selectedRange: selectedRange,
1910
+ highlightedRange: highlightedRange,
1911
+ onDayNumberClick: onDayNumberClick,
1912
+ onDayNumberHover: onDayNumberHover,
1913
+ onKeyboardNavigate: onKeyboardNavigate,
1914
+ autoFocusOnMount: autoFocusOnMount
1915
+ } }, index_es.filterDataAttrs(props)),
1916
+ React__default["default"].createElement("div", { style: { display: isClientLoaded ? "block" : "none" } },
1917
+ React__default["default"].createElement(CalendarWrapper, null,
1918
+ calendarType === "year" && (React__default["default"].createElement(CalendarMonthYearView, { isPreviousMonthDisabled: isPreviousMonthDisabled, isNextMonthDisabled: isNextMonthDisabled, onPreviousMonthClick: onPreviousMonthClick, onNextMonthClick: onNextMonthClick, onMonthChange: onMonthChange, onYearChange: onYearChange })),
1919
+ calendarType === "month" && (React__default["default"].createElement(CalendarMonthView, { isPreviousMonthDisabled: isPreviousMonthDisabled, isNextMonthDisabled: isNextMonthDisabled, onPreviousMonthClick: onPreviousMonthClick, onNextMonthClick: onNextMonthClick })),
1920
+ calendarType === "double" && (React__default["default"].createElement(CalendarDoubleMonthView, { isPreviousMonthDisabled: isDoubleMonthPreviousDisabled, isNextMonthDisabled: isDoubleMonthNextDisabled, onPreviousMonthClick: onDoubleViewPreviousClick, onNextMonthClick: onDoubleViewNextClick })),
1921
+ onCancelClick && (React__default["default"].createElement(CalendarFooter, { onCancelClick: onCancelButtonClick }))))));
1922
+ };
1923
+
1924
+ exports.Calendar = Calendar;
1925
+ exports.compareAsc = compareAsc;
1926
+ exports.isAfter = isAfter;
1927
+ exports.isBefore = isBefore;