-
-
Notifications
You must be signed in to change notification settings - Fork 1.4k
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
flaviendelangle
wants to merge
150
commits into
mui:master
Choose a base branch
from
flaviendelangle:base-ui-calendar
base: master
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Conversation
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Deploy preview: https://deploy-preview-16069--material-ui-x.netlify.app/ Updated pages: |
This pull request has conflicts, please resolve those before we can evaluate the pull request. |
github-actions
bot
added
the
PR: out-of-date
The pull request has merge conflicts and can't be merged
label
Jan 20, 2025
github-actions
bot
removed
the
PR: out-of-date
The pull request has merge conflicts and can't be merged
label
Jan 23, 2025
github-actions
bot
added
the
PR: out-of-date
The pull request has merge conflicts and can't be merged
label
Jan 27, 2025
This pull request has conflicts, please resolve those before we can evaluate the pull request. |
github-actions
bot
added
PR: out-of-date
The pull request has merge conflicts and can't be merged
and removed
PR: out-of-date
The pull request has merge conflicts and can't be merged
labels
Jan 27, 2025
This pull request has conflicts, please resolve those before we can evaluate the pull request. |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
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
@mui/x-license
temporarily even if we don't want any@mui
deps for the launchCompositeList
and a lot of things in theutils
package)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
monthPageSize
Calendar.MonthsList
Calendar.MonthsGrid
Calendar.YearsList
Calendar.YearsGrid
RangeCalendar.DaysGrid
Validation
Focus
Calendar.Root
Calendar.DaysGrid
tabIndex={0}
on the right cellCalendar.MonthsGrid
/Calendar.MonthsList
tabIndex={0}
on the right cellCalendar.YearsGrid
/Calendar.YearsList
tabIndex={0}
on the right cellOther
value
,defaultValue
,referenceDate
,onValueChange
,onError
andtimezone
with the same behavior as on the MUI version (justonChange
is renamedonValueChange
)fixedWeekNumber
monthPageSize
on<Calendar.SetVisibleMonth />
yearPageSize
on<Calendar.SetVisibleYear />
offset
on<Calendar.DaysGrid />
offset
on<Calendar.MonthsGrid />
and<Calendar.MonthsList />
availableRangePositions
is always appliedvisibleDate
andonVisibleDateChange
propsProposed 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 fromRangePosition[]
to{ start?: boolean, end?: boolean }
(unsure)Planned recipes