@salt-ds/lab 1.0.0-alpha.50 → 1.0.0-alpha.52

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 (295) hide show
  1. package/css/salt-lab.css +279 -267
  2. package/dist-cjs/calendar/Calendar.css.js +1 -1
  3. package/dist-cjs/calendar/Calendar.js +6 -15
  4. package/dist-cjs/calendar/Calendar.js.map +1 -1
  5. package/dist-cjs/calendar/CalendarNavigation.css.js +6 -0
  6. package/dist-cjs/calendar/{internal/CalendarNavigation.js → CalendarNavigation.js} +160 -63
  7. package/dist-cjs/calendar/CalendarNavigation.js.map +1 -0
  8. package/dist-cjs/calendar/formatDate.js +56 -0
  9. package/dist-cjs/calendar/formatDate.js.map +1 -0
  10. package/dist-cjs/calendar/internal/CalendarCarousel.js +3 -3
  11. package/dist-cjs/calendar/internal/CalendarCarousel.js.map +1 -1
  12. package/dist-cjs/calendar/internal/CalendarDay.css.js +1 -1
  13. package/dist-cjs/calendar/internal/CalendarDay.js +45 -33
  14. package/dist-cjs/calendar/internal/CalendarDay.js.map +1 -1
  15. package/dist-cjs/calendar/internal/CalendarMonth.js +3 -2
  16. package/dist-cjs/calendar/internal/CalendarMonth.js.map +1 -1
  17. package/dist-cjs/calendar/internal/CalendarWeekHeader.js +3 -3
  18. package/dist-cjs/calendar/internal/CalendarWeekHeader.js.map +1 -1
  19. package/dist-cjs/calendar/internal/useFocusManagement.js +7 -4
  20. package/dist-cjs/calendar/internal/useFocusManagement.js.map +1 -1
  21. package/dist-cjs/calendar/internal/utils.js +28 -23
  22. package/dist-cjs/calendar/internal/utils.js.map +1 -1
  23. package/dist-cjs/calendar/useCalendar.js +94 -45
  24. package/dist-cjs/calendar/useCalendar.js.map +1 -1
  25. package/dist-cjs/calendar/useCalendarDay.js +19 -10
  26. package/dist-cjs/calendar/useCalendarDay.js.map +1 -1
  27. package/dist-cjs/calendar/useCalendarSelection.js +360 -0
  28. package/dist-cjs/calendar/useCalendarSelection.js.map +1 -0
  29. package/dist-cjs/cascading-menu/internal/useMouseHandlers.js.map +1 -1
  30. package/dist-cjs/color-chooser/ColorChooser.js.map +1 -1
  31. package/dist-cjs/combo-box-deprecated/ComboBox.css.js +1 -1
  32. package/dist-cjs/common-hooks/useCollectionItems.js.map +1 -1
  33. package/dist-cjs/content-status/ContentStatus.css.js +1 -1
  34. package/dist-cjs/date-input/DateInput.css.js +1 -1
  35. package/dist-cjs/date-input/DateInputRange.js +355 -0
  36. package/dist-cjs/date-input/DateInputRange.js.map +1 -0
  37. package/dist-cjs/date-input/DateInputSingle.js +229 -0
  38. package/dist-cjs/date-input/DateInputSingle.js.map +1 -0
  39. package/dist-cjs/date-input/utils.js +65 -0
  40. package/dist-cjs/date-input/utils.js.map +1 -0
  41. package/dist-cjs/date-picker/DatePicker.js +40 -148
  42. package/dist-cjs/date-picker/DatePicker.js.map +1 -1
  43. package/dist-cjs/date-picker/DatePickerActions.css.js +6 -0
  44. package/dist-cjs/date-picker/DatePickerActions.css.js.map +1 -0
  45. package/dist-cjs/date-picker/DatePickerActions.js +102 -0
  46. package/dist-cjs/date-picker/DatePickerActions.js.map +1 -0
  47. package/dist-cjs/date-picker/DatePickerContext.js +23 -17
  48. package/dist-cjs/date-picker/DatePickerContext.js.map +1 -1
  49. package/dist-cjs/date-picker/DatePickerOverlay.css.js +6 -0
  50. package/dist-cjs/date-picker/DatePickerOverlay.css.js.map +1 -0
  51. package/dist-cjs/date-picker/DatePickerOverlay.js +50 -0
  52. package/dist-cjs/date-picker/DatePickerOverlay.js.map +1 -0
  53. package/dist-cjs/date-picker/DatePickerOverlayProvider.js +105 -0
  54. package/dist-cjs/date-picker/DatePickerOverlayProvider.js.map +1 -0
  55. package/dist-cjs/date-picker/DatePickerPanel.css.js +1 -1
  56. package/dist-cjs/date-picker/DatePickerRangeInput.js +118 -0
  57. package/dist-cjs/date-picker/DatePickerRangeInput.js.map +1 -0
  58. package/dist-cjs/date-picker/DatePickerRangePanel.js +206 -0
  59. package/dist-cjs/date-picker/DatePickerRangePanel.js.map +1 -0
  60. package/dist-cjs/date-picker/DatePickerSingleInput.js +97 -0
  61. package/dist-cjs/date-picker/DatePickerSingleInput.js.map +1 -0
  62. package/dist-cjs/date-picker/DatePickerSinglePanel.js +138 -0
  63. package/dist-cjs/date-picker/DatePickerSinglePanel.js.map +1 -0
  64. package/dist-cjs/date-picker/useDatePicker.js +179 -0
  65. package/dist-cjs/date-picker/useDatePicker.js.map +1 -0
  66. package/dist-cjs/dropdown/Dropdown.css.js +1 -1
  67. package/dist-cjs/dropdown/DropdownBase.js +1 -1
  68. package/dist-cjs/dropdown/DropdownBase.js.map +1 -1
  69. package/dist-cjs/dropdown/useDropdown.js.map +1 -1
  70. package/dist-cjs/form-field-legacy/FormLabel.js.map +1 -1
  71. package/dist-cjs/index.js +43 -10
  72. package/dist-cjs/index.js.map +1 -1
  73. package/dist-cjs/list/List.js.map +1 -1
  74. package/dist-cjs/menu-button/MenuButtonTrigger.css.js +1 -1
  75. package/dist-cjs/query-input/QueryInput.css.js +1 -1
  76. package/dist-cjs/slider/Slider.css.js +1 -1
  77. package/dist-cjs/slider/Slider.js +53 -105
  78. package/dist-cjs/slider/Slider.js.map +1 -1
  79. package/dist-cjs/slider/internal/SliderContext.js +21 -0
  80. package/dist-cjs/slider/internal/SliderContext.js.map +1 -0
  81. package/dist-cjs/slider/internal/SliderMarks.js +31 -0
  82. package/dist-cjs/slider/internal/SliderMarks.js.map +1 -0
  83. package/dist-cjs/slider/internal/SliderSelection.js +17 -10
  84. package/dist-cjs/slider/internal/SliderSelection.js.map +1 -1
  85. package/dist-cjs/slider/internal/SliderThumb.js +77 -0
  86. package/dist-cjs/slider/internal/SliderThumb.js.map +1 -0
  87. package/dist-cjs/slider/internal/SliderTrack.js +91 -0
  88. package/dist-cjs/slider/internal/SliderTrack.js.map +1 -0
  89. package/dist-cjs/slider/internal/useKeyDownThumb.js +53 -0
  90. package/dist-cjs/slider/internal/useKeyDownThumb.js.map +1 -0
  91. package/dist-cjs/slider/internal/utils.js +78 -116
  92. package/dist-cjs/slider/internal/utils.js.map +1 -1
  93. package/dist-cjs/stepped-tracker/TrackerStep/TrackerStep.css.js +1 -1
  94. package/dist-cjs/stepped-tracker/TrackerStep/TrackerStep.js +29 -25
  95. package/dist-cjs/stepped-tracker/TrackerStep/TrackerStep.js.map +1 -1
  96. package/dist-cjs/tabs/TabActivationIndicator.css.js +1 -1
  97. package/dist-cjs/tabs/Tabstrip.css.js +1 -1
  98. package/dist-cjs/tabs/useTabs.js.map +1 -1
  99. package/dist-cjs/toolbar/overflow-panel/OverflowPanel.css.js +1 -1
  100. package/dist-cjs/toolbar/overflow-panel/OverflowPanel.js.map +1 -1
  101. package/dist-es/calendar/Calendar.css.js +1 -1
  102. package/dist-es/calendar/Calendar.js +7 -16
  103. package/dist-es/calendar/Calendar.js.map +1 -1
  104. package/dist-es/calendar/CalendarNavigation.css.js +4 -0
  105. package/dist-es/calendar/CalendarNavigation.js +308 -0
  106. package/dist-es/calendar/CalendarNavigation.js.map +1 -0
  107. package/dist-es/calendar/formatDate.js +51 -0
  108. package/dist-es/calendar/formatDate.js.map +1 -0
  109. package/dist-es/calendar/internal/CalendarCarousel.js +3 -3
  110. package/dist-es/calendar/internal/CalendarCarousel.js.map +1 -1
  111. package/dist-es/calendar/internal/CalendarDay.css.js +1 -1
  112. package/dist-es/calendar/internal/CalendarDay.js +45 -33
  113. package/dist-es/calendar/internal/CalendarDay.js.map +1 -1
  114. package/dist-es/calendar/internal/CalendarMonth.js +3 -2
  115. package/dist-es/calendar/internal/CalendarMonth.js.map +1 -1
  116. package/dist-es/calendar/internal/CalendarWeekHeader.js +3 -3
  117. package/dist-es/calendar/internal/CalendarWeekHeader.js.map +1 -1
  118. package/dist-es/calendar/internal/useFocusManagement.js +7 -4
  119. package/dist-es/calendar/internal/useFocusManagement.js.map +1 -1
  120. package/dist-es/calendar/internal/utils.js +29 -23
  121. package/dist-es/calendar/internal/utils.js.map +1 -1
  122. package/dist-es/calendar/useCalendar.js +96 -47
  123. package/dist-es/calendar/useCalendar.js.map +1 -1
  124. package/dist-es/calendar/useCalendarDay.js +20 -11
  125. package/dist-es/calendar/useCalendarDay.js.map +1 -1
  126. package/dist-es/calendar/useCalendarSelection.js +350 -0
  127. package/dist-es/calendar/useCalendarSelection.js.map +1 -0
  128. package/dist-es/cascading-menu/internal/useMouseHandlers.js.map +1 -1
  129. package/dist-es/color-chooser/ColorChooser.js.map +1 -1
  130. package/dist-es/combo-box-deprecated/ComboBox.css.js +1 -1
  131. package/dist-es/common-hooks/useCollectionItems.js.map +1 -1
  132. package/dist-es/content-status/ContentStatus.css.js +1 -1
  133. package/dist-es/date-input/DateInput.css.js +1 -1
  134. package/dist-es/date-input/DateInputRange.js +351 -0
  135. package/dist-es/date-input/DateInputRange.js.map +1 -0
  136. package/dist-es/date-input/DateInputSingle.js +225 -0
  137. package/dist-es/date-input/DateInputSingle.js.map +1 -0
  138. package/dist-es/date-input/utils.js +57 -0
  139. package/dist-es/date-input/utils.js.map +1 -0
  140. package/dist-es/date-picker/DatePicker.js +43 -152
  141. package/dist-es/date-picker/DatePicker.js.map +1 -1
  142. package/dist-es/date-picker/DatePickerActions.css.js +4 -0
  143. package/dist-es/date-picker/DatePickerActions.css.js.map +1 -0
  144. package/dist-es/date-picker/DatePickerActions.js +98 -0
  145. package/dist-es/date-picker/DatePickerActions.js.map +1 -0
  146. package/dist-es/date-picker/DatePickerContext.js +22 -17
  147. package/dist-es/date-picker/DatePickerContext.js.map +1 -1
  148. package/dist-es/date-picker/DatePickerOverlay.css.js +4 -0
  149. package/dist-es/date-picker/DatePickerOverlay.css.js.map +1 -0
  150. package/dist-es/date-picker/DatePickerOverlay.js +46 -0
  151. package/dist-es/date-picker/DatePickerOverlay.js.map +1 -0
  152. package/dist-es/date-picker/DatePickerOverlayProvider.js +100 -0
  153. package/dist-es/date-picker/DatePickerOverlayProvider.js.map +1 -0
  154. package/dist-es/date-picker/DatePickerPanel.css.js +1 -1
  155. package/dist-es/date-picker/DatePickerRangeInput.js +114 -0
  156. package/dist-es/date-picker/DatePickerRangeInput.js.map +1 -0
  157. package/dist-es/date-picker/DatePickerRangePanel.js +198 -0
  158. package/dist-es/date-picker/DatePickerRangePanel.js.map +1 -0
  159. package/dist-es/date-picker/DatePickerSingleInput.js +93 -0
  160. package/dist-es/date-picker/DatePickerSingleInput.js.map +1 -0
  161. package/dist-es/date-picker/DatePickerSinglePanel.js +130 -0
  162. package/dist-es/date-picker/DatePickerSinglePanel.js.map +1 -0
  163. package/dist-es/date-picker/useDatePicker.js +175 -0
  164. package/dist-es/date-picker/useDatePicker.js.map +1 -0
  165. package/dist-es/dropdown/Dropdown.css.js +1 -1
  166. package/dist-es/dropdown/DropdownBase.js +1 -1
  167. package/dist-es/dropdown/DropdownBase.js.map +1 -1
  168. package/dist-es/dropdown/useDropdown.js.map +1 -1
  169. package/dist-es/form-field-legacy/FormLabel.js.map +1 -1
  170. package/dist-es/index.js +14 -3
  171. package/dist-es/index.js.map +1 -1
  172. package/dist-es/list/List.js.map +1 -1
  173. package/dist-es/menu-button/MenuButtonTrigger.css.js +1 -1
  174. package/dist-es/query-input/QueryInput.css.js +1 -1
  175. package/dist-es/slider/Slider.css.js +1 -1
  176. package/dist-es/slider/Slider.js +55 -107
  177. package/dist-es/slider/Slider.js.map +1 -1
  178. package/dist-es/slider/internal/SliderContext.js +16 -0
  179. package/dist-es/slider/internal/SliderContext.js.map +1 -0
  180. package/dist-es/slider/internal/SliderMarks.js +27 -0
  181. package/dist-es/slider/internal/SliderMarks.js.map +1 -0
  182. package/dist-es/slider/internal/SliderSelection.js +17 -10
  183. package/dist-es/slider/internal/SliderSelection.js.map +1 -1
  184. package/dist-es/slider/internal/SliderThumb.js +73 -0
  185. package/dist-es/slider/internal/SliderThumb.js.map +1 -0
  186. package/dist-es/slider/internal/SliderTrack.js +87 -0
  187. package/dist-es/slider/internal/SliderTrack.js.map +1 -0
  188. package/dist-es/slider/internal/useKeyDownThumb.js +49 -0
  189. package/dist-es/slider/internal/useKeyDownThumb.js.map +1 -0
  190. package/dist-es/slider/internal/utils.js +70 -111
  191. package/dist-es/slider/internal/utils.js.map +1 -1
  192. package/dist-es/stepped-tracker/TrackerStep/TrackerStep.css.js +1 -1
  193. package/dist-es/stepped-tracker/TrackerStep/TrackerStep.js +30 -26
  194. package/dist-es/stepped-tracker/TrackerStep/TrackerStep.js.map +1 -1
  195. package/dist-es/tabs/TabActivationIndicator.css.js +1 -1
  196. package/dist-es/tabs/Tabstrip.css.js +1 -1
  197. package/dist-es/tabs/useTabs.js.map +1 -1
  198. package/dist-es/toolbar/overflow-panel/OverflowPanel.css.js +1 -1
  199. package/dist-es/toolbar/overflow-panel/OverflowPanel.js.map +1 -1
  200. package/dist-types/calendar/Calendar.d.ts +63 -5
  201. package/dist-types/calendar/CalendarNavigation.d.ts +57 -0
  202. package/dist-types/calendar/formatDate.d.ts +14 -0
  203. package/dist-types/calendar/index.d.ts +3 -1
  204. package/dist-types/calendar/internal/CalendarDay.d.ts +2 -1
  205. package/dist-types/calendar/internal/CalendarWeekHeader.d.ts +4 -4
  206. package/dist-types/calendar/internal/useFocusManagement.d.ts +2 -1
  207. package/dist-types/calendar/internal/utils.d.ts +7 -8
  208. package/dist-types/calendar/useCalendar.d.ts +100 -16
  209. package/dist-types/calendar/useCalendarDay.d.ts +38 -0
  210. package/dist-types/calendar/useCalendarSelection.d.ts +189 -0
  211. package/dist-types/date-input/DateInputRange.d.ts +150 -0
  212. package/dist-types/date-input/DateInputSingle.d.ts +117 -0
  213. package/dist-types/date-input/index.d.ts +3 -1
  214. package/dist-types/date-input/utils.d.ts +43 -0
  215. package/dist-types/date-picker/DatePicker.d.ts +20 -62
  216. package/dist-types/date-picker/DatePickerActions.d.ts +80 -0
  217. package/dist-types/date-picker/DatePickerContext.d.ts +180 -17
  218. package/dist-types/date-picker/DatePickerOverlay.d.ts +11 -0
  219. package/dist-types/date-picker/DatePickerOverlayProvider.d.ts +67 -0
  220. package/dist-types/date-picker/DatePickerRangeInput.d.ts +7 -0
  221. package/dist-types/date-picker/DatePickerRangePanel.d.ts +64 -0
  222. package/dist-types/date-picker/DatePickerSingleInput.d.ts +7 -0
  223. package/dist-types/date-picker/DatePickerSinglePanel.d.ts +42 -0
  224. package/dist-types/date-picker/index.d.ts +7 -0
  225. package/dist-types/date-picker/useDatePicker.d.ts +112 -0
  226. package/dist-types/slider/Slider.d.ts +23 -10
  227. package/dist-types/slider/internal/SliderContext.d.ts +11 -0
  228. package/dist-types/slider/internal/SliderMarks.d.ts +7 -0
  229. package/dist-types/slider/internal/SliderSelection.d.ts +3 -3
  230. package/dist-types/slider/internal/SliderThumb.d.ts +8 -0
  231. package/dist-types/slider/internal/SliderTrack.d.ts +4 -0
  232. package/dist-types/slider/internal/index.d.ts +3 -0
  233. package/dist-types/slider/internal/useKeyDownThumb.d.ts +2 -0
  234. package/dist-types/slider/internal/utils.d.ts +18 -10
  235. package/dist-types/slider/types.d.ts +3 -1
  236. package/dist-types/stepped-tracker/TrackerStep/TrackerStep.d.ts +11 -3
  237. package/package.json +3 -3
  238. package/dist-cjs/calendar/internal/CalendarNavigation.css.js +0 -6
  239. package/dist-cjs/calendar/internal/CalendarNavigation.js.map +0 -1
  240. package/dist-cjs/calendar/useSelection.js +0 -249
  241. package/dist-cjs/calendar/useSelection.js.map +0 -1
  242. package/dist-cjs/date-input/DateInput.js +0 -281
  243. package/dist-cjs/date-input/DateInput.js.map +0 -1
  244. package/dist-cjs/date-picker/DatePickerPanel.js +0 -155
  245. package/dist-cjs/date-picker/DatePickerPanel.js.map +0 -1
  246. package/dist-cjs/slider/internal/SliderHandle.js +0 -44
  247. package/dist-cjs/slider/internal/SliderHandle.js.map +0 -1
  248. package/dist-cjs/slider/internal/SliderMarkLabels.js +0 -45
  249. package/dist-cjs/slider/internal/SliderMarkLabels.js.map +0 -1
  250. package/dist-cjs/slider/internal/SliderRail.js +0 -25
  251. package/dist-cjs/slider/internal/SliderRail.js.map +0 -1
  252. package/dist-cjs/slider/internal/SliderRailMarks.js +0 -48
  253. package/dist-cjs/slider/internal/SliderRailMarks.js.map +0 -1
  254. package/dist-cjs/slider/internal/styles.js +0 -99
  255. package/dist-cjs/slider/internal/styles.js.map +0 -1
  256. package/dist-cjs/slider/internal/useSliderKeyDown.js +0 -50
  257. package/dist-cjs/slider/internal/useSliderKeyDown.js.map +0 -1
  258. package/dist-cjs/slider/internal/useSliderMouseDown.js +0 -96
  259. package/dist-cjs/slider/internal/useSliderMouseDown.js.map +0 -1
  260. package/dist-es/calendar/internal/CalendarNavigation.css.js +0 -4
  261. package/dist-es/calendar/internal/CalendarNavigation.js +0 -211
  262. package/dist-es/calendar/internal/CalendarNavigation.js.map +0 -1
  263. package/dist-es/calendar/useSelection.js +0 -242
  264. package/dist-es/calendar/useSelection.js.map +0 -1
  265. package/dist-es/date-input/DateInput.js +0 -277
  266. package/dist-es/date-input/DateInput.js.map +0 -1
  267. package/dist-es/date-picker/DatePickerPanel.js +0 -151
  268. package/dist-es/date-picker/DatePickerPanel.js.map +0 -1
  269. package/dist-es/slider/internal/SliderHandle.js +0 -40
  270. package/dist-es/slider/internal/SliderHandle.js.map +0 -1
  271. package/dist-es/slider/internal/SliderMarkLabels.js +0 -41
  272. package/dist-es/slider/internal/SliderMarkLabels.js.map +0 -1
  273. package/dist-es/slider/internal/SliderRail.js +0 -21
  274. package/dist-es/slider/internal/SliderRail.js.map +0 -1
  275. package/dist-es/slider/internal/SliderRailMarks.js +0 -44
  276. package/dist-es/slider/internal/SliderRailMarks.js.map +0 -1
  277. package/dist-es/slider/internal/styles.js +0 -91
  278. package/dist-es/slider/internal/styles.js.map +0 -1
  279. package/dist-es/slider/internal/useSliderKeyDown.js +0 -46
  280. package/dist-es/slider/internal/useSliderKeyDown.js.map +0 -1
  281. package/dist-es/slider/internal/useSliderMouseDown.js +0 -92
  282. package/dist-es/slider/internal/useSliderMouseDown.js.map +0 -1
  283. package/dist-types/calendar/internal/CalendarNavigation.d.ts +0 -15
  284. package/dist-types/calendar/useSelection.d.ts +0 -78
  285. package/dist-types/date-input/DateInput.d.ts +0 -56
  286. package/dist-types/date-picker/DatePickerPanel.d.ts +0 -10
  287. package/dist-types/slider/internal/SliderHandle.d.ts +0 -11
  288. package/dist-types/slider/internal/SliderMarkLabels.d.ts +0 -7
  289. package/dist-types/slider/internal/SliderRail.d.ts +0 -1
  290. package/dist-types/slider/internal/SliderRailMarks.d.ts +0 -12
  291. package/dist-types/slider/internal/styles.d.ts +0 -10
  292. package/dist-types/slider/internal/useSliderKeyDown.d.ts +0 -4
  293. package/dist-types/slider/internal/useSliderMouseDown.d.ts +0 -4
  294. /package/dist-cjs/calendar/{internal/CalendarNavigation.css.js.map → CalendarNavigation.css.js.map} +0 -0
  295. /package/dist-es/calendar/{internal/CalendarNavigation.css.js.map → CalendarNavigation.css.js.map} +0 -0
