UNPKG

@taiga-ui/cdk

Version:

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

111 lines 11.8 kB
/// <reference types="@taiga-ui/tsconfig/ng-dev-mode" /> import { tuiInRange, tuiNormalizeToIntNumber } from '@taiga-ui/cdk/utils/math'; import { MAX_YEAR, MIN_YEAR } from './date-time'; /** * Immutable year object * @nosideeffects */ export class TuiYear { constructor(year) { this.year = year; ngDevMode && console.assert(TuiYear.isValidYear(year)); } /** * Checks year for validity */ static isValidYear(year) { return Number.isInteger(year) && tuiInRange(year, MIN_YEAR, MAX_YEAR + 1); } /** * Check if passed year is a leap year */ static isLeapYear(year) { ngDevMode && console.assert(TuiYear.isValidYear(year)); return year % 400 === 0 || (year % 4 === 0 && year % 100 !== 0); } /** * Returns amount of leap years from year 0 to the passed one */ static getAbsoluteLeapYears(year) { ngDevMode && console.assert(TuiYear.isValidYear(year)); return Math.ceil(year / 400) + (Math.ceil(year / 4) - Math.ceil(year / 100)); } static lengthBetween(from, to) { return to.year - from.year; } /** * Normalizes year by clamping it between min and max years */ static normalizeYearPart(year) { return tuiNormalizeToIntNumber(year, MIN_YEAR, MAX_YEAR); } get formattedYear() { return String(this.year).padStart(4, '0'); } get isLeapYear() { return TuiYear.isLeapYear(this.year); } /** * Returns amount of leap years from year 0 to current */ get absoluteLeapYears() { return TuiYear.getAbsoluteLeapYears(this.year); } /** * Passed year is after current */ yearBefore({ year }) { return this.year < year; } /** * Passed year is the same or after current */ yearSameOrBefore({ year }) { return this.year <= year; } /** * Passed year is the same as current */ yearSame({ year }) { return this.year === year; } /** * Passed year is either the same of before the current */ yearSameOrAfter({ year }) { return this.year >= year; } /** * Passed year is before current */ yearAfter({ year }) { return this.year > year; } /** * Immutably offsets year */ append({ year = 0 }) { ngDevMode && console.assert(Number.isInteger(year)); const resultYear = this.year + year; ngDevMode && console.assert(TuiYear.isValidYear(resultYear)); return new TuiYear(resultYear); } toString() { return this.formattedYear; } valueOf() { return this.year; } /** * Returns the primitive value of the given Date object. * Depending on the argument, the method can return either a string or a number. * @see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/@@toPrimitive */ [Symbol.toPrimitive](hint) { return Date.prototype[Symbol.toPrimitive].call(this, hint); } toJSON() { return this.formattedYear; } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"year.js","sourceRoot":"","sources":["../../../../projects/cdk/date-time/year.ts"],"names":[],"mappings":"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","sourcesContent":["/// <reference types=\"@taiga-ui/tsconfig/ng-dev-mode\" />\nimport {tuiInRange, tuiNormalizeToIntNumber} from '@taiga-ui/cdk/utils/math';\n\nimport {MAX_YEAR, MIN_YEAR} from './date-time';\nimport type {TuiYearLike} from './types';\n\n/**\n * Immutable year object\n * @nosideeffects\n */\nexport class TuiYear implements TuiYearLike {\n    constructor(public readonly year: number) {\n        ngDevMode && console.assert(TuiYear.isValidYear(year));\n    }\n\n    /**\n     * Checks year for validity\n     */\n    public static isValidYear(year: number): boolean {\n        return Number.isInteger(year) && tuiInRange(year, MIN_YEAR, MAX_YEAR + 1);\n    }\n\n    /**\n     * Check if passed year is a leap year\n     */\n    public static isLeapYear(year: number): boolean {\n        ngDevMode && console.assert(TuiYear.isValidYear(year));\n\n        return year % 400 === 0 || (year % 4 === 0 && year % 100 !== 0);\n    }\n\n    /**\n     * Returns amount of leap years from year 0 to the passed one\n     */\n    public static getAbsoluteLeapYears(year: number): number {\n        ngDevMode && console.assert(TuiYear.isValidYear(year));\n\n        return Math.ceil(year / 400) + (Math.ceil(year / 4) - Math.ceil(year / 100));\n    }\n\n    public static lengthBetween(from: TuiYear, to: TuiYear): number {\n        return to.year - from.year;\n    }\n\n    /**\n     * Normalizes year by clamping it between min and max years\n     */\n    public static normalizeYearPart(year: number): number {\n        return tuiNormalizeToIntNumber(year, MIN_YEAR, MAX_YEAR);\n    }\n\n    public get formattedYear(): string {\n        return String(this.year).padStart(4, '0');\n    }\n\n    public get isLeapYear(): boolean {\n        return TuiYear.isLeapYear(this.year);\n    }\n\n    /**\n     * Returns amount of leap years from year 0 to current\n     */\n    public get absoluteLeapYears(): number {\n        return TuiYear.getAbsoluteLeapYears(this.year);\n    }\n\n    /**\n     * Passed year is after current\n     */\n    public yearBefore({year}: TuiYear): boolean {\n        return this.year < year;\n    }\n\n    /**\n     * Passed year is the same or after current\n     */\n    public yearSameOrBefore({year}: TuiYear): boolean {\n        return this.year <= year;\n    }\n\n    /**\n     * Passed year is the same as current\n     */\n    public yearSame({year}: TuiYear): boolean {\n        return this.year === year;\n    }\n\n    /**\n     * Passed year is either the same of before the current\n     */\n    public yearSameOrAfter({year}: TuiYear): boolean {\n        return this.year >= year;\n    }\n\n    /**\n     * Passed year is before current\n     */\n    public yearAfter({year}: TuiYear): boolean {\n        return this.year > year;\n    }\n\n    /**\n     * Immutably offsets year\n     */\n    public append({year = 0}: TuiYearLike): TuiYear {\n        ngDevMode && console.assert(Number.isInteger(year));\n\n        const resultYear = this.year + year;\n\n        ngDevMode && console.assert(TuiYear.isValidYear(resultYear));\n\n        return new TuiYear(resultYear);\n    }\n\n    public toString(): string {\n        return this.formattedYear;\n    }\n\n    public valueOf(): number {\n        return this.year;\n    }\n\n    /**\n     * Returns the primitive value of the given Date object.\n     * Depending on the argument, the method can return either a string or a number.\n     * @see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/@@toPrimitive\n     */\n    public [Symbol.toPrimitive](hint: string): number | string {\n        return Date.prototype[Symbol.toPrimitive].call(this, hint);\n    }\n\n    public toJSON(): string {\n        return this.formattedYear;\n    }\n}\n"]}