UNPKG

@taiga-ui/kit

Version:
249 lines • 39.7 kB
import { __decorate, __extends, __param } from "tslib"; import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, forwardRef, HostBinding, Inject, Optional, Self, ViewChild, } from '@angular/core'; import { NgControl } from '@angular/forms'; import { isNativeFocused, setNativeFocused, TUI_FOCUSABLE_ITEM_ACCESSOR, TUI_IS_MOBILE, } from '@taiga-ui/cdk'; import { formatNumber, maskedMoneyValueIsEmpty, maskedNumberStringToNumber, TuiModeDirective, } from '@taiga-ui/core'; import { AbstractTuiInputSlider } from '@taiga-ui/kit/abstract'; // @dynamic var TuiInputRangeComponent = /** @class */ (function (_super) { __extends(TuiInputRangeComponent, _super); function TuiInputRangeComponent(control, changeDetectorRef, modeDirective, isMobile) { var _this = _super.call(this, control, changeDetectorRef) || this; _this.modeDirective = modeDirective; _this.isMobile = isMobile; return _this; } TuiInputRangeComponent_1 = TuiInputRangeComponent; Object.defineProperty(TuiInputRangeComponent.prototype, "nativeFocusableElement", { get: function () { return !this.nativeLeft || this.disabled ? null : this.nativeLeft.nativeElement; }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputRangeComponent.prototype, "focused", { get: function () { return this.focusedLeft || this.focusedRight; }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputRangeComponent.prototype, "focusedLeft", { get: function () { return !!this.nativeLeft && isNativeFocused(this.nativeLeft.nativeElement); }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputRangeComponent.prototype, "focusedRight", { get: function () { return !!this.nativeRight && isNativeFocused(this.nativeRight.nativeElement); }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputRangeComponent.prototype, "showMinLabel", { get: function () { return !this.focusedLeft && !!this.minLabel && this.value[0] === this.min; }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputRangeComponent.prototype, "showMaxLabel", { get: function () { return !this.focusedRight && !!this.maxLabel && this.value[1] === this.max; }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputRangeComponent.prototype, "inputValueLeft", { get: function () { return this.nativeLeft ? this.nativeLeft.nativeElement.value : ''; }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputRangeComponent.prototype, "inputValueRight", { get: function () { return this.nativeRight ? this.nativeRight.nativeElement.value : ''; }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputRangeComponent.prototype, "computedValueLeft", { get: function () { return formatNumber(this.value[0]); }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputRangeComponent.prototype, "computedValueRight", { get: function () { return formatNumber(this.value[1]); }, enumerable: true, configurable: true }); TuiInputRangeComponent.prototype.onActiveZone = function (active) { this.updateFocused(active); }; TuiInputRangeComponent.prototype.onMouseDown = function () { if (this.nativeRight && !this.isMobile) { setNativeFocused(this.nativeRight.nativeElement); } }; TuiInputRangeComponent.prototype.onKeyDownArrowUpLeft = function (event) { if (this.readOnly) { return; } event.preventDefault(); this.processStep(true, false); }; TuiInputRangeComponent.prototype.onKeyDownArrowDownLeft = function (event) { if (this.readOnly) { return; } event.preventDefault(); this.processStep(false, false); }; TuiInputRangeComponent.prototype.onKeyDownArrowUpRight = function (event) { if (this.readOnly) { return; } event.preventDefault(); this.processStep(true, true); }; TuiInputRangeComponent.prototype.onKeyDownArrowDownRight = function (event) { if (this.readOnly) { return; } event.preventDefault(); this.processStep(false, true); }; TuiInputRangeComponent.prototype.onInputLeft = function () { var value = this.inputValueLeft; var capped = this.capInputValue(value, this.value[1]); var postfix = value.slice(-1)[0] === ',' ? ',' : ''; if (maskedMoneyValueIsEmpty(value) || capped === null) { return; } var newValue = formatNumber(capped) + postfix; if (this.nativeLeft && this.inputValueLeft !== newValue) { this.nativeLeft.nativeElement.value = newValue; } this.updateValue([capped, this.value[1]]); }; TuiInputRangeComponent.prototype.onInputRight = function () { var value = this.inputValueRight; var capped = this.capInputValue(value); var postfix = value.slice(-1)[0] === ',' ? ',' : ''; if (maskedMoneyValueIsEmpty(value) || capped === null) { return; } var newValue = formatNumber(capped) + postfix; if (this.nativeRight && this.inputValueRight !== newValue) { this.nativeRight.nativeElement.value = newValue; } if (capped >= this.value[0]) { this.updateValue([this.value[0], capped]); } }; TuiInputRangeComponent.prototype.onRangeValue = function (value) { var _this = this; var guardedValue = value.map(function (item) { return _this.valueGuard(item); }); if (!this.nativeLeft || !this.nativeRight || (guardedValue[0] === this.value[0] && guardedValue[1] === this.value[1])) { return; } if (!this.isMobile) { var element = guardedValue[0] !== this.value[0] ? this.nativeLeft.nativeElement : this.nativeRight.nativeElement; setNativeFocused(element); } this.updateValue(guardedValue); this.nativeLeft.nativeElement.value = formatNumber(guardedValue[0]); }; TuiInputRangeComponent.prototype.onLeftFocused = function (focused) { if (focused || !this.nativeLeft) { return; } var inputValue = maskedNumberStringToNumber(this.computedValueLeft); var value = isNaN(inputValue) ? this.min : this.valueGuard(inputValue); this.nativeLeft.nativeElement.value = formatNumber(value); if (value !== this.value[0]) { this.updateValue([value, this.value[1]]); } }; TuiInputRangeComponent.prototype.onRightFocused = function (focused) { if (focused || !this.nativeRight) { return; } var inputValue = maskedNumberStringToNumber(this.computedValueRight); var value = isNaN(inputValue) ? this.value[0] : this.valueGuard(Math.max(inputValue, this.value[0])); this.nativeRight.nativeElement.value = formatNumber(value); if (value !== this.value[1]) { this.updateValue([this.value[0], value]); } }; TuiInputRangeComponent.prototype.getFallbackValue = function () { return [0, 0]; }; TuiInputRangeComponent.prototype.processStep = function (increment, right) { var start = this.valueGuard(increment ? this.value[0] + this.step : this.value[0] - this.step); var end = this.valueGuard(increment ? this.value[1] + this.step : this.value[1] - this.step); var value = [ right ? this.value[0] : Math.min(start, this.value[1]), right ? Math.max(end, this.value[0]) : this.value[1], ]; if (value[0] !== this.value[0] || value[1] !== this.value[1]) { this.updateValue(value); } }; var TuiInputRangeComponent_1; TuiInputRangeComponent.ctorParameters = function () { return [ { type: NgControl, decorators: [{ type: Optional }, { type: Self }, { type: Inject, args: [NgControl,] }] }, { type: ChangeDetectorRef, decorators: [{ type: Inject, args: [ChangeDetectorRef,] }] }, { type: TuiModeDirective, decorators: [{ type: Optional }, { type: Inject, args: [TuiModeDirective,] }] }, { type: Boolean, decorators: [{ type: Inject, args: [TUI_IS_MOBILE,] }] } ]; }; __decorate([ ViewChild('nativeLeft') ], TuiInputRangeComponent.prototype, "nativeLeft", void 0); __decorate([ ViewChild('nativeRight') ], TuiInputRangeComponent.prototype, "nativeRight", void 0); __decorate([ HostBinding('class._min-label') ], TuiInputRangeComponent.prototype, "showMinLabel", null); __decorate([ HostBinding('class._max-label') ], TuiInputRangeComponent.prototype, "showMaxLabel", null); TuiInputRangeComponent = TuiInputRangeComponent_1 = __decorate([ Component({ selector: 'tui-input-range', template: "<div class=\"zone\" (tuiActiveZoneChange)=\"onActiveZone($event)\">\n <tui-wrapper\n appearance=\"textfield\"\n [readOnly]=\"readOnly\"\n [disabled]=\"disabled\"\n [focused]=\"computedFocused\"\n [hovered]=\"computedHovered\"\n [invalid]=\"computedInvalid\"\n >\n <span\n *ngIf=\"hasPlaceholder\"\n class=\"placeholder\"\n automation-id=\"tui-input-range__placeholder\"\n >\n <ng-content></ng-content>\n </span>\n <div class=\"content\">\n <span *ngIf=\"!showMinLabel\" class=\"label\">\n <span class=\"value\">{{inputValueLeft}}</span>\n <span\n *ngIf=\"isPluralized(pluralize)\"\n class=\"pluralize\"\n automation-id=\"tui-input-range__pluralize-left\"\n >\n {{value[0] | tuiPluralize: pluralize}}\n </span>\n </span>\n <span\n *ngIf=\"showMinLabel\"\n class=\"label\"\n automation-id=\"tui-input-range__min-label\"\n >\n {{minLabel}}\n </span>\n <span\n *ngIf=\"showMaxLabel\"\n automation-id=\"tui-input-range__max-label\"\n class=\"max\"\n >\n {{maxLabel}}\n </span>\n </div>\n <tui-range\n class=\"slider\"\n [min]=\"min\"\n [max]=\"max\"\n [steps]=\"computedSteps\"\n [segments]=\"segments\"\n [keySteps]=\"keySteps\"\n [pluralize]=\"segmentsPluralize\"\n [focusable]=\"false\"\n [disabled]=\"readOnly || disabled\"\n [ngModel]=\"value\"\n (ngModelChange)=\"onRangeValue($event)\"\n (mousedown.prevent)=\"onMouseDown()\"\n ></tui-range>\n </tui-wrapper>\n\n <div class=\"native-wrapper\" (tuiHoveredChange)=\"onHovered($event)\">\n <input\n #nativeLeft\n class=\"native\"\n automation-id=\"tui-input-range__native-left\"\n [disabled]=\"disabled\"\n [readOnly]=\"readOnly\"\n [class.native_hidden]=\"showMinLabel\"\n [tuiInputMode]=\"inputMode\"\n [tuiFocusable]=\"focusable\"\n [textMask]=\"quantum | tuiMapper: mask: min\"\n [ngModel]=\"computedValueLeft\"\n (ngModelChange)=\"onInputLeft()\"\n (tuiFocusedChange)=\"onLeftFocused($event)\"\n (keydown.arrowUp)=\"onKeyDownArrowUpLeft($event)\"\n (keydown.arrowDown)=\"onKeyDownArrowDownLeft($event)\"\n />\n <input\n #nativeRight\n class=\"native native_right\"\n automation-id=\"tui-input-range__native-right\"\n [disabled]=\"disabled\"\n [readOnly]=\"readOnly\"\n [class.native_hidden]=\"showMaxLabel\"\n [tuiInputMode]=\"inputMode\"\n [tuiFocusable]=\"focusable\"\n [textMask]=\"quantum | tuiMapper: mask: min\"\n [ngModel]=\"computedValueRight\"\n (ngModelChange)=\"onInputRight()\"\n (tuiFocusedChange)=\"onRightFocused($event)\"\n (keydown.arrowUp)=\"onKeyDownArrowUpRight($event)\"\n (keydown.arrowDown)=\"onKeyDownArrowDownRight($event)\"\n />\n <span\n *ngIf=\"isPluralized(pluralize) && !showMaxLabel\"\n class=\"pluralize pluralize_right\"\n automation-id=\"tui-input-range__pluralize-right\"\n (mousedown)=\"onMouseDown()\"\n >\n {{value[1] | tuiPluralize: pluralize}}\n </span>\n </div>\n</div>\n", changeDetection: ChangeDetectionStrategy.OnPush, providers: [ { provide: TUI_FOCUSABLE_ITEM_ACCESSOR, useExisting: forwardRef(function () { return TuiInputRangeComponent_1; }), }, ], styles: [":host{font:var(--tui-font-text-m);position:relative;z-index:0;display:block;border-radius:var(--tui-radius-m);color:var(--tui-text-01)}:host._segmented{border-bottom:26px solid transparent}:host[data-mode=onDark]{color:var(--tui-base-01)}.zone{border-radius:inherit}.native-wrapper{position:absolute;top:0;left:0;width:100%;height:100%;display:flex}.pluralize{display:flex;align-items:center;padding-right:12px;margin-left:-8px}.pluralize_right{margin-left:-12px}:host[data-tui-host-size='l'] .pluralize_right{padding-top:20px}:host._disabled .pluralize_right{color:var(--tui-text-03)}:host[data-mode=onDark]._disabled .pluralize_right{color:var(--tui-text-03-night)}.native{padding:0 16px;border:0;border-radius:inherit;background:0 0;font-size:inherit;line-height:inherit;font-weight:inherit;color:inherit;caret-color:currentColor;-webkit-appearance:none;-moz-appearance:none;appearance:none;word-break:keep-all;-webkit-text-fill-color:currentColor;flex:1;min-width:0;color:var(--tui-text-01);box-sizing:border-box;outline:0}.native:-webkit-autofill,.native:-webkit-autofill:focus,.native:-webkit-autofill:hover{border-radius:inherit;-webkit-text-fill-color:inherit!important;color:inherit!important;background-color:transparent!important;-webkit-box-shadow:0 0 0 1000px var(--tui-autofill) inset!important}.native_right{text-align:right}.native_hidden{opacity:0}:host._disabled .native{color:var(--tui-text-03);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}:host[data-tui-host-size='l'] .native{padding:20px 16px 0}:host[data-mode=onDark] .native{color:var(--tui-text-01-night)}:host[data-mode=onDark]._disabled .native{color:var(--tui-text-03-night)}.content{display:flex;height:var(--tui-height-m);padding:0 16px;justify-content:space-between;align-items:center}:host[data-tui-host-size='l'] .content{height:var(--tui-height-l);padding:0 16px}:host[data-tui-host-size='l']._disabled .content{color:var(--tui-text-03)}:host[data-tui-host-size='l'][data-mode=onDark]._disabled .content{color:var(--tui-text-03-night)}.placeholder{transition-property:transform,min-width,color,letter-spacing;transition-duration:.3s;transition-timing-function:ease-in-out;font:var(--tui-font-text-s);color:var(--tui-text-01);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;font-size:13px;box-sizing:border-box;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;color:var(--tui-text-02);transform-origin:left;letter-spacing:normal;text-transform:none;position:absolute;top:0;width:100%;height:100%;left:16px;transform:translateY(-10px) scale(.87);line-height:var(--tui-height-l);max-width:calc(114% - 32px)}.placeholder_raised{width:114%;transform:translateY(-10px) scale(.87)}:host[data-tui-host-size='m'] .placeholder_raised{width:118%;transform:translateY(-8px) scale(.85);letter-spacing:.4px}:host._invalid:not(._focused) .placeholder_raised,:host._invalid:not(._focused)._hovered .placeholder_raised{color:var(--tui-error-fill)}:host[data-mode=onDark]._invalid:not(._focused) .placeholder_raised,:host[data-mode=onDark]._invalid:not(._focused)._hovered .placeholder_raised{color:var(--tui-error-fill-night)}:host._focused .placeholder,:host[data-tui-host-size='l']._focused._label-outside .placeholder,:host[data-tui-host-size='m']._focused._label-outside .placeholder{color:var(--tui-text-03)}:host[data-tui-host-size='l'] .placeholder{font-size:15px}:host[data-tui-host-size='l']._focused:not(._label-outside) .placeholder,:host[data-tui-host-size='m']._focused:not(._label-outside) .placeholder{color:var(--tui-text-01)}:host[data-mode=onDark] .placeholder{color:var(--tui-text-02-night)}:host[data-tui-host-size='l'][data-mode=onDark]._focused:not(._label-outside) .placeholder,:host[data-tui-host-size='m'][data-mode=onDark]._focused:not(._label-outside) .placeholder{color:var(--tui-text-01-night)}:host[data-mode=onDark]._focused .placeholder,:host[data-tui-host-size='l'][data-mode=onDark]._focused._label-outside .placeholder,:host[data-tui-host-size='m'][data-mode=onDark]._focused._label-outside .placeholder{color:var(--tui-text-02-night)}.value{visibility:hidden;overflow:hidden;padding-right:12px}:host._disabled .value{color:var(--tui-text-03)}.label{display:flex;width:50%}:host[data-tui-host-size='l'] .label{padding-top:20px}.max{text-align:right;flex:1}:host[data-tui-host-size='l'] .max{padding-top:20px;line-height:calc(var(--tui-height-l) - 20px)}.slider{position:absolute;top:100%;left:0;right:0;z-index:1;border-top-left-radius:0;border-top-right-radius:0;margin:-9px 0 0;color:transparent}:host._disabled .slider,:host._readonly .slider{pointer-events:none}"] }), __param(0, Optional()), __param(0, Self()), __param(0, Inject(NgControl)), __param(1, Inject(ChangeDetectorRef)), __param(2, Optional()), __param(2, Inject(TuiModeDirective)), __param(3, Inject(TUI_IS_MOBILE)) ], TuiInputRangeComponent); return TuiInputRangeComponent; }(AbstractTuiInputSlider)); export { TuiInputRangeComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-range.component.js","sourceRoot":"ng://@taiga-ui/kit/components/input-range/","sources":["input-range.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    forwardRef,\n    HostBinding,\n    Inject,\n    Optional,\n    Self,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {\n    isNativeFocused,\n    setNativeFocused,\n    TUI_FOCUSABLE_ITEM_ACCESSOR,\n    TUI_IS_MOBILE,\n    TuiFocusableElementAccessor,\n    TuiNativeFocusableElement,\n} from '@taiga-ui/cdk';\nimport {\n    formatNumber,\n    maskedMoneyValueIsEmpty,\n    maskedNumberStringToNumber,\n    TuiModeDirective,\n} from '@taiga-ui/core';\nimport {AbstractTuiInputSlider} from '@taiga-ui/kit/abstract';\n\n// @dynamic\n@Component({\n    selector: 'tui-input-range',\n    templateUrl: './input-range.template.html',\n    styleUrls: ['./input-range.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: TUI_FOCUSABLE_ITEM_ACCESSOR,\n            useExisting: forwardRef(() => TuiInputRangeComponent),\n        },\n    ],\n})\nexport class TuiInputRangeComponent\n    extends AbstractTuiInputSlider<[number, number]>\n    implements TuiFocusableElementAccessor {\n    @ViewChild('nativeLeft')\n    private readonly nativeLeft?: ElementRef<HTMLInputElement>;\n\n    @ViewChild('nativeRight')\n    private readonly nativeRight?: ElementRef<HTMLInputElement>;\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) changeDetectorRef: ChangeDetectorRef,\n        @Optional()\n        @Inject(TuiModeDirective)\n        protected readonly modeDirective: TuiModeDirective | null,\n        @Inject(TUI_IS_MOBILE) private readonly isMobile: boolean,\n    ) {\n        super(control, changeDetectorRef);\n    }\n\n    get nativeFocusableElement(): TuiNativeFocusableElement | null {\n        return !this.nativeLeft || this.disabled ? null : this.nativeLeft.nativeElement;\n    }\n\n    get focused(): boolean {\n        return this.focusedLeft || this.focusedRight;\n    }\n\n    get focusedLeft(): boolean {\n        return !!this.nativeLeft && isNativeFocused(this.nativeLeft.nativeElement);\n    }\n\n    get focusedRight(): boolean {\n        return !!this.nativeRight && isNativeFocused(this.nativeRight.nativeElement);\n    }\n\n    @HostBinding('class._min-label')\n    get showMinLabel(): boolean {\n        return !this.focusedLeft && !!this.minLabel && this.value[0] === this.min;\n    }\n\n    @HostBinding('class._max-label')\n    get showMaxLabel(): boolean {\n        return !this.focusedRight && !!this.maxLabel && this.value[1] === this.max;\n    }\n\n    get inputValueLeft(): string {\n        return this.nativeLeft ? this.nativeLeft.nativeElement.value : '';\n    }\n\n    get inputValueRight(): string {\n        return this.nativeRight ? this.nativeRight.nativeElement.value : '';\n    }\n\n    get computedValueLeft(): string {\n        return formatNumber(this.value[0]);\n    }\n\n    get computedValueRight(): string {\n        return formatNumber(this.value[1]);\n    }\n\n    onActiveZone(active: boolean) {\n        this.updateFocused(active);\n    }\n\n    onMouseDown() {\n        if (this.nativeRight && !this.isMobile) {\n            setNativeFocused(this.nativeRight.nativeElement);\n        }\n    }\n\n    onKeyDownArrowUpLeft(event: KeyboardEvent) {\n        if (this.readOnly) {\n            return;\n        }\n\n        event.preventDefault();\n        this.processStep(true, false);\n    }\n\n    onKeyDownArrowDownLeft(event: KeyboardEvent) {\n        if (this.readOnly) {\n            return;\n        }\n\n        event.preventDefault();\n        this.processStep(false, false);\n    }\n\n    onKeyDownArrowUpRight(event: KeyboardEvent) {\n        if (this.readOnly) {\n            return;\n        }\n\n        event.preventDefault();\n        this.processStep(true, true);\n    }\n\n    onKeyDownArrowDownRight(event: KeyboardEvent) {\n        if (this.readOnly) {\n            return;\n        }\n\n        event.preventDefault();\n        this.processStep(false, true);\n    }\n\n    onInputLeft() {\n        const value = this.inputValueLeft;\n        const capped = this.capInputValue(value, this.value[1]);\n        const postfix = value.slice(-1)[0] === ',' ? ',' : '';\n\n        if (maskedMoneyValueIsEmpty(value) || capped === null) {\n            return;\n        }\n\n        const newValue = formatNumber(capped) + postfix;\n\n        if (this.nativeLeft && this.inputValueLeft !== newValue) {\n            this.nativeLeft.nativeElement.value = newValue;\n        }\n\n        this.updateValue([capped, this.value[1]]);\n    }\n\n    onInputRight() {\n        const value = this.inputValueRight;\n        const capped = this.capInputValue(value);\n        const postfix = value.slice(-1)[0] === ',' ? ',' : '';\n\n        if (maskedMoneyValueIsEmpty(value) || capped === null) {\n            return;\n        }\n\n        const newValue = formatNumber(capped) + postfix;\n\n        if (this.nativeRight && this.inputValueRight !== newValue) {\n            this.nativeRight.nativeElement.value = newValue;\n        }\n\n        if (capped >= this.value[0]) {\n            this.updateValue([this.value[0], capped]);\n        }\n    }\n\n    onRangeValue(value: [number, number]) {\n        const guardedValue = value.map(item => this.valueGuard(item)) as [number, number];\n\n        if (\n            !this.nativeLeft ||\n            !this.nativeRight ||\n            (guardedValue[0] === this.value[0] && guardedValue[1] === this.value[1])\n        ) {\n            return;\n        }\n\n        if (!this.isMobile) {\n            const element =\n                guardedValue[0] !== this.value[0]\n                    ? this.nativeLeft.nativeElement\n                    : this.nativeRight.nativeElement;\n\n            setNativeFocused(element);\n        }\n\n        this.updateValue(guardedValue);\n        this.nativeLeft.nativeElement.value = formatNumber(guardedValue[0]);\n    }\n\n    onLeftFocused(focused: boolean) {\n        if (focused || !this.nativeLeft) {\n            return;\n        }\n\n        const inputValue = maskedNumberStringToNumber(this.computedValueLeft);\n        const value = isNaN(inputValue) ? this.min : this.valueGuard(inputValue);\n\n        this.nativeLeft.nativeElement.value = formatNumber(value);\n\n        if (value !== this.value[0]) {\n            this.updateValue([value, this.value[1]]);\n        }\n    }\n\n    onRightFocused(focused: boolean) {\n        if (focused || !this.nativeRight) {\n            return;\n        }\n\n        const inputValue = maskedNumberStringToNumber(this.computedValueRight);\n        const value = isNaN(inputValue)\n            ? this.value[0]\n            : this.valueGuard(Math.max(inputValue, this.value[0]));\n\n        this.nativeRight.nativeElement.value = formatNumber(value);\n\n        if (value !== this.value[1]) {\n            this.updateValue([this.value[0], value]);\n        }\n    }\n\n    protected getFallbackValue(): [number, number] {\n        return [0, 0];\n    }\n\n    private processStep(increment: boolean, right: boolean) {\n        const start = this.valueGuard(\n            increment ? this.value[0] + this.step : this.value[0] - this.step,\n        );\n        const end = this.valueGuard(\n            increment ? this.value[1] + this.step : this.value[1] - this.step,\n        );\n        const value: [number, number] = [\n            right ? this.value[0] : Math.min(start, this.value[1]),\n            right ? Math.max(end, this.value[0]) : this.value[1],\n        ];\n\n        if (value[0] !== this.value[0] || value[1] !== this.value[1]) {\n            this.updateValue(value);\n        }\n    }\n}\n"]}