Skip to content

Commit

Permalink
Fix next and nex2 buttons disabled if maxDate was set to the 1st mill…
Browse files Browse the repository at this point in the history
…isecond of nextActiveStartDate or nextActiveStartDate2 respectively

Closes #485
  • Loading branch information
wojtekmaj committed Aug 26, 2021
1 parent 5b360c5 commit e046024
Show file tree
Hide file tree
Showing 2 changed files with 38 additions and 2 deletions.
4 changes: 2 additions & 2 deletions src/Calendar/Navigation.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -71,12 +71,12 @@ export default function Navigation({
return minDate && minDate >= previousActiveEndDate;
})();

const nextButtonDisabled = maxDate && maxDate <= nextActiveStartDate;
const nextButtonDisabled = maxDate && maxDate < nextActiveStartDate;

const next2ButtonDisabled = (
shouldShowPrevNext2Buttons
&& maxDate
&& maxDate <= nextActiveStartDate2
&& maxDate < nextActiveStartDate2
);

function onClickPrevious() {
Expand Down
36 changes: 36 additions & 0 deletions src/Calendar/Navigation.spec.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -445,6 +445,42 @@ describe('Navigation', () => {
expect(next2.prop('disabled')).toBeTruthy();
});

it('does not disallow navigating to next month when maxDate is set to first day of the next month', () => {
const component = shallow(
<Navigation
{...defaultProps}
maxDate={new Date(2017, 1, 1)}
view="month"
/>,
);

const arrows = component.find('button.react-calendar__navigation__arrow');

const next = arrows.at(2);
const next2 = arrows.at(3);

expect(next.prop('disabled')).toBeFalsy();
expect(next2.prop('disabled')).toBeTruthy();
});

it('does not disallow navigating to next year when maxDate is set to first day of the next year', () => {
const component = shallow(
<Navigation
{...defaultProps}
maxDate={new Date(2018, 0, 1)}
view="month"
/>,
);

const arrows = component.find('button.react-calendar__navigation__arrow');

const next = arrows.at(2);
const next2 = arrows.at(3);

expect(next.prop('disabled')).toBeFalsy();
expect(next2.prop('disabled')).toBeFalsy();
});

it('disallows navigating after dynamically set maxDate', () => {
const component = shallow(
<Navigation
Expand Down

0 comments on commit e046024

Please # to comment.