@@ -15,7 +15,15 @@ var utils = require('./utils.js');
15
15
  const withBaseName = core.makePrefixer("saltCalendarDay");
16
16
  const CalendarDay = react.forwardRef(
17
17
  function CalendarDay2(props, ref) {
18
- const { className, day, renderDayContents, month, TooltipProps, ...rest } = props;
18
+ const {
19
+ className,
20
+ day,
21
+ renderDayContents,
22
+ month,
23
+ TooltipProps,
24
+ formatDate: formatDateProp = utils.formatDate,
25
+ ...rest
26
+ } = props;
19
27
  const targetWindow = window.useWindow();
20
28
  styles.useComponentCssInjection({
21
29
  testId: "salt-calendar-day",
@@ -24,7 +32,7 @@ const CalendarDay = react.forwardRef(
24
32
  });
25
33
  const dayRef = react.useRef(null);
26
34
  const buttonRef = core.useForkRef(ref, dayRef);
27
- const { status, dayProps, unselectableReason, highlightedReason } = useCalendarDay.useCalendarDay(
35
+ const { status, dayProps, unselectableReason, highlightedReason, locale } = useCalendarDay.useCalendarDay(
28
36
  {
29
37
  date: day,
30
38
  month
@@ -32,45 +40,49 @@ const CalendarDay = react.forwardRef(
32
40
  dayRef
33
41
  );
34
42
  const { outOfRange, today, unselectable, highlighted, hidden, disabled } = status;
43
+ const buttonElement = /* @__PURE__ */ jsxRuntime.jsx("button", {
44
+ "aria-label": formatDateProp(day, locale, {
45
+ day: "2-digit",
46
+ month: "long",
47
+ year: "numeric"
48
+ }),
49
+ disabled,
50
+ type: "button",
51
+ ...dayProps,
52
+ ref: buttonRef,
53
+ ...rest,
54
+ className: clsx.clsx(
55
+ withBaseName(),
56
+ {
57
+ [withBaseName("hidden")]: hidden,
58
+ [withBaseName("outOfRange")]: outOfRange,
59
+ [withBaseName("disabled")]: disabled,
60
+ [withBaseName("unselectable")]: !!unselectable,
61
+ [withBaseName("highlighted")]: !!highlighted
62
+ },
63
+ dayProps.className,
64
+ className
65
+ ),
66
+ children: /* @__PURE__ */ jsxRuntime.jsx("span", {
67
+ className: clsx.clsx(withBaseName("content"), {
68
+ [withBaseName("today")]: today
69
+ }),
70
+ children: renderDayContents ? renderDayContents(day, status) : formatDateProp(day, locale, { day: "numeric" })
71
+ })
72
+ });
73
+ const hasTooltip = unselectableReason || highlightedReason;
74
+ if (!hasTooltip) {
75
+ return buttonElement;
76
+ }
35
77
  return /* @__PURE__ */ jsxRuntime.jsx(core.Tooltip, {
36
78
  hideIcon: true,
37
79
  status: unselectableReason ? "error" : "info",
38
80
  content: unselectableReason || highlightedReason || "Date is out of range",
39
- disabled: !unselectableReason && !highlightedReason,
40
81
  placement: "top",
41
82
  enterDelay: 0,
42
83
  leaveDelay: 0,
43
84
  ...TooltipProps,
44
- children: /* @__PURE__ */ jsxRuntime.jsx("button", {
45
- "aria-label": utils.formatDate(day, {
46
- day: "2-digit",
47
- month: "long",
48
- year: "numeric"
49
- }),
50
- disabled,
51
- type: "button",
52
- ...dayProps,
53
- ref: buttonRef,
54
- ...rest,
55
- className: clsx.clsx(
56
- withBaseName(),
57
- {
58
- [withBaseName("hidden")]: hidden,
59
- [withBaseName("outOfRange")]: outOfRange,
60
- [withBaseName("disabled")]: disabled,
61
- [withBaseName("unselectable")]: !!unselectable,
62
- [withBaseName("highlighted")]: !!highlighted
63
- },
64
- dayProps.className,
65
- className
66
- ),
67
- children: /* @__PURE__ */ jsxRuntime.jsx("span", {
68
- className: clsx.clsx(withBaseName("content"), {
69
- [withBaseName("today")]: today
70
- }),
71
- children: renderDayContents ? renderDayContents(day, status) : utils.formatDate(day, { day: "numeric" })
72
- })
73
- })
85
+ children: buttonElement
74
86
  });
75
87
  }
76
88
  );
@@ -1 +1 @@
1
- {"version":3,"file":"CalendarDay.js","sources":["../src/calendar/internal/CalendarDay.tsx"],"sourcesContent":["import type { DateValue } from \"@internationalized/date\";\nimport {\n Tooltip,\n type TooltipProps,\n makePrefixer,\n useForkRef,\n} from \"@salt-ds/core\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport {\n type ComponentPropsWithRef,\n type ReactElement,\n forwardRef,\n useRef,\n} from \"react\";\nimport { type DayStatus, useCalendarDay } from \"../useCalendarDay\";\nimport calendarDayCss from \"./CalendarDay.css\";\nimport { formatDate } from \"./utils\";\n\nexport type DateFormatter = (day: Date) => string | undefined;\n\nexport interface CalendarDayProps\n extends Omit<ComponentPropsWithRef<\"button\">, \"children\"> {\n day: DateValue;\n formatDate?: DateFormatter;\n renderDayContents?: (date: DateValue, status: DayStatus) => ReactElement;\n status?: DayStatus;\n month: DateValue;\n TooltipProps?: Partial<TooltipProps>;\n}\n\nconst withBaseName = makePrefixer(\"saltCalendarDay\");\n\nexport const CalendarDay = forwardRef<HTMLButtonElement, CalendarDayProps>(\n function CalendarDay(props, ref) {\n const { className, day, renderDayContents, month, TooltipProps, ...rest } =\n props;\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-calendar-day\",\n css: calendarDayCss,\n window: targetWindow,\n });\n\n const dayRef = useRef<HTMLButtonElement>(null);\n const buttonRef = useForkRef(ref, dayRef);\n const { status, dayProps, unselectableReason, highlightedReason } =\n useCalendarDay(\n {\n date: day,\n month,\n },\n dayRef,\n );\n const { outOfRange, today, unselectable, highlighted, hidden, disabled } =\n status;\n\n return (\n <Tooltip\n hideIcon\n status={unselectableReason ? \"error\" : \"info\"}\n content={\n unselectableReason || highlightedReason || \"Date is out of range\"\n }\n disabled={!unselectableReason && !highlightedReason}\n placement=\"top\"\n enterDelay={0} // --salt-duration-instant\n leaveDelay={0} // --salt-duration-instant\n {...TooltipProps}\n >\n <button\n aria-label={formatDate(day, {\n day: \"2-digit\",\n month: \"long\",\n year: \"numeric\",\n })}\n disabled={disabled}\n type=\"button\"\n {...dayProps}\n ref={buttonRef}\n {...rest}\n className={clsx(\n withBaseName(),\n {\n [withBaseName(\"hidden\")]: hidden,\n [withBaseName(\"outOfRange\")]: outOfRange,\n [withBaseName(\"disabled\")]: disabled,\n [withBaseName(\"unselectable\")]: !!unselectable,\n [withBaseName(\"highlighted\")]: !!highlighted,\n },\n dayProps.className,\n className,\n )}\n >\n <span\n className={clsx(withBaseName(\"content\"), {\n [withBaseName(\"today\")]: today,\n })}\n >\n {renderDayContents\n ? renderDayContents(day, status)\n : formatDate(day, { day: \"numeric\" })}\n </span>\n </button>\n </Tooltip>\n );\n },\n);\n"],"names":["makePrefixer","forwardRef","CalendarDay","useWindow","useComponentCssInjection","calendarDayCss","useRef","useForkRef","useCalendarDay","jsx","Tooltip","formatDate","clsx"],"mappings":"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"}
1
+ {"version":3,"file":"CalendarDay.js","sources":["../src/calendar/internal/CalendarDay.tsx"],"sourcesContent":["import type { DateValue } from \"@internationalized/date\";\nimport {\n Tooltip,\n type TooltipProps,\n makePrefixer,\n useForkRef,\n} from \"@salt-ds/core\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { clsx } from \"clsx\";\nimport {\n type ComponentPropsWithRef,\n type ReactElement,\n forwardRef,\n useRef,\n} from \"react\";\nimport { type DayStatus, useCalendarDay } from \"../useCalendarDay\";\nimport calendarDayCss from \"./CalendarDay.css\";\nimport { formatDate as defaultFormatDate } from \"./utils\";\n\nexport type DateFormatter = (day: Date) => string | undefined;\n\nexport interface CalendarDayProps\n extends Omit<ComponentPropsWithRef<\"button\">, \"children\"> {\n day: DateValue;\n formatDate?: typeof defaultFormatDate;\n renderDayContents?: (date: DateValue, status: DayStatus) => ReactElement;\n status?: DayStatus;\n month: DateValue;\n TooltipProps?: Partial<TooltipProps>;\n}\n\nconst withBaseName = makePrefixer(\"saltCalendarDay\");\n\nexport const CalendarDay = forwardRef<HTMLButtonElement, CalendarDayProps>(\n function CalendarDay(props, ref) {\n const {\n className,\n day,\n renderDayContents,\n month,\n TooltipProps,\n formatDate: formatDateProp = defaultFormatDate,\n ...rest\n } = props;\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-calendar-day\",\n css: calendarDayCss,\n window: targetWindow,\n });\n\n const dayRef = useRef<HTMLButtonElement>(null);\n const buttonRef = useForkRef(ref, dayRef);\n const { status, dayProps, unselectableReason, highlightedReason, locale } =\n useCalendarDay(\n {\n date: day,\n month,\n },\n dayRef,\n );\n const { outOfRange, today, unselectable, highlighted, hidden, disabled } =\n status;\n\n const buttonElement = (\n <button\n aria-label={formatDateProp(day, locale, {\n day: \"2-digit\",\n month: \"long\",\n year: \"numeric\",\n })}\n disabled={disabled}\n type=\"button\"\n {...dayProps}\n ref={buttonRef}\n {...rest}\n className={clsx(\n withBaseName(),\n {\n [withBaseName(\"hidden\")]: hidden,\n [withBaseName(\"outOfRange\")]: outOfRange,\n [withBaseName(\"disabled\")]: disabled,\n [withBaseName(\"unselectable\")]: !!unselectable,\n [withBaseName(\"highlighted\")]: !!highlighted,\n },\n dayProps.className,\n className,\n )}\n >\n <span\n className={clsx(withBaseName(\"content\"), {\n [withBaseName(\"today\")]: today,\n })}\n >\n {renderDayContents\n ? renderDayContents(day, status)\n : formatDateProp(day, locale, { day: \"numeric\" })}\n </span>\n </button>\n );\n const hasTooltip = unselectableReason || highlightedReason;\n if (!hasTooltip) {\n return buttonElement;\n }\n return (\n <Tooltip\n hideIcon\n status={unselectableReason ? \"error\" : \"info\"}\n content={\n unselectableReason || highlightedReason || \"Date is out of range\"\n }\n placement=\"top\"\n enterDelay={0} // --salt-duration-instant\n leaveDelay={0} // --salt-duration-instant\n {...TooltipProps}\n >\n {buttonElement}\n </Tooltip>\n );\n },\n);\n"],"names":["makePrefixer","forwardRef","CalendarDay","defaultFormatDate","useWindow","useComponentCssInjection","calendarDayCss","useRef","useForkRef","useCalendarDay","jsx","clsx","Tooltip"],"mappings":";;;;;;;;;;;;;;AAgCA,MAAM,YAAA,GAAeA,kBAAa,iBAAiB,CAAA,CAAA;AAE5C,MAAM,WAAc,GAAAC,gBAAA;AAAA,EACzB,SAASC,YAAY,CAAA,KAAA,EAAO,GAAK,EAAA;AAC/B,IAAM,MAAA;AAAA,MACJ,SAAA;AAAA,MACA,GAAA;AAAA,MACA,iBAAA;AAAA,MACA,KAAA;AAAA,MACA,YAAA;AAAA,MACA,YAAY,cAAiB,GAAAC,gBAAA;AAAA,MAC1B,GAAA,IAAA;AAAA,KACD,GAAA,KAAA,CAAA;AACJ,IAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,mBAAA;AAAA,MACR,GAAK,EAAAC,aAAA;AAAA,MACL,MAAQ,EAAA,YAAA;AAAA,KACT,CAAA,CAAA;AAED,IAAM,MAAA,MAAA,GAASC,aAA0B,IAAI,CAAA,CAAA;AAC7C,IAAM,MAAA,SAAA,GAAYC,eAAW,CAAA,GAAA,EAAK,MAAM,CAAA,CAAA;AACxC,IAAA,MAAM,EAAE,MAAQ,EAAA,QAAA,EAAU,kBAAoB,EAAA,iBAAA,EAAmB,QAC/D,GAAAC,6BAAA;AAAA,MACE;AAAA,QACE,IAAM,EAAA,GAAA;AAAA,QACN,KAAA;AAAA,OACF;AAAA,MACA,MAAA;AAAA,KACF,CAAA;AACF,IAAA,MAAM,EAAE,UAAY,EAAA,KAAA,EAAO,cAAc,WAAa,EAAA,MAAA,EAAQ,UAC5D,GAAA,MAAA,CAAA;AAEF,IAAA,MAAM,gCACHC,cAAA,CAAA,QAAA,EAAA;AAAA,MACC,YAAA,EAAY,cAAe,CAAA,GAAA,EAAK,MAAQ,EAAA;AAAA,QACtC,GAAK,EAAA,SAAA;AAAA,QACL,KAAO,EAAA,MAAA;AAAA,QACP,IAAM,EAAA,SAAA;AAAA,OACP,CAAA;AAAA,MACD,QAAA;AAAA,MACA,IAAK,EAAA,QAAA;AAAA,MACJ,GAAG,QAAA;AAAA,MACJ,GAAK,EAAA,SAAA;AAAA,MACJ,GAAG,IAAA;AAAA,MACJ,SAAW,EAAAC,SAAA;AAAA,QACT,YAAa,EAAA;AAAA,QACb;AAAA,UACE,CAAC,YAAa,CAAA,QAAQ,CAAI,GAAA,MAAA;AAAA,UAC1B,CAAC,YAAa,CAAA,YAAY,CAAI,GAAA,UAAA;AAAA,UAC9B,CAAC,YAAa,CAAA,UAAU,CAAI,GAAA,QAAA;AAAA,UAC5B,CAAC,YAAA,CAAa,cAAc,CAAA,GAAI,CAAC,CAAC,YAAA;AAAA,UAClC,CAAC,YAAA,CAAa,aAAa,CAAA,GAAI,CAAC,CAAC,WAAA;AAAA,SACnC;AAAA,QACA,QAAS,CAAA,SAAA;AAAA,QACT,SAAA;AAAA,OACF;AAAA,MAEA,QAAC,kBAAAD,cAAA,CAAA,MAAA,EAAA;AAAA,QACC,SAAW,EAAAC,SAAA,CAAK,YAAa,CAAA,SAAS,CAAG,EAAA;AAAA,UACvC,CAAC,YAAa,CAAA,OAAO,CAAI,GAAA,KAAA;AAAA,SAC1B,CAAA;AAAA,QAEA,QAAA,EAAA,iBAAA,GACG,iBAAkB,CAAA,GAAA,EAAK,MAAM,CAAA,GAC7B,cAAe,CAAA,GAAA,EAAK,MAAQ,EAAA,EAAE,GAAK,EAAA,SAAA,EAAW,CAAA;AAAA,OACpD,CAAA;AAAA,KACF,CAAA,CAAA;AAEF,IAAA,MAAM,aAAa,kBAAsB,IAAA,iBAAA,CAAA;AACzC,IAAA,IAAI,CAAC,UAAY,EAAA;AACf,MAAO,OAAA,aAAA,CAAA;AAAA,KACT;AACA,IAAA,uBACGD,cAAA,CAAAE,YAAA,EAAA;AAAA,MACC,QAAQ,EAAA,IAAA;AAAA,MACR,MAAA,EAAQ,qBAAqB,OAAU,GAAA,MAAA;AAAA,MACvC,OAAA,EACE,sBAAsB,iBAAqB,IAAA,sBAAA;AAAA,MAE7C,SAAU,EAAA,KAAA;AAAA,MACV,UAAY,EAAA,CAAA;AAAA,MACZ,UAAY,EAAA,CAAA;AAAA,MACX,GAAG,YAAA;AAAA,MAEH,QAAA,EAAA,aAAA;AAAA,KACH,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
@@ -30,10 +30,11 @@ const CalendarMonth = react.forwardRef(
30
30
  css: CalendarMonth$1,
31
31
  window: targetWindow
32
32
  });
33
- const days = utils.generateVisibleDays(date);
34
33
  const {
34
+ state: { locale },
35
35
  helpers: { setHoveredDate }
36
36
  } = CalendarContext.useCalendarContext();
37
+ const days = utils.generateVisibleDays(date, locale);
37
38
  const handleMouseLeave = (event) => {
38
39
  setHoveredDate(event, null);
39
40
  onMouseLeave == null ? void 0 : onMouseLeave(event);
@@ -52,7 +53,7 @@ const CalendarMonth = react.forwardRef(
52
53
  renderDayContents,
53
54
  month: date,
54
55
  TooltipProps
55
- }, utils.formatDate(day.date));
56
+ }, utils.formatDate(day.date, locale));
56
57
  })
