@yamada-ui/react 2.2.1-dev-20260428150301 → 2.2.1-dev-20260428152727

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 (251) hide show
  1. package/dist/cjs/components/calendar/use-calendar.cjs +16 -20
  2. package/dist/cjs/components/calendar/use-calendar.cjs.map +1 -1
  3. package/dist/cjs/components/carousel/use-carousel.cjs +9 -8
  4. package/dist/cjs/components/carousel/use-carousel.cjs.map +1 -1
  5. package/dist/esm/components/calendar/use-calendar.js +17 -21
  6. package/dist/esm/components/calendar/use-calendar.js.map +1 -1
  7. package/dist/esm/components/carousel/use-carousel.js +9 -8
  8. package/dist/esm/components/carousel/use-carousel.js.map +1 -1
  9. package/dist/types/components/accordion/accordion.d.ts +2 -4
  10. package/dist/types/components/accordion/accordion.style.d.ts +1 -1
  11. package/dist/types/components/accordion/use-accordion.d.ts +11 -11
  12. package/dist/types/components/action-bar/action-bar.d.ts +2 -3
  13. package/dist/types/components/airy/airy.d.ts +2 -3
  14. package/dist/types/components/alert/alert.d.ts +2 -5
  15. package/dist/types/components/alert/alert.style.d.ts +1 -1
  16. package/dist/types/components/alpha-slider/alpha-slider.d.ts +2 -3
  17. package/dist/types/components/aspect-ratio/aspect-ratio.d.ts +2 -2
  18. package/dist/types/components/autocomplete/autocomplete.d.ts +2 -4
  19. package/dist/types/components/autocomplete/use-autocomplete.d.ts +5 -7
  20. package/dist/types/components/avatar/avatar.d.ts +3 -3
  21. package/dist/types/components/avatar/use-avatar-group.d.ts +2 -2
  22. package/dist/types/components/badge/badge.d.ts +2 -2
  23. package/dist/types/components/bleed/bleed.d.ts +2 -2
  24. package/dist/types/components/blockquote/blockquote.d.ts +2 -2
  25. package/dist/types/components/breadcrumb/breadcrumb.d.ts +2 -2
  26. package/dist/types/components/breadcrumb/breadcrumb.style.d.ts +1 -1
  27. package/dist/types/components/breadcrumb/use-breadcrumb.d.ts +2 -2
  28. package/dist/types/components/button/button-group.d.ts +0 -1
  29. package/dist/types/components/button/button.d.ts +2 -3
  30. package/dist/types/components/button/icon-button.d.ts +2 -2
  31. package/dist/types/components/calendar/calendar.d.ts +2 -3
  32. package/dist/types/components/calendar/calendar.style.d.ts +2 -2
  33. package/dist/types/components/calendar/use-calendar.d.ts +8 -9
  34. package/dist/types/components/card/card.d.ts +2 -2
  35. package/dist/types/components/carousel/carousel.d.ts +2 -3
  36. package/dist/types/components/carousel/carousel.style.d.ts +2 -2
  37. package/dist/types/components/carousel/use-carousel.d.ts +3 -3
  38. package/dist/types/components/center/center.d.ts +2 -2
  39. package/dist/types/components/chart/chart.d.ts +5 -5
  40. package/dist/types/components/chart/line-chart.d.ts +2 -2
  41. package/dist/types/components/chart/pie-chart.d.ts +2 -2
  42. package/dist/types/components/chart/radar-chart.d.ts +2 -2
  43. package/dist/types/components/chart/radial-chart.d.ts +2 -2
  44. package/dist/types/components/chart/use-chart.d.ts +2 -2
  45. package/dist/types/components/checkbox/checkbox-group.d.ts +0 -2
  46. package/dist/types/components/checkbox/checkbox.d.ts +4 -5
  47. package/dist/types/components/checkbox/use-checkbox-group.d.ts +2 -3
  48. package/dist/types/components/checkbox/use-checkbox.d.ts +0 -1
  49. package/dist/types/components/checkbox-card/checkbox-card-group.d.ts +0 -3
  50. package/dist/types/components/checkbox-card/checkbox-card.d.ts +5 -7
  51. package/dist/types/components/checkbox-card/checkbox-card.style.d.ts +1 -1
  52. package/dist/types/components/circle-progress/circle-progress.d.ts +2 -3
  53. package/dist/types/components/close-button/close-button.d.ts +2 -3
  54. package/dist/types/components/code/code.d.ts +2 -2
  55. package/dist/types/components/collapse/collapse.d.ts +2 -3
  56. package/dist/types/components/color-picker/color-picker.d.ts +2 -6
  57. package/dist/types/components/color-picker/use-color-picker.d.ts +2 -5
  58. package/dist/types/components/color-selector/color-selector.d.ts +2 -6
  59. package/dist/types/components/color-selector/use-color-selector.d.ts +3 -5
  60. package/dist/types/components/color-swatch/color-swatch.d.ts +2 -2
  61. package/dist/types/components/container/container.d.ts +2 -2
  62. package/dist/types/components/data-list/data-list.d.ts +2 -2
  63. package/dist/types/components/data-list/data-list.style.d.ts +1 -1
  64. package/dist/types/components/date-picker/date-picker.d.ts +2 -5
  65. package/dist/types/components/date-picker/use-date-picker.d.ts +4 -7
  66. package/dist/types/components/drawer/drawer.d.ts +2 -5
  67. package/dist/types/components/drawer/use-drawer.d.ts +0 -2
  68. package/dist/types/components/dropzone/dropzone.d.ts +5 -8
  69. package/dist/types/components/dropzone/dropzone.style.d.ts +1 -1
  70. package/dist/types/components/dropzone/use-dropzone.d.ts +0 -1
  71. package/dist/types/components/editable/editable.d.ts +4 -5
  72. package/dist/types/components/editable/use-editable.d.ts +2 -3
  73. package/dist/types/components/em/em.d.ts +2 -2
  74. package/dist/types/components/empty-state/empty-state.d.ts +2 -2
  75. package/dist/types/components/empty-state/empty-state.style.d.ts +2 -2
  76. package/dist/types/components/fade/fade.d.ts +2 -3
  77. package/dist/types/components/fade-scale/fade-scale.d.ts +0 -1
  78. package/dist/types/components/field/field.d.ts +3 -3
  79. package/dist/types/components/field/use-field-props.d.ts +4 -4
  80. package/dist/types/components/fieldset/fieldset.d.ts +3 -4
  81. package/dist/types/components/file-button/file-button.d.ts +2 -4
  82. package/dist/types/components/file-button/use-file-button.d.ts +15 -17
  83. package/dist/types/components/file-input/file-input.d.ts +2 -4
  84. package/dist/types/components/file-input/use-file-input.d.ts +15 -16
  85. package/dist/types/components/flex/flex.d.ts +2 -2
  86. package/dist/types/components/flip/flip.d.ts +4 -5
  87. package/dist/types/components/flip/flip.style.d.ts +1 -1
  88. package/dist/types/components/float/float.d.ts +2 -2
  89. package/dist/types/components/form/form.d.ts +3 -4
  90. package/dist/types/components/form/form.style.d.ts +1 -1
  91. package/dist/types/components/format/format-byte.d.ts +4 -4
  92. package/dist/types/components/format/format-date-time.d.ts +4 -4
  93. package/dist/types/components/format/format-number.d.ts +2 -2
  94. package/dist/types/components/format/use-format-byte.d.ts +0 -1
  95. package/dist/types/components/format/use-format-date-time.d.ts +0 -1
  96. package/dist/types/components/format/use-format-number.d.ts +0 -1
  97. package/dist/types/components/grid/grid-item.d.ts +2 -2
  98. package/dist/types/components/grid/grid.d.ts +2 -2
  99. package/dist/types/components/group/group.d.ts +2 -3
  100. package/dist/types/components/group/use-group.d.ts +2 -2
  101. package/dist/types/components/heading/heading.d.ts +2 -2
  102. package/dist/types/components/highlight/highlight.d.ts +0 -2
  103. package/dist/types/components/hue-slider/hue-slider.d.ts +3 -4
  104. package/dist/types/components/icon/icon.d.ts +4 -4
  105. package/dist/types/components/image/image.d.ts +2 -2
  106. package/dist/types/components/indicator/indicator.d.ts +4 -5
  107. package/dist/types/components/infinite-scroll-area/infinite-scroll-area.d.ts +2 -2
  108. package/dist/types/components/input/input-addon.d.ts +2 -2
  109. package/dist/types/components/input/input-element.d.ts +2 -2
  110. package/dist/types/components/input/input-group.d.ts +0 -2
  111. package/dist/types/components/input/input.d.ts +2 -3
  112. package/dist/types/components/kbd/kbd.d.ts +2 -2
  113. package/dist/types/components/link/link.d.ts +2 -2
  114. package/dist/types/components/link-box/link-box.d.ts +2 -2
  115. package/dist/types/components/list/list.d.ts +2 -2
  116. package/dist/types/components/list/list.style.d.ts +2 -2
  117. package/dist/types/components/loading/loading-provider.d.ts +2 -2
  118. package/dist/types/components/loading/loading.d.ts +3 -4
  119. package/dist/types/components/loading/use-loading-component.d.ts +0 -1
  120. package/dist/types/components/mark/mark.d.ts +2 -2
  121. package/dist/types/components/menu/menu.d.ts +2 -3
  122. package/dist/types/components/menu/menu.style.d.ts +2 -2
  123. package/dist/types/components/menu/use-menu.d.ts +11 -11
  124. package/dist/types/components/modal/modal.d.ts +2 -6
  125. package/dist/types/components/native-accordion/native-accordion.d.ts +2 -2
  126. package/dist/types/components/native-accordion/native-accordion.style.d.ts +2 -2
  127. package/dist/types/components/native-accordion/use-native-accordion.d.ts +2 -2
  128. package/dist/types/components/native-popover/native-popover.d.ts +2 -2
  129. package/dist/types/components/native-select/native-select.d.ts +2 -4
  130. package/dist/types/components/native-select/use-native-select.d.ts +0 -1
  131. package/dist/types/components/native-table/native-table.d.ts +4 -4
  132. package/dist/types/components/notice/notice.style.d.ts +1 -1
  133. package/dist/types/components/notice/use-notice.d.ts +0 -3
  134. package/dist/types/components/number-input/number-input.d.ts +2 -3
  135. package/dist/types/components/number-input/use-number-input.d.ts +0 -1
  136. package/dist/types/components/pagination/pagination.d.ts +2 -3
  137. package/dist/types/components/pagination/pagination.style.d.ts +1 -1
  138. package/dist/types/components/pagination/use-pagination.d.ts +2 -2
  139. package/dist/types/components/password-input/password-input.d.ts +2 -3
  140. package/dist/types/components/password-input/strength-meter.d.ts +2 -2
  141. package/dist/types/components/password-input/use-password-input.d.ts +2 -3
  142. package/dist/types/components/picture/picture.d.ts +0 -1
  143. package/dist/types/components/pin-input/pin-input.d.ts +2 -4
  144. package/dist/types/components/pin-input/use-pin-input.d.ts +7 -8
  145. package/dist/types/components/popover/popover.d.ts +2 -3
  146. package/dist/types/components/progress/progress.d.ts +4 -4
  147. package/dist/types/components/progress/use-progress.d.ts +706 -706
  148. package/dist/types/components/qr-code/qr-code.d.ts +2 -2
  149. package/dist/types/components/radio/radio-group.d.ts +0 -2
  150. package/dist/types/components/radio/radio.d.ts +3 -4
  151. package/dist/types/components/radio/use-radio-group.d.ts +2 -3
  152. package/dist/types/components/radio/use-radio.d.ts +0 -1
  153. package/dist/types/components/radio-card/radio-card-group.d.ts +0 -3
  154. package/dist/types/components/radio-card/radio-card.d.ts +4 -6
  155. package/dist/types/components/radio-card/radio-card.style.d.ts +1 -1
  156. package/dist/types/components/rating/rating.style.d.ts +2 -2
  157. package/dist/types/components/rating/use-rating.d.ts +7 -8
  158. package/dist/types/components/reorder/reorder.d.ts +2 -3
  159. package/dist/types/components/reorder/reorder.style.d.ts +1 -1
  160. package/dist/types/components/reorder/use-reorder.d.ts +3 -3
  161. package/dist/types/components/resizable/resizable.d.ts +2 -2
  162. package/dist/types/components/resizable/resizable.style.d.ts +2 -2
  163. package/dist/types/components/resizable/use-resizable.d.ts +2 -2
  164. package/dist/types/components/ripple/ripple.d.ts +2 -3
  165. package/dist/types/components/ripple/use-ripple.d.ts +2 -2
  166. package/dist/types/components/rotate/rotate.d.ts +2 -3
  167. package/dist/types/components/saturation-slider/saturation-slider.d.ts +2 -2
  168. package/dist/types/components/saturation-slider/use-saturation-slider.d.ts +2 -3
  169. package/dist/types/components/scroll-area/scroll-area.d.ts +2 -2
  170. package/dist/types/components/segmented-control/segmented-control.d.ts +2 -3
  171. package/dist/types/components/segmented-control/segmented-control.style.d.ts +2 -2
  172. package/dist/types/components/segmented-control/use-segmented-control.d.ts +9 -10
  173. package/dist/types/components/select/select.d.ts +2 -4
  174. package/dist/types/components/select/use-select.d.ts +4 -6
  175. package/dist/types/components/separator/separator.d.ts +2 -2
  176. package/dist/types/components/sidebar/sidebar.d.ts +2 -7
  177. package/dist/types/components/sidebar/use-sidebar.d.ts +9 -9
  178. package/dist/types/components/simple-grid/simple-grid.d.ts +2 -3
  179. package/dist/types/components/skeleton/skeleton.d.ts +2 -2
  180. package/dist/types/components/slide/slide.d.ts +2 -3
  181. package/dist/types/components/slide-fade/slide-fade.d.ts +2 -3
  182. package/dist/types/components/slider/slider.d.ts +2 -2
  183. package/dist/types/components/slider/use-slider.d.ts +2 -3
  184. package/dist/types/components/snacks/snacks.d.ts +0 -2
  185. package/dist/types/components/snacks/use-snacks.d.ts +0 -1
  186. package/dist/types/components/stack/h-stack.d.ts +2 -2
  187. package/dist/types/components/stack/stack.d.ts +2 -2
  188. package/dist/types/components/stack/v-stack.d.ts +2 -2
  189. package/dist/types/components/stack/z-stack.d.ts +2 -2
  190. package/dist/types/components/stat/stat.d.ts +2 -2
  191. package/dist/types/components/status/status.d.ts +2 -2
  192. package/dist/types/components/steps/steps.d.ts +2 -2
  193. package/dist/types/components/steps/steps.style.d.ts +1 -1
  194. package/dist/types/components/steps/use-steps.d.ts +10 -10
  195. package/dist/types/components/switch/switch.d.ts +2 -2
  196. package/dist/types/components/switch/use-switch.d.ts +0 -1
  197. package/dist/types/components/table/table.d.ts +2 -4
  198. package/dist/types/components/tabs/tabs.d.ts +2 -2
  199. package/dist/types/components/tabs/use-tabs.d.ts +16 -16
  200. package/dist/types/components/tag/tag.d.ts +2 -2
  201. package/dist/types/components/tag/tag.style.d.ts +1 -1
  202. package/dist/types/components/text/text.d.ts +2 -2
  203. package/dist/types/components/textarea/textarea.d.ts +2 -4
  204. package/dist/types/components/textarea/use-autosize.d.ts +2 -2
  205. package/dist/types/components/timeline/timeline.d.ts +5 -5
  206. package/dist/types/components/timeline/timeline.style.d.ts +1 -1
  207. package/dist/types/components/tip/tip.d.ts +0 -3
  208. package/dist/types/components/toggle/toggle-group.d.ts +1 -1
  209. package/dist/types/components/toggle/toggle.d.ts +5 -7
  210. package/dist/types/components/toggle/use-toggle-group.d.ts +2 -2
  211. package/dist/types/components/toggle/use-toggle.d.ts +2 -3
  212. package/dist/types/components/tooltip/tooltip.d.ts +2 -4
  213. package/dist/types/components/tree/tree.d.ts +2 -6
  214. package/dist/types/components/tree/tree.style.d.ts +1 -1
  215. package/dist/types/components/tree/use-tree.d.ts +182 -183
  216. package/dist/types/components/visually-hidden/visually-hidden.d.ts +2 -2
  217. package/dist/types/components/wrap/wrap.d.ts +2 -3
  218. package/dist/types/core/components/create-component.d.ts +9 -7
  219. package/dist/types/core/components/index.types.d.ts +1 -0
  220. package/dist/types/core/components/use-component-style.d.ts +2 -0
  221. package/dist/types/core/components/utils.d.ts +1 -0
  222. package/dist/types/core/constant.d.ts +1 -0
  223. package/dist/types/core/css/calc.d.ts +1 -0
  224. package/dist/types/core/css/config.d.ts +1 -0
  225. package/dist/types/core/css/css.d.ts +1 -0
  226. package/dist/types/core/css/index.types.d.ts +1 -0
  227. package/dist/types/core/css/styles.d.ts +1 -0
  228. package/dist/types/core/css/token.d.ts +1 -0
  229. package/dist/types/core/css/use-css.d.ts +1 -0
  230. package/dist/types/core/css/utils.d.ts +2 -0
  231. package/dist/types/core/generated-theme-tokens.types.d.ts +1 -0
  232. package/dist/types/core/index.d.ts +2 -0
  233. package/dist/types/core/system/color-mode-provider.d.ts +2 -2
  234. package/dist/types/core/system/config.d.ts +1 -0
  235. package/dist/types/core/system/create-system.d.ts +1 -0
  236. package/dist/types/core/system/factory.d.ts +1 -0
  237. package/dist/types/core/system/index.types.d.ts +1 -0
  238. package/dist/types/core/system/storage-script.d.ts +3 -3
  239. package/dist/types/core/system/styled.d.ts +3 -2
  240. package/dist/types/core/system/system-provider.d.ts +2 -2
  241. package/dist/types/core/system/var.d.ts +2 -0
  242. package/dist/types/hooks/use-async-callback/index.d.ts +0 -1
  243. package/dist/types/hooks/use-breakpoint/use-breakpoint-state.d.ts +2 -2
  244. package/dist/types/hooks/use-combobox/index.d.ts +12 -13
  245. package/dist/types/hooks/use-counter/index.d.ts +2 -2
  246. package/dist/types/hooks/use-descendants/index.d.ts +2 -2
  247. package/dist/types/index.d.ts +0 -106
  248. package/dist/types/providers/i18n-provider/i18n-provider.d.ts +3 -3
  249. package/dist/types/providers/ui-provider/ui-provider.d.ts +2 -3
  250. package/dist/types/utils/children.d.ts +2 -2
  251. package/package.json +2 -2
