@yamada-ui/react 2.2.1-dev-20260428151511 → 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 (252) 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/esm/components/calendar/use-calendar.js +17 -21
  4. package/dist/esm/components/calendar/use-calendar.js.map +1 -1
  5. package/dist/types/components/accordion/accordion.d.ts +2 -4
  6. package/dist/types/components/accordion/accordion.style.d.ts +1 -1
  7. package/dist/types/components/accordion/use-accordion.d.ts +11 -11
  8. package/dist/types/components/action-bar/action-bar.d.ts +2 -3
  9. package/dist/types/components/airy/airy.d.ts +2 -3
  10. package/dist/types/components/alert/alert.d.ts +2 -5
  11. package/dist/types/components/alpha-slider/alpha-slider.d.ts +2 -3
  12. package/dist/types/components/aspect-ratio/aspect-ratio.d.ts +2 -2
  13. package/dist/types/components/autocomplete/autocomplete.d.ts +2 -4
  14. package/dist/types/components/autocomplete/autocomplete.style.d.ts +1 -1
  15. package/dist/types/components/autocomplete/use-autocomplete.d.ts +5 -7
  16. package/dist/types/components/avatar/avatar.d.ts +5 -5
  17. package/dist/types/components/avatar/avatar.style.d.ts +1 -1
  18. package/dist/types/components/avatar/use-avatar-group.d.ts +2 -2
  19. package/dist/types/components/badge/badge.d.ts +2 -2
  20. package/dist/types/components/bleed/bleed.d.ts +2 -2
  21. package/dist/types/components/blockquote/blockquote.d.ts +2 -2
  22. package/dist/types/components/breadcrumb/breadcrumb.d.ts +2 -2
  23. package/dist/types/components/breadcrumb/breadcrumb.style.d.ts +1 -1
  24. package/dist/types/components/breadcrumb/use-breadcrumb.d.ts +2 -2
  25. package/dist/types/components/button/button-group.d.ts +0 -1
  26. package/dist/types/components/button/button.d.ts +2 -3
  27. package/dist/types/components/button/icon-button.d.ts +2 -2
  28. package/dist/types/components/calendar/calendar.d.ts +2 -3
  29. package/dist/types/components/calendar/calendar.style.d.ts +2 -2
  30. package/dist/types/components/calendar/use-calendar.d.ts +8 -9
  31. package/dist/types/components/card/card.d.ts +2 -2
  32. package/dist/types/components/carousel/carousel.d.ts +2 -3
  33. package/dist/types/components/carousel/carousel.style.d.ts +2 -2
  34. package/dist/types/components/carousel/use-carousel.d.ts +3 -3
  35. package/dist/types/components/center/center.d.ts +2 -2
  36. package/dist/types/components/chart/area-chart.d.ts +2 -2
  37. package/dist/types/components/chart/bar-chart.d.ts +2 -2
  38. package/dist/types/components/chart/chart.d.ts +5 -5
  39. package/dist/types/components/chart/composed-chart.d.ts +2 -2
  40. package/dist/types/components/chart/donut-chart.d.ts +2 -2
  41. package/dist/types/components/chart/radar-chart.d.ts +2 -2
  42. package/dist/types/components/chart/use-chart.d.ts +2 -2
  43. package/dist/types/components/checkbox/checkbox-group.d.ts +0 -2
  44. package/dist/types/components/checkbox/checkbox.d.ts +5 -6
  45. package/dist/types/components/checkbox/checkbox.style.d.ts +1 -1
  46. package/dist/types/components/checkbox/use-checkbox-group.d.ts +2 -3
  47. package/dist/types/components/checkbox/use-checkbox.d.ts +0 -1
  48. package/dist/types/components/checkbox-card/checkbox-card-group.d.ts +0 -3
  49. package/dist/types/components/checkbox-card/checkbox-card.d.ts +5 -7
  50. package/dist/types/components/checkbox-card/checkbox-card.style.d.ts +1 -1
  51. package/dist/types/components/circle-progress/circle-progress.d.ts +2 -3
  52. package/dist/types/components/close-button/close-button.d.ts +2 -3
  53. package/dist/types/components/code/code.d.ts +2 -2
  54. package/dist/types/components/collapse/collapse.d.ts +2 -3
  55. package/dist/types/components/color-picker/color-picker.d.ts +2 -6
  56. package/dist/types/components/color-picker/use-color-picker.d.ts +2 -5
  57. package/dist/types/components/color-selector/color-selector.d.ts +2 -6
  58. package/dist/types/components/color-selector/use-color-selector.d.ts +3 -5
  59. package/dist/types/components/color-swatch/color-swatch.d.ts +2 -2
  60. package/dist/types/components/container/container.d.ts +2 -2
  61. package/dist/types/components/data-list/data-list.d.ts +2 -2
  62. package/dist/types/components/data-list/data-list.style.d.ts +1 -1
  63. package/dist/types/components/date-picker/date-picker.d.ts +2 -5
  64. package/dist/types/components/date-picker/use-date-picker.d.ts +4 -7
  65. package/dist/types/components/drawer/drawer.d.ts +2 -5
  66. package/dist/types/components/drawer/use-drawer.d.ts +0 -2
  67. package/dist/types/components/dropzone/dropzone.d.ts +4 -7
  68. package/dist/types/components/dropzone/use-dropzone.d.ts +0 -1
  69. package/dist/types/components/editable/editable.d.ts +4 -5
  70. package/dist/types/components/editable/use-editable.d.ts +2 -3
  71. package/dist/types/components/em/em.d.ts +2 -2
  72. package/dist/types/components/empty-state/empty-state.d.ts +2 -2
  73. package/dist/types/components/empty-state/empty-state.style.d.ts +2 -2
  74. package/dist/types/components/fade/fade.d.ts +2 -3
  75. package/dist/types/components/fade-scale/fade-scale.d.ts +0 -1
  76. package/dist/types/components/field/field.d.ts +3 -3
  77. package/dist/types/components/field/use-field-props.d.ts +4 -4
  78. package/dist/types/components/fieldset/fieldset.d.ts +3 -4
  79. package/dist/types/components/file-button/file-button.d.ts +2 -4
  80. package/dist/types/components/file-button/use-file-button.d.ts +18 -20
  81. package/dist/types/components/file-input/file-input.d.ts +2 -4
  82. package/dist/types/components/file-input/use-file-input.d.ts +15 -16
  83. package/dist/types/components/flex/flex.d.ts +2 -2
  84. package/dist/types/components/flip/flip.d.ts +4 -5
  85. package/dist/types/components/flip/flip.style.d.ts +1 -1
  86. package/dist/types/components/float/float.d.ts +2 -2
  87. package/dist/types/components/form/form.d.ts +3 -4
  88. package/dist/types/components/format/format-byte.d.ts +2 -2
  89. package/dist/types/components/format/format-date-time.d.ts +2 -2
  90. package/dist/types/components/format/format-number.d.ts +2 -2
  91. package/dist/types/components/format/use-format-byte.d.ts +0 -1
  92. package/dist/types/components/format/use-format-date-time.d.ts +0 -1
  93. package/dist/types/components/format/use-format-number.d.ts +0 -1
  94. package/dist/types/components/grid/grid-item.d.ts +2 -2
  95. package/dist/types/components/grid/grid.d.ts +2 -2
  96. package/dist/types/components/group/group.d.ts +2 -3
  97. package/dist/types/components/group/use-group.d.ts +2 -2
  98. package/dist/types/components/heading/heading.d.ts +2 -2
  99. package/dist/types/components/highlight/highlight.d.ts +0 -2
  100. package/dist/types/components/hue-slider/hue-slider.d.ts +3 -4
  101. package/dist/types/components/icon/icon.d.ts +5 -5
  102. package/dist/types/components/image/image.d.ts +2 -2
  103. package/dist/types/components/indicator/indicator.d.ts +4 -5
  104. package/dist/types/components/infinite-scroll-area/infinite-scroll-area.d.ts +2 -2
  105. package/dist/types/components/input/input-addon.d.ts +2 -2
  106. package/dist/types/components/input/input-element.d.ts +2 -2
  107. package/dist/types/components/input/input-group.d.ts +0 -2
  108. package/dist/types/components/input/input.d.ts +2 -3
  109. package/dist/types/components/kbd/kbd.d.ts +2 -2
  110. package/dist/types/components/link/link.d.ts +2 -2
  111. package/dist/types/components/link-box/link-box.d.ts +2 -2
  112. package/dist/types/components/list/list.d.ts +2 -2
  113. package/dist/types/components/list/list.style.d.ts +2 -2
  114. package/dist/types/components/loading/loading-provider.d.ts +2 -2
  115. package/dist/types/components/loading/loading.d.ts +3 -4
  116. package/dist/types/components/loading/use-loading-component.d.ts +0 -1
  117. package/dist/types/components/mark/mark.d.ts +2 -2
  118. package/dist/types/components/menu/menu.d.ts +2 -3
  119. package/dist/types/components/menu/use-menu.d.ts +11 -11
  120. package/dist/types/components/modal/modal.d.ts +2 -6
  121. package/dist/types/components/native-accordion/native-accordion.d.ts +2 -2
  122. package/dist/types/components/native-accordion/native-accordion.style.d.ts +2 -2
  123. package/dist/types/components/native-accordion/use-native-accordion.d.ts +2 -2
  124. package/dist/types/components/native-popover/native-popover.d.ts +2 -2
  125. package/dist/types/components/native-select/native-select.d.ts +2 -4
  126. package/dist/types/components/native-select/use-native-select.d.ts +0 -1
  127. package/dist/types/components/native-table/native-table.d.ts +2 -2
  128. package/dist/types/components/notice/notice.style.d.ts +1 -1
  129. package/dist/types/components/notice/use-notice.d.ts +0 -3
  130. package/dist/types/components/number-input/number-input.d.ts +2 -3
  131. package/dist/types/components/number-input/number-input.style.d.ts +1 -1
  132. package/dist/types/components/number-input/use-number-input.d.ts +0 -1
  133. package/dist/types/components/pagination/pagination.d.ts +2 -3
  134. package/dist/types/components/pagination/pagination.style.d.ts +1 -1
  135. package/dist/types/components/pagination/use-pagination.d.ts +2 -2
  136. package/dist/types/components/password-input/password-input.d.ts +2 -3
  137. package/dist/types/components/password-input/strength-meter.d.ts +2 -2
  138. package/dist/types/components/password-input/strength-meter.style.d.ts +1 -1
  139. package/dist/types/components/password-input/use-password-input.d.ts +2 -3
  140. package/dist/types/components/picture/picture.d.ts +0 -1
  141. package/dist/types/components/pin-input/pin-input.d.ts +2 -4
  142. package/dist/types/components/pin-input/use-pin-input.d.ts +7 -8
  143. package/dist/types/components/popover/popover.d.ts +2 -3
  144. package/dist/types/components/progress/progress.d.ts +4 -4
  145. package/dist/types/components/progress/use-progress.d.ts +706 -706
  146. package/dist/types/components/qr-code/qr-code.d.ts +2 -2
  147. package/dist/types/components/radio/radio-group.d.ts +0 -2
  148. package/dist/types/components/radio/radio.d.ts +5 -6
  149. package/dist/types/components/radio/radio.style.d.ts +1 -1
  150. package/dist/types/components/radio/use-radio-group.d.ts +2 -3
  151. package/dist/types/components/radio/use-radio.d.ts +0 -1
  152. package/dist/types/components/radio-card/radio-card-group.d.ts +0 -3
  153. package/dist/types/components/radio-card/radio-card.d.ts +5 -7
  154. package/dist/types/components/radio-card/radio-card.style.d.ts +1 -1
  155. package/dist/types/components/rating/rating.style.d.ts +2 -2
  156. package/dist/types/components/rating/use-rating.d.ts +7 -8
  157. package/dist/types/components/reorder/reorder.d.ts +2 -3
  158. package/dist/types/components/reorder/reorder.style.d.ts +1 -1
  159. package/dist/types/components/reorder/use-reorder.d.ts +3 -3
  160. package/dist/types/components/resizable/resizable.d.ts +2 -2
  161. package/dist/types/components/resizable/resizable.style.d.ts +2 -2
  162. package/dist/types/components/resizable/use-resizable.d.ts +2 -2
  163. package/dist/types/components/ripple/ripple.d.ts +2 -3
  164. package/dist/types/components/ripple/use-ripple.d.ts +2 -2
  165. package/dist/types/components/rotate/rotate.d.ts +2 -3
  166. package/dist/types/components/saturation-slider/saturation-slider.d.ts +2 -2
  167. package/dist/types/components/saturation-slider/use-saturation-slider.d.ts +2 -3
  168. package/dist/types/components/scroll-area/scroll-area.d.ts +2 -2
  169. package/dist/types/components/segmented-control/segmented-control.d.ts +2 -3
  170. package/dist/types/components/segmented-control/segmented-control.style.d.ts +2 -2
  171. package/dist/types/components/segmented-control/use-segmented-control.d.ts +9 -10
  172. package/dist/types/components/select/select.d.ts +2 -4
  173. package/dist/types/components/select/select.style.d.ts +1 -1
  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/stat/stat.style.d.ts +2 -2
  192. package/dist/types/components/status/status.d.ts +2 -2
  193. package/dist/types/components/status/status.style.d.ts +2 -2
  194. package/dist/types/components/steps/steps.d.ts +2 -2
  195. package/dist/types/components/steps/steps.style.d.ts +1 -1
  196. package/dist/types/components/steps/use-steps.d.ts +10 -10
  197. package/dist/types/components/switch/switch.d.ts +2 -2
  198. package/dist/types/components/switch/use-switch.d.ts +0 -1
  199. package/dist/types/components/table/table.d.ts +2 -4
  200. package/dist/types/components/tabs/tabs.d.ts +2 -2
  201. package/dist/types/components/tabs/use-tabs.d.ts +16 -16
  202. package/dist/types/components/tag/tag.d.ts +2 -2
  203. package/dist/types/components/tag/tag.style.d.ts +1 -1
  204. package/dist/types/components/text/text.d.ts +2 -2
  205. package/dist/types/components/textarea/textarea.d.ts +2 -4
  206. package/dist/types/components/textarea/use-autosize.d.ts +2 -2
  207. package/dist/types/components/timeline/timeline.d.ts +5 -5
  208. package/dist/types/components/timeline/timeline.style.d.ts +1 -1
  209. package/dist/types/components/tip/tip.d.ts +0 -3
  210. package/dist/types/components/toggle/toggle-group.d.ts +1 -1
  211. package/dist/types/components/toggle/toggle.d.ts +5 -7
  212. package/dist/types/components/toggle/use-toggle-group.d.ts +2 -2
  213. package/dist/types/components/toggle/use-toggle.d.ts +2 -3
  214. package/dist/types/components/tooltip/tooltip.d.ts +2 -4
  215. package/dist/types/components/tree/tree.d.ts +2 -6
  216. package/dist/types/components/tree/tree.style.d.ts +1 -1
  217. package/dist/types/components/tree/use-tree.d.ts +182 -183
  218. package/dist/types/components/visually-hidden/visually-hidden.d.ts +2 -2
  219. package/dist/types/components/wrap/wrap.d.ts +2 -3
  220. package/dist/types/core/components/create-component.d.ts +9 -7
  221. package/dist/types/core/components/index.types.d.ts +1 -0
  222. package/dist/types/core/components/use-component-style.d.ts +2 -0
  223. package/dist/types/core/components/utils.d.ts +1 -0
  224. package/dist/types/core/constant.d.ts +1 -0
  225. package/dist/types/core/css/calc.d.ts +1 -0
  226. package/dist/types/core/css/config.d.ts +1 -0
  227. package/dist/types/core/css/css.d.ts +1 -0
  228. package/dist/types/core/css/index.types.d.ts +1 -0
  229. package/dist/types/core/css/styles.d.ts +1 -0
  230. package/dist/types/core/css/token.d.ts +1 -0
  231. package/dist/types/core/css/use-css.d.ts +1 -0
  232. package/dist/types/core/css/utils.d.ts +2 -0
  233. package/dist/types/core/generated-theme-tokens.types.d.ts +1 -0
  234. package/dist/types/core/index.d.ts +2 -0
  235. package/dist/types/core/system/color-mode-provider.d.ts +2 -2
  236. package/dist/types/core/system/config.d.ts +1 -0
  237. package/dist/types/core/system/create-system.d.ts +1 -0
  238. package/dist/types/core/system/factory.d.ts +1 -0
  239. package/dist/types/core/system/index.types.d.ts +1 -0
  240. package/dist/types/core/system/storage-script.d.ts +3 -3
  241. package/dist/types/core/system/styled.d.ts +3 -2
  242. package/dist/types/core/system/system-provider.d.ts +2 -2
  243. package/dist/types/core/system/var.d.ts +2 -0
  244. package/dist/types/hooks/use-async-callback/index.d.ts +0 -1
  245. package/dist/types/hooks/use-breakpoint/use-breakpoint-state.d.ts +2 -2
  246. package/dist/types/hooks/use-combobox/index.d.ts +12 -13
  247. package/dist/types/hooks/use-counter/index.d.ts +2 -2
  248. package/dist/types/index.d.ts +0 -106
  249. package/dist/types/providers/i18n-provider/i18n-provider.d.ts +3 -3
  250. package/dist/types/providers/ui-provider/ui-provider.d.ts +2 -3
  251. package/dist/types/utils/children.d.ts +2 -2
  252. package/package.json +2 -2
