@taiga-ui/kit
Version:
Taiga UI Angular main components kit
86 lines • 13.7 kB
JavaScript
import { Directive, effect, inject, signal } from '@angular/core';
import { toSignal } from '@angular/core/rxjs-interop';
import { tuiAsControl, TuiControl, tuiValueTransformerFrom } from '@taiga-ui/cdk/classes';
import { TUI_ALLOW_SIGNAL_WRITES } from '@taiga-ui/cdk/constants';
import { RANGE_SEPARATOR_CHAR, TuiMonthRange, } from '@taiga-ui/cdk/date-time';
import { tuiInjectAuxiliary, TuiSelectLike, TuiTextfieldDirective, tuiTextfieldIconBinding, TuiWithTextfield, } from '@taiga-ui/core/components/textfield';
import { TuiDropdownAuto, tuiDropdownEnabled, tuiDropdownOpen, } from '@taiga-ui/core/directives/dropdown';
import { TuiCalendarMonth } from '@taiga-ui/kit/components/calendar-month';
import { TUI_MONTH_FORMATTER } from '@taiga-ui/kit/tokens';
import { TUI_INPUT_MONTH_RANGE_OPTIONS } from './input-month-range.options';
import * as i0 from "@angular/core";
import * as i1 from "@taiga-ui/core/components/textfield";
import * as i2 from "@taiga-ui/core/directives/dropdown";
class TuiInputMonthRangeDirective extends TuiControl {
constructor() {
super(...arguments);
this.textfield = inject(TuiTextfieldDirective);
this.formatter = toSignal(inject(TUI_MONTH_FORMATTER));
this.open = tuiDropdownOpen();
this.intermediateValue = signal(null);
this.calendar = tuiInjectAuxiliary((x) => x instanceof TuiCalendarMonth);
this.icon = tuiTextfieldIconBinding(TUI_INPUT_MONTH_RANGE_OPTIONS);
this.dropdownEnabled = tuiDropdownEnabled(this.interactive);
this.valueEffect = effect(() => {
const value = this.value();
const format = this.formatter() || (() => '');
const string = value
? format(value.from) + RANGE_SEPARATOR_CHAR + format(value.to)
: '';
this.textfield.value.set(string);
}, TUI_ALLOW_SIGNAL_WRITES);
this.calendarInit = effect(() => {
const calendar = this.calendar();
if (calendar) {
calendar.options.rangeMode = true;
}
});
this.calendarSync = effect(() => {
this.calendar()?.value.set(this.intermediateValue() ?? this.value());
}, TUI_ALLOW_SIGNAL_WRITES);
// TODO: use linked signal (Angular 19+)
this.resetIntermediateValue = effect(() => {
this.intermediateValue.set(this.value() && null);
}, TUI_ALLOW_SIGNAL_WRITES);
this.onMonthClickEffect = effect((onCleanup) => {
const subscription = this.calendar()?.monthClick.subscribe((month) => {
const intermediateValue = this.intermediateValue();
if (!intermediateValue) {
this.intermediateValue.set(month);
}
else {
this.onChange(TuiMonthRange.sort(intermediateValue, month));
this.open.set(false);
}
});
onCleanup(() => subscription?.unsubscribe());
});
}
clear() {
this.onChange(null);
this.open.set(true);
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputMonthRangeDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputMonthRangeDirective, isStandalone: true, selector: "input[tuiInputMonthRange]", host: { listeners: { "input": "$event.inputType?.includes(\"delete\") && clear()" }, properties: { "disabled": "disabled()" } }, providers: [
tuiAsControl(TuiInputMonthRangeDirective),
tuiValueTransformerFrom(TUI_INPUT_MONTH_RANGE_OPTIONS),
], usesInheritance: true, hostDirectives: [{ directive: i1.TuiWithTextfield }, { directive: i1.TuiSelectLike }, { directive: i2.TuiDropdownAuto }], ngImport: i0 }); }
}
export { TuiInputMonthRangeDirective };
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputMonthRangeDirective, decorators: [{
type: Directive,
args: [{
standalone: true,
selector: 'input[tuiInputMonthRange]',
providers: [
tuiAsControl(TuiInputMonthRangeDirective),
tuiValueTransformerFrom(TUI_INPUT_MONTH_RANGE_OPTIONS),
],
hostDirectives: [TuiWithTextfield, TuiSelectLike, TuiDropdownAuto],
host: {
'[disabled]': 'disabled()',
'(input)': '$event.inputType?.includes("delete") && clear()',
},
}]
}] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-month-range.directive.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-month-range/input-month-range.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, effect, inject, signal} from '@angular/core';\nimport {toSignal} from '@angular/core/rxjs-interop';\nimport {tuiAsControl, TuiControl, tuiValueTransformerFrom} from '@taiga-ui/cdk/classes';\nimport {TUI_ALLOW_SIGNAL_WRITES} from '@taiga-ui/cdk/constants';\nimport {\n    RANGE_SEPARATOR_CHAR,\n    type TuiMonth,\n    TuiMonthRange,\n} from '@taiga-ui/cdk/date-time';\nimport {\n    tuiInjectAuxiliary,\n    TuiSelectLike,\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 {TuiCalendarMonth} from '@taiga-ui/kit/components/calendar-month';\nimport {TUI_MONTH_FORMATTER} from '@taiga-ui/kit/tokens';\n\nimport {TUI_INPUT_MONTH_RANGE_OPTIONS} from './input-month-range.options';\n\n@Directive({\n    standalone: true,\n    selector: 'input[tuiInputMonthRange]',\n    providers: [\n        tuiAsControl(TuiInputMonthRangeDirective),\n        tuiValueTransformerFrom(TUI_INPUT_MONTH_RANGE_OPTIONS),\n    ],\n    hostDirectives: [TuiWithTextfield, TuiSelectLike, TuiDropdownAuto],\n    host: {\n        '[disabled]': 'disabled()',\n        '(input)': '$event.inputType?.includes(\"delete\") && clear()',\n    },\n})\nexport class TuiInputMonthRangeDirective extends TuiControl<TuiMonthRange | null> {\n    private readonly textfield = inject(TuiTextfieldDirective);\n    private readonly formatter = toSignal(inject(TUI_MONTH_FORMATTER));\n    private readonly open = tuiDropdownOpen();\n    private readonly intermediateValue = signal<TuiMonth | null>(null);\n\n    private readonly calendar = tuiInjectAuxiliary<TuiCalendarMonth>(\n        (x) => x instanceof TuiCalendarMonth,\n    );\n\n    protected readonly icon = tuiTextfieldIconBinding(TUI_INPUT_MONTH_RANGE_OPTIONS);\n    protected readonly dropdownEnabled = tuiDropdownEnabled(this.interactive);\n\n    protected readonly valueEffect = effect(() => {\n        const value = this.value();\n        const format = this.formatter() || (() => '');\n        const string = value\n            ? format(value.from) + RANGE_SEPARATOR_CHAR + format(value.to)\n            : '';\n\n        this.textfield.value.set(string);\n    }, TUI_ALLOW_SIGNAL_WRITES);\n\n    protected readonly calendarInit = effect(() => {\n        const calendar = this.calendar();\n\n        if (calendar) {\n            calendar.options.rangeMode = true;\n        }\n    });\n\n    protected readonly calendarSync = effect(() => {\n        this.calendar()?.value.set(this.intermediateValue() ?? this.value());\n    }, TUI_ALLOW_SIGNAL_WRITES);\n\n    // TODO: use linked signal (Angular 19+)\n    protected readonly resetIntermediateValue = effect(() => {\n        this.intermediateValue.set(this.value() && null);\n    }, TUI_ALLOW_SIGNAL_WRITES);\n\n    protected onMonthClickEffect = effect((onCleanup) => {\n        const subscription = this.calendar()?.monthClick.subscribe((month) => {\n            const intermediateValue = this.intermediateValue();\n\n            if (!intermediateValue) {\n                this.intermediateValue.set(month);\n            } else {\n                this.onChange(TuiMonthRange.sort(intermediateValue, month));\n                this.open.set(false);\n            }\n        });\n\n        onCleanup(() => subscription?.unsubscribe());\n    });\n\n    protected clear(): void {\n        this.onChange(null);\n        this.open.set(true);\n    }\n}\n"]}