UNPKG

@taiga-ui/kit

Version:

Taiga UI Angular main components kit

103 lines 15.2 kB
import { computed, Directive, effect, inject, Input, signal } from '@angular/core'; import { MaskitoDirective } from '@maskito/angular'; import { maskitoNumberOptionsGenerator } from '@maskito/kit'; import { tuiAsControl, TuiControl, tuiValueTransformerFrom } from '@taiga-ui/cdk/classes'; import { TUI_ALLOW_SIGNAL_WRITES } from '@taiga-ui/cdk/constants'; import { TuiCalendarYear } from '@taiga-ui/core/components/calendar'; import { tuiInjectAuxiliary, TuiTextfieldDirective, tuiTextfieldIconBinding, TuiWithTextfield, } from '@taiga-ui/core/components/textfield'; import { TuiDropdownAuto, tuiDropdownEnabled, tuiDropdownOpen, } from '@taiga-ui/core/directives/dropdown'; import { tuiMaskito } from '@taiga-ui/kit/utils'; import { TUI_INPUT_YEAR_OPTIONS } from './input-year.options'; import * as i0 from "@angular/core"; import * as i1 from "@taiga-ui/core/components/textfield"; import * as i2 from "@maskito/angular"; import * as i3 from "@taiga-ui/core/directives/dropdown"; class TuiInputYearDirective extends TuiControl { constructor() { super(...arguments); this.options = inject(TUI_INPUT_YEAR_OPTIONS); this.textfield = inject(TuiTextfieldDirective); this.open = tuiDropdownOpen(); this.initialItem = computed(() => this.value() ?? this.calendar()?.initialItem() ?? null); this.calendar = tuiInjectAuxiliary((x) => x instanceof TuiCalendarYear); this.dropdownEnabled = tuiDropdownEnabled(this.interactive); this.icon = tuiTextfieldIconBinding(TUI_INPUT_YEAR_OPTIONS); this.min = signal(this.options.min.year); this.max = signal(this.options.max.year); /** * TODO: move to [value]="value()" after update to Angular 17+ * something wrong with change detection on host binding */ this.valueEffect = effect(() => this.textfield.value.set(this.value()?.toString() ?? ''), TUI_ALLOW_SIGNAL_WRITES); this.mask = tuiMaskito(computed(() => maskitoNumberOptionsGenerator({ min: this.min(), max: this.max(), thousandSeparator: '', }))); this.calendarInEffect = effect(() => { const calendar = this.calendar(); if (calendar) { calendar.initialItemSetter = this.initialItem(); calendar.value.set(this.value()); calendar.min.set(this.min()); calendar.max.set(this.max()); } }, TUI_ALLOW_SIGNAL_WRITES); this.calendarOutEffect = effect((onCleanup) => { const subscription = this.calendar()?.yearClick.subscribe((year) => { this.onChange(year); this.open.set(false); }); onCleanup(() => subscription?.unsubscribe()); }); } // TODO(v5): use signal inputs set minSetter(x) { this.min.set(x); } // TODO(v5): use signal inputs set maxSetter(x) { this.max.set(x); } toggle() { if (this.interactive()) { this.open.update((x) => !x); } } onInput(raw) { const value = Number(raw); this.onChange(!raw || Number.isNaN(value) ? null : value); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputYearDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputYearDirective, isStandalone: true, selector: "input[tuiInputYear]", inputs: { minSetter: ["min", "minSetter"], maxSetter: ["max", "maxSetter"] }, host: { attributes: { "maxlength": "4", "inputmode": "numeric" }, listeners: { "click": "toggle()", "input": "onInput($event.target.value)" }, properties: { "disabled": "disabled()" } }, providers: [ tuiAsControl(TuiInputYearDirective), tuiValueTransformerFrom(TUI_INPUT_YEAR_OPTIONS), ], usesInheritance: true, hostDirectives: [{ directive: i1.TuiWithTextfield }, { directive: i2.MaskitoDirective }, { directive: i3.TuiDropdownAuto }], ngImport: i0 }); } } export { TuiInputYearDirective }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputYearDirective, decorators: [{ type: Directive, args: [{ standalone: true, selector: 'input[tuiInputYear]', providers: [ tuiAsControl(TuiInputYearDirective), tuiValueTransformerFrom(TUI_INPUT_YEAR_OPTIONS), ], hostDirectives: [TuiWithTextfield, MaskitoDirective, TuiDropdownAuto], host: { maxlength: '4', inputmode: 'numeric', '[disabled]': 'disabled()', '(click)': 'toggle()', '(input)': 'onInput($event.target.value)', }, }] }], propDecorators: { minSetter: [{ type: Input, args: ['min'] }], maxSetter: [{ type: Input, args: ['max'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-year.directive.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-year/input-year.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {computed, Directive, effect, inject, Input, signal} from '@angular/core';\nimport {MaskitoDirective} from '@maskito/angular';\nimport {maskitoNumberOptionsGenerator} from '@maskito/kit';\nimport {tuiAsControl, TuiControl, tuiValueTransformerFrom} from '@taiga-ui/cdk/classes';\nimport {TUI_ALLOW_SIGNAL_WRITES} from '@taiga-ui/cdk/constants';\nimport {TuiCalendarYear} from '@taiga-ui/core/components/calendar';\nimport {\n    tuiInjectAuxiliary,\n    TuiTextfieldDirective,\n    tuiTextfieldIconBinding,\n    TuiWithTextfield,\n} from '@taiga-ui/core/components/textfield';\nimport {\n    TuiDropdownAuto,\n    tuiDropdownEnabled,\n    tuiDropdownOpen,\n} from '@taiga-ui/core/directives/dropdown';\nimport {tuiMaskito} from '@taiga-ui/kit/utils';\n\nimport {TUI_INPUT_YEAR_OPTIONS} from './input-year.options';\n\n@Directive({\n    standalone: true,\n    selector: 'input[tuiInputYear]',\n    providers: [\n        tuiAsControl(TuiInputYearDirective),\n        tuiValueTransformerFrom(TUI_INPUT_YEAR_OPTIONS),\n    ],\n    hostDirectives: [TuiWithTextfield, MaskitoDirective, TuiDropdownAuto],\n    host: {\n        maxlength: '4',\n        inputmode: 'numeric',\n        '[disabled]': 'disabled()',\n        '(click)': 'toggle()',\n        '(input)': 'onInput($event.target.value)',\n    },\n})\nexport class TuiInputYearDirective extends TuiControl<number | null> {\n    private readonly options = inject(TUI_INPUT_YEAR_OPTIONS);\n    private readonly textfield = inject(TuiTextfieldDirective);\n    private readonly open = tuiDropdownOpen();\n\n    private readonly initialItem = computed(\n        () => this.value() ?? this.calendar()?.initialItem() ?? null,\n    );\n\n    protected readonly calendar = tuiInjectAuxiliary<TuiCalendarYear>(\n        (x) => x instanceof TuiCalendarYear,\n    );\n\n    protected readonly dropdownEnabled = tuiDropdownEnabled(this.interactive);\n    protected readonly icon = tuiTextfieldIconBinding(TUI_INPUT_YEAR_OPTIONS);\n    protected readonly min = signal(this.options.min.year);\n    protected readonly max = signal(this.options.max.year);\n\n    /**\n     * TODO: move to [value]=\"value()\" after update to Angular 17+\n     * something wrong with change detection on host binding\n     */\n    protected readonly valueEffect = effect(\n        () => this.textfield.value.set(this.value()?.toString() ?? ''),\n        TUI_ALLOW_SIGNAL_WRITES,\n    );\n\n    protected readonly mask = tuiMaskito(\n        computed(() =>\n            maskitoNumberOptionsGenerator({\n                min: this.min(),\n                max: this.max(),\n                thousandSeparator: '',\n            }),\n        ),\n    );\n\n    protected readonly calendarInEffect = effect(() => {\n        const calendar = this.calendar();\n\n        if (calendar) {\n            calendar.initialItemSetter = this.initialItem();\n            calendar.value.set(this.value());\n            calendar.min.set(this.min());\n            calendar.max.set(this.max());\n        }\n    }, TUI_ALLOW_SIGNAL_WRITES);\n\n    protected readonly calendarOutEffect = effect((onCleanup) => {\n        const subscription = this.calendar()?.yearClick.subscribe((year) => {\n            this.onChange(year);\n            this.open.set(false);\n        });\n\n        onCleanup(() => subscription?.unsubscribe());\n    });\n\n    // TODO(v5): use signal inputs\n    @Input('min')\n    public set minSetter(x: number) {\n        this.min.set(x);\n    }\n\n    // TODO(v5): use signal inputs\n    @Input('max')\n    public set maxSetter(x: number) {\n        this.max.set(x);\n    }\n\n    protected toggle(): void {\n        if (this.interactive()) {\n            this.open.update((x) => !x);\n        }\n    }\n\n    protected onInput(raw: string): void {\n        const value = Number(raw);\n\n        this.onChange(!raw || Number.isNaN(value) ? null : value);\n    }\n}\n"]}