@taiga-ui/core 4.74.1 → 4.75.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (31) hide show
  1. package/components/data-list/data-list.component.d.ts +1 -0
  2. package/components/textfield/textfield.component.d.ts +1 -0
  3. package/components/textfield/textfield.directive.d.ts +7 -4
  4. package/directives/dropdown/dropdown-a11y.directive.d.ts +11 -0
  5. package/directives/dropdown/dropdown-context.directive.d.ts +2 -1
  6. package/directives/dropdown/dropdown-open.directive.d.ts +4 -3
  7. package/directives/dropdown/dropdown.d.ts +2 -1
  8. package/directives/dropdown/dropdown.directive.d.ts +3 -2
  9. package/directives/dropdown/dropdown.providers.d.ts +2 -1
  10. package/directives/dropdown/index.d.ts +1 -0
  11. package/esm2022/components/data-list/data-list.component.mjs +8 -2
  12. package/esm2022/components/root/root.component.mjs +1 -1
  13. package/esm2022/components/textfield/textfield-multi/textfield-multi.component.mjs +7 -7
  14. package/esm2022/components/textfield/textfield.component.mjs +15 -9
  15. package/esm2022/components/textfield/textfield.directive.mjs +10 -5
  16. package/esm2022/directives/dropdown/dropdown-a11y.directive.mjs +52 -0
  17. package/esm2022/directives/dropdown/dropdown-context.directive.mjs +12 -15
  18. package/esm2022/directives/dropdown/dropdown-open.directive.mjs +44 -36
  19. package/esm2022/directives/dropdown/dropdown.directive.mjs +11 -5
  20. package/esm2022/directives/dropdown/dropdown.mjs +3 -1
  21. package/esm2022/directives/dropdown/dropdown.providers.mjs +2 -1
  22. package/esm2022/directives/dropdown/index.mjs +2 -1
  23. package/fesm2022/taiga-ui-core-components-data-list.mjs +7 -1
  24. package/fesm2022/taiga-ui-core-components-data-list.mjs.map +1 -1
  25. package/fesm2022/taiga-ui-core-components-root.mjs +1 -1
  26. package/fesm2022/taiga-ui-core-components-textfield.mjs +30 -21
  27. package/fesm2022/taiga-ui-core-components-textfield.mjs.map +1 -1
  28. package/fesm2022/taiga-ui-core-directives-dropdown.mjs +105 -47
  29. package/fesm2022/taiga-ui-core-directives-dropdown.mjs.map +1 -1
  30. package/package.json +3 -3
  31. package/styles/mixins/hitbox.less +1 -1
@@ -23,6 +23,7 @@ export declare class TuiDataListComponent<T> implements TuiDataListAccessor<T>,
23
23
  ngAfterContentInit(): void;
24
24
  ngAfterContentChecked(): void;
25
25
  getOptions(includeDisabled?: boolean): readonly T[];
26
+ protected get role(): string | null;
26
27
  protected onFocusIn(relatedTarget: HTMLElement, currentTarget: HTMLElement): void;
27
28
  private get elements();
28
29
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiDataListComponent<any>, never>;
@@ -48,6 +48,7 @@ export declare class TuiTextfieldBaseComponent<T> implements TuiDataListHost<T>,
48
48
  get disabled(): boolean;
49
49
  ngAfterContentChecked(): void;
50
50
  handleOption(option: T): void;
51
+ protected get interactiveInput(): ElementRef<HTMLInputElement> | undefined;
51
52
  protected get hasLabel(): boolean;
52
53
  protected onResize({ contentRect }: ResizeObserverEntry): void;
53
54
  protected onIconClick(): void;
@@ -1,12 +1,14 @@
1
1
  import { type OnChanges } from '@angular/core';
2
2
  import { NgControl } from '@angular/forms';
3
+ import { TuiDropdownDirective } from '@taiga-ui/core/directives/dropdown';
3
4
  import { type TuiItemsHandlers } from '@taiga-ui/core/directives/items-handlers';
4
5
  import { type TuiInteractiveState } from '@taiga-ui/core/types';
5
6
  import { TuiTextfieldComponent } from './textfield.component';
6
7
  import { type TuiTextfieldAccessor } from './textfield-accessor';
7
8
  import * as i0 from "@angular/core";
