Files
Iliyan Angelov 306b20e24a Frontend start
2025-09-14 00:54:48 +03:00

61 lines
2.7 KiB
TypeScript

import * as React from 'react';
import { PickersDayProps } from '../PickersDay/PickersDay';
import { PickerOnChangeFn } from '../internals/hooks/useViews';
import { SlideDirection, SlideTransitionProps } from './PickersSlideTransition';
import { BaseDateValidationProps, DayValidationProps } from '../internals/hooks/validation/models';
import { DayPickerClasses } from './dayPickerClasses';
export interface ExportedDayPickerProps<TDate> extends Pick<PickersDayProps<TDate>, 'disableHighlightToday' | 'showDaysOutsideCurrentMonth'> {
/**
* If `true` renders `LoadingComponent` in calendar instead of calendar view.
* Can be used to preload information and show it in calendar.
* @default false
*/
loading?: boolean;
/**
* Custom renderer for day. Check the [PickersDay](https://mui.com/x/api/date-pickers/pickers-day/) component.
* @template TDate
* @param {TDate} day The day to render.
* @param {Array<TDate | null>} selectedDays The days currently selected.
* @param {PickersDayProps<TDate>} pickersDayProps The props of the day to render.
* @returns {JSX.Element} The element representing the day.
*/
renderDay?: (day: TDate, selectedDays: TDate[], pickersDayProps: PickersDayProps<TDate>) => JSX.Element;
/**
* Component displaying when passed `loading` true.
* @returns {React.ReactNode} The node to render when loading.
* @default () => "..."
*/
renderLoading?: () => React.ReactNode;
/**
* Formats the day of week displayed in the calendar header.
* @param {string} day The day of week provided by the adapter's method `getWeekdays`.
* @returns {string} The name to display.
* @default (day) => day.charAt(0).toUpperCase()
*/
dayOfWeekFormatter?: (day: string) => string;
}
export interface DayPickerProps<TDate> extends ExportedDayPickerProps<TDate>, DayValidationProps<TDate>, Required<BaseDateValidationProps<TDate>> {
autoFocus?: boolean;
className?: string;
currentMonth: TDate;
selectedDays: (TDate | null)[];
onSelectedDaysChange: PickerOnChangeFn<TDate>;
disabled?: boolean;
focusedDay: TDate | null;
isMonthSwitchingAnimating: boolean;
onFocusedDayChange: (newFocusedDay: TDate) => void;
onMonthSwitchingAnimationEnd: () => void;
readOnly?: boolean;
reduceAnimations: boolean;
slideDirection: SlideDirection;
TransitionProps?: Partial<SlideTransitionProps>;
hasFocus?: boolean;
onFocusedViewChange?: (newHasFocus: boolean) => void;
gridLabelId?: string;
classes?: Partial<DayPickerClasses>;
}
/**
* @ignore - do not document.
*/
export declare function DayPicker<TDate>(inProps: DayPickerProps<TDate>): JSX.Element;