UNPKG

@taiga-ui/kit

Version:
303 lines • 36 kB
import { __decorate, __extends, __param } from "tslib"; import { ChangeDetectionStrategy, ChangeDetectorRef, Component, forwardRef, HostListener, Inject, Input, Optional, Self, ViewChild, } from '@angular/core'; import { NgControl } from '@angular/forms'; import { AbstractTuiNullableControl, ALWAYS_FALSE_HANDLER, isNativeFocused, setNativeFocused, TUI_FOCUSABLE_ITEM_ACCESSOR, TUI_STRICT_MATCHER, tuiDefaultProp, tuiPure, TuiTime, } from '@taiga-ui/cdk'; import { sizeBigger, TUI_TEXTFIELD_SIZE, TuiPrimitiveTextfieldComponent, TuiSizeL, TuiSizeS, TuiTextfieldSizeDirective, TuiTextMaskOptions, } from '@taiga-ui/core'; import { FIXED_DROPDOWN_CONTROLLER_PROVIDER } from '@taiga-ui/kit/providers'; import { TUI_TIME_TEXTS } from '@taiga-ui/kit/tokens'; import { tuiCreateAutoCorrectedTimePipe, tuiCreateTimeMask, } from '@taiga-ui/kit/utils/mask'; import { Observable } from 'rxjs'; import { map } from 'rxjs/operators'; // @dynamic var TuiInputTimeComponent = /** @class */ (function (_super) { __extends(TuiInputTimeComponent, _super); function TuiInputTimeComponent(control, changeDetectorRef, textfieldSize, timeTexts$) { var _this = _super.call(this, control, changeDetectorRef) || this; _this.textfieldSize = textfieldSize; _this.timeTexts$ = timeTexts$; _this.disabledItemHandler = ALWAYS_FALSE_HANDLER; _this.items = []; _this.itemSize = 'm'; _this.strict = false; _this.mode = 'HH:MM'; _this.open = false; return _this; } TuiInputTimeComponent_1 = TuiInputTimeComponent; Object.defineProperty(TuiInputTimeComponent.prototype, "nativeFocusableElement", { get: function () { return this.textfield ? this.textfield.nativeFocusableElement : null; }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputTimeComponent.prototype, "focused", { get: function () { return isNativeFocused(this.nativeFocusableElement); }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputTimeComponent.prototype, "filtered", { get: function () { return this.filter(this.items, this.mode, this.computedSearch); }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputTimeComponent.prototype, "textMaskOptions", { get: function () { return this.calculateMask(this.mode); }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputTimeComponent.prototype, "computedValue", { get: function () { return this.value ? this.value.toString(this.mode) : this.nativeValue; }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputTimeComponent.prototype, "computedSearch", { get: function () { return this.computedValue.length !== this.mode.length ? this.computedValue : ''; }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputTimeComponent.prototype, "interactive", { get: function () { return !this.disabled && !this.readOnly; }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputTimeComponent.prototype, "innerPseudoFocused", { get: function () { if (this.pseudoFocused === false) { return false; } if (this.open || this.computedFocused) { return true; } return null; }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputTimeComponent.prototype, "icon", { get: function () { return sizeBigger(this.textfieldSize.size) ? 'tuiIconTimeLarge' : 'tuiIconTime'; }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputTimeComponent.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 }); TuiInputTimeComponent.prototype.getFiller$ = function (mode) { return this.timeTexts$.pipe(map(function (texts) { return texts[mode]; })); }; TuiInputTimeComponent.prototype.onValueChange = function (value) { this.open = !!this.items.length; if (value && this.control) { this.control.updateValueAndValidity(); } var match = this.getMatch(value); if (match !== undefined) { this.updateValue(match); return; } if (value.length !== this.mode.length) { this.updateValue(null); return; } var time = TuiTime.fromString(value); this.updateValue(this.strict ? this.findNearestTimeFromItems(time) : time); }; TuiInputTimeComponent.prototype.onFocused = function (focused) { var _this = this; this.updateFocused(focused); if (focused || this.value !== null || this.nativeValue === '' || this.mode === 'HH:MM') { return; } var parsedTime = TuiTime.fromString(this.nativeValue); this.updateValue(parsedTime); setTimeout(function () { if (_this.nativeValue.endsWith('.') || _this.nativeValue.endsWith(':')) { _this.nativeValue = _this.nativeValue.slice(0, -1); } }); }; TuiInputTimeComponent.prototype.onHovered = function (hovered) { this.updateHovered(hovered); }; TuiInputTimeComponent.prototype.onArrowUp = function (event) { if (this.items.length) { return; } this.processArrow(event, 1); }; TuiInputTimeComponent.prototype.onArrowDown = function (event) { if (this.items.length) { return; } this.processArrow(event, -1); }; TuiInputTimeComponent.prototype.onClick = function () { this.open = !this.open; }; TuiInputTimeComponent.prototype.onMenuClick = function (item) { this.focusInput(); this.updateValue(item); }; TuiInputTimeComponent.prototype.onOpen = function (open) { this.open = open; }; TuiInputTimeComponent.prototype.writeValue = function (value) { _super.prototype.writeValue.call(this, value); this.nativeValue = value ? this.computedValue : ''; }; TuiInputTimeComponent.prototype.findNearestTimeFromItems = function (value) { return this.items.reduce(function (previous, current) { return Math.abs(current.toAbsoluteMilliseconds() - value.toAbsoluteMilliseconds()) < Math.abs(previous.toAbsoluteMilliseconds() - value.toAbsoluteMilliseconds()) ? current : previous; }); }; TuiInputTimeComponent.prototype.getMatch = function (value) { return this.items.find(function (item) { return TUI_STRICT_MATCHER(item, value); }); }; TuiInputTimeComponent.prototype.close = function () { this.open = false; }; TuiInputTimeComponent.prototype.processArrow = function (event, shift) { var target = event.target; if (this.readOnly || !(target instanceof HTMLInputElement)) { return; } var selectionStart = target.selectionStart || 0; this.shiftTime(this.calculateShift(selectionStart, shift)); target.setSelectionRange(selectionStart, selectionStart); event.preventDefault(); }; TuiInputTimeComponent.prototype.calculateShift = function (selectionStart, shift) { if (selectionStart <= 2) { return { hours: shift }; } if (selectionStart <= 5) { return { minutes: shift }; } if (selectionStart <= 8) { return { seconds: shift }; } return { ms: shift }; }; TuiInputTimeComponent.prototype.shiftTime = function (shift) { if (this.value === null) { return; } var increasedTime = this.value.shift(shift); // Manual update so we can set caret position properly this.nativeValue = increasedTime.toString(this.mode); this.updateValue(increasedTime); }; TuiInputTimeComponent.prototype.focusInput = function (preventScroll) { if (preventScroll === void 0) { preventScroll = false; } if (this.nativeFocusableElement) { setNativeFocused(this.nativeFocusableElement, true, preventScroll); this.close(); } }; TuiInputTimeComponent.prototype.calculateMask = function (mode) { return { mask: tuiCreateTimeMask(mode), pipe: tuiCreateAutoCorrectedTimePipe(mode), guide: false, }; }; TuiInputTimeComponent.prototype.filter = function (items, mode, search) { return items.filter(function (item) { return item.toString(mode).includes(search); }); }; var TuiInputTimeComponent_1; TuiInputTimeComponent.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: Observable, decorators: [{ type: Inject, args: [TUI_TIME_TEXTS,] }] } ]; }; __decorate([ Input(), tuiDefaultProp() ], TuiInputTimeComponent.prototype, "disabledItemHandler", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiInputTimeComponent.prototype, "items", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiInputTimeComponent.prototype, "itemSize", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiInputTimeComponent.prototype, "strict", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiInputTimeComponent.prototype, "mode", void 0); __decorate([ ViewChild(TuiPrimitiveTextfieldComponent) ], TuiInputTimeComponent.prototype, "textfield", void 0); __decorate([ tuiPure ], TuiInputTimeComponent.prototype, "getFiller$", null); __decorate([ HostListener('click') ], TuiInputTimeComponent.prototype, "onClick", null); __decorate([ tuiPure ], TuiInputTimeComponent.prototype, "calculateMask", null); __decorate([ tuiPure ], TuiInputTimeComponent.prototype, "filter", null); TuiInputTimeComponent = TuiInputTimeComponent_1 = __decorate([ Component({ selector: 'tui-input-time', template: "<tui-hosted-dropdown\n class=\"wrapper\"\n [canOpen]=\"interactive && !!filtered.length\"\n [content]=\"dropdownContent\"\n [open]=\"open && !!filtered.length\"\n (openChange)=\"onOpen($event)\"\n (focusedChange)=\"onFocused($event)\"\n>\n <tui-primitive-textfield\n class=\"textfield\"\n tuiValueAccessor\n [filler]=\"getFiller$(mode) | async\"\n [nativeId]=\"nativeId\"\n [pseudoFocused]=\"innerPseudoFocused\"\n [pseudoHovered]=\"pseudoHovered\"\n [pseudoPressed]=\"pseudoPressed\"\n [invalid]=\"computedInvalid\"\n [focusable]=\"focusable\"\n [disabled]=\"disabled\"\n [readOnly]=\"readOnly\"\n [textMask]=\"textMaskOptions\"\n [iconContent]=\"icon\"\n [value]=\"computedValue\"\n (valueChange)=\"onValueChange($event)\"\n (hoveredChange)=\"onHovered($event)\"\n (keydown.arrowUp)=\"onArrowUp($event)\"\n (keydown.arrowDown)=\"onArrowDown($event)\"\n >\n <ng-content></ng-content>\n </tui-primitive-textfield>\n</tui-hosted-dropdown>\n<ng-template #dropdownContent>\n <tui-data-list automation-id=\"tui-input-time__dropdown\">\n <button\n *ngFor=\"let item of filtered\"\n tuiOption\n automation-id=\"tui-input-time__item\"\n [size]=\"itemSize\"\n [disabled]=\"disabledItemHandler(item)\"\n (click)=\"onMenuClick(item)\"\n >\n {{item}}\n </button>\n </tui-data-list>\n</ng-template>\n", changeDetection: ChangeDetectionStrategy.OnPush, providers: [ { provide: TUI_FOCUSABLE_ITEM_ACCESSOR, useExisting: forwardRef(function () { return TuiInputTimeComponent_1; }), }, FIXED_DROPDOWN_CONTROLLER_PROVIDER, ], styles: [":host{display:block;border-radius:var(--tui-radius-m)}:host._disabled{pointer-events:none}.wrapper{display:block;border-radius:inherit}.textfield{border-radius:inherit}"] }), __param(0, Optional()), __param(0, Self()), __param(0, Inject(NgControl)), __param(1, Inject(ChangeDetectorRef)), __param(2, Inject(TUI_TEXTFIELD_SIZE)), __param(3, Inject(TUI_TIME_TEXTS)) ], TuiInputTimeComponent); return TuiInputTimeComponent; }(AbstractTuiNullableControl)); export { TuiInputTimeComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-time.component.js","sourceRoot":"ng://@taiga-ui/kit/components/input-time/","sources":["input-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    AbstractTuiNullableControl,\n    ALWAYS_FALSE_HANDLER,\n    isNativeFocused,\n    setNativeFocused,\n    TUI_FOCUSABLE_ITEM_ACCESSOR,\n    TUI_STRICT_MATCHER,\n    TuiBooleanHandler,\n    tuiDefaultProp,\n    TuiFocusableElementAccessor,\n    tuiPure,\n    TuiTime,\n    TuiTimeLike,\n    TuiTimeMode,\n} from '@taiga-ui/cdk';\nimport {\n    sizeBigger,\n    TUI_TEXTFIELD_SIZE,\n    TuiPrimitiveTextfieldComponent,\n    TuiSizeL,\n    TuiSizeS,\n    TuiTextfieldSizeDirective,\n    TuiTextMaskOptions,\n} from '@taiga-ui/core';\nimport {FIXED_DROPDOWN_CONTROLLER_PROVIDER} from '@taiga-ui/kit/providers';\nimport {TUI_TIME_TEXTS} from '@taiga-ui/kit/tokens';\nimport {\n    tuiCreateAutoCorrectedTimePipe,\n    tuiCreateTimeMask,\n} from '@taiga-ui/kit/utils/mask';\nimport {Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\n// @dynamic\n@Component({\n    selector: 'tui-input-time',\n    templateUrl: './input-time.template.html',\n    styleUrls: ['./input-time.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: TUI_FOCUSABLE_ITEM_ACCESSOR,\n            useExisting: forwardRef(() => TuiInputTimeComponent),\n        },\n        FIXED_DROPDOWN_CONTROLLER_PROVIDER,\n    ],\n})\nexport class TuiInputTimeComponent\n    extends AbstractTuiNullableControl<TuiTime>\n    implements TuiFocusableElementAccessor {\n    @Input()\n    @tuiDefaultProp()\n    disabledItemHandler: TuiBooleanHandler<TuiTime> = ALWAYS_FALSE_HANDLER;\n\n    @Input()\n    @tuiDefaultProp()\n    items: ReadonlyArray<TuiTime> = [];\n\n    @Input()\n    @tuiDefaultProp()\n    itemSize: TuiSizeS | TuiSizeL = 'm';\n\n    @Input()\n    @tuiDefaultProp()\n    strict = false;\n\n    @Input()\n    @tuiDefaultProp()\n    mode: TuiTimeMode = 'HH:MM';\n\n    open = false;\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_TIME_TEXTS)\n        private readonly timeTexts$: Observable<Record<TuiTimeMode, string>>,\n    ) {\n        super(control, changeDetectorRef);\n    }\n\n    get nativeFocusableElement(): HTMLInputElement | null {\n        return this.textfield ? this.textfield.nativeFocusableElement : null;\n    }\n\n    get focused(): boolean {\n        return isNativeFocused(this.nativeFocusableElement);\n    }\n\n    get filtered(): ReadonlyArray<TuiTime> {\n        return this.filter(this.items, this.mode, this.computedSearch);\n    }\n\n    get textMaskOptions(): TuiTextMaskOptions {\n        return this.calculateMask(this.mode);\n    }\n\n    get computedValue(): string {\n        return this.value ? this.value.toString(this.mode) : this.nativeValue;\n    }\n\n    get computedSearch(): string {\n        return this.computedValue.length !== this.mode.length ? this.computedValue : '';\n    }\n\n    get interactive(): boolean {\n        return !this.disabled && !this.readOnly;\n    }\n\n    get innerPseudoFocused(): boolean | null {\n        if (this.pseudoFocused === false) {\n            return false;\n        }\n\n        if (this.open || this.computedFocused) {\n            return true;\n        }\n\n        return null;\n    }\n\n    get icon(): string {\n        return sizeBigger(this.textfieldSize.size) ? 'tuiIconTimeLarge' : 'tuiIconTime';\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    @tuiPure\n    getFiller$(mode: TuiTimeMode): Observable<string> {\n        return this.timeTexts$.pipe(map(texts => texts[mode]));\n    }\n\n    onValueChange(value: string) {\n        this.open = !!this.items.length;\n\n        if (value && this.control) {\n            this.control.updateValueAndValidity();\n        }\n\n        const match = this.getMatch(value);\n\n        if (match !== undefined) {\n            this.updateValue(match);\n\n            return;\n        }\n\n        if (value.length !== this.mode.length) {\n            this.updateValue(null);\n\n            return;\n        }\n\n        const time = TuiTime.fromString(value);\n\n        this.updateValue(this.strict ? this.findNearestTimeFromItems(time) : time);\n    }\n\n    onFocused(focused: boolean) {\n        this.updateFocused(focused);\n\n        if (\n            focused ||\n            this.value !== null ||\n            this.nativeValue === '' ||\n            this.mode === 'HH:MM'\n        ) {\n            return;\n        }\n\n        const parsedTime = TuiTime.fromString(this.nativeValue);\n\n        this.updateValue(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    onHovered(hovered: boolean) {\n        this.updateHovered(hovered);\n    }\n\n    onArrowUp(event: KeyboardEvent) {\n        if (this.items.length) {\n            return;\n        }\n\n        this.processArrow(event, 1);\n    }\n\n    onArrowDown(event: KeyboardEvent) {\n        if (this.items.length) {\n            return;\n        }\n\n        this.processArrow(event, -1);\n    }\n\n    @HostListener('click')\n    onClick() {\n        this.open = !this.open;\n    }\n\n    onMenuClick(item: TuiTime) {\n        this.focusInput();\n        this.updateValue(item);\n    }\n\n    onOpen(open: boolean) {\n        this.open = open;\n    }\n\n    writeValue(value: TuiTime | null) {\n        super.writeValue(value);\n        this.nativeValue = value ? this.computedValue : '';\n    }\n\n    private findNearestTimeFromItems(value: TuiTime): TuiTime | null {\n        return this.items.reduce((previous, current) =>\n            Math.abs(current.toAbsoluteMilliseconds() - value.toAbsoluteMilliseconds()) <\n            Math.abs(previous.toAbsoluteMilliseconds() - value.toAbsoluteMilliseconds())\n                ? current\n                : previous,\n        );\n    }\n\n    private getMatch(value: string): TuiTime | undefined {\n        return this.items.find(item => TUI_STRICT_MATCHER(item, value));\n    }\n\n    private close() {\n        this.open = false;\n    }\n\n    private processArrow(event: KeyboardEvent, shift: -1 | 1) {\n        const {target} = event;\n\n        if (this.readOnly || !(target instanceof HTMLInputElement)) {\n            return;\n        }\n\n        const selectionStart = target.selectionStart || 0;\n\n        this.shiftTime(this.calculateShift(selectionStart, shift));\n\n        target.setSelectionRange(selectionStart, selectionStart);\n        event.preventDefault();\n    }\n\n    private calculateShift(selectionStart: number, shift: number): TuiTimeLike {\n        if (selectionStart <= 2) {\n            return {hours: shift};\n        }\n\n        if (selectionStart <= 5) {\n            return {minutes: shift};\n        }\n\n        if (selectionStart <= 8) {\n            return {seconds: shift};\n        }\n\n        return {ms: shift};\n    }\n\n    private shiftTime(shift: TuiTimeLike) {\n        if (this.value === null) {\n            return;\n        }\n\n        const increasedTime = this.value.shift(shift);\n\n        // Manual update so we can set caret position properly\n        this.nativeValue = increasedTime.toString(this.mode);\n        this.updateValue(increasedTime);\n    }\n\n    private focusInput(preventScroll: boolean = false) {\n        if (this.nativeFocusableElement) {\n            setNativeFocused(this.nativeFocusableElement, true, preventScroll);\n            this.close();\n        }\n    }\n\n    @tuiPure\n    private calculateMask(mode: TuiTimeMode): TuiTextMaskOptions {\n        return {\n            mask: tuiCreateTimeMask(mode),\n            pipe: tuiCreateAutoCorrectedTimePipe(mode),\n            guide: false,\n        };\n    }\n\n    @tuiPure\n    private filter(\n        items: ReadonlyArray<TuiTime>,\n        mode: TuiTimeMode,\n        search: string,\n    ): ReadonlyArray<TuiTime> {\n        return items.filter(item => item.toString(mode).includes(search));\n    }\n}\n"]}