UNPKG

@taiga-ui/kit

Version:

Taiga UI Angular main components kit

109 lines 14.6 kB
import { __decorate } from "tslib"; import { Directive, forwardRef, inject, INJECTOR, Input, signal } from '@angular/core'; import { toSignal } from '@angular/core/rxjs-interop'; import { NgControl } from '@angular/forms'; import { TuiControl } from '@taiga-ui/cdk/classes'; import { tuiControlValue } from '@taiga-ui/cdk/observables'; import { tuiFallbackValueProvider } from '@taiga-ui/cdk/tokens'; import { tuiPure } from '@taiga-ui/cdk/utils/miscellaneous'; import { switchMap, timer } from 'rxjs'; import { TuiSliderComponent } from '../slider.component'; import { tuiCreateKeyStepsTransformer } from './key-steps'; import * as i0 from "@angular/core"; class TuiSliderKeyStepsBase { constructor() { this.injector = inject(INJECTOR); this.control = inject(NgControl, { self: true, optional: true }); this.step = 1; this.transformer = signal(null); this.value = toSignal(timer(0) // https://github.com/angular/angular/issues/54418 .pipe(switchMap(() => tuiControlValue(this.control)))); } get slider() { return this.injector.get(TuiSliderComponent); } set keySteps(steps) { this.transformer.set(steps && tuiCreateKeyStepsTransformer(steps, this.slider)); this.min = steps?.[0][1]; this.max = steps?.[steps.length - 1]?.[1]; } /** * TODO(v5): standardize logic between `TuiSlider` & `TuiInputSlider` (for non-linear slider `step` means percentage) * Add these host-bindings to `TuiSliderKeyStepsBase`: * ``` * host: { * '[attr.min]': '0', * '[attr.step]': '1', * '[attr.max]': 'totalSteps', * }, * ``` */ get totalSteps() { /** * Not-integer amount of steps is invalid usage of native sliders * ```html * <input type="range" [max]="100" [step]="3.33" /> * ``` * (impossible to select 100; 99.9 is max allowed value) */ return this.step ? Math.round(100 / this.step) : Infinity; } takeStep(coefficient) { const newValue = this.slider.value + coefficient; return (this.transformer()?.toControlValue(this.slider.value + coefficient) ?? newValue); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiSliderKeyStepsBase, deps: [], target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "16.2.12", type: TuiSliderKeyStepsBase, isStandalone: true, selector: "input[tuiSlider][keySteps]", inputs: { step: ["step", "step", (x) => (x === 'any' ? null : x)], keySteps: "keySteps" }, host: { properties: { "attr.aria-valuemin": "min", "attr.aria-valuemax": "max", "attr.aria-valuenow": "value()" } }, ngImport: i0 }); } } __decorate([ tuiPure ], TuiSliderKeyStepsBase.prototype, "slider", null); export { TuiSliderKeyStepsBase }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiSliderKeyStepsBase, decorators: [{ type: Directive, args: [{ standalone: true, selector: 'input[tuiSlider][keySteps]', host: { '[attr.aria-valuemin]': 'min', '[attr.aria-valuemax]': 'max', '[attr.aria-valuenow]': 'value()', }, }] }], propDecorators: { step: [{ type: Input, args: [{ transform: (x) => (x === 'any' ? null : x) }] }], slider: [], keySteps: [{ type: Input }] } }); class TuiSliderKeySteps extends TuiControl { constructor() { super(...arguments); this.slider = inject(forwardRef(() => TuiSliderComponent)); } set keySteps(steps) { this.transformer = tuiCreateKeyStepsTransformer(steps, this.slider); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiSliderKeySteps, deps: null, target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiSliderKeySteps, isStandalone: true, selector: "input[tuiSlider][keySteps][ngModel],input[tuiSlider][keySteps][formControl],input[tuiSlider][keySteps][formControlName]", inputs: { keySteps: "keySteps" }, host: { listeners: { "blur": "onTouched()", "input": "onChange($event.target.value)", "change": "onChange($event.target.value)" }, properties: { "value": "value()", "disabled": "disabled()" } }, providers: [tuiFallbackValueProvider(0)], usesInheritance: true, ngImport: i0 }); } } export { TuiSliderKeySteps }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiSliderKeySteps, decorators: [{ type: Directive, args: [{ standalone: true, selector: 'input[tuiSlider][keySteps][ngModel],input[tuiSlider][keySteps][formControl],input[tuiSlider][keySteps][formControlName]', providers: [tuiFallbackValueProvider(0)], host: { '[value]': 'value()', '[disabled]': 'disabled()', '(blur)': 'onTouched()', '(input)': 'onChange($event.target.value)', '(change)': 'onChange($event.target.value)', }, }] }], propDecorators: { keySteps: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider-key-steps.directive.js","sourceRoot":"","sources":["../../../../../../projects/kit/components/slider/helpers/slider-key-steps.directive.ts"],"names":[],"mappings":";AAAA,OAAO,EAAC,SAAS,EAAE,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,EAAC,MAAM,eAAe,CAAC;AACrF,OAAO,EAAC,QAAQ,EAAC,MAAM,4BAA4B,CAAC;AACpD,OAAO,EAAC,SAAS,EAAC,MAAM,gBAAgB,CAAC;AAEzC,OAAO,EAAC,UAAU,EAAC,MAAM,uBAAuB,CAAC;AACjD,OAAO,EAAC,eAAe,EAAC,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EAAC,wBAAwB,EAAC,MAAM,sBAAsB,CAAC;AAC9D,OAAO,EAAC,OAAO,EAAC,MAAM,mCAAmC,CAAC;AAC1D,OAAO,EAAC,SAAS,EAAE,KAAK,EAAC,MAAM,MAAM,CAAC;AAEtC,OAAO,EAAC,kBAAkB,EAAC,MAAM,qBAAqB,CAAC;AAEvD,OAAO,EAAC,4BAA4B,EAAC,MAAM,aAAa,CAAC;;AAEzD,MASa,qBAAqB;IATlC;QAUqB,aAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;QAC5B,YAAO,GAAG,MAAM,CAAC,SAAS,EAAE,EAAC,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAC;QAMpE,SAAI,GAAkB,CAAC,CAAC;QAExB,gBAAW,GAAG,MAAM,CAA6C,IAAI,CAAC,CAAC;QACvE,UAAK,GAAG,QAAQ,CACnB,KAAK,CAAC,CAAC,CAAC,CAAC,kDAAkD;aACtD,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,eAAe,CAAS,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CACpE,CAAC;KA4CL;IAzCG,IAAW,MAAM;QACb,OAAO,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC;IACjD,CAAC;IAED,IACW,QAAQ,CAAC,KAAyB;QACzC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,IAAI,4BAA4B,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;QAChF,IAAI,CAAC,GAAG,GAAG,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACzB,IAAI,CAAC,GAAG,GAAG,KAAK,EAAE,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAC9C,CAAC;IAED;;;;;;;;;;OAUG;IACH,IAAW,UAAU;QACjB;;;;;;WAMG;QACH,OAAO,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC;IAC9D,CAAC;IAEM,QAAQ,CAAC,WAAmB;QAC/B,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,WAAW,CAAC;QAEjD,OAAO,CACH,IAAI,CAAC,WAAW,EAAE,EAAE,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,WAAW,CAAC;YACnE,QAAQ,CACX,CAAC;IACN,CAAC;+GAzDQ,qBAAqB;mGAArB,qBAAqB,+FAOX,CAAC,CAAiB,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;;AAUlE;IADC,OAAO;mDAGP;SAnBQ,qBAAqB;4FAArB,qBAAqB;kBATjC,SAAS;mBAAC;oBACP,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE,4BAA4B;oBACtC,IAAI,EAAE;wBACF,sBAAsB,EAAE,KAAK;wBAC7B,sBAAsB,EAAE,KAAK;wBAC7B,sBAAsB,EAAE,SAAS;qBACpC;iBACJ;8BASU,IAAI;sBADV,KAAK;uBAAC,EAAC,SAAS,EAAE,CAAC,CAAiB,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,EAAC;gBAUxD,MAAM,MAKN,QAAQ;sBADlB,KAAK;;AAuCV,MAaa,iBAAkB,SAAQ,UAAkB;IAbzD;;QAcqB,WAAM,GAAG,MAAM,CAC5B,UAAU,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC,CACvC,CAAC;KAML;IAJG,IACW,QAAQ,CAAC,KAAkB;QAClC,IAAI,CAAC,WAAW,GAAG,4BAA4B,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IACxE,CAAC;+GARQ,iBAAiB;mGAAjB,iBAAiB,2YATf,CAAC,wBAAwB,CAAC,CAAC,CAAC,CAAC;;SAS/B,iBAAiB;4FAAjB,iBAAiB;kBAb7B,SAAS;mBAAC;oBACP,UAAU,EAAE,IAAI;oBAChB,QAAQ,EACJ,yHAAyH;oBAC7H,SAAS,EAAE,CAAC,wBAAwB,CAAC,CAAC,CAAC,CAAC;oBACxC,IAAI,EAAE;wBACF,SAAS,EAAE,SAAS;wBACpB,YAAY,EAAE,YAAY;wBAC1B,QAAQ,EAAE,aAAa;wBACvB,SAAS,EAAE,+BAA+B;wBAC1C,UAAU,EAAE,+BAA+B;qBAC9C;iBACJ;8BAOc,QAAQ;sBADlB,KAAK","sourcesContent":["import {Directive, forwardRef, inject, INJECTOR, Input, signal} from '@angular/core';\nimport {toSignal} from '@angular/core/rxjs-interop';\nimport {NgControl} from '@angular/forms';\nimport type {TuiValueTransformer} from '@taiga-ui/cdk/classes';\nimport {TuiControl} from '@taiga-ui/cdk/classes';\nimport {tuiControlValue} from '@taiga-ui/cdk/observables';\nimport {tuiFallbackValueProvider} from '@taiga-ui/cdk/tokens';\nimport {tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {switchMap, timer} from 'rxjs';\n\nimport {TuiSliderComponent} from '../slider.component';\nimport type {TuiKeySteps} from './key-steps';\nimport {tuiCreateKeyStepsTransformer} from './key-steps';\n\n@Directive({\n    standalone: true,\n    selector: 'input[tuiSlider][keySteps]',\n    host: {\n        '[attr.aria-valuemin]': 'min',\n        '[attr.aria-valuemax]': 'max',\n        '[attr.aria-valuenow]': 'value()',\n    },\n})\nexport class TuiSliderKeyStepsBase {\n    private readonly injector = inject(INJECTOR);\n    private readonly control = inject(NgControl, {self: true, optional: true});\n\n    protected min?: number;\n    protected max?: number;\n\n    @Input({transform: (x: number | 'any') => (x === 'any' ? null : x)})\n    public step: number | null = 1;\n\n    public transformer = signal<TuiValueTransformer<number, number> | null>(null);\n    public value = toSignal(\n        timer(0) // https://github.com/angular/angular/issues/54418\n            .pipe(switchMap(() => tuiControlValue<number>(this.control))),\n    );\n\n    @tuiPure\n    public get slider(): TuiSliderComponent {\n        return this.injector.get(TuiSliderComponent);\n    }\n\n    @Input()\n    public set keySteps(steps: TuiKeySteps | null) {\n        this.transformer.set(steps && tuiCreateKeyStepsTransformer(steps, this.slider));\n        this.min = steps?.[0][1];\n        this.max = steps?.[steps.length - 1]?.[1];\n    }\n\n    /**\n     * TODO(v5): standardize logic between `TuiSlider` & `TuiInputSlider` (for non-linear slider `step` means percentage)\n     * Add these host-bindings to `TuiSliderKeyStepsBase`:\n     * ```\n     * host: {\n     *     '[attr.min]': '0',\n     *     '[attr.step]': '1',\n     *     '[attr.max]': 'totalSteps',\n     * },\n     * ```\n     */\n    public get totalSteps(): number {\n        /**\n         * Not-integer amount of steps is invalid usage of native sliders\n         * ```html\n         * <input type=\"range\" [max]=\"100\" [step]=\"3.33\" />\n         * ```\n         * (impossible to select 100; 99.9 is max allowed value)\n         */\n        return this.step ? Math.round(100 / this.step) : Infinity;\n    }\n\n    public takeStep(coefficient: number): number {\n        const newValue = this.slider.value + coefficient;\n\n        return (\n            this.transformer()?.toControlValue(this.slider.value + coefficient) ??\n            newValue\n        );\n    }\n}\n\n@Directive({\n    standalone: true,\n    selector:\n        'input[tuiSlider][keySteps][ngModel],input[tuiSlider][keySteps][formControl],input[tuiSlider][keySteps][formControlName]',\n    providers: [tuiFallbackValueProvider(0)],\n    host: {\n        '[value]': 'value()',\n        '[disabled]': 'disabled()',\n        '(blur)': 'onTouched()',\n        '(input)': 'onChange($event.target.value)',\n        '(change)': 'onChange($event.target.value)',\n    },\n})\nexport class TuiSliderKeySteps extends TuiControl<number> {\n    private readonly slider = inject<TuiSliderComponent>(\n        forwardRef(() => TuiSliderComponent),\n    );\n\n    @Input()\n    public set keySteps(steps: TuiKeySteps) {\n        this.transformer = tuiCreateKeyStepsTransformer(steps, this.slider);\n    }\n}\n"]}