@taiga-ui/kit
Version:
Taiga UI Angular main components kit
208 lines • 29.9 kB
JavaScript
import { __decorate, __extends, __param } from "tslib";
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, forwardRef, HostBinding, Inject, Input, Optional, Self, ViewChild, } from '@angular/core';
import { NgControl } from '@angular/forms';
import { isNativeFocused, setNativeFocused, TUI_FOCUSABLE_ITEM_ACCESSOR, tuiDefaultProp, } from '@taiga-ui/cdk';
import { formatNumber, HINT_CONTROLLER_PROVIDER, maskedMoneyValueIsEmpty, maskedNumberStringToNumber, TUI_HINT_WATCHED_CONTROLLER, TuiHintControllerDirective, TuiModeDirective, } from '@taiga-ui/core';
import { AbstractTuiInputSlider } from '@taiga-ui/kit/abstract';
// @dynamic
var TuiInputSliderComponent = /** @class */ (function (_super) {
__extends(TuiInputSliderComponent, _super);
function TuiInputSliderComponent(control, changeDetectorRef, modeDirective, hintController) {
var _this = _super.call(this, control, changeDetectorRef) || this;
_this.modeDirective = modeDirective;
_this.hintController = hintController;
_this.secondary = '';
return _this;
}
TuiInputSliderComponent_1 = TuiInputSliderComponent;
Object.defineProperty(TuiInputSliderComponent.prototype, "nativeFocusableElement", {
get: function () {
return !this.focusableElement || this.computedDisabled
? null
: this.focusableElement.nativeElement;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TuiInputSliderComponent.prototype, "focused", {
get: function () {
return isNativeFocused(this.nativeFocusableElement);
},
enumerable: true,
configurable: true
});
Object.defineProperty(TuiInputSliderComponent.prototype, "hasTooltip", {
get: function () {
return !!this.hintController.content && !this.disabled;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TuiInputSliderComponent.prototype, "showMinLabel", {
get: function () {
return !this.focused && this.value === this.min && !!this.minLabel;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TuiInputSliderComponent.prototype, "showMaxLabel", {
get: function () {
return !this.focused && this.value === this.max && !!this.maxLabel;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TuiInputSliderComponent.prototype, "computedValue", {
get: function () {
if (this.focused && this.isInputValueNotFinished) {
return this.inputValue;
}
return this.formattedValue;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TuiInputSliderComponent.prototype, "showValue", {
get: function () {
return !this.showMinLabel && !this.showMaxLabel;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TuiInputSliderComponent.prototype, "inputValue", {
get: function () {
return this.focusableElement ? this.focusableElement.nativeElement.value : '';
},
set: function (value) {
if (this.focusableElement) {
this.focusableElement.nativeElement.value = value;
}
},
enumerable: true,
configurable: true
});
TuiInputSliderComponent.prototype.onMouseDown = function () {
if (this.focusableElement) {
setNativeFocused(this.focusableElement.nativeElement);
}
};
TuiInputSliderComponent.prototype.onKeyDownArrowUp = function (event) {
if (this.readOnly) {
return;
}
event.preventDefault();
this.processStep(true);
this.inputValue = this.formattedValue;
};
TuiInputSliderComponent.prototype.onKeyDownArrowDown = function (event) {
if (this.readOnly) {
return;
}
event.preventDefault();
this.processStep(false);
this.inputValue = this.formattedValue;
};
TuiInputSliderComponent.prototype.onFocused = function (focused) {
this.updateFocused(focused);
if (focused) {
return;
}
var inputValue = maskedNumberStringToNumber(this.computedValue);
var value = isNaN(inputValue) ? this.min : this.valueGuard(inputValue);
this.updateValue(value);
this.inputValue = this.formattedValue;
};
TuiInputSliderComponent.prototype.onValue = function (value) {
var capped = this.capInputValue(value);
var postfix = value.slice(-1)[0] === ',' ? ',' : '';
if (maskedMoneyValueIsEmpty(value) || capped === null) {
return;
}
var newValue = formatNumber(capped) + postfix;
if (value !== newValue) {
this.inputValue = newValue;
}
this.updateValue(capped);
};
TuiInputSliderComponent.prototype.onSliderValue = function (value) {
this.updateValue(this.valueGuard(value));
this.inputValue = this.formattedValue;
};
TuiInputSliderComponent.prototype.getFallbackValue = function () {
return 0;
};
Object.defineProperty(TuiInputSliderComponent.prototype, "formattedValue", {
get: function () {
return formatNumber(this.value);
},
enumerable: true,
configurable: true
});
Object.defineProperty(TuiInputSliderComponent.prototype, "isInputValueNotFinished", {
get: function () {
if (this.inputValue === '') {
return true;
}
var nativeNumberValue = maskedNumberStringToNumber(this.inputValue);
return nativeNumberValue < 0
? nativeNumberValue > this.max
: nativeNumberValue < this.min;
},
enumerable: true,
configurable: true
});
TuiInputSliderComponent.prototype.processStep = function (increment) {
var value = this.valueGuard(increment ? this.value + this.step : this.value - this.step);
if (value !== this.value) {
this.updateValue(value);
}
};
var TuiInputSliderComponent_1;
TuiInputSliderComponent.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: TuiHintControllerDirective, decorators: [{ type: Inject, args: [TUI_HINT_WATCHED_CONTROLLER,] }] }
]; };
__decorate([
Input(),
tuiDefaultProp()
], TuiInputSliderComponent.prototype, "secondary", void 0);
__decorate([
ViewChild('focusableElement')
], TuiInputSliderComponent.prototype, "focusableElement", void 0);
__decorate([
HostBinding('class._has-tooltip')
], TuiInputSliderComponent.prototype, "hasTooltip", null);
__decorate([
HostBinding('class._min-label')
], TuiInputSliderComponent.prototype, "showMinLabel", null);
__decorate([
HostBinding('class._max-label')
], TuiInputSliderComponent.prototype, "showMaxLabel", null);
TuiInputSliderComponent = TuiInputSliderComponent_1 = __decorate([
Component({
selector: 'tui-input-slider',
template: "<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-slider__placeholder\"\n >\n <ng-content></ng-content>\n </span>\n <input\n #focusableElement\n class=\"native\"\n automation-id=\"tui-input-slider__native\"\n [disabled]=\"disabled\"\n [readOnly]=\"readOnly\"\n [tuiInputMode]=\"inputMode\"\n [tuiFocusable]=\"focusable\"\n [textMask]=\"quantum | tuiMapper: mask: min\"\n [ngModel]=\"computedValue\"\n (ngModelChange)=\"onValue($event)\"\n (tuiFocusedChange)=\"onFocused($event)\"\n (tuiHoveredChange)=\"onHovered($event)\"\n (keydown.arrowUp)=\"onKeyDownArrowUp($event)\"\n (keydown.arrowDown)=\"onKeyDownArrowDown($event)\"\n />\n <div class=\"content\">\n <span *ngIf=\"showValue\" class=\"label\">\n <span class=\"value\">{{computedValue}}</span>\n <span\n *ngIf=\"isPluralized(pluralize)\"\n automation-id=\"tui-input-slider__pluralize\"\n >\n {{value | tuiPluralize: pluralize}}\n </span>\n </span>\n <span\n *ngIf=\"showMinLabel\"\n class=\"label\"\n automation-id=\"tui-input-slider__min-label\"\n >\n {{minLabel}}\n </span>\n <span\n *ngIf=\"showMaxLabel\"\n class=\"label\"\n automation-id=\"tui-input-slider__max-label\"\n >\n {{maxLabel}}\n </span>\n <span class=\"secondary\" automation-id=\"tui-input-slider__secondary\">\n {{secondary}}\n <tui-tooltip\n *ngIf=\"hasTooltip\"\n automation-id=\"tui-input-slider__tooltip\"\n class=\"tooltip\"\n describeId=\"placeholer_until_accesibility_is_added\"\n [content]=\"hintController.content\"\n [direction]=\"hintController.direction\"\n [mode]=\"hintController.mode\"\n (mousedown.prevent)=\"onMouseDown()\"\n ></tui-tooltip>\n </span>\n </div>\n</tui-wrapper>\n<tui-slider\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)=\"onSliderValue($event)\"\n (mousedown)=\"onMouseDown()\"\n></tui-slider>\n",
changeDetection: ChangeDetectionStrategy.OnPush,
providers: [
{
provide: TUI_FOCUSABLE_ITEM_ACCESSOR,
useExisting: forwardRef(function () { return TuiInputSliderComponent_1; }),
},
HINT_CONTROLLER_PROVIDER,
],
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}.native{position:absolute;top:0;left:0;height:100%;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;width:100%;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}:host._disabled .native{color:var(--tui-text-03);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}:host._max-label .native,:host._min-label .native{opacity:0}: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;align-items:center;height:var(--tui-height-m);padding:0 16px;justify-content:space-between}:host[data-tui-host-size='l'] .content{height:var(--tui-height-l);padding:0 16px}.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)}:host._has-tooltip .placeholder{max-width:calc(114% - 60px)}.value{visibility:hidden}.label{line-height:15px;overflow:hidden;text-overflow:ellipsis}:host[data-tui-host-size='l'] .label{padding-top:20px}.secondary{color:var(--tui-text-01)}:host._disabled .secondary{color:var(--tui-text-03)}:host[data-mode=onDark]._disabled .secondary{color:var(--tui-text-03-night)}.tooltip{margin-left:12px}.slider{position:absolute;top:100%;left:0;right:0;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_HINT_WATCHED_CONTROLLER))
], TuiInputSliderComponent);
return TuiInputSliderComponent;
}(AbstractTuiInputSlider));
export { TuiInputSliderComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-slider.component.js","sourceRoot":"ng://@taiga-ui/kit/components/input-slider/","sources":["input-slider.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    Input,\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    tuiDefaultProp,\n    TuiFocusableElementAccessor,\n    TuiNativeFocusableElement,\n} from '@taiga-ui/cdk';\nimport {\n    formatNumber,\n    HINT_CONTROLLER_PROVIDER,\n    maskedMoneyValueIsEmpty,\n    maskedNumberStringToNumber,\n    TUI_HINT_WATCHED_CONTROLLER,\n    TuiHintControllerDirective,\n    TuiModeDirective,\n} from '@taiga-ui/core';\nimport {AbstractTuiInputSlider} from '@taiga-ui/kit/abstract';\n\n// @dynamic\n@Component({\n    selector: 'tui-input-slider',\n    templateUrl: './input-slider.template.html',\n    styleUrls: ['./input-slider.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: TUI_FOCUSABLE_ITEM_ACCESSOR,\n            useExisting: forwardRef(() => TuiInputSliderComponent),\n        },\n        HINT_CONTROLLER_PROVIDER,\n    ],\n})\nexport class TuiInputSliderComponent\n    extends AbstractTuiInputSlider<number>\n    implements TuiFocusableElementAccessor {\n    @Input()\n    @tuiDefaultProp()\n    secondary = '';\n\n    @ViewChild('focusableElement')\n    private readonly focusableElement?: 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_HINT_WATCHED_CONTROLLER)\n        readonly hintController: TuiHintControllerDirective,\n    ) {\n        super(control, changeDetectorRef);\n    }\n\n    get nativeFocusableElement(): TuiNativeFocusableElement | null {\n        return !this.focusableElement || this.computedDisabled\n            ? null\n            : this.focusableElement.nativeElement;\n    }\n\n    get focused(): boolean {\n        return isNativeFocused(this.nativeFocusableElement);\n    }\n\n    @HostBinding('class._has-tooltip')\n    get hasTooltip(): boolean {\n        return !!this.hintController.content && !this.disabled;\n    }\n\n    @HostBinding('class._min-label')\n    get showMinLabel(): boolean {\n        return !this.focused && this.value === this.min && !!this.minLabel;\n    }\n\n    @HostBinding('class._max-label')\n    get showMaxLabel(): boolean {\n        return !this.focused && this.value === this.max && !!this.maxLabel;\n    }\n\n    get computedValue(): string {\n        if (this.focused && this.isInputValueNotFinished) {\n            return this.inputValue;\n        }\n\n        return this.formattedValue;\n    }\n\n    get showValue(): boolean {\n        return !this.showMinLabel && !this.showMaxLabel;\n    }\n\n    get inputValue(): string {\n        return this.focusableElement ? this.focusableElement.nativeElement.value : '';\n    }\n\n    set inputValue(value: string) {\n        if (this.focusableElement) {\n            this.focusableElement.nativeElement.value = value;\n        }\n    }\n\n    onMouseDown() {\n        if (this.focusableElement) {\n            setNativeFocused(this.focusableElement.nativeElement);\n        }\n    }\n\n    onKeyDownArrowUp(event: KeyboardEvent) {\n        if (this.readOnly) {\n            return;\n        }\n\n        event.preventDefault();\n        this.processStep(true);\n        this.inputValue = this.formattedValue;\n    }\n\n    onKeyDownArrowDown(event: KeyboardEvent) {\n        if (this.readOnly) {\n            return;\n        }\n\n        event.preventDefault();\n        this.processStep(false);\n        this.inputValue = this.formattedValue;\n    }\n\n    onFocused(focused: boolean) {\n        this.updateFocused(focused);\n\n        if (focused) {\n            return;\n        }\n\n        const inputValue = maskedNumberStringToNumber(this.computedValue);\n        const value = isNaN(inputValue) ? this.min : this.valueGuard(inputValue);\n\n        this.updateValue(value);\n        this.inputValue = this.formattedValue;\n    }\n\n    onValue(value: string) {\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 (value !== newValue) {\n            this.inputValue = newValue;\n        }\n\n        this.updateValue(capped);\n    }\n\n    onSliderValue(value: number) {\n        this.updateValue(this.valueGuard(value));\n        this.inputValue = this.formattedValue;\n    }\n\n    protected getFallbackValue(): number {\n        return 0;\n    }\n\n    private get formattedValue(): string {\n        return formatNumber(this.value);\n    }\n\n    private get isInputValueNotFinished(): boolean {\n        if (this.inputValue === '') {\n            return true;\n        }\n\n        const nativeNumberValue = maskedNumberStringToNumber(this.inputValue);\n\n        return nativeNumberValue < 0\n            ? nativeNumberValue > this.max\n            : nativeNumberValue < this.min;\n    }\n\n    private processStep(increment: boolean) {\n        const value = this.valueGuard(\n            increment ? this.value + this.step : this.value - this.step,\n        );\n\n        if (value !== this.value) {\n            this.updateValue(value);\n        }\n    }\n}\n"]}