@@ -1 +1 @@
1
- {"version":3,"file":"use-calendar.js","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 }[]","createContext","value","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","getMonthProps: PropGetter<\"table\">","getWeekdayProps: RequiredPropGetter<\"th\", { value: number }>","getButtonProps: PropGetter<\"button\">","getPrevButtonProps: PropGetter<\"button\">","getNextButtonProps: PropGetter<\"button\">","holiday","selectedValue","ev","calendarProps: (keyof UseCalendarProps)[]"],"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.js","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 }[]","createContext","value","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","getMonthProps: PropGetter<\"table\">","getWeekdayProps: RequiredPropGetter<\"th\", { value: number }>","getButtonProps: PropGetter<\"button\">","getPrevButtonProps: PropGetter<\"button\">","getNextButtonProps: PropGetter<\"button\">","holiday","selectedValue","ev","calendarProps: (keyof UseCalendarProps)[]"],"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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"}
@@ -3,13 +3,11 @@ import { ThemeProps } from "../../core/system/index.types.js";
3
3
  import { Component, HTMLStyledProps } from "../../core/components/index.types.js";
4
4
  import "../../core/index.js";
5
5
  import { WithTransitionProps } from "../motion/index.types.js";
6
- import "../motion/index.js";
7
6
  import { CollapseProps } from "../collapse/collapse.js";
