UNPKG

@activecollab/components

Version:

ActiveCollab Components

282 lines (280 loc) • 13.5 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.DateStepper = void 0; var _react = _interopRequireWildcard(require("react")); var _classnames = _interopRequireDefault(require("classnames")); var _moment = _interopRequireDefault(require("moment")); var _Styles = require("./Styles"); var _DatePicker = require("../../DatePicker"); var _Icons = require("../../Icons"); var _ArrowLeft = _interopRequireDefault(require("../../Icons/collection/ArrowLeft")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); } function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; } function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } } function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } /** * This component allow you to select date range. It accepts two parameters "from" and "to" as valid format * onChange and onBack and onForward it will return "from: Date" and "to: Date" as function arguments */ var DateStepper = exports.DateStepper = function DateStepper(_ref) { var step = _ref.step, formatCallback = _ref.formatCallback, onChange = _ref.onChange, from = _ref.from, to = _ref.to, onBack = _ref.onBack, onForward = _ref.onForward, minValue = _ref.minValue, maxValue = _ref.maxValue, className = _ref.className, _ref$period = _ref.period, period = _ref$period === void 0 ? "week" : _ref$period, datePickerClass = _ref.datePickerClass, _ref$withDatePicker = _ref.withDatePicker, withDatePicker = _ref$withDatePicker === void 0 ? true : _ref$withDatePicker, _ref$defaultMonth = _ref.defaultMonth, defaultMonth = _ref$defaultMonth === void 0 ? new Date() : _ref$defaultMonth, popperClassName = _ref.popperClassName, _ref$position = _ref.position, position = _ref$position === void 0 ? "bottom" : _ref$position; var _useState = (0, _react.useState)((0, _moment.default)(from)), _useState2 = _slicedToArray(_useState, 2), fromDate = _useState2[0], setFromDate = _useState2[1]; var _useState3 = (0, _react.useState)((0, _moment.default)(to)), _useState4 = _slicedToArray(_useState3, 2), toDate = _useState4[0], setToDate = _useState4[1]; var _useState5 = (0, _react.useState)(false), _useState6 = _slicedToArray(_useState5, 2), showDatePicker = _useState6[0], setShowDatePicker = _useState6[1]; var _useState7 = (0, _react.useState)(defaultMonth), _useState8 = _slicedToArray(_useState7, 2), month = _useState8[0], setMonth = _useState8[1]; var getDatesByPeriod = (0, _react.useCallback)(function (interval) { var date = fromDate ? fromDate : (0, _moment.default)(); if (step === "daily") { date.add(interval, "days"); return [date, date.clone()]; } else if (step === "weekly") { date.add(interval, "weeks"); return [date.clone().startOf(period), date.clone().endOf(period)]; } else if (step === "monthly") { date.add(interval, "months"); return [date.clone().startOf("month"), date.clone().endOf("month")]; } else if (step === "quarterly") { date.add(interval, "quarters"); return [date.clone().startOf("quarter"), date.clone().endOf("quarter")]; } else if (step === "yearly") { date.add(interval, "years"); return [date.clone().startOf("year"), date.clone().endOf("year")]; } return [date, date]; }, [fromDate, period, step]); var getDateFormatted = (0, _react.useMemo)(function () { if (formatCallback) { return formatCallback(fromDate.toDate(), toDate.toDate()); } var actualYear = (0, _moment.default)().year(); var showWeekOrCustomDateFormat = function showWeekOrCustomDateFormat(start, end) { if (start.year() === actualYear && end.year() === actualYear) { return start.format("MMM DD") + " - " + end.format("MMM DD"); } else { return start.format("MMM DD YYYY") + " - " + end.format("MMM DD YYYY"); } }; if (step === "daily") { if (fromDate.year() === actualYear) { return fromDate.format("MMM DD"); } return fromDate.format("MMM DD YYYY"); } else if (step === "weekly") { var startDate = fromDate.clone().startOf(period); var endDate = startDate.clone().endOf(period); return showWeekOrCustomDateFormat(startDate, endDate); } else if (step === "monthly") { return fromDate.format("MMM YYYY"); } else if (step === "quarterly") { return "Q".concat(fromDate.quarter(), "/").concat(fromDate.format("YYYY")); } else if (step === "yearly") { return fromDate.format("YYYY"); } else if (step === "custom") { return showWeekOrCustomDateFormat(fromDate, toDate); } return ""; }, [fromDate, step, toDate, formatCallback, period]); var onChangeCallback = (0, _react.useCallback)(function (amount) { var _getDatesByPeriod = getDatesByPeriod(amount), _getDatesByPeriod2 = _slicedToArray(_getDatesByPeriod, 2), newFrom = _getDatesByPeriod2[0], newTo = _getDatesByPeriod2[1]; setFromDate((0, _moment.default)(newFrom)); setToDate((0, _moment.default)(newTo)); if (onChange) { onChange(newFrom.toDate(), newTo.toDate()); } }, [onChange, getDatesByPeriod]); var onDatePickerChange = (0, _react.useCallback)(function (dates) { var fromDateTemp = dates === null || dates === void 0 ? void 0 : dates.from; var toDateTemp = dates === null || dates === void 0 ? void 0 : dates.to; setFromDate((0, _moment.default)(fromDateTemp)); setToDate((0, _moment.default)(toDateTemp)); if (onChange && fromDateTemp instanceof Date && toDateTemp instanceof Date) { onChange(fromDateTemp, toDateTemp); } }, [onChange, setFromDate, setToDate]); var isAfterMaxDate = (0, _react.useMemo)(function () { return maxValue instanceof Date && (0, _moment.default)((0, _moment.default)(maxValue).format("YYYY-MM-DD")).isSameOrBefore(toDate.format("YYYY-MM-DD")); }, [maxValue, toDate]); var isBeforeMinDate = (0, _react.useMemo)(function () { return minValue instanceof Date && (0, _moment.default)((0, _moment.default)(minValue).format("YYYY-MM-DD")).isSameOrAfter(toDate.format("YYYY-MM-DD")); }, [minValue, toDate]); (0, _react.useEffect)(function () { if (isBeforeMinDate) { if (step === "daily") { setFromDate((0, _moment.default)(minValue)); setToDate((0, _moment.default)(minValue)); } } if (isAfterMaxDate) { if (step === "daily") { setFromDate((0, _moment.default)(maxValue)); setToDate((0, _moment.default)(maxValue)); } } }, [step, minValue, maxValue, isBeforeMinDate, isAfterMaxDate]); var onRightClickHandler = (0, _react.useCallback)(function () { if (isAfterMaxDate) { return; } onChangeCallback(1); if (onForward) { onForward(fromDate.toDate(), toDate.toDate()); } }, [isAfterMaxDate, onChangeCallback, onForward, fromDate, toDate]); var onLeftClickHandler = (0, _react.useCallback)(function () { if (isBeforeMinDate) { return; } onChangeCallback(-1); if (onBack) { onBack(fromDate.toDate(), toDate.toDate()); } }, [isBeforeMinDate, onChangeCallback, onBack, fromDate, toDate]); var renderLeftRightButtons = (0, _react.useMemo)(function () { return step !== "custom"; }, [step]); var handleShow = (0, _react.useCallback)(function () { setShowDatePicker(!showDatePicker); if (fromDate) { setMonth(fromDate.toDate()); } }, [setShowDatePicker, showDatePicker, fromDate]); var closeMenu = (0, _react.useCallback)(function () { setShowDatePicker(false); }, []); var onMonthChange = (0, _react.useCallback)(function (m) { setMonth(m); }, [setMonth]); (0, _react.useEffect)(function () { setFromDate((0, _moment.default)(from)); setToDate((0, _moment.default)(to)); }, [from, to]); var dateStepperWidth = function dateStepperWidth(fromDay, toDay, range) { if (fromDay.year() !== (0, _moment.default)().year() || toDay.year() !== (0, _moment.default)().year()) { switch (range) { case "daily": case "monthly": return { minWidth: "122px" }; case "weekly": case "custom": return { minWidth: "232px" }; } } switch (range) { case "monthly": return { minWidth: "122px" }; case "weekly": case "custom": return { minWidth: "182px" }; } return { minWidth: "102px" }; }; var isDisabled = (0, _react.useCallback)(function (day) { var dayFormat = (0, _moment.default)(day).format("YYYY-MM-DD"); var isBefore = maxValue instanceof Date && (0, _moment.default)((0, _moment.default)(maxValue).format("YYYY-MM-DD")).isBefore(dayFormat); var isAfter = minValue instanceof Date && (0, _moment.default)((0, _moment.default)(minValue).format("YYYY-MM-DD")).isAfter(dayFormat); return isBefore || isAfter; }, [maxValue, minValue]); var modifiers = (0, _react.useMemo)(function () { return { day_disabled: function day_disabled(day) { return isDisabled(day); }, nonWorkingDay: function nonWorkingDay(day) { return isDisabled(day); } }; }, [isDisabled]); return /*#__PURE__*/_react.default.createElement(_Styles.StyledButtonGroup, { className: (0, _classnames.default)("c-date-stepper", className) }, renderLeftRightButtons ? /*#__PURE__*/_react.default.createElement(_Styles.StyledControl, { type: "button", variant: "secondary", onClick: onLeftClickHandler, disabled: isBeforeMinDate }, /*#__PURE__*/_react.default.createElement(_ArrowLeft.default, null)) : null, /*#__PURE__*/_react.default.createElement(_Styles.StyledDiv, { $isTargetable: step === "yearly" || !withDatePicker, $isRounded: step === "custom", style: dateStepperWidth(fromDate, toDate, step) }, withDatePicker ? /*#__PURE__*/_react.default.createElement(_Styles.StyledMenu, { target: /*#__PURE__*/_react.default.createElement(_Styles.StyledButton, { type: "button" }, /*#__PURE__*/_react.default.createElement("span", null, getDateFormatted)), open: showDatePicker, onOpen: handleShow, onClose: closeMenu, popperClassName: popperClassName, position: position }, /*#__PURE__*/_react.default.createElement(_DatePicker.DatePicker, { month: month, selectionMode: step, className: datePickerClass, selectedDays: { from: fromDate.toDate(), to: toDate.toDate() }, onChange: onDatePickerChange, onMonthChange: onMonthChange, firstDayOfWeek: period === "week" ? 0 : 1, modifiers: modifiers, dateRequired: true, fixedWeeks: true })) : /*#__PURE__*/_react.default.createElement(_Styles.StyledSpan, null, getDateFormatted)), renderLeftRightButtons ? /*#__PURE__*/_react.default.createElement(_Styles.StyledControl, { type: "button", variant: "secondary", onClick: onRightClickHandler, disabled: isAfterMaxDate }, /*#__PURE__*/_react.default.createElement(_Icons.ArrowRightIcon, null)) : null); }; DateStepper.displayName = "DateStepper"; //# sourceMappingURL=DateStepper.js.map