@fluentui/react-datepicker-compat 0.1.4 → 0.1.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (256) hide show
  1. package/CHANGELOG.json +76 -1
  2. package/CHANGELOG.md +21 -2
  3. package/lib/Calendar.js +0 -1
  4. package/lib/Calendar.js.map +1 -1
  5. package/lib/CalendarDay.js +0 -1
  6. package/lib/CalendarDay.js.map +1 -1
  7. package/lib/CalendarDayGrid.js +0 -1
  8. package/lib/CalendarDayGrid.js.map +1 -1
  9. package/lib/CalendarMonth.js +0 -1
  10. package/lib/CalendarMonth.js.map +1 -1
  11. package/lib/CalendarPicker.js +0 -1
  12. package/lib/CalendarPicker.js.map +1 -1
  13. package/lib/CalendarYear.js +0 -1
  14. package/lib/CalendarYear.js.map +1 -1
  15. package/lib/DatePicker.js +0 -1
  16. package/lib/DatePicker.js.map +1 -1
  17. package/lib/components/Calendar/Calendar.js +278 -300
  18. package/lib/components/Calendar/Calendar.js.map +1 -1
  19. package/lib/components/Calendar/Calendar.types.js +7 -12
  20. package/lib/components/Calendar/Calendar.types.js.map +1 -1
  21. package/lib/components/Calendar/defaults.js +0 -1
  22. package/lib/components/Calendar/defaults.js.map +1 -1
  23. package/lib/components/Calendar/index.js +0 -1
  24. package/lib/components/Calendar/index.js.map +1 -1
  25. package/lib/components/Calendar/useCalendarStyles.styles.js.map +1 -1
  26. package/lib/components/CalendarDay/CalendarDay.js +100 -128
  27. package/lib/components/CalendarDay/CalendarDay.js.map +1 -1
  28. package/lib/components/CalendarDay/CalendarDay.types.js +0 -1
  29. package/lib/components/CalendarDay/CalendarDay.types.js.map +1 -1
  30. package/lib/components/CalendarDay/index.js +0 -1
  31. package/lib/components/CalendarDay/index.js.map +1 -1
  32. package/lib/components/CalendarDay/useCalendarDayStyles.styles.js.map +1 -1
  33. package/lib/components/CalendarDayGrid/CalendarDayGrid.js +146 -159
  34. package/lib/components/CalendarDayGrid/CalendarDayGrid.js.map +1 -1
  35. package/lib/components/CalendarDayGrid/CalendarDayGrid.types.js +0 -1
  36. package/lib/components/CalendarDayGrid/CalendarDayGrid.types.js.map +1 -1
  37. package/lib/components/CalendarDayGrid/CalendarGridDayCell.js +150 -179
  38. package/lib/components/CalendarDayGrid/CalendarGridDayCell.js.map +1 -1
  39. package/lib/components/CalendarDayGrid/CalendarGridRow.js +20 -34
  40. package/lib/components/CalendarDayGrid/CalendarGridRow.js.map +1 -1
  41. package/lib/components/CalendarDayGrid/CalendarMonthHeaderRow.js +29 -39
  42. package/lib/components/CalendarDayGrid/CalendarMonthHeaderRow.js.map +1 -1
  43. package/lib/components/CalendarDayGrid/index.js +0 -1
  44. package/lib/components/CalendarDayGrid/index.js.map +1 -1
  45. package/lib/components/CalendarDayGrid/useCalendarDayGridStyles.styles.js.map +1 -1
  46. package/lib/components/CalendarDayGrid/useWeekCornerStyles.styles.js.map +1 -1
  47. package/lib/components/CalendarDayGrid/useWeeks.js +34 -36
  48. package/lib/components/CalendarDayGrid/useWeeks.js.map +1 -1
  49. package/lib/components/CalendarMonth/CalendarMonth.js +238 -258
  50. package/lib/components/CalendarMonth/CalendarMonth.js.map +1 -1
  51. package/lib/components/CalendarMonth/CalendarMonth.types.js +0 -1
  52. package/lib/components/CalendarMonth/CalendarMonth.types.js.map +1 -1
  53. package/lib/components/CalendarMonth/index.js +0 -1
  54. package/lib/components/CalendarMonth/index.js.map +1 -1
  55. package/lib/components/CalendarMonth/useCalendarMonthStyles.js +2 -4
  56. package/lib/components/CalendarMonth/useCalendarMonthStyles.js.map +1 -1
  57. package/lib/components/CalendarPicker/CalendarPicker.types.js +1 -2
  58. package/lib/components/CalendarPicker/CalendarPicker.types.js.map +1 -1
  59. package/lib/components/CalendarPicker/index.js +0 -1
  60. package/lib/components/CalendarPicker/index.js.map +1 -1
  61. package/lib/components/CalendarPicker/useCalendarPickerStyles.styles.js.map +1 -1
  62. package/lib/components/CalendarYear/CalendarYear.js +260 -312
  63. package/lib/components/CalendarYear/CalendarYear.js.map +1 -1
  64. package/lib/components/CalendarYear/CalendarYear.types.js +0 -1
  65. package/lib/components/CalendarYear/CalendarYear.types.js.map +1 -1
  66. package/lib/components/CalendarYear/index.js +0 -1
  67. package/lib/components/CalendarYear/index.js.map +1 -1
  68. package/lib/components/CalendarYear/useCalendarYearStyles.styles.js.map +1 -1
  69. package/lib/components/DatePicker/DatePicker.js +4 -5
  70. package/lib/components/DatePicker/DatePicker.js.map +1 -1
  71. package/lib/components/DatePicker/DatePicker.types.js +0 -1
  72. package/lib/components/DatePicker/DatePicker.types.js.map +1 -1
  73. package/lib/components/DatePicker/defaults.js +9 -10
  74. package/lib/components/DatePicker/defaults.js.map +1 -1
  75. package/lib/components/DatePicker/index.js +0 -1
  76. package/lib/components/DatePicker/index.js.map +1 -1
  77. package/lib/components/DatePicker/renderDatePicker.js +5 -12
  78. package/lib/components/DatePicker/renderDatePicker.js.map +1 -1
  79. package/lib/components/DatePicker/useDatePicker.js +401 -353
  80. package/lib/components/DatePicker/useDatePicker.js.map +1 -1
  81. package/lib/components/DatePicker/useDatePickerStyles.styles.js.map +1 -1
  82. package/lib/index.js +0 -1
  83. package/lib/index.js.map +1 -1
  84. package/lib/utils/animations.js +72 -73
  85. package/lib/utils/animations.js.map +1 -1
  86. package/lib/utils/constants.js +50 -52
  87. package/lib/utils/constants.js.map +1 -1
  88. package/lib/utils/dateFormatting/dateFormatting.defaults.js +71 -34
  89. package/lib/utils/dateFormatting/dateFormatting.defaults.js.map +1 -1
  90. package/lib/utils/dateFormatting/dateFormatting.types.js +1 -2
  91. package/lib/utils/dateFormatting/dateFormatting.types.js.map +1 -1
  92. package/lib/utils/dateFormatting/index.js +0 -1
  93. package/lib/utils/dateFormatting/index.js.map +1 -1
  94. package/lib/utils/dateGrid/dateGrid.types.js +1 -2
  95. package/lib/utils/dateGrid/dateGrid.types.js.map +1 -1
  96. package/lib/utils/dateGrid/findAvailableDate.js +14 -21
  97. package/lib/utils/dateGrid/findAvailableDate.js.map +1 -1
  98. package/lib/utils/dateGrid/getBoundedDateRange.js +11 -11
  99. package/lib/utils/dateGrid/getBoundedDateRange.js.map +1 -1
  100. package/lib/utils/dateGrid/getDateRangeTypeToUse.js +6 -8
  101. package/lib/utils/dateGrid/getDateRangeTypeToUse.js.map +1 -1
  102. package/lib/utils/dateGrid/getDayGrid.js +59 -73
  103. package/lib/utils/dateGrid/getDayGrid.js.map +1 -1
  104. package/lib/utils/dateGrid/index.js +0 -1
  105. package/lib/utils/dateGrid/index.js.map +1 -1
  106. package/lib/utils/dateGrid/isAfterMaxDate.js +3 -7
  107. package/lib/utils/dateGrid/isAfterMaxDate.js.map +1 -1
  108. package/lib/utils/dateGrid/isBeforeMinDate.js +3 -7
  109. package/lib/utils/dateGrid/isBeforeMinDate.js.map +1 -1
  110. package/lib/utils/dateGrid/isContiguous.js +11 -12
  111. package/lib/utils/dateGrid/isContiguous.js.map +1 -1
  112. package/lib/utils/dateGrid/isRestrictedDate.js +7 -13
  113. package/lib/utils/dateGrid/isRestrictedDate.js.map +1 -1
  114. package/lib/utils/dateMath/dateMath.js +179 -198
  115. package/lib/utils/dateMath/dateMath.js.map +1 -1
  116. package/lib/utils/dateMath/index.js +0 -1
  117. package/lib/utils/dateMath/index.js.map +1 -1
  118. package/lib/utils/dom.js +5 -6
  119. package/lib/utils/dom.js.map +1 -1
  120. package/lib/utils/focus.js +17 -19
  121. package/lib/utils/focus.js.map +1 -1
  122. package/lib/utils/index.js +0 -1
  123. package/lib/utils/index.js.map +1 -1
  124. package/lib/utils/usePopupPositioning.js +12 -16
  125. package/lib/utils/usePopupPositioning.js.map +1 -1
  126. package/lib-commonjs/Calendar.js +0 -3
  127. package/lib-commonjs/Calendar.js.map +1 -1
  128. package/lib-commonjs/CalendarDay.js +0 -3
  129. package/lib-commonjs/CalendarDay.js.map +1 -1
  130. package/lib-commonjs/CalendarDayGrid.js +0 -3
  131. package/lib-commonjs/CalendarDayGrid.js.map +1 -1
  132. package/lib-commonjs/CalendarMonth.js +0 -3
  133. package/lib-commonjs/CalendarMonth.js.map +1 -1
  134. package/lib-commonjs/CalendarPicker.js +0 -3
  135. package/lib-commonjs/CalendarPicker.js.map +1 -1
  136. package/lib-commonjs/CalendarYear.js +0 -3
  137. package/lib-commonjs/CalendarYear.js.map +1 -1
  138. package/lib-commonjs/DatePicker.js +0 -3
  139. package/lib-commonjs/DatePicker.js.map +1 -1
  140. package/lib-commonjs/components/Calendar/Calendar.js +1 -3
  141. package/lib-commonjs/components/Calendar/Calendar.js.map +1 -1
  142. package/lib-commonjs/components/Calendar/Calendar.types.js +5 -7
  143. package/lib-commonjs/components/Calendar/Calendar.types.js.map +1 -1
  144. package/lib-commonjs/components/Calendar/defaults.js +1 -3
  145. package/lib-commonjs/components/Calendar/defaults.js.map +1 -1
  146. package/lib-commonjs/components/Calendar/index.js +0 -3
  147. package/lib-commonjs/components/Calendar/index.js.map +1 -1
  148. package/lib-commonjs/components/Calendar/useCalendarStyles.styles.js +0 -2
  149. package/lib-commonjs/components/Calendar/useCalendarStyles.styles.js.map +1 -1
  150. package/lib-commonjs/components/CalendarDay/CalendarDay.js +1 -3
  151. package/lib-commonjs/components/CalendarDay/CalendarDay.js.map +1 -1
  152. package/lib-commonjs/components/CalendarDay/CalendarDay.types.js +0 -3
  153. package/lib-commonjs/components/CalendarDay/CalendarDay.types.js.map +1 -1
  154. package/lib-commonjs/components/CalendarDay/index.js +0 -3
  155. package/lib-commonjs/components/CalendarDay/index.js.map +1 -1
  156. package/lib-commonjs/components/CalendarDay/useCalendarDayStyles.styles.js +0 -2
  157. package/lib-commonjs/components/CalendarDay/useCalendarDayStyles.styles.js.map +1 -1
  158. package/lib-commonjs/components/CalendarDayGrid/CalendarDayGrid.js +7 -9
  159. package/lib-commonjs/components/CalendarDayGrid/CalendarDayGrid.js.map +1 -1
  160. package/lib-commonjs/components/CalendarDayGrid/CalendarDayGrid.types.js +0 -3
  161. package/lib-commonjs/components/CalendarDayGrid/CalendarDayGrid.types.js.map +1 -1
  162. package/lib-commonjs/components/CalendarDayGrid/CalendarGridDayCell.js +1 -3
  163. package/lib-commonjs/components/CalendarDayGrid/CalendarGridDayCell.js.map +1 -1
  164. package/lib-commonjs/components/CalendarDayGrid/CalendarGridRow.js +1 -3
  165. package/lib-commonjs/components/CalendarDayGrid/CalendarGridRow.js.map +1 -1
  166. package/lib-commonjs/components/CalendarDayGrid/CalendarMonthHeaderRow.js +1 -3
  167. package/lib-commonjs/components/CalendarDayGrid/CalendarMonthHeaderRow.js.map +1 -1
  168. package/lib-commonjs/components/CalendarDayGrid/index.js +0 -3
  169. package/lib-commonjs/components/CalendarDayGrid/index.js.map +1 -1
  170. package/lib-commonjs/components/CalendarDayGrid/useCalendarDayGridStyles.styles.js +0 -2
  171. package/lib-commonjs/components/CalendarDayGrid/useCalendarDayGridStyles.styles.js.map +1 -1
  172. package/lib-commonjs/components/CalendarDayGrid/useWeekCornerStyles.styles.js +0 -2
  173. package/lib-commonjs/components/CalendarDayGrid/useWeekCornerStyles.styles.js.map +1 -1
  174. package/lib-commonjs/components/CalendarDayGrid/useWeeks.js +9 -11
  175. package/lib-commonjs/components/CalendarDayGrid/useWeeks.js.map +1 -1
  176. package/lib-commonjs/components/CalendarMonth/CalendarMonth.js +1 -3
  177. package/lib-commonjs/components/CalendarMonth/CalendarMonth.js.map +1 -1
  178. package/lib-commonjs/components/CalendarMonth/CalendarMonth.types.js +0 -3
  179. package/lib-commonjs/components/CalendarMonth/CalendarMonth.types.js.map +1 -1
  180. package/lib-commonjs/components/CalendarMonth/index.js +0 -3
  181. package/lib-commonjs/components/CalendarMonth/index.js.map +1 -1
  182. package/lib-commonjs/components/CalendarMonth/useCalendarMonthStyles.js +1 -3
  183. package/lib-commonjs/components/CalendarMonth/useCalendarMonthStyles.js.map +1 -1
  184. package/lib-commonjs/components/CalendarPicker/CalendarPicker.types.js +0 -3
  185. package/lib-commonjs/components/CalendarPicker/CalendarPicker.types.js.map +1 -1
  186. package/lib-commonjs/components/CalendarPicker/index.js +0 -3
  187. package/lib-commonjs/components/CalendarPicker/index.js.map +1 -1
  188. package/lib-commonjs/components/CalendarPicker/useCalendarPickerStyles.styles.js +0 -2
  189. package/lib-commonjs/components/CalendarPicker/useCalendarPickerStyles.styles.js.map +1 -1
  190. package/lib-commonjs/components/CalendarYear/CalendarYear.js +1 -3
  191. package/lib-commonjs/components/CalendarYear/CalendarYear.js.map +1 -1
  192. package/lib-commonjs/components/CalendarYear/CalendarYear.types.js +0 -3
  193. package/lib-commonjs/components/CalendarYear/CalendarYear.types.js.map +1 -1
  194. package/lib-commonjs/components/CalendarYear/index.js +0 -3
  195. package/lib-commonjs/components/CalendarYear/index.js.map +1 -1
  196. package/lib-commonjs/components/CalendarYear/useCalendarYearStyles.styles.js +0 -2
  197. package/lib-commonjs/components/CalendarYear/useCalendarYearStyles.styles.js.map +1 -1
  198. package/lib-commonjs/components/DatePicker/DatePicker.js +1 -3
  199. package/lib-commonjs/components/DatePicker/DatePicker.js.map +1 -1
  200. package/lib-commonjs/components/DatePicker/DatePicker.types.js +0 -3
  201. package/lib-commonjs/components/DatePicker/DatePicker.types.js.map +1 -1
  202. package/lib-commonjs/components/DatePicker/defaults.js +1 -3
  203. package/lib-commonjs/components/DatePicker/defaults.js.map +1 -1
  204. package/lib-commonjs/components/DatePicker/index.js +0 -3
  205. package/lib-commonjs/components/DatePicker/index.js.map +1 -1
  206. package/lib-commonjs/components/DatePicker/renderDatePicker.js +1 -3
  207. package/lib-commonjs/components/DatePicker/renderDatePicker.js.map +1 -1
  208. package/lib-commonjs/components/DatePicker/useDatePicker.js +8 -11
  209. package/lib-commonjs/components/DatePicker/useDatePicker.js.map +1 -1
  210. package/lib-commonjs/components/DatePicker/useDatePickerStyles.styles.js +0 -2
  211. package/lib-commonjs/components/DatePicker/useDatePickerStyles.styles.js.map +1 -1
  212. package/lib-commonjs/index.js +0 -3
  213. package/lib-commonjs/index.js.map +1 -1
  214. package/lib-commonjs/utils/animations.js +4 -6
  215. package/lib-commonjs/utils/animations.js.map +1 -1
  216. package/lib-commonjs/utils/constants.js +7 -9
  217. package/lib-commonjs/utils/constants.js.map +1 -1
  218. package/lib-commonjs/utils/dateFormatting/dateFormatting.defaults.js +1 -3
  219. package/lib-commonjs/utils/dateFormatting/dateFormatting.defaults.js.map +1 -1
  220. package/lib-commonjs/utils/dateFormatting/dateFormatting.types.js +0 -3
  221. package/lib-commonjs/utils/dateFormatting/dateFormatting.types.js.map +1 -1
  222. package/lib-commonjs/utils/dateFormatting/index.js +0 -3
  223. package/lib-commonjs/utils/dateFormatting/index.js.map +1 -1
  224. package/lib-commonjs/utils/dateGrid/dateGrid.types.js +0 -3
  225. package/lib-commonjs/utils/dateGrid/dateGrid.types.js.map +1 -1
  226. package/lib-commonjs/utils/dateGrid/findAvailableDate.js +1 -3
  227. package/lib-commonjs/utils/dateGrid/findAvailableDate.js.map +1 -1
  228. package/lib-commonjs/utils/dateGrid/getBoundedDateRange.js +1 -3
  229. package/lib-commonjs/utils/dateGrid/getBoundedDateRange.js.map +1 -1
  230. package/lib-commonjs/utils/dateGrid/getDateRangeTypeToUse.js +1 -3
  231. package/lib-commonjs/utils/dateGrid/getDateRangeTypeToUse.js.map +1 -1
  232. package/lib-commonjs/utils/dateGrid/getDayGrid.js +1 -3
  233. package/lib-commonjs/utils/dateGrid/getDayGrid.js.map +1 -1
  234. package/lib-commonjs/utils/dateGrid/index.js +0 -3
  235. package/lib-commonjs/utils/dateGrid/index.js.map +1 -1
  236. package/lib-commonjs/utils/dateGrid/isAfterMaxDate.js +1 -3
  237. package/lib-commonjs/utils/dateGrid/isAfterMaxDate.js.map +1 -1
  238. package/lib-commonjs/utils/dateGrid/isBeforeMinDate.js +1 -3
  239. package/lib-commonjs/utils/dateGrid/isBeforeMinDate.js.map +1 -1
  240. package/lib-commonjs/utils/dateGrid/isContiguous.js +1 -3
  241. package/lib-commonjs/utils/dateGrid/isContiguous.js.map +1 -1
  242. package/lib-commonjs/utils/dateGrid/isRestrictedDate.js +1 -3
  243. package/lib-commonjs/utils/dateGrid/isRestrictedDate.js.map +1 -1
  244. package/lib-commonjs/utils/dateMath/dateMath.js +1 -3
  245. package/lib-commonjs/utils/dateMath/dateMath.js.map +1 -1
  246. package/lib-commonjs/utils/dateMath/index.js +0 -3
  247. package/lib-commonjs/utils/dateMath/index.js.map +1 -1
  248. package/lib-commonjs/utils/dom.js +1 -3
  249. package/lib-commonjs/utils/dom.js.map +1 -1
  250. package/lib-commonjs/utils/focus.js +1 -3
  251. package/lib-commonjs/utils/focus.js.map +1 -1
  252. package/lib-commonjs/utils/index.js +0 -3
  253. package/lib-commonjs/utils/index.js.map +1 -1
  254. package/lib-commonjs/utils/usePopupPositioning.js +1 -3
  255. package/lib-commonjs/utils/usePopupPositioning.js.map +1 -1
  256. package/package.json +11 -11
