UNPKG

@taiga-ui/core

Version:

Core library for creating Angular components and applications using Taiga UI

131 lines 17 kB
import { computed, Directive, inject, Input, signal } from '@angular/core'; import { NgControl } from '@angular/forms'; import { TuiNativeValidator } from '@taiga-ui/cdk/directives/native-validator'; import { tuiInjectElement, tuiValue } from '@taiga-ui/cdk/utils/dom'; import { tuiProvide } from '@taiga-ui/cdk/utils/miscellaneous'; import { TuiAppearance, tuiAppearance, tuiAppearanceFocus, tuiAppearanceMode, tuiAppearanceState, } from '@taiga-ui/core/directives/appearance'; import { TUI_ITEMS_HANDLERS, } from '@taiga-ui/core/directives/items-handlers'; import { TuiTextfieldComponent } from './textfield.component'; import { TUI_TEXTFIELD_OPTIONS } from './textfield.options'; import { tuiAsTextfieldAccessor } from './textfield-accessor'; import * as i0 from "@angular/core"; import * as i1 from "@taiga-ui/cdk/directives/native-validator"; import * as i2 from "@taiga-ui/core/directives/appearance"; // TODO: Drop in v5 after updated Angular and hostDirectives inherit class TuiTextfieldBase { constructor() { // TODO: refactor to signal inputs after Angular update this.focused = signal(null); this.control = inject(NgControl, { optional: true }); this.a = tuiAppearance(inject(TUI_TEXTFIELD_OPTIONS).appearance, {}); this.s = tuiAppearanceState(null, {}); this.m = tuiAppearanceMode(this.mode, {}); this.f = tuiAppearanceFocus(computed(() => this.focused() ?? this.textfield.focused()), {}); this.el = tuiInjectElement(); this.handlers = inject(TUI_ITEMS_HANDLERS); this.textfield = inject(TuiTextfieldComponent); this.readOnly = false; this.invalid = null; this.value = tuiValue(this.el); } set focusedSetter(focused) { this.focused.set(focused); } set stateSetter(state) { this.s.set(state); } get mode() { if (this.readOnly) { return 'readonly'; } if (this.invalid === false) { return 'valid'; } if (this.invalid) { return 'invalid'; } return null; } // TODO: refactor to signal inputs after Angular update ngOnChanges() { this.m.set(this.mode); } setValue(value) { this.el.focus(); this.el.select(); if (value == null) { this.el.ownerDocument.execCommand('delete'); } else { this.el.ownerDocument.execCommand('insertText', false, this.handlers.stringify()(value)); } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiTextfieldBase, deps: [], target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiTextfieldBase, isStandalone: true, inputs: { readOnly: "readOnly", invalid: "invalid", focusedSetter: ["focused", "focusedSetter"], stateSetter: ["state", "stateSetter"] }, host: { attributes: { "tuiTextfield": "" }, listeners: { "input": "0", "focusin": "0", "focusout": "0" }, properties: { "id": "textfield.id", "readOnly": "readOnly", "class._empty": "value() === \"\"" } }, providers: [tuiAsTextfieldAccessor(TuiTextfieldBase)], usesOnChanges: true, ngImport: i0 }); } } export { TuiTextfieldBase }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiTextfieldBase, decorators: [{ type: Directive, args: [{ standalone: true, providers: [tuiAsTextfieldAccessor(TuiTextfieldBase)], host: { tuiTextfield: '', '[id]': 'textfield.id', '[readOnly]': 'readOnly', '[class._empty]': 'value() === ""', '(input)': '0', '(focusin)': '0', '(focusout)': '0', }, }] }], propDecorators: { readOnly: [{ type: Input }], invalid: [{ type: Input }], focusedSetter: [{ type: Input, args: ['focused'] }], stateSetter: [{ type: Input, args: ['state'] }] } }); class TuiTextfieldDirective extends TuiTextfieldBase { static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiTextfieldDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiTextfieldDirective, isStandalone: true, selector: "input[tuiTextfield]:not([tuiInputCard]):not([tuiInputExpire]):not([tuiInputCVC])", providers: [ tuiAsTextfieldAccessor(TuiTextfieldDirective), tuiProvide(TuiTextfieldBase, TuiTextfieldDirective), ], usesInheritance: true, hostDirectives: [{ directive: i1.TuiNativeValidator }, { directive: i2.TuiAppearance }], ngImport: i0 }); } } export { TuiTextfieldDirective }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiTextfieldDirective, decorators: [{ type: Directive, args: [{ standalone: true, // TODO: Remove :not in v.5 selector: 'input[tuiTextfield]:not([tuiInputCard]):not([tuiInputExpire]):not([tuiInputCVC])', providers: [ tuiAsTextfieldAccessor(TuiTextfieldDirective), tuiProvide(TuiTextfieldBase, TuiTextfieldDirective), ], hostDirectives: [TuiNativeValidator, TuiAppearance], }] }] }); class TuiWithTextfield { static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiWithTextfield, deps: [], target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiWithTextfield, isStandalone: true, hostDirectives: [{ directive: TuiTextfieldDirective, inputs: ["invalid", "invalid", "focused", "focused", "readOnly", "readOnly", "state", "state"] }], ngImport: i0 }); } } export { TuiWithTextfield }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiWithTextfield, decorators: [{ type: Directive, args: [{ standalone: true, hostDirectives: [ { directive: TuiTextfieldDirective, inputs: ['invalid', 'focused', 'readOnly', 'state'], }, ], }] }] }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"textfield.directive.js","sourceRoot":"","sources":["../../../../../projects/core/components/textfield/textfield.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {computed, Directive, inject, Input, type OnChanges, signal} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {TuiNativeValidator} from '@taiga-ui/cdk/directives/native-validator';\nimport {tuiInjectElement, tuiValue} from '@taiga-ui/cdk/utils/dom';\nimport {tuiProvide} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {\n    TuiAppearance,\n    tuiAppearance,\n    tuiAppearanceFocus,\n    tuiAppearanceMode,\n    tuiAppearanceState,\n} from '@taiga-ui/core/directives/appearance';\nimport {\n    TUI_ITEMS_HANDLERS,\n    type TuiItemsHandlers,\n} from '@taiga-ui/core/directives/items-handlers';\nimport {type TuiInteractiveState} from '@taiga-ui/core/types';\n\nimport {TuiTextfieldComponent} from './textfield.component';\nimport {TUI_TEXTFIELD_OPTIONS} from './textfield.options';\nimport {tuiAsTextfieldAccessor, type TuiTextfieldAccessor} from './textfield-accessor';\n\n// TODO: Drop in v5 after updated Angular and hostDirectives inherit\n@Directive({\n    standalone: true,\n    providers: [tuiAsTextfieldAccessor(TuiTextfieldBase)],\n    host: {\n        tuiTextfield: '',\n        '[id]': 'textfield.id',\n        '[readOnly]': 'readOnly',\n        '[class._empty]': 'value() === \"\"',\n        '(input)': '0',\n        '(focusin)': '0',\n        '(focusout)': '0',\n    },\n})\nexport class TuiTextfieldBase<T> implements OnChanges, TuiTextfieldAccessor<T> {\n    // TODO: refactor to signal inputs after Angular update\n    private readonly focused = signal<boolean | null>(null);\n\n    protected readonly control = inject(NgControl, {optional: true});\n    protected readonly a = tuiAppearance(inject(TUI_TEXTFIELD_OPTIONS).appearance, {});\n    protected readonly s = tuiAppearanceState(null, {});\n    protected readonly m = tuiAppearanceMode(this.mode, {});\n    protected readonly f = tuiAppearanceFocus(\n        computed(() => this.focused() ?? this.textfield.focused()),\n        {},\n    );\n\n    protected readonly el = tuiInjectElement<HTMLInputElement>();\n    protected readonly handlers: TuiItemsHandlers<T> = inject(TUI_ITEMS_HANDLERS);\n    protected readonly textfield: TuiTextfieldComponent<T> =\n        inject(TuiTextfieldComponent);\n\n    @Input()\n    public readOnly = false;\n\n    @Input()\n    public invalid: boolean | null = null;\n\n    public readonly value = tuiValue(this.el);\n\n    @Input('focused')\n    public set focusedSetter(focused: boolean | null) {\n        this.focused.set(focused);\n    }\n\n    @Input('state')\n    public set stateSetter(state: TuiInteractiveState | null) {\n        this.s.set(state);\n    }\n\n    public get mode(): string | null {\n        if (this.readOnly) {\n            return 'readonly';\n        }\n\n        if (this.invalid === false) {\n            return 'valid';\n        }\n\n        if (this.invalid) {\n            return 'invalid';\n        }\n\n        return null;\n    }\n\n    // TODO: refactor to signal inputs after Angular update\n    public ngOnChanges(): void {\n        this.m.set(this.mode);\n    }\n\n    public setValue(value: T | null): void {\n        this.el.focus();\n        this.el.select();\n\n        if (value == null) {\n            this.el.ownerDocument.execCommand('delete');\n        } else {\n            this.el.ownerDocument.execCommand(\n                'insertText',\n                false,\n                this.handlers.stringify()(value),\n            );\n        }\n    }\n}\n\n@Directive({\n    standalone: true,\n    // TODO: Remove :not in v.5\n    selector:\n        'input[tuiTextfield]:not([tuiInputCard]):not([tuiInputExpire]):not([tuiInputCVC])',\n    providers: [\n        tuiAsTextfieldAccessor(TuiTextfieldDirective),\n        tuiProvide(TuiTextfieldBase, TuiTextfieldDirective),\n    ],\n    hostDirectives: [TuiNativeValidator, TuiAppearance],\n})\nexport class TuiTextfieldDirective<T> extends TuiTextfieldBase<T> {}\n\n@Directive({\n    standalone: true,\n    hostDirectives: [\n        {\n            directive: TuiTextfieldDirective,\n            inputs: ['invalid', 'focused', 'readOnly', 'state'],\n        },\n    ],\n})\nexport class TuiWithTextfield {}\n"]}