UNPKG

@taiga-ui/cdk

Version:

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

84 lines 11 kB
/// <reference types="@taiga-ui/tsconfig/ng-dev-mode" /> import { DATE_FILLER_LENGTH, DATE_RANGE_FILLER_LENGTH } from './date-fillers'; import { RANGE_SEPARATOR_CHAR } from './date-time'; import { TuiDay } from './day'; import { TuiMonthRange } from './month-range'; /** * An immutable range of two {@link TuiDay} objects */ export class TuiDayRange extends TuiMonthRange { constructor(from, to) { super(from, to); this.from = from; this.to = to; ngDevMode && console.assert(from.daySameOrBefore(to)); } /** * Creates range from two days after sorting them * * @param day1 * @param day2 * @return new range with sorted days */ static sort(day1, day2) { return day1.daySameOrBefore(day2) ? new TuiDayRange(day1, day2) : new TuiDayRange(day2, day1); } /** * Parse and correct a day range in string format * * @param rangeString a string of dates in a format dd.mm.yyyy - dd.mm.yyyy * @param dateMode {@link TuiDateMode} * @return normalized day range object */ static normalizeParse(rangeString, dateMode = 'DMY') { const leftDay = TuiDay.normalizeParse(rangeString.slice(0, DATE_FILLER_LENGTH), dateMode); if (rangeString.length < DATE_RANGE_FILLER_LENGTH) { return new TuiDayRange(leftDay, leftDay); } return TuiDayRange.sort(leftDay, TuiDay.normalizeParse(rangeString.slice(DATE_FILLER_LENGTH + RANGE_SEPARATOR_CHAR.length), dateMode)); } get isSingleDay() { return this.from.daySame(this.to); } /** * Tests ranges for identity * * @param another second range to test against current * @return `true` if days are identical */ daySame(another) { return this.from.daySame(another.from) && this.to.daySame(another.to); } /** * Locks range between two days included, or limits from one side if the other is null * * @param min * @param max * @return range — clamped range */ dayLimit(min, max) { return new TuiDayRange(this.from.dayLimit(min, max), this.to.dayLimit(min, max)); } /** * Human readable format. */ getFormattedDayRange(dateFormat, dateSeparator) { const from = this.from.getFormattedDay(dateFormat, dateSeparator); const to = this.to.getFormattedDay(dateFormat, dateSeparator); return `${from}${RANGE_SEPARATOR_CHAR}${to}`; } toString(dateFormat = 'DMY', dateSeparator = '.') { return this.getFormattedDayRange(dateFormat, dateSeparator); } toArray() { const { from, to } = this; const arr = []; for (const day = from.toUtcNativeDate(); day <= to.toUtcNativeDate(); day.setDate(day.getDate() + 1)) { arr.push(TuiDay.fromLocalNativeDate(day)); } return arr; } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"day-range.js","sourceRoot":"","sources":["../../../../projects/cdk/date-time/day-range.ts"],"names":[],"mappings":"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","sourcesContent":["/// <reference types=\"@taiga-ui/tsconfig/ng-dev-mode\" />\n\nimport {DATE_FILLER_LENGTH, DATE_RANGE_FILLER_LENGTH} from './date-fillers';\nimport {RANGE_SEPARATOR_CHAR} from './date-time';\nimport {TuiDay} from './day';\nimport {TuiMonthRange} from './month-range';\nimport type {TuiDateMode} from './types';\n\n/**\n * An immutable range of two {@link TuiDay} objects\n */\nexport class TuiDayRange extends TuiMonthRange {\n    constructor(\n        public override readonly from: TuiDay,\n        public override readonly to: TuiDay,\n    ) {\n        super(from, to);\n\n        ngDevMode && console.assert(from.daySameOrBefore(to));\n    }\n\n    /**\n     * Creates range from two days after sorting them\n     *\n     * @param day1\n     * @param day2\n     * @return new range with sorted days\n     */\n    public static override sort(day1: TuiDay, day2: TuiDay): TuiDayRange {\n        return day1.daySameOrBefore(day2)\n            ? new TuiDayRange(day1, day2)\n            : new TuiDayRange(day2, day1);\n    }\n\n    /**\n     * Parse and correct a day range in string format\n     *\n     * @param rangeString a string of dates in a format dd.mm.yyyy - dd.mm.yyyy\n     * @param dateMode {@link TuiDateMode}\n     * @return normalized day range object\n     */\n    public static normalizeParse(\n        rangeString: string,\n        dateMode: TuiDateMode = 'DMY',\n    ): TuiDayRange {\n        const leftDay = TuiDay.normalizeParse(\n            rangeString.slice(0, DATE_FILLER_LENGTH),\n            dateMode,\n        );\n\n        if (rangeString.length < DATE_RANGE_FILLER_LENGTH) {\n            return new TuiDayRange(leftDay, leftDay);\n        }\n\n        return TuiDayRange.sort(\n            leftDay,\n            TuiDay.normalizeParse(\n                rangeString.slice(DATE_FILLER_LENGTH + RANGE_SEPARATOR_CHAR.length),\n                dateMode,\n            ),\n        );\n    }\n\n    public get isSingleDay(): boolean {\n        return this.from.daySame(this.to);\n    }\n\n    /**\n     * Tests ranges for identity\n     *\n     * @param another second range to test against current\n     * @return `true` if days are identical\n     */\n    public daySame(another: TuiDayRange): boolean {\n        return this.from.daySame(another.from) && this.to.daySame(another.to);\n    }\n\n    /**\n     * Locks range between two days included, or limits from one side if the other is null\n     *\n     * @param min\n     * @param max\n     * @return range — clamped range\n     */\n    public dayLimit(min: TuiDay | null, max: TuiDay | null): TuiDayRange {\n        return new TuiDayRange(this.from.dayLimit(min, max), this.to.dayLimit(min, max));\n    }\n\n    /**\n     * Human readable format.\n     */\n    public getFormattedDayRange(dateFormat: TuiDateMode, dateSeparator: string): string {\n        const from = this.from.getFormattedDay(dateFormat, dateSeparator);\n        const to = this.to.getFormattedDay(dateFormat, dateSeparator);\n\n        return `${from}${RANGE_SEPARATOR_CHAR}${to}`;\n    }\n\n    public override toString(\n        dateFormat: TuiDateMode = 'DMY',\n        dateSeparator = '.',\n    ): string {\n        return this.getFormattedDayRange(dateFormat, dateSeparator);\n    }\n\n    public toArray(): readonly TuiDay[] {\n        const {from, to} = this;\n        const arr = [];\n\n        for (\n            const day = from.toUtcNativeDate();\n            day <= to.toUtcNativeDate();\n            day.setDate(day.getDate() + 1)\n        ) {\n            arr.push(TuiDay.fromLocalNativeDate(day));\n        }\n\n        return arr;\n    }\n}\n"]}