@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
JavaScript
/// <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"]}