From 1306eb20cbdbb7cdea14e280d7a5939a0200ca73 Mon Sep 17 00:00:00 2001 From: Jmenache Date: Mon, 18 Dec 2017 15:41:06 +0100 Subject: [PATCH] Added preventOpenOnFocus prop (#1181) * Added preventOpenOnFocus prop * Added tests for preventOpenOnFocus prop --- src/index.jsx | 8 ++++++-- test/datepicker_test.js | 16 ++++++++++++++++ 2 files changed, 22 insertions(+), 2 deletions(-) diff --git a/src/index.jsx b/src/index.jsx index d845b01a3..d66757e70 100644 --- a/src/index.jsx +++ b/src/index.jsx @@ -94,6 +94,7 @@ export default class DatePicker extends React.Component { popperClassName: PropTypes.string, // props popperModifiers: PropTypes.object, // props popperPlacement: PropTypes.oneOf(popperPlacementPositions), // props + preventOpenOnFocus: PropTypes.bool, readOnly: PropTypes.bool, required: PropTypes.bool, scrollableYearDropdown: PropTypes.bool, @@ -139,6 +140,7 @@ export default class DatePicker extends React.Component { onSelect () {}, onClickOutside () {}, onMonthChange () {}, + preventOpenOnFocus: false, onYearChange () {}, monthsShown: 1, withPortal: false, @@ -215,7 +217,9 @@ export default class DatePicker extends React.Component { handleFocus = (event) => { if (!this.state.preventFocus) { this.props.onFocus(event) - this.setOpen(true) + if (!this.props.preventOpenOnFocus) { + this.setOpen(true) + } } } @@ -344,7 +348,7 @@ export default class DatePicker extends React.Component { onInputKeyDown = (event) => { this.props.onKeyDown(event) const eventKey = event.key - if (!this.state.open && !this.props.inline) { + if (!this.state.open && !this.props.inline && !this.props.preventOpenOnFocus) { if (eventKey !== 'Enter' && eventKey !== 'Escape' && eventKey !== 'Tab') { this.onInputClick() } diff --git a/test/datepicker_test.js b/test/datepicker_test.js index c0c96ad40..001a18f99 100644 --- a/test/datepicker_test.js +++ b/test/datepicker_test.js @@ -784,4 +784,20 @@ describe('DatePicker', () => { datePicker.setProps({ selected: future }) expect(utils.formatDate(datePicker.state('preSelection'), 'YYYY-MM-DD')).to.equal(utils.formatDate(future, 'YYYY-MM-DD')) }) + it('should not set open state when focusing on the date input and the preventOpenOnFocus prop is set', () => { + const datePicker = TestUtils.renderIntoDocument( + + ) + const dateInput = datePicker.input + TestUtils.Simulate.focus(ReactDOM.findDOMNode(dateInput)) + expect(datePicker.state.open).to.be.false + }) + it('should not set open state onInputKeyDown when preventOpenOnFocus prop is set', () => { + const datePicker = TestUtils.renderIntoDocument( + + ) + const dateInput = datePicker.input + TestUtils.Simulate.keyDown(ReactDOM.findDOMNode(dateInput), getKey('ArrowLeft')) + expect(datePicker.state.open).to.be.false + }) })