UNPKG

@catull/igniteui-angular

Version:

Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps

376 lines 40.5 kB
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":"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","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"]}