@taiga-ui/core 3.18.0-dev.main-b65667d → 3.18.0-dev.main-a12f1fc
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/taiga-ui-core-components-primitive-textfield.umd.js +9 -6
- package/bundles/taiga-ui-core-components-primitive-textfield.umd.js.map +1 -1
- package/bundles/taiga-ui-core-directives-textfield-controller.umd.js +66 -11
- package/bundles/taiga-ui-core-directives-textfield-controller.umd.js.map +1 -1
- package/bundles/taiga-ui-core-tokens.umd.js +2 -0
- package/bundles/taiga-ui-core-tokens.umd.js.map +1 -1
- package/components/primitive-textfield/primitive-textfield.component.d.ts +3 -3
- package/directives/textfield-controller/index.d.ts +1 -0
- package/directives/textfield-controller/textfield-appearance.directive.d.ts +9 -0
- package/directives/textfield-controller/textfield-controller.module.d.ts +11 -10
- package/directives/textfield-controller/textfield.controller.d.ts +5 -1
- package/esm2015/components/primitive-textfield/primitive-textfield.component.js +7 -8
- package/esm2015/directives/textfield-controller/index.js +2 -1
- package/esm2015/directives/textfield-controller/textfield-appearance.directive.js +38 -0
- package/esm2015/directives/textfield-controller/textfield-controller.module.js +8 -3
- package/esm2015/directives/textfield-controller/textfield-controller.provider.js +7 -3
- package/esm2015/directives/textfield-controller/textfield.controller.js +7 -2
- package/esm2015/tokens/textfield-appearance.js +3 -1
- package/fesm2015/taiga-ui-core-components-primitive-textfield.js +6 -7
- package/fesm2015/taiga-ui-core-components-primitive-textfield.js.map +1 -1
- package/fesm2015/taiga-ui-core-directives-textfield-controller.js +53 -6
- package/fesm2015/taiga-ui-core-directives-textfield-controller.js.map +1 -1
- package/fesm2015/taiga-ui-core-tokens.js +2 -0
- package/fesm2015/taiga-ui-core-tokens.js.map +1 -1
- package/package.json +1 -1
- package/tokens/textfield-appearance.d.ts +1 -0
|
@@ -9,7 +9,6 @@ import { TuiPrimitiveTextfield } from './primitive-textfield-types';
|
|
|
9
9
|
import * as i0 from "@angular/core";
|
|
10
10
|
export declare class TuiPrimitiveTextfieldComponent extends AbstractTuiInteractive implements TuiPrimitiveTextfield {
|
|
11
11
|
readonly mode$: Observable<TuiBrightness | null>;
|
|
12
|
-
readonly appearance: string;
|
|
13
12
|
readonly controller: TuiTextfieldController;
|
|
14
13
|
readonly hintOptions: TuiHintOptionsDirective | null;
|
|
15
14
|
readonly options: TuiTextfieldOptions;
|
|
@@ -34,12 +33,13 @@ export declare class TuiPrimitiveTextfieldComponent extends AbstractTuiInteracti
|
|
|
34
33
|
readonly valueChange: EventEmitter<string>;
|
|
35
34
|
readonly content?: QueryList<unknown>;
|
|
36
35
|
autofilled: boolean;
|
|
37
|
-
constructor(mode$: Observable<TuiBrightness | null>,
|
|
36
|
+
constructor(mode$: Observable<TuiBrightness | null>, controller: TuiTextfieldController, hintOptions: TuiHintOptionsDirective | null, options: TuiTextfieldOptions, elementRef: ElementRef<HTMLElement>);
|
|
38
37
|
get prefix(): string;
|
|
39
38
|
get postfix(): string;
|
|
40
39
|
get filler(): string;
|
|
41
40
|
get nativeFocusableElement(): HTMLInputElement | null;
|
|
42
41
|
get focused(): boolean;
|
|
42
|
+
get appearance(): string;
|
|
43
43
|
get size(): TuiSizeL | TuiSizeS;
|
|
44
44
|
get computedInvalid(): boolean;
|
|
45
45
|
get inputHidden(): boolean;
|
|
@@ -67,6 +67,6 @@ export declare class TuiPrimitiveTextfieldComponent extends AbstractTuiInteracti
|
|
|
67
67
|
private get placeholderRaisable();
|
|
68
68
|
private updateAutofilled;
|
|
69
69
|
private updateValue;
|
|
70
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<TuiPrimitiveTextfieldComponent, [null, null,
|
|
70
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TuiPrimitiveTextfieldComponent, [null, null, { optional: true; }, null, null]>;
|
|
71
71
|
static ɵcmp: i0.ɵɵComponentDeclaration<TuiPrimitiveTextfieldComponent, "tui-primitive-textfield", never, { "editable": "editable"; "textfieldFiller": "filler"; "iconCleaner": "iconCleaner"; "readOnly": "readOnly"; "invalid": "invalid"; "disabled": "disabled"; "textfieldPrefix": "prefix"; "textfieldPostfix": "postfix"; "value": "value"; }, { "valueChange": "valueChange"; }, ["content"], ["input", "select", "tuiContent", "*"]>;
|
|
72
72
|
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { InjectionToken } from '@angular/core';
|
|
2
|
+
import { AbstractTuiController } from '@taiga-ui/cdk';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare const TUI_TEXTFIELD_APPEARANCE_DIRECTIVE: InjectionToken<TuiTextfieldAppearanceDirective>;
|
|
5
|
+
export declare class TuiTextfieldAppearanceDirective extends AbstractTuiController {
|
|
6
|
+
appearance: string;
|
|
7
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TuiTextfieldAppearanceDirective, never>;
|
|
8
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<TuiTextfieldAppearanceDirective, "[tuiTextfieldAppearance]", never, { "appearance": "tuiTextfieldAppearance"; }, {}, never>;
|
|
9
|
+
}
|
|
@@ -1,15 +1,16 @@
|
|
|
1
1
|
import * as i0 from "@angular/core";
|
|
2
|
-
import * as i1 from "./textfield-
|
|
3
|
-
import * as i2 from "./textfield-
|
|
4
|
-
import * as i3 from "./textfield-
|
|
5
|
-
import * as i4 from "./textfield-
|
|
6
|
-
import * as i5 from "./textfield-
|
|
7
|
-
import * as i6 from "./textfield-icon
|
|
8
|
-
import * as i7 from "./textfield-
|
|
9
|
-
import * as i8 from "./textfield-
|
|
10
|
-
import * as i9 from "./textfield-
|
|
2
|
+
import * as i1 from "./textfield-appearance.directive";
|
|
3
|
+
import * as i2 from "./textfield-cleaner.directive";
|
|
4
|
+
import * as i3 from "./textfield-custom-content.directive";
|
|
5
|
+
import * as i4 from "./textfield-label-outside.directive";
|
|
6
|
+
import * as i5 from "./textfield-size.directive";
|
|
7
|
+
import * as i6 from "./textfield-icon.directive";
|
|
8
|
+
import * as i7 from "./textfield-icon-left.directive";
|
|
9
|
+
import * as i8 from "./textfield-prefix.directive";
|
|
10
|
+
import * as i9 from "./textfield-postfix.directive";
|
|
11
|
+
import * as i10 from "./textfield-filler.directive";
|
|
11
12
|
export declare class TuiTextfieldControllerModule {
|
|
12
13
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiTextfieldControllerModule, never>;
|
|
13
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<TuiTextfieldControllerModule, [typeof i1.
|
|
14
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<TuiTextfieldControllerModule, [typeof i1.TuiTextfieldAppearanceDirective, typeof i2.TuiTextfieldCleanerDirective, typeof i3.TuiTextfieldCustomContentDirective, typeof i4.TuiTextfieldLabelOutsideDirective, typeof i5.TuiTextfieldSizeDirective, typeof i6.TuiTextfieldIconDirective, typeof i7.TuiTextfieldIconLeftDirective, typeof i8.TuiTextfieldPrefixDirective, typeof i9.TuiTextfieldPostfixDirective, typeof i10.TuiTextfieldFillerDirective], never, [typeof i1.TuiTextfieldAppearanceDirective, typeof i2.TuiTextfieldCleanerDirective, typeof i3.TuiTextfieldCustomContentDirective, typeof i4.TuiTextfieldLabelOutsideDirective, typeof i5.TuiTextfieldSizeDirective, typeof i6.TuiTextfieldIconDirective, typeof i7.TuiTextfieldIconLeftDirective, typeof i8.TuiTextfieldPrefixDirective, typeof i9.TuiTextfieldPostfixDirective, typeof i10.TuiTextfieldFillerDirective]>;
|
|
14
15
|
static ɵinj: i0.ɵɵInjectorDeclaration<TuiTextfieldControllerModule>;
|
|
15
16
|
}
|
|
@@ -2,6 +2,7 @@ import { TuiContextWithImplicit } from '@taiga-ui/cdk';
|
|
|
2
2
|
import { TuiSizeL, TuiSizeS } from '@taiga-ui/core/types';
|
|
3
3
|
import { PolymorpheusContent } from '@tinkoff/ng-polymorpheus';
|
|
4
4
|
import { Observable } from 'rxjs';
|
|
5
|
+
import { TuiTextfieldAppearanceDirective } from './textfield-appearance.directive';
|
|
5
6
|
import { TuiTextfieldCleanerDirective } from './textfield-cleaner.directive';
|
|
6
7
|
import { TuiTextfieldCustomContentDirective } from './textfield-custom-content.directive';
|
|
7
8
|
import { TuiTextfieldFillerDirective } from './textfield-filler.directive';
|
|
@@ -15,6 +16,8 @@ import { TuiTextfieldSizeDirective } from './textfield-size.directive';
|
|
|
15
16
|
export declare class TuiTextfieldController {
|
|
16
17
|
readonly change$: Observable<void>;
|
|
17
18
|
readonly options: TuiTextfieldOptions;
|
|
19
|
+
private readonly legacyAppearance;
|
|
20
|
+
private readonly appearanceDirective;
|
|
18
21
|
private readonly cleanerDirective;
|
|
19
22
|
private readonly customContentDirective;
|
|
20
23
|
private readonly iconDirective;
|
|
@@ -24,7 +27,8 @@ export declare class TuiTextfieldController {
|
|
|
24
27
|
private readonly prefixDirective;
|
|
25
28
|
private readonly postfixDirective;
|
|
26
29
|
private readonly fillerDirective;
|
|
27
|
-
constructor(change$: Observable<void>, options: TuiTextfieldOptions, cleanerDirective: TuiTextfieldCleanerDirective, customContentDirective: TuiTextfieldCustomContentDirective, iconDirective: TuiTextfieldIconDirective, iconLeftDirective: TuiTextfieldIconLeftDirective, labelOutsideDirective: TuiTextfieldLabelOutsideDirective, sizeDirective: TuiTextfieldSizeDirective, prefixDirective: TuiTextfieldPrefixDirective, postfixDirective: TuiTextfieldPostfixDirective, fillerDirective: TuiTextfieldFillerDirective);
|
|
30
|
+
constructor(change$: Observable<void>, options: TuiTextfieldOptions, legacyAppearance: string, appearanceDirective: TuiTextfieldAppearanceDirective, cleanerDirective: TuiTextfieldCleanerDirective, customContentDirective: TuiTextfieldCustomContentDirective, iconDirective: TuiTextfieldIconDirective, iconLeftDirective: TuiTextfieldIconLeftDirective, labelOutsideDirective: TuiTextfieldLabelOutsideDirective, sizeDirective: TuiTextfieldSizeDirective, prefixDirective: TuiTextfieldPrefixDirective, postfixDirective: TuiTextfieldPostfixDirective, fillerDirective: TuiTextfieldFillerDirective);
|
|
31
|
+
get appearance(): string;
|
|
28
32
|
get cleaner(): boolean;
|
|
29
33
|
get customContent(): PolymorpheusContent;
|
|
30
34
|
get icon(): PolymorpheusContent<TuiContextWithImplicit<TuiSizeL | TuiSizeS>>;
|
|
@@ -4,7 +4,7 @@ import { AbstractTuiInteractive, tuiAsFocusableItemAccessor, tuiDefaultProp, tui
|
|
|
4
4
|
import { TuiHintOptionsDirective } from '@taiga-ui/core/directives/hint';
|
|
5
5
|
import { TEXTFIELD_CONTROLLER_PROVIDER, TUI_TEXTFIELD_OPTIONS, TUI_TEXTFIELD_WATCHED_CONTROLLER, } from '@taiga-ui/core/directives/textfield-controller';
|
|
6
6
|
import { MODE_PROVIDER } from '@taiga-ui/core/providers';
|
|
7
|
-
import { TUI_MODE
|
|
7
|
+
import { TUI_MODE } from '@taiga-ui/core/tokens';
|
|
8
8
|
import { tuiGetBorder } from '@taiga-ui/core/utils/miscellaneous';
|
|
9
9
|
import { PolymorpheusOutletDirective } from '@tinkoff/ng-polymorpheus';
|
|
10
10
|
import { fromEvent } from 'rxjs';
|
|
@@ -25,10 +25,9 @@ import * as i12 from "@taiga-ui/core/directives/hint";
|
|
|
25
25
|
const ICON_PADDING = 1.75;
|
|
26
26
|
const ICON_PADDING_S = 1.5;
|
|
27
27
|
export class TuiPrimitiveTextfieldComponent extends AbstractTuiInteractive {
|
|
28
|
-
constructor(mode$,
|
|
28
|
+
constructor(mode$, controller, hintOptions, options, elementRef) {
|
|
29
29
|
super();
|
|
30
30
|
this.mode$ = mode$;
|
|
31
|
-
this.appearance = appearance;
|
|
32
31
|
this.controller = controller;
|
|
33
32
|
this.hintOptions = hintOptions;
|
|
34
33
|
this.options = options;
|
|
@@ -72,6 +71,9 @@ export class TuiPrimitiveTextfieldComponent extends AbstractTuiInteractive {
|
|
|
72
71
|
get focused() {
|
|
73
72
|
return tuiIsNativeFocusedIn(this.elementRef.nativeElement);
|
|
74
73
|
}
|
|
74
|
+
get appearance() {
|
|
75
|
+
return this.controller.appearance;
|
|
76
|
+
}
|
|
75
77
|
get size() {
|
|
76
78
|
return this.controller.size;
|
|
77
79
|
}
|
|
@@ -183,7 +185,7 @@ export class TuiPrimitiveTextfieldComponent extends AbstractTuiInteractive {
|
|
|
183
185
|
this.valueChange.emit(value);
|
|
184
186
|
}
|
|
185
187
|
}
|
|
186
|
-
TuiPrimitiveTextfieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiPrimitiveTextfieldComponent, deps: [{ token: TUI_MODE }, { token:
|
|
188
|
+
TuiPrimitiveTextfieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiPrimitiveTextfieldComponent, deps: [{ token: TUI_MODE }, { token: TUI_TEXTFIELD_WATCHED_CONTROLLER }, { token: TuiHintOptionsDirective, optional: true }, { token: TUI_TEXTFIELD_OPTIONS }, { token: ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
187
189
|
TuiPrimitiveTextfieldComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiPrimitiveTextfieldComponent, selector: "tui-primitive-textfield", inputs: { editable: "editable", textfieldFiller: ["filler", "textfieldFiller"], iconCleaner: "iconCleaner", readOnly: "readOnly", invalid: "invalid", disabled: "disabled", textfieldPrefix: ["prefix", "textfieldPrefix"], textfieldPostfix: ["postfix", "textfieldPostfix"], value: "value" }, outputs: { valueChange: "valueChange" }, host: { listeners: { "$.data-mode.attr": "mode$", "focusin": "onFocused(true)", "focusout": "onFocused(false)" }, properties: { "class._autofilled": "autofilled", "class._label-outside": "controller.labelOutside", "class._readonly": "this.readOnly", "attr.data-size": "this.size", "class._invalid": "this.computedInvalid", "class._hidden": "this.inputHidden", "style.--border-start.rem": "this.borderStart", "style.--border-end.rem": "this.borderEnd" } }, providers: [
|
|
188
190
|
tuiAsFocusableItemAccessor(TuiPrimitiveTextfieldComponent),
|
|
189
191
|
TEXTFIELD_CONTROLLER_PROVIDER,
|
|
@@ -240,9 +242,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
240
242
|
}], ctorParameters: function () { return [{ type: i10.Observable, decorators: [{
|
|
241
243
|
type: Inject,
|
|
242
244
|
args: [TUI_MODE]
|
|
243
|
-
}] }, { type: undefined, decorators: [{
|
|
244
|
-
type: Inject,
|
|
245
|
-
args: [TUI_TEXTFIELD_APPEARANCE]
|
|
246
245
|
}] }, { type: i11.TuiTextfieldController, decorators: [{
|
|
247
246
|
type: Inject,
|
|
248
247
|
args: [TUI_TEXTFIELD_WATCHED_CONTROLLER]
|
|
@@ -311,4 +310,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
311
310
|
type: HostListener,
|
|
312
311
|
args: ['focusout', ['false']]
|
|
313
312
|
}], getIndent$: [] } });
|
|
314
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"primitive-textfield.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/primitive-textfield/primitive-textfield.component.ts","../../../../../projects/core/components/primitive-textfield/primitive-textfield.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    Optional,\n    Output,\n    QueryList,\n    ViewChild,\n} from '@angular/core';\nimport {\n    AbstractTuiInteractive,\n    tuiAsFocusableItemAccessor,\n    TuiContextWithImplicit,\n    tuiDefaultProp,\n    tuiIsNativeFocusedIn,\n    tuiPure,\n} from '@taiga-ui/cdk';\nimport {TuiHintOptionsDirective} from '@taiga-ui/core/directives/hint';\nimport {\n    TEXTFIELD_CONTROLLER_PROVIDER,\n    TUI_TEXTFIELD_OPTIONS,\n    TUI_TEXTFIELD_WATCHED_CONTROLLER,\n    TuiTextfieldController,\n    TuiTextfieldOptions,\n} from '@taiga-ui/core/directives/textfield-controller';\nimport {MODE_PROVIDER} from '@taiga-ui/core/providers';\nimport {TUI_MODE, TUI_TEXTFIELD_APPEARANCE} from '@taiga-ui/core/tokens';\nimport {TuiBrightness, TuiSizeL, TuiSizeS} from '@taiga-ui/core/types';\nimport {tuiGetBorder} from '@taiga-ui/core/utils/miscellaneous';\nimport {PolymorpheusContent, PolymorpheusOutletDirective} from '@tinkoff/ng-polymorpheus';\nimport {fromEvent, Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\nimport {TuiPrimitiveTextfield} from './primitive-textfield-types';\n\nconst ICON_PADDING = 1.75;\nconst ICON_PADDING_S = 1.5;\n\n@Component({\n    selector: 'tui-primitive-textfield',\n    templateUrl: './primitive-textfield.template.html',\n    styleUrls: ['./primitive-textfield.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiPrimitiveTextfieldComponent),\n        TEXTFIELD_CONTROLLER_PROVIDER,\n        MODE_PROVIDER,\n    ],\n    host: {\n        '($.data-mode.attr)': 'mode$',\n        '[class._autofilled]': 'autofilled',\n        '[class._label-outside]': 'controller.labelOutside',\n    },\n})\nexport class TuiPrimitiveTextfieldComponent\n    extends AbstractTuiInteractive\n    implements TuiPrimitiveTextfield\n{\n    @ViewChild('focusableElement')\n    private readonly focusableElement?: ElementRef<HTMLInputElement>;\n\n    @Input()\n    @tuiDefaultProp()\n    editable = true;\n\n    /** @deprecated use `tuiTextfieldFiller` from {@link TuiTextfieldControllerModule} instead */\n    @Input('filler')\n    @tuiDefaultProp()\n    textfieldFiller = '';\n\n    /**\n     * @deprecated:\n     * use `tuiTextfieldOptionsProvider({iconCleaner: `tuiIconChevronUp`})`\n     */\n    @Input()\n    @tuiDefaultProp()\n    iconCleaner = this.options.iconCleaner;\n\n    @Input()\n    @HostBinding('class._readonly')\n    @tuiDefaultProp()\n    readOnly = false;\n\n    @Input()\n    @tuiDefaultProp()\n    invalid = false;\n\n    @Input()\n    @tuiDefaultProp()\n    disabled = false;\n\n    /** @deprecated use `tuiTextfieldPrefix` from {@link TuiTextfieldControllerModule} instead */\n    @Input('prefix')\n    @tuiDefaultProp()\n    textfieldPrefix = '';\n\n    /** @deprecated use `tuiTextfieldPostfix` from {@link TuiTextfieldControllerModule} instead */\n    @Input('postfix')\n    @tuiDefaultProp()\n    textfieldPostfix = '';\n\n    @Input()\n    @tuiDefaultProp()\n    value = '';\n\n    @Output()\n    readonly valueChange = new EventEmitter<string>();\n\n    @ContentChildren(PolymorpheusOutletDirective, {descendants: true})\n    readonly content?: QueryList<unknown>;\n\n    autofilled = false;\n\n    constructor(\n        @Inject(TUI_MODE) readonly mode$: Observable<TuiBrightness | null>,\n        @Inject(TUI_TEXTFIELD_APPEARANCE) readonly appearance: string,\n        @Inject(TUI_TEXTFIELD_WATCHED_CONTROLLER)\n        readonly controller: TuiTextfieldController,\n        @Optional()\n        @Inject(TuiHintOptionsDirective)\n        readonly hintOptions: TuiHintOptionsDirective | null,\n        @Inject(TUI_TEXTFIELD_OPTIONS)\n        readonly options: TuiTextfieldOptions,\n        @Inject(ElementRef) private readonly elementRef: ElementRef<HTMLElement>,\n    ) {\n        super();\n    }\n\n    get prefix(): string {\n        return this.textfieldPrefix || this.controller.prefix;\n    }\n\n    get postfix(): string {\n        return this.textfieldPostfix || this.controller.postfix;\n    }\n\n    get filler(): string {\n        return this.textfieldFiller || this.controller.filler;\n    }\n\n    get nativeFocusableElement(): HTMLInputElement | null {\n        if (this.computedDisabled || !this.focusableElement) {\n            return null;\n        }\n\n        const {nativeElement} = this.focusableElement;\n\n        return (nativeElement.previousElementSibling ||\n            nativeElement) as HTMLInputElement | null;\n    }\n\n    get focused(): boolean {\n        return tuiIsNativeFocusedIn(this.elementRef.nativeElement);\n    }\n\n    @HostBinding('attr.data-size')\n    get size(): TuiSizeL | TuiSizeS {\n        return this.controller.size;\n    }\n\n    @HostBinding('class._invalid')\n    get computedInvalid(): boolean {\n        return !this.readOnly && !this.disabled && this.invalid;\n    }\n\n    @HostBinding('class._hidden')\n    get inputHidden(): boolean {\n        return !!this.content?.length;\n    }\n\n    get hasValue(): boolean {\n        return !!this.value;\n    }\n\n    get hasCleaner(): boolean {\n        return (\n            this.controller.cleaner &&\n            this.hasValue &&\n            !this.computedDisabled &&\n            !this.readOnly\n        );\n    }\n\n    get hasTooltip(): boolean {\n        return !!this.hintOptions?.content && !this.computedDisabled;\n    }\n\n    get hasCustomContent(): boolean {\n        return !!this.controller.customContent;\n    }\n\n    get showOnlyPlaceholder(): boolean {\n        return (\n            this.focused &&\n            this.placeholderVisible &&\n            (this.size === 's' || (this.size === 'm' && !this.placeholderRaisable))\n        );\n    }\n\n    get placeholderVisible(): boolean {\n        const hasDecor =\n            this.nativeFocusableElement?.placeholder || this.prefix || this.postfix;\n        const showDecor = hasDecor && !this.readOnly && this.computedFocused;\n\n        return !this.hasValue && !showDecor;\n    }\n\n    get hasPlaceholder(): boolean {\n        return (\n            !this.showOnlyPlaceholder &&\n            (this.placeholderRaisable || this.placeholderVisible)\n        );\n    }\n\n    get placeholderRaised(): boolean {\n        return (\n            this.placeholderRaisable &&\n            ((this.computedFocused && !this.readOnly) || this.hasValue || this.autofilled)\n        );\n    }\n\n    @HostBinding('style.--border-start.rem')\n    get borderStart(): number {\n        return this.iconLeftContent ? this.iconPaddingLeft : 0;\n    }\n\n    @HostBinding('style.--border-end.rem')\n    get borderEnd(): number {\n        return tuiGetBorder(\n            !!this.iconContent,\n            this.hasCleaner,\n            this.hasTooltip,\n            this.hasCustomContent,\n        );\n    }\n\n    get iconContent(): PolymorpheusContent<TuiContextWithImplicit<TuiSizeL | TuiSizeS>> {\n        return this.controller.icon;\n    }\n\n    get iconLeftContent(): PolymorpheusContent<\n        TuiContextWithImplicit<TuiSizeL | TuiSizeS>\n    > {\n        return this.controller.iconLeft;\n    }\n\n    // Safari expiration date autofill workaround\n    get name(): 'ccexpiryyear' | null {\n        return this.nativeFocusableElement?.autocomplete === 'cc-exp'\n            ? 'ccexpiryyear'\n            : null;\n    }\n\n    get computedId(): string {\n        return this.nativeFocusableElement?.id || '';\n    }\n\n    @HostListener('focusin', ['true'])\n    @HostListener('focusout', ['false'])\n    onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n    }\n\n    @tuiPure\n    getIndent$(element: HTMLElement): Observable<number> {\n        return fromEvent(element, 'scroll').pipe(map(() => -1 * element.scrollLeft));\n    }\n\n    clear(): void {\n        if (this.nativeFocusableElement) {\n            this.nativeFocusableElement.value = '';\n        }\n\n        this.updateValue('');\n    }\n\n    onMouseDown(event: MouseEvent): void {\n        const {nativeFocusableElement} = this;\n\n        if (!nativeFocusableElement || event.target === nativeFocusableElement) {\n            return;\n        }\n\n        event.preventDefault();\n        nativeFocusableElement.focus();\n    }\n\n    onModelChange(value: string): void {\n        this.updateValue(value);\n    }\n\n    onAutofilled(autofilled: boolean): void {\n        this.updateAutofilled(autofilled);\n    }\n\n    private get iconPaddingLeft(): number {\n        return this.size === 's' ? ICON_PADDING_S : ICON_PADDING;\n    }\n\n    private get placeholderRaisable(): boolean {\n        return this.size !== 's' && !this.controller.labelOutside;\n    }\n\n    private updateAutofilled(autofilled: boolean): void {\n        if (this.autofilled === autofilled) {\n            return;\n        }\n\n        this.autofilled = autofilled;\n    }\n\n    private updateValue(value: string): void {\n        this.value = value;\n        this.valueChange.emit(value);\n    }\n}\n","<ng-container *ngIf=\"content?.changes | async\"></ng-container>\n<ng-container *ngIf=\"hintOptions?.change$ | async\"></ng-container>\n<div\n    tuiWrapper\n    automation-id=\"tui-primitive-textfield__wrapper\"\n    [appearance]=\"appearance\"\n    [readOnly]=\"readOnly\"\n    [disabled]=\"disabled\"\n    [focus]=\"computedFocused\"\n    [hover]=\"pseudoHover\"\n    [active]=\"pseudoActive\"\n    [invalid]=\"computedInvalid\"\n    [style.--text-indent.px]=\"decor.pre$ | async\"\n    (mousedown)=\"onMouseDown($event)\"\n    (click.prevent.silent)=\"(0)\"\n    (tuiAutofilledChange)=\"onAutofilled($event)\"\n>\n    <ng-content select=\"input\"></ng-content>\n    <ng-content select=\"select\"></ng-content>\n    <input\n        #focusableElement\n        tuiMaskAccessor\n        automation-id=\"tui-primitive-textfield__native-input\"\n        class=\"t-input\"\n        [attr.disabled]=\"computedDisabled || null\"\n        [attr.name]=\"name\"\n        [attr.aria-invalid]=\"computedInvalid\"\n        [id]=\"id\"\n        [readOnly]=\"readOnly || !editable\"\n        [tuiFocusable]=\"computedFocusable\"\n        [ngModel]=\"value\"\n        (ngModelChange)=\"onModelChange($event)\"\n    />\n    <div\n        *ngIf=\"inputHidden\"\n        automation-id=\"tui-primitive-textfield__value\"\n        class=\"t-input t-input_template\"\n    >\n        <ng-content select=\"tuiContent\"></ng-content>\n    </div>\n    <div class=\"t-content\">\n        <div\n            *ngIf=\"iconLeftContent\"\n            class=\"t-icon t-icon_left t-textfield-icon\"\n        >\n            <tui-svg\n                *polymorpheusOutlet=\"iconLeftContent as src; context: {$implicit: size}\"\n                tuiWrapper\n                appearance=\"icon\"\n                class=\"t-icon\"\n                [src]=\"src\"\n            ></tui-svg>\n        </div>\n        <div class=\"t-wrapper\">\n            <label\n                *ngIf=\"hasPlaceholder\"\n                automation-id=\"tui-primitive-textfield__placeholder\"\n                class=\"t-placeholder\"\n                [class.t-placeholder_raised]=\"placeholderRaised\"\n                [for]=\"computedId\"\n            >\n                <ng-content></ng-content>\n            </label>\n            <div class=\"t-wrapper-value-decoration\">\n                <tui-value-decoration\n                    #decor\n                    automation-id=\"tui-primitive-textfield__value-decoration\"\n                    aria-hidden=\"true\"\n                    class=\"t-value-decoration\"\n                    [class.t-has-value]=\"value\"\n                    [style.textIndent.px]=\"getIndent$(focusableElement) | async\"\n                ></tui-value-decoration>\n            </div>\n        </div>\n        <div\n            *ngIf=\"hasCustomContent\"\n            automation-id=\"tui-primitive-textfield__custom-content\"\n            class=\"t-custom-content\"\n        >\n            <tui-svg\n                *polymorpheusOutlet=\"controller.customContent as src\"\n                class=\"t-custom-icon\"\n                [src]=\"src\"\n            ></tui-svg>\n        </div>\n        <span\n            *ngIf=\"hasCleaner\"\n            tuiWrapper\n            appearance=\"icon\"\n            automation-id=\"tui-primitive-textfield__cleaner\"\n            class=\"t-cleaner\"\n            (click.stop)=\"clear()\"\n        >\n            <tui-svg\n                *polymorpheusOutlet=\"iconCleaner || controller.options.iconCleaner as src; context: {$implicit: size}\"\n                [src]=\"src\"\n            ></tui-svg>\n        </span>\n        <tui-tooltip\n            *ngIf=\"hintOptions && hintOptions.content && !computedDisabled\"\n            automation-id=\"tui-primitive-textfield__tooltip\"\n            [describeId]=\"computedId\"\n            [content]=\"hintOptions.content\"\n            [direction]=\"hintOptions.direction\"\n            [appearance]=\"hintOptions.appearance\"\n            [showDelay]=\"hintOptions.showDelay\"\n            [hideDelay]=\"hintOptions.hideDelay\"\n        ></tui-tooltip>\n        <div\n            *ngIf=\"iconContent\"\n            class=\"t-icon t-textfield-icon\"\n        >\n            <tui-svg\n                *polymorpheusOutlet=\"iconContent as src; context: {$implicit: size}\"\n                tuiWrapper\n                appearance=\"icon\"\n                [src]=\"src\"\n            ></tui-svg>\n        </div>\n    </div>\n</div>\n"]}
|
|
313
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"primitive-textfield.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/primitive-textfield/primitive-textfield.component.ts","../../../../../projects/core/components/primitive-textfield/primitive-textfield.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    Optional,\n    Output,\n    QueryList,\n    ViewChild,\n} from '@angular/core';\nimport {\n    AbstractTuiInteractive,\n    tuiAsFocusableItemAccessor,\n    TuiContextWithImplicit,\n    tuiDefaultProp,\n    tuiIsNativeFocusedIn,\n    tuiPure,\n} from '@taiga-ui/cdk';\nimport {TuiHintOptionsDirective} from '@taiga-ui/core/directives/hint';\nimport {\n    TEXTFIELD_CONTROLLER_PROVIDER,\n    TUI_TEXTFIELD_OPTIONS,\n    TUI_TEXTFIELD_WATCHED_CONTROLLER,\n    TuiTextfieldController,\n    TuiTextfieldOptions,\n} from '@taiga-ui/core/directives/textfield-controller';\nimport {MODE_PROVIDER} from '@taiga-ui/core/providers';\nimport {TUI_MODE} from '@taiga-ui/core/tokens';\nimport {TuiBrightness, TuiSizeL, TuiSizeS} from '@taiga-ui/core/types';\nimport {tuiGetBorder} from '@taiga-ui/core/utils/miscellaneous';\nimport {PolymorpheusContent, PolymorpheusOutletDirective} from '@tinkoff/ng-polymorpheus';\nimport {fromEvent, Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\nimport {TuiPrimitiveTextfield} from './primitive-textfield-types';\n\nconst ICON_PADDING = 1.75;\nconst ICON_PADDING_S = 1.5;\n\n@Component({\n    selector: 'tui-primitive-textfield',\n    templateUrl: './primitive-textfield.template.html',\n    styleUrls: ['./primitive-textfield.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiPrimitiveTextfieldComponent),\n        TEXTFIELD_CONTROLLER_PROVIDER,\n        MODE_PROVIDER,\n    ],\n    host: {\n        '($.data-mode.attr)': 'mode$',\n        '[class._autofilled]': 'autofilled',\n        '[class._label-outside]': 'controller.labelOutside',\n    },\n})\nexport class TuiPrimitiveTextfieldComponent\n    extends AbstractTuiInteractive\n    implements TuiPrimitiveTextfield\n{\n    @ViewChild('focusableElement')\n    private readonly focusableElement?: ElementRef<HTMLInputElement>;\n\n    @Input()\n    @tuiDefaultProp()\n    editable = true;\n\n    /** @deprecated use `tuiTextfieldFiller` from {@link TuiTextfieldControllerModule} instead */\n    @Input('filler')\n    @tuiDefaultProp()\n    textfieldFiller = '';\n\n    /**\n     * @deprecated:\n     * use `tuiTextfieldOptionsProvider({iconCleaner: `tuiIconChevronUp`})`\n     */\n    @Input()\n    @tuiDefaultProp()\n    iconCleaner = this.options.iconCleaner;\n\n    @Input()\n    @HostBinding('class._readonly')\n    @tuiDefaultProp()\n    readOnly = false;\n\n    @Input()\n    @tuiDefaultProp()\n    invalid = false;\n\n    @Input()\n    @tuiDefaultProp()\n    disabled = false;\n\n    /** @deprecated use `tuiTextfieldPrefix` from {@link TuiTextfieldControllerModule} instead */\n    @Input('prefix')\n    @tuiDefaultProp()\n    textfieldPrefix = '';\n\n    /** @deprecated use `tuiTextfieldPostfix` from {@link TuiTextfieldControllerModule} instead */\n    @Input('postfix')\n    @tuiDefaultProp()\n    textfieldPostfix = '';\n\n    @Input()\n    @tuiDefaultProp()\n    value = '';\n\n    @Output()\n    readonly valueChange = new EventEmitter<string>();\n\n    @ContentChildren(PolymorpheusOutletDirective, {descendants: true})\n    readonly content?: QueryList<unknown>;\n\n    autofilled = false;\n\n    constructor(\n        @Inject(TUI_MODE) readonly mode$: Observable<TuiBrightness | null>,\n        @Inject(TUI_TEXTFIELD_WATCHED_CONTROLLER)\n        readonly controller: TuiTextfieldController,\n        @Optional()\n        @Inject(TuiHintOptionsDirective)\n        readonly hintOptions: TuiHintOptionsDirective | null,\n        @Inject(TUI_TEXTFIELD_OPTIONS)\n        readonly options: TuiTextfieldOptions,\n        @Inject(ElementRef) private readonly elementRef: ElementRef<HTMLElement>,\n    ) {\n        super();\n    }\n\n    get prefix(): string {\n        return this.textfieldPrefix || this.controller.prefix;\n    }\n\n    get postfix(): string {\n        return this.textfieldPostfix || this.controller.postfix;\n    }\n\n    get filler(): string {\n        return this.textfieldFiller || this.controller.filler;\n    }\n\n    get nativeFocusableElement(): HTMLInputElement | null {\n        if (this.computedDisabled || !this.focusableElement) {\n            return null;\n        }\n\n        const {nativeElement} = this.focusableElement;\n\n        return (nativeElement.previousElementSibling ||\n            nativeElement) as HTMLInputElement | null;\n    }\n\n    get focused(): boolean {\n        return tuiIsNativeFocusedIn(this.elementRef.nativeElement);\n    }\n\n    get appearance(): string {\n        return this.controller.appearance;\n    }\n\n    @HostBinding('attr.data-size')\n    get size(): TuiSizeL | TuiSizeS {\n        return this.controller.size;\n    }\n\n    @HostBinding('class._invalid')\n    get computedInvalid(): boolean {\n        return !this.readOnly && !this.disabled && this.invalid;\n    }\n\n    @HostBinding('class._hidden')\n    get inputHidden(): boolean {\n        return !!this.content?.length;\n    }\n\n    get hasValue(): boolean {\n        return !!this.value;\n    }\n\n    get hasCleaner(): boolean {\n        return (\n            this.controller.cleaner &&\n            this.hasValue &&\n            !this.computedDisabled &&\n            !this.readOnly\n        );\n    }\n\n    get hasTooltip(): boolean {\n        return !!this.hintOptions?.content && !this.computedDisabled;\n    }\n\n    get hasCustomContent(): boolean {\n        return !!this.controller.customContent;\n    }\n\n    get showOnlyPlaceholder(): boolean {\n        return (\n            this.focused &&\n            this.placeholderVisible &&\n            (this.size === 's' || (this.size === 'm' && !this.placeholderRaisable))\n        );\n    }\n\n    get placeholderVisible(): boolean {\n        const hasDecor =\n            this.nativeFocusableElement?.placeholder || this.prefix || this.postfix;\n        const showDecor = hasDecor && !this.readOnly && this.computedFocused;\n\n        return !this.hasValue && !showDecor;\n    }\n\n    get hasPlaceholder(): boolean {\n        return (\n            !this.showOnlyPlaceholder &&\n            (this.placeholderRaisable || this.placeholderVisible)\n        );\n    }\n\n    get placeholderRaised(): boolean {\n        return (\n            this.placeholderRaisable &&\n            ((this.computedFocused && !this.readOnly) || this.hasValue || this.autofilled)\n        );\n    }\n\n    @HostBinding('style.--border-start.rem')\n    get borderStart(): number {\n        return this.iconLeftContent ? this.iconPaddingLeft : 0;\n    }\n\n    @HostBinding('style.--border-end.rem')\n    get borderEnd(): number {\n        return tuiGetBorder(\n            !!this.iconContent,\n            this.hasCleaner,\n            this.hasTooltip,\n            this.hasCustomContent,\n        );\n    }\n\n    get iconContent(): PolymorpheusContent<TuiContextWithImplicit<TuiSizeL | TuiSizeS>> {\n        return this.controller.icon;\n    }\n\n    get iconLeftContent(): PolymorpheusContent<\n        TuiContextWithImplicit<TuiSizeL | TuiSizeS>\n    > {\n        return this.controller.iconLeft;\n    }\n\n    // Safari expiration date autofill workaround\n    get name(): 'ccexpiryyear' | null {\n        return this.nativeFocusableElement?.autocomplete === 'cc-exp'\n            ? 'ccexpiryyear'\n            : null;\n    }\n\n    get computedId(): string {\n        return this.nativeFocusableElement?.id || '';\n    }\n\n    @HostListener('focusin', ['true'])\n    @HostListener('focusout', ['false'])\n    onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n    }\n\n    @tuiPure\n    getIndent$(element: HTMLElement): Observable<number> {\n        return fromEvent(element, 'scroll').pipe(map(() => -1 * element.scrollLeft));\n    }\n\n    clear(): void {\n        if (this.nativeFocusableElement) {\n            this.nativeFocusableElement.value = '';\n        }\n\n        this.updateValue('');\n    }\n\n    onMouseDown(event: MouseEvent): void {\n        const {nativeFocusableElement} = this;\n\n        if (!nativeFocusableElement || event.target === nativeFocusableElement) {\n            return;\n        }\n\n        event.preventDefault();\n        nativeFocusableElement.focus();\n    }\n\n    onModelChange(value: string): void {\n        this.updateValue(value);\n    }\n\n    onAutofilled(autofilled: boolean): void {\n        this.updateAutofilled(autofilled);\n    }\n\n    private get iconPaddingLeft(): number {\n        return this.size === 's' ? ICON_PADDING_S : ICON_PADDING;\n    }\n\n    private get placeholderRaisable(): boolean {\n        return this.size !== 's' && !this.controller.labelOutside;\n    }\n\n    private updateAutofilled(autofilled: boolean): void {\n        if (this.autofilled === autofilled) {\n            return;\n        }\n\n        this.autofilled = autofilled;\n    }\n\n    private updateValue(value: string): void {\n        this.value = value;\n        this.valueChange.emit(value);\n    }\n}\n","<ng-container *ngIf=\"content?.changes | async\"></ng-container>\n<ng-container *ngIf=\"hintOptions?.change$ | async\"></ng-container>\n<div\n    tuiWrapper\n    automation-id=\"tui-primitive-textfield__wrapper\"\n    [appearance]=\"appearance\"\n    [readOnly]=\"readOnly\"\n    [disabled]=\"disabled\"\n    [focus]=\"computedFocused\"\n    [hover]=\"pseudoHover\"\n    [active]=\"pseudoActive\"\n    [invalid]=\"computedInvalid\"\n    [style.--text-indent.px]=\"decor.pre$ | async\"\n    (mousedown)=\"onMouseDown($event)\"\n    (click.prevent.silent)=\"(0)\"\n    (tuiAutofilledChange)=\"onAutofilled($event)\"\n>\n    <ng-content select=\"input\"></ng-content>\n    <ng-content select=\"select\"></ng-content>\n    <input\n        #focusableElement\n        tuiMaskAccessor\n        automation-id=\"tui-primitive-textfield__native-input\"\n        class=\"t-input\"\n        [attr.disabled]=\"computedDisabled || null\"\n        [attr.name]=\"name\"\n        [attr.aria-invalid]=\"computedInvalid\"\n        [id]=\"id\"\n        [readOnly]=\"readOnly || !editable\"\n        [tuiFocusable]=\"computedFocusable\"\n        [ngModel]=\"value\"\n        (ngModelChange)=\"onModelChange($event)\"\n    />\n    <div\n        *ngIf=\"inputHidden\"\n        automation-id=\"tui-primitive-textfield__value\"\n        class=\"t-input t-input_template\"\n    >\n        <ng-content select=\"tuiContent\"></ng-content>\n    </div>\n    <div class=\"t-content\">\n        <div\n            *ngIf=\"iconLeftContent\"\n            class=\"t-icon t-icon_left t-textfield-icon\"\n        >\n            <tui-svg\n                *polymorpheusOutlet=\"iconLeftContent as src; context: {$implicit: size}\"\n                tuiWrapper\n                appearance=\"icon\"\n                class=\"t-icon\"\n                [src]=\"src\"\n            ></tui-svg>\n        </div>\n        <div class=\"t-wrapper\">\n            <label\n                *ngIf=\"hasPlaceholder\"\n                automation-id=\"tui-primitive-textfield__placeholder\"\n                class=\"t-placeholder\"\n                [class.t-placeholder_raised]=\"placeholderRaised\"\n                [for]=\"computedId\"\n            >\n                <ng-content></ng-content>\n            </label>\n            <div class=\"t-wrapper-value-decoration\">\n                <tui-value-decoration\n                    #decor\n                    automation-id=\"tui-primitive-textfield__value-decoration\"\n                    aria-hidden=\"true\"\n                    class=\"t-value-decoration\"\n                    [class.t-has-value]=\"value\"\n                    [style.textIndent.px]=\"getIndent$(focusableElement) | async\"\n                ></tui-value-decoration>\n            </div>\n        </div>\n        <div\n            *ngIf=\"hasCustomContent\"\n            automation-id=\"tui-primitive-textfield__custom-content\"\n            class=\"t-custom-content\"\n        >\n            <tui-svg\n                *polymorpheusOutlet=\"controller.customContent as src\"\n                class=\"t-custom-icon\"\n                [src]=\"src\"\n            ></tui-svg>\n        </div>\n        <span\n            *ngIf=\"hasCleaner\"\n            tuiWrapper\n            appearance=\"icon\"\n            automation-id=\"tui-primitive-textfield__cleaner\"\n            class=\"t-cleaner\"\n            (click.stop)=\"clear()\"\n        >\n            <tui-svg\n                *polymorpheusOutlet=\"iconCleaner || controller.options.iconCleaner as src; context: {$implicit: size}\"\n                [src]=\"src\"\n            ></tui-svg>\n        </span>\n        <tui-tooltip\n            *ngIf=\"hintOptions && hintOptions.content && !computedDisabled\"\n            automation-id=\"tui-primitive-textfield__tooltip\"\n            [describeId]=\"computedId\"\n            [content]=\"hintOptions.content\"\n            [direction]=\"hintOptions.direction\"\n            [appearance]=\"hintOptions.appearance\"\n            [showDelay]=\"hintOptions.showDelay\"\n            [hideDelay]=\"hintOptions.hideDelay\"\n        ></tui-tooltip>\n        <div\n            *ngIf=\"iconContent\"\n            class=\"t-icon t-textfield-icon\"\n        >\n            <tui-svg\n                *polymorpheusOutlet=\"iconContent as src; context: {$implicit: size}\"\n                tuiWrapper\n                appearance=\"icon\"\n                [src]=\"src\"\n            ></tui-svg>\n        </div>\n    </div>\n</div>\n"]}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
export * from './textfield.controller';
|
|
2
|
+
export * from './textfield-appearance.directive';
|
|
2
3
|
export * from './textfield-cleaner.directive';
|
|
3
4
|
export * from './textfield-controller.module';
|
|
4
5
|
export * from './textfield-controller.provider';
|
|
@@ -11,4 +12,4 @@ export * from './textfield-options';
|
|
|
11
12
|
export * from './textfield-postfix.directive';
|
|
12
13
|
export * from './textfield-prefix.directive';
|
|
13
14
|
export * from './textfield-size.directive';
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2RpcmVjdGl2ZXMvdGV4dGZpZWxkLWNvbnRyb2xsZXIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLDRCQUE0QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi90ZXh0ZmllbGQuY29udHJvbGxlcic7XG5leHBvcnQgKiBmcm9tICcuL3RleHRmaWVsZC1hcHBlYXJhbmNlLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3RleHRmaWVsZC1jbGVhbmVyLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3RleHRmaWVsZC1jb250cm9sbGVyLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL3RleHRmaWVsZC1jb250cm9sbGVyLnByb3ZpZGVyJztcbmV4cG9ydCAqIGZyb20gJy4vdGV4dGZpZWxkLWN1c3RvbS1jb250ZW50LmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3RleHRmaWVsZC1maWxsZXIuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vdGV4dGZpZWxkLWljb24uZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vdGV4dGZpZWxkLWljb24tbGVmdC5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXh0ZmllbGQtbGFiZWwtb3V0c2lkZS5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi90ZXh0ZmllbGQtb3B0aW9ucyc7XG5leHBvcnQgKiBmcm9tICcuL3RleHRmaWVsZC1wb3N0Zml4LmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3RleHRmaWVsZC1wcmVmaXguZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vdGV4dGZpZWxkLXNpemUuZGlyZWN0aXZlJztcbiJdfQ==
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { Directive, forwardRef, InjectionToken, Input } from '@angular/core';
|
|
2
|
+
import { AbstractTuiController } from '@taiga-ui/cdk';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
// TODO: rename to TUI_TEXTFIELD_APPEARANCE in v4
|
|
5
|
+
export const TUI_TEXTFIELD_APPEARANCE_DIRECTIVE = new InjectionToken('[TUI_TEXTFIELD_APPEARANCE_DIRECTIVE]: tuiTextfieldAppearance', {
|
|
6
|
+
factory: () => new TuiTextfieldAppearanceDirective(),
|
|
7
|
+
});
|
|
8
|
+
export class TuiTextfieldAppearanceDirective extends AbstractTuiController {
|
|
9
|
+
constructor() {
|
|
10
|
+
super(...arguments);
|
|
11
|
+
// it's an empty string by default for backward compatibility
|
|
12
|
+
// (see comment https://github.com/Tinkoff/taiga-ui/pull/3007#issuecomment-1315179508)
|
|
13
|
+
this.appearance = '';
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
TuiTextfieldAppearanceDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiTextfieldAppearanceDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive });
|
|
17
|
+
TuiTextfieldAppearanceDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.17", type: TuiTextfieldAppearanceDirective, selector: "[tuiTextfieldAppearance]", inputs: { appearance: ["tuiTextfieldAppearance", "appearance"] }, providers: [
|
|
18
|
+
{
|
|
19
|
+
provide: TUI_TEXTFIELD_APPEARANCE_DIRECTIVE,
|
|
20
|
+
useExisting: forwardRef(() => TuiTextfieldAppearanceDirective),
|
|
21
|
+
},
|
|
22
|
+
], usesInheritance: true, ngImport: i0 });
|
|
23
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiTextfieldAppearanceDirective, decorators: [{
|
|
24
|
+
type: Directive,
|
|
25
|
+
args: [{
|
|
26
|
+
selector: '[tuiTextfieldAppearance]',
|
|
27
|
+
providers: [
|
|
28
|
+
{
|
|
29
|
+
provide: TUI_TEXTFIELD_APPEARANCE_DIRECTIVE,
|
|
30
|
+
useExisting: forwardRef(() => TuiTextfieldAppearanceDirective),
|
|
31
|
+
},
|
|
32
|
+
],
|
|
33
|
+
}]
|
|
34
|
+
}], propDecorators: { appearance: [{
|
|
35
|
+
type: Input,
|
|
36
|
+
args: ['tuiTextfieldAppearance']
|
|
37
|
+
}] } });
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dGZpZWxkLWFwcGVhcmFuY2UuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9kaXJlY3RpdmVzL3RleHRmaWVsZC1jb250cm9sbGVyL3RleHRmaWVsZC1hcHBlYXJhbmNlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFVBQVUsRUFBRSxjQUFjLEVBQUUsS0FBSyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQzNFLE9BQU8sRUFBQyxxQkFBcUIsRUFBQyxNQUFNLGVBQWUsQ0FBQzs7QUFFcEQsaURBQWlEO0FBQ2pELE1BQU0sQ0FBQyxNQUFNLGtDQUFrQyxHQUMzQyxJQUFJLGNBQWMsQ0FDZCw4REFBOEQsRUFDOUQ7SUFDSSxPQUFPLEVBQUUsR0FBRyxFQUFFLENBQUMsSUFBSSwrQkFBK0IsRUFBRTtDQUN2RCxDQUNKLENBQUM7QUFXTixNQUFNLE9BQU8sK0JBQWdDLFNBQVEscUJBQXFCO0lBVDFFOztRQVVJLDZEQUE2RDtRQUM3RCxzRkFBc0Y7UUFFdEYsZUFBVSxHQUFHLEVBQUUsQ0FBQztLQUNuQjs7NkhBTFksK0JBQStCO2lIQUEvQiwrQkFBK0IscUhBUDdCO1FBQ1A7WUFDSSxPQUFPLEVBQUUsa0NBQWtDO1lBQzNDLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsK0JBQStCLENBQUM7U0FDakU7S0FDSjs0RkFFUSwrQkFBK0I7a0JBVDNDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLDBCQUEwQjtvQkFDcEMsU0FBUyxFQUFFO3dCQUNQOzRCQUNJLE9BQU8sRUFBRSxrQ0FBa0M7NEJBQzNDLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLGdDQUFnQyxDQUFDO3lCQUNqRTtxQkFDSjtpQkFDSjs4QkFLRyxVQUFVO3NCQURULEtBQUs7dUJBQUMsd0JBQXdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEaXJlY3RpdmUsIGZvcndhcmRSZWYsIEluamVjdGlvblRva2VuLCBJbnB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0Fic3RyYWN0VHVpQ29udHJvbGxlcn0gZnJvbSAnQHRhaWdhLXVpL2Nkayc7XG5cbi8vIFRPRE86IHJlbmFtZSB0byBUVUlfVEVYVEZJRUxEX0FQUEVBUkFOQ0UgaW4gdjRcbmV4cG9ydCBjb25zdCBUVUlfVEVYVEZJRUxEX0FQUEVBUkFOQ0VfRElSRUNUSVZFID1cbiAgICBuZXcgSW5qZWN0aW9uVG9rZW48VHVpVGV4dGZpZWxkQXBwZWFyYW5jZURpcmVjdGl2ZT4oXG4gICAgICAgICdbVFVJX1RFWFRGSUVMRF9BUFBFQVJBTkNFX0RJUkVDVElWRV06IHR1aVRleHRmaWVsZEFwcGVhcmFuY2UnLFxuICAgICAgICB7XG4gICAgICAgICAgICBmYWN0b3J5OiAoKSA9PiBuZXcgVHVpVGV4dGZpZWxkQXBwZWFyYW5jZURpcmVjdGl2ZSgpLFxuICAgICAgICB9LFxuICAgICk7XG5cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW3R1aVRleHRmaWVsZEFwcGVhcmFuY2VdJyxcbiAgICBwcm92aWRlcnM6IFtcbiAgICAgICAge1xuICAgICAgICAgICAgcHJvdmlkZTogVFVJX1RFWFRGSUVMRF9BUFBFQVJBTkNFX0RJUkVDVElWRSxcbiAgICAgICAgICAgIHVzZUV4aXN0aW5nOiBmb3J3YXJkUmVmKCgpID0+IFR1aVRleHRmaWVsZEFwcGVhcmFuY2VEaXJlY3RpdmUpLFxuICAgICAgICB9LFxuICAgIF0sXG59KVxuZXhwb3J0IGNsYXNzIFR1aVRleHRmaWVsZEFwcGVhcmFuY2VEaXJlY3RpdmUgZXh0ZW5kcyBBYnN0cmFjdFR1aUNvbnRyb2xsZXIge1xuICAgIC8vIGl0J3MgYW4gZW1wdHkgc3RyaW5nIGJ5IGRlZmF1bHQgZm9yIGJhY2t3YXJkIGNvbXBhdGliaWxpdHlcbiAgICAvLyAoc2VlIGNvbW1lbnQgaHR0cHM6Ly9naXRodWIuY29tL1RpbmtvZmYvdGFpZ2EtdWkvcHVsbC8zMDA3I2lzc3VlY29tbWVudC0xMzE1MTc5NTA4KVxuICAgIEBJbnB1dCgndHVpVGV4dGZpZWxkQXBwZWFyYW5jZScpXG4gICAgYXBwZWFyYW5jZSA9ICcnO1xufVxuIl19
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { NgModule } from '@angular/core';
|
|
2
|
+
import { TuiTextfieldAppearanceDirective } from './textfield-appearance.directive';
|
|
2
3
|
import { TuiTextfieldCleanerDirective } from './textfield-cleaner.directive';
|
|
3
4
|
import { TuiTextfieldCustomContentDirective } from './textfield-custom-content.directive';
|
|
4
5
|
import { TuiTextfieldFillerDirective } from './textfield-filler.directive';
|
|
@@ -12,7 +13,8 @@ import * as i0 from "@angular/core";
|
|
|
12
13
|
export class TuiTextfieldControllerModule {
|
|
13
14
|
}
|
|
14
15
|
TuiTextfieldControllerModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiTextfieldControllerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
15
|
-
TuiTextfieldControllerModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiTextfieldControllerModule, declarations: [
|
|
16
|
+
TuiTextfieldControllerModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiTextfieldControllerModule, declarations: [TuiTextfieldAppearanceDirective,
|
|
17
|
+
TuiTextfieldCleanerDirective,
|
|
16
18
|
TuiTextfieldCustomContentDirective,
|
|
17
19
|
TuiTextfieldLabelOutsideDirective,
|
|
18
20
|
TuiTextfieldSizeDirective,
|
|
@@ -20,7 +22,8 @@ TuiTextfieldControllerModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.
|
|
|
20
22
|
TuiTextfieldIconLeftDirective,
|
|
21
23
|
TuiTextfieldPrefixDirective,
|
|
22
24
|
TuiTextfieldPostfixDirective,
|
|
23
|
-
TuiTextfieldFillerDirective], exports: [
|
|
25
|
+
TuiTextfieldFillerDirective], exports: [TuiTextfieldAppearanceDirective,
|
|
26
|
+
TuiTextfieldCleanerDirective,
|
|
24
27
|
TuiTextfieldCustomContentDirective,
|
|
25
28
|
TuiTextfieldLabelOutsideDirective,
|
|
26
29
|
TuiTextfieldSizeDirective,
|
|
@@ -34,6 +37,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
34
37
|
type: NgModule,
|
|
35
38
|
args: [{
|
|
36
39
|
declarations: [
|
|
40
|
+
TuiTextfieldAppearanceDirective,
|
|
37
41
|
TuiTextfieldCleanerDirective,
|
|
38
42
|
TuiTextfieldCustomContentDirective,
|
|
39
43
|
TuiTextfieldLabelOutsideDirective,
|
|
@@ -45,6 +49,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
45
49
|
TuiTextfieldFillerDirective,
|
|
46
50
|
],
|
|
47
51
|
exports: [
|
|
52
|
+
TuiTextfieldAppearanceDirective,
|
|
48
53
|
TuiTextfieldCleanerDirective,
|
|
49
54
|
TuiTextfieldCustomContentDirective,
|
|
50
55
|
TuiTextfieldLabelOutsideDirective,
|
|
@@ -57,4 +62,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
57
62
|
],
|
|
58
63
|
}]
|
|
59
64
|
}] });
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dGZpZWxkLWNvbnRyb2xsZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9kaXJlY3RpdmVzL3RleHRmaWVsZC1jb250cm9sbGVyL3RleHRmaWVsZC1jb250cm9sbGVyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRXZDLE9BQU8sRUFBQywrQkFBK0IsRUFBQyxNQUFNLGtDQUFrQyxDQUFDO0FBQ2pGLE9BQU8sRUFBQyw0QkFBNEIsRUFBQyxNQUFNLCtCQUErQixDQUFDO0FBQzNFLE9BQU8sRUFBQyxrQ0FBa0MsRUFBQyxNQUFNLHNDQUFzQyxDQUFDO0FBQ3hGLE9BQU8sRUFBQywyQkFBMkIsRUFBQyxNQUFNLDhCQUE4QixDQUFDO0FBQ3pFLE9BQU8sRUFBQyx5QkFBeUIsRUFBQyxNQUFNLDRCQUE0QixDQUFDO0FBQ3JFLE9BQU8sRUFBQyw2QkFBNkIsRUFBQyxNQUFNLGlDQUFpQyxDQUFDO0FBQzlFLE9BQU8sRUFBQyxpQ0FBaUMsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQ3RGLE9BQU8sRUFBQyw0QkFBNEIsRUFBQyxNQUFNLCtCQUErQixDQUFDO0FBQzNFLE9BQU8sRUFBQywyQkFBMkIsRUFBQyxNQUFNLDhCQUE4QixDQUFDO0FBQ3pFLE9BQU8sRUFBQyx5QkFBeUIsRUFBQyxNQUFNLDRCQUE0QixDQUFDOztBQTRCckUsTUFBTSxPQUFPLDRCQUE0Qjs7MEhBQTVCLDRCQUE0QjsySEFBNUIsNEJBQTRCLGlCQXhCakMsK0JBQStCO1FBQy9CLDRCQUE0QjtRQUM1QixrQ0FBa0M7UUFDbEMsaUNBQWlDO1FBQ2pDLHlCQUF5QjtRQUN6Qix5QkFBeUI7UUFDekIsNkJBQTZCO1FBQzdCLDJCQUEyQjtRQUMzQiw0QkFBNEI7UUFDNUIsMkJBQTJCLGFBRzNCLCtCQUErQjtRQUMvQiw0QkFBNEI7UUFDNUIsa0NBQWtDO1FBQ2xDLGlDQUFpQztRQUNqQyx5QkFBeUI7UUFDekIseUJBQXlCO1FBQ3pCLDZCQUE2QjtRQUM3QiwyQkFBMkI7UUFDM0IsNEJBQTRCO1FBQzVCLDJCQUEyQjsySEFHdEIsNEJBQTRCOzRGQUE1Qiw0QkFBNEI7a0JBMUJ4QyxRQUFRO21CQUFDO29CQUNOLFlBQVksRUFBRTt3QkFDViwrQkFBK0I7d0JBQy9CLDRCQUE0Qjt3QkFDNUIsa0NBQWtDO3dCQUNsQyxpQ0FBaUM7d0JBQ2pDLHlCQUF5Qjt3QkFDekIseUJBQXlCO3dCQUN6Qiw2QkFBNkI7d0JBQzdCLDJCQUEyQjt3QkFDM0IsNEJBQTRCO3dCQUM1QiwyQkFBMkI7cUJBQzlCO29CQUNELE9BQU8sRUFBRTt3QkFDTCwrQkFBK0I7d0JBQy9CLDRCQUE0Qjt3QkFDNUIsa0NBQWtDO3dCQUNsQyxpQ0FBaUM7d0JBQ2pDLHlCQUF5Qjt3QkFDekIseUJBQXlCO3dCQUN6Qiw2QkFBNkI7d0JBQzdCLDJCQUEyQjt3QkFDM0IsNEJBQTRCO3dCQUM1QiwyQkFBMkI7cUJBQzlCO2lCQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7VHVpVGV4dGZpZWxkQXBwZWFyYW5jZURpcmVjdGl2ZX0gZnJvbSAnLi90ZXh0ZmllbGQtYXBwZWFyYW5jZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHtUdWlUZXh0ZmllbGRDbGVhbmVyRGlyZWN0aXZlfSBmcm9tICcuL3RleHRmaWVsZC1jbGVhbmVyLmRpcmVjdGl2ZSc7XG5pbXBvcnQge1R1aVRleHRmaWVsZEN1c3RvbUNvbnRlbnREaXJlY3RpdmV9IGZyb20gJy4vdGV4dGZpZWxkLWN1c3RvbS1jb250ZW50LmRpcmVjdGl2ZSc7XG5pbXBvcnQge1R1aVRleHRmaWVsZEZpbGxlckRpcmVjdGl2ZX0gZnJvbSAnLi90ZXh0ZmllbGQtZmlsbGVyLmRpcmVjdGl2ZSc7XG5pbXBvcnQge1R1aVRleHRmaWVsZEljb25EaXJlY3RpdmV9IGZyb20gJy4vdGV4dGZpZWxkLWljb24uZGlyZWN0aXZlJztcbmltcG9ydCB7VHVpVGV4dGZpZWxkSWNvbkxlZnREaXJlY3RpdmV9IGZyb20gJy4vdGV4dGZpZWxkLWljb24tbGVmdC5kaXJlY3RpdmUnO1xuaW1wb3J0IHtUdWlUZXh0ZmllbGRMYWJlbE91dHNpZGVEaXJlY3RpdmV9IGZyb20gJy4vdGV4dGZpZWxkLWxhYmVsLW91dHNpZGUuZGlyZWN0aXZlJztcbmltcG9ydCB7VHVpVGV4dGZpZWxkUG9zdGZpeERpcmVjdGl2ZX0gZnJvbSAnLi90ZXh0ZmllbGQtcG9zdGZpeC5kaXJlY3RpdmUnO1xuaW1wb3J0IHtUdWlUZXh0ZmllbGRQcmVmaXhEaXJlY3RpdmV9IGZyb20gJy4vdGV4dGZpZWxkLXByZWZpeC5kaXJlY3RpdmUnO1xuaW1wb3J0IHtUdWlUZXh0ZmllbGRTaXplRGlyZWN0aXZlfSBmcm9tICcuL3RleHRmaWVsZC1zaXplLmRpcmVjdGl2ZSc7XG5cbkBOZ01vZHVsZSh7XG4gICAgZGVjbGFyYXRpb25zOiBbXG4gICAgICAgIFR1aVRleHRmaWVsZEFwcGVhcmFuY2VEaXJlY3RpdmUsXG4gICAgICAgIFR1aVRleHRmaWVsZENsZWFuZXJEaXJlY3RpdmUsXG4gICAgICAgIFR1aVRleHRmaWVsZEN1c3RvbUNvbnRlbnREaXJlY3RpdmUsXG4gICAgICAgIFR1aVRleHRmaWVsZExhYmVsT3V0c2lkZURpcmVjdGl2ZSxcbiAgICAgICAgVHVpVGV4dGZpZWxkU2l6ZURpcmVjdGl2ZSxcbiAgICAgICAgVHVpVGV4dGZpZWxkSWNvbkRpcmVjdGl2ZSxcbiAgICAgICAgVHVpVGV4dGZpZWxkSWNvbkxlZnREaXJlY3RpdmUsXG4gICAgICAgIFR1aVRleHRmaWVsZFByZWZpeERpcmVjdGl2ZSxcbiAgICAgICAgVHVpVGV4dGZpZWxkUG9zdGZpeERpcmVjdGl2ZSxcbiAgICAgICAgVHVpVGV4dGZpZWxkRmlsbGVyRGlyZWN0aXZlLFxuICAgIF0sXG4gICAgZXhwb3J0czogW1xuICAgICAgICBUdWlUZXh0ZmllbGRBcHBlYXJhbmNlRGlyZWN0aXZlLFxuICAgICAgICBUdWlUZXh0ZmllbGRDbGVhbmVyRGlyZWN0aXZlLFxuICAgICAgICBUdWlUZXh0ZmllbGRDdXN0b21Db250ZW50RGlyZWN0aXZlLFxuICAgICAgICBUdWlUZXh0ZmllbGRMYWJlbE91dHNpZGVEaXJlY3RpdmUsXG4gICAgICAgIFR1aVRleHRmaWVsZFNpemVEaXJlY3RpdmUsXG4gICAgICAgIFR1aVRleHRmaWVsZEljb25EaXJlY3RpdmUsXG4gICAgICAgIFR1aVRleHRmaWVsZEljb25MZWZ0RGlyZWN0aXZlLFxuICAgICAgICBUdWlUZXh0ZmllbGRQcmVmaXhEaXJlY3RpdmUsXG4gICAgICAgIFR1aVRleHRmaWVsZFBvc3RmaXhEaXJlY3RpdmUsXG4gICAgICAgIFR1aVRleHRmaWVsZEZpbGxlckRpcmVjdGl2ZSxcbiAgICBdLFxufSlcbmV4cG9ydCBjbGFzcyBUdWlUZXh0ZmllbGRDb250cm9sbGVyTW9kdWxlIHt9XG4iXX0=
|
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
import { ChangeDetectorRef, InjectionToken } from '@angular/core';
|
|
2
2
|
import { TuiDestroyService, tuiWatch } from '@taiga-ui/cdk';
|
|
3
|
+
import { TUI_TEXTFIELD_APPEARANCE } from '@taiga-ui/core/tokens';
|
|
3
4
|
import { merge, NEVER } from 'rxjs';
|
|
4
5
|
import { takeUntil } from 'rxjs/operators';
|
|
5
6
|
import { TuiTextfieldController } from './textfield.controller';
|
|
7
|
+
import { TUI_TEXTFIELD_APPEARANCE_DIRECTIVE, } from './textfield-appearance.directive';
|
|
6
8
|
import { TUI_TEXTFIELD_CLEANER, } from './textfield-cleaner.directive';
|
|
7
9
|
import { TUI_TEXTFIELD_CUSTOM_CONTENT, } from './textfield-custom-content.directive';
|
|
8
10
|
import { TUI_TEXTFIELD_FILLER, } from './textfield-filler.directive';
|
|
@@ -22,6 +24,8 @@ export const TEXTFIELD_CONTROLLER_PROVIDER = [
|
|
|
22
24
|
ChangeDetectorRef,
|
|
23
25
|
TuiDestroyService,
|
|
24
26
|
TUI_TEXTFIELD_OPTIONS,
|
|
27
|
+
TUI_TEXTFIELD_APPEARANCE,
|
|
28
|
+
TUI_TEXTFIELD_APPEARANCE_DIRECTIVE,
|
|
25
29
|
TUI_TEXTFIELD_CLEANER,
|
|
26
30
|
TUI_TEXTFIELD_CUSTOM_CONTENT,
|
|
27
31
|
TUI_TEXTFIELD_ICON,
|
|
@@ -32,11 +36,11 @@ export const TEXTFIELD_CONTROLLER_PROVIDER = [
|
|
|
32
36
|
TUI_TEXTFIELD_POSTFIX,
|
|
33
37
|
TUI_TEXTFIELD_FILLER,
|
|
34
38
|
],
|
|
35
|
-
useFactory: (changeDetectorRef, destroy$, options, ...controllers) => {
|
|
39
|
+
useFactory: (changeDetectorRef, destroy$, options, legacyAppearance, ...controllers) => {
|
|
36
40
|
const change$ = merge(...controllers.map(({ change$ }) => change$ || NEVER)).pipe(tuiWatch(changeDetectorRef), takeUntil(destroy$));
|
|
37
41
|
change$.subscribe();
|
|
38
|
-
return new TuiTextfieldController(change$, options, ...controllers);
|
|
42
|
+
return new TuiTextfieldController(change$, options, legacyAppearance, ...controllers);
|
|
39
43
|
},
|
|
40
44
|
},
|
|
41
45
|
];
|
|
42
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dGZpZWxkLWNvbnRyb2xsZXIucHJvdmlkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2RpcmVjdGl2ZXMvdGV4dGZpZWxkLWNvbnRyb2xsZXIvdGV4dGZpZWxkLWNvbnRyb2xsZXIucHJvdmlkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLGlCQUFpQixFQUFFLGNBQWMsRUFBVyxNQUFNLGVBQWUsQ0FBQztBQUMxRSxPQUFPLEVBQUMsaUJBQWlCLEVBQUUsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQzFELE9BQU8sRUFBQyx3QkFBd0IsRUFBQyxNQUFNLHVCQUF1QixDQUFDO0FBQy9ELE9BQU8sRUFBQyxLQUFLLEVBQUUsS0FBSyxFQUFhLE1BQU0sTUFBTSxDQUFDO0FBQzlDLE9BQU8sRUFBQyxTQUFTLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUV6QyxPQUFPLEVBQUMsc0JBQXNCLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQztBQUM5RCxPQUFPLEVBQ0gsa0NBQWtDLEdBRXJDLE1BQU0sa0NBQWtDLENBQUM7QUFDMUMsT0FBTyxFQUNILHFCQUFxQixHQUV4QixNQUFNLCtCQUErQixDQUFDO0FBQ3ZDLE9BQU8sRUFDSCw0QkFBNEIsR0FFL0IsTUFBTSxzQ0FBc0MsQ0FBQztBQUM5QyxPQUFPLEVBQ0gsb0JBQW9CLEdBRXZCLE1BQU0sOEJBQThCLENBQUM7QUFDdEMsT0FBTyxFQUFDLGtCQUFrQixFQUE0QixNQUFNLDRCQUE0QixDQUFDO0FBQ3pGLE9BQU8sRUFDSCx1QkFBdUIsR0FFMUIsTUFBTSxpQ0FBaUMsQ0FBQztBQUN6QyxPQUFPLEVBQ0gsMkJBQTJCLEdBRTlCLE1BQU0scUNBQXFDLENBQUM7QUFDN0MsT0FBTyxFQUFDLHFCQUFxQixFQUFzQixNQUFNLHFCQUFxQixDQUFDO0FBQy9FLE9BQU8sRUFDSCxxQkFBcUIsR0FFeEIsTUFBTSwrQkFBK0IsQ0FBQztBQUN2QyxPQUFPLEVBQ0gsb0JBQW9CLEdBRXZCLE1BQU0sOEJBQThCLENBQUM7QUFDdEMsT0FBTyxFQUFDLGtCQUFrQixFQUE0QixNQUFNLDRCQUE0QixDQUFDO0FBRXpGLE1BQU0sQ0FBQyxNQUFNLGdDQUFnQyxHQUN6QyxJQUFJLGNBQWMsQ0FDZCxrRUFBa0UsQ0FDckUsQ0FBQztBQUVOLE1BQU0sQ0FBQyxNQUFNLDZCQUE2QixHQUFhO0lBQ25ELGlCQUFpQjtJQUNqQjtRQUNJLE9BQU8sRUFBRSxnQ0FBZ0M7UUFDekMsSUFBSSxFQUFFO1lBQ0YsaUJBQWlCO1lBQ2pCLGlCQUFpQjtZQUNqQixxQkFBcUI7WUFDckIsd0JBQXdCO1lBQ3hCLGtDQUFrQztZQUNsQyxxQkFBcUI7WUFDckIsNEJBQTRCO1lBQzVCLGtCQUFrQjtZQUNsQix1QkFBdUI7WUFDdkIsMkJBQTJCO1lBQzNCLGtCQUFrQjtZQUNsQixvQkFBb0I7WUFDcEIscUJBQXFCO1lBQ3JCLG9CQUFvQjtTQUN2QjtRQUNELFVBQVUsRUFBRSxDQUNSLGlCQUFvQyxFQUNwQyxRQUEwQixFQUMxQixPQUE0QixFQUM1QixnQkFBd0IsRUFDeEIsR0FBRyxXQVdGLEVBQ0gsRUFBRTtZQUNBLE1BQU0sT0FBTyxHQUFHLEtBQUssQ0FDakIsR0FBRyxXQUFXLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBQyxPQUFPLEVBQUMsRUFBRSxFQUFFLENBQUMsT0FBTyxJQUFJLEtBQUssQ0FBQyxDQUN0RCxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsaUJBQWlCLENBQUMsRUFBRSxTQUFTLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztZQUV6RCxPQUFPLENBQUMsU0FBUyxFQUFFLENBQUM7WUFFcEIsT0FBTyxJQUFJLHNCQUFzQixDQUM3QixPQUFPLEVBQ1AsT0FBTyxFQUNQLGdCQUFnQixFQUNoQixHQUFHLFdBQVcsQ0FDakIsQ0FBQztRQUNOLENBQUM7S0FDSjtDQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NoYW5nZURldGVjdG9yUmVmLCBJbmplY3Rpb25Ub2tlbiwgUHJvdmlkZXJ9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtUdWlEZXN0cm95U2VydmljZSwgdHVpV2F0Y2h9IGZyb20gJ0B0YWlnYS11aS9jZGsnO1xuaW1wb3J0IHtUVUlfVEVYVEZJRUxEX0FQUEVBUkFOQ0V9IGZyb20gJ0B0YWlnYS11aS9jb3JlL3Rva2Vucyc7XG5pbXBvcnQge21lcmdlLCBORVZFUiwgT2JzZXJ2YWJsZX0gZnJvbSAncnhqcyc7XG5pbXBvcnQge3Rha2VVbnRpbH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5pbXBvcnQge1R1aVRleHRmaWVsZENvbnRyb2xsZXJ9IGZyb20gJy4vdGV4dGZpZWxkLmNvbnRyb2xsZXInO1xuaW1wb3J0IHtcbiAgICBUVUlfVEVYVEZJRUxEX0FQUEVBUkFOQ0VfRElSRUNUSVZFLFxuICAgIFR1aVRleHRmaWVsZEFwcGVhcmFuY2VEaXJlY3RpdmUsXG59IGZyb20gJy4vdGV4dGZpZWxkLWFwcGVhcmFuY2UuZGlyZWN0aXZlJztcbmltcG9ydCB7XG4gICAgVFVJX1RFWFRGSUVMRF9DTEVBTkVSLFxuICAgIFR1aVRleHRmaWVsZENsZWFuZXJEaXJlY3RpdmUsXG59IGZyb20gJy4vdGV4dGZpZWxkLWNsZWFuZXIuZGlyZWN0aXZlJztcbmltcG9ydCB7XG4gICAgVFVJX1RFWFRGSUVMRF9DVVNUT01fQ09OVEVOVCxcbiAgICBUdWlUZXh0ZmllbGRDdXN0b21Db250ZW50RGlyZWN0aXZlLFxufSBmcm9tICcuL3RleHRmaWVsZC1jdXN0b20tY29udGVudC5kaXJlY3RpdmUnO1xuaW1wb3J0IHtcbiAgICBUVUlfVEVYVEZJRUxEX0ZJTExFUixcbiAgICBUdWlUZXh0ZmllbGRGaWxsZXJEaXJlY3RpdmUsXG59IGZyb20gJy4vdGV4dGZpZWxkLWZpbGxlci5kaXJlY3RpdmUnO1xuaW1wb3J0IHtUVUlfVEVYVEZJRUxEX0lDT04sIFR1aVRleHRmaWVsZEljb25EaXJlY3RpdmV9IGZyb20gJy4vdGV4dGZpZWxkLWljb24uZGlyZWN0aXZlJztcbmltcG9ydCB7XG4gICAgVFVJX1RFWFRGSUVMRF9JQ09OX0xFRlQsXG4gICAgVHVpVGV4dGZpZWxkSWNvbkxlZnREaXJlY3RpdmUsXG59IGZyb20gJy4vdGV4dGZpZWxkLWljb24tbGVmdC5kaXJlY3RpdmUnO1xuaW1wb3J0IHtcbiAgICBUVUlfVEVYVEZJRUxEX0xBQkVMX09VVFNJREUsXG4gICAgVHVpVGV4dGZpZWxkTGFiZWxPdXRzaWRlRGlyZWN0aXZlLFxufSBmcm9tICcuL3RleHRmaWVsZC1sYWJlbC1vdXRzaWRlLmRpcmVjdGl2ZSc7XG5pbXBvcnQge1RVSV9URVhURklFTERfT1BUSU9OUywgVHVpVGV4dGZpZWxkT3B0aW9uc30gZnJvbSAnLi90ZXh0ZmllbGQtb3B0aW9ucyc7XG5pbXBvcnQge1xuICAgIFRVSV9URVhURklFTERfUE9TVEZJWCxcbiAgICBUdWlUZXh0ZmllbGRQb3N0Zml4RGlyZWN0aXZlLFxufSBmcm9tICcuL3RleHRmaWVsZC1wb3N0Zml4LmRpcmVjdGl2ZSc7XG5pbXBvcnQge1xuICAgIFRVSV9URVhURklFTERfUFJFRklYLFxuICAgIFR1aVRleHRmaWVsZFByZWZpeERpcmVjdGl2ZSxcbn0gZnJvbSAnLi90ZXh0ZmllbGQtcHJlZml4LmRpcmVjdGl2ZSc7XG5pbXBvcnQge1RVSV9URVhURklFTERfU0laRSwgVHVpVGV4dGZpZWxkU2l6ZURpcmVjdGl2ZX0gZnJvbSAnLi90ZXh0ZmllbGQtc2l6ZS5kaXJlY3RpdmUnO1xuXG5leHBvcnQgY29uc3QgVFVJX1RFWFRGSUVMRF9XQVRDSEVEX0NPTlRST0xMRVIgPVxuICAgIG5ldyBJbmplY3Rpb25Ub2tlbjxUdWlUZXh0ZmllbGRDb250cm9sbGVyPihcbiAgICAgICAgYFtUVUlfVEVYVEZJRUxEX1dBVENIRURfQ09OVFJPTExFUl06IHdhdGNoZWQgdGV4dGZpZWxkIGNvbnRyb2xsZXJgLFxuICAgICk7XG5cbmV4cG9ydCBjb25zdCBURVhURklFTERfQ09OVFJPTExFUl9QUk9WSURFUjogUHJvdmlkZXIgPSBbXG4gICAgVHVpRGVzdHJveVNlcnZpY2UsXG4gICAge1xuICAgICAgICBwcm92aWRlOiBUVUlfVEVYVEZJRUxEX1dBVENIRURfQ09OVFJPTExFUixcbiAgICAgICAgZGVwczogW1xuICAgICAgICAgICAgQ2hhbmdlRGV0ZWN0b3JSZWYsXG4gICAgICAgICAgICBUdWlEZXN0cm95U2VydmljZSxcbiAgICAgICAgICAgIFRVSV9URVhURklFTERfT1BUSU9OUyxcbiAgICAgICAgICAgIFRVSV9URVhURklFTERfQVBQRUFSQU5DRSxcbiAgICAgICAgICAgIFRVSV9URVhURklFTERfQVBQRUFSQU5DRV9ESVJFQ1RJVkUsXG4gICAgICAgICAgICBUVUlfVEVYVEZJRUxEX0NMRUFORVIsXG4gICAgICAgICAgICBUVUlfVEVYVEZJRUxEX0NVU1RPTV9DT05URU5ULFxuICAgICAgICAgICAgVFVJX1RFWFRGSUVMRF9JQ09OLFxuICAgICAgICAgICAgVFVJX1RFWFRGSUVMRF9JQ09OX0xFRlQsXG4gICAgICAgICAgICBUVUlfVEVYVEZJRUxEX0xBQkVMX09VVFNJREUsXG4gICAgICAgICAgICBUVUlfVEVYVEZJRUxEX1NJWkUsXG4gICAgICAgICAgICBUVUlfVEVYVEZJRUxEX1BSRUZJWCxcbiAgICAgICAgICAgIFRVSV9URVhURklFTERfUE9TVEZJWCxcbiAgICAgICAgICAgIFRVSV9URVhURklFTERfRklMTEVSLFxuICAgICAgICBdLFxuICAgICAgICB1c2VGYWN0b3J5OiAoXG4gICAgICAgICAgICBjaGFuZ2VEZXRlY3RvclJlZjogQ2hhbmdlRGV0ZWN0b3JSZWYsXG4gICAgICAgICAgICBkZXN0cm95JDogT2JzZXJ2YWJsZTx2b2lkPixcbiAgICAgICAgICAgIG9wdGlvbnM6IFR1aVRleHRmaWVsZE9wdGlvbnMsXG4gICAgICAgICAgICBsZWdhY3lBcHBlYXJhbmNlOiBzdHJpbmcsXG4gICAgICAgICAgICAuLi5jb250cm9sbGVyczogW1xuICAgICAgICAgICAgICAgIFR1aVRleHRmaWVsZEFwcGVhcmFuY2VEaXJlY3RpdmUsXG4gICAgICAgICAgICAgICAgVHVpVGV4dGZpZWxkQ2xlYW5lckRpcmVjdGl2ZSxcbiAgICAgICAgICAgICAgICBUdWlUZXh0ZmllbGRDdXN0b21Db250ZW50RGlyZWN0aXZlLFxuICAgICAgICAgICAgICAgIFR1aVRleHRmaWVsZEljb25EaXJlY3RpdmUsXG4gICAgICAgICAgICAgICAgVHVpVGV4dGZpZWxkSWNvbkxlZnREaXJlY3RpdmUsXG4gICAgICAgICAgICAgICAgVHVpVGV4dGZpZWxkTGFiZWxPdXRzaWRlRGlyZWN0aXZlLFxuICAgICAgICAgICAgICAgIFR1aVRleHRmaWVsZFNpemVEaXJlY3RpdmUsXG4gICAgICAgICAgICAgICAgVHVpVGV4dGZpZWxkUHJlZml4RGlyZWN0aXZlLFxuICAgICAgICAgICAgICAgIFR1aVRleHRmaWVsZFBvc3RmaXhEaXJlY3RpdmUsXG4gICAgICAgICAgICAgICAgVHVpVGV4dGZpZWxkRmlsbGVyRGlyZWN0aXZlLFxuICAgICAgICAgICAgXVxuICAgICAgICApID0+IHtcbiAgICAgICAgICAgIGNvbnN0IGNoYW5nZSQgPSBtZXJnZShcbiAgICAgICAgICAgICAgICAuLi5jb250cm9sbGVycy5tYXAoKHtjaGFuZ2UkfSkgPT4gY2hhbmdlJCB8fCBORVZFUiksXG4gICAgICAgICAgICApLnBpcGUodHVpV2F0Y2goY2hhbmdlRGV0ZWN0b3JSZWYpLCB0YWtlVW50aWwoZGVzdHJveSQpKTtcblxuICAgICAgICAgICAgY2hhbmdlJC5zdWJzY3JpYmUoKTtcblxuICAgICAgICAgICAgcmV0dXJuIG5ldyBUdWlUZXh0ZmllbGRDb250cm9sbGVyKFxuICAgICAgICAgICAgICAgIGNoYW5nZSQsXG4gICAgICAgICAgICAgICAgb3B0aW9ucyxcbiAgICAgICAgICAgICAgICBsZWdhY3lBcHBlYXJhbmNlLFxuICAgICAgICAgICAgICAgIC4uLmNvbnRyb2xsZXJzLFxuICAgICAgICAgICAgKTtcbiAgICAgICAgfSxcbiAgICB9LFxuXTtcbiJdfQ==
|
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
export class TuiTextfieldController {
|
|
2
|
-
constructor(change$, options, cleanerDirective, customContentDirective, iconDirective, iconLeftDirective, labelOutsideDirective, sizeDirective, prefixDirective, postfixDirective, fillerDirective) {
|
|
2
|
+
constructor(change$, options, legacyAppearance, appearanceDirective, cleanerDirective, customContentDirective, iconDirective, iconLeftDirective, labelOutsideDirective, sizeDirective, prefixDirective, postfixDirective, fillerDirective) {
|
|
3
3
|
this.change$ = change$;
|
|
4
4
|
this.options = options;
|
|
5
|
+
this.legacyAppearance = legacyAppearance;
|
|
6
|
+
this.appearanceDirective = appearanceDirective;
|
|
5
7
|
this.cleanerDirective = cleanerDirective;
|
|
6
8
|
this.customContentDirective = customContentDirective;
|
|
7
9
|
this.iconDirective = iconDirective;
|
|
@@ -12,6 +14,9 @@ export class TuiTextfieldController {
|
|
|
12
14
|
this.postfixDirective = postfixDirective;
|
|
13
15
|
this.fillerDirective = fillerDirective;
|
|
14
16
|
}
|
|
17
|
+
get appearance() {
|
|
18
|
+
return this.appearanceDirective.appearance || this.legacyAppearance;
|
|
19
|
+
}
|
|
15
20
|
get cleaner() {
|
|
16
21
|
return this.cleanerDirective.cleaner;
|
|
17
22
|
}
|
|
@@ -40,4 +45,4 @@ export class TuiTextfieldController {
|
|
|
40
45
|
return this.fillerDirective.filler;
|
|
41
46
|
}
|
|
42
47
|
}
|
|
43
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dGZpZWxkLmNvbnRyb2xsZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2RpcmVjdGl2ZXMvdGV4dGZpZWxkLWNvbnRyb2xsZXIvdGV4dGZpZWxkLmNvbnRyb2xsZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaUJBLE1BQU0sT0FBTyxzQkFBc0I7SUFDL0IsWUFDYSxPQUF5QixFQUN6QixPQUE0QixFQUNwQixnQkFBd0IsRUFDeEIsbUJBQW9ELEVBQ3BELGdCQUE4QyxFQUM5QyxzQkFBMEQsRUFDMUQsYUFBd0MsRUFDeEMsaUJBQWdELEVBQ2hELHFCQUF3RCxFQUN4RCxhQUF3QyxFQUN4QyxlQUE0QyxFQUM1QyxnQkFBOEMsRUFDOUMsZUFBNEM7UUFacEQsWUFBTyxHQUFQLE9BQU8sQ0FBa0I7UUFDekIsWUFBTyxHQUFQLE9BQU8sQ0FBcUI7UUFDcEIscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFRO1FBQ3hCLHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBaUM7UUFDcEQscUJBQWdCLEdBQWhCLGdCQUFnQixDQUE4QjtRQUM5QywyQkFBc0IsR0FBdEIsc0JBQXNCLENBQW9DO1FBQzFELGtCQUFhLEdBQWIsYUFBYSxDQUEyQjtRQUN4QyxzQkFBaUIsR0FBakIsaUJBQWlCLENBQStCO1FBQ2hELDBCQUFxQixHQUFyQixxQkFBcUIsQ0FBbUM7UUFDeEQsa0JBQWEsR0FBYixhQUFhLENBQTJCO1FBQ3hDLG9CQUFlLEdBQWYsZUFBZSxDQUE2QjtRQUM1QyxxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQThCO1FBQzlDLG9CQUFlLEdBQWYsZUFBZSxDQUE2QjtJQUM5RCxDQUFDO0lBRUosSUFBSSxVQUFVO1FBQ1YsT0FBTyxJQUFJLENBQUMsbUJBQW1CLENBQUMsVUFBVSxJQUFJLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQztJQUN4RSxDQUFDO0lBRUQsSUFBSSxPQUFPO1FBQ1AsT0FBTyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxDQUFDO0lBQ3pDLENBQUM7SUFFRCxJQUFJLGFBQWE7UUFDYixPQUFPLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxhQUFhLElBQUksRUFBRSxDQUFDO0lBQzNELENBQUM7SUFFRCxJQUFJLElBQUk7UUFDSixPQUFPLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDO0lBQ25DLENBQUM7SUFFRCxJQUFJLFFBQVE7UUFDUixPQUFPLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxRQUFRLENBQUM7SUFDM0MsQ0FBQztJQUVELElBQUksWUFBWTtRQUNaLE9BQU8sSUFBSSxDQUFDLHFCQUFxQixDQUFDLFlBQVksQ0FBQztJQUNuRCxDQUFDO0lBRUQsSUFBSSxJQUFJO1FBQ0osT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQztJQUNuQyxDQUFDO0lBRUQsSUFBSSxNQUFNO1FBQ04sT0FBTyxJQUFJLENBQUMsZUFBZSxDQUFDLE1BQU0sQ0FBQztJQUN2QyxDQUFDO0lBRUQsSUFBSSxPQUFPO1FBQ1AsT0FBTyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxDQUFDO0lBQ3pDLENBQUM7SUFFRCxJQUFJLE1BQU07UUFDTixPQUFPLElBQUksQ0FBQyxlQUFlLENBQUMsTUFBTSxDQUFDO0lBQ3ZDLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7VHVpQ29udGV4dFdpdGhJbXBsaWNpdH0gZnJvbSAnQHRhaWdhLXVpL2Nkayc7XG5pbXBvcnQge1R1aVNpemVMLCBUdWlTaXplU30gZnJvbSAnQHRhaWdhLXVpL2NvcmUvdHlwZXMnO1xuaW1wb3J0IHtQb2x5bW9ycGhldXNDb250ZW50fSBmcm9tICdAdGlua29mZi9uZy1wb2x5bW9ycGhldXMnO1xuaW1wb3J0IHtPYnNlcnZhYmxlfSBmcm9tICdyeGpzJztcblxuaW1wb3J0IHtUdWlUZXh0ZmllbGRBcHBlYXJhbmNlRGlyZWN0aXZlfSBmcm9tICcuL3RleHRmaWVsZC1hcHBlYXJhbmNlLmRpcmVjdGl2ZSc7XG5pbXBvcnQge1R1aVRleHRmaWVsZENsZWFuZXJEaXJlY3RpdmV9IGZyb20gJy4vdGV4dGZpZWxkLWNsZWFuZXIuZGlyZWN0aXZlJztcbmltcG9ydCB7VHVpVGV4dGZpZWxkQ3VzdG9tQ29udGVudERpcmVjdGl2ZX0gZnJvbSAnLi90ZXh0ZmllbGQtY3VzdG9tLWNvbnRlbnQuZGlyZWN0aXZlJztcbmltcG9ydCB7VHVpVGV4dGZpZWxkRmlsbGVyRGlyZWN0aXZlfSBmcm9tICcuL3RleHRmaWVsZC1maWxsZXIuZGlyZWN0aXZlJztcbmltcG9ydCB7VHVpVGV4dGZpZWxkSWNvbkRpcmVjdGl2ZX0gZnJvbSAnLi90ZXh0ZmllbGQtaWNvbi5kaXJlY3RpdmUnO1xuaW1wb3J0IHtUdWlUZXh0ZmllbGRJY29uTGVmdERpcmVjdGl2ZX0gZnJvbSAnLi90ZXh0ZmllbGQtaWNvbi1sZWZ0LmRpcmVjdGl2ZSc7XG5pbXBvcnQge1R1aVRleHRmaWVsZExhYmVsT3V0c2lkZURpcmVjdGl2ZX0gZnJvbSAnLi90ZXh0ZmllbGQtbGFiZWwtb3V0c2lkZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHtUdWlUZXh0ZmllbGRPcHRpb25zfSBmcm9tICcuL3RleHRmaWVsZC1vcHRpb25zJztcbmltcG9ydCB7VHVpVGV4dGZpZWxkUG9zdGZpeERpcmVjdGl2ZX0gZnJvbSAnLi90ZXh0ZmllbGQtcG9zdGZpeC5kaXJlY3RpdmUnO1xuaW1wb3J0IHtUdWlUZXh0ZmllbGRQcmVmaXhEaXJlY3RpdmV9IGZyb20gJy4vdGV4dGZpZWxkLXByZWZpeC5kaXJlY3RpdmUnO1xuaW1wb3J0IHtUdWlUZXh0ZmllbGRTaXplRGlyZWN0aXZlfSBmcm9tICcuL3RleHRmaWVsZC1zaXplLmRpcmVjdGl2ZSc7XG5cbmV4cG9ydCBjbGFzcyBUdWlUZXh0ZmllbGRDb250cm9sbGVyIHtcbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgcmVhZG9ubHkgY2hhbmdlJDogT2JzZXJ2YWJsZTx2b2lkPixcbiAgICAgICAgcmVhZG9ubHkgb3B0aW9uczogVHVpVGV4dGZpZWxkT3B0aW9ucyxcbiAgICAgICAgcHJpdmF0ZSByZWFkb25seSBsZWdhY3lBcHBlYXJhbmNlOiBzdHJpbmcsXG4gICAgICAgIHByaXZhdGUgcmVhZG9ubHkgYXBwZWFyYW5jZURpcmVjdGl2ZTogVHVpVGV4dGZpZWxkQXBwZWFyYW5jZURpcmVjdGl2ZSxcbiAgICAgICAgcHJpdmF0ZSByZWFkb25seSBjbGVhbmVyRGlyZWN0aXZlOiBUdWlUZXh0ZmllbGRDbGVhbmVyRGlyZWN0aXZlLFxuICAgICAgICBwcml2YXRlIHJlYWRvbmx5IGN1c3RvbUNvbnRlbnREaXJlY3RpdmU6IFR1aVRleHRmaWVsZEN1c3RvbUNvbnRlbnREaXJlY3RpdmUsXG4gICAgICAgIHByaXZhdGUgcmVhZG9ubHkgaWNvbkRpcmVjdGl2ZTogVHVpVGV4dGZpZWxkSWNvbkRpcmVjdGl2ZSxcbiAgICAgICAgcHJpdmF0ZSByZWFkb25seSBpY29uTGVmdERpcmVjdGl2ZTogVHVpVGV4dGZpZWxkSWNvbkxlZnREaXJlY3RpdmUsXG4gICAgICAgIHByaXZhdGUgcmVhZG9ubHkgbGFiZWxPdXRzaWRlRGlyZWN0aXZlOiBUdWlUZXh0ZmllbGRMYWJlbE91dHNpZGVEaXJlY3RpdmUsXG4gICAgICAgIHByaXZhdGUgcmVhZG9ubHkgc2l6ZURpcmVjdGl2ZTogVHVpVGV4dGZpZWxkU2l6ZURpcmVjdGl2ZSxcbiAgICAgICAgcHJpdmF0ZSByZWFkb25seSBwcmVmaXhEaXJlY3RpdmU6IFR1aVRleHRmaWVsZFByZWZpeERpcmVjdGl2ZSxcbiAgICAgICAgcHJpdmF0ZSByZWFkb25seSBwb3N0Zml4RGlyZWN0aXZlOiBUdWlUZXh0ZmllbGRQb3N0Zml4RGlyZWN0aXZlLFxuICAgICAgICBwcml2YXRlIHJlYWRvbmx5IGZpbGxlckRpcmVjdGl2ZTogVHVpVGV4dGZpZWxkRmlsbGVyRGlyZWN0aXZlLFxuICAgICkge31cblxuICAgIGdldCBhcHBlYXJhbmNlKCk6IHN0cmluZyB7XG4gICAgICAgIHJldHVybiB0aGlzLmFwcGVhcmFuY2VEaXJlY3RpdmUuYXBwZWFyYW5jZSB8fCB0aGlzLmxlZ2FjeUFwcGVhcmFuY2U7XG4gICAgfVxuXG4gICAgZ2V0IGNsZWFuZXIoKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiB0aGlzLmNsZWFuZXJEaXJlY3RpdmUuY2xlYW5lcjtcbiAgICB9XG5cbiAgICBnZXQgY3VzdG9tQ29udGVudCgpOiBQb2x5bW9ycGhldXNDb250ZW50IHtcbiAgICAgICAgcmV0dXJuIHRoaXMuY3VzdG9tQ29udGVudERpcmVjdGl2ZS5jdXN0b21Db250ZW50IHx8IGBgO1xuICAgIH1cblxuICAgIGdldCBpY29uKCk6IFBvbHltb3JwaGV1c0NvbnRlbnQ8VHVpQ29udGV4dFdpdGhJbXBsaWNpdDxUdWlTaXplTCB8IFR1aVNpemVTPj4ge1xuICAgICAgICByZXR1cm4gdGhpcy5pY29uRGlyZWN0aXZlLmljb247XG4gICAgfVxuXG4gICAgZ2V0IGljb25MZWZ0KCk6IFBvbHltb3JwaGV1c0NvbnRlbnQ8VHVpQ29udGV4dFdpdGhJbXBsaWNpdDxUdWlTaXplTCB8IFR1aVNpemVTPj4ge1xuICAgICAgICByZXR1cm4gdGhpcy5pY29uTGVmdERpcmVjdGl2ZS5pY29uTGVmdDtcbiAgICB9XG5cbiAgICBnZXQgbGFiZWxPdXRzaWRlKCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gdGhpcy5sYWJlbE91dHNpZGVEaXJlY3RpdmUubGFiZWxPdXRzaWRlO1xuICAgIH1cblxuICAgIGdldCBzaXplKCk6IFR1aVNpemVMIHwgVHVpU2l6ZVMge1xuICAgICAgICByZXR1cm4gdGhpcy5zaXplRGlyZWN0aXZlLnNpemU7XG4gICAgfVxuXG4gICAgZ2V0IHByZWZpeCgpOiBzdHJpbmcge1xuICAgICAgICByZXR1cm4gdGhpcy5wcmVmaXhEaXJlY3RpdmUucHJlZml4O1xuICAgIH1cblxuICAgIGdldCBwb3N0Zml4KCk6IHN0cmluZyB7XG4gICAgICAgIHJldHVybiB0aGlzLnBvc3RmaXhEaXJlY3RpdmUucG9zdGZpeDtcbiAgICB9XG5cbiAgICBnZXQgZmlsbGVyKCk6IHN0cmluZyB7XG4gICAgICAgIHJldHVybiB0aGlzLmZpbGxlckRpcmVjdGl2ZS5maWxsZXI7XG4gICAgfVxufVxuIl19
|
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
import { InjectionToken } from '@angular/core';
|
|
2
|
+
// TODO: drop in v4
|
|
3
|
+
/** @deprecated use {@link TUI_TEXTFIELD_APPEARANCE_DIRECTIVE} instead */
|
|
2
4
|
export const TUI_TEXTFIELD_APPEARANCE = new InjectionToken(`[TUI_TEXTFIELD_APPEARANCE]: Appearance for inputs`, {
|
|
3
5
|
factory: () => "textfield" /* Textfield */,
|
|
4
6
|
});
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dGZpZWxkLWFwcGVhcmFuY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3Rva2Vucy90ZXh0ZmllbGQtYXBwZWFyYW5jZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRzdDLG1CQUFtQjtBQUNuQix5RUFBeUU7QUFDekUsTUFBTSxDQUFDLE1BQU0sd0JBQXdCLEdBQUcsSUFBSSxjQUFjLENBQ3RELG1EQUFtRCxFQUNuRDtJQUNJLE9BQU8sRUFBRSxHQUFHLEVBQUUsNEJBQXdCO0NBQ3pDLENBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0aW9uVG9rZW59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtUdWlBcHBlYXJhbmNlfSBmcm9tICdAdGFpZ2EtdWkvY29yZS9lbnVtcyc7XG5cbi8vIFRPRE86IGRyb3AgaW4gdjRcbi8qKiBAZGVwcmVjYXRlZCB1c2Uge0BsaW5rIFRVSV9URVhURklFTERfQVBQRUFSQU5DRV9ESVJFQ1RJVkV9IGluc3RlYWQgKi9cbmV4cG9ydCBjb25zdCBUVUlfVEVYVEZJRUxEX0FQUEVBUkFOQ0UgPSBuZXcgSW5qZWN0aW9uVG9rZW48c3RyaW5nPihcbiAgICBgW1RVSV9URVhURklFTERfQVBQRUFSQU5DRV06IEFwcGVhcmFuY2UgZm9yIGlucHV0c2AsXG4gICAge1xuICAgICAgICBmYWN0b3J5OiAoKSA9PiBUdWlBcHBlYXJhbmNlLlRleHRmaWVsZCxcbiAgICB9LFxuKTtcbiJdfQ==
|
|
@@ -8,7 +8,7 @@ import { TuiHintOptionsDirective } from '@taiga-ui/core/directives/hint';
|
|
|
8
8
|
import * as i11 from '@taiga-ui/core/directives/textfield-controller';
|
|
9
9
|
import { TUI_TEXTFIELD_WATCHED_CONTROLLER, TUI_TEXTFIELD_OPTIONS, TEXTFIELD_CONTROLLER_PROVIDER } from '@taiga-ui/core/directives/textfield-controller';
|
|
10
10
|
import { MODE_PROVIDER } from '@taiga-ui/core/providers';
|
|
11
|
-
import { TUI_MODE,
|
|
11
|
+
import { TUI_MODE, tuiAsTextfieldHost, TUI_TEXTFIELD_HOST } from '@taiga-ui/core/tokens';
|
|
12
12
|
import { tuiGetBorder } from '@taiga-ui/core/utils/miscellaneous';
|
|
13
13
|
import * as i9 from '@tinkoff/ng-polymorpheus';
|
|
14
14
|
import { PolymorpheusOutletDirective, PolymorpheusModule } from '@tinkoff/ng-polymorpheus';
|
|
@@ -107,10 +107,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
107
107
|
const ICON_PADDING = 1.75;
|
|
108
108
|
const ICON_PADDING_S = 1.5;
|
|
109
109
|
class TuiPrimitiveTextfieldComponent extends AbstractTuiInteractive {
|
|
110
|
-
constructor(mode$,
|
|
110
|
+
constructor(mode$, controller, hintOptions, options, elementRef) {
|
|
111
111
|
super();
|
|
112
112
|
this.mode$ = mode$;
|
|
113
|
-
this.appearance = appearance;
|
|
114
113
|
this.controller = controller;
|
|
115
114
|
this.hintOptions = hintOptions;
|
|
116
115
|
this.options = options;
|
|
@@ -154,6 +153,9 @@ class TuiPrimitiveTextfieldComponent extends AbstractTuiInteractive {
|
|
|
154
153
|
get focused() {
|
|
155
154
|
return tuiIsNativeFocusedIn(this.elementRef.nativeElement);
|
|
156
155
|
}
|
|
156
|
+
get appearance() {
|
|
157
|
+
return this.controller.appearance;
|
|
158
|
+
}
|
|
157
159
|
get size() {
|
|
158
160
|
return this.controller.size;
|
|
159
161
|
}
|
|
@@ -265,7 +267,7 @@ class TuiPrimitiveTextfieldComponent extends AbstractTuiInteractive {
|
|
|
265
267
|
this.valueChange.emit(value);
|
|
266
268
|
}
|
|
267
269
|
}
|
|
268
|
-
TuiPrimitiveTextfieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiPrimitiveTextfieldComponent, deps: [{ token: TUI_MODE }, { token:
|
|
270
|
+
TuiPrimitiveTextfieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiPrimitiveTextfieldComponent, deps: [{ token: TUI_MODE }, { token: TUI_TEXTFIELD_WATCHED_CONTROLLER }, { token: TuiHintOptionsDirective, optional: true }, { token: TUI_TEXTFIELD_OPTIONS }, { token: ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
269
271
|
TuiPrimitiveTextfieldComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiPrimitiveTextfieldComponent, selector: "tui-primitive-textfield", inputs: { editable: "editable", textfieldFiller: ["filler", "textfieldFiller"], iconCleaner: "iconCleaner", readOnly: "readOnly", invalid: "invalid", disabled: "disabled", textfieldPrefix: ["prefix", "textfieldPrefix"], textfieldPostfix: ["postfix", "textfieldPostfix"], value: "value" }, outputs: { valueChange: "valueChange" }, host: { listeners: { "$.data-mode.attr": "mode$", "focusin": "onFocused(true)", "focusout": "onFocused(false)" }, properties: { "class._autofilled": "autofilled", "class._label-outside": "controller.labelOutside", "class._readonly": "this.readOnly", "attr.data-size": "this.size", "class._invalid": "this.computedInvalid", "class._hidden": "this.inputHidden", "style.--border-start.rem": "this.borderStart", "style.--border-end.rem": "this.borderEnd" } }, providers: [
|
|
270
272
|
tuiAsFocusableItemAccessor(TuiPrimitiveTextfieldComponent),
|
|
271
273
|
TEXTFIELD_CONTROLLER_PROVIDER,
|
|
@@ -322,9 +324,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
322
324
|
}], ctorParameters: function () { return [{ type: i10.Observable, decorators: [{
|
|
323
325
|
type: Inject,
|
|
324
326
|
args: [TUI_MODE]
|
|
325
|
-
}] }, { type: undefined, decorators: [{
|
|
326
|
-
type: Inject,
|
|
327
|
-
args: [TUI_TEXTFIELD_APPEARANCE]
|
|
328
327
|
}] }, { type: i11.TuiTextfieldController, decorators: [{
|
|
329
328
|
type: Inject,
|
|
330
329
|
args: [TUI_TEXTFIELD_WATCHED_CONTROLLER]
|