@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.
- package/components/data-list/data-list.component.d.ts +1 -0
- package/components/textfield/textfield.component.d.ts +1 -0
- package/components/textfield/textfield.directive.d.ts +7 -4
- package/directives/dropdown/dropdown-a11y.directive.d.ts +11 -0
- package/directives/dropdown/dropdown-context.directive.d.ts +2 -1
- package/directives/dropdown/dropdown-open.directive.d.ts +4 -3
- package/directives/dropdown/dropdown.d.ts +2 -1
- package/directives/dropdown/dropdown.directive.d.ts +3 -2
- package/directives/dropdown/dropdown.providers.d.ts +2 -1
- package/directives/dropdown/index.d.ts +1 -0
- package/esm2022/components/data-list/data-list.component.mjs +8 -2
- package/esm2022/components/root/root.component.mjs +1 -1
- package/esm2022/components/textfield/textfield-multi/textfield-multi.component.mjs +7 -7
- package/esm2022/components/textfield/textfield.component.mjs +15 -9
- package/esm2022/components/textfield/textfield.directive.mjs +10 -5
- package/esm2022/directives/dropdown/dropdown-a11y.directive.mjs +52 -0
- package/esm2022/directives/dropdown/dropdown-context.directive.mjs +12 -15
- package/esm2022/directives/dropdown/dropdown-open.directive.mjs +44 -36
- package/esm2022/directives/dropdown/dropdown.directive.mjs +11 -5
- package/esm2022/directives/dropdown/dropdown.mjs +3 -1
- package/esm2022/directives/dropdown/dropdown.providers.mjs +2 -1
- package/esm2022/directives/dropdown/index.mjs +2 -1
- package/fesm2022/taiga-ui-core-components-data-list.mjs +7 -1
- package/fesm2022/taiga-ui-core-components-data-list.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-components-root.mjs +1 -1
- package/fesm2022/taiga-ui-core-components-textfield.mjs +30 -21
- package/fesm2022/taiga-ui-core-components-textfield.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-directives-dropdown.mjs +105 -47
- package/fesm2022/taiga-ui-core-directives-dropdown.mjs.map +1 -1
- package/package.json +3 -3
- package/styles/mixins/hitbox.less +1 -1
|
@@ -1,36 +1,27 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { computed, ContentChild, Directive, ElementRef, EventEmitter, inject, Input, Output, } from '@angular/core';
|
|
1
|
+
import { computed, ContentChild, Directive, ElementRef, EventEmitter, inject, Input, NgZone, Output, } from '@angular/core';
|
|
3
2
|
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
4
3
|
import { TuiActiveZone } from '@taiga-ui/cdk/directives/active-zone';
|
|
5
4
|
import { TuiObscured } from '@taiga-ui/cdk/directives/obscured';
|
|
6
5
|
import { tuiCloseWatcher, tuiIfMap, tuiWatch, tuiZonefull, } from '@taiga-ui/cdk/observables';
|
|
7
6
|
import { tuiGetActualTarget, tuiInjectElement, tuiIsElement, tuiIsElementEditable, tuiIsHTMLElement, } from '@taiga-ui/cdk/utils/dom';
|
|
8
7
|
import { tuiGetClosestFocusable, tuiIsNativeFocusedIn, tuiIsNativeKeyboardFocusable, } from '@taiga-ui/cdk/utils/focus';
|
|
8
|
+
import { tuiProvide } from '@taiga-ui/cdk/utils/miscellaneous';
|
|
9
9
|
import { tuiAsDriver } from '@taiga-ui/core/classes';
|
|
10
10
|
import { tuiIsEditingKey } from '@taiga-ui/core/utils/miscellaneous';
|
|
11
|
-
import { shouldCall } from '@taiga-ui/event-plugins';
|
|
12
11
|
import { filter, fromEvent, merge } from 'rxjs';
|
|
13
12
|
import { TuiDropdownDirective } from './dropdown.directive';
|
|
14
13
|
import { TuiDropdownDriver } from './dropdown.driver';
|
|
14
|
+
import { TUI_DROPDOWN_HOST } from './dropdown.providers';
|
|
15
15
|
import * as i0 from "@angular/core";
|
|
16
16
|
import * as i1 from "@taiga-ui/cdk/directives/obscured";
|
|
17
17
|
import * as i2 from "@taiga-ui/cdk/directives/active-zone";
|
|
18
|
-
function shouldClose(event) {
|
|
19
|
-
return (
|
|
20
|
-
// @ts-ignore
|
|
21
|
-
typeof CloseWatcher === 'undefined' &&
|
|
22
|
-
// ?. for auto fill events
|
|
23
|
-
event.key?.toLowerCase() === 'escape' &&
|
|
24
|
-
this.tuiDropdownEnabled &&
|
|
25
|
-
!!this.tuiDropdownOpen &&
|
|
26
|
-
!this['dropdown']()?.nextElementSibling);
|
|
27
|
-
}
|
|
28
18
|
class TuiDropdownOpen {
|
|
29
19
|
constructor() {
|
|
30
20
|
this.directive = inject(TuiDropdownDirective);
|
|
31
21
|
this.el = tuiInjectElement();
|
|
32
22
|
this.obscured = inject(TuiObscured);
|
|
33
23
|
this.activeZone = inject(TuiActiveZone);
|
|
24
|
+
this.zone = inject(NgZone);
|
|
34
25
|
this.dropdown = computed(() => this.directive.ref()?.location.nativeElement);
|
|
35
26
|
this.tuiDropdownEnabled = true;
|
|
36
27
|
this.tuiDropdownOpen = false;
|
|
@@ -38,7 +29,7 @@ class TuiDropdownOpen {
|
|
|
38
29
|
// TODO: make it private when all legacy controls will be deleted from @taiga-ui/legacy (5.0)
|
|
39
30
|
this.driver = inject(TuiDropdownDriver);
|
|
40
31
|
this.sub = this.driver
|
|
41
|
-
.pipe(tuiIfMap(() => merge(tuiCloseWatcher(), this.obscured.tuiObscured.pipe(filter(Boolean)), this.activeZone.tuiActiveZoneChange.pipe(filter((a) => !a)), fromEvent(this.el, 'focusin').pipe(filter((event) => !this.
|
|
32
|
+
.pipe(tuiIfMap(() => merge(tuiCloseWatcher(), this.obscured.tuiObscured.pipe(filter(Boolean)), this.activeZone.tuiActiveZoneChange.pipe(filter((a) => !a)), fromEvent(this.el, 'focusin').pipe(filter((event) => !this.nativeElement.contains(tuiGetActualTarget(event)) ||
|
|
42
33
|
!this.directive.ref())))), tuiZonefull(), tuiWatch(), takeUntilDestroyed())
|
|
43
34
|
.subscribe(() => this.toggle(false));
|
|
44
35
|
this.sync = this.driver.pipe(takeUntilDestroyed()).subscribe((open) => {
|
|
@@ -47,28 +38,46 @@ class TuiDropdownOpen {
|
|
|
47
38
|
}
|
|
48
39
|
});
|
|
49
40
|
}
|
|
41
|
+
get nativeElement() {
|
|
42
|
+
const initial = this.dropdownHost?.nativeElement || this.el;
|
|
43
|
+
const focusable = tuiIsNativeKeyboardFocusable(initial)
|
|
44
|
+
? initial
|
|
45
|
+
: tuiGetClosestFocusable({ initial, root: this.el });
|
|
46
|
+
return this.dropdownHost?.nativeElement || focusable || this.el;
|
|
47
|
+
}
|
|
50
48
|
ngOnChanges() {
|
|
51
49
|
this.drive(!!this.tuiDropdownOpen);
|
|
52
50
|
this.tuiDropdownOpenChange.emit(!!this.tuiDropdownOpen);
|
|
53
51
|
}
|
|
54
52
|
toggle(open) {
|
|
55
53
|
if (this.focused && !open) {
|
|
56
|
-
this.
|
|
54
|
+
this.nativeElement.focus({ preventScroll: true });
|
|
57
55
|
}
|
|
58
56
|
this.update(open);
|
|
59
57
|
}
|
|
60
58
|
onEsc(event) {
|
|
61
|
-
|
|
62
|
-
|
|
59
|
+
if (
|
|
60
|
+
// @ts-ignore
|
|
61
|
+
typeof CloseWatcher === 'undefined' &&
|
|
62
|
+
// ?. for autofill events
|
|
63
|
+
event.key?.toLowerCase() === 'escape' &&
|
|
64
|
+
this.tuiDropdownEnabled &&
|
|
65
|
+
!!this.tuiDropdownOpen &&
|
|
66
|
+
!this.dropdown()?.nextElementSibling) {
|
|
67
|
+
this.zone.run(() => {
|
|
68
|
+
event.preventDefault();
|
|
69
|
+
this.toggle(false);
|
|
70
|
+
});
|
|
71
|
+
}
|
|
63
72
|
}
|
|
64
73
|
onClick(target) {
|
|
65
|
-
if (!this.editable && this.
|
|
74
|
+
if (!this.editable && this.nativeElement.contains(target)) {
|
|
66
75
|
this.update(!this.tuiDropdownOpen);
|
|
67
76
|
}
|
|
68
77
|
}
|
|
69
78
|
onArrow(event, up) {
|
|
70
79
|
if (!tuiIsElement(event.target) ||
|
|
71
|
-
!this.
|
|
80
|
+
!this.nativeElement.contains(event.target) ||
|
|
72
81
|
!this.tuiDropdownEnabled ||
|
|
73
82
|
!this.directive._content()) {
|
|
74
83
|
return;
|
|
@@ -84,21 +93,15 @@ class TuiDropdownOpen {
|
|
|
84
93
|
this.focused &&
|
|
85
94
|
tuiIsHTMLElement(target) &&
|
|
86
95
|
!tuiIsElementEditable(target)) {
|
|
87
|
-
this.
|
|
96
|
+
this.nativeElement.focus({ preventScroll: true });
|
|
88
97
|
}
|
|
89
98
|
}
|
|
90
|
-
get host() {
|
|
91
|
-
const initial = this.dropdownHost?.nativeElement || this.el;
|
|
92
|
-
const focusable = tuiIsNativeKeyboardFocusable(initial)
|
|
93
|
-
? initial
|
|
94
|
-
: tuiGetClosestFocusable({ initial, root: this.el });
|
|
95
|
-
return this.dropdownHost?.nativeElement || focusable || this.el;
|
|
96
|
-
}
|
|
97
99
|
get editable() {
|
|
98
|
-
return tuiIsElementEditable(this.
|
|
100
|
+
return tuiIsElementEditable(this.nativeElement);
|
|
99
101
|
}
|
|
100
102
|
get focused() {
|
|
101
|
-
return tuiIsNativeFocusedIn(this.
|
|
103
|
+
return (tuiIsNativeFocusedIn(this.nativeElement) ||
|
|
104
|
+
tuiIsNativeFocusedIn(this.dropdown()));
|
|
102
105
|
}
|
|
103
106
|
update(open) {
|
|
104
107
|
if (open && !this.tuiDropdownEnabled) {
|
|
@@ -126,18 +129,23 @@ class TuiDropdownOpen {
|
|
|
126
129
|
focusable?.focus();
|
|
127
130
|
}
|
|
128
131
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiDropdownOpen, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
129
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiDropdownOpen, isStandalone: true, selector: "[tuiDropdown][tuiDropdownOpen],[tuiDropdown][tuiDropdownOpenChange]", inputs: { tuiDropdownEnabled: "tuiDropdownEnabled", tuiDropdownOpen: "tuiDropdownOpen" }, outputs: { tuiDropdownOpenChange: "tuiDropdownOpenChange" }, host: { listeners: { "click": "onClick($event.target)", "keydown.arrowDown": "onArrow($event, false)", "keydown.arrowUp": "onArrow($event, true)", "document:keydown.zoneless.capture": "onEsc($event)", "document:keydown.zoneless": "onKeydown($event)", "tuiActiveZoneChange": "0" } }, providers: [
|
|
132
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiDropdownOpen, isStandalone: true, selector: "[tuiDropdown][tuiDropdownOpen],[tuiDropdown][tuiDropdownOpenChange]", inputs: { tuiDropdownEnabled: "tuiDropdownEnabled", tuiDropdownOpen: "tuiDropdownOpen" }, outputs: { tuiDropdownOpenChange: "tuiDropdownOpenChange" }, host: { listeners: { "click": "onClick($event.target)", "keydown.arrowDown": "onArrow($event, false)", "keydown.arrowUp": "onArrow($event, true)", "document:keydown.zoneless.capture": "onEsc($event)", "document:keydown.zoneless": "onKeydown($event)", "tuiActiveZoneChange": "0" } }, providers: [
|
|
133
|
+
TuiDropdownDriver,
|
|
134
|
+
tuiAsDriver(TuiDropdownDriver),
|
|
135
|
+
tuiProvide(TUI_DROPDOWN_HOST, TuiDropdownOpen),
|
|
136
|
+
], queries: [{ propertyName: "dropdownHost", first: true, predicate: ["tuiDropdownHost"], descendants: true, read: ElementRef }], usesOnChanges: true, hostDirectives: [{ directive: i1.TuiObscured }, { directive: i2.TuiActiveZone, inputs: ["tuiActiveZoneParent", "tuiActiveZoneParent"], outputs: ["tuiActiveZoneChange", "tuiActiveZoneChange"] }], ngImport: i0 }); }
|
|
130
137
|
}
|
|
131
|
-
__decorate([
|
|
132
|
-
shouldCall(shouldClose)
|
|
133
|
-
], TuiDropdownOpen.prototype, "onEsc", null);
|
|
134
138
|
export { TuiDropdownOpen };
|
|
135
139
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiDropdownOpen, decorators: [{
|
|
136
140
|
type: Directive,
|
|
137
141
|
args: [{
|
|
138
142
|
standalone: true,
|
|
139
143
|
selector: '[tuiDropdown][tuiDropdownOpen],[tuiDropdown][tuiDropdownOpenChange]',
|
|
140
|
-
providers: [
|
|
144
|
+
providers: [
|
|
145
|
+
TuiDropdownDriver,
|
|
146
|
+
tuiAsDriver(TuiDropdownDriver),
|
|
147
|
+
tuiProvide(TUI_DROPDOWN_HOST, TuiDropdownOpen),
|
|
148
|
+
],
|
|
141
149
|
hostDirectives: [
|
|
142
150
|
TuiObscured,
|
|
143
151
|
{
|
|
@@ -165,5 +173,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
165
173
|
type: Input
|
|
166
174
|
}], tuiDropdownOpenChange: [{
|
|
167
175
|
type: Output
|
|
168
|
-
}]
|
|
169
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-open.directive.js","sourceRoot":"","sources":["../../../../../projects/core/directives/dropdown/dropdown-open.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    computed,\n    ContentChild,\n    Directive,\n    ElementRef,\n    EventEmitter,\n    inject,\n    Input,\n    type OnChanges,\n    Output,\n} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {TuiActiveZone} from '@taiga-ui/cdk/directives/active-zone';\nimport {TuiObscured} from '@taiga-ui/cdk/directives/obscured';\nimport {\n    tuiCloseWatcher,\n    tuiIfMap,\n    tuiWatch,\n    tuiZonefull,\n} from '@taiga-ui/cdk/observables';\nimport {\n    tuiGetActualTarget,\n    tuiInjectElement,\n    tuiIsElement,\n    tuiIsElementEditable,\n    tuiIsHTMLElement,\n} from '@taiga-ui/cdk/utils/dom';\nimport {\n    tuiGetClosestFocusable,\n    tuiIsNativeFocusedIn,\n    tuiIsNativeKeyboardFocusable,\n} from '@taiga-ui/cdk/utils/focus';\nimport {tuiAsDriver} from '@taiga-ui/core/classes';\nimport {tuiIsEditingKey} from '@taiga-ui/core/utils/miscellaneous';\nimport {shouldCall} from '@taiga-ui/event-plugins';\nimport {filter, fromEvent, merge} from 'rxjs';\n\nimport {TuiDropdownDirective} from './dropdown.directive';\nimport {TuiDropdownDriver} from './dropdown.driver';\n\nfunction shouldClose(this: TuiDropdownOpen, event: KeyboardEvent): boolean {\n    return (\n        // @ts-ignore\n        typeof CloseWatcher === 'undefined' &&\n        // ?. for auto fill events\n        event.key?.toLowerCase() === 'escape' &&\n        this.tuiDropdownEnabled &&\n        !!this.tuiDropdownOpen &&\n        !this['dropdown']()?.nextElementSibling\n    );\n}\n\n@Directive({\n    standalone: true,\n    selector: '[tuiDropdown][tuiDropdownOpen],[tuiDropdown][tuiDropdownOpenChange]',\n    providers: [TuiDropdownDriver, tuiAsDriver(TuiDropdownDriver)],\n    hostDirectives: [\n        TuiObscured,\n        {\n            directive: TuiActiveZone,\n            inputs: ['tuiActiveZoneParent'],\n            outputs: ['tuiActiveZoneChange'],\n        },\n    ],\n    host: {\n        '(click)': 'onClick($event.target)',\n        '(keydown.arrowDown)': 'onArrow($event, false)',\n        '(keydown.arrowUp)': 'onArrow($event, true)',\n        '(document:keydown.zoneless.capture)': 'onEsc($event)',\n        '(document:keydown.zoneless)': 'onKeydown($event)',\n        // TODO: Necessary because startWith(false) + distinctUntilChanged() in TuiActiveZone, think of better solution\n        '(tuiActiveZoneChange)': '0',\n    },\n})\nexport class TuiDropdownOpen implements OnChanges {\n    @ContentChild('tuiDropdownHost', {descendants: true, read: ElementRef})\n    private readonly dropdownHost?: ElementRef<HTMLElement>;\n\n    private readonly directive = inject(TuiDropdownDirective);\n    private readonly el = tuiInjectElement();\n    private readonly obscured = inject(TuiObscured);\n    private readonly activeZone = inject(TuiActiveZone);\n\n    private readonly dropdown = computed(\n        () => this.directive.ref()?.location.nativeElement,\n    );\n\n    @Input()\n    public tuiDropdownEnabled = true;\n\n    @Input()\n    public tuiDropdownOpen: boolean | '' = false;\n\n    @Output()\n    public readonly tuiDropdownOpenChange = new EventEmitter<boolean>();\n\n    // TODO: make it private when all legacy controls will be deleted from @taiga-ui/legacy (5.0)\n    public readonly driver = inject(TuiDropdownDriver);\n    public readonly sub = this.driver\n        .pipe(\n            tuiIfMap(() =>\n                merge(\n                    tuiCloseWatcher(),\n                    this.obscured.tuiObscured.pipe(filter(Boolean)),\n                    this.activeZone.tuiActiveZoneChange.pipe(filter((a) => !a)),\n                    fromEvent(this.el, 'focusin').pipe(\n                        filter(\n                            (event) =>\n                                !this.host.contains(tuiGetActualTarget(event)) ||\n                                !this.directive.ref(),\n                        ),\n                    ),\n                ),\n            ),\n            tuiZonefull(),\n            tuiWatch(),\n            takeUntilDestroyed(),\n        )\n        .subscribe(() => this.toggle(false));\n\n    public readonly sync = this.driver.pipe(takeUntilDestroyed()).subscribe((open) => {\n        if (open !== this.tuiDropdownOpen) {\n            this.update(open);\n        }\n    });\n\n    public ngOnChanges(): void {\n        this.drive(!!this.tuiDropdownOpen);\n        this.tuiDropdownOpenChange.emit(!!this.tuiDropdownOpen);\n    }\n\n    public toggle(open: boolean): void {\n        if (this.focused && !open) {\n            this.host.focus({preventScroll: true});\n        }\n\n        this.update(open);\n    }\n\n    @shouldCall(shouldClose)\n    protected onEsc(event: KeyboardEvent): void {\n        event.preventDefault();\n        this.toggle(false);\n    }\n\n    protected onClick(target: HTMLElement): void {\n        if (!this.editable && this.host.contains(target)) {\n            this.update(!this.tuiDropdownOpen);\n        }\n    }\n\n    protected onArrow(event: KeyboardEvent, up: boolean): void {\n        if (\n            !tuiIsElement(event.target) ||\n            !this.host.contains(event.target) ||\n            !this.tuiDropdownEnabled ||\n            !this.directive._content()\n        ) {\n            return;\n        }\n\n        event.preventDefault();\n        this.focusDropdown(up);\n    }\n\n    protected onKeydown(event: KeyboardEvent): void {\n        const target = tuiGetActualTarget(event);\n\n        if (\n            !event.defaultPrevented &&\n            tuiIsEditingKey(event.key) &&\n            this.editable &&\n            this.focused &&\n            tuiIsHTMLElement(target) &&\n            !tuiIsElementEditable(target)\n        ) {\n            this.host.focus({preventScroll: true});\n        }\n    }\n\n    private get host(): HTMLElement {\n        const initial = this.dropdownHost?.nativeElement || this.el;\n        const focusable = tuiIsNativeKeyboardFocusable(initial)\n            ? initial\n            : tuiGetClosestFocusable({initial, root: this.el});\n\n        return this.dropdownHost?.nativeElement || focusable || this.el;\n    }\n\n    private get editable(): boolean {\n        return tuiIsElementEditable(this.host);\n    }\n\n    private get focused(): boolean {\n        return tuiIsNativeFocusedIn(this.host) || tuiIsNativeFocusedIn(this.dropdown());\n    }\n\n    private update(open: boolean): void {\n        if (open && !this.tuiDropdownEnabled) {\n            return this.drive();\n        }\n\n        this.tuiDropdownOpen = open;\n        this.tuiDropdownOpenChange.emit(open);\n        this.drive();\n    }\n\n    private drive(open = !!this.tuiDropdownOpen && this.tuiDropdownEnabled): void {\n        this.obscured.tuiObscuredEnabled = open;\n        this.driver.next(open);\n    }\n\n    private focusDropdown(previous: boolean): void {\n        const root = this.dropdown();\n\n        if (!root) {\n            this.update(true);\n\n            return;\n        }\n\n        const doc = this.el.ownerDocument;\n        const child = root.appendChild(doc.createElement('div'));\n        const initial = previous ? child : root;\n        const focusable = tuiGetClosestFocusable({initial, previous, root});\n\n        child.remove();\n        focusable?.focus();\n    }\n}\n"]}
|
|
176
|
+
}] } });
|
|
177
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-open.directive.js","sourceRoot":"","sources":["../../../../../projects/core/directives/dropdown/dropdown-open.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    computed,\n    ContentChild,\n    Directive,\n    ElementRef,\n    EventEmitter,\n    inject,\n    Input,\n    NgZone,\n    type OnChanges,\n    Output,\n} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {TuiActiveZone} from '@taiga-ui/cdk/directives/active-zone';\nimport {TuiObscured} from '@taiga-ui/cdk/directives/obscured';\nimport {\n    tuiCloseWatcher,\n    tuiIfMap,\n    tuiWatch,\n    tuiZonefull,\n} from '@taiga-ui/cdk/observables';\nimport {\n    tuiGetActualTarget,\n    tuiInjectElement,\n    tuiIsElement,\n    tuiIsElementEditable,\n    tuiIsHTMLElement,\n} from '@taiga-ui/cdk/utils/dom';\nimport {\n    tuiGetClosestFocusable,\n    tuiIsNativeFocusedIn,\n    tuiIsNativeKeyboardFocusable,\n} from '@taiga-ui/cdk/utils/focus';\nimport {tuiProvide} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {tuiAsDriver} from '@taiga-ui/core/classes';\nimport {tuiIsEditingKey} from '@taiga-ui/core/utils/miscellaneous';\nimport {filter, fromEvent, merge} from 'rxjs';\n\nimport {TuiDropdownDirective} from './dropdown.directive';\nimport {TuiDropdownDriver} from './dropdown.driver';\nimport {TUI_DROPDOWN_HOST} from './dropdown.providers';\n\n@Directive({\n    standalone: true,\n    selector: '[tuiDropdown][tuiDropdownOpen],[tuiDropdown][tuiDropdownOpenChange]',\n    providers: [\n        TuiDropdownDriver,\n        tuiAsDriver(TuiDropdownDriver),\n        tuiProvide(TUI_DROPDOWN_HOST, TuiDropdownOpen),\n    ],\n    hostDirectives: [\n        TuiObscured,\n        {\n            directive: TuiActiveZone,\n            inputs: ['tuiActiveZoneParent'],\n            outputs: ['tuiActiveZoneChange'],\n        },\n    ],\n    host: {\n        '(click)': 'onClick($event.target)',\n        '(keydown.arrowDown)': 'onArrow($event, false)',\n        '(keydown.arrowUp)': 'onArrow($event, true)',\n        '(document:keydown.zoneless.capture)': 'onEsc($event)',\n        '(document:keydown.zoneless)': 'onKeydown($event)',\n        // TODO: Necessary because startWith(false) + distinctUntilChanged() in TuiActiveZone, think of better solution\n        '(tuiActiveZoneChange)': '0',\n    },\n})\nexport class TuiDropdownOpen implements OnChanges, ElementRef<Element> {\n    @ContentChild('tuiDropdownHost', {descendants: true, read: ElementRef})\n    private readonly dropdownHost?: ElementRef<HTMLElement>;\n\n    private readonly directive = inject(TuiDropdownDirective);\n    private readonly el = tuiInjectElement();\n    private readonly obscured = inject(TuiObscured);\n    private readonly activeZone = inject(TuiActiveZone);\n    private readonly zone = inject(NgZone);\n\n    private readonly dropdown = computed(\n        () => this.directive.ref()?.location.nativeElement,\n    );\n\n    @Input()\n    public tuiDropdownEnabled = true;\n\n    @Input()\n    public tuiDropdownOpen: boolean | '' = false;\n\n    @Output()\n    public readonly tuiDropdownOpenChange = new EventEmitter<boolean>();\n\n    // TODO: make it private when all legacy controls will be deleted from @taiga-ui/legacy (5.0)\n    public readonly driver = inject(TuiDropdownDriver);\n    public readonly sub = this.driver\n        .pipe(\n            tuiIfMap(() =>\n                merge(\n                    tuiCloseWatcher(),\n                    this.obscured.tuiObscured.pipe(filter(Boolean)),\n                    this.activeZone.tuiActiveZoneChange.pipe(filter((a) => !a)),\n                    fromEvent(this.el, 'focusin').pipe(\n                        filter(\n                            (event) =>\n                                !this.nativeElement.contains(tuiGetActualTarget(event)) ||\n                                !this.directive.ref(),\n                        ),\n                    ),\n                ),\n            ),\n            tuiZonefull(),\n            tuiWatch(),\n            takeUntilDestroyed(),\n        )\n        .subscribe(() => this.toggle(false));\n\n    public readonly sync = this.driver.pipe(takeUntilDestroyed()).subscribe((open) => {\n        if (open !== this.tuiDropdownOpen) {\n            this.update(open);\n        }\n    });\n\n    public get nativeElement(): HTMLElement {\n        const initial = this.dropdownHost?.nativeElement || this.el;\n        const focusable = tuiIsNativeKeyboardFocusable(initial)\n            ? initial\n            : tuiGetClosestFocusable({initial, root: this.el});\n\n        return this.dropdownHost?.nativeElement || focusable || this.el;\n    }\n\n    public ngOnChanges(): void {\n        this.drive(!!this.tuiDropdownOpen);\n        this.tuiDropdownOpenChange.emit(!!this.tuiDropdownOpen);\n    }\n\n    public toggle(open: boolean): void {\n        if (this.focused && !open) {\n            this.nativeElement.focus({preventScroll: true});\n        }\n\n        this.update(open);\n    }\n\n    protected onEsc(event: KeyboardEvent): void {\n        if (\n            // @ts-ignore\n            typeof CloseWatcher === 'undefined' &&\n            // ?. for autofill events\n            event.key?.toLowerCase() === 'escape' &&\n            this.tuiDropdownEnabled &&\n            !!this.tuiDropdownOpen &&\n            !this.dropdown()?.nextElementSibling\n        ) {\n            this.zone.run(() => {\n                event.preventDefault();\n                this.toggle(false);\n            });\n        }\n    }\n\n    protected onClick(target: HTMLElement): void {\n        if (!this.editable && this.nativeElement.contains(target)) {\n            this.update(!this.tuiDropdownOpen);\n        }\n    }\n\n    protected onArrow(event: KeyboardEvent, up: boolean): void {\n        if (\n            !tuiIsElement(event.target) ||\n            !this.nativeElement.contains(event.target) ||\n            !this.tuiDropdownEnabled ||\n            !this.directive._content()\n        ) {\n            return;\n        }\n\n        event.preventDefault();\n        this.focusDropdown(up);\n    }\n\n    protected onKeydown(event: KeyboardEvent): void {\n        const target = tuiGetActualTarget(event);\n\n        if (\n            !event.defaultPrevented &&\n            tuiIsEditingKey(event.key) &&\n            this.editable &&\n            this.focused &&\n            tuiIsHTMLElement(target) &&\n            !tuiIsElementEditable(target)\n        ) {\n            this.nativeElement.focus({preventScroll: true});\n        }\n    }\n\n    private get editable(): boolean {\n        return tuiIsElementEditable(this.nativeElement);\n    }\n\n    private get focused(): boolean {\n        return (\n            tuiIsNativeFocusedIn(this.nativeElement) ||\n            tuiIsNativeFocusedIn(this.dropdown())\n        );\n    }\n\n    private update(open: boolean): void {\n        if (open && !this.tuiDropdownEnabled) {\n            return this.drive();\n        }\n\n        this.tuiDropdownOpen = open;\n        this.tuiDropdownOpenChange.emit(open);\n        this.drive();\n    }\n\n    private drive(open = !!this.tuiDropdownOpen && this.tuiDropdownEnabled): void {\n        this.obscured.tuiObscuredEnabled = open;\n        this.driver.next(open);\n    }\n\n    private focusDropdown(previous: boolean): void {\n        const root = this.dropdown();\n\n        if (!root) {\n            this.update(true);\n\n            return;\n        }\n\n        const doc = this.el.ownerDocument;\n        const child = root.appendChild(doc.createElement('div'));\n        const initial = previous ? child : root;\n        const focusable = tuiGetClosestFocusable({initial, previous, root});\n\n        child.remove();\n        focusable?.focus();\n    }\n}\n"]}
|
|
@@ -1,19 +1,22 @@
|
|
|
1
1
|
import { coerceArray } from '@angular/cdk/coercion';
|
|
2
|
-
import { ChangeDetectorRef, Directive, inject, INJECTOR, Input, signal, TemplateRef, } from '@angular/core';
|
|
2
|
+
import { ChangeDetectorRef, Directive, ElementRef, inject, INJECTOR, Input, signal, TemplateRef, } from '@angular/core';
|
|
3
3
|
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
4
4
|
import { tuiZonefreeScheduler } from '@taiga-ui/cdk/observables';
|
|
5
5
|
import { tuiInjectElement } from '@taiga-ui/cdk/utils/dom';
|
|
6
6
|
import { tuiAsRectAccessor, tuiAsVehicle, } from '@taiga-ui/core/classes';
|
|
7
7
|
import { tuiCheckFixedPosition } from '@taiga-ui/core/utils';
|
|
8
|
+
import { tuiProvide } from '@taiga-ui/cdk/utils/miscellaneous';
|
|
8
9
|
import { PolymorpheusComponent, PolymorpheusTemplate, } from '@taiga-ui/polymorpheus';
|
|
9
10
|
import { Subject, throttleTime } from 'rxjs';
|
|
10
11
|
import { TuiDropdownDriver, TuiDropdownDriverDirective } from './dropdown.driver';
|
|
11
|
-
import { TUI_DROPDOWN_COMPONENT } from './dropdown.providers';
|
|
12
|
+
import { TUI_DROPDOWN_COMPONENT, TUI_DROPDOWN_HOST } from './dropdown.providers';
|
|
12
13
|
import { TuiDropdownService } from './dropdown.service';
|
|
13
14
|
import { TuiDropdownPosition } from './dropdown-position.directive';
|
|
15
|
+
import { TuiDropdownA11y } from './dropdown-a11y.directive';
|
|
14
16
|
import * as i0 from "@angular/core";
|
|
15
17
|
import * as i1 from "./dropdown.driver";
|
|
16
|
-
import * as i2 from "./dropdown-
|
|
18
|
+
import * as i2 from "./dropdown-a11y.directive";
|
|
19
|
+
import * as i3 from "./dropdown-position.directive";
|
|
17
20
|
class TuiDropdownDirective {
|
|
18
21
|
constructor() {
|
|
19
22
|
this.refresh$ = new Subject();
|
|
@@ -82,7 +85,8 @@ class TuiDropdownDirective {
|
|
|
82
85
|
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiDropdownDirective, isStandalone: true, selector: "[tuiDropdown]:not(ng-container):not(ng-template)", inputs: { tuiDropdown: "tuiDropdown" }, host: { properties: { "class.tui-dropdown-open": "ref()" } }, providers: [
|
|
83
86
|
tuiAsRectAccessor(TuiDropdownDirective),
|
|
84
87
|
tuiAsVehicle(TuiDropdownDirective),
|
|
85
|
-
|
|
88
|
+
tuiProvide(TUI_DROPDOWN_HOST, ElementRef),
|
|
89
|
+
], exportAs: ["tuiDropdown"], hostDirectives: [{ directive: i1.TuiDropdownDriverDirective }, { directive: i2.TuiDropdownA11y, inputs: ["tuiDropdownRole", "tuiDropdownRole"] }, { directive: i3.TuiDropdownPosition, outputs: ["tuiDropdownDirectionChange", "tuiDropdownDirectionChange"] }], ngImport: i0 }); }
|
|
86
90
|
}
|
|
87
91
|
export { TuiDropdownDirective };
|
|
88
92
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiDropdownDirective, decorators: [{
|
|
@@ -93,10 +97,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
93
97
|
providers: [
|
|
94
98
|
tuiAsRectAccessor(TuiDropdownDirective),
|
|
95
99
|
tuiAsVehicle(TuiDropdownDirective),
|
|
100
|
+
tuiProvide(TUI_DROPDOWN_HOST, ElementRef),
|
|
96
101
|
],
|
|
97
102
|
exportAs: 'tuiDropdown',
|
|
98
103
|
hostDirectives: [
|
|
99
104
|
TuiDropdownDriverDirective,
|
|
105
|
+
{ directive: TuiDropdownA11y, inputs: ['tuiDropdownRole'] },
|
|
100
106
|
{
|
|
101
107
|
directive: TuiDropdownPosition,
|
|
102
108
|
outputs: ['tuiDropdownDirectionChange'],
|
|
@@ -109,4 +115,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
109
115
|
}], propDecorators: { tuiDropdown: [{
|
|
110
116
|
type: Input
|
|
111
117
|
}] } });
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.directive.js","sourceRoot":"","sources":["../../../../../projects/core/directives/dropdown/dropdown.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {coerceArray} from '@angular/cdk/coercion';\nimport {\n    type AfterViewChecked,\n    ChangeDetectorRef,\n    type ComponentRef,\n    Directive,\n    inject,\n    INJECTOR,\n    Input,\n    type OnDestroy,\n    signal,\n    TemplateRef,\n} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {tuiZonefreeScheduler} from '@taiga-ui/cdk/observables';\nimport {type TuiContext} from '@taiga-ui/cdk/types';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {\n    tuiAsRectAccessor,\n    tuiAsVehicle,\n    type TuiRectAccessor,\n    type TuiVehicle,\n} from '@taiga-ui/core/classes';\nimport {type TuiPortalItem} from '@taiga-ui/core/types';\nimport {tuiCheckFixedPosition} from '@taiga-ui/core/utils';\nimport {\n    PolymorpheusComponent,\n    type PolymorpheusContent,\n    PolymorpheusTemplate,\n} from '@taiga-ui/polymorpheus';\nimport {Subject, throttleTime} from 'rxjs';\n\nimport {TuiDropdownDriver, TuiDropdownDriverDirective} from './dropdown.driver';\nimport {TUI_DROPDOWN_COMPONENT} from './dropdown.providers';\nimport {TuiDropdownService} from './dropdown.service';\nimport {TuiDropdownPosition} from './dropdown-position.directive';\n\n@Directive({\n    standalone: true,\n    selector: '[tuiDropdown]:not(ng-container):not(ng-template)',\n    providers: [\n        tuiAsRectAccessor(TuiDropdownDirective),\n        tuiAsVehicle(TuiDropdownDirective),\n    ],\n    exportAs: 'tuiDropdown',\n    hostDirectives: [\n        TuiDropdownDriverDirective,\n        {\n            directive: TuiDropdownPosition,\n            outputs: ['tuiDropdownDirectionChange'],\n        },\n    ],\n    host: {\n        '[class.tui-dropdown-open]': 'ref()',\n    },\n})\nexport class TuiDropdownDirective\n    implements AfterViewChecked, OnDestroy, TuiPortalItem, TuiRectAccessor, TuiVehicle\n{\n    private readonly refresh$ = new Subject<void>();\n    private readonly service = inject(TuiDropdownService);\n    private readonly cdr = inject(ChangeDetectorRef);\n\n    // TODO: think of a better solution later\n    private readonly drivers = coerceArray(\n        inject(TuiDropdownDriver, {self: true, optional: true}),\n    );\n\n    protected readonly sub = this.refresh$\n        .pipe(throttleTime(0, tuiZonefreeScheduler()), takeUntilDestroyed())\n        .subscribe(() => {\n            this.ref()?.changeDetectorRef.detectChanges();\n            this.ref()?.changeDetectorRef.markForCheck();\n        });\n\n    public readonly el = tuiInjectElement();\n    public readonly type = 'dropdown';\n    public readonly component = new PolymorpheusComponent(\n        inject(TUI_DROPDOWN_COMPONENT),\n        inject(INJECTOR),\n    );\n\n    public ref = signal<ComponentRef<unknown> | null>(null);\n    // TODO(v5): rename to `content`\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    public readonly _content = signal<PolymorpheusContent<TuiContext<() => void>>>(null);\n\n    @Input()\n    public set tuiDropdown(content: PolymorpheusContent<TuiContext<() => void>>) {\n        this._content.set(\n            content instanceof TemplateRef\n                ? new PolymorpheusTemplate(content, this.cdr)\n                : content,\n        );\n\n        if (!this._content()) {\n            this.toggle(false);\n        }\n    }\n\n    public get position(): 'absolute' | 'fixed' {\n        return tuiCheckFixedPosition(this.el) ? 'fixed' : 'absolute';\n    }\n\n    // TODO(v5): delete\n    public get content(): PolymorpheusContent<TuiContext<() => void>> {\n        return this._content();\n    }\n\n    // TODO(v5): delete\n    public set content(x: PolymorpheusContent<TuiContext<() => void>>) {\n        this._content.set(x);\n    }\n\n    public ngAfterViewChecked(): void {\n        if (this.ref()) {\n            this.refresh$.next();\n        }\n    }\n\n    public ngOnDestroy(): void {\n        this.toggle(false);\n    }\n\n    public getClientRect(): DOMRect {\n        return this.el.getBoundingClientRect();\n    }\n\n    public toggle(show: boolean): void {\n        const ref = this.ref();\n\n        if (show && this._content() && !ref) {\n            this.ref.set(this.service.add(this.component));\n        } else if (!show && ref) {\n            this.ref.set(null);\n            this.service.remove(ref);\n        }\n\n        this.drivers.forEach((driver) => driver?.next(show));\n\n        // TODO: Remove in v5, only needed in Angular 16\n        this.cdr.markForCheck();\n    }\n}\n"]}
|
|
118
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.directive.js","sourceRoot":"","sources":["../../../../../projects/core/directives/dropdown/dropdown.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {coerceArray} from '@angular/cdk/coercion';\nimport {\n    type AfterViewChecked,\n    ChangeDetectorRef,\n    type ComponentRef,\n    Directive,\n    ElementRef,\n    inject,\n    INJECTOR,\n    Input,\n    type OnDestroy,\n    signal,\n    TemplateRef,\n} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {tuiZonefreeScheduler} from '@taiga-ui/cdk/observables';\nimport {type TuiContext} from '@taiga-ui/cdk/types';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {\n    tuiAsRectAccessor,\n    tuiAsVehicle,\n    type TuiRectAccessor,\n    type TuiVehicle,\n} from '@taiga-ui/core/classes';\nimport {type TuiPortalItem} from '@taiga-ui/core/types';\nimport {tuiCheckFixedPosition} from '@taiga-ui/core/utils';\nimport {tuiProvide} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {\n    PolymorpheusComponent,\n    type PolymorpheusContent,\n    PolymorpheusTemplate,\n} from '@taiga-ui/polymorpheus';\nimport {Subject, throttleTime} from 'rxjs';\n\nimport {TuiDropdownDriver, TuiDropdownDriverDirective} from './dropdown.driver';\nimport {TUI_DROPDOWN_COMPONENT, TUI_DROPDOWN_HOST} from './dropdown.providers';\nimport {TuiDropdownService} from './dropdown.service';\nimport {TuiDropdownPosition} from './dropdown-position.directive';\nimport {TuiDropdownA11y} from './dropdown-a11y.directive';\n\n@Directive({\n    standalone: true,\n    selector: '[tuiDropdown]:not(ng-container):not(ng-template)',\n    providers: [\n        tuiAsRectAccessor(TuiDropdownDirective),\n        tuiAsVehicle(TuiDropdownDirective),\n        tuiProvide(TUI_DROPDOWN_HOST, ElementRef),\n    ],\n    exportAs: 'tuiDropdown',\n    hostDirectives: [\n        TuiDropdownDriverDirective,\n        {directive: TuiDropdownA11y, inputs: ['tuiDropdownRole']},\n        {\n            directive: TuiDropdownPosition,\n            outputs: ['tuiDropdownDirectionChange'],\n        },\n    ],\n    host: {\n        '[class.tui-dropdown-open]': 'ref()',\n    },\n})\nexport class TuiDropdownDirective\n    implements AfterViewChecked, OnDestroy, TuiPortalItem, TuiRectAccessor, TuiVehicle\n{\n    private readonly refresh$ = new Subject<void>();\n    private readonly service = inject(TuiDropdownService);\n    private readonly cdr = inject(ChangeDetectorRef);\n\n    // TODO: think of a better solution later\n    private readonly drivers = coerceArray(\n        inject(TuiDropdownDriver, {self: true, optional: true}),\n    );\n\n    protected readonly sub = this.refresh$\n        .pipe(throttleTime(0, tuiZonefreeScheduler()), takeUntilDestroyed())\n        .subscribe(() => {\n            this.ref()?.changeDetectorRef.detectChanges();\n            this.ref()?.changeDetectorRef.markForCheck();\n        });\n\n    public readonly el = tuiInjectElement();\n    public readonly type = 'dropdown';\n    public readonly component = new PolymorpheusComponent(\n        inject(TUI_DROPDOWN_COMPONENT),\n        inject(INJECTOR),\n    );\n\n    public ref = signal<ComponentRef<unknown> | null>(null);\n    // TODO(v5): rename to `content`\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    public readonly _content = signal<PolymorpheusContent<TuiContext<() => void>>>(null);\n\n    @Input()\n    public set tuiDropdown(content: PolymorpheusContent<TuiContext<() => void>>) {\n        this._content.set(\n            content instanceof TemplateRef\n                ? new PolymorpheusTemplate(content, this.cdr)\n                : content,\n        );\n\n        if (!this._content()) {\n            this.toggle(false);\n        }\n    }\n\n    public get position(): 'absolute' | 'fixed' {\n        return tuiCheckFixedPosition(this.el) ? 'fixed' : 'absolute';\n    }\n\n    // TODO(v5): delete\n    public get content(): PolymorpheusContent<TuiContext<() => void>> {\n        return this._content();\n    }\n\n    // TODO(v5): delete\n    public set content(x: PolymorpheusContent<TuiContext<() => void>>) {\n        this._content.set(x);\n    }\n\n    public ngAfterViewChecked(): void {\n        if (this.ref()) {\n            this.refresh$.next();\n        }\n    }\n\n    public ngOnDestroy(): void {\n        this.toggle(false);\n    }\n\n    public getClientRect(): DOMRect {\n        return this.el.getBoundingClientRect();\n    }\n\n    public toggle(show: boolean): void {\n        const ref = this.ref();\n\n        if (show && this._content() && !ref) {\n            this.ref.set(this.service.add(this.component));\n        } else if (!show && ref) {\n            this.ref.set(null);\n            this.service.remove(ref);\n        }\n\n        this.drivers.forEach((driver) => driver?.next(show));\n\n        // TODO: Remove in v5, only needed in Angular 16\n        this.cdr.markForCheck();\n    }\n}\n"]}
|
|
@@ -11,6 +11,7 @@ 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
|
+
import { TuiDropdownA11y } from './dropdown-a11y.directive';
|
|
14
15
|
export const TuiDropdown = [
|
|
15
16
|
TuiDropdownOptionsDirective,
|
|
16
17
|
TuiDropdownDriverDirective,
|
|
@@ -25,5 +26,6 @@ export const TuiDropdown = [
|
|
|
25
26
|
TuiDropdownPosition,
|
|
26
27
|
TuiDropdownPositionSided,
|
|
27
28
|
TuiDropdownSelection,
|
|
29
|
+
TuiDropdownA11y,
|
|
28
30
|
];
|
|
29
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2RpcmVjdGl2ZXMvZHJvcGRvd24vZHJvcGRvd24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFDMUQsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFDMUQsT0FBTyxFQUFDLDBCQUEwQixFQUFDLE1BQU0sbUJBQW1CLENBQUM7QUFDN0QsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFDaEUsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sNEJBQTRCLENBQUM7QUFDNUQsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sNkJBQTZCLENBQUM7QUFDOUQsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLDJCQUEyQixDQUFDO0FBQzFELE9BQU8sRUFBQyxxQkFBcUIsRUFBQyxNQUFNLGtDQUFrQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBQywyQkFBMkIsRUFBQyxNQUFNLDhCQUE4QixDQUFDO0FBQ3pFLE9BQU8sRUFBQyxpQkFBaUIsRUFBQyxNQUFNLDZCQUE2QixDQUFDO0FBQzlELE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLCtCQUErQixDQUFDO0FBQ2xFLE9BQU8sRUFBQyx3QkFBd0IsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQzdFLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLGdDQUFnQyxDQUFDO0FBQ3BFLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSwyQkFBMkIsQ0FBQztBQUUxRCxNQUFNLENBQUMsTUFBTSxXQUFXLEdBQUc7SUFDdkIsMkJBQTJCO0lBQzNCLDBCQUEwQjtJQUMxQixvQkFBb0I7SUFDcEIsb0JBQW9CO0lBQ3BCLGVBQWU7SUFDZixxQkFBcUI7SUFDckIsaUJBQWlCO0lBQ2pCLGlCQUFpQjtJQUNqQixnQkFBZ0I7SUFDaEIsa0JBQWtCO0lBQ2xCLG1CQUFtQjtJQUNuQix3QkFBd0I7SUFDeEIsb0JBQW9CO0lBQ3BCLGVBQWU7Q0FDVCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtUdWlEcm9wZG93bkNvbXBvbmVudH0gZnJvbSAnLi9kcm9wZG93bi5jb21wb25lbnQnO1xuaW1wb3J0IHtUdWlEcm9wZG93bkRpcmVjdGl2ZX0gZnJvbSAnLi9kcm9wZG93bi5kaXJlY3RpdmUnO1xuaW1wb3J0IHtUdWlEcm9wZG93bkRyaXZlckRpcmVjdGl2ZX0gZnJvbSAnLi9kcm9wZG93bi5kcml2ZXInO1xuaW1wb3J0IHtUdWlEcm9wZG93bkNvbnRleHR9IGZyb20gJy4vZHJvcGRvd24tY29udGV4dC5kaXJlY3RpdmUnO1xuaW1wb3J0IHtUdWlEcm9wZG93bkhvdmVyfSBmcm9tICcuL2Ryb3Bkb3duLWhvdmVyLmRpcmVjdGl2ZSc7XG5pbXBvcnQge1R1aURyb3Bkb3duTWFudWFsfSBmcm9tICcuL2Ryb3Bkb3duLW1hbnVhbC5kaXJlY3RpdmUnO1xuaW1wb3J0IHtUdWlEcm9wZG93bk9wZW59IGZyb20gJy4vZHJvcGRvd24tb3Blbi5kaXJlY3RpdmUnO1xuaW1wb3J0IHtUdWlEcm9wZG93bk9wZW5MZWdhY3l9IGZyb20gJy4vZHJvcGRvd24tb3Blbi1sZWdhY3kuZGlyZWN0aXZlJztcbmltcG9ydCB7VHVpRHJvcGRvd25PcHRpb25zRGlyZWN0aXZlfSBmcm9tICcuL2Ryb3Bkb3duLW9wdGlvbnMuZGlyZWN0aXZlJztcbmltcG9ydCB7VHVpRHJvcGRvd25Qb3J0YWx9IGZyb20gJy4vZHJvcGRvd24tcG9ydGFsLmRpcmVjdGl2ZSc7XG5pbXBvcnQge1R1aURyb3Bkb3duUG9zaXRpb259IGZyb20gJy4vZHJvcGRvd24tcG9zaXRpb24uZGlyZWN0aXZlJztcbmltcG9ydCB7VHVpRHJvcGRvd25Qb3NpdGlvblNpZGVkfSBmcm9tICcuL2Ryb3Bkb3duLXBvc2l0aW9uLXNpZGVkLmRpcmVjdGl2ZSc7XG5pbXBvcnQge1R1aURyb3Bkb3duU2VsZWN0aW9ufSBmcm9tICcuL2Ryb3Bkb3duLXNlbGVjdGlvbi5kaXJlY3RpdmUnO1xuaW1wb3J0IHtUdWlEcm9wZG93bkExMXl9IGZyb20gJy4vZHJvcGRvd24tYTExeS5kaXJlY3RpdmUnO1xuXG5leHBvcnQgY29uc3QgVHVpRHJvcGRvd24gPSBbXG4gICAgVHVpRHJvcGRvd25PcHRpb25zRGlyZWN0aXZlLFxuICAgIFR1aURyb3Bkb3duRHJpdmVyRGlyZWN0aXZlLFxuICAgIFR1aURyb3Bkb3duRGlyZWN0aXZlLFxuICAgIFR1aURyb3Bkb3duQ29tcG9uZW50LFxuICAgIFR1aURyb3Bkb3duT3BlbixcbiAgICBUdWlEcm9wZG93bk9wZW5MZWdhY3ksXG4gICAgVHVpRHJvcGRvd25Qb3J0YWwsXG4gICAgVHVpRHJvcGRvd25NYW51YWwsXG4gICAgVHVpRHJvcGRvd25Ib3ZlcixcbiAgICBUdWlEcm9wZG93bkNvbnRleHQsXG4gICAgVHVpRHJvcGRvd25Qb3NpdGlvbixcbiAgICBUdWlEcm9wZG93blBvc2l0aW9uU2lkZWQsXG4gICAgVHVpRHJvcGRvd25TZWxlY3Rpb24sXG4gICAgVHVpRHJvcGRvd25BMTF5LFxuXSBhcyBjb25zdDtcbiJdfQ==
|
|
@@ -7,4 +7,5 @@ export const TUI_DROPDOWN_COMPONENT = new InjectionToken(ngDevMode ? 'TUI_DROPDO
|
|
|
7
7
|
factory: () => TuiDropdownComponent,
|
|
8
8
|
});
|
|
9
9
|
export const TUI_DROPDOWN_CONTEXT = new InjectionToken(ngDevMode ? 'TUI_DROPDOWN_CONTEXT' : '');
|
|
10
|
-
|
|
10
|
+
export const TUI_DROPDOWN_HOST = new InjectionToken(ngDevMode ? 'TUI_DROPDOWN_HOST' : '');
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24ucHJvdmlkZXJzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9kaXJlY3RpdmVzL2Ryb3Bkb3duL2Ryb3Bkb3duLnByb3ZpZGVycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWtCLGNBQWMsRUFBWSxNQUFNLGVBQWUsQ0FBQztBQUV6RSxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUUxRDs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLHNCQUFzQixHQUFHLElBQUksY0FBYyxDQUNwRCxTQUFTLENBQUMsQ0FBQyxDQUFDLHdCQUF3QixDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQ3pDO0lBQ0ksT0FBTyxFQUFFLEdBQUcsRUFBRSxDQUFDLG9CQUFvQjtDQUN0QyxDQUNKLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxvQkFBb0IsR0FBRyxJQUFJLGNBQWMsQ0FDbEQsU0FBUyxDQUFDLENBQUMsQ0FBQyxzQkFBc0IsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUMxQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsSUFBSSxjQUFjLENBQy9DLFNBQVMsQ0FBQyxDQUFDLENBQUMsbUJBQW1CLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FDdkMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7dHlwZSBFbGVtZW50UmVmLCBJbmplY3Rpb25Ub2tlbiwgdHlwZSBUeXBlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHtUdWlEcm9wZG93bkNvbXBvbmVudH0gZnJvbSAnLi9kcm9wZG93bi5jb21wb25lbnQnO1xuXG4vKipcbiAqIEEgY29tcG9uZW50IHRvIGRpc3BsYXkgYSBkcm9wZG93blxuICovXG5leHBvcnQgY29uc3QgVFVJX0RST1BET1dOX0NPTVBPTkVOVCA9IG5ldyBJbmplY3Rpb25Ub2tlbjxUeXBlPGFueT4+KFxuICAgIG5nRGV2TW9kZSA/ICdUVUlfRFJPUERPV05fQ09NUE9ORU5UJyA6ICcnLFxuICAgIHtcbiAgICAgICAgZmFjdG9yeTogKCkgPT4gVHVpRHJvcGRvd25Db21wb25lbnQsXG4gICAgfSxcbik7XG5cbmV4cG9ydCBjb25zdCBUVUlfRFJPUERPV05fQ09OVEVYVCA9IG5ldyBJbmplY3Rpb25Ub2tlbjxSZWNvcmQ8YW55LCBhbnk+PihcbiAgICBuZ0Rldk1vZGUgPyAnVFVJX0RST1BET1dOX0NPTlRFWFQnIDogJycsXG4pO1xuXG5leHBvcnQgY29uc3QgVFVJX0RST1BET1dOX0hPU1QgPSBuZXcgSW5qZWN0aW9uVG9rZW48RWxlbWVudFJlZjxFbGVtZW50Pj4oXG4gICAgbmdEZXZNb2RlID8gJ1RVSV9EUk9QRE9XTl9IT1NUJyA6ICcnLFxuKTtcbiJdfQ==
|
|
@@ -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';
|
|
@@ -19,4 +20,4 @@ export * from './dropdown-position-sided.directive';
|
|
|
19
20
|
export * from './dropdown-selection.directive';
|
|
20
21
|
export * from './dropdowns.component';
|
|
21
22
|
export * from './with-dropdown-open.directive';
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2RpcmVjdGl2ZXMvZHJvcGRvd24vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsZ0NBQWdDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2Ryb3Bkb3duJztcbmV4cG9ydCAqIGZyb20gJy4vZHJvcGRvd24uYmluZGluZ3MnO1xuZXhwb3J0ICogZnJvbSAnLi9kcm9wZG93bi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9kcm9wZG93bi5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9kcm9wZG93bi5kcml2ZXInO1xuZXhwb3J0ICogZnJvbSAnLi9kcm9wZG93bi5wcm92aWRlcnMnO1xuZXhwb3J0ICogZnJvbSAnLi9kcm9wZG93bi5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vZHJvcGRvd24tYTExeS5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9kcm9wZG93bi1jb250ZXh0LmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2Ryb3Bkb3duLWhvdmVyLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2Ryb3Bkb3duLWhvdmVyLm9wdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9kcm9wZG93bi1saW1pdC13aWR0aCc7XG5leHBvcnQgKiBmcm9tICcuL2Ryb3Bkb3duLW1hbnVhbC5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9kcm9wZG93bi1vcGVuLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2Ryb3Bkb3duLW9wZW4tbGVnYWN5LmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2Ryb3Bkb3duLW9wdGlvbnMuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZHJvcGRvd24tcG9ydGFsLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2Ryb3Bkb3duLXBvc2l0aW9uLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2Ryb3Bkb3duLXBvc2l0aW9uLXNpZGVkLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2Ryb3Bkb3duLXNlbGVjdGlvbi5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9kcm9wZG93bnMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vd2l0aC1kcm9wZG93bi1vcGVuLmRpcmVjdGl2ZSc7XG4iXX0=
|
|
@@ -295,6 +295,11 @@ class TuiDataListComponent {
|
|
|
295
295
|
.map(({ value }) => (isSignal(value) ? value() : value))
|
|
296
296
|
.filter(tuiIsPresent);
|
|
297
297
|
}
|
|
298
|
+
get role() {
|
|
299
|
+
return this.el.parentElement?.closest('[role="menu"],[role="listbox"]')
|
|
300
|
+
? null
|
|
301
|
+
: this.el.role;
|
|
302
|
+
}
|
|
298
303
|
onFocusIn(relatedTarget, currentTarget) {
|
|
299
304
|
if (!currentTarget.contains(relatedTarget) && !this.origin) {
|
|
300
305
|
this.origin = relatedTarget;
|
|
@@ -304,7 +309,7 @@ class TuiDataListComponent {
|
|
|
304
309
|
return Array.from(this.el.querySelectorAll('[tuiOption]'));
|
|
305
310
|
}
|
|
306
311
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiDataListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
307
|
-
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: [
|
|
312
|
+
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: [
|
|
308
313
|
tuiAsDataListAccessor(TuiDataListComponent),
|
|
309
314
|
{
|
|
310
315
|
provide: TUI_OPTION_CONTENT,
|
|
@@ -336,6 +341,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
336
341
|
},
|
|
337
342
|
], host: {
|
|
338
343
|
role: 'listbox',
|
|
344
|
+
'[attr.role]': 'role',
|
|
339
345
|
'[attr.data-size]': 'size',
|
|
340
346
|
'(focusin)': 'onFocusIn($event.relatedTarget, $event.currentTarget)',
|
|
341
347
|
'(mousedown.prevent)': '(0)',
|