@taiga-ui/kit
Version:
Taiga UI Angular main components kit
118 lines • 19.4 kB
JavaScript
import { ChangeDetectionStrategy, Component, computed, Directive, effect, inject, ViewEncapsulation, } from '@angular/core';
import { TUI_IDENTITY_VALUE_TRANSFORMER, TuiNonNullableValueTransformer, TuiValueTransformer, } from '@taiga-ui/cdk/classes';
import { TUI_ALLOW_SIGNAL_WRITES } from '@taiga-ui/cdk/constants';
import { TUI_IS_MOBILE } from '@taiga-ui/cdk/tokens';
import { tuiInjectElement, tuiIsElement, tuiIsInput } from '@taiga-ui/cdk/utils/dom';
import { tuiClamp } from '@taiga-ui/cdk/utils/math';
import { tuiWithStyles } from '@taiga-ui/cdk/utils/miscellaneous';
import { tuiInjectAuxiliary } from '@taiga-ui/core/components/textfield';
import { TuiInputNumberDirective, tuiInputNumberOptionsProvider, } from '@taiga-ui/kit/components/input-number';
import { TuiSliderComponent } from '@taiga-ui/kit/components/slider';
import { filter, fromEvent } from 'rxjs';
import * as i0 from "@angular/core";
import * as i1 from "@taiga-ui/kit/components/input-number";
class TuiInputSliderDirective {
constructor() {
this.isMobile = inject(TUI_IS_MOBILE);
this.element = tuiInjectElement();
this.inputNumber = inject(TuiInputNumberDirective, { self: true });
this.slider = tuiInjectAuxiliary((x) => x instanceof TuiSliderComponent);
this.controlTransformer = inject(TuiValueTransformer, { self: true });
this.value = computed(() => this.controlTransformer.toControlValue(this.inputNumber.value()));
this.keyStepsTransformer = computed(() => this.slider()?.keySteps?.transformer() ?? TUI_IDENTITY_VALUE_TRANSFORMER);
this.nothing = tuiWithStyles(TuiInputSliderStyles);
this.textfieldToSliderSync = effect(() => {
const slider = this.slider();
if (!slider) {
return;
}
if (slider.keySteps?.transformer() &&
Number.isFinite(slider.keySteps?.totalSteps)) {
// TODO(v5): move all if-condition body inside `TuiSliderKeyStepsBase`
slider.min = 0;
slider.step = 1;
slider.max = slider.keySteps?.totalSteps ?? 100;
}
else {
slider.min = this.inputNumber.min();
slider.max = this.inputNumber.max();
}
slider.value = this.keyStepsTransformer().fromControlValue(this.value());
slider.el.disabled = !this.inputNumber.interactive();
}, TUI_ALLOW_SIGNAL_WRITES);
this.sliderInitEffect = effect((onCleanup) => {
const slider = this.slider();
if (!slider) {
return;
}
slider.el.style.setProperty('--tui-slider-track-color', 'transparent');
if (slider.keySteps) {
slider.keySteps.value = this.value;
}
const subscription = fromEvent(slider.el, 'input', (x) => x.target)
.pipe(filter(tuiIsElement), filter(tuiIsInput))
.subscribe((x) => this.onSliderInput(x.valueAsNumber));
onCleanup(() => subscription.unsubscribe());
});
}
onStep(coefficient) {
const slider = this.slider();
if (slider && this.inputNumber.interactive()) {
const newValue = tuiClamp(slider.keySteps?.takeStep(coefficient) ??
slider.value + coefficient * slider.step, this.inputNumber.min(), this.inputNumber.max());
this.inputNumber.setValue(newValue);
}
}
onBlur() {
if (!this.element.value) {
this.inputNumber.setValue(this.value() ?? null);
}
}
onSliderInput(value) {
this.inputNumber.setValue(this.keyStepsTransformer().toControlValue(value));
if (!this.isMobile) {
this.element.focus();
}
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputSliderDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputSliderDirective, isStandalone: true, selector: "input[tuiInputSlider]", host: { listeners: { "blur": "onBlur()", "keydown.arrowUp": "onStep(1)", "keydown.arrowDown": "onStep(-1)" } }, providers: [
tuiInputNumberOptionsProvider({
valueTransformer: new TuiNonNullableValueTransformer(),
}),
], hostDirectives: [{ directive: i1.TuiInputNumberDirective, inputs: ["min", "min", "max", "max", "prefix", "prefix", "postfix", "postfix", "invalid", "invalid", "readOnly", "readOnly"] }], ngImport: i0 }); }
}
export { TuiInputSliderDirective };
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputSliderDirective, decorators: [{
type: Directive,
args: [{
standalone: true,
selector: 'input[tuiInputSlider]',
providers: [
tuiInputNumberOptionsProvider({
valueTransformer: new TuiNonNullableValueTransformer(),
}),
],
hostDirectives: [
{
directive: TuiInputNumberDirective,
inputs: ['min', 'max', 'prefix', 'postfix', 'invalid', 'readOnly'],
},
],
host: {
'(blur)': 'onBlur()',
'(keydown.arrowUp)': 'onStep(1)',
'(keydown.arrowDown)': 'onStep(-1)',
},
}]
}] });
class TuiInputSliderStyles {
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputSliderStyles, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputSliderStyles, isStandalone: true, selector: "ng-component", host: { classAttribute: "tui-input-slider" }, ngImport: i0, template: '', isInline: true, styles: ["tui-textfield [tuiInputSlider]~.t-content .t-clear{display:none!important}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputSliderStyles, decorators: [{
type: Component,
args: [{ standalone: true, template: '', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, host: {
class: 'tui-input-slider',
}, styles: ["tui-textfield [tuiInputSlider]~.t-content .t-clear{display:none!important}\n"] }]
}] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-slider.directive.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-slider/input-slider.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    Directive,\n    effect,\n    inject,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {\n    TUI_IDENTITY_VALUE_TRANSFORMER,\n    TuiNonNullableValueTransformer,\n    TuiValueTransformer,\n} from '@taiga-ui/cdk/classes';\nimport {TUI_ALLOW_SIGNAL_WRITES} from '@taiga-ui/cdk/constants';\nimport {TUI_IS_MOBILE} from '@taiga-ui/cdk/tokens';\nimport {tuiInjectElement, tuiIsElement, tuiIsInput} from '@taiga-ui/cdk/utils/dom';\nimport {tuiClamp} from '@taiga-ui/cdk/utils/math';\nimport {tuiWithStyles} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {tuiInjectAuxiliary} from '@taiga-ui/core/components/textfield';\nimport {\n    TuiInputNumberDirective,\n    tuiInputNumberOptionsProvider,\n} from '@taiga-ui/kit/components/input-number';\nimport {TuiSliderComponent} from '@taiga-ui/kit/components/slider';\nimport {filter, fromEvent} from 'rxjs';\n\n@Directive({\n    standalone: true,\n    selector: 'input[tuiInputSlider]',\n    providers: [\n        tuiInputNumberOptionsProvider({\n            valueTransformer: new TuiNonNullableValueTransformer(),\n        }),\n    ],\n    hostDirectives: [\n        {\n            directive: TuiInputNumberDirective,\n            inputs: ['min', 'max', 'prefix', 'postfix', 'invalid', 'readOnly'],\n        },\n    ],\n    host: {\n        '(blur)': 'onBlur()',\n        '(keydown.arrowUp)': 'onStep(1)',\n        '(keydown.arrowDown)': 'onStep(-1)',\n    },\n})\nexport class TuiInputSliderDirective {\n    private readonly isMobile = inject(TUI_IS_MOBILE);\n    private readonly element = tuiInjectElement<HTMLInputElement>();\n    private readonly inputNumber = inject(TuiInputNumberDirective, {self: true});\n    private readonly slider = tuiInjectAuxiliary<TuiSliderComponent>(\n        (x) => x instanceof TuiSliderComponent,\n    );\n\n    private readonly controlTransformer = inject<\n        TuiValueTransformer<number | null, number>\n    >(TuiValueTransformer, {self: true});\n\n    private readonly value = computed(() =>\n        this.controlTransformer.toControlValue(this.inputNumber.value()),\n    );\n\n    private readonly keyStepsTransformer = computed(\n        () => this.slider()?.keySteps?.transformer() ?? TUI_IDENTITY_VALUE_TRANSFORMER,\n    );\n\n    protected readonly nothing = tuiWithStyles(TuiInputSliderStyles);\n\n    protected readonly textfieldToSliderSync = effect(() => {\n        const slider = this.slider();\n\n        if (!slider) {\n            return;\n        }\n\n        if (\n            slider.keySteps?.transformer() &&\n            Number.isFinite(slider.keySteps?.totalSteps)\n        ) {\n            // TODO(v5): move all if-condition body inside `TuiSliderKeyStepsBase`\n            slider.min = 0;\n            slider.step = 1;\n            slider.max = slider.keySteps?.totalSteps ?? 100;\n        } else {\n            slider.min = this.inputNumber.min();\n            slider.max = this.inputNumber.max();\n        }\n\n        slider.value = this.keyStepsTransformer().fromControlValue(this.value());\n        slider.el.disabled = !this.inputNumber.interactive();\n    }, TUI_ALLOW_SIGNAL_WRITES);\n\n    protected readonly sliderInitEffect = effect((onCleanup) => {\n        const slider = this.slider();\n\n        if (!slider) {\n            return;\n        }\n\n        slider.el.style.setProperty('--tui-slider-track-color', 'transparent');\n\n        if (slider.keySteps) {\n            slider.keySteps.value = this.value;\n        }\n\n        const subscription = fromEvent(slider.el, 'input', (x) => x.target)\n            .pipe(filter(tuiIsElement), filter(tuiIsInput))\n            .subscribe((x) => this.onSliderInput(x.valueAsNumber));\n\n        onCleanup(() => subscription.unsubscribe());\n    });\n\n    protected onStep(coefficient: number): void {\n        const slider = this.slider();\n\n        if (slider && this.inputNumber.interactive()) {\n            const newValue = tuiClamp(\n                slider.keySteps?.takeStep(coefficient) ??\n                    slider.value + coefficient * slider.step,\n                this.inputNumber.min(),\n                this.inputNumber.max(),\n            );\n\n            this.inputNumber.setValue(newValue);\n        }\n    }\n\n    protected onBlur(): void {\n        if (!this.element.value) {\n            this.inputNumber.setValue(this.value() ?? null);\n        }\n    }\n\n    private onSliderInput(value: number): void {\n        this.inputNumber.setValue(this.keyStepsTransformer().toControlValue(value));\n\n        if (!this.isMobile) {\n            this.element.focus();\n        }\n    }\n}\n\n@Component({\n    standalone: true,\n    template: '',\n    styles: [\n        // TODO: tui-textfield:has([tuiInputSlider]) .t-clear\n        'tui-textfield [tuiInputSlider] ~ .t-content .t-clear {display: none !important}',\n    ],\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        class: 'tui-input-slider',\n    },\n})\nclass TuiInputSliderStyles {}\n"]}