8
- import "../collapse/index.js";
9
7
  import "../../index.js";
10
8
  import { AccordionStyle } from "./accordion.style.js";
11
9
  import { UseAccordionItemProps, UseAccordionProps } from "./use-accordion.js";
12
- import * as react469 from "react";
10
+ import * as react83 from "react";
13
11
 
14
12
  //#region src/components/accordion/accordion.d.ts
15
13
  interface AccordionCallBackProps {
@@ -33,7 +31,7 @@ interface AccordionRootProps extends Omit<HTMLStyledProps, "onChange">, ThemePro
33
31
  */
34
32
  items?: AccordionItem[];
35
33
  }
36
- declare const AccordionPropsContext: react469.Context<Partial<AccordionRootProps> | undefined>, useAccordionPropsContext: () => Partial<AccordionRootProps> | undefined;
34
+ declare const AccordionPropsContext: react83.Context<Partial<AccordionRootProps> | undefined>, useAccordionPropsContext: () => Partial<AccordionRootProps> | undefined;
37
35
  /**
38
36
  * `Accordion` is a component for a list that displays information in an expandable or collapsible manner.
39
37
  *
@@ -3,7 +3,7 @@ import { CSSModifierObject, CSSPropObject, CSSSlotObject } from "../../core/css/
3
3
  import "../../index.js";
4
4
 
5
5
  //#region src/components/accordion/accordion.style.d.ts
6
- declare const accordionStyle: ComponentSlotStyle<"button" | "panel" | "icon" | "item" | "root", CSSPropObject<CSSSlotObject<"button" | "panel" | "icon" | "item" | "root">>, CSSModifierObject<CSSSlotObject<"button" | "panel" | "icon" | "item" | "root">>, {
6
+ declare const accordionStyle: ComponentSlotStyle<"button" | "panel" | "icon" | "root" | "item", CSSPropObject<CSSSlotObject<"button" | "panel" | "icon" | "root" | "item">>, CSSModifierObject<CSSSlotObject<"button" | "panel" | "icon" | "root" | "item">>, {
7
7
  panel: {
8
8
  button: {
9
9
  rounded: "l2";
@@ -2,10 +2,10 @@ import { HTMLProps, PropGetter } from "../../core/components/index.types.js";
2
2
  import "../../core/index.js";
3
3
  import { Descendant } from "../../hooks/use-descendants/index.js";
4
4
  import "../../index.js";
5
- import * as react457 from "react";
5
+ import * as react71 from "react";
6
6
 
7
7
  //#region src/components/accordion/use-accordion.d.ts
8
- declare const AccordionDescendantsContext: react457.Context<{
8
+ declare const AccordionDescendantsContext: react71.Context<{
9
9
  active: (target?: HTMLButtonElement | Descendant<HTMLButtonElement, {}> | null | undefined, options?: FocusOptions) => void;
10
10
  count: (props?: Partial<{}> | undefined) => number;
11
11
  destroy: () => void;
@@ -24,7 +24,7 @@ declare const AccordionDescendantsContext: react457.Context<{
24
24
  prevValue: (indexOrNode: number | HTMLButtonElement | Descendant<HTMLButtonElement, {}> | null, loop?: boolean, props?: Partial<{}> | undefined) => Descendant<HTMLButtonElement, {}> | undefined;
25
25
  register: (props?: {
26
26
  disabled?: boolean | ((node: HTMLButtonElement) => boolean) | undefined;
27
- } | undefined) => react457.RefCallback<HTMLButtonElement>;
27
+ } | undefined) => react71.RefCallback<HTMLButtonElement>;
28
28
  unregister: (node?: HTMLButtonElement | null | undefined) => void;
29
29
  value: (indexOrNode: number | HTMLButtonElement | null) => Descendant<HTMLButtonElement, {}> | undefined;
30
30
  values: (props?: Partial<{}> | undefined) => Descendant<HTMLButtonElement, {}>[];
@@ -50,12 +50,12 @@ declare const AccordionDescendantsContext: react457.Context<{
50
50
  prevValue: (indexOrNode: number | HTMLButtonElement | Descendant<HTMLButtonElement, {}> | null, loop?: boolean, props?: Partial<{}> | undefined) => Descendant<HTMLButtonElement, {}> | undefined;
51
51
  register: (props?: {
52
52
  disabled?: boolean | ((node: HTMLButtonElement) => boolean) | undefined;
53
- } | undefined) => react457.RefCallback<HTMLButtonElement>;
53
+ } | undefined) => react71.RefCallback<HTMLButtonElement>;
54
54
  unregister: (node?: HTMLButtonElement | null | undefined) => void;
55
55
  value: (indexOrNode: number | HTMLButtonElement | null) => Descendant<HTMLButtonElement, {}> | undefined;
56
56
  values: (props?: Partial<{}> | undefined) => Descendant<HTMLButtonElement, {}>[];
57
57
  };
58
- register: react457.RefCallback<HTMLButtonElement>;
58
+ register: react71.RefCallback<HTMLButtonElement>;
59
59
  }, useAccordionDescendants: () => {
60
60
  active: (target?: HTMLButtonElement | Descendant<HTMLButtonElement, {}> | null | undefined, options?: FocusOptions) => void;
61
61
  count: (props?: Partial<{}> | undefined) => number;
@@ -75,15 +75,15 @@ declare const AccordionDescendantsContext: react457.Context<{
75
75
  prevValue: (indexOrNode: number | HTMLButtonElement | Descendant<HTMLButtonElement, {}> | null, loop?: boolean, props?: Partial<{}> | undefined) => Descendant<HTMLButtonElement, {}> | undefined;
76
76
  register: (props?: {
77
77
  disabled?: boolean | ((node: HTMLButtonElement) => boolean) | undefined;
78
- } | undefined) => react457.RefCallback<HTMLButtonElement>;
78
+ } | undefined) => react71.RefCallback<HTMLButtonElement>;
79
79
  unregister: (node?: HTMLButtonElement | null | undefined) => void;
80
80
  value: (indexOrNode: number | HTMLButtonElement | null) => Descendant<HTMLButtonElement, {}> | undefined;
81
81
  values: (props?: Partial<{}> | undefined) => Descendant<HTMLButtonElement, {}>[];
82
82
  };
83
83
  interface AccordionContext extends Omit<UseAccordionReturn, "descendants" | "getRootProps"> {}
84
- declare const AccordionContext: react457.Context<AccordionContext>, useAccordionContext: () => AccordionContext;
84
+ declare const AccordionContext: react71.Context<AccordionContext>, useAccordionContext: () => AccordionContext;
85
85
  interface AccordionItemContext extends Omit<UseAccordionItemReturn, "getItemProps"> {}
86
- declare const AccordionItemContext: react457.Context<AccordionItemContext>, useAccordionItemContext: () => AccordionItemContext;
86
+ declare const AccordionItemContext: react71.Context<AccordionItemContext>, useAccordionItemContext: () => AccordionItemContext;
87
87
  interface UseAccordionProps extends Omit<HTMLProps, "onChange"> {
88
88
  /**
89
89
  * The initial index(es) of the accordion item to expand.
@@ -137,7 +137,7 @@ declare const useAccordion: ({
137
137
  prevValue: (indexOrNode: number | HTMLButtonElement | Descendant<HTMLButtonElement, {}> | null, loop?: boolean, props?: Partial<{}> | undefined) => Descendant<HTMLButtonElement, {}> | undefined;
138
138
  register: (props?: {
139
139
  disabled?: boolean | ((node: HTMLButtonElement) => boolean) | undefined;
140
- } | undefined) => react457.RefCallback<HTMLButtonElement>;
140
+ } | undefined) => react71.RefCallback<HTMLButtonElement>;
141
141
  unregister: (node?: HTMLButtonElement | null | undefined) => void;
142
142
  value: (indexOrNode: number | HTMLButtonElement | null) => Descendant<HTMLButtonElement, {}> | undefined;
143
143
  values: (props?: Partial<{}> | undefined) => Descendant<HTMLButtonElement, {}>[];
@@ -145,8 +145,8 @@ declare const useAccordion: ({
145
145
  focusedIndex: number;
146
146
  index: number | number[];
147
147
  multiple: boolean | undefined;
148
- setFocusedIndex: react457.Dispatch<react457.SetStateAction<number>>;
149
- setIndex: react457.Dispatch<react457.SetStateAction<number | number[]>>;
148
+ setFocusedIndex: react71.Dispatch<react71.SetStateAction<number>>;
149
+ setIndex: react71.Dispatch<react71.SetStateAction<number | number[]>>;
150
150
  toggle: boolean | undefined;
151
151
  getRootProps: PropGetter<"div", undefined, undefined>;
152
152
  };
@@ -4,10 +4,9 @@ import "../../core/index.js";
4
4
  import { ActionBarStyle } from "./action-bar.style.js";
5
5
  import { PortalProps } from "../portal/portal.js";
6
6
  import { UsePopupAnimationProps } from "../popover/popover.js";
7
- import "../popover/index.js";
8
7
  import { UseActionBarProps } from "./use-action-bar.js";
9
8
  import "../../index.js";
10
- import * as react456 from "react";
9
+ import * as react68 from "react";
11
10
  import { PropsWithChildren, ReactNode } from "react";
12
11
 
13
12
  //#region src/components/action-bar/action-bar.d.ts
@@ -29,7 +28,7 @@ interface ActionBarRootProps extends Omit<HTMLStyledProps, "content">, ThemeProp
29
28
  */
