diff --git a/packages/x-date-pickers/src/DigitalClock/DigitalClock.tsx b/packages/x-date-pickers/src/DigitalClock/DigitalClock.tsx index 2c8d50a137a28..f3774080061e4 100644 --- a/packages/x-date-pickers/src/DigitalClock/DigitalClock.tsx +++ b/packages/x-date-pickers/src/DigitalClock/DigitalClock.tsx @@ -274,13 +274,14 @@ export const DigitalClock = React.forwardRef(function DigitalClock { + const result: TDate[] = []; const startOfDay = utils.startOfDay(valueOrReferenceDate); - return [ - startOfDay, - ...Array.from({ length: Math.ceil((24 * 60) / timeStep) - 1 }, (_, index) => - utils.addMinutes(startOfDay, timeStep * (index + 1)), - ), - ]; + let nextTimeStepOption = startOfDay; + while (utils.isSameDay(valueOrReferenceDate, nextTimeStepOption)) { + result.push(nextTimeStepOption); + nextTimeStepOption = utils.addMinutes(nextTimeStepOption, timeStep); + } + return result; }, [valueOrReferenceDate, timeStep, utils]); return ( @@ -301,9 +302,10 @@ export const DigitalClock = React.forwardRef(function DigitalClock !readOnly && handleItemSelect(option)} selected={isSelected} disabled={disabled || isTimeDisabled(option)} @@ -314,7 +316,7 @@ export const DigitalClock = React.forwardRef(function DigitalClock - {utils.format(option, ampm ? 'fullTime12h' : 'fullTime24h')} + {formattedValue} ); })} diff --git a/packages/x-date-pickers/src/DigitalClock/tests/timezone.DigitalClock.test.tsx b/packages/x-date-pickers/src/DigitalClock/tests/timezone.DigitalClock.test.tsx index 50d692bfe6792..65649144b3968 100644 --- a/packages/x-date-pickers/src/DigitalClock/tests/timezone.DigitalClock.test.tsx +++ b/packages/x-date-pickers/src/DigitalClock/tests/timezone.DigitalClock.test.tsx @@ -38,6 +38,74 @@ describe(' - Timezone', () => { expect(actualDate).toEqualDateTime(expectedDate); }); + it('should render correct time options when fall back DST occurs', () => { + render( + , + ); + const oneAM = adapter.setMinutes( + adapter.setHours(adapter.dateWithTimezone(undefined, 'default'), 1), + 0, + ); + const elevenPM = adapter.setMinutes( + adapter.setHours(adapter.dateWithTimezone(undefined, 'default'), 23), + 0, + ); + expect( + screen.getAllByText( + adapter.format( + oneAM, + adapter.is12HourCycleInCurrentLocale() ? 'fullTime12h' : 'fullTime24h', + ), + ), + ).to.have.length(adapter.lib === 'dayjs' ? 1 : 2); + expect( + screen.getAllByText( + adapter.format( + elevenPM, + adapter.is12HourCycleInCurrentLocale() ? 'fullTime12h' : 'fullTime24h', + ), + ), + ).to.have.length(1); + }); + + it('should contain time options until the end of day when spring forward DST occurs', () => { + render( + , + ); + const startOfDay = adapter.setMinutes( + adapter.setHours(adapter.dateWithTimezone(undefined, 'default'), 0), + 0, + ); + const eleven30PM = adapter.setMinutes( + adapter.setHours(adapter.dateWithTimezone(undefined, 'default'), 23), + 30, + ); + expect( + screen.getAllByText( + adapter.format( + startOfDay, + adapter.is12HourCycleInCurrentLocale() ? 'fullTime12h' : 'fullTime24h', + ), + ), + ).to.have.length(1); + expect( + screen.getAllByText( + adapter.format( + eleven30PM, + adapter.is12HourCycleInCurrentLocale() ? 'fullTime12h' : 'fullTime24h', + ), + ), + ).to.have.length(1); + }); + TIMEZONE_TO_TEST.forEach((timezone) => { describe(`Timezone: ${timezone}`, () => { it('should use timezone prop for onChange when no value is provided', () => {