@taiga-ui/core 4.0.0-rc.5 → 4.0.0-rc.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/data-list/data-list.component.d.ts +5 -4
- package/components/data-list/data-list.tokens.d.ts +1 -1
- package/components/data-list/option.component.d.ts +1 -3
- package/components/dialog/dialog.component.d.ts +1 -0
- package/components/textfield/textfield.component.d.ts +0 -1
- package/components/textfield/textfield.options.d.ts +1 -2
- package/directives/appearance/appearance.directive.d.ts +1 -0
- package/directives/dropdown/dropdown-context.directive.d.ts +7 -0
- package/directives/dropdown/dropdown-manual.directive.d.ts +1 -1
- package/directives/dropdown/dropdown-open-legacy.directive.d.ts +11 -0
- package/directives/dropdown/dropdown-open.directive.d.ts +3 -3
- package/directives/dropdown/dropdown-position.directive.d.ts +1 -1
- package/directives/dropdown/dropdown.component.d.ts +2 -5
- package/directives/dropdown/dropdown.d.ts +2 -1
- package/directives/dropdown/dropdown.directive.d.ts +1 -1
- package/directives/dropdown/index.d.ts +1 -0
- package/directives/hint/hint-host.directive.d.ts +1 -1
- package/directives/hint/hint-options.directive.d.ts +5 -3
- package/directives/hint/hint-overflow.directive.d.ts +8 -0
- package/directives/hint/hint-pointer.directive.d.ts +1 -1
- package/directives/hint/hint.component.d.ts +1 -0
- package/directives/hint/hint.d.ts +2 -1
- package/directives/hint/index.d.ts +1 -0
- package/esm2022/components/button/button.directive.mjs +1 -1
- package/esm2022/components/data-list/data-list.component.mjs +14 -17
- package/esm2022/components/data-list/data-list.tokens.mjs +1 -1
- package/esm2022/components/data-list/option.component.mjs +6 -9
- package/esm2022/components/dialog/dialog-close.service.mjs +3 -3
- package/esm2022/components/dialog/dialog.component.mjs +6 -5
- package/esm2022/components/icon/icon.component.mjs +5 -6
- package/esm2022/components/label/label.directive.mjs +6 -6
- package/esm2022/components/link/link.directive.mjs +5 -5
- package/esm2022/components/root/root.component.mjs +3 -3
- package/esm2022/components/scrollbar/scroll-controls.component.mjs +3 -3
- package/esm2022/components/scrollbar/scrollbar.directive.mjs +3 -3
- package/esm2022/components/textfield/select.directive.mjs +3 -3
- package/esm2022/components/textfield/textfield.component.mjs +6 -8
- package/esm2022/components/textfield/textfield.options.mjs +4 -6
- package/esm2022/directives/appearance/appearance.directive.mjs +14 -2
- package/esm2022/directives/dropdown/dropdown-context.directive.mjs +55 -4
- package/esm2022/directives/dropdown/dropdown-manual.directive.mjs +2 -2
- package/esm2022/directives/dropdown/dropdown-open-legacy.directive.mjs +29 -0
- package/esm2022/directives/dropdown/dropdown-open.directive.mjs +19 -24
- package/esm2022/directives/dropdown/dropdown-position.directive.mjs +2 -2
- package/esm2022/directives/dropdown/dropdown-selection.directive.mjs +2 -2
- package/esm2022/directives/dropdown/dropdown.component.mjs +22 -41
- package/esm2022/directives/dropdown/dropdown.directive.mjs +11 -11
- package/esm2022/directives/dropdown/dropdown.mjs +3 -1
- package/esm2022/directives/dropdown/index.mjs +2 -1
- package/esm2022/directives/hint/hint-host.directive.mjs +1 -1
- package/esm2022/directives/hint/hint-options.directive.mjs +9 -6
- package/esm2022/directives/hint/hint-overflow.directive.mjs +32 -0
- package/esm2022/directives/hint/hint-pointer.directive.mjs +1 -1
- package/esm2022/directives/hint/hint.component.mjs +16 -16
- package/esm2022/directives/hint/hint.mjs +3 -1
- package/esm2022/directives/hint/index.mjs +2 -1
- package/esm2022/directives/icons/icons.directive.mjs +1 -1
- package/esm2022/directives/title/title.directive.mjs +1 -1
- package/esm2022/services/dark-theme.service.mjs +3 -3
- package/esm2022/services/position.service.mjs +5 -5
- package/esm2022/services/visual-viewport.service.mjs +3 -3
- package/esm2022/tokens/viewport.mjs +3 -3
- package/fesm2022/taiga-ui-core-components-button.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-components-data-list.mjs +18 -24
- package/fesm2022/taiga-ui-core-components-data-list.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-components-dialog.mjs +7 -6
- package/fesm2022/taiga-ui-core-components-dialog.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-components-icon.mjs +4 -5
- package/fesm2022/taiga-ui-core-components-icon.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-components-label.mjs +5 -5
- package/fesm2022/taiga-ui-core-components-label.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-components-link.mjs +4 -4
- package/fesm2022/taiga-ui-core-components-link.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-components-root.mjs +2 -2
- package/fesm2022/taiga-ui-core-components-root.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-components-scrollbar.mjs +3 -3
- package/fesm2022/taiga-ui-core-components-scrollbar.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-components-textfield.mjs +9 -13
- package/fesm2022/taiga-ui-core-components-textfield.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-directives-appearance.mjs +13 -2
- package/fesm2022/taiga-ui-core-directives-appearance.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-directives-dropdown.mjs +132 -80
- package/fesm2022/taiga-ui-core-directives-dropdown.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-directives-hint.mjs +51 -21
- package/fesm2022/taiga-ui-core-directives-hint.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-directives-icons.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-directives-title.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-services.mjs +5 -5
- package/fesm2022/taiga-ui-core-services.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-tokens.mjs +2 -2
- package/fesm2022/taiga-ui-core-tokens.mjs.map +1 -1
- package/package.json +9 -10
- package/styles/components/appearance.less +38 -0
- package/styles/components/button.less +134 -0
- package/styles/components/icon.less +38 -0
- package/styles/components/icons.less +41 -0
- package/styles/components/label.less +62 -0
- package/styles/components/link.less +55 -0
- package/styles/components/title.less +60 -0
- package/styles/taiga-ui-fonts.less +3 -1
- package/styles/theme/appearance/accent.less +1 -1
- package/styles/theme/appearance/floating.less +1 -1
- package/styles/theme/appearance/glass.less +1 -1
- package/styles/theme/appearance/icon.less +1 -1
- package/styles/theme/appearance/opposite.less +1 -1
- package/styles/theme/appearance/outline.less +1 -1
- package/styles/theme/appearance/primary.less +1 -1
- package/styles/theme/appearance/secondary.less +1 -1
- package/styles/theme/appearance/status.less +1 -1
- package/styles/theme/appearance/textfield.less +1 -1
- package/styles/theme/appearance.less +0 -1
- package/styles/theme/variables.less +2 -2
- package/styles/theme/wrapper.less +1 -1
- package/styles/theme/appearance/base.less +0 -19
|
@@ -1,20 +1,21 @@
|
|
|
1
|
+
import type { AfterContentChecked } from '@angular/core';
|
|
1
2
|
import type { TuiSizeL, TuiSizeS } from '@taiga-ui/core/types';
|
|
2
3
|
import type { PolymorpheusContent } from '@taiga-ui/polymorpheus';
|
|
3
|
-
import type { Observable } from 'rxjs';
|
|
4
4
|
import type { TuiDataListAccessor } from './data-list.tokens';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export declare function tuiInjectDataListSize(): TuiSizeL | TuiSizeS;
|
|
7
|
-
export declare class TuiDataListComponent<T> implements TuiDataListAccessor<T
|
|
7
|
+
export declare class TuiDataListComponent<T> implements TuiDataListAccessor<T>, AfterContentChecked {
|
|
8
8
|
private readonly options;
|
|
9
9
|
private origin?;
|
|
10
10
|
private readonly el;
|
|
11
|
-
protected readonly
|
|
11
|
+
protected readonly fallback: import("@angular/core").Signal<string | undefined>;
|
|
12
|
+
protected empty: boolean;
|
|
12
13
|
emptyContent: PolymorpheusContent;
|
|
13
14
|
size: "m" | "l" | "s";
|
|
14
15
|
onKeyDownArrow(current: HTMLElement, step: number): void;
|
|
15
16
|
handleFocusLossIfNecessary(element?: Element): void;
|
|
17
|
+
ngAfterContentChecked(): void;
|
|
16
18
|
getOptions(includeDisabled?: boolean): readonly T[];
|
|
17
|
-
protected get empty$(): Observable<boolean>;
|
|
18
19
|
protected onFocusIn(relatedTarget: HTMLElement, currentTarget: HTMLElement): void;
|
|
19
20
|
protected noop(): void;
|
|
20
21
|
private get elements();
|
|
@@ -8,7 +8,7 @@ export interface TuiDataListAccessor<T = unknown> {
|
|
|
8
8
|
}
|
|
9
9
|
export interface TuiDataListHost<T> {
|
|
10
10
|
checkOption?(option: T): void;
|
|
11
|
-
handleOption(option: T): void;
|
|
11
|
+
handleOption?(option: T): void;
|
|
12
12
|
readonly identityMatcher?: TuiIdentityMatcher<T>;
|
|
13
13
|
readonly stringify?: TuiStringHandler<T>;
|
|
14
14
|
readonly size?: TuiSizeL | TuiSizeS;
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import type { OnDestroy, TemplateRef } from '@angular/core';
|
|
2
2
|
import type { TuiContext } from '@taiga-ui/cdk/types';
|
|
3
|
-
import { TuiDropdownDirective } from '@taiga-ui/core/directives/dropdown';
|
|
4
3
|
import type { PolymorpheusContent } from '@taiga-ui/polymorpheus';
|
|
5
4
|
import * as i0 from "@angular/core";
|
|
6
5
|
import * as i1 from "@taiga-ui/core/directives/icons";
|
|
@@ -10,11 +9,10 @@ export declare class TuiOption<T = unknown> implements OnDestroy {
|
|
|
10
9
|
private readonly dataList;
|
|
11
10
|
private readonly host;
|
|
12
11
|
protected readonly content: PolymorpheusContent<TuiContext<TemplateRef<Record<string, unknown>>>>;
|
|
13
|
-
protected readonly dropdown:
|
|
12
|
+
protected readonly dropdown: import("@angular/core").WritableSignal<import("@angular/core").ComponentRef<unknown> | null> | undefined;
|
|
14
13
|
disabled: boolean;
|
|
15
14
|
value?: T;
|
|
16
15
|
ngOnDestroy(): void;
|
|
17
|
-
protected get active(): boolean;
|
|
18
16
|
protected onClick(): void;
|
|
19
17
|
protected onMouseMove(): void;
|
|
20
18
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiOption<any>, never>;
|
|
@@ -14,6 +14,7 @@ export declare class TuiDialogComponent<O, I> {
|
|
|
14
14
|
protected readonly context: TuiPopover<TuiDialogOptions<I>, O>;
|
|
15
15
|
protected readonly closeWord$: Observable<string>;
|
|
16
16
|
protected readonly icons: import("@taiga-ui/core/tokens").TuiCommonIcons;
|
|
17
|
+
protected closeable$: Observable<boolean>;
|
|
17
18
|
constructor();
|
|
18
19
|
protected get size(): TuiDialogSize;
|
|
19
20
|
protected get header(): PolymorpheusContent<TuiPopover<TuiDialogOptions<I>, O>>;
|
|
@@ -16,7 +16,6 @@ export declare class TuiTextfieldComponent<T> implements TuiDataListHost<T> {
|
|
|
16
16
|
protected readonly label?: ElementRef<HTMLElement>;
|
|
17
17
|
protected readonly control?: NgControl;
|
|
18
18
|
protected side: number;
|
|
19
|
-
protected readonly change$: import("rxjs").Subject<void> | undefined;
|
|
20
19
|
protected readonly options: import("./textfield.options").TuiTextfieldOptions;
|
|
21
20
|
protected readonly icons: import("@taiga-ui/core/tokens").TuiCommonIcons;
|
|
22
21
|
readonly el?: ElementRef<HTMLInputElement>;
|
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import type { Provider, WritableSignal } from '@angular/core';
|
|
2
|
-
import { AbstractTuiController } from '@taiga-ui/cdk/classes';
|
|
3
2
|
import type { TuiSizeL, TuiSizeS } from '@taiga-ui/core/types';
|
|
4
3
|
import * as i0 from "@angular/core";
|
|
5
4
|
export interface TuiTextfieldOptions {
|
|
@@ -9,7 +8,7 @@ export interface TuiTextfieldOptions {
|
|
|
9
8
|
}
|
|
10
9
|
export declare const TUI_TEXTFIELD_OPTIONS: import("@angular/core").InjectionToken<TuiTextfieldOptions>;
|
|
11
10
|
export declare function tuiTextfieldOptionsProvider(options: Partial<TuiTextfieldOptions>): Provider;
|
|
12
|
-
export declare class TuiTextfieldOptionsDirective
|
|
11
|
+
export declare class TuiTextfieldOptionsDirective implements TuiTextfieldOptions {
|
|
13
12
|
private readonly options;
|
|
14
13
|
appearance: WritableSignal<string>;
|
|
15
14
|
size: WritableSignal<"l" | "m" | "s">;
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import type { TuiInteractiveState } from '@taiga-ui/core/types';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export declare class TuiAppearance {
|
|
4
|
+
protected readonly nothing: undefined;
|
|
4
5
|
tuiAppearance: string;
|
|
5
6
|
tuiAppearanceState: TuiInteractiveState | null;
|
|
6
7
|
tuiAppearanceFocus: boolean | null;
|
|
@@ -2,13 +2,20 @@ import { TuiActiveZone } from '@taiga-ui/cdk/directives/active-zone';
|
|
|
2
2
|
import { TuiRectAccessor } from '@taiga-ui/core/classes';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export declare class TuiDropdownContext extends TuiRectAccessor {
|
|
5
|
+
private readonly isIOS;
|
|
6
|
+
private readonly isTouch;
|
|
5
7
|
private readonly driver;
|
|
6
8
|
private currentRect;
|
|
9
|
+
private longTapTimeout;
|
|
10
|
+
protected readonly userSelect: import("@angular/core").Signal<"none" | null>;
|
|
7
11
|
protected readonly activeZone: TuiActiveZone;
|
|
8
12
|
readonly type = "dropdown";
|
|
9
13
|
getClientRect(): DOMRect;
|
|
10
14
|
protected onContextMenu(x: number, y: number): void;
|
|
11
15
|
protected closeDropdown(): void;
|
|
16
|
+
protected onTouchStart(x: number, y: number): void;
|
|
17
|
+
protected onTouchMove(x: number, y: number): void;
|
|
18
|
+
protected onTouchEnd(): void;
|
|
12
19
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiDropdownContext, never>;
|
|
13
20
|
static ɵdir: i0.ɵɵDirectiveDeclaration<TuiDropdownContext, "[tuiDropdownContext]", never, {}, {}, never, never, true, never>;
|
|
14
21
|
}
|
|
@@ -2,7 +2,7 @@ import type { OnChanges } from '@angular/core';
|
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export declare class TuiDropdownManual implements OnChanges {
|
|
4
4
|
private readonly driver;
|
|
5
|
-
tuiDropdownManual: boolean;
|
|
5
|
+
tuiDropdownManual: boolean | '';
|
|
6
6
|
ngOnChanges(): void;
|
|
7
7
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiDropdownManual, never>;
|
|
8
8
|
static ɵdir: i0.ɵɵDirectiveDeclaration<TuiDropdownManual, "[tuiDropdownManual]", never, { "tuiDropdownManual": { "alias": "tuiDropdownManual"; "required": false; }; }, {}, never, never, true, never>;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { BehaviorSubject } from 'rxjs';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
/**
|
|
4
|
+
* @deprecated TODO: remove in v.5 when legacy controls are dropped
|
|
5
|
+
*/
|
|
6
|
+
export declare class TuiDropdownOpenLegacy {
|
|
7
|
+
readonly tuiDropdownOpenChange: BehaviorSubject<boolean>;
|
|
8
|
+
set tuiDropdownOpen(open: boolean);
|
|
9
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TuiDropdownOpenLegacy, never>;
|
|
10
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<TuiDropdownOpenLegacy, "[tuiDropdownOpen]:not([tuiDropdown]),[tuiDropdownOpenChange]:not([tuiDropdown])", never, { "tuiDropdownOpen": { "alias": "tuiDropdownOpen"; "required": false; }; }, { "tuiDropdownOpenChange": "tuiDropdownOpenChange"; }, never, never, true, never>;
|
|
11
|
+
}
|
|
@@ -9,13 +9,12 @@ export declare class TuiDropdownOpen implements OnChanges {
|
|
|
9
9
|
private readonly directive;
|
|
10
10
|
private readonly el;
|
|
11
11
|
private readonly obscured;
|
|
12
|
+
private readonly dropdown;
|
|
12
13
|
protected readonly sub: import("rxjs").Subscription;
|
|
13
14
|
tuiDropdownEnabled: boolean;
|
|
14
15
|
tuiDropdownOpen: boolean | '';
|
|
15
16
|
readonly tuiDropdownOpenChange: EventEmitter<boolean>;
|
|
16
17
|
readonly driver: TuiDropdownDriver;
|
|
17
|
-
get dropdown(): HTMLElement | undefined;
|
|
18
|
-
get focused(): boolean;
|
|
19
18
|
ngOnChanges(): void;
|
|
20
19
|
toggle(open: boolean): void;
|
|
21
20
|
protected onClick(target: HTMLElement): void;
|
|
@@ -24,9 +23,10 @@ export declare class TuiDropdownOpen implements OnChanges {
|
|
|
24
23
|
protected onKeydown({ key, target, defaultPrevented }: KeyboardEvent): void;
|
|
25
24
|
private get host();
|
|
26
25
|
private get editable();
|
|
26
|
+
private get focused();
|
|
27
27
|
private update;
|
|
28
28
|
private drive;
|
|
29
29
|
private focusDropdown;
|
|
30
30
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiDropdownOpen, never>;
|
|
31
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<TuiDropdownOpen, "[tuiDropdownOpen],[tuiDropdownOpenChange]", never, { "tuiDropdownEnabled": { "alias": "tuiDropdownEnabled"; "required": false; }; "tuiDropdownOpen": { "alias": "tuiDropdownOpen"; "required": false; }; }, { "tuiDropdownOpenChange": "tuiDropdownOpenChange"; }, ["dropdownHost"], never, true, [{ directive: typeof i1.TuiObscured; inputs: {}; outputs: {}; }, { directive: typeof i2.TuiActiveZone; inputs: { "tuiActiveZoneParent": "tuiActiveZoneParent"; }; outputs: { "tuiActiveZoneChange": "tuiActiveZoneChange"; }; }]>;
|
|
31
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<TuiDropdownOpen, "[tuiDropdown][tuiDropdownOpen],[tuiDropdown][tuiDropdownOpenChange]", never, { "tuiDropdownEnabled": { "alias": "tuiDropdownEnabled"; "required": false; }; "tuiDropdownOpen": { "alias": "tuiDropdownOpen"; "required": false; }; }, { "tuiDropdownOpenChange": "tuiDropdownOpenChange"; }, ["dropdownHost"], never, true, [{ directive: typeof i1.TuiObscured; inputs: {}; outputs: {}; }, { directive: typeof i2.TuiActiveZone; inputs: { "tuiActiveZoneParent": "tuiActiveZoneParent"; }; outputs: { "tuiActiveZoneChange": "tuiActiveZoneChange"; }; }]>;
|
|
32
32
|
}
|
|
@@ -6,7 +6,7 @@ export declare class TuiDropdownPosition extends TuiPositionAccessor {
|
|
|
6
6
|
private readonly viewport;
|
|
7
7
|
private previous?;
|
|
8
8
|
readonly type = "dropdown";
|
|
9
|
-
readonly accessor: TuiRectAccessor;
|
|
9
|
+
readonly accessor: TuiRectAccessor | null;
|
|
10
10
|
getPosition({ width, height }: DOMRect): TuiPoint;
|
|
11
11
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiDropdownPosition, never>;
|
|
12
12
|
static ɵdir: i0.ɵɵDirectiveDeclaration<TuiDropdownPosition, "[tuiDropdownPosition]", never, {}, {}, never, never, true, never>;
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import type { OnInit } from '@angular/core';
|
|
2
1
|
import { TuiDropdownDirective } from './dropdown.directive';
|
|
3
2
|
import * as i0 from "@angular/core";
|
|
4
3
|
import * as i1 from "@taiga-ui/cdk/directives/active-zone";
|
|
@@ -7,7 +6,7 @@ import * as i1 from "@taiga-ui/cdk/directives/active-zone";
|
|
|
7
6
|
* This component is used to show template in a portal
|
|
8
7
|
* using default style of white rounded box with a shadow
|
|
9
8
|
*/
|
|
10
|
-
export declare class TuiDropdownComponent
|
|
9
|
+
export declare class TuiDropdownComponent {
|
|
11
10
|
private readonly el;
|
|
12
11
|
private readonly accessor;
|
|
13
12
|
private readonly win;
|
|
@@ -18,10 +17,8 @@ export declare class TuiDropdownComponent implements OnInit {
|
|
|
18
17
|
protected readonly context: Record<any, any> | null;
|
|
19
18
|
protected readonly theme: string | null | undefined;
|
|
20
19
|
protected readonly sub: import("rxjs").Subscription;
|
|
21
|
-
ngOnInit(): void;
|
|
22
20
|
protected readonly close: () => void;
|
|
23
|
-
private
|
|
24
|
-
private updateWidth;
|
|
21
|
+
private getStyles;
|
|
25
22
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiDropdownComponent, never>;
|
|
26
23
|
static ɵcmp: i0.ɵɵComponentDeclaration<TuiDropdownComponent, "tui-dropdown", never, {}, {}, never, never, true, [{ directive: typeof i1.TuiActiveZone; inputs: {}; outputs: {}; }]>;
|
|
27
24
|
}
|
|
@@ -5,9 +5,10 @@ import { TuiDropdownContext } from './dropdown-context.directive';
|
|
|
5
5
|
import { TuiDropdownHover } from './dropdown-hover.directive';
|
|
6
6
|
import { TuiDropdownManual } from './dropdown-manual.directive';
|
|
7
7
|
import { TuiDropdownOpen } from './dropdown-open.directive';
|
|
8
|
+
import { TuiDropdownOpenLegacy } from './dropdown-open-legacy.directive';
|
|
8
9
|
import { TuiDropdownOptionsDirective } from './dropdown-options.directive';
|
|
9
10
|
import { TuiDropdownPortal } from './dropdown-portal.directive';
|
|
10
11
|
import { TuiDropdownPosition } from './dropdown-position.directive';
|
|
11
12
|
import { TuiDropdownPositionSided } from './dropdown-position-sided.directive';
|
|
12
13
|
import { TuiDropdownSelection } from './dropdown-selection.directive';
|
|
13
|
-
export declare const TuiDropdown: readonly [typeof TuiDropdownOptionsDirective, typeof TuiDropdownDriverDirective, typeof TuiDropdownDirective, typeof TuiDropdownComponent, typeof TuiDropdownOpen, typeof TuiDropdownPortal, typeof TuiDropdownManual, typeof TuiDropdownHover, typeof TuiDropdownContext, typeof TuiDropdownPosition, typeof TuiDropdownPositionSided, typeof TuiDropdownSelection];
|
|
14
|
+
export declare const TuiDropdown: readonly [typeof TuiDropdownOptionsDirective, typeof TuiDropdownDriverDirective, typeof TuiDropdownDirective, typeof TuiDropdownComponent, typeof TuiDropdownOpen, typeof TuiDropdownOpenLegacy, typeof TuiDropdownPortal, typeof TuiDropdownManual, typeof TuiDropdownHover, typeof TuiDropdownContext, typeof TuiDropdownPosition, typeof TuiDropdownPositionSided, typeof TuiDropdownSelection];
|
|
@@ -15,7 +15,7 @@ export declare class TuiDropdownDirective implements AfterViewChecked, OnDestroy
|
|
|
15
15
|
readonly el: HTMLElement;
|
|
16
16
|
readonly type = "dropdown";
|
|
17
17
|
readonly component: PolymorpheusComponent<any>;
|
|
18
|
-
|
|
18
|
+
ref: import("@angular/core").WritableSignal<ComponentRef<unknown> | null>;
|
|
19
19
|
content: PolymorpheusContent<TuiContext<() => void>>;
|
|
20
20
|
set tuiDropdown(content: PolymorpheusContent<TuiContext<() => void>>);
|
|
21
21
|
get position(): 'absolute' | 'fixed';
|
|
@@ -10,6 +10,7 @@ export * from './dropdown-hover.directive';
|
|
|
10
10
|
export * from './dropdown-hover.options';
|
|
11
11
|
export * from './dropdown-manual.directive';
|
|
12
12
|
export * from './dropdown-open.directive';
|
|
13
|
+
export * from './dropdown-open-legacy.directive';
|
|
13
14
|
export * from './dropdown-options.directive';
|
|
14
15
|
export * from './dropdown-portal.directive';
|
|
15
16
|
export * from './dropdown-position.directive';
|
|
@@ -3,7 +3,7 @@ import * as i0 from "@angular/core";
|
|
|
3
3
|
export declare class TuiHintHost extends TuiRectAccessor {
|
|
4
4
|
tuiHintHost?: HTMLElement;
|
|
5
5
|
readonly type = "hint";
|
|
6
|
-
getClientRect():
|
|
6
|
+
getClientRect(): DOMRect;
|
|
7
7
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiHintHost, never>;
|
|
8
8
|
static ɵdir: i0.ɵɵDirectiveDeclaration<TuiHintHost, "[tuiHint][tuiHintHost]", never, { "tuiHintHost": { "alias": "tuiHintHost"; "required": false; }; }, {}, never, never, true, never>;
|
|
9
9
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import type { FactoryProvider } from '@angular/core';
|
|
2
|
-
import { AbstractTuiController } from '@taiga-ui/cdk/classes';
|
|
1
|
+
import type { FactoryProvider, OnChanges } from '@angular/core';
|
|
3
2
|
import type { PolymorpheusContent } from '@taiga-ui/polymorpheus';
|
|
3
|
+
import { Subject } from 'rxjs';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export type TuiHintDirection = 'bottom-left' | 'bottom-right' | 'bottom' | 'left-bottom' | 'left-top' | 'left' | 'right-bottom' | 'right-top' | 'right' | 'top-left' | 'top-right' | 'top';
|
|
6
6
|
export declare const TUI_HINT_DIRECTIONS: readonly TuiHintDirection[];
|
|
@@ -21,7 +21,7 @@ export declare const tuiHintOptionsProvider: (options: Partial<TuiHintOptions>)
|
|
|
21
21
|
/**
|
|
22
22
|
* @deprecated: drop in 5.0
|
|
23
23
|
*/
|
|
24
|
-
export declare class TuiHintOptionsDirective
|
|
24
|
+
export declare class TuiHintOptionsDirective implements TuiHintOptions, OnChanges {
|
|
25
25
|
private readonly options;
|
|
26
26
|
content: PolymorpheusContent;
|
|
27
27
|
direction: TuiHintDirection;
|
|
@@ -29,6 +29,8 @@ export declare class TuiHintOptionsDirective extends AbstractTuiController imple
|
|
|
29
29
|
showDelay: number;
|
|
30
30
|
hideDelay: number;
|
|
31
31
|
icon: string;
|
|
32
|
+
readonly change$: Subject<void>;
|
|
33
|
+
ngOnChanges(): void;
|
|
32
34
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiHintOptionsDirective, never>;
|
|
33
35
|
static ɵdir: i0.ɵɵDirectiveDeclaration<TuiHintOptionsDirective, "[tuiHintContent]", never, { "content": { "alias": "tuiHintContent"; "required": false; }; "direction": { "alias": "tuiHintDirection"; "required": false; }; "appearance": { "alias": "tuiHintAppearance"; "required": false; }; "showDelay": { "alias": "tuiHintShowDelay"; "required": false; }; "hideDelay": { "alias": "tuiHintHideDelay"; "required": false; }; }, {}, never, never, true, never>;
|
|
34
36
|
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
import * as i1 from "./hint.directive";
|
|
3
|
+
export declare class TuiHintOverflow {
|
|
4
|
+
private readonly hint;
|
|
5
|
+
protected onMouseEnter({ scrollWidth, clientWidth, textContent }: Element): void;
|
|
6
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TuiHintOverflow, never>;
|
|
7
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<TuiHintOverflow, "[tuiHintOverflow]", never, {}, {}, never, never, true, [{ directive: typeof i1.TuiHintDirective; inputs: { "tuiHintAppearance": "tuiHintAppearance"; }; outputs: {}; }]>;
|
|
8
|
+
}
|
|
@@ -3,7 +3,7 @@ import { TuiHintHover } from './hint-hover.directive';
|
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export declare class TuiHintPointer extends TuiHintHover implements TuiRectAccessor {
|
|
5
5
|
private currentRect;
|
|
6
|
-
getClientRect():
|
|
6
|
+
getClientRect(): DOMRect;
|
|
7
7
|
protected onMove({ clientX, clientY }: MouseEvent): void;
|
|
8
8
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiHintPointer, never>;
|
|
9
9
|
static ɵdir: i0.ɵɵDirectiveDeclaration<TuiHintPointer, "[tuiHint][tuiHintPointer]", never, {}, {}, never, never, true, never>;
|
|
@@ -19,6 +19,7 @@ export declare class TuiHintComponent<C = any> {
|
|
|
19
19
|
protected get content(): PolymorpheusContent<C>;
|
|
20
20
|
protected get context(): C | undefined;
|
|
21
21
|
protected onClick(target: HTMLElement): void;
|
|
22
|
+
private apply;
|
|
22
23
|
private update;
|
|
23
24
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiHintComponent<any>, never>;
|
|
24
25
|
static ɵcmp: i0.ɵɵComponentDeclaration<TuiHintComponent<any>, "tui-hint", never, {}, {}, never, ["*"], true, never>;
|
|
@@ -6,7 +6,8 @@ import { TuiHintHost } from './hint-host.directive';
|
|
|
6
6
|
import { TuiHintHover } from './hint-hover.directive';
|
|
7
7
|
import { TuiHintManual } from './hint-manual.directive';
|
|
8
8
|
import { TuiHintOptionsDirective } from './hint-options.directive';
|
|
9
|
+
import { TuiHintOverflow } from './hint-overflow.directive';
|
|
9
10
|
import { TuiHintPointer } from './hint-pointer.directive';
|
|
10
11
|
import { TuiHintPosition } from './hint-position.directive';
|
|
11
12
|
import { TuiHintUnstyled } from './hint-unstyled.component';
|
|
12
|
-
export declare const TuiHint: readonly [typeof TuiHintComponent, typeof TuiHintDirective, typeof TuiHintOptionsDirective, typeof TuiHintUnstyled, typeof TuiHintDriver, typeof TuiHintPosition, typeof TuiHintHover, typeof TuiHintDescribe, typeof TuiHintHost, typeof TuiHintManual, typeof TuiHintPointer];
|
|
13
|
+
export declare const TuiHint: readonly [typeof TuiHintComponent, typeof TuiHintDirective, typeof TuiHintOptionsDirective, typeof TuiHintUnstyled, typeof TuiHintDriver, typeof TuiHintPosition, typeof TuiHintHover, typeof TuiHintOverflow, typeof TuiHintDescribe, typeof TuiHintHost, typeof TuiHintManual, typeof TuiHintPointer];
|
|
@@ -9,6 +9,7 @@ export * from './hint-host.directive';
|
|
|
9
9
|
export * from './hint-hover.directive';
|
|
10
10
|
export * from './hint-manual.directive';
|
|
11
11
|
export * from './hint-options.directive';
|
|
12
|
+
export * from './hint-overflow.directive';
|
|
12
13
|
export * from './hint-pointer.directive';
|
|
13
14
|
export * from './hint-position.directive';
|
|
14
15
|
export * from './hint-unstyled.component';
|
|
@@ -40,4 +40,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
40
40
|
}], propDecorators: { size: [{
|
|
41
41
|
type: Input
|
|
42
42
|
}] } });
|
|
43
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvY29tcG9uZW50cy9idXR0b24vYnV0dG9uLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0gsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxTQUFTLEVBQ1QsTUFBTSxFQUNOLEtBQUssRUFDTCxpQkFBaUIsR0FDcEIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLG1DQUFtQyxDQUFDO0FBQ2hFLE9BQU8sRUFDSCw0QkFBNEIsRUFDNUIsaUJBQWlCLEdBQ3BCLE1BQU0sc0NBQXNDLENBQUM7QUFDOUMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlDQUFpQyxDQUFDO0FBRTdELE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLGtCQUFrQixDQUFDOzs7O0FBRXBELE1BVU0sZUFBZTsrR0FBZixlQUFlO21HQUFmLGVBQWUsZ0hBUlAsRUFBRTs7NEZBUVYsZUFBZTtrQkFWcEIsU0FBUztpQ0FDTSxJQUFJLFlBQ04sRUFBRSxpQkFFRyxpQkFBaUIsQ0FBQyxJQUFJLG1CQUNwQix1QkFBdUIsQ0FBQyxNQUFNLFFBQ3pDO3dCQUNGLEtBQUssRUFBRSxZQUFZO3FCQUN0Qjs7QUFJTCxNQVNhLFNBQVM7SUFUdEI7UUFVcUIsWUFBTyxHQUFHLE1BQU0sQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1FBRW5DLFlBQU8sR0FBRyxhQUFhLENBQUMsZUFBZSxDQUFDLENBQUM7UUFHckQsU0FBSSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDO0tBQ25DOytHQVBZLFNBQVM7bUdBQVQsU0FBUyxrTUFOUCxDQUFDLDRCQUE0QixDQUFDLGtCQUFrQixDQUFDLENBQUM7O1NBTXBELFNBQVM7NEZBQVQsU0FBUztrQkFUckIsU0FBUzttQkFBQztvQkFDUCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLHVFQUF1RTtvQkFDakYsU0FBUyxFQUFFLENBQUMsNEJBQTRCLENBQUMsa0JBQWtCLENBQUMsQ0FBQztvQkFDN0QsY0FBYyxFQUFFLENBQUMsaUJBQWlCLEVBQUUsWUFBWSxDQUFDO29CQUNqRCxJQUFJLEVBQUU7d0JBQ0Ysa0JBQWtCLEVBQUUsTUFBTTtxQkFDN0I7aUJBQ0o7OEJBT1UsSUFBSTtzQkFEVixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgICBDb21wb25lbnQsXG4gICAgRGlyZWN0aXZlLFxuICAgIGluamVjdCxcbiAgICBJbnB1dCxcbiAgICBWaWV3RW5jYXBzdWxhdGlvbixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge3R1aVdpdGhTdHlsZXN9IGZyb20gJ0B0YWlnYS11aS9jZGsvdXRpbHMvbWlzY2VsbGFuZW91cyc7XG5pbXBvcnQge1xuICAgIHR1aUFwcGVhcmFuY2VPcHRpb25zUHJvdmlkZXIsXG4gICAgVHVpV2l0aEFwcGVhcmFuY2UsXG59IGZyb20gJ0B0YWlnYS11aS9jb3JlL2RpcmVjdGl2ZXMvYXBwZWFyYW5jZSc7XG5pbXBvcnQge1R1aVdpdGhJY29uc30gZnJvbSAnQHRhaWdhLXVpL2NvcmUvZGlyZWN0aXZlcy9pY29ucyc7XG5cbmltcG9ydCB7VFVJX0JVVFRPTl9PUFRJT05TfSBmcm9tICcuL2J1dHRvbi5vcHRpb25zJztcblxuQENvbXBvbmVudCh7XG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICB0ZW1wbGF0ZTogJycsXG4gICAgc3R5bGVzOiBbJ0BpbXBvcnQgXCJAdGFpZ2EtdWkvY29yZS9zdHlsZXMvY29tcG9uZW50cy9idXR0b24ubGVzc1wiOyddLFxuICAgIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gICAgaG9zdDoge1xuICAgICAgICBjbGFzczogJ3R1aS1idXR0b24nLFxuICAgIH0sXG59KVxuY2xhc3MgVHVpQnV0dG9uU3R5bGVzIHt9XG5cbkBEaXJlY3RpdmUoe1xuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgc2VsZWN0b3I6ICdhW3R1aUJ1dHRvbl0sYnV0dG9uW3R1aUJ1dHRvbl0sYVt0dWlJY29uQnV0dG9uXSxidXR0b25bdHVpSWNvbkJ1dHRvbl0nLFxuICAgIHByb3ZpZGVyczogW3R1aUFwcGVhcmFuY2VPcHRpb25zUHJvdmlkZXIoVFVJX0JVVFRPTl9PUFRJT05TKV0sXG4gICAgaG9zdERpcmVjdGl2ZXM6IFtUdWlXaXRoQXBwZWFyYW5jZSwgVHVpV2l0aEljb25zXSxcbiAgICBob3N0OiB7XG4gICAgICAgICdbYXR0ci5kYXRhLXNpemVdJzogJ3NpemUnLFxuICAgIH0sXG59KVxuZXhwb3J0IGNsYXNzIFR1aUJ1dHRvbiB7XG4gICAgcHJpdmF0ZSByZWFkb25seSBvcHRpb25zID0gaW5qZWN0KFRVSV9CVVRUT05fT1BUSU9OUyk7XG5cbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgbm90aGluZyA9IHR1aVdpdGhTdHlsZXMoVHVpQnV0dG9uU3R5bGVzKTtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIHNpemUgPSB0aGlzLm9wdGlvbnMuc2l6ZTtcbn1cbiJdfQ==
|
|
@@ -1,14 +1,12 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { AsyncPipe, NgIf } from '@angular/common';
|
|
1
|
+
import { NgIf } from '@angular/common';
|
|
3
2
|
import { ChangeDetectionStrategy, Component, ContentChildren, forwardRef, HostBinding, HostListener, inject, Input, ViewEncapsulation, } from '@angular/core';
|
|
3
|
+
import { toSignal } from '@angular/core/rxjs-interop';
|
|
4
4
|
import { EMPTY_QUERY } from '@taiga-ui/cdk/constants';
|
|
5
|
-
import { tuiQueryListChanges } from '@taiga-ui/cdk/observables';
|
|
6
5
|
import { tuiInjectElement } from '@taiga-ui/cdk/utils/dom';
|
|
7
6
|
import { tuiIsNativeFocusedIn, tuiMoveFocus } from '@taiga-ui/cdk/utils/focus';
|
|
8
|
-
import { tuiIsPresent
|
|
7
|
+
import { tuiIsPresent } from '@taiga-ui/cdk/utils/miscellaneous';
|
|
9
8
|
import { TUI_NOTHING_FOUND_MESSAGE } from '@taiga-ui/core/tokens';
|
|
10
9
|
import { PolymorpheusOutlet } from '@taiga-ui/polymorpheus';
|
|
11
|
-
import { map } from 'rxjs';
|
|
12
10
|
import { TUI_DATA_LIST_HOST, tuiAsDataListAccessor } from './data-list.tokens';
|
|
13
11
|
import { TuiOption } from './option.component';
|
|
14
12
|
import * as i0 from "@angular/core";
|
|
@@ -22,7 +20,8 @@ class TuiDataListComponent {
|
|
|
22
20
|
constructor() {
|
|
23
21
|
this.options = EMPTY_QUERY;
|
|
24
22
|
this.el = tuiInjectElement();
|
|
25
|
-
this.
|
|
23
|
+
this.fallback = toSignal(inject(TUI_NOTHING_FOUND_MESSAGE));
|
|
24
|
+
this.empty = true;
|
|
26
25
|
this.size = tuiInjectDataListSize();
|
|
27
26
|
}
|
|
28
27
|
onKeyDownArrow(current, step) {
|
|
@@ -34,15 +33,16 @@ class TuiDataListComponent {
|
|
|
34
33
|
this.origin?.focus({ preventScroll: true });
|
|
35
34
|
}
|
|
36
35
|
}
|
|
36
|
+
ngAfterContentChecked() {
|
|
37
|
+
// TODO: Refactor to :has after Safari support bumped to 15
|
|
38
|
+
this.empty = !this.el.querySelector('[tuiOption]');
|
|
39
|
+
}
|
|
37
40
|
getOptions(includeDisabled = false) {
|
|
38
41
|
return this.options
|
|
39
42
|
.filter(({ disabled }) => includeDisabled || !disabled)
|
|
40
43
|
.map(({ value }) => value)
|
|
41
44
|
.filter(tuiIsPresent);
|
|
42
45
|
}
|
|
43
|
-
get empty$() {
|
|
44
|
-
return tuiQueryListChanges(this.options).pipe(map(({ length }) => !length));
|
|
45
|
-
}
|
|
46
46
|
onFocusIn(relatedTarget, currentTarget) {
|
|
47
47
|
if (!currentTarget.contains(relatedTarget) && !this.origin) {
|
|
48
48
|
this.origin = relatedTarget;
|
|
@@ -53,17 +53,14 @@ class TuiDataListComponent {
|
|
|
53
53
|
return Array.from(this.el.querySelectorAll('a[tuiOption],button[tuiOption],input'));
|
|
54
54
|
}
|
|
55
55
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiDataListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
56
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiDataListComponent, isStandalone: true, selector: "tui-data-list", inputs: { emptyContent: "emptyContent", size: "size" }, host: { attributes: { "role": "listbox" }, listeners: { "keydown.arrowDown.prevent": "onKeyDownArrow($event.target,1)", "keydown.arrowUp.prevent": "onKeyDownArrow($event.target,-1)", "wheel.silent.passive": "handleFocusLossIfNecessary()", "mouseleave": "handleFocusLossIfNecessary($event.target)", "keydown.tab": "handleFocusLossIfNecessary()", "keydown.shift.tab": "handleFocusLossIfNecessary()", "focusin": "onFocusIn($event.relatedTarget,$event.currentTarget)", "mousedown.prevent": "noop()" }, properties: { "attr.data-size": "this.size" } }, providers: [tuiAsDataListAccessor(TuiDataListComponent)], queries: [{ propertyName: "options", predicate: i0.forwardRef(function () { return TuiOption; }), descendants: true }], ngImport: i0, template: "<ng-content />\n<div\n *ngIf=\"empty
|
|
56
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiDataListComponent, isStandalone: true, selector: "tui-data-list", inputs: { emptyContent: "emptyContent", size: "size" }, host: { attributes: { "role": "listbox" }, listeners: { "keydown.arrowDown.prevent": "onKeyDownArrow($event.target,1)", "keydown.arrowUp.prevent": "onKeyDownArrow($event.target,-1)", "wheel.silent.passive": "handleFocusLossIfNecessary()", "mouseleave": "handleFocusLossIfNecessary($event.target)", "keydown.tab": "handleFocusLossIfNecessary()", "keydown.shift.tab": "handleFocusLossIfNecessary()", "focusin": "onFocusIn($event.relatedTarget,$event.currentTarget)", "mousedown.prevent": "noop()" }, properties: { "attr.data-size": "this.size" } }, providers: [tuiAsDataListAccessor(TuiDataListComponent)], queries: [{ propertyName: "options", predicate: i0.forwardRef(function () { return TuiOption; }), descendants: true }], ngImport: i0, template: "<ng-content />\n<div\n *ngIf=\"empty\"\n class=\"t-empty\"\n>\n <ng-container *polymorpheusOutlet=\"emptyContent || fallback() as text\">\n {{ text }}\n </ng-container>\n</div>\n", styles: ["tui-data-list{--tui-data-list-padding: .25rem;--tui-data-list-margin: .0625rem;display:flex;font:var(--tui-font-text-m);flex-direction:column;padding:calc(var(--tui-data-list-padding) - var(--tui-data-list-margin)) var(--tui-data-list-padding);color:var(--tui-text-tertiary)}tui-data-list:focus-within .t-trap{display:none}tui-data-list:focus-within [tuiOption]._with-dropdown:not(:focus){background-color:transparent}tui-data-list[data-size=s]{--tui-data-list-margin: 0rem}tui-data-list[data-size=s]>.t-empty,tui-data-list[data-size=s] [tuiOption]{font:var(--tui-font-text-s);min-height:2rem;padding:.3125rem .5rem}tui-data-list[data-size=s]>.t-empty:before,tui-data-list[data-size=s] [tuiOption]:before{font-size:1rem}tui-data-list[data-size=m]>.t-empty,tui-data-list[data-size=m] [tuiOption]{font:var(--tui-font-text-s);min-height:2.5rem;padding:.375rem .5rem}tui-data-list[data-size=l]{--tui-data-list-padding: .375rem;--tui-data-list-margin: .125rem}tui-data-list[data-size=l]>.t-empty,tui-data-list[data-size=l] [tuiOption]{font:var(--tui-font-text-m);min-height:2.75rem;padding:.375rem .625rem}tui-data-list>.t-empty{display:flex;align-items:center;box-sizing:border-box;margin:var(--tui-data-list-margin) 0}tui-data-list [tuiOption]{-webkit-appearance:none;appearance:none;padding:0;border:0;background:none;font-size:inherit;line-height:inherit;text-decoration:none;transition-property:background;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;display:flex;align-items:center;box-sizing:border-box;margin:var(--tui-data-list-margin) 0;justify-content:space-between;text-align:left;color:var(--tui-text-primary);border-radius:var(--tui-radius-s);outline:none;cursor:pointer;background-clip:padding-box}tui-data-list [tuiOption]:disabled{opacity:var(--tui-disabled-opacity);cursor:default}tui-data-list [tuiOption]:focus-within,tui-data-list [tuiOption]._with-dropdown{background-color:var(--tui-background-neutral-1)}tui-data-list [tuiOption]:before{margin-inline-end:.5rem}tui-data-list [tuiOption]:after{font-size:1rem;margin:0 -.75rem 0 auto;border-left:.5rem solid;border-right:.5rem solid}tui-opt-group{position:relative;display:flex;font:var(--tui-font-text-xs);color:var(--tui-text-secondary);flex-direction:column;line-height:1rem}tui-data-list[data-size=l] tui-opt-group{font:var(--tui-font-text-s);line-height:1.25rem}tui-data-list[data-size=l] tui-opt-group:before{padding-left:.625rem;padding-right:.625rem}tui-data-list[data-size=l] tui-opt-group:after{left:.625rem;right:.625rem}tui-opt-group:empty:before,tui-opt-group:empty:after{display:none}tui-opt-group:before{content:attr(data-label);padding:var(--tui-data-list-padding) .5rem var(--tui-data-list-padding);margin:var(--tui-data-list-margin) 0;white-space:normal;word-break:break-word}tui-opt-group:after{position:absolute;left:.5rem;right:.5rem;top:var(--tui-data-list-padding);height:1px;background:var(--tui-border-normal)}tui-opt-group:not(:empty)~tui-opt-group:before{padding-top:calc(.75rem + var(--tui-data-list-padding))}tui-opt-group:not(:empty)~tui-opt-group[data-label=\"\"]:before,tui-opt-group:not(:empty)~tui-opt-group:not([data-label]):before{padding:var(--tui-data-list-padding) 0}tui-opt-group:not(:empty)~tui-opt-group:after{content:\"\"}tui-opt-group[data-label=\"\"]:before,tui-opt-group:not([data-label]):before{padding:0;margin:0}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: PolymorpheusOutlet, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
57
57
|
}
|
|
58
|
-
__decorate([
|
|
59
|
-
tuiPure
|
|
60
|
-
], TuiDataListComponent.prototype, "empty$", null);
|
|
61
58
|
export { TuiDataListComponent };
|
|
62
59
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiDataListComponent, decorators: [{
|
|
63
60
|
type: Component,
|
|
64
|
-
args: [{ standalone: true, selector: 'tui-data-list', imports: [NgIf,
|
|
61
|
+
args: [{ standalone: true, selector: 'tui-data-list', imports: [NgIf, PolymorpheusOutlet], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [tuiAsDataListAccessor(TuiDataListComponent)], host: {
|
|
65
62
|
role: 'listbox',
|
|
66
|
-
}, template: "<ng-content />\n<div\n *ngIf=\"empty
|
|
63
|
+
}, template: "<ng-content />\n<div\n *ngIf=\"empty\"\n class=\"t-empty\"\n>\n <ng-container *polymorpheusOutlet=\"emptyContent || fallback() as text\">\n {{ text }}\n </ng-container>\n</div>\n", styles: ["tui-data-list{--tui-data-list-padding: .25rem;--tui-data-list-margin: .0625rem;display:flex;font:var(--tui-font-text-m);flex-direction:column;padding:calc(var(--tui-data-list-padding) - var(--tui-data-list-margin)) var(--tui-data-list-padding);color:var(--tui-text-tertiary)}tui-data-list:focus-within .t-trap{display:none}tui-data-list:focus-within [tuiOption]._with-dropdown:not(:focus){background-color:transparent}tui-data-list[data-size=s]{--tui-data-list-margin: 0rem}tui-data-list[data-size=s]>.t-empty,tui-data-list[data-size=s] [tuiOption]{font:var(--tui-font-text-s);min-height:2rem;padding:.3125rem .5rem}tui-data-list[data-size=s]>.t-empty:before,tui-data-list[data-size=s] [tuiOption]:before{font-size:1rem}tui-data-list[data-size=m]>.t-empty,tui-data-list[data-size=m] [tuiOption]{font:var(--tui-font-text-s);min-height:2.5rem;padding:.375rem .5rem}tui-data-list[data-size=l]{--tui-data-list-padding: .375rem;--tui-data-list-margin: .125rem}tui-data-list[data-size=l]>.t-empty,tui-data-list[data-size=l] [tuiOption]{font:var(--tui-font-text-m);min-height:2.75rem;padding:.375rem .625rem}tui-data-list>.t-empty{display:flex;align-items:center;box-sizing:border-box;margin:var(--tui-data-list-margin) 0}tui-data-list [tuiOption]{-webkit-appearance:none;appearance:none;padding:0;border:0;background:none;font-size:inherit;line-height:inherit;text-decoration:none;transition-property:background;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;display:flex;align-items:center;box-sizing:border-box;margin:var(--tui-data-list-margin) 0;justify-content:space-between;text-align:left;color:var(--tui-text-primary);border-radius:var(--tui-radius-s);outline:none;cursor:pointer;background-clip:padding-box}tui-data-list [tuiOption]:disabled{opacity:var(--tui-disabled-opacity);cursor:default}tui-data-list [tuiOption]:focus-within,tui-data-list [tuiOption]._with-dropdown{background-color:var(--tui-background-neutral-1)}tui-data-list [tuiOption]:before{margin-inline-end:.5rem}tui-data-list [tuiOption]:after{font-size:1rem;margin:0 -.75rem 0 auto;border-left:.5rem solid;border-right:.5rem solid}tui-opt-group{position:relative;display:flex;font:var(--tui-font-text-xs);color:var(--tui-text-secondary);flex-direction:column;line-height:1rem}tui-data-list[data-size=l] tui-opt-group{font:var(--tui-font-text-s);line-height:1.25rem}tui-data-list[data-size=l] tui-opt-group:before{padding-left:.625rem;padding-right:.625rem}tui-data-list[data-size=l] tui-opt-group:after{left:.625rem;right:.625rem}tui-opt-group:empty:before,tui-opt-group:empty:after{display:none}tui-opt-group:before{content:attr(data-label);padding:var(--tui-data-list-padding) .5rem var(--tui-data-list-padding);margin:var(--tui-data-list-margin) 0;white-space:normal;word-break:break-word}tui-opt-group:after{position:absolute;left:.5rem;right:.5rem;top:var(--tui-data-list-padding);height:1px;background:var(--tui-border-normal)}tui-opt-group:not(:empty)~tui-opt-group:before{padding-top:calc(.75rem + var(--tui-data-list-padding))}tui-opt-group:not(:empty)~tui-opt-group[data-label=\"\"]:before,tui-opt-group:not(:empty)~tui-opt-group:not([data-label]):before{padding:var(--tui-data-list-padding) 0}tui-opt-group:not(:empty)~tui-opt-group:after{content:\"\"}tui-opt-group[data-label=\"\"]:before,tui-opt-group:not([data-label]):before{padding:0;margin:0}\n"] }]
|
|
67
64
|
}], propDecorators: { options: [{
|
|
68
65
|
type: ContentChildren,
|
|
69
66
|
args: [forwardRef(() => TuiOption), { descendants: true }]
|
|
@@ -92,11 +89,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
92
89
|
}, {
|
|
93
90
|
type: HostListener,
|
|
94
91
|
args: ['keydown.shift.tab']
|
|
95
|
-
}],
|
|
92
|
+
}], onFocusIn: [{
|
|
96
93
|
type: HostListener,
|
|
97
94
|
args: ['focusin', ['$event.relatedTarget', '$event.currentTarget']]
|
|
98
95
|
}], noop: [{
|
|
99
96
|
type: HostListener,
|
|
100
97
|
args: ['mousedown.prevent']
|
|
101
98
|
}] } });
|
|
102
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-list.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/data-list/data-list.component.ts","../../../../../projects/core/components/data-list/data-list.template.html"],"names":[],"mappings":"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","sourcesContent":["import {AsyncPipe, NgIf} from '@angular/common';\nimport type {QueryList} from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    forwardRef,\n    HostBinding,\n    HostListener,\n    inject,\n    Input,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {EMPTY_QUERY} from '@taiga-ui/cdk/constants';\nimport {tuiQueryListChanges} from '@taiga-ui/cdk/observables';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiIsNativeFocusedIn, tuiMoveFocus} from '@taiga-ui/cdk/utils/focus';\nimport {tuiIsPresent, tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TUI_NOTHING_FOUND_MESSAGE} from '@taiga-ui/core/tokens';\nimport type {TuiSizeL, TuiSizeS} from '@taiga-ui/core/types';\nimport type {PolymorpheusContent} from '@taiga-ui/polymorpheus';\nimport {PolymorpheusOutlet} from '@taiga-ui/polymorpheus';\nimport type {Observable} from 'rxjs';\nimport {map} from 'rxjs';\n\nimport type {TuiDataListAccessor} from './data-list.tokens';\nimport {TUI_DATA_LIST_HOST, tuiAsDataListAccessor} from './data-list.tokens';\nimport {TuiOption} from './option.component';\n\nexport function tuiInjectDataListSize(): TuiSizeL | TuiSizeS {\n    const sizes = ['s', 'm', 'l'] as const;\n    const size = inject(TUI_DATA_LIST_HOST, {optional: true})?.size;\n\n    return size && sizes.includes(size) ? size : 'l';\n}\n\n// TODO: Consider aria-activedescendant for proper accessibility implementation\n@Component({\n    standalone: true,\n    selector: 'tui-data-list',\n    imports: [NgIf, AsyncPipe, PolymorpheusOutlet],\n    templateUrl: './data-list.template.html',\n    styleUrls: ['./data-list.style.less'],\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [tuiAsDataListAccessor(TuiDataListComponent)],\n    host: {\n        role: 'listbox',\n    },\n})\nexport class TuiDataListComponent<T> implements TuiDataListAccessor<T> {\n    @ContentChildren(forwardRef(() => TuiOption), {descendants: true})\n    private readonly options: QueryList<TuiOption<T>> = EMPTY_QUERY;\n\n    private origin?: HTMLElement;\n    private readonly el = tuiInjectElement();\n\n    protected readonly defaultEmptyContent$ = inject(TUI_NOTHING_FOUND_MESSAGE);\n\n    @Input()\n    public emptyContent: PolymorpheusContent;\n\n    @Input()\n    @HostBinding('attr.data-size')\n    public size = tuiInjectDataListSize();\n\n    @HostListener('keydown.arrowDown.prevent', ['$event.target', '1'])\n    @HostListener('keydown.arrowUp.prevent', ['$event.target', '-1'])\n    public onKeyDownArrow(current: HTMLElement, step: number): void {\n        const {elements} = this;\n\n        tuiMoveFocus(elements.indexOf(current), elements, step);\n    }\n\n    @HostListener('wheel.silent.passive')\n    @HostListener('mouseleave', ['$event.target'])\n    @HostListener('keydown.tab')\n    @HostListener('keydown.shift.tab')\n    public handleFocusLossIfNecessary(element: Element = this.el): void {\n        if (tuiIsNativeFocusedIn(element)) {\n            this.origin?.focus({preventScroll: true});\n        }\n    }\n\n    public getOptions(includeDisabled = false): readonly T[] {\n        return this.options\n            .filter(({disabled}) => includeDisabled || !disabled)\n            .map(({value}) => value)\n            .filter(tuiIsPresent);\n    }\n\n    @tuiPure\n    protected get empty$(): Observable<boolean> {\n        return tuiQueryListChanges(this.options).pipe(map(({length}) => !length));\n    }\n\n    @HostListener('focusin', ['$event.relatedTarget', '$event.currentTarget'])\n    protected onFocusIn(relatedTarget: HTMLElement, currentTarget: HTMLElement): void {\n        if (!currentTarget.contains(relatedTarget) && !this.origin) {\n            this.origin = relatedTarget;\n        }\n    }\n\n    @HostListener('mousedown.prevent')\n    protected noop(): void {}\n\n    private get elements(): readonly HTMLElement[] {\n        return Array.from(\n            this.el.querySelectorAll('a[tuiOption],button[tuiOption],input'),\n        );\n    }\n}\n","<ng-content />\n<div\n    *ngIf=\"empty$ | async\"\n    class=\"t-empty\"\n>\n    <ng-container *polymorpheusOutlet=\"emptyContent || (defaultEmptyContent$ | async) as text\">\n        {{ text }}\n    </ng-container>\n</div>\n"]}
|
|
99
|
+
//# 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 {NgIf} from '@angular/common';\nimport type {AfterContentChecked, QueryList} from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    forwardRef,\n    HostBinding,\n    HostListener,\n    inject,\n    Input,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {toSignal} from '@angular/core/rxjs-interop';\nimport {EMPTY_QUERY} from '@taiga-ui/cdk/constants';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiIsNativeFocusedIn, tuiMoveFocus} from '@taiga-ui/cdk/utils/focus';\nimport {tuiIsPresent} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TUI_NOTHING_FOUND_MESSAGE} from '@taiga-ui/core/tokens';\nimport type {TuiSizeL, TuiSizeS} from '@taiga-ui/core/types';\nimport type {PolymorpheusContent} from '@taiga-ui/polymorpheus';\nimport {PolymorpheusOutlet} from '@taiga-ui/polymorpheus';\n\nimport type {TuiDataListAccessor} from './data-list.tokens';\nimport {TUI_DATA_LIST_HOST, tuiAsDataListAccessor} from './data-list.tokens';\nimport {TuiOption} from './option.component';\n\nexport function tuiInjectDataListSize(): TuiSizeL | TuiSizeS {\n    const sizes = ['s', 'm', 'l'] as const;\n    const size = inject(TUI_DATA_LIST_HOST, {optional: true})?.size;\n\n    return size && sizes.includes(size) ? size : 'l';\n}\n\n// TODO: Consider aria-activedescendant for proper accessibility implementation\n@Component({\n    standalone: true,\n    selector: 'tui-data-list',\n    imports: [NgIf, PolymorpheusOutlet],\n    templateUrl: './data-list.template.html',\n    styleUrls: ['./data-list.style.less'],\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [tuiAsDataListAccessor(TuiDataListComponent)],\n    host: {\n        role: 'listbox',\n    },\n})\nexport class TuiDataListComponent<T>\n    implements TuiDataListAccessor<T>, AfterContentChecked\n{\n    @ContentChildren(forwardRef(() => TuiOption), {descendants: true})\n    private readonly options: QueryList<TuiOption<T>> = EMPTY_QUERY;\n\n    private origin?: HTMLElement;\n    private readonly el = tuiInjectElement();\n\n    protected readonly fallback = toSignal(inject(TUI_NOTHING_FOUND_MESSAGE));\n    protected empty = true;\n\n    @Input()\n    public emptyContent: PolymorpheusContent;\n\n    @Input()\n    @HostBinding('attr.data-size')\n    public size = tuiInjectDataListSize();\n\n    @HostListener('keydown.arrowDown.prevent', ['$event.target', '1'])\n    @HostListener('keydown.arrowUp.prevent', ['$event.target', '-1'])\n    public onKeyDownArrow(current: HTMLElement, step: number): void {\n        const {elements} = this;\n\n        tuiMoveFocus(elements.indexOf(current), elements, step);\n    }\n\n    @HostListener('wheel.silent.passive')\n    @HostListener('mouseleave', ['$event.target'])\n    @HostListener('keydown.tab')\n    @HostListener('keydown.shift.tab')\n    public handleFocusLossIfNecessary(element: Element = this.el): void {\n        if (tuiIsNativeFocusedIn(element)) {\n            this.origin?.focus({preventScroll: true});\n        }\n    }\n\n    public ngAfterContentChecked(): void {\n        // TODO: Refactor to :has after Safari support bumped to 15\n        this.empty = !this.el.querySelector('[tuiOption]');\n    }\n\n    public getOptions(includeDisabled = false): readonly T[] {\n        return this.options\n            .filter(({disabled}) => includeDisabled || !disabled)\n            .map(({value}) => value)\n            .filter(tuiIsPresent);\n    }\n\n    @HostListener('focusin', ['$event.relatedTarget', '$event.currentTarget'])\n    protected onFocusIn(relatedTarget: HTMLElement, currentTarget: HTMLElement): void {\n        if (!currentTarget.contains(relatedTarget) && !this.origin) {\n            this.origin = relatedTarget;\n        }\n    }\n\n    @HostListener('mousedown.prevent')\n    protected noop(): void {}\n\n    private get elements(): readonly HTMLElement[] {\n        return Array.from(\n            this.el.querySelectorAll('a[tuiOption],button[tuiOption],input'),\n        );\n    }\n}\n","<ng-content />\n<div\n    *ngIf=\"empty\"\n    class=\"t-empty\"\n>\n    <ng-container *polymorpheusOutlet=\"emptyContent || fallback() as text\">\n        {{ text }}\n    </ng-container>\n</div>\n"]}
|
|
@@ -24,4 +24,4 @@ export const TUI_DATA_LIST_HOST = new InjectionToken('[TUI_DATA_LIST_HOST]');
|
|
|
24
24
|
export function tuiAsDataListHost(host) {
|
|
25
25
|
return tuiProvide(TUI_DATA_LIST_HOST, host);
|
|
26
26
|
}
|
|
27
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1saXN0LnRva2Vucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvY29tcG9uZW50cy9kYXRhLWxpc3QvZGF0YS1saXN0LnRva2Vucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRTdDLE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQWlCN0Q7O0dBRUc7QUFDSCxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxJQUFJLGNBQWMsQ0FFbEQsc0JBQXNCLENBQUMsQ0FBQztBQUUxQixNQUFNLFVBQVUsa0JBQWtCLENBQzlCLFFBQStFO0lBRS9FLE9BQU87UUFDSCxPQUFPLEVBQUUsa0JBQWtCO1FBQzNCLFFBQVE7S0FDWCxDQUFDO0FBQ04sQ0FBQztBQUVEOztHQUVHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUcsSUFBSSxjQUFjLENBQ3BELDBCQUEwQixDQUM3QixDQUFDO0FBRUYsTUFBTSxVQUFVLHFCQUFxQixDQUFDLFFBQW1DO0lBQ3JFLE9BQU8sVUFBVSxDQUFDLHNCQUFzQixFQUFFLFFBQVEsQ0FBQyxDQUFDO0FBQ3hELENBQUM7QUFFRDs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLElBQUksY0FBYyxDQUNoRCxzQkFBc0IsQ0FDekIsQ0FBQztBQUVGLE1BQU0sVUFBVSxpQkFBaUIsQ0FBQyxJQUFvQztJQUNsRSxPQUFPLFVBQVUsQ0FBQyxrQkFBa0IsRUFBRSxJQUFJLENBQUMsQ0FBQztBQUNoRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge1Byb3ZpZGVyLCBUZW1wbGF0ZVJlZiwgVHlwZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0luamVjdGlvblRva2VufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB0eXBlIHtUdWlDb250ZXh0LCBUdWlJZGVudGl0eU1hdGNoZXIsIFR1aVN0cmluZ0hhbmRsZXJ9IGZyb20gJ0B0YWlnYS11aS9jZGsvdHlwZXMnO1xuaW1wb3J0IHt0dWlQcm92aWRlfSBmcm9tICdAdGFpZ2EtdWkvY2RrL3V0aWxzL21pc2NlbGxhbmVvdXMnO1xuaW1wb3J0IHR5cGUge1R1aVNpemVMLCBUdWlTaXplU30gZnJvbSAnQHRhaWdhLXVpL2NvcmUvdHlwZXMnO1xuaW1wb3J0IHR5cGUge1BvbHltb3JwaGV1c0NvbnRlbnR9IGZyb20gJ0B0YWlnYS11aS9wb2x5bW9ycGhldXMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFR1aURhdGFMaXN0QWNjZXNzb3I8VCA9IHVua25vd24+
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1saXN0LnRva2Vucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvY29tcG9uZW50cy9kYXRhLWxpc3QvZGF0YS1saXN0LnRva2Vucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRTdDLE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQWlCN0Q7O0dBRUc7QUFDSCxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxJQUFJLGNBQWMsQ0FFbEQsc0JBQXNCLENBQUMsQ0FBQztBQUUxQixNQUFNLFVBQVUsa0JBQWtCLENBQzlCLFFBQStFO0lBRS9FLE9BQU87UUFDSCxPQUFPLEVBQUUsa0JBQWtCO1FBQzNCLFFBQVE7S0FDWCxDQUFDO0FBQ04sQ0FBQztBQUVEOztHQUVHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUcsSUFBSSxjQUFjLENBQ3BELDBCQUEwQixDQUM3QixDQUFDO0FBRUYsTUFBTSxVQUFVLHFCQUFxQixDQUFDLFFBQW1DO0lBQ3JFLE9BQU8sVUFBVSxDQUFDLHNCQUFzQixFQUFFLFFBQVEsQ0FBQyxDQUFDO0FBQ3hELENBQUM7QUFFRDs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLElBQUksY0FBYyxDQUNoRCxzQkFBc0IsQ0FDekIsQ0FBQztBQUVGLE1BQU0sVUFBVSxpQkFBaUIsQ0FBQyxJQUFvQztJQUNsRSxPQUFPLFVBQVUsQ0FBQyxrQkFBa0IsRUFBRSxJQUFJLENBQUMsQ0FBQztBQUNoRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge1Byb3ZpZGVyLCBUZW1wbGF0ZVJlZiwgVHlwZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0luamVjdGlvblRva2VufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB0eXBlIHtUdWlDb250ZXh0LCBUdWlJZGVudGl0eU1hdGNoZXIsIFR1aVN0cmluZ0hhbmRsZXJ9IGZyb20gJ0B0YWlnYS11aS9jZGsvdHlwZXMnO1xuaW1wb3J0IHt0dWlQcm92aWRlfSBmcm9tICdAdGFpZ2EtdWkvY2RrL3V0aWxzL21pc2NlbGxhbmVvdXMnO1xuaW1wb3J0IHR5cGUge1R1aVNpemVMLCBUdWlTaXplU30gZnJvbSAnQHRhaWdhLXVpL2NvcmUvdHlwZXMnO1xuaW1wb3J0IHR5cGUge1BvbHltb3JwaGV1c0NvbnRlbnR9IGZyb20gJ0B0YWlnYS11aS9wb2x5bW9ycGhldXMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFR1aURhdGFMaXN0QWNjZXNzb3I8VCA9IHVua25vd24+IHtcbiAgICBnZXRPcHRpb25zKGluY2x1ZGVEaXNhYmxlZD86IGJvb2xlYW4pOiByZWFkb25seSBUW107XG59XG5cbi8vIFRPRE86IENvbnNpZGVyIHJlZmFjdG9yaW5nIGNoZWNrT3B0aW9uLCBpdCBpcyBvbmx5IG5lZWRlZCBpbiBDb21ib0JveFxuZXhwb3J0IGludGVyZmFjZSBUdWlEYXRhTGlzdEhvc3Q8VD4ge1xuICAgIGNoZWNrT3B0aW9uPyhvcHRpb246IFQpOiB2b2lkO1xuICAgIGhhbmRsZU9wdGlvbj8ob3B0aW9uOiBUKTogdm9pZDtcbiAgICByZWFkb25seSBpZGVudGl0eU1hdGNoZXI/OiBUdWlJZGVudGl0eU1hdGNoZXI8VD47XG4gICAgcmVhZG9ubHkgc3RyaW5naWZ5PzogVHVpU3RyaW5nSGFuZGxlcjxUPjtcbiAgICByZWFkb25seSBzaXplPzogVHVpU2l6ZUwgfCBUdWlTaXplUztcbn1cblxuLyoqXG4gKiBDb250ZW50IGZvciB0dWlPcHRpb24gY29tcG9uZW50XG4gKi9cbmV4cG9ydCBjb25zdCBUVUlfT1BUSU9OX0NPTlRFTlQgPSBuZXcgSW5qZWN0aW9uVG9rZW48XG4gICAgUG9seW1vcnBoZXVzQ29udGVudDxUdWlDb250ZXh0PFRlbXBsYXRlUmVmPFJlY29yZDxzdHJpbmcsIHVua25vd24+Pj4+XG4+KCdbVFVJX09QVElPTl9DT05URU5UXScpO1xuXG5leHBvcnQgZnVuY3Rpb24gdHVpQXNPcHRpb25Db250ZW50KFxuICAgIHVzZVZhbHVlOiBQb2x5bW9ycGhldXNDb250ZW50PFR1aUNvbnRleHQ8VGVtcGxhdGVSZWY8UmVjb3JkPHN0cmluZywgdW5rbm93bj4+Pj4sXG4pOiBQcm92aWRlciB7XG4gICAgcmV0dXJuIHtcbiAgICAgICAgcHJvdmlkZTogVFVJX09QVElPTl9DT05URU5ULFxuICAgICAgICB1c2VWYWx1ZSxcbiAgICB9O1xufVxuXG4vKipcbiAqIEFjY2Vzc29yIGZvciBkYXRhLWxpc3Qgb3B0aW9uc1xuICovXG5leHBvcnQgY29uc3QgVFVJX0RBVEFfTElTVF9BQ0NFU1NPUiA9IG5ldyBJbmplY3Rpb25Ub2tlbjxUdWlEYXRhTGlzdEFjY2Vzc29yPihcbiAgICAnW1RVSV9EQVRBX0xJU1RfQUNDRVNTT1JdJyxcbik7XG5cbmV4cG9ydCBmdW5jdGlvbiB0dWlBc0RhdGFMaXN0QWNjZXNzb3IoYWNjZXNzb3I6IFR5cGU8VHVpRGF0YUxpc3RBY2Nlc3Nvcj4pOiBQcm92aWRlciB7XG4gICAgcmV0dXJuIHR1aVByb3ZpZGUoVFVJX0RBVEFfTElTVF9BQ0NFU1NPUiwgYWNjZXNzb3IpO1xufVxuXG4vKipcbiAqIERhdGFMaXN0IGNvbnRyb2xsZXJcbiAqL1xuZXhwb3J0IGNvbnN0IFRVSV9EQVRBX0xJU1RfSE9TVCA9IG5ldyBJbmplY3Rpb25Ub2tlbjxUdWlEYXRhTGlzdEhvc3Q8dW5rbm93bj4+KFxuICAgICdbVFVJX0RBVEFfTElTVF9IT1NUXScsXG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gdHVpQXNEYXRhTGlzdEhvc3QoaG9zdDogVHlwZTxUdWlEYXRhTGlzdEhvc3Q8dW5rbm93bj4+KTogUHJvdmlkZXIge1xuICAgIHJldHVybiB0dWlQcm92aWRlKFRVSV9EQVRBX0xJU1RfSE9TVCwgaG9zdCk7XG59XG4iXX0=
|