30
29
  onCloseComplete?: () => void;
31
30
  }
32
- declare const ActionBarPropsContext: react456.Context<Partial<ActionBarRootProps> | undefined>, useActionBarPropsContext: () => Partial<ActionBarRootProps> | undefined;
31
+ declare const ActionBarPropsContext: react68.Context<Partial<ActionBarRootProps> | undefined>, useActionBarPropsContext: () => Partial<ActionBarRootProps> | undefined;
33
32
  /**
34
33
  * `ActionBar` is a component that is used to display a bottom action bar with a set of actions.
35
34
  *
@@ -2,10 +2,9 @@ import { KeyframeIdent, ThemeProps } from "../../core/system/index.types.js";
2
2
  import { Component } from "../../core/components/index.types.js";
3
3
  import "../../core/index.js";
4
4
  import { HTMLMotionProps } from "../motion/index.types.js";
5
- import "../motion/index.js";
6
5
  import { AiryStyle } from "./airy.style.js";
7
6
  import "../../index.js";
8
- import * as react455 from "react";
7
+ import * as react101 from "react";
9
8
  import { ReactNode } from "react";
10
9
 
11
10
  //#region src/components/airy/airy.d.ts
@@ -57,7 +56,7 @@ interface AiryProps extends Omit<HTMLMotionProps<"button">, "onChange">, ThemePr
57
56
  */
