UNPKG

@taiga-ui/kit

Version:
285 lines 40.9 kB
var TuiInputDateRangeComponent_1; import { __decorate, __param } from "tslib"; import { ChangeDetectorRef, Component, forwardRef, HostListener, Inject, Injector, Input, Optional, Self, Type, ViewChild, } from '@angular/core'; import { NgControl } from '@angular/forms'; import { AbstractTuiNullableControl, ALWAYS_FALSE_HANDLER, nullableSame, RANGE_SEPARATOR_CHAR, setNativeFocused, TUI_DATE_FILLER, TUI_DATE_RANGE_FILLER, TUI_FIRST_DAY, TUI_FOCUSABLE_ITEM_ACCESSOR, TUI_IS_MOBILE, TUI_LAST_DAY, TuiDayRange, tuiDefaultProp, TuiMonth, } from '@taiga-ui/cdk'; import { sizeBigger, TUI_DEFAULT_MARKER_HANDLER, TUI_TEXTFIELD_EXAMPLE_TEXT, TUI_TEXTFIELD_SIZE, TuiDialogService, TuiMarkerHandler, TuiPrimitiveTextfieldComponent, TuiTextfieldExampleTextDirective, TuiTextfieldSizeDirective, TuiTextMaskOptions, TuiWithOptionalMinMax, } from '@taiga-ui/core'; import { EMPTY_MASK, MAX_DAY_RANGE_LENGTH_MAPPER, TUI_DATE_RANGE_MASK, } from '@taiga-ui/kit/constants'; import { LEFT_ALIGNED_DROPDOWN_CONTROLLER_PROVIDER } from '@taiga-ui/kit/providers'; import { TUI_CALENDAR_DATA_STREAM, TUI_MOBILE_CALENDAR } from '@taiga-ui/kit/tokens'; import { tuiCreateAutoCorrectedDateRangePipe } from '@taiga-ui/kit/utils/mask'; import { TuiReplayControlValueChangesFactory } from '@taiga-ui/kit/utils/miscellaneous'; import { PolymorpheusComponent } from '@tinkoff/ng-polymorpheus'; import { takeUntil } from 'rxjs/operators'; const ɵ0 = TuiReplayControlValueChangesFactory; let TuiInputDateRangeComponent = TuiInputDateRangeComponent_1 = class TuiInputDateRangeComponent extends AbstractTuiNullableControl { constructor(control, changeDetectorRef, injector, isMobile, dialogService, mobileCalendar, textfieldSize, textfieldExampleText, filler, rangeFiller) { super(control, changeDetectorRef); this.injector = injector; this.isMobile = isMobile; this.dialogService = dialogService; this.mobileCalendar = mobileCalendar; this.textfieldSize = textfieldSize; this.textfieldExampleText = textfieldExampleText; this.filler = filler; this.rangeFiller = rangeFiller; this.disabledItemHandler = ALWAYS_FALSE_HANDLER; this.markerHandler = TUI_DEFAULT_MARKER_HANDLER; this.defaultViewedMonth = TuiMonth.currentLocal(); this.items = []; this.min = TUI_FIRST_DAY; this.max = TUI_LAST_DAY; this.minLength = null; this.maxLength = null; this.open = false; this.maxLengthMapper = MAX_DAY_RANGE_LENGTH_MAPPER; this.textMaskOptions = { mask: TUI_DATE_RANGE_MASK, pipe: tuiCreateAutoCorrectedDateRangePipe(this), guide: false, }; } get nativeFocusableElement() { return this.textfield ? this.textfield.nativeFocusableElement : null; } get focused() { return !!this.textfield && this.textfield.focused; } get computedMobile() { return this.isMobile && !!this.mobileCalendar; } get calendarIcon() { return sizeBigger(this.textfieldSize.size) ? 'tuiIconCalendarLarge' : 'tuiIconCalendar'; } get canOpen() { return !this.computedDisabled && !this.readOnly && !this.computedMobile; } get computedExampleText() { return this.items.length ? this.textfieldExampleText.exampleText : ''; } get computedFiller() { return this.activePeriod ? '' : this.rangeFiller; } get computedMask() { return this.activePeriod ? EMPTY_MASK : this.textMaskOptions; } get activePeriod() { return (this.items.find(item => nullableSame(this.value, item.range, (a, b) => a.from.daySame(b.from.dayLimit(this.min, this.max)) && a.to.daySame(b.to.dayLimit(this.min, this.max)))) || null); } get computedValue() { const { value, nativeValue, activePeriod } = this; if (activePeriod) { return String(activePeriod); } return value ? value.formattedDayRange : nativeValue; } get innerPseudoFocused() { if (this.pseudoFocused === false) { return false; } if (this.open || this.computedFocused) { return true; } return null; } get nativeValue() { return this.nativeFocusableElement ? this.nativeFocusableElement.value : ''; } set nativeValue(value) { if (!this.nativeFocusableElement) { return; } this.nativeFocusableElement.value = value; } onMobileClick() { if (!this.mobileCalendar) { this.toggle(); return; } this.dialogService .open(new PolymorpheusComponent(this.mobileCalendar, this.injector), { size: 'fullscreen', closeable: false, data: { single: false, min: this.maxLengthMapper(this.min, this.value, this.maxLength, true), max: this.maxLengthMapper(this.max, this.value, this.maxLength, false), disabledItemHandler: this.disabledItemHandler, }, }) .pipe(takeUntil(this.destroy$)) .subscribe(value => { this.updateValue(value); }); } onClick() { if (!this.isMobile) { this.toggle(); } } onOpenChange(open) { this.open = open; } onValueChange(value) { if (value && this.control) { this.control.updateValueAndValidity(); } if (value.length !== this.rangeFiller.length) { this.updateValue(null); return; } const parsedValue = TuiDayRange.normalizeParse(value, this.filler, this.rangeFiller); this.updateValue(!this.minLength && !this.maxLength ? parsedValue : this.clampValue(parsedValue)); } onRangeChange(range) { this.toggle(); this.focusInput(); if (!nullableSame(this.value, range, (a, b) => a.daySame(b))) { this.updateValue(range); } } onItemSelect(item) { this.toggle(); this.focusInput(); if (typeof item !== 'string') { this.updateValue(item.range.dayLimit(this.min, this.max)); return; } if (this.activePeriod !== null) { this.updateValue(null); this.nativeValue = ''; } } onHovered(hovered) { this.updateHovered(hovered); } onPressed(pressed) { this.updatePressed(pressed); } onActiveZone(focused) { this.updateFocused(focused); if (!focused && !this.itemSelected && (this.nativeValue.length === this.filler.length || this.nativeValue.length === this.filler.length + RANGE_SEPARATOR_CHAR.length)) { this.updateValue(TuiDayRange.normalizeParse(this.nativeValue, this.filler, this.rangeFiller)); } } writeValue(value) { super.writeValue(value); this.nativeValue = value ? this.computedValue : ''; } get itemSelected() { return this.items.findIndex(item => String(item) === this.nativeValue) !== -1; } toggle() { this.open = !this.open; } focusInput(preventScroll = false) { if (this.nativeFocusableElement) { setNativeFocused(this.nativeFocusableElement, true, preventScroll); } } clampValue(value) { const clampedBottom = this.minLength && value.from.append(this.minLength).dayAfter(value.to) ? new TuiDayRange(value.from, value.from.append(this.minLength).append({ day: -1 })) : value; const availableMax = this.maxLength ? clampedBottom.from.append(this.maxLength).append({ day: -1 }) : this.max; return clampedBottom.to.dayAfter(availableMax) ? new TuiDayRange(clampedBottom.from, availableMax) : clampedBottom; } }; TuiInputDateRangeComponent.ctorParameters = () => [ { type: NgControl, decorators: [{ type: Optional }, { type: Self }, { type: Inject, args: [NgControl,] }] }, { type: ChangeDetectorRef, decorators: [{ type: Inject, args: [ChangeDetectorRef,] }] }, { type: Injector, decorators: [{ type: Inject, args: [Injector,] }] }, { type: Boolean, decorators: [{ type: Inject, args: [TUI_IS_MOBILE,] }] }, { type: TuiDialogService, decorators: [{ type: Inject, args: [TuiDialogService,] }] }, { type: Type, decorators: [{ type: Optional }, { type: Inject, args: [TUI_MOBILE_CALENDAR,] }] }, { type: TuiTextfieldSizeDirective, decorators: [{ type: Inject, args: [TUI_TEXTFIELD_SIZE,] }] }, { type: TuiTextfieldExampleTextDirective, decorators: [{ type: Inject, args: [TUI_TEXTFIELD_EXAMPLE_TEXT,] }] }, { type: String, decorators: [{ type: Inject, args: [TUI_DATE_FILLER,] }] }, { type: String, decorators: [{ type: Inject, args: [TUI_DATE_RANGE_FILLER,] }] } ]; __decorate([ Input(), tuiDefaultProp() ], TuiInputDateRangeComponent.prototype, "disabledItemHandler", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiInputDateRangeComponent.prototype, "markerHandler", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiInputDateRangeComponent.prototype, "defaultViewedMonth", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiInputDateRangeComponent.prototype, "items", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiInputDateRangeComponent.prototype, "min", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiInputDateRangeComponent.prototype, "max", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiInputDateRangeComponent.prototype, "minLength", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiInputDateRangeComponent.prototype, "maxLength", void 0); __decorate([ ViewChild(TuiPrimitiveTextfieldComponent) ], TuiInputDateRangeComponent.prototype, "textfield", void 0); __decorate([ HostListener('click') ], TuiInputDateRangeComponent.prototype, "onClick", null); TuiInputDateRangeComponent = TuiInputDateRangeComponent_1 = __decorate([ Component({ selector: 'tui-input-date-range', template: "<tui-hosted-dropdown\n class=\"hosted\"\n [canOpen]=\"canOpen\"\n [content]=\"dropdown\"\n [open]=\"open && canOpen\"\n (openChange)=\"onOpenChange($event)\"\n (tuiActiveZoneChange)=\"onActiveZone($event)\"\n>\n <tui-primitive-textfield\n automation-id=\"tui-input-date-range__textfield\"\n class=\"textfield\"\n tuiValueAccessor\n [pseudoFocused]=\"innerPseudoFocused\"\n [pseudoHovered]=\"pseudoHovered\"\n [pseudoPressed]=\"pseudoPressed\"\n [invalid]=\"computedInvalid\"\n [tuiTextfieldExampleText]=\"computedExampleText\"\n [nativeId]=\"nativeId\"\n [filler]=\"computedFiller\"\n [readOnly]=\"readOnly\"\n [iconContent]=\"computedMobile ? iconContent : calendarIcon\"\n [disabled]=\"computedDisabled\"\n [textMask]=\"computedMask\"\n [value]=\"computedValue\"\n (valueChange)=\"onValueChange($event)\"\n (hoveredChange)=\"onHovered($event)\"\n (pressedChange)=\"onPressed($event)\"\n >\n <ng-content></ng-content>\n </tui-primitive-textfield>\n\n <ng-template #iconContent>\n <tui-svg\n automation-id=\"tui-input-date-range__icon\"\n [class.icon]=\"!computedDisabled\"\n [src]=\"calendarIcon\"\n (click)=\"onMobileClick()\"\n ></tui-svg>\n </ng-template>\n\n <ng-template #dropdown>\n <tui-calendar-range\n [defaultViewedMonth]=\"defaultViewedMonth\"\n [disabledItemHandler]=\"disabledItemHandler\"\n [items]=\"items\"\n [min]=\"min\"\n [max]=\"max\"\n [markerHandler]=\"markerHandler\"\n [minLength]=\"minLength\"\n [maxLength]=\"maxLength\"\n (rangeChange)=\"onRangeChange($event)\"\n ></tui-calendar-range>\n </ng-template>\n</tui-hosted-dropdown>\n", providers: [ { provide: TUI_FOCUSABLE_ITEM_ACCESSOR, useExisting: forwardRef(() => TuiInputDateRangeComponent_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)}:host._disabled{pointer-events:none}.hosted{display:block;border-radius:inherit}.textfield{border-radius:inherit}.icon{pointer-events:auto}"] }), __param(0, Optional()), __param(0, Self()), __param(0, Inject(NgControl)), __param(1, Inject(ChangeDetectorRef)), __param(2, Inject(Injector)), __param(3, Inject(TUI_IS_MOBILE)), __param(4, Inject(TuiDialogService)), __param(5, Optional()), __param(5, Inject(TUI_MOBILE_CALENDAR)), __param(6, Inject(TUI_TEXTFIELD_SIZE)), __param(7, Inject(TUI_TEXTFIELD_EXAMPLE_TEXT)), __param(8, Inject(TUI_DATE_FILLER)), __param(9, Inject(TUI_DATE_RANGE_FILLER)) ], TuiInputDateRangeComponent); export { TuiInputDateRangeComponent }; export { ɵ0 }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date-range.component.js","sourceRoot":"ng://@taiga-ui/kit/components/input-date-range/","sources":["input-date-range.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectorRef,\n    Component,\n    forwardRef,\n    HostListener,\n    Inject,\n    Injector,\n    Input,\n    Optional,\n    Self,\n    Type,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {\n    AbstractTuiNullableControl,\n    ALWAYS_FALSE_HANDLER,\n    nullableSame,\n    RANGE_SEPARATOR_CHAR,\n    setNativeFocused,\n    TUI_DATE_FILLER,\n    TUI_DATE_RANGE_FILLER,\n    TUI_FIRST_DAY,\n    TUI_FOCUSABLE_ITEM_ACCESSOR,\n    TUI_IS_MOBILE,\n    TUI_LAST_DAY,\n    TuiBooleanHandler,\n    TuiDay,\n    TuiDayLike,\n    TuiDayRange,\n    tuiDefaultProp,\n    TuiFocusableElementAccessor,\n    TuiMapper,\n    TuiMonth,\n} from '@taiga-ui/cdk';\nimport {\n    sizeBigger,\n    TUI_DEFAULT_MARKER_HANDLER,\n    TUI_TEXTFIELD_EXAMPLE_TEXT,\n    TUI_TEXTFIELD_SIZE,\n    TuiDialogService,\n    TuiMarkerHandler,\n    TuiPrimitiveTextfieldComponent,\n    TuiTextfieldExampleTextDirective,\n    TuiTextfieldSizeDirective,\n    TuiTextMaskOptions,\n    TuiWithOptionalMinMax,\n} from '@taiga-ui/core';\nimport {TuiDayRangePeriod} from '@taiga-ui/kit/classes';\nimport {\n    EMPTY_MASK,\n    MAX_DAY_RANGE_LENGTH_MAPPER,\n    TUI_DATE_RANGE_MASK,\n} from '@taiga-ui/kit/constants';\nimport {LEFT_ALIGNED_DROPDOWN_CONTROLLER_PROVIDER} from '@taiga-ui/kit/providers';\nimport {TUI_CALENDAR_DATA_STREAM, TUI_MOBILE_CALENDAR} from '@taiga-ui/kit/tokens';\nimport {tuiCreateAutoCorrectedDateRangePipe} from '@taiga-ui/kit/utils/mask';\nimport {TuiReplayControlValueChangesFactory} from '@taiga-ui/kit/utils/miscellaneous';\nimport {PolymorpheusComponent} from '@tinkoff/ng-polymorpheus';\nimport {takeUntil} from 'rxjs/operators';\n\n@Component({\n    selector: 'tui-input-date-range',\n    templateUrl: './input-date-range.template.html',\n    styleUrls: ['./input-date-range.style.less'],\n    providers: [\n        {\n            provide: TUI_FOCUSABLE_ITEM_ACCESSOR,\n            useExisting: forwardRef(() => TuiInputDateRangeComponent),\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 TuiInputDateRangeComponent\n    extends AbstractTuiNullableControl<TuiDayRange>\n    implements TuiWithOptionalMinMax<TuiDay>, TuiFocusableElementAccessor {\n    @Input()\n    @tuiDefaultProp()\n    disabledItemHandler: TuiBooleanHandler<TuiDay> = ALWAYS_FALSE_HANDLER;\n\n    @Input()\n    @tuiDefaultProp()\n    markerHandler: TuiMarkerHandler = TUI_DEFAULT_MARKER_HANDLER;\n\n    @Input()\n    @tuiDefaultProp()\n    defaultViewedMonth = TuiMonth.currentLocal();\n\n    @Input()\n    @tuiDefaultProp()\n    items: ReadonlyArray<TuiDayRangePeriod> = [];\n\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    minLength: TuiDayLike | null = null;\n\n    @Input()\n    @tuiDefaultProp()\n    maxLength: TuiDayLike | null = null;\n\n    open = false;\n\n    readonly maxLengthMapper: TuiMapper<TuiDay, TuiDay> = MAX_DAY_RANGE_LENGTH_MAPPER;\n\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly textfield?: TuiPrimitiveTextfieldComponent;\n\n    private readonly textMaskOptions: TuiTextMaskOptions = {\n        mask: TUI_DATE_RANGE_MASK,\n        pipe: tuiCreateAutoCorrectedDateRangePipe(this),\n        guide: false,\n    };\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) changeDetectorRef: ChangeDetectorRef,\n        @Inject(Injector) private readonly injector: Injector,\n        @Inject(TUI_IS_MOBILE) private readonly isMobile: boolean,\n        @Inject(TuiDialogService) private readonly dialogService: TuiDialogService,\n        @Optional()\n        @Inject(TUI_MOBILE_CALENDAR)\n        private readonly mobileCalendar: Type<any> | null,\n        @Inject(TUI_TEXTFIELD_SIZE)\n        private readonly textfieldSize: TuiTextfieldSizeDirective,\n        @Inject(TUI_TEXTFIELD_EXAMPLE_TEXT)\n        private readonly textfieldExampleText: TuiTextfieldExampleTextDirective,\n        @Inject(TUI_DATE_FILLER) readonly filler: string,\n        @Inject(TUI_DATE_RANGE_FILLER) readonly rangeFiller: 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 !!this.textfield && this.textfield.focused;\n    }\n\n    get computedMobile(): boolean {\n        return this.isMobile && !!this.mobileCalendar;\n    }\n\n    get calendarIcon(): string {\n        return sizeBigger(this.textfieldSize.size)\n            ? 'tuiIconCalendarLarge'\n            : 'tuiIconCalendar';\n    }\n\n    get canOpen(): boolean {\n        return !this.computedDisabled && !this.readOnly && !this.computedMobile;\n    }\n\n    get computedExampleText(): string {\n        return this.items.length ? this.textfieldExampleText.exampleText : '';\n    }\n\n    get computedFiller(): string {\n        return this.activePeriod ? '' : this.rangeFiller;\n    }\n\n    get computedMask(): TuiTextMaskOptions {\n        return this.activePeriod ? EMPTY_MASK : this.textMaskOptions;\n    }\n\n    get activePeriod(): TuiDayRangePeriod | null {\n        return (\n            this.items.find(item =>\n                nullableSame(\n                    this.value,\n                    item.range,\n                    (a, b) =>\n                        a.from.daySame(b.from.dayLimit(this.min, this.max)) &&\n                        a.to.daySame(b.to.dayLimit(this.min, this.max)),\n                ),\n            ) || null\n        );\n    }\n\n    get computedValue(): string {\n        const {value, nativeValue, activePeriod} = this;\n\n        if (activePeriod) {\n            return String(activePeriod);\n        }\n\n        return value ? value.formattedDayRange : nativeValue;\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 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    onMobileClick() {\n        if (!this.mobileCalendar) {\n            this.toggle();\n\n            return;\n        }\n\n        this.dialogService\n            .open<TuiDayRange>(\n                new PolymorpheusComponent(this.mobileCalendar, this.injector),\n                {\n                    size: 'fullscreen',\n                    closeable: false,\n                    data: {\n                        single: false,\n                        min: this.maxLengthMapper(\n                            this.min,\n                            this.value,\n                            this.maxLength,\n                            true,\n                        ),\n                        max: this.maxLengthMapper(\n                            this.max,\n                            this.value,\n                            this.maxLength,\n                            false,\n                        ),\n                        disabledItemHandler: this.disabledItemHandler,\n                    },\n                },\n            )\n            .pipe(takeUntil(this.destroy$))\n            .subscribe(value => {\n                this.updateValue(value);\n            });\n    }\n\n    @HostListener('click')\n    onClick() {\n        if (!this.isMobile) {\n            this.toggle();\n        }\n    }\n\n    onOpenChange(open: boolean) {\n        this.open = open;\n    }\n\n    onValueChange(value: string) {\n        if (value && this.control) {\n            this.control.updateValueAndValidity();\n        }\n\n        if (value.length !== this.rangeFiller.length) {\n            this.updateValue(null);\n\n            return;\n        }\n\n        const parsedValue = TuiDayRange.normalizeParse(\n            value,\n            this.filler,\n            this.rangeFiller,\n        );\n\n        this.updateValue(\n            !this.minLength && !this.maxLength\n                ? parsedValue\n                : this.clampValue(parsedValue),\n        );\n    }\n\n    onRangeChange(range: TuiDayRange) {\n        this.toggle();\n        this.focusInput();\n\n        if (!nullableSame<TuiDayRange>(this.value, range, (a, b) => a.daySame(b))) {\n            this.updateValue(range);\n        }\n    }\n\n    onItemSelect(item: string | TuiDayRangePeriod) {\n        this.toggle();\n        this.focusInput();\n\n        if (typeof item !== 'string') {\n            this.updateValue(item.range.dayLimit(this.min, this.max));\n\n            return;\n        }\n\n        if (this.activePeriod !== null) {\n            this.updateValue(null);\n            this.nativeValue = '';\n        }\n    }\n\n    onHovered(hovered: boolean) {\n        this.updateHovered(hovered);\n    }\n\n    onPressed(pressed: boolean) {\n        this.updatePressed(pressed);\n    }\n\n    onActiveZone(focused: boolean) {\n        this.updateFocused(focused);\n\n        if (\n            !focused &&\n            !this.itemSelected &&\n            (this.nativeValue.length === this.filler.length ||\n                this.nativeValue.length ===\n                    this.filler.length + RANGE_SEPARATOR_CHAR.length)\n        ) {\n            this.updateValue(\n                TuiDayRange.normalizeParse(\n                    this.nativeValue,\n                    this.filler,\n                    this.rangeFiller,\n                ),\n            );\n        }\n    }\n\n    writeValue(value: TuiDayRange | null) {\n        super.writeValue(value);\n        this.nativeValue = value ? this.computedValue : '';\n    }\n\n    private get itemSelected(): boolean {\n        return this.items.findIndex(item => String(item) === this.nativeValue) !== -1;\n    }\n\n    private toggle() {\n        this.open = !this.open;\n    }\n\n    private focusInput(preventScroll: boolean = false) {\n        if (this.nativeFocusableElement) {\n            setNativeFocused(this.nativeFocusableElement, true, preventScroll);\n        }\n    }\n\n    private clampValue(value: TuiDayRange): TuiDayRange {\n        const clampedBottom =\n            this.minLength && value.from.append(this.minLength).dayAfter(value.to)\n                ? new TuiDayRange(\n                      value.from,\n                      value.from.append(this.minLength).append({day: -1}),\n                  )\n                : value;\n\n        const availableMax = this.maxLength\n            ? clampedBottom.from.append(this.maxLength).append({day: -1})\n            : this.max;\n\n        return clampedBottom.to.dayAfter(availableMax)\n            ? new TuiDayRange(clampedBottom.from, availableMax)\n            : clampedBottom;\n    }\n}\n"]}