8
- import * as i1 from "@taiga-ui/cdk/directives/native-validator";
9
- import * as i2 from "@taiga-ui/core/directives/appearance";
9
+ import * as i1 from "@taiga-ui/core/directives/dropdown";
10
+ import * as i2 from "@taiga-ui/cdk/directives/native-validator";
11
+ import * as i3 from "@taiga-ui/core/directives/appearance";
10
12
  export declare class TuiTextfieldBase<T> implements OnChanges, TuiTextfieldAccessor<T> {
11
13
  private readonly focused;
12
14
  protected readonly control: NgControl | null;
@@ -17,6 +19,7 @@ export declare class TuiTextfieldBase<T> implements OnChanges, TuiTextfieldAcces
17
19
  protected readonly el: HTMLInputElement;
18
20
  protected readonly handlers: TuiItemsHandlers<T>;
19
21
  protected readonly textfield: TuiTextfieldComponent<T>;
22
+ protected readonly dropdown: TuiDropdownDirective;
20
23
  readOnly: boolean;
21
24
  invalid: boolean | null;
22
25
  readonly value: import("@angular/core").WritableSignal<string>;
@@ -26,11 +29,11 @@ export declare class TuiTextfieldBase<T> implements OnChanges, TuiTextfieldAcces
26
29
  ngOnChanges(): void;
27
30
  setValue(value: T | null): void;
28
31
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiTextfieldBase<any>, never>;
29
- static ɵdir: i0.ɵɵDirectiveDeclaration<TuiTextfieldBase<any>, never, never, { "readOnly": { "alias": "readOnly"; "required": false; }; "invalid": { "alias": "invalid"; "required": false; }; "focusedSetter": { "alias": "focused"; "required": false; }; "stateSetter": { "alias": "state"; "required": false; }; }, {}, never, never, true, never>;
32
+ static ɵdir: i0.ɵɵDirectiveDeclaration<TuiTextfieldBase<any>, never, never, { "readOnly": { "alias": "readOnly"; "required": false; }; "invalid": { "alias": "invalid"; "required": false; }; "focusedSetter": { "alias": "focused"; "required": false; }; "stateSetter": { "alias": "state"; "required": false; }; }, {}, never, never, true, [{ directive: typeof i1.TuiDropdownA11y; inputs: {}; outputs: {}; }]>;
30
33
  }
31
34
  export declare class TuiTextfieldDirective<T> extends TuiTextfieldBase<T> {
32
35
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiTextfieldDirective<any>, never>;
33
- static ɵdir: i0.ɵɵDirectiveDeclaration<TuiTextfieldDirective<any>, "input[tuiTextfield]:not([tuiInputCard]):not([tuiInputExpire]):not([tuiInputCVC])", never, {}, {}, never, never, true, [{ directive: typeof i1.TuiNativeValidator; inputs: {}; outputs: {}; }, { directive: typeof i2.TuiAppearance; inputs: {}; outputs: {}; }]>;
36
+ static ɵdir: i0.ɵɵDirectiveDeclaration<TuiTextfieldDirective<any>, "input[tuiTextfield]:not([tuiInputCard]):not([tuiInputExpire]):not([tuiInputCVC])", never, {}, {}, never, never, true, [{ directive: typeof i2.TuiNativeValidator; inputs: {}; outputs: {}; }, { directive: typeof i3.TuiAppearance; inputs: {}; outputs: {}; }]>;
34
37
  }
