@taiga-ui/core 3.12.1 → 3.14.0
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-data-list.umd.js +12 -6
- package/bundles/taiga-ui-core-components-data-list.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-primitive-textfield.umd.js +63 -28
- package/bundles/taiga-ui-core-components-primitive-textfield.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-root.umd.js +1 -1
- package/bundles/taiga-ui-core-directives-dropdown.umd.js +5 -0
- package/bundles/taiga-ui-core-directives-dropdown.umd.js.map +1 -1
- package/bundles/taiga-ui-core-directives-textfield-controller.umd.js +175 -7
- package/bundles/taiga-ui-core-directives-textfield-controller.umd.js.map +1 -1
- package/bundles/taiga-ui-core-utils-miscellaneous.umd.js +10 -2
- package/bundles/taiga-ui-core-utils-miscellaneous.umd.js.map +1 -1
- package/components/data-list/data-list.component.d.ts +2 -2
- package/components/primitive-textfield/index.d.ts +1 -0
- package/components/primitive-textfield/primitive-textfield-options.d.ts +20 -8
- package/components/primitive-textfield/primitive-textfield.component.d.ts +18 -9
- package/directives/dropdown/dropdown.directive.d.ts +3 -2
- package/directives/textfield-controller/index.d.ts +4 -0
- package/directives/textfield-controller/textfield-controller.module.d.ts +4 -1
- package/directives/textfield-controller/textfield-filler.directive.d.ts +9 -0
- package/directives/textfield-controller/textfield-options.d.ts +11 -0
- package/directives/textfield-controller/textfield-postfix.directive.d.ts +9 -0
- package/directives/textfield-controller/textfield-prefix.directive.d.ts +9 -0
- package/directives/textfield-controller/textfield.controller.d.ts +12 -1
- package/esm2015/components/data-list/data-list.component.js +13 -7
- package/esm2015/components/data-list/option/option.component.js +1 -1
- package/esm2015/components/primitive-textfield/index.js +2 -1
- package/esm2015/components/primitive-textfield/primitive-textfield-options.js +17 -13
- package/esm2015/components/primitive-textfield/primitive-textfield.component.js +37 -19
- package/esm2015/components/root/root.component.js +1 -1
- package/esm2015/directives/dropdown/dropdown.directive.js +6 -1
- package/esm2015/directives/textfield-controller/index.js +5 -1
- package/esm2015/directives/textfield-controller/textfield-controller.module.js +18 -3
- package/esm2015/directives/textfield-controller/textfield-controller.provider.js +11 -3
- package/esm2015/directives/textfield-controller/textfield-filler.directive.js +35 -0
- package/esm2015/directives/textfield-controller/textfield-options.js +11 -0
- package/esm2015/directives/textfield-controller/textfield-postfix.directive.js +35 -0
- package/esm2015/directives/textfield-controller/textfield-prefix.directive.js +35 -0
- package/esm2015/directives/textfield-controller/textfield.controller.js +15 -2
- package/esm2015/utils/miscellaneous/size-bigger.js +11 -3
- package/fesm2015/taiga-ui-core-components-data-list.js +13 -7
- package/fesm2015/taiga-ui-core-components-data-list.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-primitive-textfield.js +54 -31
- package/fesm2015/taiga-ui-core-components-primitive-textfield.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-root.js +1 -1
- package/fesm2015/taiga-ui-core-directives-dropdown.js +5 -0
- package/fesm2015/taiga-ui-core-directives-dropdown.js.map +1 -1
- package/fesm2015/taiga-ui-core-directives-textfield-controller.js +141 -6
- package/fesm2015/taiga-ui-core-directives-textfield-controller.js.map +1 -1
- package/fesm2015/taiga-ui-core-utils-miscellaneous.js +10 -2
- package/fesm2015/taiga-ui-core-utils-miscellaneous.js.map +1 -1
- package/package.json +4 -4
- package/styles/theme/variables.less +3 -1
- package/styles/theme/wrapper/table.less +1 -1
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ElementRef } from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { TuiTextfieldController } from '@taiga-ui/core/directives';
|
|
3
3
|
import { TuiDataListAccessor } from '@taiga-ui/core/interfaces';
|
|
4
4
|
import { TuiDataListRole } from '@taiga-ui/core/types';
|
|
5
5
|
import { PolymorpheusContent } from '@tinkoff/ng-polymorpheus';
|
|
@@ -14,7 +14,7 @@ export declare class TuiDataListComponent<T> implements TuiDataListAccessor<T> {
|
|
|
14
14
|
role: TuiDataListRole;
|
|
15
15
|
emptyContent: PolymorpheusContent;
|
|
16
16
|
size: "m" | "l" | "s";
|
|
17
|
-
constructor(controller:
|
|
17
|
+
constructor(controller: TuiTextfieldController | null, elementRef: ElementRef<HTMLElement>, defaultEmptyContent$: Observable<string>);
|
|
18
18
|
get empty$(): Observable<boolean>;
|
|
19
19
|
onFocusIn(relatedTarget: HTMLElement, currentTarget: HTMLElement): void;
|
|
20
20
|
noop(): void;
|
|
@@ -2,5 +2,6 @@ export * from './primitive-textfield.component';
|
|
|
2
2
|
export * from './primitive-textfield.directive';
|
|
3
3
|
export * from './primitive-textfield.module';
|
|
4
4
|
export * from './primitive-textfield-options';
|
|
5
|
+
export * from './primitive-textfield-types';
|
|
5
6
|
export * from './textfield/textfield.component';
|
|
6
7
|
export * from './value-decoration/value-decoration.component';
|
|
@@ -1,9 +1,21 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
1
|
+
import { TuiTextfieldOptions } from '@taiga-ui/core/directives';
|
|
2
|
+
/**
|
|
3
|
+
* @deprecated:
|
|
4
|
+
* use {@link TuiTextfieldOptions}
|
|
5
|
+
*/
|
|
6
|
+
export declare type TuiPrimitiveTextfieldOptions = TuiTextfieldOptions;
|
|
7
|
+
/**
|
|
8
|
+
* @deprecated:
|
|
9
|
+
* use {@link TUI_TEXTFIELD_DEFAULT_OPTIONS}
|
|
10
|
+
*/
|
|
7
11
|
export declare const TUI_PRIMITIVE_TEXTFIELD_DEFAULT_OPTIONS: TuiPrimitiveTextfieldOptions;
|
|
8
|
-
|
|
9
|
-
|
|
12
|
+
/**
|
|
13
|
+
* @deprecated:
|
|
14
|
+
* use {@link TUI_TEXTFIELD_OPTIONS}
|
|
15
|
+
*/
|
|
16
|
+
export declare const TUI_PRIMITIVE_TEXTFIELD_OPTIONS: import("@angular/core").InjectionToken<TuiTextfieldOptions>;
|
|
17
|
+
/**
|
|
18
|
+
* @deprecated:
|
|
19
|
+
* use {@link tuiTextfieldOptionsProvider}
|
|
20
|
+
*/
|
|
21
|
+
export declare const tuiPrimitiveTextfieldOptionsProvider: (options: Partial<TuiTextfieldOptions>) => import("@angular/core").ValueProvider;
|
|
@@ -1,11 +1,10 @@
|
|
|
1
1
|
import { ElementRef, EventEmitter, QueryList } from '@angular/core';
|
|
2
2
|
import { AbstractTuiInteractive, TuiContextWithImplicit } from '@taiga-ui/cdk';
|
|
3
3
|
import { TuiHintOptionsDirective } from '@taiga-ui/core/directives/hint';
|
|
4
|
-
import { TuiTextfieldController } from '@taiga-ui/core/directives/textfield-controller';
|
|
4
|
+
import { TuiTextfieldController, TuiTextfieldOptions } from '@taiga-ui/core/directives/textfield-controller';
|
|
5
5
|
import { TuiBrightness, TuiSizeL, TuiSizeS } from '@taiga-ui/core/types';
|
|
6
6
|
import { PolymorpheusContent } from '@tinkoff/ng-polymorpheus';
|
|
7
7
|
import { Observable } from 'rxjs';
|
|
8
|
-
import { TuiPrimitiveTextfieldOptions } from './primitive-textfield-options';
|
|
9
8
|
import { TuiPrimitiveTextfield } from './primitive-textfield-types';
|
|
10
9
|
import * as i0 from "@angular/core";
|
|
11
10
|
export declare class TuiPrimitiveTextfieldComponent extends AbstractTuiInteractive implements TuiPrimitiveTextfield {
|
|
@@ -13,22 +12,32 @@ export declare class TuiPrimitiveTextfieldComponent extends AbstractTuiInteracti
|
|
|
13
12
|
readonly appearance: string;
|
|
14
13
|
readonly controller: TuiTextfieldController;
|
|
15
14
|
readonly hintOptions: TuiHintOptionsDirective | null;
|
|
16
|
-
readonly options:
|
|
15
|
+
readonly options: TuiTextfieldOptions;
|
|
17
16
|
private readonly elementRef;
|
|
18
17
|
private readonly focusableElement?;
|
|
19
18
|
editable: boolean;
|
|
20
|
-
|
|
21
|
-
|
|
19
|
+
/** @deprecated use `tuiTextfieldFiller` from {@link TuiTextfieldControllerModule} instead */
|
|
20
|
+
textfieldFiller: string;
|
|
21
|
+
/**
|
|
22
|
+
* @deprecated:
|
|
23
|
+
* use `tuiTextfieldOptionsProvider({iconCleaner: `tuiIconChevronUp`})`
|
|
24
|
+
*/
|
|
25
|
+
iconCleaner: string | number | import("@angular/core").TemplateRef<Partial<any>> | import("@tinkoff/ng-polymorpheus").PolymorpheusTemplate<string | Partial<any>> | import("@tinkoff/ng-polymorpheus").PolymorpheusComponent<any, any> | import("@tinkoff/ng-polymorpheus").PolymorpheusHandler<any> | import("@angular/core").TemplateRef<Partial<TuiContextWithImplicit<"m" | "l" | "s">>> | import("@tinkoff/ng-polymorpheus").PolymorpheusTemplate<string | Partial<TuiContextWithImplicit<"m" | "l" | "s">>> | import("@tinkoff/ng-polymorpheus").PolymorpheusComponent<any, TuiContextWithImplicit<"m" | "l" | "s">> | import("@tinkoff/ng-polymorpheus").PolymorpheusHandler<TuiContextWithImplicit<"m" | "l" | "s">> | null | undefined;
|
|
22
26
|
readOnly: boolean;
|
|
23
27
|
invalid: boolean;
|
|
24
28
|
disabled: boolean;
|
|
25
|
-
|
|
26
|
-
|
|
29
|
+
/** @deprecated use `tuiTextfieldPrefix` from {@link TuiTextfieldControllerModule} instead */
|
|
30
|
+
textfieldPrefix: string;
|
|
31
|
+
/** @deprecated use `tuiTextfieldPostfix` from {@link TuiTextfieldControllerModule} instead */
|
|
32
|
+
textfieldPostfix: string;
|
|
27
33
|
value: string;
|
|
28
34
|
readonly valueChange: EventEmitter<string>;
|
|
29
35
|
readonly content?: QueryList<unknown>;
|
|
30
36
|
autofilled: boolean;
|
|
31
|
-
constructor(mode$: Observable<TuiBrightness | null>, appearance: string, controller: TuiTextfieldController, hintOptions: TuiHintOptionsDirective | null, options:
|
|
37
|
+
constructor(mode$: Observable<TuiBrightness | null>, appearance: string, controller: TuiTextfieldController, hintOptions: TuiHintOptionsDirective | null, options: TuiTextfieldOptions, elementRef: ElementRef<HTMLElement>);
|
|
38
|
+
get prefix(): string;
|
|
39
|
+
get postfix(): string;
|
|
40
|
+
get filler(): string;
|
|
32
41
|
get nativeFocusableElement(): HTMLInputElement | null;
|
|
33
42
|
get focused(): boolean;
|
|
34
43
|
get size(): TuiSizeL | TuiSizeS;
|
|
@@ -59,5 +68,5 @@ export declare class TuiPrimitiveTextfieldComponent extends AbstractTuiInteracti
|
|
|
59
68
|
private updateAutofilled;
|
|
60
69
|
private updateValue;
|
|
61
70
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiPrimitiveTextfieldComponent, [null, null, null, { optional: true; }, null, null]>;
|
|
62
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<TuiPrimitiveTextfieldComponent, "tui-primitive-textfield", never, { "editable": "editable"; "
|
|
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", "*"]>;
|
|
63
72
|
}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import { ComponentRef, ElementRef, OnChanges, OnDestroy } from '@angular/core';
|
|
1
|
+
import { AfterViewChecked, ComponentRef, ElementRef, OnChanges, OnDestroy } from '@angular/core';
|
|
2
2
|
import { TuiActiveZoneDirective, TuiContextWithImplicit, TuiDropdownPortalService } from '@taiga-ui/cdk';
|
|
3
3
|
import { TuiRectAccessor, TuiVehicle } from '@taiga-ui/core/abstract';
|
|
4
4
|
import { TuiPortalItem } from '@taiga-ui/core/interfaces';
|
|
5
5
|
import { PolymorpheusComponent, PolymorpheusContent } from '@tinkoff/ng-polymorpheus';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
|
-
export declare class TuiDropdownDirective implements OnDestroy, OnChanges, TuiPortalItem, TuiRectAccessor, TuiVehicle {
|
|
7
|
+
export declare class TuiDropdownDirective implements AfterViewChecked, OnDestroy, OnChanges, TuiPortalItem, TuiRectAccessor, TuiVehicle {
|
|
8
8
|
private readonly elementRef;
|
|
9
9
|
readonly component: PolymorpheusComponent<unknown, any>;
|
|
10
10
|
private readonly dropdownService;
|
|
@@ -12,6 +12,7 @@ export declare class TuiDropdownDirective implements OnDestroy, OnChanges, TuiPo
|
|
|
12
12
|
dropdownBoxRef: ComponentRef<unknown> | null;
|
|
13
13
|
constructor(elementRef: ElementRef<HTMLElement>, component: PolymorpheusComponent<unknown, any>, dropdownService: TuiDropdownPortalService);
|
|
14
14
|
get position(): `absolute` | `fixed`;
|
|
15
|
+
ngAfterViewChecked(): void;
|
|
15
16
|
ngOnChanges(): void;
|
|
16
17
|
ngOnDestroy(): void;
|
|
17
18
|
getClientRect(): ClientRect;
|
|
@@ -3,7 +3,11 @@ export * from './textfield-cleaner.directive';
|
|
|
3
3
|
export * from './textfield-controller.module';
|
|
4
4
|
export * from './textfield-controller.provider';
|
|
5
5
|
export * from './textfield-custom-content.directive';
|
|
6
|
+
export * from './textfield-filler.directive';
|
|
6
7
|
export * from './textfield-icon.directive';
|
|
7
8
|
export * from './textfield-icon-left.directive';
|
|
8
9
|
export * from './textfield-label-outside.directive';
|
|
10
|
+
export * from './textfield-options';
|
|
11
|
+
export * from './textfield-postfix.directive';
|
|
12
|
+
export * from './textfield-prefix.directive';
|
|
9
13
|
export * from './textfield-size.directive';
|
|
@@ -5,8 +5,11 @@ import * as i3 from "./textfield-label-outside.directive";
|
|
|
5
5
|
import * as i4 from "./textfield-size.directive";
|
|
6
6
|
import * as i5 from "./textfield-icon.directive";
|
|
7
7
|
import * as i6 from "./textfield-icon-left.directive";
|
|
8
|
+
import * as i7 from "./textfield-prefix.directive";
|
|
9
|
+
import * as i8 from "./textfield-postfix.directive";
|
|
10
|
+
import * as i9 from "./textfield-filler.directive";
|
|
8
11
|
export declare class TuiTextfieldControllerModule {
|
|
9
12
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiTextfieldControllerModule, never>;
|
|
10
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<TuiTextfieldControllerModule, [typeof i1.TuiTextfieldCleanerDirective, typeof i2.TuiTextfieldCustomContentDirective, typeof i3.TuiTextfieldLabelOutsideDirective, typeof i4.TuiTextfieldSizeDirective, typeof i5.TuiTextfieldIconDirective, typeof i6.TuiTextfieldIconLeftDirective], never, [typeof i1.TuiTextfieldCleanerDirective, typeof i2.TuiTextfieldCustomContentDirective, typeof i3.TuiTextfieldLabelOutsideDirective, typeof i4.TuiTextfieldSizeDirective, typeof i5.TuiTextfieldIconDirective, typeof i6.TuiTextfieldIconLeftDirective]>;
|
|
13
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<TuiTextfieldControllerModule, [typeof i1.TuiTextfieldCleanerDirective, typeof i2.TuiTextfieldCustomContentDirective, typeof i3.TuiTextfieldLabelOutsideDirective, typeof i4.TuiTextfieldSizeDirective, typeof i5.TuiTextfieldIconDirective, typeof i6.TuiTextfieldIconLeftDirective, typeof i7.TuiTextfieldPrefixDirective, typeof i8.TuiTextfieldPostfixDirective, typeof i9.TuiTextfieldFillerDirective], never, [typeof i1.TuiTextfieldCleanerDirective, typeof i2.TuiTextfieldCustomContentDirective, typeof i3.TuiTextfieldLabelOutsideDirective, typeof i4.TuiTextfieldSizeDirective, typeof i5.TuiTextfieldIconDirective, typeof i6.TuiTextfieldIconLeftDirective, typeof i7.TuiTextfieldPrefixDirective, typeof i8.TuiTextfieldPostfixDirective, typeof i9.TuiTextfieldFillerDirective]>;
|
|
11
14
|
static ɵinj: i0.ɵɵInjectorDeclaration<TuiTextfieldControllerModule>;
|
|
12
15
|
}
|
|
@@ -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_FILLER: InjectionToken<TuiTextfieldFillerDirective>;
|
|
5
|
+
export declare class TuiTextfieldFillerDirective extends AbstractTuiController {
|
|
6
|
+
filler: string;
|
|
7
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TuiTextfieldFillerDirective, never>;
|
|
8
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<TuiTextfieldFillerDirective, "[tuiTextfieldFiller]", never, { "filler": "tuiTextfieldFiller"; }, {}, never>;
|
|
9
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { InjectionToken, ValueProvider } from '@angular/core';
|
|
2
|
+
import { TuiContextWithImplicit } from '@taiga-ui/cdk';
|
|
3
|
+
import { TuiSizeL, TuiSizeS } from '@taiga-ui/core/types';
|
|
4
|
+
import { PolymorpheusContent } from '@tinkoff/ng-polymorpheus';
|
|
5
|
+
export interface TuiTextfieldOptions {
|
|
6
|
+
readonly iconCleaner: PolymorpheusContent | PolymorpheusContent<TuiContextWithImplicit<TuiSizeL | TuiSizeS>>;
|
|
7
|
+
}
|
|
8
|
+
/** Default values for primitive textfield options */
|
|
9
|
+
export declare const TUI_TEXTFIELD_DEFAULT_OPTIONS: TuiTextfieldOptions;
|
|
10
|
+
export declare const TUI_TEXTFIELD_OPTIONS: InjectionToken<TuiTextfieldOptions>;
|
|
11
|
+
export declare const tuiTextfieldOptionsProvider: (options: Partial<TuiTextfieldOptions>) => ValueProvider;
|
|
@@ -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_POSTFIX: InjectionToken<TuiTextfieldPostfixDirective>;
|
|
5
|
+
export declare class TuiTextfieldPostfixDirective extends AbstractTuiController {
|
|
6
|
+
postfix: string;
|
|
7
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TuiTextfieldPostfixDirective, never>;
|
|
8
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<TuiTextfieldPostfixDirective, "[tuiTextfieldPostfix]", never, { "postfix": "tuiTextfieldPostfix"; }, {}, never>;
|
|
9
|
+
}
|
|
@@ -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_PREFIX: InjectionToken<TuiTextfieldPrefixDirective>;
|
|
5
|
+
export declare class TuiTextfieldPrefixDirective extends AbstractTuiController {
|
|
6
|
+
prefix: string;
|
|
7
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TuiTextfieldPrefixDirective, never>;
|
|
8
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<TuiTextfieldPrefixDirective, "[tuiTextfieldPrefix]", never, { "prefix": "tuiTextfieldPrefix"; }, {}, never>;
|
|
9
|
+
}
|
|
@@ -4,23 +4,34 @@ import { PolymorpheusContent } from '@tinkoff/ng-polymorpheus';
|
|
|
4
4
|
import { Observable } from 'rxjs';
|
|
5
5
|
import { TuiTextfieldCleanerDirective } from './textfield-cleaner.directive';
|
|
6
6
|
import { TuiTextfieldCustomContentDirective } from './textfield-custom-content.directive';
|
|
7
|
+
import { TuiTextfieldFillerDirective } from './textfield-filler.directive';
|
|
7
8
|
import { TuiTextfieldIconDirective } from './textfield-icon.directive';
|
|
8
9
|
import { TuiTextfieldIconLeftDirective } from './textfield-icon-left.directive';
|
|
9
10
|
import { TuiTextfieldLabelOutsideDirective } from './textfield-label-outside.directive';
|
|
11
|
+
import { TuiTextfieldOptions } from './textfield-options';
|
|
12
|
+
import { TuiTextfieldPostfixDirective } from './textfield-postfix.directive';
|
|
13
|
+
import { TuiTextfieldPrefixDirective } from './textfield-prefix.directive';
|
|
10
14
|
import { TuiTextfieldSizeDirective } from './textfield-size.directive';
|
|
11
15
|
export declare class TuiTextfieldController {
|
|
12
16
|
readonly change$: Observable<void>;
|
|
17
|
+
readonly options: TuiTextfieldOptions;
|
|
13
18
|
private readonly cleanerDirective;
|
|
14
19
|
private readonly customContentDirective;
|
|
15
20
|
private readonly iconDirective;
|
|
16
21
|
private readonly iconLeftDirective;
|
|
17
22
|
private readonly labelOutsideDirective;
|
|
18
23
|
private readonly sizeDirective;
|
|
19
|
-
|
|
24
|
+
private readonly prefixDirective;
|
|
25
|
+
private readonly postfixDirective;
|
|
26
|
+
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);
|
|
20
28
|
get cleaner(): boolean;
|
|
21
29
|
get customContent(): PolymorpheusContent;
|
|
22
30
|
get icon(): PolymorpheusContent<TuiContextWithImplicit<TuiSizeL | TuiSizeS>>;
|
|
23
31
|
get iconLeft(): PolymorpheusContent<TuiContextWithImplicit<TuiSizeL | TuiSizeS>>;
|
|
24
32
|
get labelOutside(): boolean;
|
|
25
33
|
get size(): TuiSizeL | TuiSizeS;
|
|
34
|
+
get prefix(): string;
|
|
35
|
+
get postfix(): string;
|
|
36
|
+
get filler(): string;
|
|
26
37
|
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
2
|
import { ChangeDetectionStrategy, Component, ContentChildren, ElementRef, forwardRef, HostBinding, HostListener, Inject, Input, Optional, ViewEncapsulation, } from '@angular/core';
|
|
3
3
|
import { EMPTY_QUERY, tuiDefaultProp, tuiIsElement, tuiIsNativeFocusedIn, tuiIsPresent, tuiItemsQueryListObservable, tuiMoveFocus, tuiPure, tuiSetNativeMouseFocused, } from '@taiga-ui/cdk';
|
|
4
|
-
import {
|
|
4
|
+
import { TEXTFIELD_CONTROLLER_PROVIDER, TUI_TEXTFIELD_WATCHED_CONTROLLER, } from '@taiga-ui/core/directives';
|
|
5
5
|
import { TUI_NOTHING_FOUND_MESSAGE, tuiAsDataListAccessor } from '@taiga-ui/core/tokens';
|
|
6
6
|
import { map } from 'rxjs/operators';
|
|
7
7
|
// TODO: find the best way for prevent cycle
|
|
@@ -61,8 +61,11 @@ export class TuiDataListComponent {
|
|
|
61
61
|
return Array.from(this.elementRef.nativeElement.querySelectorAll(`[tuiOption]`));
|
|
62
62
|
}
|
|
63
63
|
}
|
|
64
|
-
TuiDataListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiDataListComponent, deps: [{ token:
|
|
65
|
-
TuiDataListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiDataListComponent, selector: "tui-data-list", inputs: { role: "role", emptyContent: "emptyContent", size: "size" }, host: { listeners: { "focusin": "onFocusIn($event.relatedTarget,$event.currentTarget)", "mousedown.prevent": "noop()", "keydown.arrowDown.prevent": "onKeyDownArrow($event.target,1)", "keydown.arrowUp.prevent": "onKeyDownArrow($event.target,-1)", "wheel.silent.passive": "handleFocusLossIfNecessary()", "mouseleave": "handleFocusLossIfNecessary($event.target)" }, properties: { "attr.role": "this.role", "attr.data-list-size": "this.size" } }, providers: [
|
|
64
|
+
TuiDataListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiDataListComponent, deps: [{ token: TUI_TEXTFIELD_WATCHED_CONTROLLER, optional: true }, { token: ElementRef }, { token: TUI_NOTHING_FOUND_MESSAGE }], target: i0.ɵɵFactoryTarget.Component });
|
|
65
|
+
TuiDataListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiDataListComponent, selector: "tui-data-list", inputs: { role: "role", emptyContent: "emptyContent", size: "size" }, host: { listeners: { "focusin": "onFocusIn($event.relatedTarget,$event.currentTarget)", "mousedown.prevent": "noop()", "keydown.arrowDown.prevent": "onKeyDownArrow($event.target,1)", "keydown.arrowUp.prevent": "onKeyDownArrow($event.target,-1)", "wheel.silent.passive": "handleFocusLossIfNecessary()", "mouseleave": "handleFocusLossIfNecessary($event.target)" }, properties: { "attr.role": "this.role", "attr.data-list-size": "this.size" } }, providers: [
|
|
66
|
+
tuiAsDataListAccessor(TuiDataListComponent),
|
|
67
|
+
TEXTFIELD_CONTROLLER_PROVIDER,
|
|
68
|
+
], queries: [{ propertyName: "options", predicate: i0.forwardRef(function () { return TuiOptionComponent; }), descendants: true }], ngImport: i0, template: "<div\n tabindex=\"0\"\n class=\"t-trap\"\n (focusin)=\"onFocus($event, true)\"\n></div>\n<ng-content></ng-content>\n<div\n *ngIf=\"empty$ | async\"\n class=\"t-empty\"\n>\n <ng-container *polymorpheusOutlet=\"emptyContent || (defaultEmptyContent$ | async) as text\">\n {{ text }}\n </ng-container>\n</div>\n<div\n tabindex=\"0\"\n class=\"t-trap\"\n (focusin)=\"onFocus($event, false)\"\n></div>\n", styles: ["tui-data-list{--tui-data-list-padding: .25rem;--tui-data-list-margin: .0625rem;display:flex;font:var(--tui-font-text-m);flex-direction:column;padding:calc(var(--tui-data-list-padding) - var(--tui-data-list-margin)) var(--tui-data-list-padding);color:var(--tui-text-03)}tui-data-list:focus-within .t-trap{display:none}tui-data-list:focus-within [tuiOption]._with-dropdown:not(:focus){background-color:transparent}tui-data-list[data-list-size=s]{--tui-data-list-margin: 0}tui-data-list[data-list-size=l]{--tui-data-list-padding: .375rem;--tui-data-list-margin: .125rem}tui-data-list>.t-empty{margin:.75rem 1rem}tui-opt-group{position:relative;display:flex;font:var(--tui-font-text-xs);color:var(--tui-text-02);flex-direction:column;line-height:1rem}tui-data-list[data-list-size=l] tui-opt-group{font:var(--tui-font-text-s);line-height:1.25rem}tui-data-list[data-list-size=l] tui-opt-group:before{padding-left:.625rem;padding-right:.625rem}tui-data-list[data-list-size=l] tui-opt-group:after{left:.625rem;right:.625rem}tui-opt-group:empty:before,tui-opt-group:empty:after{display:none}tui-opt-group:before{content:attr(data-label);padding:var(--tui-data-list-padding) .5rem var(--tui-data-list-padding);margin:var(--tui-data-list-margin) 0;white-space:normal;word-break:break-word}tui-opt-group:after{position:absolute;left:.5rem;right:.5rem;top:var(--tui-data-list-padding);height:1px;background:var(--tui-base-03)}tui-opt-group:not(:empty)~tui-opt-group:before{padding-top:calc(.75rem + var(--tui-data-list-padding))}tui-opt-group:not(:empty)~tui-opt-group[data-label=\"\"]:before{padding:var(--tui-data-list-padding) 0}tui-opt-group:not(:empty)~tui-opt-group:after{content:\"\"}tui-opt-group[data-label=\"\"]:before{padding:0 .5rem}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }], pipes: { "async": i1.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
66
69
|
__decorate([
|
|
67
70
|
tuiDefaultProp()
|
|
68
71
|
], TuiDataListComponent.prototype, "role", void 0);
|
|
@@ -83,13 +86,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
83
86
|
styleUrls: [`./data-list.style.less`],
|
|
84
87
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
85
88
|
encapsulation: ViewEncapsulation.None,
|
|
86
|
-
providers: [
|
|
89
|
+
providers: [
|
|
90
|
+
tuiAsDataListAccessor(TuiDataListComponent),
|
|
91
|
+
TEXTFIELD_CONTROLLER_PROVIDER,
|
|
92
|
+
],
|
|
87
93
|
}]
|
|
88
|
-
}], ctorParameters: function () { return [{ type: i3.
|
|
94
|
+
}], ctorParameters: function () { return [{ type: i3.TuiTextfieldController, decorators: [{
|
|
89
95
|
type: Optional
|
|
90
96
|
}, {
|
|
91
97
|
type: Inject,
|
|
92
|
-
args: [
|
|
98
|
+
args: [TUI_TEXTFIELD_WATCHED_CONTROLLER]
|
|
93
99
|
}] }, { type: i0.ElementRef, decorators: [{
|
|
94
100
|
type: Inject,
|
|
95
101
|
args: [ElementRef]
|
|
@@ -130,4 +136,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
130
136
|
type: HostListener,
|
|
131
137
|
args: [`mouseleave`, [`$event.target`]]
|
|
132
138
|
}] } });
|
|
133
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-list.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/data-list/data-list.component.ts","../../../../../projects/core/components/data-list/data-list.template.html"],"names":[],"mappings":";AAAA,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,eAAe,EACf,UAAU,EACV,UAAU,EACV,WAAW,EACX,YAAY,EACZ,MAAM,EACN,KAAK,EACL,QAAQ,EAER,iBAAiB,GACpB,MAAM,eAAe,CAAC;AACvB,OAAO,EACH,WAAW,EACX,cAAc,EACd,YAAY,EACZ,oBAAoB,EACpB,YAAY,EACZ,2BAA2B,EAC3B,YAAY,EACZ,OAAO,EACP,wBAAwB,GAC3B,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,yBAAyB,EAAC,MAAM,2BAA2B,CAAC;AAEpE,OAAO,EAAC,yBAAyB,EAAE,qBAAqB,EAAC,MAAM,uBAAuB,CAAC;AAIvF,OAAO,EAAC,GAAG,EAAC,MAAM,gBAAgB,CAAC;AAEnC,4CAA4C;AAC5C,2CAA2C;AAC3C,OAAO,EAAC,kBAAkB,EAAC,MAAM,2BAA2B,CAAC;;;;;;AAE7D,+EAA+E;AAS/E,MAAM,OAAO,oBAAoB;IAoB7B,YAGqB,UAA4C,EACxB,UAAmC,EAE/D,oBAAwC;;QAHhC,eAAU,GAAV,UAAU,CAAkC;QACxB,eAAU,GAAV,UAAU,CAAyB;QAE/D,yBAAoB,GAApB,oBAAoB,CAAoB;QAxBpC,YAAO,GAAqC,WAAW,CAAC;QAOzE,SAAI,GAAoB,SAAS,CAAC;QAIlC,iBAAY,GAAwB,EAAE,CAAC;QAKvC,SAAI,GAAG,CAAA,MAAA,IAAI,CAAC,UAAU,0CAAE,IAAI,KAAI,GAAG,CAAC;IASjC,CAAC;IAGJ,IAAI,MAAM;QACN,OAAO,2BAA2B,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAC,MAAM,EAAC,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;IACtF,CAAC;IAGD,SAAS,CAAC,aAA0B,EAAE,aAA0B;QAC5D,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YACxD,IAAI,CAAC,MAAM,GAAG,aAAa,CAAC;SAC/B;IACL,CAAC;IAGD,IAAI,KAAU,CAAC;IAIf,cAAc,CAAC,OAAoB,EAAE,IAAY;QAC7C,MAAM,EAAC,QAAQ,EAAC,GAAG,IAAI,CAAC;QAExB,YAAY,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC;IAC5D,CAAC;IAED,+EAA+E;IAG/E,0BAA0B,CAAC,UAAmB,IAAI,CAAC,UAAU,CAAC,aAAa;QACvE,IAAI,IAAI,CAAC,MAAM,IAAI,oBAAoB,CAAC,OAAO,CAAC,EAAE;YAC9C,wBAAwB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;SACrD;IACL,CAAC;IAED,UAAU,CAAC,kBAA2B,KAAK;QACvC,OAAO,IAAI,CAAC,OAAO;aACd,MAAM,CAAC,CAAC,EAAC,QAAQ,EAAC,EAAE,EAAE,CAAC,eAAe,IAAI,CAAC,QAAQ,CAAC;aACpD,GAAG,CAAC,CAAC,EAAC,KAAK,EAAC,EAAE,EAAE,CAAC,KAAK,CAAC;aACvB,MAAM,CAAC,YAAY,CAAC,CAAC;IAC9B,CAAC;IAED,OAAO,CAAC,EAAC,MAAM,EAAQ,EAAE,GAAY;QACjC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE;YACvB,OAAO;SACV;QAED,MAAM,EAAC,QAAQ,EAAC,GAAG,IAAI,CAAC;QAExB,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,EAAE,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACjE,IAAI,CAAC,0BAA0B,CAAC,MAAM,CAAC,CAAC;IAC5C,CAAC;IAED,IAAY,QAAQ;QAChB,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC,CAAC;IACrF,CAAC;;kHAjFQ,oBAAoB,kBAsBjB,yBAAyB,6BAEzB,UAAU,aACV,yBAAyB;sGAzB5B,oBAAoB,yiBAFlB,CAAC,qBAAqB,CAAC,oBAAoB,CAAC,CAAC,qFAGtB,kBAAkB,oDC/CxD,obAmBA;ADoCI;IADC,cAAc,EAAE;kDACiB;AAIlC;IADC,cAAc,EAAE;0DACsB;AAKvC;IADC,cAAc,EAAE;kDACmB;AAYpC;IADC,OAAO;kDAGP;4FAhCQ,oBAAoB;kBARhC,SAAS;mBAAC;oBACP,QAAQ,EAAE,eAAe;oBACzB,WAAW,EAAE,2BAA2B;oBACxC,SAAS,EAAE,CAAC,wBAAwB,CAAC;oBACrC,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,aAAa,EAAE,iBAAiB,CAAC,IAAI;oBACrC,SAAS,EAAE,CAAC,qBAAqB,sBAAsB,CAAC;iBAC3D;;0BAsBQ,QAAQ;;0BACR,MAAM;2BAAC,yBAAyB;;0BAEhC,MAAM;2BAAC,UAAU;;0BACjB,MAAM;2BAAC,yBAAyB;4CAvBpB,OAAO;sBADvB,eAAe;uBAAC,UAAU,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC,EAAE,EAAC,WAAW,EAAE,IAAI,EAAC;gBAQ1E,IAAI;sBAHH,KAAK;;sBACL,WAAW;uBAAC,WAAW;gBAMxB,YAAY;sBAFX,KAAK;gBAON,IAAI;sBAHH,KAAK;;sBACL,WAAW;uBAAC,qBAAqB;gBAc9B,MAAM,MAKV,SAAS;sBADR,YAAY;uBAAC,SAAS,EAAE,CAAC,sBAAsB,EAAE,sBAAsB,CAAC;gBAQzE,IAAI;sBADH,YAAY;uBAAC,mBAAmB;gBAKjC,cAAc;sBAFb,YAAY;uBAAC,2BAA2B,EAAE,CAAC,eAAe,EAAE,GAAG,CAAC;;sBAChE,YAAY;uBAAC,yBAAyB,EAAE,CAAC,eAAe,EAAE,IAAI,CAAC;gBAUhE,0BAA0B;sBAFzB,YAAY;uBAAC,sBAAsB;;sBACnC,YAAY;uBAAC,YAAY,EAAE,CAAC,eAAe,CAAC","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    ElementRef,\n    forwardRef,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    Optional,\n    QueryList,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {\n    EMPTY_QUERY,\n    tuiDefaultProp,\n    tuiIsElement,\n    tuiIsNativeFocusedIn,\n    tuiIsPresent,\n    tuiItemsQueryListObservable,\n    tuiMoveFocus,\n    tuiPure,\n    tuiSetNativeMouseFocused,\n} from '@taiga-ui/cdk';\nimport {TuiTextfieldSizeDirective} from '@taiga-ui/core/directives';\nimport {TuiDataListAccessor} from '@taiga-ui/core/interfaces';\nimport {TUI_NOTHING_FOUND_MESSAGE, tuiAsDataListAccessor} from '@taiga-ui/core/tokens';\nimport {TuiDataListRole} from '@taiga-ui/core/types';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\n// TODO: find the best way for prevent cycle\n// eslint-disable-next-line import/no-cycle\nimport {TuiOptionComponent} from './option/option.component';\n\n// TODO: Consider aria-activedescendant for proper accessibility implementation\n@Component({\n    selector: `tui-data-list`,\n    templateUrl: `./data-list.template.html`,\n    styleUrls: [`./data-list.style.less`],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    providers: [tuiAsDataListAccessor(TuiDataListComponent)],\n})\nexport class TuiDataListComponent<T> implements TuiDataListAccessor<T> {\n    @ContentChildren(forwardRef(() => TuiOptionComponent), {descendants: true})\n    private readonly options: QueryList<TuiOptionComponent<T>> = EMPTY_QUERY;\n\n    private origin?: HTMLElement;\n\n    @Input()\n    @HostBinding(`attr.role`)\n    @tuiDefaultProp()\n    role: TuiDataListRole = `listbox`;\n\n    @Input()\n    @tuiDefaultProp()\n    emptyContent: PolymorpheusContent = ``;\n\n    @Input()\n    @HostBinding(`attr.data-list-size`)\n    @tuiDefaultProp()\n    size = this.controller?.size || `m`;\n\n    constructor(\n        @Optional()\n        @Inject(TuiTextfieldSizeDirective)\n        private readonly controller: TuiTextfieldSizeDirective | null,\n        @Inject(ElementRef) private readonly elementRef: ElementRef<HTMLElement>,\n        @Inject(TUI_NOTHING_FOUND_MESSAGE)\n        readonly defaultEmptyContent$: Observable<string>,\n    ) {}\n\n    @tuiPure\n    get empty$(): Observable<boolean> {\n        return tuiItemsQueryListObservable(this.options).pipe(map(({length}) => !length));\n    }\n\n    @HostListener(`focusin`, [`$event.relatedTarget`, `$event.currentTarget`])\n    onFocusIn(relatedTarget: HTMLElement, currentTarget: HTMLElement): void {\n        if (!currentTarget.contains(relatedTarget) && !this.origin) {\n            this.origin = relatedTarget;\n        }\n    }\n\n    @HostListener(`mousedown.prevent`)\n    noop(): void {}\n\n    @HostListener(`keydown.arrowDown.prevent`, [`$event.target`, `1`])\n    @HostListener(`keydown.arrowUp.prevent`, [`$event.target`, `-1`])\n    onKeyDownArrow(current: HTMLElement, step: number): void {\n        const {elements} = this;\n\n        tuiMoveFocus(elements.indexOf(current), elements, step);\n    }\n\n    // TODO: Consider aria-activedescendant for proper accessibility implementation\n    @HostListener(`wheel.silent.passive`)\n    @HostListener(`mouseleave`, [`$event.target`])\n    handleFocusLossIfNecessary(element: Element = this.elementRef.nativeElement): void {\n        if (this.origin && tuiIsNativeFocusedIn(element)) {\n            tuiSetNativeMouseFocused(this.origin, true, true);\n        }\n    }\n\n    getOptions(includeDisabled: boolean = false): readonly T[] {\n        return this.options\n            .filter(({disabled}) => includeDisabled || !disabled)\n            .map(({value}) => value)\n            .filter(tuiIsPresent);\n    }\n\n    onFocus({target}: Event, top: boolean): void {\n        if (!tuiIsElement(target)) {\n            return;\n        }\n\n        const {elements} = this;\n\n        tuiMoveFocus(top ? -1 : elements.length, elements, top ? 1 : -1);\n        this.handleFocusLossIfNecessary(target);\n    }\n\n    private get elements(): readonly HTMLElement[] {\n        return Array.from(this.elementRef.nativeElement.querySelectorAll(`[tuiOption]`));\n    }\n}\n","<div\n    tabindex=\"0\"\n    class=\"t-trap\"\n    (focusin)=\"onFocus($event, true)\"\n></div>\n<ng-content></ng-content>\n<div\n    *ngIf=\"empty$ | async\"\n    class=\"t-empty\"\n>\n    <ng-container *polymorpheusOutlet=\"emptyContent || (defaultEmptyContent$ | async) as text\">\n        {{ text }}\n    </ng-container>\n</div>\n<div\n    tabindex=\"0\"\n    class=\"t-trap\"\n    (focusin)=\"onFocus($event, false)\"\n></div>\n"]}
|
|
139
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-list.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/data-list/data-list.component.ts","../../../../../projects/core/components/data-list/data-list.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    ElementRef,\n    forwardRef,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    Optional,\n    QueryList,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {\n    EMPTY_QUERY,\n    tuiDefaultProp,\n    tuiIsElement,\n    tuiIsNativeFocusedIn,\n    tuiIsPresent,\n    tuiItemsQueryListObservable,\n    tuiMoveFocus,\n    tuiPure,\n    tuiSetNativeMouseFocused,\n} from '@taiga-ui/cdk';\nimport {\n    TEXTFIELD_CONTROLLER_PROVIDER,\n    TUI_TEXTFIELD_WATCHED_CONTROLLER,\n    TuiTextfieldController,\n} from '@taiga-ui/core/directives';\nimport {TuiDataListAccessor} from '@taiga-ui/core/interfaces';\nimport {TUI_NOTHING_FOUND_MESSAGE, tuiAsDataListAccessor} from '@taiga-ui/core/tokens';\nimport {TuiDataListRole} from '@taiga-ui/core/types';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\n// TODO: find the best way for prevent cycle\n// eslint-disable-next-line import/no-cycle\nimport {TuiOptionComponent} from './option/option.component';\n\n// TODO: Consider aria-activedescendant for proper accessibility implementation\n@Component({\n    selector: `tui-data-list`,\n    templateUrl: `./data-list.template.html`,\n    styleUrls: [`./data-list.style.less`],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    providers: [\n        tuiAsDataListAccessor(TuiDataListComponent),\n        TEXTFIELD_CONTROLLER_PROVIDER,\n    ],\n})\nexport class TuiDataListComponent<T> implements TuiDataListAccessor<T> {\n    @ContentChildren(forwardRef(() => TuiOptionComponent), {descendants: true})\n    private readonly options: QueryList<TuiOptionComponent<T>> = EMPTY_QUERY;\n\n    private origin?: HTMLElement;\n\n    @Input()\n    @HostBinding(`attr.role`)\n    @tuiDefaultProp()\n    role: TuiDataListRole = `listbox`;\n\n    @Input()\n    @tuiDefaultProp()\n    emptyContent: PolymorpheusContent = ``;\n\n    @Input()\n    @HostBinding(`attr.data-list-size`)\n    @tuiDefaultProp()\n    size = this.controller?.size || `m`;\n\n    constructor(\n        @Optional()\n        @Inject(TUI_TEXTFIELD_WATCHED_CONTROLLER)\n        private readonly controller: TuiTextfieldController | null,\n        @Inject(ElementRef) private readonly elementRef: ElementRef<HTMLElement>,\n        @Inject(TUI_NOTHING_FOUND_MESSAGE)\n        readonly defaultEmptyContent$: Observable<string>,\n    ) {}\n\n    @tuiPure\n    get empty$(): Observable<boolean> {\n        return tuiItemsQueryListObservable(this.options).pipe(map(({length}) => !length));\n    }\n\n    @HostListener(`focusin`, [`$event.relatedTarget`, `$event.currentTarget`])\n    onFocusIn(relatedTarget: HTMLElement, currentTarget: HTMLElement): void {\n        if (!currentTarget.contains(relatedTarget) && !this.origin) {\n            this.origin = relatedTarget;\n        }\n    }\n\n    @HostListener(`mousedown.prevent`)\n    noop(): void {}\n\n    @HostListener(`keydown.arrowDown.prevent`, [`$event.target`, `1`])\n    @HostListener(`keydown.arrowUp.prevent`, [`$event.target`, `-1`])\n    onKeyDownArrow(current: HTMLElement, step: number): void {\n        const {elements} = this;\n\n        tuiMoveFocus(elements.indexOf(current), elements, step);\n    }\n\n    // TODO: Consider aria-activedescendant for proper accessibility implementation\n    @HostListener(`wheel.silent.passive`)\n    @HostListener(`mouseleave`, [`$event.target`])\n    handleFocusLossIfNecessary(element: Element = this.elementRef.nativeElement): void {\n        if (this.origin && tuiIsNativeFocusedIn(element)) {\n            tuiSetNativeMouseFocused(this.origin, true, true);\n        }\n    }\n\n    getOptions(includeDisabled: boolean = false): readonly T[] {\n        return this.options\n            .filter(({disabled}) => includeDisabled || !disabled)\n            .map(({value}) => value)\n            .filter(tuiIsPresent);\n    }\n\n    onFocus({target}: Event, top: boolean): void {\n        if (!tuiIsElement(target)) {\n            return;\n        }\n\n        const {elements} = this;\n\n        tuiMoveFocus(top ? -1 : elements.length, elements, top ? 1 : -1);\n        this.handleFocusLossIfNecessary(target);\n    }\n\n    private get elements(): readonly HTMLElement[] {\n        return Array.from(this.elementRef.nativeElement.querySelectorAll(`[tuiOption]`));\n    }\n}\n","<div\n    tabindex=\"0\"\n    class=\"t-trap\"\n    (focusin)=\"onFocus($event, true)\"\n></div>\n<ng-content></ng-content>\n<div\n    *ngIf=\"empty$ | async\"\n    class=\"t-empty\"\n>\n    <ng-container *polymorpheusOutlet=\"emptyContent || (defaultEmptyContent$ | async) as text\">\n        {{ text }}\n    </ng-container>\n</div>\n<div\n    tabindex=\"0\"\n    class=\"t-trap\"\n    (focusin)=\"onFocus($event, false)\"\n></div>\n"]}
|
|
@@ -47,7 +47,7 @@ export class TuiOptionComponent {
|
|
|
47
47
|
}
|
|
48
48
|
}
|
|
49
49
|
TuiOptionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiOptionComponent, deps: [{ token: TUI_OPTION_CONTENT, optional: true }, { token: forwardRef(() => TuiDataListComponent) }, { token: ElementRef }, { token: TUI_DATA_LIST_HOST, optional: true }, { token: TuiDropdownDirective, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
50
|
-
TuiOptionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiOptionComponent, selector: "button[tuiOption], a[tuiOption]", inputs: { size: "size", role: "role", disabled: "disabled", value: "value" }, host: { attributes: { "tabIndex": "-1", "type": "button" }, listeners: { "click": "onClick()", "mousemove.init": "onMouseMove($event)", "mousemove.silent": "onMouseMove($event)" }, properties: { "attr.disabled": "disabled || null", "attr.data-size": "this.size", "attr.role": "this.role", "class._with-dropdown": "this.active" } }, ngImport: i0, template: "<ng-container *polymorpheusOutlet=\"content || base as text; context: {$implicit: base}\">\n {{ text }}\n</ng-container>\n<ng-template #base>\n <ng-content></ng-content>\n <tui-svg\n *ngIf=\"dropdown\"\n src=\"tuiIconChevronRight\"\n class=\"t-arrow\"\n ></tui-svg>\n</ng-template>\n", styles: [":host{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:none;font-size:inherit;line-height:inherit;transition-property:background;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;display:flex;align-items:center;justify-content:space-between;text-align:left;box-sizing:border-box;color:var(--tui-text-01);border-radius:var(--tui-radius-s);outline:none;text-decoration:none;cursor:pointer;background-clip:padding-box;font:var(--tui-font-text-s);min-height:2.5rem;padding:.375rem .5rem;margin:.125rem 0}:host:disabled{opacity:var(--tui-disabled-opacity);cursor:default}:host:focus,:host._with-dropdown{background-color:var(--tui-clear
|
|
50
|
+
TuiOptionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiOptionComponent, selector: "button[tuiOption], a[tuiOption]", inputs: { size: "size", role: "role", disabled: "disabled", value: "value" }, host: { attributes: { "tabIndex": "-1", "type": "button" }, listeners: { "click": "onClick()", "mousemove.init": "onMouseMove($event)", "mousemove.silent": "onMouseMove($event)" }, properties: { "attr.disabled": "disabled || null", "attr.data-size": "this.size", "attr.role": "this.role", "class._with-dropdown": "this.active" } }, ngImport: i0, template: "<ng-container *polymorpheusOutlet=\"content || base as text; context: {$implicit: base}\">\n {{ text }}\n</ng-container>\n<ng-template #base>\n <ng-content></ng-content>\n <tui-svg\n *ngIf=\"dropdown\"\n src=\"tuiIconChevronRight\"\n class=\"t-arrow\"\n ></tui-svg>\n</ng-template>\n", styles: [":host{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:none;font-size:inherit;line-height:inherit;transition-property:background;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;display:flex;align-items:center;justify-content:space-between;text-align:left;box-sizing:border-box;color:var(--tui-text-01);border-radius:var(--tui-radius-s);outline:none;text-decoration:none;cursor:pointer;background-clip:padding-box;font:var(--tui-font-text-s);min-height:2.5rem;padding:.375rem .5rem;margin:.125rem 0}:host:disabled{opacity:var(--tui-disabled-opacity);cursor:default}:host:focus,:host._with-dropdown{background-color:var(--tui-clear)}:host :host-context([data-list-size=\"s\"]),:host :host-context([data-list-size=\"xs\"]),:host[data-size=s][data-size=s],:host[data-size=xs][data-size=xs]{font:var(--tui-font-text-s);min-height:2rem;padding:.3125rem .5rem;margin:var(--tui-data-list-margin) 0}:host :host-context([data-list-size=\"m\"]),:host[data-size=m][data-size=m]{font:var(--tui-font-text-s);min-height:2.5rem;padding:.375rem .5rem;margin:var(--tui-data-list-margin) 0}:host :host-context([data-list-size=\"l\"]),:host[data-size=l][data-size=l]{font:var(--tui-font-text-m);min-height:2.75rem;padding:.375rem .625rem;margin:var(--tui-data-list-margin) 0}.t-arrow{margin:0 -.5rem 0 .75rem}\n"], components: [{ type: i1.TuiSvgComponent, selector: "tui-svg", inputs: ["src"] }], directives: [{ type: i2.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
51
51
|
__decorate([
|
|
52
52
|
tuiDefaultProp()
|
|
53
53
|
], TuiOptionComponent.prototype, "size", void 0);
|
|
@@ -2,6 +2,7 @@ export * from './primitive-textfield.component';
|
|
|
2
2
|
export * from './primitive-textfield.directive';
|
|
3
3
|
export * from './primitive-textfield.module';
|
|
4
4
|
export * from './primitive-textfield-options';
|
|
5
|
+
export * from './primitive-textfield-types';
|
|
5
6
|
export * from './textfield/textfield.component';
|
|
6
7
|
export * from './value-decoration/value-decoration.component';
|
|
7
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvcHJpbWl0aXZlLXRleHRmaWVsZC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLCtDQUErQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9wcmltaXRpdmUtdGV4dGZpZWxkLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3ByaW1pdGl2ZS10ZXh0ZmllbGQuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vcHJpbWl0aXZlLXRleHRmaWVsZC5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9wcmltaXRpdmUtdGV4dGZpZWxkLW9wdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9wcmltaXRpdmUtdGV4dGZpZWxkLXR5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4vdGV4dGZpZWxkL3RleHRmaWVsZC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi92YWx1ZS1kZWNvcmF0aW9uL3ZhbHVlLWRlY29yYXRpb24uY29tcG9uZW50JztcbiJdfQ==
|
|
@@ -1,13 +1,17 @@
|
|
|
1
|
-
import {
|
|
2
|
-
/**
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
export const
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
1
|
+
import { TUI_TEXTFIELD_DEFAULT_OPTIONS, TUI_TEXTFIELD_OPTIONS, tuiTextfieldOptionsProvider, } from '@taiga-ui/core/directives';
|
|
2
|
+
/**
|
|
3
|
+
* @deprecated:
|
|
4
|
+
* use {@link TUI_TEXTFIELD_DEFAULT_OPTIONS}
|
|
5
|
+
*/
|
|
6
|
+
export const TUI_PRIMITIVE_TEXTFIELD_DEFAULT_OPTIONS = TUI_TEXTFIELD_DEFAULT_OPTIONS;
|
|
7
|
+
/**
|
|
8
|
+
* @deprecated:
|
|
9
|
+
* use {@link TUI_TEXTFIELD_OPTIONS}
|
|
10
|
+
*/
|
|
11
|
+
export const TUI_PRIMITIVE_TEXTFIELD_OPTIONS = TUI_TEXTFIELD_OPTIONS;
|
|
12
|
+
/**
|
|
13
|
+
* @deprecated:
|
|
14
|
+
* use {@link tuiTextfieldOptionsProvider}
|
|
15
|
+
*/
|
|
16
|
+
export const tuiPrimitiveTextfieldOptionsProvider = tuiTextfieldOptionsProvider;
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJpbWl0aXZlLXRleHRmaWVsZC1vcHRpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9jb21wb25lbnRzL3ByaW1pdGl2ZS10ZXh0ZmllbGQvcHJpbWl0aXZlLXRleHRmaWVsZC1vcHRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDSCw2QkFBNkIsRUFDN0IscUJBQXFCLEVBRXJCLDJCQUEyQixHQUM5QixNQUFNLDJCQUEyQixDQUFDO0FBUW5DOzs7R0FHRztBQUNILE1BQU0sQ0FBQyxNQUFNLHVDQUF1QyxHQUNoRCw2QkFBNkIsQ0FBQztBQUVsQzs7O0dBR0c7QUFDSCxNQUFNLENBQUMsTUFBTSwrQkFBK0IsR0FBRyxxQkFBcUIsQ0FBQztBQUVyRTs7O0dBR0c7QUFDSCxNQUFNLENBQUMsTUFBTSxvQ0FBb0MsR0FBRywyQkFBMkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgVFVJX1RFWFRGSUVMRF9ERUZBVUxUX09QVElPTlMsXG4gICAgVFVJX1RFWFRGSUVMRF9PUFRJT05TLFxuICAgIFR1aVRleHRmaWVsZE9wdGlvbnMsXG4gICAgdHVpVGV4dGZpZWxkT3B0aW9uc1Byb3ZpZGVyLFxufSBmcm9tICdAdGFpZ2EtdWkvY29yZS9kaXJlY3RpdmVzJztcblxuLyoqXG4gKiBAZGVwcmVjYXRlZDpcbiAqIHVzZSB7QGxpbmsgVHVpVGV4dGZpZWxkT3B0aW9uc31cbiAqL1xuZXhwb3J0IHR5cGUgVHVpUHJpbWl0aXZlVGV4dGZpZWxkT3B0aW9ucyA9IFR1aVRleHRmaWVsZE9wdGlvbnM7XG5cbi8qKlxuICogQGRlcHJlY2F0ZWQ6XG4gKiB1c2Uge0BsaW5rIFRVSV9URVhURklFTERfREVGQVVMVF9PUFRJT05TfVxuICovXG5leHBvcnQgY29uc3QgVFVJX1BSSU1JVElWRV9URVhURklFTERfREVGQVVMVF9PUFRJT05TOiBUdWlQcmltaXRpdmVUZXh0ZmllbGRPcHRpb25zID1cbiAgICBUVUlfVEVYVEZJRUxEX0RFRkFVTFRfT1BUSU9OUztcblxuLyoqXG4gKiBAZGVwcmVjYXRlZDpcbiAqIHVzZSB7QGxpbmsgVFVJX1RFWFRGSUVMRF9PUFRJT05TfVxuICovXG5leHBvcnQgY29uc3QgVFVJX1BSSU1JVElWRV9URVhURklFTERfT1BUSU9OUyA9IFRVSV9URVhURklFTERfT1BUSU9OUztcblxuLyoqXG4gKiBAZGVwcmVjYXRlZDpcbiAqIHVzZSB7QGxpbmsgdHVpVGV4dGZpZWxkT3B0aW9uc1Byb3ZpZGVyfVxuICovXG5leHBvcnQgY29uc3QgdHVpUHJpbWl0aXZlVGV4dGZpZWxkT3B0aW9uc1Byb3ZpZGVyID0gdHVpVGV4dGZpZWxkT3B0aW9uc1Byb3ZpZGVyO1xuIl19
|