Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[POC][pickers] Explore the Base UI Calendar component #16069

Draft
wants to merge 143 commits into
base: master
Choose a base branch
from

Conversation

flaviendelangle
Copy link
Member

@flaviendelangle flaviendelangle commented Jan 3, 2025

Closes #15598
Doc preview

There is a lot of polishing to do before considering any of this to be ready.
This POC is mostly here to test some of the assumption I made in my RFC.

New features compared to MUI

Steps before creating the Base UI X pickers package

  • Decide how to name the package that will validate the license (it can use @mui/x-license temporarily even if we don't want any @mui deps for the launch
  • Decide how to name the Base UI X pickers packages
  • Expose the utilities of Base UI that we need (CompositeList and a lot of things in the utils package)
  • Move the adapters into a standalone package (can't be moved to the Base UI package, otherwise they won't be accessible in the scheduler when we start working on it)
  • Decide how we structure the doc (for shared features between MUI X and Base UI X like the localization or the validation, when do we duplicate? when do we link to the Base UI X doc)
  • Validate how we want to structure MIT / commercial features for the Base UI X offering

Work

Components

Calendar.*

  • Calendar.Root
  • Calendar.SetVisibleMonth
  • Calendar.SetVisibleYear
  • Calendar.DaysGrid
  • Calendar.DaysGridHeader
  • Calendar.DaysGridHeaderCell
  • Calendar.DaysGridBody
  • Calendar.DaysWeekRow
  • Calendar.DaysCell
  • Calendar.MonthsList
  • Calendar.MonthsGrid
  • Calendar.MonthsCell
  • Calendar.YearsList
  • Calendar.YearsGrid
  • Calendar.YearsCell

RangeCalendar.*

  • RangeCalendar.Root
  • RangeCalendar.SetVisibleMonth
  • RangeCalendar.SetVisibleYear
  • RangeCalendar.DaysGrid
  • RangeCalendar.DaysGridHeader
  • RangeCalendar.DaysGridHeaderCell
  • RangeCalendar.DaysGridBody
  • RangeCalendar.DaysWeekRow
  • RangeCalendar.DaysCell
  • RangeCalendar.MonthsList (no range selection for now, only usable for navigation)
  • RangeCalendar.MonthsGrid(no range selection for now, only usable for navigation)
  • RangeCalendar.MonthsCell
  • RangeCalendar.YearsList (no range selection for now, only usable for navigation)
  • RangeCalendar.YearsGrid (no range selection for now, only usable for navigation)
  • RangeCalendar.YearsCell

Keyboard navigation

  • Calendar.DaysGrid
    • Navigation inside a given month
    • Navigation that triggers a change in the visible month
    • Navigation that moves the focus to another visible month (when rendering several at once)
    • Support monthPageSize
    • Only add the default tabbable day (on the reference date or 1st day of the month) when the other rendered month also have no tabbable day
  • Calendar.MonthsList
    • Navigation inside a given year
    • Navigation that triggers a change in the visible year
    • Navigation that moves the focus to another visible month (when rendering several at once)
  • Calendar.MonthsGrid
    • Navigation inside a given year
    • Navigation that triggers a change in the visible year
    • Navigation that moves the focus to another visible month (when rendering several at once)
  • Calendar.YearsList
    • Navigation inside the list
  • Calendar.YearsGrid
    • Navigation inside the grid
  • RangeCalendar.DaysGrid
    • Range expand / collapse using keyboard

Validation

  • Apply the same rules to disable day / month and year buttons as on the MUI version
  • Apply the same rules to disable the navigation button as on the MUI version

Focus

  • Calendar.Root
    • Support focusing tabbable cell on mount
  • Calendar.DaysGrid
    • Add tabIndex={0} on the right cell
    • Get focus on mount when it was inside the previous view
  • Calendar.MonthsGrid / Calendar.MonthsList
    • Add tabIndex={0} on the right cell
    • Scroll to the tabbable cell if needed
    • Get focus on mount when it was inside the previous view
  • Calendar.YearsGrid / Calendar.YearsList
    • Add tabIndex={0} on the right cell
    • Scroll to the tabbable cell if needed
    • Get focus on mount when it was inside the previous view

Other

  • Support value, defaultValue, referenceDate, onValueChange, onError and timezone with the same behavior as on the MUI version (just onChange is renamed onValueChange)
  • Support fixedWeekNumber
  • Support monthPageSize on <Calendar.SetVisibleMonth />
  • Support yearPageSize on <Calendar.SetVisibleYear />
  • Support offset on <Calendar.DaysGrid />
  • Support offset on <Calendar.MonthsGrid /> and <Calendar.MonthsList />
  • Support same value lifecycle when clicking on a day, a month a year as on the MUI version
  • Check that availableRangePositions is always applied
  • Add visibleDate and onVisibleDateChange props

Proposed breaking changes

  • Stop using disable in validation terminology to clearly differentiate the "disabled" and "invalid" state:

    • shouldDisableDate => isDateInvalid
    • shouldDisableMonth => isMonthInvalid
    • shouldDisableYear => isYearInvalid
  • Change the availableRangePosition signature from RangePosition[] to { start?: boolean, end?: boolean } (unsure)

Planned recipes

  • Full replication of our current Date Calendar
  • Horizontal swipe to navigate month
  • Vertical scroll to navigate month

@mui-bot
Copy link

mui-bot commented Jan 3, 2025

@flaviendelangle flaviendelangle self-assigned this Jan 4, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[pickers] New unstyled component: Calendar
2 participants