35
38
  export declare class TuiWithTextfield {
36
39
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiWithTextfield, never>;
@@ -0,0 +1,11 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class TuiDropdownA11y {
3
+ private readonly id;
4
+ private readonly host;
5
+ private readonly dropdown;
6
+ protected readonly sync: import("@angular/core").EffectRef;
7
+ readonly _tuiDropdownRole: import("@angular/core").WritableSignal<string>;
8
+ set tuiDropdownRole(role: string);
9
+ static ɵfac: i0.ɵɵFactoryDeclaration<TuiDropdownA11y, never>;
10
+ static ɵdir: i0.ɵɵDirectiveDeclaration<TuiDropdownA11y, "[tuiDropdownA11y]", never, { "tuiDropdownRole": { "alias": "tuiDropdownRole"; "required": false; }; }, {}, never, never, true, never>;
11
+ }
@@ -3,6 +3,7 @@ import { TuiRectAccessor } from '@taiga-ui/core/classes';
3
3
  import { TuiDropdownDriver } from './dropdown.driver';
4
4
  import * as i0 from "@angular/core";
5
5
  export declare class TuiDropdownContext extends TuiRectAccessor {
6
+ private readonly zone;
6
7
  private readonly isTouch;
7
8
  private currentRect;
8
9
  protected readonly userSelect: import("@angular/core").Signal<"none" | null>;
@@ -12,7 +13,7 @@ export declare class TuiDropdownContext extends TuiRectAccessor {
12
13
  protected readonly sub: import("rxjs").Subscription;
13
14
  readonly type = "dropdown";
14
15
  getClientRect(): DOMRect;
15
- protected closeDropdown(_event?: Event): void;
16
+ protected closeDropdown(event?: Event): void;
16
17
  protected onContextMenu(x: number, y: number): void;
17
18
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiDropdownContext, never>;
18
19
  static ɵdir: i0.ɵɵDirectiveDeclaration<TuiDropdownContext, "[tuiDropdownContext]", never, {}, {}, never, never, true, never>;
@@ -1,14 +1,15 @@
1
- import { EventEmitter, type OnChanges } from '@angular/core';
1
+ import { ElementRef, EventEmitter, type OnChanges } from '@angular/core';
2
2
  import { TuiDropdownDriver } from './dropdown.driver';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "@taiga-ui/cdk/directives/obscured";
5
5
  import * as i2 from "@taiga-ui/cdk/directives/active-zone";
6
- export declare class TuiDropdownOpen implements OnChanges {
6
+ export declare class TuiDropdownOpen implements OnChanges, ElementRef<Element> {
7
7
  private readonly dropdownHost?;
8
8
  private readonly directive;
9
9
  private readonly el;
10
10
  private readonly obscured;
11
11
  private readonly activeZone;
12
+ private readonly zone;
12
13
  private readonly dropdown;
13
14
  tuiDropdownEnabled: boolean;
14
15
  tuiDropdownOpen: boolean | '';
@@ -16,13 +17,13 @@ export declare class TuiDropdownOpen implements OnChanges {
16
17
  readonly driver: TuiDropdownDriver;
17
18
  readonly sub: import("rxjs").Subscription;
18
19
  readonly sync: import("rxjs").Subscription;
20
+ get nativeElement(): HTMLElement;
19
21
  ngOnChanges(): void;
20
22
  toggle(open: boolean): void;
21
23
  protected onEsc(event: KeyboardEvent): void;
22
24
  protected onClick(target: HTMLElement): void;
23
25
  protected onArrow(event: KeyboardEvent, up: boolean): void;
24
26
  protected onKeydown(event: KeyboardEvent): void;
25
- private get host();
26
27
  private get editable();
27
28
  private get focused();
28
29
  private update;
@@ -11,4 +11,5 @@ import { TuiDropdownPortal } from './dropdown-portal.directive';
11
11
  import { TuiDropdownPosition } from './dropdown-position.directive';
12
12
  import { TuiDropdownPositionSided } from './dropdown-position-sided.directive';
13
13
  import { TuiDropdownSelection } from './dropdown-selection.directive';
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];
14
+ import { TuiDropdownA11y } from './dropdown-a11y.directive';
15
+ 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, typeof TuiDropdownA11y];
@@ -5,7 +5,8 @@ import { type TuiPortalItem } from '@taiga-ui/core/types';
5
5
  import { PolymorpheusComponent, type PolymorpheusContent } from '@taiga-ui/polymorpheus';
6
6
  import * as i0 from "@angular/core";
7
7
  import * as i1 from "./dropdown.driver";
8
- import * as i2 from "./dropdown-position.directive";
8
+ import * as i2 from "./dropdown-a11y.directive";
9
+ import * as i3 from "./dropdown-position.directive";
9
10
  export declare class TuiDropdownDirective implements AfterViewChecked, OnDestroy, TuiPortalItem, TuiRectAccessor, TuiVehicle {
10
11
  private readonly refresh$;
11
12
  private readonly service;
@@ -26,5 +27,5 @@ export declare class TuiDropdownDirective implements AfterViewChecked, OnDestroy
26
27
  getClientRect(): DOMRect;
27
28
  toggle(show: boolean): void;
28
29
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiDropdownDirective, never>;
29
- static ɵdir: i0.ɵɵDirectiveDeclaration<TuiDropdownDirective, "[tuiDropdown]:not(ng-container):not(ng-template)", ["tuiDropdown"], { "tuiDropdown": { "alias": "tuiDropdown"; "required": false; }; }, {}, never, never, true, [{ directive: typeof i1.TuiDropdownDriverDirective; inputs: {}; outputs: {}; }, { directive: typeof i2.TuiDropdownPosition; inputs: {}; outputs: { "tuiDropdownDirectionChange": "tuiDropdownDirectionChange"; }; }]>;
30
+ static ɵdir: i0.ɵɵDirectiveDeclaration<TuiDropdownDirective, "[tuiDropdown]:not(ng-container):not(ng-template)", ["tuiDropdown"], { "tuiDropdown": { "alias": "tuiDropdown"; "required": false; }; }, {}, never, never, true, [{ directive: typeof i1.TuiDropdownDriverDirective; inputs: {}; outputs: {}; }, { directive: typeof i2.TuiDropdownA11y; inputs: { "tuiDropdownRole": "tuiDropdownRole"; }; outputs: {}; }, { directive: typeof i3.TuiDropdownPosition; inputs: {}; outputs: { "tuiDropdownDirectionChange": "tuiDropdownDirectionChange"; }; }]>;
30
31
  }
@@ -1,6 +1,7 @@
1
- import { InjectionToken, type Type } from '@angular/core';
1
+ import { type ElementRef, InjectionToken, type Type } from '@angular/core';
2
2
  /**
3
3
  * A component to display a dropdown
4
4
  */
5
5
  export declare const TUI_DROPDOWN_COMPONENT: InjectionToken<Type<any>>;
6
6
  export declare const TUI_DROPDOWN_CONTEXT: InjectionToken<Record<any, any>>;
7
+ export declare const TUI_DROPDOWN_HOST: InjectionToken<ElementRef<Element>>;
@@ -5,6 +5,7 @@ export * from './dropdown.directive';
5
5
  export * from './dropdown.driver';
6
6
  export * from './dropdown.providers';
7
7
  export * from './dropdown.service';
8
+ export * from './dropdown-a11y.directive';
8
9
  export * from './dropdown-context.directive';
9
10
  export * from './dropdown-hover.directive';
10
11
  export * from './dropdown-hover.options';
@@ -73,6 +73,11 @@ class TuiDataListComponent {
73
73
  .map(({ value }) => (isSignal(value) ? value() : value))
74
74
  .filter(tuiIsPresent);
75
75
  }
76
+ get role() {
77
+ return this.el.parentElement?.closest('[role="menu"],[role="listbox"]')
78
+ ? null
79
+ : this.el.role;
80
+ }
76
81
  onFocusIn(relatedTarget, currentTarget) {
77
82
  if (!currentTarget.contains(relatedTarget) && !this.origin) {
78
83
  this.origin = relatedTarget;
@@ -82,7 +87,7 @@ class TuiDataListComponent {
82
87
  return Array.from(this.el.querySelectorAll('[tuiOption]'));
83
88
  }
84
89
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiDataListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
85
- 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: { "focusin": "onFocusIn($event.relatedTarget, $event.currentTarget)", "mousedown.prevent": "(0)", "wheel.zoneless.passive": "handleFocusLossIfNecessary()", "mouseleave": "handleFocusLossIfNecessary($event.target)", "keydown.tab": "handleFocusLossIfNecessary()", "keydown.shift.tab": "handleFocusLossIfNecessary()", "keydown.arrowDown.prevent": "onKeyDownArrow($event.target, 1)", "keydown.arrowUp.prevent": "onKeyDownArrow($event.target, -1)" }, properties: { "attr.data-size": "size" } }, providers: [
90
+ 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: { "focusin": "onFocusIn($event.relatedTarget, $event.currentTarget)", "mousedown.prevent": "(0)", "wheel.zoneless.passive": "handleFocusLossIfNecessary()", "mouseleave": "handleFocusLossIfNecessary($event.target)", "keydown.tab": "handleFocusLossIfNecessary()", "keydown.shift.tab": "handleFocusLossIfNecessary()", "keydown.arrowDown.prevent": "onKeyDownArrow($event.target, 1)", "keydown.arrowUp.prevent": "onKeyDownArrow($event.target, -1)" }, properties: { "attr.role": "role", "attr.data-size": "size" } }, providers: [
86
91
  tuiAsDataListAccessor(TuiDataListComponent),
87
92
  {
88
93
  provide: TUI_OPTION_CONTENT,
@@ -115,6 +120,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
115
120
  },
116
121
  ], host: {
117
122
  role: 'listbox',
123
+ '[attr.role]': 'role',
118
124
  '[attr.data-size]': 'size',
119
125
  '(focusin)': 'onFocusIn($event.relatedTarget, $event.currentTarget)',
120
126
  '(mousedown.prevent)': '(0)',
@@ -136,4 +142,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
136
142
  }], size: [{
137
143
  type: Input
138
144
  }] } });
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 {NgIf} from '@angular/common';\nimport {\n    type AfterContentChecked,\n    type AfterContentInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    DestroyRef,\n    forwardRef,\n    inject,\n    Input,\n    isSignal,\n    NgZone,\n    type QueryList,\n    signal,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {toSignal} from '@angular/core/rxjs-interop';\nimport {EMPTY_QUERY} from '@taiga-ui/cdk/constants';\nimport {\n    tuiQueryListChanges,\n    tuiTakeUntilDestroyed,\n    tuiZonefree,\n} from '@taiga-ui/cdk/observables';\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, type TuiSizeS} from '@taiga-ui/core/types';\nimport {type PolymorpheusContent, PolymorpheusOutlet} from '@taiga-ui/polymorpheus';\nimport {combineLatest, map, ReplaySubject, startWith, switchMap, timer} from 'rxjs';\n\nimport {\n    TUI_DATA_LIST_HOST,\n    tuiAsDataListAccessor,\n    type TuiDataListAccessor,\n} from './data-list.tokens';\nimport {TuiOptionWithValue} from './option/option.directive';\nimport {TUI_OPTION_CONTENT, TuiWithOptionContent} from './option/option-content';\nimport {TuiOption} from './option/option-legacy.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: [\n        tuiAsDataListAccessor(TuiDataListComponent),\n        {\n            provide: TUI_OPTION_CONTENT,\n            useFactory: () =>\n                inject(TuiWithOptionContent, {optional: true})?.content ??\n                // TODO(v5): remove when all legacy controls are deleted\n                inject(TUI_OPTION_CONTENT, {\n                    host: true,\n                    skipSelf: true,\n                    optional: true,\n                }) ??\n                inject(TUI_OPTION_CONTENT, {skipSelf: true, optional: true}),\n        },\n    ],\n    host: {\n        role: 'listbox',\n        '[attr.data-size]': 'size',\n        '(focusin)': 'onFocusIn($event.relatedTarget, $event.currentTarget)',\n        '(mousedown.prevent)': '(0)',\n        '(wheel.zoneless.passive)': 'handleFocusLossIfNecessary()',\n        '(mouseleave)': 'handleFocusLossIfNecessary($event.target)',\n        '(keydown.tab)': 'handleFocusLossIfNecessary()',\n        '(keydown.shift.tab)': 'handleFocusLossIfNecessary()',\n        '(keydown.arrowDown.prevent)': 'onKeyDownArrow($event.target, 1)',\n        '(keydown.arrowUp.prevent)': 'onKeyDownArrow($event.target, -1)',\n    },\n})\nexport class TuiDataListComponent<T>\n    implements TuiDataListAccessor<T>, AfterContentChecked, AfterContentInit\n{\n    // TODO(v5): delete\n    @ContentChildren(forwardRef(() => TuiOption), {descendants: true})\n    private readonly legacyOptionsQuery: QueryList<TuiOption<T>> = EMPTY_QUERY;\n\n    @ContentChildren(forwardRef(() => TuiOptionWithValue), {descendants: true})\n    private readonly optionsQuery: QueryList<TuiOptionWithValue<T>> = EMPTY_QUERY;\n\n    private origin?: HTMLElement;\n    private readonly ngZone = inject(NgZone);\n    private readonly destroyRef = inject(DestroyRef);\n    private readonly el = tuiInjectElement();\n    private readonly cdr = inject(ChangeDetectorRef);\n    private readonly contentReady$ = new ReplaySubject<boolean>(1);\n\n    protected readonly fallback = toSignal(inject(TUI_NOTHING_FOUND_MESSAGE));\n    protected readonly empty = signal(false);\n\n    @Input()\n    public emptyContent: PolymorpheusContent;\n\n    @Input()\n    public size = tuiInjectDataListSize();\n\n    // TODO(v5): use signal `contentChildren`\n    public readonly options = toSignal<readonly T[]>(\n        this.contentReady$.pipe(\n            switchMap(() =>\n                combineLatest([\n                    tuiQueryListChanges(this.legacyOptionsQuery),\n                    tuiQueryListChanges(this.optionsQuery),\n                ]),\n            ),\n            map(([legacyOptions, options]) =>\n                [\n                    ...legacyOptions.map(({value}) => value),\n                    ...options.map(({value}) => value()),\n                ].filter(tuiIsPresent),\n            ),\n            startWith([]),\n        ),\n        {requireSync: true},\n    );\n\n    public onKeyDownArrow(current: HTMLElement, step: number): void {\n        const {elements} = this;\n\n        tuiMoveFocus(elements.indexOf(current), elements, step);\n    }\n\n    public handleFocusLossIfNecessary(element: Element = this.el): void {\n        if (tuiIsNativeFocusedIn(element)) {\n            this.origin?.focus({preventScroll: true});\n        }\n    }\n\n    public ngAfterContentInit(): void {\n        this.contentReady$.next(true);\n    }\n\n    // TODO: Refactor to :has after Safari support bumped to 15\n    public ngAfterContentChecked(): void {\n        timer(0)\n            .pipe(tuiZonefree(this.ngZone), tuiTakeUntilDestroyed(this.destroyRef))\n            .subscribe(() => {\n                this.empty.set(!this.elements.length);\n                this.cdr.detectChanges();\n            });\n    }\n\n    // TODO(v5): delete\n    public getOptions(includeDisabled = false): readonly T[] {\n        return [\n            ...this.legacyOptionsQuery, // TODO(v5): delete\n            ...this.optionsQuery,\n        ]\n            .filter(({disabled}) => includeDisabled || !disabled)\n            .map(({value}) => (isSignal(value) ? value() : value))\n            .filter(tuiIsPresent);\n    }\n\n    protected onFocusIn(relatedTarget: HTMLElement, currentTarget: HTMLElement): void {\n        if (!currentTarget.contains(relatedTarget) && !this.origin) {\n            this.origin = relatedTarget;\n        }\n    }\n\n    private get elements(): readonly HTMLElement[] {\n        return Array.from(this.el.querySelectorAll('[tuiOption]'));\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"]}
145
+ //# 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 {\n    type AfterContentChecked,\n    type AfterContentInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    DestroyRef,\n    forwardRef,\n    inject,\n    Input,\n    isSignal,\n    NgZone,\n    type QueryList,\n    signal,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {toSignal} from '@angular/core/rxjs-interop';\nimport {EMPTY_QUERY} from '@taiga-ui/cdk/constants';\nimport {\n    tuiQueryListChanges,\n    tuiTakeUntilDestroyed,\n    tuiZonefree,\n} from '@taiga-ui/cdk/observables';\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, type TuiSizeS} from '@taiga-ui/core/types';\nimport {type PolymorpheusContent, PolymorpheusOutlet} from '@taiga-ui/polymorpheus';\nimport {combineLatest, map, ReplaySubject, startWith, switchMap, timer} from 'rxjs';\n\nimport {\n    TUI_DATA_LIST_HOST,\n    tuiAsDataListAccessor,\n    type TuiDataListAccessor,\n} from './data-list.tokens';\nimport {TuiOptionWithValue} from './option/option.directive';\nimport {TUI_OPTION_CONTENT, TuiWithOptionContent} from './option/option-content';\nimport {TuiOption} from './option/option-legacy.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: [\n        tuiAsDataListAccessor(TuiDataListComponent),\n        {\n            provide: TUI_OPTION_CONTENT,\n            useFactory: () =>\n                inject(TuiWithOptionContent, {optional: true})?.content ??\n                // TODO(v5): remove when all legacy controls are deleted\n                inject(TUI_OPTION_CONTENT, {\n                    host: true,\n                    skipSelf: true,\n                    optional: true,\n                }) ??\n                inject(TUI_OPTION_CONTENT, {skipSelf: true, optional: true}),\n        },\n    ],\n    host: {\n        role: 'listbox',\n        '[attr.role]': 'role',\n        '[attr.data-size]': 'size',\n        '(focusin)': 'onFocusIn($event.relatedTarget, $event.currentTarget)',\n        '(mousedown.prevent)': '(0)',\n        '(wheel.zoneless.passive)': 'handleFocusLossIfNecessary()',\n        '(mouseleave)': 'handleFocusLossIfNecessary($event.target)',\n        '(keydown.tab)': 'handleFocusLossIfNecessary()',\n        '(keydown.shift.tab)': 'handleFocusLossIfNecessary()',\n        '(keydown.arrowDown.prevent)': 'onKeyDownArrow($event.target, 1)',\n        '(keydown.arrowUp.prevent)': 'onKeyDownArrow($event.target, -1)',\n    },\n})\nexport class TuiDataListComponent<T>\n    implements TuiDataListAccessor<T>, AfterContentChecked, AfterContentInit\n{\n    // TODO(v5): delete\n    @ContentChildren(forwardRef(() => TuiOption), {descendants: true})\n    private readonly legacyOptionsQuery: QueryList<TuiOption<T>> = EMPTY_QUERY;\n\n    @ContentChildren(forwardRef(() => TuiOptionWithValue), {descendants: true})\n    private readonly optionsQuery: QueryList<TuiOptionWithValue<T>> = EMPTY_QUERY;\n\n    private origin?: HTMLElement;\n    private readonly ngZone = inject(NgZone);\n    private readonly destroyRef = inject(DestroyRef);\n    private readonly el = tuiInjectElement();\n    private readonly cdr = inject(ChangeDetectorRef);\n    private readonly contentReady$ = new ReplaySubject<boolean>(1);\n\n    protected readonly fallback = toSignal(inject(TUI_NOTHING_FOUND_MESSAGE));\n    protected readonly empty = signal(false);\n\n    @Input()\n    public emptyContent: PolymorpheusContent;\n\n    @Input()\n    public size = tuiInjectDataListSize();\n\n    // TODO(v5): use signal `contentChildren`\n    public readonly options = toSignal<readonly T[]>(\n        this.contentReady$.pipe(\n            switchMap(() =>\n                combineLatest([\n                    tuiQueryListChanges(this.legacyOptionsQuery),\n                    tuiQueryListChanges(this.optionsQuery),\n                ]),\n            ),\n            map(([legacyOptions, options]) =>\n                [\n                    ...legacyOptions.map(({value}) => value),\n                    ...options.map(({value}) => value()),\n                ].filter(tuiIsPresent),\n            ),\n            startWith([]),\n        ),\n        {requireSync: true},\n    );\n\n    public onKeyDownArrow(current: HTMLElement, step: number): void {\n        const {elements} = this;\n\n        tuiMoveFocus(elements.indexOf(current), elements, step);\n    }\n\n    public handleFocusLossIfNecessary(element: Element = this.el): void {\n        if (tuiIsNativeFocusedIn(element)) {\n            this.origin?.focus({preventScroll: true});\n        }\n    }\n\n    public ngAfterContentInit(): void {\n        this.contentReady$.next(true);\n    }\n\n    // TODO: Refactor to :has after Safari support bumped to 15\n    public ngAfterContentChecked(): void {\n        timer(0)\n            .pipe(tuiZonefree(this.ngZone), tuiTakeUntilDestroyed(this.destroyRef))\n            .subscribe(() => {\n                this.empty.set(!this.elements.length);\n                this.cdr.detectChanges();\n            });\n    }\n\n    // TODO(v5): delete\n    public getOptions(includeDisabled = false): readonly T[] {\n        return [\n            ...this.legacyOptionsQuery, // TODO(v5): delete\n            ...this.optionsQuery,\n        ]\n            .filter(({disabled}) => includeDisabled || !disabled)\n            .map(({value}) => (isSignal(value) ? value() : value))\n            .filter(tuiIsPresent);\n    }\n\n    protected get role(): string | null {\n        return this.el.parentElement?.closest('[role=\"menu\"],[role=\"listbox\"]')\n            ? null\n            : this.el.role;\n    }\n\n    protected onFocusIn(relatedTarget: HTMLElement, currentTarget: HTMLElement): void {\n        if (!currentTarget.contains(relatedTarget) && !this.origin) {\n            this.origin = relatedTarget;\n        }\n    }\n\n    private get elements(): readonly HTMLElement[] {\n        return Array.from(this.el.querySelectorAll('[tuiOption]'));\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"]}
@@ -61,7 +61,7 @@ class TuiRoot {
61
61
  : !this.isChildRoot;
62
62
  }
63
63
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiRoot, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
64
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiRoot, isStandalone: true, selector: "tui-root", host: { attributes: { "data-tui-version": "4.74.1" }, listeners: { "touchstart.passive.zoneless": "0", "document:fullscreenchange": "top.set(isTopLayer)" }, properties: { "style.--tui-duration.ms": "duration", "style.--tui-scroll-behavior": "reducedMotion ? \"auto\" : \"smooth\"", "class._mobile": "isMobileRes()" } }, hostDirectives: [{ directive: i1.TuiPlatform }, { directive: i2.TuiVisualViewport }, { directive: i3.TuiFontSize }, { directive: i4.TuiActiveZone }], ngImport: i0, template: "<div class=\"t-root-content\">\n <ng-content />\n</div>\n<ng-container *ngIf=\"top()\">\n <tui-scroll-controls\n *ngIf=\"scrollbars\"\n class=\"t-root-scrollbar\"\n />\n <tui-popups />\n <ng-content select=\"tuiOverContent\" />\n <tui-dialogs />\n <ng-content select=\"tuiOverDialogs\" />\n <tui-alerts />\n <ng-content select=\"tuiOverAlerts\" />\n <tui-dropdowns />\n <ng-content select=\"tuiOverDropdowns\" />\n <tui-hints />\n <ng-content select=\"tuiOverHints\" />\n</ng-container>\n", styles: ["@keyframes tuiSkeletonVibe{to{opacity:.5}}@keyframes tuiPresent{to{opacity:.99999}}@keyframes tuiFade{0%{opacity:0}}@keyframes tuiSlide{0%{transform:var(--tui-from, translateY(100%))}}@keyframes tuiScale{0%{transform:scale(var(--tui-scale, 0))}}@keyframes tuiCollapse{0%{grid-template-rows:0fr}to{grid-template-rows:1fr}}.tui-enter,.tui-leave{animation-duration:var(--tui-duration);animation-timing-function:ease-in-out;pointer-events:none}.tui-leave{animation-direction:reverse}\n", ".tui-zero-scrollbar{scrollbar-width:none;-ms-overflow-style:none}.tui-zero-scrollbar::-webkit-scrollbar,.tui-zero-scrollbar::-webkit-scrollbar-thumb{display:none}body,input{margin:0}tui-root{position:relative;display:block;font:var(--tui-font-text-s);color:var(--tui-text-primary);flex:1;border-image:conic-gradient(var(--tui-background-base) 0 0) fill 0/0/0 0 100vh 0;-webkit-tap-highlight-color:transparent}:root{--tui-inline-start: left;--tui-inline-end: right;--tui-inline: 1}[dir=rtl]{--tui-inline-start: right;--tui-inline-end: left;--tui-inline: -1}tui-root>.t-root-scrollbar{position:fixed;top:0;left:0;bottom:0;right:0;z-index:0;display:none;margin:0}[data-tui-theme] tui-root>.t-root-scrollbar{display:block}.t-root-content{position:relative;top:var(--t-root-top);block-size:100%;isolation:isolate}.t-root-content>*{--t-root-top: 0}[tuiDropdownButton][tuiDropdownButton]{display:none}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: TuiAlerts, selector: "tui-alerts" }, { kind: "component", type: TuiDialogs, selector: "tui-dialogs" }, { kind: "component", type: TuiDropdowns, selector: "tui-dropdowns" }, { kind: "component", type: TuiHints, selector: "tui-hints" }, { kind: "component", type: TuiPopups, selector: "tui-popups" }, { kind: "component", type: TuiScrollControls, selector: "tui-scroll-controls" }], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None }); }
64
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiRoot, isStandalone: true, selector: "tui-root", host: { attributes: { "data-tui-version": "4.75.0" }, listeners: { "touchstart.passive.zoneless": "0", "document:fullscreenchange": "top.set(isTopLayer)" }, properties: { "style.--tui-duration.ms": "duration", "style.--tui-scroll-behavior": "reducedMotion ? \"auto\" : \"smooth\"", "class._mobile": "isMobileRes()" } }, hostDirectives: [{ directive: i1.TuiPlatform }, { directive: i2.TuiVisualViewport }, { directive: i3.TuiFontSize }, { directive: i4.TuiActiveZone }], ngImport: i0, template: "<div class=\"t-root-content\">\n <ng-content />\n</div>\n<ng-container *ngIf=\"top()\">\n <tui-scroll-controls\n *ngIf=\"scrollbars\"\n class=\"t-root-scrollbar\"\n />\n <tui-popups />\n <ng-content select=\"tuiOverContent\" />\n <tui-dialogs />\n <ng-content select=\"tuiOverDialogs\" />\n <tui-alerts />\n <ng-content select=\"tuiOverAlerts\" />\n <tui-dropdowns />\n <ng-content select=\"tuiOverDropdowns\" />\n <tui-hints />\n <ng-content select=\"tuiOverHints\" />\n</ng-container>\n", styles: ["@keyframes tuiSkeletonVibe{to{opacity:.5}}@keyframes tuiPresent{to{opacity:.99999}}@keyframes tuiFade{0%{opacity:0}}@keyframes tuiSlide{0%{transform:var(--tui-from, translateY(100%))}}@keyframes tuiScale{0%{transform:scale(var(--tui-scale, 0))}}@keyframes tuiCollapse{0%{grid-template-rows:0fr}to{grid-template-rows:1fr}}.tui-enter,.tui-leave{animation-duration:var(--tui-duration);animation-timing-function:ease-in-out;pointer-events:none}.tui-leave{animation-direction:reverse}\n", ".tui-zero-scrollbar{scrollbar-width:none;-ms-overflow-style:none}.tui-zero-scrollbar::-webkit-scrollbar,.tui-zero-scrollbar::-webkit-scrollbar-thumb{display:none}body,input{margin:0}tui-root{position:relative;display:block;font:var(--tui-font-text-s);color:var(--tui-text-primary);flex:1;border-image:conic-gradient(var(--tui-background-base) 0 0) fill 0/0/0 0 100vh 0;-webkit-tap-highlight-color:transparent}:root{--tui-inline-start: left;--tui-inline-end: right;--tui-inline: 1}[dir=rtl]{--tui-inline-start: right;--tui-inline-end: left;--tui-inline: -1}tui-root>.t-root-scrollbar{position:fixed;top:0;left:0;bottom:0;right:0;z-index:0;display:none;margin:0}[data-tui-theme] tui-root>.t-root-scrollbar{display:block}.t-root-content{position:relative;top:var(--t-root-top);block-size:100%;isolation:isolate}.t-root-content>*{--t-root-top: 0}[tuiDropdownButton][tuiDropdownButton]{display:none}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: TuiAlerts, selector: "tui-alerts" }, { kind: "component", type: TuiDialogs, selector: "tui-dialogs" }, { kind: "component", type: TuiDropdowns, selector: "tui-dropdowns" }, { kind: "component", type: TuiHints, selector: "tui-hints" }, { kind: "component", type: TuiPopups, selector: "tui-popups" }, { kind: "component", type: TuiScrollControls, selector: "tui-scroll-controls" }], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None }); }
65
65
  }
66
66
  export { TuiRoot };
67
67
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiRoot, decorators: [{