58
57
  onChange?: (value: KeyframeIdent) => void;
59
58
  }
60
- declare const AiryPropsContext: react455.Context<Partial<AiryProps> | undefined>, useAiryPropsContext: () => Partial<AiryProps> | undefined;
59
+ declare const AiryPropsContext: react101.Context<Partial<AiryProps> | undefined>, useAiryPropsContext: () => Partial<AiryProps> | undefined;
61
60
  /**
62
61
  * `Airy` is a component that creates an airy animation, switching between two elements when one is clicked.
63
62
  *
@@ -3,13 +3,10 @@ import { Component, HTMLStyledProps } from "../../core/components/index.types.js
3
3
  import "../../core/index.js";
4
4
  import { AlertStyle } from "./alert.style.js";
5
5
  import { IconProps } from "../icon/icon.js";
6
- import "../icon/index.js";
7
6
  import { LoadingProps } from "../loading/loading.js";
8
- import "../loading/index.js";
9
7
  import { StatusScheme } from "../status/status.js";
10
- import "../status/index.js";
11
8
  import "../../index.js";
12
- import * as react454 from "react";
9
+ import * as react97 from "react";
13
10
 
14
11
  //#region src/components/alert/alert.d.ts
15
12
  interface AlertRootProps extends HTMLStyledProps, ThemeProps<AlertStyle> {
@@ -20,7 +17,7 @@ interface AlertRootProps extends HTMLStyledProps, ThemeProps<AlertStyle> {
20
17
  */
