@angular/aria 21.0.0-rc.2 → 21.0.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/_adev_assets/aria-accordion.json +5 -19
- package/_adev_assets/aria-combobox.json +9 -97
- package/_adev_assets/aria-grid.json +5 -19
- package/_adev_assets/aria-listbox.json +0 -51
- package/_adev_assets/aria-menu.json +7 -35
- package/_adev_assets/aria-tabs.json +3 -294
- package/_adev_assets/aria-toolbar.json +22 -212
- package/_adev_assets/aria-tree.json +3 -356
- package/fesm2022/accordion.mjs +11 -11
- package/fesm2022/accordion.mjs.map +1 -1
- package/fesm2022/aria.mjs +1 -1
- package/fesm2022/aria.mjs.map +1 -1
- package/fesm2022/combobox.mjs +5 -11
- package/fesm2022/combobox.mjs.map +1 -1
- package/fesm2022/grid.mjs +5 -4
- package/fesm2022/grid.mjs.map +1 -1
- package/fesm2022/listbox.mjs +8 -8
- package/fesm2022/listbox.mjs.map +1 -1
- package/fesm2022/menu.mjs +6 -4
- package/fesm2022/menu.mjs.map +1 -1
- package/fesm2022/private.mjs +5 -3
- package/fesm2022/private.mjs.map +1 -1
- package/fesm2022/tabs.mjs +23 -22
- package/fesm2022/tabs.mjs.map +1 -1
- package/fesm2022/toolbar.mjs +40 -20
- package/fesm2022/toolbar.mjs.map +1 -1
- package/fesm2022/tree.mjs +21 -20
- package/fesm2022/tree.mjs.map +1 -1
- package/package.json +3 -3
- package/types/accordion.d.ts +2 -2
- package/types/combobox.d.ts +1 -5
- package/types/grid.d.ts +1 -1
- package/types/listbox.d.ts +2 -2
- package/types/menu.d.ts +3 -3
- package/types/private.d.ts +1 -1
- package/types/tabs.d.ts +8 -8
- package/types/toolbar.d.ts +12 -10
- package/types/tree.d.ts +8 -8
|
@@ -149,137 +149,6 @@
|
|
|
149
149
|
"description": "The `aria-current` type. It can be used in navigation trees to indicate the currently active item.\nSee https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Reference/Attributes/aria-current for more details.",
|
|
150
150
|
"jsdocTags": []
|
|
151
151
|
},
|
|
152
|
-
{
|
|
153
|
-
"name": "onFocus",
|
|
154
|
-
"signatures": [
|
|
155
|
-
{
|
|
156
|
-
"name": "onFocus",
|
|
157
|
-
"entryType": "function",
|
|
158
|
-
"description": "",
|
|
159
|
-
"generics": [],
|
|
160
|
-
"isNewType": false,
|
|
161
|
-
"jsdocTags": [],
|
|
162
|
-
"params": [],
|
|
163
|
-
"rawComment": "",
|
|
164
|
-
"returnType": "void"
|
|
165
|
-
}
|
|
166
|
-
],
|
|
167
|
-
"implementation": {
|
|
168
|
-
"params": [],
|
|
169
|
-
"isNewType": false,
|
|
170
|
-
"returnType": "void",
|
|
171
|
-
"generics": [],
|
|
172
|
-
"name": "onFocus",
|
|
173
|
-
"description": "",
|
|
174
|
-
"entryType": "function",
|
|
175
|
-
"jsdocTags": [],
|
|
176
|
-
"rawComment": ""
|
|
177
|
-
},
|
|
178
|
-
"entryType": "function",
|
|
179
|
-
"description": "",
|
|
180
|
-
"jsdocTags": [],
|
|
181
|
-
"rawComment": "",
|
|
182
|
-
"memberType": "method",
|
|
183
|
-
"memberTags": []
|
|
184
|
-
},
|
|
185
|
-
{
|
|
186
|
-
"name": "register",
|
|
187
|
-
"signatures": [
|
|
188
|
-
{
|
|
189
|
-
"name": "register",
|
|
190
|
-
"entryType": "function",
|
|
191
|
-
"description": "",
|
|
192
|
-
"generics": [],
|
|
193
|
-
"isNewType": false,
|
|
194
|
-
"jsdocTags": [],
|
|
195
|
-
"params": [
|
|
196
|
-
{
|
|
197
|
-
"name": "child",
|
|
198
|
-
"description": "",
|
|
199
|
-
"type": "TreeItem<V>",
|
|
200
|
-
"isOptional": false,
|
|
201
|
-
"isRestParam": false
|
|
202
|
-
}
|
|
203
|
-
],
|
|
204
|
-
"rawComment": "",
|
|
205
|
-
"returnType": "void"
|
|
206
|
-
}
|
|
207
|
-
],
|
|
208
|
-
"implementation": {
|
|
209
|
-
"params": [
|
|
210
|
-
{
|
|
211
|
-
"name": "child",
|
|
212
|
-
"description": "",
|
|
213
|
-
"type": "TreeItem<V>",
|
|
214
|
-
"isOptional": false,
|
|
215
|
-
"isRestParam": false
|
|
216
|
-
}
|
|
217
|
-
],
|
|
218
|
-
"isNewType": false,
|
|
219
|
-
"returnType": "void",
|
|
220
|
-
"generics": [],
|
|
221
|
-
"name": "register",
|
|
222
|
-
"description": "",
|
|
223
|
-
"entryType": "function",
|
|
224
|
-
"jsdocTags": [],
|
|
225
|
-
"rawComment": ""
|
|
226
|
-
},
|
|
227
|
-
"entryType": "function",
|
|
228
|
-
"description": "",
|
|
229
|
-
"jsdocTags": [],
|
|
230
|
-
"rawComment": "",
|
|
231
|
-
"memberType": "method",
|
|
232
|
-
"memberTags": []
|
|
233
|
-
},
|
|
234
|
-
{
|
|
235
|
-
"name": "unregister",
|
|
236
|
-
"signatures": [
|
|
237
|
-
{
|
|
238
|
-
"name": "unregister",
|
|
239
|
-
"entryType": "function",
|
|
240
|
-
"description": "",
|
|
241
|
-
"generics": [],
|
|
242
|
-
"isNewType": false,
|
|
243
|
-
"jsdocTags": [],
|
|
244
|
-
"params": [
|
|
245
|
-
{
|
|
246
|
-
"name": "child",
|
|
247
|
-
"description": "",
|
|
248
|
-
"type": "TreeItem<V>",
|
|
249
|
-
"isOptional": false,
|
|
250
|
-
"isRestParam": false
|
|
251
|
-
}
|
|
252
|
-
],
|
|
253
|
-
"rawComment": "",
|
|
254
|
-
"returnType": "void"
|
|
255
|
-
}
|
|
256
|
-
],
|
|
257
|
-
"implementation": {
|
|
258
|
-
"params": [
|
|
259
|
-
{
|
|
260
|
-
"name": "child",
|
|
261
|
-
"description": "",
|
|
262
|
-
"type": "TreeItem<V>",
|
|
263
|
-
"isOptional": false,
|
|
264
|
-
"isRestParam": false
|
|
265
|
-
}
|
|
266
|
-
],
|
|
267
|
-
"isNewType": false,
|
|
268
|
-
"returnType": "void",
|
|
269
|
-
"generics": [],
|
|
270
|
-
"name": "unregister",
|
|
271
|
-
"description": "",
|
|
272
|
-
"entryType": "function",
|
|
273
|
-
"jsdocTags": [],
|
|
274
|
-
"rawComment": ""
|
|
275
|
-
},
|
|
276
|
-
"entryType": "function",
|
|
277
|
-
"description": "",
|
|
278
|
-
"jsdocTags": [],
|
|
279
|
-
"rawComment": "",
|
|
280
|
-
"memberType": "method",
|
|
281
|
-
"memberTags": []
|
|
282
|
-
},
|
|
283
152
|
{
|
|
284
153
|
"name": "scrollActiveItemIntoView",
|
|
285
154
|
"signatures": [
|
|
@@ -591,88 +460,6 @@
|
|
|
591
460
|
"rawComment": "",
|
|
592
461
|
"memberType": "method",
|
|
593
462
|
"memberTags": []
|
|
594
|
-
},
|
|
595
|
-
{
|
|
596
|
-
"name": "register",
|
|
597
|
-
"signatures": [
|
|
598
|
-
{
|
|
599
|
-
"name": "register",
|
|
600
|
-
"entryType": "function",
|
|
601
|
-
"description": "",
|
|
602
|
-
"generics": [],
|
|
603
|
-
"isNewType": false,
|
|
604
|
-
"jsdocTags": [],
|
|
605
|
-
"params": [
|
|
606
|
-
{
|
|
607
|
-
"name": "group",
|
|
608
|
-
"description": "",
|
|
609
|
-
"type": "TreeItemGroup<V>",
|
|
610
|
-
"isOptional": false,
|
|
611
|
-
"isRestParam": false
|
|
612
|
-
}
|
|
613
|
-
],
|
|
614
|
-
"rawComment": "",
|
|
615
|
-
"returnType": "void"
|
|
616
|
-
}
|
|
617
|
-
],
|
|
618
|
-
"implementation": {
|
|
619
|
-
"params": [
|
|
620
|
-
{
|
|
621
|
-
"name": "group",
|
|
622
|
-
"description": "",
|
|
623
|
-
"type": "TreeItemGroup<V>",
|
|
624
|
-
"isOptional": false,
|
|
625
|
-
"isRestParam": false
|
|
626
|
-
}
|
|
627
|
-
],
|
|
628
|
-
"isNewType": false,
|
|
629
|
-
"returnType": "void",
|
|
630
|
-
"generics": [],
|
|
631
|
-
"name": "register",
|
|
632
|
-
"description": "",
|
|
633
|
-
"entryType": "function",
|
|
634
|
-
"jsdocTags": [],
|
|
635
|
-
"rawComment": ""
|
|
636
|
-
},
|
|
637
|
-
"entryType": "function",
|
|
638
|
-
"description": "",
|
|
639
|
-
"jsdocTags": [],
|
|
640
|
-
"rawComment": "",
|
|
641
|
-
"memberType": "method",
|
|
642
|
-
"memberTags": []
|
|
643
|
-
},
|
|
644
|
-
{
|
|
645
|
-
"name": "unregister",
|
|
646
|
-
"signatures": [
|
|
647
|
-
{
|
|
648
|
-
"name": "unregister",
|
|
649
|
-
"entryType": "function",
|
|
650
|
-
"description": "",
|
|
651
|
-
"generics": [],
|
|
652
|
-
"isNewType": false,
|
|
653
|
-
"jsdocTags": [],
|
|
654
|
-
"params": [],
|
|
655
|
-
"rawComment": "",
|
|
656
|
-
"returnType": "void"
|
|
657
|
-
}
|
|
658
|
-
],
|
|
659
|
-
"implementation": {
|
|
660
|
-
"params": [],
|
|
661
|
-
"isNewType": false,
|
|
662
|
-
"returnType": "void",
|
|
663
|
-
"generics": [],
|
|
664
|
-
"name": "unregister",
|
|
665
|
-
"description": "",
|
|
666
|
-
"entryType": "function",
|
|
667
|
-
"jsdocTags": [],
|
|
668
|
-
"rawComment": ""
|
|
669
|
-
},
|
|
670
|
-
"entryType": "function",
|
|
671
|
-
"description": "",
|
|
672
|
-
"jsdocTags": [],
|
|
673
|
-
"rawComment": "",
|
|
674
|
-
"memberType": "method",
|
|
675
|
-
"memberTags": []
|
|
676
463
|
}
|
|
677
464
|
],
|
|
678
465
|
"generics": [
|
|
@@ -702,7 +489,7 @@
|
|
|
702
489
|
"source": {
|
|
703
490
|
"filePath": "/src/aria/tree/tree.ts",
|
|
704
491
|
"startLine": 257,
|
|
705
|
-
"endLine":
|
|
492
|
+
"endLine": 385
|
|
706
493
|
}
|
|
707
494
|
},
|
|
708
495
|
{
|
|
@@ -720,16 +507,6 @@
|
|
|
720
507
|
"description": "A reference to the host element.",
|
|
721
508
|
"jsdocTags": []
|
|
722
509
|
},
|
|
723
|
-
{
|
|
724
|
-
"name": "children",
|
|
725
|
-
"type": "any",
|
|
726
|
-
"memberType": "property",
|
|
727
|
-
"memberTags": [
|
|
728
|
-
"readonly"
|
|
729
|
-
],
|
|
730
|
-
"description": "Child items within this group.",
|
|
731
|
-
"jsdocTags": []
|
|
732
|
-
},
|
|
733
510
|
{
|
|
734
511
|
"name": "ownedBy",
|
|
735
512
|
"type": "any",
|
|
@@ -805,104 +582,6 @@
|
|
|
805
582
|
"rawComment": "",
|
|
806
583
|
"memberType": "method",
|
|
807
584
|
"memberTags": []
|
|
808
|
-
},
|
|
809
|
-
{
|
|
810
|
-
"name": "register",
|
|
811
|
-
"signatures": [
|
|
812
|
-
{
|
|
813
|
-
"name": "register",
|
|
814
|
-
"entryType": "function",
|
|
815
|
-
"description": "",
|
|
816
|
-
"generics": [],
|
|
817
|
-
"isNewType": false,
|
|
818
|
-
"jsdocTags": [],
|
|
819
|
-
"params": [
|
|
820
|
-
{
|
|
821
|
-
"name": "child",
|
|
822
|
-
"description": "",
|
|
823
|
-
"type": "TreeItem<V>",
|
|
824
|
-
"isOptional": false,
|
|
825
|
-
"isRestParam": false
|
|
826
|
-
}
|
|
827
|
-
],
|
|
828
|
-
"rawComment": "",
|
|
829
|
-
"returnType": "void"
|
|
830
|
-
}
|
|
831
|
-
],
|
|
832
|
-
"implementation": {
|
|
833
|
-
"params": [
|
|
834
|
-
{
|
|
835
|
-
"name": "child",
|
|
836
|
-
"description": "",
|
|
837
|
-
"type": "TreeItem<V>",
|
|
838
|
-
"isOptional": false,
|
|
839
|
-
"isRestParam": false
|
|
840
|
-
}
|
|
841
|
-
],
|
|
842
|
-
"isNewType": false,
|
|
843
|
-
"returnType": "void",
|
|
844
|
-
"generics": [],
|
|
845
|
-
"name": "register",
|
|
846
|
-
"description": "",
|
|
847
|
-
"entryType": "function",
|
|
848
|
-
"jsdocTags": [],
|
|
849
|
-
"rawComment": ""
|
|
850
|
-
},
|
|
851
|
-
"entryType": "function",
|
|
852
|
-
"description": "",
|
|
853
|
-
"jsdocTags": [],
|
|
854
|
-
"rawComment": "",
|
|
855
|
-
"memberType": "method",
|
|
856
|
-
"memberTags": []
|
|
857
|
-
},
|
|
858
|
-
{
|
|
859
|
-
"name": "unregister",
|
|
860
|
-
"signatures": [
|
|
861
|
-
{
|
|
862
|
-
"name": "unregister",
|
|
863
|
-
"entryType": "function",
|
|
864
|
-
"description": "",
|
|
865
|
-
"generics": [],
|
|
866
|
-
"isNewType": false,
|
|
867
|
-
"jsdocTags": [],
|
|
868
|
-
"params": [
|
|
869
|
-
{
|
|
870
|
-
"name": "child",
|
|
871
|
-
"description": "",
|
|
872
|
-
"type": "TreeItem<V>",
|
|
873
|
-
"isOptional": false,
|
|
874
|
-
"isRestParam": false
|
|
875
|
-
}
|
|
876
|
-
],
|
|
877
|
-
"rawComment": "",
|
|
878
|
-
"returnType": "void"
|
|
879
|
-
}
|
|
880
|
-
],
|
|
881
|
-
"implementation": {
|
|
882
|
-
"params": [
|
|
883
|
-
{
|
|
884
|
-
"name": "child",
|
|
885
|
-
"description": "",
|
|
886
|
-
"type": "TreeItem<V>",
|
|
887
|
-
"isOptional": false,
|
|
888
|
-
"isRestParam": false
|
|
889
|
-
}
|
|
890
|
-
],
|
|
891
|
-
"isNewType": false,
|
|
892
|
-
"returnType": "void",
|
|
893
|
-
"generics": [],
|
|
894
|
-
"name": "unregister",
|
|
895
|
-
"description": "",
|
|
896
|
-
"entryType": "function",
|
|
897
|
-
"jsdocTags": [],
|
|
898
|
-
"rawComment": ""
|
|
899
|
-
},
|
|
900
|
-
"entryType": "function",
|
|
901
|
-
"description": "",
|
|
902
|
-
"jsdocTags": [],
|
|
903
|
-
"rawComment": "",
|
|
904
|
-
"memberType": "method",
|
|
905
|
-
"memberTags": []
|
|
906
585
|
}
|
|
907
586
|
],
|
|
908
587
|
"generics": [
|
|
@@ -924,8 +603,8 @@
|
|
|
924
603
|
],
|
|
925
604
|
"source": {
|
|
926
605
|
"filePath": "/src/aria/tree/tree.ts",
|
|
927
|
-
"startLine":
|
|
928
|
-
"endLine":
|
|
606
|
+
"startLine": 407,
|
|
607
|
+
"endLine": 451
|
|
929
608
|
}
|
|
930
609
|
}
|
|
931
610
|
],
|
|
@@ -1086,18 +765,6 @@
|
|
|
1086
765
|
"Tree.currentType",
|
|
1087
766
|
"@angular/aria/tree"
|
|
1088
767
|
],
|
|
1089
|
-
[
|
|
1090
|
-
"Tree.onFocus",
|
|
1091
|
-
"@angular/aria/tree"
|
|
1092
|
-
],
|
|
1093
|
-
[
|
|
1094
|
-
"Tree.register",
|
|
1095
|
-
"@angular/aria/tree"
|
|
1096
|
-
],
|
|
1097
|
-
[
|
|
1098
|
-
"Tree.unregister",
|
|
1099
|
-
"@angular/aria/tree"
|
|
1100
|
-
],
|
|
1101
768
|
[
|
|
1102
769
|
"Tree.scrollActiveItemIntoView",
|
|
1103
770
|
"@angular/aria/tree"
|
|
@@ -1170,14 +837,6 @@
|
|
|
1170
837
|
"TreeItem.ngOnDestroy",
|
|
1171
838
|
"@angular/aria/tree"
|
|
1172
839
|
],
|
|
1173
|
-
[
|
|
1174
|
-
"TreeItem.register",
|
|
1175
|
-
"@angular/aria/tree"
|
|
1176
|
-
],
|
|
1177
|
-
[
|
|
1178
|
-
"TreeItem.unregister",
|
|
1179
|
-
"@angular/aria/tree"
|
|
1180
|
-
],
|
|
1181
840
|
[
|
|
1182
841
|
"TreeItemGroup",
|
|
1183
842
|
"@angular/aria/tree"
|
|
@@ -1186,10 +845,6 @@
|
|
|
1186
845
|
"TreeItemGroup.element",
|
|
1187
846
|
"@angular/aria/tree"
|
|
1188
847
|
],
|
|
1189
|
-
[
|
|
1190
|
-
"TreeItemGroup.children",
|
|
1191
|
-
"@angular/aria/tree"
|
|
1192
|
-
],
|
|
1193
848
|
[
|
|
1194
849
|
"TreeItemGroup.ownedBy",
|
|
1195
850
|
"@angular/aria/tree"
|
|
@@ -1201,14 +856,6 @@
|
|
|
1201
856
|
[
|
|
1202
857
|
"TreeItemGroup.ngOnDestroy",
|
|
1203
858
|
"@angular/aria/tree"
|
|
1204
|
-
],
|
|
1205
|
-
[
|
|
1206
|
-
"TreeItemGroup.register",
|
|
1207
|
-
"@angular/aria/tree"
|
|
1208
|
-
],
|
|
1209
|
-
[
|
|
1210
|
-
"TreeItemGroup.unregister",
|
|
1211
|
-
"@angular/aria/tree"
|
|
1212
859
|
]
|
|
1213
860
|
]
|
|
1214
861
|
}
|
package/fesm2022/accordion.mjs
CHANGED
|
@@ -16,13 +16,13 @@ class AccordionPanel {
|
|
|
16
16
|
visible = computed(() => !this._pattern.hidden(), ...(ngDevMode ? [{
|
|
17
17
|
debugName: "visible"
|
|
18
18
|
}] : []));
|
|
19
|
-
|
|
20
|
-
debugName: "
|
|
19
|
+
_accordionTriggerPattern = signal(undefined, ...(ngDevMode ? [{
|
|
20
|
+
debugName: "_accordionTriggerPattern"
|
|
21
21
|
}] : []));
|
|
22
22
|
_pattern = new AccordionPanelPattern({
|
|
23
23
|
id: this.id,
|
|
24
24
|
panelId: this.panelId,
|
|
25
|
-
accordionTrigger: () => this.
|
|
25
|
+
accordionTrigger: () => this._accordionTriggerPattern()
|
|
26
26
|
});
|
|
27
27
|
constructor() {
|
|
28
28
|
afterRenderEffect(() => {
|
|
@@ -30,13 +30,13 @@ class AccordionPanel {
|
|
|
30
30
|
});
|
|
31
31
|
}
|
|
32
32
|
expand() {
|
|
33
|
-
this.
|
|
33
|
+
this._accordionTriggerPattern()?.open();
|
|
34
34
|
}
|
|
35
35
|
collapse() {
|
|
36
|
-
this.
|
|
36
|
+
this._accordionTriggerPattern()?.close();
|
|
37
37
|
}
|
|
38
38
|
toggle() {
|
|
39
|
-
this.
|
|
39
|
+
this._accordionTriggerPattern()?.toggle();
|
|
40
40
|
}
|
|
41
41
|
static ɵfac = i0.ɵɵngDeclareFactory({
|
|
42
42
|
minVersion: "12.0.0",
|
|
@@ -132,13 +132,13 @@ class AccordionTrigger {
|
|
|
132
132
|
active = computed(() => this._pattern.active(), ...(ngDevMode ? [{
|
|
133
133
|
debugName: "active"
|
|
134
134
|
}] : []));
|
|
135
|
-
|
|
136
|
-
debugName: "
|
|
135
|
+
_accordionPanelPattern = signal(undefined, ...(ngDevMode ? [{
|
|
136
|
+
debugName: "_accordionPanelPattern"
|
|
137
137
|
}] : []));
|
|
138
138
|
_pattern = new AccordionTriggerPattern({
|
|
139
139
|
...this,
|
|
140
140
|
accordionGroup: computed(() => this._accordionGroup._pattern),
|
|
141
|
-
accordionPanel: this.
|
|
141
|
+
accordionPanel: this._accordionPanelPattern,
|
|
142
142
|
element: () => this.element
|
|
143
143
|
});
|
|
144
144
|
expand() {
|
|
@@ -295,9 +295,9 @@ class AccordionGroup {
|
|
|
295
295
|
const panels = this._panels();
|
|
296
296
|
for (const trigger of triggers) {
|
|
297
297
|
const panel = panels.find(p => p.panelId() === trigger.panelId());
|
|
298
|
-
trigger.
|
|
298
|
+
trigger._accordionPanelPattern.set(panel?._pattern);
|
|
299
299
|
if (panel) {
|
|
300
|
-
panel.
|
|
300
|
+
panel._accordionTriggerPattern.set(trigger._pattern);
|
|
301
301
|
}
|
|
302
302
|
}
|
|
303
303
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"accordion.mjs","sources":["../../../../../darwin_arm64-fastbuild-ST-199a4f3c4e20/bin/src/aria/accordion/accordion.ts"],"sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {\n Directive,\n input,\n ElementRef,\n inject,\n contentChildren,\n afterRenderEffect,\n signal,\n model,\n booleanAttribute,\n computed,\n WritableSignal,\n} from '@angular/core';\nimport {_IdGenerator} from '@angular/cdk/a11y';\nimport {Directionality} from '@angular/cdk/bidi';\nimport {\n DeferredContent,\n DeferredContentAware,\n AccordionGroupPattern,\n AccordionPanelPattern,\n AccordionTriggerPattern,\n} from '@angular/aria/private';\n\n/**\n * The content panel of an accordion item that is conditionally visible.\n *\n * This directive is a container for the content that is shown or hidden. It requires\n * a `panelId` that must match the `panelId` of its corresponding `ngAccordionTrigger`.\n * The content within the panel should be provided using an `ng-template` with the\n * `ngAccordionContent` directive so that the content is not rendered on the page until the trigger\n * is expanded. It applies `role=\"region\"` for accessibility and uses the `inert` attribute to hide\n * its content from assistive technologies when not visible.\n *\n * ```html\n * <div ngAccordionPanel panelId=\"unique-id-1\">\n * <ng-template ngAccordionContent>\n * <p>This content is lazily rendered and will be shown when the panel is expanded.</p>\n * </ng-template>\n * </div>\n * ```\n *\n * @developerPreview 21.0\n */\n@Directive({\n selector: '[ngAccordionPanel]',\n exportAs: 'ngAccordionPanel',\n hostDirectives: [\n {\n directive: DeferredContentAware,\n inputs: ['preserveContent'],\n },\n ],\n host: {\n 'role': 'region',\n '[attr.id]': '_pattern.id()',\n '[attr.aria-labelledby]': '_pattern.accordionTrigger()?.id()',\n '[attr.inert]': '!visible() ? true : null',\n },\n})\nexport class AccordionPanel {\n /** The DeferredContentAware host directive. */\n private readonly _deferredContentAware = inject(DeferredContentAware);\n\n /** A global unique identifier for the panel. */\n readonly id = input(inject(_IdGenerator).getId('ng-accordion-panel-', true));\n\n /** A local unique identifier for the panel, used to match with its trigger's `panelId`. */\n readonly panelId = input.required<string>();\n\n /** Whether the accordion panel is visible. True if the associated trigger is expanded. */\n readonly visible = computed(() => !this._pattern.hidden());\n\n /** The parent accordion trigger pattern that controls this panel. This is set by AccordionGroup. */\n readonly accordionTrigger: WritableSignal<AccordionTriggerPattern | undefined> =\n signal(undefined);\n\n /** The UI pattern instance for this panel. */\n readonly _pattern: AccordionPanelPattern = new AccordionPanelPattern({\n id: this.id,\n panelId: this.panelId,\n accordionTrigger: () => this.accordionTrigger(),\n });\n\n constructor() {\n // Connect the panel's hidden state to the DeferredContentAware's visibility.\n afterRenderEffect(() => {\n this._deferredContentAware.contentVisible.set(this.visible());\n });\n }\n\n /** Expands this item. */\n expand() {\n this.accordionTrigger()?.open();\n }\n\n /** Collapses this item. */\n collapse() {\n this.accordionTrigger()?.close();\n }\n\n /** Toggles the expansion state of this item. */\n toggle() {\n this.accordionTrigger()?.toggle();\n }\n}\n\n/**\n * The trigger that toggles the visibility of its associated `ngAccordionPanel`.\n *\n * This directive requires a `panelId` that must match the `panelId` of the `ngAccordionPanel` it\n * controls. When clicked, it will expand or collapse the panel. It also handles keyboard\n * interactions for navigation within the `ngAccordionGroup`. It applies `role=\"button\"` and manages\n * `aria-expanded`, `aria-controls`, and `aria-disabled` attributes for accessibility.\n * The `disabled` input can be used to disable the trigger.\n *\n * ```html\n * <button ngAccordionTrigger panelId=\"unique-id-1\">\n * Accordion Trigger Text\n * </button>\n * ```\n *\n * @developerPreview 21.0\n */\n@Directive({\n selector: '[ngAccordionTrigger]',\n exportAs: 'ngAccordionTrigger',\n host: {\n '[attr.data-active]': 'active()',\n 'role': 'button',\n '[id]': '_pattern.id()',\n '[attr.aria-expanded]': 'expanded()',\n '[attr.aria-controls]': '_pattern.controls()',\n '[attr.aria-disabled]': '_pattern.disabled()',\n '[attr.disabled]': '_pattern.hardDisabled() ? true : null',\n '[attr.tabindex]': '_pattern.tabIndex()',\n },\n})\nexport class AccordionTrigger {\n /** A reference to the trigger element. */\n private readonly _elementRef = inject(ElementRef);\n\n /** A reference to the trigger element. */\n readonly element = this._elementRef.nativeElement as HTMLElement;\n\n /** The parent AccordionGroup. */\n private readonly _accordionGroup = inject(AccordionGroup);\n\n /** A unique identifier for the widget. */\n readonly id = input(inject(_IdGenerator).getId('ng-accordion-trigger-', true));\n\n /** A local unique identifier for the trigger, used to match with its panel's `panelId`. */\n readonly panelId = input.required<string>();\n\n /** Whether the trigger is disabled. */\n readonly disabled = input(false, {transform: booleanAttribute});\n\n /** Whether the corresponding panel is expanded. */\n readonly expanded = model<boolean>(false);\n\n /** Whether the trigger is active. */\n readonly active = computed(() => this._pattern.active());\n\n /** The accordion panel pattern controlled by this trigger. This is set by AccordionGroup. */\n readonly _accordionPanel: WritableSignal<AccordionPanelPattern | undefined> = signal(undefined);\n\n /** The UI pattern instance for this trigger. */\n readonly _pattern: AccordionTriggerPattern = new AccordionTriggerPattern({\n ...this,\n accordionGroup: computed(() => this._accordionGroup._pattern),\n accordionPanel: this._accordionPanel,\n element: () => this.element,\n });\n\n /** Expands this item. */\n expand() {\n this._pattern.open();\n }\n\n /** Collapses this item. */\n collapse() {\n this._pattern.close();\n }\n\n /** Toggles the expansion state of this item. */\n toggle() {\n this._pattern.toggle();\n }\n}\n\n/**\n * A container for a group of accordion items. It manages the overall state and\n * interactions of the accordion, such as keyboard navigation and expansion mode.\n *\n * The `ngAccordionGroup` serves as the root of a group of accordion triggers and panels,\n * coordinating the behavior of the `ngAccordionTrigger` and `ngAccordionPanel` elements within it.\n * It supports both single and multiple expansion modes.\n *\n * ```html\n * <div ngAccordionGroup [multiExpandable]=\"true\" [(expandedPanels)]=\"expandedItems\">\n * <div class=\"accordion-item\">\n * <h3>\n * <button ngAccordionTrigger panelId=\"item-1\">Item 1</button>\n * </h3>\n * <div ngAccordionPanel panelId=\"item-1\">\n * <ng-template ngAccordionContent>\n * <p>Content for Item 1.</p>\n * </ng-template>\n * </div>\n * </div>\n * <div class=\"accordion-item\">\n * <h3>\n * <button ngAccordionTrigger panelId=\"item-2\">Item 2</button>\n * </h3>\n * <div ngAccordionPanel panelId=\"item-2\">\n * <ng-template ngAccordionContent>\n * <p>Content for Item 2.</p>\n * </ng-template>\n * </div>\n * </div>\n * </div>\n * ```\n *\n * @developerPreview 21.0\n */\n@Directive({\n selector: '[ngAccordionGroup]',\n exportAs: 'ngAccordionGroup',\n host: {\n '(keydown)': '_pattern.onKeydown($event)',\n '(pointerdown)': '_pattern.onPointerdown($event)',\n '(focusin)': '_pattern.onFocus($event)',\n },\n})\nexport class AccordionGroup {\n /** A reference to the group element. */\n private readonly _elementRef = inject(ElementRef);\n\n /** A reference to the group element. */\n readonly element = this._elementRef.nativeElement as HTMLElement;\n\n /** The AccordionTriggers nested inside this group. */\n private readonly _triggers = contentChildren(AccordionTrigger, {descendants: true});\n\n /** The AccordionTrigger patterns nested inside this group. */\n private readonly _triggerPatterns = computed(() => this._triggers().map(t => t._pattern));\n\n /** The AccordionPanels nested inside this group. */\n private readonly _panels = contentChildren(AccordionPanel, {descendants: true});\n\n /** The text direction (ltr or rtl). */\n readonly textDirection = inject(Directionality).valueSignal;\n\n /** Whether the entire accordion group is disabled. */\n readonly disabled = input(false, {transform: booleanAttribute});\n\n /** Whether multiple accordion items can be expanded simultaneously. */\n readonly multiExpandable = input(true, {transform: booleanAttribute});\n\n /**\n * Whether to allow disabled items to receive focus. When `true`, disabled items are\n * focusable but not interactive. When `false`, disabled items are skipped during navigation.\n */\n readonly softDisabled = input(true, {transform: booleanAttribute});\n\n /** Whether keyboard navigation should wrap around from the last item to the first, and vice-versa. */\n readonly wrap = input(false, {transform: booleanAttribute});\n\n /** The UI pattern instance for this accordion group. */\n readonly _pattern: AccordionGroupPattern = new AccordionGroupPattern({\n ...this,\n activeItem: signal(undefined),\n items: this._triggerPatterns,\n // TODO(ok7sai): Investigate whether an accordion should support horizontal mode.\n orientation: () => 'vertical',\n getItem: e => this._getItem(e),\n element: () => this.element,\n });\n\n constructor() {\n // Effect to link triggers with their corresponding panels and update the group's items.\n afterRenderEffect(() => {\n const triggers = this._triggers();\n const panels = this._panels();\n\n for (const trigger of triggers) {\n const panel = panels.find(p => p.panelId() === trigger.panelId());\n trigger._accordionPanel.set(panel?._pattern);\n if (panel) {\n panel.accordionTrigger.set(trigger._pattern);\n }\n }\n });\n }\n\n /** Expands all accordion panels if multi-expandable. */\n expandAll() {\n this._pattern.expansionBehavior.openAll();\n }\n\n /** Collapses all accordion panels. */\n collapseAll() {\n this._pattern.expansionBehavior.closeAll();\n }\n\n /** Gets the trigger pattern for a given element. */\n private _getItem(element: Element | null | undefined): AccordionTriggerPattern | undefined {\n let target = element;\n\n while (target) {\n const pattern = this._triggerPatterns().find(t => t.element() === target);\n if (pattern) {\n return pattern;\n }\n\n target = target.parentElement?.closest('[ngAccordionTrigger]');\n }\n\n return undefined;\n }\n}\n\n/**\n * A structural directive that provides a mechanism for lazily rendering the content for an\n * `ngAccordionPanel`.\n *\n * This directive should be applied to an `ng-template` inside an `ngAccordionPanel`.\n * It allows the content of the panel to be lazily rendered, improving performance\n * by only creating the content when the panel is first expanded.\n *\n * ```html\n * <div ngAccordionPanel panelId=\"unique-id-1\">\n * <ng-template ngAccordionContent>\n * <p>This is the content that will be displayed inside the panel.</p>\n * </ng-template>\n * </div>\n * ```\n *\n * @developerPreview 21.0\n */\n@Directive({\n selector: 'ng-template[ngAccordionContent]',\n hostDirectives: [DeferredContent],\n})\nexport class AccordionContent {}\n"],"names":["AccordionPanel","_deferredContentAware","inject","DeferredContentAware","id","input","_IdGenerator","getId","panelId","required","visible","computed","_pattern","hidden","accordionTrigger","signal","undefined","AccordionPanelPattern","constructor","afterRenderEffect","contentVisible","set","expand","open","collapse","close","toggle","deps","target","i0","ɵɵFactoryTarget","Directive","isStandalone","selector","inputs","classPropertyName","publicName","isSignal","isRequired","transformFunction","host","attributes","properties","exportAs","hostDirectives","directive","i1","ngImport","decorators","args","AccordionTrigger","_elementRef","ElementRef","element","nativeElement","_accordionGroup","AccordionGroup","disabled","transform","booleanAttribute","expanded","model","active","_accordionPanel","AccordionTriggerPattern","accordionGroup","accordionPanel","outputs","_triggers","contentChildren","descendants","_triggerPatterns","map","t","ngDevMode","debugName","_panels","textDirection","Directionality","valueSignal","multiExpandable","softDisabled","wrap","AccordionGroupPattern","activeItem","items","orientation","getItem","e","_getItem","triggers","panels","trigger","panel","find","p","expandAll","expansionBehavior","openAll","collapseAll","closeAll","pattern","parentElement","closest","listeners","queries","propertyName","predicate","AccordionContent","DeferredContent"],"mappings":";;;;;;;MAmEaA,cAAc,CAAA;AAERC,EAAAA,qBAAqB,GAAGC,MAAM,CAACC,oBAAoB,CAAC;AAG5DC,EAAAA,EAAE,GAAGC,KAAK,CAACH,MAAM,CAACI,YAAY,CAAC,CAACC,KAAK,CAAC,qBAAqB,EAAE,IAAI,CAAC;;WAAC;EAGnEC,OAAO,GAAGH,KAAK,CAACI,QAAQ;;WAAU;AAGlCC,EAAAA,OAAO,GAAGC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAACC,QAAQ,CAACC,MAAM,EAAE;;WAAC;EAGjDC,gBAAgB,GACvBC,MAAM,CAACC,SAAS;;WAAC;EAGVJ,QAAQ,GAA0B,IAAIK,qBAAqB,CAAC;IACnEb,EAAE,EAAE,IAAI,CAACA,EAAE;IACXI,OAAO,EAAE,IAAI,CAACA,OAAO;AACrBM,IAAAA,gBAAgB,EAAEA,MAAM,IAAI,CAACA,gBAAgB;AAC9C,GAAA,CAAC;AAEFI,EAAAA,WAAAA,GAAA;AAEEC,IAAAA,iBAAiB,CAAC,MAAK;AACrB,MAAA,IAAI,CAAClB,qBAAqB,CAACmB,cAAc,CAACC,GAAG,CAAC,IAAI,CAACX,OAAO,EAAE,CAAC;AAC/D,KAAC,CAAC;AACJ;AAGAY,EAAAA,MAAMA,GAAA;AACJ,IAAA,IAAI,CAACR,gBAAgB,EAAE,EAAES,IAAI,EAAE;AACjC;AAGAC,EAAAA,QAAQA,GAAA;AACN,IAAA,IAAI,CAACV,gBAAgB,EAAE,EAAEW,KAAK,EAAE;AAClC;AAGAC,EAAAA,MAAMA,GAAA;AACJ,IAAA,IAAI,CAACZ,gBAAgB,EAAE,EAAEY,MAAM,EAAE;AACnC;;;;;UA5CW1B,cAAc;AAAA2B,IAAAA,IAAA,EAAA,EAAA;AAAAC,IAAAA,MAAA,EAAAC,EAAA,CAAAC,eAAA,CAAAC;AAAA,GAAA,CAAA;;;;UAAd/B,cAAc;AAAAgC,IAAAA,YAAA,EAAA,IAAA;AAAAC,IAAAA,QAAA,EAAA,oBAAA;AAAAC,IAAAA,MAAA,EAAA;AAAA9B,MAAAA,EAAA,EAAA;AAAA+B,QAAAA,iBAAA,EAAA,IAAA;AAAAC,QAAAA,UAAA,EAAA,IAAA;AAAAC,QAAAA,QAAA,EAAA,IAAA;AAAAC,QAAAA,UAAA,EAAA,KAAA;AAAAC,QAAAA,iBAAA,EAAA;OAAA;AAAA/B,MAAAA,OAAA,EAAA;AAAA2B,QAAAA,iBAAA,EAAA,SAAA;AAAAC,QAAAA,UAAA,EAAA,SAAA;AAAAC,QAAAA,QAAA,EAAA,IAAA;AAAAC,QAAAA,UAAA,EAAA,IAAA;AAAAC,QAAAA,iBAAA,EAAA;AAAA;KAAA;AAAAC,IAAAA,IAAA,EAAA;AAAAC,MAAAA,UAAA,EAAA;AAAA,QAAA,MAAA,EAAA;OAAA;AAAAC,MAAAA,UAAA,EAAA;AAAA,QAAA,SAAA,EAAA,eAAA;AAAA,QAAA,sBAAA,EAAA,mCAAA;AAAA,QAAA,YAAA,EAAA;AAAA;KAAA;IAAAC,QAAA,EAAA,CAAA,kBAAA,CAAA;AAAAC,IAAAA,cAAA,EAAA,CAAA;MAAAC,SAAA,EAAAC,EAAA,CAAA3C,oBAAA;AAAA+B,MAAAA,MAAA,EAAA,CAAA,iBAAA,EAAA,iBAAA;AAAA,KAAA,CAAA;AAAAa,IAAAA,QAAA,EAAAlB;AAAA,GAAA,CAAA;;;;;;QAAd7B,cAAc;AAAAgD,EAAAA,UAAA,EAAA,CAAA;UAhB1BjB,SAAS;AAACkB,IAAAA,IAAA,EAAA,CAAA;AACThB,MAAAA,QAAQ,EAAE,oBAAoB;AAC9BU,MAAAA,QAAQ,EAAE,kBAAkB;AAC5BC,MAAAA,cAAc,EAAE,CACd;AACEC,QAAAA,SAAS,EAAE1C,oBAAoB;QAC/B+B,MAAM,EAAE,CAAC,iBAAiB;AAC3B,OAAA,CACF;AACDM,MAAAA,IAAI,EAAE;AACJ,QAAA,MAAM,EAAE,QAAQ;AAChB,QAAA,WAAW,EAAE,eAAe;AAC5B,QAAA,wBAAwB,EAAE,mCAAmC;AAC7D,QAAA,cAAc,EAAE;AACjB;KACF;;;;MA+EYU,gBAAgB,CAAA;AAEVC,EAAAA,WAAW,GAAGjD,MAAM,CAACkD,UAAU,CAAC;AAGxCC,EAAAA,OAAO,GAAG,IAAI,CAACF,WAAW,CAACG,aAA4B;AAG/CC,EAAAA,eAAe,GAAGrD,MAAM,CAACsD,cAAc,CAAC;AAGhDpD,EAAAA,EAAE,GAAGC,KAAK,CAACH,MAAM,CAACI,YAAY,CAAC,CAACC,KAAK,CAAC,uBAAuB,EAAE,IAAI,CAAC;;WAAC;EAGrEC,OAAO,GAAGH,KAAK,CAACI,QAAQ;;WAAU;EAGlCgD,QAAQ,GAAGpD,KAAK,CAAC,KAAK;;AAAGqD,IAAAA,SAAS,EAAEC;GAAgB,CAAA,GAAA,CAA5B;AAACD,IAAAA,SAAS,EAAEC;GAAiB,GAAC;EAGtDC,QAAQ,GAAGC,KAAK,CAAU,KAAK;;WAAC;AAGhCC,EAAAA,MAAM,GAAGnD,QAAQ,CAAC,MAAM,IAAI,CAACC,QAAQ,CAACkD,MAAM,EAAE;;WAAC;EAG/CC,eAAe,GAAsDhD,MAAM,CAACC,SAAS;;WAAC;EAGtFJ,QAAQ,GAA4B,IAAIoD,uBAAuB,CAAC;AACvE,IAAA,GAAG,IAAI;IACPC,cAAc,EAAEtD,QAAQ,CAAC,MAAM,IAAI,CAAC4C,eAAe,CAAC3C,QAAQ,CAAC;IAC7DsD,cAAc,EAAE,IAAI,CAACH,eAAe;AACpCV,IAAAA,OAAO,EAAEA,MAAM,IAAI,CAACA;AACrB,GAAA,CAAC;AAGF/B,EAAAA,MAAMA,GAAA;AACJ,IAAA,IAAI,CAACV,QAAQ,CAACW,IAAI,EAAE;AACtB;AAGAC,EAAAA,QAAQA,GAAA;AACN,IAAA,IAAI,CAACZ,QAAQ,CAACa,KAAK,EAAE;AACvB;AAGAC,EAAAA,MAAMA,GAAA;AACJ,IAAA,IAAI,CAACd,QAAQ,CAACc,MAAM,EAAE;AACxB;;;;;UAjDWwB,gBAAgB;AAAAvB,IAAAA,IAAA,EAAA,EAAA;AAAAC,IAAAA,MAAA,EAAAC,EAAA,CAAAC,eAAA,CAAAC;AAAA,GAAA,CAAA;;;;UAAhBmB,gBAAgB;AAAAlB,IAAAA,YAAA,EAAA,IAAA;AAAAC,IAAAA,QAAA,EAAA,sBAAA;AAAAC,IAAAA,MAAA,EAAA;AAAA9B,MAAAA,EAAA,EAAA;AAAA+B,QAAAA,iBAAA,EAAA,IAAA;AAAAC,QAAAA,UAAA,EAAA,IAAA;AAAAC,QAAAA,QAAA,EAAA,IAAA;AAAAC,QAAAA,UAAA,EAAA,KAAA;AAAAC,QAAAA,iBAAA,EAAA;OAAA;AAAA/B,MAAAA,OAAA,EAAA;AAAA2B,QAAAA,iBAAA,EAAA,SAAA;AAAAC,QAAAA,UAAA,EAAA,SAAA;AAAAC,QAAAA,QAAA,EAAA,IAAA;AAAAC,QAAAA,UAAA,EAAA,IAAA;AAAAC,QAAAA,iBAAA,EAAA;OAAA;AAAAkB,MAAAA,QAAA,EAAA;AAAAtB,QAAAA,iBAAA,EAAA,UAAA;AAAAC,QAAAA,UAAA,EAAA,UAAA;AAAAC,QAAAA,QAAA,EAAA,IAAA;AAAAC,QAAAA,UAAA,EAAA,KAAA;AAAAC,QAAAA,iBAAA,EAAA;OAAA;AAAAqB,MAAAA,QAAA,EAAA;AAAAzB,QAAAA,iBAAA,EAAA,UAAA;AAAAC,QAAAA,UAAA,EAAA,UAAA;AAAAC,QAAAA,QAAA,EAAA,IAAA;AAAAC,QAAAA,UAAA,EAAA,KAAA;AAAAC,QAAAA,iBAAA,EAAA;AAAA;KAAA;AAAA4B,IAAAA,OAAA,EAAA;AAAAP,MAAAA,QAAA,EAAA;KAAA;AAAApB,IAAAA,IAAA,EAAA;AAAAC,MAAAA,UAAA,EAAA;AAAA,QAAA,MAAA,EAAA;OAAA;AAAAC,MAAAA,UAAA,EAAA;AAAA,QAAA,kBAAA,EAAA,UAAA;AAAA,QAAA,IAAA,EAAA,eAAA;AAAA,QAAA,oBAAA,EAAA,YAAA;AAAA,QAAA,oBAAA,EAAA,qBAAA;AAAA,QAAA,oBAAA,EAAA,qBAAA;AAAA,QAAA,eAAA,EAAA,uCAAA;AAAA,QAAA,eAAA,EAAA;AAAA;KAAA;IAAAC,QAAA,EAAA,CAAA,oBAAA,CAAA;AAAAI,IAAAA,QAAA,EAAAlB;AAAA,GAAA,CAAA;;;;;;QAAhBqB,gBAAgB;AAAAF,EAAAA,UAAA,EAAA,CAAA;UAd5BjB,SAAS;AAACkB,IAAAA,IAAA,EAAA,CAAA;AACThB,MAAAA,QAAQ,EAAE,sBAAsB;AAChCU,MAAAA,QAAQ,EAAE,oBAAoB;AAC9BH,MAAAA,IAAI,EAAE;AACJ,QAAA,oBAAoB,EAAE,UAAU;AAChC,QAAA,MAAM,EAAE,QAAQ;AAChB,QAAA,MAAM,EAAE,eAAe;AACvB,QAAA,sBAAsB,EAAE,YAAY;AACpC,QAAA,sBAAsB,EAAE,qBAAqB;AAC7C,QAAA,sBAAsB,EAAE,qBAAqB;AAC7C,QAAA,iBAAiB,EAAE,uCAAuC;AAC1D,QAAA,iBAAiB,EAAE;AACpB;KACF;;;MAiGYgB,cAAc,CAAA;AAERL,EAAAA,WAAW,GAAGjD,MAAM,CAACkD,UAAU,CAAC;AAGxCC,EAAAA,OAAO,GAAG,IAAI,CAACF,WAAW,CAACG,aAA4B;EAG/Cc,SAAS,GAAGC,eAAe,CAACnB,gBAAgB;;AAAGoB,IAAAA,WAAW,EAAE;GAAI,CAAA,GAAA,CAAlB;AAACA,IAAAA,WAAW,EAAE;GAAK,GAAC;EAGlEC,gBAAgB,GAAG5D,QAAQ,CAAC,MAAM,IAAI,CAACyD,SAAS,EAAE,CAACI,GAAG,CAACC,CAAC,IAAIA,CAAC,CAAC7D,QAAQ,CAAC,EAAA,IAAA8D,SAAA,GAAA,CAAA;AAAAC,IAAAA,SAAA,EAAA;AAAA,GAAA,CAAA,GAAA,EAAA,CAAA,CAAC;EAGxEC,OAAO,GAAGP,eAAe,CAACrE,cAAc;;AAAGsE,IAAAA,WAAW,EAAE;GAAI,CAAA,GAAA,CAAlB;AAACA,IAAAA,WAAW,EAAE;GAAK,GAAC;AAGtEO,EAAAA,aAAa,GAAG3E,MAAM,CAAC4E,cAAc,CAAC,CAACC,WAAW;EAGlDtB,QAAQ,GAAGpD,KAAK,CAAC,KAAK;;AAAGqD,IAAAA,SAAS,EAAEC;GAAgB,CAAA,GAAA,CAA5B;AAACD,IAAAA,SAAS,EAAEC;GAAiB,GAAC;EAGtDqB,eAAe,GAAG3E,KAAK,CAAC,IAAI;;AAAGqD,IAAAA,SAAS,EAAEC;GAAgB,CAAA,GAAA,CAA5B;AAACD,IAAAA,SAAS,EAAEC;GAAiB,GAAC;EAM5DsB,YAAY,GAAG5E,KAAK,CAAC,IAAI;;AAAGqD,IAAAA,SAAS,EAAEC;GAAgB,CAAA,GAAA,CAA5B;AAACD,IAAAA,SAAS,EAAEC;GAAiB,GAAC;EAGzDuB,IAAI,GAAG7E,KAAK,CAAC,KAAK;;AAAGqD,IAAAA,SAAS,EAAEC;GAAgB,CAAA,GAAA,CAA5B;AAACD,IAAAA,SAAS,EAAEC;GAAiB,GAAC;EAGlD/C,QAAQ,GAA0B,IAAIuE,qBAAqB,CAAC;AACnE,IAAA,GAAG,IAAI;AACPC,IAAAA,UAAU,EAAErE,MAAM,CAACC,SAAS,CAAC;IAC7BqE,KAAK,EAAE,IAAI,CAACd,gBAAgB;IAE5Be,WAAW,EAAEA,MAAM,UAAU;IAC7BC,OAAO,EAAEC,CAAC,IAAI,IAAI,CAACC,QAAQ,CAACD,CAAC,CAAC;AAC9BnC,IAAAA,OAAO,EAAEA,MAAM,IAAI,CAACA;AACrB,GAAA,CAAC;AAEFnC,EAAAA,WAAAA,GAAA;AAEEC,IAAAA,iBAAiB,CAAC,MAAK;AACrB,MAAA,MAAMuE,QAAQ,GAAG,IAAI,CAACtB,SAAS,EAAE;AACjC,MAAA,MAAMuB,MAAM,GAAG,IAAI,CAACf,OAAO,EAAE;AAE7B,MAAA,KAAK,MAAMgB,OAAO,IAAIF,QAAQ,EAAE;AAC9B,QAAA,MAAMG,KAAK,GAAGF,MAAM,CAACG,IAAI,CAACC,CAAC,IAAIA,CAAC,CAACvF,OAAO,EAAE,KAAKoF,OAAO,CAACpF,OAAO,EAAE,CAAC;QACjEoF,OAAO,CAAC7B,eAAe,CAAC1C,GAAG,CAACwE,KAAK,EAAEjF,QAAQ,CAAC;AAC5C,QAAA,IAAIiF,KAAK,EAAE;UACTA,KAAK,CAAC/E,gBAAgB,CAACO,GAAG,CAACuE,OAAO,CAAChF,QAAQ,CAAC;AAC9C;AACF;AACF,KAAC,CAAC;AACJ;AAGAoF,EAAAA,SAASA,GAAA;AACP,IAAA,IAAI,CAACpF,QAAQ,CAACqF,iBAAiB,CAACC,OAAO,EAAE;AAC3C;AAGAC,EAAAA,WAAWA,GAAA;AACT,IAAA,IAAI,CAACvF,QAAQ,CAACqF,iBAAiB,CAACG,QAAQ,EAAE;AAC5C;EAGQX,QAAQA,CAACpC,OAAmC,EAAA;IAClD,IAAIzB,MAAM,GAAGyB,OAAO;AAEpB,IAAA,OAAOzB,MAAM,EAAE;AACb,MAAA,MAAMyE,OAAO,GAAG,IAAI,CAAC9B,gBAAgB,EAAE,CAACuB,IAAI,CAACrB,CAAC,IAAIA,CAAC,CAACpB,OAAO,EAAE,KAAKzB,MAAM,CAAC;AACzE,MAAA,IAAIyE,OAAO,EAAE;AACX,QAAA,OAAOA,OAAO;AAChB;MAEAzE,MAAM,GAAGA,MAAM,CAAC0E,aAAa,EAAEC,OAAO,CAAC,sBAAsB,CAAC;AAChE;AAEA,IAAA,OAAOvF,SAAS;AAClB;;;;;UArFWwC,cAAc;AAAA7B,IAAAA,IAAA,EAAA,EAAA;AAAAC,IAAAA,MAAA,EAAAC,EAAA,CAAAC,eAAA,CAAAC;AAAA,GAAA,CAAA;;;;UAAdyB,cAAc;AAAAxB,IAAAA,YAAA,EAAA,IAAA;AAAAC,IAAAA,QAAA,EAAA,oBAAA;AAAAC,IAAAA,MAAA,EAAA;AAAAuB,MAAAA,QAAA,EAAA;AAAAtB,QAAAA,iBAAA,EAAA,UAAA;AAAAC,QAAAA,UAAA,EAAA,UAAA;AAAAC,QAAAA,QAAA,EAAA,IAAA;AAAAC,QAAAA,UAAA,EAAA,KAAA;AAAAC,QAAAA,iBAAA,EAAA;OAAA;AAAAyC,MAAAA,eAAA,EAAA;AAAA7C,QAAAA,iBAAA,EAAA,iBAAA;AAAAC,QAAAA,UAAA,EAAA,iBAAA;AAAAC,QAAAA,QAAA,EAAA,IAAA;AAAAC,QAAAA,UAAA,EAAA,KAAA;AAAAC,QAAAA,iBAAA,EAAA;OAAA;AAAA0C,MAAAA,YAAA,EAAA;AAAA9C,QAAAA,iBAAA,EAAA,cAAA;AAAAC,QAAAA,UAAA,EAAA,cAAA;AAAAC,QAAAA,QAAA,EAAA,IAAA;AAAAC,QAAAA,UAAA,EAAA,KAAA;AAAAC,QAAAA,iBAAA,EAAA;OAAA;AAAA2C,MAAAA,IAAA,EAAA;AAAA/C,QAAAA,iBAAA,EAAA,MAAA;AAAAC,QAAAA,UAAA,EAAA,MAAA;AAAAC,QAAAA,QAAA,EAAA,IAAA;AAAAC,QAAAA,UAAA,EAAA,KAAA;AAAAC,QAAAA,iBAAA,EAAA;AAAA;KAAA;AAAAC,IAAAA,IAAA,EAAA;AAAAgE,MAAAA,SAAA,EAAA;AAAA,QAAA,SAAA,EAAA,4BAAA;AAAA,QAAA,aAAA,EAAA,gCAAA;AAAA,QAAA,SAAA,EAAA;AAAA;KAAA;AAAAC,IAAAA,OAAA,EAAA,CAAA;AAAAC,MAAAA,YAAA,EAAA,WAAA;AAAAC,MAAAA,SAAA,EAQoBzD,gBAAgB;AAAAoB,MAAAA,WAAA,EAAA,IAAA;AAAAjC,MAAAA,QAAA,EAAA;AAAA,KAAA,EAAA;AAAAqE,MAAAA,YAAA,EAAA,SAAA;AAAAC,MAAAA,SAAA,EAMlB3G,cAAc;AAAAsE,MAAAA,WAAA,EAAA,IAAA;AAAAjC,MAAAA,QAAA,EAAA;AAAA,KAAA,CAAA;IAAAM,QAAA,EAAA,CAAA,kBAAA,CAAA;AAAAI,IAAAA,QAAA,EAAAlB;AAAA,GAAA,CAAA;;;;;;QAd9C2B,cAAc;AAAAR,EAAAA,UAAA,EAAA,CAAA;UAT1BjB,SAAS;AAACkB,IAAAA,IAAA,EAAA,CAAA;AACThB,MAAAA,QAAQ,EAAE,oBAAoB;AAC9BU,MAAAA,QAAQ,EAAE,kBAAkB;AAC5BH,MAAAA,IAAI,EAAE;AACJ,QAAA,WAAW,EAAE,4BAA4B;AACzC,QAAA,eAAe,EAAE,gCAAgC;AACjD,QAAA,WAAW,EAAE;AACd;KACF;;;;MA+GYoE,gBAAgB,CAAA;;;;;UAAhBA,gBAAgB;AAAAjF,IAAAA,IAAA,EAAA,EAAA;AAAAC,IAAAA,MAAA,EAAAC,EAAA,CAAAC,eAAA,CAAAC;AAAA,GAAA,CAAA;;;;UAAhB6E,gBAAgB;AAAA5E,IAAAA,YAAA,EAAA,IAAA;AAAAC,IAAAA,QAAA,EAAA,iCAAA;AAAAW,IAAAA,cAAA,EAAA,CAAA;MAAAC,SAAA,EAAAC,EAAA,CAAA+D;AAAA,KAAA,CAAA;AAAA9D,IAAAA,QAAA,EAAAlB;AAAA,GAAA,CAAA;;;;;;QAAhB+E,gBAAgB;AAAA5D,EAAAA,UAAA,EAAA,CAAA;UAJ5BjB,SAAS;AAACkB,IAAAA,IAAA,EAAA,CAAA;AACThB,MAAAA,QAAQ,EAAE,iCAAiC;MAC3CW,cAAc,EAAE,CAACiE,eAAe;KACjC;;;;;;"}
|
|
1
|
+
{"version":3,"file":"accordion.mjs","sources":["../../../../../darwin_arm64-fastbuild-ST-199a4f3c4e20/bin/src/aria/accordion/accordion.ts"],"sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {\n Directive,\n input,\n ElementRef,\n inject,\n contentChildren,\n afterRenderEffect,\n signal,\n model,\n booleanAttribute,\n computed,\n WritableSignal,\n} from '@angular/core';\nimport {_IdGenerator} from '@angular/cdk/a11y';\nimport {Directionality} from '@angular/cdk/bidi';\nimport {\n DeferredContent,\n DeferredContentAware,\n AccordionGroupPattern,\n AccordionPanelPattern,\n AccordionTriggerPattern,\n} from '@angular/aria/private';\n\n/**\n * The content panel of an accordion item that is conditionally visible.\n *\n * This directive is a container for the content that is shown or hidden. It requires\n * a `panelId` that must match the `panelId` of its corresponding `ngAccordionTrigger`.\n * The content within the panel should be provided using an `ng-template` with the\n * `ngAccordionContent` directive so that the content is not rendered on the page until the trigger\n * is expanded. It applies `role=\"region\"` for accessibility and uses the `inert` attribute to hide\n * its content from assistive technologies when not visible.\n *\n * ```html\n * <div ngAccordionPanel panelId=\"unique-id-1\">\n * <ng-template ngAccordionContent>\n * <p>This content is lazily rendered and will be shown when the panel is expanded.</p>\n * </ng-template>\n * </div>\n * ```\n *\n * @developerPreview 21.0\n */\n@Directive({\n selector: '[ngAccordionPanel]',\n exportAs: 'ngAccordionPanel',\n hostDirectives: [\n {\n directive: DeferredContentAware,\n inputs: ['preserveContent'],\n },\n ],\n host: {\n 'role': 'region',\n '[attr.id]': '_pattern.id()',\n '[attr.aria-labelledby]': '_pattern.accordionTrigger()?.id()',\n '[attr.inert]': '!visible() ? true : null',\n },\n})\nexport class AccordionPanel {\n /** The DeferredContentAware host directive. */\n private readonly _deferredContentAware = inject(DeferredContentAware);\n\n /** A global unique identifier for the panel. */\n readonly id = input(inject(_IdGenerator).getId('ng-accordion-panel-', true));\n\n /** A local unique identifier for the panel, used to match with its trigger's `panelId`. */\n readonly panelId = input.required<string>();\n\n /** Whether the accordion panel is visible. True if the associated trigger is expanded. */\n readonly visible = computed(() => !this._pattern.hidden());\n\n /** The parent accordion trigger pattern that controls this panel. This is set by AccordionGroup. */\n readonly _accordionTriggerPattern: WritableSignal<AccordionTriggerPattern | undefined> =\n signal(undefined);\n\n /** The UI pattern instance for this panel. */\n readonly _pattern: AccordionPanelPattern = new AccordionPanelPattern({\n id: this.id,\n panelId: this.panelId,\n accordionTrigger: () => this._accordionTriggerPattern(),\n });\n\n constructor() {\n // Connect the panel's hidden state to the DeferredContentAware's visibility.\n afterRenderEffect(() => {\n this._deferredContentAware.contentVisible.set(this.visible());\n });\n }\n\n /** Expands this item. */\n expand() {\n this._accordionTriggerPattern()?.open();\n }\n\n /** Collapses this item. */\n collapse() {\n this._accordionTriggerPattern()?.close();\n }\n\n /** Toggles the expansion state of this item. */\n toggle() {\n this._accordionTriggerPattern()?.toggle();\n }\n}\n\n/**\n * The trigger that toggles the visibility of its associated `ngAccordionPanel`.\n *\n * This directive requires a `panelId` that must match the `panelId` of the `ngAccordionPanel` it\n * controls. When clicked, it will expand or collapse the panel. It also handles keyboard\n * interactions for navigation within the `ngAccordionGroup`. It applies `role=\"button\"` and manages\n * `aria-expanded`, `aria-controls`, and `aria-disabled` attributes for accessibility.\n * The `disabled` input can be used to disable the trigger.\n *\n * ```html\n * <button ngAccordionTrigger panelId=\"unique-id-1\">\n * Accordion Trigger Text\n * </button>\n * ```\n *\n * @developerPreview 21.0\n */\n@Directive({\n selector: '[ngAccordionTrigger]',\n exportAs: 'ngAccordionTrigger',\n host: {\n '[attr.data-active]': 'active()',\n 'role': 'button',\n '[id]': '_pattern.id()',\n '[attr.aria-expanded]': 'expanded()',\n '[attr.aria-controls]': '_pattern.controls()',\n '[attr.aria-disabled]': '_pattern.disabled()',\n '[attr.disabled]': '_pattern.hardDisabled() ? true : null',\n '[attr.tabindex]': '_pattern.tabIndex()',\n },\n})\nexport class AccordionTrigger {\n /** A reference to the trigger element. */\n private readonly _elementRef = inject(ElementRef);\n\n /** A reference to the trigger element. */\n readonly element = this._elementRef.nativeElement as HTMLElement;\n\n /** The parent AccordionGroup. */\n private readonly _accordionGroup = inject(AccordionGroup);\n\n /** A unique identifier for the widget. */\n readonly id = input(inject(_IdGenerator).getId('ng-accordion-trigger-', true));\n\n /** A local unique identifier for the trigger, used to match with its panel's `panelId`. */\n readonly panelId = input.required<string>();\n\n /** Whether the trigger is disabled. */\n readonly disabled = input(false, {transform: booleanAttribute});\n\n /** Whether the corresponding panel is expanded. */\n readonly expanded = model<boolean>(false);\n\n /** Whether the trigger is active. */\n readonly active = computed(() => this._pattern.active());\n\n /** The accordion panel pattern controlled by this trigger. This is set by AccordionGroup. */\n readonly _accordionPanelPattern: WritableSignal<AccordionPanelPattern | undefined> =\n signal(undefined);\n\n /** The UI pattern instance for this trigger. */\n readonly _pattern: AccordionTriggerPattern = new AccordionTriggerPattern({\n ...this,\n accordionGroup: computed(() => this._accordionGroup._pattern),\n accordionPanel: this._accordionPanelPattern,\n element: () => this.element,\n });\n\n /** Expands this item. */\n expand() {\n this._pattern.open();\n }\n\n /** Collapses this item. */\n collapse() {\n this._pattern.close();\n }\n\n /** Toggles the expansion state of this item. */\n toggle() {\n this._pattern.toggle();\n }\n}\n\n/**\n * A container for a group of accordion items. It manages the overall state and\n * interactions of the accordion, such as keyboard navigation and expansion mode.\n *\n * The `ngAccordionGroup` serves as the root of a group of accordion triggers and panels,\n * coordinating the behavior of the `ngAccordionTrigger` and `ngAccordionPanel` elements within it.\n * It supports both single and multiple expansion modes.\n *\n * ```html\n * <div ngAccordionGroup [multiExpandable]=\"true\" [(expandedPanels)]=\"expandedItems\">\n * <div class=\"accordion-item\">\n * <h3>\n * <button ngAccordionTrigger panelId=\"item-1\">Item 1</button>\n * </h3>\n * <div ngAccordionPanel panelId=\"item-1\">\n * <ng-template ngAccordionContent>\n * <p>Content for Item 1.</p>\n * </ng-template>\n * </div>\n * </div>\n * <div class=\"accordion-item\">\n * <h3>\n * <button ngAccordionTrigger panelId=\"item-2\">Item 2</button>\n * </h3>\n * <div ngAccordionPanel panelId=\"item-2\">\n * <ng-template ngAccordionContent>\n * <p>Content for Item 2.</p>\n * </ng-template>\n * </div>\n * </div>\n * </div>\n * ```\n *\n * @developerPreview 21.0\n */\n@Directive({\n selector: '[ngAccordionGroup]',\n exportAs: 'ngAccordionGroup',\n host: {\n '(keydown)': '_pattern.onKeydown($event)',\n '(pointerdown)': '_pattern.onPointerdown($event)',\n '(focusin)': '_pattern.onFocus($event)',\n },\n})\nexport class AccordionGroup {\n /** A reference to the group element. */\n private readonly _elementRef = inject(ElementRef);\n\n /** A reference to the group element. */\n readonly element = this._elementRef.nativeElement as HTMLElement;\n\n /** The AccordionTriggers nested inside this group. */\n private readonly _triggers = contentChildren(AccordionTrigger, {descendants: true});\n\n /** The AccordionTrigger patterns nested inside this group. */\n private readonly _triggerPatterns = computed(() => this._triggers().map(t => t._pattern));\n\n /** The AccordionPanels nested inside this group. */\n private readonly _panels = contentChildren(AccordionPanel, {descendants: true});\n\n /** The text direction (ltr or rtl). */\n readonly textDirection = inject(Directionality).valueSignal;\n\n /** Whether the entire accordion group is disabled. */\n readonly disabled = input(false, {transform: booleanAttribute});\n\n /** Whether multiple accordion items can be expanded simultaneously. */\n readonly multiExpandable = input(true, {transform: booleanAttribute});\n\n /**\n * Whether to allow disabled items to receive focus. When `true`, disabled items are\n * focusable but not interactive. When `false`, disabled items are skipped during navigation.\n */\n readonly softDisabled = input(true, {transform: booleanAttribute});\n\n /** Whether keyboard navigation should wrap around from the last item to the first, and vice-versa. */\n readonly wrap = input(false, {transform: booleanAttribute});\n\n /** The UI pattern instance for this accordion group. */\n readonly _pattern: AccordionGroupPattern = new AccordionGroupPattern({\n ...this,\n activeItem: signal(undefined),\n items: this._triggerPatterns,\n // TODO(ok7sai): Investigate whether an accordion should support horizontal mode.\n orientation: () => 'vertical',\n getItem: e => this._getItem(e),\n element: () => this.element,\n });\n\n constructor() {\n // Effect to link triggers with their corresponding panels and update the group's items.\n afterRenderEffect(() => {\n const triggers = this._triggers();\n const panels = this._panels();\n\n for (const trigger of triggers) {\n const panel = panels.find(p => p.panelId() === trigger.panelId());\n trigger._accordionPanelPattern.set(panel?._pattern);\n if (panel) {\n panel._accordionTriggerPattern.set(trigger._pattern);\n }\n }\n });\n }\n\n /** Expands all accordion panels if multi-expandable. */\n expandAll() {\n this._pattern.expansionBehavior.openAll();\n }\n\n /** Collapses all accordion panels. */\n collapseAll() {\n this._pattern.expansionBehavior.closeAll();\n }\n\n /** Gets the trigger pattern for a given element. */\n private _getItem(element: Element | null | undefined): AccordionTriggerPattern | undefined {\n let target = element;\n\n while (target) {\n const pattern = this._triggerPatterns().find(t => t.element() === target);\n if (pattern) {\n return pattern;\n }\n\n target = target.parentElement?.closest('[ngAccordionTrigger]');\n }\n\n return undefined;\n }\n}\n\n/**\n * A structural directive that provides a mechanism for lazily rendering the content for an\n * `ngAccordionPanel`.\n *\n * This directive should be applied to an `ng-template` inside an `ngAccordionPanel`.\n * It allows the content of the panel to be lazily rendered, improving performance\n * by only creating the content when the panel is first expanded.\n *\n * ```html\n * <div ngAccordionPanel panelId=\"unique-id-1\">\n * <ng-template ngAccordionContent>\n * <p>This is the content that will be displayed inside the panel.</p>\n * </ng-template>\n * </div>\n * ```\n *\n * @developerPreview 21.0\n */\n@Directive({\n selector: 'ng-template[ngAccordionContent]',\n hostDirectives: [DeferredContent],\n})\nexport class AccordionContent {}\n"],"names":["AccordionPanel","_deferredContentAware","inject","DeferredContentAware","id","input","_IdGenerator","getId","panelId","required","visible","computed","_pattern","hidden","_accordionTriggerPattern","signal","undefined","AccordionPanelPattern","accordionTrigger","constructor","afterRenderEffect","contentVisible","set","expand","open","collapse","close","toggle","deps","target","i0","ɵɵFactoryTarget","Directive","isStandalone","selector","inputs","classPropertyName","publicName","isSignal","isRequired","transformFunction","host","attributes","properties","exportAs","hostDirectives","directive","i1","ngImport","decorators","args","AccordionTrigger","_elementRef","ElementRef","element","nativeElement","_accordionGroup","AccordionGroup","disabled","transform","booleanAttribute","expanded","model","active","_accordionPanelPattern","AccordionTriggerPattern","accordionGroup","accordionPanel","outputs","_triggers","contentChildren","descendants","_triggerPatterns","map","t","ngDevMode","debugName","_panels","textDirection","Directionality","valueSignal","multiExpandable","softDisabled","wrap","AccordionGroupPattern","activeItem","items","orientation","getItem","e","_getItem","triggers","panels","trigger","panel","find","p","expandAll","expansionBehavior","openAll","collapseAll","closeAll","pattern","parentElement","closest","listeners","queries","propertyName","predicate","AccordionContent","DeferredContent"],"mappings":"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"}
|
package/fesm2022/aria.mjs
CHANGED
package/fesm2022/aria.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"aria.mjs","sources":["../../../../../darwin_arm64-fastbuild-ST-199a4f3c4e20/bin/src/aria/version.ts"],"sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {Version} from '@angular/core';\n\n/** Current version of the CDK Experimental package. */\nexport const VERSION = new Version('21.0.0
|
|
1
|
+
{"version":3,"file":"aria.mjs","sources":["../../../../../darwin_arm64-fastbuild-ST-199a4f3c4e20/bin/src/aria/version.ts"],"sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {Version} from '@angular/core';\n\n/** Current version of the CDK Experimental package. */\nexport const VERSION = new Version('21.0.0');\n"],"names":["VERSION","Version"],"mappings":";;MAWaA,OAAO,GAAG,IAAIC,OAAO,CAAC,mBAAmB;;;;"}
|
package/fesm2022/combobox.mjs
CHANGED
|
@@ -56,7 +56,7 @@ class Combobox {
|
|
|
56
56
|
inputValue: signal(''),
|
|
57
57
|
inputEl: signal(undefined),
|
|
58
58
|
containerEl: () => this._elementRef.nativeElement,
|
|
59
|
-
popupControls: () => this.popup()?.
|
|
59
|
+
popupControls: () => this.popup()?._controls()
|
|
60
60
|
});
|
|
61
61
|
constructor() {
|
|
62
62
|
afterRenderEffect(() => {
|
|
@@ -78,12 +78,6 @@ class Combobox {
|
|
|
78
78
|
close() {
|
|
79
79
|
this._pattern.close();
|
|
80
80
|
}
|
|
81
|
-
expand() {
|
|
82
|
-
this._pattern.open();
|
|
83
|
-
}
|
|
84
|
-
collapse() {
|
|
85
|
-
this._pattern.close();
|
|
86
|
-
}
|
|
87
81
|
static ɵfac = i0.ɵɵngDeclareFactory({
|
|
88
82
|
minVersion: "12.0.0",
|
|
89
83
|
version: "20.2.0-next.2",
|
|
@@ -198,7 +192,7 @@ class ComboboxInput {
|
|
|
198
192
|
constructor() {
|
|
199
193
|
this.combobox._pattern.inputs.inputEl.set(this._elementRef.nativeElement);
|
|
200
194
|
this.combobox._pattern.inputs.inputValue = this.value;
|
|
201
|
-
const controls = this.combobox.popup()?.
|
|
195
|
+
const controls = this.combobox.popup()?._controls();
|
|
202
196
|
if (controls instanceof ComboboxDialogPattern) {
|
|
203
197
|
return;
|
|
204
198
|
}
|
|
@@ -318,8 +312,8 @@ class ComboboxPopup {
|
|
|
318
312
|
combobox = inject(Combobox, {
|
|
319
313
|
optional: true
|
|
320
314
|
});
|
|
321
|
-
|
|
322
|
-
debugName: "
|
|
315
|
+
_controls = signal(undefined, ...(ngDevMode ? [{
|
|
316
|
+
debugName: "_controls"
|
|
323
317
|
}] : []));
|
|
324
318
|
static ɵfac = i0.ɵɵngDeclareFactory({
|
|
325
319
|
minVersion: "12.0.0",
|
|
@@ -367,7 +361,7 @@ class ComboboxDialog {
|
|
|
367
361
|
combobox: this.combobox._pattern
|
|
368
362
|
});
|
|
369
363
|
if (this._popup) {
|
|
370
|
-
this._popup.
|
|
364
|
+
this._popup._controls.set(this._pattern);
|
|
371
365
|
}
|
|
372
366
|
afterRenderEffect(() => {
|
|
373
367
|
if (this._elementRef) {
|