@@ -286,11 +286,7 @@ const useCalendar = ({ defaultMonth = /* @__PURE__ */ new Date(), multiple = fal
286
286
  require_effect.useUpdateEffect(() => {
287
287
  setMonth((prev) => getAdjustedMonth(value, prev));
288
288
  }, [value]);
289
- const getRootProps = (0, react.useCallback)((props = {}) => ({
290
- "data-disabled": (0, require_utils_index.utils_exports.dataAttr)(disabled),
291
- ...rest,
292
- ...props
293
- }), [disabled, rest]);
289
+ const getRootProps = (0, react.useCallback)((props = {}) => require_props.mergeProps({ "data-disabled": (0, require_utils_index.utils_exports.dataAttr)(disabled) }, rest, props)(), [disabled, rest]);
294
290
  const getNavigationProps = (0, react.useCallback)((props = {}) => ({
295
291
  "data-disabled": (0, require_utils_index.utils_exports.dataAttr)(disabled),
296
292
  ...props
@@ -570,19 +566,20 @@ const useCalendarDay = ({ value, ...rest }) => {
570
566
  ]);
571
567
  return {
572
568
  outside,
573
- getDayProps: (0, react.useCallback)(({ ref, "aria-label": ariaLabel, ...props } = {}) => {
574
- if (!ariaLabel) {
575
- ariaLabel = dateTimeFormat((0, dayjs.default)(value).toDate(), {
569
+ getDayProps: (0, react.useCallback)(({ "aria-label": ariaLabel, ...props } = {}) => {
570
+ let resolvedAriaLabel = ariaLabel;
571
+ if (!resolvedAriaLabel) {
572
+ resolvedAriaLabel = dateTimeFormat((0, dayjs.default)(value).toDate(), {
576
573
  day: "numeric",
577
574
  month: "long",
578
575
  weekday: "long",
579
576
  year: "numeric"
580
577
  });
581
- if (today) ariaLabel = `${t("Today")}, ${ariaLabel}`;
578
+ if (today) resolvedAriaLabel = `${t("Today")}, ${resolvedAriaLabel}`;
582
579
  }
583
- return {
580
+ return require_props.mergeProps({
584
581
  "aria-disabled": (0, require_utils_index.utils_exports.ariaAttr)(disabled),
585
- "aria-label": ariaLabel,
582
+ "aria-label": resolvedAriaLabel,
586
583
  "aria-selected": (0, require_utils_index.utils_exports.ariaAttr)(selected),
587
584
  "data-between": (0, require_utils_index.utils_exports.dataAttr)(between),
588
585
  "data-disabled": (0, require_utils_index.utils_exports.dataAttr)(disabled),
@@ -594,15 +591,14 @@ const useCalendarDay = ({ value, ...rest }) => {
594
591
  "data-today": (0, require_utils_index.utils_exports.dataAttr)(today),
595
592
  "data-value": (0, dayjs.default)(value).format("YYYY-MM-DD"),
596
593
  "data-weekend": (0, require_utils_index.utils_exports.dataAttr)(weekend),
597
- tabIndex: -1,
598
- ...rest,
599
- ...props,
600
- ref: require_ref.mergeRefs(ref, cellRef, outside ? null : register),
601
- onBlur: (0, require_utils_index.utils_exports.handlerAll)(props.onBlur, onBlur),
602
- onClick: (0, require_utils_index.utils_exports.handlerAll)(props.onClick, onClick),
603
- onFocus: (0, require_utils_index.utils_exports.handlerAll)(props.onFocus, (ev) => ev.preventDefault()),
604
- onKeyDown: (0, require_utils_index.utils_exports.handlerAll)(props.onKeyDown, onKeyDown)
605
- };
594
+ tabIndex: -1
595
+ }, rest, props, {
596
+ ref: require_ref.mergeRefs(cellRef, outside ? null : register),
597
+ onBlur,
598
+ onClick,
599
+ onFocus: (ev) => ev.preventDefault(),
600
+ onKeyDown
601
+ })();
606
602
  }, [
607
603
  between,
608
604
  dateTimeFormat,
@@ -1 +1 @@
1
- {"version":3,"file":"use-calendar.cjs","names":["DEFAULT_HOLIDAYS: Date[]","DEFAULT_WEEKEND_DAYS: number[]","DEFAULT_FIRST_DAY_OF_WEEK: StartDayOfWeek","DEFAULT_MAX_DATE: Date","DEFAULT_MIN_DATE: Date","weekdays: { label: string; value: number }[]","weeks: { label: string; value: Date }[][]","days: { label: string; value: Date }[]","createDescendants","createContext","useI18n","useDateTimeFormat","value","useControllableState","startOfMonth","yearItems: { label: string; value: string }[]","yearItems","monthItems: { label: string; value: string }[]","month","monthItems","index: null | number","descendant: Descendant<HTMLTableCellElement> | undefined","getRootProps: PropGetter","getNavigationProps: PropGetter<\"nav\">","getYearSelectProps: PropGetter<\n \"div\",\n { value?: string; onChange?: (value: string) => void },\n { value?: string; onChange?: (value: string) => void }\n >","getMonthSelectProps: PropGetter<\n \"div\",\n { value?: string; onChange?: (value: string) => void },\n { value?: string; onChange?: (value: string) => void }\n >","getStatusProps: PropGetter","visuallyHiddenAttributes","getMonthProps: PropGetter<\"table\">","mergeRefs","getWeekdayProps: RequiredPropGetter<\"th\", { value: number }>","getButtonProps: PropGetter<\"button\">","getPrevButtonProps: PropGetter<\"button\">","getNextButtonProps: PropGetter<\"button\">","holiday","selectedValue","ev","calendarProps: (keyof UseCalendarProps)[]","useSplitProps"],"sources":["../../../../src/components/calendar/use-calendar.ts"],"sourcesContent":["\"use client\"\n\nimport type { FocusEvent, KeyboardEvent } from \"react\"\nimport type { HTMLProps, PropGetter, RequiredPropGetter } from \"../../core\"\nimport type { Descendant } from \"../../hooks/use-descendants\"\nimport type { Locale } from \"../../providers/i18n-provider\"\nimport type { AnyString, Dict } from \"../../utils\"\nimport dayjs from \"dayjs\"\nimport { useCallback, useMemo, useRef } from \"react\"\nimport { useSplitProps } from \"../../core\"\nimport { useControllableState } from \"../../hooks/use-controllable-state\"\nimport { createDescendants } from \"../../hooks/use-descendants\"\nimport { useI18n } from \"../../providers/i18n-provider\"\nimport {\n ariaAttr,\n contains,\n createContext,\n dataAttr,\n handlerAll,\n isArray,\n isDate,\n isNumber,\n isObject,\n mergeRefs,\n runKeyAction,\n useUpdateEffect,\n visuallyHiddenAttributes,\n} from \"../../utils\"\nimport { useDateTimeFormat } from \"../format\"\n\nexport const DEFAULT_HOLIDAYS: Date[] = []\nexport const DEFAULT_WEEKEND_DAYS: number[] = [0, 6]\nexport const DEFAULT_FIRST_DAY_OF_WEEK: StartDayOfWeek = \"sunday\"\nexport const DEFAULT_MAX_DATE: Date = new Date(\"2099-12-31\")\nexport const DEFAULT_MIN_DATE: Date = new Date(\"1900-01-01\")\n\nexport type MaybeDate = Date | Date[] | undefined | { end?: Date; start?: Date }\nexport type MaybeDateValue<\n Multiple extends boolean = false,\n Range extends boolean = false,\n> = Range extends true\n ? { end?: Date; start?: Date }\n : Multiple extends true\n ? Date[]\n : Date | undefined\nexport type StartDayOfWeek = \"monday\" | \"sunday\"\nexport interface CalendarFormat {\n day?: Intl.DateTimeFormatOptions[\"day\"] | null\n month?: Intl.DateTimeFormatOptions[\"month\"] | null\n weekday?: Intl.DateTimeFormatOptions[\"weekday\"] | null\n year?: Intl.DateTimeFormatOptions[\"year\"] | null\n}\n\nexport const getStartOfWeek = (\n date: Date,\n startDayOfWeek: StartDayOfWeek,\n): Date =>\n dayjs(date)\n .subtract(startDayOfWeek === \"monday\" ? 1 : 0, \"day\")\n .startOf(\"week\")\n .add(startDayOfWeek === \"monday\" ? 1 : 0, \"day\")\n .toDate()\n\nexport const getEndOfWeek = (\n date: Date,\n startDayOfWeek: StartDayOfWeek,\n): Date =>\n dayjs(date)\n .subtract(startDayOfWeek === \"monday\" ? 1 : 0, \"day\")\n .endOf(\"week\")\n .add(startDayOfWeek === \"monday\" ? 1 : 0, \"day\")\n .toDate()\n\nexport const getWeekdays = (\n startDayOfWeek: StartDayOfWeek,\n format: (value: Date) => string,\n): { label: string; value: number }[] => {\n let weekdays: { label: string; value: number }[] = []\n\n const date = getStartOfWeek(new Date(), startDayOfWeek)\n\n for (let i = 0; i < 7; i += 1) {\n const label = format(date)\n const value = date.getDay()\n\n weekdays = [...weekdays, { label, value }]\n\n date.setDate(date.getDate() + 1)\n }\n\n return weekdays\n}\n\nexport const getMonthDays = (\n date: Date,\n startDayOfWeek: StartDayOfWeek,\n format: (value: Date) => string,\n): { label: string; value: Date }[][] => {\n const currentMonth = date.getMonth()\n const startOfMonth = new Date(date.getFullYear(), currentMonth, 1)\n const endOfMonth = new Date(date.getFullYear(), date.getMonth() + 1, 0)\n const startDate = getStartOfWeek(startOfMonth, startDayOfWeek)\n const endDate = getEndOfWeek(endOfMonth, startDayOfWeek)\n\n const weeks: { label: string; value: Date }[][] = []\n\n while (startDate <= endDate) {\n const days: { label: string; value: Date }[] = []\n\n for (let i = 0; i < 7; i += 1) {\n const value = new Date(startDate)\n const label = format(value)\n\n days.push({ label, value })\n\n startDate.setDate(startDate.getDate() + 1)\n }\n\n weeks.push(days)\n }\n\n return weeks\n}\n\nexport const isSameYear = (\n date: Date | undefined,\n comparison: Date | undefined,\n): boolean =>\n date instanceof Date &&\n comparison instanceof Date &&\n dayjs(date).isSame(comparison, \"year\")\n\nexport const isSameMonth = (\n date: Date | undefined,\n comparison: Date | undefined,\n): boolean =>\n date instanceof Date &&\n comparison instanceof Date &&\n dayjs(date).isSame(comparison, \"month\")\n\nexport const isSameDate = (\n date: Date | undefined,\n comparison: Date | undefined,\n) =>\n date instanceof Date &&\n comparison instanceof Date &&\n dayjs(date).isSame(comparison, \"date\")\n\nexport const isAfterDate = (value: Date, date: Date | undefined) =>\n date instanceof Date && dayjs(value).isAfter(date, \"date\")\n\nexport const isBeforeDate = (value: Date, date: Date | undefined) =>\n date instanceof Date && dayjs(value).isBefore(date, \"date\")\n\nexport const isSameAfterDate = (value: Date, date: Date | undefined) =>\n date instanceof Date &&\n (dayjs(date).isSame(value, \"date\") || dayjs(value).isAfter(date, \"date\"))\n\nexport const isSameBeforeDate = (value: Date, date: Date | undefined) =>\n date instanceof Date &&\n (dayjs(date).isSame(value, \"date\") || dayjs(value).isBefore(date, \"date\"))\n\nexport const isAfterMonth = (value: Date, date: Date | undefined) =>\n date instanceof Date && dayjs(value).isAfter(date, \"month\")\n\nexport const isBeforeMonth = (value: Date, date: Date | undefined) =>\n date instanceof Date && dayjs(value).isBefore(date, \"month\")\n\nexport const isSameAfterMonth = (value: Date, date: Date | undefined) =>\n date instanceof Date &&\n (dayjs(date).isSame(value, \"month\") || dayjs(value).isAfter(date, \"month\"))\n\nexport const isSameBeforeMonth = (value: Date, date: Date | undefined) =>\n date instanceof Date &&\n (dayjs(date).isSame(value, \"month\") || dayjs(value).isBefore(date, \"month\"))\n\nexport const isAfterYear = (value: Date, date: Date | undefined) =>\n date instanceof Date && dayjs(value).isAfter(date, \"year\")\n\nexport const isBeforeYear = (value: Date, date: Date | undefined) =>\n date instanceof Date && dayjs(value).isBefore(date, \"year\")\n\nexport const isSameAfterYear = (value: Date, date: Date | undefined) =>\n date instanceof Date &&\n (dayjs(date).isSame(value, \"year\") || dayjs(value).isAfter(date, \"year\"))\n\nexport const isSameBeforeYear = (value: Date, date: Date | undefined) =>\n date instanceof Date &&\n (dayjs(date).isSame(value, \"year\") || dayjs(value).isBefore(date, \"year\"))\n\nexport const isIncludeDates = (comparison: Date, dates: Date[]) =>\n dates.some((date) => dayjs(date).isSame(comparison, \"date\"))\n\nexport const isInRange = (date: Date, minDate?: Date, maxDate?: Date) => {\n const hasMinDate = minDate instanceof Date\n const hasMaxDate = maxDate instanceof Date\n\n if (!hasMaxDate && !hasMinDate) return false\n\n const minInRange = hasMinDate ? isAfterDate(date, minDate) : false\n const maxInRange = hasMaxDate ? isBeforeDate(date, maxDate) : false\n\n return maxInRange && minInRange\n}\n\nexport const sortDates = (dates: Date[], type: \"asc\" | \"desc\" = \"asc\") => {\n if (type === \"asc\") {\n return dates.sort((a, b) => (dayjs(a).isAfter(b, \"date\") ? 1 : -1))\n } else {\n return dates.sort((a, b) => (dayjs(a).isBefore(b, \"date\") ? 1 : -1))\n }\n}\n\nexport const updateMaybeDateValue =\n (value: Date, max?: number) =>\n (prev: MaybeDate): MaybeDate => {\n if (isArray(prev)) {\n if (isIncludeDates(value, prev)) {\n return prev.filter((prevValue) => !isSameDate(prevValue, value))\n } else if (!isNumber(max) || prev.length < max) {\n return [...prev, value]\n } else {\n return prev\n }\n } else if (isObject(prev) && !isDate(prev)) {\n const { end, start } = prev\n\n if ((start && end) || !start) {\n return { end: undefined, start: value }\n } else {\n if (isSameDate(start, value)) {\n return { end: undefined, start: undefined }\n } else if (isBeforeDate(value, start)) {\n return { end: start, start: value }\n } else {\n return { end: value, start }\n }\n }\n } else {\n if (isSameDate(prev, value)) {\n return undefined\n } else {\n return value\n }\n }\n }\n\nexport const getAdjustedMonth = (value: MaybeDate, month: Date) => {\n if (isDate(value)) {\n if (!isSameMonth(value, month)) month = dayjs(value).set(\"date\", 1).toDate()\n } else if (isArray(value)) {\n const lastValue = value.at(-1)\n\n if (lastValue && !isSameMonth(lastValue, month))\n month = dayjs(lastValue).set(\"date\", 1).toDate()\n } else if (isObject(value)) {\n if (value.end) {\n month = dayjs(value.end).set(\"date\", 1).toDate()\n } else if (value.start) {\n month = dayjs(value.start).set(\"date\", 1).toDate()\n }\n }\n\n return month\n}\n\nconst {\n DescendantsContext: CalendarDescendantsContext,\n useDescendant: useCalendarDescendant,\n useDescendants: useCalendarDescendants,\n} = createDescendants<HTMLTableCellElement>()\n\nexport {\n CalendarDescendantsContext,\n useCalendarDescendant,\n useCalendarDescendants,\n}\n\ninterface CalendarContext extends Omit<\n UseCalendarReturn,\n | \"descendants\"\n | \"getMonthProps\"\n | \"getMonthSelectProps\"\n | \"getNavigationProps\"\n | \"getNextButtonProps\"\n | \"getPrevButtonProps\"\n | \"getRootProps\"\n | \"getStatusProps\"\n | \"getWeekdayProps\"\n | \"getYearSelectProps\"\n | \"monthDays\"\n | \"monthItems\"\n | \"weekdays\"\n | \"yearItems\"\n> {}\n\nconst [CalendarContext, useCalendarContext] = createContext<CalendarContext>({\n name: \"CalendarContext\",\n})\n\nexport { CalendarContext, useCalendarContext }\n\nexport interface UseCalendarProps<\n Multiple extends boolean = false,\n Range extends boolean = false,\n> extends Omit<HTMLProps, \"defaultValue\" | \"onChange\"> {\n /**\n * The initial month of the calendar.\n *\n * @default new Date()\n */\n defaultMonth?: Date\n /**\n * The initial value of the calendar.\n */\n defaultValue?: MaybeDateValue<Multiple, Range>\n /**\n * If `true`, disables the calendar.\n *\n * @default false\n */\n disabled?: boolean\n /**\n * The format used for conversion.\n * Check the docs to see the format of possible modifiers you can pass.\n *\n * @see https://day.js.org/docs/en/display/format#list-of-localized-formats\n */\n format?: CalendarFormat\n /**\n * Define holidays.\n */\n holidays?: Date[]\n /**\n * The locale of the calendar.\n *\n * @default 'en-US'\n */\n locale?: AnyString | Locale\n /**\n * The maximum selectable value.\n */\n max?: number\n /**\n * The maximum possible date.\n *\n * @default new Date(2099, 11, 31)\n */\n maxDate?: Date\n /**\n * The minimum possible date.\n *\n * @default new Date(1900, 0, 1)\n */\n minDate?: Date\n /**\n * The month of the calendar.\n */\n month?: Date\n /**\n * If `true`, the calendar will be multiple.\n *\n * @default false\n */\n multiple?: Multiple\n /**\n * If `true`, enables date range selection.\n *\n * @default false\n */\n range?: Range\n /**\n * Define the start day of the week.\n *\n * @default 'monday'\n */\n startDayOfWeek?: StartDayOfWeek\n /**\n * If `true`, highlight today.\n *\n * @default true\n */\n today?: boolean\n /**\n * The value of the calendar.\n */\n value?: MaybeDateValue<Multiple, Range>\n /**\n * Define weekend days.\n *\n * @default [0, 6]\n */\n weekendDays?: number[]\n /**\n * Callback function to determine whether the day should be disabled.\n */\n excludeDate?: (date: Date) => boolean\n /**\n * The callback invoked when value state changes.\n */\n onChange?: (value: MaybeDateValue<Multiple, Range>) => void\n /**\n * The callback invoked when month state changes.\n */\n onChangeMonth?: (value: Date) => void\n}\n\nexport const useCalendar = <\n Multiple extends boolean = false,\n Range extends boolean = false,\n>({\n defaultMonth = new Date(),\n multiple = false as Multiple,\n range = false as Range,\n defaultValue = (range\n ? { end: undefined, start: undefined }\n : multiple\n ? []\n : undefined) as MaybeDateValue<Multiple, Range>,\n disabled = false,\n excludeDate,\n format = {},\n holidays = DEFAULT_HOLIDAYS,\n locale: localeProp,\n max,\n maxDate = DEFAULT_MAX_DATE,\n minDate = DEFAULT_MIN_DATE,\n month: monthProp,\n startDayOfWeek = DEFAULT_FIRST_DAY_OF_WEEK,\n today = true,\n value: valueProp,\n weekendDays = DEFAULT_WEEKEND_DAYS,\n onChange: onChangeProp,\n onChangeMonth: onChangeMonthProp,\n ...rest\n}: UseCalendarProps<Multiple, Range> = {}) => {\n if (dayjs(minDate).isAfter(dayjs(maxDate))) maxDate = minDate\n\n const { locale: defaultLocale, t } = useI18n(\"calendar\")\n const locale = localeProp ?? defaultLocale\n const dateTimeFormat = useDateTimeFormat({ locale })\n const yearFormat = useCallback(\n (value: Date) => {\n if (format.year === null) {\n return value.getFullYear().toString()\n } else {\n const year = format.year ?? \"numeric\"\n\n return dateTimeFormat(value, { year })\n }\n },\n [dateTimeFormat, format.year],\n )\n const monthFormat = useCallback(\n (value: Date) => {\n if (format.month === null) {\n return (value.getMonth() + 1).toString()\n } else {\n const month = format.month ?? \"short\"\n\n return dateTimeFormat(value, { month })\n }\n },\n [dateTimeFormat, format.month],\n )\n const weekdayFormat = useCallback(\n (value: Date) => {\n return dateTimeFormat(value, {\n weekday: format.weekday ?? \"short\",\n })\n },\n [dateTimeFormat, format.weekday],\n )\n const dayFormat = useCallback(\n (value: Date) => {\n if (format.day) {\n return dateTimeFormat(value, {\n day: format.day,\n })\n } else {\n return value.getDate().toString()\n }\n },\n [dateTimeFormat, format.day],\n )\n const descendants = useCalendarDescendants()\n const monthRef = useRef<HTMLTableElement>(null)\n const [value, setValue] = useControllableState({\n defaultValue,\n value: valueProp,\n onChange: onChangeProp,\n })\n const [month, setMonth] = useControllableState({\n defaultValue: () => {\n if (dayjs(minDate).isAfter(dayjs(defaultMonth)))\n defaultMonth = dayjs(minDate).set(\"date\", 1).toDate()\n\n if (valueProp) {\n defaultMonth = getAdjustedMonth(valueProp, defaultMonth)\n } else if (defaultValue) {\n defaultMonth = getAdjustedMonth(defaultValue, defaultMonth)\n }\n\n return defaultMonth\n },\n value: monthProp,\n onChange: onChangeMonthProp,\n })\n const { endOfMonth, startOfMonth } = useMemo(() => {\n const startOfMonth = dayjs(month).startOf(\"month\").toDate()\n const endOfMonth = dayjs(month).endOf(\"month\").toDate()\n\n return { endOfMonth, startOfMonth }\n }, [month])\n const weekdays = useMemo(\n () => getWeekdays(startDayOfWeek, weekdayFormat),\n [startDayOfWeek, weekdayFormat],\n )\n const monthDays = useMemo(\n () => getMonthDays(month, startDayOfWeek, dayFormat),\n [month, startDayOfWeek, dayFormat],\n )\n const yearItems = useMemo(() => {\n const minYear = dayjs(minDate).year()\n const maxYear = dayjs(maxDate).year()\n const yearItems: { label: string; value: string }[] = []\n\n for (let year = minYear; year <= maxYear; year++) {\n const label = yearFormat(dayjs().set(\"year\", year).toDate())\n const value = year.toString()\n\n yearItems.push({ label, value })\n }\n\n return yearItems\n }, [maxDate, minDate, yearFormat])\n const monthItems = useMemo(() => {\n const monthItems: { label: string; value: string }[] = []\n const date = dayjs(month).toDate()\n\n for (let month = 0; month < 12; month++) {\n date.setMonth(month)\n\n if (isAfterMonth(date, maxDate)) continue\n if (isBeforeMonth(date, minDate)) continue\n\n const label = monthFormat(dayjs().set(\"month\", month).toDate())\n const value = month.toString()\n\n monthItems.push({ label, value })\n }\n\n return monthItems\n }, [month, maxDate, minDate, monthFormat])\n\n const onChange = useCallback(\n (value: Date) => {\n if (isBeforeDate(value, minDate)) return\n if (isAfterDate(value, maxDate)) return\n\n setValue(\n (prev) =>\n updateMaybeDateValue(value, max)(prev) as MaybeDateValue<\n Multiple,\n Range\n >,\n )\n },\n [max, maxDate, minDate, setValue],\n )\n\n const onMonthChange = useCallback(\n (month: Date) => {\n if (isAfterMonth(month, maxDate)) {\n setMonth(dayjs(maxDate).set(\"date\", 1).toDate())\n } else if (isBeforeMonth(month, minDate)) {\n setMonth(dayjs(minDate).set(\"date\", 1).toDate())\n } else {\n setMonth((prev) => {\n if (isSameMonth(prev, month)) return prev\n\n return month\n })\n }\n },\n [maxDate, minDate, setMonth],\n )\n\n const onPrevMonth = useCallback(() => {\n setMonth((prev) => {\n if (isSameMonth(prev, minDate)) return prev\n\n return dayjs(prev).subtract(1, \"month\").toDate()\n })\n }, [minDate, setMonth])\n\n const onNextMonth = useCallback(() => {\n setMonth((prev) => {\n if (isSameMonth(prev, maxDate)) return prev\n\n return dayjs(prev).add(1, \"month\").toDate()\n })\n }, [maxDate, setMonth])\n\n const onFocus = useCallback(() => {\n let index: null | number = null\n let descendant: Descendant<HTMLTableCellElement> | undefined\n\n if (value) {\n if (isDate(value)) {\n if (isSameMonth(month, new Date())) index = new Date().getDate() - 1\n } else if (isArray(value)) {\n const firstValue = value[0]\n\n if (firstValue && isSameMonth(month, firstValue))\n index = firstValue.getDate() - 1\n } else if (isObject(value)) {\n if (value.start && isSameMonth(month, value.start)) {\n index = value.start.getDate() - 1\n } else if (value.end && isSameMonth(month, value.end)) {\n index = value.end.getDate() - 1\n }\n }\n } else if (isSameMonth(month, new Date())) {\n index = new Date().getDate() - 1\n }\n\n descendant = descendants.value(index)\n\n if (!descendant) descendant = descendants.enabledFirstValue()\n\n if (!descendant) return\n\n descendant.node.focus()\n descendant.node.tabIndex = 0\n\n if (monthRef.current) monthRef.current.tabIndex = -1\n }, [descendants, month, value])\n\n const onBlur = useCallback((ev: FocusEvent<HTMLTableElement>) => {\n if (contains(monthRef.current, ev.relatedTarget)) return\n\n if (monthRef.current) monthRef.current.tabIndex = 0\n }, [])\n\n useUpdateEffect(() => {\n setMonth((prev) => getAdjustedMonth(value, prev))\n }, [value])\n\n const getRootProps: PropGetter = useCallback(\n (props = {}) => ({\n \"data-disabled\": dataAttr(disabled),\n ...rest,\n ...props,\n }),\n [disabled, rest],\n )\n\n const getNavigationProps: PropGetter<\"nav\"> = useCallback(\n (props = {}) => ({ \"data-disabled\": dataAttr(disabled), ...props }),\n [disabled],\n )\n\n const getYearSelectProps: PropGetter<\n \"div\",\n { value?: string; onChange?: (value: string) => void },\n { value?: string; onChange?: (value: string) => void }\n > = useCallback(\n (props = {}) => ({\n \"aria-label\": t(\"Choose the year\"),\n disabled,\n value: dayjs(month).get(\"year\").toString(),\n ...props,\n onChange: handlerAll(props.onChange, (value) =>\n onMonthChange(dayjs(month).set(\"year\", parseInt(value)).toDate()),\n ),\n }),\n [disabled, month, onMonthChange, t],\n )\n\n const getMonthSelectProps: PropGetter<\n \"div\",\n { value?: string; onChange?: (value: string) => void },\n { value?: string; onChange?: (value: string) => void }\n > = useCallback(\n (props = {}) => ({\n \"aria-label\": t(\"Choose the month\"),\n disabled,\n value: dayjs(month).get(\"month\").toString(),\n ...props,\n onChange: handlerAll(props.onChange, (value) =>\n onMonthChange(dayjs(month).set(\"month\", parseInt(value)).toDate()),\n ),\n }),\n [disabled, month, onMonthChange, t],\n )\n\n const getStatusProps: PropGetter = useCallback(\n (props = {}) => ({\n style: visuallyHiddenAttributes.style,\n \"aria-live\": \"polite\",\n children: dateTimeFormat(dayjs(month).toDate(), {\n month: \"long\",\n year: \"numeric\",\n }),\n role: \"status\",\n ...props,\n }),\n [dateTimeFormat, month],\n )\n\n const getMonthProps: PropGetter<\"table\"> = useCallback(\n ({ ref, ...props } = {}) => ({\n ref: mergeRefs(ref, monthRef),\n \"aria-label\": dateTimeFormat(dayjs(month).toDate(), {\n month: \"long\",\n year: \"numeric\",\n }),\n \"aria-multiselectable\": ariaAttr(multiple || range),\n \"data-disabled\": dataAttr(disabled),\n role: \"grid\",\n tabIndex: disabled ? -1 : 0,\n ...props,\n onBlur: handlerAll(props.onBlur, onBlur),\n onFocus: handlerAll(props.onFocus, onFocus),\n }),\n [dateTimeFormat, disabled, month, multiple, onBlur, onFocus, range],\n )\n\n const getWeekdayProps: RequiredPropGetter<\"th\", { value: number }> =\n useCallback(\n ({ value, ...props }) => ({\n \"data-disabled\": dataAttr(disabled),\n \"data-value\": value.toString(),\n abbr: dateTimeFormat(dayjs().set(\"day\", value).toDate(), {\n weekday: \"long\",\n }),\n ...props,\n }),\n [dateTimeFormat, disabled],\n )\n\n const getButtonProps: PropGetter<\"button\"> = useCallback(\n (props) => ({\n type: \"button\",\n \"data-disabled\": dataAttr(disabled),\n ...props,\n }),\n [disabled],\n )\n\n const getPrevButtonProps: PropGetter<\"button\"> = useCallback(\n (props = {}) =>\n getButtonProps({\n \"aria-label\": t(\"Go to the previous month\"),\n disabled: isSameBeforeMonth(month, minDate),\n ...props,\n onClick: handlerAll(props.onClick, onPrevMonth),\n }),\n [getButtonProps, minDate, month, onPrevMonth, t],\n )\n\n const getNextButtonProps: PropGetter<\"button\"> = useCallback(\n (props = {}) =>\n getButtonProps({\n \"aria-label\": t(\"Go to the next month\"),\n disabled: isSameAfterMonth(month, maxDate),\n ...props,\n onClick: handlerAll(props.onClick, onNextMonth),\n }),\n [getButtonProps, maxDate, month, onNextMonth, t],\n )\n\n return {\n descendants,\n disabled,\n endOfMonth,\n excludeDate,\n holidays,\n locale,\n max,\n maxDate,\n minDate,\n month,\n monthDays,\n monthItems,\n multiple,\n range,\n startDayOfWeek,\n startOfMonth,\n today,\n value,\n weekdays,\n weekendDays,\n yearItems,\n getMonthProps,\n getMonthSelectProps,\n getNavigationProps,\n getNextButtonProps,\n getPrevButtonProps,\n getRootProps,\n getStatusProps,\n getWeekdayProps,\n getYearSelectProps,\n onChange,\n onMonthChange,\n onNextMonth,\n onPrevMonth,\n }\n}\n\nexport type UseCalendarReturn = ReturnType<typeof useCalendar>\n\nexport interface UseCalendarDayProps extends Omit<HTMLProps<\"td\">, \"value\"> {\n value: Date\n}\n\nexport const useCalendarDay = ({ value, ...rest }: UseCalendarDayProps) => {\n const { t } = useI18n(\"calendar\")\n const {\n disabled: rootDisabled,\n excludeDate,\n holidays,\n locale,\n max,\n maxDate,\n minDate,\n month,\n startDayOfWeek,\n today: highlightToday,\n value: selectedValue,\n weekendDays,\n onChange,\n onMonthChange,\n onNextMonth,\n onPrevMonth,\n } = useCalendarContext()\n const dateTimeFormat = useDateTimeFormat({ locale })\n const cellRef = useRef<HTMLTableCellElement>(null)\n const outside = useMemo(() => !isSameMonth(month, value), [month, value])\n const holiday = useMemo(\n () => holidays.some((holiday) => isSameDate(holiday, value)),\n [holidays, value],\n )\n const weekend = useMemo(\n () => weekendDays.includes(value.getDay()),\n [weekendDays, value],\n )\n const today = useMemo(\n () => highlightToday && isSameDate(value, new Date()),\n [highlightToday, value],\n )\n const selected = useMemo(() => {\n if (isDate(selectedValue)) {\n return isSameDate(selectedValue, value)\n } else if (isArray(selectedValue)) {\n return selectedValue.some((selectedValue) =>\n isSameDate(selectedValue, value),\n )\n } else if (isObject(selectedValue)) {\n return (\n isSameDate(selectedValue.start, value) ||\n isSameDate(selectedValue.end, value)\n )\n }\n }, [selectedValue, value])\n const disabled = useMemo(() => {\n if (rootDisabled) return true\n if (isAfterDate(value, maxDate)) return true\n if (isBeforeDate(value, minDate)) return true\n if (excludeDate?.(value)) return true\n if (\n isArray(selectedValue) &&\n isNumber(max) &&\n selectedValue.length >= max &&\n !isIncludeDates(value, selectedValue)\n )\n return true\n\n return false\n }, [excludeDate, max, maxDate, minDate, rootDisabled, selectedValue, value])\n const between = useMemo(() => {\n if (isDate(selectedValue) || isArray(selectedValue)) return false\n\n return isInRange(value, selectedValue?.start, selectedValue?.end)\n }, [selectedValue, value])\n const startValue = useMemo(() => {\n if (isDate(selectedValue) || isArray(selectedValue)) return false\n\n const { end, start } = selectedValue ?? {}\n\n return start && end && isSameDate(value, start)\n }, [selectedValue, value])\n const endValue = useMemo(() => {\n if (isDate(selectedValue) || isArray(selectedValue)) return false\n\n const { end, start } = selectedValue ?? {}\n\n return start && end && isSameDate(value, end)\n }, [selectedValue, value])\n const { descendants, register } = useCalendarDescendant({\n disabled: disabled,\n })\n\n const onFocusDescendant = useCallback(\n (descendant?: Descendant<HTMLTableCellElement>) => {\n if (!descendant) return\n\n descendant.node.focus()\n descendant.node.tabIndex = 0\n },\n [],\n )\n\n const onBlur = useCallback(() => {\n if (cellRef.current) cellRef.current.tabIndex = -1\n }, [])\n\n const onClick = useCallback(() => {\n if (disabled) return\n\n onChange(value)\n }, [disabled, onChange, value])\n\n const onPrevDate = useCallback(() => {\n const descendant = descendants.enabledPrevValue(cellRef.current, false)\n\n if (descendant) {\n onFocusDescendant(descendant)\n } else if (!isSameBeforeDate(value, minDate)) {\n onPrevMonth()\n\n setTimeout(() => onFocusDescendant(descendants.enabledLastValue()))\n }\n }, [descendants, minDate, onFocusDescendant, onPrevMonth, value])\n\n const onNextDate = useCallback(() => {\n const descendant = descendants.enabledNextValue(cellRef.current, false)\n\n if (descendant) {\n onFocusDescendant(descendant)\n } else if (!isSameAfterDate(value, maxDate)) {\n onNextMonth()\n\n setTimeout(() => onFocusDescendant(descendants.enabledFirstValue()))\n }\n }, [descendants, maxDate, onFocusDescendant, onNextMonth, value])\n\n const onPrevTraverseDate = useCallback(\n (date: Date) => {\n onMonthChange(dayjs(date).set(\"date\", 1).toDate())\n\n setTimeout(() => {\n const descendant = isBeforeDate(date, minDate)\n ? descendants.enabledFirstValue()\n : descendants.value(date.getDate() - 1)\n\n if (!descendant) return\n\n if (descendant.disabled) {\n onFocusDescendant(descendants.enabledNextValue(descendant, false))\n } else {\n onFocusDescendant(descendant)\n }\n })\n },\n [descendants, minDate, onFocusDescendant, onMonthChange],\n )\n\n const onNextTraverseDate = useCallback(\n (date: Date) => {\n onMonthChange(dayjs(date).set(\"date\", 1).toDate())\n\n setTimeout(() => {\n const descendant = isAfterDate(date, maxDate)\n ? descendants.enabledLastValue()\n : descendants.value(date.getDate() - 1)\n\n if (!descendant) return\n\n if (descendant.disabled) {\n onFocusDescendant(descendants.enabledPrevValue(descendant, false))\n } else {\n onFocusDescendant(descendant)\n }\n })\n },\n [descendants, maxDate, onFocusDescendant, onMonthChange],\n )\n\n const onKeyDown = useCallback(\n (ev: KeyboardEvent<HTMLTableCellElement>) => {\n runKeyAction(ev, {\n ArrowDown: () =>\n onNextTraverseDate(dayjs(value).add(1, \"week\").toDate()),\n ArrowLeft: onPrevDate,\n ArrowRight: onNextDate,\n ArrowUp: () =>\n onPrevTraverseDate(dayjs(value).subtract(1, \"week\").toDate()),\n End: () => onNextTraverseDate(getEndOfWeek(value, startDayOfWeek)),\n Enter: onClick,\n Home: () => onPrevTraverseDate(getStartOfWeek(value, startDayOfWeek)),\n PageDown: (ev) => {\n if (ev.shiftKey) {\n onNextTraverseDate(dayjs(value).add(1, \"year\").toDate())\n } else {\n onNextTraverseDate(dayjs(value).add(1, \"month\").toDate())\n }\n },\n PageUp: (ev) => {\n if (ev.shiftKey) {\n onPrevTraverseDate(dayjs(value).subtract(1, \"year\").toDate())\n } else {\n onPrevTraverseDate(dayjs(value).subtract(1, \"month\").toDate())\n }\n },\n Space: onClick,\n })\n },\n [\n onClick,\n onNextDate,\n onNextTraverseDate,\n onPrevDate,\n onPrevTraverseDate,\n startDayOfWeek,\n value,\n ],\n )\n\n const getDayProps: PropGetter<\"td\"> = useCallback(\n ({ ref, \"aria-label\": ariaLabel, ...props } = {}) => {\n if (!ariaLabel) {\n ariaLabel = dateTimeFormat(dayjs(value).toDate(), {\n day: \"numeric\",\n month: \"long\",\n weekday: \"long\",\n year: \"numeric\",\n })\n\n if (today) ariaLabel = `${t(\"Today\")}, ${ariaLabel}`\n }\n\n return {\n \"aria-disabled\": ariaAttr(disabled),\n \"aria-label\": ariaLabel,\n \"aria-selected\": ariaAttr(selected),\n \"data-between\": dataAttr(between),\n \"data-disabled\": dataAttr(disabled),\n \"data-end\": dataAttr(endValue),\n \"data-holiday\": dataAttr(holiday),\n \"data-outside\": dataAttr(outside),\n \"data-selected\": dataAttr(selected),\n \"data-start\": dataAttr(startValue),\n \"data-today\": dataAttr(today),\n \"data-value\": dayjs(value).format(\"YYYY-MM-DD\"),\n \"data-weekend\": dataAttr(weekend),\n tabIndex: -1,\n ...rest,\n ...props,\n ref: mergeRefs(ref, cellRef, outside ? null : register),\n onBlur: handlerAll(props.onBlur, onBlur),\n onClick: handlerAll(props.onClick, onClick),\n onFocus: handlerAll(props.onFocus, (ev) => ev.preventDefault()),\n onKeyDown: handlerAll(props.onKeyDown, onKeyDown),\n }\n },\n [\n between,\n dateTimeFormat,\n disabled,\n endValue,\n holiday,\n onBlur,\n onClick,\n onKeyDown,\n outside,\n register,\n rest,\n selected,\n startValue,\n t,\n today,\n value,\n weekend,\n ],\n )\n\n return { outside, getDayProps }\n}\n\nexport type UseCalendarDayReturn = ReturnType<typeof useCalendarDay>\n\nconst calendarProps: (keyof UseCalendarProps)[] = [\n \"defaultMonth\",\n \"defaultValue\",\n \"disabled\",\n \"excludeDate\",\n \"format\",\n \"holidays\",\n \"locale\",\n \"max\",\n \"maxDate\",\n \"minDate\",\n \"month\",\n \"range\",\n \"startDayOfWeek\",\n \"today\",\n \"value\",\n \"weekendDays\",\n \"onChange\",\n \"onChangeMonth\",\n]\n\nexport const useCalendarProps = <\n Y extends boolean = false,\n M extends boolean = false,\n D extends Dict = Dict,\n H extends keyof UseCalendarProps<Y, M> = keyof UseCalendarProps<Y, M>,\n>(\n props: D,\n omitKeys?: H[],\n) => {\n return useSplitProps(\n props,\n calendarProps.filter((key) => !omitKeys?.includes(key as H)),\n ) as unknown as [\n keyof UseCalendarProps<Y, M> extends H\n ? UseCalendarProps<Y, M>\n : Omit<UseCalendarProps<Y, M>, H>,\n Omit<\n M,\n keyof UseCalendarProps<Y, M> extends H\n ? keyof UseCalendarProps<Y, M>\n : Exclude<keyof UseCalendarProps<Y, M>, H>\n >,\n ]\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"use-calendar.cjs","names":["DEFAULT_HOLIDAYS: Date[]","DEFAULT_WEEKEND_DAYS: number[]","DEFAULT_FIRST_DAY_OF_WEEK: StartDayOfWeek","DEFAULT_MAX_DATE: Date","DEFAULT_MIN_DATE: Date","weekdays: { label: string; value: number }[]","weeks: { label: string; value: Date }[][]","days: { label: string; value: Date }[]","createDescendants","createContext","useI18n","useDateTimeFormat","value","useControllableState","startOfMonth","yearItems: { label: string; value: string }[]","yearItems","monthItems: { label: string; value: string }[]","month","monthItems","index: null | number","descendant: Descendant<HTMLTableCellElement> | undefined","getRootProps: PropGetter","mergeProps","getNavigationProps: PropGetter<\"nav\">","getYearSelectProps: PropGetter<\n \"div\",\n { value?: string; onChange?: (value: string) => void },\n { value?: string; onChange?: (value: string) => void }\n >","getMonthSelectProps: PropGetter<\n \"div\",\n { value?: string; onChange?: (value: string) => void },\n { value?: string; onChange?: (value: string) => void }\n >","getStatusProps: PropGetter","visuallyHiddenAttributes","getMonthProps: PropGetter<\"table\">","mergeRefs","getWeekdayProps: RequiredPropGetter<\"th\", { value: number }>","getButtonProps: PropGetter<\"button\">","getPrevButtonProps: PropGetter<\"button\">","getNextButtonProps: PropGetter<\"button\">","holiday","selectedValue","ev","calendarProps: (keyof UseCalendarProps)[]","useSplitProps"],"sources":["../../../../src/components/calendar/use-calendar.ts"],"sourcesContent":["\"use client\"\n\nimport type { FocusEvent, KeyboardEvent } from \"react\"\nimport type { HTMLProps, PropGetter, RequiredPropGetter } from \"../../core\"\nimport type { Descendant } from \"../../hooks/use-descendants\"\nimport type { Locale } from \"../../providers/i18n-provider\"\nimport type { AnyString, Dict } from \"../../utils\"\nimport dayjs from \"dayjs\"\nimport { useCallback, useMemo, useRef } from \"react\"\nimport { mergeProps, useSplitProps } from \"../../core\"\nimport { useControllableState } from \"../../hooks/use-controllable-state\"\nimport { createDescendants } from \"../../hooks/use-descendants\"\nimport { useI18n } from \"../../providers/i18n-provider\"\nimport {\n ariaAttr,\n contains,\n createContext,\n dataAttr,\n handlerAll,\n isArray,\n isDate,\n isNumber,\n isObject,\n mergeRefs,\n runKeyAction,\n useUpdateEffect,\n visuallyHiddenAttributes,\n} from \"../../utils\"\nimport { useDateTimeFormat } from \"../format\"\n\nexport const DEFAULT_HOLIDAYS: Date[] = []\nexport const DEFAULT_WEEKEND_DAYS: number[] = [0, 6]\nexport const DEFAULT_FIRST_DAY_OF_WEEK: StartDayOfWeek = \"sunday\"\nexport const DEFAULT_MAX_DATE: Date = new Date(\"2099-12-31\")\nexport const DEFAULT_MIN_DATE: Date = new Date(\"1900-01-01\")\n\nexport type MaybeDate = Date | Date[] | undefined | { end?: Date; start?: Date }\nexport type MaybeDateValue<\n Multiple extends boolean = false,\n Range extends boolean = false,\n> = Range extends true\n ? { end?: Date; start?: Date }\n : Multiple extends true\n ? Date[]\n : Date | undefined\nexport type StartDayOfWeek = \"monday\" | \"sunday\"\nexport interface CalendarFormat {\n day?: Intl.DateTimeFormatOptions[\"day\"] | null\n month?: Intl.DateTimeFormatOptions[\"month\"] | null\n weekday?: Intl.DateTimeFormatOptions[\"weekday\"] | null\n year?: Intl.DateTimeFormatOptions[\"year\"] | null\n}\n\nexport const getStartOfWeek = (\n date: Date,\n startDayOfWeek: StartDayOfWeek,\n): Date =>\n dayjs(date)\n .subtract(startDayOfWeek === \"monday\" ? 1 : 0, \"day\")\n .startOf(\"week\")\n .add(startDayOfWeek === \"monday\" ? 1 : 0, \"day\")\n .toDate()\n\nexport const getEndOfWeek = (\n date: Date,\n startDayOfWeek: StartDayOfWeek,\n): Date =>\n dayjs(date)\n .subtract(startDayOfWeek === \"monday\" ? 1 : 0, \"day\")\n .endOf(\"week\")\n .add(startDayOfWeek === \"monday\" ? 1 : 0, \"day\")\n .toDate()\n\nexport const getWeekdays = (\n startDayOfWeek: StartDayOfWeek,\n format: (value: Date) => string,\n): { label: string; value: number }[] => {\n let weekdays: { label: string; value: number }[] = []\n\n const date = getStartOfWeek(new Date(), startDayOfWeek)\n\n for (let i = 0; i < 7; i += 1) {\n const label = format(date)\n const value = date.getDay()\n\n weekdays = [...weekdays, { label, value }]\n\n date.setDate(date.getDate() + 1)\n }\n\n return weekdays\n}\n\nexport const getMonthDays = (\n date: Date,\n startDayOfWeek: StartDayOfWeek,\n format: (value: Date) => string,\n): { label: string; value: Date }[][] => {\n const currentMonth = date.getMonth()\n const startOfMonth = new Date(date.getFullYear(), currentMonth, 1)\n const endOfMonth = new Date(date.getFullYear(), date.getMonth() + 1, 0)\n const startDate = getStartOfWeek(startOfMonth, startDayOfWeek)\n const endDate = getEndOfWeek(endOfMonth, startDayOfWeek)\n\n const weeks: { label: string; value: Date }[][] = []\n\n while (startDate <= endDate) {\n const days: { label: string; value: Date }[] = []\n\n for (let i = 0; i < 7; i += 1) {\n const value = new Date(startDate)\n const label = format(value)\n\n days.push({ label, value })\n\n startDate.setDate(startDate.getDate() + 1)\n }\n\n weeks.push(days)\n }\n\n return weeks\n}\n\nexport const isSameYear = (\n date: Date | undefined,\n comparison: Date | undefined,\n): boolean =>\n date instanceof Date &&\n comparison instanceof Date &&\n dayjs(date).isSame(comparison, \"year\")\n\nexport const isSameMonth = (\n date: Date | undefined,\n comparison: Date | undefined,\n): boolean =>\n date instanceof Date &&\n comparison instanceof Date &&\n dayjs(date).isSame(comparison, \"month\")\n\nexport const isSameDate = (\n date: Date | undefined,\n comparison: Date | undefined,\n) =>\n date instanceof Date &&\n comparison instanceof Date &&\n dayjs(date).isSame(comparison, \"date\")\n\nexport const isAfterDate = (value: Date, date: Date | undefined) =>\n date instanceof Date && dayjs(value).isAfter(date, \"date\")\n\nexport const isBeforeDate = (value: Date, date: Date | undefined) =>\n date instanceof Date && dayjs(value).isBefore(date, \"date\")\n\nexport const isSameAfterDate = (value: Date, date: Date | undefined) =>\n date instanceof Date &&\n (dayjs(date).isSame(value, \"date\") || dayjs(value).isAfter(date, \"date\"))\n\nexport const isSameBeforeDate = (value: Date, date: Date | undefined) =>\n date instanceof Date &&\n (dayjs(date).isSame(value, \"date\") || dayjs(value).isBefore(date, \"date\"))\n\nexport const isAfterMonth = (value: Date, date: Date | undefined) =>\n date instanceof Date && dayjs(value).isAfter(date, \"month\")\n\nexport const isBeforeMonth = (value: Date, date: Date | undefined) =>\n date instanceof Date && dayjs(value).isBefore(date, \"month\")\n\nexport const isSameAfterMonth = (value: Date, date: Date | undefined) =>\n date instanceof Date &&\n (dayjs(date).isSame(value, \"month\") || dayjs(value).isAfter(date, \"month\"))\n\nexport const isSameBeforeMonth = (value: Date, date: Date | undefined) =>\n date instanceof Date &&\n (dayjs(date).isSame(value, \"month\") || dayjs(value).isBefore(date, \"month\"))\n\nexport const isAfterYear = (value: Date, date: Date | undefined) =>\n date instanceof Date && dayjs(value).isAfter(date, \"year\")\n\nexport const isBeforeYear = (value: Date, date: Date | undefined) =>\n date instanceof Date && dayjs(value).isBefore(date, \"year\")\n\nexport const isSameAfterYear = (value: Date, date: Date | undefined) =>\n date instanceof Date &&\n (dayjs(date).isSame(value, \"year\") || dayjs(value).isAfter(date, \"year\"))\n\nexport const isSameBeforeYear = (value: Date, date: Date | undefined) =>\n date instanceof Date &&\n (dayjs(date).isSame(value, \"year\") || dayjs(value).isBefore(date, \"year\"))\n\nexport const isIncludeDates = (comparison: Date, dates: Date[]) =>\n dates.some((date) => dayjs(date).isSame(comparison, \"date\"))\n\nexport const isInRange = (date: Date, minDate?: Date, maxDate?: Date) => {\n const hasMinDate = minDate instanceof Date\n const hasMaxDate = maxDate instanceof Date\n\n if (!hasMaxDate && !hasMinDate) return false\n\n const minInRange = hasMinDate ? isAfterDate(date, minDate) : false\n const maxInRange = hasMaxDate ? isBeforeDate(date, maxDate) : false\n\n return maxInRange && minInRange\n}\n\nexport const sortDates = (dates: Date[], type: \"asc\" | \"desc\" = \"asc\") => {\n if (type === \"asc\") {\n return dates.sort((a, b) => (dayjs(a).isAfter(b, \"date\") ? 1 : -1))\n } else {\n return dates.sort((a, b) => (dayjs(a).isBefore(b, \"date\") ? 1 : -1))\n }\n}\n\nexport const updateMaybeDateValue =\n (value: Date, max?: number) =>\n (prev: MaybeDate): MaybeDate => {\n if (isArray(prev)) {\n if (isIncludeDates(value, prev)) {\n return prev.filter((prevValue) => !isSameDate(prevValue, value))\n } else if (!isNumber(max) || prev.length < max) {\n return [...prev, value]\n } else {\n return prev\n }\n } else if (isObject(prev) && !isDate(prev)) {\n const { end, start } = prev\n\n if ((start && end) || !start) {\n return { end: undefined, start: value }\n } else {\n if (isSameDate(start, value)) {\n return { end: undefined, start: undefined }\n } else if (isBeforeDate(value, start)) {\n return { end: start, start: value }\n } else {\n return { end: value, start }\n }\n }\n } else {\n if (isSameDate(prev, value)) {\n return undefined\n } else {\n return value\n }\n }\n }\n\nexport const getAdjustedMonth = (value: MaybeDate, month: Date) => {\n if (isDate(value)) {\n if (!isSameMonth(value, month)) month = dayjs(value).set(\"date\", 1).toDate()\n } else if (isArray(value)) {\n const lastValue = value.at(-1)\n\n if (lastValue && !isSameMonth(lastValue, month))\n month = dayjs(lastValue).set(\"date\", 1).toDate()\n } else if (isObject(value)) {\n if (value.end) {\n month = dayjs(value.end).set(\"date\", 1).toDate()\n } else if (value.start) {\n month = dayjs(value.start).set(\"date\", 1).toDate()\n }\n }\n\n return month\n}\n\nconst {\n DescendantsContext: CalendarDescendantsContext,\n useDescendant: useCalendarDescendant,\n useDescendants: useCalendarDescendants,\n} = createDescendants<HTMLTableCellElement>()\n\nexport {\n CalendarDescendantsContext,\n useCalendarDescendant,\n useCalendarDescendants,\n}\n\ninterface CalendarContext extends Omit<\n UseCalendarReturn,\n | \"descendants\"\n | \"getMonthProps\"\n | \"getMonthSelectProps\"\n | \"getNavigationProps\"\n | \"getNextButtonProps\"\n | \"getPrevButtonProps\"\n | \"getRootProps\"\n | \"getStatusProps\"\n | \"getWeekdayProps\"\n | \"getYearSelectProps\"\n | \"monthDays\"\n | \"monthItems\"\n | \"weekdays\"\n | \"yearItems\"\n> {}\n\nconst [CalendarContext, useCalendarContext] = createContext<CalendarContext>({\n name: \"CalendarContext\",\n})\n\nexport { CalendarContext, useCalendarContext }\n\nexport interface UseCalendarProps<\n Multiple extends boolean = false,\n Range extends boolean = false,\n> extends Omit<HTMLProps, \"defaultValue\" | \"onChange\"> {\n /**\n * The initial month of the calendar.\n *\n * @default new Date()\n */\n defaultMonth?: Date\n /**\n * The initial value of the calendar.\n */\n defaultValue?: MaybeDateValue<Multiple, Range>\n /**\n * If `true`, disables the calendar.\n *\n * @default false\n */\n disabled?: boolean\n /**\n * The format used for conversion.\n * Check the docs to see the format of possible modifiers you can pass.\n *\n * @see https://day.js.org/docs/en/display/format#list-of-localized-formats\n */\n format?: CalendarFormat\n /**\n * Define holidays.\n */\n holidays?: Date[]\n /**\n * The locale of the calendar.\n *\n * @default 'en-US'\n */\n locale?: AnyString | Locale\n /**\n * The maximum selectable value.\n */\n max?: number\n /**\n * The maximum possible date.\n *\n * @default new Date(2099, 11, 31)\n */\n maxDate?: Date\n /**\n * The minimum possible date.\n *\n * @default new Date(1900, 0, 1)\n */\n minDate?: Date\n /**\n * The month of the calendar.\n */\n month?: Date\n /**\n * If `true`, the calendar will be multiple.\n *\n * @default false\n */\n multiple?: Multiple\n /**\n * If `true`, enables date range selection.\n *\n * @default false\n */\n range?: Range\n /**\n * Define the start day of the week.\n *\n * @default 'monday'\n */\n startDayOfWeek?: StartDayOfWeek\n /**\n * If `true`, highlight today.\n *\n * @default true\n */\n today?: boolean\n /**\n * The value of the calendar.\n */\n value?: MaybeDateValue<Multiple, Range>\n /**\n * Define weekend days.\n *\n * @default [0, 6]\n */\n weekendDays?: number[]\n /**\n * Callback function to determine whether the day should be disabled.\n */\n excludeDate?: (date: Date) => boolean\n /**\n * The callback invoked when value state changes.\n */\n onChange?: (value: MaybeDateValue<Multiple, Range>) => void\n /**\n * The callback invoked when month state changes.\n */\n onChangeMonth?: (value: Date) => void\n}\n\nexport const useCalendar = <\n Multiple extends boolean = false,\n Range extends boolean = false,\n>({\n defaultMonth = new Date(),\n multiple = false as Multiple,\n range = false as Range,\n defaultValue = (range\n ? { end: undefined, start: undefined }\n : multiple\n ? []\n : undefined) as MaybeDateValue<Multiple, Range>,\n disabled = false,\n excludeDate,\n format = {},\n holidays = DEFAULT_HOLIDAYS,\n locale: localeProp,\n max,\n maxDate = DEFAULT_MAX_DATE,\n minDate = DEFAULT_MIN_DATE,\n month: monthProp,\n startDayOfWeek = DEFAULT_FIRST_DAY_OF_WEEK,\n today = true,\n value: valueProp,\n weekendDays = DEFAULT_WEEKEND_DAYS,\n onChange: onChangeProp,\n onChangeMonth: onChangeMonthProp,\n ...rest\n}: UseCalendarProps<Multiple, Range> = {}) => {\n if (dayjs(minDate).isAfter(dayjs(maxDate))) maxDate = minDate\n\n const { locale: defaultLocale, t } = useI18n(\"calendar\")\n const locale = localeProp ?? defaultLocale\n const dateTimeFormat = useDateTimeFormat({ locale })\n const yearFormat = useCallback(\n (value: Date) => {\n if (format.year === null) {\n return value.getFullYear().toString()\n } else {\n const year = format.year ?? \"numeric\"\n\n return dateTimeFormat(value, { year })\n }\n },\n [dateTimeFormat, format.year],\n )\n const monthFormat = useCallback(\n (value: Date) => {\n if (format.month === null) {\n return (value.getMonth() + 1).toString()\n } else {\n const month = format.month ?? \"short\"\n\n return dateTimeFormat(value, { month })\n }\n },\n [dateTimeFormat, format.month],\n )\n const weekdayFormat = useCallback(\n (value: Date) => {\n return dateTimeFormat(value, {\n weekday: format.weekday ?? \"short\",\n })\n },\n [dateTimeFormat, format.weekday],\n )\n const dayFormat = useCallback(\n (value: Date) => {\n if (format.day) {\n return dateTimeFormat(value, {\n day: format.day,\n })\n } else {\n return value.getDate().toString()\n }\n },\n [dateTimeFormat, format.day],\n )\n const descendants = useCalendarDescendants()\n const monthRef = useRef<HTMLTableElement>(null)\n const [value, setValue] = useControllableState({\n defaultValue,\n value: valueProp,\n onChange: onChangeProp,\n })\n const [month, setMonth] = useControllableState({\n defaultValue: () => {\n if (dayjs(minDate).isAfter(dayjs(defaultMonth)))\n defaultMonth = dayjs(minDate).set(\"date\", 1).toDate()\n\n if (valueProp) {\n defaultMonth = getAdjustedMonth(valueProp, defaultMonth)\n } else if (defaultValue) {\n defaultMonth = getAdjustedMonth(defaultValue, defaultMonth)\n }\n\n return defaultMonth\n },\n value: monthProp,\n onChange: onChangeMonthProp,\n })\n const { endOfMonth, startOfMonth } = useMemo(() => {\n const startOfMonth = dayjs(month).startOf(\"month\").toDate()\n const endOfMonth = dayjs(month).endOf(\"month\").toDate()\n\n return { endOfMonth, startOfMonth }\n }, [month])\n const weekdays = useMemo(\n () => getWeekdays(startDayOfWeek, weekdayFormat),\n [startDayOfWeek, weekdayFormat],\n )\n const monthDays = useMemo(\n () => getMonthDays(month, startDayOfWeek, dayFormat),\n [month, startDayOfWeek, dayFormat],\n )\n const yearItems = useMemo(() => {\n const minYear = dayjs(minDate).year()\n const maxYear = dayjs(maxDate).year()\n const yearItems: { label: string; value: string }[] = []\n\n for (let year = minYear; year <= maxYear; year++) {\n const label = yearFormat(dayjs().set(\"year\", year).toDate())\n const value = year.toString()\n\n yearItems.push({ label, value })\n }\n\n return yearItems\n }, [maxDate, minDate, yearFormat])\n const monthItems = useMemo(() => {\n const monthItems: { label: string; value: string }[] = []\n const date = dayjs(month).toDate()\n\n for (let month = 0; month < 12; month++) {\n date.setMonth(month)\n\n if (isAfterMonth(date, maxDate)) continue\n if (isBeforeMonth(date, minDate)) continue\n\n const label = monthFormat(dayjs().set(\"month\", month).toDate())\n const value = month.toString()\n\n monthItems.push({ label, value })\n }\n\n return monthItems\n }, [month, maxDate, minDate, monthFormat])\n\n const onChange = useCallback(\n (value: Date) => {\n if (isBeforeDate(value, minDate)) return\n if (isAfterDate(value, maxDate)) return\n\n setValue(\n (prev) =>\n updateMaybeDateValue(value, max)(prev) as MaybeDateValue<\n Multiple,\n Range\n >,\n )\n },\n [max, maxDate, minDate, setValue],\n )\n\n const onMonthChange = useCallback(\n (month: Date) => {\n if (isAfterMonth(month, maxDate)) {\n setMonth(dayjs(maxDate).set(\"date\", 1).toDate())\n } else if (isBeforeMonth(month, minDate)) {\n setMonth(dayjs(minDate).set(\"date\", 1).toDate())\n } else {\n setMonth((prev) => {\n if (isSameMonth(prev, month)) return prev\n\n return month\n })\n }\n },\n [maxDate, minDate, setMonth],\n )\n\n const onPrevMonth = useCallback(() => {\n setMonth((prev) => {\n if (isSameMonth(prev, minDate)) return prev\n\n return dayjs(prev).subtract(1, \"month\").toDate()\n })\n }, [minDate, setMonth])\n\n const onNextMonth = useCallback(() => {\n setMonth((prev) => {\n if (isSameMonth(prev, maxDate)) return prev\n\n return dayjs(prev).add(1, \"month\").toDate()\n })\n }, [maxDate, setMonth])\n\n const onFocus = useCallback(() => {\n let index: null | number = null\n let descendant: Descendant<HTMLTableCellElement> | undefined\n\n if (value) {\n if (isDate(value)) {\n if (isSameMonth(month, new Date())) index = new Date().getDate() - 1\n } else if (isArray(value)) {\n const firstValue = value[0]\n\n if (firstValue && isSameMonth(month, firstValue))\n index = firstValue.getDate() - 1\n } else if (isObject(value)) {\n if (value.start && isSameMonth(month, value.start)) {\n index = value.start.getDate() - 1\n } else if (value.end && isSameMonth(month, value.end)) {\n index = value.end.getDate() - 1\n }\n }\n } else if (isSameMonth(month, new Date())) {\n index = new Date().getDate() - 1\n }\n\n descendant = descendants.value(index)\n\n if (!descendant) descendant = descendants.enabledFirstValue()\n\n if (!descendant) return\n\n descendant.node.focus()\n descendant.node.tabIndex = 0\n\n if (monthRef.current) monthRef.current.tabIndex = -1\n }, [descendants, month, value])\n\n const onBlur = useCallback((ev: FocusEvent<HTMLTableElement>) => {\n if (contains(monthRef.current, ev.relatedTarget)) return\n\n if (monthRef.current) monthRef.current.tabIndex = 0\n }, [])\n\n useUpdateEffect(() => {\n setMonth((prev) => getAdjustedMonth(value, prev))\n }, [value])\n\n const getRootProps: PropGetter = useCallback(\n (props = {}) =>\n mergeProps({ \"data-disabled\": dataAttr(disabled) }, rest, props)(),\n [disabled, rest],\n )\n\n const getNavigationProps: PropGetter<\"nav\"> = useCallback(\n (props = {}) => ({ \"data-disabled\": dataAttr(disabled), ...props }),\n [disabled],\n )\n\n const getYearSelectProps: PropGetter<\n \"div\",\n { value?: string; onChange?: (value: string) => void },\n { value?: string; onChange?: (value: string) => void }\n > = useCallback(\n (props = {}) => ({\n \"aria-label\": t(\"Choose the year\"),\n disabled,\n value: dayjs(month).get(\"year\").toString(),\n ...props,\n onChange: handlerAll(props.onChange, (value) =>\n onMonthChange(dayjs(month).set(\"year\", parseInt(value)).toDate()),\n ),\n }),\n [disabled, month, onMonthChange, t],\n )\n\n const getMonthSelectProps: PropGetter<\n \"div\",\n { value?: string; onChange?: (value: string) => void },\n { value?: string; onChange?: (value: string) => void }\n > = useCallback(\n (props = {}) => ({\n \"aria-label\": t(\"Choose the month\"),\n disabled,\n value: dayjs(month).get(\"month\").toString(),\n ...props,\n onChange: handlerAll(props.onChange, (value) =>\n onMonthChange(dayjs(month).set(\"month\", parseInt(value)).toDate()),\n ),\n }),\n [disabled, month, onMonthChange, t],\n )\n\n const getStatusProps: PropGetter = useCallback(\n (props = {}) => ({\n style: visuallyHiddenAttributes.style,\n \"aria-live\": \"polite\",\n children: dateTimeFormat(dayjs(month).toDate(), {\n month: \"long\",\n year: \"numeric\",\n }),\n role: \"status\",\n ...props,\n }),\n [dateTimeFormat, month],\n )\n\n const getMonthProps: PropGetter<\"table\"> = useCallback(\n ({ ref, ...props } = {}) => ({\n ref: mergeRefs(ref, monthRef),\n \"aria-label\": dateTimeFormat(dayjs(month).toDate(), {\n month: \"long\",\n year: \"numeric\",\n }),\n \"aria-multiselectable\": ariaAttr(multiple || range),\n \"data-disabled\": dataAttr(disabled),\n role: \"grid\",\n tabIndex: disabled ? -1 : 0,\n ...props,\n onBlur: handlerAll(props.onBlur, onBlur),\n onFocus: handlerAll(props.onFocus, onFocus),\n }),\n [dateTimeFormat, disabled, month, multiple, onBlur, onFocus, range],\n )\n\n const getWeekdayProps: RequiredPropGetter<\"th\", { value: number }> =\n useCallback(\n ({ value, ...props }) => ({\n \"data-disabled\": dataAttr(disabled),\n \"data-value\": value.toString(),\n abbr: dateTimeFormat(dayjs().set(\"day\", value).toDate(), {\n weekday: \"long\",\n }),\n ...props,\n }),\n [dateTimeFormat, disabled],\n )\n\n const getButtonProps: PropGetter<\"button\"> = useCallback(\n (props) => ({\n type: \"button\",\n \"data-disabled\": dataAttr(disabled),\n ...props,\n }),\n [disabled],\n )\n\n const getPrevButtonProps: PropGetter<\"button\"> = useCallback(\n (props = {}) =>\n getButtonProps({\n \"aria-label\": t(\"Go to the previous month\"),\n disabled: isSameBeforeMonth(month, minDate),\n ...props,\n onClick: handlerAll(props.onClick, onPrevMonth),\n }),\n [getButtonProps, minDate, month, onPrevMonth, t],\n )\n\n const getNextButtonProps: PropGetter<\"button\"> = useCallback(\n (props = {}) =>\n getButtonProps({\n \"aria-label\": t(\"Go to the next month\"),\n disabled: isSameAfterMonth(month, maxDate),\n ...props,\n onClick: handlerAll(props.onClick, onNextMonth),\n }),\n [getButtonProps, maxDate, month, onNextMonth, t],\n )\n\n return {\n descendants,\n disabled,\n endOfMonth,\n excludeDate,\n holidays,\n locale,\n max,\n maxDate,\n minDate,\n month,\n monthDays,\n monthItems,\n multiple,\n range,\n startDayOfWeek,\n startOfMonth,\n today,\n value,\n weekdays,\n weekendDays,\n yearItems,\n getMonthProps,\n getMonthSelectProps,\n getNavigationProps,\n getNextButtonProps,\n getPrevButtonProps,\n getRootProps,\n getStatusProps,\n getWeekdayProps,\n getYearSelectProps,\n onChange,\n onMonthChange,\n onNextMonth,\n onPrevMonth,\n }\n}\n\nexport type UseCalendarReturn = ReturnType<typeof useCalendar>\n\nexport interface UseCalendarDayProps extends Omit<HTMLProps<\"td\">, \"value\"> {\n value: Date\n}\n\nexport const useCalendarDay = ({ value, ...rest }: UseCalendarDayProps) => {\n const { t } = useI18n(\"calendar\")\n const {\n disabled: rootDisabled,\n excludeDate,\n holidays,\n locale,\n max,\n maxDate,\n minDate,\n month,\n startDayOfWeek,\n today: highlightToday,\n value: selectedValue,\n weekendDays,\n onChange,\n onMonthChange,\n onNextMonth,\n onPrevMonth,\n } = useCalendarContext()\n const dateTimeFormat = useDateTimeFormat({ locale })\n const cellRef = useRef<HTMLTableCellElement>(null)\n const outside = useMemo(() => !isSameMonth(month, value), [month, value])\n const holiday = useMemo(\n () => holidays.some((holiday) => isSameDate(holiday, value)),\n [holidays, value],\n )\n const weekend = useMemo(\n () => weekendDays.includes(value.getDay()),\n [weekendDays, value],\n )\n const today = useMemo(\n () => highlightToday && isSameDate(value, new Date()),\n [highlightToday, value],\n )\n const selected = useMemo(() => {\n if (isDate(selectedValue)) {\n return isSameDate(selectedValue, value)\n } else if (isArray(selectedValue)) {\n return selectedValue.some((selectedValue) =>\n isSameDate(selectedValue, value),\n )\n } else if (isObject(selectedValue)) {\n return (\n isSameDate(selectedValue.start, value) ||\n isSameDate(selectedValue.end, value)\n )\n }\n }, [selectedValue, value])\n const disabled = useMemo(() => {\n if (rootDisabled) return true\n if (isAfterDate(value, maxDate)) return true\n if (isBeforeDate(value, minDate)) return true\n if (excludeDate?.(value)) return true\n if (\n isArray(selectedValue) &&\n isNumber(max) &&\n selectedValue.length >= max &&\n !isIncludeDates(value, selectedValue)\n )\n return true\n\n return false\n }, [excludeDate, max, maxDate, minDate, rootDisabled, selectedValue, value])\n const between = useMemo(() => {\n if (isDate(selectedValue) || isArray(selectedValue)) return false\n\n return isInRange(value, selectedValue?.start, selectedValue?.end)\n }, [selectedValue, value])\n const startValue = useMemo(() => {\n if (isDate(selectedValue) || isArray(selectedValue)) return false\n\n const { end, start } = selectedValue ?? {}\n\n return start && end && isSameDate(value, start)\n }, [selectedValue, value])\n const endValue = useMemo(() => {\n if (isDate(selectedValue) || isArray(selectedValue)) return false\n\n const { end, start } = selectedValue ?? {}\n\n return start && end && isSameDate(value, end)\n }, [selectedValue, value])\n const { descendants, register } = useCalendarDescendant({\n disabled: disabled,\n })\n\n const onFocusDescendant = useCallback(\n (descendant?: Descendant<HTMLTableCellElement>) => {\n if (!descendant) return\n\n descendant.node.focus()\n descendant.node.tabIndex = 0\n },\n [],\n )\n\n const onBlur = useCallback(() => {\n if (cellRef.current) cellRef.current.tabIndex = -1\n }, [])\n\n const onClick = useCallback(() => {\n if (disabled) return\n\n onChange(value)\n }, [disabled, onChange, value])\n\n const onPrevDate = useCallback(() => {\n const descendant = descendants.enabledPrevValue(cellRef.current, false)\n\n if (descendant) {\n onFocusDescendant(descendant)\n } else if (!isSameBeforeDate(value, minDate)) {\n onPrevMonth()\n\n setTimeout(() => onFocusDescendant(descendants.enabledLastValue()))\n }\n }, [descendants, minDate, onFocusDescendant, onPrevMonth, value])\n\n const onNextDate = useCallback(() => {\n const descendant = descendants.enabledNextValue(cellRef.current, false)\n\n if (descendant) {\n onFocusDescendant(descendant)\n } else if (!isSameAfterDate(value, maxDate)) {\n onNextMonth()\n\n setTimeout(() => onFocusDescendant(descendants.enabledFirstValue()))\n }\n }, [descendants, maxDate, onFocusDescendant, onNextMonth, value])\n\n const onPrevTraverseDate = useCallback(\n (date: Date) => {\n onMonthChange(dayjs(date).set(\"date\", 1).toDate())\n\n setTimeout(() => {\n const descendant = isBeforeDate(date, minDate)\n ? descendants.enabledFirstValue()\n : descendants.value(date.getDate() - 1)\n\n if (!descendant) return\n\n if (descendant.disabled) {\n onFocusDescendant(descendants.enabledNextValue(descendant, false))\n } else {\n onFocusDescendant(descendant)\n }\n })\n },\n [descendants, minDate, onFocusDescendant, onMonthChange],\n )\n\n const onNextTraverseDate = useCallback(\n (date: Date) => {\n onMonthChange(dayjs(date).set(\"date\", 1).toDate())\n\n setTimeout(() => {\n const descendant = isAfterDate(date, maxDate)\n ? descendants.enabledLastValue()\n : descendants.value(date.getDate() - 1)\n\n if (!descendant) return\n\n if (descendant.disabled) {\n onFocusDescendant(descendants.enabledPrevValue(descendant, false))\n } else {\n onFocusDescendant(descendant)\n }\n })\n },\n [descendants, maxDate, onFocusDescendant, onMonthChange],\n )\n\n const onKeyDown = useCallback(\n (ev: KeyboardEvent<HTMLTableCellElement>) => {\n runKeyAction(ev, {\n ArrowDown: () =>\n onNextTraverseDate(dayjs(value).add(1, \"week\").toDate()),\n ArrowLeft: onPrevDate,\n ArrowRight: onNextDate,\n ArrowUp: () =>\n onPrevTraverseDate(dayjs(value).subtract(1, \"week\").toDate()),\n End: () => onNextTraverseDate(getEndOfWeek(value, startDayOfWeek)),\n Enter: onClick,\n Home: () => onPrevTraverseDate(getStartOfWeek(value, startDayOfWeek)),\n PageDown: (ev) => {\n if (ev.shiftKey) {\n onNextTraverseDate(dayjs(value).add(1, \"year\").toDate())\n } else {\n onNextTraverseDate(dayjs(value).add(1, \"month\").toDate())\n }\n },\n PageUp: (ev) => {\n if (ev.shiftKey) {\n onPrevTraverseDate(dayjs(value).subtract(1, \"year\").toDate())\n } else {\n onPrevTraverseDate(dayjs(value).subtract(1, \"month\").toDate())\n }\n },\n Space: onClick,\n })\n },\n [\n onClick,\n onNextDate,\n onNextTraverseDate,\n onPrevDate,\n onPrevTraverseDate,\n startDayOfWeek,\n value,\n ],\n )\n\n const getDayProps: PropGetter<\"td\"> = useCallback(\n ({ \"aria-label\": ariaLabel, ...props } = {}) => {\n let resolvedAriaLabel = ariaLabel\n if (!resolvedAriaLabel) {\n resolvedAriaLabel = dateTimeFormat(dayjs(value).toDate(), {\n day: \"numeric\",\n month: \"long\",\n weekday: \"long\",\n year: \"numeric\",\n })\n\n if (today) resolvedAriaLabel = `${t(\"Today\")}, ${resolvedAriaLabel}`\n }\n\n return mergeProps(\n {\n \"aria-disabled\": ariaAttr(disabled),\n \"aria-label\": resolvedAriaLabel,\n \"aria-selected\": ariaAttr(selected),\n \"data-between\": dataAttr(between),\n \"data-disabled\": dataAttr(disabled),\n \"data-end\": dataAttr(endValue),\n \"data-holiday\": dataAttr(holiday),\n \"data-outside\": dataAttr(outside),\n \"data-selected\": dataAttr(selected),\n \"data-start\": dataAttr(startValue),\n \"data-today\": dataAttr(today),\n \"data-value\": dayjs(value).format(\"YYYY-MM-DD\"),\n \"data-weekend\": dataAttr(weekend),\n tabIndex: -1,\n },\n rest,\n props,\n {\n ref: mergeRefs(cellRef, outside ? null : register),\n onBlur,\n onClick,\n onFocus: (ev) => ev.preventDefault(),\n onKeyDown,\n },\n )()\n },\n [\n between,\n dateTimeFormat,\n disabled,\n endValue,\n holiday,\n onBlur,\n onClick,\n onKeyDown,\n outside,\n register,\n rest,\n selected,\n startValue,\n t,\n today,\n value,\n weekend,\n ],\n )\n\n return { outside, getDayProps }\n}\n\nexport type UseCalendarDayReturn = ReturnType<typeof useCalendarDay>\n\nconst calendarProps: (keyof UseCalendarProps)[] = [\n \"defaultMonth\",\n \"defaultValue\",\n \"disabled\",\n \"excludeDate\",\n \"format\",\n \"holidays\",\n \"locale\",\n \"max\",\n \"maxDate\",\n \"minDate\",\n \"month\",\n \"range\",\n \"startDayOfWeek\",\n \"today\",\n \"value\",\n \"weekendDays\",\n \"onChange\",\n \"onChangeMonth\",\n]\n\nexport const useCalendarProps = <\n Y extends boolean = false,\n M extends boolean = false,\n D extends Dict = Dict,\n H extends keyof UseCalendarProps<Y, M> = keyof UseCalendarProps<Y, M>,\n>(\n props: D,\n omitKeys?: H[],\n) => {\n return useSplitProps(\n props,\n calendarProps.filter((key) => !omitKeys?.includes(key as H)),\n ) as unknown as [\n keyof UseCalendarProps<Y, M> extends H\n ? UseCalendarProps<Y, M>\n : Omit<UseCalendarProps<Y, M>, H>,\n Omit<\n M,\n keyof UseCalendarProps<Y, M> extends H\n ? keyof UseCalendarProps<Y, M>\n : Exclude<keyof UseCalendarProps<Y, M>, H>\n >,\n ]\n}\n"],"mappings":"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"}
@@ -6,6 +6,8 @@ const require_dom = require('../../utils/dom.cjs');
6
6
  const require_effect = require('../../utils/effect.cjs');
7
7
  const require_ref = require('../../utils/ref.cjs');
8
8
  const require_utils_index = require('../../utils/index.cjs');
9
+ const require_props = require('../../core/components/props.cjs');
10
+ require('../../core/index.cjs');
9
11
  const require_hooks_use_controllable_state_index = require('../../hooks/use-controllable-state/index.cjs');
10
12
  const require_i18n_provider = require('../../providers/i18n-provider/i18n-provider.cjs');
11
13
  require('../../providers/i18n-provider/index.cjs');
@@ -171,16 +173,15 @@ const useCarousel = ({ id, align = "center", autoplay = false, containScroll = f
171
173
  skipSnaps,
172
174
  slidesToScroll
173
175
  ]);
174
- const getRootProps = (0, react.useCallback)(({ ref, ...props } = {}) => ({
176
+ const getRootProps = (0, react.useCallback)(({ ref, ...props } = {}) => require_props.mergeProps({
175
177
  id,
176
178
  "aria-roledescription": "carousel",
177
- "data-orientation": orientation,
178
- ...rest,
179
- ...props,
180
- ref: require_ref.mergeRefs(ref, rest.ref),
181
- onMouseEnter: (0, require_utils_index.utils_exports.handlerAll)(props.onMouseEnter, onMouseEnter),
182
- onMouseLeave: (0, require_utils_index.utils_exports.handlerAll)(props.onMouseLeave, onMouseLeave)
183
- }), [
179
+ "data-orientation": orientation
180
+ }, rest, {
181
+ ref,
182
+ onMouseEnter,
183
+ onMouseLeave
184
+ }, props)(), [
184
185
  id,
185
186
  onMouseEnter,
186
187
  onMouseLeave,
@@ -1 +1 @@
1
- {"version":3,"file":"use-carousel.cjs","names":["createContext","useI18n","useControllableState","useIds","useBoolean","snapCount","total","index","getRootProps: PropGetter<\"section\">","mergeRefs","getListProps: PropGetter","getItemProps: RequiredPropGetter<\"div\", { index: number }>","indexProp","getPrevTriggerProps: PropGetter<\"button\">","getNextTriggerProps: PropGetter<\"button\">","getIndicatorsProps: PropGetter"],"sources":["../../../../src/components/carousel/use-carousel.ts"],"sourcesContent":["\"use client\"\n\nimport type {\n EmblaCarouselType,\n EmblaOptionsType,\n EmblaPluginType,\n} from \"embla-carousel\"\nimport type { KeyboardEvent, RefObject } from \"react\"\nimport type {\n HTMLProps,\n Orientation,\n PropGetter,\n RequiredPropGetter,\n} from \"../../core\"\nimport useEmblaCarousel from \"embla-carousel-react\"\nimport { useCallback, useEffect, useRef, useState } from \"react\"\nimport { useBoolean } from \"../../hooks/use-boolean\"\nimport { useControllableState } from \"../../hooks/use-controllable-state\"\nimport { useI18n } from \"../../providers/i18n-provider\"\nimport {\n assignRef,\n createContext,\n dataAttr,\n handlerAll,\n isFunction,\n mergeRefs,\n runKeyAction,\n useIds,\n useUpdateEffect,\n} from \"../../utils\"\n\ntype EmblaOptions = Required<EmblaOptionsType>\nexport type CarouselAlign = EmblaOptions[\"align\"]\nexport type CarouselContainScroll = EmblaOptions[\"containScroll\"]\nexport type CarouselInViewThreshold = EmblaOptions[\"inViewThreshold\"]\nexport type CarouselWatchDrag = EmblaOptions[\"watchDrag\"]\nexport type CarouselWatchResize = EmblaOptions[\"watchResize\"]\nexport type CarouselWatchSlides = EmblaOptions[\"watchSlides\"]\nexport type CarouselControl = EmblaCarouselType\nexport type CarouselPlugin = EmblaPluginType\n\nexport interface CarouselContext extends Omit<\n UseCarouselReturn,\n \"getRootProps\"\n> {}\n\nconst [CarouselContext, useCarouselContext] = createContext<CarouselContext>({\n name: \"CarouselContext\",\n})\n\nexport { CarouselContext, useCarouselContext }\n\nexport interface UseCarouselProps extends Omit<\n HTMLProps<\"section\">,\n \"onChange\"\n> {\n /**\n * The alignment of the carousel.\n *\n * @default 'center'\n */\n align?: CarouselAlign\n /**\n * If `true`, the carousel will be autoplay.\n *\n * @default false\n */\n autoplay?: boolean\n /**\n * Clear leading and trailing empty space that causes excessive scrolling.\n * Use trimSnaps to only use snap points that trigger scrolling or keepSnaps to keep them.\n *\n * @default false\n */\n containScroll?: CarouselContainScroll\n /**\n * Ref of the resizable item callback.\n */\n controlRef?: RefObject<CarouselControl | null>\n /**\n * The initial index of the carousel slide.\n *\n * @default 0\n */\n defaultIndex?: number\n /**\n * The number for the autoplay interval of the carousel.\n *\n * @default 4000\n */\n delay?: number\n /**\n * If `true`, momentum scrolling will be enabled.\n *\n * @default false\n */\n dragFree?: boolean\n /**\n * If `true`, carousel can be scrolled with mouse and touch interactions.\n *\n * @default true\n */\n draggable?: boolean\n /**\n * Set scroll duration when triggered by any of the API methods.\n * Higher numbers enables slower scrolling.\n * Drag interactions are not affected because duration is then determined by the drag force.\n *\n * @default 25\n */\n duration?: number\n /**\n * The index of the carousel slide.\n */\n index?: number\n /**\n * Choose a fraction representing the percentage portion of a slide that needs to be visible in order to be considered in view.\n *\n * @default 0\n */\n inViewThreshold?: CarouselInViewThreshold\n /**\n * If `true`, infinite looping.\n * Automatically falls back to false if slide content isn't enough to loop.\n *\n * @default true\n */\n loop?: boolean\n /**\n * The orientation of the carousel.\n *\n * @default 'horizontal'\n */\n orientation?: Orientation\n /**\n * Embla plugins to use.\n */\n plugins?: CarouselPlugin[]\n /**\n * If `true`, allow the carousel to skip scroll snaps if it's dragged vigorously.\n * Note that this option will be ignored if the dragFree option is set to true.\n *\n * @default false\n */\n skipSnaps?: boolean\n /**\n * The number of slides that should be scrolled with next or previous buttons.\n *\n * @default 1\n */\n slidesToScroll?: number\n /**\n * If `true`, autoplay will pause when the mouse entries over.\n *\n * @default true\n */\n stopMouseEnterAutoplay?: boolean\n /**\n * Enables for scrolling the carousel with mouse and touch interactions.\n * Set this to `false` to disable drag events or pass a custom callback to add your own drag logic.\n *\n * @default true\n */\n watchDrag?: CarouselWatchDrag\n /**\n * Embla automatically watches the container and slides for size changes and runs `reInit` when any size has changed.\n * Set this to `false` to disable this behaviour or pass a custom callback to add your own resize logic.\n *\n * @default true\n */\n watchResize?: CarouselWatchResize\n /**\n * Embla automatically watches the container for added and/or removed slides and runs `reInit` if needed.\n * Set this to `false` to disable this behaviour or pass a custom callback to add your own slides changed logic.\n *\n * @default true\n */\n watchSlides?: CarouselWatchSlides\n /**\n * The callback invoked when carousel slide selected.\n */\n onChange?: (index: number) => void\n /**\n * A callback that return the current scroll amount when the carousel is scrolled.\n */\n onScrollProgress?: (progress: number) => void\n}\n\nexport const useCarousel = ({\n id,\n align = \"center\",\n autoplay = false,\n containScroll = false,\n controlRef,\n defaultIndex = 0,\n delay = 4000,\n dragFree = false,\n draggable = true,\n duration = 25,\n index: indexProp,\n inViewThreshold = 0,\n loop = true,\n orientation = \"horizontal\",\n plugins = [],\n skipSnaps = false,\n slidesToScroll = 1,\n stopMouseEnterAutoplay = true,\n watchDrag = draggable,\n watchResize: watchResizeProp = true,\n watchSlides = true,\n onChange,\n onScrollProgress,\n ...rest\n}: UseCarouselProps = {}) => {\n const { t } = useI18n(\"carousel\")\n const [index, setIndex] = useControllableState({\n defaultValue: defaultIndex,\n value: indexProp,\n onChange,\n })\n const [rootId, listId] = useIds()\n const [hover, { off: onMouseLeave, on: onMouseEnter }] = useBoolean()\n const timeoutId = useRef<NodeJS.Timeout | null>(null)\n const indicatorMapRef = useRef<Map<number, HTMLButtonElement | null>>(\n new Map(),\n )\n const listRef = useRef<HTMLDivElement>(null)\n const horizontal = orientation === \"horizontal\"\n const axis = horizontal ? \"x\" : \"y\"\n const [snapCount, setSnapCount] = useState(0)\n const [total, setTotal] = useState(0)\n const watchResize = useCallback<Extract<CarouselWatchResize, Function>>(\n (methods, entries) => {\n const result = isFunction(watchResizeProp)\n ? watchResizeProp(methods, entries)\n : true\n const snapCount = methods.scrollSnapList().length\n const total = methods.slideNodes().length\n\n setSnapCount(snapCount)\n setTotal(total)\n\n return result\n },\n [watchResizeProp],\n )\n const [carouselRef, carousel] = useEmblaCarousel(\n {\n align,\n axis,\n container: listRef.current,\n containScroll,\n dragFree,\n duration,\n inViewThreshold,\n loop,\n skipSnaps,\n slidesToScroll,\n startIndex: defaultIndex,\n watchDrag,\n watchResize,\n watchSlides,\n },\n plugins,\n )\n\n id ??= rootId\n\n const onInit = useCallback((methods: CarouselControl) => {\n const snapCount = methods.scrollSnapList().length\n const total = methods.slideNodes().length\n\n setSnapCount(snapCount)\n setTotal(total)\n }, [])\n\n const onScroll = useCallback(() => {\n if (!carousel) return\n\n const progress = Math.round(\n Math.max(0, Math.min(1, carousel.scrollProgress())) * 100,\n )\n\n onScrollProgress?.(progress)\n }, [carousel, onScrollProgress])\n\n const onSelect = useCallback(() => {\n if (!carousel) return\n\n const index = carousel.selectedScrollSnap()\n\n setIndex(index)\n }, [carousel, setIndex])\n\n const onFocusIndicator = useCallback(\n (index: number) => {\n const el = indicatorMapRef.current.get(index)\n\n el?.focus()\n carousel?.scrollTo(index)\n },\n [carousel],\n )\n\n const onKeyDown = useCallback(\n (index: number) => (ev: KeyboardEvent<HTMLButtonElement>) => {\n const lastIndex = snapCount - 1\n\n runKeyAction(ev, {\n ArrowDown: () => {\n if (horizontal) return\n\n index = index === lastIndex ? 0 : index + 1\n\n onFocusIndicator(index)\n },\n ArrowLeft: () => {\n if (!horizontal) return\n\n index = index === 0 ? lastIndex : index - 1\n\n onFocusIndicator(index)\n },\n ArrowRight: () => {\n if (!horizontal) return\n\n index = index === lastIndex ? 0 : index + 1\n\n onFocusIndicator(index)\n },\n ArrowUp: () => {\n if (horizontal) return\n\n index = index === 0 ? lastIndex : index - 1\n\n onFocusIndicator(index)\n },\n End: () => {\n onFocusIndicator(lastIndex)\n },\n Home: () => {\n onFocusIndicator(0)\n },\n })\n },\n [snapCount, horizontal, onFocusIndicator],\n )\n\n assignRef(controlRef, carousel)\n\n useEffect(() => {\n if (carousel) {\n carousel.on(\"reInit\", onInit)\n carousel.on(\"select\", onSelect)\n carousel.on(\"scroll\", onScroll)\n\n onScroll()\n\n return () => {\n carousel.off(\"reInit\", onInit)\n carousel.off(\"select\", onSelect)\n carousel.off(\"scroll\", onScroll)\n }\n }\n }, [carousel, onInit, onScroll, onSelect])\n\n useEffect(() => {\n const stop = hover && stopMouseEnterAutoplay\n const last = !carousel?.canScrollNext()\n\n if (carousel && autoplay && !stop && !last) {\n timeoutId.current = setInterval(() => {\n carousel.scrollNext()\n }, delay)\n } else {\n if (timeoutId.current) clearInterval(timeoutId.current)\n\n timeoutId.current = null\n }\n\n return () => {\n if (timeoutId.current) clearInterval(timeoutId.current)\n }\n }, [autoplay, carousel, delay, hover, stopMouseEnterAutoplay])\n\n useUpdateEffect(() => {\n if (!carousel) return\n\n if (indexProp === undefined) return\n\n carousel.scrollTo(indexProp)\n }, [indexProp])\n\n useUpdateEffect(() => {\n if (!carousel) return\n\n carousel.reInit()\n }, [\n carousel,\n total,\n align,\n axis,\n containScroll,\n dragFree,\n duration,\n inViewThreshold,\n loop,\n skipSnaps,\n slidesToScroll,\n ])\n\n const getRootProps: PropGetter<\"section\"> = useCallback(\n ({ ref, ...props } = {}) => ({\n id,\n \"aria-roledescription\": \"carousel\",\n \"data-orientation\": orientation,\n ...rest,\n ...props,\n ref: mergeRefs(ref, rest.ref),\n onMouseEnter: handlerAll(props.onMouseEnter, onMouseEnter),\n onMouseLeave: handlerAll(props.onMouseLeave, onMouseLeave),\n }),\n [id, onMouseEnter, onMouseLeave, rest, orientation],\n )\n\n const getListProps: PropGetter = useCallback(\n ({ ref, ...props } = {}) => ({\n id: listId,\n \"aria-live\": autoplay ? \"off\" : \"polite\",\n \"data-orientation\": orientation,\n ...props,\n ref: mergeRefs(ref, listRef, carouselRef),\n }),\n [autoplay, listId, orientation, carouselRef],\n )\n\n const getItemProps: RequiredPropGetter<\"div\", { index: number }> =\n useCallback(\n ({ index: indexProp, ...props }) => {\n const page = indexProp + 1\n const selected = index === indexProp\n\n return {\n id: `${listId}-${indexProp}`,\n \"aria-label\": t(\"{page} of {total}\", { page, total }),\n \"aria-roledescription\": \"slide\",\n \"data-index\": indexProp.toString(),\n \"data-orientation\": orientation,\n \"data-selected\": dataAttr(selected),\n role: \"tabpanel\",\n ...props,\n }\n },\n [index, listId, total, orientation, t],\n )\n\n const getPrevTriggerProps: PropGetter<\"button\"> = useCallback(\n (props = {}) => ({\n \"aria-controls\": listId,\n \"aria-label\": t(\"Go to previous slide\"),\n \"data-orientation\": orientation,\n disabled: !carousel?.canScrollPrev(),\n ...props,\n onClick: handlerAll(props.onClick, () => carousel?.scrollPrev()),\n }),\n [carousel, listId, orientation, t],\n )\n\n const getNextTriggerProps: PropGetter<\"button\"> = useCallback(\n (props = {}) => ({\n \"aria-controls\": listId,\n \"aria-label\": t(\"Go to next slide\"),\n \"data-orientation\": orientation,\n disabled: !carousel?.canScrollNext(),\n ...props,\n onClick: handlerAll(props.onClick, () => carousel?.scrollNext()),\n }),\n [carousel, listId, orientation, t],\n )\n\n const getIndicatorsProps: PropGetter = useCallback(\n (props = {}) => ({\n \"aria-label\": t(\"Slides\"),\n \"aria-orientation\": orientation,\n role: \"tablist\",\n ...props,\n }),\n [orientation, t],\n )\n\n const getIndicatorProps: RequiredPropGetter<\"button\", { index: number }> =\n useCallback(\n ({ ref, index: indexProp, ...props }) => {\n const page = indexProp + 1\n const selected = index === indexProp\n\n return {\n type: \"button\" as const,\n \"aria-controls\": `${listId}-${indexProp}`,\n \"aria-label\": t(\"Go to {page} slide\", { page }),\n \"aria-selected\": selected,\n \"data-index\": indexProp.toString(),\n \"data-orientation\": orientation,\n \"data-selected\": dataAttr(selected),\n role: \"tab\",\n tabIndex: selected ? 0 : -1,\n ...props,\n ref: mergeRefs(ref, (node) => {\n indicatorMapRef.current.set(indexProp, node)\n }),\n onClick: handlerAll(props.onClick, () =>\n carousel?.scrollTo(indexProp),\n ),\n onKeyDown: handlerAll(props.onKeyDown, onKeyDown(indexProp)),\n }\n },\n [index, listId, t, orientation, onKeyDown, carousel],\n )\n\n return {\n carousel,\n index,\n setIndex,\n snapCount,\n total,\n getIndicatorProps,\n getIndicatorsProps,\n getItemProps,\n getListProps,\n getNextTriggerProps,\n getPrevTriggerProps,\n getRootProps,\n }\n}\n\nexport type UseCarouselReturn = ReturnType<typeof useCarousel>\n"],"mappings":"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"}
1
+ {"version":3,"file":"use-carousel.cjs","names":["createContext","useI18n","useControllableState","useIds","useBoolean","snapCount","total","index","getRootProps: PropGetter<\"section\">","mergeProps","getListProps: PropGetter","mergeRefs","getItemProps: RequiredPropGetter<\"div\", { index: number }>","indexProp","getPrevTriggerProps: PropGetter<\"button\">","getNextTriggerProps: PropGetter<\"button\">","getIndicatorsProps: PropGetter"],"sources":["../../../../src/components/carousel/use-carousel.ts"],"sourcesContent":["\"use client\"\n\nimport type {\n EmblaCarouselType,\n EmblaOptionsType,\n EmblaPluginType,\n} from \"embla-carousel\"\nimport type { KeyboardEvent, RefObject } from \"react\"\nimport type {\n HTMLProps,\n Orientation,\n PropGetter,\n RequiredPropGetter,\n} from \"../../core\"\nimport useEmblaCarousel from \"embla-carousel-react\"\nimport { useCallback, useEffect, useRef, useState } from \"react\"\nimport { mergeProps } from \"../../core\"\nimport { useBoolean } from \"../../hooks/use-boolean\"\nimport { useControllableState } from \"../../hooks/use-controllable-state\"\nimport { useI18n } from \"../../providers/i18n-provider\"\nimport {\n assignRef,\n createContext,\n dataAttr,\n handlerAll,\n isFunction,\n mergeRefs,\n runKeyAction,\n useIds,\n useUpdateEffect,\n} from \"../../utils\"\n\ntype EmblaOptions = Required<EmblaOptionsType>\nexport type CarouselAlign = EmblaOptions[\"align\"]\nexport type CarouselContainScroll = EmblaOptions[\"containScroll\"]\nexport type CarouselInViewThreshold = EmblaOptions[\"inViewThreshold\"]\nexport type CarouselWatchDrag = EmblaOptions[\"watchDrag\"]\nexport type CarouselWatchResize = EmblaOptions[\"watchResize\"]\nexport type CarouselWatchSlides = EmblaOptions[\"watchSlides\"]\nexport type CarouselControl = EmblaCarouselType\nexport type CarouselPlugin = EmblaPluginType\n\nexport interface CarouselContext extends Omit<\n UseCarouselReturn,\n \"getRootProps\"\n> {}\n\nconst [CarouselContext, useCarouselContext] = createContext<CarouselContext>({\n name: \"CarouselContext\",\n})\n\nexport { CarouselContext, useCarouselContext }\n\nexport interface UseCarouselProps extends Omit<\n HTMLProps<\"section\">,\n \"onChange\"\n> {\n /**\n * The alignment of the carousel.\n *\n * @default 'center'\n */\n align?: CarouselAlign\n /**\n * If `true`, the carousel will be autoplay.\n *\n * @default false\n */\n autoplay?: boolean\n /**\n * Clear leading and trailing empty space that causes excessive scrolling.\n * Use trimSnaps to only use snap points that trigger scrolling or keepSnaps to keep them.\n *\n * @default false\n */\n containScroll?: CarouselContainScroll\n /**\n * Ref of the resizable item callback.\n */\n controlRef?: RefObject<CarouselControl | null>\n /**\n * The initial index of the carousel slide.\n *\n * @default 0\n */\n defaultIndex?: number\n /**\n * The number for the autoplay interval of the carousel.\n *\n * @default 4000\n */\n delay?: number\n /**\n * If `true`, momentum scrolling will be enabled.\n *\n * @default false\n */\n dragFree?: boolean\n /**\n * If `true`, carousel can be scrolled with mouse and touch interactions.\n *\n * @default true\n */\n draggable?: boolean\n /**\n * Set scroll duration when triggered by any of the API methods.\n * Higher numbers enables slower scrolling.\n * Drag interactions are not affected because duration is then determined by the drag force.\n *\n * @default 25\n */\n duration?: number\n /**\n * The index of the carousel slide.\n */\n index?: number\n /**\n * Choose a fraction representing the percentage portion of a slide that needs to be visible in order to be considered in view.\n *\n * @default 0\n */\n inViewThreshold?: CarouselInViewThreshold\n /**\n * If `true`, infinite looping.\n * Automatically falls back to false if slide content isn't enough to loop.\n *\n * @default true\n */\n loop?: boolean\n /**\n * The orientation of the carousel.\n *\n * @default 'horizontal'\n */\n orientation?: Orientation\n /**\n * Embla plugins to use.\n */\n plugins?: CarouselPlugin[]\n /**\n * If `true`, allow the carousel to skip scroll snaps if it's dragged vigorously.\n * Note that this option will be ignored if the dragFree option is set to true.\n *\n * @default false\n */\n skipSnaps?: boolean\n /**\n * The number of slides that should be scrolled with next or previous buttons.\n *\n * @default 1\n */\n slidesToScroll?: number\n /**\n * If `true`, autoplay will pause when the mouse entries over.\n *\n * @default true\n */\n stopMouseEnterAutoplay?: boolean\n /**\n * Enables for scrolling the carousel with mouse and touch interactions.\n * Set this to `false` to disable drag events or pass a custom callback to add your own drag logic.\n *\n * @default true\n */\n watchDrag?: CarouselWatchDrag\n /**\n * Embla automatically watches the container and slides for size changes and runs `reInit` when any size has changed.\n * Set this to `false` to disable this behaviour or pass a custom callback to add your own resize logic.\n *\n * @default true\n */\n watchResize?: CarouselWatchResize\n /**\n * Embla automatically watches the container for added and/or removed slides and runs `reInit` if needed.\n * Set this to `false` to disable this behaviour or pass a custom callback to add your own slides changed logic.\n *\n * @default true\n */\n watchSlides?: CarouselWatchSlides\n /**\n * The callback invoked when carousel slide selected.\n */\n onChange?: (index: number) => void\n /**\n * A callback that return the current scroll amount when the carousel is scrolled.\n */\n onScrollProgress?: (progress: number) => void\n}\n\nexport const useCarousel = ({\n id,\n align = \"center\",\n autoplay = false,\n containScroll = false,\n controlRef,\n defaultIndex = 0,\n delay = 4000,\n dragFree = false,\n draggable = true,\n duration = 25,\n index: indexProp,\n inViewThreshold = 0,\n loop = true,\n orientation = \"horizontal\",\n plugins = [],\n skipSnaps = false,\n slidesToScroll = 1,\n stopMouseEnterAutoplay = true,\n watchDrag = draggable,\n watchResize: watchResizeProp = true,\n watchSlides = true,\n onChange,\n onScrollProgress,\n ...rest\n}: UseCarouselProps = {}) => {\n const { t } = useI18n(\"carousel\")\n const [index, setIndex] = useControllableState({\n defaultValue: defaultIndex,\n value: indexProp,\n onChange,\n })\n const [rootId, listId] = useIds()\n const [hover, { off: onMouseLeave, on: onMouseEnter }] = useBoolean()\n const timeoutId = useRef<NodeJS.Timeout | null>(null)\n const indicatorMapRef = useRef<Map<number, HTMLButtonElement | null>>(\n new Map(),\n )\n const listRef = useRef<HTMLDivElement>(null)\n const horizontal = orientation === \"horizontal\"\n const axis = horizontal ? \"x\" : \"y\"\n const [snapCount, setSnapCount] = useState(0)\n const [total, setTotal] = useState(0)\n const watchResize = useCallback<Extract<CarouselWatchResize, Function>>(\n (methods, entries) => {\n const result = isFunction(watchResizeProp)\n ? watchResizeProp(methods, entries)\n : true\n const snapCount = methods.scrollSnapList().length\n const total = methods.slideNodes().length\n\n setSnapCount(snapCount)\n setTotal(total)\n\n return result\n },\n [watchResizeProp],\n )\n const [carouselRef, carousel] = useEmblaCarousel(\n {\n align,\n axis,\n container: listRef.current,\n containScroll,\n dragFree,\n duration,\n inViewThreshold,\n loop,\n skipSnaps,\n slidesToScroll,\n startIndex: defaultIndex,\n watchDrag,\n watchResize,\n watchSlides,\n },\n plugins,\n )\n\n id ??= rootId\n\n const onInit = useCallback((methods: CarouselControl) => {\n const snapCount = methods.scrollSnapList().length\n const total = methods.slideNodes().length\n\n setSnapCount(snapCount)\n setTotal(total)\n }, [])\n\n const onScroll = useCallback(() => {\n if (!carousel) return\n\n const progress = Math.round(\n Math.max(0, Math.min(1, carousel.scrollProgress())) * 100,\n )\n\n onScrollProgress?.(progress)\n }, [carousel, onScrollProgress])\n\n const onSelect = useCallback(() => {\n if (!carousel) return\n\n const index = carousel.selectedScrollSnap()\n\n setIndex(index)\n }, [carousel, setIndex])\n\n const onFocusIndicator = useCallback(\n (index: number) => {\n const el = indicatorMapRef.current.get(index)\n\n el?.focus()\n carousel?.scrollTo(index)\n },\n [carousel],\n )\n\n const onKeyDown = useCallback(\n (index: number) => (ev: KeyboardEvent<HTMLButtonElement>) => {\n const lastIndex = snapCount - 1\n\n runKeyAction(ev, {\n ArrowDown: () => {\n if (horizontal) return\n\n index = index === lastIndex ? 0 : index + 1\n\n onFocusIndicator(index)\n },\n ArrowLeft: () => {\n if (!horizontal) return\n\n index = index === 0 ? lastIndex : index - 1\n\n onFocusIndicator(index)\n },\n ArrowRight: () => {\n if (!horizontal) return\n\n index = index === lastIndex ? 0 : index + 1\n\n onFocusIndicator(index)\n },\n ArrowUp: () => {\n if (horizontal) return\n\n index = index === 0 ? lastIndex : index - 1\n\n onFocusIndicator(index)\n },\n End: () => {\n onFocusIndicator(lastIndex)\n },\n Home: () => {\n onFocusIndicator(0)\n },\n })\n },\n [snapCount, horizontal, onFocusIndicator],\n )\n\n assignRef(controlRef, carousel)\n\n useEffect(() => {\n if (carousel) {\n carousel.on(\"reInit\", onInit)\n carousel.on(\"select\", onSelect)\n carousel.on(\"scroll\", onScroll)\n\n onScroll()\n\n return () => {\n carousel.off(\"reInit\", onInit)\n carousel.off(\"select\", onSelect)\n carousel.off(\"scroll\", onScroll)\n }\n }\n }, [carousel, onInit, onScroll, onSelect])\n\n useEffect(() => {\n const stop = hover && stopMouseEnterAutoplay\n const last = !carousel?.canScrollNext()\n\n if (carousel && autoplay && !stop && !last) {\n timeoutId.current = setInterval(() => {\n carousel.scrollNext()\n }, delay)\n } else {\n if (timeoutId.current) clearInterval(timeoutId.current)\n\n timeoutId.current = null\n }\n\n return () => {\n if (timeoutId.current) clearInterval(timeoutId.current)\n }\n }, [autoplay, carousel, delay, hover, stopMouseEnterAutoplay])\n\n useUpdateEffect(() => {\n if (!carousel) return\n\n if (indexProp === undefined) return\n\n carousel.scrollTo(indexProp)\n }, [indexProp])\n\n useUpdateEffect(() => {\n if (!carousel) return\n\n carousel.reInit()\n }, [\n carousel,\n total,\n align,\n axis,\n containScroll,\n dragFree,\n duration,\n inViewThreshold,\n loop,\n skipSnaps,\n slidesToScroll,\n ])\n\n const getRootProps: PropGetter<\"section\"> = useCallback(\n ({ ref, ...props } = {}) =>\n mergeProps(\n {\n id,\n \"aria-roledescription\": \"carousel\",\n \"data-orientation\": orientation,\n },\n rest,\n {\n ref,\n onMouseEnter,\n onMouseLeave,\n },\n props,\n )(),\n [id, onMouseEnter, onMouseLeave, rest, orientation],\n )\n\n const getListProps: PropGetter = useCallback(\n ({ ref, ...props } = {}) => ({\n id: listId,\n \"aria-live\": autoplay ? \"off\" : \"polite\",\n \"data-orientation\": orientation,\n ...props,\n ref: mergeRefs(ref, listRef, carouselRef),\n }),\n [autoplay, listId, orientation, carouselRef],\n )\n\n const getItemProps: RequiredPropGetter<\"div\", { index: number }> =\n useCallback(\n ({ index: indexProp, ...props }) => {\n const page = indexProp + 1\n const selected = index === indexProp\n\n return {\n id: `${listId}-${indexProp}`,\n \"aria-label\": t(\"{page} of {total}\", { page, total }),\n \"aria-roledescription\": \"slide\",\n \"data-index\": indexProp.toString(),\n \"data-orientation\": orientation,\n \"data-selected\": dataAttr(selected),\n role: \"tabpanel\",\n ...props,\n }\n },\n [index, listId, total, orientation, t],\n )\n\n const getPrevTriggerProps: PropGetter<\"button\"> = useCallback(\n (props = {}) => ({\n \"aria-controls\": listId,\n \"aria-label\": t(\"Go to previous slide\"),\n \"data-orientation\": orientation,\n disabled: !carousel?.canScrollPrev(),\n ...props,\n onClick: handlerAll(props.onClick, () => carousel?.scrollPrev()),\n }),\n [carousel, listId, orientation, t],\n )\n\n const getNextTriggerProps: PropGetter<\"button\"> = useCallback(\n (props = {}) => ({\n \"aria-controls\": listId,\n \"aria-label\": t(\"Go to next slide\"),\n \"data-orientation\": orientation,\n disabled: !carousel?.canScrollNext(),\n ...props,\n onClick: handlerAll(props.onClick, () => carousel?.scrollNext()),\n }),\n [carousel, listId, orientation, t],\n )\n\n const getIndicatorsProps: PropGetter = useCallback(\n (props = {}) => ({\n \"aria-label\": t(\"Slides\"),\n \"aria-orientation\": orientation,\n role: \"tablist\",\n ...props,\n }),\n [orientation, t],\n )\n\n const getIndicatorProps: RequiredPropGetter<\"button\", { index: number }> =\n useCallback(\n ({ ref, index: indexProp, ...props }) => {\n const page = indexProp + 1\n const selected = index === indexProp\n\n return {\n type: \"button\" as const,\n \"aria-controls\": `${listId}-${indexProp}`,\n \"aria-label\": t(\"Go to {page} slide\", { page }),\n \"aria-selected\": selected,\n \"data-index\": indexProp.toString(),\n \"data-orientation\": orientation,\n \"data-selected\": dataAttr(selected),\n role: \"tab\",\n tabIndex: selected ? 0 : -1,\n ...props,\n ref: mergeRefs(ref, (node) => {\n indicatorMapRef.current.set(indexProp, node)\n }),\n onClick: handlerAll(props.onClick, () =>\n carousel?.scrollTo(indexProp),\n ),\n onKeyDown: handlerAll(props.onKeyDown, onKeyDown(indexProp)),\n }\n },\n [index, listId, t, orientation, onKeyDown, carousel],\n )\n\n return {\n carousel,\n index,\n setIndex,\n snapCount,\n total,\n getIndicatorProps,\n getIndicatorsProps,\n getItemProps,\n getListProps,\n getNextTriggerProps,\n getPrevTriggerProps,\n getRootProps,\n }\n}\n\nexport type UseCarouselReturn = ReturnType<typeof useCarousel>\n"],"mappings":"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"}
@@ -5,7 +5,7 @@ import { runKeyAction, visuallyHiddenAttributes } from "../../utils/dom.js";
5
5
  import { useUpdateEffect } from "../../utils/effect.js";
6
6
  import { mergeRefs } from "../../utils/ref.js";
7
7
  import { utils_exports } from "../../utils/index.js";
8
- import { useSplitProps } from "../../core/components/props.js";
8
+ import { mergeProps, useSplitProps } from "../../core/components/props.js";
9
9
  import "../../core/index.js";
10
10
  import { useControllableState } from "../../hooks/use-controllable-state/index.js";
11
11
  import { createDescendants } from "../../hooks/use-descendants/index.js";
@@ -284,11 +284,7 @@ const useCalendar = ({ defaultMonth = /* @__PURE__ */ new Date(), multiple = fal
284
284
  useUpdateEffect(() => {
285
285
  setMonth((prev) => getAdjustedMonth(value, prev));
286
286
  }, [value]);
287
- const getRootProps = useCallback((props = {}) => ({
288
- "data-disabled": (0, utils_exports.dataAttr)(disabled),
289
- ...rest,
290
- ...props
291
- }), [disabled, rest]);
287
+ const getRootProps = useCallback((props = {}) => mergeProps({ "data-disabled": (0, utils_exports.dataAttr)(disabled) }, rest, props)(), [disabled, rest]);
292
288
  const getNavigationProps = useCallback((props = {}) => ({
293
289
  "data-disabled": (0, utils_exports.dataAttr)(disabled),
294
290
  ...props
@@ -568,19 +564,20 @@ const useCalendarDay = ({ value, ...rest }) => {
568
564
  ]);
569
565
  return {
570
566
  outside,
571
- getDayProps: useCallback(({ ref, "aria-label": ariaLabel, ...props } = {}) => {
572
- if (!ariaLabel) {
573
- ariaLabel = dateTimeFormat(dayjs(value).toDate(), {
567
+ getDayProps: useCallback(({ "aria-label": ariaLabel, ...props } = {}) => {
568
+ let resolvedAriaLabel = ariaLabel;
569
+ if (!resolvedAriaLabel) {
570
+ resolvedAriaLabel = dateTimeFormat(dayjs(value).toDate(), {
574
571
  day: "numeric",
575
572
  month: "long",
576
573
  weekday: "long",
577
574
  year: "numeric"
578
575
  });
579
- if (today) ariaLabel = `${t("Today")}, ${ariaLabel}`;
576
+ if (today) resolvedAriaLabel = `${t("Today")}, ${resolvedAriaLabel}`;
580
577
  }
581
- return {
578
+ return mergeProps({
582
579
  "aria-disabled": (0, utils_exports.ariaAttr)(disabled),
583
- "aria-label": ariaLabel,
580
+ "aria-label": resolvedAriaLabel,
584
581
  "aria-selected": (0, utils_exports.ariaAttr)(selected),
585
582
  "data-between": (0, utils_exports.dataAttr)(between),
586
583
  "data-disabled": (0, utils_exports.dataAttr)(disabled),
@@ -592,15 +589,14 @@ const useCalendarDay = ({ value, ...rest }) => {
592
589
  "data-today": (0, utils_exports.dataAttr)(today),
593
590
  "data-value": dayjs(value).format("YYYY-MM-DD"),
594
591
  "data-weekend": (0, utils_exports.dataAttr)(weekend),
595
- tabIndex: -1,
596
- ...rest,
597
- ...props,
598
- ref: mergeRefs(ref, cellRef, outside ? null : register),
599
- onBlur: (0, utils_exports.handlerAll)(props.onBlur, onBlur),
600
- onClick: (0, utils_exports.handlerAll)(props.onClick, onClick),
601
- onFocus: (0, utils_exports.handlerAll)(props.onFocus, (ev) => ev.preventDefault()),
602
- onKeyDown: (0, utils_exports.handlerAll)(props.onKeyDown, onKeyDown)
603
- };
592
+ tabIndex: -1
593
+ }, rest, props, {
594
+ ref: mergeRefs(cellRef, outside ? null : register),
595
+ onBlur,
596
+ onClick,
597
+ onFocus: (ev) => ev.preventDefault(),
598
+ onKeyDown
599
+ })();
604
600
  }, [
605
601
  between,
606
602
  dateTimeFormat,