UNPKG

@mui/x-date-pickers

Version:

The community edition of the Date and Time Picker components (MUI X).

90 lines (89 loc) 2.99 kB
import * as React from 'react'; import { SxProps } from '@mui/system'; import { Theme } from '@mui/material/styles'; import { YearCalendarClasses } from './yearCalendarClasses'; import { BaseDateValidationProps, YearValidationProps } from '../internals/models/validation'; import { PickerValidDate, TimezoneProps } from '../models'; import type { PickersYearProps } from './PickersYear'; import { SlotComponentPropsFromProps } from '../internals/models/helpers'; export interface YearCalendarSlots { /** * Button displayed to render a single year in the `year` view. * @default YearCalendarButton */ yearButton?: React.ElementType; } export interface YearCalendarSlotProps { yearButton?: SlotComponentPropsFromProps<React.HTMLAttributes<HTMLButtonElement> & { sx: SxProps; }, {}, PickersYearProps>; } export interface ExportedYearCalendarProps { /** * Years are displayed in ascending (chronological) order by default. * If `desc`, years are displayed in descending order. * @default 'asc' */ yearsOrder?: 'asc' | 'desc'; /** * Years rendered per row. * @default 3 */ yearsPerRow?: 3 | 4; } export interface YearCalendarProps<TDate extends PickerValidDate> extends ExportedYearCalendarProps, YearValidationProps<TDate>, BaseDateValidationProps<TDate>, TimezoneProps { autoFocus?: boolean; className?: string; /** * Override or extend the styles applied to the component. */ classes?: Partial<YearCalendarClasses>; /** * Overridable component slots. * @default {} */ slots?: YearCalendarSlots; /** * The props used for each component slot. * @default {} */ slotProps?: YearCalendarSlotProps; /** * The system prop that allows defining system overrides as well as additional CSS styles. */ sx?: SxProps<Theme>; /** If `true` picker is disabled */ disabled?: boolean; /** * The selected value. * Used when the component is controlled. */ value?: TDate | null; /** * The default selected value. * Used when the component is not controlled. */ defaultValue?: TDate | null; /** * The date used to generate the new value when both `value` and `defaultValue` are empty. * @default The closest valid year using the validation props, except callbacks such as `shouldDisableYear`. */ referenceDate?: TDate; /** * Callback fired when the value changes. * @template TDate * @param {TDate} value The new value. */ onChange?: (value: TDate) => void; /** If `true` picker is readonly */ readOnly?: boolean; /** * If `true`, today's date is rendering without highlighting with circle. * @default false */ disableHighlightToday?: boolean; onYearFocus?: (year: number) => void; hasFocus?: boolean; onFocusedViewChange?: (hasFocus: boolean) => void; gridLabelId?: string; }