@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
376 lines • 40.5 kB
JavaScript
import { __values } from "tslib";
import { DateRangeType } from '../core/dates';
var MDAYS = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];
var FEBRUARY = 1;
export function range(start, stop, step) {
if (start === void 0) { start = 0; }
if (step === void 0) { step = 1; }
var res = [];
var cur = (stop === undefined) ? 0 : start;
var max = (stop === undefined) ? start : stop;
for (var i = cur; step < 0 ? i > max : i < max; i += step) {
res.push(i);
}
return res;
}
/**
* Returns true for leap years, false for non-leap years.
*
* @export
* @param year
* @returns
*/
export function isLeap(year) {
return (year % 4 === 0) && ((year % 100 !== 0) || (year % 400 === 0));
}
export function weekDay(year, month, day) {
return new Date(year, month, day).getDay();
}
/**
* Return weekday and number of days for year, month.
*
* @export
* @param year
* @param month
* @returns
*/
export function monthRange(year, month) {
if ((month < 0) || (month > 11)) {
throw new Error('Invalid month specified');
}
var day = weekDay(year, month, 1);
var nDays = MDAYS[month];
if ((month === FEBRUARY) && (isLeap(year))) {
nDays++;
}
return [day, nDays];
}
export function isDateInRanges(date, ranges) {
var e_1, _a, e_2, _b;
date = new Date(date.getFullYear(), date.getMonth(), date.getDate());
var dateInMs = date.getTime();
if (!ranges) {
return false;
}
try {
for (var ranges_1 = __values(ranges), ranges_1_1 = ranges_1.next(); !ranges_1_1.done; ranges_1_1 = ranges_1.next()) {
var descriptor = ranges_1_1.value;
var dRanges = descriptor.dateRange ? descriptor.dateRange.map(function (r) { return new Date(r.getFullYear(), r.getMonth(), r.getDate()); }) : undefined;
switch (descriptor.type) {
case (DateRangeType.After):
if (dateInMs > dRanges[0].getTime()) {
return true;
}
break;
case (DateRangeType.Before):
if (dateInMs < dRanges[0].getTime()) {
return true;
}
break;
case (DateRangeType.Between):
var dRange = dRanges.map(function (d) { return d.getTime(); });
var min = Math.min(dRange[0], dRange[1]);
var max = Math.max(dRange[0], dRange[1]);
if (dateInMs >= min && dateInMs <= max) {
return true;
}
break;
case (DateRangeType.Specific):
var datesInMs = dRanges.map(function (d) { return d.getTime(); });
try {
for (var datesInMs_1 = (e_2 = void 0, __values(datesInMs)), datesInMs_1_1 = datesInMs_1.next(); !datesInMs_1_1.done; datesInMs_1_1 = datesInMs_1.next()) {
var specificDateInMs = datesInMs_1_1.value;
if (dateInMs === specificDateInMs) {
return true;
}
}
}
catch (e_2_1) { e_2 = { error: e_2_1 }; }
finally {
try {
if (datesInMs_1_1 && !datesInMs_1_1.done && (_b = datesInMs_1.return)) _b.call(datesInMs_1);
}
finally { if (e_2) throw e_2.error; }
}
break;
case (DateRangeType.Weekdays):
var day = date.getDay();
if (day % 6 !== 0) {
return true;
}
break;
case (DateRangeType.Weekends):
var weekday = date.getDay();
if (weekday % 6 === 0) {
return true;
}
break;
default:
return false;
}
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (ranges_1_1 && !ranges_1_1.done && (_a = ranges_1.return)) _a.call(ranges_1);
}
finally { if (e_1) throw e_1.error; }
}
return false;
}
export var WEEKDAYS;
(function (WEEKDAYS) {
WEEKDAYS[WEEKDAYS["SUNDAY"] = 0] = "SUNDAY";
WEEKDAYS[WEEKDAYS["MONDAY"] = 1] = "MONDAY";
WEEKDAYS[WEEKDAYS["TUESDAY"] = 2] = "TUESDAY";
WEEKDAYS[WEEKDAYS["WEDNESDAY"] = 3] = "WEDNESDAY";
WEEKDAYS[WEEKDAYS["THURSDAY"] = 4] = "THURSDAY";
WEEKDAYS[WEEKDAYS["FRIDAY"] = 5] = "FRIDAY";
WEEKDAYS[WEEKDAYS["SATURDAY"] = 6] = "SATURDAY";
})(WEEKDAYS || (WEEKDAYS = {}));
var Calendar = /** @class */ (function () {
function Calendar(firstWeekDay) {
if (firstWeekDay === void 0) { firstWeekDay = WEEKDAYS.SUNDAY; }
this._firstWeekDay = firstWeekDay;
}
Object.defineProperty(Calendar.prototype, "firstWeekDay", {
get: function () {
return this._firstWeekDay % 7;
},
set: function (value) {
this._firstWeekDay = value;
},
enumerable: true,
configurable: true
});
/**
* Returns an array of weekdays for one week starting
* with the currently set `firstWeekDay`
*
* this.firstWeekDay = 0 (Sunday) --> [0, 1, 2, 3, 4, 5, 6]
* this.firstWeekDay = 1 (Monday) --> [1, 2, 3, 4, 5, 6, 0]
*
* @returns
*
* @memberof Calendar
*/
Calendar.prototype.weekdays = function () {
var e_3, _a;
var res = [];
try {
for (var _b = __values(range(this.firstWeekDay, this.firstWeekDay + 7)), _c = _b.next(); !_c.done; _c = _b.next()) {
var i = _c.value;
res.push(i % 7);
}
}
catch (e_3_1) { e_3 = { error: e_3_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_3) throw e_3.error; }
}
return res;
};
/**
* Returns the date values for one month. It will always iterate throught
* complete weeks, so it will contain dates outside the specified month.
*
* @param year
* @param month
* @param boolean
* @returns
*
* @memberof Calendar
*/
Calendar.prototype.monthdates = function (year, month, extraWeek) {
var e_4, _a;
if (extraWeek === void 0) { extraWeek = false; }
var date = new Date(year, month, 1);
var days = (date.getDay() - this.firstWeekDay) % 7;
if (days < 0) {
days = 7 - Math.abs(days);
}
date = this.timedelta(date, 'day', -days);
var res = [];
var value;
while (true) {
value = this.generateICalendarDate(date, year, month);
res.push(value);
date = this.timedelta(date, 'day', 1);
if ((date.getMonth() !== month) && (date.getDay() === this.firstWeekDay)) {
if (extraWeek && res.length <= 35) {
try {
for (var _b = (e_4 = void 0, __values(range(0, 7))), _c = _b.next(); !_c.done; _c = _b.next()) {
var _ = _c.value;
value = this.generateICalendarDate(date, year, month);
res.push(value);
date = this.timedelta(date, 'day', 1);
}
}
catch (e_4_1) { e_4 = { error: e_4_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_4) throw e_4.error; }
}
}
break;
}
}
return res;
};
/**
* Returns a matrix (array of arrays) representing a month's calendar.
* Each row represents a full week; week entries are ICalendarDate objects.
*
* @param year
* @param month
* @returns
*
* @memberof Calendar
*/
Calendar.prototype.monthdatescalendar = function (year, month, extraWeek) {
var e_5, _a;
if (extraWeek === void 0) { extraWeek = false; }
var dates = this.monthdates(year, month, extraWeek);
var res = [];
try {
for (var _b = __values(range(0, dates.length, 7)), _c = _b.next(); !_c.done; _c = _b.next()) {
var i = _c.value;
res.push(dates.slice(i, i + 7));
}
}
catch (e_5_1) { e_5 = { error: e_5_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_5) throw e_5.error; }
}
return res;
};
Calendar.prototype.timedelta = function (date, interval, units) {
var ret = new Date(date);
var checkRollover = function () {
if (ret.getDate() !== date.getDate()) {
ret.setDate(0);
}
};
switch (interval.toLowerCase()) {
case 'year':
ret.setFullYear(ret.getFullYear() + units);
checkRollover();
break;
case 'quarter':
ret.setMonth(ret.getMonth() + 3 * units);
checkRollover();
break;
case 'month':
ret.setMonth(ret.getMonth() + units);
checkRollover();
break;
case 'week':
ret.setDate(ret.getDate() + 7 * units);
break;
case 'day':
ret.setDate(ret.getDate() + units);
break;
case 'hour':
ret.setTime(ret.getTime() + units * 3600000);
break;
case 'minute':
ret.setTime(ret.getTime() + units * 60000);
break;
case 'second':
ret.setTime(ret.getTime() + units * 1000);
break;
default:
throw new Error('Invalid interval specifier');
}
return ret;
};
Calendar.prototype.formatToParts = function (date, locale, options, parts) {
var e_6, _a, e_7, _b;
var formatter = new Intl.DateTimeFormat(locale, options);
var result = {
date: date,
full: formatter.format(date)
};
if (formatter.formatToParts) {
var formattedParts_1 = formatter.formatToParts(date);
var toType = function (partType) {
var index = formattedParts_1.findIndex(function (_a) {
var type = _a.type;
return type === partType;
});
var o = { value: '', literal: '', combined: '' };
if (partType === 'era' && index > -1) {
o.value = formattedParts_1[index].value;
return o;
}
else if (partType === 'era' && index === -1) {
return o;
}
o.value = formattedParts_1[index].value;
o.literal = formattedParts_1[index + 1] ? formattedParts_1[index + 1].value : '';
o.combined = [o.value, o.literal].join('');
return o;
};
try {
for (var parts_1 = __values(parts), parts_1_1 = parts_1.next(); !parts_1_1.done; parts_1_1 = parts_1.next()) {
var each = parts_1_1.value;
result[each] = toType(each);
}
}
catch (e_6_1) { e_6 = { error: e_6_1 }; }
finally {
try {
if (parts_1_1 && !parts_1_1.done && (_a = parts_1.return)) _a.call(parts_1);
}
finally { if (e_6) throw e_6.error; }
}
}
else {
try {
for (var parts_2 = __values(parts), parts_2_1 = parts_2.next(); !parts_2_1.done; parts_2_1 = parts_2.next()) {
var each = parts_2_1.value;
result[each] = { value: '', literal: '', combined: '' };
}
}
catch (e_7_1) { e_7 = { error: e_7_1 }; }
finally {
try {
if (parts_2_1 && !parts_2_1.done && (_b = parts_2.return)) _b.call(parts_2);
}
finally { if (e_7) throw e_7.error; }
}
}
return result;
};
Calendar.prototype.generateICalendarDate = function (date, year, month) {
return {
date: date,
isCurrentMonth: date.getFullYear() === year && date.getMonth() === month,
isNextMonth: this.isNextMonth(date, year, month),
isPrevMonth: this.isPreviousMonth(date, year, month)
};
};
Calendar.prototype.isPreviousMonth = function (date, year, month) {
if (date.getFullYear() === year) {
return date.getMonth() < month;
}
return date.getFullYear() < year;
};
Calendar.prototype.isNextMonth = function (date, year, month) {
if (date.getFullYear() === year) {
return date.getMonth() > month;
}
return date.getFullYear() > year;
};
return Calendar;
}());
export { Calendar };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/calendar/calendar.ts"],"names":[],"mappings":";AAAA,OAAO,EAAuB,aAAa,EAAE,MAAM,eAAe,CAAC;AAEnE,IAAM,KAAK,GAAG,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;AAC/D,IAAM,QAAQ,GAAG,CAAC,CAAC;AAEnB,MAAM,UAAU,KAAK,CAAC,KAAS,EAAE,IAAI,EAAE,IAAQ;IAAzB,sBAAA,EAAA,SAAS;IAAQ,qBAAA,EAAA,QAAQ;IAC3C,IAAM,GAAG,GAAG,EAAE,CAAC;IACf,IAAM,GAAG,GAAG,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;IAC7C,IAAM,GAAG,GAAG,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC;IAChD,KAAK,IAAI,CAAC,GAAG,GAAG,EAAE,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,EAAE,CAAC,IAAI,IAAI,EAAE;QACvD,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;KACf;IACD,OAAO,GAAG,CAAC;AACf,CAAC;AAED;;;;;;GAMG;AACH,MAAM,UAAU,MAAM,CAAC,IAAY;IAC/B,OAAO,CAAC,IAAI,GAAG,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,GAAG,GAAG,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,GAAG,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC1E,CAAC;AAED,MAAM,UAAU,OAAO,CAAC,IAAY,EAAE,KAAa,EAAE,GAAW;IAC5D,OAAO,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC;AAC/C,CAAC;AAED;;;;;;;GAOG;AACH,MAAM,UAAU,UAAU,CAAC,IAAY,EAAE,KAAa;IAClD,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC,EAAE;QAC7B,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;KAC9C;IACD,IAAM,GAAG,GAAG,OAAO,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;IACpC,IAAI,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;IACzB,IAAI,CAAC,KAAK,KAAK,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE;QACxC,KAAK,EAAE,CAAC;KACX;IACD,OAAO,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;AACxB,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,IAAU,EAAE,MAA6B;;IACpE,IAAI,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;IACrE,IAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;IAEhC,IAAI,CAAC,MAAM,EAAE;QACT,OAAO,KAAK,CAAC;KAChB;;QAED,KAAyB,IAAA,WAAA,SAAA,MAAM,CAAA,8BAAA,kDAAE;YAA5B,IAAM,UAAU,mBAAA;YACjB,IAAM,OAAO,GAAG,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU,CAAC,SAAS,CAAC,GAAG,CAC3D,UAAA,CAAC,IAAI,OAAA,IAAI,IAAI,CAAC,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,EAApD,CAAoD,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;YAC3E,QAAQ,UAAU,CAAC,IAAI,EAAE;gBACrB,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC;oBACtB,IAAI,QAAQ,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,EAAE;wBACjC,OAAO,IAAI,CAAC;qBACf;oBAED,MAAM;gBACV,KAAK,CAAC,aAAa,CAAC,MAAM,CAAC;oBACvB,IAAI,QAAQ,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,EAAE;wBACjC,OAAO,IAAI,CAAC;qBACf;oBAED,MAAM;gBACV,KAAK,CAAC,aAAa,CAAC,OAAO,CAAC;oBACxB,IAAM,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,OAAO,EAAE,EAAX,CAAW,CAAC,CAAC;oBAC7C,IAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;oBAC3C,IAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;oBAC3C,IAAI,QAAQ,IAAI,GAAG,IAAI,QAAQ,IAAI,GAAG,EAAE;wBACpC,OAAO,IAAI,CAAC;qBACf;oBAED,MAAM;gBACV,KAAK,CAAC,aAAa,CAAC,QAAQ,CAAC;oBACzB,IAAM,SAAS,GAAG,OAAO,CAAC,GAAG,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,OAAO,EAAE,EAAX,CAAW,CAAC,CAAC;;wBAChD,KAA+B,IAAA,6BAAA,SAAA,SAAS,CAAA,CAAA,oCAAA,2DAAE;4BAArC,IAAM,gBAAgB,sBAAA;4BACvB,IAAI,QAAQ,KAAK,gBAAgB,EAAE;gCAC/B,OAAO,IAAI,CAAC;6BACf;yBACJ;;;;;;;;;oBAED,MAAM;gBACV,KAAK,CAAC,aAAa,CAAC,QAAQ,CAAC;oBACzB,IAAM,GAAG,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;oBAC1B,IAAI,GAAG,GAAG,CAAC,KAAK,CAAC,EAAE;wBACf,OAAO,IAAI,CAAC;qBACf;oBAED,MAAM;gBACV,KAAK,CAAC,aAAa,CAAC,QAAQ,CAAC;oBACzB,IAAM,OAAO,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;oBAC9B,IAAI,OAAO,GAAG,CAAC,KAAK,CAAC,EAAE;wBACnB,OAAO,IAAI,CAAC;qBACf;oBAED,MAAM;gBACV;oBACI,OAAO,KAAK,CAAC;aACpB;SACJ;;;;;;;;;IAED,OAAO,KAAK,CAAC;AACjB,CAAC;AA6BD,MAAM,CAAN,IAAY,QAQX;AARD,WAAY,QAAQ;IAChB,2CAAU,CAAA;IACV,2CAAU,CAAA;IACV,6CAAW,CAAA;IACX,iDAAa,CAAA;IACb,+CAAY,CAAA;IACZ,2CAAU,CAAA;IACV,+CAAY,CAAA;AAChB,CAAC,EARW,QAAQ,KAAR,QAAQ,QAQnB;AAED;IAII,kBAAY,YAAiD;QAAjD,6BAAA,EAAA,eAAkC,QAAQ,CAAC,MAAM;QACzD,IAAI,CAAC,aAAa,GAAG,YAAY,CAAC;IACtC,CAAC;IAED,sBAAW,kCAAY;aAAvB;YACI,OAAO,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC;QAClC,CAAC;aAED,UAAwB,KAAa;YACjC,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC/B,CAAC;;;OAJA;IAMD;;;;;;;;;;OAUG;IACI,2BAAQ,GAAf;;QACI,IAAM,GAAG,GAAG,EAAE,CAAC;;YACf,KAAgB,IAAA,KAAA,SAAA,KAAK,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC,CAAA,gBAAA,4BAAE;gBAA5D,IAAM,CAAC,WAAA;gBACR,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;aACnB;;;;;;;;;QACD,OAAO,GAAG,CAAC;IACf,CAAC;IAED;;;;;;;;;;OAUG;IACI,6BAAU,GAAjB,UAAkB,IAAY,EAAE,KAAa,EAAE,SAA0B;;QAA1B,0BAAA,EAAA,iBAA0B;QACrE,IAAI,IAAI,GAAG,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;QACpC,IAAI,IAAI,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;QACnD,IAAI,IAAI,GAAG,CAAC,EAAE;YACV,IAAI,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;SAC7B;QACD,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,IAAI,CAAC,CAAC;QAC1C,IAAM,GAAG,GAAG,EAAE,CAAC;QACf,IAAI,KAAoB,CAAC;QAEzB,OAAO,IAAI,EAAE;YAET,KAAK,GAAG,IAAI,CAAC,qBAAqB,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;YACtD,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAEhB,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;YAEtC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,KAAK,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,IAAI,CAAC,YAAY,CAAC,EAAE;gBACtE,IAAI,SAAS,IAAI,GAAG,CAAC,MAAM,IAAI,EAAE,EAAE;;wBAC/B,KAAgB,IAAA,oBAAA,SAAA,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA,CAAA,gBAAA,4BAAE;4BAAxB,IAAM,CAAC,WAAA;4BACR,KAAK,GAAG,IAAI,CAAC,qBAAqB,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;4BACtD,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;4BAChB,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;yBACzC;;;;;;;;;iBACJ;gBACD,MAAM;aACT;SACJ;QACD,OAAO,GAAG,CAAC;IACf,CAAC;IAED;;;;;;;;;OASG;IACI,qCAAkB,GAAzB,UAA0B,IAAY,EAAE,KAAa,EAAE,SAA0B;;QAA1B,0BAAA,EAAA,iBAA0B;QAC7E,IAAM,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC;QACtD,IAAM,GAAG,GAAG,EAAE,CAAC;;YACf,KAAgB,IAAA,KAAA,SAAA,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC,CAAA,gBAAA,4BAAE;gBAAtC,IAAM,CAAC,WAAA;gBACR,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;aACnC;;;;;;;;;QACD,OAAO,GAAG,CAAC;IACf,CAAC;IAEM,4BAAS,GAAhB,UAAiB,IAAU,EAAE,QAAgB,EAAE,KAAa;QACxD,IAAM,GAAG,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,CAAC;QAE3B,IAAM,aAAa,GAAG;YAClB,IAAI,GAAG,CAAC,OAAO,EAAE,KAAK,IAAI,CAAC,OAAO,EAAE,EAAE;gBAClC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;aAClB;QACL,CAAC,CAAC;QAEF,QAAQ,QAAQ,CAAC,WAAW,EAAE,EAAE;YAC5B,KAAK,MAAM;gBACP,GAAG,CAAC,WAAW,CAAC,GAAG,CAAC,WAAW,EAAE,GAAG,KAAK,CAAC,CAAC;gBAC3C,aAAa,EAAE,CAAC;gBAChB,MAAM;YACV,KAAK,SAAS;gBACV,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,EAAE,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC;gBACzC,aAAa,EAAE,CAAC;gBAChB,MAAM;YACV,KAAK,OAAO;gBACR,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,EAAE,GAAG,KAAK,CAAC,CAAC;gBACrC,aAAa,EAAE,CAAC;gBAChB,MAAM;YACV,KAAK,MAAM;gBACP,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC;gBACvC,MAAM;YACV,KAAK,KAAK;gBACN,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,KAAK,CAAC,CAAC;gBACnC,MAAM;YACV,KAAK,MAAM;gBACP,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,KAAK,GAAG,OAAO,CAAC,CAAC;gBAC7C,MAAM;YACV,KAAK,QAAQ;gBACT,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,KAAK,GAAG,KAAK,CAAC,CAAC;gBAC3C,MAAM;YACV,KAAK,QAAQ;gBACT,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,KAAK,GAAG,IAAI,CAAC,CAAC;gBAC1C,MAAM;YACV;gBACI,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;SACrD;QACD,OAAO,GAAG,CAAC;IACf,CAAC;IAEM,gCAAa,GAApB,UAAqB,IAAU,EAAE,MAAc,EAAE,OAAY,EAAE,KAAe;;QAC1E,IAAM,SAAS,GAAG,IAAI,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QAC3D,IAAM,MAAM,GAAG;YACX,IAAI,MAAA;YACJ,IAAI,EAAE,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC;SAC/B,CAAC;QAEF,IAAK,SAAiB,CAAC,aAAa,EAAE;YAClC,IAAM,gBAAc,GAAI,SAAiB,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;YAE9D,IAAM,MAAM,GAAG,UAAC,QAAgB;gBAC5B,IAAM,KAAK,GAAG,gBAAc,CAAC,SAAS,CAAC,UAAC,EAAQ;wBAAN,cAAI;oBAAO,OAAA,IAAI,KAAK,QAAQ;gBAAjB,CAAiB,CAAC,CAAC;gBACxE,IAAM,CAAC,GAAoB,EAAE,KAAK,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC;gBAEpE,IAAI,QAAQ,KAAK,KAAK,IAAI,KAAK,GAAG,CAAC,CAAC,EAAE;oBAClC,CAAC,CAAC,KAAK,GAAG,gBAAc,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC;oBACtC,OAAO,CAAC,CAAC;iBACZ;qBAAM,IAAI,QAAQ,KAAK,KAAK,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE;oBAC3C,OAAO,CAAC,CAAC;iBACZ;gBAED,CAAC,CAAC,KAAK,GAAG,gBAAc,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC;gBACtC,CAAC,CAAC,OAAO,GAAG,gBAAc,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,gBAAc,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;gBAC7E,CAAC,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;gBAC3C,OAAO,CAAC,CAAC;YACb,CAAC,CAAC;;gBAEF,KAAmB,IAAA,UAAA,SAAA,KAAK,CAAA,4BAAA,+CAAE;oBAArB,IAAM,IAAI,kBAAA;oBACX,MAAM,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;iBAC/B;;;;;;;;;SACJ;aAAM;;gBACH,KAAmB,IAAA,UAAA,SAAA,KAAK,CAAA,4BAAA,+CAAE;oBAArB,IAAM,IAAI,kBAAA;oBACX,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC;iBAC3D;;;;;;;;;SACJ;QACD,OAAO,MAAM,CAAC;IAClB,CAAC;IAEO,wCAAqB,GAA7B,UAA8B,IAAU,EAAE,IAAY,EAAE,KAAa;QACjE,OAAO;YACH,IAAI,MAAA;YACJ,cAAc,EAAE,IAAI,CAAC,WAAW,EAAE,KAAK,IAAI,IAAI,IAAI,CAAC,QAAQ,EAAE,KAAK,KAAK;YACxE,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC;YAChD,WAAW,EAAE,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC;SACvD,CAAC;IACN,CAAC;IAEO,kCAAe,GAAvB,UAAwB,IAAU,EAAE,IAAY,EAAE,KAAa;QAC3D,IAAI,IAAI,CAAC,WAAW,EAAE,KAAK,IAAI,EAAE;YAC7B,OAAO,IAAI,CAAC,QAAQ,EAAE,GAAG,KAAK,CAAC;SAClC;QACD,OAAO,IAAI,CAAC,WAAW,EAAE,GAAG,IAAI,CAAC;IACrC,CAAC;IAEO,8BAAW,GAAnB,UAAoB,IAAU,EAAE,IAAY,EAAE,KAAa;QACvD,IAAI,IAAI,CAAC,WAAW,EAAE,KAAK,IAAI,EAAE;YAC7B,OAAO,IAAI,CAAC,QAAQ,EAAE,GAAG,KAAK,CAAC;SAClC;QAED,OAAO,IAAI,CAAC,WAAW,EAAE,GAAG,IAAI,CAAC;IACrC,CAAC;IACL,eAAC;AAAD,CAAC,AAxMD,IAwMC","sourcesContent":["import { DateRangeDescriptor, DateRangeType } from '../core/dates';\n\nconst MDAYS = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];\nconst FEBRUARY = 1;\n\nexport function range(start = 0, stop, step = 1) {\n    const res = [];\n    const cur = (stop === undefined) ? 0 : start;\n    const max = (stop === undefined) ? start : stop;\n    for (let i = cur; step < 0 ? i > max : i < max; i += step) {\n        res.push(i);\n    }\n    return res;\n}\n\n/**\n * Returns true for leap years, false for non-leap years.\n *\n * @export\n * @param year\n * @returns\n */\nexport function isLeap(year: number): boolean {\n    return (year % 4 === 0) && ((year % 100 !== 0) || (year % 400 === 0));\n}\n\nexport function weekDay(year: number, month: number, day: number): number {\n    return new Date(year, month, day).getDay();\n}\n\n/**\n * Return weekday and number of days for year, month.\n *\n * @export\n * @param year\n * @param month\n * @returns\n */\nexport function monthRange(year: number, month: number): number[] {\n    if ((month < 0) || (month > 11)) {\n        throw new Error('Invalid month specified');\n    }\n    const day = weekDay(year, month, 1);\n    let nDays = MDAYS[month];\n    if ((month === FEBRUARY) && (isLeap(year))) {\n        nDays++;\n    }\n    return [day, nDays];\n}\n\nexport function isDateInRanges(date: Date, ranges: DateRangeDescriptor[]): boolean {\n    date = new Date(date.getFullYear(), date.getMonth(), date.getDate());\n    const dateInMs = date.getTime();\n\n    if (!ranges) {\n        return false;\n    }\n\n    for (const descriptor of ranges) {\n        const dRanges = descriptor.dateRange ? descriptor.dateRange.map(\n            r => new Date(r.getFullYear(), r.getMonth(), r.getDate())) : undefined;\n        switch (descriptor.type) {\n            case (DateRangeType.After):\n                if (dateInMs > dRanges[0].getTime()) {\n                    return true;\n                }\n\n                break;\n            case (DateRangeType.Before):\n                if (dateInMs < dRanges[0].getTime()) {\n                    return true;\n                }\n\n                break;\n            case (DateRangeType.Between):\n                const dRange = dRanges.map(d => d.getTime());\n                const min = Math.min(dRange[0], dRange[1]);\n                const max = Math.max(dRange[0], dRange[1]);\n                if (dateInMs >= min && dateInMs <= max) {\n                    return true;\n                }\n\n                break;\n            case (DateRangeType.Specific):\n                const datesInMs = dRanges.map(d => d.getTime());\n                for (const specificDateInMs of datesInMs) {\n                    if (dateInMs === specificDateInMs) {\n                        return true;\n                    }\n                }\n\n                break;\n            case (DateRangeType.Weekdays):\n                const day = date.getDay();\n                if (day % 6 !== 0) {\n                    return true;\n                }\n\n                break;\n            case (DateRangeType.Weekends):\n                const weekday = date.getDay();\n                if (weekday % 6 === 0) {\n                    return true;\n                }\n\n                break;\n            default:\n                return false;\n        }\n    }\n\n    return false;\n}\n\nexport interface ICalendarDate {\n    date: Date;\n    isCurrentMonth: boolean;\n    isPrevMonth: boolean;\n    isNextMonth: boolean;\n}\n\nexport interface IFormattedParts {\n    value: string;\n    literal?: string;\n    combined: string;\n}\n\nexport interface IFormattingOptions {\n    day?: string;\n    month?: string;\n    weekday?: string;\n    year?: string;\n}\n\n\nexport interface IFormattingViews {\n    day?: boolean;\n    month?: boolean;\n    year?: boolean;\n}\n\nexport enum WEEKDAYS {\n    SUNDAY = 0,\n    MONDAY = 1,\n    TUESDAY = 2,\n    WEDNESDAY = 3,\n    THURSDAY = 4,\n    FRIDAY = 5,\n    SATURDAY = 6\n}\n\nexport class Calendar {\n\n    private _firstWeekDay: number | WEEKDAYS;\n\n    constructor(firstWeekDay: number | WEEKDAYS = WEEKDAYS.SUNDAY) {\n        this._firstWeekDay = firstWeekDay;\n    }\n\n    public get firstWeekDay(): number {\n        return this._firstWeekDay % 7;\n    }\n\n    public set firstWeekDay(value: number) {\n        this._firstWeekDay = value;\n    }\n\n    /**\n     * Returns an array of weekdays for one week starting\n     * with the currently set `firstWeekDay`\n     *\n     * this.firstWeekDay = 0 (Sunday) --> [0, 1, 2, 3, 4, 5, 6]\n     * this.firstWeekDay = 1 (Monday) --> [1, 2, 3, 4, 5, 6, 0]\n     *\n     * @returns\n     *\n     * @memberof Calendar\n     */\n    public weekdays(): number[] {\n        const res = [];\n        for (const i of range(this.firstWeekDay, this.firstWeekDay + 7)) {\n            res.push(i % 7);\n        }\n        return res;\n    }\n\n    /**\n     * Returns the date values for one month. It will always iterate throught\n     * complete weeks, so it will contain dates outside the specified month.\n     *\n     * @param year\n     * @param month\n     * @param boolean\n     * @returns\n     *\n     * @memberof Calendar\n     */\n    public monthdates(year: number, month: number, extraWeek: boolean = false): ICalendarDate[] {\n        let date = new Date(year, month, 1);\n        let days = (date.getDay() - this.firstWeekDay) % 7;\n        if (days < 0) {\n            days = 7 - Math.abs(days);\n        }\n        date = this.timedelta(date, 'day', -days);\n        const res = [];\n        let value: ICalendarDate;\n\n        while (true) {\n\n            value = this.generateICalendarDate(date, year, month);\n            res.push(value);\n\n            date = this.timedelta(date, 'day', 1);\n\n            if ((date.getMonth() !== month) && (date.getDay() === this.firstWeekDay)) {\n                if (extraWeek && res.length <= 35) {\n                    for (const _ of range(0, 7)) {\n                        value = this.generateICalendarDate(date, year, month);\n                        res.push(value);\n                        date = this.timedelta(date, 'day', 1);\n                    }\n                }\n                break;\n            }\n        }\n        return res;\n    }\n\n    /**\n     * Returns a matrix (array of arrays) representing a month's calendar.\n     * Each row represents a full week; week entries are ICalendarDate objects.\n     *\n     * @param year\n     * @param month\n     * @returns\n     *\n     * @memberof Calendar\n     */\n    public monthdatescalendar(year: number, month: number, extraWeek: boolean = false): ICalendarDate[][] {\n        const dates = this.monthdates(year, month, extraWeek);\n        const res = [];\n        for (const i of range(0, dates.length, 7)) {\n            res.push(dates.slice(i, i + 7));\n        }\n        return res;\n    }\n\n    public timedelta(date: Date, interval: string, units: number): Date {\n        const ret = new Date(date);\n\n        const checkRollover = () => {\n            if (ret.getDate() !== date.getDate()) {\n                ret.setDate(0);\n            }\n        };\n\n        switch (interval.toLowerCase()) {\n            case 'year':\n                ret.setFullYear(ret.getFullYear() + units);\n                checkRollover();\n                break;\n            case 'quarter':\n                ret.setMonth(ret.getMonth() + 3 * units);\n                checkRollover();\n                break;\n            case 'month':\n                ret.setMonth(ret.getMonth() + units);\n                checkRollover();\n                break;\n            case 'week':\n                ret.setDate(ret.getDate() + 7 * units);\n                break;\n            case 'day':\n                ret.setDate(ret.getDate() + units);\n                break;\n            case 'hour':\n                ret.setTime(ret.getTime() + units * 3600000);\n                break;\n            case 'minute':\n                ret.setTime(ret.getTime() + units * 60000);\n                break;\n            case 'second':\n                ret.setTime(ret.getTime() + units * 1000);\n                break;\n            default:\n                throw new Error('Invalid interval specifier');\n        }\n        return ret;\n    }\n\n    public formatToParts(date: Date, locale: string, options: any, parts: string[]) {\n        const formatter = new Intl.DateTimeFormat(locale, options);\n        const result = {\n            date,\n            full: formatter.format(date)\n        };\n\n        if ((formatter as any).formatToParts) {\n            const formattedParts = (formatter as any).formatToParts(date);\n\n            const toType = (partType: string) => {\n                const index = formattedParts.findIndex(({ type }) => type === partType);\n                const o: IFormattedParts = { value: '', literal: '', combined: '' };\n\n                if (partType === 'era' && index > -1) {\n                    o.value = formattedParts[index].value;\n                    return o;\n                } else if (partType === 'era' && index === -1) {\n                    return o;\n                }\n\n                o.value = formattedParts[index].value;\n                o.literal = formattedParts[index + 1] ? formattedParts[index + 1].value : '';\n                o.combined = [o.value, o.literal].join('');\n                return o;\n            };\n\n            for (const each of parts) {\n                result[each] = toType(each);\n            }\n        } else {\n            for (const each of parts) {\n                result[each] = { value: '', literal: '', combined: '' };\n            }\n        }\n        return result;\n    }\n\n    private generateICalendarDate(date: Date, year: number, month: number): ICalendarDate {\n        return {\n            date,\n            isCurrentMonth: date.getFullYear() === year && date.getMonth() === month,\n            isNextMonth: this.isNextMonth(date, year, month),\n            isPrevMonth: this.isPreviousMonth(date, year, month)\n        };\n    }\n\n    private isPreviousMonth(date: Date, year: number, month: number): boolean {\n        if (date.getFullYear() === year) {\n            return date.getMonth() < month;\n        }\n        return date.getFullYear() < year;\n    }\n\n    private isNextMonth(date: Date, year: number, month: number): boolean {\n        if (date.getFullYear() === year) {\n            return date.getMonth() > month;\n        }\n\n        return date.getFullYear() > year;\n    }\n}\n"]}