UNPKG

@taiga-ui/cdk

Version:

Base library for creating Angular components and applications using Taiga UI principles regarding of actual visual appearance

149 lines • 17.3 kB
/// <reference types="@taiga-ui/tsconfig/ng-dev-mode" /> import { tuiInRange, tuiNormalizeToIntNumber } from '@taiga-ui/cdk/utils/math'; import { MAX_MONTH, MIN_MONTH, MONTHS_IN_YEAR } from './date-time'; import { TuiMonthNumber } from './month-number'; import { TuiYear } from './year'; /** * Immutable object consisting of year and month */ export class TuiMonth extends TuiYear { /** * @param year * @param month (starting with 0) */ constructor(year, month) { super(year); this.month = month; ngDevMode && console.assert(TuiMonth.isValidMonth(year, month)); } /** * Tests month and year for validity */ static isValidMonth(year, month) { return TuiYear.isValidYear(year) && TuiMonth.isValidMonthPart(month); } /** * Returns number of days in a month */ static getMonthDaysCount(month, isLeapYear) { ngDevMode && console.assert(TuiMonth.isValidMonthPart(month)); switch (month) { case TuiMonthNumber.April: case TuiMonthNumber.June: case TuiMonthNumber.November: case TuiMonthNumber.September: return 30; case TuiMonthNumber.February: return isLeapYear ? 29 : 28; default: return 31; } } /** * Returns current month and year based on local time zone * @nosideeffects */ static currentLocal() { const nativeDate = new Date(); return new TuiMonth(nativeDate.getFullYear(), nativeDate.getMonth()); } /** * Returns current month and year based on UTC */ static currentUtc() { const nativeDate = new Date(); return new TuiMonth(nativeDate.getUTCFullYear(), nativeDate.getUTCMonth()); } static lengthBetween(from, to) { const absoluteFrom = from.month + from.year * 12; const absoluteTo = to.month + to.year * 12; return absoluteTo - absoluteFrom; } /** * Normalizes number by clamping it between min and max month */ static normalizeMonthPart(month) { return tuiNormalizeToIntNumber(month, MIN_MONTH, MAX_MONTH); } /** * Tests month for validity */ static isValidMonthPart(month) { return Number.isInteger(month) && tuiInRange(month, MIN_MONTH, MAX_MONTH + 1); } get formattedMonthPart() { return String(this.month + 1).padStart(2, '0'); } /** * Returns days in a month */ get daysCount() { return TuiMonth.getMonthDaysCount(this.month, this.isLeapYear); } /** * Passed month and year are after current */ monthBefore(another) { return (this.yearBefore(another) || (this.yearSame(another) && this.month < another.month)); } /** * Passed month and year are after or the same as current */ monthSameOrBefore(another) { return (this.yearBefore(another) || (this.yearSame(another) && this.month <= another.month)); } /** * Passed month and year are the same as current */ monthSame(another) { return this.yearSame(another) && this.month === another.month; } /** * Passed month and year are either before or equal to current */ monthSameOrAfter(another) { return (this.yearAfter(another) || (this.yearSame(another) && this.month >= another.month)); } /** * Passed month and year are before current */ monthAfter(another) { return (this.yearAfter(another) || (this.yearSame(another) && this.month > another.month)); } /** * Immutably alters current month and year by passed offset * * @param offset * @return new month and year object as a result of offsetting current */ append({ year = 0, month = 0 }) { const totalMonths = (this.year + year) * MONTHS_IN_YEAR + this.month + month; return new TuiMonth(Math.floor(totalMonths / MONTHS_IN_YEAR), totalMonths % MONTHS_IN_YEAR); } toString() { return `${this.formattedMonthPart}.${this.formattedYear}`; } valueOf() { return this.toLocalNativeDate().valueOf(); } toJSON() { return `${super.toJSON()}-${this.formattedMonthPart}`; } /** * Returns native {@link Date} based on local time zone */ toLocalNativeDate() { return new Date(this.year, this.month); } /** * Returns native {@link Date} based on UTC */ toUtcNativeDate() { return new Date(Date.UTC(this.year, this.month)); } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"month.js","sourceRoot":"","sources":["../../../../projects/cdk/date-time/month.ts"],"names":[],"mappings":"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","sourcesContent":["/// <reference types=\"@taiga-ui/tsconfig/ng-dev-mode\" />\n\nimport {tuiInRange, tuiNormalizeToIntNumber} from '@taiga-ui/cdk/utils/math';\n\nimport {MAX_MONTH, MIN_MONTH, MONTHS_IN_YEAR} from './date-time';\nimport {TuiMonthNumber} from './month-number';\nimport type {TuiMonthLike} from './types';\nimport {TuiYear} from './year';\n\n/**\n * Immutable object consisting of year and month\n */\nexport class TuiMonth extends TuiYear implements TuiMonthLike {\n    /**\n     * @param year\n     * @param month (starting with 0)\n     */\n    constructor(\n        year: number,\n        public readonly month: number,\n    ) {\n        super(year);\n        ngDevMode && console.assert(TuiMonth.isValidMonth(year, month));\n    }\n\n    /**\n     * Tests month and year for validity\n     */\n    public static isValidMonth(year: number, month: number): boolean {\n        return TuiYear.isValidYear(year) && TuiMonth.isValidMonthPart(month);\n    }\n\n    /**\n     * Returns number of days in a month\n     */\n    public static getMonthDaysCount(month: number, isLeapYear: boolean): number {\n        ngDevMode && console.assert(TuiMonth.isValidMonthPart(month));\n\n        switch (month) {\n            case TuiMonthNumber.April:\n            case TuiMonthNumber.June:\n            case TuiMonthNumber.November:\n            case TuiMonthNumber.September:\n                return 30;\n            case TuiMonthNumber.February:\n                return isLeapYear ? 29 : 28;\n            default:\n                return 31;\n        }\n    }\n\n    /**\n     * Returns current month and year based on local time zone\n     * @nosideeffects\n     */\n    public static currentLocal(): TuiMonth {\n        const nativeDate = new Date();\n\n        return new TuiMonth(nativeDate.getFullYear(), nativeDate.getMonth());\n    }\n\n    /**\n     * Returns current month and year based on UTC\n     */\n    public static currentUtc(): TuiMonth {\n        const nativeDate = new Date();\n\n        return new TuiMonth(nativeDate.getUTCFullYear(), nativeDate.getUTCMonth());\n    }\n\n    public static override lengthBetween(from: TuiMonth, to: TuiMonth): number {\n        const absoluteFrom = from.month + from.year * 12;\n        const absoluteTo = to.month + to.year * 12;\n\n        return absoluteTo - absoluteFrom;\n    }\n\n    /**\n     * Normalizes number by clamping it between min and max month\n     */\n    public static normalizeMonthPart(month: number): number {\n        return tuiNormalizeToIntNumber(month, MIN_MONTH, MAX_MONTH);\n    }\n\n    /**\n     * Tests month for validity\n     */\n    private static isValidMonthPart(month: number): boolean {\n        return Number.isInteger(month) && tuiInRange(month, MIN_MONTH, MAX_MONTH + 1);\n    }\n\n    public get formattedMonthPart(): string {\n        return String(this.month + 1).padStart(2, '0');\n    }\n\n    /**\n     * Returns days in a month\n     */\n    public get daysCount(): number {\n        return TuiMonth.getMonthDaysCount(this.month, this.isLeapYear);\n    }\n\n    /**\n     * Passed month and year are after current\n     */\n    public monthBefore(another: TuiMonth): boolean {\n        return (\n            this.yearBefore(another) ||\n            (this.yearSame(another) && this.month < another.month)\n        );\n    }\n\n    /**\n     * Passed month and year are after or the same as current\n     */\n    public monthSameOrBefore(another: TuiMonth): boolean {\n        return (\n            this.yearBefore(another) ||\n            (this.yearSame(another) && this.month <= another.month)\n        );\n    }\n\n    /**\n     * Passed month and year are the same as current\n     */\n    public monthSame(another: TuiMonth): boolean {\n        return this.yearSame(another) && this.month === another.month;\n    }\n\n    /**\n     * Passed month and year are either before or equal to current\n     */\n    public monthSameOrAfter(another: TuiMonth): boolean {\n        return (\n            this.yearAfter(another) ||\n            (this.yearSame(another) && this.month >= another.month)\n        );\n    }\n\n    /**\n     * Passed month and year are before current\n     */\n    public monthAfter(another: TuiMonth): boolean {\n        return (\n            this.yearAfter(another) ||\n            (this.yearSame(another) && this.month > another.month)\n        );\n    }\n\n    /**\n     * Immutably alters current month and year by passed offset\n     *\n     * @param offset\n     * @return new month and year object as a result of offsetting current\n     */\n    public override append({year = 0, month = 0}: TuiMonthLike): TuiMonth {\n        const totalMonths = (this.year + year) * MONTHS_IN_YEAR + this.month + month;\n\n        return new TuiMonth(\n            Math.floor(totalMonths / MONTHS_IN_YEAR),\n            totalMonths % MONTHS_IN_YEAR,\n        );\n    }\n\n    public override toString(): string {\n        return `${this.formattedMonthPart}.${this.formattedYear}`;\n    }\n\n    public override valueOf(): number {\n        return this.toLocalNativeDate().valueOf();\n    }\n\n    public override toJSON(): string {\n        return `${super.toJSON()}-${this.formattedMonthPart}`;\n    }\n\n    /**\n     * Returns native {@link Date} based on local time zone\n     */\n    public toLocalNativeDate(): Date {\n        return new Date(this.year, this.month);\n    }\n\n    /**\n     * Returns native {@link Date} based on UTC\n     */\n    public toUtcNativeDate(): Date {\n        return new Date(Date.UTC(this.year, this.month));\n    }\n}\n"]}