UNPKG

@taiga-ui/kit

Version:

Taiga UI Angular main components kit

159 lines 25.3 kB
import { computed, Directive, effect, inject, Input, signal } from '@angular/core'; import { toSignal } from '@angular/core/rxjs-interop'; import { MaskitoDirective } from '@maskito/angular'; import { maskitoDateOptionsGenerator } from '@maskito/kit'; import { tuiAsControl, TuiControl, tuiValueTransformerFrom } from '@taiga-ui/cdk/classes'; import { TUI_ALLOW_SIGNAL_WRITES } from '@taiga-ui/cdk/constants'; import { DATE_FILLER_LENGTH, TuiDay } from '@taiga-ui/cdk/date-time'; import { TUI_IS_MOBILE } from '@taiga-ui/cdk/tokens'; import { tuiInjectElement } from '@taiga-ui/cdk/utils/dom'; import { changeDateSeparator, tuiDirectiveBinding, } from '@taiga-ui/cdk/utils/miscellaneous'; import { TuiCalendar } from '@taiga-ui/core/components/calendar'; import { tuiAsOptionContent } from '@taiga-ui/core/components/data-list'; import { tuiInjectAuxiliary, TuiTextfieldComponent, TuiTextfieldDirective, tuiTextfieldIconBinding, TuiWithTextfield, } from '@taiga-ui/core/components/textfield'; import { TuiDropdownAuto, tuiDropdownEnabled, tuiDropdownOpen, } from '@taiga-ui/core/directives/dropdown'; import { TUI_ITEMS_HANDLERS, TuiItemsHandlersDirective, TuiItemsHandlersValidator, } from '@taiga-ui/core/directives/items-handlers'; import { TUI_DATE_FORMAT, TUI_DEFAULT_DATE_FORMAT } from '@taiga-ui/core/tokens'; import { TuiCalendarRange } from '@taiga-ui/kit/components/calendar-range'; import { TuiSelectOption } from '@taiga-ui/kit/components/select'; import { TUI_DATE_TEXTS } from '@taiga-ui/kit/tokens'; import { tuiMaskito } from '@taiga-ui/kit/utils'; import { TUI_INPUT_DATE_OPTIONS_NEW } from './input-date.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"; import * as i3 from "@taiga-ui/core/directives/items-handlers"; import * as i4 from "@maskito/angular"; export const TUI_DATE_ADAPTER = { DMY: 'dd/mm/yyyy', MDY: 'mm/dd/yyyy', YMD: 'yyyy/mm/dd', }; class TuiInputDateBase extends TuiControl { constructor() { super(...arguments); this.el = tuiInjectElement(); this.options = inject(TUI_INPUT_DATE_OPTIONS_NEW); this.handlers = inject(TuiItemsHandlersDirective); this.textfield = inject(TuiTextfieldDirective); this.texts = toSignal(inject(TUI_DATE_TEXTS)); this.calendar = tuiInjectAuxiliary((x) => x instanceof TuiCalendar || x instanceof TuiCalendarRange); this.filler = tuiDirectiveBinding(TuiTextfieldComponent, 'fillerSetter', computed(() => { const { mode, separator } = this.format(); const texts = this.texts() || ''; return texts && changeDateSeparator(texts[mode], separator); }), {}); this.mobile = inject(TUI_IS_MOBILE); this.open = tuiDropdownOpen(); this.icon = tuiTextfieldIconBinding(TUI_INPUT_DATE_OPTIONS_NEW); this.dropdownEnabled = tuiDropdownEnabled(computed(() => !this.native && this.interactive())); this.format = toSignal(inject(TUI_DATE_FORMAT), { initialValue: TUI_DEFAULT_DATE_FORMAT, }); this.mask = tuiMaskito(computed(() => maskitoDateOptionsGenerator({ separator: this.format().separator, mode: TUI_DATE_ADAPTER[this.format().mode], min: this.min().toLocalNativeDate(), max: this.max().toLocalNativeDate(), }))); this.valueEffect = effect(() => { const value = this.value()?.toString(this.format().mode, this.format().separator) ?? (this.filler().length === this.el.value.length ? '' : this.el.value); this.textfield.value.set(value); }, TUI_ALLOW_SIGNAL_WRITES); this.calendarIn = effect(() => { if (this.calendar()) { this.processCalendar(this.calendar()); } }, TUI_ALLOW_SIGNAL_WRITES); this.calendarOut = effect((onCleanup) => { const subscription = this.calendar()?.valueChange.subscribe((value) => { this.onChange(value); this.open.set(false); if (!this.el.closest('tui-dropdown')) { this.el.blur(); } }); onCleanup(() => subscription?.unsubscribe()); }); this.native = this.el.type === 'date' && this.mobile; this.min = signal(this.options.min); this.max = signal(this.options.max); } set minSetter(min) { this.min.set(min || this.options.min); } set maxSetter(max) { this.max.set(max || this.options.max); } processCalendar(calendar) { calendar.value = this.value(); calendar.disabledItemHandler = this.handlers.disabledItemHandler(); calendar.min = this.min(); calendar.max = this.max(); } onClick() { if (!this.mobile) { this.open.update((open) => !open); } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputDateBase, deps: null, target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputDateBase, isStandalone: true, inputs: { minSetter: ["min", "minSetter"], maxSetter: ["max", "maxSetter"] }, host: { listeners: { "input": "onValueChange($event.target.value)", "click.capture.stop": "onClick()" }, properties: { "attr.inputmode": "mobile && open() ? \"none\" : \"numeric\"", "disabled": "disabled()" } }, usesInheritance: true, ngImport: i0 }); } } export { TuiInputDateBase }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputDateBase, decorators: [{ type: Directive, args: [{ standalone: true, host: { '[attr.inputmode]': 'mobile && open() ? "none" : "numeric"', '[disabled]': 'disabled()', '(input)': 'onValueChange($event.target.value)', '(click.capture.stop)': 'onClick()', }, }] }], propDecorators: { minSetter: [{ type: Input, args: ['min'] }], maxSetter: [{ type: Input, args: ['max'] }] } }); class TuiInputDateDirective extends TuiInputDateBase { constructor() { super(...arguments); this.identity = inject(TUI_ITEMS_HANDLERS).identityMatcher.set((a, b) => a.daySame(b)); } onValueChange(value) { this.control?.control?.updateValueAndValidity({ emitEvent: false }); this.onChange(value.length === DATE_FILLER_LENGTH ? TuiDay.normalizeParse(value, this.format().mode) : null); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputDateDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputDateDirective, isStandalone: true, selector: "input[tuiInputDate]", providers: [ tuiAsOptionContent(TuiSelectOption), tuiAsControl(TuiInputDateDirective), tuiValueTransformerFrom(TUI_INPUT_DATE_OPTIONS_NEW), ], usesInheritance: true, hostDirectives: [{ directive: i1.TuiWithTextfield }, { directive: i2.TuiDropdownAuto }, { directive: i3.TuiItemsHandlersValidator }, { directive: i4.MaskitoDirective }], ngImport: i0 }); } } export { TuiInputDateDirective }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputDateDirective, decorators: [{ type: Directive, args: [{ standalone: true, selector: 'input[tuiInputDate]', providers: [ tuiAsOptionContent(TuiSelectOption), tuiAsControl(TuiInputDateDirective), tuiValueTransformerFrom(TUI_INPUT_DATE_OPTIONS_NEW), ], hostDirectives: [ TuiWithTextfield, TuiDropdownAuto, TuiItemsHandlersValidator, MaskitoDirective, ], }] }] }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date.directive.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-date/input-date.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAC,MAAM,eAAe,CAAC;AACjF,OAAO,EAAC,QAAQ,EAAC,MAAM,4BAA4B,CAAC;AACpD,OAAO,EAAC,gBAAgB,EAAC,MAAM,kBAAkB,CAAC;AAElD,OAAO,EAAC,2BAA2B,EAAC,MAAM,cAAc,CAAC;AACzD,OAAO,EAAC,YAAY,EAAE,UAAU,EAAE,uBAAuB,EAAC,MAAM,uBAAuB,CAAC;AACxF,OAAO,EAAC,uBAAuB,EAAC,MAAM,yBAAyB,CAAC;AAEhE,OAAO,EAAC,kBAAkB,EAAE,MAAM,EAAC,MAAM,yBAAyB,CAAC;AACnE,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAC,gBAAgB,EAAC,MAAM,yBAAyB,CAAC;AACzD,OAAO,EACH,mBAAmB,EACnB,mBAAmB,GACtB,MAAM,mCAAmC,CAAC;AAC3C,OAAO,EAAC,WAAW,EAAC,MAAM,oCAAoC,CAAC;AAC/D,OAAO,EAAC,kBAAkB,EAAC,MAAM,qCAAqC,CAAC;AACvE,OAAO,EACH,kBAAkB,EAClB,qBAAqB,EACrB,qBAAqB,EACrB,uBAAuB,EACvB,gBAAgB,GACnB,MAAM,qCAAqC,CAAC;AAC7C,OAAO,EACH,eAAe,EACf,kBAAkB,EAClB,eAAe,GAClB,MAAM,oCAAoC,CAAC;AAE5C,OAAO,EACH,kBAAkB,EAClB,yBAAyB,EACzB,yBAAyB,GAC5B,MAAM,0CAA0C,CAAC;AAClD,OAAO,EAAC,eAAe,EAAE,uBAAuB,EAAC,MAAM,uBAAuB,CAAC;AAC/E,OAAO,EAAC,gBAAgB,EAAC,MAAM,yCAAyC,CAAC;AACzE,OAAO,EAAC,eAAe,EAAC,MAAM,iCAAiC,CAAC;AAChE,OAAO,EAAC,cAAc,EAAC,MAAM,sBAAsB,CAAC;AACpD,OAAO,EAAC,UAAU,EAAC,MAAM,qBAAqB,CAAC;AAE/C,OAAO,EAAC,0BAA0B,EAAC,MAAM,sBAAsB,CAAC;;;;;;AAEhE,MAAM,CAAC,MAAM,gBAAgB,GAAyC;IAClE,GAAG,EAAE,YAAY;IACjB,GAAG,EAAE,YAAY;IACjB,GAAG,EAAE,YAAY;CACpB,CAAC;AAEF,MASsB,gBAEpB,SAAQ,UAAoB;IAX9B;;QAYqB,OAAE,GAAG,gBAAgB,EAAoB,CAAC;QAC1C,YAAO,GAAG,MAAM,CAAC,0BAA0B,CAAC,CAAC;QAC7C,aAAQ,GAAG,MAAM,CAAC,yBAAyB,CAAC,CAAC;QAC7C,cAAS,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;QAC1C,UAAK,GAAG,QAAQ,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC;QACzC,aAAQ,GAAG,kBAAkB,CAC1C,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,YAAY,WAAW,IAAI,CAAC,YAAY,gBAAgB,CACnE,CAAC;QAEiB,WAAM,GAAG,mBAAmB,CAC3C,qBAAqB,EACrB,cAAc,EACd,QAAQ,CAAC,GAAG,EAAE;YACV,MAAM,EAAC,IAAI,EAAE,SAAS,EAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;YACxC,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC;YAEjC,OAAO,KAAK,IAAI,mBAAmB,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,SAAS,CAAC,CAAC;QAChE,CAAC,CAAC,EACF,EAAE,CACL,CAAC;QAEiB,WAAM,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC;QAC/B,SAAI,GAAG,eAAe,EAAE,CAAC;QACzB,SAAI,GAAG,uBAAuB,CAAC,0BAA0B,CAAC,CAAC;QAC3D,oBAAe,GAAG,kBAAkB,CACnD,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC,CACrD,CAAC;QAEiB,WAAM,GAAG,QAAQ,CAAC,MAAM,CAAC,eAAe,CAAC,EAAE;YAC1D,YAAY,EAAE,uBAAuB;SACxC,CAAC,CAAC;QAEgB,SAAI,GAAG,UAAU,CAChC,QAAQ,CAAC,GAAG,EAAE,CACV,2BAA2B,CAAC;YACxB,SAAS,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,SAAS;YAClC,IAAI,EAAE,gBAAgB,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC;YAC1C,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,CAAC,iBAAiB,EAAE;YACnC,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,CAAC,iBAAiB,EAAE;SACtC,CAAC,CACL,CACJ,CAAC;QAEiB,gBAAW,GAAG,MAAM,CAAC,GAAG,EAAE;YACzC,MAAM,KAAK,GACP,IAAI,CAAC,KAAK,EAAE,EAAE,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,SAAS,CAAC;gBACnE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,MAAM,KAAK,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;YAEzE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACpC,CAAC,EAAE,uBAAuB,CAAC,CAAC;QAET,eAAU,GAAG,MAAM,CAAC,GAAG,EAAE;YACxC,IAAI,IAAI,CAAC,QAAQ,EAAE,EAAE;gBACjB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,EAAG,CAAC,CAAC;aAC1C;QACL,CAAC,EAAE,uBAAuB,CAAC,CAAC;QAET,gBAAW,GAAG,MAAM,CAAC,CAAC,SAAS,EAAE,EAAE;YAClD,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,EAAE,EAAE,WAAW,CAAC,SAAS,CAAC,CAAC,KAAU,EAAE,EAAE;gBACvE,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;gBACrB,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;gBAErB,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,cAAc,CAAC,EAAE;oBAClC,IAAI,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC;iBAClB;YACL,CAAC,CAAC,CAAC;YAEH,SAAS,CAAC,GAAG,EAAE,CAAC,YAAY,EAAE,WAAW,EAAE,CAAC,CAAC;QACjD,CAAC,CAAC,CAAC;QAEa,WAAM,GAAG,IAAI,CAAC,EAAE,CAAC,IAAI,KAAK,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC;QAChD,QAAG,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QAC/B,QAAG,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;KA0BlD;IAtBG,IACW,SAAS,CAAC,GAAkB;QACnC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,IAAI,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IAC1C,CAAC;IAED,IACW,SAAS,CAAC,GAAkB;QACnC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,IAAI,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IAC1C,CAAC;IAES,eAAe,CAAC,QAAwC;QAC9D,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;QAC9B,QAAQ,CAAC,mBAAmB,GAAG,IAAI,CAAC,QAAQ,CAAC,mBAAmB,EAAE,CAAC;QACnE,QAAQ,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC1B,QAAQ,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IAC9B,CAAC;IAES,OAAO;QACb,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YACd,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC;SACrC;IACL,CAAC;+GApGiB,gBAAgB;mGAAhB,gBAAgB;;SAAhB,gBAAgB;4FAAhB,gBAAgB;kBATrC,SAAS;mBAAC;oBACP,UAAU,EAAE,IAAI;oBAChB,IAAI,EAAE;wBACF,kBAAkB,EAAE,uCAAuC;wBAC3D,YAAY,EAAE,YAAY;wBAC1B,SAAS,EAAE,oCAAoC;wBAC/C,sBAAsB,EAAE,WAAW;qBACtC;iBACJ;8BAiFc,SAAS;sBADnB,KAAK;uBAAC,KAAK;gBAMD,SAAS;sBADnB,KAAK;uBAAC,KAAK;;AAmBhB,MAea,qBAAsB,SAAQ,gBAAwB;IAfnE;;QAgBuB,aAAQ,GAAG,MAAM,CAChC,kBAAkB,CACrB,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;KAUjD;IARsB,aAAa,CAAC,KAAa;QAC1C,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,sBAAsB,CAAC,EAAC,SAAS,EAAE,KAAK,EAAC,CAAC,CAAC;QAClE,IAAI,CAAC,QAAQ,CACT,KAAK,CAAC,MAAM,KAAK,kBAAkB;YAC/B,CAAC,CAAC,MAAM,CAAC,cAAc,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC;YAClD,CAAC,CAAC,IAAI,CACb,CAAC;IACN,CAAC;+GAZQ,qBAAqB;mGAArB,qBAAqB,kEAZnB;YACP,kBAAkB,CAAC,eAAe,CAAC;YACnC,YAAY,CAAC,qBAAqB,CAAC;YACnC,uBAAuB,CAAC,0BAA0B,CAAC;SACtD;;SAQQ,qBAAqB;4FAArB,qBAAqB;kBAfjC,SAAS;mBAAC;oBACP,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE,qBAAqB;oBAC/B,SAAS,EAAE;wBACP,kBAAkB,CAAC,eAAe,CAAC;wBACnC,YAAY,uBAAuB;wBACnC,uBAAuB,CAAC,0BAA0B,CAAC;qBACtD;oBACD,cAAc,EAAE;wBACZ,gBAAgB;wBAChB,eAAe;wBACf,yBAAyB;wBACzB,gBAAgB;qBACnB;iBACJ","sourcesContent":["import {computed, Directive, effect, inject, Input, signal} from '@angular/core';\nimport {toSignal} from '@angular/core/rxjs-interop';\nimport {MaskitoDirective} from '@maskito/angular';\nimport type {MaskitoDateMode} from '@maskito/kit';\nimport {maskitoDateOptionsGenerator} from '@maskito/kit';\nimport {tuiAsControl, TuiControl, tuiValueTransformerFrom} from '@taiga-ui/cdk/classes';\nimport {TUI_ALLOW_SIGNAL_WRITES} from '@taiga-ui/cdk/constants';\nimport type {TuiDateMode, TuiDayRange} from '@taiga-ui/cdk/date-time';\nimport {DATE_FILLER_LENGTH, TuiDay} from '@taiga-ui/cdk/date-time';\nimport {TUI_IS_MOBILE} from '@taiga-ui/cdk/tokens';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {\n    changeDateSeparator,\n    tuiDirectiveBinding,\n} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TuiCalendar} from '@taiga-ui/core/components/calendar';\nimport {tuiAsOptionContent} from '@taiga-ui/core/components/data-list';\nimport {\n    tuiInjectAuxiliary,\n    TuiTextfieldComponent,\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 type {TuiItemsHandlers} from '@taiga-ui/core/directives/items-handlers';\nimport {\n    TUI_ITEMS_HANDLERS,\n    TuiItemsHandlersDirective,\n    TuiItemsHandlersValidator,\n} from '@taiga-ui/core/directives/items-handlers';\nimport {TUI_DATE_FORMAT, TUI_DEFAULT_DATE_FORMAT} from '@taiga-ui/core/tokens';\nimport {TuiCalendarRange} from '@taiga-ui/kit/components/calendar-range';\nimport {TuiSelectOption} from '@taiga-ui/kit/components/select';\nimport {TUI_DATE_TEXTS} from '@taiga-ui/kit/tokens';\nimport {tuiMaskito} from '@taiga-ui/kit/utils';\n\nimport {TUI_INPUT_DATE_OPTIONS_NEW} from './input-date.options';\n\nexport const TUI_DATE_ADAPTER: Record<TuiDateMode, MaskitoDateMode> = {\n    DMY: 'dd/mm/yyyy',\n    MDY: 'mm/dd/yyyy',\n    YMD: 'yyyy/mm/dd',\n};\n\n@Directive({\n    standalone: true,\n    host: {\n        '[attr.inputmode]': 'mobile && open() ? \"none\" : \"numeric\"',\n        '[disabled]': 'disabled()',\n        '(input)': 'onValueChange($event.target.value)',\n        '(click.capture.stop)': 'onClick()',\n    },\n})\nexport abstract class TuiInputDateBase<\n    T extends TuiDay | TuiDayRange,\n> extends TuiControl<T | null> {\n    private readonly el = tuiInjectElement<HTMLInputElement>();\n    private readonly options = inject(TUI_INPUT_DATE_OPTIONS_NEW);\n    private readonly handlers = inject(TuiItemsHandlersDirective);\n    private readonly textfield = inject(TuiTextfieldDirective);\n    private readonly texts = toSignal(inject(TUI_DATE_TEXTS));\n    private readonly calendar = tuiInjectAuxiliary<TuiCalendar | TuiCalendarRange>(\n        (x) => x instanceof TuiCalendar || x instanceof TuiCalendarRange,\n    );\n\n    protected readonly filler = tuiDirectiveBinding(\n        TuiTextfieldComponent,\n        'fillerSetter',\n        computed(() => {\n            const {mode, separator} = this.format();\n            const texts = this.texts() || '';\n\n            return texts && changeDateSeparator(texts[mode], separator);\n        }),\n        {},\n    );\n\n    protected readonly mobile = inject(TUI_IS_MOBILE);\n    protected readonly open = tuiDropdownOpen();\n    protected readonly icon = tuiTextfieldIconBinding(TUI_INPUT_DATE_OPTIONS_NEW);\n    protected readonly dropdownEnabled = tuiDropdownEnabled(\n        computed(() => !this.native && this.interactive()),\n    );\n\n    protected readonly format = toSignal(inject(TUI_DATE_FORMAT), {\n        initialValue: TUI_DEFAULT_DATE_FORMAT,\n    });\n\n    protected readonly mask = tuiMaskito(\n        computed(() =>\n            maskitoDateOptionsGenerator({\n                separator: this.format().separator,\n                mode: TUI_DATE_ADAPTER[this.format().mode],\n                min: this.min().toLocalNativeDate(),\n                max: this.max().toLocalNativeDate(),\n            }),\n        ),\n    );\n\n    protected readonly valueEffect = effect(() => {\n        const value =\n            this.value()?.toString(this.format().mode, this.format().separator) ??\n            (this.filler().length === this.el.value.length ? '' : this.el.value);\n\n        this.textfield.value.set(value);\n    }, TUI_ALLOW_SIGNAL_WRITES);\n\n    protected readonly calendarIn = effect(() => {\n        if (this.calendar()) {\n            this.processCalendar(this.calendar()!);\n        }\n    }, TUI_ALLOW_SIGNAL_WRITES);\n\n    protected readonly calendarOut = effect((onCleanup) => {\n        const subscription = this.calendar()?.valueChange.subscribe((value: any) => {\n            this.onChange(value);\n            this.open.set(false);\n\n            if (!this.el.closest('tui-dropdown')) {\n                this.el.blur();\n            }\n        });\n\n        onCleanup(() => subscription?.unsubscribe());\n    });\n\n    public readonly native = this.el.type === 'date' && this.mobile;\n    public readonly min = signal(this.options.min);\n    public readonly max = signal(this.options.max);\n\n    protected abstract onValueChange(value: string): void;\n\n    @Input('min')\n    public set minSetter(min: TuiDay | null) {\n        this.min.set(min || this.options.min);\n    }\n\n    @Input('max')\n    public set maxSetter(max: TuiDay | null) {\n        this.max.set(max || this.options.max);\n    }\n\n    protected processCalendar(calendar: TuiCalendar | TuiCalendarRange): void {\n        calendar.value = this.value();\n        calendar.disabledItemHandler = this.handlers.disabledItemHandler();\n        calendar.min = this.min();\n        calendar.max = this.max();\n    }\n\n    protected onClick(): void {\n        if (!this.mobile) {\n            this.open.update((open) => !open);\n        }\n    }\n}\n\n@Directive({\n    standalone: true,\n    selector: 'input[tuiInputDate]',\n    providers: [\n        tuiAsOptionContent(TuiSelectOption),\n        tuiAsControl(TuiInputDateDirective),\n        tuiValueTransformerFrom(TUI_INPUT_DATE_OPTIONS_NEW),\n    ],\n    hostDirectives: [\n        TuiWithTextfield,\n        TuiDropdownAuto,\n        TuiItemsHandlersValidator,\n        MaskitoDirective,\n    ],\n})\nexport class TuiInputDateDirective extends TuiInputDateBase<TuiDay> {\n    protected readonly identity = inject<TuiItemsHandlers<TuiDay>>(\n        TUI_ITEMS_HANDLERS,\n    ).identityMatcher.set((a, b) => a.daySame(b));\n\n    protected override onValueChange(value: string): void {\n        this.control?.control?.updateValueAndValidity({emitEvent: false});\n        this.onChange(\n            value.length === DATE_FILLER_LENGTH\n                ? TuiDay.normalizeParse(value, this.format().mode)\n                : null,\n        );\n    }\n}\n"]}