@taiga-ui/core
Version:
Core library for creating Angular components and applications using Taiga UI
131 lines • 17 kB
JavaScript
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"]}