rittenhop-dev/versions/5.94.2/node_modules/@breejs/later/lib/index.js
2024-09-23 19:40:12 -04:00

1667 lines
233 KiB
JavaScript

"use strict";
var pkg = require('../package.json');
var later = {
version: pkg.version
};
later.array = {};
later.array.sort = function (array, zeroIsLast) {
array.sort(function (a, b) {
return Number(a) - Number(b);
});
if (zeroIsLast && array[0] === 0) {
array.push(array.shift());
}
};
later.array.next = function (value, values, extent) {
var cur;
var zeroIsLargest = extent[0] !== 0;
var nextIdx = 0;
for (var i = values.length - 1; i > -1; --i) {
cur = values[i];
if (cur === value) {
return cur;
}
if (cur > value || cur === 0 && zeroIsLargest && extent[1] > value) {
nextIdx = i;
continue;
}
break;
}
return values[nextIdx];
};
later.array.nextInvalid = function (value, values, extent) {
var min = extent[0];
var max = extent[1];
var length = values.length;
var zeroValue = values[length - 1] === 0 && min !== 0 ? max : 0;
var next = value;
var i = values.indexOf(value);
var start = next;
while (next === (values[i] || zeroValue)) {
next++;
if (next > max) {
next = min;
}
i++;
if (i === length) {
i = 0;
}
if (next === start) {
return undefined;
}
}
return next;
};
later.array.prev = function (value, values, extent) {
var cur;
var length = values.length;
var zeroIsLargest = extent[0] !== 0;
var previousIdx = length - 1;
for (var i = 0; i < length; i++) {
cur = values[i];
if (cur === value) {
return cur;
}
if (cur < value || cur === 0 && zeroIsLargest && extent[1] < value) {
previousIdx = i;
continue;
}
break;
}
return values[previousIdx];
};
later.array.prevInvalid = function (value, values, extent) {
var min = extent[0];
var max = extent[1];
var length = values.length;
var zeroValue = values[length - 1] === 0 && min !== 0 ? max : 0;
var next = value;
var i = values.indexOf(value);
var start = next;
while (next === (values[i] || zeroValue)) {
next--;
if (next < min) {
next = max;
}
i--;
if (i === -1) {
i = length - 1;
}
if (next === start) {
return undefined;
}
}
return next;
};
later.day = later.D = {
name: 'day',
range: 86400,
val: function val(d) {
return d.D || (d.D = later.date.getDate.call(d));
},
isValid: function isValid(d, value) {
return later.D.val(d) === (value || later.D.extent(d)[1]);
},
extent: function extent(d) {
if (d.DExtent) return d.DExtent;
var month = later.M.val(d);
var max = later.DAYS_IN_MONTH[month - 1];
if (month === 2 && later.dy.extent(d)[1] === 366) {
max += 1;
}
return d.DExtent = [1, max];
},
start: function start(d) {
return d.DStart || (d.DStart = later.date.next(later.Y.val(d), later.M.val(d), later.D.val(d)));
},
end: function end(d) {
return d.DEnd || (d.DEnd = later.date.prev(later.Y.val(d), later.M.val(d), later.D.val(d)));
},
next: function next(d, value) {
value = value > later.D.extent(d)[1] ? 1 : value;
var month = later.date.nextRollover(d, value, later.D, later.M);
var DMax = later.D.extent(month)[1];
value = value > DMax ? 1 : value || DMax;
return later.date.next(later.Y.val(month), later.M.val(month), value);
},
prev: function prev(d, value) {
var month = later.date.prevRollover(d, value, later.D, later.M);
var DMax = later.D.extent(month)[1];
return later.date.prev(later.Y.val(month), later.M.val(month), value > DMax ? DMax : value || DMax);
}
};
later.dayOfWeekCount = later.dc = {
name: 'day of week count',
range: 604800,
val: function val(d) {
return d.dc || (d.dc = Math.floor((later.D.val(d) - 1) / 7) + 1);
},
isValid: function isValid(d, value) {
return later.dc.val(d) === value || value === 0 && later.D.val(d) > later.D.extent(d)[1] - 7;
},
extent: function extent(d) {
return d.dcExtent || (d.dcExtent = [1, Math.ceil(later.D.extent(d)[1] / 7)]);
},
start: function start(d) {
return d.dcStart || (d.dcStart = later.date.next(later.Y.val(d), later.M.val(d), Math.max(1, (later.dc.val(d) - 1) * 7 + 1 || 1)));
},
end: function end(d) {
return d.dcEnd || (d.dcEnd = later.date.prev(later.Y.val(d), later.M.val(d), Math.min(later.dc.val(d) * 7, later.D.extent(d)[1])));
},
next: function next(d, value) {
value = value > later.dc.extent(d)[1] ? 1 : value;
var month = later.date.nextRollover(d, value, later.dc, later.M);
var dcMax = later.dc.extent(month)[1];
value = value > dcMax ? 1 : value;
var next = later.date.next(later.Y.val(month), later.M.val(month), value === 0 ? later.D.extent(month)[1] - 6 : 1 + 7 * (value - 1));
if (next.getTime() <= d.getTime()) {
month = later.M.next(d, later.M.val(d) + 1);
return later.date.next(later.Y.val(month), later.M.val(month), value === 0 ? later.D.extent(month)[1] - 6 : 1 + 7 * (value - 1));
}
return next;
},
prev: function prev(d, value) {
var month = later.date.prevRollover(d, value, later.dc, later.M);
var dcMax = later.dc.extent(month)[1];
value = value > dcMax ? dcMax : value || dcMax;
return later.dc.end(later.date.prev(later.Y.val(month), later.M.val(month), 1 + 7 * (value - 1)));
}
};
later.dayOfWeek = later.dw = later.d = {
name: 'day of week',
range: 86400,
val: function val(d) {
return d.dw || (d.dw = later.date.getDay.call(d) + 1);
},
isValid: function isValid(d, value) {
return later.dw.val(d) === (value || 7);
},
extent: function extent() {
return [1, 7];
},
start: function start(d) {
return later.D.start(d);
},
end: function end(d) {
return later.D.end(d);
},
next: function next(d, value) {
value = value > 7 ? 1 : value || 7;
return later.date.next(later.Y.val(d), later.M.val(d), later.D.val(d) + (value - later.dw.val(d)) + (value <= later.dw.val(d) ? 7 : 0));
},
prev: function prev(d, value) {
value = value > 7 ? 7 : value || 7;
return later.date.prev(later.Y.val(d), later.M.val(d), later.D.val(d) + (value - later.dw.val(d)) + (value >= later.dw.val(d) ? -7 : 0));
}
};
later.dayOfYear = later.dy = {
name: 'day of year',
range: 86400,
val: function val(d) {
return d.dy || (d.dy = Math.ceil(1 + (later.D.start(d).getTime() - later.Y.start(d).getTime()) / later.DAY));
},
isValid: function isValid(d, value) {
return later.dy.val(d) === (value || later.dy.extent(d)[1]);
},
extent: function extent(d) {
var year = later.Y.val(d);
return d.dyExtent || (d.dyExtent = [1, year % 4 ? 365 : 366]);
},
start: function start(d) {
return later.D.start(d);
},
end: function end(d) {
return later.D.end(d);
},
next: function next(d, value) {
value = value > later.dy.extent(d)[1] ? 1 : value;
var year = later.date.nextRollover(d, value, later.dy, later.Y);
var dyMax = later.dy.extent(year)[1];
value = value > dyMax ? 1 : value || dyMax;
return later.date.next(later.Y.val(year), later.M.val(year), value);
},
prev: function prev(d, value) {
var year = later.date.prevRollover(d, value, later.dy, later.Y);
var dyMax = later.dy.extent(year)[1];
value = value > dyMax ? dyMax : value || dyMax;
return later.date.prev(later.Y.val(year), later.M.val(year), value);
}
};
later.hour = later.h = {
name: 'hour',
range: 3600,
val: function val(d) {
return d.h || (d.h = later.date.getHour.call(d));
},
isValid: function isValid(d, value) {
return later.h.val(d) === value;
},
extent: function extent() {
return [0, 23];
},
start: function start(d) {
return d.hStart || (d.hStart = later.date.next(later.Y.val(d), later.M.val(d), later.D.val(d), later.h.val(d)));
},
end: function end(d) {
return d.hEnd || (d.hEnd = later.date.prev(later.Y.val(d), later.M.val(d), later.D.val(d), later.h.val(d)));
},
next: function next(d, value) {
value = value > 23 ? 0 : value;
var next = later.date.next(later.Y.val(d), later.M.val(d), later.D.val(d) + (value <= later.h.val(d) ? 1 : 0), value);
if (!later.date.isUTC && next.getTime() <= d.getTime()) {
next = later.date.next(later.Y.val(next), later.M.val(next), later.D.val(next), value + 1);
}
return next;
},
prev: function prev(d, value) {
value = value > 23 ? 23 : value;
return later.date.prev(later.Y.val(d), later.M.val(d), later.D.val(d) + (value >= later.h.val(d) ? -1 : 0), value);
}
};
later.minute = later.m = {
name: 'minute',
range: 60,
val: function val(d) {
return d.m || (d.m = later.date.getMin.call(d));
},
isValid: function isValid(d, value) {
return later.m.val(d) === value;
},
extent: function extent(d) {
return [0, 59];
},
start: function start(d) {
return d.mStart || (d.mStart = later.date.next(later.Y.val(d), later.M.val(d), later.D.val(d), later.h.val(d), later.m.val(d)));
},
end: function end(d) {
return d.mEnd || (d.mEnd = later.date.prev(later.Y.val(d), later.M.val(d), later.D.val(d), later.h.val(d), later.m.val(d)));
},
next: function next(d, value) {
var m = later.m.val(d);
var s = later.s.val(d);
var inc = value > 59 ? 60 - m : value <= m ? 60 - m + value : value - m;
var next = new Date(d.getTime() + inc * later.MIN - s * later.SEC);
if (!later.date.isUTC && next.getTime() <= d.getTime()) {
next = new Date(d.getTime() + (inc + 120) * later.MIN - s * later.SEC);
}
return next;
},
prev: function prev(d, value) {
value = value > 59 ? 59 : value;
return later.date.prev(later.Y.val(d), later.M.val(d), later.D.val(d), later.h.val(d) + (value >= later.m.val(d) ? -1 : 0), value);
}
};
later.month = later.M = {
name: 'month',
range: 2629740,
val: function val(d) {
return d.M || (d.M = later.date.getMonth.call(d) + 1);
},
isValid: function isValid(d, value) {
return later.M.val(d) === (value || 12);
},
extent: function extent() {
return [1, 12];
},
start: function start(d) {
return d.MStart || (d.MStart = later.date.next(later.Y.val(d), later.M.val(d)));
},
end: function end(d) {
return d.MEnd || (d.MEnd = later.date.prev(later.Y.val(d), later.M.val(d)));
},
next: function next(d, value) {
value = value > 12 ? 1 : value || 12;
return later.date.next(later.Y.val(d) + (value > later.M.val(d) ? 0 : 1), value);
},
prev: function prev(d, value) {
value = value > 12 ? 12 : value || 12;
return later.date.prev(later.Y.val(d) - (value >= later.M.val(d) ? 1 : 0), value);
}
};
later.second = later.s = {
name: 'second',
range: 1,
val: function val(d) {
return d.s || (d.s = later.date.getSec.call(d));
},
isValid: function isValid(d, value) {
return later.s.val(d) === value;
},
extent: function extent() {
return [0, 59];
},
start: function start(d) {
return d;
},
end: function end(d) {
return d;
},
next: function next(d, value) {
var s = later.s.val(d);
var inc = value > 59 ? 60 - s : value <= s ? 60 - s + value : value - s;
var next = new Date(d.getTime() + inc * later.SEC);
if (!later.date.isUTC && next.getTime() <= d.getTime()) {
next = new Date(d.getTime() + (inc + 7200) * later.SEC);
}
return next;
},
prev: function prev(d, value, cache) {
value = value > 59 ? 59 : value;
return later.date.prev(later.Y.val(d), later.M.val(d), later.D.val(d), later.h.val(d), later.m.val(d) + (value >= later.s.val(d) ? -1 : 0), value);
}
};
later.time = later.t = {
name: 'time',
range: 1,
val: function val(d) {
return d.t || (d.t = later.h.val(d) * 3600 + later.m.val(d) * 60 + later.s.val(d));
},
isValid: function isValid(d, value) {
return later.t.val(d) === value;
},
extent: function extent() {
return [0, 86399];
},
start: function start(d) {
return d;
},
end: function end(d) {
return d;
},
next: function next(d, value) {
value = value > 86399 ? 0 : value;
var next = later.date.next(later.Y.val(d), later.M.val(d), later.D.val(d) + (value <= later.t.val(d) ? 1 : 0), 0, 0, value);
if (!later.date.isUTC && next.getTime() < d.getTime()) {
next = later.date.next(later.Y.val(next), later.M.val(next), later.D.val(next), later.h.val(next), later.m.val(next), value + 7200);
}
return next;
},
prev: function prev(d, value) {
value = value > 86399 ? 86399 : value;
return later.date.next(later.Y.val(d), later.M.val(d), later.D.val(d) + (value >= later.t.val(d) ? -1 : 0), 0, 0, value);
}
};
later.weekOfMonth = later.wm = {
name: 'week of month',
range: 604800,
val: function val(d) {
return d.wm || (d.wm = (later.D.val(d) + (later.dw.val(later.M.start(d)) - 1) + (7 - later.dw.val(d))) / 7);
},
isValid: function isValid(d, value) {
return later.wm.val(d) === (value || later.wm.extent(d)[1]);
},
extent: function extent(d) {
return d.wmExtent || (d.wmExtent = [1, (later.D.extent(d)[1] + (later.dw.val(later.M.start(d)) - 1) + (7 - later.dw.val(later.M.end(d)))) / 7]);
},
start: function start(d) {
return d.wmStart || (d.wmStart = later.date.next(later.Y.val(d), later.M.val(d), Math.max(later.D.val(d) - later.dw.val(d) + 1, 1)));
},
end: function end(d) {
return d.wmEnd || (d.wmEnd = later.date.prev(later.Y.val(d), later.M.val(d), Math.min(later.D.val(d) + (7 - later.dw.val(d)), later.D.extent(d)[1])));
},
next: function next(d, value) {
value = value > later.wm.extent(d)[1] ? 1 : value;
var month = later.date.nextRollover(d, value, later.wm, later.M);
var wmMax = later.wm.extent(month)[1];
value = value > wmMax ? 1 : value || wmMax;
return later.date.next(later.Y.val(month), later.M.val(month), Math.max(1, (value - 1) * 7 - (later.dw.val(month) - 2)));
},
prev: function prev(d, value) {
var month = later.date.prevRollover(d, value, later.wm, later.M);
var wmMax = later.wm.extent(month)[1];
value = value > wmMax ? wmMax : value || wmMax;
return later.wm.end(later.date.next(later.Y.val(month), later.M.val(month), Math.max(1, (value - 1) * 7 - (later.dw.val(month) - 2))));
}
};
later.weekOfYear = later.wy = {
name: 'week of year (ISO)',
range: 604800,
val: function val(d) {
if (d.wy) return d.wy;
var wThur = later.dw.next(later.wy.start(d), 5);
var YThur = later.dw.next(later.Y.prev(wThur, later.Y.val(wThur) - 1), 5);
return d.wy = 1 + Math.ceil((wThur.getTime() - YThur.getTime()) / later.WEEK);
},
isValid: function isValid(d, value) {
return later.wy.val(d) === (value || later.wy.extent(d)[1]);
},
extent: function extent(d) {
if (d.wyExtent) return d.wyExtent;
var year = later.dw.next(later.wy.start(d), 5);
var dwFirst = later.dw.val(later.Y.start(year));
var dwLast = later.dw.val(later.Y.end(year));
return d.wyExtent = [1, dwFirst === 5 || dwLast === 5 ? 53 : 52];
},
start: function start(d) {
return d.wyStart || (d.wyStart = later.date.next(later.Y.val(d), later.M.val(d), later.D.val(d) - (later.dw.val(d) > 1 ? later.dw.val(d) - 2 : 6)));
},
end: function end(d) {
return d.wyEnd || (d.wyEnd = later.date.prev(later.Y.val(d), later.M.val(d), later.D.val(d) + (later.dw.val(d) > 1 ? 8 - later.dw.val(d) : 0)));
},
next: function next(d, value) {
value = value > later.wy.extent(d)[1] ? 1 : value;
var wyThur = later.dw.next(later.wy.start(d), 5);
var year = later.date.nextRollover(wyThur, value, later.wy, later.Y);
if (later.wy.val(year) !== 1) {
year = later.dw.next(year, 2);
}
var wyMax = later.wy.extent(year)[1];
var wyStart = later.wy.start(year);
value = value > wyMax ? 1 : value || wyMax;
return later.date.next(later.Y.val(wyStart), later.M.val(wyStart), later.D.val(wyStart) + 7 * (value - 1));
},
prev: function prev(d, value) {
var wyThur = later.dw.next(later.wy.start(d), 5);
var year = later.date.prevRollover(wyThur, value, later.wy, later.Y);
if (later.wy.val(year) !== 1) {
year = later.dw.next(year, 2);
}
var wyMax = later.wy.extent(year)[1];
var wyEnd = later.wy.end(year);
value = value > wyMax ? wyMax : value || wyMax;
return later.wy.end(later.date.next(later.Y.val(wyEnd), later.M.val(wyEnd), later.D.val(wyEnd) + 7 * (value - 1)));
}
};
later.year = later.Y = {
name: 'year',
range: 31556900,
val: function val(d) {
return d.Y || (d.Y = later.date.getYear.call(d));
},
isValid: function isValid(d, value) {
return later.Y.val(d) === value;
},
extent: function extent() {
return [1970, 2099];
},
start: function start(d) {
return d.YStart || (d.YStart = later.date.next(later.Y.val(d)));
},
end: function end(d) {
return d.YEnd || (d.YEnd = later.date.prev(later.Y.val(d)));
},
next: function next(d, value) {
return value > later.Y.val(d) && value <= later.Y.extent()[1] ? later.date.next(value) : later.NEVER;
},
prev: function prev(d, value) {
return value < later.Y.val(d) && value >= later.Y.extent()[0] ? later.date.prev(value) : later.NEVER;
}
};
later.fullDate = later.fd = {
name: 'full date',
range: 1,
val: function val(d) {
return d.fd || (d.fd = d.getTime());
},
isValid: function isValid(d, value) {
return later.fd.val(d) === value;
},
extent: function extent() {
return [0, 3250368e7];
},
start: function start(d) {
return d;
},
end: function end(d) {
return d;
},
next: function next(d, value) {
return later.fd.val(d) < value ? new Date(value) : later.NEVER;
},
prev: function prev(d, value) {
return later.fd.val(d) > value ? new Date(value) : later.NEVER;
}
};
later.modifier = {};
later.modifier.after = later.modifier.a = function (constraint, values) {
var value = values[0];
return {
name: 'after ' + constraint.name,
range: (constraint.extent(new Date())[1] - value) * constraint.range,
val: constraint.val,
isValid: function isValid(d, value_) {
return this.val(d) >= value;
},
extent: constraint.extent,
start: constraint.start,
end: constraint.end,
next: function next(startDate, value_) {
if (value_ != value) value_ = constraint.extent(startDate)[0];
return constraint.next(startDate, value_);
},
prev: function prev(startDate, value_) {
value_ = value_ === value ? constraint.extent(startDate)[1] : value - 1;
return constraint.prev(startDate, value_);
}
};
};
later.modifier.before = later.modifier.b = function (constraint, values) {
var value = values[values.length - 1];
return {
name: 'before ' + constraint.name,
range: constraint.range * (value - 1),
val: constraint.val,
isValid: function isValid(d, value_) {
return this.val(d) < value;
},
extent: constraint.extent,
start: constraint.start,
end: constraint.end,
next: function next(startDate, value_) {
value_ = value_ === value ? constraint.extent(startDate)[0] : value;
return constraint.next(startDate, value_);
},
prev: function prev(startDate, value_) {
value_ = value_ === value ? value - 1 : constraint.extent(startDate)[1];
return constraint.prev(startDate, value_);
}
};
};
later.compile = function (schedDef) {
var constraints = [];
var constraintsLength = 0;
var tickConstraint;
for (var key in schedDef) {
var nameParts = key.split('_');
var name = nameParts[0];
var mod = nameParts[1];
var vals = schedDef[key];
var constraint = mod ? later.modifier[mod](later[name], vals) : later[name];
constraints.push({
constraint: constraint,
vals: vals
});
constraintsLength++;
}
constraints.sort(function (a, b) {
var ra = a.constraint.range;
var rb = b.constraint.range;
return rb < ra ? -1 : rb > ra ? 1 : 0;
});
tickConstraint = constraints[constraintsLength - 1].constraint;
function compareFn(dir) {
return dir === 'next' ? function (a, b) {
if (!a || !b) return true;
return a.getTime() > b.getTime();
} : function (a, b) {
if (!a || !b) return true;
return b.getTime() > a.getTime();
};
}
return {
start: function start(dir, startDate) {
var next = startDate;
var nextValue = later.array[dir];
var maxAttempts = 1e3;
var done;
while (maxAttempts-- && !done && next) {
done = true;
for (var i = 0; i < constraintsLength; i++) {
var _constraint = constraints[i].constraint;
var curValue = _constraint.val(next);
var extent = _constraint.extent(next);
var newValue = nextValue(curValue, constraints[i].vals, extent);
if (!_constraint.isValid(next, newValue)) {
next = _constraint[dir](next, newValue);
done = false;
break;
}
}
}
if (next !== later.NEVER) {
next = dir === 'next' ? tickConstraint.start(next) : tickConstraint.end(next);
}
return next;
},
end: function end(dir, startDate) {
var result;
var nextValue = later.array[dir + 'Invalid'];
var compare = compareFn(dir);
for (var i = constraintsLength - 1; i >= 0; i--) {
var _constraint2 = constraints[i].constraint;
var curValue = _constraint2.val(startDate);
var extent = _constraint2.extent(startDate);
var newValue = nextValue(curValue, constraints[i].vals, extent);
var next;
if (newValue !== undefined) {
next = _constraint2[dir](startDate, newValue);
if (next && (!result || compare(result, next))) {
result = next;
}
}
}
return result;
},
tick: function tick(dir, date) {
return new Date(dir === 'next' ? tickConstraint.end(date).getTime() + later.SEC : tickConstraint.start(date).getTime() - later.SEC);
},
tickStart: function tickStart(date) {
return tickConstraint.start(date);
}
};
};
later.schedule = function (sched) {
if (!sched) throw new Error('Missing schedule definition.');
if (!sched.schedules) throw new Error('Definition must include at least one schedule.');
var schedules = [];
var schedulesLength = sched.schedules.length;
var exceptions = [];
var exceptionsLength = sched.exceptions ? sched.exceptions.length : 0;
for (var i = 0; i < schedulesLength; i++) {
schedules.push(later.compile(sched.schedules[i]));
}
for (var j = 0; j < exceptionsLength; j++) {
exceptions.push(later.compile(sched.exceptions[j]));
}
function getInstances(dir, count, startDate, endDate, isRange) {
var compare = compareFn(dir);
var loopCount = count;
var maxAttempts = 1e3;
var schedStarts = [];
var exceptStarts = [];
var next;
var end;
var results = [];
var isForward = dir === 'next';
var lastResult;
var rStart = isForward ? 0 : 1;
var rEnd = isForward ? 1 : 0;
startDate = startDate ? new Date(startDate) : new Date();
if (!startDate || !startDate.getTime()) throw new Error('Invalid start date.');
setNextStarts(dir, schedules, schedStarts, startDate);
setRangeStarts(dir, exceptions, exceptStarts, startDate);
while (maxAttempts-- && loopCount && (next = findNext(schedStarts, compare))) {
if (endDate && compare(next, endDate)) {
break;
}
if (exceptionsLength) {
updateRangeStarts(dir, exceptions, exceptStarts, next);
if (end = calcRangeOverlap(dir, exceptStarts, next)) {
updateNextStarts(dir, schedules, schedStarts, end);
continue;
}
}
if (isRange) {
var maxEndDate = calcMaxEndDate(exceptStarts, compare);
end = calcEnd(dir, schedules, schedStarts, next, maxEndDate);
var r = isForward ? [new Date(Math.max(startDate, next)), end ? new Date(endDate ? Math.min(end, endDate) : end) : undefined] : [end ? new Date(endDate ? Math.max(endDate, end.getTime() + later.SEC) : end.getTime() + later.SEC) : undefined, new Date(Math.min(startDate, next.getTime() + later.SEC))];
if (lastResult && r[rStart].getTime() === lastResult[rEnd].getTime()) {
lastResult[rEnd] = r[rEnd];
loopCount++;
} else {
lastResult = r;
results.push(lastResult);
}
if (!end) break;
updateNextStarts(dir, schedules, schedStarts, end);
} else {
results.push(isForward ? new Date(Math.max(startDate, next)) : getStart(schedules, schedStarts, next, endDate));
tickStarts(dir, schedules, schedStarts, next);
}
loopCount--;
}
for (var _i = 0, length = results.length; _i < length; _i++) {
var result = results[_i];
results[_i] = Object.prototype.toString.call(result) === '[object Array]' ? [cleanDate(result[0]), cleanDate(result[1])] : cleanDate(result);
}
return results.length === 0 ? later.NEVER : count === 1 ? results[0] : results;
}
function cleanDate(d) {
if (d instanceof Date && !isNaN(d.valueOf())) {
return new Date(d);
}
return undefined;
}
function setNextStarts(dir, schedArray, startsArray, startDate) {
for (var _i2 = 0, length = schedArray.length; _i2 < length; _i2++) {
startsArray[_i2] = schedArray[_i2].start(dir, startDate);
}
}
function updateNextStarts(dir, schedArray, startsArray, startDate) {
var compare = compareFn(dir);
for (var _i3 = 0, length = schedArray.length; _i3 < length; _i3++) {
if (startsArray[_i3] && !compare(startsArray[_i3], startDate)) {
startsArray[_i3] = schedArray[_i3].start(dir, startDate);
}
}
}
function setRangeStarts(dir, schedArray, rangesArray, startDate) {
var compare = compareFn(dir);
for (var _i4 = 0, length = schedArray.length; _i4 < length; _i4++) {
var nextStart = schedArray[_i4].start(dir, startDate);
if (!nextStart) {
rangesArray[_i4] = later.NEVER;
} else {
rangesArray[_i4] = [nextStart, schedArray[_i4].end(dir, nextStart)];
}
}
}
function updateRangeStarts(dir, schedArray, rangesArray, startDate) {
var compare = compareFn(dir);
for (var _i5 = 0, length = schedArray.length; _i5 < length; _i5++) {
if (rangesArray[_i5] && !compare(rangesArray[_i5][0], startDate)) {
var nextStart = schedArray[_i5].start(dir, startDate);
if (!nextStart) {
rangesArray[_i5] = later.NEVER;
} else {
rangesArray[_i5] = [nextStart, schedArray[_i5].end(dir, nextStart)];
}
}
}
}
function tickStarts(dir, schedArray, startsArray, startDate) {
for (var _i6 = 0, length = schedArray.length; _i6 < length; _i6++) {
if (startsArray[_i6] && startsArray[_i6].getTime() === startDate.getTime()) {
startsArray[_i6] = schedArray[_i6].start(dir, schedArray[_i6].tick(dir, startDate));
}
}
}
function getStart(schedArray, startsArray, startDate, minEndDate) {
var result;
for (var _i7 = 0, length = startsArray.length; _i7 < length; _i7++) {
if (startsArray[_i7] && startsArray[_i7].getTime() === startDate.getTime()) {
var start = schedArray[_i7].tickStart(startDate);
if (minEndDate && start < minEndDate) {
return minEndDate;
}
if (!result || start > result) {
result = start;
}
}
}
return result;
}
function calcRangeOverlap(dir, rangesArray, startDate) {
var compare = compareFn(dir);
var result;
for (var _i8 = 0, length = rangesArray.length; _i8 < length; _i8++) {
var range = rangesArray[_i8];
if (range && !compare(range[0], startDate) && (!range[1] || compare(range[1], startDate))) {
if (!result || compare(range[1], result)) {
result = range[1];
}
}
}
return result;
}
function calcMaxEndDate(exceptsArray, compare) {
var result;
for (var _i9 = 0, length = exceptsArray.length; _i9 < length; _i9++) {
if (exceptsArray[_i9] && (!result || compare(result, exceptsArray[_i9][0]))) {
result = exceptsArray[_i9][0];
}
}
return result;
}
function calcEnd(dir, schedArray, startsArray, startDate, maxEndDate) {
var compare = compareFn(dir);
var result;
for (var _i10 = 0, length = schedArray.length; _i10 < length; _i10++) {
var start = startsArray[_i10];
if (start && start.getTime() === startDate.getTime()) {
var end = schedArray[_i10].end(dir, start);
if (maxEndDate && (!end || compare(end, maxEndDate))) {
return maxEndDate;
}
if (!result || compare(end, result)) {
result = end;
}
}
}
return result;
}
function compareFn(dir) {
return dir === 'next' ? function (a, b) {
if (!a || !b) return true;
return a.getTime() > b.getTime();
} : function (a, b) {
if (!a || !b) return true;
return b.getTime() > a.getTime();
};
}
function findNext(array, compare) {
var next = array[0];
for (var _i11 = 1, length = array.length; _i11 < length; _i11++) {
if (array[_i11] && compare(next, array[_i11])) {
next = array[_i11];
}
}
return next;
}
return {
isValid: function isValid(d) {
return getInstances('next', 1, d, d) !== later.NEVER;
},
next: function next(count, startDate, endDate) {
return getInstances('next', count || 1, startDate, endDate);
},
prev: function prev(count, startDate, endDate) {
return getInstances('prev', count || 1, startDate, endDate);
},
nextRange: function nextRange(count, startDate, endDate) {
return getInstances('next', count || 1, startDate, endDate, true);
},
prevRange: function prevRange(count, startDate, endDate) {
return getInstances('prev', count || 1, startDate, endDate, true);
}
};
};
later.setTimeout = function (fn, sched, timezone) {
var s = later.schedule(sched);
var t;
if (fn) {
scheduleTimeout();
}
function scheduleTimeout() {
var date = new Date();
var now = date.getTime();
var next = function () {
if (!timezone || ['local', 'system'].includes(timezone)) {
return s.next(2, now);
}
var localOffsetMillis = date.getTimezoneOffset() * 6e4;
var offsetMillis = getOffset(date, timezone);
// Specified timezone has the same offset as local timezone.
// ie. America/New_York = America/Nassau = GMT-4
if (offsetMillis === localOffsetMillis) {
return s.next(2, now);
}
// Offsets differ, adjust current time to match what
// it should've been for the specified timezone.
var adjustedNow = new Date(now + localOffsetMillis - offsetMillis);
return (s.next(2, adjustedNow) || /* istanbul ignore next */[]).map(function (sched) {
// adjust scheduled times to match their intended timezone
// ie. scheduled = 2021-08-22T11:30:00.000-04:00 => America/New_York
// intended = 2021-08-22T11:30:00.000-05:00 => America/Mexico_City
return new Date(sched.getTime() + offsetMillis - localOffsetMillis);
});
}();
if (!next[0]) {
t = undefined;
return;
}
var diff = next[0].getTime() - now;
if (diff < 1e3) {
diff = next[1] ? next[1].getTime() - now : 1e3;
}
t = diff < 2147483647 ? setTimeout(fn, diff) : setTimeout(scheduleTimeout, 2147483647);
} // scheduleTimeout()
return {
isDone: function isDone() {
return !t;
},
clear: function clear() {
clearTimeout(t);
}
};
}; // setTimeout()
later.setInterval = function (fn, sched, timezone) {
if (!fn) {
return;
}
var t = later.setTimeout(scheduleTimeout, sched, timezone);
var done = t.isDone();
function scheduleTimeout() {
/* istanbul ignore else */
if (!done) {
fn();
t = later.setTimeout(scheduleTimeout, sched, timezone);
}
}
return {
isDone: function isDone() {
return t.isDone();
},
clear: function clear() {
done = true;
t.clear();
}
};
}; // setInterval()
later.date = {};
later.date.timezone = function (useLocalTime) {
later.date.build = useLocalTime ? function (Y, M, D, h, m, s) {
return new Date(Y, M, D, h, m, s);
} : function (Y, M, D, h, m, s) {
return new Date(Date.UTC(Y, M, D, h, m, s));
};
var get = useLocalTime ? 'get' : 'getUTC';
var d = Date.prototype;
later.date.getYear = d[get + 'FullYear'];
later.date.getMonth = d[get + 'Month'];
later.date.getDate = d[get + 'Date'];
later.date.getDay = d[get + 'Day'];
later.date.getHour = d[get + 'Hours'];
later.date.getMin = d[get + 'Minutes'];
later.date.getSec = d[get + 'Seconds'];
later.date.isUTC = !useLocalTime;
};
later.date.UTC = function () {
later.date.timezone(false);
};
later.date.localTime = function () {
later.date.timezone(true);
};
later.date.UTC();
later.SEC = 1e3;
later.MIN = later.SEC * 60;
later.HOUR = later.MIN * 60;
later.DAY = later.HOUR * 24;
later.WEEK = later.DAY * 7;
later.DAYS_IN_MONTH = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];
later.NEVER = 0;
later.date.next = function (Y, M, D, h, m, s) {
return later.date.build(Y, M !== undefined ? M - 1 : 0, D !== undefined ? D : 1, h || 0, m || 0, s || 0);
};
later.date.nextRollover = function (d, value, constraint, period) {
var cur = constraint.val(d);
var max = constraint.extent(d)[1];
return (value || max) <= cur || value > max ? new Date(period.end(d).getTime() + later.SEC) : period.start(d);
};
later.date.prev = function (Y, M, D, h, m, s) {
var length = arguments.length;
M = length < 2 ? 11 : M - 1;
D = length < 3 ? later.D.extent(later.date.next(Y, M + 1))[1] : D;
h = length < 4 ? 23 : h;
m = length < 5 ? 59 : m;
s = length < 6 ? 59 : s;
return later.date.build(Y, M, D, h, m, s);
};
later.date.prevRollover = function (d, value, constraint, period) {
var cur = constraint.val(d);
return value >= cur || !value ? period.start(period.prev(d, period.val(d) - 1)) : period.start(d);
};
later.parse = {};
later.parse.cron = function (expr, hasSeconds) {
var NAMES = {
JAN: 1,
FEB: 2,
MAR: 3,
APR: 4,
MAY: 5,
JUN: 6,
JUL: 7,
AUG: 8,
SEP: 9,
OCT: 10,
NOV: 11,
DEC: 12,
SUN: 1,
MON: 2,
TUE: 3,
WED: 4,
THU: 5,
FRI: 6,
SAT: 7
};
var REPLACEMENTS = {
'* * * * * *': '0/1 * * * * *',
'@YEARLY': '0 0 1 1 *',
'@ANNUALLY': '0 0 1 1 *',
'@MONTHLY': '0 0 1 * *',
'@WEEKLY': '0 0 * * 0',
'@DAILY': '0 0 * * *',
'@HOURLY': '0 * * * *'
};
var FIELDS = {
s: [0, 0, 59],
m: [1, 0, 59],
h: [2, 0, 23],
D: [3, 1, 31],
M: [4, 1, 12],
Y: [6, 1970, 2099],
d: [5, 1, 7, 1]
};
function getValue(value, offset, max) {
return isNaN(value) ? NAMES[value] || null : Math.min(Number(value) + (offset || 0), max || 9999);
}
function cloneSchedule(sched) {
var clone = {};
var field;
for (field in sched) {
if (field !== 'dc' && field !== 'd') {
clone[field] = sched[field].slice(0);
}
}
return clone;
}
function add(sched, name, min, max, inc) {
var i = min;
if (!sched[name]) {
sched[name] = [];
}
while (i <= max) {
if (!sched[name].includes(i)) {
sched[name].push(i);
}
i += inc || 1;
}
sched[name].sort(function (a, b) {
return a - b;
});
}
function addHash(schedules, curSched, value, hash) {
if (curSched.d && !curSched.dc || curSched.dc && !curSched.dc.includes(hash)) {
schedules.push(cloneSchedule(curSched));
curSched = schedules[schedules.length - 1];
}
add(curSched, 'd', value, value);
add(curSched, 'dc', hash, hash);
}
function addWeekday(s, curSched, value) {
var except1 = {};
var except2 = {};
if (value === 1) {
add(curSched, 'D', 1, 3);
add(curSched, 'd', NAMES.MON, NAMES.FRI);
add(except1, 'D', 2, 2);
add(except1, 'd', NAMES.TUE, NAMES.FRI);
add(except2, 'D', 3, 3);
add(except2, 'd', NAMES.TUE, NAMES.FRI);
} else {
add(curSched, 'D', value - 1, value + 1);
add(curSched, 'd', NAMES.MON, NAMES.FRI);
add(except1, 'D', value - 1, value - 1);
add(except1, 'd', NAMES.MON, NAMES.THU);
add(except2, 'D', value + 1, value + 1);
add(except2, 'd', NAMES.TUE, NAMES.FRI);
}
s.exceptions.push(except1);
s.exceptions.push(except2);
}
function addRange(item, curSched, name, min, max, offset) {
var incSplit = item.split('/');
var inc = Number(incSplit[1]);
var range = incSplit[0];
if (range !== '*' && range !== '0') {
var rangeSplit = range.split('-');
min = getValue(rangeSplit[0], offset, max);
max = getValue(rangeSplit[1], offset, max) || max;
}
add(curSched, name, min, max, inc);
}
function parse(item, s, name, min, max, offset) {
var value;
var split;
var schedules = s.schedules;
var curSched = schedules[schedules.length - 1];
if (item === 'L') {
item = min - 1;
}
if ((value = getValue(item, offset, max)) !== null) {
add(curSched, name, value, value);
} else if ((value = getValue(item.replace('W', ''), offset, max)) !== null) {
addWeekday(s, curSched, value);
} else if ((value = getValue(item.replace('L', ''), offset, max)) !== null) {
addHash(schedules, curSched, value, min - 1);
} else if ((split = item.split('#')).length === 2) {
value = getValue(split[0], offset, max);
addHash(schedules, curSched, value, getValue(split[1]));
} else {
addRange(item, curSched, name, min, max, offset);
}
}
function isHash(item) {
return item.includes('#') || item.indexOf('L') > 0;
}
function itemSorter(a, b) {
return isHash(a) && !isHash(b) ? 1 : a - b;
}
function parseExpr(expr) {
var schedule = {
schedules: [{}],
exceptions: []
};
var components = expr.replace(/(\s)+/g, ' ').split(' ');
var field;
var f;
var component;
var items;
for (field in FIELDS) {
f = FIELDS[field];
component = components[f[0]];
if (component && component !== '*' && component !== '?') {
items = component.split(',').sort(itemSorter);
var i;
var _items = items,
length = _items.length;
for (i = 0; i < length; i++) {
parse(items[i], schedule, field, f[1], f[2], f[3]);
}
}
}
return schedule;
}
function prepareExpr(expr) {
var prepared = expr.toUpperCase();
return REPLACEMENTS[prepared] || prepared;
}
var e = prepareExpr(expr);
return parseExpr(hasSeconds ? e : '0 ' + e);
};
later.parse.recur = function () {
var schedules = [];
var exceptions = [];
var cur;
var curArray = schedules;
var curName;
var values;
var _every;
var modifier;
var applyMin;
var applyMax;
var i;
var last;
function add(name, min, max) {
name = modifier ? name + '_' + modifier : name;
if (!cur) {
curArray.push({});
cur = curArray[0];
}
if (!cur[name]) {
cur[name] = [];
}
curName = cur[name];
if (_every) {
values = [];
for (i = min; i <= max; i += _every) {
values.push(i);
}
last = {
n: name,
x: _every,
c: curName.length,
m: max
};
}
values = applyMin ? [min] : applyMax ? [max] : values;
var _values = values,
length = _values.length;
for (i = 0; i < length; i += 1) {
var value = values[i];
if (!curName.includes(value)) {
curName.push(value);
}
}
values = _every = modifier = applyMin = applyMax = 0;
}
return {
schedules: schedules,
exceptions: exceptions,
on: function on() {
values = Array.isArray(arguments[0]) ? arguments[0] : arguments;
return this;
},
every: function every(x) {
_every = x || 1;
return this;
},
after: function after(x) {
modifier = 'a';
values = [x];
return this;
},
before: function before(x) {
modifier = 'b';
values = [x];
return this;
},
first: function first() {
applyMin = 1;
return this;
},
last: function last() {
applyMax = 1;
return this;
},
time: function time() {
for (var _i12 = 0, _values2 = values, length = _values2.length; _i12 < length; _i12++) {
var split = values[_i12].split(':');
if (split.length < 3) split.push(0);
values[_i12] = Number(split[0]) * 3600 + Number(split[1]) * 60 + Number(split[2]);
}
add('t');
return this;
},
second: function second() {
add('s', 0, 59);
return this;
},
minute: function minute() {
add('m', 0, 59);
return this;
},
hour: function hour() {
add('h', 0, 23);
return this;
},
dayOfMonth: function dayOfMonth() {
add('D', 1, applyMax ? 0 : 31);
return this;
},
dayOfWeek: function dayOfWeek() {
add('d', 1, 7);
return this;
},
onWeekend: function onWeekend() {
values = [1, 7];
return this.dayOfWeek();
},
onWeekday: function onWeekday() {
values = [2, 3, 4, 5, 6];
return this.dayOfWeek();
},
dayOfWeekCount: function dayOfWeekCount() {
add('dc', 1, applyMax ? 0 : 5);
return this;
},
dayOfYear: function dayOfYear() {
add('dy', 1, applyMax ? 0 : 366);
return this;
},
weekOfMonth: function weekOfMonth() {
add('wm', 1, applyMax ? 0 : 5);
return this;
},
weekOfYear: function weekOfYear() {
add('wy', 1, applyMax ? 0 : 53);
return this;
},
month: function month() {
add('M', 1, 12);
return this;
},
year: function year() {
add('Y', 1970, 2450);
return this;
},
fullDate: function fullDate() {
for (var _i13 = 0, _values3 = values, length = _values3.length; _i13 < length; _i13++) {
values[_i13] = values[_i13].getTime();
}
add('fd');
return this;
},
customModifier: function customModifier(id, vals) {
var custom = later.modifier[id];
if (!custom) throw new Error('Custom modifier ' + id + ' not recognized!');
modifier = id;
values = Array.isArray(arguments[1]) ? arguments[1] : [arguments[1]];
return this;
},
customPeriod: function customPeriod(id) {
var custom = later[id];
if (!custom) throw new Error('Custom time period ' + id + ' not recognized!');
add(id, custom.extent(new Date())[0], custom.extent(new Date())[1]);
return this;
},
startingOn: function startingOn(start) {
return this.between(start, last.m);
},
between: function between(start, end) {
cur[last.n] = cur[last.n].splice(0, last.c);
_every = last.x;
add(last.n, start, end);
return this;
},
and: function and() {
cur = curArray[curArray.push({}) - 1];
return this;
},
except: function except() {
curArray = exceptions;
cur = null;
return this;
}
};
};
later.parse.text = function (string) {
var recur = later.parse.recur;
var pos = 0;
var input = '';
var error;
var TOKENTYPES = {
eof: /^$/,
rank: /^((\d+)(st|nd|rd|th)?)\b/,
time: /^(((0?[1-9]|1[0-2]):[0-5]\d(\s)?(am|pm))|((0?\d|1\d|2[0-3]):[0-5]\d))\b/,
dayName: /^((sun|mon|tue(s)?|wed(nes)?|thu(r(s)?)?|fri|sat(ur)?)(day)?)\b/,
monthName: /^(jan(uary)?|feb(ruary)?|ma((r(ch)?)?|y)|apr(il)?|ju(ly|ne)|aug(ust)?|oct(ober)?|(sept|nov|dec)(ember)?)\b/,
yearIndex: /^(\d{4})\b/,
every: /^every\b/,
after: /^after\b/,
before: /^before\b/,
second: /^(s|sec(ond)?(s)?)\b/,
minute: /^(m|min(ute)?(s)?)\b/,
hour: /^(h|hour(s)?)\b/,
day: /^(day(s)?( of the month)?)\b/,
dayInstance: /^day instance\b/,
dayOfWeek: /^day(s)? of the week\b/,
dayOfYear: /^day(s)? of the year\b/,
weekOfYear: /^week(s)?( of the year)?\b/,
weekOfMonth: /^week(s)? of the month\b/,
weekday: /^weekday\b/,
weekend: /^weekend\b/,
month: /^month(s)?\b/,
year: /^year(s)?\b/,
between: /^between (the)?\b/,
start: /^(start(ing)? (at|on( the)?)?)\b/,
at: /^(at|@)\b/,
and: /^(,|and\b)/,
except: /^(except\b)/,
also: /(also)\b/,
first: /^(first)\b/,
last: /^last\b/,
in: /^in\b/,
of: /^of\b/,
onthe: /^on the\b/,
on: /^on\b/,
through: /(-|^(to|through)\b)/
};
var NAMES = {
jan: 1,
feb: 2,
mar: 3,
apr: 4,
may: 5,
jun: 6,
jul: 7,
aug: 8,
sep: 9,
oct: 10,
nov: 11,
dec: 12,
sun: 1,
mon: 2,
tue: 3,
wed: 4,
thu: 5,
fri: 6,
sat: 7,
'1st': 1,
fir: 1,
'2nd': 2,
sec: 2,
'3rd': 3,
thi: 3,
'4th': 4,
for: 4
};
function t(start, end, text, type) {
return {
startPos: start,
endPos: end,
text: text,
type: type
};
}
function peek(expected) {
var scanTokens = Array.isArray(expected) ? expected : [expected];
var whiteSpace = /\s+/;
var token;
var curInput;
var m;
var scanToken;
var start;
var length_;
scanTokens.push(whiteSpace);
start = pos;
while (!token || token.type === whiteSpace) {
length_ = -1;
curInput = input.slice(Math.max(0, start));
token = t(start, start, input.split(whiteSpace)[0]);
var i;
var length = scanTokens.length;
for (i = 0; i < length; i++) {
scanToken = scanTokens[i];
m = scanToken.exec(curInput);
if (m && m.index === 0 && m[0].length > length_) {
length_ = m[0].length;
token = t(start, start + length_, curInput.slice(0, Math.max(0, length_)), scanToken);
}
}
if (token.type === whiteSpace) {
start = token.endPos;
}
}
return token;
}
function scan(expectedToken) {
var token = peek(expectedToken);
pos = token.endPos;
return token;
}
function parseThroughExpr(tokenType) {
var start = Number(parseTokenValue(tokenType));
var end = checkAndParse(TOKENTYPES.through) ? Number(parseTokenValue(tokenType)) : start;
var nums = [];
for (var i = start; i <= end; i++) {
nums.push(i);
}
return nums;
}
function parseRanges(tokenType) {
var nums = parseThroughExpr(tokenType);
while (checkAndParse(TOKENTYPES.and)) {
nums = nums.concat(parseThroughExpr(tokenType));
}
return nums;
}
function parseEvery(r) {
var number;
var period;
var start;
var end;
if (checkAndParse(TOKENTYPES.weekend)) {
r.on(NAMES.sun, NAMES.sat).dayOfWeek();
} else if (checkAndParse(TOKENTYPES.weekday)) {
r.on(NAMES.mon, NAMES.tue, NAMES.wed, NAMES.thu, NAMES.fri).dayOfWeek();
} else {
number = parseTokenValue(TOKENTYPES.rank);
r.every(number);
period = parseTimePeriod(r);
if (checkAndParse(TOKENTYPES.start)) {
number = parseTokenValue(TOKENTYPES.rank);
r.startingOn(number);
parseToken(period.type);
} else if (checkAndParse(TOKENTYPES.between)) {
start = parseTokenValue(TOKENTYPES.rank);
if (checkAndParse(TOKENTYPES.and)) {
end = parseTokenValue(TOKENTYPES.rank);
r.between(start, end);
}
}
}
}
function parseOnThe(r) {
if (checkAndParse(TOKENTYPES.first)) {
r.first();
} else if (checkAndParse(TOKENTYPES.last)) {
r.last();
} else {
r.on(parseRanges(TOKENTYPES.rank));
}
parseTimePeriod(r);
}
function parseScheduleExpr(string_) {
pos = 0;
input = string_;
error = -1;
var r = recur();
while (pos < input.length && error < 0) {
var token = parseToken([TOKENTYPES.every, TOKENTYPES.after, TOKENTYPES.before, TOKENTYPES.onthe, TOKENTYPES.on, TOKENTYPES.of, TOKENTYPES.in, TOKENTYPES.at, TOKENTYPES.and, TOKENTYPES.except, TOKENTYPES.also]);
switch (token.type) {
case TOKENTYPES.every:
parseEvery(r);
break;
case TOKENTYPES.after:
if (peek(TOKENTYPES.time).type !== undefined) {
r.after(parseTokenValue(TOKENTYPES.time));
r.time();
} else {
r.after(parseTokenValue(TOKENTYPES.rank));
parseTimePeriod(r);
}
break;
case TOKENTYPES.before:
if (peek(TOKENTYPES.time).type !== undefined) {
r.before(parseTokenValue(TOKENTYPES.time));
r.time();
} else {
r.before(parseTokenValue(TOKENTYPES.rank));
parseTimePeriod(r);
}
break;
case TOKENTYPES.onthe:
parseOnThe(r);
break;
case TOKENTYPES.on:
r.on(parseRanges(TOKENTYPES.dayName)).dayOfWeek();
break;
case TOKENTYPES.of:
r.on(parseRanges(TOKENTYPES.monthName)).month();
break;
case TOKENTYPES.in:
r.on(parseRanges(TOKENTYPES.yearIndex)).year();
break;
case TOKENTYPES.at:
r.on(parseTokenValue(TOKENTYPES.time)).time();
while (checkAndParse(TOKENTYPES.and)) {
r.on(parseTokenValue(TOKENTYPES.time)).time();
}
break;
case TOKENTYPES.and:
break;
case TOKENTYPES.also:
r.and();
break;
case TOKENTYPES.except:
r.except();
break;
default:
error = pos;
}
}
return {
schedules: r.schedules,
exceptions: r.exceptions,
error: error
};
}
function parseTimePeriod(r) {
var timePeriod = parseToken([TOKENTYPES.second, TOKENTYPES.minute, TOKENTYPES.hour, TOKENTYPES.dayOfYear, TOKENTYPES.dayOfWeek, TOKENTYPES.dayInstance, TOKENTYPES.day, TOKENTYPES.month, TOKENTYPES.year, TOKENTYPES.weekOfMonth, TOKENTYPES.weekOfYear]);
switch (timePeriod.type) {
case TOKENTYPES.second:
r.second();
break;
case TOKENTYPES.minute:
r.minute();
break;
case TOKENTYPES.hour:
r.hour();
break;
case TOKENTYPES.dayOfYear:
r.dayOfYear();
break;
case TOKENTYPES.dayOfWeek:
r.dayOfWeek();
break;
case TOKENTYPES.dayInstance:
r.dayOfWeekCount();
break;
case TOKENTYPES.day:
r.dayOfMonth();
break;
case TOKENTYPES.weekOfMonth:
r.weekOfMonth();
break;
case TOKENTYPES.weekOfYear:
r.weekOfYear();
break;
case TOKENTYPES.month:
r.month();
break;
case TOKENTYPES.year:
r.year();
break;
default:
error = pos;
}
return timePeriod;
}
function checkAndParse(tokenType) {
var found = peek(tokenType).type === tokenType;
if (found) {
scan(tokenType);
}
return found;
}
function parseToken(tokenType) {
var t = scan(tokenType);
if (t.type) {
t.text = convertString(t.text, tokenType);
} else {
error = pos;
}
return t;
}
function parseTokenValue(tokenType) {
return parseToken(tokenType).text;
}
function convertString(string_, tokenType) {
var output = string_;
switch (tokenType) {
case TOKENTYPES.time:
/*
const parts = string_.split(/(:|am|pm)/);
const hour =
parts[3] === 'pm' && parts[0] < 12
? Number.parseInt(parts[0], 10) + 12
: parts[0];
const min = parts[2].trim();
output = (hour.length === 1 ? '0' : '') + hour + ':' + min;
*/
// <https://github.com/bunkat/later/pull/188>
var parts = string_.split(/(:|am|pm)/);
var hour = Number.parseInt(parts[0], 10);
var min = parts[2].trim();
if (parts[3] === 'pm' && hour < 12) {
hour += 12;
} else if (parts[3] === 'am' && hour === 12) {
hour -= 12;
}
hour = String(hour);
output = (hour.length === 1 ? '0' : '') + hour + ':' + min;
break;
case TOKENTYPES.rank:
output = Number.parseInt(/^\d+/.exec(string_)[0], 10);
break;
case TOKENTYPES.monthName:
case TOKENTYPES.dayName:
output = NAMES[string_.slice(0, 3)];
break;
}
return output;
}
return parseScheduleExpr(string.toLowerCase());
};
function getOffset(date, zone) {
var d = date.toLocaleString('en-US', {
hour12: false,
timeZone: zone,
timeZoneName: 'short'
}) //=> ie. "8/22/2021, 24:30:00 EDT"
.match(/(\d+)\/(\d+)\/(\d+),? (\d+):(\d+):(\d+)/).map(function (n) {
return n.length === 1 ? '0' + n : n;
});
var zdate = new Date("".concat(d[3], "-").concat(d[1], "-").concat(d[2], "T").concat(d[4].replace('24', '00'), ":").concat(d[5], ":").concat(d[6], "Z"));
return date.getTime() - zdate.getTime();
} // getOffset()
module.exports = later;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["pkg","require","later","version","array","sort","zeroIsLast","a","b","Number","push","shift","next","value","values","extent","cur","zeroIsLargest","nextIdx","i","length","nextInvalid","min","max","zeroValue","indexOf","start","undefined","prev","previousIdx","prevInvalid","day","D","name","range","val","d","date","getDate","call","isValid","DExtent","month","M","DAYS_IN_MONTH","dy","DStart","Y","end","DEnd","nextRollover","DMax","prevRollover","dayOfWeekCount","dc","Math","floor","dcExtent","ceil","dcStart","dcEnd","dcMax","getTime","dayOfWeek","dw","getDay","dayOfYear","DAY","year","dyExtent","dyMax","hour","h","getHour","hStart","hEnd","isUTC","minute","m","getMin","mStart","mEnd","s","inc","Date","MIN","SEC","getMonth","MStart","MEnd","second","getSec","cache","time","t","weekOfMonth","wm","wmExtent","wmStart","wmEnd","wmMax","weekOfYear","wy","wThur","YThur","WEEK","wyExtent","dwFirst","dwLast","wyStart","wyEnd","wyThur","wyMax","getYear","YStart","YEnd","NEVER","fullDate","fd","modifier","after","constraint","value_","startDate","before","compile","schedDef","constraints","constraintsLength","tickConstraint","key","nameParts","split","mod","vals","ra","rb","compareFn","dir","nextValue","maxAttempts","done","curValue","newValue","result","compare","tick","tickStart","schedule","sched","Error","schedules","schedulesLength","exceptions","exceptionsLength","j","getInstances","count","endDate","isRange","loopCount","schedStarts","exceptStarts","results","isForward","lastResult","rStart","rEnd","setNextStarts","setRangeStarts","findNext","updateRangeStarts","calcRangeOverlap","updateNextStarts","maxEndDate","calcMaxEndDate","calcEnd","r","getStart","tickStarts","Object","prototype","toString","cleanDate","isNaN","valueOf","schedArray","startsArray","rangesArray","nextStart","minEndDate","exceptsArray","nextRange","prevRange","setTimeout","fn","timezone","scheduleTimeout","now","includes","localOffsetMillis","getTimezoneOffset","offsetMillis","getOffset","adjustedNow","map","diff","isDone","clear","clearTimeout","setInterval","useLocalTime","build","UTC","get","localTime","HOUR","period","arguments","parse","cron","expr","hasSeconds","NAMES","JAN","FEB","MAR","APR","MAY","JUN","JUL","AUG","SEP","OCT","NOV","DEC","SUN","MON","TUE","WED","THU","FRI","SAT","REPLACEMENTS","FIELDS","getValue","offset","cloneSchedule","clone","field","slice","add","addHash","curSched","hash","addWeekday","except1","except2","addRange","item","incSplit","rangeSplit","replace","isHash","itemSorter","parseExpr","components","f","component","items","_items","prepareExpr","prepared","toUpperCase","e","recur","curArray","curName","every","applyMin","applyMax","last","n","x","c","_values","on","Array","isArray","first","_values2","dayOfMonth","onWeekend","onWeekday","_values3","customModifier","id","custom","customPeriod","startingOn","between","splice","and","except","text","string","pos","input","error","TOKENTYPES","eof","rank","dayName","monthName","yearIndex","dayInstance","weekday","weekend","at","also","in","of","onthe","through","jan","feb","mar","apr","may","jun","jul","aug","sep","oct","nov","dec","sun","mon","tue","wed","thu","fri","sat","fir","sec","thi","for","type","startPos","endPos","peek","expected","scanTokens","whiteSpace","token","curInput","scanToken","length_","exec","index","scan","expectedToken","parseThroughExpr","tokenType","parseTokenValue","checkAndParse","nums","parseRanges","concat","parseEvery","number","parseTimePeriod","parseToken","parseOnThe","parseScheduleExpr","string_","timePeriod","found","convertString","output","parts","parseInt","trim","String","toLowerCase","zone","toLocaleString","hour12","timeZone","timeZoneName","match","zdate","module","exports"],"sources":["../src/index.js"],"sourcesContent":["const pkg = require('../package.json');\n\nconst later = {\n  version: pkg.version\n};\n\nlater.array = {};\nlater.array.sort = function (array, zeroIsLast) {\n  array.sort(function (a, b) {\n    return Number(a) - Number(b);\n  });\n  if (zeroIsLast && array[0] === 0) {\n    array.push(array.shift());\n  }\n};\n\nlater.array.next = function (value, values, extent) {\n  let cur;\n  const zeroIsLargest = extent[0] !== 0;\n  let nextIdx = 0;\n  for (let i = values.length - 1; i > -1; --i) {\n    cur = values[i];\n    if (cur === value) {\n      return cur;\n    }\n\n    if (cur > value || (cur === 0 && zeroIsLargest && extent[1] > value)) {\n      nextIdx = i;\n      continue;\n    }\n\n    break;\n  }\n\n  return values[nextIdx];\n};\n\nlater.array.nextInvalid = function (value, values, extent) {\n  const min = extent[0];\n  const max = extent[1];\n  const { length } = values;\n  const zeroValue = values[length - 1] === 0 && min !== 0 ? max : 0;\n  let next = value;\n  let i = values.indexOf(value);\n  const start = next;\n  while (next === (values[i] || zeroValue)) {\n    next++;\n    if (next > max) {\n      next = min;\n    }\n\n    i++;\n    if (i === length) {\n      i = 0;\n    }\n\n    if (next === start) {\n      return undefined;\n    }\n  }\n\n  return next;\n};\n\nlater.array.prev = function (value, values, extent) {\n  let cur;\n  const { length } = values;\n  const zeroIsLargest = extent[0] !== 0;\n  let previousIdx = length - 1;\n  for (let i = 0; i < length; i++) {\n    cur = values[i];\n    if (cur === value) {\n      return cur;\n    }\n\n    if (cur < value || (cur === 0 && zeroIsLargest && extent[1] < value)) {\n      previousIdx = i;\n      continue;\n    }\n\n    break;\n  }\n\n  return values[previousIdx];\n};\n\nlater.array.prevInvalid = function (value, values, extent) {\n  const min = extent[0];\n  const max = extent[1];\n  const { length } = values;\n  const zeroValue = values[length - 1] === 0 && min !== 0 ? max : 0;\n  let next = value;\n  let i = values.indexOf(value);\n  const start = next;\n  while (next === (values[i] || zeroValue)) {\n    next--;\n    if (next < min) {\n      next = max;\n    }\n\n    i--;\n    if (i === -1) {\n      i = length - 1;\n    }\n\n    if (next === start) {\n      return undefined;\n    }\n  }\n\n  return next;\n};\n\nlater.day = later.D = {\n  name: 'day',\n  range: 86400,\n  val(d) {\n    return d.D || (d.D = later.date.getDate.call(d));\n  },\n  isValid(d, value) {\n    return later.D.val(d) === (value || later.D.extent(d)[1]);\n  },\n  extent(d) {\n    if (d.DExtent) return d.DExtent;\n    const month = later.M.val(d);\n    let max = later.DAYS_IN_MONTH[month - 1];\n    if (month === 2 && later.dy.extent(d)[1] === 366) {\n      max += 1;\n    }\n\n    return (d.DExtent = [1, max]);\n  },\n  start(d) {\n    return (\n      d.DStart ||\n      (d.DStart = later.date.next(\n        later.Y.val(d),\n        later.M.val(d),\n        later.D.val(d)\n      ))\n    );\n  },\n  end(d) {\n    return (\n      d.DEnd ||\n      (d.DEnd = later.date.prev(later.Y.val(d), later.M.val(d), later.D.val(d)))\n    );\n  },\n  next(d, value) {\n    value = value > later.D.extent(d)[1] ? 1 : value;\n    const month = later.date.nextRollover(d, value, later.D, later.M);\n    const DMax = later.D.extent(month)[1];\n    value = value > DMax ? 1 : value || DMax;\n    return later.date.next(later.Y.val(month), later.M.val(month), value);\n  },\n  prev(d, value) {\n    const month = later.date.prevRollover(d, value, later.D, later.M);\n    const DMax = later.D.extent(month)[1];\n    return later.date.prev(\n      later.Y.val(month),\n      later.M.val(month),\n      value > DMax ? DMax : value || DMax\n    );\n  }\n};\nlater.dayOfWeekCount = later.dc = {\n  name: 'day of week count',\n  range: 604800,\n  val(d) {\n    return d.dc || (d.dc = Math.floor((later.D.val(d) - 1) / 7) + 1);\n  },\n  isValid(d, value) {\n    return (\n      later.dc.val(d) === value ||\n      (value === 0 && later.D.val(d) > later.D.extent(d)[1] - 7)\n    );\n  },\n  extent(d) {\n    return (\n      d.dcExtent || (d.dcExtent = [1, Math.ceil(later.D.extent(d)[1] / 7)])\n    );\n  },\n  start(d) {\n    return (\n      d.dcStart ||\n      (d.dcStart = later.date.next(\n        later.Y.val(d),\n        later.M.val(d),\n        Math.max(1, (later.dc.val(d) - 1) * 7 + 1 || 1)\n      ))\n    );\n  },\n  end(d) {\n    return (\n      d.dcEnd ||\n      (d.dcEnd = later.date.prev(\n        later.Y.val(d),\n        later.M.val(d),\n        Math.min(later.dc.val(d) * 7, later.D.extent(d)[1])\n      ))\n    );\n  },\n  next(d, value) {\n    value = value > later.dc.extent(d)[1] ? 1 : value;\n    let month = later.date.nextRollover(d, value, later.dc, later.M);\n    const dcMax = later.dc.extent(month)[1];\n    value = value > dcMax ? 1 : value;\n    const next = later.date.next(\n      later.Y.val(month),\n      later.M.val(month),\n      value === 0 ? later.D.extent(month)[1] - 6 : 1 + 7 * (value - 1)\n    );\n    if (next.getTime() <= d.getTime()) {\n      month = later.M.next(d, later.M.val(d) + 1);\n      return later.date.next(\n        later.Y.val(month),\n        later.M.val(month),\n        value === 0 ? later.D.extent(month)[1] - 6 : 1 + 7 * (value - 1)\n      );\n    }\n\n    return next;\n  },\n  prev(d, value) {\n    const month = later.date.prevRollover(d, value, later.dc, later.M);\n    const dcMax = later.dc.extent(month)[1];\n    value = value > dcMax ? dcMax : value || dcMax;\n    return later.dc.end(\n      later.date.prev(\n        later.Y.val(month),\n        later.M.val(month),\n        1 + 7 * (value - 1)\n      )\n    );\n  }\n};\nlater.dayOfWeek = later.dw = later.d = {\n  name: 'day of week',\n  range: 86400,\n  val(d) {\n    return d.dw || (d.dw = later.date.getDay.call(d) + 1);\n  },\n  isValid(d, value) {\n    return later.dw.val(d) === (value || 7);\n  },\n  extent() {\n    return [1, 7];\n  },\n  start(d) {\n    return later.D.start(d);\n  },\n  end(d) {\n    return later.D.end(d);\n  },\n  next(d, value) {\n    value = value > 7 ? 1 : value || 7;\n    return later.date.next(\n      later.Y.val(d),\n      later.M.val(d),\n      later.D.val(d) +\n        (value - later.dw.val(d)) +\n        (value <= later.dw.val(d) ? 7 : 0)\n    );\n  },\n  prev(d, value) {\n    value = value > 7 ? 7 : value || 7;\n    return later.date.prev(\n      later.Y.val(d),\n      later.M.val(d),\n      later.D.val(d) +\n        (value - later.dw.val(d)) +\n        (value >= later.dw.val(d) ? -7 : 0)\n    );\n  }\n};\nlater.dayOfYear = later.dy = {\n  name: 'day of year',\n  range: 86400,\n  val(d) {\n    return (\n      d.dy ||\n      (d.dy = Math.ceil(\n        1 +\n          (later.D.start(d).getTime() - later.Y.start(d).getTime()) / later.DAY\n      ))\n    );\n  },\n  isValid(d, value) {\n    return later.dy.val(d) === (value || later.dy.extent(d)[1]);\n  },\n  extent(d) {\n    const year = later.Y.val(d);\n    return d.dyExtent || (d.dyExtent = [1, year % 4 ? 365 : 366]);\n  },\n  start(d) {\n    return later.D.start(d);\n  },\n  end(d) {\n    return later.D.end(d);\n  },\n  next(d, value) {\n    value = value > later.dy.extent(d)[1] ? 1 : value;\n    const year = later.date.nextRollover(d, value, later.dy, later.Y);\n    const dyMax = later.dy.extent(year)[1];\n    value = value > dyMax ? 1 : value || dyMax;\n    return later.date.next(later.Y.val(year), later.M.val(year), value);\n  },\n  prev(d, value) {\n    const year = later.date.prevRollover(d, value, later.dy, later.Y);\n    const dyMax = later.dy.extent(year)[1];\n    value = value > dyMax ? dyMax : value || dyMax;\n    return later.date.prev(later.Y.val(year), later.M.val(year), value);\n  }\n};\nlater.hour = later.h = {\n  name: 'hour',\n  range: 3600,\n  val(d) {\n    return d.h || (d.h = later.date.getHour.call(d));\n  },\n  isValid(d, value) {\n    return later.h.val(d) === value;\n  },\n  extent() {\n    return [0, 23];\n  },\n  start(d) {\n    return (\n      d.hStart ||\n      (d.hStart = later.date.next(\n        later.Y.val(d),\n        later.M.val(d),\n        later.D.val(d),\n        later.h.val(d)\n      ))\n    );\n  },\n  end(d) {\n    return (\n      d.hEnd ||\n      (d.hEnd = later.date.prev(\n        later.Y.val(d),\n        later.M.val(d),\n        later.D.val(d),\n        later.h.val(d)\n      ))\n    );\n  },\n  next(d, value) {\n    value = value > 23 ? 0 : value;\n    let next = later.date.next(\n      later.Y.val(d),\n      later.M.val(d),\n      later.D.val(d) + (value <= later.h.val(d) ? 1 : 0),\n      value\n    );\n    if (!later.date.isUTC && next.getTime() <= d.getTime()) {\n      next = later.date.next(\n        later.Y.val(next),\n        later.M.val(next),\n        later.D.val(next),\n        value + 1\n      );\n    }\n\n    return next;\n  },\n  prev(d, value) {\n    value = value > 23 ? 23 : value;\n    return later.date.prev(\n      later.Y.val(d),\n      later.M.val(d),\n      later.D.val(d) + (value >= later.h.val(d) ? -1 : 0),\n      value\n    );\n  }\n};\nlater.minute = later.m = {\n  name: 'minute',\n  range: 60,\n  val(d) {\n    return d.m || (d.m = later.date.getMin.call(d));\n  },\n  isValid(d, value) {\n    return later.m.val(d) === value;\n  },\n  extent(d) {\n    return [0, 59];\n  },\n  start(d) {\n    return (\n      d.mStart ||\n      (d.mStart = later.date.next(\n        later.Y.val(d),\n        later.M.val(d),\n        later.D.val(d),\n        later.h.val(d),\n        later.m.val(d)\n      ))\n    );\n  },\n  end(d) {\n    return (\n      d.mEnd ||\n      (d.mEnd = later.date.prev(\n        later.Y.val(d),\n        later.M.val(d),\n        later.D.val(d),\n        later.h.val(d),\n        later.m.val(d)\n      ))\n    );\n  },\n  next(d, value) {\n    const m = later.m.val(d);\n    const s = later.s.val(d);\n    const inc = value > 59 ? 60 - m : value <= m ? 60 - m + value : value - m;\n    let next = new Date(d.getTime() + inc * later.MIN - s * later.SEC);\n    if (!later.date.isUTC && next.getTime() <= d.getTime()) {\n      next = new Date(d.getTime() + (inc + 120) * later.MIN - s * later.SEC);\n    }\n\n    return next;\n  },\n  prev(d, value) {\n    value = value > 59 ? 59 : value;\n    return later.date.prev(\n      later.Y.val(d),\n      later.M.val(d),\n      later.D.val(d),\n      later.h.val(d) + (value >= later.m.val(d) ? -1 : 0),\n      value\n    );\n  }\n};\nlater.month = later.M = {\n  name: 'month',\n  range: 2629740,\n  val(d) {\n    return d.M || (d.M = later.date.getMonth.call(d) + 1);\n  },\n  isValid(d, value) {\n    return later.M.val(d) === (value || 12);\n  },\n  extent() {\n    return [1, 12];\n  },\n  start(d) {\n    return (\n      d.MStart || (d.MStart = later.date.next(later.Y.val(d), later.M.val(d)))\n    );\n  },\n  end(d) {\n    return d.MEnd || (d.MEnd = later.date.prev(later.Y.val(d), later.M.val(d)));\n  },\n  next(d, value) {\n    value = value > 12 ? 1 : value || 12;\n    return later.date.next(\n      later.Y.val(d) + (value > later.M.val(d) ? 0 : 1),\n      value\n    );\n  },\n  prev(d, value) {\n    value = value > 12 ? 12 : value || 12;\n    return later.date.prev(\n      later.Y.val(d) - (value >= later.M.val(d) ? 1 : 0),\n      value\n    );\n  }\n};\nlater.second = later.s = {\n  name: 'second',\n  range: 1,\n  val(d) {\n    return d.s || (d.s = later.date.getSec.call(d));\n  },\n  isValid(d, value) {\n    return later.s.val(d) === value;\n  },\n  extent() {\n    return [0, 59];\n  },\n  start(d) {\n    return d;\n  },\n  end(d) {\n    return d;\n  },\n  next(d, value) {\n    const s = later.s.val(d);\n    const inc = value > 59 ? 60 - s : value <= s ? 60 - s + value : value - s;\n    let next = new Date(d.getTime() + inc * later.SEC);\n    if (!later.date.isUTC && next.getTime() <= d.getTime()) {\n      next = new Date(d.getTime() + (inc + 7200) * later.SEC);\n    }\n\n    return next;\n  },\n  prev(d, value, cache) {\n    value = value > 59 ? 59 : value;\n    return later.date.prev(\n      later.Y.val(d),\n      later.M.val(d),\n      later.D.val(d),\n      later.h.val(d),\n      later.m.val(d) + (value >= later.s.val(d) ? -1 : 0),\n      value\n    );\n  }\n};\nlater.time = later.t = {\n  name: 'time',\n  range: 1,\n  val(d) {\n    return (\n      d.t ||\n      (d.t = later.h.val(d) * 3600 + later.m.val(d) * 60 + later.s.val(d))\n    );\n  },\n  isValid(d, value) {\n    return later.t.val(d) === value;\n  },\n  extent() {\n    return [0, 86399];\n  },\n  start(d) {\n    return d;\n  },\n  end(d) {\n    return d;\n  },\n  next(d, value) {\n    value = value > 86399 ? 0 : value;\n    let next = later.date.next(\n      later.Y.val(d),\n      later.M.val(d),\n      later.D.val(d) + (value <= later.t.val(d) ? 1 : 0),\n      0,\n      0,\n      value\n    );\n    if (!later.date.isUTC && next.getTime() < d.getTime()) {\n      next = later.date.next(\n        later.Y.val(next),\n        later.M.val(next),\n        later.D.val(next),\n        later.h.val(next),\n        later.m.val(next),\n        value + 7200\n      );\n    }\n\n    return next;\n  },\n  prev(d, value) {\n    value = value > 86399 ? 86399 : value;\n    return later.date.next(\n      later.Y.val(d),\n      later.M.val(d),\n      later.D.val(d) + (value >= later.t.val(d) ? -1 : 0),\n      0,\n      0,\n      value\n    );\n  }\n};\nlater.weekOfMonth = later.wm = {\n  name: 'week of month',\n  range: 604800,\n  val(d) {\n    return (\n      d.wm ||\n      (d.wm =\n        (later.D.val(d) +\n          (later.dw.val(later.M.start(d)) - 1) +\n          (7 - later.dw.val(d))) /\n        7)\n    );\n  },\n  isValid(d, value) {\n    return later.wm.val(d) === (value || later.wm.extent(d)[1]);\n  },\n  extent(d) {\n    return (\n      d.wmExtent ||\n      (d.wmExtent = [\n        1,\n        (later.D.extent(d)[1] +\n          (later.dw.val(later.M.start(d)) - 1) +\n          (7 - later.dw.val(later.M.end(d)))) /\n          7\n      ])\n    );\n  },\n  start(d) {\n    return (\n      d.wmStart ||\n      (d.wmStart = later.date.next(\n        later.Y.val(d),\n        later.M.val(d),\n        Math.max(later.D.val(d) - later.dw.val(d) + 1, 1)\n      ))\n    );\n  },\n  end(d) {\n    return (\n      d.wmEnd ||\n      (d.wmEnd = later.date.prev(\n        later.Y.val(d),\n        later.M.val(d),\n        Math.min(later.D.val(d) + (7 - later.dw.val(d)), later.D.extent(d)[1])\n      ))\n    );\n  },\n  next(d, value) {\n    value = value > later.wm.extent(d)[1] ? 1 : value;\n    const month = later.date.nextRollover(d, value, later.wm, later.M);\n    const wmMax = later.wm.extent(month)[1];\n    value = value > wmMax ? 1 : value || wmMax;\n    return later.date.next(\n      later.Y.val(month),\n      later.M.val(month),\n      Math.max(1, (value - 1) * 7 - (later.dw.val(month) - 2))\n    );\n  },\n  prev(d, value) {\n    const month = later.date.prevRollover(d, value, later.wm, later.M);\n    const wmMax = later.wm.extent(month)[1];\n    value = value > wmMax ? wmMax : value || wmMax;\n    return later.wm.end(\n      later.date.next(\n        later.Y.val(month),\n        later.M.val(month),\n        Math.max(1, (value - 1) * 7 - (later.dw.val(month) - 2))\n      )\n    );\n  }\n};\nlater.weekOfYear = later.wy = {\n  name: 'week of year (ISO)',\n  range: 604800,\n  val(d) {\n    if (d.wy) return d.wy;\n    const wThur = later.dw.next(later.wy.start(d), 5);\n    const YThur = later.dw.next(later.Y.prev(wThur, later.Y.val(wThur) - 1), 5);\n    return (d.wy =\n      1 + Math.ceil((wThur.getTime() - YThur.getTime()) / later.WEEK));\n  },\n  isValid(d, value) {\n    return later.wy.val(d) === (value || later.wy.extent(d)[1]);\n  },\n  extent(d) {\n    if (d.wyExtent) return d.wyExtent;\n    const year = later.dw.next(later.wy.start(d), 5);\n    const dwFirst = later.dw.val(later.Y.start(year));\n    const dwLast = later.dw.val(later.Y.end(year));\n    return (d.wyExtent = [1, dwFirst === 5 || dwLast === 5 ? 53 : 52]);\n  },\n  start(d) {\n    return (\n      d.wyStart ||\n      (d.wyStart = later.date.next(\n        later.Y.val(d),\n        later.M.val(d),\n        later.D.val(d) - (later.dw.val(d) > 1 ? later.dw.val(d) - 2 : 6)\n      ))\n    );\n  },\n  end(d) {\n    return (\n      d.wyEnd ||\n      (d.wyEnd = later.date.prev(\n        later.Y.val(d),\n        later.M.val(d),\n        later.D.val(d) + (later.dw.val(d) > 1 ? 8 - later.dw.val(d) : 0)\n      ))\n    );\n  },\n  next(d, value) {\n    value = value > later.wy.extent(d)[1] ? 1 : value;\n    const wyThur = later.dw.next(later.wy.start(d), 5);\n    let year = later.date.nextRollover(wyThur, value, later.wy, later.Y);\n    if (later.wy.val(year) !== 1) {\n      year = later.dw.next(year, 2);\n    }\n\n    const wyMax = later.wy.extent(year)[1];\n    const wyStart = later.wy.start(year);\n    value = value > wyMax ? 1 : value || wyMax;\n    return later.date.next(\n      later.Y.val(wyStart),\n      later.M.val(wyStart),\n      later.D.val(wyStart) + 7 * (value - 1)\n    );\n  },\n  prev(d, value) {\n    const wyThur = later.dw.next(later.wy.start(d), 5);\n    let year = later.date.prevRollover(wyThur, value, later.wy, later.Y);\n    if (later.wy.val(year) !== 1) {\n      year = later.dw.next(year, 2);\n    }\n\n    const wyMax = later.wy.extent(year)[1];\n    const wyEnd = later.wy.end(year);\n    value = value > wyMax ? wyMax : value || wyMax;\n    return later.wy.end(\n      later.date.next(\n        later.Y.val(wyEnd),\n        later.M.val(wyEnd),\n        later.D.val(wyEnd) + 7 * (value - 1)\n      )\n    );\n  }\n};\nlater.year = later.Y = {\n  name: 'year',\n  range: 31556900,\n  val(d) {\n    return d.Y || (d.Y = later.date.getYear.call(d));\n  },\n  isValid(d, value) {\n    return later.Y.val(d) === value;\n  },\n  extent() {\n    return [1970, 2099];\n  },\n  start(d) {\n    return d.YStart || (d.YStart = later.date.next(later.Y.val(d)));\n  },\n  end(d) {\n    return d.YEnd || (d.YEnd = later.date.prev(later.Y.val(d)));\n  },\n  next(d, value) {\n    return value > later.Y.val(d) && value <= later.Y.extent()[1]\n      ? later.date.next(value)\n      : later.NEVER;\n  },\n  prev(d, value) {\n    return value < later.Y.val(d) && value >= later.Y.extent()[0]\n      ? later.date.prev(value)\n      : later.NEVER;\n  }\n};\nlater.fullDate = later.fd = {\n  name: 'full date',\n  range: 1,\n  val(d) {\n    return d.fd || (d.fd = d.getTime());\n  },\n  isValid(d, value) {\n    return later.fd.val(d) === value;\n  },\n  extent() {\n    return [0, 3250368e7];\n  },\n  start(d) {\n    return d;\n  },\n  end(d) {\n    return d;\n  },\n  next(d, value) {\n    return later.fd.val(d) < value ? new Date(value) : later.NEVER;\n  },\n  prev(d, value) {\n    return later.fd.val(d) > value ? new Date(value) : later.NEVER;\n  }\n};\nlater.modifier = {};\nlater.modifier.after = later.modifier.a = function (constraint, values) {\n  const value = values[0];\n  return {\n    name: 'after ' + constraint.name,\n    range: (constraint.extent(new Date())[1] - value) * constraint.range,\n    val: constraint.val,\n    isValid(d, value_) {\n      return this.val(d) >= value;\n    },\n    extent: constraint.extent,\n    start: constraint.start,\n    end: constraint.end,\n    next(startDate, value_) {\n      if (value_ != value) value_ = constraint.extent(startDate)[0];\n      return constraint.next(startDate, value_);\n    },\n    prev(startDate, value_) {\n      value_ = value_ === value ? constraint.extent(startDate)[1] : value - 1;\n      return constraint.prev(startDate, value_);\n    }\n  };\n};\n\nlater.modifier.before = later.modifier.b = function (constraint, values) {\n  const value = values[values.length - 1];\n  return {\n    name: 'before ' + constraint.name,\n    range: constraint.range * (value - 1),\n    val: constraint.val,\n    isValid(d, value_) {\n      return this.val(d) < value;\n    },\n    extent: constraint.extent,\n    start: constraint.start,\n    end: constraint.end,\n    next(startDate, value_) {\n      value_ = value_ === value ? constraint.extent(startDate)[0] : value;\n      return constraint.next(startDate, value_);\n    },\n    prev(startDate, value_) {\n      value_ = value_ === value ? value - 1 : constraint.extent(startDate)[1];\n      return constraint.prev(startDate, value_);\n    }\n  };\n};\n\nlater.compile = function (schedDef) {\n  const constraints = [];\n  let constraintsLength = 0;\n  let tickConstraint;\n  for (const key in schedDef) {\n    const nameParts = key.split('_');\n    const name = nameParts[0];\n    const mod = nameParts[1];\n    const vals = schedDef[key];\n    const constraint = mod\n      ? later.modifier[mod](later[name], vals)\n      : later[name];\n    constraints.push({\n      constraint,\n      vals\n    });\n    constraintsLength++;\n  }\n\n  constraints.sort(function (a, b) {\n    const ra = a.constraint.range;\n    const rb = b.constraint.range;\n    return rb < ra ? -1 : rb > ra ? 1 : 0;\n  });\n  tickConstraint = constraints[constraintsLength - 1].constraint;\n  function compareFn(dir) {\n    return dir === 'next'\n      ? function (a, b) {\n          if (!a || !b) return true;\n          return a.getTime() > b.getTime();\n        }\n      : function (a, b) {\n          if (!a || !b) return true;\n          return b.getTime() > a.getTime();\n        };\n  }\n\n  return {\n    start(dir, startDate) {\n      let next = startDate;\n      const nextValue = later.array[dir];\n      let maxAttempts = 1e3;\n      let done;\n      while (maxAttempts-- && !done && next) {\n        done = true;\n        for (let i = 0; i < constraintsLength; i++) {\n          const { constraint } = constraints[i];\n          const curValue = constraint.val(next);\n          const extent = constraint.extent(next);\n          const newValue = nextValue(curValue, constraints[i].vals, extent);\n          if (!constraint.isValid(next, newValue)) {\n            next = constraint[dir](next, newValue);\n            done = false;\n            break;\n          }\n        }\n      }\n\n      if (next !== later.NEVER) {\n        next =\n          dir === 'next'\n            ? tickConstraint.start(next)\n            : tickConstraint.end(next);\n      }\n\n      return next;\n    },\n    end(dir, startDate) {\n      let result;\n      const nextValue = later.array[dir + 'Invalid'];\n      const compare = compareFn(dir);\n      for (let i = constraintsLength - 1; i >= 0; i--) {\n        const { constraint } = constraints[i];\n        const curValue = constraint.val(startDate);\n        const extent = constraint.extent(startDate);\n        const newValue = nextValue(curValue, constraints[i].vals, extent);\n        var next;\n        if (newValue !== undefined) {\n          next = constraint[dir](startDate, newValue);\n          if (next && (!result || compare(result, next))) {\n            result = next;\n          }\n        }\n      }\n\n      return result;\n    },\n    tick(dir, date) {\n      return new Date(\n        dir === 'next'\n          ? tickConstraint.end(date).getTime() + later.SEC\n          : tickConstraint.start(date).getTime() - later.SEC\n      );\n    },\n    tickStart(date) {\n      return tickConstraint.start(date);\n    }\n  };\n};\n\nlater.schedule = function (sched) {\n  if (!sched) throw new Error('Missing schedule definition.');\n  if (!sched.schedules)\n    throw new Error('Definition must include at least one schedule.');\n  const schedules = [];\n  const schedulesLength = sched.schedules.length;\n  const exceptions = [];\n  const exceptionsLength = sched.exceptions ? sched.exceptions.length : 0;\n  for (let i = 0; i < schedulesLength; i++) {\n    schedules.push(later.compile(sched.schedules[i]));\n  }\n\n  for (let j = 0; j < exceptionsLength; j++) {\n    exceptions.push(later.compile(sched.exceptions[j]));\n  }\n\n  function getInstances(dir, count, startDate, endDate, isRange) {\n    const compare = compareFn(dir);\n    let loopCount = count;\n    let maxAttempts = 1e3;\n    const schedStarts = [];\n    const exceptStarts = [];\n    let next;\n    let end;\n    const results = [];\n    const isForward = dir === 'next';\n    let lastResult;\n    const rStart = isForward ? 0 : 1;\n    const rEnd = isForward ? 1 : 0;\n    startDate = startDate ? new Date(startDate) : new Date();\n    if (!startDate || !startDate.getTime())\n      throw new Error('Invalid start date.');\n    setNextStarts(dir, schedules, schedStarts, startDate);\n    setRangeStarts(dir, exceptions, exceptStarts, startDate);\n    while (\n      maxAttempts-- &&\n      loopCount &&\n      (next = findNext(schedStarts, compare))\n    ) {\n      if (endDate && compare(next, endDate)) {\n        break;\n      }\n\n      if (exceptionsLength) {\n        updateRangeStarts(dir, exceptions, exceptStarts, next);\n        if ((end = calcRangeOverlap(dir, exceptStarts, next))) {\n          updateNextStarts(dir, schedules, schedStarts, end);\n          continue;\n        }\n      }\n\n      if (isRange) {\n        const maxEndDate = calcMaxEndDate(exceptStarts, compare);\n        end = calcEnd(dir, schedules, schedStarts, next, maxEndDate);\n        const r = isForward\n          ? [\n              new Date(Math.max(startDate, next)),\n              end ? new Date(endDate ? Math.min(end, endDate) : end) : undefined\n            ]\n          : [\n              end\n                ? new Date(\n                    endDate\n                      ? Math.max(endDate, end.getTime() + later.SEC)\n                      : end.getTime() + later.SEC\n                  )\n                : undefined,\n              new Date(Math.min(startDate, next.getTime() + later.SEC))\n            ];\n        if (lastResult && r[rStart].getTime() === lastResult[rEnd].getTime()) {\n          lastResult[rEnd] = r[rEnd];\n          loopCount++;\n        } else {\n          lastResult = r;\n          results.push(lastResult);\n        }\n\n        if (!end) break;\n        updateNextStarts(dir, schedules, schedStarts, end);\n      } else {\n        results.push(\n          isForward\n            ? new Date(Math.max(startDate, next))\n            : getStart(schedules, schedStarts, next, endDate)\n        );\n        tickStarts(dir, schedules, schedStarts, next);\n      }\n\n      loopCount--;\n    }\n\n    for (let i = 0, { length } = results; i < length; i++) {\n      const result = results[i];\n      results[i] =\n        Object.prototype.toString.call(result) === '[object Array]'\n          ? [cleanDate(result[0]), cleanDate(result[1])]\n          : cleanDate(result);\n    }\n\n    return results.length === 0\n      ? later.NEVER\n      : count === 1\n      ? results[0]\n      : results;\n  }\n\n  function cleanDate(d) {\n    if (d instanceof Date && !isNaN(d.valueOf())) {\n      return new Date(d);\n    }\n\n    return undefined;\n  }\n\n  function setNextStarts(dir, schedArray, startsArray, startDate) {\n    for (let i = 0, { length } = schedArray; i < length; i++) {\n      startsArray[i] = schedArray[i].start(dir, startDate);\n    }\n  }\n\n  function updateNextStarts(dir, schedArray, startsArray, startDate) {\n    const compare = compareFn(dir);\n    for (let i = 0, { length } = schedArray; i < length; i++) {\n      if (startsArray[i] && !compare(startsArray[i], startDate)) {\n        startsArray[i] = schedArray[i].start(dir, startDate);\n      }\n    }\n  }\n\n  function setRangeStarts(dir, schedArray, rangesArray, startDate) {\n    const compare = compareFn(dir);\n    for (let i = 0, { length } = schedArray; i < length; i++) {\n      const nextStart = schedArray[i].start(dir, startDate);\n      if (!nextStart) {\n        rangesArray[i] = later.NEVER;\n      } else {\n        rangesArray[i] = [nextStart, schedArray[i].end(dir, nextStart)];\n      }\n    }\n  }\n\n  function updateRangeStarts(dir, schedArray, rangesArray, startDate) {\n    const compare = compareFn(dir);\n    for (let i = 0, { length } = schedArray; i < length; i++) {\n      if (rangesArray[i] && !compare(rangesArray[i][0], startDate)) {\n        const nextStart = schedArray[i].start(dir, startDate);\n        if (!nextStart) {\n          rangesArray[i] = later.NEVER;\n        } else {\n          rangesArray[i] = [nextStart, schedArray[i].end(dir, nextStart)];\n        }\n      }\n    }\n  }\n\n  function tickStarts(dir, schedArray, startsArray, startDate) {\n    for (let i = 0, { length } = schedArray; i < length; i++) {\n      if (startsArray[i] && startsArray[i].getTime() === startDate.getTime()) {\n        startsArray[i] = schedArray[i].start(\n          dir,\n          schedArray[i].tick(dir, startDate)\n        );\n      }\n    }\n  }\n\n  function getStart(schedArray, startsArray, startDate, minEndDate) {\n    let result;\n    for (let i = 0, { length } = startsArray; i < length; i++) {\n      if (startsArray[i] && startsArray[i].getTime() === startDate.getTime()) {\n        const start = schedArray[i].tickStart(startDate);\n        if (minEndDate && start < minEndDate) {\n          return minEndDate;\n        }\n\n        if (!result || start > result) {\n          result = start;\n        }\n      }\n    }\n\n    return result;\n  }\n\n  function calcRangeOverlap(dir, rangesArray, startDate) {\n    const compare = compareFn(dir);\n    let result;\n    for (let i = 0, { length } = rangesArray; i < length; i++) {\n      const range = rangesArray[i];\n      if (\n        range &&\n        !compare(range[0], startDate) &&\n        (!range[1] || compare(range[1], startDate))\n      ) {\n        if (!result || compare(range[1], result)) {\n          result = range[1];\n        }\n      }\n    }\n\n    return result;\n  }\n\n  function calcMaxEndDate(exceptsArray, compare) {\n    let result;\n    for (let i = 0, { length } = exceptsArray; i < length; i++) {\n      if (exceptsArray[i] && (!result || compare(result, exceptsArray[i][0]))) {\n        result = exceptsArray[i][0];\n      }\n    }\n\n    return result;\n  }\n\n  function calcEnd(dir, schedArray, startsArray, startDate, maxEndDate) {\n    const compare = compareFn(dir);\n    let result;\n    for (let i = 0, { length } = schedArray; i < length; i++) {\n      const start = startsArray[i];\n      if (start && start.getTime() === startDate.getTime()) {\n        const end = schedArray[i].end(dir, start);\n        if (maxEndDate && (!end || compare(end, maxEndDate))) {\n          return maxEndDate;\n        }\n\n        if (!result || compare(end, result)) {\n          result = end;\n        }\n      }\n    }\n\n    return result;\n  }\n\n  function compareFn(dir) {\n    return dir === 'next'\n      ? function (a, b) {\n          if (!a || !b) return true;\n          return a.getTime() > b.getTime();\n        }\n      : function (a, b) {\n          if (!a || !b) return true;\n          return b.getTime() > a.getTime();\n        };\n  }\n\n  function findNext(array, compare) {\n    let next = array[0];\n    for (let i = 1, { length } = array; i < length; i++) {\n      if (array[i] && compare(next, array[i])) {\n        next = array[i];\n      }\n    }\n\n    return next;\n  }\n\n  return {\n    isValid(d) {\n      return getInstances('next', 1, d, d) !== later.NEVER;\n    },\n    next(count, startDate, endDate) {\n      return getInstances('next', count || 1, startDate, endDate);\n    },\n    prev(count, startDate, endDate) {\n      return getInstances('prev', count || 1, startDate, endDate);\n    },\n    nextRange(count, startDate, endDate) {\n      return getInstances('next', count || 1, startDate, endDate, true);\n    },\n    prevRange(count, startDate, endDate) {\n      return getInstances('prev', count || 1, startDate, endDate, true);\n    }\n  };\n};\n\nlater.setTimeout = function (fn, sched, timezone) {\n  const s = later.schedule(sched);\n  let t;\n  if (fn) {\n    scheduleTimeout();\n  }\n\n  function scheduleTimeout() {\n    const date = new Date();\n    const now = date.getTime();\n\n    const next = (() => {\n      if (!timezone || ['local', 'system'].includes(timezone)) {\n        return s.next(2, now);\n      }\n\n      const localOffsetMillis = date.getTimezoneOffset() * 6e4;\n      const offsetMillis = getOffset(date, timezone);\n\n      // Specified timezone has the same offset as local timezone.\n      // ie. America/New_York = America/Nassau = GMT-4\n      if (offsetMillis === localOffsetMillis) {\n        return s.next(2, now);\n      }\n\n      // Offsets differ, adjust current time to match what\n      // it should've been for the specified timezone.\n      const adjustedNow = new Date(now + localOffsetMillis - offsetMillis);\n\n      return (s.next(2, adjustedNow) || /* istanbul ignore next */ []).map(\n        (sched) => {\n          // adjust scheduled times to match their intended timezone\n          // ie. scheduled = 2021-08-22T11:30:00.000-04:00 => America/New_York\n          //     intended  = 2021-08-22T11:30:00.000-05:00 => America/Mexico_City\n          return new Date(sched.getTime() + offsetMillis - localOffsetMillis);\n        }\n      );\n    })();\n\n    if (!next[0]) {\n      t = undefined;\n      return;\n    }\n\n    let diff = next[0].getTime() - now;\n    if (diff < 1e3) {\n      diff = next[1] ? next[1].getTime() - now : 1e3;\n    }\n\n    t =\n      diff < 2147483647\n        ? setTimeout(fn, diff)\n        : setTimeout(scheduleTimeout, 2147483647);\n  } // scheduleTimeout()\n\n  return {\n    isDone() {\n      return !t;\n    },\n    clear() {\n      clearTimeout(t);\n    }\n  };\n}; // setTimeout()\n\nlater.setInterval = function (fn, sched, timezone) {\n  if (!fn) {\n    return;\n  }\n\n  let t = later.setTimeout(scheduleTimeout, sched, timezone);\n  let done = t.isDone();\n  function scheduleTimeout() {\n    /* istanbul ignore else */\n    if (!done) {\n      fn();\n      t = later.setTimeout(scheduleTimeout, sched, timezone);\n    }\n  }\n\n  return {\n    isDone() {\n      return t.isDone();\n    },\n    clear() {\n      done = true;\n      t.clear();\n    }\n  };\n}; // setInterval()\n\nlater.date = {};\nlater.date.timezone = function (useLocalTime) {\n  later.date.build = useLocalTime\n    ? function (Y, M, D, h, m, s) {\n        return new Date(Y, M, D, h, m, s);\n      }\n    : function (Y, M, D, h, m, s) {\n        return new Date(Date.UTC(Y, M, D, h, m, s));\n      };\n\n  const get = useLocalTime ? 'get' : 'getUTC';\n  const d = Date.prototype;\n  later.date.getYear = d[get + 'FullYear'];\n  later.date.getMonth = d[get + 'Month'];\n  later.date.getDate = d[get + 'Date'];\n  later.date.getDay = d[get + 'Day'];\n  later.date.getHour = d[get + 'Hours'];\n  later.date.getMin = d[get + 'Minutes'];\n  later.date.getSec = d[get + 'Seconds'];\n  later.date.isUTC = !useLocalTime;\n};\n\nlater.date.UTC = function () {\n  later.date.timezone(false);\n};\n\nlater.date.localTime = function () {\n  later.date.timezone(true);\n};\n\nlater.date.UTC();\nlater.SEC = 1e3;\nlater.MIN = later.SEC * 60;\nlater.HOUR = later.MIN * 60;\nlater.DAY = later.HOUR * 24;\nlater.WEEK = later.DAY * 7;\nlater.DAYS_IN_MONTH = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];\nlater.NEVER = 0;\nlater.date.next = function (Y, M, D, h, m, s) {\n  return later.date.build(\n    Y,\n    M !== undefined ? M - 1 : 0,\n    D !== undefined ? D : 1,\n    h || 0,\n    m || 0,\n    s || 0\n  );\n};\n\nlater.date.nextRollover = function (d, value, constraint, period) {\n  const cur = constraint.val(d);\n  const max = constraint.extent(d)[1];\n  return (value || max) <= cur || value > max\n    ? new Date(period.end(d).getTime() + later.SEC)\n    : period.start(d);\n};\n\nlater.date.prev = function (Y, M, D, h, m, s) {\n  const { length } = arguments;\n  M = length < 2 ? 11 : M - 1;\n  D = length < 3 ? later.D.extent(later.date.next(Y, M + 1))[1] : D;\n  h = length < 4 ? 23 : h;\n  m = length < 5 ? 59 : m;\n  s = length < 6 ? 59 : s;\n  return later.date.build(Y, M, D, h, m, s);\n};\n\nlater.date.prevRollover = function (d, value, constraint, period) {\n  const cur = constraint.val(d);\n  return value >= cur || !value\n    ? period.start(period.prev(d, period.val(d) - 1))\n    : period.start(d);\n};\n\nlater.parse = {};\nlater.parse.cron = function (expr, hasSeconds) {\n  const NAMES = {\n    JAN: 1,\n    FEB: 2,\n    MAR: 3,\n    APR: 4,\n    MAY: 5,\n    JUN: 6,\n    JUL: 7,\n    AUG: 8,\n    SEP: 9,\n    OCT: 10,\n    NOV: 11,\n    DEC: 12,\n    SUN: 1,\n    MON: 2,\n    TUE: 3,\n    WED: 4,\n    THU: 5,\n    FRI: 6,\n    SAT: 7\n  };\n  const REPLACEMENTS = {\n    '* * * * * *': '0/1 * * * * *',\n    '@YEARLY': '0 0 1 1 *',\n    '@ANNUALLY': '0 0 1 1 *',\n    '@MONTHLY': '0 0 1 * *',\n    '@WEEKLY': '0 0 * * 0',\n    '@DAILY': '0 0 * * *',\n    '@HOURLY': '0 * * * *'\n  };\n  const FIELDS = {\n    s: [0, 0, 59],\n    m: [1, 0, 59],\n    h: [2, 0, 23],\n    D: [3, 1, 31],\n    M: [4, 1, 12],\n    Y: [6, 1970, 2099],\n    d: [5, 1, 7, 1]\n  };\n  function getValue(value, offset, max) {\n    return isNaN(value)\n      ? NAMES[value] || null\n      : Math.min(Number(value) + (offset || 0), max || 9999);\n  }\n\n  function cloneSchedule(sched) {\n    const clone = {};\n    let field;\n    for (field in sched) {\n      if (field !== 'dc' && field !== 'd') {\n        clone[field] = sched[field].slice(0);\n      }\n    }\n\n    return clone;\n  }\n\n  function add(sched, name, min, max, inc) {\n    let i = min;\n    if (!sched[name]) {\n      sched[name] = [];\n    }\n\n    while (i <= max) {\n      if (!sched[name].includes(i)) {\n        sched[name].push(i);\n      }\n\n      i += inc || 1;\n    }\n\n    sched[name].sort(function (a, b) {\n      return a - b;\n    });\n  }\n\n  function addHash(schedules, curSched, value, hash) {\n    if (\n      (curSched.d && !curSched.dc) ||\n      (curSched.dc && !curSched.dc.includes(hash))\n    ) {\n      schedules.push(cloneSchedule(curSched));\n      curSched = schedules[schedules.length - 1];\n    }\n\n    add(curSched, 'd', value, value);\n    add(curSched, 'dc', hash, hash);\n  }\n\n  function addWeekday(s, curSched, value) {\n    const except1 = {};\n    const except2 = {};\n    if (value === 1) {\n      add(curSched, 'D', 1, 3);\n      add(curSched, 'd', NAMES.MON, NAMES.FRI);\n      add(except1, 'D', 2, 2);\n      add(except1, 'd', NAMES.TUE, NAMES.FRI);\n      add(except2, 'D', 3, 3);\n      add(except2, 'd', NAMES.TUE, NAMES.FRI);\n    } else {\n      add(curSched, 'D', value - 1, value + 1);\n      add(curSched, 'd', NAMES.MON, NAMES.FRI);\n      add(except1, 'D', value - 1, value - 1);\n      add(except1, 'd', NAMES.MON, NAMES.THU);\n      add(except2, 'D', value + 1, value + 1);\n      add(except2, 'd', NAMES.TUE, NAMES.FRI);\n    }\n\n    s.exceptions.push(except1);\n    s.exceptions.push(except2);\n  }\n\n  function addRange(item, curSched, name, min, max, offset) {\n    const incSplit = item.split('/');\n    const inc = Number(incSplit[1]);\n    const range = incSplit[0];\n    if (range !== '*' && range !== '0') {\n      const rangeSplit = range.split('-');\n      min = getValue(rangeSplit[0], offset, max);\n      max = getValue(rangeSplit[1], offset, max) || max;\n    }\n\n    add(curSched, name, min, max, inc);\n  }\n\n  function parse(item, s, name, min, max, offset) {\n    let value;\n    let split;\n    const { schedules } = s;\n    const curSched = schedules[schedules.length - 1];\n    if (item === 'L') {\n      item = min - 1;\n    }\n\n    if ((value = getValue(item, offset, max)) !== null) {\n      add(curSched, name, value, value);\n    } else if (\n      (value = getValue(item.replace('W', ''), offset, max)) !== null\n    ) {\n      addWeekday(s, curSched, value);\n    } else if (\n      (value = getValue(item.replace('L', ''), offset, max)) !== null\n    ) {\n      addHash(schedules, curSched, value, min - 1);\n    } else if ((split = item.split('#')).length === 2) {\n      value = getValue(split[0], offset, max);\n      addHash(schedules, curSched, value, getValue(split[1]));\n    } else {\n      addRange(item, curSched, name, min, max, offset);\n    }\n  }\n\n  function isHash(item) {\n    return item.includes('#') || item.indexOf('L') > 0;\n  }\n\n  function itemSorter(a, b) {\n    return isHash(a) && !isHash(b) ? 1 : a - b;\n  }\n\n  function parseExpr(expr) {\n    const schedule = {\n      schedules: [{}],\n      exceptions: []\n    };\n    const components = expr.replace(/(\\s)+/g, ' ').split(' ');\n    let field;\n    let f;\n    let component;\n    let items;\n    for (field in FIELDS) {\n      f = FIELDS[field];\n      component = components[f[0]];\n      if (component && component !== '*' && component !== '?') {\n        items = component.split(',').sort(itemSorter);\n        var i;\n        const { length } = items;\n        for (i = 0; i < length; i++) {\n          parse(items[i], schedule, field, f[1], f[2], f[3]);\n        }\n      }\n    }\n\n    return schedule;\n  }\n\n  function prepareExpr(expr) {\n    const prepared = expr.toUpperCase();\n    return REPLACEMENTS[prepared] || prepared;\n  }\n\n  const e = prepareExpr(expr);\n  return parseExpr(hasSeconds ? e : '0 ' + e);\n};\n\nlater.parse.recur = function () {\n  const schedules = [];\n  const exceptions = [];\n  let cur;\n  let curArray = schedules;\n  let curName;\n  let values;\n  let every;\n  let modifier;\n  let applyMin;\n  let applyMax;\n  let i;\n  let last;\n  function add(name, min, max) {\n    name = modifier ? name + '_' + modifier : name;\n    if (!cur) {\n      curArray.push({});\n      cur = curArray[0];\n    }\n\n    if (!cur[name]) {\n      cur[name] = [];\n    }\n\n    curName = cur[name];\n    if (every) {\n      values = [];\n      for (i = min; i <= max; i += every) {\n        values.push(i);\n      }\n\n      last = {\n        n: name,\n        x: every,\n        c: curName.length,\n        m: max\n      };\n    }\n\n    values = applyMin ? [min] : applyMax ? [max] : values;\n    const { length } = values;\n    for (i = 0; i < length; i += 1) {\n      const value = values[i];\n      if (!curName.includes(value)) {\n        curName.push(value);\n      }\n    }\n\n    values = every = modifier = applyMin = applyMax = 0;\n  }\n\n  return {\n    schedules,\n    exceptions,\n    on() {\n      values = Array.isArray(arguments[0]) ? arguments[0] : arguments;\n      return this;\n    },\n    every(x) {\n      every = x || 1;\n      return this;\n    },\n    after(x) {\n      modifier = 'a';\n      values = [x];\n      return this;\n    },\n    before(x) {\n      modifier = 'b';\n      values = [x];\n      return this;\n    },\n    first() {\n      applyMin = 1;\n      return this;\n    },\n    last() {\n      applyMax = 1;\n      return this;\n    },\n    time() {\n      for (let i = 0, { length } = values; i < length; i++) {\n        const split = values[i].split(':');\n        if (split.length < 3) split.push(0);\n        values[i] =\n          Number(split[0]) * 3600 + Number(split[1]) * 60 + Number(split[2]);\n      }\n\n      add('t');\n      return this;\n    },\n    second() {\n      add('s', 0, 59);\n      return this;\n    },\n    minute() {\n      add('m', 0, 59);\n      return this;\n    },\n    hour() {\n      add('h', 0, 23);\n      return this;\n    },\n    dayOfMonth() {\n      add('D', 1, applyMax ? 0 : 31);\n      return this;\n    },\n    dayOfWeek() {\n      add('d', 1, 7);\n      return this;\n    },\n    onWeekend() {\n      values = [1, 7];\n      return this.dayOfWeek();\n    },\n    onWeekday() {\n      values = [2, 3, 4, 5, 6];\n      return this.dayOfWeek();\n    },\n    dayOfWeekCount() {\n      add('dc', 1, applyMax ? 0 : 5);\n      return this;\n    },\n    dayOfYear() {\n      add('dy', 1, applyMax ? 0 : 366);\n      return this;\n    },\n    weekOfMonth() {\n      add('wm', 1, applyMax ? 0 : 5);\n      return this;\n    },\n    weekOfYear() {\n      add('wy', 1, applyMax ? 0 : 53);\n      return this;\n    },\n    month() {\n      add('M', 1, 12);\n      return this;\n    },\n    year() {\n      add('Y', 1970, 2450);\n      return this;\n    },\n    fullDate() {\n      for (let i = 0, { length } = values; i < length; i++) {\n        values[i] = values[i].getTime();\n      }\n\n      add('fd');\n      return this;\n    },\n    customModifier(id, vals) {\n      const custom = later.modifier[id];\n      if (!custom)\n        throw new Error('Custom modifier ' + id + ' not recognized!');\n      modifier = id;\n      values = Array.isArray(arguments[1]) ? arguments[1] : [arguments[1]];\n      return this;\n    },\n    customPeriod(id) {\n      const custom = later[id];\n      if (!custom)\n        throw new Error('Custom time period ' + id + ' not recognized!');\n      add(id, custom.extent(new Date())[0], custom.extent(new Date())[1]);\n      return this;\n    },\n    startingOn(start) {\n      return this.between(start, last.m);\n    },\n    between(start, end) {\n      cur[last.n] = cur[last.n].splice(0, last.c);\n      every = last.x;\n      add(last.n, start, end);\n      return this;\n    },\n    and() {\n      cur = curArray[curArray.push({}) - 1];\n      return this;\n    },\n    except() {\n      curArray = exceptions;\n      cur = null;\n      return this;\n    }\n  };\n};\n\nlater.parse.text = function (string) {\n  const { recur } = later.parse;\n  let pos = 0;\n  let input = '';\n  let error;\n  const TOKENTYPES = {\n    eof: /^$/,\n    rank: /^((\\d+)(st|nd|rd|th)?)\\b/,\n    time: /^(((0?[1-9]|1[0-2]):[0-5]\\d(\\s)?(am|pm))|((0?\\d|1\\d|2[0-3]):[0-5]\\d))\\b/,\n    dayName: /^((sun|mon|tue(s)?|wed(nes)?|thu(r(s)?)?|fri|sat(ur)?)(day)?)\\b/,\n    monthName: /^(jan(uary)?|feb(ruary)?|ma((r(ch)?)?|y)|apr(il)?|ju(ly|ne)|aug(ust)?|oct(ober)?|(sept|nov|dec)(ember)?)\\b/,\n    yearIndex: /^(\\d{4})\\b/,\n    every: /^every\\b/,\n    after: /^after\\b/,\n    before: /^before\\b/,\n    second: /^(s|sec(ond)?(s)?)\\b/,\n    minute: /^(m|min(ute)?(s)?)\\b/,\n    hour: /^(h|hour(s)?)\\b/,\n    day: /^(day(s)?( of the month)?)\\b/,\n    dayInstance: /^day instance\\b/,\n    dayOfWeek: /^day(s)? of the week\\b/,\n    dayOfYear: /^day(s)? of the year\\b/,\n    weekOfYear: /^week(s)?( of the year)?\\b/,\n    weekOfMonth: /^week(s)? of the month\\b/,\n    weekday: /^weekday\\b/,\n    weekend: /^weekend\\b/,\n    month: /^month(s)?\\b/,\n    year: /^year(s)?\\b/,\n    between: /^between (the)?\\b/,\n    start: /^(start(ing)? (at|on( the)?)?)\\b/,\n    at: /^(at|@)\\b/,\n    and: /^(,|and\\b)/,\n    except: /^(except\\b)/,\n    also: /(also)\\b/,\n    first: /^(first)\\b/,\n    last: /^last\\b/,\n    in: /^in\\b/,\n    of: /^of\\b/,\n    onthe: /^on the\\b/,\n    on: /^on\\b/,\n    through: /(-|^(to|through)\\b)/\n  };\n  const NAMES = {\n    jan: 1,\n    feb: 2,\n    mar: 3,\n    apr: 4,\n    may: 5,\n    jun: 6,\n    jul: 7,\n    aug: 8,\n    sep: 9,\n    oct: 10,\n    nov: 11,\n    dec: 12,\n    sun: 1,\n    mon: 2,\n    tue: 3,\n    wed: 4,\n    thu: 5,\n    fri: 6,\n    sat: 7,\n    '1st': 1,\n    fir: 1,\n    '2nd': 2,\n    sec: 2,\n    '3rd': 3,\n    thi: 3,\n    '4th': 4,\n    for: 4\n  };\n  function t(start, end, text, type) {\n    return {\n      startPos: start,\n      endPos: end,\n      text,\n      type\n    };\n  }\n\n  function peek(expected) {\n    const scanTokens = Array.isArray(expected) ? expected : [expected];\n    const whiteSpace = /\\s+/;\n    let token;\n    let curInput;\n    let m;\n    let scanToken;\n    let start;\n    let length_;\n    scanTokens.push(whiteSpace);\n    start = pos;\n    while (!token || token.type === whiteSpace) {\n      length_ = -1;\n      curInput = input.slice(Math.max(0, start));\n      token = t(start, start, input.split(whiteSpace)[0]);\n      var i;\n      const { length } = scanTokens;\n      for (i = 0; i < length; i++) {\n        scanToken = scanTokens[i];\n        m = scanToken.exec(curInput);\n        if (m && m.index === 0 && m[0].length > length_) {\n          length_ = m[0].length;\n          token = t(\n            start,\n            start + length_,\n            curInput.slice(0, Math.max(0, length_)),\n            scanToken\n          );\n        }\n      }\n\n      if (token.type === whiteSpace) {\n        start = token.endPos;\n      }\n    }\n\n    return token;\n  }\n\n  function scan(expectedToken) {\n    const token = peek(expectedToken);\n    pos = token.endPos;\n    return token;\n  }\n\n  function parseThroughExpr(tokenType) {\n    const start = Number(parseTokenValue(tokenType));\n    const end = checkAndParse(TOKENTYPES.through)\n      ? Number(parseTokenValue(tokenType))\n      : start;\n    const nums = [];\n    for (let i = start; i <= end; i++) {\n      nums.push(i);\n    }\n\n    return nums;\n  }\n\n  function parseRanges(tokenType) {\n    let nums = parseThroughExpr(tokenType);\n    while (checkAndParse(TOKENTYPES.and)) {\n      nums = nums.concat(parseThroughExpr(tokenType));\n    }\n\n    return nums;\n  }\n\n  function parseEvery(r) {\n    let number;\n    let period;\n    let start;\n    let end;\n    if (checkAndParse(TOKENTYPES.weekend)) {\n      r.on(NAMES.sun, NAMES.sat).dayOfWeek();\n    } else if (checkAndParse(TOKENTYPES.weekday)) {\n      r.on(NAMES.mon, NAMES.tue, NAMES.wed, NAMES.thu, NAMES.fri).dayOfWeek();\n    } else {\n      number = parseTokenValue(TOKENTYPES.rank);\n      r.every(number);\n      period = parseTimePeriod(r);\n      if (checkAndParse(TOKENTYPES.start)) {\n        number = parseTokenValue(TOKENTYPES.rank);\n        r.startingOn(number);\n        parseToken(period.type);\n      } else if (checkAndParse(TOKENTYPES.between)) {\n        start = parseTokenValue(TOKENTYPES.rank);\n        if (checkAndParse(TOKENTYPES.and)) {\n          end = parseTokenValue(TOKENTYPES.rank);\n          r.between(start, end);\n        }\n      }\n    }\n  }\n\n  function parseOnThe(r) {\n    if (checkAndParse(TOKENTYPES.first)) {\n      r.first();\n    } else if (checkAndParse(TOKENTYPES.last)) {\n      r.last();\n    } else {\n      r.on(parseRanges(TOKENTYPES.rank));\n    }\n\n    parseTimePeriod(r);\n  }\n\n  function parseScheduleExpr(string_) {\n    pos = 0;\n    input = string_;\n    error = -1;\n    const r = recur();\n    while (pos < input.length && error < 0) {\n      const token = parseToken([\n        TOKENTYPES.every,\n        TOKENTYPES.after,\n        TOKENTYPES.before,\n        TOKENTYPES.onthe,\n        TOKENTYPES.on,\n        TOKENTYPES.of,\n        TOKENTYPES.in,\n        TOKENTYPES.at,\n        TOKENTYPES.and,\n        TOKENTYPES.except,\n        TOKENTYPES.also\n      ]);\n      switch (token.type) {\n        case TOKENTYPES.every:\n          parseEvery(r);\n          break;\n\n        case TOKENTYPES.after:\n          if (peek(TOKENTYPES.time).type !== undefined) {\n            r.after(parseTokenValue(TOKENTYPES.time));\n            r.time();\n          } else {\n            r.after(parseTokenValue(TOKENTYPES.rank));\n            parseTimePeriod(r);\n          }\n\n          break;\n\n        case TOKENTYPES.before:\n          if (peek(TOKENTYPES.time).type !== undefined) {\n            r.before(parseTokenValue(TOKENTYPES.time));\n            r.time();\n          } else {\n            r.before(parseTokenValue(TOKENTYPES.rank));\n            parseTimePeriod(r);\n          }\n\n          break;\n\n        case TOKENTYPES.onthe:\n          parseOnThe(r);\n          break;\n\n        case TOKENTYPES.on:\n          r.on(parseRanges(TOKENTYPES.dayName)).dayOfWeek();\n          break;\n\n        case TOKENTYPES.of:\n          r.on(parseRanges(TOKENTYPES.monthName)).month();\n          break;\n\n        case TOKENTYPES.in:\n          r.on(parseRanges(TOKENTYPES.yearIndex)).year();\n          break;\n\n        case TOKENTYPES.at:\n          r.on(parseTokenValue(TOKENTYPES.time)).time();\n          while (checkAndParse(TOKENTYPES.and)) {\n            r.on(parseTokenValue(TOKENTYPES.time)).time();\n          }\n\n          break;\n\n        case TOKENTYPES.and:\n          break;\n\n        case TOKENTYPES.also:\n          r.and();\n          break;\n\n        case TOKENTYPES.except:\n          r.except();\n          break;\n\n        default:\n          error = pos;\n      }\n    }\n\n    return {\n      schedules: r.schedules,\n      exceptions: r.exceptions,\n      error\n    };\n  }\n\n  function parseTimePeriod(r) {\n    const timePeriod = parseToken([\n      TOKENTYPES.second,\n      TOKENTYPES.minute,\n      TOKENTYPES.hour,\n      TOKENTYPES.dayOfYear,\n      TOKENTYPES.dayOfWeek,\n      TOKENTYPES.dayInstance,\n      TOKENTYPES.day,\n      TOKENTYPES.month,\n      TOKENTYPES.year,\n      TOKENTYPES.weekOfMonth,\n      TOKENTYPES.weekOfYear\n    ]);\n    switch (timePeriod.type) {\n      case TOKENTYPES.second:\n        r.second();\n        break;\n\n      case TOKENTYPES.minute:\n        r.minute();\n        break;\n\n      case TOKENTYPES.hour:\n        r.hour();\n        break;\n\n      case TOKENTYPES.dayOfYear:\n        r.dayOfYear();\n        break;\n\n      case TOKENTYPES.dayOfWeek:\n        r.dayOfWeek();\n        break;\n\n      case TOKENTYPES.dayInstance:\n        r.dayOfWeekCount();\n        break;\n\n      case TOKENTYPES.day:\n        r.dayOfMonth();\n        break;\n\n      case TOKENTYPES.weekOfMonth:\n        r.weekOfMonth();\n        break;\n\n      case TOKENTYPES.weekOfYear:\n        r.weekOfYear();\n        break;\n\n      case TOKENTYPES.month:\n        r.month();\n        break;\n\n      case TOKENTYPES.year:\n        r.year();\n        break;\n\n      default:\n        error = pos;\n    }\n\n    return timePeriod;\n  }\n\n  function checkAndParse(tokenType) {\n    const found = peek(tokenType).type === tokenType;\n    if (found) {\n      scan(tokenType);\n    }\n\n    return found;\n  }\n\n  function parseToken(tokenType) {\n    const t = scan(tokenType);\n    if (t.type) {\n      t.text = convertString(t.text, tokenType);\n    } else {\n      error = pos;\n    }\n\n    return t;\n  }\n\n  function parseTokenValue(tokenType) {\n    return parseToken(tokenType).text;\n  }\n\n  function convertString(string_, tokenType) {\n    let output = string_;\n    switch (tokenType) {\n      case TOKENTYPES.time:\n        /*\n        const parts = string_.split(/(:|am|pm)/);\n        const hour =\n          parts[3] === 'pm' && parts[0] < 12\n            ? Number.parseInt(parts[0], 10) + 12\n            : parts[0];\n        const min = parts[2].trim();\n        output = (hour.length === 1 ? '0' : '') + hour + ':' + min;\n        */\n        // <https://github.com/bunkat/later/pull/188>\n        const parts = string_.split(/(:|am|pm)/);\n        let hour = Number.parseInt(parts[0], 10);\n        const min = parts[2].trim();\n        if (parts[3] === 'pm' && hour < 12) {\n          hour += 12;\n        } else if (parts[3] === 'am' && hour === 12) {\n          hour -= 12;\n        }\n\n        hour = String(hour);\n        output = (hour.length === 1 ? '0' : '') + hour + ':' + min;\n        break;\n\n      case TOKENTYPES.rank:\n        output = Number.parseInt(/^\\d+/.exec(string_)[0], 10);\n        break;\n\n      case TOKENTYPES.monthName:\n      case TOKENTYPES.dayName:\n        output = NAMES[string_.slice(0, 3)];\n        break;\n    }\n\n    return output;\n  }\n\n  return parseScheduleExpr(string.toLowerCase());\n};\n\nfunction getOffset(date, zone) {\n  const d = date\n    .toLocaleString('en-US', {\n      hour12: false,\n      timeZone: zone,\n      timeZoneName: 'short'\n    }) //=> ie. \"8/22/2021, 24:30:00 EDT\"\n    .match(/(\\d+)\\/(\\d+)\\/(\\d+),? (\\d+):(\\d+):(\\d+)/)\n    .map((n) => (n.length === 1 ? '0' + n : n));\n\n  const zdate = new Date(\n    `${d[3]}-${d[1]}-${d[2]}T${d[4].replace('24', '00')}:${d[5]}:${d[6]}Z`\n  );\n\n  return date.getTime() - zdate.getTime();\n} // getOffset()\n\nmodule.exports = later;\n"],"mappings":"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"}