///
import type { DayPickerProps, LocaleUtils } from "react-day-picker";
import type { TimePickerProps } from "./timePickerProps";
import type { TimePrecision } from "./timePrecision";
/**
* Collection of functions that determine which modifier classes get applied to which days.
* See the [**react-day-picker** documentation](https://react-day-picker-v7.netlify.app/api/ModifiersUtils)
* to learn more.
*/
export interface DatePickerModifiers {
[name: string]: (date: Date) => boolean;
}
export interface DatePickerBaseProps {
/**
* Props to pass to ReactDayPicker. See API documentation
* [here](https://react-day-picker-v7.netlify.app/api/DayPicker).
*
* The following props are managed by the component and cannot be configured:
* `canChangeMonth`, `captionElement`, `fromMonth` (use `minDate`), `month` (use
* `initialMonth`), `toMonth` (use `maxDate`).
*
* In case of supplying your owner `renderDay` function, make sure to apply the appropriate
* CSS wrapper class to obtain default Blueprint styling.
* eg.
* `
{CONTENT_HERE}
`
*
*/
dayPickerProps?: DayPickerProps;
/**
* An additional element to show below the date picker.
*/
footerElement?: React.JSX.Element;
/**
* Whether the current day should be highlighted in the calendar.
*
* @default false
*/
highlightCurrentDay?: boolean;
/**
* The initial month the calendar displays.
*/
initialMonth?: Date;
/**
* The locale name, which is passed to the functions in `localeUtils`
* (and `formatDate` and `parseDate` if supported).
*/
locale?: string;
/**
* Collection of functions that provide internationalization support.
*/
localeUtils?: typeof LocaleUtils;
/**
* The latest date the user can select.
*
* @default 6 months from now.
*/
maxDate?: Date;
/**
* The earliest date the user can select.
*
* @default Jan. 1st, 20 years in the past.
*/
minDate?: Date;
/**
* Collection of functions that determine which modifier classes get applied to which days.
* Each function should accept a `Date` and return a boolean.
* See the [**react-day-picker** documentation](https://react-day-picker-v7.netlify.app/api/ModifiersUtils)
* to learn more.
*/
modifiers?: DatePickerModifiers;
/**
* If `true`, the month menu will appear to the left of the year menu.
* Otherwise, the month menu will apear to the right of the year menu.
*
* @default false
*/
reverseMonthAndYearMenus?: boolean;
/**
* The precision of time selection that accompanies the calendar. Passing a
* `TimePrecision` value (or providing `timePickerProps`) shows a
* `TimePicker` below the calendar. Time is preserved across date changes.
*
* This is shorthand for `timePickerProps.precision` and is a quick way to
* enable time selection.
*/
timePrecision?: TimePrecision;
/**
* Further configure the `TimePicker` that appears beneath the calendar.
* `onChange` and `value` are ignored in favor of the corresponding
* top-level props on this component.
*
* Passing any non-empty object to this prop will cause the `TimePicker` to appear.
*/
timePickerProps?: TimePickerProps;
}