@taiga-ui/core 4.0.0-rc.5 → 4.0.0-rc.6
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/components/textfield/textfield.component.d.ts +0 -1
- package/components/textfield/textfield.options.d.ts +1 -2
- package/directives/dropdown/dropdown-context.directive.d.ts +7 -0
- package/directives/dropdown/dropdown-open-legacy.directive.d.ts +11 -0
- package/directives/dropdown/dropdown-open.directive.d.ts +2 -2
- package/directives/dropdown/dropdown.component.d.ts +2 -5
- package/directives/dropdown/dropdown.d.ts +2 -1
- package/directives/dropdown/index.d.ts +1 -0
- package/directives/hint/hint-options.directive.d.ts +5 -3
- package/directives/hint/hint-overflow.directive.d.ts +8 -0
- package/directives/hint/hint.component.d.ts +1 -0
- package/directives/hint/hint.d.ts +2 -1
- package/directives/hint/index.d.ts +1 -0
- package/esm2022/components/data-list/data-list.component.mjs +3 -3
- package/esm2022/components/data-list/option.component.mjs +2 -2
- package/esm2022/components/root/root.component.mjs +3 -3
- package/esm2022/components/textfield/textfield.component.mjs +4 -6
- package/esm2022/components/textfield/textfield.options.mjs +4 -6
- package/esm2022/directives/dropdown/dropdown-context.directive.mjs +55 -4
- package/esm2022/directives/dropdown/dropdown-open-legacy.directive.mjs +29 -0
- package/esm2022/directives/dropdown/dropdown-open.directive.mjs +12 -12
- package/esm2022/directives/dropdown/dropdown.component.mjs +20 -39
- package/esm2022/directives/dropdown/dropdown.mjs +3 -1
- package/esm2022/directives/dropdown/index.mjs +2 -1
- package/esm2022/directives/hint/hint-options.directive.mjs +9 -6
- package/esm2022/directives/hint/hint-overflow.directive.mjs +32 -0
- package/esm2022/directives/hint/hint.component.mjs +15 -15
- package/esm2022/directives/hint/hint.mjs +3 -1
- package/esm2022/directives/hint/index.mjs +2 -1
- package/esm2022/services/position.service.mjs +3 -3
- package/fesm2022/taiga-ui-core-components-data-list.mjs +3 -3
- package/fesm2022/taiga-ui-core-components-data-list.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-components-root.mjs +2 -2
- package/fesm2022/taiga-ui-core-components-root.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-components-textfield.mjs +5 -9
- package/fesm2022/taiga-ui-core-components-textfield.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-directives-dropdown.mjs +112 -55
- package/fesm2022/taiga-ui-core-directives-dropdown.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-directives-hint.mjs +50 -20
- package/fesm2022/taiga-ui-core-directives-hint.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-services.mjs +1 -1
- package/fesm2022/taiga-ui-core-services.mjs.map +1 -1
- package/package.json +6 -6
- package/styles/taiga-ui-fonts.less +3 -1
- package/styles/theme/variables.less +2 -2
|
@@ -16,7 +16,6 @@ export declare class TuiTextfieldComponent<T> implements TuiDataListHost<T> {
|
|
|
16
16
|
protected readonly label?: ElementRef<HTMLElement>;
|
|
17
17
|
protected readonly control?: NgControl;
|
|
18
18
|
protected side: number;
|
|
19
|
-
protected readonly change$: import("rxjs").Subject<void> | undefined;
|
|
20
19
|
protected readonly options: import("./textfield.options").TuiTextfieldOptions;
|
|
21
20
|
protected readonly icons: import("@taiga-ui/core/tokens").TuiCommonIcons;
|
|
22
21
|
readonly el?: ElementRef<HTMLInputElement>;
|
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import type { Provider, WritableSignal } from '@angular/core';
|
|
2
|
-
import { AbstractTuiController } from '@taiga-ui/cdk/classes';
|
|
3
2
|
import type { TuiSizeL, TuiSizeS } from '@taiga-ui/core/types';
|
|
4
3
|
import * as i0 from "@angular/core";
|
|
5
4
|
export interface TuiTextfieldOptions {
|
|
@@ -9,7 +8,7 @@ export interface TuiTextfieldOptions {
|
|
|
9
8
|
}
|
|
10
9
|
export declare const TUI_TEXTFIELD_OPTIONS: import("@angular/core").InjectionToken<TuiTextfieldOptions>;
|
|
11
10
|
export declare function tuiTextfieldOptionsProvider(options: Partial<TuiTextfieldOptions>): Provider;
|
|
12
|
-
export declare class TuiTextfieldOptionsDirective
|
|
11
|
+
export declare class TuiTextfieldOptionsDirective implements TuiTextfieldOptions {
|
|
13
12
|
private readonly options;
|
|
14
13
|
appearance: WritableSignal<string>;
|
|
15
14
|
size: WritableSignal<"l" | "m" | "s">;
|
|
@@ -2,13 +2,20 @@ import { TuiActiveZone } from '@taiga-ui/cdk/directives/active-zone';
|
|
|
2
2
|
import { TuiRectAccessor } from '@taiga-ui/core/classes';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export declare class TuiDropdownContext extends TuiRectAccessor {
|
|
5
|
+
private readonly isIOS;
|
|
6
|
+
private readonly isTouch;
|
|
5
7
|
private readonly driver;
|
|
6
8
|
private currentRect;
|
|
9
|
+
private longTapTimeout;
|
|
10
|
+
protected readonly userSelect: import("@angular/core").Signal<"none" | null>;
|
|
7
11
|
protected readonly activeZone: TuiActiveZone;
|
|
8
12
|
readonly type = "dropdown";
|
|
9
13
|
getClientRect(): DOMRect;
|
|
10
14
|
protected onContextMenu(x: number, y: number): void;
|
|
11
15
|
protected closeDropdown(): void;
|
|
16
|
+
protected onTouchStart(x: number, y: number): void;
|
|
17
|
+
protected onTouchMove(x: number, y: number): void;
|
|
18
|
+
protected onTouchEnd(): void;
|
|
12
19
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiDropdownContext, never>;
|
|
13
20
|
static ɵdir: i0.ɵɵDirectiveDeclaration<TuiDropdownContext, "[tuiDropdownContext]", never, {}, {}, never, never, true, never>;
|
|
14
21
|
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { BehaviorSubject } from 'rxjs';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
/**
|
|
4
|
+
* @deprecated TODO: remove in v.5 when legacy controls are dropped
|
|
5
|
+
*/
|
|
6
|
+
export declare class TuiDropdownOpenLegacy {
|
|
7
|
+
readonly tuiDropdownOpenChange: BehaviorSubject<boolean>;
|
|
8
|
+
set tuiDropdownOpen(open: boolean);
|
|
9
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TuiDropdownOpenLegacy, never>;
|
|
10
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<TuiDropdownOpenLegacy, "[tuiDropdownOpen]:not([tuiDropdown]),[tuiDropdownOpenChange]:not([tuiDropdown])", never, { "tuiDropdownOpen": { "alias": "tuiDropdownOpen"; "required": false; }; }, { "tuiDropdownOpenChange": "tuiDropdownOpenChange"; }, never, never, true, never>;
|
|
11
|
+
}
|
|
@@ -15,7 +15,6 @@ export declare class TuiDropdownOpen implements OnChanges {
|
|
|
15
15
|
readonly tuiDropdownOpenChange: EventEmitter<boolean>;
|
|
16
16
|
readonly driver: TuiDropdownDriver;
|
|
17
17
|
get dropdown(): HTMLElement | undefined;
|
|
18
|
-
get focused(): boolean;
|
|
19
18
|
ngOnChanges(): void;
|
|
20
19
|
toggle(open: boolean): void;
|
|
21
20
|
protected onClick(target: HTMLElement): void;
|
|
@@ -24,9 +23,10 @@ export declare class TuiDropdownOpen implements OnChanges {
|
|
|
24
23
|
protected onKeydown({ key, target, defaultPrevented }: KeyboardEvent): void;
|
|
25
24
|
private get host();
|
|
26
25
|
private get editable();
|
|
26
|
+
private get focused();
|
|
27
27
|
private update;
|
|
28
28
|
private drive;
|
|
29
29
|
private focusDropdown;
|
|
30
30
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiDropdownOpen, never>;
|
|
31
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<TuiDropdownOpen, "[tuiDropdownOpen],[tuiDropdownOpenChange]", never, { "tuiDropdownEnabled": { "alias": "tuiDropdownEnabled"; "required": false; }; "tuiDropdownOpen": { "alias": "tuiDropdownOpen"; "required": false; }; }, { "tuiDropdownOpenChange": "tuiDropdownOpenChange"; }, ["dropdownHost"], never, true, [{ directive: typeof i1.TuiObscured; inputs: {}; outputs: {}; }, { directive: typeof i2.TuiActiveZone; inputs: { "tuiActiveZoneParent": "tuiActiveZoneParent"; }; outputs: { "tuiActiveZoneChange": "tuiActiveZoneChange"; }; }]>;
|
|
31
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<TuiDropdownOpen, "[tuiDropdown][tuiDropdownOpen],[tuiDropdown][tuiDropdownOpenChange]", never, { "tuiDropdownEnabled": { "alias": "tuiDropdownEnabled"; "required": false; }; "tuiDropdownOpen": { "alias": "tuiDropdownOpen"; "required": false; }; }, { "tuiDropdownOpenChange": "tuiDropdownOpenChange"; }, ["dropdownHost"], never, true, [{ directive: typeof i1.TuiObscured; inputs: {}; outputs: {}; }, { directive: typeof i2.TuiActiveZone; inputs: { "tuiActiveZoneParent": "tuiActiveZoneParent"; }; outputs: { "tuiActiveZoneChange": "tuiActiveZoneChange"; }; }]>;
|
|
32
32
|
}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import type { OnInit } from '@angular/core';
|
|
2
1
|
import { TuiDropdownDirective } from './dropdown.directive';
|
|
3
2
|
import * as i0 from "@angular/core";
|
|
4
3
|
import * as i1 from "@taiga-ui/cdk/directives/active-zone";
|
|
@@ -7,7 +6,7 @@ import * as i1 from "@taiga-ui/cdk/directives/active-zone";
|
|
|
7
6
|
* This component is used to show template in a portal
|
|
8
7
|
* using default style of white rounded box with a shadow
|
|
9
8
|
*/
|
|
10
|
-
export declare class TuiDropdownComponent
|
|
9
|
+
export declare class TuiDropdownComponent {
|
|
11
10
|
private readonly el;
|
|
12
11
|
private readonly accessor;
|
|
13
12
|
private readonly win;
|
|
@@ -18,10 +17,8 @@ export declare class TuiDropdownComponent implements OnInit {
|
|
|
18
17
|
protected readonly context: Record<any, any> | null;
|
|
19
18
|
protected readonly theme: string | null | undefined;
|
|
20
19
|
protected readonly sub: import("rxjs").Subscription;
|
|
21
|
-
ngOnInit(): void;
|
|
22
20
|
protected readonly close: () => void;
|
|
23
|
-
private
|
|
24
|
-
private updateWidth;
|
|
21
|
+
private getStyles;
|
|
25
22
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiDropdownComponent, never>;
|
|
26
23
|
static ɵcmp: i0.ɵɵComponentDeclaration<TuiDropdownComponent, "tui-dropdown", never, {}, {}, never, never, true, [{ directive: typeof i1.TuiActiveZone; inputs: {}; outputs: {}; }]>;
|
|
27
24
|
}
|
|
@@ -5,9 +5,10 @@ import { TuiDropdownContext } from './dropdown-context.directive';
|
|
|
5
5
|
import { TuiDropdownHover } from './dropdown-hover.directive';
|
|
6
6
|
import { TuiDropdownManual } from './dropdown-manual.directive';
|
|
7
7
|
import { TuiDropdownOpen } from './dropdown-open.directive';
|
|
8
|
+
import { TuiDropdownOpenLegacy } from './dropdown-open-legacy.directive';
|
|
8
9
|
import { TuiDropdownOptionsDirective } from './dropdown-options.directive';
|
|
9
10
|
import { TuiDropdownPortal } from './dropdown-portal.directive';
|
|
10
11
|
import { TuiDropdownPosition } from './dropdown-position.directive';
|
|
11
12
|
import { TuiDropdownPositionSided } from './dropdown-position-sided.directive';
|
|
12
13
|
import { TuiDropdownSelection } from './dropdown-selection.directive';
|
|
13
|
-
export declare const TuiDropdown: readonly [typeof TuiDropdownOptionsDirective, typeof TuiDropdownDriverDirective, typeof TuiDropdownDirective, typeof TuiDropdownComponent, typeof TuiDropdownOpen, typeof TuiDropdownPortal, typeof TuiDropdownManual, typeof TuiDropdownHover, typeof TuiDropdownContext, typeof TuiDropdownPosition, typeof TuiDropdownPositionSided, typeof TuiDropdownSelection];
|
|
14
|
+
export declare const TuiDropdown: readonly [typeof TuiDropdownOptionsDirective, typeof TuiDropdownDriverDirective, typeof TuiDropdownDirective, typeof TuiDropdownComponent, typeof TuiDropdownOpen, typeof TuiDropdownOpenLegacy, typeof TuiDropdownPortal, typeof TuiDropdownManual, typeof TuiDropdownHover, typeof TuiDropdownContext, typeof TuiDropdownPosition, typeof TuiDropdownPositionSided, typeof TuiDropdownSelection];
|
|
@@ -10,6 +10,7 @@ export * from './dropdown-hover.directive';
|
|
|
10
10
|
export * from './dropdown-hover.options';
|
|
11
11
|
export * from './dropdown-manual.directive';
|
|
12
12
|
export * from './dropdown-open.directive';
|
|
13
|
+
export * from './dropdown-open-legacy.directive';
|
|
13
14
|
export * from './dropdown-options.directive';
|
|
14
15
|
export * from './dropdown-portal.directive';
|
|
15
16
|
export * from './dropdown-position.directive';
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import type { FactoryProvider } from '@angular/core';
|
|
2
|
-
import { AbstractTuiController } from '@taiga-ui/cdk/classes';
|
|
1
|
+
import type { FactoryProvider, OnChanges } from '@angular/core';
|
|
3
2
|
import type { PolymorpheusContent } from '@taiga-ui/polymorpheus';
|
|
3
|
+
import { Subject } from 'rxjs';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export type TuiHintDirection = 'bottom-left' | 'bottom-right' | 'bottom' | 'left-bottom' | 'left-top' | 'left' | 'right-bottom' | 'right-top' | 'right' | 'top-left' | 'top-right' | 'top';
|
|
6
6
|
export declare const TUI_HINT_DIRECTIONS: readonly TuiHintDirection[];
|
|
@@ -21,7 +21,7 @@ export declare const tuiHintOptionsProvider: (options: Partial<TuiHintOptions>)
|
|
|
21
21
|
/**
|
|
22
22
|
* @deprecated: drop in 5.0
|
|
23
23
|
*/
|
|
24
|
-
export declare class TuiHintOptionsDirective
|
|
24
|
+
export declare class TuiHintOptionsDirective implements TuiHintOptions, OnChanges {
|
|
25
25
|
private readonly options;
|
|
26
26
|
content: PolymorpheusContent;
|
|
27
27
|
direction: TuiHintDirection;
|
|
@@ -29,6 +29,8 @@ export declare class TuiHintOptionsDirective extends AbstractTuiController imple
|
|
|
29
29
|
showDelay: number;
|
|
30
30
|
hideDelay: number;
|
|
31
31
|
icon: string;
|
|
32
|
+
readonly change$: Subject<void>;
|
|
33
|
+
ngOnChanges(): void;
|
|
32
34
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiHintOptionsDirective, never>;
|
|
33
35
|
static ɵdir: i0.ɵɵDirectiveDeclaration<TuiHintOptionsDirective, "[tuiHintContent]", never, { "content": { "alias": "tuiHintContent"; "required": false; }; "direction": { "alias": "tuiHintDirection"; "required": false; }; "appearance": { "alias": "tuiHintAppearance"; "required": false; }; "showDelay": { "alias": "tuiHintShowDelay"; "required": false; }; "hideDelay": { "alias": "tuiHintHideDelay"; "required": false; }; }, {}, never, never, true, never>;
|
|
34
36
|
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
import * as i1 from "./hint.directive";
|
|
3
|
+
export declare class TuiHintOverflow {
|
|
4
|
+
private readonly hint;
|
|
5
|
+
protected onMouseEnter({ scrollWidth, clientWidth, textContent }: Element): void;
|
|
6
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TuiHintOverflow, never>;
|
|
7
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<TuiHintOverflow, "[tuiHintOverflow]", never, {}, {}, never, never, true, [{ directive: typeof i1.TuiHintDirective; inputs: { "tuiHintAppearance": "tuiHintAppearance"; }; outputs: {}; }]>;
|
|
8
|
+
}
|
|
@@ -19,6 +19,7 @@ export declare class TuiHintComponent<C = any> {
|
|
|
19
19
|
protected get content(): PolymorpheusContent<C>;
|
|
20
20
|
protected get context(): C | undefined;
|
|
21
21
|
protected onClick(target: HTMLElement): void;
|
|
22
|
+
private apply;
|
|
22
23
|
private update;
|
|
23
24
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiHintComponent<any>, never>;
|
|
24
25
|
static ɵcmp: i0.ɵɵComponentDeclaration<TuiHintComponent<any>, "tui-hint", never, {}, {}, never, ["*"], true, never>;
|
|
@@ -6,7 +6,8 @@ import { TuiHintHost } from './hint-host.directive';
|
|
|
6
6
|
import { TuiHintHover } from './hint-hover.directive';
|
|
7
7
|
import { TuiHintManual } from './hint-manual.directive';
|
|
8
8
|
import { TuiHintOptionsDirective } from './hint-options.directive';
|
|
9
|
+
import { TuiHintOverflow } from './hint-overflow.directive';
|
|
9
10
|
import { TuiHintPointer } from './hint-pointer.directive';
|
|
10
11
|
import { TuiHintPosition } from './hint-position.directive';
|
|
11
12
|
import { TuiHintUnstyled } from './hint-unstyled.component';
|
|
12
|
-
export declare const TuiHint: readonly [typeof TuiHintComponent, typeof TuiHintDirective, typeof TuiHintOptionsDirective, typeof TuiHintUnstyled, typeof TuiHintDriver, typeof TuiHintPosition, typeof TuiHintHover, typeof TuiHintDescribe, typeof TuiHintHost, typeof TuiHintManual, typeof TuiHintPointer];
|
|
13
|
+
export declare const TuiHint: readonly [typeof TuiHintComponent, typeof TuiHintDirective, typeof TuiHintOptionsDirective, typeof TuiHintUnstyled, typeof TuiHintDriver, typeof TuiHintPosition, typeof TuiHintHover, typeof TuiHintOverflow, typeof TuiHintDescribe, typeof TuiHintHost, typeof TuiHintManual, typeof TuiHintPointer];
|
|
@@ -9,6 +9,7 @@ export * from './hint-host.directive';
|
|
|
9
9
|
export * from './hint-hover.directive';
|
|
10
10
|
export * from './hint-manual.directive';
|
|
11
11
|
export * from './hint-options.directive';
|
|
12
|
+
export * from './hint-overflow.directive';
|
|
12
13
|
export * from './hint-pointer.directive';
|
|
13
14
|
export * from './hint-position.directive';
|
|
14
15
|
export * from './hint-unstyled.component';
|
|
@@ -53,7 +53,7 @@ class TuiDataListComponent {
|
|
|
53
53
|
return Array.from(this.el.querySelectorAll('a[tuiOption],button[tuiOption],input'));
|
|
54
54
|
}
|
|
55
55
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiDataListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
56
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiDataListComponent, isStandalone: true, selector: "tui-data-list", inputs: { emptyContent: "emptyContent", size: "size" }, host: { attributes: { "role": "listbox" }, listeners: { "keydown.arrowDown.prevent": "onKeyDownArrow($event.target,1)", "keydown.arrowUp.prevent": "onKeyDownArrow($event.target,-1)", "wheel.silent.passive": "handleFocusLossIfNecessary()", "mouseleave": "handleFocusLossIfNecessary($event.target)", "keydown.tab": "handleFocusLossIfNecessary()", "keydown.shift.tab": "handleFocusLossIfNecessary()", "focusin": "onFocusIn($event.relatedTarget,$event.currentTarget)", "mousedown.prevent": "noop()" }, properties: { "attr.data-size": "this.size" } }, providers: [tuiAsDataListAccessor(TuiDataListComponent)], queries: [{ propertyName: "options", predicate: i0.forwardRef(function () { return TuiOption; }), descendants: true }], ngImport: i0, template: "<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", 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-tertiary)}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-size=s]{--tui-data-list-margin: 0rem}tui-data-list[data-size=s]>.t-empty,tui-data-list[data-size=s] [tuiOption]{font:var(--tui-font-text-s);min-height:2rem;padding:.3125rem .5rem}tui-data-list[data-size=s]>.t-empty:before,tui-data-list[data-size=s] [tuiOption]:before{font-size:1rem}tui-data-list[data-size=m]>.t-empty,tui-data-list[data-size=m] [tuiOption]{font:var(--tui-font-text-s);min-height:2.5rem;padding:.375rem .5rem}tui-data-list[data-size=l]{--tui-data-list-padding: .375rem;--tui-data-list-margin: .125rem}tui-data-list[data-size=l]>.t-empty,tui-data-list[data-size=l] [tuiOption]{font:var(--tui-font-text-m);min-height:2.75rem;padding:.375rem .625rem}tui-data-list>.t-empty{display:flex;align-items:center;box-sizing:border-box;margin:var(--tui-data-list-margin) 0}tui-opt-group{position:relative;display:flex;font:var(--tui-font-text-xs);color:var(--tui-text-secondary);flex-direction:column;line-height:1rem}tui-data-list[data-size=l] tui-opt-group{font:var(--tui-font-text-s);line-height:1.25rem}tui-data-list[data-size=l] tui-opt-group:before{padding-left:.625rem;padding-right:.625rem}tui-data-list[data-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-border-normal)}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,tui-opt-group:not(:empty)~tui-opt-group:not([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,tui-opt-group:not([data-label]):before{padding:0;margin:0}
|
|
56
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiDataListComponent, isStandalone: true, selector: "tui-data-list", inputs: { emptyContent: "emptyContent", size: "size" }, host: { attributes: { "role": "listbox" }, listeners: { "keydown.arrowDown.prevent": "onKeyDownArrow($event.target,1)", "keydown.arrowUp.prevent": "onKeyDownArrow($event.target,-1)", "wheel.silent.passive": "handleFocusLossIfNecessary()", "mouseleave": "handleFocusLossIfNecessary($event.target)", "keydown.tab": "handleFocusLossIfNecessary()", "keydown.shift.tab": "handleFocusLossIfNecessary()", "focusin": "onFocusIn($event.relatedTarget,$event.currentTarget)", "mousedown.prevent": "noop()" }, properties: { "attr.data-size": "this.size" } }, providers: [tuiAsDataListAccessor(TuiDataListComponent)], queries: [{ propertyName: "options", predicate: i0.forwardRef(function () { return TuiOption; }), descendants: true }], ngImport: i0, template: "<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", 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-tertiary)}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-size=s]{--tui-data-list-margin: 0rem}tui-data-list[data-size=s]>.t-empty,tui-data-list[data-size=s] [tuiOption]{font:var(--tui-font-text-s);min-height:2rem;padding:.3125rem .5rem}tui-data-list[data-size=s]>.t-empty:before,tui-data-list[data-size=s] [tuiOption]:before{font-size:1rem}tui-data-list[data-size=m]>.t-empty,tui-data-list[data-size=m] [tuiOption]{font:var(--tui-font-text-s);min-height:2.5rem;padding:.375rem .5rem}tui-data-list[data-size=l]{--tui-data-list-padding: .375rem;--tui-data-list-margin: .125rem}tui-data-list[data-size=l]>.t-empty,tui-data-list[data-size=l] [tuiOption]{font:var(--tui-font-text-m);min-height:2.75rem;padding:.375rem .625rem}tui-data-list>.t-empty{display:flex;align-items:center;box-sizing:border-box;margin:var(--tui-data-list-margin) 0}tui-data-list [tuiOption]{-webkit-appearance:none;appearance:none;padding:0;border:0;background:none;font-size:inherit;line-height:inherit;text-decoration:none;transition-property:background;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;display:flex;align-items:center;box-sizing:border-box;margin:var(--tui-data-list-margin) 0;justify-content:space-between;text-align:left;color:var(--tui-text-primary);border-radius:var(--tui-radius-s);outline:none;cursor:pointer;background-clip:padding-box}tui-data-list [tuiOption]:disabled{opacity:var(--tui-disabled-opacity);cursor:default}tui-data-list [tuiOption]:focus-within,tui-data-list [tuiOption]._with-dropdown{background-color:var(--tui-background-neutral-1)}tui-data-list [tuiOption]:before{margin-inline-end:.5rem}tui-data-list [tuiOption]:after{font-size:1rem;margin:0 -.75rem 0 auto;border-left:.5rem solid;border-right:.5rem solid}tui-opt-group{position:relative;display:flex;font:var(--tui-font-text-xs);color:var(--tui-text-secondary);flex-direction:column;line-height:1rem}tui-data-list[data-size=l] tui-opt-group{font:var(--tui-font-text-s);line-height:1.25rem}tui-data-list[data-size=l] tui-opt-group:before{padding-left:.625rem;padding-right:.625rem}tui-data-list[data-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-border-normal)}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,tui-opt-group:not(:empty)~tui-opt-group:not([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,tui-opt-group:not([data-label]):before{padding:0;margin:0}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "directive", type: PolymorpheusOutlet, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
57
57
|
}
|
|
58
58
|
__decorate([
|
|
59
59
|
tuiPure
|
|
@@ -63,7 +63,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
63
63
|
type: Component,
|
|
64
64
|
args: [{ standalone: true, selector: 'tui-data-list', imports: [NgIf, AsyncPipe, PolymorpheusOutlet], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [tuiAsDataListAccessor(TuiDataListComponent)], host: {
|
|
65
65
|
role: 'listbox',
|
|
66
|
-
}, template: "<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", 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-tertiary)}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-size=s]{--tui-data-list-margin: 0rem}tui-data-list[data-size=s]>.t-empty,tui-data-list[data-size=s] [tuiOption]{font:var(--tui-font-text-s);min-height:2rem;padding:.3125rem .5rem}tui-data-list[data-size=s]>.t-empty:before,tui-data-list[data-size=s] [tuiOption]:before{font-size:1rem}tui-data-list[data-size=m]>.t-empty,tui-data-list[data-size=m] [tuiOption]{font:var(--tui-font-text-s);min-height:2.5rem;padding:.375rem .5rem}tui-data-list[data-size=l]{--tui-data-list-padding: .375rem;--tui-data-list-margin: .125rem}tui-data-list[data-size=l]>.t-empty,tui-data-list[data-size=l] [tuiOption]{font:var(--tui-font-text-m);min-height:2.75rem;padding:.375rem .625rem}tui-data-list>.t-empty{display:flex;align-items:center;box-sizing:border-box;margin:var(--tui-data-list-margin) 0}tui-opt-group{position:relative;display:flex;font:var(--tui-font-text-xs);color:var(--tui-text-secondary);flex-direction:column;line-height:1rem}tui-data-list[data-size=l] tui-opt-group{font:var(--tui-font-text-s);line-height:1.25rem}tui-data-list[data-size=l] tui-opt-group:before{padding-left:.625rem;padding-right:.625rem}tui-data-list[data-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-border-normal)}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,tui-opt-group:not(:empty)~tui-opt-group:not([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,tui-opt-group:not([data-label]):before{padding:0;margin:0}
|
|
66
|
+
}, template: "<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", 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-tertiary)}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-size=s]{--tui-data-list-margin: 0rem}tui-data-list[data-size=s]>.t-empty,tui-data-list[data-size=s] [tuiOption]{font:var(--tui-font-text-s);min-height:2rem;padding:.3125rem .5rem}tui-data-list[data-size=s]>.t-empty:before,tui-data-list[data-size=s] [tuiOption]:before{font-size:1rem}tui-data-list[data-size=m]>.t-empty,tui-data-list[data-size=m] [tuiOption]{font:var(--tui-font-text-s);min-height:2.5rem;padding:.375rem .5rem}tui-data-list[data-size=l]{--tui-data-list-padding: .375rem;--tui-data-list-margin: .125rem}tui-data-list[data-size=l]>.t-empty,tui-data-list[data-size=l] [tuiOption]{font:var(--tui-font-text-m);min-height:2.75rem;padding:.375rem .625rem}tui-data-list>.t-empty{display:flex;align-items:center;box-sizing:border-box;margin:var(--tui-data-list-margin) 0}tui-data-list [tuiOption]{-webkit-appearance:none;appearance:none;padding:0;border:0;background:none;font-size:inherit;line-height:inherit;text-decoration:none;transition-property:background;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;display:flex;align-items:center;box-sizing:border-box;margin:var(--tui-data-list-margin) 0;justify-content:space-between;text-align:left;color:var(--tui-text-primary);border-radius:var(--tui-radius-s);outline:none;cursor:pointer;background-clip:padding-box}tui-data-list [tuiOption]:disabled{opacity:var(--tui-disabled-opacity);cursor:default}tui-data-list [tuiOption]:focus-within,tui-data-list [tuiOption]._with-dropdown{background-color:var(--tui-background-neutral-1)}tui-data-list [tuiOption]:before{margin-inline-end:.5rem}tui-data-list [tuiOption]:after{font-size:1rem;margin:0 -.75rem 0 auto;border-left:.5rem solid;border-right:.5rem solid}tui-opt-group{position:relative;display:flex;font:var(--tui-font-text-xs);color:var(--tui-text-secondary);flex-direction:column;line-height:1rem}tui-data-list[data-size=l] tui-opt-group{font:var(--tui-font-text-s);line-height:1.25rem}tui-data-list[data-size=l] tui-opt-group:before{padding-left:.625rem;padding-right:.625rem}tui-data-list[data-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-border-normal)}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,tui-opt-group:not(:empty)~tui-opt-group:not([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,tui-opt-group:not([data-label]):before{padding:0;margin:0}\n"] }]
|
|
67
67
|
}], propDecorators: { options: [{
|
|
68
68
|
type: ContentChildren,
|
|
69
69
|
args: [forwardRef(() => TuiOption), { descendants: true }]
|
|
@@ -99,4 +99,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
99
99
|
type: HostListener,
|
|
100
100
|
args: ['mousedown.prevent']
|
|
101
101
|
}] } });
|
|
102
|
-
//# 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 {AsyncPipe, NgIf} from '@angular/common';\nimport type {QueryList} from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    forwardRef,\n    HostBinding,\n    HostListener,\n    inject,\n    Input,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {EMPTY_QUERY} from '@taiga-ui/cdk/constants';\nimport {tuiQueryListChanges} from '@taiga-ui/cdk/observables';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiIsNativeFocusedIn, tuiMoveFocus} from '@taiga-ui/cdk/utils/focus';\nimport {tuiIsPresent, tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TUI_NOTHING_FOUND_MESSAGE} from '@taiga-ui/core/tokens';\nimport type {TuiSizeL, TuiSizeS} from '@taiga-ui/core/types';\nimport type {PolymorpheusContent} from '@taiga-ui/polymorpheus';\nimport {PolymorpheusOutlet} from '@taiga-ui/polymorpheus';\nimport type {Observable} from 'rxjs';\nimport {map} from 'rxjs';\n\nimport type {TuiDataListAccessor} from './data-list.tokens';\nimport {TUI_DATA_LIST_HOST, tuiAsDataListAccessor} from './data-list.tokens';\nimport {TuiOption} from './option.component';\n\nexport function tuiInjectDataListSize(): TuiSizeL | TuiSizeS {\n    const sizes = ['s', 'm', 'l'] as const;\n    const size = inject(TUI_DATA_LIST_HOST, {optional: true})?.size;\n\n    return size && sizes.includes(size) ? size : 'l';\n}\n\n// TODO: Consider aria-activedescendant for proper accessibility implementation\n@Component({\n    standalone: true,\n    selector: 'tui-data-list',\n    imports: [NgIf, AsyncPipe, PolymorpheusOutlet],\n    templateUrl: './data-list.template.html',\n    styleUrls: ['./data-list.style.less'],\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [tuiAsDataListAccessor(TuiDataListComponent)],\n    host: {\n        role: 'listbox',\n    },\n})\nexport class TuiDataListComponent<T> implements TuiDataListAccessor<T> {\n    @ContentChildren(forwardRef(() => TuiOption), {descendants: true})\n    private readonly options: QueryList<TuiOption<T>> = EMPTY_QUERY;\n\n    private origin?: HTMLElement;\n    private readonly el = tuiInjectElement();\n\n    protected readonly defaultEmptyContent$ = inject(TUI_NOTHING_FOUND_MESSAGE);\n\n    @Input()\n    public emptyContent: PolymorpheusContent;\n\n    @Input()\n    @HostBinding('attr.data-size')\n    public size = tuiInjectDataListSize();\n\n    @HostListener('keydown.arrowDown.prevent', ['$event.target', '1'])\n    @HostListener('keydown.arrowUp.prevent', ['$event.target', '-1'])\n    public onKeyDownArrow(current: HTMLElement, step: number): void {\n        const {elements} = this;\n\n        tuiMoveFocus(elements.indexOf(current), elements, step);\n    }\n\n    @HostListener('wheel.silent.passive')\n    @HostListener('mouseleave', ['$event.target'])\n    @HostListener('keydown.tab')\n    @HostListener('keydown.shift.tab')\n    public handleFocusLossIfNecessary(element: Element = this.el): void {\n        if (tuiIsNativeFocusedIn(element)) {\n            this.origin?.focus({preventScroll: true});\n        }\n    }\n\n    public getOptions(includeDisabled = false): readonly T[] {\n        return this.options\n            .filter(({disabled}) => includeDisabled || !disabled)\n            .map(({value}) => value)\n            .filter(tuiIsPresent);\n    }\n\n    @tuiPure\n    protected get empty$(): Observable<boolean> {\n        return tuiQueryListChanges(this.options).pipe(map(({length}) => !length));\n    }\n\n    @HostListener('focusin', ['$event.relatedTarget', '$event.currentTarget'])\n    protected 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    protected noop(): void {}\n\n    private get elements(): readonly HTMLElement[] {\n        return Array.from(\n            this.el.querySelectorAll('a[tuiOption],button[tuiOption],input'),\n        );\n    }\n}\n","<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"]}
|
|
102
|
+
//# 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 {AsyncPipe, NgIf} from '@angular/common';\nimport type {QueryList} from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    forwardRef,\n    HostBinding,\n    HostListener,\n    inject,\n    Input,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {EMPTY_QUERY} from '@taiga-ui/cdk/constants';\nimport {tuiQueryListChanges} from '@taiga-ui/cdk/observables';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiIsNativeFocusedIn, tuiMoveFocus} from '@taiga-ui/cdk/utils/focus';\nimport {tuiIsPresent, tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TUI_NOTHING_FOUND_MESSAGE} from '@taiga-ui/core/tokens';\nimport type {TuiSizeL, TuiSizeS} from '@taiga-ui/core/types';\nimport type {PolymorpheusContent} from '@taiga-ui/polymorpheus';\nimport {PolymorpheusOutlet} from '@taiga-ui/polymorpheus';\nimport type {Observable} from 'rxjs';\nimport {map} from 'rxjs';\n\nimport type {TuiDataListAccessor} from './data-list.tokens';\nimport {TUI_DATA_LIST_HOST, tuiAsDataListAccessor} from './data-list.tokens';\nimport {TuiOption} from './option.component';\n\nexport function tuiInjectDataListSize(): TuiSizeL | TuiSizeS {\n    const sizes = ['s', 'm', 'l'] as const;\n    const size = inject(TUI_DATA_LIST_HOST, {optional: true})?.size;\n\n    return size && sizes.includes(size) ? size : 'l';\n}\n\n// TODO: Consider aria-activedescendant for proper accessibility implementation\n@Component({\n    standalone: true,\n    selector: 'tui-data-list',\n    imports: [NgIf, AsyncPipe, PolymorpheusOutlet],\n    templateUrl: './data-list.template.html',\n    styleUrls: ['./data-list.style.less'],\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [tuiAsDataListAccessor(TuiDataListComponent)],\n    host: {\n        role: 'listbox',\n    },\n})\nexport class TuiDataListComponent<T> implements TuiDataListAccessor<T> {\n    @ContentChildren(forwardRef(() => TuiOption), {descendants: true})\n    private readonly options: QueryList<TuiOption<T>> = EMPTY_QUERY;\n\n    private origin?: HTMLElement;\n    private readonly el = tuiInjectElement();\n\n    protected readonly defaultEmptyContent$ = inject(TUI_NOTHING_FOUND_MESSAGE);\n\n    @Input()\n    public emptyContent: PolymorpheusContent;\n\n    @Input()\n    @HostBinding('attr.data-size')\n    public size = tuiInjectDataListSize();\n\n    @HostListener('keydown.arrowDown.prevent', ['$event.target', '1'])\n    @HostListener('keydown.arrowUp.prevent', ['$event.target', '-1'])\n    public onKeyDownArrow(current: HTMLElement, step: number): void {\n        const {elements} = this;\n\n        tuiMoveFocus(elements.indexOf(current), elements, step);\n    }\n\n    @HostListener('wheel.silent.passive')\n    @HostListener('mouseleave', ['$event.target'])\n    @HostListener('keydown.tab')\n    @HostListener('keydown.shift.tab')\n    public handleFocusLossIfNecessary(element: Element = this.el): void {\n        if (tuiIsNativeFocusedIn(element)) {\n            this.origin?.focus({preventScroll: true});\n        }\n    }\n\n    public getOptions(includeDisabled = false): readonly T[] {\n        return this.options\n            .filter(({disabled}) => includeDisabled || !disabled)\n            .map(({value}) => value)\n            .filter(tuiIsPresent);\n    }\n\n    @tuiPure\n    protected get empty$(): Observable<boolean> {\n        return tuiQueryListChanges(this.options).pipe(map(({length}) => !length));\n    }\n\n    @HostListener('focusin', ['$event.relatedTarget', '$event.currentTarget'])\n    protected 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    protected noop(): void {}\n\n    private get elements(): readonly HTMLElement[] {\n        return Array.from(\n            this.el.querySelectorAll('a[tuiOption],button[tuiOption],input'),\n        );\n    }\n}\n","<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"]}
|
|
@@ -38,7 +38,7 @@ class TuiOption {
|
|
|
38
38
|
}
|
|
39
39
|
}
|
|
40
40
|
onMouseMove() {
|
|
41
|
-
if (!this.isMobile && !tuiIsNativeFocused(this.el)) {
|
|
41
|
+
if (!this.isMobile && !tuiIsNativeFocused(this.el) && this.dataList) {
|
|
42
42
|
this.el.focus({ preventScroll: true });
|
|
43
43
|
}
|
|
44
44
|
}
|
|
@@ -83,4 +83,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
83
83
|
}], value: [{
|
|
84
84
|
type: Input
|
|
85
85
|
}] } });
|
|
86
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvY29tcG9uZW50cy9kYXRhLWxpc3Qvb3B0aW9uLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQ0gsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxVQUFVLEVBQ1YsTUFBTSxFQUNOLEtBQUssR0FDUixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFFbkQsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sMkJBQTJCLENBQUM7QUFDN0QsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sb0NBQW9DLENBQUM7QUFDeEUsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlDQUFpQyxDQUFDO0FBRTdELE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBRTFELE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLHVCQUF1QixDQUFDO0FBRTNELE9BQU8sRUFBQyxrQkFBa0IsRUFBRSxrQkFBa0IsRUFBQyxNQUFNLG9CQUFvQixDQUFDOzs7QUFFMUUsOENBQThDO0FBQzlDLE1BdUJhLFNBQVM7SUF2QnRCO1FBd0JxQixhQUFRLEdBQUcsTUFBTSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQ2pDLE9BQUUsR0FBRyxnQkFBZ0IsRUFBRSxDQUFDO1FBQ3hCLGFBQVEsR0FBRyxNQUFNLENBQzlCLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQyxFQUN0QyxFQUFDLFFBQVEsRUFBRSxJQUFJLEVBQUMsQ0FDbkIsQ0FBQztRQUVlLFNBQUksR0FBRyxNQUFNLENBQXFCLGtCQUFrQixFQUFFO1lBQ25FLFFBQVEsRUFBRSxJQUFJO1NBQ2pCLENBQUMsQ0FBQztRQUVnQixZQUFPLEdBRXRCLE1BQU0sQ0FBQyxrQkFBa0IsRUFBRSxFQUFDLFFBQVEsRUFBRSxJQUFJLEVBQUMsQ0FBQyxDQUFDO1FBRTlCLGFBQVEsR0FBRyxNQUFNLENBQUMsb0JBQW9CLEVBQUU7WUFDdkQsSUFBSSxFQUFFLElBQUk7WUFDVixRQUFRLEVBQUUsSUFBSTtTQUNqQixDQUFDLENBQUM7UUFHSSxhQUFRLEdBQUcsS0FBSyxDQUFDO0tBeUIzQjtJQXBCRyxvREFBb0Q7SUFDN0MsV0FBVztRQUNkLElBQUksQ0FBQyxRQUFRLEVBQUUsMEJBQTBCLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ3ZELENBQUM7SUFFRCxJQUFjLE1BQU07UUFDaEIsT0FBTyxDQUFDLENBQUMsSUFBSSxDQUFDLFFBQVEsSUFBSSxDQUFDLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxjQUFjLENBQUM7SUFDN0QsQ0FBQztJQUVTLE9BQU87UUFDYixJQUFJLElBQUksQ0FBQyxJQUFJLElBQUksSUFBSSxDQUFDLEtBQUssS0FBSyxTQUFTLEVBQUU7WUFDdkMsSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1NBQ3RDO0lBQ0wsQ0FBQztJQUVTLFdBQVc7UUFDakIsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNqRSxJQUFJLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxFQUFDLGFBQWEsRUFBRSxJQUFJLEVBQUMsQ0FBQyxDQUFDO1NBQ3hDO0lBQ0wsQ0FBQzsrR0E5Q1EsU0FBUzttR0FBVCxTQUFTLGdiQW5CUjs7Ozs7OztLQU9ULDREQVJTLGtCQUFrQjs7U0FvQm5CLFNBQVM7NEZBQVQsU0FBUztrQkF2QnJCLFNBQVM7bUJBQUM7b0JBQ1AsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSxtREFBbUQ7b0JBQzdELE9BQU8sRUFBRSxDQUFDLGtCQUFrQixDQUFDO29CQUM3QixRQUFRLEVBQUU7Ozs7Ozs7S0FPVDtvQkFDRCxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtvQkFDL0MsY0FBYyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUM5QixJQUFJLEVBQUU7d0JBQ0YsSUFBSSxFQUFFLFFBQVE7d0JBQ2QsSUFBSSxFQUFFLFFBQVE7d0JBQ2QsaUJBQWlCLEVBQUUsa0JBQWtCO3dCQUNyQyx3QkFBd0IsRUFBRSxRQUFRO3dCQUNsQyxTQUFTLEVBQUUsV0FBVzt3QkFDdEIsb0JBQW9CLEVBQUUsZUFBZTtxQkFDeEM7aUJBQ0o7OEJBdUJVLFFBQVE7c0JBRGQsS0FBSztnQkFJQyxLQUFLO3NCQURYLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7T25EZXN0cm95LCBUZW1wbGF0ZVJlZn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1xuICAgIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICAgIENvbXBvbmVudCxcbiAgICBmb3J3YXJkUmVmLFxuICAgIGluamVjdCxcbiAgICBJbnB1dCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1RVSV9JU19NT0JJTEV9IGZyb20gJ0B0YWlnYS11aS9jZGsvdG9rZW5zJztcbmltcG9ydCB0eXBlIHtUdWlDb250ZXh0fSBmcm9tICdAdGFpZ2EtdWkvY2RrL3R5cGVzJztcbmltcG9ydCB7dHVpSW5qZWN0RWxlbWVudH0gZnJvbSAnQHRhaWdhLXVpL2Nkay91dGlscy9kb20nO1xuaW1wb3J0IHt0dWlJc05hdGl2ZUZvY3VzZWR9IGZyb20gJ0B0YWlnYS11aS9jZGsvdXRpbHMvZm9jdXMnO1xuaW1wb3J0IHtUdWlEcm9wZG93bkRpcmVjdGl2ZX0gZnJvbSAnQHRhaWdhLXVpL2NvcmUvZGlyZWN0aXZlcy9kcm9wZG93bic7XG5pbXBvcnQge1R1aVdpdGhJY29uc30gZnJvbSAnQHRhaWdhLXVpL2NvcmUvZGlyZWN0aXZlcy9pY29ucyc7XG5pbXBvcnQgdHlwZSB7UG9seW1vcnBoZXVzQ29udGVudH0gZnJvbSAnQHRhaWdhLXVpL3BvbHltb3JwaGV1cyc7XG5pbXBvcnQge1BvbHltb3JwaGV1c091dGxldH0gZnJvbSAnQHRhaWdhLXVpL3BvbHltb3JwaGV1cyc7XG5cbmltcG9ydCB7VHVpRGF0YUxpc3RDb21wb25lbnR9IGZyb20gJy4vZGF0YS1saXN0LmNvbXBvbmVudCc7XG5pbXBvcnQgdHlwZSB7VHVpRGF0YUxpc3RIb3N0fSBmcm9tICcuL2RhdGEtbGlzdC50b2tlbnMnO1xuaW1wb3J0IHtUVUlfREFUQV9MSVNUX0hPU1QsIFRVSV9PUFRJT05fQ09OVEVOVH0gZnJvbSAnLi9kYXRhLWxpc3QudG9rZW5zJztcblxuLy8gVE9ETzogQ29uc2lkZXIgYWxsIHVzZSBjYXNlcyBmb3IgYXJpYSByb2xlc1xuQENvbXBvbmVudCh7XG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBzZWxlY3RvcjogJ2J1dHRvblt0dWlPcHRpb25dLCBhW3R1aU9wdGlvbl0sIGxhYmVsW3R1aU9wdGlvbl0nLFxuICAgIGltcG9ydHM6IFtQb2x5bW9ycGhldXNPdXRsZXRdLFxuICAgIHRlbXBsYXRlOiBgXG4gICAgICAgIDxuZy1jb250YWluZXIgKnBvbHltb3JwaGV1c091dGxldD1cImNvbnRlbnQgfHwgdCBhcyB0ZXh0OyBjb250ZXh0OiB7JGltcGxpY2l0OiB0fVwiPlxuICAgICAgICAgICAge3sgdGV4dCB9fVxuICAgICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICAgICAgPG5nLXRlbXBsYXRlICN0PlxuICAgICAgICAgICAgPG5nLWNvbnRlbnQgLz5cbiAgICAgICAgPC9uZy10ZW1wbGF0ZT5cbiAgICBgLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIGhvc3REaXJlY3RpdmVzOiBbVHVpV2l0aEljb25zXSxcbiAgICBob3N0OiB7XG4gICAgICAgIHR5cGU6ICdidXR0b24nLFxuICAgICAgICByb2xlOiAnb3B0aW9uJyxcbiAgICAgICAgJ1thdHRyLmRpc2FibGVkXSc6ICdkaXNhYmxlZCB8fCBudWxsJyxcbiAgICAgICAgJ1tjbGFzcy5fd2l0aC1kcm9wZG93bl0nOiAnYWN0aXZlJyxcbiAgICAgICAgJyhjbGljayknOiAnb25DbGljaygpJyxcbiAgICAgICAgJyhtb3VzZW1vdmUuc2lsZW50KSc6ICdvbk1vdXNlTW92ZSgpJyxcbiAgICB9LFxufSlcbmV4cG9ydCBjbGFzcyBUdWlPcHRpb248VCA9IHVua25vd24+IGltcGxlbWVudHMgT25EZXN0cm95IHtcbiAgICBwcml2YXRlIHJlYWRvbmx5IGlzTW9iaWxlID0gaW5qZWN0KFRVSV9JU19NT0JJTEUpO1xuICAgIHByaXZhdGUgcmVhZG9ubHkgZWwgPSB0dWlJbmplY3RFbGVtZW50KCk7XG4gICAgcHJpdmF0ZSByZWFkb25seSBkYXRhTGlzdCA9IGluamVjdDxUdWlEYXRhTGlzdENvbXBvbmVudDxUPj4oXG4gICAgICAgIGZvcndhcmRSZWYoKCkgPT4gVHVpRGF0YUxpc3RDb21wb25lbnQpLFxuICAgICAgICB7b3B0aW9uYWw6IHRydWV9LFxuICAgICk7XG5cbiAgICBwcml2YXRlIHJlYWRvbmx5IGhvc3QgPSBpbmplY3Q8VHVpRGF0YUxpc3RIb3N0PFQ+PihUVUlfREFUQV9MSVNUX0hPU1QsIHtcbiAgICAgICAgb3B0aW9uYWw6IHRydWUsXG4gICAgfSk7XG5cbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgY29udGVudDogUG9seW1vcnBoZXVzQ29udGVudDxcbiAgICAgICAgVHVpQ29udGV4dDxUZW1wbGF0ZVJlZjxSZWNvcmQ8c3RyaW5nLCB1bmtub3duPj4+XG4gICAgPiA9IGluamVjdChUVUlfT1BUSU9OX0NPTlRFTlQsIHtvcHRpb25hbDogdHJ1ZX0pO1xuXG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IGRyb3Bkb3duID0gaW5qZWN0KFR1aURyb3Bkb3duRGlyZWN0aXZlLCB7XG4gICAgICAgIHNlbGY6IHRydWUsXG4gICAgICAgIG9wdGlvbmFsOiB0cnVlLFxuICAgIH0pO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgZGlzYWJsZWQgPSBmYWxzZTtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIHZhbHVlPzogVDtcblxuICAgIC8vIFByZXZlbnRpbmcgZm9jdXMgbG9zcyB1cG9uIGZvY3VzZWQgb3B0aW9uIHJlbW92YWxcbiAgICBwdWJsaWMgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgICAgIHRoaXMuZGF0YUxpc3Q/LmhhbmRsZUZvY3VzTG9zc0lmTmVjZXNzYXJ5KHRoaXMuZWwpO1xuICAgIH1cblxuICAgIHByb3RlY3RlZCBnZXQgYWN0aXZlKCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gISF0aGlzLmRyb3Bkb3duICYmICEhdGhpcy5kcm9wZG93bi5kcm9wZG93bkJveFJlZjtcbiAgICB9XG5cbiAgICBwcm90ZWN0ZWQgb25DbGljaygpOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMuaG9zdCAmJiB0aGlzLnZhbHVlICE9PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICAgIHRoaXMuaG9zdC5oYW5kbGVPcHRpb24odGhpcy52YWx1ZSk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBwcm90ZWN0ZWQgb25Nb3VzZU1vdmUoKTogdm9pZCB7XG4gICAgICAgIGlmICghdGhpcy5pc01vYmlsZSAmJiAhdHVpSXNOYXRpdmVGb2N1c2VkKHRoaXMuZWwpICYmIHRoaXMuZGF0YUxpc3QpIHtcbiAgICAgICAgICAgIHRoaXMuZWwuZm9jdXMoe3ByZXZlbnRTY3JvbGw6IHRydWV9KTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiJdfQ==
|
|
@@ -27,7 +27,7 @@ class TuiRoot {
|
|
|
27
27
|
inject(DOCUMENT).defaultView?.document.documentElement.setAttribute('data-tui-theme', inject(TUI_THEME).toLowerCase());
|
|
28
28
|
}
|
|
29
29
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiRoot, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
30
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiRoot, isStandalone: true, selector: "tui-root", host: { attributes: { "data-tui-version": "4.0.0-rc.
|
|
30
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiRoot, isStandalone: true, selector: "tui-root", host: { attributes: { "data-tui-version": "4.0.0-rc.6" }, listeners: { "touchstart.passive.silent": "0" }, properties: { "style.--tui-duration.ms": "duration", "class._reduced-motion": "reducedMotion", "class._mobile": "isMobileRes()" } }, hostDirectives: [{ directive: i1.TuiPlatform }], ngImport: i0, template: "<tui-scroll-controls\n *ngIf=\"scrollbars$ | async\"\n class=\"t-root-scrollbar\"\n/>\n<tui-dropdowns>\n <div class=\"t-root-content\">\n <ng-content />\n </div>\n <ng-content select=\"tuiOverContent\" />\n <tui-dialogs />\n <ng-content select=\"tuiOverDialogs\" />\n <tui-alerts />\n <ng-content select=\"tuiOverAlerts\" />\n</tui-dropdowns>\n<ng-content select=\"tuiOverDropdowns\" />\n<tui-hints />\n<ng-content select=\"tuiOverHints\" />\n", styles: ["@keyframes tuiPresent{to{content:\"\"}}@keyframes tuiSkeletonVibe{to{opacity:.5}}html[data-tui-theme],.tui-zero-scrollbar{scrollbar-width:none;-ms-overflow-style:none}html[data-tui-theme]::-webkit-scrollbar,.tui-zero-scrollbar::-webkit-scrollbar,html[data-tui-theme]::-webkit-scrollbar-thumb,.tui-zero-scrollbar::-webkit-scrollbar-thumb{display:none}body,input{margin:0}tui-root{position:relative;display:block;font:var(--tui-font-text-s);color:var(--tui-text-primary);flex:1;-webkit-tap-highlight-color:transparent}tui-root:before{position:fixed;top:0;left:0;width:100%;height:100%;content:\"\";background:var(--tui-background-base)}tui-root>.t-root-scrollbar{position:fixed;top:0;left:0;bottom:0;right:0;display:none;margin:0}[data-tui-theme] tui-root>.t-root-scrollbar{display:block}.t-root-content{position:relative;top:var(--t-root-top);height:100%;isolation:isolate}.t-root-content>*{--t-root-top: 0}[tuiDropdownButton][tuiDropdownButton]{display:none}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "component", type: TuiDropdowns, selector: "tui-dropdowns" }, { kind: "component", type: TuiDialogs, selector: "tui-dialogs" }, { kind: "component", type: TuiAlerts, selector: "tui-alerts" }, { kind: "component", type: TuiHints, selector: "tui-hints" }, { kind: "component", type: TuiScrollControls, selector: "tui-scroll-controls" }], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None }); }
|
|
31
31
|
}
|
|
32
32
|
export { TuiRoot };
|
|
33
33
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiRoot, decorators: [{
|
|
@@ -47,6 +47,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
47
47
|
'[class._mobile]': 'isMobileRes()',
|
|
48
48
|
// Required for the :active state to work in Safari. https://stackoverflow.com/a/33681490
|
|
49
49
|
'(touchstart.passive.silent)': '0',
|
|
50
|
-
}, template: "<tui-scroll-controls\n *ngIf=\"scrollbars$ | async\"\n class=\"t-root-scrollbar\"\n/>\n<tui-dropdowns>\n <div class=\"t-root-content\">\n <ng-content />\n </div>\n <ng-content select=\"tuiOverContent\" />\n <tui-dialogs />\n <ng-content select=\"tuiOverDialogs\" />\n <tui-alerts />\n <ng-content select=\"tuiOverAlerts\" />\n</tui-dropdowns>\n<ng-content select=\"tuiOverDropdowns\" />\n<tui-hints />\n<ng-content select=\"tuiOverHints\" />\n", styles: ["@keyframes tuiPresent{to{content:\"\"}}@keyframes tuiSkeletonVibe{to{opacity:.5}}html[data-tui-theme],.tui-zero-scrollbar{scrollbar-width:none;-ms-overflow-style:none}html[data-tui-theme]::-webkit-scrollbar,.tui-zero-scrollbar::-webkit-scrollbar,html[data-tui-theme]::-webkit-scrollbar-thumb,.tui-zero-scrollbar::-webkit-scrollbar-thumb{display:none}body,input{margin:0}tui-root{position:relative;display:block;font:var(--tui-font-text-s);color:var(--tui-text-primary);flex:1;-webkit-tap-highlight-color:transparent}tui-root:before{position:fixed;top:0;left:0;width:100%;height:100%;content:\"\";background:var(--tui-background-base)}tui-root>.t-root-scrollbar{position:fixed;top:0;left:0;bottom:0;right:0;display:none;margin:0}[data-tui-theme] tui-root>.t-root-scrollbar{display:block}.t-root-content{height:100%;isolation:isolate
|
|
50
|
+
}, template: "<tui-scroll-controls\n *ngIf=\"scrollbars$ | async\"\n class=\"t-root-scrollbar\"\n/>\n<tui-dropdowns>\n <div class=\"t-root-content\">\n <ng-content />\n </div>\n <ng-content select=\"tuiOverContent\" />\n <tui-dialogs />\n <ng-content select=\"tuiOverDialogs\" />\n <tui-alerts />\n <ng-content select=\"tuiOverAlerts\" />\n</tui-dropdowns>\n<ng-content select=\"tuiOverDropdowns\" />\n<tui-hints />\n<ng-content select=\"tuiOverHints\" />\n", styles: ["@keyframes tuiPresent{to{content:\"\"}}@keyframes tuiSkeletonVibe{to{opacity:.5}}html[data-tui-theme],.tui-zero-scrollbar{scrollbar-width:none;-ms-overflow-style:none}html[data-tui-theme]::-webkit-scrollbar,.tui-zero-scrollbar::-webkit-scrollbar,html[data-tui-theme]::-webkit-scrollbar-thumb,.tui-zero-scrollbar::-webkit-scrollbar-thumb{display:none}body,input{margin:0}tui-root{position:relative;display:block;font:var(--tui-font-text-s);color:var(--tui-text-primary);flex:1;-webkit-tap-highlight-color:transparent}tui-root:before{position:fixed;top:0;left:0;width:100%;height:100%;content:\"\";background:var(--tui-background-base)}tui-root>.t-root-scrollbar{position:fixed;top:0;left:0;bottom:0;right:0;display:none;margin:0}[data-tui-theme] tui-root>.t-root-scrollbar{display:block}.t-root-content{position:relative;top:var(--t-root-top);height:100%;isolation:isolate}.t-root-content>*{--t-root-top: 0}[tuiDropdownButton][tuiDropdownButton]{display:none}\n"] }]
|
|
51
51
|
}], ctorParameters: function () { return []; } });
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm9vdC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvcm9vdC9yb290LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvY29tcG9uZW50cy9yb290L3Jvb3QudGVtcGxhdGUuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUMxRCxPQUFPLEVBQ0gsdUJBQXVCLEVBQ3ZCLGlCQUFpQixFQUNqQixTQUFTLEVBQ1QsTUFBTSxFQUNOLGlCQUFpQixHQUNwQixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sNEJBQTRCLENBQUM7QUFDcEQsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ3BELE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQUM5RCxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sMkJBQTJCLENBQUM7QUFDbkQsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHNCQUFzQixDQUFDO0FBQ25ELE9BQU8sRUFBQyxTQUFTLEVBQUMsTUFBTSxpQ0FBaUMsQ0FBQztBQUMxRCxPQUFPLEVBQUMsV0FBVyxFQUFFLFVBQVUsRUFBQyxNQUFNLGtDQUFrQyxDQUFDO0FBQ3pFLE9BQU8sRUFBQyxpQkFBaUIsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQ3RFLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSwyQkFBMkIsQ0FBQztBQUN2RCxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZ0NBQWdDLENBQUM7QUFDeEQsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFDN0QsT0FBTyxFQUFDLG9CQUFvQixFQUFFLGtCQUFrQixFQUFFLFNBQVMsRUFBQyxNQUFNLHVCQUF1QixDQUFDO0FBQzFGLE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUVwRCxPQUFPLEVBQUMsWUFBWSxFQUFFLEdBQUcsRUFBRSxFQUFFLEVBQUMsTUFBTSxNQUFNLENBQUM7OztBQUUzQyxNQTJCYSxPQUFPO0lBa0JoQjtRQWpCbUIsa0JBQWEsR0FBRyxNQUFNLENBQUMsa0JBQWtCLENBQUMsQ0FBQztRQUMzQyxhQUFRLEdBQUcsY0FBYyxDQUFDLE1BQU0sQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDLENBQUM7UUFFeEQsZ0JBQVcsR0FBRyxRQUFRLENBQ3JDLE1BQU0sQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDLElBQUksQ0FDN0IsR0FBRyxDQUFDLENBQUMsVUFBVSxFQUFFLEVBQUUsQ0FBQyxVQUFVLEtBQUssUUFBUSxDQUFDLEVBQzVDLFFBQVEsQ0FBQyxNQUFNLENBQUMsaUJBQWlCLENBQUMsQ0FBQyxDQUN0QyxDQUNKLENBQUM7UUFFaUIsZ0JBQVcsR0FBd0IsTUFBTSxDQUFDLGFBQWEsQ0FBQztZQUN2RSxDQUFDLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQztZQUNYLENBQUMsQ0FBQyxNQUFNLENBQWlDLFdBQVcsQ0FBQyxDQUFDLElBQUksQ0FDcEQsR0FBRyxDQUFDLENBQUMsRUFBQyxNQUFNLEVBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxNQUFNLENBQUMsRUFDMUIsWUFBWSxDQUFDLENBQUMsQ0FBQyxDQUNsQixDQUFDO1FBR0osTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDLFdBQVcsRUFBRSxRQUFRLENBQUMsZUFBZSxDQUFDLFlBQVksQ0FDL0QsZ0JBQWdCLEVBQ2hCLE1BQU0sQ0FBQyxTQUFTLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FDbEMsQ0FBQztJQUNOLENBQUM7K0dBdkJRLE9BQU87bUdBQVAsT0FBTyxxV0NuRHBCLCtkQWlCQSwwL0JEV1EsSUFBSSx3RkFDSixTQUFTLDhDQUNULFlBQVksMERBQ1osVUFBVSx3REFDVixTQUFTLHVEQUNULFFBQVEsc0RBQ1IsaUJBQWlCOztTQWlCWixPQUFPOzRGQUFQLE9BQU87a0JBM0JuQixTQUFTO2lDQUNNLElBQUksWUFDTixVQUFVLFdBQ1g7d0JBQ0wsSUFBSTt3QkFDSixTQUFTO3dCQUNULFlBQVk7d0JBQ1osVUFBVTt3QkFDVixTQUFTO3dCQUNULFFBQVE7d0JBQ1IsaUJBQWlCO3FCQUNwQixpQkFHYyxpQkFBaUIsQ0FBQyxJQUFJLG1CQUVwQix1QkFBdUIsQ0FBQyxPQUFPLGtCQUNoQyxDQUFDLFdBQVcsQ0FBQyxRQUN2Qjt3QkFDRixrQkFBa0IsRUFBRSxXQUFXO3dCQUMvQiwyQkFBMkIsRUFBRSxVQUFVO3dCQUN2Qyx5QkFBeUIsRUFBRSxlQUFlO3dCQUMxQyxpQkFBaUIsRUFBRSxlQUFlO3dCQUNsQyx5RkFBeUY7d0JBQ3pGLDZCQUE2QixFQUFFLEdBQUc7cUJBQ3JDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtBc3luY1BpcGUsIERPQ1VNRU5ULCBOZ0lmfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtcbiAgICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgICBDaGFuZ2VEZXRlY3RvclJlZixcbiAgICBDb21wb25lbnQsXG4gICAgaW5qZWN0LFxuICAgIFZpZXdFbmNhcHN1bGF0aW9uLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7dG9TaWduYWx9IGZyb20gJ0Bhbmd1bGFyL2NvcmUvcnhqcy1pbnRlcm9wJztcbmltcG9ydCB7VFVJX1ZFUlNJT059IGZyb20gJ0B0YWlnYS11aS9jZGsvY29uc3RhbnRzJztcbmltcG9ydCB7VHVpUGxhdGZvcm19IGZyb20gJ0B0YWlnYS11aS9jZGsvZGlyZWN0aXZlcy9wbGF0Zm9ybSc7XG5pbXBvcnQge3R1aVdhdGNofSBmcm9tICdAdGFpZ2EtdWkvY2RrL29ic2VydmFibGVzJztcbmltcG9ydCB7VFVJX0lTX01PQklMRX0gZnJvbSAnQHRhaWdhLXVpL2Nkay90b2tlbnMnO1xuaW1wb3J0IHtUdWlBbGVydHN9IGZyb20gJ0B0YWlnYS11aS9jb3JlL2NvbXBvbmVudHMvYWxlcnQnO1xuaW1wb3J0IHtUVUlfRElBTE9HUywgVHVpRGlhbG9nc30gZnJvbSAnQHRhaWdhLXVpL2NvcmUvY29tcG9uZW50cy9kaWFsb2cnO1xuaW1wb3J0IHtUdWlTY3JvbGxDb250cm9sc30gZnJvbSAnQHRhaWdhLXVpL2NvcmUvY29tcG9uZW50cy9zY3JvbGxiYXInO1xuaW1wb3J0IHtUdWlEcm9wZG93bnN9IGZyb20gJ0B0YWlnYS11aS9jb3JlL2RpcmVjdGl2ZXMnO1xuaW1wb3J0IHtUdWlIaW50c30gZnJvbSAnQHRhaWdhLXVpL2NvcmUvZGlyZWN0aXZlcy9oaW50JztcbmltcG9ydCB7VHVpQnJlYWtwb2ludFNlcnZpY2V9IGZyb20gJ0B0YWlnYS11aS9jb3JlL3NlcnZpY2VzJztcbmltcG9ydCB7VFVJX0FOSU1BVElPTlNfU1BFRUQsIFRVSV9SRURVQ0VEX01PVElPTiwgVFVJX1RIRU1FfSBmcm9tICdAdGFpZ2EtdWkvY29yZS90b2tlbnMnO1xuaW1wb3J0IHt0dWlHZXREdXJhdGlvbn0gZnJvbSAnQHRhaWdhLXVpL2NvcmUvdXRpbHMnO1xuaW1wb3J0IHR5cGUge09ic2VydmFibGV9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHtkZWJvdW5jZVRpbWUsIG1hcCwgb2Z9IGZyb20gJ3J4anMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIHNlbGVjdG9yOiAndHVpLXJvb3QnLFxuICAgIGltcG9ydHM6IFtcbiAgICAgICAgTmdJZixcbiAgICAgICAgQXN5bmNQaXBlLFxuICAgICAgICBUdWlEcm9wZG93bnMsXG4gICAgICAgIFR1aURpYWxvZ3MsXG4gICAgICAgIFR1aUFsZXJ0cyxcbiAgICAgICAgVHVpSGludHMsXG4gICAgICAgIFR1aVNjcm9sbENvbnRyb2xzLFxuICAgIF0sXG4gICAgdGVtcGxhdGVVcmw6ICcuL3Jvb3QudGVtcGxhdGUuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vcm9vdC5zdHlsZS5sZXNzJ10sXG4gICAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQGFuZ3VsYXItZXNsaW50L3ByZWZlci1vbi1wdXNoLWNvbXBvbmVudC1jaGFuZ2UtZGV0ZWN0aW9uXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5EZWZhdWx0LFxuICAgIGhvc3REaXJlY3RpdmVzOiBbVHVpUGxhdGZvcm1dLFxuICAgIGhvc3Q6IHtcbiAgICAgICAgJ2RhdGEtdHVpLXZlcnNpb24nOiBUVUlfVkVSU0lPTixcbiAgICAgICAgJ1tzdHlsZS4tLXR1aS1kdXJhdGlvbi5tc10nOiAnZHVyYXRpb24nLFxuICAgICAgICAnW2NsYXNzLl9yZWR1Y2VkLW1vdGlvbl0nOiAncmVkdWNlZE1vdGlvbicsXG4gICAgICAgICdbY2xhc3MuX21vYmlsZV0nOiAnaXNNb2JpbGVSZXMoKScsXG4gICAgICAgIC8vIFJlcXVpcmVkIGZvciB0aGUgOmFjdGl2ZSBzdGF0ZSB0byB3b3JrIGluIFNhZmFyaS4gaHR0cHM6Ly9zdGFja292ZXJmbG93LmNvbS9hLzMzNjgxNDkwXG4gICAgICAgICcodG91Y2hzdGFydC5wYXNzaXZlLnNpbGVudCknOiAnMCcsXG4gICAgfSxcbn0pXG5leHBvcnQgY2xhc3MgVHVpUm9vdCB7XG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IHJlZHVjZWRNb3Rpb24gPSBpbmplY3QoVFVJX1JFRFVDRURfTU9USU9OKTtcbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgZHVyYXRpb24gPSB0dWlHZXREdXJhdGlvbihpbmplY3QoVFVJX0FOSU1BVElPTlNfU1BFRUQpKTtcblxuICAgIHByb3RlY3RlZCByZWFkb25seSBpc01vYmlsZVJlcyA9IHRvU2lnbmFsKFxuICAgICAgICBpbmplY3QoVHVpQnJlYWtwb2ludFNlcnZpY2UpLnBpcGUoXG4gICAgICAgICAgICBtYXAoKGJyZWFrcG9pbnQpID0+IGJyZWFrcG9pbnQgPT09ICdtb2JpbGUnKSxcbiAgICAgICAgICAgIHR1aVdhdGNoKGluamVjdChDaGFuZ2VEZXRlY3RvclJlZikpLFxuICAgICAgICApLFxuICAgICk7XG5cbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgc2Nyb2xsYmFycyQ6IE9ic2VydmFibGU8Ym9vbGVhbj4gPSBpbmplY3QoVFVJX0lTX01PQklMRSlcbiAgICAgICAgPyBvZihmYWxzZSlcbiAgICAgICAgOiBpbmplY3Q8T2JzZXJ2YWJsZTxyZWFkb25seSB1bmtub3duW10+PihUVUlfRElBTE9HUykucGlwZShcbiAgICAgICAgICAgICAgbWFwKCh7bGVuZ3RofSkgPT4gIWxlbmd0aCksXG4gICAgICAgICAgICAgIGRlYm91bmNlVGltZSgwKSxcbiAgICAgICAgICApO1xuXG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIGluamVjdChET0NVTUVOVCkuZGVmYXVsdFZpZXc/LmRvY3VtZW50LmRvY3VtZW50RWxlbWVudC5zZXRBdHRyaWJ1dGUoXG4gICAgICAgICAgICAnZGF0YS10dWktdGhlbWUnLFxuICAgICAgICAgICAgaW5qZWN0KFRVSV9USEVNRSkudG9Mb3dlckNhc2UoKSxcbiAgICAgICAgKTtcbiAgICB9XG59XG4iLCI8dHVpLXNjcm9sbC1jb250cm9sc1xuICAgICpuZ0lmPVwic2Nyb2xsYmFycyQgfCBhc3luY1wiXG4gICAgY2xhc3M9XCJ0LXJvb3Qtc2Nyb2xsYmFyXCJcbi8+XG48dHVpLWRyb3Bkb3ducz5cbiAgICA8ZGl2IGNsYXNzPVwidC1yb290LWNvbnRlbnRcIj5cbiAgICAgICAgPG5nLWNvbnRlbnQgLz5cbiAgICA8L2Rpdj5cbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJ0dWlPdmVyQ29udGVudFwiIC8+XG4gICAgPHR1aS1kaWFsb2dzIC8+XG4gICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwidHVpT3ZlckRpYWxvZ3NcIiAvPlxuICAgIDx0dWktYWxlcnRzIC8+XG4gICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwidHVpT3ZlckFsZXJ0c1wiIC8+XG48L3R1aS1kcm9wZG93bnM+XG48bmctY29udGVudCBzZWxlY3Q9XCJ0dWlPdmVyRHJvcGRvd25zXCIgLz5cbjx0dWktaGludHMgLz5cbjxuZy1jb250ZW50IHNlbGVjdD1cInR1aU92ZXJIaW50c1wiIC8+XG4iXX0=
|
|
@@ -13,7 +13,7 @@ import { TuiWithIcons } from '@taiga-ui/core/directives/icons';
|
|
|
13
13
|
import { TUI_COMMON_ICONS } from '@taiga-ui/core/tokens';
|
|
14
14
|
import { PolymorpheusOutlet } from '@taiga-ui/polymorpheus';
|
|
15
15
|
import { TuiTextfieldDirective } from './textfield.directive';
|
|
16
|
-
import { TUI_TEXTFIELD_OPTIONS
|
|
16
|
+
import { TUI_TEXTFIELD_OPTIONS } from './textfield.options';
|
|
17
17
|
import { TuiWithTextfieldDropdown } from './textfield-dropdown.directive';
|
|
18
18
|
import * as i0 from "@angular/core";
|
|
19
19
|
import * as i1 from "@taiga-ui/cdk/directives/native-validator";
|
|
@@ -25,8 +25,6 @@ class TuiTextfieldComponent {
|
|
|
25
25
|
this.open = tuiDropdownOpen();
|
|
26
26
|
this.focusedIn = tuiFocusedIn(tuiInjectElement());
|
|
27
27
|
this.side = 0;
|
|
28
|
-
this.change$ = inject(TuiTextfieldOptionsDirective, { optional: true })
|
|
29
|
-
?.change$;
|
|
30
28
|
this.options = inject(TUI_TEXTFIELD_OPTIONS);
|
|
31
29
|
this.icons = inject(TUI_COMMON_ICONS);
|
|
32
30
|
this.filler = '';
|
|
@@ -57,7 +55,7 @@ class TuiTextfieldComponent {
|
|
|
57
55
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiTextfieldComponent, isStandalone: true, selector: "tui-textfield", inputs: { filler: "filler", stringify: "stringify", content: "content" }, host: { properties: { "style.--t-side.px": "side", "attr.data-size": "options.size()", "class._with-label": "hasLabel", "class._disabled": "el?.nativeElement.disabled" } }, providers: [
|
|
58
56
|
tuiAsDataListHost(TuiTextfieldComponent),
|
|
59
57
|
tuiDropdownOptionsProvider({ limitWidth: 'fixed' }),
|
|
60
|
-
], queries: [{ propertyName: "directive", first: true, predicate: i0.forwardRef(function () { return TuiTextfieldDirective; }), descendants: true }, { propertyName: "label", first: true, predicate: i0.forwardRef(function () { return TuiLabel; }), descendants: true, read: ElementRef }, { propertyName: "control", first: true, predicate: NgControl, descendants: true }, { propertyName: "el", first: true, predicate: i0.forwardRef(function () { return TuiTextfieldDirective; }), descendants: true, read: ElementRef }], hostDirectives: [{ directive: i1.TuiNativeValidator }, { directive: i2.TuiDropdownDirective }, { directive: i2.TuiWithDropdownOpen }, { directive: i3.TuiWithTextfieldDropdown }, { directive: i4.TuiWithIcons }], ngImport: i0, template: "<ng-
|
|
58
|
+
], queries: [{ propertyName: "directive", first: true, predicate: i0.forwardRef(function () { return TuiTextfieldDirective; }), descendants: true }, { propertyName: "label", first: true, predicate: i0.forwardRef(function () { return TuiLabel; }), descendants: true, read: ElementRef }, { propertyName: "control", first: true, predicate: NgControl, descendants: true }, { propertyName: "el", first: true, predicate: i0.forwardRef(function () { return TuiTextfieldDirective; }), descendants: true, read: ElementRef }], hostDirectives: [{ directive: i1.TuiNativeValidator }, { directive: i2.TuiDropdownDirective }, { directive: i2.TuiWithDropdownOpen }, { directive: i3.TuiWithTextfieldDropdown }, { directive: i4.TuiWithIcons }], ngImport: i0, template: "<ng-content select=\"input\" />\n<ng-content select=\"select\" />\n<ng-content select=\"label\" />\n<span\n class=\"t-content\"\n (waResizeObserver)=\"side = $event[0].contentRect.width\"\n>\n <ng-content />\n <button\n *ngIf=\"options.cleaner()\"\n appearance=\"icon\"\n size=\"xs\"\n tabindex=\"-1\"\n tuiIconButton\n class=\"t-clear\"\n [iconStart]=\"icons.close\"\n (click)=\"directive?.setValue('')\"\n (pointerdown.silent.prevent)=\"el?.nativeElement?.focus()\"\n ></button>\n <ng-content select=\"tui-icon\" />\n</span>\n<span class=\"t-template\">\n <ng-container *polymorpheusOutlet=\"content as text; context: {$implicit: control?.value}\">\n {{ text }}\n </ng-container>\n</span>\n<input\n *ngIf=\"showFiller\"\n aria-hidden=\"true\"\n disabled\n class=\"t-filler\"\n [value]=\"computedFiller\"\n/>\n", styles: [":host{transition-property:color;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;--t-left: 0rem;--t-right: 0rem;position:relative;display:flex;align-items:center;pointer-events:none;cursor:pointer;height:var(--t-height);color:var(--tui-text-tertiary)}:host[data-size=s]{--t-height: var(--tui-height-s);padding:0 var(--tui-padding-s);border-radius:var(--tui-radius-m);font:var(--tui-font-text-s)}:host[data-size=s]._icon-start{--t-left: 1.25rem}:host[data-size=s]._icon-end{--t-right: 1.25rem}:host[data-size=s]:before{margin-inline-start:-.25rem;margin-inline-end:.5rem;font-size:1rem}:host[data-size=s]:after{margin-inline-end:-.175rem;margin-inline-start:.25rem;font-size:1rem}:host[data-size=s] ::ng-deep [tuiTextfield]{font:var(--tui-font-text-s)}:host[data-size=s] .t-content{gap:0}:host[data-size=m]{--t-height: var(--tui-height-m);padding:0 var(--tui-padding-m);border-radius:var(--tui-radius-m);font:var(--tui-font-text-s)}:host[data-size=m]._icon-start{--t-left: 1.75rem}:host[data-size=m]._icon-end{--t-right: 1.75rem}:host[data-size=m]:before{margin-inline-start:-.125rem;margin-inline-end:.375rem}:host[data-size=m]:after{margin-inline-start:.375rem;margin-inline-end:-.125rem}:host[data-size=m] ::ng-deep [tuiTextfield]{font:var(--tui-font-text-s)}:host[data-size=l]{--t-height: var(--tui-height-l);padding:0 var(--tui-padding-l);border-radius:var(--tui-radius-l);font:var(--tui-font-text-m)}:host[data-size=l]._icon-start{--t-left: 2.25rem}:host[data-size=l]._icon-end{--t-right: 2.25rem}:host[data-size=l]:before{margin-inline-end:.75rem}:host[data-size=l]:after{margin-inline-start:.25rem}:host[data-size=l] ::ng-deep [tuiTextfield]{font:var(--tui-font-text-m)}:host:hover{color:var(--tui-text-secondary)}:host:before{z-index:1}:host._disabled:before,:host._disabled:after,:host._disabled .t-template{opacity:var(--tui-disabled-opacity)}:host._with-label .t-template,:host._with-label ::ng-deep [tuiTextfield]{padding-top:calc(var(--t-height) / 3)}:host._with-label .t-template::placeholder,:host._with-label ::ng-deep [tuiTextfield]::placeholder,:host._with-label .t-template._empty,:host._with-label ::ng-deep [tuiTextfield]._empty{color:transparent}:host .t-template,:host ::ng-deep [tuiTextfield]{position:absolute;top:0;left:0;width:100%;height:100%;-webkit-appearance:none;appearance:none;box-sizing:border-box;border:none;border-inline-start:var(--t-left) solid transparent!important;border-inline-end:calc(var(--t-right) + var(--t-side)) solid transparent!important;border-radius:inherit;padding:inherit}:host ::ng-deep [tuiTextfield]{pointer-events:auto;background:transparent no-repeat center right 1rem / 2rem;background-clip:border-box,padding-box}:host ::ng-deep [tuiTextfield]:read-only~.t-filler{display:none}:host ::ng-deep [tuiTextfield]:disabled~label,:host ::ng-deep [tuiTextfield]:disabled~.t-content{opacity:var(--tui-disabled-opacity)}:host ::ng-deep [tuiTextfield]:disabled~label [tuiTooltip],:host ::ng-deep [tuiTextfield]:disabled~.t-content [tuiTooltip]{display:none}:host ::ng-deep [tuiTextfield]:not(._empty)~label{font-size:.83em;transform:translateY(-.7em)}:host ::ng-deep [tuiTextfield]:not(._empty):not(:disabled)[data-mode=invalid]~label,:host ::ng-deep [tuiTextfield]:not(._empty):invalid:not(:disabled):not([data-mode])~label{color:var(--tui-text-negative)}:host ::ng-deep [tuiTextfield]:not(._empty):not(:disabled):not([data-mode=readonly])~.t-content .t-clear{display:flex}:host ::ng-deep [tuiTextfield]:not([data-mode=readonly]):focus-visible:not([data-focus=false])::placeholder,:host ::ng-deep [tuiTextfield]:not([data-mode=readonly]):focus-visible:not([data-focus=false])._empty{color:var(--tui-text-tertiary)}:host ::ng-deep [tuiTextfield]:not([data-mode=readonly]):focus-visible:not([data-focus=false])~label{color:var(--tui-text-primary)!important;font-size:.83em;transform:translateY(-.7em)}:host ::ng-deep [tuiTextfield]:not([data-mode=readonly])[data-focus=true]::placeholder,:host ::ng-deep [tuiTextfield]:not([data-mode=readonly])[data-focus=true]._empty{color:var(--tui-text-tertiary)}:host ::ng-deep [tuiTextfield]:not([data-mode=readonly])[data-focus=true]~label{color:var(--tui-text-primary)!important;font-size:.83em;transform:translateY(-.7em)}:host ::ng-deep label{transition-property:all;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;position:relative;display:block;flex:1;font-size:inherit}:host ::ng-deep label,:host ::ng-deep input::placeholder,:host ::ng-deep select._empty{color:var(--tui-text-secondary)}:host ::ng-deep select:not([data-mode=readonly]){cursor:pointer}@supports (-webkit-touch-callout: none){:host ::ng-deep [tuiTextfield]:active{font-size:1rem}:host ::ng-deep [tuiTextfield]._ios-fix{position:fixed;left:1000rem}}.t-content{display:flex;align-items:center;gap:.25rem;margin-inline-start:auto}.t-clear{display:none;pointer-events:auto}.t-filler{pointer-events:none;background:none;color:var(--tui-text-tertiary);opacity:1}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: ResizeObserverDirective, selector: "[waResizeObserver]", inputs: ["box"], outputs: ["waResizeObserver"] }, { kind: "directive", type: TuiButton, selector: "a[tuiButton],button[tuiButton],a[tuiIconButton],button[tuiIconButton]", inputs: ["size"] }, { kind: "directive", type: PolymorpheusOutlet, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
61
59
|
}
|
|
62
60
|
export { TuiTextfieldComponent };
|
|
63
61
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiTextfieldComponent, decorators: [{
|
|
@@ -76,7 +74,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
76
74
|
'[attr.data-size]': 'options.size()',
|
|
77
75
|
'[class._with-label]': 'hasLabel',
|
|
78
76
|
'[class._disabled]': 'el?.nativeElement.disabled',
|
|
79
|
-
}, template: "<ng-
|
|
77
|
+
}, template: "<ng-content select=\"input\" />\n<ng-content select=\"select\" />\n<ng-content select=\"label\" />\n<span\n class=\"t-content\"\n (waResizeObserver)=\"side = $event[0].contentRect.width\"\n>\n <ng-content />\n <button\n *ngIf=\"options.cleaner()\"\n appearance=\"icon\"\n size=\"xs\"\n tabindex=\"-1\"\n tuiIconButton\n class=\"t-clear\"\n [iconStart]=\"icons.close\"\n (click)=\"directive?.setValue('')\"\n (pointerdown.silent.prevent)=\"el?.nativeElement?.focus()\"\n ></button>\n <ng-content select=\"tui-icon\" />\n</span>\n<span class=\"t-template\">\n <ng-container *polymorpheusOutlet=\"content as text; context: {$implicit: control?.value}\">\n {{ text }}\n </ng-container>\n</span>\n<input\n *ngIf=\"showFiller\"\n aria-hidden=\"true\"\n disabled\n class=\"t-filler\"\n [value]=\"computedFiller\"\n/>\n", styles: [":host{transition-property:color;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;--t-left: 0rem;--t-right: 0rem;position:relative;display:flex;align-items:center;pointer-events:none;cursor:pointer;height:var(--t-height);color:var(--tui-text-tertiary)}:host[data-size=s]{--t-height: var(--tui-height-s);padding:0 var(--tui-padding-s);border-radius:var(--tui-radius-m);font:var(--tui-font-text-s)}:host[data-size=s]._icon-start{--t-left: 1.25rem}:host[data-size=s]._icon-end{--t-right: 1.25rem}:host[data-size=s]:before{margin-inline-start:-.25rem;margin-inline-end:.5rem;font-size:1rem}:host[data-size=s]:after{margin-inline-end:-.175rem;margin-inline-start:.25rem;font-size:1rem}:host[data-size=s] ::ng-deep [tuiTextfield]{font:var(--tui-font-text-s)}:host[data-size=s] .t-content{gap:0}:host[data-size=m]{--t-height: var(--tui-height-m);padding:0 var(--tui-padding-m);border-radius:var(--tui-radius-m);font:var(--tui-font-text-s)}:host[data-size=m]._icon-start{--t-left: 1.75rem}:host[data-size=m]._icon-end{--t-right: 1.75rem}:host[data-size=m]:before{margin-inline-start:-.125rem;margin-inline-end:.375rem}:host[data-size=m]:after{margin-inline-start:.375rem;margin-inline-end:-.125rem}:host[data-size=m] ::ng-deep [tuiTextfield]{font:var(--tui-font-text-s)}:host[data-size=l]{--t-height: var(--tui-height-l);padding:0 var(--tui-padding-l);border-radius:var(--tui-radius-l);font:var(--tui-font-text-m)}:host[data-size=l]._icon-start{--t-left: 2.25rem}:host[data-size=l]._icon-end{--t-right: 2.25rem}:host[data-size=l]:before{margin-inline-end:.75rem}:host[data-size=l]:after{margin-inline-start:.25rem}:host[data-size=l] ::ng-deep [tuiTextfield]{font:var(--tui-font-text-m)}:host:hover{color:var(--tui-text-secondary)}:host:before{z-index:1}:host._disabled:before,:host._disabled:after,:host._disabled .t-template{opacity:var(--tui-disabled-opacity)}:host._with-label .t-template,:host._with-label ::ng-deep [tuiTextfield]{padding-top:calc(var(--t-height) / 3)}:host._with-label .t-template::placeholder,:host._with-label ::ng-deep [tuiTextfield]::placeholder,:host._with-label .t-template._empty,:host._with-label ::ng-deep [tuiTextfield]._empty{color:transparent}:host .t-template,:host ::ng-deep [tuiTextfield]{position:absolute;top:0;left:0;width:100%;height:100%;-webkit-appearance:none;appearance:none;box-sizing:border-box;border:none;border-inline-start:var(--t-left) solid transparent!important;border-inline-end:calc(var(--t-right) + var(--t-side)) solid transparent!important;border-radius:inherit;padding:inherit}:host ::ng-deep [tuiTextfield]{pointer-events:auto;background:transparent no-repeat center right 1rem / 2rem;background-clip:border-box,padding-box}:host ::ng-deep [tuiTextfield]:read-only~.t-filler{display:none}:host ::ng-deep [tuiTextfield]:disabled~label,:host ::ng-deep [tuiTextfield]:disabled~.t-content{opacity:var(--tui-disabled-opacity)}:host ::ng-deep [tuiTextfield]:disabled~label [tuiTooltip],:host ::ng-deep [tuiTextfield]:disabled~.t-content [tuiTooltip]{display:none}:host ::ng-deep [tuiTextfield]:not(._empty)~label{font-size:.83em;transform:translateY(-.7em)}:host ::ng-deep [tuiTextfield]:not(._empty):not(:disabled)[data-mode=invalid]~label,:host ::ng-deep [tuiTextfield]:not(._empty):invalid:not(:disabled):not([data-mode])~label{color:var(--tui-text-negative)}:host ::ng-deep [tuiTextfield]:not(._empty):not(:disabled):not([data-mode=readonly])~.t-content .t-clear{display:flex}:host ::ng-deep [tuiTextfield]:not([data-mode=readonly]):focus-visible:not([data-focus=false])::placeholder,:host ::ng-deep [tuiTextfield]:not([data-mode=readonly]):focus-visible:not([data-focus=false])._empty{color:var(--tui-text-tertiary)}:host ::ng-deep [tuiTextfield]:not([data-mode=readonly]):focus-visible:not([data-focus=false])~label{color:var(--tui-text-primary)!important;font-size:.83em;transform:translateY(-.7em)}:host ::ng-deep [tuiTextfield]:not([data-mode=readonly])[data-focus=true]::placeholder,:host ::ng-deep [tuiTextfield]:not([data-mode=readonly])[data-focus=true]._empty{color:var(--tui-text-tertiary)}:host ::ng-deep [tuiTextfield]:not([data-mode=readonly])[data-focus=true]~label{color:var(--tui-text-primary)!important;font-size:.83em;transform:translateY(-.7em)}:host ::ng-deep label{transition-property:all;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;position:relative;display:block;flex:1;font-size:inherit}:host ::ng-deep label,:host ::ng-deep input::placeholder,:host ::ng-deep select._empty{color:var(--tui-text-secondary)}:host ::ng-deep select:not([data-mode=readonly]){cursor:pointer}@supports (-webkit-touch-callout: none){:host ::ng-deep [tuiTextfield]:active{font-size:1rem}:host ::ng-deep [tuiTextfield]._ios-fix{position:fixed;left:1000rem}}.t-content{display:flex;align-items:center;gap:.25rem;margin-inline-start:auto}.t-clear{display:none;pointer-events:auto}.t-filler{pointer-events:none;background:none;color:var(--tui-text-tertiary);opacity:1}\n"] }]
|
|
80
78
|
}], propDecorators: { directive: [{
|
|
81
79
|
type: ContentChild,
|
|
82
80
|
args: [forwardRef(() => TuiTextfieldDirective)]
|
|
@@ -96,4 +94,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
96
94
|
}], content: [{
|
|
97
95
|
type: Input
|
|
98
96
|
}] } });
|
|
99
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"textfield.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/textfield/textfield.component.ts","../../../../../projects/core/components/textfield/textfield.template.html"],"names":[],"mappings":"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","sourcesContent":["import {AsyncPipe, NgIf} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    ContentChild,\n    ElementRef,\n    forwardRef,\n    inject,\n    Input,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {ResizeObserverDirective} from '@ng-web-apis/resize-observer';\nimport {TuiNativeValidator} from '@taiga-ui/cdk/directives/native-validator';\nimport type {TuiContext, TuiStringHandler} from '@taiga-ui/cdk/types';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiFocusedIn} from '@taiga-ui/cdk/utils/focus';\nimport {TuiButton} from '@taiga-ui/core/components/button';\nimport type {TuiDataListHost} from '@taiga-ui/core/components/data-list';\nimport {tuiAsDataListHost} from '@taiga-ui/core/components/data-list';\nimport {TuiLabel} from '@taiga-ui/core/components/label';\nimport {\n    TuiDropdownDirective,\n    tuiDropdownOpen,\n    tuiDropdownOptionsProvider,\n    TuiWithDropdownOpen,\n} from '@taiga-ui/core/directives/dropdown';\nimport {TuiWithIcons} from '@taiga-ui/core/directives/icons';\nimport {TUI_COMMON_ICONS} from '@taiga-ui/core/tokens';\nimport type {PolymorpheusContent} from '@taiga-ui/polymorpheus';\nimport {PolymorpheusOutlet} from '@taiga-ui/polymorpheus';\n\nimport {TuiTextfieldDirective} from './textfield.directive';\nimport {TUI_TEXTFIELD_OPTIONS, TuiTextfieldOptionsDirective} from './textfield.options';\nimport {TuiWithTextfieldDropdown} from './textfield-dropdown.directive';\n\n@Component({\n    standalone: true,\n    selector: 'tui-textfield',\n    imports: [NgIf, AsyncPipe, ResizeObserverDirective, TuiButton, PolymorpheusOutlet],\n    templateUrl: './textfield.template.html',\n    styleUrls: ['./textfield.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsDataListHost(TuiTextfieldComponent),\n        tuiDropdownOptionsProvider({limitWidth: 'fixed'}),\n    ],\n    hostDirectives: [\n        TuiNativeValidator,\n        TuiDropdownDirective,\n        TuiWithDropdownOpen,\n        TuiWithTextfieldDropdown,\n        TuiWithIcons,\n    ],\n    host: {\n        '[style.--t-side.px]': 'side',\n        '[attr.data-size]': 'options.size()',\n        '[class._with-label]': 'hasLabel',\n        '[class._disabled]': 'el?.nativeElement.disabled',\n    },\n})\nexport class TuiTextfieldComponent<T> implements TuiDataListHost<T> {\n    private readonly open = tuiDropdownOpen();\n    private readonly focusedIn = tuiFocusedIn(tuiInjectElement());\n\n    @ContentChild(forwardRef(() => TuiTextfieldDirective))\n    protected readonly directive?: TuiTextfieldDirective;\n\n    @ContentChild(forwardRef(() => TuiLabel), {read: ElementRef})\n    protected readonly label?: ElementRef<HTMLElement>;\n\n    @ContentChild(NgControl)\n    protected readonly control?: NgControl;\n\n    protected side = 0;\n    protected readonly change$ = inject(TuiTextfieldOptionsDirective, {optional: true})\n        ?.change$;\n\n    protected readonly options = inject(TUI_TEXTFIELD_OPTIONS);\n    protected readonly icons = inject(TUI_COMMON_ICONS);\n\n    @ContentChild(forwardRef(() => TuiTextfieldDirective), {read: ElementRef})\n    public readonly el?: ElementRef<HTMLInputElement>;\n\n    @Input()\n    public filler = '';\n\n    @Input()\n    public stringify: TuiStringHandler<T> = String;\n\n    @Input()\n    public content: PolymorpheusContent<TuiContext<T>>;\n\n    public readonly focused = computed(() => this.open() || this.focusedIn());\n\n    public get id(): string {\n        return this.el?.nativeElement.id || '';\n    }\n\n    public handleOption(option: T): void {\n        this.directive?.setValue(this.stringify(option));\n        this.open.set(false);\n    }\n\n    protected get computedFiller(): string {\n        const value = this.el?.nativeElement.value || '';\n        const filler = value + this.filler.slice(value.length);\n\n        return filler.length > value.length ? filler : '';\n    }\n\n    protected get showFiller(): boolean {\n        return (\n            this.focused() &&\n            !!this.computedFiller &&\n            (!!this.el?.nativeElement.value || !this.el?.nativeElement.placeholder)\n        );\n    }\n\n    protected get hasLabel(): boolean {\n        return Boolean(this.label?.nativeElement?.childNodes.length);\n    }\n}\n","<ng-container *ngIf=\"change$ | async\" />\n<ng-content select=\"input\" />\n<ng-content select=\"select\" />\n<ng-content select=\"label\" />\n<span\n    class=\"t-content\"\n    (waResizeObserver)=\"side = $event[0].contentRect.width\"\n>\n    <ng-content />\n    <button\n        *ngIf=\"options.cleaner()\"\n        appearance=\"icon\"\n        size=\"xs\"\n        tabindex=\"-1\"\n        tuiIconButton\n        class=\"t-clear\"\n        [iconStart]=\"icons.close\"\n        (click)=\"directive?.setValue('')\"\n        (pointerdown.silent.prevent)=\"el?.nativeElement?.focus()\"\n    ></button>\n    <ng-content select=\"tui-icon\" />\n</span>\n<span class=\"t-template\">\n    <ng-container *polymorpheusOutlet=\"content as text; context: {$implicit: control?.value}\">\n        {{ text }}\n    </ng-container>\n</span>\n<input\n    *ngIf=\"showFiller\"\n    aria-hidden=\"true\"\n    disabled\n    class=\"t-filler\"\n    [value]=\"computedFiller\"\n/>\n"]}
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"textfield.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/textfield/textfield.component.ts","../../../../../projects/core/components/textfield/textfield.template.html"],"names":[],"mappings":"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","sourcesContent":["import {AsyncPipe, NgIf} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    ContentChild,\n    ElementRef,\n    forwardRef,\n    inject,\n    Input,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {ResizeObserverDirective} from '@ng-web-apis/resize-observer';\nimport {TuiNativeValidator} from '@taiga-ui/cdk/directives/native-validator';\nimport type {TuiContext, TuiStringHandler} from '@taiga-ui/cdk/types';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiFocusedIn} from '@taiga-ui/cdk/utils/focus';\nimport {TuiButton} from '@taiga-ui/core/components/button';\nimport type {TuiDataListHost} from '@taiga-ui/core/components/data-list';\nimport {tuiAsDataListHost} from '@taiga-ui/core/components/data-list';\nimport {TuiLabel} from '@taiga-ui/core/components/label';\nimport {\n    TuiDropdownDirective,\n    tuiDropdownOpen,\n    tuiDropdownOptionsProvider,\n    TuiWithDropdownOpen,\n} from '@taiga-ui/core/directives/dropdown';\nimport {TuiWithIcons} from '@taiga-ui/core/directives/icons';\nimport {TUI_COMMON_ICONS} from '@taiga-ui/core/tokens';\nimport type {PolymorpheusContent} from '@taiga-ui/polymorpheus';\nimport {PolymorpheusOutlet} from '@taiga-ui/polymorpheus';\n\nimport {TuiTextfieldDirective} from './textfield.directive';\nimport {TUI_TEXTFIELD_OPTIONS} from './textfield.options';\nimport {TuiWithTextfieldDropdown} from './textfield-dropdown.directive';\n\n@Component({\n    standalone: true,\n    selector: 'tui-textfield',\n    imports: [NgIf, AsyncPipe, ResizeObserverDirective, TuiButton, PolymorpheusOutlet],\n    templateUrl: './textfield.template.html',\n    styleUrls: ['./textfield.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsDataListHost(TuiTextfieldComponent),\n        tuiDropdownOptionsProvider({limitWidth: 'fixed'}),\n    ],\n    hostDirectives: [\n        TuiNativeValidator,\n        TuiDropdownDirective,\n        TuiWithDropdownOpen,\n        TuiWithTextfieldDropdown,\n        TuiWithIcons,\n    ],\n    host: {\n        '[style.--t-side.px]': 'side',\n        '[attr.data-size]': 'options.size()',\n        '[class._with-label]': 'hasLabel',\n        '[class._disabled]': 'el?.nativeElement.disabled',\n    },\n})\nexport class TuiTextfieldComponent<T> implements TuiDataListHost<T> {\n    private readonly open = tuiDropdownOpen();\n    private readonly focusedIn = tuiFocusedIn(tuiInjectElement());\n\n    @ContentChild(forwardRef(() => TuiTextfieldDirective))\n    protected readonly directive?: TuiTextfieldDirective;\n\n    @ContentChild(forwardRef(() => TuiLabel), {read: ElementRef})\n    protected readonly label?: ElementRef<HTMLElement>;\n\n    @ContentChild(NgControl)\n    protected readonly control?: NgControl;\n\n    protected side = 0;\n\n    protected readonly options = inject(TUI_TEXTFIELD_OPTIONS);\n    protected readonly icons = inject(TUI_COMMON_ICONS);\n\n    @ContentChild(forwardRef(() => TuiTextfieldDirective), {read: ElementRef})\n    public readonly el?: ElementRef<HTMLInputElement>;\n\n    @Input()\n    public filler = '';\n\n    @Input()\n    public stringify: TuiStringHandler<T> = String;\n\n    @Input()\n    public content: PolymorpheusContent<TuiContext<T>>;\n\n    public readonly focused = computed(() => this.open() || this.focusedIn());\n\n    public get id(): string {\n        return this.el?.nativeElement.id || '';\n    }\n\n    public handleOption(option: T): void {\n        this.directive?.setValue(this.stringify(option));\n        this.open.set(false);\n    }\n\n    protected get computedFiller(): string {\n        const value = this.el?.nativeElement.value || '';\n        const filler = value + this.filler.slice(value.length);\n\n        return filler.length > value.length ? filler : '';\n    }\n\n    protected get showFiller(): boolean {\n        return (\n            this.focused() &&\n            !!this.computedFiller &&\n            (!!this.el?.nativeElement.value || !this.el?.nativeElement.placeholder)\n        );\n    }\n\n    protected get hasLabel(): boolean {\n        return Boolean(this.label?.nativeElement?.childNodes.length);\n    }\n}\n","<ng-content select=\"input\" />\n<ng-content select=\"select\" />\n<ng-content select=\"label\" />\n<span\n    class=\"t-content\"\n    (waResizeObserver)=\"side = $event[0].contentRect.width\"\n>\n    <ng-content />\n    <button\n        *ngIf=\"options.cleaner()\"\n        appearance=\"icon\"\n        size=\"xs\"\n        tabindex=\"-1\"\n        tuiIconButton\n        class=\"t-clear\"\n        [iconStart]=\"icons.close\"\n        (click)=\"directive?.setValue('')\"\n        (pointerdown.silent.prevent)=\"el?.nativeElement?.focus()\"\n    ></button>\n    <ng-content select=\"tui-icon\" />\n</span>\n<span class=\"t-template\">\n    <ng-container *polymorpheusOutlet=\"content as text; context: {$implicit: control?.value}\">\n        {{ text }}\n    </ng-container>\n</span>\n<input\n    *ngIf=\"showFiller\"\n    aria-hidden=\"true\"\n    disabled\n    class=\"t-filler\"\n    [value]=\"computedFiller\"\n/>\n"]}
|