@taiga-ui/core 3.23.1 → 3.24.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-alert.umd.js +6 -6
- package/bundles/taiga-ui-core-components-alert.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-button.umd.js +4 -4
- package/bundles/taiga-ui-core-components-button.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-data-list.umd.js +7 -7
- package/bundles/taiga-ui-core-components-data-list.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-dialog.umd.js +18 -11
- package/bundles/taiga-ui-core-components-dialog.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-expand.umd.js +3 -3
- package/bundles/taiga-ui-core-components-expand.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-hosted-dropdown.umd.js +5 -5
- package/bundles/taiga-ui-core-components-hosted-dropdown.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-link.umd.js +4 -4
- package/bundles/taiga-ui-core-components-link.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-loader.umd.js +6 -6
- package/bundles/taiga-ui-core-components-loader.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-notification.umd.js +8 -2
- package/bundles/taiga-ui-core-components-notification.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-primitive-textfield.umd.js +8 -8
- package/bundles/taiga-ui-core-components-primitive-textfield.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-root.umd.js +3 -11
- package/bundles/taiga-ui-core-components-root.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-scroll-controls.umd.js +14 -14
- package/bundles/taiga-ui-core-components-scroll-controls.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-scrollbar.umd.js +7 -7
- package/bundles/taiga-ui-core-components-scrollbar.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-svg.umd.js +10 -13
- package/bundles/taiga-ui-core-components-svg.umd.js.map +1 -1
- package/bundles/taiga-ui-core-directives-dropdown.umd.js +26 -30
- package/bundles/taiga-ui-core-directives-dropdown.umd.js.map +1 -1
- package/bundles/taiga-ui-core-directives-hint.umd.js +17 -19
- package/bundles/taiga-ui-core-directives-hint.umd.js.map +1 -1
- package/bundles/taiga-ui-core-directives-scroll-into-view.umd.js +4 -4
- package/bundles/taiga-ui-core-directives-scroll-into-view.umd.js.map +1 -1
- package/bundles/taiga-ui-core-directives-textfield-controller.umd.js +2 -2
- package/bundles/taiga-ui-core-directives-textfield-controller.umd.js.map +1 -1
- package/bundles/taiga-ui-core-internal-svg-defs-host.umd.js +3 -3
- package/bundles/taiga-ui-core-internal-svg-defs-host.umd.js.map +1 -1
- package/bundles/taiga-ui-core-pipes-calendar-sheet.umd.js +4 -4
- package/bundles/taiga-ui-core-pipes-calendar-sheet.umd.js.map +1 -1
- package/bundles/taiga-ui-core-pipes-format-phone.umd.js +2 -1
- package/bundles/taiga-ui-core-pipes-format-phone.umd.js.map +1 -1
- package/bundles/taiga-ui-core-providers.umd.js +2 -2
- package/bundles/taiga-ui-core-providers.umd.js.map +1 -1
- package/bundles/taiga-ui-core-services.umd.js +11 -10
- package/bundles/taiga-ui-core-services.umd.js.map +1 -1
- package/bundles/taiga-ui-core-tokens.umd.js +13 -9
- package/bundles/taiga-ui-core-tokens.umd.js.map +1 -1
- package/bundles/taiga-ui-core-utils-dom.umd.js +2 -2
- package/bundles/taiga-ui-core-utils-dom.umd.js.map +1 -1
- package/bundles/taiga-ui-core-utils-mask.umd.js +8 -9
- package/bundles/taiga-ui-core-utils-mask.umd.js.map +1 -1
- package/bundles/taiga-ui-core-utils-mobile.umd.js +2 -2
- package/bundles/taiga-ui-core-utils-mobile.umd.js.map +1 -1
- package/components/alert/alert.component.d.ts +2 -2
- package/components/alert/alert.service.d.ts +1 -1
- package/components/button/button.component.d.ts +2 -2
- package/components/data-list/data-list.component.d.ts +2 -2
- package/components/data-list/option/option.component.d.ts +2 -2
- package/components/dialog/dialog-close.service.d.ts +4 -4
- package/components/dialog/dialog.component.d.ts +1 -0
- package/components/dialog/dialog.service.d.ts +1 -1
- package/components/expand/expand.component.d.ts +2 -2
- package/components/hosted-dropdown/hosted-dropdown.component.d.ts +2 -2
- package/components/link/link.component.d.ts +2 -2
- package/components/loader/loader.component.d.ts +3 -3
- package/components/notification/notification.component.d.ts +2 -1
- package/components/primitive-textfield/primitive-textfield.component.d.ts +2 -2
- package/components/primitive-textfield/textfield/textfield.component.d.ts +2 -2
- package/components/root/root.component.d.ts +1 -3
- package/components/scroll-controls/scroll-controls.component.d.ts +2 -2
- package/components/scroll-controls/scrollbar.directive.d.ts +4 -4
- package/components/scrollbar/scrollable.directive.d.ts +2 -2
- package/components/scrollbar/scrollbar.component.d.ts +2 -2
- package/components/svg/svg.component.d.ts +4 -4
- package/directives/dropdown/dropdown-selection.directive.d.ts +4 -4
- package/directives/dropdown/dropdown.component.d.ts +3 -3
- package/directives/dropdown/dropdown.directive.d.ts +3 -3
- package/directives/hint/hint-describe.directive.d.ts +3 -3
- package/directives/hint/hint-hover.directive.d.ts +2 -2
- package/directives/hint/hint.component.d.ts +2 -2
- package/directives/hint/hint.directive.d.ts +3 -3
- package/directives/scroll-into-view/scroll-into-view.directive.d.ts +2 -2
- package/esm2015/components/alert/alert.component.js +7 -7
- package/esm2015/components/button/button.component.js +5 -5
- package/esm2015/components/data-list/data-list.component.js +5 -5
- package/esm2015/components/data-list/option/option.component.js +4 -4
- package/esm2015/components/dialog/dialog-close.service.js +10 -10
- package/esm2015/components/dialog/dialog.component.js +6 -3
- package/esm2015/components/expand/expand.component.js +4 -4
- package/esm2015/components/hosted-dropdown/hosted-dropdown.component.js +6 -6
- package/esm2015/components/link/link.component.js +5 -5
- package/esm2015/components/loader/loader.component.js +7 -7
- package/esm2015/components/notification/notification.component.js +9 -3
- package/esm2015/components/primitive-textfield/primitive-textfield.component.js +4 -4
- package/esm2015/components/primitive-textfield/textfield/textfield.component.js +6 -6
- package/esm2015/components/root/root.component.js +7 -15
- package/esm2015/components/scroll-controls/scroll-controls.component.js +5 -5
- package/esm2015/components/scroll-controls/scrollbar.directive.js +11 -11
- package/esm2015/components/scrollbar/scrollable.directive.js +5 -5
- package/esm2015/components/scrollbar/scrollbar.component.js +4 -4
- package/esm2015/components/svg/svg.component.js +11 -14
- package/esm2015/directives/dropdown/dropdown-selection.directive.js +15 -17
- package/esm2015/directives/dropdown/dropdown.component.js +9 -9
- package/esm2015/directives/dropdown/dropdown.directive.js +5 -7
- package/esm2015/directives/hint/hint-describe.directive.js +7 -8
- package/esm2015/directives/hint/hint-hover.directive.js +3 -3
- package/esm2015/directives/hint/hint.component.js +7 -8
- package/esm2015/directives/hint/hint.directive.js +4 -4
- package/esm2015/directives/scroll-into-view/scroll-into-view.directive.js +5 -5
- package/esm2015/directives/textfield-controller/textfield-controller.provider.js +3 -3
- package/esm2015/interfaces/data-list-host.js +1 -1
- package/esm2015/interfaces/portal-item.js +1 -1
- package/esm2015/internal/svg-defs-host/svg-defs-host.component.js +4 -4
- package/esm2015/pipes/calendar-sheet/utils.js +5 -5
- package/esm2015/pipes/format-phone/format-phone.pipe.js +3 -2
- package/esm2015/providers/watched-controller-provider-factory.js +3 -3
- package/esm2015/services/breakpoint.service.js +5 -5
- package/esm2015/services/night-theme.service.js +3 -3
- package/esm2015/services/router-link-active.service.js +2 -1
- package/esm2015/services/svg.service.js +2 -2
- package/esm2015/services/visual-viewport.service.js +5 -5
- package/esm2015/tokens/assert-enabled.js +5 -1
- package/esm2015/tokens/is-mobile-resolution.js +3 -3
- package/esm2015/tokens/selection-stream.js +3 -3
- package/esm2015/tokens/viewport.js +6 -6
- package/esm2015/utils/dom/get-screen-width.js +3 -3
- package/esm2015/utils/mask/create-auto-corrected-money-pipe.js +3 -4
- package/esm2015/utils/mask/create-correction-mask.js +3 -2
- package/esm2015/utils/mask/create-number-mask.js +5 -6
- package/esm2015/utils/mobile/is-mobile.js +3 -3
- package/fesm2015/taiga-ui-core-components-alert.js +6 -6
- package/fesm2015/taiga-ui-core-components-alert.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-button.js +4 -4
- package/fesm2015/taiga-ui-core-components-button.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-data-list.js +7 -7
- package/fesm2015/taiga-ui-core-components-data-list.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-dialog.js +14 -11
- package/fesm2015/taiga-ui-core-components-dialog.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-expand.js +3 -3
- package/fesm2015/taiga-ui-core-components-expand.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-hosted-dropdown.js +5 -5
- package/fesm2015/taiga-ui-core-components-hosted-dropdown.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-link.js +4 -4
- package/fesm2015/taiga-ui-core-components-link.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-loader.js +6 -6
- package/fesm2015/taiga-ui-core-components-loader.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-notification.js +8 -2
- package/fesm2015/taiga-ui-core-components-notification.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-primitive-textfield.js +8 -8
- package/fesm2015/taiga-ui-core-components-primitive-textfield.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-root.js +6 -14
- package/fesm2015/taiga-ui-core-components-root.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-scroll-controls.js +14 -14
- package/fesm2015/taiga-ui-core-components-scroll-controls.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-scrollbar.js +7 -7
- package/fesm2015/taiga-ui-core-components-scrollbar.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-svg.js +10 -13
- package/fesm2015/taiga-ui-core-components-svg.js.map +1 -1
- package/fesm2015/taiga-ui-core-directives-dropdown.js +26 -30
- package/fesm2015/taiga-ui-core-directives-dropdown.js.map +1 -1
- package/fesm2015/taiga-ui-core-directives-hint.js +17 -19
- package/fesm2015/taiga-ui-core-directives-hint.js.map +1 -1
- package/fesm2015/taiga-ui-core-directives-scroll-into-view.js +4 -4
- package/fesm2015/taiga-ui-core-directives-scroll-into-view.js.map +1 -1
- package/fesm2015/taiga-ui-core-directives-textfield-controller.js +2 -2
- package/fesm2015/taiga-ui-core-directives-textfield-controller.js.map +1 -1
- package/fesm2015/taiga-ui-core-internal-svg-defs-host.js +3 -3
- package/fesm2015/taiga-ui-core-internal-svg-defs-host.js.map +1 -1
- package/fesm2015/taiga-ui-core-pipes-calendar-sheet.js +4 -4
- package/fesm2015/taiga-ui-core-pipes-calendar-sheet.js.map +1 -1
- package/fesm2015/taiga-ui-core-pipes-format-phone.js +2 -1
- package/fesm2015/taiga-ui-core-pipes-format-phone.js.map +1 -1
- package/fesm2015/taiga-ui-core-providers.js +2 -2
- package/fesm2015/taiga-ui-core-providers.js.map +1 -1
- package/fesm2015/taiga-ui-core-services.js +12 -11
- package/fesm2015/taiga-ui-core-services.js.map +1 -1
- package/fesm2015/taiga-ui-core-tokens.js +13 -9
- package/fesm2015/taiga-ui-core-tokens.js.map +1 -1
- package/fesm2015/taiga-ui-core-utils-dom.js +2 -2
- package/fesm2015/taiga-ui-core-utils-dom.js.map +1 -1
- package/fesm2015/taiga-ui-core-utils-mask.js +8 -9
- package/fesm2015/taiga-ui-core-utils-mask.js.map +1 -1
- package/fesm2015/taiga-ui-core-utils-mobile.js +2 -2
- package/fesm2015/taiga-ui-core-utils-mobile.js.map +1 -1
- package/interfaces/data-list-host.d.ts +2 -1
- package/interfaces/portal-item.d.ts +1 -1
- package/internal/svg-defs-host/svg-defs-host.component.d.ts +2 -2
- package/package.json +4 -4
- package/providers/watched-controller-provider-factory.d.ts +1 -1
- package/services/breakpoint.service.d.ts +1 -1
- package/services/night-theme.service.d.ts +1 -1
- package/services/visual-viewport.service.d.ts +2 -2
- package/tokens/assert-enabled.d.ts +4 -0
- package/utils/dom/get-screen-width.d.ts +1 -1
- package/utils/mobile/is-mobile.d.ts +1 -1
|
@@ -3,8 +3,8 @@ import { PolymorpheusContent } from '@tinkoff/ng-polymorpheus';
|
|
|
3
3
|
import { TuiLoaderOptions } from './loader-options';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export declare class TuiLoaderComponent {
|
|
6
|
-
private readonly
|
|
7
|
-
private readonly
|
|
6
|
+
private readonly doc;
|
|
7
|
+
private readonly el;
|
|
8
8
|
private readonly isIos;
|
|
9
9
|
private readonly options;
|
|
10
10
|
size: "m" | "s" | "xs" | "l" | "xl" | "xxl";
|
|
@@ -14,7 +14,7 @@ export declare class TuiLoaderComponent {
|
|
|
14
14
|
set showLoader(value: boolean);
|
|
15
15
|
loading: boolean;
|
|
16
16
|
readonly isApple: boolean;
|
|
17
|
-
constructor(
|
|
17
|
+
constructor(doc: Document, el: ElementRef<HTMLElement>, isIos: boolean, options: TuiLoaderOptions);
|
|
18
18
|
get hasOverlay(): boolean;
|
|
19
19
|
get hasText(): boolean;
|
|
20
20
|
get isHorizontal(): boolean;
|
|
@@ -13,10 +13,11 @@ export declare class TuiNotificationComponent {
|
|
|
13
13
|
readonly options: TuiNotificationDefaultOptions;
|
|
14
14
|
hasIcon: boolean;
|
|
15
15
|
status: 'error' | 'info' | 'success' | 'warning';
|
|
16
|
+
hideClose: boolean;
|
|
16
17
|
readonly close: EventEmitter<void>;
|
|
17
18
|
constructor(closeWord$: Observable<string>, options: TuiNotificationDefaultOptions);
|
|
18
19
|
get icon(): string;
|
|
19
20
|
get hasClose(): boolean;
|
|
20
21
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiNotificationComponent, never>;
|
|
21
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<TuiNotificationComponent, "tui-notification", never, { "hasIcon": "hasIcon"; "status": "status"; }, { "close": "close"; }, never, ["*"]>;
|
|
22
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TuiNotificationComponent, "tui-notification", never, { "hasIcon": "hasIcon"; "status": "status"; "hideClose": "hideClose"; }, { "close": "close"; }, never, ["*"]>;
|
|
22
23
|
}
|
|
@@ -12,7 +12,7 @@ export declare class TuiPrimitiveTextfieldComponent extends AbstractTuiInteracti
|
|
|
12
12
|
readonly controller: TuiTextfieldController;
|
|
13
13
|
readonly hintOptions: TuiHintOptionsDirective | null;
|
|
14
14
|
readonly options: TuiTextfieldOptions;
|
|
15
|
-
private readonly
|
|
15
|
+
private readonly el;
|
|
16
16
|
private readonly focusableElement?;
|
|
17
17
|
editable: boolean;
|
|
18
18
|
/** @deprecated use `tuiTextfieldFiller` from {@link TuiTextfieldControllerModule} instead */
|
|
@@ -33,7 +33,7 @@ export declare class TuiPrimitiveTextfieldComponent extends AbstractTuiInteracti
|
|
|
33
33
|
readonly valueChange: EventEmitter<string>;
|
|
34
34
|
readonly content?: QueryList<unknown>;
|
|
35
35
|
autofilled: boolean;
|
|
36
|
-
constructor(mode$: Observable<TuiBrightness | null>, controller: TuiTextfieldController, hintOptions: TuiHintOptionsDirective | null, options: TuiTextfieldOptions,
|
|
36
|
+
constructor(mode$: Observable<TuiBrightness | null>, controller: TuiTextfieldController, hintOptions: TuiHintOptionsDirective | null, options: TuiTextfieldOptions, el: ElementRef<HTMLElement>);
|
|
37
37
|
get prefix(): string;
|
|
38
38
|
get postfix(): string;
|
|
39
39
|
get filler(): string;
|
|
@@ -6,9 +6,9 @@ import * as i0 from "@angular/core";
|
|
|
6
6
|
export declare class TuiTextfieldComponent {
|
|
7
7
|
readonly host: TuiTextfieldHost;
|
|
8
8
|
readonly controller: TuiTextfieldController;
|
|
9
|
-
private readonly
|
|
9
|
+
private readonly el;
|
|
10
10
|
private readonly idService;
|
|
11
|
-
constructor(host: TuiTextfieldHost, controller: TuiTextfieldController,
|
|
11
|
+
constructor(host: TuiTextfieldHost, controller: TuiTextfieldController, el: ElementRef<HTMLInputElement>, idService: TuiIdService);
|
|
12
12
|
get id(): string;
|
|
13
13
|
get inputMode(): string;
|
|
14
14
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiTextfieldComponent, never>;
|
|
@@ -1,14 +1,12 @@
|
|
|
1
|
-
import { ElementRef } from '@angular/core';
|
|
2
1
|
import { Observable } from 'rxjs';
|
|
3
2
|
import * as i0 from "@angular/core";
|
|
4
3
|
export declare class TuiRootComponent {
|
|
5
4
|
readonly duration: number;
|
|
6
|
-
readonly elementRef: ElementRef<HTMLElement>;
|
|
7
5
|
readonly dialogs: ReadonlyArray<Observable<readonly unknown[]>>;
|
|
8
6
|
private readonly isMobile;
|
|
9
7
|
readonly isMobileRes$: Observable<boolean>;
|
|
10
8
|
readonly scrollbars$: Observable<boolean>;
|
|
11
|
-
constructor(duration: number,
|
|
9
|
+
constructor(duration: number, dialogs: ReadonlyArray<Observable<readonly unknown[]>>, isMobile: boolean, isMobileRes$: Observable<boolean>, { body }: Document, theme: string);
|
|
12
10
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiRootComponent, never>;
|
|
13
11
|
static ɵcmp: i0.ɵɵComponentDeclaration<TuiRootComponent, "tui-root", never, {}, {}, never, ["*", "tuiOverContent", "tuiOverDialogs", "tuiOverAlerts", "tuiOverPortals", "tuiOverHints"]>;
|
|
14
12
|
}
|
|
@@ -6,7 +6,7 @@ import * as i0 from "@angular/core";
|
|
|
6
6
|
export declare class TuiScrollControlsComponent {
|
|
7
7
|
private readonly options;
|
|
8
8
|
private readonly ngZone;
|
|
9
|
-
private readonly
|
|
9
|
+
private readonly doc;
|
|
10
10
|
private readonly scrollRef;
|
|
11
11
|
private readonly animationFrame$;
|
|
12
12
|
readonly mode$: Observable<TuiBrightness | null>;
|
|
@@ -18,7 +18,7 @@ export declare class TuiScrollControlsComponent {
|
|
|
18
18
|
} | undefined;
|
|
19
19
|
readonly value: "";
|
|
20
20
|
};
|
|
21
|
-
constructor(options: AnimationOptions, ngZone: NgZone,
|
|
21
|
+
constructor(options: AnimationOptions, ngZone: NgZone, doc: Document, scrollRef: ElementRef<HTMLElement> | null, animationFrame$: Observable<number>, mode$: Observable<TuiBrightness | null>);
|
|
22
22
|
private get scrollbars();
|
|
23
23
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiScrollControlsComponent, [null, null, null, { optional: true; }, null, null]>;
|
|
24
24
|
static ɵcmp: i0.ɵɵComponentDeclaration<TuiScrollControlsComponent, "tui-scroll-controls", never, {}, {}, never, never>;
|
|
@@ -6,12 +6,12 @@ import * as i0 from "@angular/core";
|
|
|
6
6
|
export declare class TuiScrollbarDirective {
|
|
7
7
|
private readonly wrapper;
|
|
8
8
|
private readonly container;
|
|
9
|
-
private readonly
|
|
10
|
-
private readonly
|
|
11
|
-
private readonly
|
|
9
|
+
private readonly doc;
|
|
10
|
+
private readonly win;
|
|
11
|
+
private readonly el;
|
|
12
12
|
private readonly viewportScroller;
|
|
13
13
|
tuiScrollbar: TuiOrientation;
|
|
14
|
-
constructor(ngZone: NgZone, renderer: Renderer2, destroy$: Observable<void>, animationFrame$: Observable<number>, wrapper: ElementRef<HTMLElement>, container: ElementRef<HTMLElement> | null,
|
|
14
|
+
constructor(ngZone: NgZone, renderer: Renderer2, destroy$: Observable<void>, animationFrame$: Observable<number>, wrapper: ElementRef<HTMLElement>, container: ElementRef<HTMLElement> | null, doc: Document, win: Window, el: ElementRef<HTMLElement>, viewportScroller: ViewportScroller);
|
|
15
15
|
private get scrolled();
|
|
16
16
|
private get compensation();
|
|
17
17
|
private get thumb();
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { ElementRef, OnInit } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export declare class TuiScrollableDirective implements OnInit {
|
|
4
|
-
private readonly
|
|
5
|
-
constructor(
|
|
4
|
+
private readonly el;
|
|
5
|
+
constructor(el: ElementRef<HTMLElement>);
|
|
6
6
|
ngOnInit(): void;
|
|
7
7
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiScrollableDirective, never>;
|
|
8
8
|
static ɵdir: i0.ɵɵDirectiveDeclaration<TuiScrollableDirective, "[tuiScrollable]", never, {}, {}, never>;
|
|
@@ -4,14 +4,14 @@ import { TuiInjectionTokenType } from '@taiga-ui/cdk';
|
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export declare class TuiScrollbarComponent {
|
|
6
6
|
private readonly cssRef;
|
|
7
|
-
private readonly
|
|
7
|
+
private readonly el;
|
|
8
8
|
private readonly userAgent;
|
|
9
9
|
private readonly isIos;
|
|
10
10
|
private delegated;
|
|
11
11
|
private readonly isLegacy;
|
|
12
12
|
hidden: boolean;
|
|
13
13
|
readonly browserScrollRef: ElementRef<HTMLElement>;
|
|
14
|
-
constructor(cssRef: TuiInjectionTokenType<typeof CSS_TOKEN>,
|
|
14
|
+
constructor(cssRef: TuiInjectionTokenType<typeof CSS_TOKEN>, el: ElementRef<HTMLElement>, userAgent: string, isIos: boolean);
|
|
15
15
|
get showScrollbars(): boolean;
|
|
16
16
|
get showNative(): boolean;
|
|
17
17
|
onScrollable(element: HTMLElement): void;
|
|
@@ -6,18 +6,18 @@ import { Observable } from 'rxjs';
|
|
|
6
6
|
import { TuiSvgOptions } from './svg-options';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
export declare class TuiSvgComponent {
|
|
9
|
-
private readonly
|
|
10
|
-
private readonly
|
|
9
|
+
private readonly doc;
|
|
10
|
+
private readonly win;
|
|
11
11
|
private readonly options;
|
|
12
12
|
private readonly tuiSanitizer;
|
|
13
13
|
private readonly svgService;
|
|
14
14
|
private readonly staticRequestService;
|
|
15
15
|
private readonly sanitizer;
|
|
16
|
-
private readonly
|
|
16
|
+
private readonly el;
|
|
17
17
|
private readonly src$;
|
|
18
18
|
private icon;
|
|
19
19
|
readonly innerHTML$: Observable<SafeHtml>;
|
|
20
|
-
constructor(
|
|
20
|
+
constructor(doc: Document, win: Window, options: TuiSvgOptions, tuiSanitizer: Sanitizer | null, svgService: TuiSvgService, staticRequestService: TuiStaticRequestService, sanitizer: DomSanitizer, el: ElementRef<Element>);
|
|
21
21
|
set src(src: SafeHtml | string);
|
|
22
22
|
get src(): SafeHtml | string;
|
|
23
23
|
get use(): string;
|
|
@@ -6,10 +6,10 @@ import { TuiDropdownDirective } from './dropdown.directive';
|
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
export declare class TuiDropdownSelectionDirective extends TuiDriver implements TuiRectAccessor, OnDestroy {
|
|
8
8
|
private range;
|
|
9
|
-
private readonly
|
|
9
|
+
private readonly doc;
|
|
10
10
|
private readonly selection$;
|
|
11
|
-
private readonly
|
|
12
|
-
private readonly
|
|
11
|
+
private readonly el;
|
|
12
|
+
private readonly vcr;
|
|
13
13
|
private readonly dropdown;
|
|
14
14
|
private readonly handler$;
|
|
15
15
|
private readonly stream$;
|
|
@@ -17,7 +17,7 @@ export declare class TuiDropdownSelectionDirective extends TuiDriver implements
|
|
|
17
17
|
position: 'selection' | 'tag' | 'word';
|
|
18
18
|
set tuiDropdownSelection(visible: TuiBooleanHandler<Range> | string);
|
|
19
19
|
readonly type = "dropdown";
|
|
20
|
-
constructor(range: Range,
|
|
20
|
+
constructor(range: Range, doc: Document, selection$: Observable<unknown>, el: ElementRef<HTMLElement>, vcr: ViewContainerRef, dropdown: TuiDropdownDirective);
|
|
21
21
|
getClientRect(): ClientRect;
|
|
22
22
|
ngOnDestroy(): void;
|
|
23
23
|
private getRange;
|
|
@@ -17,10 +17,10 @@ import * as i0 from "@angular/core";
|
|
|
17
17
|
*/
|
|
18
18
|
export declare class TuiDropdownComponent implements OnDestroy {
|
|
19
19
|
readonly directive: TuiDropdownDirective;
|
|
20
|
-
private readonly
|
|
20
|
+
private readonly el;
|
|
21
21
|
private readonly host;
|
|
22
22
|
private readonly accessor;
|
|
23
|
-
private readonly
|
|
23
|
+
private readonly win;
|
|
24
24
|
private readonly animationOptions;
|
|
25
25
|
private readonly options;
|
|
26
26
|
private readonly hoverDirective;
|
|
@@ -31,7 +31,7 @@ export declare class TuiDropdownComponent implements OnDestroy {
|
|
|
31
31
|
} | undefined;
|
|
32
32
|
value: TuiDropdownAnimation;
|
|
33
33
|
};
|
|
34
|
-
constructor(position$: Observable<TuiPoint>, destroy$: Observable<void>, directive: TuiDropdownDirective,
|
|
34
|
+
constructor(position$: Observable<TuiPoint>, destroy$: Observable<void>, directive: TuiDropdownDirective, el: ElementRef<HTMLElement>, host: AbstractTuiPortalHostComponent, accessor: TuiRectAccessor, win: Window, animationOptions: AnimationOptions, options: TuiDropdownOptions, hoverDirective: TuiDropdownHoverDirective | null, visualViewportService: TuiVisualViewportService);
|
|
35
35
|
ngOnDestroy(): void;
|
|
36
36
|
onHoveredChange(hovered: boolean): void;
|
|
37
37
|
onTopFocus(): void;
|
|
@@ -5,15 +5,15 @@ 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
7
|
export declare class TuiDropdownDirective implements AfterViewChecked, OnDestroy, OnChanges, TuiPortalItem, TuiRectAccessor, TuiVehicle {
|
|
8
|
-
readonly
|
|
8
|
+
readonly el: ElementRef<HTMLElement>;
|
|
9
9
|
private readonly hapica;
|
|
10
10
|
private readonly injector;
|
|
11
11
|
private readonly dropdownService;
|
|
12
12
|
content: PolymorpheusContent<TuiContextWithImplicit<TuiActiveZoneDirective>>;
|
|
13
13
|
dropdownBoxRef: ComponentRef<unknown> | null;
|
|
14
14
|
readonly type = "dropdown";
|
|
15
|
-
readonly component: PolymorpheusComponent<unknown,
|
|
16
|
-
constructor(
|
|
15
|
+
readonly component: PolymorpheusComponent<unknown, any>;
|
|
16
|
+
constructor(el: ElementRef<HTMLElement>, hapica: Type<unknown>, injector: Injector, dropdownService: TuiDropdownPortalService);
|
|
17
17
|
get position(): 'absolute' | 'fixed';
|
|
18
18
|
ngAfterViewChecked(): void;
|
|
19
19
|
ngOnChanges(): void;
|
|
@@ -3,12 +3,12 @@ import { TuiDriver } from '@taiga-ui/core/abstract';
|
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export declare class TuiHintDescribeDirective extends TuiDriver {
|
|
5
5
|
private readonly ngZone;
|
|
6
|
-
private readonly
|
|
7
|
-
private readonly
|
|
6
|
+
private readonly doc;
|
|
7
|
+
private readonly el;
|
|
8
8
|
private readonly stream$;
|
|
9
9
|
tuiHintDescribe: string | '';
|
|
10
10
|
readonly type = "hint";
|
|
11
|
-
constructor(ngZone: NgZone,
|
|
11
|
+
constructor(ngZone: NgZone, doc: Document, el: ElementRef<HTMLElement>);
|
|
12
12
|
private get focused();
|
|
13
13
|
private get element();
|
|
14
14
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiHintDescribeDirective, never>;
|
|
@@ -6,7 +6,7 @@ import * as i0 from "@angular/core";
|
|
|
6
6
|
export declare class TuiHintHoverDirective extends TuiDriver {
|
|
7
7
|
private readonly hovered$;
|
|
8
8
|
private readonly options;
|
|
9
|
-
readonly
|
|
9
|
+
readonly el: ElementRef<HTMLElement>;
|
|
10
10
|
private visible;
|
|
11
11
|
private readonly toggle$;
|
|
12
12
|
private readonly stream$;
|
|
@@ -14,7 +14,7 @@ export declare class TuiHintHoverDirective extends TuiDriver {
|
|
|
14
14
|
hideDelay: TuiHintOptions['hideDelay'];
|
|
15
15
|
readonly type = "hint";
|
|
16
16
|
enabled: boolean;
|
|
17
|
-
constructor(hovered$: Observable<boolean>, options: TuiHintOptions,
|
|
17
|
+
constructor(hovered$: Observable<boolean>, options: TuiHintOptions, el: ElementRef<HTMLElement>);
|
|
18
18
|
toggle(visible?: boolean): void;
|
|
19
19
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiHintHoverDirective, never>;
|
|
20
20
|
static ɵdir: i0.ɵɵDirectiveDeclaration<TuiHintHoverDirective, "[tuiHint]:not(ng-container)", ["tuiHintHover"], { "showDelay": "tuiHintShowDelay"; "hideDelay": "tuiHintHideDelay"; }, {}, never>;
|
|
@@ -12,7 +12,7 @@ import { TuiHintHoverDirective } from './hint-hover.directive';
|
|
|
12
12
|
import * as i0 from "@angular/core";
|
|
13
13
|
export declare class TuiHintComponent<C = any> {
|
|
14
14
|
protected readonly accessor: TuiRectAccessor;
|
|
15
|
-
private readonly
|
|
15
|
+
private readonly el;
|
|
16
16
|
private readonly options;
|
|
17
17
|
private readonly polymorpheus;
|
|
18
18
|
private readonly hover;
|
|
@@ -28,7 +28,7 @@ export declare class TuiHintComponent<C = any> {
|
|
|
28
28
|
};
|
|
29
29
|
readonly appearance: string | null | undefined;
|
|
30
30
|
readonly untouchable: boolean;
|
|
31
|
-
constructor(hovered$: Observable<boolean>, position$: Observable<TuiPoint>, destroy$: Observable<void>, accessor: TuiRectAccessor,
|
|
31
|
+
constructor(hovered$: Observable<boolean>, position$: Observable<TuiPoint>, destroy$: Observable<void>, accessor: TuiRectAccessor, el: ElementRef<HTMLElement>, options: AnimationOptions, polymorpheus: TuiContextWithImplicit<TuiPortalItem<C>>, hover: TuiHintHoverDirective, pointer: unknown, mode: TuiModeDirective | null, visualViewportService: TuiVisualViewportService);
|
|
32
32
|
get content(): PolymorpheusContent<C>;
|
|
33
33
|
get context(): C | undefined;
|
|
34
34
|
onClick(target: HTMLElement): void;
|
|
@@ -7,8 +7,8 @@ import { PolymorpheusComponent, PolymorpheusContent } from '@tinkoff/ng-polymorp
|
|
|
7
7
|
import { TuiHintOptions } from './hint-options.directive';
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
9
|
export declare class TuiHintDirective<C> implements OnDestroy, OnChanges, TuiPortalItem<C>, TuiRectAccessor, TuiVehicle {
|
|
10
|
-
private readonly
|
|
11
|
-
readonly component: PolymorpheusComponent<unknown
|
|
10
|
+
private readonly el;
|
|
11
|
+
readonly component: PolymorpheusComponent<unknown>;
|
|
12
12
|
private readonly hintService;
|
|
13
13
|
private readonly options;
|
|
14
14
|
readonly activeZone?: TuiActiveZoneDirective | null | undefined;
|
|
@@ -16,7 +16,7 @@ export declare class TuiHintDirective<C> implements OnDestroy, OnChanges, TuiPor
|
|
|
16
16
|
context?: C;
|
|
17
17
|
tuiHintAppearance: string | null;
|
|
18
18
|
readonly type = "hint";
|
|
19
|
-
constructor(
|
|
19
|
+
constructor(el: ElementRef<HTMLElement>, component: PolymorpheusComponent<unknown>, hintService: TuiHintService, options: TuiHintOptions, activeZone?: TuiActiveZoneDirective | null | undefined);
|
|
20
20
|
get appearance(): string;
|
|
21
21
|
ngOnChanges(): void;
|
|
22
22
|
ngOnDestroy(): void;
|
|
@@ -5,10 +5,10 @@ import * as i0 from "@angular/core";
|
|
|
5
5
|
* Directive scrolls element into view inside tui-scrollbar
|
|
6
6
|
*/
|
|
7
7
|
export declare class TuiScrollIntoViewDirective {
|
|
8
|
-
private readonly
|
|
8
|
+
private readonly el;
|
|
9
9
|
private readonly destroy$;
|
|
10
10
|
set tuiScrollIntoView(scroll: boolean);
|
|
11
|
-
constructor(
|
|
11
|
+
constructor(el: ElementRef<Element>, destroy$: Observable<void>);
|
|
12
12
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiScrollIntoViewDirective, [null, { self: true; }]>;
|
|
13
13
|
static ɵdir: i0.ɵɵDirectiveDeclaration<TuiScrollIntoViewDirective, "[tuiScrollIntoView]", never, { "tuiScrollIntoView": "tuiScrollIntoView"; }, {}, never>;
|
|
14
14
|
}
|
|
@@ -12,8 +12,8 @@ import * as i3 from "@tinkoff/ng-polymorpheus";
|
|
|
12
12
|
import * as i4 from "@taiga-ui/cdk";
|
|
13
13
|
// TODO: get rid of $any in template
|
|
14
14
|
export class TuiAlertComponent {
|
|
15
|
-
constructor(
|
|
16
|
-
this.
|
|
15
|
+
constructor(el, destroy$, options, animationOptions, item) {
|
|
16
|
+
this.el = el;
|
|
17
17
|
this.destroy$ = destroy$;
|
|
18
18
|
this.options = options;
|
|
19
19
|
this.animationOptions = animationOptions;
|
|
@@ -36,22 +36,22 @@ export class TuiAlertComponent {
|
|
|
36
36
|
timer(tuiIsNumber(this.autoClose)
|
|
37
37
|
? this.autoClose
|
|
38
38
|
: this.options.defaultAutoCloseTime)
|
|
39
|
-
.pipe(takeUntil(fromEvent(this.
|
|
39
|
+
.pipe(takeUntil(fromEvent(this.el.nativeElement, 'mouseenter')),
|
|
40
40
|
/**
|
|
41
41
|
* TODO: replace to
|
|
42
42
|
* repeat({
|
|
43
|
-
* delay: () => fromEvent(this.
|
|
43
|
+
* delay: () => fromEvent(this.el.nativeElement, 'mouseleave'),
|
|
44
44
|
* })
|
|
45
45
|
*
|
|
46
46
|
* in RxJS 7
|
|
47
47
|
*/
|
|
48
48
|
// eslint-disable-next-line rxjs/no-ignored-notifier
|
|
49
|
-
repeatWhen(() => fromEvent(this.
|
|
49
|
+
repeatWhen(() => fromEvent(this.el.nativeElement, 'mouseleave')), takeUntil(this.destroy$))
|
|
50
50
|
.subscribe(() => this.closeNotification());
|
|
51
51
|
}
|
|
52
52
|
}
|
|
53
53
|
TuiAlertComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiAlertComponent, deps: [{ token: ElementRef }, { token: TuiDestroyService, self: true }, { token: TUI_NOTIFICATION_OPTIONS }, { token: TUI_ANIMATION_OPTIONS }, { token: POLYMORPHEUS_CONTEXT }], target: i0.ɵɵFactoryTarget.Component });
|
|
54
|
-
TuiAlertComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiAlertComponent, selector: "tui-alert", host: { attributes: { "role": "alert" }, properties: { "@tuiFadeIn": "this.animation", "@tuiSlideInRight": "this.animation", "@tuiHeightCollapse": "this.animation" } }, providers: [TuiDestroyService], ngImport: i0, template: "<tui-notification\n
|
|
54
|
+
TuiAlertComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiAlertComponent, selector: "tui-alert", host: { attributes: { "role": "alert" }, properties: { "@tuiFadeIn": "this.animation", "@tuiSlideInRight": "this.animation", "@tuiHeightCollapse": "this.animation" } }, providers: [TuiDestroyService], ngImport: i0, template: "<tui-notification\n [status]=\"item.status\"\n [hasIcon]=\"item.hasIcon\"\n [hideClose]=\"!item.hasCloseButton\"\n (close)=\"closeNotification()\"\n>\n <label\n *ngIf=\"item.label\"\n automation-id=\"tui-notification-alert__heading\"\n class=\"t-heading\"\n >\n <!-- TODO: Polymorpheus fix type -->\n <ng-container *polymorpheusOutlet=\"$any(item.label) as text; context: item\">\n {{ text }}\n </ng-container>\n </label>\n <div\n automation-id=\"tui-notification-alert__content\"\n class=\"t-content\"\n >\n <!-- TODO: Polymorpheus fix type -->\n <div\n *polymorpheusOutlet=\"item.content as text; context: $any(item)\"\n [innerHTML]=\"text\"\n ></div>\n </div>\n</tui-notification>\n", styles: [":host{box-shadow:0 1.5rem 1rem #00000008,0 .75rem .75rem #0000000a,0 .25rem .375rem #0000000d;display:block;border-radius:var(--tui-radius-m);width:18rem;margin:2rem 3rem 0 auto}:host-context(tui-root._mobile) :host{margin:1rem 1rem 0 auto}:host:not(:first-child){margin-top:.75rem}.t-heading{font:var(--tui-font-text-m);line-height:1.25rem;font-weight:bold;margin:0}.t-content{color:var(--tui-text-01);word-wrap:break-word}.t-content:empty{display:none}\n"], components: [{ type: i1.TuiNotificationComponent, selector: "tui-notification", inputs: ["hasIcon", "status", "hideClose"], outputs: ["close"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }], animations: [tuiFadeIn, tuiSlideInRight, tuiHeightCollapse], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
55
55
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiAlertComponent, decorators: [{
|
|
56
56
|
type: Component,
|
|
57
57
|
args: [{
|
|
@@ -90,4 +90,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
90
90
|
type: HostBinding,
|
|
91
91
|
args: ['@tuiHeightCollapse']
|
|
92
92
|
}] } });
|
|
93
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
93
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alert.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/alert/alert.component.ts","../../../../../projects/core/components/alert/alert.template.html"],"names":[],"mappings":"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","sourcesContent":["import {AnimationOptions} from '@angular/animations';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    HostBinding,\n    Inject,\n    OnInit,\n    Self,\n} from '@angular/core';\nimport {TuiDestroyService, TuiDialog, tuiIsNumber} from '@taiga-ui/cdk';\nimport {tuiFadeIn, tuiHeightCollapse, tuiSlideInRight} from '@taiga-ui/core/animations';\nimport {TuiAlertOptions} from '@taiga-ui/core/interfaces';\nimport {\n    TUI_ANIMATION_OPTIONS,\n    TUI_NOTIFICATION_OPTIONS,\n    TuiNotificationDefaultOptions,\n} from '@taiga-ui/core/tokens';\nimport {POLYMORPHEUS_CONTEXT} from '@tinkoff/ng-polymorpheus';\nimport {fromEvent, timer} from 'rxjs';\nimport {repeatWhen, takeUntil} from 'rxjs/operators';\n\n// TODO: get rid of $any in template\n@Component({\n    selector: 'tui-alert',\n    templateUrl: './alert.template.html',\n    styleUrls: ['./alert.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [TuiDestroyService],\n    animations: [tuiFadeIn, tuiSlideInRight, tuiHeightCollapse],\n    host: {role: 'alert'},\n})\nexport class TuiAlertComponent<O, I> implements OnInit {\n    private readonly autoClose =\n        typeof this.item.autoClose === 'function'\n            ? this.item.autoClose(this.item.status)\n            : this.item.autoClose;\n\n    @HostBinding('@tuiFadeIn')\n    @HostBinding('@tuiSlideInRight')\n    @HostBinding('@tuiHeightCollapse')\n    readonly animation = {value: '', ...this.animationOptions} as const;\n\n    constructor(\n        @Inject(ElementRef) private readonly el: ElementRef<HTMLElement>,\n        @Self() @Inject(TuiDestroyService) private readonly destroy$: TuiDestroyService,\n        @Inject(TUI_NOTIFICATION_OPTIONS)\n        private readonly options: TuiNotificationDefaultOptions,\n        @Inject(TUI_ANIMATION_OPTIONS)\n        private readonly animationOptions: AnimationOptions,\n        @Inject(POLYMORPHEUS_CONTEXT) readonly item: TuiDialog<TuiAlertOptions<I>, O>,\n    ) {}\n\n    ngOnInit(): void {\n        this.initAutoClose();\n    }\n\n    closeNotification(): void {\n        this.item.$implicit.complete();\n    }\n\n    private initAutoClose(): void {\n        if (!this.autoClose) {\n            return;\n        }\n\n        timer(\n            tuiIsNumber(this.autoClose)\n                ? this.autoClose\n                : this.options.defaultAutoCloseTime,\n        )\n            .pipe(\n                takeUntil(fromEvent(this.el.nativeElement, 'mouseenter')),\n                /**\n                 * TODO: replace to\n                 * repeat({\n                 *    delay: () => fromEvent(this.el.nativeElement, 'mouseleave'),\n                 * })\n                 *\n                 * in RxJS 7\n                 */\n                // eslint-disable-next-line rxjs/no-ignored-notifier\n                repeatWhen(() => fromEvent(this.el.nativeElement, 'mouseleave')),\n                takeUntil(this.destroy$),\n            )\n            .subscribe(() => this.closeNotification());\n    }\n}\n","<tui-notification\n    [status]=\"item.status\"\n    [hasIcon]=\"item.hasIcon\"\n    [hideClose]=\"!item.hasCloseButton\"\n    (close)=\"closeNotification()\"\n>\n    <label\n        *ngIf=\"item.label\"\n        automation-id=\"tui-notification-alert__heading\"\n        class=\"t-heading\"\n    >\n        <!-- TODO: Polymorpheus fix type -->\n        <ng-container *polymorpheusOutlet=\"$any(item.label) as text; context: item\">\n            {{ text }}\n        </ng-container>\n    </label>\n    <div\n        automation-id=\"tui-notification-alert__content\"\n        class=\"t-content\"\n    >\n        <!-- TODO: Polymorpheus fix type -->\n        <div\n            *polymorpheusOutlet=\"item.content as text; context: $any(item)\"\n            [innerHTML]=\"text\"\n        ></div>\n    </div>\n</tui-notification>\n"]}
|
|
@@ -14,11 +14,11 @@ import * as i5 from "@tinkoff/ng-polymorpheus";
|
|
|
14
14
|
import * as i6 from "@taiga-ui/core/directives";
|
|
15
15
|
import * as i7 from "@taiga-ui/cdk";
|
|
16
16
|
export class TuiButtonComponent extends AbstractTuiInteractive {
|
|
17
|
-
constructor(mode,
|
|
17
|
+
constructor(mode, el, focusVisible$, options) {
|
|
18
18
|
var _a;
|
|
19
19
|
super();
|
|
20
20
|
this.mode = mode;
|
|
21
|
-
this.
|
|
21
|
+
this.el = el;
|
|
22
22
|
this.options = options;
|
|
23
23
|
this.mode$ = ((_a = this.mode) === null || _a === void 0 ? void 0 : _a.change$) || EMPTY;
|
|
24
24
|
this.appearance = null;
|
|
@@ -34,10 +34,10 @@ export class TuiButtonComponent extends AbstractTuiInteractive {
|
|
|
34
34
|
});
|
|
35
35
|
}
|
|
36
36
|
get nativeFocusableElement() {
|
|
37
|
-
return this.nativeDisabled ? null : this.
|
|
37
|
+
return this.nativeDisabled ? null : this.el.nativeElement;
|
|
38
38
|
}
|
|
39
39
|
get focused() {
|
|
40
|
-
return !this.showLoader && tuiIsNativeFocused(this.
|
|
40
|
+
return !this.showLoader && tuiIsNativeFocused(this.el.nativeElement);
|
|
41
41
|
}
|
|
42
42
|
get loaderSize() {
|
|
43
43
|
return this.size === 'l' || this.size === 'xl' ? 'm' : 's';
|
|
@@ -149,4 +149,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
149
149
|
type: HostListener,
|
|
150
150
|
args: ['focusout', ['false']]
|
|
151
151
|
}] } });
|
|
152
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/button/button.component.ts","../../../../../projects/core/components/button/button.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    Optional,\n} from '@angular/core';\nimport {\n    AbstractTuiInteractive,\n    tuiAsFocusableItemAccessor,\n    tuiDefaultProp,\n    TuiDestroyService,\n    TuiFocusableElementAccessor,\n    TuiFocusVisibleService,\n    tuiIsNativeFocused,\n} from '@taiga-ui/cdk';\nimport {TuiModeDirective} from '@taiga-ui/core/directives';\nimport {TuiSizeS} from '@taiga-ui/core/types';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {EMPTY, Observable} from 'rxjs';\nimport {distinctUntilChanged, map, startWith} from 'rxjs/operators';\n\nimport {TUI_BUTTON_OPTIONS, TuiButtonOptions} from './button-options';\n\n@Component({\n    selector: 'button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]',\n    templateUrl: './button.template.html',\n    styleUrls: ['./button.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiButtonComponent),\n        TuiDestroyService,\n        TuiFocusVisibleService,\n    ],\n})\nexport class TuiButtonComponent\n    extends AbstractTuiInteractive\n    implements TuiFocusableElementAccessor, TuiButtonOptions\n{\n    private readonly mode$: Observable<unknown> = this.mode?.change$ || EMPTY;\n\n    @Input()\n    @tuiDefaultProp()\n    appearance: TuiButtonOptions['appearance'] = null;\n\n    @Input()\n    @tuiDefaultProp()\n    disabled = false;\n\n    @Input()\n    @tuiDefaultProp()\n    icon: PolymorpheusContent = '';\n\n    @Input()\n    @tuiDefaultProp()\n    iconRight: PolymorpheusContent = '';\n\n    @Input()\n    @HostBinding('attr.data-shape')\n    @tuiDefaultProp()\n    shape = this.options.shape;\n\n    @Input()\n    @HostBinding('class._loading')\n    @tuiDefaultProp()\n    showLoader = false;\n\n    @Input()\n    @HostBinding('attr.data-size')\n    @tuiDefaultProp()\n    size = this.options.size;\n\n    readonly appearance$ = this.mode$.pipe(\n        startWith(null),\n        map(() => this.computedAppearance),\n        distinctUntilChanged(),\n    );\n\n    constructor(\n        @Optional()\n        @Inject(TuiModeDirective)\n        private readonly mode: TuiModeDirective | null,\n        @Inject(ElementRef) private readonly elementRef: ElementRef<HTMLElement>,\n        @Inject(TuiFocusVisibleService) focusVisible$: TuiFocusVisibleService,\n        @Inject(TUI_BUTTON_OPTIONS) private readonly options: TuiButtonOptions,\n    ) {\n        super();\n        focusVisible$.subscribe(focusVisible => {\n            this.updateFocusVisible(focusVisible);\n        });\n    }\n\n    get nativeFocusableElement(): HTMLElement | null {\n        return this.nativeDisabled ? null : this.elementRef.nativeElement;\n    }\n\n    get focused(): boolean {\n        return !this.showLoader && tuiIsNativeFocused(this.elementRef.nativeElement);\n    }\n\n    get loaderSize(): TuiSizeS {\n        return this.size === 'l' || this.size === 'xl' ? 'm' : 's';\n    }\n\n    @HostBinding('attr.data-appearance')\n    get computedAppearance(): string {\n        return this.appearance ?? (this.options.appearance || '');\n    }\n\n    @HostBinding('attr.disabled')\n    get nativeDisabled(): '' | null {\n        return this.computedDisabled || this.showLoader ? '' : null;\n    }\n\n    @HostBinding('tabIndex')\n    get tabIndex(): number {\n        return this.focusable ? 0 : -1;\n    }\n\n    @HostListener('focusin', ['true'])\n    @HostListener('focusout', ['false'])\n    onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n    }\n}\n","<ng-container *ngIf=\"appearance$ | async\"></ng-container>\n<div\n    tuiWrapper\n    class=\"t-wrapper\"\n    [appearance]=\"computedAppearance\"\n    [hover]=\"pseudoHover\"\n    [active]=\"pseudoActive\"\n    [disabled]=\"computedDisabled\"\n    [focus]=\"computedFocusVisible\"\n>\n    <span class=\"t-content\">\n        <span\n            *ngIf=\"icon\"\n            class=\"t-left\"\n        >\n            <tui-svg\n                *polymorpheusOutlet=\"icon as text\"\n                class=\"t-icon\"\n                [src]=\"text\"\n            ></tui-svg>\n        </span>\n        <ng-content></ng-content>\n        <span\n            *ngIf=\"iconRight\"\n            class=\"t-right\"\n        >\n            <tui-svg\n                *polymorpheusOutlet=\"iconRight as text\"\n                class=\"t-icon\"\n                [src]=\"text\"\n            ></tui-svg>\n        </span>\n    </span>\n    <tui-loader\n        *ngIf=\"showLoader\"\n        class=\"t-loader\"\n        [size]=\"loaderSize\"\n        [inheritColor]=\"true\"\n    ></tui-loader>\n</div>\n"]}
|
|
152
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/button/button.component.ts","../../../../../projects/core/components/button/button.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    Optional,\n} from '@angular/core';\nimport {\n    AbstractTuiInteractive,\n    tuiAsFocusableItemAccessor,\n    tuiDefaultProp,\n    TuiDestroyService,\n    TuiFocusableElementAccessor,\n    TuiFocusVisibleService,\n    tuiIsNativeFocused,\n} from '@taiga-ui/cdk';\nimport {TuiModeDirective} from '@taiga-ui/core/directives';\nimport {TuiSizeS} from '@taiga-ui/core/types';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {EMPTY, Observable} from 'rxjs';\nimport {distinctUntilChanged, map, startWith} from 'rxjs/operators';\n\nimport {TUI_BUTTON_OPTIONS, TuiButtonOptions} from './button-options';\n\n@Component({\n    selector: 'button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]',\n    templateUrl: './button.template.html',\n    styleUrls: ['./button.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiButtonComponent),\n        TuiDestroyService,\n        TuiFocusVisibleService,\n    ],\n})\nexport class TuiButtonComponent\n    extends AbstractTuiInteractive\n    implements TuiFocusableElementAccessor, TuiButtonOptions\n{\n    private readonly mode$: Observable<unknown> = this.mode?.change$ || EMPTY;\n\n    @Input()\n    @tuiDefaultProp()\n    appearance: TuiButtonOptions['appearance'] = null;\n\n    @Input()\n    @tuiDefaultProp()\n    disabled = false;\n\n    @Input()\n    @tuiDefaultProp()\n    icon: PolymorpheusContent = '';\n\n    @Input()\n    @tuiDefaultProp()\n    iconRight: PolymorpheusContent = '';\n\n    @Input()\n    @HostBinding('attr.data-shape')\n    @tuiDefaultProp()\n    shape = this.options.shape;\n\n    @Input()\n    @HostBinding('class._loading')\n    @tuiDefaultProp()\n    showLoader = false;\n\n    @Input()\n    @HostBinding('attr.data-size')\n    @tuiDefaultProp()\n    size = this.options.size;\n\n    readonly appearance$ = this.mode$.pipe(\n        startWith(null),\n        map(() => this.computedAppearance),\n        distinctUntilChanged(),\n    );\n\n    constructor(\n        @Optional()\n        @Inject(TuiModeDirective)\n        private readonly mode: TuiModeDirective | null,\n        @Inject(ElementRef) private readonly el: ElementRef<HTMLElement>,\n        @Inject(TuiFocusVisibleService) focusVisible$: TuiFocusVisibleService,\n        @Inject(TUI_BUTTON_OPTIONS) private readonly options: TuiButtonOptions,\n    ) {\n        super();\n        focusVisible$.subscribe(focusVisible => {\n            this.updateFocusVisible(focusVisible);\n        });\n    }\n\n    get nativeFocusableElement(): HTMLElement | null {\n        return this.nativeDisabled ? null : this.el.nativeElement;\n    }\n\n    get focused(): boolean {\n        return !this.showLoader && tuiIsNativeFocused(this.el.nativeElement);\n    }\n\n    get loaderSize(): TuiSizeS {\n        return this.size === 'l' || this.size === 'xl' ? 'm' : 's';\n    }\n\n    @HostBinding('attr.data-appearance')\n    get computedAppearance(): string {\n        return this.appearance ?? (this.options.appearance || '');\n    }\n\n    @HostBinding('attr.disabled')\n    get nativeDisabled(): '' | null {\n        return this.computedDisabled || this.showLoader ? '' : null;\n    }\n\n    @HostBinding('tabIndex')\n    get tabIndex(): number {\n        return this.focusable ? 0 : -1;\n    }\n\n    @HostListener('focusin', ['true'])\n    @HostListener('focusout', ['false'])\n    onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n    }\n}\n","<ng-container *ngIf=\"appearance$ | async\"></ng-container>\n<div\n    tuiWrapper\n    class=\"t-wrapper\"\n    [appearance]=\"computedAppearance\"\n    [hover]=\"pseudoHover\"\n    [active]=\"pseudoActive\"\n    [disabled]=\"computedDisabled\"\n    [focus]=\"computedFocusVisible\"\n>\n    <span class=\"t-content\">\n        <span\n            *ngIf=\"icon\"\n            class=\"t-left\"\n        >\n            <tui-svg\n                *polymorpheusOutlet=\"icon as text\"\n                class=\"t-icon\"\n                [src]=\"text\"\n            ></tui-svg>\n        </span>\n        <ng-content></ng-content>\n        <span\n            *ngIf=\"iconRight\"\n            class=\"t-right\"\n        >\n            <tui-svg\n                *polymorpheusOutlet=\"iconRight as text\"\n                class=\"t-icon\"\n                [src]=\"text\"\n            ></tui-svg>\n        </span>\n    </span>\n    <tui-loader\n        *ngIf=\"showLoader\"\n        class=\"t-loader\"\n        [size]=\"loaderSize\"\n        [inheritColor]=\"true\"\n    ></tui-loader>\n</div>\n"]}
|
|
@@ -14,10 +14,10 @@ import * as i3 from "@taiga-ui/core/directives";
|
|
|
14
14
|
import * as i4 from "rxjs";
|
|
15
15
|
// TODO: Consider aria-activedescendant for proper accessibility implementation
|
|
16
16
|
export class TuiDataListComponent {
|
|
17
|
-
constructor(controller,
|
|
17
|
+
constructor(controller, el, defaultEmptyContent$) {
|
|
18
18
|
var _a;
|
|
19
19
|
this.controller = controller;
|
|
20
|
-
this.
|
|
20
|
+
this.el = el;
|
|
21
21
|
this.defaultEmptyContent$ = defaultEmptyContent$;
|
|
22
22
|
this.options = EMPTY_QUERY;
|
|
23
23
|
this.role = 'listbox';
|
|
@@ -38,7 +38,7 @@ export class TuiDataListComponent {
|
|
|
38
38
|
tuiMoveFocus(elements.indexOf(current), elements, step);
|
|
39
39
|
}
|
|
40
40
|
// TODO: Consider aria-activedescendant for proper accessibility implementation
|
|
41
|
-
handleFocusLossIfNecessary(element = this.
|
|
41
|
+
handleFocusLossIfNecessary(element = this.el.nativeElement) {
|
|
42
42
|
if (this.origin && tuiIsNativeFocusedIn(element)) {
|
|
43
43
|
tuiSetNativeMouseFocused(this.origin, true, true);
|
|
44
44
|
}
|
|
@@ -58,7 +58,7 @@ export class TuiDataListComponent {
|
|
|
58
58
|
this.handleFocusLossIfNecessary(target);
|
|
59
59
|
}
|
|
60
60
|
get elements() {
|
|
61
|
-
return Array.from(this.
|
|
61
|
+
return Array.from(this.el.nativeElement.querySelectorAll('[tuiOption]'));
|
|
62
62
|
}
|
|
63
63
|
}
|
|
64
64
|
TuiDataListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDataListComponent, deps: [{ token: TUI_TEXTFIELD_WATCHED_CONTROLLER, optional: true }, { token: ElementRef }, { token: TUI_NOTHING_FOUND_MESSAGE }], target: i0.ɵɵFactoryTarget.Component });
|
|
@@ -136,4 +136,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
136
136
|
type: HostListener,
|
|
137
137
|
args: ['mouseleave', ['$event.target']]
|
|
138
138
|
}] } });
|
|
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    tuiMoveFocus,\n    tuiPure,\n    tuiQueryListChanges,\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 tuiQueryListChanges(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    tuiMoveFocus,\n    tuiPure,\n    tuiQueryListChanges,\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 el: ElementRef<HTMLElement>,\n        @Inject(TUI_NOTHING_FOUND_MESSAGE)\n        readonly defaultEmptyContent$: Observable<string>,\n    ) {}\n\n    @tuiPure\n    get empty$(): Observable<boolean> {\n        return tuiQueryListChanges(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.el.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.el.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"]}
|