From 64467ee4500506653ae575b5ff0fa4bf4c0eb2b7 Mon Sep 17 00:00:00 2001 From: Tim Finucane Date: Tue, 23 May 2023 16:06:02 +1000 Subject: [PATCH] Fix and test turning goToRangeStartOnSelect off --- src/Calendar.spec.tsx | 79 +++++++++++++++++++++++++++++++++++++++++++ src/Calendar.tsx | 2 +- 2 files changed, 80 insertions(+), 1 deletion(-) diff --git a/src/Calendar.spec.tsx b/src/Calendar.spec.tsx index 905e8d09..046ef755 100644 --- a/src/Calendar.spec.tsx +++ b/src/Calendar.spec.tsx @@ -707,6 +707,85 @@ describe('Calendar', () => { expect(onActiveStartDateChange).not.toHaveBeenCalled(); }); + + it('returns to start of range when range is completed', () => { + const onActiveStartDateChange = vi.fn(); + + const initialRange = new Date(2017, 0, 10); + + const { container } = render( + , + ); + + const nextMonthButton = container.querySelector( + 'button.react-calendar__navigation__next-button', + ) as HTMLButtonElement; + + act(() => { + nextMonthButton.click(); + }); + // Disregard the call on the above button click + onActiveStartDateChange.mockClear(); + + // First day not in the previous month + const firstDayTile = container.querySelector( + '.react-calendar__tile:not([react-calendar__month-view__days__day--weekend])', + ) as HTMLButtonElement; + + act(() => { + firstDayTile.click(); + }); + + expect(onActiveStartDateChange).toHaveBeenCalledWith( + expect.objectContaining({ + action: 'onChange', + activeStartDate: new Date(2017, 0, 1), + view: 'month', + }), + ); + }); + + it('does not change activeStartDate on range completion when goToRangeStartOnSelect is set to false', () => { + const onActiveStartDateChange = vi.fn(); + + const initialRange = new Date(2017, 0, 10); + + const { container } = render( + , + ); + + const nextMonthButton = container.querySelector( + 'button.react-calendar__navigation__next-button', + ) as HTMLButtonElement; + + act(() => { + nextMonthButton.click(); + }); + // Disregard the call on the above button click + onActiveStartDateChange.mockClear(); + + // First day not in the previous month + const firstDayTile = container.querySelector( + '.react-calendar__tile:not([react-calendar__month-view__days__day--weekend])', + ) as HTMLButtonElement; + + act(() => { + firstDayTile.click(); + }); + + expect(onActiveStartDateChange).not.toHaveBeenCalled(); + }); }); describe('handles view change properly', () => { diff --git a/src/Calendar.tsx b/src/Calendar.tsx index c7c5c435..3bdf0a5f 100644 --- a/src/Calendar.tsx +++ b/src/Calendar.tsx @@ -691,7 +691,7 @@ export default class Calendar extends Component { ...(this.props as CalendarPropsWithDefaults), value: nextValue, }) - : null; + : this.activeStartDate; event.persist();