@taiga-ui/core 3.23.1-dev.main-d8b7500 → 3.23.1-dev.main-3d032b2
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 +5 -5
- 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-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 +2 -10
- 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 +6 -5
- 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/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/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/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 +2 -2
- 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 +2 -2
- package/directives/scroll-into-view/scroll-into-view.directive.d.ts +2 -2
- package/esm2015/components/alert/alert.component.js +6 -6
- 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/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 +6 -14
- 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/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 +2 -2
- package/esm2015/utils/mask/create-correction-mask.js +3 -2
- package/esm2015/utils/mask/create-number-mask.js +4 -4
- package/esm2015/utils/mobile/is-mobile.js +3 -3
- package/fesm2015/taiga-ui-core-components-alert.js +5 -5
- 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-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 +5 -13
- 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 +6 -5
- 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/internal/svg-defs-host/svg-defs-host.component.d.ts +2 -2
- package/package.json +1 -1
- 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
|
@@ -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,7 +5,7 @@ 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;
|
|
@@ -13,7 +13,7 @@ export declare class TuiDropdownDirective implements AfterViewChecked, OnDestroy
|
|
|
13
13
|
dropdownBoxRef: ComponentRef<unknown> | null;
|
|
14
14
|
readonly type = "dropdown";
|
|
15
15
|
readonly component: PolymorpheusComponent<unknown, unknown>;
|
|
16
|
-
constructor(
|
|
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,7 +7,7 @@ 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
|
|
10
|
+
private readonly el;
|
|
11
11
|
readonly component: PolymorpheusComponent<unknown, any>;
|
|
12
12
|
private readonly hintService;
|
|
13
13
|
private readonly options;
|
|
@@ -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, any>, 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,17 +36,17 @@ 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
|
}
|
|
@@ -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    *ngIf=\"item.hasCloseButton; else noClose\"\n    [status]=\"item.status\"\n    [hasIcon]=\"item.hasIcon\"\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        <ng-container *polymorpheusOutlet=\"item.content as text; context: $any(item)\">\n            {{ text }}\n        </ng-container>\n    </div>\n</tui-notification>\n<ng-template #noClose>\n    <tui-notification\n        [status]=\"item.status\"\n        [hasIcon]=\"item.hasIcon\"\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            <ng-container *polymorpheusOutlet=\"item.content as text; context: $any(item)\">\n                {{ text }}\n            </ng-container>\n        </div>\n    </tui-notification>\n</ng-template>\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"]}
|
|
@@ -18,10 +18,10 @@ function shouldFocus({ currentTarget }) {
|
|
|
18
18
|
}
|
|
19
19
|
// TODO: Consider all use cases for aria roles
|
|
20
20
|
export class TuiOptionComponent {
|
|
21
|
-
constructor(content, dataList,
|
|
21
|
+
constructor(content, dataList, el, host, dropdown) {
|
|
22
22
|
this.content = content;
|
|
23
23
|
this.dataList = dataList;
|
|
24
|
-
this.
|
|
24
|
+
this.el = el;
|
|
25
25
|
this.host = host;
|
|
26
26
|
this.dropdown = dropdown;
|
|
27
27
|
/** @deprecated use size on {@link TuiDataListComponent} instead */
|
|
@@ -43,7 +43,7 @@ export class TuiOptionComponent {
|
|
|
43
43
|
}
|
|
44
44
|
// Preventing focus loss upon focused option removal
|
|
45
45
|
ngOnDestroy() {
|
|
46
|
-
this.dataList.handleFocusLossIfNecessary(this.
|
|
46
|
+
this.dataList.handleFocusLossIfNecessary(this.el.nativeElement);
|
|
47
47
|
}
|
|
48
48
|
}
|
|
49
49
|
TuiOptionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiOptionComponent, deps: [{ token: TUI_OPTION_CONTENT, optional: true }, { token: forwardRef(() => TuiDataListComponent) }, { token: ElementRef }, { token: TUI_DATA_LIST_HOST, optional: true }, { token: TuiDropdownDirective, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
@@ -120,4 +120,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
120
120
|
type: HostListener,
|
|
121
121
|
args: ['mousemove.silent', ['$event']]
|
|
122
122
|
}] } });
|
|
123
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
123
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"option.component.js","sourceRoot":"","sources":["../../../../../../projects/core/components/data-list/option/option.component.ts","../../../../../../projects/core/components/data-list/option/option.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    forwardRef,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    OnDestroy,\n    Optional,\n    Self,\n    TemplateRef,\n} from '@angular/core';\nimport {\n    TuiContextWithImplicit,\n    tuiDefaultProp,\n    TuiEventWith,\n    tuiIsNativeFocused,\n} from '@taiga-ui/cdk';\nimport {TuiDropdownDirective} from '@taiga-ui/core/directives/dropdown';\nimport {TuiDataListHost} from '@taiga-ui/core/interfaces';\nimport {TUI_DATA_LIST_HOST, TUI_OPTION_CONTENT} from '@taiga-ui/core/tokens';\nimport {TuiOptionRole, TuiSizeL, TuiSizeXS} from '@taiga-ui/core/types';\nimport {shouldCall} from '@tinkoff/ng-event-plugins';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\n\n// TODO: find the best way for prevent cycle\n// eslint-disable-next-line import/no-cycle\nimport {TuiDataListComponent} from '../data-list.component';\n\nfunction shouldFocus({currentTarget}: TuiEventWith<MouseEvent, HTMLElement>): boolean {\n    return !tuiIsNativeFocused(currentTarget);\n}\n\n// TODO: Consider all use cases for aria roles\n@Component({\n    selector: 'button[tuiOption], a[tuiOption]',\n    templateUrl: './option.template.html',\n    styleUrls: ['./option.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        tabIndex: '-1',\n        type: 'button',\n        '[attr.disabled]': 'disabled || null',\n    },\n})\nexport class TuiOptionComponent<T = unknown> implements OnDestroy {\n    /** @deprecated use size on {@link TuiDataListComponent} instead */\n    @Input()\n    @HostBinding('attr.data-size')\n    @tuiDefaultProp()\n    size: TuiSizeL | TuiSizeXS | null = null;\n\n    @Input()\n    @HostBinding('attr.role')\n    @tuiDefaultProp()\n    role: TuiOptionRole = 'option';\n\n    @Input()\n    @tuiDefaultProp()\n    disabled = false;\n\n    @Input()\n    value?: T;\n\n    constructor(\n        @Optional()\n        @Inject(TUI_OPTION_CONTENT)\n        readonly content: PolymorpheusContent<\n            TuiContextWithImplicit<TemplateRef<Record<string, unknown>>>\n        > | null,\n        @Inject(forwardRef(() => TuiDataListComponent))\n        private readonly dataList: TuiDataListComponent<T>,\n        @Inject(ElementRef) private readonly el: ElementRef<HTMLElement>,\n        @Optional()\n        @Inject(TUI_DATA_LIST_HOST)\n        private readonly host: TuiDataListHost<T> | null,\n        @Optional()\n        @Self()\n        @Inject(TuiDropdownDirective)\n        readonly dropdown: TuiDropdownDirective | null,\n    ) {}\n\n    @HostBinding('class._with-dropdown')\n    get active(): boolean {\n        return !!this.dropdown && !!this.dropdown.dropdownBoxRef;\n    }\n\n    @HostListener('click')\n    onClick(): void {\n        if (this.host && this.value !== undefined) {\n            this.host.handleOption(this.value);\n        }\n    }\n\n    // @bad TODO: Consider aria-activedescendant for proper accessibility implementation\n    @shouldCall(shouldFocus)\n    @HostListener('mousemove.silent', ['$event'])\n    onMouseMove({currentTarget}: TuiEventWith<MouseEvent, HTMLElement>): void {\n        currentTarget.focus({preventScroll: true});\n    }\n\n    // Preventing focus loss upon focused option removal\n    ngOnDestroy(): void {\n        this.dataList.handleFocusLossIfNecessary(this.el.nativeElement);\n    }\n}\n","<ng-container *polymorpheusOutlet=\"content || base as text; context: {$implicit: base}\">\n    {{ text }}\n</ng-container>\n<ng-template #base>\n    <ng-content></ng-content>\n    <tui-svg\n        *ngIf=\"dropdown\"\n        src=\"tuiIconChevronRight\"\n        class=\"t-arrow\"\n    ></tui-svg>\n</ng-template>\n"]}
|