From 3a967b1cc33c723322ad4d4ef04163acfdd7277f Mon Sep 17 00:00:00 2001 From: Unknown Date: Thu, 25 Oct 2018 20:19:22 +0300 Subject: [PATCH] Allow passing popperProps. Fixes #1525 --- src/index.jsx | 101 ++++++++++++++++++++------------------- src/popper_component.jsx | 29 ++++++----- 2 files changed, 70 insertions(+), 60 deletions(-) diff --git a/src/index.jsx b/src/index.jsx index a7f1384a8..c45c687e4 100644 --- a/src/index.jsx +++ b/src/index.jsx @@ -1,8 +1,8 @@ -import Calendar from './calendar'; -import React from 'react'; -import PropTypes from 'prop-types'; -import PopperComponent, { popperPlacementPositions } from './popper_component'; -import classnames from 'classnames'; +import Calendar from "./calendar"; +import React from "react"; +import PropTypes from "prop-types"; +import PopperComponent, { popperPlacementPositions } from "./popper_component"; +import classnames from "classnames"; import { newDate, now, @@ -34,13 +34,13 @@ import { safeDateFormat, getHightLightDaysMap, getYear, - getMonth, -} from './date_utils'; -import onClickOutside from 'react-onclickoutside'; + getMonth +} from "./date_utils"; +import onClickOutside from "react-onclickoutside"; -export { default as CalendarContainer } from './calendar_container'; +export { default as CalendarContainer } from "./calendar_container"; -const outsideClickIgnoreClass = 'react-datepicker-ignore-onclickoutside'; +const outsideClickIgnoreClass = "react-datepicker-ignore-onclickoutside"; const WrappedCalendar = onClickOutside(Calendar); // Compares dates year+month combinations @@ -65,7 +65,7 @@ function hasSelectionChanged(date1, date2) { /** * General datepicker component. */ -const INPUT_ERR_1 = 'Date input not valid.'; +const INPUT_ERR_1 = "Date input not valid."; export default class DatePicker extends React.Component { static propTypes = { @@ -85,7 +85,7 @@ export default class DatePicker extends React.Component { dayClassName: PropTypes.func, disabled: PropTypes.bool, disabledKeyboardNavigation: PropTypes.bool, - dropdownMode: PropTypes.oneOf(['scroll', 'select']).isRequired, + dropdownMode: PropTypes.oneOf(["scroll", "select"]).isRequired, endDate: PropTypes.object, excludeDates: PropTypes.array, filterDate: PropTypes.func, @@ -123,6 +123,7 @@ export default class DatePicker extends React.Component { popperClassName: PropTypes.string, // props popperModifiers: PropTypes.object, // props popperPlacement: PropTypes.oneOf(popperPlacementPositions), // props + popperProps: PropTypes.object, preventOpenOnFocus: PropTypes.bool, readOnly: PropTypes.bool, required: PropTypes.bool, @@ -168,12 +169,12 @@ export default class DatePicker extends React.Component { static get defaultProps() { return { allowSameDay: false, - dateFormat: 'L', - dateFormatCalendar: 'MMMM YYYY', + dateFormat: "L", + dateFormatCalendar: "MMMM YYYY", onChange() {}, disabled: false, disabledKeyboardNavigation: false, - dropdownMode: 'scroll', + dropdownMode: "scroll", onFocus() {}, onBlur() {}, onKeyDown() {}, @@ -190,9 +191,9 @@ export default class DatePicker extends React.Component { shouldCloseOnSelect: true, showTimeSelect: false, timeIntervals: 30, - timeCaption: 'Time', - previousMonthButtonLabel: 'Previous Month', - nextMonthButtonLabel: 'Next month', + timeCaption: "Time", + previousMonthButtonLabel: "Previous Month", + nextMonthButtonLabel: "Next month" }; } @@ -210,7 +211,7 @@ export default class DatePicker extends React.Component { } if (prevProps.highlightDates !== this.props.highlightDates) { this.setState({ - highlightDates: getHightLightDaysMap(this.props.highlightDates), + highlightDates: getHightLightDaysMap(this.props.highlightDates) }); } if ( @@ -253,7 +254,7 @@ export default class DatePicker extends React.Component { // transforming highlighted days (perhaps nested array) // to flat Map for faster access in day.jsx highlightDates: getHightLightDaysMap(this.props.highlightDates), - focused: false, + focused: false }; }; @@ -276,7 +277,7 @@ export default class DatePicker extends React.Component { open && this.state.open ? this.state.preSelection : this.calcInitialState().preSelection, - lastPreSelectChange: PRESELECT_CHANGE_VIA_NAVIGATE, + lastPreSelectChange: PRESELECT_CHANGE_VIA_NAVIGATE }); }; inputOk = () => @@ -335,7 +336,7 @@ export default class DatePicker extends React.Component { if (this.props.onChangeRaw) { this.props.onChangeRaw.apply(this, allArgs); if ( - typeof event.isDefaultPrevented !== 'function' || + typeof event.isDefaultPrevented !== "function" || event.isDefaultPrevented() ) { return; @@ -343,7 +344,7 @@ export default class DatePicker extends React.Component { } this.setState({ inputValue: event.target.value, - lastPreSelectChange: PRESELECT_CHANGE_VIA_INPUT, + lastPreSelectChange: PRESELECT_CHANGE_VIA_INPUT }); const date = parseDate(event.target.value, this.props); if (date || !event.target.value) { @@ -357,7 +358,7 @@ export default class DatePicker extends React.Component { this.setState({ preventFocus: true }, () => { this.preventFocusTimeout = setTimeout( () => this.setState({ preventFocus: false }), - 50, + 50 ); return this.preventFocusTimeout; }); @@ -396,12 +397,12 @@ export default class DatePicker extends React.Component { changedDate = setTime(newDate(changedDate), { hour: getHour(selected), minute: getMinute(selected), - second: getSecond(selected), + second: getSecond(selected) }); } if (!this.props.inline) { this.setState({ - preSelection: changedDate, + preSelection: changedDate }); } } @@ -417,15 +418,15 @@ export default class DatePicker extends React.Component { setPreSelection = date => { const isDateRangePresent = - typeof this.props.minDate !== 'undefined' && - typeof this.props.maxDate !== 'undefined'; + typeof this.props.minDate !== "undefined" && + typeof this.props.maxDate !== "undefined"; const isValidDateSelection = isDateRangePresent && date ? isDayInRange(date, this.props.minDate, this.props.maxDate) : true; if (isValidDateSelection) { this.setState({ - preSelection: date, + preSelection: date }); } }; @@ -436,11 +437,11 @@ export default class DatePicker extends React.Component { : this.getPreSelection(); let changedDate = setTime(cloneDate(selected), { hour: getHour(time), - minute: getMinute(time), + minute: getMinute(time) }); this.setState({ - preSelection: changedDate, + preSelection: changedDate }); this.props.onChange(changedDate); @@ -464,13 +465,13 @@ export default class DatePicker extends React.Component { !this.props.inline && !this.props.preventOpenOnFocus ) { - if (eventKey === 'ArrowDown' || eventKey === 'ArrowUp') { + if (eventKey === "ArrowDown" || eventKey === "ArrowUp") { this.onInputClick(); } return; } const copy = newDate(this.state.preSelection); - if (eventKey === 'Enter') { + if (eventKey === "Enter") { event.preventDefault(); if ( this.inputOk() && @@ -485,7 +486,7 @@ export default class DatePicker extends React.Component { this.setOpen(false); } - } else if (eventKey === 'Escape') { + } else if (eventKey === "Escape") { event.preventDefault(); this.input.blur(); @@ -496,33 +497,33 @@ export default class DatePicker extends React.Component { if (!this.inputOk()) { this.props.onInputError({ code: 1, msg: INPUT_ERR_1 }); } - } else if (eventKey === 'Tab') { + } else if (eventKey === "Tab") { this.setOpen(false); } else if (!this.props.disabledKeyboardNavigation) { let newSelection; switch (eventKey) { - case 'ArrowLeft': + case "ArrowLeft": newSelection = subtractDays(copy, 1); break; - case 'ArrowRight': + case "ArrowRight": newSelection = addDays(copy, 1); break; - case 'ArrowUp': + case "ArrowUp": newSelection = subtractWeeks(copy, 1); break; - case 'ArrowDown': + case "ArrowDown": newSelection = addWeeks(copy, 1); break; - case 'PageUp': + case "PageUp": newSelection = subtractMonths(copy, 1); break; - case 'PageDown': + case "PageDown": newSelection = addMonths(copy, 1); break; - case 'Home': + case "Home": newSelection = subtractYears(copy, 1); break; - case 'End': + case "End": newSelection = addYears(copy, 1); break; } @@ -628,6 +629,7 @@ export default class DatePicker extends React.Component { nextMonthButtonLabel={this.props.nextMonthButtonLabel} disabledKeyboardNavigation={this.props.disabledKeyboardNavigation} renderCustomHeader={this.props.renderCustomHeader} + popperProps={this.props.popperProps} > {this.props.children} @@ -640,11 +642,11 @@ export default class DatePicker extends React.Component { }); const customInput = this.props.customInput || ; - const customInputRef = this.props.customInputRef || 'ref'; + const customInputRef = this.props.customInputRef || "ref"; const inputValue = - typeof this.props.value === 'string' + typeof this.props.value === "string" ? this.props.value - : typeof this.state.inputValue === 'string' + : typeof this.state.inputValue === "string" ? this.state.inputValue : safeDateFormat(this.props.selected, this.props); @@ -668,7 +670,7 @@ export default class DatePicker extends React.Component { title: this.props.title, readOnly: this.props.readOnly, required: this.props.required, - tabIndex: this.props.tabIndex, + tabIndex: this.props.tabIndex }); }; @@ -725,10 +727,11 @@ export default class DatePicker extends React.Component { popperContainer={this.props.popperContainer} popperComponent={calendar} popperPlacement={this.props.popperPlacement} + popperProps={this.props.popperProps} /> ); } } -const PRESELECT_CHANGE_VIA_INPUT = 'input'; -const PRESELECT_CHANGE_VIA_NAVIGATE = 'navigate'; +const PRESELECT_CHANGE_VIA_INPUT = "input"; +const PRESELECT_CHANGE_VIA_NAVIGATE = "navigate"; diff --git a/src/popper_component.jsx b/src/popper_component.jsx index 19e8ac267..7f33791de 100644 --- a/src/popper_component.jsx +++ b/src/popper_component.jsx @@ -26,6 +26,7 @@ export default class PopperComponent extends React.Component { popperModifiers: PropTypes.object, // props popperPlacement: PropTypes.oneOf(popperPlacementPositions), // props popperContainer: PropTypes.func, + popperProps: PropTypes.object, targetComponent: PropTypes.element }; @@ -39,6 +40,7 @@ export default class PopperComponent extends React.Component { boundariesElement: "viewport" } }, + popperProps: {}, popperPlacement: "bottom-start" }; } @@ -50,6 +52,7 @@ export default class PopperComponent extends React.Component { popperComponent, popperModifiers, popperPlacement, + popperProps, targetComponent } = this.props; @@ -58,7 +61,11 @@ export default class PopperComponent extends React.Component { if (!hidePopper) { const classes = classnames("react-datepicker-popper", className); popper = ( - + {({ ref, style, placement, arrowProps }) => (
- - {({ ref }) => ( -
- {targetComponent} -
- )} -
- {popper} - + + + {({ ref }) => ( +
+ {targetComponent} +
+ )} +
+ {popper} +
); } }