UNPKG

@preamp/datepicker

Version:

VideoAmp's Component library

187 lines 17.7 kB
var __rest = (this && this.__rest) || function (s, e) { var t = {}; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p]; if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]]; } return t; }; import * as React from 'react'; import cx from 'classnames'; import { format, isBefore } from 'date-fns'; import DayPicker from 'react-day-picker'; import { Button, ButtonTheme } from '@preamp/core'; import { MONTH_YEAR_FORMAT, VADateRangeClassNamesMap } from '../../../constants'; import { CustomDayElement, CustomNavBar } from '../../../custom'; import { isDateFirstDayOfMonth, isDateLastDayOfMonth, isSelectingStartDay } from '../../../utils'; /** * A basic date range picker. */ export class DateRangePicker extends React.PureComponent { constructor() { super(...arguments); this.state = { from: null, to: null, enteredTo: null, resetDateRange: false }; this.returnDateRange = (day, prevFrom, prevTo) => { const isStartDateSet = !!prevFrom; const isNewDateEarlierThanStartDate = isBefore(day, prevFrom); const isDateRangeSet = !!prevFrom && !!prevTo; const dateRangeIsEmpty = !isStartDateSet && !prevTo; if (dateRangeIsEmpty || (isStartDateSet && isNewDateEarlierThanStartDate) || isDateRangeSet) { return { from: day, to: null }; } const isNewDateLaterThanStartDate = isStartDateSet && !isNewDateEarlierThanStartDate; if (isNewDateLaterThanStartDate) { return { from: prevFrom, to: day }; } return { from: prevFrom, to: prevTo }; }; // Events with callbacks this.onHandleDayClick = (day, modifiers, event) => { let dateRange = { from: null, to: null }; if (modifiers['va-datepicker-day--disabled']) { return; } this.setState((prevState) => { const { from: prevFrom, to: prevTo } = prevState; const shouldResetDateRange = isSelectingStartDay(prevFrom, prevTo, day); dateRange = this.returnDateRange(day, prevFrom, prevTo); return Object.assign(Object.assign({}, dateRange), { enteredTo: dateRange.to, resetDateRange: shouldResetDateRange }); }, () => this.props.handleDayClick(dateRange, day, modifiers, event)); }; this.onConfirmDates = () => { const { onConfirmDates } = this.props; const { from, to } = this.state; onConfirmDates({ from, to }); }; this.onClearSelectedDates = () => { this.setState({ from: null, to: null, enteredTo: null }, () => this.props.onClearSelectedDates({ from: null, to: null })); }; // Internal state events this.handleDayMouseEnter = (day) => { const { from, to } = this.state; if (!isSelectingStartDay(from, to, day)) { this.setState({ enteredTo: day }); } else if (!to && day <= from) { this.setState({ enteredTo: null }); } }; this.renderActionsWrapper = () => { const { dataUI } = this.props; const { from, to } = this.state; return (React.createElement(React.Fragment, null, this.props.showActionsBar && (React.createElement("div", { className: VADateRangeClassNamesMap.actionsWrapper }, React.createElement(Button, { dataUI: `${dataUI}_button-confirm`, disabled: !from || !to, onClick: this.onConfirmDates, // disable button if there are not both selected from and to dates theme: ButtonTheme.Primary }, "Confirm Dates"), React.createElement(Button, { dataUI: `${dataUI}_button-cancel`, onClick: this.onClearSelectedDates, theme: ButtonTheme.Secondary }, "Cancel"))))); }; this.returnCustomDay = CustomDayElement(this.props.dataUI); this.returnCustomNavBar = CustomNavBar(this.props.dataUI); } componentDidMount() { const { selectedDates } = this.props; if (selectedDates) { const { enteredTo } = this.state; this.setState({ from: selectedDates.from, to: selectedDates.to, enteredTo: selectedDates.to ? selectedDates.to : enteredTo }); } if (document.querySelectorAll('.va-daterange-month')) { const { dataUI } = this.props; document .querySelectorAll('.va-daterange-month') .forEach((month, index) => month.setAttribute('data-ui', `${dataUI}_month--${index}`)); } } componentDidUpdate(prevProps) { if (prevProps.selectedDates !== this.props.selectedDates) { const { selectedDates } = this.props; const { resetDateRange } = this.state; if (selectedDates) { const toDate = selectedDates.to; const enteredToDate = resetDateRange ? null : toDate; this.setState({ from: selectedDates.from, to: selectedDates.to, enteredTo: enteredToDate }); } this.setState({ resetDateRange: false }); } } render() { const { from, to, enteredTo } = this.state; const _a = this.props, { className, dataUI, id, label, isOptional, firstDayOfWeek, modifiers, style, initialMonth } = _a, rest = __rest(_a, ["className", "dataUI", "id", "label", "isOptional", "firstDayOfWeek", "modifiers", "style", "initialMonth"]); const dateRangeModifiers = Object.assign(Object.assign({}, modifiers), { start: from, end: enteredTo, startWeek: { daysOfWeek: [firstDayOfWeek] }, endWeek: { daysOfWeek: [firstDayOfWeek > 0 ? firstDayOfWeek - 1 : 6] }, firstOfMonth: isDateFirstDayOfMonth, lastOfMonth: isDateLastDayOfMonth }); const isSelectingRange = !!from && !to; const enterToIsLessThanStart = !!from && !enteredTo; return (React.createElement("div", { className: className }, (label || isOptional) && (React.createElement("label", { className: "va-form-label", htmlFor: id }, label, isOptional && (React.createElement("span", { className: "u-label--optional" }, "Optional")))), React.createElement("div", { className: cx({ isSelectingRange: isSelectingRange, enterToIsLessThanStart: enterToIsLessThanStart }, 'va-daterange-picker-container'), id: id, style: style }, React.createElement(DayPicker, Object.assign({ captionElement: ({ date }) => (React.createElement("div", { className: VADateRangeClassNamesMap.caption }, React.createElement("h4", null, format(date, MONTH_YEAR_FORMAT)))), containerProps: { /* eslint-disable @typescript-eslint/ban-ts-ignore */ // @ts-ignore 'data-ui': dataUI }, firstDayOfWeek: firstDayOfWeek, initialMonth: initialMonth, modifiers: dateRangeModifiers, navbarElement: this.returnCustomNavBar, numberOfMonths: 2, onDayClick: this.onHandleDayClick, onDayMouseEnter: this.handleDayMouseEnter, renderDay: this.returnCustomDay, selectedDays: [from, { from, to: enteredTo }] }, rest, { tabIndex: -1 })), this.renderActionsWrapper()))); } } DateRangePicker.defaultProps = { dataUI: 'date-range-picker', showOutsideDays: false, weekdaysShort: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'], classNames: VADateRangeClassNamesMap, className: VADateRangeClassNamesMap.daterangeWrapper, firstDayOfWeek: 0, selectedDates: { from: null, to: null }, showActionsBar: true, onConfirmDates: () => null, onClearSelectedDates: () => null, handleDayClick: () => null }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DateRangePicker.js","sourceRoot":"","sources":["../../../../components/datepickers/DateRangePicker/DateRangePicker.tsx"],"names":[],"mappings":"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"}