21
18
  status?: StatusScheme;
22
19
  }
23
- declare const AlertPropsContext: react454.Context<Partial<AlertRootProps> | undefined>, useAlertPropsContext: () => Partial<AlertRootProps> | undefined;
20
+ declare const AlertPropsContext: react97.Context<Partial<AlertRootProps> | undefined>, useAlertPropsContext: () => Partial<AlertRootProps> | undefined;
24
21
  /**
25
22
  * `Alert` is a component that conveys information to the user.
26
23
  *
@@ -3,9 +3,8 @@ import { Component } from "../../core/components/index.types.js";
3
3
  import "../../core/index.js";
4
4
  import { AlphaSliderStyle } from "./alpha-slider.style.js";
5
5
  import { HueSliderOverlayProps, HueSliderRootProps, HueSliderThumbProps, HueSliderTrackProps } from "../hue-slider/hue-slider.js";
6
- import "../hue-slider/index.js";
7
6
  import "../../index.js";
8
- import * as react453 from "react";
7
+ import * as react67 from "react";
9
8
 
10
9
  //#region src/components/alpha-slider/alpha-slider.d.ts
11
10
  interface AlphaSliderRootProps extends WithoutThemeProps<Omit<HueSliderRootProps, "color" | "max" | "step" | "thumbProps" | "trackProps">, AlphaSliderStyle> {
@@ -38,7 +37,7 @@ interface AlphaSliderRootProps extends WithoutThemeProps<Omit<HueSliderRootProps
38
37
  */
39
38
  trackProps?: AlphaSliderTrackProps;
40
39
  }
41
- declare const AlphaSliderPropsContext: react453.Context<Partial<AlphaSliderRootProps> | undefined>, useAlphaSliderPropsContext: () => Partial<AlphaSliderRootProps> | undefined;
40
+ declare const AlphaSliderPropsContext: react67.Context<Partial<AlphaSliderRootProps> | undefined>, useAlphaSliderPropsContext: () => Partial<AlphaSliderRootProps> | undefined;
42
41
  /**
43
42
  * `AlphaSlider` is a component used to allow the user to select color transparency.
44
43
  *
@@ -2,7 +2,7 @@ import { StyleValue } from "../../core/css/index.types.js";
2
2
  import { Component, HTMLStyledProps } from "../../core/components/index.types.js";
3
3
  import "../../core/index.js";
4
4
  import "../../index.js";
5
- import * as react452 from "react";
5
+ import * as react84 from "react";
6
6
 
7
7
  //#region src/components/aspect-ratio/aspect-ratio.d.ts
8
8
  interface AspectRatioProps extends HTMLStyledProps {
@@ -13,7 +13,7 @@ interface AspectRatioProps extends HTMLStyledProps {
13
13
  */
14
14
  ratio?: StyleValue<number>;
15
15
  }
