@preamp/datepicker
Version:
VideoAmp's Component library
187 lines • 17.7 kB
JavaScript
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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"}