1 | import type { CalendarWeek, CalendarDay, CalendarMonth } from "./classes/index.js";
|
2 | import type { DayPickerProps } from "./types/props.js";
|
3 | import type { DateLib } from "./types/shared.js";
|
4 | /**
|
5 | * Return the calendar object to work with the calendar in custom components.
|
6 | *
|
7 | * @see https://daypicker.dev/guides/custom-components
|
8 | */
|
9 | export interface Calendar {
|
10 | /**
|
11 | * All the days displayed in the calendar. As opposite from
|
12 | * {@link CalendarContext.dates}, it may return duplicated dates when shown
|
13 | * outside the month.
|
14 | */
|
15 | days: CalendarDay[];
|
16 | /** The months displayed in the calendar. */
|
17 | weeks: CalendarWeek[];
|
18 | /** The months displayed in the calendar. */
|
19 | months: CalendarMonth[];
|
20 | /** The next month to display. */
|
21 | nextMonth: Date | undefined;
|
22 | /** The previous month to display. */
|
23 | previousMonth: Date | undefined;
|
24 | /**
|
25 | * The month where the navigation starts. `undefined` if the calendar can be
|
26 | * navigated indefinitely to the past.
|
27 | */
|
28 | navStart: Date | undefined;
|
29 | /**
|
30 | * The month where the navigation ends. `undefined` if the calendar can be
|
31 | * navigated indefinitely to the past.
|
32 | */
|
33 | navEnd: Date | undefined;
|
34 | /** Navigate to the specified month. Will fire the `onMonthChange` callback. */
|
35 | goToMonth: (month: Date) => void;
|
36 | /**
|
37 | * Navigate to the specified date. If the second parameter (refDate) is
|
38 | * provided and the date is before the refDate, then the month is set to one
|
39 | * month before the date.
|
40 | *
|
41 | * @param day - The date to navigate to.
|
42 | * @param dateToCompare - Optional. If `date` is before `dateToCompare`, the
|
43 | * month is set to one month before the date.
|
44 | */
|
45 | goToDay: (day: CalendarDay) => void;
|
46 | }
|
47 | /** @private */
|
48 | export declare function useCalendar(props: DayPickerProps, dateLib: DateLib): Calendar;
|