16
- declare const AspectRatioPropsContext: react452.Context<Partial<AspectRatioProps> | undefined>, useAspectRatioPropsContext: () => Partial<AspectRatioProps> | undefined;
16
+ declare const AspectRatioPropsContext: react84.Context<Partial<AspectRatioProps> | undefined>, useAspectRatioPropsContext: () => Partial<AspectRatioProps> | undefined;
17
17
  /**
18
18
  * `AspectRatio` is a component for embedding things like videos and maps while maintaining the aspect ratio.
19
19
  *
@@ -3,16 +3,14 @@ import { ThemeProps } from "../../core/system/index.types.js";
3
3
  import { Component, GenericsComponent, HTMLStyledProps } from "../../core/components/index.types.js";
4
4
  import "../../core/index.js";
5
5
  import { PopoverContentProps, UsePopoverStyleProps, UsePopupAnimationProps } from "../popover/popover.js";
6
- import "../popover/index.js";
7
6
  import { AutocompleteStyle } from "./autocomplete.style.js";
8
7
  import { UseComboboxGroupProps } from "../../hooks/use-combobox/index.js";
9
8
  import { UseInputBorderProps } from "../input/use-input-border.js";
10
9
  import { InputElementProps } from "../input/input-element.js";
11
10
  import { InputGroupRootProps } from "../input/input-group.js";
12
- import "../input/index.js";
13
11
  import { UseAutocompleteOptionProps, UseAutocompleteProps } from "./use-autocomplete.js";
14
12
  import "../../index.js";
15
- import * as react451 from "react";
13
+ import * as react66 from "react";
16
14
  import { ReactElement, ReactNode } from "react";
17
15
 
18
16
  //#region src/components/autocomplete/autocomplete.d.ts
@@ -68,7 +66,7 @@ interface AutocompleteRootProps<Multiple extends boolean = false> extends Omit<H
68
66
  */
69
67
  rootProps?: InputGroupRootProps;
70
68
  }
71
- declare const AutocompletePropsContext: react451.Context<Partial<AutocompleteRootProps<false>> | undefined>, useAutocompletePropsContext: () => Partial<AutocompleteRootProps<false>> | undefined;
69
+ declare const AutocompletePropsContext: react66.Context<Partial<AutocompleteRootProps<false>> | undefined>, useAutocompletePropsContext: () => Partial<AutocompleteRootProps<false>> | undefined;
72
70
  /**
73
71
  * `Autocomplete` is a component used to display suggestions in response to user text input.
74
72
  *
@@ -3,7 +3,7 @@ import { CSSPropObject, CSSSlotObject } from "../../core/css/index.types.js";
3
3
  import "../../index.js";
4
4
 
5
5
  //#region src/components/autocomplete/autocomplete.style.d.ts
6
- declare const autocompleteStyle: ComponentSlotStyle<"input" | "label" | "option" | "content" | "group" | "separator" | "icon" | "indicator" | "root" | "field" | "empty" | "valueText", CSSPropObject<CSSSlotObject<"input" | "label" | "option" | "content" | "group" | "separator" | "icon" | "indicator" | "root" | "field" | "empty" | "valueText">>, {
6
+ declare const autocompleteStyle: ComponentSlotStyle<"input" | "label" | "option" | "content" | "group" | "separator" | "icon" | "root" | "indicator" | "field" | "valueText" | "empty", CSSPropObject<CSSSlotObject<"input" | "label" | "option" | "content" | "group" | "separator" | "icon" | "root" | "indicator" | "field" | "valueText" | "empty">>, {
7
7
  xs: {
8
8
  empty: {
9
9
  gap: "1.5";
@@ -2,13 +2,11 @@ import { index_d_exports } from "../../utils/index.js";
2
2
  import { HTMLProps, HTMLRefAttributes, PropGetter } from "../../core/components/index.types.js";
3
3
  import "../../core/index.js";
4
4
  import { UsePopoverProps } from "../popover/use-popover.js";
5
- import "../popover/index.js";
6
5
  import { FieldProps } from "../field/field.js";
7
- import "../field/index.js";
8
6
  import { Descendant, DescendantProps } from "../../hooks/use-descendants/index.js";
9
7
  import { ComboboxDescendant, ComboboxDescendantProps, ComboboxItem, ComboboxItemWithValue, UseComboboxItemProps, UseComboboxProps } from "../../hooks/use-combobox/index.js";
10
8
  import "../../index.js";
11
- import * as react445 from "react";
9
+ import * as react60 from "react";
12
10
  import { ChangeEvent, ReactNode } from "react";
13
11
 
14
12
  //#region src/components/autocomplete/use-autocomplete.d.ts
@@ -28,7 +26,7 @@ interface AutocompleteFilter {
28
26
  }
29
27
  type AutocompleteMatcher = typeof index_d_exports.match;
30
28
  interface AutocompleteContext extends Pick<UseAutocompleteReturn, "max" | "value"> {}
31
- declare const AutocompleteContext: react445.Context<AutocompleteContext>, useAutocompleteContext: () => AutocompleteContext;
29
+ declare const AutocompleteContext: react60.Context<AutocompleteContext>, useAutocompleteContext: () => AutocompleteContext;
32
30
  interface UseAutocompleteProps<Multiple extends boolean = false> extends Omit<HTMLProps, "defaultValue" | "onChange" | "ref" | "value">, Omit<UseComboboxProps, "defaultValue" | "initialFocusValue" | "onChange" | "ref" | "value">, HTMLRefAttributes<"input">, FieldProps {
33
31
  /**
34
32
  * If `true`, the autocomplete will allow custom value.
@@ -156,7 +154,7 @@ declare const useAutocomplete: <Multiple extends boolean = false>(props?: UseAut
156
154
  lastValue: (props?: Partial<ComboboxDescendantProps> | undefined) => Descendant<HTMLDivElement, ComboboxDescendantProps> | undefined;
157
155
  nextValue: (indexOrNode: number | HTMLDivElement | Descendant<HTMLDivElement, ComboboxDescendantProps> | null, loop?: boolean, props?: Partial<ComboboxDescendantProps> | undefined) => Descendant<HTMLDivElement, ComboboxDescendantProps> | undefined;
158
156
  prevValue: (indexOrNode: number | HTMLDivElement | Descendant<HTMLDivElement, ComboboxDescendantProps> | null, loop?: boolean, props?: Partial<ComboboxDescendantProps> | undefined) => Descendant<HTMLDivElement, ComboboxDescendantProps> | undefined;
159
- register: (props?: DescendantProps<HTMLDivElement, ComboboxDescendantProps> | undefined) => react445.RefCallback<HTMLDivElement>;
157
+ register: (props?: DescendantProps<HTMLDivElement, ComboboxDescendantProps> | undefined) => react60.RefCallback<HTMLDivElement>;
160
158
  unregister: (node?: HTMLDivElement | null | undefined) => void;
161
159
  value: (indexOrNode: number | HTMLDivElement | null) => Descendant<HTMLDivElement, ComboboxDescendantProps> | undefined;
162
160
  values: (props?: Partial<ComboboxDescendantProps> | undefined) => Descendant<HTMLDivElement, ComboboxDescendantProps>[];
@@ -166,8 +164,8 @@ declare const useAutocomplete: <Multiple extends boolean = false>(props?: UseAut
166
164
  items: ComboboxItem[];
167
165
  max: number | undefined;
168
166
  open: boolean;
169
- setInputValue: react445.Dispatch<react445.SetStateAction<string>>;
170
- setValue: react445.Dispatch<react445.SetStateAction<Multiple extends true ? string[] : string>>;
167
+ setInputValue: react60.Dispatch<react60.SetStateAction<string>>;
168
+ setValue: react60.Dispatch<react60.SetStateAction<Multiple extends true ? string[] : string>>;
171
169
  value: Multiple extends true ? string[] : string;
172
170
  valueMap: {
173
171
  [key: string]: ComboboxItemWithValue;
@@ -6,9 +6,9 @@ import "../../core/index.js";
6
6
  import { AvatarStyle } from "./avatar.style.js";
7
7
  import { UseAvatarProps } from "./use-avatar.js";
8
8
  import "../../index.js";
9
- import * as react1216 from "react";
9
+ import * as react56 from "react";
10
10
  import { ReactElement } from "react";
11
- import * as _yamada_ui_utils19 from "@yamada-ui/utils";
11
+ import * as _yamada_ui_utils2 from "@yamada-ui/utils";
12
12
 
13
13
  //#region src/components/avatar/avatar.d.ts
14
14
  interface AvatarProps extends HTMLStyledProps, ThemeProps<AvatarStyle>, UseAvatarProps {
@@ -25,7 +25,7 @@ interface AvatarProps extends HTMLStyledProps, ThemeProps<AvatarStyle>, UseAvata
25
25
  */
