react-js-cron-mantine
Version:
Fork of [react-js-cron](https://github.com/xrutayisire/react-js-cron), made to work with [mantine](https://mantine.dev)
401 lines (345 loc) • 19.1 kB
JavaScript
"use strict";
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = Cron;
var _react = _interopRequireWildcard(require("react"));
var _Period = _interopRequireDefault(require("./fields/Period"));
var _MonthDays = _interopRequireDefault(require("./fields/MonthDays"));
var _Months = _interopRequireDefault(require("./fields/Months"));
var _Hours = _interopRequireDefault(require("./fields/Hours"));
var _Minutes = _interopRequireDefault(require("./fields/Minutes"));
var _WeekDays = _interopRequireDefault(require("./fields/WeekDays"));
var _utils = require("./utils");
var _locale = require("./locale");
var _converter = require("./converter");
var _core = require("@mantine/core");
var _dayjs = _interopRequireDefault(require("dayjs"));
var _relativeTime = _interopRequireDefault(require("dayjs/plugin/relativeTime"));
var _timezone = _interopRequireDefault(require("dayjs/plugin/timezone"));
var _utc = _interopRequireDefault(require("dayjs/plugin/utc"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
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(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
function Cron(props) {
var _props$timezone_value = props.timezone_value,
timezone_value = _props$timezone_value === void 0 ? 'UTC' : _props$timezone_value,
_props$clearButton = props.clearButton,
clearButton = _props$clearButton === void 0 ? true : _props$clearButton,
_props$convertToTimez = props.convertToTimezone,
convertToTimezone = _props$convertToTimez === void 0 ? false : _props$convertToTimez,
_props$clearButtonAct = props.clearButtonAction,
clearButtonAction = _props$clearButtonAct === void 0 ? 'fill-with-every' : _props$clearButtonAct,
_props$locale = props.locale,
locale = _props$locale === void 0 ? _locale.DEFAULT_LOCALE_EN : _props$locale,
_props$value = props.value,
value = _props$value === void 0 ? '' : _props$value,
setValue = props.setValue,
setValueObj = props.setValueObj,
_props$displayError = props.displayError,
displayError = _props$displayError === void 0 ? true : _props$displayError,
onError = props.onError,
className = props.className,
_props$defaultPeriod = props.defaultPeriod,
defaultPeriod = _props$defaultPeriod === void 0 ? 'day' : _props$defaultPeriod,
_props$allowEmpty = props.allowEmpty,
allowEmpty = _props$allowEmpty === void 0 ? 'for-default-value' : _props$allowEmpty,
_props$humanizeLabels = props.humanizeLabels,
humanizeLabels = _props$humanizeLabels === void 0 ? true : _props$humanizeLabels,
_props$humanizeValue = props.humanizeValue,
humanizeValue = _props$humanizeValue === void 0 ? false : _props$humanizeValue,
_props$disabled = props.disabled,
disabled = _props$disabled === void 0 ? false : _props$disabled,
_props$readOnly = props.readOnly,
readOnly = _props$readOnly === void 0 ? false : _props$readOnly,
_props$leadingZero = props.leadingZero,
leadingZero = _props$leadingZero === void 0 ? false : _props$leadingZero,
_props$shortcuts = props.shortcuts,
shortcuts = _props$shortcuts === void 0 ? ['@yearly', '@annually', '@monthly', '@weekly', '@daily', '@midnight', '@hourly'] : _props$shortcuts,
clockFormat = props.clockFormat,
_props$periodicityOnD = props.periodicityOnDoubleClick,
periodicityOnDoubleClick = _props$periodicityOnD === void 0 ? true : _props$periodicityOnD,
_props$mode = props.mode,
mode = _props$mode === void 0 ? 'multiple' : _props$mode,
_props$allowedDropdow = props.allowedDropdowns,
allowedDropdowns = _props$allowedDropdow === void 0 ? ['period', 'months', 'month-days', 'week-days', 'hours', 'minutes', 'switch'] : _props$allowedDropdow,
_props$allowedPeriods = props.allowedPeriods,
allowedPeriods = _props$allowedPeriods === void 0 ? ['year', 'month', 'week', 'day', 'hour', 'minute', 'reboot'] : _props$allowedPeriods;
var internalValueRef = (0, _react.useRef)(value);
var defaultPeriodRef = (0, _react.useRef)(defaultPeriod);
var _useState = (0, _react.useState)(),
_useState2 = _slicedToArray(_useState, 2),
period = _useState2[0],
setPeriod = _useState2[1];
var _useState3 = (0, _react.useState)(),
_useState4 = _slicedToArray(_useState3, 2),
monthDays = _useState4[0],
setMonthDays = _useState4[1];
var _useState5 = (0, _react.useState)(),
_useState6 = _slicedToArray(_useState5, 2),
months = _useState6[0],
setMonths = _useState6[1];
var _useState7 = (0, _react.useState)(),
_useState8 = _slicedToArray(_useState7, 2),
weekDays = _useState8[0],
setWeekDays = _useState8[1];
var _useState9 = (0, _react.useState)(),
_useState10 = _slicedToArray(_useState9, 2),
hours = _useState10[0],
setHours = _useState10[1];
var _useState11 = (0, _react.useState)(),
_useState12 = _slicedToArray(_useState11, 2),
minutes = _useState12[0],
setMinutes = _useState12[1];
var _useState13 = (0, _react.useState)(),
_useState14 = _slicedToArray(_useState13, 2),
tzhours = _useState14[0],
setTzHours = _useState14[1];
var _useState15 = (0, _react.useState)(),
_useState16 = _slicedToArray(_useState15, 2),
tzminutes = _useState16[0],
setTzMinutes = _useState16[1];
var _useState17 = (0, _react.useState)(),
_useState18 = _slicedToArray(_useState17, 2),
utchours = _useState18[0],
utcsetHours = _useState18[1];
var _useState19 = (0, _react.useState)(),
_useState20 = _slicedToArray(_useState19, 2),
utcminutes = _useState20[0],
utcsetMinutes = _useState20[1];
var _useState21 = (0, _react.useState)(false),
_useState22 = _slicedToArray(_useState21, 2),
error = _useState22[0],
setInternalError = _useState22[1];
var _useState23 = (0, _react.useState)(''),
_useState24 = _slicedToArray(_useState23, 2),
tzerror = _useState24[0],
setTzError = _useState24[1];
var _useState25 = (0, _react.useState)(false),
_useState26 = _slicedToArray(_useState25, 2),
valueCleared = _useState26[0],
setValueCleared = _useState26[1];
var previousValueCleared = (0, _utils.usePrevious)(valueCleared);
var localeJSON = JSON.stringify(locale);
var _useState27 = (0, _react.useState)(false),
_useState28 = _slicedToArray(_useState27, 2),
checked = _useState28[0],
setChecked = _useState28[1];
(0, _react.useEffect)(function () {
(0, _converter.setValuesFromCronString)(value, setInternalError, onError, allowEmpty, internalValueRef, true, locale, shortcuts, setMinutes, setHours, setMonthDays, setMonths, setWeekDays, setPeriod);
}, []);
(0, _react.useEffect)(function () {
if (value !== internalValueRef.current) {
(0, _converter.setValuesFromCronString)(value, setInternalError, onError, allowEmpty, internalValueRef, false, locale, shortcuts, setMinutes, setHours, setMonthDays, setMonths, setWeekDays, setPeriod);
}
}, [value, internalValueRef, localeJSON, allowEmpty, shortcuts]);
(0, _react.useEffect)(function () {
if ((period || minutes || months || monthDays || weekDays || hours) && !valueCleared && !previousValueCleared) {
var selectedPeriod = period || defaultPeriodRef.current;
var cron = (0, _converter.getCronStringFromValues)(selectedPeriod, months, monthDays, weekDays, convertToTimezone ? tzhours : hours, convertToTimezone ? tzminutes : minutes, setValueObj, humanizeValue);
setValue(cron, {
selectedPeriod: selectedPeriod
});
internalValueRef.current = cron;
setInternalError(false);
} else if (valueCleared) {
setValueCleared(false);
}
}, [period, monthDays, months, weekDays, tzhours, tzminutes, minutes, hours, humanizeValue, timezone_value, valueCleared]);
var handleClear = (0, _react.useCallback)(function () {
setMonthDays([]);
setMonths([]);
setWeekDays([]);
setHours([]);
setMinutes([]);
var newValue = '';
var newPeriod = period !== 'reboot' && period ? period : defaultPeriodRef.current;
if (newPeriod !== period) {
setPeriod(newPeriod);
}
if (clearButtonAction === 'fill-with-every') {
var cron = (0, _converter.getCronStringFromValues)(newPeriod, undefined, undefined, undefined, undefined, undefined, setValueObj);
newValue = cron;
}
setValue(newValue, {
selectedPeriod: newPeriod
});
internalValueRef.current = newValue;
setValueCleared(true);
if (allowEmpty === 'never' && clearButtonAction === 'empty') {
setInternalError(true);
} else {
setInternalError(false);
}
}, [period, setValue, onError, clearButtonAction]);
var internalClassName = (0, _react.useMemo)(function () {
var _classNames;
return (0, _utils.classNames)((_classNames = {
'react-js-cron': true,
'react-js-cron-error': error && displayError,
'react-js-cron-disabled': disabled,
'react-js-cron-read-only': readOnly
}, _defineProperty(_classNames, "".concat(className), !!className), _defineProperty(_classNames, "".concat(className, "-error"), error && displayError && !!className), _defineProperty(_classNames, "".concat(className, "-disabled"), disabled && !!className), _defineProperty(_classNames, "".concat(className, "-read-only"), readOnly && !!className), _classNames));
}, [className, error, displayError, disabled, readOnly]);
var clearButtonClassName = (0, _react.useMemo)(function () {
return (0, _utils.classNames)(_defineProperty({
'react-js-cron-clear-button': true
}, "".concat(className, "-clear-button"), !!className));
}, [className]);
var clearButtonNode = (0, _react.useMemo)(function () {
if (clearButton && !readOnly) {
return _react["default"].createElement(_core.Button, {
disabled: disabled,
ml: 5,
onClick: handleClear,
color: "red",
size: "xs"
}, "Clear");
}
return null;
}, [clearButton, readOnly, localeJSON, clearButtonClassName, disabled, handleClear]);
var periodForRender = period || defaultPeriodRef.current;
_dayjs["default"].extend(_relativeTime["default"]);
_dayjs["default"].extend(_utc["default"]);
_dayjs["default"].extend(_timezone["default"]);
(0, _react.useEffect)(function () {
var hourarr = [];
var minutearr = [];
if (convertToTimezone == true) {
try {
if (hours && hours.length > 0) {
var newh = hours === null || hours === void 0 ? void 0 : hours.map(function (h) {
if (minutes && minutes.length > 0) {
minutes === null || minutes === void 0 ? void 0 : minutes.map(function (m) {
hourarr.includes(Number((0, _dayjs["default"])().hour(h).minute(m).tz(timezone_value).format('HH'))) ? null : hourarr.push(Number((0, _dayjs["default"])().hour(h).minute(m).tz(timezone_value).format('HH')));
minutearr.includes(Number((0, _dayjs["default"])().hour(h).minute(m).tz(timezone_value).format('mm'))) ? null : minutearr.push(Number((0, _dayjs["default"])().hour(h).minute(m).tz(timezone_value).format('mm')));
});
} else {
if (Number((0, _dayjs["default"])().hour(h).minute(0).tz(timezone_value).format('mm')) !== 0) {
hourarr.includes(Number((0, _dayjs["default"])().hour(h).minute(0).tz(timezone_value).format('HH'))) ? null : hourarr.push(Number((0, _dayjs["default"])().hour(h).minute(0).tz(timezone_value).format('HH')));
minutearr.includes(Number((0, _dayjs["default"])().hour(h).minute(0).tz(timezone_value).format('mm'))) ? null : minutearr.push(Number((0, _dayjs["default"])().hour(h).minute(0).tz(timezone_value).format('mm')));
} else {
hourarr.includes(Number((0, _dayjs["default"])().hour(h).minute(0).tz(timezone_value).format('HH'))) ? null : hourarr.push(Number((0, _dayjs["default"])().hour(h).minute(0).tz(timezone_value).format('HH')));
}
}
});
}
setTzHours(hourarr);
setTzMinutes(minutearr);
setInternalError(false);
onError && onError(undefined);
setTzError('');
} catch (err) {
setTzError(err.message);
onError && onError({
type: 'invalid_cron',
description: err.message
});
setInternalError(true);
}
} else {
setTzError('');
setInternalError(false);
onError && onError(undefined);
setTzHours([]);
setTzMinutes([]);
}
}, [hours, minutes, timezone_value, convertToTimezone]);
return _react["default"].createElement(_react["default"].Fragment, null, _react["default"].createElement(_core.SimpleGrid, {
breakpoints: [{
maxWidth: 980,
cols: 2,
spacing: 'md'
}, {
maxWidth: 755,
cols: 2,
spacing: 'sm'
}, {
maxWidth: 600,
cols: 1,
spacing: 'sm'
}],
mb: 10,
cols: 2
}, ' ', allowedDropdowns.includes('period') && _react["default"].createElement(_Period["default"], {
value: periodForRender,
setValue: setPeriod,
locale: locale,
className: className,
disabled: disabled,
readOnly: readOnly,
shortcuts: shortcuts,
allowedPeriods: allowedPeriods
}), periodForRender === 'reboot' ? clearButtonNode : _react["default"].createElement(_react["default"].Fragment, null, periodForRender === 'year' && allowedDropdowns.includes('months') && _react["default"].createElement(_Months["default"], {
value: months,
setValue: setMonths,
locale: locale,
className: className,
humanizeLabels: humanizeLabels,
disabled: disabled,
readOnly: readOnly,
period: periodForRender,
periodicityOnDoubleClick: periodicityOnDoubleClick,
mode: mode
}), (periodForRender === 'year' || periodForRender === 'month') && allowedDropdowns.includes('month-days') && _react["default"].createElement(_MonthDays["default"], {
value: monthDays,
setValue: setMonthDays,
locale: locale,
className: className,
weekDays: weekDays,
disabled: disabled,
readOnly: readOnly,
leadingZero: leadingZero,
period: periodForRender,
periodicityOnDoubleClick: periodicityOnDoubleClick,
mode: mode
}), (periodForRender === 'year' || periodForRender === 'month' || periodForRender === 'week') && allowedDropdowns.includes('week-days') && _react["default"].createElement(_WeekDays["default"], {
value: weekDays,
setValue: setWeekDays,
locale: locale,
className: className,
humanizeLabels: humanizeLabels,
monthDays: monthDays,
disabled: disabled,
readOnly: readOnly,
period: periodForRender,
periodicityOnDoubleClick: periodicityOnDoubleClick,
mode: mode
}), periodForRender !== 'minute' && periodForRender !== 'hour' && allowedDropdowns.includes('hours') && _react["default"].createElement(_Hours["default"], {
value: hours,
setValue: setHours,
locale: locale,
className: className,
disabled: disabled,
readOnly: readOnly,
leadingZero: leadingZero,
clockFormat: clockFormat,
period: periodForRender,
periodicityOnDoubleClick: periodicityOnDoubleClick,
mode: mode
}), periodForRender !== 'minute' && allowedDropdowns.includes('minutes') && _react["default"].createElement(_Minutes["default"], {
value: minutes,
setValue: setMinutes,
locale: locale,
period: periodForRender,
className: className,
disabled: disabled,
readOnly: readOnly,
leadingZero: leadingZero,
clockFormat: clockFormat,
periodicityOnDoubleClick: periodicityOnDoubleClick,
mode: mode
}))), _react["default"].createElement("div", {
style: {
"float": 'right'
}
}, clearButtonNode));
}