@activecollab/components
Version:
ActiveCollab Components
282 lines (280 loc) • 14.2 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.DateStepper = void 0;
var _react = _interopRequireWildcard(require("react"));
var _classnames = _interopRequireDefault(require("classnames"));
var _momentTimezone = _interopRequireDefault(require("moment-timezone"));
var _Styles = require("./Styles");
var _DatePicker = require("../../DatePicker/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,
_ref$withDatePicker = _ref.withDatePicker,
withDatePicker = _ref$withDatePicker === void 0 ? true : _ref$withDatePicker,
_ref$defaultMonth = _ref.defaultMonth,
defaultMonth = _ref$defaultMonth === void 0 ? (0, _momentTimezone.default)() : _ref$defaultMonth,
enableYearPicker = _ref.enableYearPicker,
_ref$position = _ref.position,
position = _ref$position === void 0 ? "bottom" : _ref$position,
popperClassName = _ref.popperClassName,
_ref$mode = _ref.mode,
mode = _ref$mode === void 0 ? "outlined" : _ref$mode,
_ref$alwaysShowDate = _ref.alwaysShowDate,
alwaysShowDate = _ref$alwaysShowDate === void 0 ? false : _ref$alwaysShowDate;
var _useState = (0, _react.useState)(_momentTimezone.default.utc(from)),
_useState2 = _slicedToArray(_useState, 2),
fromDate = _useState2[0],
setFromDate = _useState2[1];
var _useState3 = (0, _react.useState)(_momentTimezone.default.utc(to)),
_useState4 = _slicedToArray(_useState3, 2),
toDate = _useState4[0],
setToDate = _useState4[1];
var getDatesByPeriod = (0, _react.useCallback)(function (interval) {
var date = fromDate ? fromDate : (0, _momentTimezone.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);
}
var actualYear = (0, _momentTimezone.default)().year();
var showWeekOrCustomDateFormat = function showWeekOrCustomDateFormat(start, end) {
if (start.year() === actualYear && end.year() === actualYear) {
return start.utc().format("MMM DD") + " - " + end.utc().format("MMM DD");
} else {
return start.utc().format("MMM DD YYYY") + " - " + end.utc().format("MMM DD YYYY");
}
};
if (step === "daily") {
if (fromDate.year() === actualYear) {
return fromDate.utc().format("MMM DD");
}
return fromDate.utc().format("MMM DD YYYY");
} else if (step === "weekly") {
var startDate = fromDate.clone().utc().startOf(period);
var endDate = startDate.clone().utc().endOf(period);
return showWeekOrCustomDateFormat(startDate, endDate);
} else if (step === "monthly") {
return fromDate.utc().format("MMM YYYY");
} else if (step === "quarterly") {
return "Q".concat(fromDate.utc().quarter(), "/").concat(fromDate.utc().format("YYYY"));
} else if (step === "yearly") {
return fromDate.utc().format("YYYY");
} else if (step === "range") {
return showWeekOrCustomDateFormat(fromDate, toDate);
}
return "";
}, [fromDate, toDate, step, formatCallback, period]);
var datePickerMode = (0, _react.useMemo)(function () {
if (step === "range") return "custom";
if (step === "yearly") return "custom";
return step;
}, [step]);
var onDatePickerChange = (0, _react.useCallback)(function (dates) {
var fromDateTemp = _momentTimezone.default.utc(Number(dates === null || dates === void 0 ? void 0 : dates.from) * 1000);
var toDateTemp = _momentTimezone.default.utc(Number(dates === null || dates === void 0 ? void 0 : dates.to) * 1000);
setFromDate(fromDateTemp);
setToDate(toDateTemp);
if (onChange && _momentTimezone.default.isMoment(fromDateTemp) && _momentTimezone.default.isMoment(toDateTemp)) {
onChange(fromDateTemp.toDate(), toDateTemp.toDate());
}
}, [onChange, setFromDate, setToDate]);
var isAfterMaxDate = (0, _react.useMemo)(function () {
return _momentTimezone.default.isMoment(maxValue) && (0, _momentTimezone.default)(_momentTimezone.default.utc(maxValue).format("YYYY-MM-DD")).isSameOrBefore(toDate.utc().format("YYYY-MM-DD"));
}, [maxValue, toDate]);
var isBeforeMinDate = (0, _react.useMemo)(function () {
return _momentTimezone.default.isMoment(minValue) && _momentTimezone.default.utc(_momentTimezone.default.utc(minValue).format("YYYY-MM-DD")).isSameOrAfter(toDate.utc().format("YYYY-MM-DD"));
}, [minValue, toDate]);
(0, _react.useEffect)(function () {
if (isBeforeMinDate) {
if (step === "daily") {
setFromDate(_momentTimezone.default.utc(minValue));
setToDate(_momentTimezone.default.utc(minValue));
}
}
if (isAfterMaxDate) {
if (step === "daily") {
setFromDate(_momentTimezone.default.utc(maxValue));
setToDate(_momentTimezone.default.utc(maxValue));
}
}
}, [step, minValue, maxValue, isBeforeMinDate, isAfterMaxDate]);
var onRightClickHandler = (0, _react.useCallback)(function () {
if (isAfterMaxDate) {
return;
}
var _getDatesByPeriod = getDatesByPeriod(1),
_getDatesByPeriod2 = _slicedToArray(_getDatesByPeriod, 2),
newFrom = _getDatesByPeriod2[0],
newTo = _getDatesByPeriod2[1];
setFromDate(_momentTimezone.default.utc(newFrom));
setToDate(_momentTimezone.default.utc(newTo));
if (onChange) {
onChange(_momentTimezone.default.utc(newFrom), _momentTimezone.default.utc(newTo));
}
if (onForward) {
onForward(_momentTimezone.default.utc(newFrom).toDate(), _momentTimezone.default.utc(newTo).toDate());
}
}, [isAfterMaxDate, getDatesByPeriod, onChange, onForward]);
var onLeftClickHandler = (0, _react.useCallback)(function () {
if (isBeforeMinDate) {
return;
}
var _getDatesByPeriod3 = getDatesByPeriod(-1),
_getDatesByPeriod4 = _slicedToArray(_getDatesByPeriod3, 2),
newFrom = _getDatesByPeriod4[0],
newTo = _getDatesByPeriod4[1];
setFromDate(_momentTimezone.default.utc(newFrom));
setToDate(_momentTimezone.default.utc(newTo));
if (onChange) {
onChange(_momentTimezone.default.utc(newFrom), _momentTimezone.default.utc(newTo));
}
if (onBack) {
onBack(_momentTimezone.default.utc(newFrom).toDate(), _momentTimezone.default.utc(newTo).toDate());
}
}, [isBeforeMinDate, getDatesByPeriod, onChange, onBack]);
var renderLeftRightButtons = (0, _react.useMemo)(function () {
return step !== "range";
}, [step]);
(0, _react.useEffect)(function () {
setFromDate(_momentTimezone.default.utc(from));
setToDate(_momentTimezone.default.utc(to));
}, [from, to]);
var dateStepperWidth = function dateStepperWidth(fromDay, toDay, range) {
if (fromDay.utc().year() !== _momentTimezone.default.utc().year() || toDay.utc().year() !== _momentTimezone.default.utc().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 = _momentTimezone.default.utc(day).format("YYYY-MM-DD");
var isBefore = _momentTimezone.default.isMoment(maxValue) && (0, _momentTimezone.default)(_momentTimezone.default.utc(maxValue).format("YYYY-MM-DD")).isBefore(dayFormat);
var isAfter = _momentTimezone.default.isMoment(minValue) && (0, _momentTimezone.default)(_momentTimezone.default.utc(minValue).format("YYYY-MM-DD")).isAfter(dayFormat);
return isBefore || isAfter;
}, [maxValue, minValue]);
var modifiers = (0, _react.useMemo)(function () {
return {
disabled: function disabled(day) {
return {
matched: isDisabled(day),
title: null
};
},
nonWorkingDay: function nonWorkingDay(day) {
return {
matched: isDisabled(day),
title: null
};
}
};
}, [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: mode === "flat" ? "text gray" : "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 === "range",
$mode: mode,
$alwaysShowDate: alwaysShowDate,
style: dateStepperWidth(fromDate, toDate, step)
}, withDatePicker && step !== "yearly" ? /*#__PURE__*/_react.default.createElement(_DatePicker.DatePicker, {
month: defaultMonth,
target: /*#__PURE__*/_react.default.createElement(_Styles.StyledButton, {
type: "button"
}, getDateFormatted),
mode: datePickerMode,
selected: {
from: _momentTimezone.default.utc(fromDate).unix(),
to: _momentTimezone.default.utc(toDate).unix()
},
onChange: onDatePickerChange,
firstDayOfWeek: period === "week" ? 0 : 1,
modifiers: modifiers,
disabledDaysAfter: maxValue,
disabledDaysBefore: minValue,
disableYearPicker: !enableYearPicker,
popperClassName: popperClassName,
position: position,
key: datePickerMode,
instant: true,
required: true
}) : /*#__PURE__*/_react.default.createElement(_Styles.StyledSpan, null, getDateFormatted)), renderLeftRightButtons ? /*#__PURE__*/_react.default.createElement(_Styles.StyledControl, {
type: "button",
variant: mode === "flat" ? "text gray" : "secondary",
onClick: onRightClickHandler,
disabled: isAfterMaxDate
}, /*#__PURE__*/_react.default.createElement(_Icons.ArrowRightIcon, null)) : null);
};
DateStepper.displayName = "DateStepper";
//# sourceMappingURL=DateStepper.js.map