57
58
  })
58
59
  });
@@ -1 +1 @@
1
- {"version":3,"file":"CalendarMonth.js","sources":["../src/calendar/internal/CalendarMonth.tsx"],"sourcesContent":["import type { DateValue } from \"@internationalized/date\";\nimport { makePrefixer } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport {\n type ComponentPropsWithRef,\n type MouseEvent,\n type SyntheticEvent,\n forwardRef,\n} from \"react\";\nimport { CalendarDay, type CalendarDayProps } from \"./CalendarDay\";\nimport { formatDate, generateVisibleDays } from \"./utils\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useCalendarContext } from \"./CalendarContext\";\nimport calendarMonthCss from \"./CalendarMonth.css\";\n\nexport interface CalendarMonthProps extends ComponentPropsWithRef<\"div\"> {\n date: DateValue;\n hideOutOfRangeDates?: boolean;\n renderDayContents?: CalendarDayProps[\"renderDayContents\"];\n TooltipProps?: CalendarDayProps[\"TooltipProps\"];\n}\n\nconst withBaseName = makePrefixer(\"saltCalendarMonth\");\n\nexport const CalendarMonth = forwardRef<HTMLDivElement, CalendarMonthProps>(\n function CalendarMonth(props, ref) {\n const {\n className,\n date,\n renderDayContents,\n onMouseLeave,\n TooltipProps,\n ...rest\n } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-calendar-month\",\n css: calendarMonthCss,\n window: targetWindow,\n });\n\n const days = generateVisibleDays(date);\n const {\n helpers: { setHoveredDate },\n } = useCalendarContext();\n\n const handleMouseLeave = (event: SyntheticEvent) => {\n setHoveredDate(event, null);\n onMouseLeave?.(event as MouseEvent<HTMLDivElement>);\n };\n\n return (\n <div\n className={clsx(withBaseName(), className)}\n ref={ref}\n onMouseLeave={handleMouseLeave}\n {...rest}\n >\n <div\n data-testid=\"CalendarDateGrid\"\n className={withBaseName(\"dateGrid\")}\n >\n {days.map((day) => {\n return (\n <CalendarDay\n key={formatDate(day.date)}\n day={day.date}\n renderDayContents={renderDayContents}\n month={date}\n TooltipProps={TooltipProps}\n />\n );\n })}\n </div>\n </div>\n );\n },\n);\n"],"names":["makePrefixer","forwardRef","CalendarMonth","useWindow","useComponentCssInjection","calendarMonthCss","generateVisibleDays","useCalendarContext","jsx","clsx","CalendarDay","formatDate"],"mappings":";;;;;;;;;;;;;;;AAwBA,MAAM,YAAA,GAAeA,kBAAa,mBAAmB,CAAA,CAAA;AAE9C,MAAM,aAAgB,GAAAC,gBAAA;AAAA,EAC3B,SAASC,cAAc,CAAA,KAAA,EAAO,GAAK,EAAA;AACjC,IAAM,MAAA;AAAA,MACJ,SAAA;AAAA,MACA,IAAA;AAAA,MACA,iBAAA;AAAA,MACA,YAAA;AAAA,MACA,YAAA;AAAA,MACG,GAAA,IAAA;AAAA,KACD,GAAA,KAAA,CAAA;AAEJ,IAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,qBAAA;AAAA,MACR,GAAK,EAAAC,eAAA;AAAA,MACL,MAAQ,EAAA,YAAA;AAAA,KACT,CAAA,CAAA;AAED,IAAM,MAAA,IAAA,GAAOC,0BAAoB,IAAI,CAAA,CAAA;AACrC,IAAM,MAAA;AAAA,MACJ,OAAA,EAAS,EAAE,cAAe,EAAA;AAAA,QACxBC,kCAAmB,EAAA,CAAA;AAEvB,IAAM,MAAA,gBAAA,GAAmB,CAAC,KAA0B,KAAA;AAClD,MAAA,cAAA,CAAe,OAAO,IAAI,CAAA,CAAA;AAC1B,MAAe,YAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,YAAA,CAAA,KAAA,CAAA,CAAA;AAAA,KACjB,CAAA;AAEA,IAAA,uBACGC,cAAA,CAAA,KAAA,EAAA;AAAA,MACC,SAAW,EAAAC,SAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,MACzC,GAAA;AAAA,MACA,YAAc,EAAA,gBAAA;AAAA,MACb,GAAG,IAAA;AAAA,MAEJ,QAAC,kBAAAD,cAAA,CAAA,KAAA,EAAA;AAAA,QACC,aAAY,EAAA,kBAAA;AAAA,QACZ,SAAA,EAAW,aAAa,UAAU,CAAA;AAAA,QAEjC,QAAA,EAAA,IAAA,CAAK,GAAI,CAAA,CAAC,GAAQ,KAAA;AACjB,UAAA,uBACGA,cAAA,CAAAE,uBAAA,EAAA;AAAA,YAEC,KAAK,GAAI,CAAA,IAAA;AAAA,YACT,iBAAA;AAAA,YACA,KAAO,EAAA,IAAA;AAAA,YACP,YAAA;AAAA,WAJK,EAAAC,gBAAA,CAAW,GAAI,CAAA,IAAI,CAK1B,CAAA,CAAA;AAAA,SAEH,CAAA;AAAA,OACH,CAAA;AAAA,KACF,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
1
+ {"version":3,"file":"CalendarMonth.js","sources":["../src/calendar/internal/CalendarMonth.tsx"],"sourcesContent":["import type { DateValue } from \"@internationalized/date\";\nimport { makePrefixer } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport {\n type ComponentPropsWithRef,\n type MouseEvent,\n type SyntheticEvent,\n forwardRef,\n} from \"react\";\nimport { CalendarDay, type CalendarDayProps } from \"./CalendarDay\";\nimport { formatDate, generateVisibleDays } from \"./utils\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useCalendarContext } from \"./CalendarContext\";\nimport calendarMonthCss from \"./CalendarMonth.css\";\n\nexport interface CalendarMonthProps extends ComponentPropsWithRef<\"div\"> {\n date: DateValue;\n hideOutOfRangeDates?: boolean;\n renderDayContents?: CalendarDayProps[\"renderDayContents\"];\n TooltipProps?: CalendarDayProps[\"TooltipProps\"];\n}\n\nconst withBaseName = makePrefixer(\"saltCalendarMonth\");\n\nexport const CalendarMonth = forwardRef<HTMLDivElement, CalendarMonthProps>(\n function CalendarMonth(props, ref) {\n const {\n className,\n date,\n renderDayContents,\n onMouseLeave,\n TooltipProps,\n ...rest\n } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-calendar-month\",\n css: calendarMonthCss,\n window: targetWindow,\n });\n\n const {\n state: { locale },\n helpers: { setHoveredDate },\n } = useCalendarContext();\n const days = generateVisibleDays(date, locale);\n\n const handleMouseLeave = (event: SyntheticEvent) => {\n setHoveredDate(event, null);\n onMouseLeave?.(event as MouseEvent<HTMLDivElement>);\n };\n\n return (\n <div\n className={clsx(withBaseName(), className)}\n ref={ref}\n onMouseLeave={handleMouseLeave}\n {...rest}\n >\n <div\n data-testid=\"CalendarDateGrid\"\n className={withBaseName(\"dateGrid\")}\n >\n {days.map((day) => {\n return (\n <CalendarDay\n key={formatDate(day.date, locale)}\n day={day.date}\n renderDayContents={renderDayContents}\n month={date}\n TooltipProps={TooltipProps}\n />\n );\n })}\n </div>\n </div>\n );\n },\n);\n"],"names":["makePrefixer","forwardRef","CalendarMonth","useWindow","useComponentCssInjection","calendarMonthCss","useCalendarContext","generateVisibleDays","jsx","clsx","CalendarDay","formatDate"],"mappings":";;;;;;;;;;;;;;;AAwBA,MAAM,YAAA,GAAeA,kBAAa,mBAAmB,CAAA,CAAA;AAE9C,MAAM,aAAgB,GAAAC,gBAAA;AAAA,EAC3B,SAASC,cAAc,CAAA,KAAA,EAAO,GAAK,EAAA;AACjC,IAAM,MAAA;AAAA,MACJ,SAAA;AAAA,MACA,IAAA;AAAA,MACA,iBAAA;AAAA,MACA,YAAA;AAAA,MACA,YAAA;AAAA,MACG,GAAA,IAAA;AAAA,KACD,GAAA,KAAA,CAAA;AAEJ,IAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,qBAAA;AAAA,MACR,GAAK,EAAAC,eAAA;AAAA,MACL,MAAQ,EAAA,YAAA;AAAA,KACT,CAAA,CAAA;AAED,IAAM,MAAA;AAAA,MACJ,KAAA,EAAO,EAAE,MAAO,EAAA;AAAA,MAChB,OAAA,EAAS,EAAE,cAAe,EAAA;AAAA,QACxBC,kCAAmB,EAAA,CAAA;AACvB,IAAM,MAAA,IAAA,GAAOC,yBAAoB,CAAA,IAAA,EAAM,MAAM,CAAA,CAAA;AAE7C,IAAM,MAAA,gBAAA,GAAmB,CAAC,KAA0B,KAAA;AAClD,MAAA,cAAA,CAAe,OAAO,IAAI,CAAA,CAAA;AAC1B,MAAe,YAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,YAAA,CAAA,KAAA,CAAA,CAAA;AAAA,KACjB,CAAA;AAEA,IAAA,uBACGC,cAAA,CAAA,KAAA,EAAA;AAAA,MACC,SAAW,EAAAC,SAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,MACzC,GAAA;AAAA,MACA,YAAc,EAAA,gBAAA;AAAA,MACb,GAAG,IAAA;AAAA,MAEJ,QAAC,kBAAAD,cAAA,CAAA,KAAA,EAAA;AAAA,QACC,aAAY,EAAA,kBAAA;AAAA,QACZ,SAAA,EAAW,aAAa,UAAU,CAAA;AAAA,QAEjC,QAAA,EAAA,IAAA,CAAK,GAAI,CAAA,CAAC,GAAQ,KAAA;AACjB,UAAA,uBACGA,cAAA,CAAAE,uBAAA,EAAA;AAAA,YAEC,KAAK,GAAI,CAAA,IAAA;AAAA,YACT,iBAAA;AAAA,YACA,KAAO,EAAA,IAAA;AAAA,YACP,YAAA;AAAA,WAAA,EAJKC,gBAAW,CAAA,GAAA,CAAI,IAAM,EAAA,MAAM,CAKlC,CAAA,CAAA;AAAA,SAEH,CAAA;AAAA,OACH,CAAA;AAAA,KACF,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
@@ -12,9 +12,9 @@ var window = require('@salt-ds/window');
12
12
  var CalendarWeekHeader$1 = require('./CalendarWeekHeader.css.js');
13
13
 
14
14
  const withBaseName = core.makePrefixer("saltCalendarWeekHeader");
15
- const CalendarWeekHeader = react.forwardRef(function CalendarWeekHeader2({ className, ...rest }, ref) {
16
- const weekdaysShort = utils.daysForLocale("narrow");
17
- const weekdaysLong = utils.daysForLocale("long");
15
+ const CalendarWeekHeader = react.forwardRef(function CalendarWeekHeader2({ className, locale, ...rest }, ref) {
16
+ const weekdaysShort = utils.daysForLocale("narrow", locale);
17
+ const weekdaysLong = utils.daysForLocale("long", locale);
18
18
  const targetWindow = window.useWindow();
19
19
  styles.useComponentCssInjection({
20
20
  testId: "salt-calendar",
@@ -1 +1 @@
1
- {"version":3,"file":"CalendarWeekHeader.js","sources":["../src/calendar/internal/CalendarWeekHeader.tsx"],"sourcesContent":["import { makePrefixer } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { type ComponentPropsWithRef, forwardRef } from \"react\";\nimport { daysForLocale } from \"./utils\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport calendarWeekHeaderCss from \"./CalendarWeekHeader.css\";\n\nexport type CalendarWeekHeaderProps = ComponentPropsWithRef<\"div\">;\n\nconst withBaseName = makePrefixer(\"saltCalendarWeekHeader\");\n\nexport const CalendarWeekHeader = forwardRef<\n HTMLDivElement,\n CalendarWeekHeaderProps\n>(function CalendarWeekHeader({ className, ...rest }, ref) {\n const weekdaysShort = daysForLocale(\"narrow\");\n const weekdaysLong = daysForLocale(\"long\");\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-calendar\",\n css: calendarWeekHeaderCss,\n window: targetWindow,\n });\n\n return (\n <div\n data-testid=\"CalendarWeekHeader\"\n className={clsx(withBaseName(), className)}\n ref={ref}\n {...rest}\n >\n {weekdaysShort.map((day, index) => (\n <small\n aria-hidden\n key={weekdaysLong[index]}\n className={withBaseName(\"dayOfWeek\")}\n >\n {day}\n </small>\n ))}\n </div>\n );\n});\n"],"names":["makePrefixer","forwardRef","CalendarWeekHeader","daysForLocale","useWindow","useComponentCssInjection","calendarWeekHeaderCss","jsx","clsx"],"mappings":";;;;;;;;;;;;;AAWA,MAAM,YAAA,GAAeA,kBAAa,wBAAwB,CAAA,CAAA;AAE7C,MAAA,kBAAA,GAAqBC,iBAGhC,SAASC,mBAAAA,CAAmB,EAAE,SAAc,EAAA,GAAA,IAAA,IAAQ,GAAK,EAAA;AACzD,EAAM,MAAA,aAAA,GAAgBC,oBAAc,QAAQ,CAAA,CAAA;AAC5C,EAAM,MAAA,YAAA,GAAeA,oBAAc,MAAM,CAAA,CAAA;AAEzC,EAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,eAAA;AAAA,IACR,GAAK,EAAAC,oBAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,uBACGC,cAAA,CAAA,KAAA,EAAA;AAAA,IACC,aAAY,EAAA,oBAAA;AAAA,IACZ,SAAW,EAAAC,SAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,IACzC,GAAA;AAAA,IACC,GAAG,IAAA;AAAA,IAEH,QAAc,EAAA,aAAA,CAAA,GAAA,CAAI,CAAC,GAAA,EAAK,0BACtBD,cAAA,CAAA,OAAA,EAAA;AAAA,MACC,aAAW,EAAA,IAAA;AAAA,MAEX,SAAA,EAAW,aAAa,WAAW,CAAA;AAAA,MAElC,QAAA,EAAA,GAAA;AAAA,KAHI,EAAA,YAAA,CAAa,MAIpB,CACD,CAAA;AAAA,GACH,CAAA,CAAA;AAEJ,CAAC;;;;"}
1
+ {"version":3,"file":"CalendarWeekHeader.js","sources":["../src/calendar/internal/CalendarWeekHeader.tsx"],"sourcesContent":["import { makePrefixer } from \"@salt-ds/core\";\nimport { clsx } from \"clsx\";\nimport { type ComponentPropsWithRef, forwardRef } from \"react\";\nimport { daysForLocale } from \"./utils\";\n\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport calendarWeekHeaderCss from \"./CalendarWeekHeader.css\";\n\nexport type CalendarWeekHeaderProps = ComponentPropsWithRef<\"div\"> & {\n locale: string;\n};\n\nconst withBaseName = makePrefixer(\"saltCalendarWeekHeader\");\n\nexport const CalendarWeekHeader = forwardRef<\n HTMLDivElement,\n CalendarWeekHeaderProps\n>(function CalendarWeekHeader({ className, locale, ...rest }, ref) {\n const weekdaysShort = daysForLocale(\"narrow\", locale);\n const weekdaysLong = daysForLocale(\"long\", locale);\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-calendar\",\n css: calendarWeekHeaderCss,\n window: targetWindow,\n });\n\n return (\n <div\n data-testid=\"CalendarWeekHeader\"\n className={clsx(withBaseName(), className)}\n ref={ref}\n {...rest}\n >\n {weekdaysShort.map((day, index) => (\n <small\n aria-hidden\n key={weekdaysLong[index]}\n className={withBaseName(\"dayOfWeek\")}\n >\n {day}\n </small>\n ))}\n </div>\n );\n});\n"],"names":["makePrefixer","forwardRef","CalendarWeekHeader","daysForLocale","useWindow","useComponentCssInjection","calendarWeekHeaderCss","jsx","clsx"],"mappings":";;;;;;;;;;;;;AAaA,MAAM,YAAA,GAAeA,kBAAa,wBAAwB,CAAA,CAAA;AAE7C,MAAA,kBAAA,GAAqBC,iBAGhC,SAASC,mBAAAA,CAAmB,EAAE,SAAW,EAAA,MAAA,EAAA,GAAW,IAAK,EAAA,EAAG,GAAK,EAAA;AACjE,EAAM,MAAA,aAAA,GAAgBC,mBAAc,CAAA,QAAA,EAAU,MAAM,CAAA,CAAA;AACpD,EAAM,MAAA,YAAA,GAAeA,mBAAc,CAAA,MAAA,EAAQ,MAAM,CAAA,CAAA;AAEjD,EAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,eAAA;AAAA,IACR,GAAK,EAAAC,oBAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,uBACGC,cAAA,CAAA,KAAA,EAAA;AAAA,IACC,aAAY,EAAA,oBAAA;AAAA,IACZ,SAAW,EAAAC,SAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,IACzC,GAAA;AAAA,IACC,GAAG,IAAA;AAAA,IAEH,QAAc,EAAA,aAAA,CAAA,GAAA,CAAI,CAAC,GAAA,EAAK,0BACtBD,cAAA,CAAA,OAAA,EAAA;AAAA,MACC,aAAW,EAAA,IAAA;AAAA,MAEX,SAAA,EAAW,aAAa,WAAW,CAAA;AAAA,MAElC,QAAA,EAAA,GAAA;AAAA,KAHI,EAAA,YAAA,CAAa,MAIpB,CACD,CAAA;AAAA,GACH,CAAA,CAAA;AAEJ,CAAC;;;;"}
@@ -3,10 +3,13 @@
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  var date = require('@internationalized/date');
6
+ var formatDate = require('../formatDate.js');
6
7
  var CalendarContext = require('./CalendarContext.js');
7
- var utils = require('./utils.js');
8
8
 
9
- function useFocusManagement({ date: date$1 }) {
9
+ function useFocusManagement({
10
+ date: date$1,
11
+ locale = formatDate.getCurrentLocale()
12
+ }) {
10
13
  const {
11
14
  helpers: { setFocusedDate }
12
15
  } = CalendarContext.useCalendarContext();
@@ -29,10 +32,10 @@ function useFocusManagement({ date: date$1 }) {
29
32
  newDate = date$1.add({ days: 1 });
30
33
  break;
31
34
  case "Home":
32
- newDate = date.startOfWeek(date$1, utils.getCurrentLocale());
35
+ newDate = date.startOfWeek(date$1, locale);
33
36
  break;
34
37
  case "End":
35
- newDate = date.endOfWeek(date$1, utils.getCurrentLocale());
38
+ newDate = date.endOfWeek(date$1, locale);
36
39
  break;
37
40
  case "PageUp":
38
41
  if (event.shiftKey) {
@@ -1 +1 @@
1
- {"version":3,"file":"useFocusManagement.js","sources":["../src/calendar/internal/useFocusManagement.ts"],"sourcesContent":["import {\n type DateValue,\n endOfWeek,\n startOfWeek,\n} from \"@internationalized/date\";\nimport type {\n FocusEventHandler,\n KeyboardEventHandler,\n MouseEventHandler,\n} from \"react\";\nimport { useCalendarContext } from \"./CalendarContext\";\nimport { getCurrentLocale } from \"./utils\";\n\nexport function useFocusManagement({ date }: { date: DateValue }) {\n const {\n helpers: { setFocusedDate },\n } = useCalendarContext();\n const handleClick: MouseEventHandler<HTMLButtonElement> = (event) => {\n setFocusedDate(event, date);\n };\n\n const handleKeyDown: KeyboardEventHandler<HTMLButtonElement> = (event) => {\n let newDate = date;\n switch (event.key) {\n case \"ArrowUp\":\n newDate = date.subtract({ weeks: 1 });\n break;\n case \"ArrowDown\":\n newDate = date.add({ weeks: 1 });\n break;\n case \"ArrowLeft\":\n newDate = date.subtract({ days: 1 });\n break;\n case \"ArrowRight\":\n newDate = date.add({ days: 1 });\n break;\n case \"Home\":\n newDate = startOfWeek(date, getCurrentLocale());\n break;\n case \"End\":\n // @ts-ignore TODO bug in @internationalized/date\n newDate = endOfWeek(date, getCurrentLocale());\n break;\n case \"PageUp\":\n if (event.shiftKey) {\n newDate = date.subtract({ years: 1 });\n } else {\n newDate = date.subtract({ months: 1 });\n }\n break;\n case \"PageDown\":\n if (event.shiftKey) {\n newDate = date.add({ years: 1 });\n } else {\n newDate = date.add({ months: 1 });\n }\n break;\n default:\n }\n if (newDate.compare(date) !== 0) {\n event.preventDefault();\n }\n setFocusedDate(event, newDate);\n };\n\n const handleFocus: FocusEventHandler<HTMLButtonElement> = (event) => {\n setFocusedDate(event, date);\n };\n\n return {\n handleClick,\n handleKeyDown,\n handleFocus,\n };\n}\n"],"names":["date","useCalendarContext","startOfWeek","getCurrentLocale","endOfWeek"],"mappings":";;;;;;;;AAagB,SAAA,kBAAA,CAAmB,QAAEA,MAAA,EAA6B,EAAA;AAChE,EAAM,MAAA;AAAA,IACJ,OAAA,EAAS,EAAE,cAAe,EAAA;AAAA,MACxBC,kCAAmB,EAAA,CAAA;AACvB,EAAM,MAAA,WAAA,GAAoD,CAAC,KAAU,KAAA;AACnE,IAAA,cAAA,CAAe,OAAOD,MAAI,CAAA,CAAA;AAAA,GAC5B,CAAA;AAEA,EAAM,MAAA,aAAA,GAAyD,CAAC,KAAU,KAAA;AACxE,IAAA,IAAI,OAAU,GAAAA,MAAA,CAAA;AACd,IAAA,QAAQ,KAAM,CAAA,GAAA;AAAA,MACP,KAAA,SAAA;AACH,QAAA,OAAA,GAAUA,MAAK,CAAA,QAAA,CAAS,EAAE,KAAA,EAAO,GAAG,CAAA,CAAA;AACpC,QAAA,MAAA;AAAA,MACG,KAAA,WAAA;AACH,QAAA,OAAA,GAAUA,MAAK,CAAA,GAAA,CAAI,EAAE,KAAA,EAAO,GAAG,CAAA,CAAA;AAC/B,QAAA,MAAA;AAAA,MACG,KAAA,WAAA;AACH,QAAA,OAAA,GAAUA,MAAK,CAAA,QAAA,CAAS,EAAE,IAAA,EAAM,GAAG,CAAA,CAAA;AACnC,QAAA,MAAA;AAAA,MACG,KAAA,YAAA;AACH,QAAA,OAAA,GAAUA,MAAK,CAAA,GAAA,CAAI,EAAE,IAAA,EAAM,GAAG,CAAA,CAAA;AAC9B,QAAA,MAAA;AAAA,MACG,KAAA,MAAA;AACH,QAAU,OAAA,GAAAE,gBAAA,CAAYF,MAAM,EAAAG,sBAAA,EAAkB,CAAA,CAAA;AAC9C,QAAA,MAAA;AAAA,MACG,KAAA,KAAA;AAEH,QAAU,OAAA,GAAAC,cAAA,CAAUJ,MAAM,EAAAG,sBAAA,EAAkB,CAAA,CAAA;AAC5C,QAAA,MAAA;AAAA,MACG,KAAA,QAAA;AACH,QAAA,IAAI,MAAM,QAAU,EAAA;AAClB,UAAA,OAAA,GAAUH,MAAK,CAAA,QAAA,CAAS,EAAE,KAAA,EAAO,GAAG,CAAA,CAAA;AAAA,SAC/B,MAAA;AACL,UAAA,OAAA,GAAUA,MAAK,CAAA,QAAA,CAAS,EAAE,MAAA,EAAQ,GAAG,CAAA,CAAA;AAAA,SACvC;AACA,QAAA,MAAA;AAAA,MACG,KAAA,UAAA;AACH,QAAA,IAAI,MAAM,QAAU,EAAA;AAClB,UAAA,OAAA,GAAUA,MAAK,CAAA,GAAA,CAAI,EAAE,KAAA,EAAO,GAAG,CAAA,CAAA;AAAA,SAC1B,MAAA;AACL,UAAA,OAAA,GAAUA,MAAK,CAAA,GAAA,CAAI,EAAE,MAAA,EAAQ,GAAG,CAAA,CAAA;AAAA,SAClC;AACA,QAAA,MAAA;AAAA,KAAA;AAGJ,IAAA,IAAI,OAAQ,CAAA,OAAA,CAAQA,MAAI,CAAA,KAAM,CAAG,EAAA;AAC/B,MAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AAAA,KACvB;AACA,IAAA,cAAA,CAAe,OAAO,OAAO,CAAA,CAAA;AAAA,GAC/B,CAAA;AAEA,EAAM,MAAA,WAAA,GAAoD,CAAC,KAAU,KAAA;AACnE,IAAA,cAAA,CAAe,OAAOA,MAAI,CAAA,CAAA;AAAA,GAC5B,CAAA;AAEA,EAAO,OAAA;AAAA,IACL,WAAA;AAAA,IACA,aAAA;AAAA,IACA,WAAA;AAAA,GACF,CAAA;AACF;;;;"}
1
+ {"version":3,"file":"useFocusManagement.js","sources":["../src/calendar/internal/useFocusManagement.ts"],"sourcesContent":["import {\n type DateValue,\n endOfWeek,\n startOfWeek,\n} from \"@internationalized/date\";\nimport type {\n FocusEventHandler,\n KeyboardEventHandler,\n MouseEventHandler,\n} from \"react\";\nimport { getCurrentLocale } from \"../formatDate\";\nimport { useCalendarContext } from \"./CalendarContext\";\n\nexport function useFocusManagement({\n date,\n locale = getCurrentLocale(),\n}: {\n date: DateValue;\n locale: string;\n}) {\n const {\n helpers: { setFocusedDate },\n } = useCalendarContext();\n const handleClick: MouseEventHandler<HTMLButtonElement> = (event) => {\n setFocusedDate(event, date);\n };\n\n const handleKeyDown: KeyboardEventHandler<HTMLButtonElement> = (event) => {\n let newDate = date;\n switch (event.key) {\n case \"ArrowUp\":\n newDate = date.subtract({ weeks: 1 });\n break;\n case \"ArrowDown\":\n newDate = date.add({ weeks: 1 });\n break;\n case \"ArrowLeft\":\n newDate = date.subtract({ days: 1 });\n break;\n case \"ArrowRight\":\n newDate = date.add({ days: 1 });\n break;\n case \"Home\":\n newDate = startOfWeek(date, locale);\n break;\n case \"End\":\n // @ts-ignore TODO bug in @internationalized/date\n newDate = endOfWeek(date, locale);\n break;\n case \"PageUp\":\n if (event.shiftKey) {\n newDate = date.subtract({ years: 1 });\n } else {\n newDate = date.subtract({ months: 1 });\n }\n break;\n case \"PageDown\":\n if (event.shiftKey) {\n newDate = date.add({ years: 1 });\n } else {\n newDate = date.add({ months: 1 });\n }\n break;\n default:\n }\n if (newDate.compare(date) !== 0) {\n event.preventDefault();\n }\n setFocusedDate(event, newDate);\n };\n\n const handleFocus: FocusEventHandler<HTMLButtonElement> = (event) => {\n setFocusedDate(event, date);\n };\n\n return {\n handleClick,\n handleKeyDown,\n handleFocus,\n };\n}\n"],"names":["date","getCurrentLocale","useCalendarContext","startOfWeek","endOfWeek"],"mappings":";;;;;;;;AAaO,SAAS,kBAAmB,CAAA;AAAA,QACjCA,MAAA;AAAA,EACA,SAASC,2BAAiB,EAAA;AAC5B,CAGG,EAAA;AACD,EAAM,MAAA;AAAA,IACJ,OAAA,EAAS,EAAE,cAAe,EAAA;AAAA,MACxBC,kCAAmB,EAAA,CAAA;AACvB,EAAM,MAAA,WAAA,GAAoD,CAAC,KAAU,KAAA;AACnE,IAAA,cAAA,CAAe,OAAOF,MAAI,CAAA,CAAA;AAAA,GAC5B,CAAA;AAEA,EAAM,MAAA,aAAA,GAAyD,CAAC,KAAU,KAAA;AACxE,IAAA,IAAI,OAAU,GAAAA,MAAA,CAAA;AACd,IAAA,QAAQ,KAAM,CAAA,GAAA;AAAA,MACP,KAAA,SAAA;AACH,QAAA,OAAA,GAAUA,MAAK,CAAA,QAAA,CAAS,EAAE,KAAA,EAAO,GAAG,CAAA,CAAA;AACpC,QAAA,MAAA;AAAA,MACG,KAAA,WAAA;AACH,QAAA,OAAA,GAAUA,MAAK,CAAA,GAAA,CAAI,EAAE,KAAA,EAAO,GAAG,CAAA,CAAA;AAC/B,QAAA,MAAA;AAAA,MACG,KAAA,WAAA;AACH,QAAA,OAAA,GAAUA,MAAK,CAAA,QAAA,CAAS,EAAE,IAAA,EAAM,GAAG,CAAA,CAAA;AACnC,QAAA,MAAA;AAAA,MACG,KAAA,YAAA;AACH,QAAA,OAAA,GAAUA,MAAK,CAAA,GAAA,CAAI,EAAE,IAAA,EAAM,GAAG,CAAA,CAAA;AAC9B,QAAA,MAAA;AAAA,MACG,KAAA,MAAA;AACH,QAAU,OAAA,GAAAG,gBAAA,CAAYH,QAAM,MAAM,CAAA,CAAA;AAClC,QAAA,MAAA;AAAA,MACG,KAAA,KAAA;AAEH,QAAU,OAAA,GAAAI,cAAA,CAAUJ,QAAM,MAAM,CAAA,CAAA;AAChC,QAAA,MAAA;AAAA,MACG,KAAA,QAAA;AACH,QAAA,IAAI,MAAM,QAAU,EAAA;AAClB,UAAA,OAAA,GAAUA,MAAK,CAAA,QAAA,CAAS,EAAE,KAAA,EAAO,GAAG,CAAA,CAAA;AAAA,SAC/B,MAAA;AACL,UAAA,OAAA,GAAUA,MAAK,CAAA,QAAA,CAAS,EAAE,MAAA,EAAQ,GAAG,CAAA,CAAA;AAAA,SACvC;AACA,QAAA,MAAA;AAAA,MACG,KAAA,UAAA;AACH,QAAA,IAAI,MAAM,QAAU,EAAA;AAClB,UAAA,OAAA,GAAUA,MAAK,CAAA,GAAA,CAAI,EAAE,KAAA,EAAO,GAAG,CAAA,CAAA;AAAA,SAC1B,MAAA;AACL,UAAA,OAAA,GAAUA,MAAK,CAAA,GAAA,CAAI,EAAE,MAAA,EAAQ,GAAG,CAAA,CAAA;AAAA,SAClC;AACA,QAAA,MAAA;AAAA,KAAA;AAGJ,IAAA,IAAI,OAAQ,CAAA,OAAA,CAAQA,MAAI,CAAA,KAAM,CAAG,EAAA;AAC/B,MAAA,KAAA,CAAM,cAAe,EAAA,CAAA;AAAA,KACvB;AACA,IAAA,cAAA,CAAe,OAAO,OAAO,CAAA,CAAA;AAAA,GAC/B,CAAA;AAEA,EAAM,MAAA,WAAA,GAAoD,CAAC,KAAU,KAAA;AACnE,IAAA,cAAA,CAAe,OAAOA,MAAI,CAAA,CAAA;AAAA,GAC5B,CAAA;AAEA,EAAO,OAAA;AAAA,IACL,WAAA;AAAA,IACA,aAAA;AAAA,IACA,WAAA;AAAA,GACF,CAAA;AACF;;;;"}
@@ -3,34 +3,31 @@
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  var date = require('@internationalized/date');
6
+ var formatDate$1 = require('../formatDate.js');
6
7
 
7
- const localTimezone = date.getLocalTimeZone();
8
- function getCurrentLocale() {
9
- return navigator.languages[0];
8
+ function formatDate(date$1, locale, options) {
9
+ const timeLocale = locale || formatDate$1.getCurrentLocale();
10
+ const timeZone = (options == null ? void 0 : options.timeZone) || date.getLocalTimeZone();
11
+ const formatter = new date.DateFormatter(timeLocale, options);
12
+ return formatter.format(date$1.toDate(timeZone));
10
13
  }
11
- function getDateFormatter(options) {
12
- return new date.DateFormatter(getCurrentLocale(), options);
13
- }
14
- function formatDate(date, options) {
15
- const formatter = getDateFormatter(options);
16
- return formatter.format(date.toDate(localTimezone));
17
- }
18
- function getCalender() {
19
- const calendarIdentifier = getDateFormatter().resolvedOptions().calendar;
14
+ function getCalendar(locale) {
15
+ const calendarIdentifier = new date.DateFormatter(locale).resolvedOptions().calendar;
20
16
  return date.createCalendar(calendarIdentifier);
21
17
  }
22
- function daysForLocale(weekday = "long") {
18
+ function daysForLocale(weekday, locale) {
23
19
  return [...Array(7).keys()].map(
24
20
  (day) => formatDate(
25
- date.startOfWeek(date.today(date.getLocalTimeZone()), getCurrentLocale()).add({
21
+ date.startOfWeek(date.today(date.getLocalTimeZone()), locale).add({
26
22
  days: day
27
23
  }),
28
- { weekday }
24
+ locale,
25
+ { weekday: weekday || "long" }
29
26
  )
30
27
  );
31
28
  }
32
- function monthsForLocale(currentYear) {
33
- const calendar = getCalender();
29
+ function monthsForLocale(currentYear, locale) {
30
+ const calendar = getCalendar(locale);
34
31
  return [...Array(calendar.getMonthsInYear(currentYear)).keys()].map(
35
32
  (month) => date.startOfYear(currentYear).add({ months: month })
36
33
  );
@@ -42,10 +39,9 @@ function mapDate(currentDate, currentMonth) {
42
39
  isCurrentMonth: date.isSameMonth(currentDate, currentMonth)
43
40
  };
44
41
  }
45
- function generateVisibleDays(currentMonth) {
42
+ function generateVisibleDays(currentMonth, locale) {
46
43
  const totalDays = 6 * 7;
47
- const currentLocale = getCurrentLocale();
48
- const startDate = date.startOfWeek(date.startOfMonth(currentMonth), currentLocale);
44
+ const startDate = date.startOfWeek(date.startOfMonth(currentMonth), locale);
49
45
  return [...Array(totalDays).keys()].map((dayDelta) => {
50
46
  const day = startDate.add({ days: dayDelta });
51
47
  return mapDate(day, currentMonth);
@@ -54,13 +50,22 @@ function generateVisibleDays(currentMonth) {
54
50
  function monthDiff(a, b) {
55
51
  return b.month - a.month + 12 * (b.year - a.year);
56
52
  }
53
+ function generateDatesForMonth(date$1) {
54
+ const calendarDate = date.toCalendarDate(date$1);
55
+ const startDate = date.startOfMonth(calendarDate);
56
+ const endDate = date.endOfMonth(calendarDate);
57
+ const dates = [];
58
+ for (let currentDate = startDate; currentDate.compare(endDate) <= 0; currentDate = currentDate.add({ days: 1 })) {
59
+ dates.push(currentDate);
60
+ }
61
+ return dates;
62
+ }
57
63
 
58
64
  exports.daysForLocale = daysForLocale;
59
65
  exports.formatDate = formatDate;
66
+ exports.generateDatesForMonth = generateDatesForMonth;
60
67
  exports.generateVisibleDays = generateVisibleDays;
61
- exports.getCalender = getCalender;
62
- exports.getCurrentLocale = getCurrentLocale;
63
- exports.getDateFormatter = getDateFormatter;
68
+ exports.getCalendar = getCalendar;
64
69
  exports.monthDiff = monthDiff;
65
70
  exports.monthsForLocale = monthsForLocale;
66
71
  //# sourceMappingURL=utils.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"utils.js","sources":["../src/calendar/internal/utils.ts"],"sourcesContent":["import {\n DateFormatter,\n type DateValue,\n createCalendar,\n getLocalTimeZone,\n isSameMonth,\n startOfMonth,\n startOfWeek,\n startOfYear,\n today,\n} from \"@internationalized/date\";\n\nconst localTimezone = getLocalTimeZone();\n\nexport function getCurrentLocale() {\n return navigator.languages[0];\n}\n\nexport function getDateFormatter(options?: Intl.DateTimeFormatOptions) {\n return new DateFormatter(getCurrentLocale(), options);\n}\n\nexport function formatDate(\n date: DateValue,\n options?: Intl.DateTimeFormatOptions,\n) {\n const formatter = getDateFormatter(options);\n return formatter.format(date.toDate(localTimezone));\n}\n\nexport function getCalender() {\n const calendarIdentifier = getDateFormatter().resolvedOptions().calendar;\n return createCalendar(calendarIdentifier);\n}\n\ntype WeekdayFormat = Intl.DateTimeFormatOptions[\"weekday\"];\n\nexport function daysForLocale(weekday: WeekdayFormat = \"long\") {\n return [...Array(7).keys()].map((day) =>\n formatDate(\n startOfWeek(today(getLocalTimeZone()), getCurrentLocale()).add({\n days: day,\n }),\n { weekday },\n ),\n );\n}\n\nexport function monthsForLocale(currentYear: DateValue) {\n const calendar = getCalender();\n return [...Array(calendar.getMonthsInYear(currentYear)).keys()].map((month) =>\n startOfYear(currentYear).add({ months: month }),\n );\n}\n\nfunction mapDate(currentDate: DateValue, currentMonth: DateValue) {\n return {\n date: currentDate,\n dateOfMonth: currentDate.month,\n isCurrentMonth: isSameMonth(currentDate, currentMonth),\n };\n}\n\nexport function generateVisibleDays(currentMonth: DateValue) {\n const totalDays = 6 * 7;\n const currentLocale = getCurrentLocale();\n const startDate = startOfWeek(startOfMonth(currentMonth), currentLocale);\n\n return [...Array(totalDays).keys()].map((dayDelta) => {\n const day = startDate.add({ days: dayDelta });\n return mapDate(day, currentMonth);\n });\n}\n\nexport function monthDiff(a: DateValue, b: DateValue) {\n return b.month - a.month + 12 * (b.year - a.year);\n}\n"],"names":["getLocalTimeZone","DateFormatter","createCalendar","startOfWeek","today","startOfYear","isSameMonth","startOfMonth"],"mappings":";;;;;;AAYA,MAAM,gBAAgBA,qBAAiB,EAAA,CAAA;AAEhC,SAAS,gBAAmB,GAAA;AACjC,EAAA,OAAO,UAAU,SAAU,CAAA,CAAA,CAAA,CAAA;AAC7B,CAAA;AAEO,SAAS,iBAAiB,OAAsC,EAAA;AACrE,EAAA,OAAO,IAAIC,kBAAA,CAAc,gBAAiB,EAAA,EAAG,OAAO,CAAA,CAAA;AACtD,CAAA;AAEgB,SAAA,UAAA,CACd,MACA,OACA,EAAA;AACA,EAAM,MAAA,SAAA,GAAY,iBAAiB,OAAO,CAAA,CAAA;AAC1C,EAAA,OAAO,SAAU,CAAA,MAAA,CAAO,IAAK,CAAA,MAAA,CAAO,aAAa,CAAC,CAAA,CAAA;AACpD,CAAA;AAEO,SAAS,WAAc,GAAA;AAC5B,EAAA,MAAM,kBAAqB,GAAA,gBAAA,EAAmB,CAAA,eAAA,EAAkB,CAAA,QAAA,CAAA;AAChE,EAAA,OAAOC,oBAAe,kBAAkB,CAAA,CAAA;AAC1C,CAAA;AAIgB,SAAA,aAAA,CAAc,UAAyB,MAAQ,EAAA;AAC7D,EAAA,OAAO,CAAC,GAAG,KAAA,CAAM,CAAC,CAAE,CAAA,IAAA,EAAM,CAAE,CAAA,GAAA;AAAA,IAAI,CAAC,GAC/B,KAAA,UAAA;AAAA,MACEC,gBAAA,CAAYC,WAAMJ,qBAAiB,EAAC,GAAG,gBAAiB,EAAC,EAAE,GAAI,CAAA;AAAA,QAC7D,IAAM,EAAA,GAAA;AAAA,OACP,CAAA;AAAA,MACD,EAAE,OAAQ,EAAA;AAAA,KACZ;AAAA,GACF,CAAA;AACF,CAAA;AAEO,SAAS,gBAAgB,WAAwB,EAAA;AACtD,EAAA,MAAM,WAAW,WAAY,EAAA,CAAA;AAC7B,EAAO,OAAA,CAAC,GAAG,KAAA,CAAM,QAAS,CAAA,eAAA,CAAgB,WAAW,CAAC,CAAA,CAAE,IAAK,EAAC,CAAE,CAAA,GAAA;AAAA,IAAI,CAAC,UACnEK,gBAAY,CAAA,WAAW,EAAE,GAAI,CAAA,EAAE,MAAQ,EAAA,KAAA,EAAO,CAAA;AAAA,GAChD,CAAA;AACF,CAAA;AAEA,SAAS,OAAA,CAAQ,aAAwB,YAAyB,EAAA;AAChE,EAAO,OAAA;AAAA,IACL,IAAM,EAAA,WAAA;AAAA,IACN,aAAa,WAAY,CAAA,KAAA;AAAA,IACzB,cAAA,EAAgBC,gBAAY,CAAA,WAAA,EAAa,YAAY,CAAA;AAAA,GACvD,CAAA;AACF,CAAA;AAEO,SAAS,oBAAoB,YAAyB,EAAA;AAC3D,EAAA,MAAM,YAAY,CAAI,GAAA,CAAA,CAAA;AACtB,EAAA,MAAM,gBAAgB,gBAAiB,EAAA,CAAA;AACvC,EAAA,MAAM,SAAY,GAAAH,gBAAA,CAAYI,iBAAa,CAAA,YAAY,GAAG,aAAa,CAAA,CAAA;AAEvE,EAAO,OAAA,CAAC,GAAG,KAAA,CAAM,SAAS,CAAA,CAAE,MAAM,CAAA,CAAE,GAAI,CAAA,CAAC,QAAa,KAAA;AACpD,IAAA,MAAM,MAAM,SAAU,CAAA,GAAA,CAAI,EAAE,IAAA,EAAM,UAAU,CAAA,CAAA;AAC5C,IAAO,OAAA,OAAA,CAAQ,KAAK,YAAY,CAAA,CAAA;AAAA,GACjC,CAAA,CAAA;AACH,CAAA;AAEgB,SAAA,SAAA,CAAU,GAAc,CAAc,EAAA;AACpD,EAAA,OAAO,EAAE,KAAQ,GAAA,CAAA,CAAE,QAAQ,EAAM,IAAA,CAAA,CAAE,OAAO,CAAE,CAAA,IAAA,CAAA,CAAA;AAC9C;;;;;;;;;;;"}
1
+ {"version":3,"file":"utils.js","sources":["../src/calendar/internal/utils.ts"],"sourcesContent":["import {\n type CalendarDate,\n DateFormatter,\n type DateValue,\n createCalendar,\n endOfMonth,\n getLocalTimeZone,\n isSameMonth,\n startOfMonth,\n startOfWeek,\n startOfYear,\n toCalendarDate,\n today,\n} from \"@internationalized/date\";\nimport { getCurrentLocale } from \"../formatDate\";\n\nexport function formatDate(\n date: DateValue,\n locale: string,\n options?: Intl.DateTimeFormatOptions,\n) {\n const timeLocale = locale || getCurrentLocale();\n const timeZone = options?.timeZone || getLocalTimeZone();\n const formatter = new DateFormatter(timeLocale, options);\n return formatter.format(date.toDate(timeZone));\n}\n\nexport function getCalendar(locale: string) {\n const calendarIdentifier = new DateFormatter(locale).resolvedOptions()\n .calendar;\n return createCalendar(calendarIdentifier);\n}\n\ntype WeekdayFormat = Intl.DateTimeFormatOptions[\"weekday\"];\n\nexport function daysForLocale(weekday: WeekdayFormat, locale: string) {\n return [...Array(7).keys()].map((day) =>\n formatDate(\n startOfWeek(today(getLocalTimeZone()), locale).add({\n days: day,\n }),\n locale,\n { weekday: weekday || \"long\" },\n ),\n );\n}\n\nexport function monthsForLocale(currentYear: DateValue, locale: string) {\n const calendar = getCalendar(locale);\n return [...Array(calendar.getMonthsInYear(currentYear)).keys()].map((month) =>\n startOfYear(currentYear).add({ months: month }),\n );\n}\n\nfunction mapDate(currentDate: DateValue, currentMonth: DateValue) {\n return {\n date: currentDate,\n dateOfMonth: currentDate.month,\n isCurrentMonth: isSameMonth(currentDate, currentMonth),\n };\n}\n\nexport function generateVisibleDays(currentMonth: DateValue, locale: string) {\n const totalDays = 6 * 7;\n const startDate = startOfWeek(startOfMonth(currentMonth), locale);\n\n return [...Array(totalDays).keys()].map((dayDelta) => {\n const day = startDate.add({ days: dayDelta });\n return mapDate(day, currentMonth);\n });\n}\n\nexport function monthDiff(a: DateValue, b: DateValue) {\n return b.month - a.month + 12 * (b.year - a.year);\n}\n\nexport function generateDatesForMonth(date: DateValue): CalendarDate[] {\n const calendarDate = toCalendarDate(date);\n const startDate = startOfMonth(calendarDate);\n const endDate = endOfMonth(calendarDate);\n const dates = [];\n for (\n let currentDate = startDate;\n currentDate.compare(endDate) <= 0;\n currentDate = currentDate.add({ days: 1 })\n ) {\n dates.push(currentDate);\n }\n return dates;\n}\n"],"names":["date","getCurrentLocale","getLocalTimeZone","DateFormatter","createCalendar","startOfWeek","today","startOfYear","isSameMonth","startOfMonth","toCalendarDate","endOfMonth"],"mappings":"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"}
@@ -5,7 +5,9 @@ Object.defineProperty(exports, '__esModule', { value: true });
5
5
  var date = require('@internationalized/date');
6
6
  var core = require('@salt-ds/core');
7
7
  var react = require('react');
8
- var useSelection = require('./useSelection.js');
8
+ var formatDate = require('./formatDate.js');
9
+ var utils = require('./internal/utils.js');
10
+ var useCalendarSelection = require('./useCalendarSelection.js');
9
11
 
10
12
  const defaultIsDayUnselectable = () => false;
11
13
  const defaultIsDayHighlighted = () => false;
@@ -15,19 +17,21 @@ function useCalendar(props) {
15
17
  selectedDate,
16
18
  defaultSelectedDate,
17
19
  visibleMonth: visibleMonthProp,
18
- hideYearDropdown,
19
20
  hideOutOfRangeDates,
20
- defaultVisibleMonth = date.today(date.getLocalTimeZone()),
21
+ timeZone = date.getLocalTimeZone(),
22
+ locale = formatDate.getCurrentLocale(),
23
+ defaultVisibleMonth = date.today(timeZone),
21
24
  onSelectedDateChange,
22
25
  onVisibleMonthChange,
23
26
  isDayUnselectable = defaultIsDayUnselectable,
24
27
  isDayHighlighted = defaultIsDayHighlighted,
25
28
  isDayDisabled = defaultIsDayDisabled,
26
- minDate = hideYearDropdown ? date.startOfYear(date.today(date.getLocalTimeZone())) : void 0,
27
- maxDate = hideYearDropdown ? date.endOfYear(date.today(date.getLocalTimeZone())) : void 0,
29
+ minDate,
30
+ maxDate,
28
31
  selectionVariant,
29
32
  onHoveredDateChange,
30
- hoveredDate
33
+ hoveredDate,
34
+ select
31
35
  } = props;
32
36
  const [visibleMonth, setVisibleMonthState] = core.useControlled({
33
37
  controlled: visibleMonthProp ? date.startOfMonth(visibleMonthProp) : void 0,
@@ -37,60 +41,77 @@ function useCalendar(props) {
37
41
  });
38
42
  const isOutsideAllowedDates = react.useCallback(
39
43
  (date) => {
40
- return minDate != null && date.compare(minDate) < 0 || maxDate != null && date.compare(maxDate) > 0;
44
+ return minDate && date.compare(minDate) < 0 || maxDate && date.compare(maxDate) > 0;
41
45
  },
42
46
  [maxDate, minDate]
43
47
  );
44
- const isOutsideAllowedMonths = (date$1) => {
45
- return minDate != null && date.endOfMonth(date$1).compare(minDate) < 0 || maxDate != null && date.startOfMonth(date$1).compare(maxDate) > 0;
46
- };
47
- const isOutsideAllowedYears = (date$1) => {
48
- return minDate != null && date.endOfYear(date$1).compare(minDate) < 0 || maxDate != null && date.startOfYear(date$1).compare(maxDate) > 0;
49
- };
48
+ const isOutsideAllowedMonths = react.useCallback(
49
+ (date$1) => {
50
+ return minDate && date.endOfMonth(date$1).compare(minDate) < 0 || maxDate && date.startOfMonth(date$1).compare(maxDate) > 0;
51
+ },
52
+ [minDate, maxDate]
53
+ );
54
+ const isOutsideAllowedYears = react.useCallback(
55
+ (date$1) => {
56
+ return minDate && date.endOfYear(date$1).compare(minDate) < 0 || maxDate && date.startOfYear(date$1).compare(maxDate) > 0;
57
+ },
58
+ [minDate, maxDate]
59
+ );
50
60
  const isDaySelectable = react.useCallback(
51
61
  (date) => !(date && (isDayUnselectable(date) || isDayDisabled(date) || isOutsideAllowedDates(date))),
52
62
  [isDayUnselectable, isDayDisabled, isOutsideAllowedDates]
53
63
  );
54
- const selectionManager = useSelection.useSelectionCalendar({
64
+ const selectionManager = useCalendarSelection.useCalendarSelection({
55
65
  defaultSelectedDate,
56
66
  selectedDate,
57
67
  onSelectedDateChange,
58
- startDateOffset: props.selectionVariant === "offset" ? props.startDateOffset : (date) => date,
59
- endDateOffset: props.selectionVariant === "offset" ? props.endDateOffset : (date) => date,
68
+ startDateOffset: props.selectionVariant === "offset" ? props.startDateOffset : void 0,
69
+ endDateOffset: props.selectionVariant === "offset" ? props.endDateOffset : void 0,
60
70
  isDaySelectable,
61
71
  selectionVariant,
62
72
  onHoveredDateChange,
63
- hoveredDate
73
+ hoveredDate,
74
+ select
64
75
  });
65
76
  const [calendarFocused, setCalendarFocused] = react.useState(false);
66
- const isInVisibleMonth = (date$1) => date$1 != null && date.isSameMonth(date$1, visibleMonth);
67
- const getInitialFocusedDate = () => {
77
+ const isInVisibleMonth = react.useCallback(
78
+ (date$1) => date$1 != null && date.isSameMonth(date$1, visibleMonth),
79
+ [visibleMonth]
80
+ );
81
+ const getInitialFocusedDate = react.useCallback(() => {
68
82
  const selectedDate2 = selectionManager.state.selectedDate;
69
- if ((selectionVariant === "range" || selectionVariant === "offset") && useSelection.isRangeOrOffsetSelectionWithStartDate(selectedDate2)) {
83
+ if ((selectionVariant === "range" || selectionVariant === "offset") && useCalendarSelection.isDateRangeSelection(selectedDate2)) {
70
84
  if (isInVisibleMonth(selectedDate2 == null ? void 0 : selectedDate2.startDate)) {
71
85
  return selectedDate2.startDate;
72
86
  }
73
87
  if (isInVisibleMonth(selectedDate2 == null ? void 0 : selectedDate2.endDate)) {
74
88
  return selectedDate2.endDate;
75
89
  }
76
- if ((selectedDate2 == null ? void 0 : selectedDate2.startDate) && (selectedDate2 == null ? void 0 : selectedDate2.endDate) && visibleMonth.compare(selectedDate2.startDate) < 0 && visibleMonth.compare(selectedDate2.endDate) > 0) {
77
- return date.startOfMonth(visibleMonth);
78
- }
79
- }
80
- if (selectionVariant === "multiselect" && Array.isArray(selectedDate2)) {
90
+ } else if (selectionVariant === "multiselect" && Array.isArray(selectedDate2)) {
81
91
  const selectionInMonth = selectedDate2.filter((day) => isInVisibleMonth(day)).sort((a, b) => a.compare(b));
82
92
  if (selectionInMonth.length > 0) {
83
93
  return selectionInMonth[0];
84
94
  }
85
- }
86
- if (selectionVariant === "default" && !useSelection.isRangeOrOffsetSelectionWithStartDate(selectedDate2) && !Array.isArray(selectedDate2) && isInVisibleMonth(selectedDate2)) {
95
+ } else if (selectionVariant === "single" && !useCalendarSelection.isDateRangeSelection(selectedDate2) && !Array.isArray(selectedDate2) && isInVisibleMonth(selectedDate2)) {
87
96
  return selectedDate2;
88
97
  }
89
- if (isInVisibleMonth(date.today(date.getLocalTimeZone()))) {
90
- return date.today(date.getLocalTimeZone());
98
+ if (isDaySelectable(date.today(timeZone)) && isInVisibleMonth(date.today(timeZone))) {
99
+ return date.today(timeZone);
100
+ }
101
+ const firstSelectableDate = utils.generateDatesForMonth(visibleMonth).find(
102
+ (visibleDay) => isDaySelectable(visibleDay)
103
+ );
104
+ if (firstSelectableDate) {
105
+ return firstSelectableDate;
91
106
  }
92
- return date.startOfMonth(visibleMonth);
93
- };
107
+ return null;
108
+ }, [
109
+ isInVisibleMonth,
110
+ selectionVariant,
111
+ selectionManager.state.selectedDate,
112
+ timeZone,
113
+ visibleMonth
114
+ ]);
94
115
  const [focusedDate, setFocusedDateState] = react.useState(
95
116
  getInitialFocusedDate
96
117
  );
@@ -109,11 +130,11 @@ function useCalendar(props) {
109
130
  setVisibleMonthState(newVisibleMonth);
110
131
  onVisibleMonthChange == null ? void 0 : onVisibleMonthChange(event, newVisibleMonth);
111
132
  },
112
- [onVisibleMonthChange, setVisibleMonthState]
133
+ [onVisibleMonthChange]
113
134
  );
114
135
  const setFocusedDate = react.useCallback(
115
136
  (event, date$1) => {
116
- if (date.isSameDay(date$1, focusedDate) || isOutsideAllowedDates(date$1))
137
+ if (!focusedDate || date.isSameDay(date$1, focusedDate) || isOutsideAllowedDates(date$1))
117
138
  return;
118
139
  setFocusedDateState(date$1);
119
140
  const shouldTransition = !isDayVisible(date$1) && isDaySelectable(date$1) && !isOutsideAllowedDates(date$1);
@@ -130,12 +151,42 @@ function useCalendar(props) {
130
151
  ]
131
152
  );
132
153
  react.useEffect(() => {
133
- if (!isDayVisible(focusedDate)) {
134
- setFocusedDateState(getInitialFocusedDate());
154
+ if (visibleMonth && focusedDate && !isDayVisible(focusedDate)) {
155
+ const focusableDate = getInitialFocusedDate();
156
+ if (focusableDate) {
157
+ setFocusedDateState(focusableDate);
158
+ }
135
159
  }
136
- }, [isDayVisible, focusedDate, visibleMonth]);
137
- return {
138
- state: {
160
+ }, [isDayVisible, focusedDate, getInitialFocusedDate, visibleMonth]);
161
+ return react.useMemo(
162
+ () => ({
163
+ state: {
164
+ visibleMonth,
165
+ focusedDate,
166
+ minDate,
167
+ maxDate,
168
+ selectionVariant,
169
+ hideOutOfRangeDates,
170
+ calendarFocused,
171
+ timeZone,
172
+ locale,
173
+ ...selectionManager.state
174
+ },
175
+ helpers: {
176
+ setVisibleMonth,
177
+ setFocusedDate,
178
+ setCalendarFocused,
179
+ isDayUnselectable,
180
+ isDayHighlighted,
181
+ isDayDisabled,
182
+ isDayVisible,
183
+ isOutsideAllowedDates,
184
+ isOutsideAllowedMonths,
185
+ isOutsideAllowedYears,
186
+ ...selectionManager.helpers
187
+ }
188
+ }),
189
+ [
139
190
  visibleMonth,
140
191
  focusedDate,
141
192
  minDate,
@@ -143,12 +194,10 @@ function useCalendar(props) {
143
194
  selectionVariant,
144
195
  hideOutOfRangeDates,
145
196
  calendarFocused,
146
- ...selectionManager.state
147
- },
148
- helpers: {
197
+ timeZone,
198
+ locale,
149
199
  setVisibleMonth,
150
200
  setFocusedDate,
151
- setCalendarFocused,
152
201
  isDayUnselectable,
153
202
  isDayHighlighted,
154
203
  isDayDisabled,
@@ -156,9 +205,9 @@ function useCalendar(props) {
156
205
  isOutsideAllowedDates,
157
206
  isOutsideAllowedMonths,
158
207
  isOutsideAllowedYears,
159
- ...selectionManager.helpers
160
- }
161
- };
208
+ selectionManager
209
+ ]
210
+ );
162
211
  }
163
212
 
164
213
  exports.useCalendar = useCalendar;