26
26
  imageProps?: AvatarImageProps;
27
27
  }
28
- declare const component: <H extends "fragment" | As = "div", R extends _yamada_ui_utils19.Dict = _yamada_ui_utils19.Dict<any>>(el: H | react1216.FC<R>, slot?: ComponentSlot<ComponentSlotName<ComponentSlotStyle<"image" | "group" | "fallback" | "root", {
28
+ declare const component: <H extends "fragment" | As = "div", R extends _yamada_ui_utils2.Dict = _yamada_ui_utils2.Dict<any>>(el: H | react56.FC<R>, slot?: ComponentSlot<ComponentSlotName<ComponentSlotStyle<"image" | "group" | "root" | "fallback", {
29
29
  shape: {
30
30
  circle: {
31
31
  root: {
@@ -148,7 +148,7 @@ declare const component: <H extends "fragment" | As = "div", R extends _yamada_u
148
148
  name,
149
149
  className,
150
150
  ...options
151
- }?: ComponentOptions) => (initialProps?: InitialProps<R>, ...superProps: SuperProps<R>[]) => H extends "fragment" ? react1216.FunctionComponent<R> : Component<Exclude<H, "fragment">, R>, AvatarPropsContext: react1216.Context<Partial<AvatarProps> | undefined>, useAvatarPropsContext: () => Partial<AvatarProps> | undefined, useRootComponentProps: <Y extends _yamada_ui_utils19.Dict = {}, R extends keyof Y = keyof Y>(props: Y, slot?: ComponentSlot<ComponentSlotName<ComponentSlotStyle<"image" | "group" | "fallback" | "root", {
151
+ }?: ComponentOptions) => (initialProps?: InitialProps<R>, ...superProps: SuperProps<R>[]) => H extends "fragment" ? react56.FunctionComponent<R> : Component<Exclude<H, "fragment">, R>, AvatarPropsContext: react56.Context<Partial<AvatarProps> | undefined>, useAvatarPropsContext: () => Partial<AvatarProps> | undefined, useRootComponentProps: <Y extends _yamada_ui_utils2.Dict = {}, R extends keyof Y = keyof Y>(props: Y, slot?: ComponentSlot<ComponentSlotName<ComponentSlotStyle<"image" | "group" | "root" | "fallback", {
152
152
  shape: {
153
153
  circle: {
154
154
  root: {
@@ -271,7 +271,7 @@ declare const component: <H extends "fragment" | As = "div", R extends _yamada_u
271
271
  className,
272
272
  withContext,
273
273
  transferProps
274
- }?: UseComponentPropsOptions<R>) => [CSSSlotObject, _yamada_ui_utils19.Merge<WithoutThemeProps<Y, ComponentSlotStyle<"image" | "group" | "fallback" | "root", {
274
+ }?: UseComponentPropsOptions<R>) => [CSSSlotObject, _yamada_ui_utils2.Merge<WithoutThemeProps<Y, ComponentSlotStyle<"image" | "group" | "root" | "fallback", {
275
275
  shape: {
276
276
  circle: {
277
277
  root: {
@@ -2,7 +2,7 @@ import { ComponentSlotStyle } from "../../core/system/index.types.js";
2
2
  import "../../index.js";
3
3
 
4
4
  //#region src/components/avatar/avatar.style.d.ts
5
- declare const avatarStyle: ComponentSlotStyle<"image" | "group" | "fallback" | "root", {
5
+ declare const avatarStyle: ComponentSlotStyle<"image" | "group" | "root" | "fallback", {
6
6
  /**
7
7
  * The shape of the component
8
8
  *