@taiga-ui/kit
Version:
Taiga UI Angular main components kit
269 lines • 35.1 kB
JavaScript
import { __decorate, __extends, __param, __read, __spread } from "tslib";
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, forwardRef, HostListener, Inject, Input, Optional, Self, ViewChild, } from '@angular/core';
import { NgControl } from '@angular/forms';
import { AbstractTuiControl, ALWAYS_FALSE_HANDLER, nullableSame, TUI_DATE_FILLER, TUI_FIRST_DAY, TUI_FOCUSABLE_ITEM_ACCESSOR, TUI_LAST_DAY, TuiDay, tuiDefaultProp, TuiMonth, tuiPure, TuiTime, } from '@taiga-ui/cdk';
import { sizeBigger, TUI_TEXTFIELD_SIZE, TuiPrimitiveTextfieldComponent, TuiTextfieldSizeDirective, TuiTextMaskOptions, TuiWithOptionalMinMax, } from '@taiga-ui/core';
import { DATE_TIME_SEPARATOR, TUI_DATE_MASK } from '@taiga-ui/kit/constants';
import { LEFT_ALIGNED_DROPDOWN_CONTROLLER_PROVIDER } from '@taiga-ui/kit/providers';
import { TUI_CALENDAR_DATA_STREAM, TUI_TIME_TEXTS } from '@taiga-ui/kit/tokens';
import { tuiCreateAutoCorrectedDateTimePipe, tuiCreateTimeMask, } from '@taiga-ui/kit/utils/mask';
import { TuiReplayControlValueChangesFactory } from '@taiga-ui/kit/utils/miscellaneous';
import { Observable } from 'rxjs';
import { map } from 'rxjs/operators';
var ɵ0 = TuiReplayControlValueChangesFactory;
// @dynamic
var TuiInputDateTimeComponent = /** @class */ (function (_super) {
__extends(TuiInputDateTimeComponent, _super);
function TuiInputDateTimeComponent(control, changeDetectorRef, textfieldSize, dateFiller, timeTexts$) {
var _this = _super.call(this, control, changeDetectorRef) || this;
_this.textfieldSize = textfieldSize;
_this.dateFiller = dateFiller;
_this.timeTexts$ = timeTexts$;
_this.min = TUI_FIRST_DAY;
_this.max = TUI_LAST_DAY;
_this.disabledItemHandler = ALWAYS_FALSE_HANDLER;
_this.defaultActiveYearMonth = TuiMonth.currentLocal();
_this.timeMode = 'HH:MM';
_this.open = false;
_this.month = null;
return _this;
}
TuiInputDateTimeComponent_1 = TuiInputDateTimeComponent;
Object.defineProperty(TuiInputDateTimeComponent.prototype, "fillerLength", {
get: function () {
return this.dateFiller.length + DATE_TIME_SEPARATOR.length + this.timeMode.length;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TuiInputDateTimeComponent.prototype, "textMaskOptions", {
get: function () {
return this.calculateMask(this.value[0], this.min, this.max, this.timeMode, this.dateFiller);
},
enumerable: true,
configurable: true
});
Object.defineProperty(TuiInputDateTimeComponent.prototype, "nativeFocusableElement", {
get: function () {
return this.textfield ? this.textfield.nativeFocusableElement : null;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TuiInputDateTimeComponent.prototype, "focused", {
get: function () {
return !!this.textfield && this.textfield.focused;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TuiInputDateTimeComponent.prototype, "calendarIcon", {
get: function () {
return sizeBigger(this.textfieldSize.size)
? 'tuiIconCalendarLarge'
: 'tuiIconCalendar';
},
enumerable: true,
configurable: true
});
Object.defineProperty(TuiInputDateTimeComponent.prototype, "computedValue", {
get: function () {
var _a = this, value = _a.value, nativeValue = _a.nativeValue, focused = _a.focused, touched = _a.touched;
var _b = __read(value, 2), date = _b[0], time = _b[1];
if ((date && !nativeValue) ||
(date && nativeValue.length === this.dateFiller.length) ||
(date && time)) {
return "" + date.toString() + DATE_TIME_SEPARATOR + (time ? time.toString(this.timeMode) : '');
}
if (touched || focused) {
return nativeValue;
}
return date !== null ? date.toString() : '';
},
enumerable: true,
configurable: true
});
Object.defineProperty(TuiInputDateTimeComponent.prototype, "calendarValue", {
get: function () {
return this.value[0];
},
enumerable: true,
configurable: true
});
Object.defineProperty(TuiInputDateTimeComponent.prototype, "computedActiveYearMonth", {
get: function () {
return this.month || this.value[0] || this.defaultActiveYearMonth;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TuiInputDateTimeComponent.prototype, "nativeValue", {
get: function () {
return this.nativeFocusableElement ? this.nativeFocusableElement.value : '';
},
set: function (value) {
if (!this.nativeFocusableElement) {
return;
}
this.nativeFocusableElement.value = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TuiInputDateTimeComponent.prototype, "canOpen", {
get: function () {
return !this.computedDisabled && !this.readOnly;
},
enumerable: true,
configurable: true
});
TuiInputDateTimeComponent.prototype.getFiller$ = function (dateFiller, timeMode) {
return this.timeTexts$.pipe(map(function (texts) { return "" + dateFiller + DATE_TIME_SEPARATOR + texts[timeMode]; }));
};
TuiInputDateTimeComponent.prototype.onClick = function () {
this.open = !this.open;
};
TuiInputDateTimeComponent.prototype.onValueChange = function (value) {
if (value.length < this.dateFiller.length) {
this.updateValue([null, null]);
return;
}
var _a = __read(value.split(DATE_TIME_SEPARATOR), 2), date = _a[0], time = _a[1];
var parsedDate = TuiDay.normalizeParse(date);
var parsedTime = time && time.length === this.timeMode.length
? TuiTime.fromString(time)
: null;
if (parsedDate !== null) {
this.open = false;
}
this.updateValue([parsedDate, parsedTime]);
};
TuiInputDateTimeComponent.prototype.onDayClick = function (day) {
this.updateValue([day, this.value[1]]);
this.open = false;
};
TuiInputDateTimeComponent.prototype.onHovered = function (hovered) {
this.updateHovered(hovered);
};
TuiInputDateTimeComponent.prototype.onMonthChange = function (month) {
this.month = month;
};
TuiInputDateTimeComponent.prototype.onOpenChange = function (open) {
this.open = open;
};
TuiInputDateTimeComponent.prototype.onFocused = function (focused) {
var _this = this;
this.updateFocused(focused);
if (focused ||
this.value[0] === null ||
this.value[1] !== null ||
this.nativeValue.length <= this.fillerLength + DATE_TIME_SEPARATOR.length ||
this.timeMode === 'HH:MM') {
return;
}
var _a = __read(this.nativeValue.split(DATE_TIME_SEPARATOR), 2), time = _a[1];
if (!time) {
return;
}
var parsedTime = TuiTime.fromString(time);
this.updateValue([this.value[0], parsedTime]);
setTimeout(function () {
if (_this.nativeValue.endsWith('.') || _this.nativeValue.endsWith(':')) {
_this.nativeValue = _this.nativeValue.slice(0, -1);
}
});
};
TuiInputDateTimeComponent.prototype.setDisabledState = function () {
_super.prototype.setDisabledState.call(this);
this.open = false;
};
TuiInputDateTimeComponent.prototype.writeValue = function (value) {
_super.prototype.writeValue.call(this, value);
this.nativeValue = value && (value[0] || value[1]) ? this.computedValue : '';
};
TuiInputDateTimeComponent.prototype.getFallbackValue = function () {
return [null, null];
};
TuiInputDateTimeComponent.prototype.valueIdenticalComparator = function (oldValue, newValue) {
return (nullableSame(oldValue[0], newValue[0], function (a, b) { return a.daySame(b); }) &&
nullableSame(oldValue[1], newValue[1], function (a, b) { return a.toString() === b.toString(); }));
};
TuiInputDateTimeComponent.prototype.calculateMask = function (day, min, max, timeMode, filler) {
return {
mask: __spread(TUI_DATE_MASK, [',', ' '], tuiCreateTimeMask(timeMode)),
pipe: tuiCreateAutoCorrectedDateTimePipe({ value: day, min: min, max: max, filler: filler }, timeMode),
guide: false,
};
};
var TuiInputDateTimeComponent_1;
TuiInputDateTimeComponent.ctorParameters = function () { return [
{ type: NgControl, decorators: [{ type: Optional }, { type: Self }, { type: Inject, args: [NgControl,] }] },
{ type: ChangeDetectorRef, decorators: [{ type: Inject, args: [ChangeDetectorRef,] }] },
{ type: TuiTextfieldSizeDirective, decorators: [{ type: Inject, args: [TUI_TEXTFIELD_SIZE,] }] },
{ type: String, decorators: [{ type: Inject, args: [TUI_DATE_FILLER,] }] },
{ type: Observable, decorators: [{ type: Inject, args: [TUI_TIME_TEXTS,] }] }
]; };
__decorate([
Input(),
tuiDefaultProp()
], TuiInputDateTimeComponent.prototype, "min", void 0);
__decorate([
Input(),
tuiDefaultProp()
], TuiInputDateTimeComponent.prototype, "max", void 0);
__decorate([
Input(),
tuiDefaultProp()
], TuiInputDateTimeComponent.prototype, "disabledItemHandler", void 0);
__decorate([
Input(),
tuiDefaultProp()
], TuiInputDateTimeComponent.prototype, "defaultActiveYearMonth", void 0);
__decorate([
Input(),
tuiDefaultProp()
], TuiInputDateTimeComponent.prototype, "timeMode", void 0);
__decorate([
ViewChild(TuiPrimitiveTextfieldComponent)
], TuiInputDateTimeComponent.prototype, "textfield", void 0);
__decorate([
tuiPure
], TuiInputDateTimeComponent.prototype, "getFiller$", null);
__decorate([
HostListener('click')
], TuiInputDateTimeComponent.prototype, "onClick", null);
__decorate([
tuiPure
], TuiInputDateTimeComponent.prototype, "calculateMask", null);
TuiInputDateTimeComponent = TuiInputDateTimeComponent_1 = __decorate([
Component({
selector: 'tui-input-date-time',
template: "<tui-hosted-dropdown\n class=\"hosted\"\n [canOpen]=\"canOpen\"\n [content]=\"dropdown\"\n [open]=\"open && canOpen\"\n (openChange)=\"onOpenChange($event)\"\n>\n <tui-primitive-textfield\n class=\"textfield\"\n tuiValueAccessor\n [pseudoFocused]=\"pseudoFocused\"\n [pseudoHovered]=\"pseudoHovered\"\n [invalid]=\"computedInvalid\"\n [filler]=\"getFiller$(dateFiller, timeMode) | async\"\n [nativeId]=\"nativeId\"\n [readOnly]=\"readOnly\"\n [iconContent]=\"calendarIcon\"\n [disabled]=\"disabled\"\n [textMask]=\"textMaskOptions\"\n [value]=\"computedValue\"\n (valueChange)=\"onValueChange($event)\"\n (hoveredChange)=\"onHovered($event)\"\n (focusedChange)=\"onFocused($event)\"\n >\n <ng-content></ng-content>\n </tui-primitive-textfield>\n\n <ng-template #dropdown=\"polymorpheus\" polymorpheus>\n <tui-calendar\n tuiPreventDefault=\"mousedown\"\n [min]=\"min\"\n [max]=\"max\"\n [disabledItemHandler]=\"disabledItemHandler\"\n [month]=\"computedActiveYearMonth\"\n [value]=\"calendarValue\"\n (dayClick)=\"onDayClick($event)\"\n (monthChange)=\"onMonthChange($event)\"\n ></tui-calendar>\n </ng-template>\n</tui-hosted-dropdown>\n",
changeDetection: ChangeDetectionStrategy.OnPush,
providers: [
{
provide: TUI_FOCUSABLE_ITEM_ACCESSOR,
useExisting: forwardRef(function () { return TuiInputDateTimeComponent_1; }),
},
{
provide: TUI_CALENDAR_DATA_STREAM,
deps: [[new Optional(), new Self(), NgControl]],
useFactory: ɵ0,
},
LEFT_ALIGNED_DROPDOWN_CONTROLLER_PROVIDER,
],
styles: [":host{display:block;border-radius:var(--tui-radius-m)}.hosted{display:block;border-radius:inherit}.textfield{border-radius:inherit}.icon{position:relative;cursor:pointer}.button{display:flex;height:44px;justify-content:center;box-shadow:inset 0 1px var(--tui-base-03)}"]
}),
__param(0, Optional()),
__param(0, Self()),
__param(0, Inject(NgControl)),
__param(1, Inject(ChangeDetectorRef)),
__param(2, Inject(TUI_TEXTFIELD_SIZE)),
__param(3, Inject(TUI_DATE_FILLER)),
__param(4, Inject(TUI_TIME_TEXTS))
], TuiInputDateTimeComponent);
return TuiInputDateTimeComponent;
}(AbstractTuiControl));
export { TuiInputDateTimeComponent };
export { ɵ0 };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date-time.component.js","sourceRoot":"ng://@taiga-ui/kit/components/input-date-time/","sources":["input-date-time.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    forwardRef,\n    HostListener,\n    Inject,\n    Input,\n    Optional,\n    Self,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {\n    AbstractTuiControl,\n    ALWAYS_FALSE_HANDLER,\n    nullableSame,\n    TUI_DATE_FILLER,\n    TUI_FIRST_DAY,\n    TUI_FOCUSABLE_ITEM_ACCESSOR,\n    TUI_LAST_DAY,\n    TuiBooleanHandler,\n    TuiDay,\n    tuiDefaultProp,\n    TuiFocusableElementAccessor,\n    TuiMonth,\n    tuiPure,\n    TuiTime,\n    TuiTimeMode,\n} from '@taiga-ui/cdk';\nimport {\n    sizeBigger,\n    TUI_TEXTFIELD_SIZE,\n    TuiPrimitiveTextfieldComponent,\n    TuiTextfieldSizeDirective,\n    TuiTextMaskOptions,\n    TuiWithOptionalMinMax,\n} from '@taiga-ui/core';\nimport {DATE_TIME_SEPARATOR, TUI_DATE_MASK} from '@taiga-ui/kit/constants';\nimport {LEFT_ALIGNED_DROPDOWN_CONTROLLER_PROVIDER} from '@taiga-ui/kit/providers';\nimport {TUI_CALENDAR_DATA_STREAM, TUI_TIME_TEXTS} from '@taiga-ui/kit/tokens';\nimport {\n    tuiCreateAutoCorrectedDateTimePipe,\n    tuiCreateTimeMask,\n} from '@taiga-ui/kit/utils/mask';\nimport {TuiReplayControlValueChangesFactory} from '@taiga-ui/kit/utils/miscellaneous';\nimport {Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\n// @dynamic\n@Component({\n    selector: 'tui-input-date-time',\n    templateUrl: './input-date-time.template.html',\n    styleUrls: ['./input-date-time.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: TUI_FOCUSABLE_ITEM_ACCESSOR,\n            useExisting: forwardRef(() => TuiInputDateTimeComponent),\n        },\n        {\n            provide: TUI_CALENDAR_DATA_STREAM,\n            deps: [[new Optional(), new Self(), NgControl]],\n            useFactory: TuiReplayControlValueChangesFactory,\n        },\n        LEFT_ALIGNED_DROPDOWN_CONTROLLER_PROVIDER,\n    ],\n})\nexport class TuiInputDateTimeComponent\n    extends AbstractTuiControl<[TuiDay | null, TuiTime | null]>\n    implements TuiWithOptionalMinMax<TuiDay>, TuiFocusableElementAccessor {\n    @Input()\n    @tuiDefaultProp()\n    min = TUI_FIRST_DAY;\n\n    @Input()\n    @tuiDefaultProp()\n    max = TUI_LAST_DAY;\n\n    @Input()\n    @tuiDefaultProp()\n    disabledItemHandler: TuiBooleanHandler<TuiDay> = ALWAYS_FALSE_HANDLER;\n\n    @Input()\n    @tuiDefaultProp()\n    defaultActiveYearMonth = TuiMonth.currentLocal();\n\n    @Input()\n    @tuiDefaultProp()\n    timeMode: TuiTimeMode = 'HH:MM';\n\n    open = false;\n\n    private month: TuiMonth | null = null;\n\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly textfield?: TuiPrimitiveTextfieldComponent;\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) changeDetectorRef: ChangeDetectorRef,\n        @Inject(TUI_TEXTFIELD_SIZE)\n        private readonly textfieldSize: TuiTextfieldSizeDirective,\n        @Inject(TUI_DATE_FILLER) readonly dateFiller: string,\n        @Inject(TUI_TIME_TEXTS)\n        readonly timeTexts$: Observable<Record<TuiTimeMode, string>>,\n    ) {\n        super(control, changeDetectorRef);\n    }\n\n    get fillerLength(): number {\n        return this.dateFiller.length + DATE_TIME_SEPARATOR.length + this.timeMode.length;\n    }\n\n    get textMaskOptions(): TuiTextMaskOptions {\n        return this.calculateMask(\n            this.value[0],\n            this.min,\n            this.max,\n            this.timeMode,\n            this.dateFiller,\n        );\n    }\n\n    get nativeFocusableElement(): HTMLInputElement | null {\n        return this.textfield ? this.textfield.nativeFocusableElement : null;\n    }\n\n    get focused(): boolean {\n        return !!this.textfield && this.textfield.focused;\n    }\n\n    get calendarIcon(): string {\n        return sizeBigger(this.textfieldSize.size)\n            ? 'tuiIconCalendarLarge'\n            : 'tuiIconCalendar';\n    }\n\n    get computedValue(): string {\n        const {value, nativeValue, focused, touched} = this;\n        const [date, time] = value;\n\n        if (\n            (date && !nativeValue) ||\n            (date && nativeValue.length === this.dateFiller.length) ||\n            (date && time)\n        ) {\n            return `${date.toString()}${DATE_TIME_SEPARATOR}${\n                time ? time.toString(this.timeMode) : ''\n            }`;\n        }\n\n        if (touched || focused) {\n            return nativeValue;\n        }\n\n        return date !== null ? date.toString() : '';\n    }\n\n    get calendarValue(): TuiDay | null {\n        return this.value[0];\n    }\n\n    get computedActiveYearMonth(): TuiMonth {\n        return this.month || this.value[0] || this.defaultActiveYearMonth;\n    }\n\n    get nativeValue(): string {\n        return this.nativeFocusableElement ? this.nativeFocusableElement.value : '';\n    }\n\n    set nativeValue(value: string) {\n        if (!this.nativeFocusableElement) {\n            return;\n        }\n\n        this.nativeFocusableElement.value = value;\n    }\n\n    get canOpen(): boolean {\n        return !this.computedDisabled && !this.readOnly;\n    }\n\n    @tuiPure\n    getFiller$(dateFiller: string, timeMode: TuiTimeMode): Observable<string> {\n        return this.timeTexts$.pipe(\n            map(texts => `${dateFiller}${DATE_TIME_SEPARATOR}${texts[timeMode]}`),\n        );\n    }\n\n    @HostListener('click')\n    onClick() {\n        this.open = !this.open;\n    }\n\n    onValueChange(value: string) {\n        if (value.length < this.dateFiller.length) {\n            this.updateValue([null, null]);\n\n            return;\n        }\n\n        const [date, time] = value.split(DATE_TIME_SEPARATOR);\n\n        const parsedDate = TuiDay.normalizeParse(date);\n        const parsedTime =\n            time && time.length === this.timeMode.length\n                ? TuiTime.fromString(time)\n                : null;\n\n        if (parsedDate !== null) {\n            this.open = false;\n        }\n\n        this.updateValue([parsedDate, parsedTime]);\n    }\n\n    onDayClick(day: TuiDay) {\n        this.updateValue([day, this.value[1]]);\n        this.open = false;\n    }\n\n    onHovered(hovered: boolean) {\n        this.updateHovered(hovered);\n    }\n\n    onMonthChange(month: TuiMonth) {\n        this.month = month;\n    }\n\n    onOpenChange(open: boolean) {\n        this.open = open;\n    }\n\n    onFocused(focused: boolean) {\n        this.updateFocused(focused);\n\n        if (\n            focused ||\n            this.value[0] === null ||\n            this.value[1] !== null ||\n            this.nativeValue.length <= this.fillerLength + DATE_TIME_SEPARATOR.length ||\n            this.timeMode === 'HH:MM'\n        ) {\n            return;\n        }\n\n        const [, time] = this.nativeValue.split(DATE_TIME_SEPARATOR);\n\n        if (!time) {\n            return;\n        }\n\n        const parsedTime = TuiTime.fromString(time);\n\n        this.updateValue([this.value[0], parsedTime]);\n\n        setTimeout(() => {\n            if (this.nativeValue.endsWith('.') || this.nativeValue.endsWith(':')) {\n                this.nativeValue = this.nativeValue.slice(0, -1);\n            }\n        });\n    }\n\n    setDisabledState() {\n        super.setDisabledState();\n        this.open = false;\n    }\n\n    writeValue(value: [TuiDay | null, TuiTime | null] | null) {\n        super.writeValue(value);\n\n        this.nativeValue = value && (value[0] || value[1]) ? this.computedValue : '';\n    }\n\n    protected getFallbackValue(): [TuiDay | null, TuiTime | null] {\n        return [null, null];\n    }\n\n    protected valueIdenticalComparator(\n        oldValue: [TuiDay | null, TuiTime | null],\n        newValue: [TuiDay | null, TuiTime | null],\n    ): boolean {\n        return (\n            nullableSame(oldValue[0], newValue[0], (a, b) => a.daySame(b)) &&\n            nullableSame(\n                oldValue[1],\n                newValue[1],\n                (a, b) => a.toString() === b.toString(),\n            )\n        );\n    }\n\n    @tuiPure\n    private calculateMask(\n        day: TuiDay | null,\n        min: TuiDay,\n        max: TuiDay,\n        timeMode: TuiTimeMode,\n        filler: string,\n    ): TuiTextMaskOptions {\n        return {\n            mask: [...TUI_DATE_MASK, ',', ' ', ...tuiCreateTimeMask(timeMode)],\n            pipe: tuiCreateAutoCorrectedDateTimePipe(\n                {value: day, min, max, filler},\n                timeMode,\n            ),\n            guide: false,\n        };\n    }\n}\n"]}