@@ -8,343 +8,291 @@ import { useCalendarYearStyles_unstable } from './useCalendarYearStyles.styles';
8
8
  const CELL_COUNT = 12;
9
9
  const CELLS_PER_ROW = 4;
10
10
  const DefaultCalendarYearStrings = {
11
- prevRangeAriaLabel: undefined,
12
- nextRangeAriaLabel: undefined
11
+ prevRangeAriaLabel: undefined,
12
+ nextRangeAriaLabel: undefined
13
13
  };
14
- const CalendarYearGridCell = props => {
15
- const {
16
- className,
17
- highlightCurrentYear,
18
- highlightSelectedYear,
19
- year,
20
- selected,
21
- disabled,
22
- componentRef,
23
- onSelectYear,
24
- onRenderYear
25
- } = props;
26
- const buttonRef = React.useRef(null);
27
- React.useImperativeHandle(componentRef, () => {
28
- return {
29
- focus() {
30
- var _buttonRef_current, _buttonRef_current_focus;
31
- (_buttonRef_current = buttonRef.current) === null || _buttonRef_current === void 0 ? void 0 : (_buttonRef_current_focus = _buttonRef_current.focus) === null || _buttonRef_current_focus === void 0 ? void 0 : _buttonRef_current_focus.call(_buttonRef_current);
32
- }
14
+ const CalendarYearGridCell = (props)=>{
15
+ const { className , highlightCurrentYear , highlightSelectedYear , year , selected , disabled , componentRef , onSelectYear , onRenderYear } = props;
16
+ const buttonRef = React.useRef(null);
17
+ React.useImperativeHandle(componentRef, ()=>{
18
+ return {
19
+ focus () {
20
+ var _buttonRef_current, _buttonRef_current_focus;
21
+ (_buttonRef_current = buttonRef.current) === null || _buttonRef_current === void 0 ? void 0 : (_buttonRef_current_focus = _buttonRef_current.focus) === null || _buttonRef_current_focus === void 0 ? void 0 : _buttonRef_current_focus.call(_buttonRef_current);
22
+ }
23
+ };
24
+ }, []);
25
+ const onClick = ()=>{
26
+ onSelectYear === null || onSelectYear === void 0 ? void 0 : onSelectYear(year);
33
27
  };
34
- }, []);
35
- const onClick = () => {
36
- onSelectYear === null || onSelectYear === void 0 ? void 0 : onSelectYear(year);
37
- };
38
- const onKeyDown = ev => {
39
- if (ev.key === Enter) {
40
- onSelectYear === null || onSelectYear === void 0 ? void 0 : onSelectYear(year);
41
- }
42
- };
43
- const classNames = useCalendarYearStyles_unstable({
44
- className,
45
- highlightCurrent: highlightCurrentYear,
46
- highlightSelected: highlightSelectedYear
47
- });
48
- var _onRenderYear;
49
- return /*#__PURE__*/React.createElement("button", {
50
- className: mergeClasses(classNames.itemButton, selected && classNames.selected, disabled && classNames.disabled),
51
- type: "button",
52
- role: "gridcell",
53
- onClick: !disabled ? onClick : undefined,
54
- onKeyDown: !disabled ? onKeyDown : undefined,
55
- disabled: disabled,
56
- "aria-selected": selected,
57
- ref: buttonRef
58
- }, (_onRenderYear = onRenderYear === null || onRenderYear === void 0 ? void 0 : onRenderYear(year)) !== null && _onRenderYear !== void 0 ? _onRenderYear : year);
28
+ const onKeyDown = (ev)=>{
29
+ if (ev.key === Enter) {
30
+ onSelectYear === null || onSelectYear === void 0 ? void 0 : onSelectYear(year);
31
+ }
32
+ };
33
+ const classNames = useCalendarYearStyles_unstable({
34
+ className,
35
+ highlightCurrent: highlightCurrentYear,
36
+ highlightSelected: highlightSelectedYear
37
+ });
38
+ var _onRenderYear;
39
+ return /*#__PURE__*/ React.createElement("button", {
40
+ className: mergeClasses(classNames.itemButton, selected && classNames.selected, disabled && classNames.disabled),
41
+ type: "button",
42
+ role: "gridcell",
43
+ onClick: !disabled ? onClick : undefined,
44
+ onKeyDown: !disabled ? onKeyDown : undefined,
45
+ disabled: disabled,
46
+ "aria-selected": selected,
47
+ ref: buttonRef
48
+ }, (_onRenderYear = onRenderYear === null || onRenderYear === void 0 ? void 0 : onRenderYear(year)) !== null && _onRenderYear !== void 0 ? _onRenderYear : year);
59
49
  };
60
50
  CalendarYearGridCell.displayName = 'CalendarYearGridCell';
61
- const CalendarYearGrid = props => {
62
- const {
63
- className,
64
- fromYear,
65
- toYear,
66
- animationDirection,
67
- animateBackwards,
68
- minYear,
69
- maxYear,
70
- onSelectYear,
71
- selectedYear,
72
- componentRef
73
- } = props;
74
- const selectedCellRef = React.useRef(null);
75
- const currentCellRef = React.useRef(null);
76
- React.useImperativeHandle(componentRef, () => {
77
- return {
78
- focus() {
79
- var _ref, _ref_focus;
80
- (_ref = selectedCellRef.current || currentCellRef.current) === null || _ref === void 0 ? void 0 : (_ref_focus = _ref.focus) === null || _ref_focus === void 0 ? void 0 : _ref_focus.call(_ref);
81
- }
51
+ const CalendarYearGrid = (props)=>{
52
+ const { className , fromYear , toYear , animationDirection , animateBackwards , minYear , maxYear , onSelectYear , selectedYear , componentRef } = props;
53
+ const selectedCellRef = React.useRef(null);
54
+ const currentCellRef = React.useRef(null);
55
+ React.useImperativeHandle(componentRef, ()=>{
56
+ return {
57
+ focus () {
58
+ var _ref, _ref_focus;
59
+ (_ref = selectedCellRef.current || currentCellRef.current) === null || _ref === void 0 ? void 0 : (_ref_focus = _ref.focus) === null || _ref_focus === void 0 ? void 0 : _ref_focus.call(_ref);
60
+ }
61
+ };
62
+ }, []);
63
+ const renderCell = (yearToRender)=>{
64
+ const selected = yearToRender === selectedYear;
65
+ const disabled = minYear !== undefined && yearToRender < minYear || maxYear !== undefined && yearToRender > maxYear;
66
+ const current = yearToRender === new Date().getFullYear();
67
+ return /*#__PURE__*/ React.createElement(CalendarYearGridCell, {
68
+ ...props,
69
+ key: yearToRender,
70
+ year: yearToRender,
71
+ selected: selected,
72
+ current: current,
73
+ disabled: disabled,
74
+ onSelectYear: onSelectYear,
75
+ componentRef: selected ? selectedCellRef : current ? currentCellRef : undefined
76
+ });
82
77
  };
83
- }, []);
84
- const renderCell = yearToRender => {
85
- const selected = yearToRender === selectedYear;
86
- const disabled = minYear !== undefined && yearToRender < minYear || maxYear !== undefined && yearToRender > maxYear;
87
- const current = yearToRender === new Date().getFullYear();
88
- return /*#__PURE__*/React.createElement(CalendarYearGridCell, {
89
- ...props,
90
- key: yearToRender,
91
- year: yearToRender,
92
- selected: selected,
93
- current: current,
94
- disabled: disabled,
95
- onSelectYear: onSelectYear,
96
- componentRef: selected ? selectedCellRef : current ? currentCellRef : undefined
78
+ const classNames = useCalendarYearStyles_unstable({
79
+ className,
80
+ animateBackwards,
81
+ animationDirection
97
82
  });
98
- };
99
- const classNames = useCalendarYearStyles_unstable({
100
- className,
101
- animateBackwards,
102
- animationDirection
103
- });
104
- const onRenderYear = value => {
105
- var _props_onRenderYear;
106
- var _props_onRenderYear1;
107
- return (_props_onRenderYear1 = (_props_onRenderYear = props.onRenderYear) === null || _props_onRenderYear === void 0 ? void 0 : _props_onRenderYear.call(props, value)) !== null && _props_onRenderYear1 !== void 0 ? _props_onRenderYear1 : value;
108
- };
109
- const gridAriaLabel = `${onRenderYear(fromYear)} - ${onRenderYear(toYear)}`;
110
- let year = fromYear;
111
- const cells = [];
112
- for (let i = 0; i < (toYear - fromYear + 1) / CELLS_PER_ROW; i++) {
113
- cells.push([]);
114
- for (let j = 0; j < CELLS_PER_ROW; j++) {
115
- cells[i].push(renderCell(year));
116
- year++;
83
+ const onRenderYear = (value)=>{
84
+ var _props_onRenderYear;
85
+ var _props_onRenderYear1;
86
+ return (_props_onRenderYear1 = (_props_onRenderYear = props.onRenderYear) === null || _props_onRenderYear === void 0 ? void 0 : _props_onRenderYear.call(props, value)) !== null && _props_onRenderYear1 !== void 0 ? _props_onRenderYear1 : value;
87
+ };
88
+ const gridAriaLabel = `${onRenderYear(fromYear)} - ${onRenderYear(toYear)}`;
89
+ let year = fromYear;
90
+ const cells = [];
91
+ for(let i = 0; i < (toYear - fromYear + 1) / CELLS_PER_ROW; i++){
92
+ cells.push([]);
93
+ for(let j = 0; j < CELLS_PER_ROW; j++){
94
+ cells[i].push(renderCell(year));
95
+ year++;
96
+ }
117
97
  }
118
- }
119
- const arrowNavigationAttributes = useArrowNavigationGroup({
120
- axis: 'both'
121
- });
122
- return /*#__PURE__*/React.createElement("div", arrowNavigationAttributes, /*#__PURE__*/React.createElement("div", {
123
- className: classNames.gridContainer,
124
- role: "grid",
125
- "aria-label": gridAriaLabel
126
- }, cells.map((cellRow, index) => {
127
- return /*#__PURE__*/React.createElement("div", {
128
- key: 'yearPickerRow_' + index + '_' + fromYear,
129
- role: "row",
130
- className: classNames.buttonRow
131
- }, cellRow);
132
- })));
98
+ const arrowNavigationAttributes = useArrowNavigationGroup({
99
+ axis: 'both'
100
+ });
101
+ return /*#__PURE__*/ React.createElement("div", arrowNavigationAttributes, /*#__PURE__*/ React.createElement("div", {
102
+ className: classNames.gridContainer,
103
+ role: "grid",
104
+ "aria-label": gridAriaLabel
105
+ }, cells.map((cellRow, index)=>{
106
+ return /*#__PURE__*/ React.createElement("div", {
107
+ key: 'yearPickerRow_' + index + '_' + fromYear,
108
+ role: "row",
109
+ className: classNames.buttonRow
110
+ }, cellRow);
111
+ })));
133
112
  };
134
113
  CalendarYearGrid.displayName = 'CalendarYearGrid';
135
114
  const CalendarYearNavDirection = {
136
- Previous: 0,
137
- Next: 1
115
+ Previous: 0,
116
+ Next: 1
138
117
  };
139
- const CalendarYearNavArrow = props => {
140
- const {
141
- className,
142
- strings = DefaultCalendarYearStrings,
143
- direction,
144
- onSelectPrev,
145
- onSelectNext,
146
- fromYear,
147
- toYear,
148
- maxYear,
149
- minYear
150
- } = props;
151
- const classNames = useCalendarYearStyles_unstable({
152
- className
153
- });
154
- const ariaLabel = direction === CalendarYearNavDirection.Previous ? strings.prevRangeAriaLabel : strings.nextRangeAriaLabel;
155
- const newRangeOffset = direction === CalendarYearNavDirection.Previous ? -CELL_COUNT : CELL_COUNT;
156
- const newRange = {
157
- fromYear: fromYear + newRangeOffset,
158
- toYear: toYear + newRangeOffset
159
- };
160
- const ariaLabelString = ariaLabel ? typeof ariaLabel === 'string' ? ariaLabel : ariaLabel(newRange) : undefined;
161
- const disabled = direction === CalendarYearNavDirection.Previous ? minYear !== undefined && fromYear < minYear : maxYear !== undefined && props.fromYear + CELL_COUNT > maxYear;
162
- const onNavigate = () => {
163
- direction === CalendarYearNavDirection.Previous ? onSelectPrev === null || onSelectPrev === void 0 ? void 0 : onSelectPrev() : onSelectNext === null || onSelectNext === void 0 ? void 0 : onSelectNext();
164
- };
165
- const onKeyDown = ev => {
166
- if (ev.key === Enter) {
167
- onNavigate();
168
- }
169
- };
170
- const {
171
- dir
172
- } = useFluent_unstable();
173
- // can be condensed, but leaving verbose for clarity due to regressions
174
- const isLeftNavigation = dir === 'rtl' ? direction === CalendarYearNavDirection.Next : direction === CalendarYearNavDirection.Previous;
175
- return /*#__PURE__*/React.createElement("button", {
176
- className: mergeClasses(classNames.navigationButton, disabled && classNames.disabled),
177
- onClick: !disabled ? onNavigate : undefined,
178
- onKeyDown: !disabled ? onKeyDown : undefined,
179
- type: "button",
180
- title: ariaLabelString,
181
- disabled: disabled
182
- }, isLeftNavigation ? /*#__PURE__*/React.createElement(ArrowUpRegular, null) : /*#__PURE__*/React.createElement(ArrowDownRegular, null));
118
+ const CalendarYearNavArrow = (props)=>{
119
+ const { className , strings =DefaultCalendarYearStrings , direction , onSelectPrev , onSelectNext , fromYear , toYear , maxYear , minYear } = props;
120
+ const classNames = useCalendarYearStyles_unstable({
121
+ className
122
+ });
123
+ const ariaLabel = direction === CalendarYearNavDirection.Previous ? strings.prevRangeAriaLabel : strings.nextRangeAriaLabel;
124
+ const newRangeOffset = direction === CalendarYearNavDirection.Previous ? -CELL_COUNT : CELL_COUNT;
125
+ const newRange = {
126
+ fromYear: fromYear + newRangeOffset,
127
+ toYear: toYear + newRangeOffset
128
+ };
129
+ const ariaLabelString = ariaLabel ? typeof ariaLabel === 'string' ? ariaLabel : ariaLabel(newRange) : undefined;
130
+ const disabled = direction === CalendarYearNavDirection.Previous ? minYear !== undefined && fromYear < minYear : maxYear !== undefined && props.fromYear + CELL_COUNT > maxYear;
131
+ const onNavigate = ()=>{
132
+ direction === CalendarYearNavDirection.Previous ? onSelectPrev === null || onSelectPrev === void 0 ? void 0 : onSelectPrev() : onSelectNext === null || onSelectNext === void 0 ? void 0 : onSelectNext();
133
+ };
134
+ const onKeyDown = (ev)=>{
135
+ if (ev.key === Enter) {
136
+ onNavigate();
137
+ }
138
+ };
139
+ const { dir } = useFluent_unstable();
140
+ // can be condensed, but leaving verbose for clarity due to regressions
141
+ const isLeftNavigation = dir === 'rtl' ? direction === CalendarYearNavDirection.Next : direction === CalendarYearNavDirection.Previous;
142
+ return /*#__PURE__*/ React.createElement("button", {
143
+ className: mergeClasses(classNames.navigationButton, disabled && classNames.disabled),
144
+ onClick: !disabled ? onNavigate : undefined,
145
+ onKeyDown: !disabled ? onKeyDown : undefined,
146
+ type: "button",
147
+ title: ariaLabelString,
148
+ disabled: disabled
149
+ }, isLeftNavigation ? /*#__PURE__*/ React.createElement(ArrowUpRegular, null) : /*#__PURE__*/ React.createElement(ArrowDownRegular, null));
183
150
  };
184
151
  CalendarYearNavArrow.displayName = 'CalendarYearNavArrow';
185
- const CalendarYearNav = props => {
186
- const {
187
- className
188
- } = props;
189
- const classNames = useCalendarYearStyles_unstable({
190
- className
191
- });
192
- return /*#__PURE__*/React.createElement("div", {
193
- className: classNames.navigationButtonsContainer
194
- }, /*#__PURE__*/React.createElement(CalendarYearNavArrow, {
195
- ...props,
196
- direction: CalendarYearNavDirection.Previous
197
- }), /*#__PURE__*/React.createElement(CalendarYearNavArrow, {
198
- ...props,
199
- direction: CalendarYearNavDirection.Next
200
- }));
152
+ const CalendarYearNav = (props)=>{
153
+ const { className } = props;
154
+ const classNames = useCalendarYearStyles_unstable({
155
+ className
156
+ });
157
+ return /*#__PURE__*/ React.createElement("div", {
158
+ className: classNames.navigationButtonsContainer
159
+ }, /*#__PURE__*/ React.createElement(CalendarYearNavArrow, {
160
+ ...props,
161
+ direction: CalendarYearNavDirection.Previous
162
+ }), /*#__PURE__*/ React.createElement(CalendarYearNavArrow, {
163
+ ...props,
164
+ direction: CalendarYearNavDirection.Next
165
+ }));
201
166
  };
202
167
  CalendarYearNav.displayName = 'CalendarYearNav';
203
- const CalendarYearTitle = props => {
204
- const {
205
- className,
206
- fromYear,
207
- toYear,
208
- strings = DefaultCalendarYearStrings,
209
- animateBackwards,
210
- animationDirection
211
- } = props;
212
- const onHeaderSelect = () => {
213
- var _props_onHeaderSelect;
214
- (_props_onHeaderSelect = props.onHeaderSelect) === null || _props_onHeaderSelect === void 0 ? void 0 : _props_onHeaderSelect.call(props, true);
215
- };
216
- const onHeaderKeyDown = ev => {
217
- if (ev.key === Enter || ev.key === Space) {
218
- onHeaderSelect();
168
+ const CalendarYearTitle = (props)=>{
169
+ const { className , fromYear , toYear , strings =DefaultCalendarYearStrings , animateBackwards , animationDirection } = props;
170
+ const onHeaderSelect = ()=>{
171
+ var _props_onHeaderSelect;
172
+ (_props_onHeaderSelect = props.onHeaderSelect) === null || _props_onHeaderSelect === void 0 ? void 0 : _props_onHeaderSelect.call(props, true);
173
+ };
174
+ const onHeaderKeyDown = (ev)=>{
175
+ if (ev.key === Enter || ev.key === Space) {
176
+ onHeaderSelect();
177
+ }
178
+ };
179
+ const onRenderYear = (year)=>{
180
+ var _props_onRenderYear;
181
+ var _props_onRenderYear1;
182
+ return (_props_onRenderYear1 = (_props_onRenderYear = props.onRenderYear) === null || _props_onRenderYear === void 0 ? void 0 : _props_onRenderYear.call(props, year)) !== null && _props_onRenderYear1 !== void 0 ? _props_onRenderYear1 : year;
183
+ };
184
+ const classNames = useCalendarYearStyles_unstable({
185
+ className,
186
+ hasHeaderClickCallback: !!props.onHeaderSelect,
187
+ animateBackwards,
188
+ animationDirection
189
+ });
190
+ if (props.onHeaderSelect) {
191
+ const rangeAriaLabel = strings.rangeAriaLabel;
192
+ const headerAriaLabelFormatString = strings.headerAriaLabelFormatString;
193
+ const currentDateRange = rangeAriaLabel ? typeof rangeAriaLabel === 'string' ? rangeAriaLabel : rangeAriaLabel(props) : undefined;
194
+ const ariaLabel = headerAriaLabelFormatString ? headerAriaLabelFormatString.replace('{0}', currentDateRange !== null && currentDateRange !== void 0 ? currentDateRange : '') : currentDateRange;
195
+ return /*#__PURE__*/ React.createElement("button", {
196
+ className: classNames.currentItemButton,
197
+ onClick: onHeaderSelect,
198
+ onKeyDown: onHeaderKeyDown,
199
+ "aria-label": ariaLabel,
200
+ role: "button",
201
+ type: "button"
202
+ }, /*#__PURE__*/ React.createElement("span", {
203
+ "aria-live": "assertive",
204
+ "aria-atomic": "true"
205
+ }, onRenderYear(fromYear), " - ", onRenderYear(toYear)));
219
206
  }
220
- };
221
- const onRenderYear = year => {
222
- var _props_onRenderYear;
223
- var _props_onRenderYear1;
224
- return (_props_onRenderYear1 = (_props_onRenderYear = props.onRenderYear) === null || _props_onRenderYear === void 0 ? void 0 : _props_onRenderYear.call(props, year)) !== null && _props_onRenderYear1 !== void 0 ? _props_onRenderYear1 : year;
225
- };
226
- const classNames = useCalendarYearStyles_unstable({
227
- className,
228
- hasHeaderClickCallback: !!props.onHeaderSelect,
229
- animateBackwards,
230
- animationDirection
231
- });
232
- if (props.onHeaderSelect) {
233
- const rangeAriaLabel = strings.rangeAriaLabel;
234
- const headerAriaLabelFormatString = strings.headerAriaLabelFormatString;
235
- const currentDateRange = rangeAriaLabel ? typeof rangeAriaLabel === 'string' ? rangeAriaLabel : rangeAriaLabel(props) : undefined;
236
- const ariaLabel = headerAriaLabelFormatString ? headerAriaLabelFormatString.replace('{0}', currentDateRange !== null && currentDateRange !== void 0 ? currentDateRange : '') : currentDateRange;
237
- return /*#__PURE__*/React.createElement("button", {
238
- className: classNames.currentItemButton,
239
- onClick: onHeaderSelect,
240
- onKeyDown: onHeaderKeyDown,
241
- "aria-label": ariaLabel,
242
- role: "button",
243
- type: "button"
244
- }, /*#__PURE__*/React.createElement("span", {
245
- "aria-live": "assertive",
246
- "aria-atomic": "true"
247
- }, onRenderYear(fromYear), " - ", onRenderYear(toYear)));
248
- }
249
- return /*#__PURE__*/React.createElement("div", {
250
- className: classNames.current
251
- }, onRenderYear(fromYear), " - ", onRenderYear(toYear));
207
+ return /*#__PURE__*/ React.createElement("div", {
208
+ className: classNames.current
209
+ }, onRenderYear(fromYear), " - ", onRenderYear(toYear));
252
210
  };
253
211
  CalendarYearTitle.displayName = 'CalendarYearTitle';
254
- const CalendarYearHeader = props => {
255
- const {
256
- className,
257
- animateBackwards,
258
- animationDirection,
259
- onRenderTitle
260
- } = props;
261
- const classNames = useCalendarYearStyles_unstable({
262
- className,
263
- hasHeaderClickCallback: !!props.onHeaderSelect,
264
- animateBackwards,
265
- animationDirection
266
- });
267
- var _onRenderTitle;
268
- return /*#__PURE__*/React.createElement("div", {
269
- className: classNames.headerContainer
270
- }, (_onRenderTitle = onRenderTitle === null || onRenderTitle === void 0 ? void 0 : onRenderTitle(props)) !== null && _onRenderTitle !== void 0 ? _onRenderTitle : /*#__PURE__*/React.createElement(CalendarYearTitle, props), /*#__PURE__*/React.createElement(CalendarYearNav, props));
212
+ const CalendarYearHeader = (props)=>{
213
+ const { className , animateBackwards , animationDirection , onRenderTitle } = props;
214
+ const classNames = useCalendarYearStyles_unstable({
215
+ className,
216
+ hasHeaderClickCallback: !!props.onHeaderSelect,
217
+ animateBackwards,
218
+ animationDirection
219
+ });
220
+ var _onRenderTitle;
221
+ return /*#__PURE__*/ React.createElement("div", {
222
+ className: classNames.headerContainer
223
+ }, (_onRenderTitle = onRenderTitle === null || onRenderTitle === void 0 ? void 0 : onRenderTitle(props)) !== null && _onRenderTitle !== void 0 ? _onRenderTitle : /*#__PURE__*/ React.createElement(CalendarYearTitle, props), /*#__PURE__*/ React.createElement(CalendarYearNav, props));
271
224
  };
272
225
  CalendarYearHeader.displayName = 'CalendarYearHeader';
273
- function useAnimateBackwards({
274
- selectedYear,
275
- navigatedYear
276
- }) {
277
- const rangeYear = selectedYear || navigatedYear || new Date().getFullYear();
278
- const fromYear = Math.floor(rangeYear / 10) * 10;
279
- const previousFromYearRef = React.useRef(fromYear);
280
- React.useRef(() => {
281
- previousFromYearRef.current = fromYear;
282
- });
283
- const previousFromYear = previousFromYearRef.current;
284
- if (!previousFromYear || previousFromYear === fromYear) {
285
- return undefined;
286
- } else if (previousFromYear > fromYear) {
287
- return true;
288
- } else {
289
- return false;
290
- }
226
+ function useAnimateBackwards({ selectedYear , navigatedYear }) {
227
+ const rangeYear = selectedYear || navigatedYear || new Date().getFullYear();
228
+ const fromYear = Math.floor(rangeYear / 10) * 10;
229
+ const previousFromYearRef = React.useRef(fromYear);
230
+ React.useRef(()=>{
231
+ previousFromYearRef.current = fromYear;
232
+ });
233
+ const previousFromYear = previousFromYearRef.current;
234
+ if (!previousFromYear || previousFromYear === fromYear) {
235
+ return undefined;
236
+ } else if (previousFromYear > fromYear) {
237
+ return true;
238
+ } else {
239
+ return false;
240
+ }
291
241
  }
292
242
  const NavigationDirection = {
293
- Previous: 0,
294
- Next: 1
243
+ Previous: 0,
244
+ Next: 1
295
245
  };
296
- function useYearRangeState({
297
- selectedYear,
298
- navigatedYear
299
- }) {
300
- const [fromYear, navigate] = React.useReducer((state, action) => {
301
- return state + (action === NavigationDirection.Next ? CELL_COUNT : -CELL_COUNT);
302
- }, undefined, () => {
303
- const rangeYear = selectedYear || navigatedYear || new Date().getFullYear();
304
- return Math.floor(rangeYear / 10) * 10;
305
- });
306
- const toYear = fromYear + CELL_COUNT - 1;
307
- const onNavNext = () => navigate(NavigationDirection.Next);
308
- const onNavPrevious = () => navigate(NavigationDirection.Previous);
309
- return [fromYear, toYear, onNavNext, onNavPrevious];
246
+ function useYearRangeState({ selectedYear , navigatedYear }) {
247
+ const [fromYear, navigate] = React.useReducer((state, action)=>{
248
+ return state + (action === NavigationDirection.Next ? CELL_COUNT : -CELL_COUNT);
249
+ }, undefined, ()=>{
250
+ const rangeYear = selectedYear || navigatedYear || new Date().getFullYear();
251
+ return Math.floor(rangeYear / 10) * 10;
252
+ });
253
+ const toYear = fromYear + CELL_COUNT - 1;
254
+ const onNavNext = ()=>navigate(NavigationDirection.Next);
255
+ const onNavPrevious = ()=>navigate(NavigationDirection.Previous);
256
+ return [
257
+ fromYear,
258
+ toYear,
259
+ onNavNext,
260
+ onNavPrevious
261
+ ];
310
262
  }
311
263
  /**
312
264
  * @internal
313
- */
314
- export const CalendarYear = props => {
315
- const animateBackwards = useAnimateBackwards(props);
316
- const [fromYear, toYear, onNavNext, onNavPrevious] = useYearRangeState(props);
317
- const gridRef = React.useRef(null);
318
- React.useImperativeHandle(props.componentRef, () => {
319
- return {
320
- focus() {
321
- var _gridRef_current, _gridRef_current_focus;
322
- (_gridRef_current = gridRef.current) === null || _gridRef_current === void 0 ? void 0 : (_gridRef_current_focus = _gridRef_current.focus) === null || _gridRef_current_focus === void 0 ? void 0 : _gridRef_current_focus.call(_gridRef_current);
323
- }
324
- };
325
- });
326
- const {
327
- className
328
- } = props;
329
- const classNames = useCalendarYearStyles_unstable({
330
- className
331
- });
332
- return /*#__PURE__*/React.createElement("div", {
333
- className: classNames.root
334
- }, /*#__PURE__*/React.createElement(CalendarYearHeader, {
335
- ...props,
336
- fromYear: fromYear,
337
- toYear: toYear,
338
- onSelectPrev: onNavPrevious,
339
- onSelectNext: onNavNext,
340
- animateBackwards: animateBackwards
341
- }), /*#__PURE__*/React.createElement(CalendarYearGrid, {
342
- ...props,
343
- fromYear: fromYear,
344
- toYear: toYear,
345
- animateBackwards: animateBackwards,
346
- componentRef: gridRef
347
- }));
265
+ */ export const CalendarYear = (props)=>{
266
+ const animateBackwards = useAnimateBackwards(props);
267
+ const [fromYear, toYear, onNavNext, onNavPrevious] = useYearRangeState(props);
268
+ const gridRef = React.useRef(null);
269
+ React.useImperativeHandle(props.componentRef, ()=>{
270
+ return {
271
+ focus () {
272
+ var _gridRef_current, _gridRef_current_focus;
273
+ (_gridRef_current = gridRef.current) === null || _gridRef_current === void 0 ? void 0 : (_gridRef_current_focus = _gridRef_current.focus) === null || _gridRef_current_focus === void 0 ? void 0 : _gridRef_current_focus.call(_gridRef_current);
274
+ }
275
+ };
276
+ });
277
+ const { className } = props;
278
+ const classNames = useCalendarYearStyles_unstable({
279
+ className
280
+ });
281
+ return /*#__PURE__*/ React.createElement("div", {
282
+ className: classNames.root
283
+ }, /*#__PURE__*/ React.createElement(CalendarYearHeader, {
284
+ ...props,
285
+ fromYear: fromYear,
286
+ toYear: toYear,
287
+ onSelectPrev: onNavPrevious,
288
+ onSelectNext: onNavNext,
289
+ animateBackwards: animateBackwards
290
+ }), /*#__PURE__*/ React.createElement(CalendarYearGrid, {
291
+ ...props,
292
+ fromYear: fromYear,
293
+ toYear: toYear,
294
+ animateBackwards: animateBackwards,
295
+ componentRef: gridRef
296
+ }));
348
297
  };
349
298
  CalendarYear.displayName = 'CalendarYear';
350
- //# sourceMappingURL=CalendarYear.js.map