primeng 16.0.2 → 16.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (222) hide show
  1. package/accordion/accordion.d.ts +35 -11
  2. package/api/translation.d.ts +23 -0
  3. package/api/treenode.d.ts +1 -1
  4. package/avatar/avatar.d.ts +11 -1
  5. package/breadcrumb/breadcrumb.d.ts +5 -1
  6. package/button/button.d.ts +3 -0
  7. package/chip/chip.d.ts +1 -0
  8. package/contextmenu/contextmenu.d.ts +157 -67
  9. package/dock/dock.d.ts +47 -2
  10. package/dom/domhandler.d.ts +1 -0
  11. package/esm2022/accordion/accordion.mjs +177 -43
  12. package/esm2022/api/primengconfig.mjs +75 -2
  13. package/esm2022/api/translation.mjs +1 -1
  14. package/esm2022/api/treenode.mjs +1 -1
  15. package/esm2022/autocomplete/autocomplete.mjs +3 -3
  16. package/esm2022/avatar/avatar.mjs +18 -4
  17. package/esm2022/blockui/blockui.mjs +19 -3
  18. package/esm2022/breadcrumb/breadcrumb.mjs +50 -33
  19. package/esm2022/button/button.mjs +4 -1
  20. package/esm2022/card/card.mjs +3 -3
  21. package/esm2022/chip/chip.mjs +18 -13
  22. package/esm2022/contextmenu/contextmenu.mjs +993 -547
  23. package/esm2022/divider/divider.mjs +3 -3
  24. package/esm2022/dock/dock.mjs +284 -86
  25. package/esm2022/dom/domhandler.mjs +19 -7
  26. package/esm2022/dynamicdialog/dynamicdialog-ref.mjs +4 -1
  27. package/esm2022/fieldset/fieldset.mjs +59 -32
  28. package/esm2022/image/image.mjs +11 -3
  29. package/esm2022/inplace/inplace.mjs +18 -11
  30. package/esm2022/megamenu/megamenu.mjs +997 -348
  31. package/esm2022/menu/menu.mjs +397 -166
  32. package/esm2022/menubar/menubar.mjs +895 -282
  33. package/esm2022/orderlist/orderlist.mjs +9 -15
  34. package/esm2022/panel/panel.mjs +44 -33
  35. package/esm2022/panelmenu/panelmenu.mjs +982 -344
  36. package/esm2022/progressbar/progressbar.mjs +19 -15
  37. package/esm2022/progressspinner/progressspinner.mjs +5 -5
  38. package/esm2022/ripple/ripple.mjs +3 -1
  39. package/esm2022/scrollpanel/scrollpanel.mjs +195 -23
  40. package/esm2022/scrolltop/scrolltop.mjs +11 -2
  41. package/esm2022/skeleton/skeleton.mjs +3 -3
  42. package/esm2022/slidemenu/slidemenu.mjs +1059 -372
  43. package/esm2022/splitbutton/splitbutton.mjs +2 -2
  44. package/esm2022/splitter/splitter.mjs +160 -29
  45. package/esm2022/steps/steps.mjs +112 -22
  46. package/esm2022/table/table.mjs +13 -7
  47. package/esm2022/tabmenu/tabmenu.mjs +191 -63
  48. package/esm2022/tabview/tabview.mjs +173 -39
  49. package/esm2022/terminal/terminal.mjs +3 -3
  50. package/esm2022/tieredmenu/tieredmenu.mjs +868 -392
  51. package/esm2022/toolbar/toolbar.mjs +17 -10
  52. package/esm2022/tooltip/tooltip.mjs +1 -1
  53. package/esm2022/tree/tree.mjs +3 -3
  54. package/esm2022/treetable/treetable.mjs +17 -17
  55. package/esm2022/utils/objectutils.mjs +31 -1
  56. package/esm2022/utils/uniquecomponentid.mjs +2 -3
  57. package/fesm2022/primeng-accordion.mjs +176 -42
  58. package/fesm2022/primeng-accordion.mjs.map +1 -1
  59. package/fesm2022/primeng-api.mjs +74 -1
  60. package/fesm2022/primeng-api.mjs.map +1 -1
  61. package/fesm2022/primeng-autocomplete.mjs +2 -2
  62. package/fesm2022/primeng-autocomplete.mjs.map +1 -1
  63. package/fesm2022/primeng-avatar.mjs +17 -3
  64. package/fesm2022/primeng-avatar.mjs.map +1 -1
  65. package/fesm2022/primeng-blockui.mjs +18 -2
  66. package/fesm2022/primeng-blockui.mjs.map +1 -1
  67. package/fesm2022/primeng-breadcrumb.mjs +49 -32
  68. package/fesm2022/primeng-breadcrumb.mjs.map +1 -1
  69. package/fesm2022/primeng-button.mjs +3 -0
  70. package/fesm2022/primeng-button.mjs.map +1 -1
  71. package/fesm2022/primeng-card.mjs +2 -2
  72. package/fesm2022/primeng-card.mjs.map +1 -1
  73. package/fesm2022/primeng-chip.mjs +17 -12
  74. package/fesm2022/primeng-chip.mjs.map +1 -1
  75. package/fesm2022/primeng-contextmenu.mjs +992 -546
  76. package/fesm2022/primeng-contextmenu.mjs.map +1 -1
  77. package/fesm2022/primeng-divider.mjs +2 -2
  78. package/fesm2022/primeng-divider.mjs.map +1 -1
  79. package/fesm2022/primeng-dock.mjs +283 -85
  80. package/fesm2022/primeng-dock.mjs.map +1 -1
  81. package/fesm2022/primeng-dom.mjs +18 -6
  82. package/fesm2022/primeng-dom.mjs.map +1 -1
  83. package/fesm2022/primeng-dynamicdialog.mjs +3 -0
  84. package/fesm2022/primeng-dynamicdialog.mjs.map +1 -1
  85. package/fesm2022/primeng-fieldset.mjs +57 -30
  86. package/fesm2022/primeng-fieldset.mjs.map +1 -1
  87. package/fesm2022/primeng-image.mjs +10 -2
  88. package/fesm2022/primeng-image.mjs.map +1 -1
  89. package/fesm2022/primeng-inplace.mjs +17 -10
  90. package/fesm2022/primeng-inplace.mjs.map +1 -1
  91. package/fesm2022/primeng-megamenu.mjs +996 -348
  92. package/fesm2022/primeng-megamenu.mjs.map +1 -1
  93. package/fesm2022/primeng-menu.mjs +396 -165
  94. package/fesm2022/primeng-menu.mjs.map +1 -1
  95. package/fesm2022/primeng-menubar.mjs +894 -281
  96. package/fesm2022/primeng-menubar.mjs.map +1 -1
  97. package/fesm2022/primeng-orderlist.mjs +8 -14
  98. package/fesm2022/primeng-orderlist.mjs.map +1 -1
  99. package/fesm2022/primeng-panel.mjs +44 -33
  100. package/fesm2022/primeng-panel.mjs.map +1 -1
  101. package/fesm2022/primeng-panelmenu.mjs +981 -344
  102. package/fesm2022/primeng-panelmenu.mjs.map +1 -1
  103. package/fesm2022/primeng-progressbar.mjs +18 -14
  104. package/fesm2022/primeng-progressbar.mjs.map +1 -1
  105. package/fesm2022/primeng-progressspinner.mjs +4 -4
  106. package/fesm2022/primeng-progressspinner.mjs.map +1 -1
  107. package/fesm2022/primeng-ripple.mjs +2 -0
  108. package/fesm2022/primeng-ripple.mjs.map +1 -1
  109. package/fesm2022/primeng-scrollpanel.mjs +194 -22
  110. package/fesm2022/primeng-scrollpanel.mjs.map +1 -1
  111. package/fesm2022/primeng-scrolltop.mjs +10 -1
  112. package/fesm2022/primeng-scrolltop.mjs.map +1 -1
  113. package/fesm2022/primeng-skeleton.mjs +2 -2
  114. package/fesm2022/primeng-skeleton.mjs.map +1 -1
  115. package/fesm2022/primeng-slidemenu.mjs +1058 -371
  116. package/fesm2022/primeng-slidemenu.mjs.map +1 -1
  117. package/fesm2022/primeng-splitbutton.mjs +1 -1
  118. package/fesm2022/primeng-splitbutton.mjs.map +1 -1
  119. package/fesm2022/primeng-splitter.mjs +160 -29
  120. package/fesm2022/primeng-splitter.mjs.map +1 -1
  121. package/fesm2022/primeng-steps.mjs +111 -21
  122. package/fesm2022/primeng-steps.mjs.map +1 -1
  123. package/fesm2022/primeng-table.mjs +12 -6
  124. package/fesm2022/primeng-table.mjs.map +1 -1
  125. package/fesm2022/primeng-tabmenu.mjs +190 -62
  126. package/fesm2022/primeng-tabmenu.mjs.map +1 -1
  127. package/fesm2022/primeng-tabview.mjs +172 -38
  128. package/fesm2022/primeng-tabview.mjs.map +1 -1
  129. package/fesm2022/primeng-terminal.mjs +2 -2
  130. package/fesm2022/primeng-terminal.mjs.map +1 -1
  131. package/fesm2022/primeng-tieredmenu.mjs +867 -391
  132. package/fesm2022/primeng-tieredmenu.mjs.map +1 -1
  133. package/fesm2022/primeng-toolbar.mjs +16 -9
  134. package/fesm2022/primeng-toolbar.mjs.map +1 -1
  135. package/fesm2022/primeng-tooltip.mjs.map +1 -1
  136. package/fesm2022/primeng-tree.mjs +2 -2
  137. package/fesm2022/primeng-tree.mjs.map +1 -1
  138. package/fesm2022/primeng-treetable.mjs +16 -16
  139. package/fesm2022/primeng-treetable.mjs.map +1 -1
  140. package/fesm2022/primeng-utils.mjs +31 -2
  141. package/fesm2022/primeng-utils.mjs.map +1 -1
  142. package/fieldset/fieldset.d.ts +6 -5
  143. package/image/image.d.ts +1 -0
  144. package/inplace/inplace.d.ts +6 -1
  145. package/megamenu/megamenu.d.ts +137 -15
  146. package/menu/menu.d.ts +64 -7
  147. package/menubar/menubar.d.ts +116 -22
  148. package/orderlist/orderlist.d.ts +2 -1
  149. package/package.json +124 -124
  150. package/panel/panel.d.ts +6 -5
  151. package/panelmenu/panelmenu.d.ts +134 -22
  152. package/resources/components/autocomplete/autocomplete.css +9 -8
  153. package/resources/components/breadcrumb/breadcrumb.css +9 -3
  154. package/resources/components/common/common.css +1 -1
  155. package/resources/components/contextmenu/contextmenu.css +1 -7
  156. package/resources/components/dock/dock.css +1 -1
  157. package/resources/components/megamenu/megamenu.css +9 -10
  158. package/resources/components/panelmenu/panelmenu.css +4 -2
  159. package/resources/components/slidemenu/slidemenu.css +40 -41
  160. package/resources/primeng.css +1 -1
  161. package/resources/primeng.min.css +1 -1
  162. package/resources/themes/arya-blue/theme.css +342 -390
  163. package/resources/themes/arya-green/theme.css +342 -390
  164. package/resources/themes/arya-orange/theme.css +342 -390
  165. package/resources/themes/arya-purple/theme.css +342 -390
  166. package/resources/themes/bootstrap4-dark-blue/theme.css +357 -416
  167. package/resources/themes/bootstrap4-dark-purple/theme.css +357 -416
  168. package/resources/themes/bootstrap4-light-blue/theme.css +369 -428
  169. package/resources/themes/bootstrap4-light-purple/theme.css +369 -428
  170. package/resources/themes/fluent-light/theme.css +352 -400
  171. package/resources/themes/lara-dark-blue/theme.css +344 -392
  172. package/resources/themes/lara-dark-indigo/theme.css +344 -392
  173. package/resources/themes/lara-dark-purple/theme.css +344 -392
  174. package/resources/themes/lara-dark-teal/theme.css +344 -392
  175. package/resources/themes/lara-light-blue/theme.css +370 -418
  176. package/resources/themes/lara-light-indigo/theme.css +370 -418
  177. package/resources/themes/lara-light-purple/theme.css +370 -418
  178. package/resources/themes/lara-light-teal/theme.css +370 -418
  179. package/resources/themes/luna-amber/theme.css +360 -408
  180. package/resources/themes/luna-blue/theme.css +360 -408
  181. package/resources/themes/luna-green/theme.css +360 -408
  182. package/resources/themes/luna-pink/theme.css +360 -408
  183. package/resources/themes/md-dark-deeppurple/theme.css +373 -403
  184. package/resources/themes/md-dark-indigo/theme.css +373 -403
  185. package/resources/themes/md-light-deeppurple/theme.css +373 -403
  186. package/resources/themes/md-light-indigo/theme.css +373 -403
  187. package/resources/themes/mdc-dark-deeppurple/theme.css +373 -403
  188. package/resources/themes/mdc-dark-indigo/theme.css +373 -403
  189. package/resources/themes/mdc-light-deeppurple/theme.css +373 -403
  190. package/resources/themes/mdc-light-indigo/theme.css +373 -403
  191. package/resources/themes/mira/theme.css +347 -395
  192. package/resources/themes/nano/theme.css +348 -396
  193. package/resources/themes/nova/theme.css +336 -384
  194. package/resources/themes/nova-accent/theme.css +336 -384
  195. package/resources/themes/nova-alt/theme.css +336 -384
  196. package/resources/themes/rhea/theme.css +336 -384
  197. package/resources/themes/saga-blue/theme.css +348 -396
  198. package/resources/themes/saga-green/theme.css +348 -396
  199. package/resources/themes/saga-orange/theme.css +348 -396
  200. package/resources/themes/saga-purple/theme.css +348 -396
  201. package/resources/themes/soho-dark/theme.css +362 -410
  202. package/resources/themes/soho-light/theme.css +370 -418
  203. package/resources/themes/tailwind-light/theme.css +361 -409
  204. package/resources/themes/vela-blue/theme.css +348 -396
  205. package/resources/themes/vela-green/theme.css +348 -396
  206. package/resources/themes/vela-orange/theme.css +348 -396
  207. package/resources/themes/vela-purple/theme.css +348 -396
  208. package/resources/themes/viva-dark/theme.css +342 -390
  209. package/resources/themes/viva-light/theme.css +348 -396
  210. package/scrollpanel/scrollpanel.d.ts +22 -4
  211. package/scrolltop/scrolltop.d.ts +6 -1
  212. package/slidemenu/slidemenu.d.ts +192 -88
  213. package/splitter/splitter.d.ts +18 -5
  214. package/steps/steps.d.ts +20 -3
  215. package/table/table.d.ts +3 -1
  216. package/tabmenu/tabmenu.d.ts +24 -1
  217. package/tabview/tabview.d.ts +26 -3
  218. package/tieredmenu/tieredmenu.d.ts +134 -50
  219. package/toolbar/toolbar.d.ts +6 -1
  220. package/tooltip/tooltip.d.ts +1 -1
  221. package/utils/objectutils.d.ts +4 -0
  222. package/utils/uniquecomponentid.d.ts +1 -1
@@ -1,13 +1,13 @@
1
1
  import { animate, style, transition, trigger } from '@angular/animations';
2
- import { CommonModule, DOCUMENT } from '@angular/common';
3
- import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Inject, Input, NgModule, Output, ViewChild, ViewEncapsulation } from '@angular/core';
2
+ import { CommonModule, DOCUMENT, isPlatformBrowser } from '@angular/common';
3
+ import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Inject, Input, NgModule, Output, PLATFORM_ID, ViewChild, ViewEncapsulation, effect, signal } from '@angular/core';
4
4
  import { RouterModule } from '@angular/router';
5
5
  import { PrimeTemplate, SharedModule } from 'primeng/api';
6
6
  import { ConnectedOverlayScrollHandler, DomHandler } from 'primeng/dom';
7
7
  import { AngleRightIcon } from 'primeng/icons/angleright';
8
8
  import { RippleModule } from 'primeng/ripple';
9
9
  import { TooltipModule } from 'primeng/tooltip';
10
- import { ZIndexUtils } from 'primeng/utils';
10
+ import { ObjectUtils, UniqueComponentId, ZIndexUtils } from 'primeng/utils';
11
11
  import * as i0 from "@angular/core";
12
12
  import * as i1 from "@angular/common";
13
13
  import * as i2 from "@angular/router";
@@ -20,32 +20,25 @@ class TieredMenuSub {
20
20
  renderer;
21
21
  cd;
22
22
  tieredMenu;
23
- item;
24
- root;
23
+ items;
24
+ root = false;
25
25
  autoDisplay;
26
26
  autoZIndex = true;
27
27
  baseZIndex = 0;
28
- mobileActive;
29
28
  popup;
30
- get parentActive() {
31
- return this._parentActive;
32
- }
33
- set parentActive(value) {
34
- if (!this.root) {
35
- this._parentActive = value;
36
- if (!value)
37
- this.activeItem = null;
38
- else
39
- this.positionSubmenu();
40
- }
41
- }
29
+ menuId;
30
+ ariaLabel;
31
+ ariaLabelledBy;
32
+ level = 0;
33
+ focusedItemId;
34
+ activeItemPath;
35
+ tabindex = 0;
36
+ itemClick = new EventEmitter();
37
+ itemMouseEnter = new EventEmitter();
38
+ menuFocus = new EventEmitter();
39
+ menuBlur = new EventEmitter();
40
+ menuKeydown = new EventEmitter();
42
41
  sublistViewChild;
43
- leafClick = new EventEmitter();
44
- keydownItem = new EventEmitter();
45
- _parentActive;
46
- documentClickListener;
47
- menuHoverActive = false;
48
- activeItem;
49
42
  constructor(document, el, renderer, cd, tieredMenu) {
50
43
  this.document = document;
51
44
  this.el = el;
@@ -53,101 +46,6 @@ class TieredMenuSub {
53
46
  this.cd = cd;
54
47
  this.tieredMenu = tieredMenu;
55
48
  }
56
- onItemClick(event, item) {
57
- if (item.disabled) {
58
- event.preventDefault();
59
- return;
60
- }
61
- if (!item.url && !item.routerLink) {
62
- event.preventDefault();
63
- }
64
- if (item.command) {
65
- item.command({
66
- originalEvent: event,
67
- item: item
68
- });
69
- }
70
- if (item.items) {
71
- if (this.activeItem && item === this.activeItem) {
72
- this.activeItem = null;
73
- this.unbindDocumentClickListener();
74
- }
75
- else {
76
- this.activeItem = item;
77
- if (this.root) {
78
- this.bindDocumentClickListener();
79
- }
80
- }
81
- }
82
- if (!item.items) {
83
- this.onLeafClick();
84
- }
85
- }
86
- onItemMouseEnter(event, item) {
87
- if (item.disabled || this.mobileActive) {
88
- event.preventDefault();
89
- return;
90
- }
91
- if (this.root) {
92
- if (this.activeItem || this.autoDisplay || this.popup) {
93
- this.activeItem = item;
94
- this.bindDocumentClickListener();
95
- }
96
- }
97
- else {
98
- this.activeItem = item;
99
- this.bindDocumentClickListener();
100
- }
101
- }
102
- onLeafClick() {
103
- this.activeItem = null;
104
- if (this.root) {
105
- this.unbindDocumentClickListener();
106
- }
107
- this.leafClick.emit();
108
- }
109
- onItemKeyDown(event, item) {
110
- let listItem = event.currentTarget.parentElement;
111
- switch (event.key) {
112
- case 'ArrowDown':
113
- const nextItem = this.findNextItem(listItem);
114
- if (nextItem) {
115
- nextItem.children[0].focus();
116
- }
117
- event.preventDefault();
118
- break;
119
- case 'ArrowUp':
120
- const prevItem = this.findPrevItem(listItem);
121
- if (prevItem) {
122
- prevItem.children[0].focus();
123
- }
124
- event.preventDefault();
125
- break;
126
- case 'ArrowRight':
127
- if (item.items) {
128
- this.activeItem = item;
129
- if (this.root) {
130
- this.bindDocumentClickListener();
131
- }
132
- setTimeout(() => {
133
- (listItem?.children[1].children[0].children[0].children[0]).focus();
134
- }, 50);
135
- }
136
- event.preventDefault();
137
- break;
138
- case 'Enter':
139
- if (!item.routerLink) {
140
- this.onItemClick(event, item);
141
- }
142
- break;
143
- default:
144
- break;
145
- }
146
- this.keydownItem.emit({
147
- originalEvent: event,
148
- element: listItem
149
- });
150
- }
151
49
  positionSubmenu() {
152
50
  let sublist = this.sublistViewChild && this.sublistViewChild.nativeElement;
153
51
  if (sublist) {
@@ -161,140 +59,210 @@ class TieredMenuSub {
161
59
  }
162
60
  }
163
61
  }
164
- findNextItem(item) {
165
- let nextItem = item.nextElementSibling;
166
- if (nextItem)
167
- return DomHandler.hasClass(nextItem, 'p-disabled') || !DomHandler.hasClass(nextItem, 'p-menuitem') ? this.findNextItem(nextItem) : nextItem;
168
- else
169
- return null;
62
+ getItemProp(processedItem, name, params = null) {
63
+ return processedItem && processedItem.item ? ObjectUtils.getItemValue(processedItem.item[name], params) : undefined;
170
64
  }
171
- findPrevItem(item) {
172
- let prevItem = item.previousElementSibling;
173
- if (prevItem)
174
- return DomHandler.hasClass(prevItem, 'p-disabled') || !DomHandler.hasClass(prevItem, 'p-menuitem') ? this.findPrevItem(prevItem) : prevItem;
175
- else
176
- return null;
65
+ getItemId(processedItem) {
66
+ return `${this.menuId}_${processedItem.key}`;
177
67
  }
178
- onChildItemKeyDown(event) {
179
- if (event.key === 'ArrowLeft') {
180
- this.activeItem = null;
181
- if (this.root) {
182
- this.unbindDocumentClickListener();
183
- }
184
- if (event.target) {
185
- const parent = event.target.parentElement;
186
- if (parent && parent.parentElement && parent.parentElement.parentElement) {
187
- parent.parentElement.parentElement.children[0].focus();
188
- }
189
- }
190
- }
68
+ getItemKey(processedItem) {
69
+ return this.getItemId(processedItem);
191
70
  }
192
- bindDocumentClickListener() {
193
- if (!this.documentClickListener) {
194
- this.documentClickListener = this.renderer.listen(this.document, 'click', (event) => {
195
- if (this.el && !this.el.nativeElement.contains(event.target)) {
196
- this.activeItem = null;
197
- this.cd.markForCheck();
198
- this.unbindDocumentClickListener();
199
- }
200
- });
71
+ getItemClass(processedItem) {
72
+ return {
73
+ ...this.getItemProp(processedItem, 'class'),
74
+ 'p-menuitem': true,
75
+ 'p-highlight': this.isItemActive(processedItem),
76
+ 'p-menuitem-active': this.isItemActive(processedItem),
77
+ 'p-focus': this.isItemFocused(processedItem),
78
+ 'p-disabled': this.isItemDisabled(processedItem)
79
+ };
80
+ }
81
+ getItemLabel(processedItem) {
82
+ return this.getItemProp(processedItem, 'label');
83
+ }
84
+ getSeparatorItemClass(processedItem) {
85
+ return {
86
+ ...this.getItemProp(processedItem, 'class'),
87
+ 'p-menuitem-separator': true
88
+ };
89
+ }
90
+ getAriaSetSize() {
91
+ return this.items.filter((processedItem) => this.isItemVisible(processedItem) && !this.getItemProp(processedItem, 'separator')).length;
92
+ }
93
+ getAriaPosInset(index) {
94
+ return index - this.items.slice(0, index).filter((processedItem) => this.isItemVisible(processedItem) && this.getItemProp(processedItem, 'separator')).length + 1;
95
+ }
96
+ isItemVisible(processedItem) {
97
+ return this.getItemProp(processedItem, 'visible') !== false;
98
+ }
99
+ isItemActive(processedItem) {
100
+ if (this.activeItemPath) {
101
+ return this.activeItemPath.some((path) => path.key === processedItem.key);
201
102
  }
202
103
  }
203
- unbindDocumentClickListener() {
204
- if (this.documentClickListener) {
205
- this.documentClickListener();
206
- this.documentClickListener = null;
104
+ isItemDisabled(processedItem) {
105
+ return this.getItemProp(processedItem, 'disabled');
106
+ }
107
+ isItemFocused(processedItem) {
108
+ return this.focusedItemId === this.getItemId(processedItem);
109
+ }
110
+ isItemGroup(processedItem) {
111
+ return ObjectUtils.isNotEmpty(processedItem.items);
112
+ }
113
+ onItemMouseEnter(param) {
114
+ if (this.autoDisplay) {
115
+ const { event, processedItem } = param;
116
+ this.itemMouseEnter.emit({ originalEvent: event, processedItem });
207
117
  }
208
118
  }
209
- ngOnDestroy() {
210
- this.unbindDocumentClickListener();
119
+ onItemClick(event, processedItem) {
120
+ this.getItemProp(processedItem, 'command', { originalEvent: event, item: processedItem.item });
121
+ this.itemClick.emit({ originalEvent: event, processedItem, isFocus: true });
211
122
  }
212
123
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: TieredMenuSub, deps: [{ token: DOCUMENT }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }, { token: TieredMenu }], target: i0.ɵɵFactoryTarget.Component });
213
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: TieredMenuSub, selector: "p-tieredMenuSub", inputs: { item: "item", root: "root", autoDisplay: "autoDisplay", autoZIndex: "autoZIndex", baseZIndex: "baseZIndex", mobileActive: "mobileActive", popup: "popup", parentActive: "parentActive" }, outputs: { leafClick: "leafClick", keydownItem: "keydownItem" }, host: { classAttribute: "p-element" }, viewQueries: [{ propertyName: "sublistViewChild", first: true, predicate: ["sublist"], descendants: true }], ngImport: i0, template: `
214
- <ul #sublist [ngClass]="{ 'p-submenu-list': !root }">
215
- <ng-template ngFor let-child [ngForOf]="root ? item : item?.items">
216
- <li *ngIf="child.separator" class="p-menu-separator" [ngClass]="{ 'p-hidden': child.visible === false }"></li>
124
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: TieredMenuSub, selector: "p-tieredMenuSub", inputs: { items: "items", root: "root", autoDisplay: "autoDisplay", autoZIndex: "autoZIndex", baseZIndex: "baseZIndex", popup: "popup", menuId: "menuId", ariaLabel: "ariaLabel", ariaLabelledBy: "ariaLabelledBy", level: "level", focusedItemId: "focusedItemId", activeItemPath: "activeItemPath", tabindex: "tabindex" }, outputs: { itemClick: "itemClick", itemMouseEnter: "itemMouseEnter", menuFocus: "menuFocus", menuBlur: "menuBlur", menuKeydown: "menuKeydown" }, host: { classAttribute: "p-element" }, viewQueries: [{ propertyName: "sublistViewChild", first: true, predicate: ["sublist"], descendants: true, static: true }], ngImport: i0, template: `
125
+ <ul
126
+ #sublist
127
+ role="menu"
128
+ [ngClass]="{ 'p-submenu-list': !root, 'p-tieredmenu-root-list': root }"
129
+ [id]="menuId + '_list'"
130
+ [tabindex]="tabindex"
131
+ [attr.aria-label]="ariaLabel"
132
+ [attr.aria-labelledBy]="ariaLabelledBy"
133
+ [attr.aria-aria-activedescendant]="focusedItemId"
134
+ [attr.aria-orientation]="'vertical'"
135
+ [attr.data-pc-section]="'menu'"
136
+ (keydown)="menuKeydown.emit($event)"
137
+ (focus)="menuFocus.emit($event)"
138
+ (blur)="menuBlur.emit($event)"
139
+ >
140
+ <ng-template ngFor let-processedItem [ngForOf]="items" let-index="index">
141
+ <li
142
+ *ngIf="isItemVisible(processedItem) && getItemProp(processedItem, 'separator')"
143
+ [id]="getItemId(processedItem)"
144
+ [style]="getItemProp(processedItem, 'style')"
145
+ [ngClass]="getSeparatorItemClass(processedItem)"
146
+ role="separator"
147
+ [attr.data-pc-section]="'separator'"
148
+ ></li>
217
149
  <li
218
- *ngIf="!child.separator"
219
150
  #listItem
220
- [ngClass]="{ 'p-menuitem': true, 'p-menuitem-active': child === activeItem, 'p-hidden': child.visible === false }"
221
- [ngStyle]="child.style"
222
- [class]="child.styleClass"
151
+ *ngIf="isItemVisible(processedItem) && !getItemProp(processedItem, 'separator')"
152
+ role="menuitem"
153
+ [id]="getItemId(processedItem)"
154
+ [attr.data-pc-section]="'menuitem'"
155
+ [attr.data-p-highlight]="isItemActive(processedItem)"
156
+ [attr.data-p-focused]="isItemFocused(processedItem)"
157
+ [attr.data-p-disabled]="isItemDisabled(processedItem)"
158
+ [attr.aria-label]="getItemLabel(processedItem)"
159
+ [attr.aria-disabled]="isItemDisabled(processedItem) || undefined"
160
+ [attr.aria-haspopup]="isItemGroup(processedItem) && !getItemProp(processedItem, 'to') ? 'menu' : undefined"
161
+ [attr.aria-expanded]="isItemGroup(processedItem) ? isItemActive(processedItem) : undefined"
162
+ [attr.aria-level]="level + 1"
163
+ [attr.aria-setsize]="getAriaSetSize()"
164
+ [attr.aria-posinset]="getAriaPosInset(index)"
165
+ [ngStyle]="getItemProp(processedItem, 'style')"
166
+ [ngClass]="getItemClass(processedItem)"
167
+ [class]="getItemProp(processedItem, 'styleClass')"
223
168
  pTooltip
224
- [tooltipOptions]="child.tooltipOptions"
169
+ [tooltipOptions]="getItemProp(processedItem, 'tooltipOptions')"
225
170
  >
226
- <a
227
- *ngIf="!child.routerLink"
228
- (keydown)="onItemKeyDown($event, child)"
229
- [attr.href]="child.url"
230
- [attr.data-automationid]="child.automationId"
231
- [target]="child.target"
232
- [attr.title]="child.title"
233
- [attr.id]="child.id"
234
- (click)="onItemClick($event, child)"
235
- (mouseenter)="onItemMouseEnter($event, child)"
236
- [ngClass]="{ 'p-menuitem-link': true, 'p-disabled': child.disabled }"
237
- [attr.tabindex]="child.disabled ? null : '0'"
238
- [attr.aria-haspopup]="item.items != null"
239
- [attr.aria-expanded]="item === activeItem"
240
- pRipple
241
- >
242
- <span class="p-menuitem-icon" *ngIf="child.icon" [ngClass]="child.icon" [ngStyle]="child.iconStyle"></span>
243
- <span class="p-menuitem-text" *ngIf="child.escape !== false; else htmlLabel">{{ child.label }}</span>
244
- <ng-template #htmlLabel><span class="p-menuitem-text" [innerHTML]="child.label"></span></ng-template>
245
- <span class="p-menuitem-badge" *ngIf="child.badge" [ngClass]="child.badgeStyleClass">{{ child.badge }}</span>
246
- <ng-container *ngIf="child.items">
247
- <AngleRightIcon *ngIf="!tieredMenu.submenuIconTemplate" [styleClass]="'p-submenu-icon'" />
248
- <ng-template *ngTemplateOutlet="tieredMenu.submenuIconTemplate"></ng-template>
249
- </ng-container>
250
- </a>
251
- <a
252
- *ngIf="child.routerLink"
253
- (keydown)="onItemKeyDown($event, child)"
254
- [routerLink]="child.routerLink"
255
- [attr.data-automationid]="child.automationId"
256
- [queryParams]="child.queryParams"
257
- [routerLinkActive]="'p-menuitem-link-active'"
258
- [routerLinkActiveOptions]="child.routerLinkActiveOptions || { exact: false }"
259
- [target]="child.target"
260
- [attr.title]="child.title"
261
- [attr.id]="child.id"
262
- [attr.tabindex]="child.disabled ? null : '0'"
263
- role="menuitem"
264
- (click)="onItemClick($event, child)"
265
- (mouseenter)="onItemMouseEnter($event, child)"
266
- [ngClass]="{ 'p-menuitem-link': true, 'p-disabled': child.disabled }"
267
- [fragment]="child.fragment"
268
- [queryParamsHandling]="child.queryParamsHandling"
269
- [preserveFragment]="child.preserveFragment"
270
- [skipLocationChange]="child.skipLocationChange"
271
- [replaceUrl]="child.replaceUrl"
272
- [state]="child.state"
273
- pRipple
274
- >
275
- <span class="p-menuitem-icon" *ngIf="child.icon" [ngClass]="child.icon" [ngStyle]="child.iconStyle"></span>
276
- <span class="p-menuitem-text" *ngIf="child.escape !== false; else htmlRouteLabel">{{ child.label }}</span>
277
- <ng-template #htmlRouteLabel><span class="p-menuitem-text" [innerHTML]="child.label"></span></ng-template>
278
- <span class="p-menuitem-badge" *ngIf="child.badge" [ngClass]="child.badgeStyleClass">{{ child.badge }}</span>
279
- <ng-container *ngIf="child.items">
280
- <AngleRightIcon *ngIf="!tieredMenu.submenuIconTemplate" [styleClass]="'p-submenu-icon'" />
281
- <ng-template *ngTemplateOutlet="tieredMenu.submenuIconTemplate"></ng-template>
282
- </ng-container>
283
- </a>
171
+ <div [attr.data-pc-section]="'content'" class="p-menuitem-content" (click)="onItemClick($event, processedItem)" (mouseenter)="onItemMouseEnter({$event, processedItem})">
172
+ <a
173
+ *ngIf="!getItemProp(processedItem, 'routerLink')"
174
+ [attr.href]="getItemProp(processedItem, 'url')"
175
+ [attr.aria-hidden]="true"
176
+ [attr.data-automationid]="getItemProp(processedItem, 'automationId')"
177
+ [attr.data-pc-section]="'action'"
178
+ [target]="getItemProp(processedItem, 'target')"
179
+ [ngClass]="{ 'p-menuitem-link': true, 'p-disabled': getItemProp(processedItem, 'disabled') }"
180
+ [attr.tabindex]="-1"
181
+ pRipple
182
+ >
183
+ <span
184
+ *ngIf="getItemProp(processedItem, 'icon')"
185
+ class="p-menuitem-icon"
186
+ [ngClass]="getItemProp(processedItem, 'icon')"
187
+ [ngStyle]="getItemProp(processedItem, 'iconStyle')"
188
+ [attr.data-pc-section]="'icon'"
189
+ [attr.aria-hidden]="true"
190
+ [attr.tabindex]="-1"
191
+ >
192
+ </span>
193
+ <span *ngIf="getItemProp(processedItem, 'escape'); else htmlLabel" class="p-menuitem-text" [attr.data-pc-section]="'label'">
194
+ {{ getItemLabel(processedItem) }}
195
+ </span>
196
+ <ng-template #htmlLabel>
197
+ <span class="p-menuitem-text" [innerHTML]="getItemLabel(processedItem)" [attr.data-pc-section]="'label'"></span>
198
+ </ng-template>
199
+ <span class="p-menuitem-badge" *ngIf="getItemProp(processedItem, 'badge')" [ngClass]="getItemProp(processedItem, 'badgeStyleClass')">{{ child.badge }}</span>
200
+
201
+ <ng-container *ngIf="isItemGroup(processedItem)">
202
+ <AngleRightIcon *ngIf="!tieredMenu.submenuIconTemplate" [styleClass]="'p-submenu-icon'" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true" />
203
+ <ng-template *ngTemplateOutlet="tieredMenu.submenuIconTemplate" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true"></ng-template>
204
+ </ng-container>
205
+ </a>
206
+ <a
207
+ *ngIf="getItemProp(processedItem, 'routerLink')"
208
+ [routerLink]="getItemProp(processedItem, 'routerLink')"
209
+ [attr.data-automationid]="getItemProp(processedItem, 'automationId')"
210
+ [attr.tabindex]="-1"
211
+ [attr.aria-hidden]="true"
212
+ [attr.data-pc-section]="'action'"
213
+ [queryParams]="getItemProp(processedItem, 'queryParams')"
214
+ [routerLinkActive]="'p-menuitem-link-active'"
215
+ [routerLinkActiveOptions]="getItemProp(processedItem, 'routerLinkActiveOptions') || { exact: false }"
216
+ [target]="getItemProp(processedItem, 'target')"
217
+ [ngClass]="{ 'p-menuitem-link': true, 'p-disabled': getItemProp(processedItem, 'disabled') }"
218
+ [fragment]="getItemProp(processedItem, 'fragment')"
219
+ [queryParamsHandling]="getItemProp(processedItem, 'queryParamsHandling')"
220
+ [preserveFragment]="getItemProp(processedItem, 'preserveFragment')"
221
+ [skipLocationChange]="getItemProp(processedItem, 'skipLocationChange')"
222
+ [replaceUrl]="getItemProp(processedItem, 'replaceUrl')"
223
+ [state]="getItemProp(processedItem, 'state')"
224
+ pRipple
225
+ >
226
+ <span
227
+ *ngIf="getItemProp(processedItem, 'icon')"
228
+ class="p-menuitem-icon"
229
+ [ngClass]="getItemProp(processedItem, 'icon')"
230
+ [ngStyle]="getItemProp(processedItem, 'iconStyle')"
231
+ [attr.data-pc-section]="'icon'"
232
+ [attr.aria-hidden]="true"
233
+ [attr.tabindex]="-1"
234
+ >
235
+ </span>
236
+ <span *ngIf="getItemProp(processedItem, 'escape'); else htmlLabel" class="p-menuitem-text" [attr.data-pc-section]="'label'">
237
+ {{ getItemLabel(processedItem) }}
238
+ </span>
239
+ <ng-template #htmlLabel>
240
+ <span class="p-menuitem-text" [innerHTML]="getItemLabel(processedItem)" [attr.data-pc-section]="'label'"></span>
241
+ </ng-template>
242
+ <span class="p-menuitem-badge" *ngIf="getItemProp(processedItem, 'badge')" [ngClass]="getItemProp(processedItem, 'badgeStyleClass')">{{ child.badge }}</span>
243
+
244
+ <ng-container *ngIf="isItemGroup(processedItem)">
245
+ <AngleRightIcon *ngIf="!tieredMenu.submenuIconTemplate" [styleClass]="'p-submenu-icon'" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true" />
246
+ <ng-template *ngTemplateOutlet="tieredMenu.submenuIconTemplate" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true"></ng-template>
247
+ </ng-container>
248
+ </a>
249
+ </div>
250
+
284
251
  <p-tieredMenuSub
285
- (keydownItem)="onChildItemKeyDown($event)"
286
- [parentActive]="child === activeItem"
287
- [item]="child"
288
- *ngIf="child.items"
289
- [mobileActive]="mobileActive"
252
+ *ngIf="isItemVisible(processedItem) && isItemGroup(processedItem)"
253
+ [items]="processedItem.items"
290
254
  [autoDisplay]="autoDisplay"
291
- (leafClick)="onLeafClick()"
292
- [popup]="popup"
255
+ [menuId]="menuId"
256
+ [activeItemPath]="activeItemPath"
257
+ [focusedItemId]="focusedItemId"
258
+ [level]="level + 1"
259
+ (itemClick)="itemClick.emit($event)"
260
+ (itemMouseEnter)="onItemMouseEnter($event)"
293
261
  ></p-tieredMenuSub>
294
262
  </li>
295
263
  </ng-template>
296
264
  </ul>
297
- `, isInline: true, dependencies: [{ kind: "directive", type: i0.forwardRef(function () { return i1.NgClass; }), selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgForOf; }), selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgTemplateOutlet; }), selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgStyle; }), selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.RouterLink; }), selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.RouterLinkActive; }), selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "ariaCurrentWhenActive", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }, { kind: "directive", type: i0.forwardRef(function () { return i3.Ripple; }), selector: "[pRipple]" }, { kind: "directive", type: i0.forwardRef(function () { return i4.Tooltip; }), selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "component", type: i0.forwardRef(function () { return AngleRightIcon; }), selector: "AngleRightIcon" }, { kind: "component", type: i0.forwardRef(function () { return TieredMenuSub; }), selector: "p-tieredMenuSub", inputs: ["item", "root", "autoDisplay", "autoZIndex", "baseZIndex", "mobileActive", "popup", "parentActive"], outputs: ["leafClick", "keydownItem"] }], encapsulation: i0.ViewEncapsulation.None });
265
+ `, isInline: true, dependencies: [{ kind: "directive", type: i0.forwardRef(function () { return i1.NgClass; }), selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgForOf; }), selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgTemplateOutlet; }), selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i0.forwardRef(function () { return i1.NgStyle; }), selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.RouterLink; }), selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.RouterLinkActive; }), selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "ariaCurrentWhenActive", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }, { kind: "directive", type: i0.forwardRef(function () { return i3.Ripple; }), selector: "[pRipple]" }, { kind: "directive", type: i0.forwardRef(function () { return i4.Tooltip; }), selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "component", type: i0.forwardRef(function () { return AngleRightIcon; }), selector: "AngleRightIcon" }, { kind: "component", type: i0.forwardRef(function () { return TieredMenuSub; }), selector: "p-tieredMenuSub", inputs: ["items", "root", "autoDisplay", "autoZIndex", "baseZIndex", "popup", "menuId", "ariaLabel", "ariaLabelledBy", "level", "focusedItemId", "activeItemPath", "tabindex"], outputs: ["itemClick", "itemMouseEnter", "menuFocus", "menuBlur", "menuKeydown"] }], encapsulation: i0.ViewEncapsulation.None });
298
266
  }
299
267
  export { TieredMenuSub };
300
268
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: TieredMenuSub, decorators: [{
@@ -302,85 +270,142 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
302
270
  args: [{
303
271
  selector: 'p-tieredMenuSub',
304
272
  template: `
305
- <ul #sublist [ngClass]="{ 'p-submenu-list': !root }">
306
- <ng-template ngFor let-child [ngForOf]="root ? item : item?.items">
307
- <li *ngIf="child.separator" class="p-menu-separator" [ngClass]="{ 'p-hidden': child.visible === false }"></li>
273
+ <ul
274
+ #sublist
275
+ role="menu"
276
+ [ngClass]="{ 'p-submenu-list': !root, 'p-tieredmenu-root-list': root }"
277
+ [id]="menuId + '_list'"
278
+ [tabindex]="tabindex"
279
+ [attr.aria-label]="ariaLabel"
280
+ [attr.aria-labelledBy]="ariaLabelledBy"
281
+ [attr.aria-aria-activedescendant]="focusedItemId"
282
+ [attr.aria-orientation]="'vertical'"
283
+ [attr.data-pc-section]="'menu'"
284
+ (keydown)="menuKeydown.emit($event)"
285
+ (focus)="menuFocus.emit($event)"
286
+ (blur)="menuBlur.emit($event)"
287
+ >
288
+ <ng-template ngFor let-processedItem [ngForOf]="items" let-index="index">
289
+ <li
290
+ *ngIf="isItemVisible(processedItem) && getItemProp(processedItem, 'separator')"
291
+ [id]="getItemId(processedItem)"
292
+ [style]="getItemProp(processedItem, 'style')"
293
+ [ngClass]="getSeparatorItemClass(processedItem)"
294
+ role="separator"
295
+ [attr.data-pc-section]="'separator'"
296
+ ></li>
308
297
  <li
309
- *ngIf="!child.separator"
310
298
  #listItem
311
- [ngClass]="{ 'p-menuitem': true, 'p-menuitem-active': child === activeItem, 'p-hidden': child.visible === false }"
312
- [ngStyle]="child.style"
313
- [class]="child.styleClass"
299
+ *ngIf="isItemVisible(processedItem) && !getItemProp(processedItem, 'separator')"
300
+ role="menuitem"
301
+ [id]="getItemId(processedItem)"
302
+ [attr.data-pc-section]="'menuitem'"
303
+ [attr.data-p-highlight]="isItemActive(processedItem)"
304
+ [attr.data-p-focused]="isItemFocused(processedItem)"
305
+ [attr.data-p-disabled]="isItemDisabled(processedItem)"
306
+ [attr.aria-label]="getItemLabel(processedItem)"
307
+ [attr.aria-disabled]="isItemDisabled(processedItem) || undefined"
308
+ [attr.aria-haspopup]="isItemGroup(processedItem) && !getItemProp(processedItem, 'to') ? 'menu' : undefined"
309
+ [attr.aria-expanded]="isItemGroup(processedItem) ? isItemActive(processedItem) : undefined"
310
+ [attr.aria-level]="level + 1"
311
+ [attr.aria-setsize]="getAriaSetSize()"
312
+ [attr.aria-posinset]="getAriaPosInset(index)"
313
+ [ngStyle]="getItemProp(processedItem, 'style')"
314
+ [ngClass]="getItemClass(processedItem)"
315
+ [class]="getItemProp(processedItem, 'styleClass')"
314
316
  pTooltip
315
- [tooltipOptions]="child.tooltipOptions"
317
+ [tooltipOptions]="getItemProp(processedItem, 'tooltipOptions')"
316
318
  >
317
- <a
318
- *ngIf="!child.routerLink"
319
- (keydown)="onItemKeyDown($event, child)"
320
- [attr.href]="child.url"
321
- [attr.data-automationid]="child.automationId"
322
- [target]="child.target"
323
- [attr.title]="child.title"
324
- [attr.id]="child.id"
325
- (click)="onItemClick($event, child)"
326
- (mouseenter)="onItemMouseEnter($event, child)"
327
- [ngClass]="{ 'p-menuitem-link': true, 'p-disabled': child.disabled }"
328
- [attr.tabindex]="child.disabled ? null : '0'"
329
- [attr.aria-haspopup]="item.items != null"
330
- [attr.aria-expanded]="item === activeItem"
331
- pRipple
332
- >
333
- <span class="p-menuitem-icon" *ngIf="child.icon" [ngClass]="child.icon" [ngStyle]="child.iconStyle"></span>
334
- <span class="p-menuitem-text" *ngIf="child.escape !== false; else htmlLabel">{{ child.label }}</span>
335
- <ng-template #htmlLabel><span class="p-menuitem-text" [innerHTML]="child.label"></span></ng-template>
336
- <span class="p-menuitem-badge" *ngIf="child.badge" [ngClass]="child.badgeStyleClass">{{ child.badge }}</span>
337
- <ng-container *ngIf="child.items">
338
- <AngleRightIcon *ngIf="!tieredMenu.submenuIconTemplate" [styleClass]="'p-submenu-icon'" />
339
- <ng-template *ngTemplateOutlet="tieredMenu.submenuIconTemplate"></ng-template>
340
- </ng-container>
341
- </a>
342
- <a
343
- *ngIf="child.routerLink"
344
- (keydown)="onItemKeyDown($event, child)"
345
- [routerLink]="child.routerLink"
346
- [attr.data-automationid]="child.automationId"
347
- [queryParams]="child.queryParams"
348
- [routerLinkActive]="'p-menuitem-link-active'"
349
- [routerLinkActiveOptions]="child.routerLinkActiveOptions || { exact: false }"
350
- [target]="child.target"
351
- [attr.title]="child.title"
352
- [attr.id]="child.id"
353
- [attr.tabindex]="child.disabled ? null : '0'"
354
- role="menuitem"
355
- (click)="onItemClick($event, child)"
356
- (mouseenter)="onItemMouseEnter($event, child)"
357
- [ngClass]="{ 'p-menuitem-link': true, 'p-disabled': child.disabled }"
358
- [fragment]="child.fragment"
359
- [queryParamsHandling]="child.queryParamsHandling"
360
- [preserveFragment]="child.preserveFragment"
361
- [skipLocationChange]="child.skipLocationChange"
362
- [replaceUrl]="child.replaceUrl"
363
- [state]="child.state"
364
- pRipple
365
- >
366
- <span class="p-menuitem-icon" *ngIf="child.icon" [ngClass]="child.icon" [ngStyle]="child.iconStyle"></span>
367
- <span class="p-menuitem-text" *ngIf="child.escape !== false; else htmlRouteLabel">{{ child.label }}</span>
368
- <ng-template #htmlRouteLabel><span class="p-menuitem-text" [innerHTML]="child.label"></span></ng-template>
369
- <span class="p-menuitem-badge" *ngIf="child.badge" [ngClass]="child.badgeStyleClass">{{ child.badge }}</span>
370
- <ng-container *ngIf="child.items">
371
- <AngleRightIcon *ngIf="!tieredMenu.submenuIconTemplate" [styleClass]="'p-submenu-icon'" />
372
- <ng-template *ngTemplateOutlet="tieredMenu.submenuIconTemplate"></ng-template>
373
- </ng-container>
374
- </a>
319
+ <div [attr.data-pc-section]="'content'" class="p-menuitem-content" (click)="onItemClick($event, processedItem)" (mouseenter)="onItemMouseEnter({$event, processedItem})">
320
+ <a
321
+ *ngIf="!getItemProp(processedItem, 'routerLink')"
322
+ [attr.href]="getItemProp(processedItem, 'url')"
323
+ [attr.aria-hidden]="true"
324
+ [attr.data-automationid]="getItemProp(processedItem, 'automationId')"
325
+ [attr.data-pc-section]="'action'"
326
+ [target]="getItemProp(processedItem, 'target')"
327
+ [ngClass]="{ 'p-menuitem-link': true, 'p-disabled': getItemProp(processedItem, 'disabled') }"
328
+ [attr.tabindex]="-1"
329
+ pRipple
330
+ >
331
+ <span
332
+ *ngIf="getItemProp(processedItem, 'icon')"
333
+ class="p-menuitem-icon"
334
+ [ngClass]="getItemProp(processedItem, 'icon')"
335
+ [ngStyle]="getItemProp(processedItem, 'iconStyle')"
336
+ [attr.data-pc-section]="'icon'"
337
+ [attr.aria-hidden]="true"
338
+ [attr.tabindex]="-1"
339
+ >
340
+ </span>
341
+ <span *ngIf="getItemProp(processedItem, 'escape'); else htmlLabel" class="p-menuitem-text" [attr.data-pc-section]="'label'">
342
+ {{ getItemLabel(processedItem) }}
343
+ </span>
344
+ <ng-template #htmlLabel>
345
+ <span class="p-menuitem-text" [innerHTML]="getItemLabel(processedItem)" [attr.data-pc-section]="'label'"></span>
346
+ </ng-template>
347
+ <span class="p-menuitem-badge" *ngIf="getItemProp(processedItem, 'badge')" [ngClass]="getItemProp(processedItem, 'badgeStyleClass')">{{ child.badge }}</span>
348
+
349
+ <ng-container *ngIf="isItemGroup(processedItem)">
350
+ <AngleRightIcon *ngIf="!tieredMenu.submenuIconTemplate" [styleClass]="'p-submenu-icon'" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true" />
351
+ <ng-template *ngTemplateOutlet="tieredMenu.submenuIconTemplate" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true"></ng-template>
352
+ </ng-container>
353
+ </a>
354
+ <a
355
+ *ngIf="getItemProp(processedItem, 'routerLink')"
356
+ [routerLink]="getItemProp(processedItem, 'routerLink')"
357
+ [attr.data-automationid]="getItemProp(processedItem, 'automationId')"
358
+ [attr.tabindex]="-1"
359
+ [attr.aria-hidden]="true"
360
+ [attr.data-pc-section]="'action'"
361
+ [queryParams]="getItemProp(processedItem, 'queryParams')"
362
+ [routerLinkActive]="'p-menuitem-link-active'"
363
+ [routerLinkActiveOptions]="getItemProp(processedItem, 'routerLinkActiveOptions') || { exact: false }"
364
+ [target]="getItemProp(processedItem, 'target')"
365
+ [ngClass]="{ 'p-menuitem-link': true, 'p-disabled': getItemProp(processedItem, 'disabled') }"
366
+ [fragment]="getItemProp(processedItem, 'fragment')"
367
+ [queryParamsHandling]="getItemProp(processedItem, 'queryParamsHandling')"
368
+ [preserveFragment]="getItemProp(processedItem, 'preserveFragment')"
369
+ [skipLocationChange]="getItemProp(processedItem, 'skipLocationChange')"
370
+ [replaceUrl]="getItemProp(processedItem, 'replaceUrl')"
371
+ [state]="getItemProp(processedItem, 'state')"
372
+ pRipple
373
+ >
374
+ <span
375
+ *ngIf="getItemProp(processedItem, 'icon')"
376
+ class="p-menuitem-icon"
377
+ [ngClass]="getItemProp(processedItem, 'icon')"
378
+ [ngStyle]="getItemProp(processedItem, 'iconStyle')"
379
+ [attr.data-pc-section]="'icon'"
380
+ [attr.aria-hidden]="true"
381
+ [attr.tabindex]="-1"
382
+ >
383
+ </span>
384
+ <span *ngIf="getItemProp(processedItem, 'escape'); else htmlLabel" class="p-menuitem-text" [attr.data-pc-section]="'label'">
385
+ {{ getItemLabel(processedItem) }}
386
+ </span>
387
+ <ng-template #htmlLabel>
388
+ <span class="p-menuitem-text" [innerHTML]="getItemLabel(processedItem)" [attr.data-pc-section]="'label'"></span>
389
+ </ng-template>
390
+ <span class="p-menuitem-badge" *ngIf="getItemProp(processedItem, 'badge')" [ngClass]="getItemProp(processedItem, 'badgeStyleClass')">{{ child.badge }}</span>
391
+
392
+ <ng-container *ngIf="isItemGroup(processedItem)">
393
+ <AngleRightIcon *ngIf="!tieredMenu.submenuIconTemplate" [styleClass]="'p-submenu-icon'" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true" />
394
+ <ng-template *ngTemplateOutlet="tieredMenu.submenuIconTemplate" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true"></ng-template>
395
+ </ng-container>
396
+ </a>
397
+ </div>
398
+
375
399
  <p-tieredMenuSub
376
- (keydownItem)="onChildItemKeyDown($event)"
377
- [parentActive]="child === activeItem"
378
- [item]="child"
379
- *ngIf="child.items"
380
- [mobileActive]="mobileActive"
400
+ *ngIf="isItemVisible(processedItem) && isItemGroup(processedItem)"
401
+ [items]="processedItem.items"
381
402
  [autoDisplay]="autoDisplay"
382
- (leafClick)="onLeafClick()"
383
- [popup]="popup"
403
+ [menuId]="menuId"
404
+ [activeItemPath]="activeItemPath"
405
+ [focusedItemId]="focusedItemId"
406
+ [level]="level + 1"
407
+ (itemClick)="itemClick.emit($event)"
408
+ (itemMouseEnter)="onItemMouseEnter($event)"
384
409
  ></p-tieredMenuSub>
385
410
  </li>
386
411
  </ng-template>
@@ -394,7 +419,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
394
419
  }], ctorParameters: function () { return [{ type: Document, decorators: [{
395
420
  type: Inject,
396
421
  args: [DOCUMENT]
397
- }] }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }, { type: TieredMenu }]; }, propDecorators: { item: [{
422
+ }] }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }, { type: TieredMenu }]; }, propDecorators: { items: [{
398
423
  type: Input
399
424
  }], root: [{
400
425
  type: Input
@@ -404,19 +429,35 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
404
429
  type: Input
405
430
  }], baseZIndex: [{
406
431
  type: Input
407
- }], mobileActive: [{
408
- type: Input
409
432
  }], popup: [{
410
433
  type: Input
411
- }], parentActive: [{
434
+ }], menuId: [{
412
435
  type: Input
413
- }], sublistViewChild: [{
414
- type: ViewChild,
415
- args: ['sublist']
416
- }], leafClick: [{
436
+ }], ariaLabel: [{
437
+ type: Input
438
+ }], ariaLabelledBy: [{
439
+ type: Input
440
+ }], level: [{
441
+ type: Input
442
+ }], focusedItemId: [{
443
+ type: Input
444
+ }], activeItemPath: [{
445
+ type: Input
446
+ }], tabindex: [{
447
+ type: Input
448
+ }], itemClick: [{
449
+ type: Output
450
+ }], itemMouseEnter: [{
451
+ type: Output
452
+ }], menuFocus: [{
417
453
  type: Output
418
- }], keydownItem: [{
454
+ }], menuBlur: [{
419
455
  type: Output
456
+ }], menuKeydown: [{
457
+ type: Output
458
+ }], sublistViewChild: [{
459
+ type: ViewChild,
460
+ args: ['sublist', { static: true }]
420
461
  }] } });
421
462
  /**
422
463
  * TieredMenu displays submenus in nested overlays.
@@ -424,6 +465,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
424
465
  */
425
466
  class TieredMenu {
426
467
  document;
468
+ platformId;
427
469
  el;
428
470
  renderer;
429
471
  cd;
@@ -466,9 +508,10 @@ class TieredMenu {
466
508
  baseZIndex = 0;
467
509
  /**
468
510
  * Whether to show a root submenu on mouse over.
511
+ * @defaultValue true
469
512
  * @group Props
470
513
  */
471
- autoDisplay;
514
+ autoDisplay = true;
472
515
  /**
473
516
  * Transition options of the show animation.
474
517
  * @group Props
@@ -479,6 +522,31 @@ class TieredMenu {
479
522
  * @group Props
480
523
  */
481
524
  hideTransitionOptions = '.1s linear';
525
+ /**
526
+ * Current id state as a string.
527
+ * @group Props
528
+ */
529
+ id;
530
+ /**
531
+ * Defines a string value that labels an interactive element.
532
+ * @group Props
533
+ */
534
+ ariaLabel;
535
+ /**
536
+ * Identifier of the underlying input element.
537
+ * @group Props
538
+ */
539
+ ariaLabelledBy;
540
+ /**
541
+ * When present, it specifies that the component should be disabled.
542
+ * @group Props
543
+ */
544
+ disabled = false;
545
+ /**
546
+ * Index of the element in tabbing order.
547
+ * @group Props
548
+ */
549
+ tabindex = 0;
482
550
  /**
483
551
  * Callback to invoke when overlay menu is shown.
484
552
  * @group Emits
@@ -490,25 +558,63 @@ class TieredMenu {
490
558
  */
491
559
  onHide = new EventEmitter();
492
560
  templates;
561
+ rootmenu;
562
+ containerViewChild;
493
563
  submenuIconTemplate;
494
- parentActive;
495
564
  container;
496
- documentClickListener;
497
- documentResizeListener;
498
- preventDocumentDefault;
565
+ outsideClickListener;
566
+ resizeListener;
499
567
  scrollHandler;
500
568
  target;
569
+ relatedTarget;
501
570
  visible;
502
571
  relativeAlign;
503
572
  window;
504
- constructor(document, el, renderer, cd, config, overlayService) {
573
+ dirty = false;
574
+ focused = false;
575
+ activeItemPath = signal([]);
576
+ number = signal(0);
577
+ focusedItemInfo = signal({ index: -1, level: 0, parentKey: '' });
578
+ searchValue = '';
579
+ searchTimeout;
580
+ _processedItems;
581
+ get visibleItems() {
582
+ const processedItem = this.activeItemPath().find((p) => p.key === this.focusedItemInfo().parentKey);
583
+ return processedItem ? processedItem.items : this.processedItems;
584
+ }
585
+ get processedItems() {
586
+ if (!this._processedItems || !this._processedItems.length) {
587
+ this._processedItems = this.createProcessedItems(this.model || []);
588
+ }
589
+ return this._processedItems;
590
+ }
591
+ get focusedItemId() {
592
+ const focusedItemInfo = this.focusedItemInfo();
593
+ return focusedItemInfo.index !== -1 ? `${this.id}${ObjectUtils.isNotEmpty(focusedItemInfo.parentKey) ? '_' + focusedItemInfo.parentKey : ''}_${focusedItemInfo.index}` : null;
594
+ }
595
+ constructor(document, platformId, el, renderer, cd, config, overlayService) {
505
596
  this.document = document;
597
+ this.platformId = platformId;
506
598
  this.el = el;
507
599
  this.renderer = renderer;
508
600
  this.cd = cd;
509
601
  this.config = config;
510
602
  this.overlayService = overlayService;
511
603
  this.window = this.document.defaultView;
604
+ effect(() => {
605
+ const path = this.activeItemPath();
606
+ if (ObjectUtils.isNotEmpty(path)) {
607
+ this.bindOutsideClickListener();
608
+ this.bindResizeListener();
609
+ }
610
+ else {
611
+ this.unbindOutsideClickListener();
612
+ this.unbindResizeListener();
613
+ }
614
+ });
615
+ }
616
+ ngOnInit() {
617
+ this.id = this.id || UniqueComponentId();
512
618
  }
513
619
  ngAfterContentInit() {
514
620
  this.templates?.forEach((item) => {
@@ -519,30 +625,56 @@ class TieredMenu {
519
625
  }
520
626
  });
521
627
  }
522
- /**
523
- * Toggles the visibility of the popup menu.
524
- * @param {Event} event - Browser event.
525
- * @group Method
526
- */
527
- toggle(event) {
528
- if (this.visible)
529
- this.hide();
530
- else
531
- this.show(event);
532
- this.preventDocumentDefault = true;
628
+ createProcessedItems(items, level = 0, parent = {}, parentKey = '') {
629
+ const processedItems = [];
630
+ items &&
631
+ items.forEach((item, index) => {
632
+ const key = (parentKey !== '' ? parentKey + '_' : '') + index;
633
+ const newItem = {
634
+ item,
635
+ index,
636
+ level,
637
+ key,
638
+ parent,
639
+ parentKey
640
+ };
641
+ newItem['items'] = this.createProcessedItems(item.items, level + 1, newItem, key);
642
+ processedItems.push(newItem);
643
+ });
644
+ return processedItems;
533
645
  }
534
- /**
535
- * Displays the popup menu.
536
- * @param {Event} even - Browser event.
537
- * @group Method
538
- */
539
- show(event) {
540
- this.target = event.currentTarget;
541
- this.relativeAlign = event.relativeAlign;
542
- this.visible = true;
543
- this.parentActive = true;
544
- this.preventDocumentDefault = true;
545
- this.cd.markForCheck();
646
+ getItemProp(item, name) {
647
+ return item ? ObjectUtils.getItemValue(item[name]) : undefined;
648
+ }
649
+ getProccessedItemLabel(processedItem) {
650
+ return processedItem ? this.getItemLabel(processedItem.item) : undefined;
651
+ }
652
+ getItemLabel(item) {
653
+ return this.getItemProp(item, 'label');
654
+ }
655
+ isProcessedItemGroup(processedItem) {
656
+ return processedItem && ObjectUtils.isNotEmpty(processedItem.items);
657
+ }
658
+ isSelected(processedItem) {
659
+ return this.activeItemPath().some((p) => p.key === processedItem.key);
660
+ }
661
+ isValidSelectedItem(processedItem) {
662
+ return this.isValidItem(processedItem) && this.isSelected(processedItem);
663
+ }
664
+ isValidItem(processedItem) {
665
+ return !!processedItem && !this.isItemDisabled(processedItem.item) && !this.isItemSeparator(processedItem.item);
666
+ }
667
+ isItemDisabled(item) {
668
+ return this.getItemProp(item, 'disabled');
669
+ }
670
+ isItemSeparator(item) {
671
+ return this.getItemProp(item, 'separator');
672
+ }
673
+ isItemMatched(processedItem) {
674
+ return this.isValidItem(processedItem) && this.getProccessedItemLabel(processedItem).toLocaleLowerCase().startsWith(this.searchValue.toLocaleLowerCase());
675
+ }
676
+ isProccessedItemGroup(processedItem) {
677
+ return processedItem && ObjectUtils.isNotEmpty(processedItem.items);
546
678
  }
547
679
  onOverlayClick(event) {
548
680
  if (this.popup) {
@@ -551,7 +683,189 @@ class TieredMenu {
551
683
  target: this.el.nativeElement
552
684
  });
553
685
  }
554
- this.preventDocumentDefault = true;
686
+ }
687
+ onItemClick(event) {
688
+ const { originalEvent, processedItem } = event;
689
+ const grouped = this.isProcessedItemGroup(processedItem);
690
+ const root = ObjectUtils.isEmpty(processedItem.parent);
691
+ const selected = this.isSelected(processedItem);
692
+ if (selected) {
693
+ const { index, key, level, parentKey } = processedItem;
694
+ this.activeItemPath.set(this.activeItemPath().filter((p) => key !== p.key && key.startsWith(p.key)));
695
+ this.focusedItemInfo.set({ index, level, parentKey });
696
+ this.dirty = !root;
697
+ DomHandler.focus(this.rootmenu.sublistViewChild.nativeElement);
698
+ }
699
+ else {
700
+ if (grouped) {
701
+ this.onItemChange(event);
702
+ }
703
+ else {
704
+ const rootProcessedItem = root ? processedItem : this.activeItemPath().find((p) => p.parentKey === '');
705
+ this.hide(originalEvent);
706
+ this.changeFocusedItemIndex(originalEvent, rootProcessedItem ? rootProcessedItem.index : -1);
707
+ DomHandler.focus(this.rootmenu.sublistViewChild.nativeElement);
708
+ }
709
+ }
710
+ }
711
+ onItemMouseEnter(event) {
712
+ if (this.dirty) {
713
+ this.onItemChange(event);
714
+ }
715
+ }
716
+ onKeyDown(event) {
717
+ const metaKey = event.metaKey || event.ctrlKey;
718
+ switch (event.code) {
719
+ case 'ArrowDown':
720
+ this.onArrowDownKey(event);
721
+ break;
722
+ case 'ArrowUp':
723
+ this.onArrowUpKey(event);
724
+ break;
725
+ case 'ArrowLeft':
726
+ this.onArrowLeftKey(event);
727
+ break;
728
+ case 'ArrowRight':
729
+ this.onArrowRightKey(event);
730
+ break;
731
+ case 'Home':
732
+ this.onHomeKey(event);
733
+ break;
734
+ case 'End':
735
+ this.onEndKey(event);
736
+ break;
737
+ case 'Space':
738
+ this.onSpaceKey(event);
739
+ break;
740
+ case 'Enter':
741
+ this.onEnterKey(event);
742
+ break;
743
+ case 'Escape':
744
+ this.onEscapeKey(event);
745
+ break;
746
+ case 'Tab':
747
+ this.onTabKey(event);
748
+ break;
749
+ case 'PageDown':
750
+ case 'PageUp':
751
+ case 'Backspace':
752
+ case 'ShiftLeft':
753
+ case 'ShiftRight':
754
+ //NOOP
755
+ break;
756
+ default:
757
+ if (!metaKey && ObjectUtils.isPrintableCharacter(event.key)) {
758
+ this.searchItems(event, event.key);
759
+ }
760
+ break;
761
+ }
762
+ }
763
+ onArrowDownKey(event) {
764
+ const itemIndex = this.focusedItemInfo().index !== -1 ? this.findNextItemIndex(this.focusedItemInfo().index) : this.findFirstFocusedItemIndex();
765
+ this.changeFocusedItemIndex(event, itemIndex);
766
+ event.preventDefault();
767
+ }
768
+ onArrowRightKey(event) {
769
+ const processedItem = this.visibleItems[this.focusedItemInfo().index];
770
+ const grouped = this.isProccessedItemGroup(processedItem);
771
+ if (grouped) {
772
+ this.onItemChange({ originalEvent: event, processedItem });
773
+ this.focusedItemInfo.set({ index: -1, parentKey: processedItem.key });
774
+ this.searchValue = '';
775
+ this.onArrowDownKey(event);
776
+ }
777
+ event.preventDefault();
778
+ }
779
+ onArrowUpKey(event) {
780
+ if (event.altKey) {
781
+ if (this.focusedItemInfo().index !== -1) {
782
+ const processedItem = this.visibleItems[this.focusedItemInfo().index];
783
+ const grouped = this.isProccessedItemGroup(processedItem);
784
+ !grouped && this.onItemChange({ originalEvent: event, processedItem });
785
+ }
786
+ this.popup && this.hide(event, true);
787
+ event.preventDefault();
788
+ }
789
+ else {
790
+ const itemIndex = this.focusedItemInfo().index !== -1 ? this.findPrevItemIndex(this.focusedItemInfo().index) : this.findLastFocusedItemIndex();
791
+ this.changeFocusedItemIndex(event, itemIndex);
792
+ event.preventDefault();
793
+ }
794
+ }
795
+ onArrowLeftKey(event) {
796
+ const processedItem = this.visibleItems[this.focusedItemInfo().index];
797
+ const parentItem = this.activeItemPath().find((p) => p.key === processedItem.parentKey);
798
+ const root = ObjectUtils.isEmpty(processedItem.parent);
799
+ if (!root) {
800
+ this.focusedItemInfo.set({ index: -1, parentKey: parentItem ? parentItem.parentKey : '' });
801
+ this.searchValue = '';
802
+ this.onArrowDownKey(event);
803
+ }
804
+ const activeItemPath = this.activeItemPath().filter((p) => p.parentKey !== this.focusedItemInfo().parentKey);
805
+ this.activeItemPath.set(activeItemPath);
806
+ event.preventDefault();
807
+ }
808
+ onHomeKey(event) {
809
+ this.changeFocusedItemIndex(event, this.findFirstItemIndex());
810
+ event.preventDefault();
811
+ }
812
+ onEndKey(event) {
813
+ this.changeFocusedItemIndex(event, this.findLastItemIndex());
814
+ event.preventDefault();
815
+ }
816
+ onSpaceKey(event) {
817
+ this.onEnterKey(event);
818
+ }
819
+ onEscapeKey(event) {
820
+ this.hide(event, true);
821
+ this.focusedItemInfo().index = this.findFirstFocusedItemIndex();
822
+ event.preventDefault();
823
+ }
824
+ onTabKey(event) {
825
+ if (this.focusedItemInfo().index !== -1) {
826
+ const processedItem = this.visibleItems[this.focusedItemInfo().index];
827
+ const grouped = this.isProccessedItemGroup(processedItem);
828
+ !grouped && this.onItemChange({ originalEvent: event, processedItem });
829
+ }
830
+ this.hide();
831
+ }
832
+ onEnterKey(event) {
833
+ if (this.focusedItemInfo().index !== -1) {
834
+ const element = DomHandler.findSingle(this.rootmenu.el.nativeElement, `li[id="${`${this.focusedItemId}`}"]`);
835
+ const anchorElement = element && DomHandler.findSingle(element, 'a[data-pc-section="action"]');
836
+ anchorElement ? anchorElement.click() : element && element.click();
837
+ const processedItem = this.visibleItems[this.focusedItemInfo().index];
838
+ if (!this.popup) {
839
+ const processedItem = this.visibleItems[this.focusedItemInfo().index];
840
+ const grouped = this.isProccessedItemGroup(processedItem);
841
+ !grouped && (this.focusedItemInfo().index = this.findFirstFocusedItemIndex());
842
+ }
843
+ }
844
+ event.preventDefault();
845
+ }
846
+ onItemChange(event) {
847
+ const { processedItem, isFocus } = event;
848
+ if (ObjectUtils.isEmpty(processedItem))
849
+ return;
850
+ const { index, key, level, parentKey, items } = processedItem;
851
+ const grouped = ObjectUtils.isNotEmpty(items);
852
+ const activeItemPath = this.activeItemPath().filter((p) => p.parentKey !== parentKey && p.parentKey !== key);
853
+ grouped && activeItemPath.push(processedItem);
854
+ this.focusedItemInfo.set({ index, level, parentKey });
855
+ this.activeItemPath.set(activeItemPath);
856
+ grouped && (this.dirty = true);
857
+ isFocus && DomHandler.focus(this.rootmenu.sublistViewChild.nativeElement);
858
+ }
859
+ onMenuFocus(event) {
860
+ this.focused = true;
861
+ const focusedItemInfo = this.focusedItemInfo().index !== -1 ? this.focusedItemInfo() : { index: this.findFirstFocusedItemIndex(), level: 0, parentKey: '' };
862
+ this.focusedItemInfo.set(focusedItemInfo);
863
+ }
864
+ onMenuBlur(event) {
865
+ this.focused = false;
866
+ this.focusedItemInfo.set({ index: -1, level: 0, parentKey: '' });
867
+ this.searchValue = '';
868
+ this.dirty = false;
555
869
  }
556
870
  onOverlayAnimationStart(event) {
557
871
  switch (event.toState) {
@@ -562,9 +876,11 @@ class TieredMenu {
562
876
  this.onShow.emit({});
563
877
  this.appendOverlay();
564
878
  this.alignOverlay();
565
- this.bindDocumentClickListener();
566
- this.bindDocumentResizeListener();
879
+ this.bindOutsideClickListener();
880
+ this.bindResizeListener();
567
881
  this.bindScrollListener();
882
+ DomHandler.focus(this.rootmenu.sublistViewChild.nativeElement);
883
+ this.scrollInView();
568
884
  }
569
885
  break;
570
886
  case 'void':
@@ -608,56 +924,115 @@ class TieredMenu {
608
924
  * Hides the popup menu.
609
925
  * @group Method
610
926
  */
611
- hide() {
612
- this.visible = false;
613
- this.relativeAlign = false;
614
- this.parentActive = false;
615
- this.cd.markForCheck();
616
- }
617
- onWindowResize() {
618
- if (this.visible && !DomHandler.isTouchDevice()) {
619
- this.hide();
927
+ hide(event, isFocus) {
928
+ if (this.popup) {
929
+ this.onHide.emit({});
930
+ this.visible = false;
620
931
  }
932
+ this.activeItemPath.set([]);
933
+ this.focusedItemInfo.set({ index: -1, level: 0, parentKey: '' });
934
+ isFocus && DomHandler.focus(this.relatedTarget || this.target || this.rootmenu.sublistViewChild.nativeElement);
935
+ this.dirty = false;
936
+ }
937
+ /**
938
+ * Toggles the visibility of the popup menu.
939
+ * @param {Event} event - Browser event.
940
+ * @group Method
941
+ */
942
+ toggle(event) {
943
+ this.visible ? this.hide(event, true) : this.show(event);
621
944
  }
622
- onLeafClick() {
945
+ /**
946
+ * Displays the popup menu.
947
+ * @param {Event} even - Browser event.
948
+ * @group Method
949
+ */
950
+ show(event, isFocus) {
623
951
  if (this.popup) {
624
- this.hide();
952
+ this.visible = true;
953
+ this.target = this.target || event.currentTarget;
954
+ this.relatedTarget = event.relatedTarget || null;
625
955
  }
626
- this.unbindDocumentClickListener();
627
- }
628
- bindDocumentClickListener() {
629
- if (!this.documentClickListener) {
630
- const documentTarget = this.el ? this.el.nativeElement.ownerDocument : 'document';
631
- this.documentClickListener = this.renderer.listen(documentTarget, 'click', () => {
632
- if (!this.preventDocumentDefault && this.popup) {
633
- this.hide();
634
- }
635
- this.preventDocumentDefault = false;
636
- });
956
+ this.focusedItemInfo.set({ index: this.findFirstFocusedItemIndex(), level: 0, parentKey: '' });
957
+ if (!this.popup) {
958
+ isFocus && DomHandler.focus(this.rootmenu.sublistViewChild.nativeElement);
637
959
  }
960
+ this.cd.markForCheck();
638
961
  }
639
- unbindDocumentClickListener() {
640
- if (this.documentClickListener) {
641
- this.documentClickListener();
642
- this.documentClickListener = null;
962
+ searchItems(event, char) {
963
+ this.searchValue = (this.searchValue || '') + char;
964
+ let itemIndex = -1;
965
+ let matched = false;
966
+ if (this.focusedItemInfo().index !== -1) {
967
+ itemIndex = this.visibleItems.slice(this.focusedItemInfo().index).findIndex((processedItem) => this.isItemMatched(processedItem));
968
+ itemIndex = itemIndex === -1 ? this.visibleItems.slice(0, this.focusedItemInfo().index).findIndex((processedItem) => this.isItemMatched(processedItem)) : itemIndex + this.focusedItemInfo().index;
969
+ }
970
+ else {
971
+ itemIndex = this.visibleItems.findIndex((processedItem) => this.isItemMatched(processedItem));
972
+ }
973
+ if (itemIndex !== -1) {
974
+ matched = true;
975
+ }
976
+ if (itemIndex === -1 && this.focusedItemInfo().index === -1) {
977
+ itemIndex = this.findFirstFocusedItemIndex();
978
+ }
979
+ if (itemIndex !== -1) {
980
+ this.changeFocusedItemIndex(event, itemIndex);
643
981
  }
982
+ if (this.searchTimeout) {
983
+ clearTimeout(this.searchTimeout);
984
+ }
985
+ this.searchTimeout = setTimeout(() => {
986
+ this.searchValue = '';
987
+ this.searchTimeout = null;
988
+ }, 500);
989
+ return matched;
990
+ }
991
+ findLastFocusedItemIndex() {
992
+ const selectedIndex = this.findSelectedItemIndex();
993
+ return selectedIndex < 0 ? this.findLastItemIndex() : selectedIndex;
994
+ }
995
+ findLastItemIndex() {
996
+ return ObjectUtils.findLastIndex(this.visibleItems, (processedItem) => this.isValidItem(processedItem));
997
+ }
998
+ findPrevItemIndex(index) {
999
+ const matchedItemIndex = index > 0 ? ObjectUtils.findLastIndex(this.visibleItems.slice(0, index), (processedItem) => this.isValidItem(processedItem)) : -1;
1000
+ return matchedItemIndex > -1 ? matchedItemIndex : index;
1001
+ }
1002
+ findNextItemIndex(index) {
1003
+ const matchedItemIndex = index < this.visibleItems.length - 1 ? this.visibleItems.slice(index + 1).findIndex((processedItem) => this.isValidItem(processedItem)) : -1;
1004
+ return matchedItemIndex > -1 ? matchedItemIndex + index + 1 : index;
1005
+ }
1006
+ findFirstFocusedItemIndex() {
1007
+ const selectedIndex = this.findSelectedItemIndex();
1008
+ return selectedIndex < 0 ? this.findFirstItemIndex() : selectedIndex;
1009
+ }
1010
+ findFirstItemIndex() {
1011
+ return this.visibleItems.findIndex((processedItem) => this.isValidItem(processedItem));
1012
+ }
1013
+ findSelectedItemIndex() {
1014
+ return this.visibleItems.findIndex((processedItem) => this.isValidSelectedItem(processedItem));
644
1015
  }
645
- bindDocumentResizeListener() {
646
- if (!this.documentResizeListener) {
647
- this.documentResizeListener = this.renderer.listen(this.window, 'resize', this.onWindowResize.bind(this));
1016
+ changeFocusedItemIndex(event, index) {
1017
+ if (this.focusedItemInfo().index !== index) {
1018
+ this.focusedItemInfo.mutate((value) => {
1019
+ value.index = index;
1020
+ });
1021
+ this.scrollInView();
648
1022
  }
649
1023
  }
650
- unbindDocumentResizeListener() {
651
- if (this.documentResizeListener) {
652
- this.documentResizeListener();
653
- this.documentResizeListener = null;
1024
+ scrollInView(index = -1) {
1025
+ const id = index !== -1 ? `${this.id}_${index}` : this.focusedItemId;
1026
+ const element = DomHandler.findSingle(this.rootmenu.el.nativeElement, `li[id="${id}"]`);
1027
+ if (element) {
1028
+ element.scrollIntoView && element.scrollIntoView({ block: 'nearest', inline: 'start' });
654
1029
  }
655
1030
  }
656
1031
  bindScrollListener() {
657
1032
  if (!this.scrollHandler) {
658
- this.scrollHandler = new ConnectedOverlayScrollHandler(this.target, () => {
1033
+ this.scrollHandler = new ConnectedOverlayScrollHandler(this.target, (event) => {
659
1034
  if (this.visible) {
660
- this.hide();
1035
+ this.hide(event, true);
661
1036
  }
662
1037
  });
663
1038
  }
@@ -666,13 +1041,49 @@ class TieredMenu {
666
1041
  unbindScrollListener() {
667
1042
  if (this.scrollHandler) {
668
1043
  this.scrollHandler.unbindScrollListener();
1044
+ this.scrollHandler = null;
1045
+ }
1046
+ }
1047
+ bindResizeListener() {
1048
+ if (isPlatformBrowser(this.platformId)) {
1049
+ if (!this.resizeListener) {
1050
+ this.resizeListener = this.renderer.listen(this.document.defaultView, 'resize', (event) => {
1051
+ if (!DomHandler.isTouchDevice()) {
1052
+ this.hide(event, true);
1053
+ }
1054
+ });
1055
+ }
1056
+ }
1057
+ }
1058
+ bindOutsideClickListener() {
1059
+ if (isPlatformBrowser(this.platformId)) {
1060
+ if (!this.outsideClickListener) {
1061
+ this.outsideClickListener = this.renderer.listen(this.document, 'click', (event) => {
1062
+ const isOutsideContainer = this.containerViewChild && !this.containerViewChild.nativeElement.contains(event.target);
1063
+ const isOutsideTarget = this.popup ? !(this.target && (this.target === event.target || this.target.contains(event.target))) : true;
1064
+ if (isOutsideContainer && isOutsideTarget) {
1065
+ this.hide();
1066
+ }
1067
+ });
1068
+ }
1069
+ }
1070
+ }
1071
+ unbindOutsideClickListener() {
1072
+ if (this.outsideClickListener) {
1073
+ this.outsideClickListener();
1074
+ this.outsideClickListener = null;
1075
+ }
1076
+ }
1077
+ unbindResizeListener() {
1078
+ if (this.resizeListener) {
1079
+ this.resizeListener();
1080
+ this.resizeListener = null;
669
1081
  }
670
1082
  }
671
1083
  onOverlayHide() {
672
- this.unbindDocumentClickListener();
673
- this.unbindDocumentResizeListener();
1084
+ this.unbindOutsideClickListener();
1085
+ this.unbindResizeListener();
674
1086
  this.unbindScrollListener();
675
- this.preventDocumentDefault = false;
676
1087
  if (!this.cd.destroyed) {
677
1088
  this.target = null;
678
1089
  }
@@ -690,9 +1101,13 @@ class TieredMenu {
690
1101
  this.onOverlayHide();
691
1102
  }
692
1103
  }
693
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: TieredMenu, deps: [{ token: DOCUMENT }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }, { token: i5.PrimeNGConfig }, { token: i5.OverlayService }], target: i0.ɵɵFactoryTarget.Component });
694
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: TieredMenu, selector: "p-tieredMenu", inputs: { model: "model", popup: "popup", style: "style", styleClass: "styleClass", appendTo: "appendTo", autoZIndex: "autoZIndex", baseZIndex: "baseZIndex", autoDisplay: "autoDisplay", showTransitionOptions: "showTransitionOptions", hideTransitionOptions: "hideTransitionOptions" }, outputs: { onShow: "onShow", onHide: "onHide" }, host: { classAttribute: "p-element" }, queries: [{ propertyName: "templates", predicate: PrimeTemplate }], ngImport: i0, template: `
1104
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: TieredMenu, deps: [{ token: DOCUMENT }, { token: PLATFORM_ID }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }, { token: i5.PrimeNGConfig }, { token: i5.OverlayService }], target: i0.ɵɵFactoryTarget.Component });
1105
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: TieredMenu, selector: "p-tieredMenu", inputs: { model: "model", popup: "popup", style: "style", styleClass: "styleClass", appendTo: "appendTo", autoZIndex: "autoZIndex", baseZIndex: "baseZIndex", autoDisplay: "autoDisplay", showTransitionOptions: "showTransitionOptions", hideTransitionOptions: "hideTransitionOptions", id: "id", ariaLabel: "ariaLabel", ariaLabelledBy: "ariaLabelledBy", disabled: "disabled", tabindex: "tabindex" }, outputs: { onShow: "onShow", onHide: "onHide" }, host: { classAttribute: "p-element" }, queries: [{ propertyName: "templates", predicate: PrimeTemplate }], viewQueries: [{ propertyName: "rootmenu", first: true, predicate: ["rootmenu"], descendants: true }, { propertyName: "containerViewChild", first: true, predicate: ["container"], descendants: true }], ngImport: i0, template: `
695
1106
  <div
1107
+ #container
1108
+ [attr.data-pc-section]="'root'"
1109
+ [attr.data-pc-name]="'tieredmenu'"
1110
+ [id]="id"
696
1111
  [ngClass]="{ 'p-tieredmenu p-component': true, 'p-tieredmenu-overlay': popup }"
697
1112
  [class]="styleClass"
698
1113
  [ngStyle]="style"
@@ -703,15 +1118,38 @@ class TieredMenu {
703
1118
  (@overlayAnimation.done)="onOverlayAnimationEnd($event)"
704
1119
  *ngIf="!popup || visible"
705
1120
  >
706
- <p-tieredMenuSub [item]="model" root="root" [parentActive]="parentActive" [baseZIndex]="baseZIndex" [autoZIndex]="autoZIndex" (leafClick)="onLeafClick()" [autoDisplay]="autoDisplay" [popup]="popup"></p-tieredMenuSub>
1121
+ <p-tieredMenuSub
1122
+ #rootmenu
1123
+ [root]="true"
1124
+ [items]="processedItems"
1125
+ [menuId]="id"
1126
+ [tabindex]="!disabled ? tabindex : -1"
1127
+ [ariaLabel]="ariaLabel"
1128
+ [ariaLabelledBy]="ariaLabelledBy"
1129
+ [baseZIndex]="baseZIndex"
1130
+ [autoZIndex]="autoZIndex"
1131
+ [autoDisplay]="autoDisplay"
1132
+ [popup]="popup"
1133
+ [focusedItemId]="focused ? focusedItemId : undefined"
1134
+ [activeItemPath]="activeItemPath()"
1135
+ (itemClick)="onItemClick($event)"
1136
+ (menuFocus)="onMenuFocus($event)"
1137
+ (menuBlur)="onMenuBlur($event)"
1138
+ (menuKeydown)="onKeyDown($event)"
1139
+ (itemMouseEnter)="onItemMouseEnter($event)"
1140
+ ></p-tieredMenuSub>
707
1141
  </div>
708
- `, isInline: true, styles: [".p-tieredmenu-overlay{position:absolute;top:0;left:0}.p-tieredmenu ul{margin:0;padding:0;list-style:none}.p-tieredmenu .p-submenu-list{position:absolute;min-width:100%;z-index:1;display:none}.p-tieredmenu .p-menuitem-link{cursor:pointer;display:flex;align-items:center;text-decoration:none;overflow:hidden;position:relative}.p-tieredmenu .p-menuitem-text{line-height:1}.p-tieredmenu .p-menuitem{position:relative}.p-tieredmenu .p-menuitem-link .p-submenu-icon:not(svg){margin-left:auto}.p-tieredmenu .p-menuitem-link .p-icon-wrapper{margin-left:auto}.p-tieredmenu .p-menuitem-active>p-tieredmenusub>.p-submenu-list{display:block;left:100%;top:0}.p-tieredmenu .p-menuitem-active>p-tieredmenusub>.p-submenu-list.p-submenu-list-flipped{left:-100%}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: TieredMenuSub, selector: "p-tieredMenuSub", inputs: ["item", "root", "autoDisplay", "autoZIndex", "baseZIndex", "mobileActive", "popup", "parentActive"], outputs: ["leafClick", "keydownItem"] }], animations: [trigger('overlayAnimation', [transition(':enter', [style({ opacity: 0, transform: 'scaleY(0.8)' }), animate('{{showTransitionParams}}')]), transition(':leave', [animate('{{hideTransitionParams}}', style({ opacity: 0 }))])])], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
1142
+ `, isInline: true, styles: [".p-tieredmenu-overlay{position:absolute;top:0;left:0}.p-tieredmenu ul{margin:0;padding:0;list-style:none}.p-tieredmenu .p-submenu-list{position:absolute;min-width:100%;z-index:1;display:none}.p-tieredmenu .p-menuitem-link{cursor:pointer;display:flex;align-items:center;text-decoration:none;overflow:hidden;position:relative}.p-tieredmenu .p-menuitem-text{line-height:1}.p-tieredmenu .p-menuitem{position:relative}.p-tieredmenu .p-menuitem-link .p-submenu-icon:not(svg){margin-left:auto}.p-tieredmenu .p-menuitem-link .p-icon-wrapper{margin-left:auto}.p-tieredmenu .p-menuitem-active>p-tieredmenusub>.p-submenu-list{display:block;left:100%;top:0}.p-tieredmenu .p-menuitem-active>p-tieredmenusub>.p-submenu-list.p-submenu-list-flipped{left:-100%}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: TieredMenuSub, selector: "p-tieredMenuSub", inputs: ["items", "root", "autoDisplay", "autoZIndex", "baseZIndex", "popup", "menuId", "ariaLabel", "ariaLabelledBy", "level", "focusedItemId", "activeItemPath", "tabindex"], outputs: ["itemClick", "itemMouseEnter", "menuFocus", "menuBlur", "menuKeydown"] }], animations: [trigger('overlayAnimation', [transition(':enter', [style({ opacity: 0, transform: 'scaleY(0.8)' }), animate('{{showTransitionParams}}')]), transition(':leave', [animate('{{hideTransitionParams}}', style({ opacity: 0 }))])])], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
709
1143
  }
710
1144
  export { TieredMenu };
711
1145
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: TieredMenu, decorators: [{
712
1146
  type: Component,
713
1147
  args: [{ selector: 'p-tieredMenu', template: `
714
1148
  <div
1149
+ #container
1150
+ [attr.data-pc-section]="'root'"
1151
+ [attr.data-pc-name]="'tieredmenu'"
1152
+ [id]="id"
715
1153
  [ngClass]="{ 'p-tieredmenu p-component': true, 'p-tieredmenu-overlay': popup }"
716
1154
  [class]="styleClass"
717
1155
  [ngStyle]="style"
@@ -722,7 +1160,26 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
722
1160
  (@overlayAnimation.done)="onOverlayAnimationEnd($event)"
723
1161
  *ngIf="!popup || visible"
724
1162
  >
725
- <p-tieredMenuSub [item]="model" root="root" [parentActive]="parentActive" [baseZIndex]="baseZIndex" [autoZIndex]="autoZIndex" (leafClick)="onLeafClick()" [autoDisplay]="autoDisplay" [popup]="popup"></p-tieredMenuSub>
1163
+ <p-tieredMenuSub
1164
+ #rootmenu
1165
+ [root]="true"
1166
+ [items]="processedItems"
1167
+ [menuId]="id"
1168
+ [tabindex]="!disabled ? tabindex : -1"
1169
+ [ariaLabel]="ariaLabel"
1170
+ [ariaLabelledBy]="ariaLabelledBy"
1171
+ [baseZIndex]="baseZIndex"
1172
+ [autoZIndex]="autoZIndex"
1173
+ [autoDisplay]="autoDisplay"
1174
+ [popup]="popup"
1175
+ [focusedItemId]="focused ? focusedItemId : undefined"
1176
+ [activeItemPath]="activeItemPath()"
1177
+ (itemClick)="onItemClick($event)"
1178
+ (menuFocus)="onMenuFocus($event)"
1179
+ (menuBlur)="onMenuBlur($event)"
1180
+ (menuKeydown)="onKeyDown($event)"
1181
+ (itemMouseEnter)="onItemMouseEnter($event)"
1182
+ ></p-tieredMenuSub>
726
1183
  </div>
727
1184
  `, animations: [trigger('overlayAnimation', [transition(':enter', [style({ opacity: 0, transform: 'scaleY(0.8)' }), animate('{{showTransitionParams}}')]), transition(':leave', [animate('{{hideTransitionParams}}', style({ opacity: 0 }))])])], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: {
728
1185
  class: 'p-element'
@@ -730,6 +1187,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
730
1187
  }], ctorParameters: function () { return [{ type: Document, decorators: [{
731
1188
  type: Inject,
732
1189
  args: [DOCUMENT]
1190
+ }] }, { type: undefined, decorators: [{
1191
+ type: Inject,
1192
+ args: [PLATFORM_ID]
733
1193
  }] }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }, { type: i5.PrimeNGConfig }, { type: i5.OverlayService }]; }, propDecorators: { model: [{
734
1194
  type: Input
735
1195
  }], popup: [{
@@ -750,6 +1210,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
750
1210
  type: Input
751
1211
  }], hideTransitionOptions: [{
752
1212
  type: Input
1213
+ }], id: [{
1214
+ type: Input
1215
+ }], ariaLabel: [{
1216
+ type: Input
1217
+ }], ariaLabelledBy: [{
1218
+ type: Input
1219
+ }], disabled: [{
1220
+ type: Input
1221
+ }], tabindex: [{
1222
+ type: Input
753
1223
  }], onShow: [{
754
1224
  type: Output
755
1225
  }], onHide: [{
@@ -757,6 +1227,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
757
1227
  }], templates: [{
758
1228
  type: ContentChildren,
759
1229
  args: [PrimeTemplate]
1230
+ }], rootmenu: [{
1231
+ type: ViewChild,
1232
+ args: ['rootmenu']
1233
+ }], containerViewChild: [{
1234
+ type: ViewChild,
1235
+ args: ['container']
760
1236
  }] } });
761
1237
  class TieredMenuModule {
762
1238
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: TieredMenuModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
@@ -772,4 +1248,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
772
1248
  declarations: [TieredMenu, TieredMenuSub]
773
1249
  }]
774
1250
  }] });
775
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tieredmenu.js","sourceRoot":"","sources":["../../../src/app/components/tieredmenu/tieredmenu.ts"],"names":[],"mappings":"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","sourcesContent":["import { AnimationEvent, animate, style, transition, trigger } from '@angular/animations';\nimport { CommonModule, DOCUMENT } from '@angular/common';\nimport {\n    AfterContentInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    Inject,\n    Input,\n    NgModule,\n    OnDestroy,\n    Output,\n    QueryList,\n    Renderer2,\n    TemplateRef,\n    ViewChild,\n    ViewEncapsulation,\n    ViewRef\n} from '@angular/core';\nimport { RouterModule } from '@angular/router';\nimport { MenuItem, OverlayService, PrimeNGConfig, PrimeTemplate, SharedModule } from 'primeng/api';\nimport { ConnectedOverlayScrollHandler, DomHandler } from 'primeng/dom';\nimport { AngleRightIcon } from 'primeng/icons/angleright';\nimport { RippleModule } from 'primeng/ripple';\nimport { TooltipModule } from 'primeng/tooltip';\nimport { ZIndexUtils } from 'primeng/utils';\nimport { Nullable, VoidListener } from 'primeng/ts-helpers';\n\n@Component({\n    selector: 'p-tieredMenuSub',\n    template: `\n        <ul #sublist [ngClass]=\"{ 'p-submenu-list': !root }\">\n            <ng-template ngFor let-child [ngForOf]=\"root ? item : item?.items\">\n                <li *ngIf=\"child.separator\" class=\"p-menu-separator\" [ngClass]=\"{ 'p-hidden': child.visible === false }\"></li>\n                <li\n                    *ngIf=\"!child.separator\"\n                    #listItem\n                    [ngClass]=\"{ 'p-menuitem': true, 'p-menuitem-active': child === activeItem, 'p-hidden': child.visible === false }\"\n                    [ngStyle]=\"child.style\"\n                    [class]=\"child.styleClass\"\n                    pTooltip\n                    [tooltipOptions]=\"child.tooltipOptions\"\n                >\n                    <a\n                        *ngIf=\"!child.routerLink\"\n                        (keydown)=\"onItemKeyDown($event, child)\"\n                        [attr.href]=\"child.url\"\n                        [attr.data-automationid]=\"child.automationId\"\n                        [target]=\"child.target\"\n                        [attr.title]=\"child.title\"\n                        [attr.id]=\"child.id\"\n                        (click)=\"onItemClick($event, child)\"\n                        (mouseenter)=\"onItemMouseEnter($event, child)\"\n                        [ngClass]=\"{ 'p-menuitem-link': true, 'p-disabled': child.disabled }\"\n                        [attr.tabindex]=\"child.disabled ? null : '0'\"\n                        [attr.aria-haspopup]=\"item.items != null\"\n                        [attr.aria-expanded]=\"item === activeItem\"\n                        pRipple\n                    >\n                        <span class=\"p-menuitem-icon\" *ngIf=\"child.icon\" [ngClass]=\"child.icon\" [ngStyle]=\"child.iconStyle\"></span>\n                        <span class=\"p-menuitem-text\" *ngIf=\"child.escape !== false; else htmlLabel\">{{ child.label }}</span>\n                        <ng-template #htmlLabel><span class=\"p-menuitem-text\" [innerHTML]=\"child.label\"></span></ng-template>\n                        <span class=\"p-menuitem-badge\" *ngIf=\"child.badge\" [ngClass]=\"child.badgeStyleClass\">{{ child.badge }}</span>\n                        <ng-container *ngIf=\"child.items\">\n                            <AngleRightIcon *ngIf=\"!tieredMenu.submenuIconTemplate\" [styleClass]=\"'p-submenu-icon'\" />\n                            <ng-template *ngTemplateOutlet=\"tieredMenu.submenuIconTemplate\"></ng-template>\n                        </ng-container>\n                    </a>\n                    <a\n                        *ngIf=\"child.routerLink\"\n                        (keydown)=\"onItemKeyDown($event, child)\"\n                        [routerLink]=\"child.routerLink\"\n                        [attr.data-automationid]=\"child.automationId\"\n                        [queryParams]=\"child.queryParams\"\n                        [routerLinkActive]=\"'p-menuitem-link-active'\"\n                        [routerLinkActiveOptions]=\"child.routerLinkActiveOptions || { exact: false }\"\n                        [target]=\"child.target\"\n                        [attr.title]=\"child.title\"\n                        [attr.id]=\"child.id\"\n                        [attr.tabindex]=\"child.disabled ? null : '0'\"\n                        role=\"menuitem\"\n                        (click)=\"onItemClick($event, child)\"\n                        (mouseenter)=\"onItemMouseEnter($event, child)\"\n                        [ngClass]=\"{ 'p-menuitem-link': true, 'p-disabled': child.disabled }\"\n                        [fragment]=\"child.fragment\"\n                        [queryParamsHandling]=\"child.queryParamsHandling\"\n                        [preserveFragment]=\"child.preserveFragment\"\n                        [skipLocationChange]=\"child.skipLocationChange\"\n                        [replaceUrl]=\"child.replaceUrl\"\n                        [state]=\"child.state\"\n                        pRipple\n                    >\n                        <span class=\"p-menuitem-icon\" *ngIf=\"child.icon\" [ngClass]=\"child.icon\" [ngStyle]=\"child.iconStyle\"></span>\n                        <span class=\"p-menuitem-text\" *ngIf=\"child.escape !== false; else htmlRouteLabel\">{{ child.label }}</span>\n                        <ng-template #htmlRouteLabel><span class=\"p-menuitem-text\" [innerHTML]=\"child.label\"></span></ng-template>\n                        <span class=\"p-menuitem-badge\" *ngIf=\"child.badge\" [ngClass]=\"child.badgeStyleClass\">{{ child.badge }}</span>\n                        <ng-container *ngIf=\"child.items\">\n                            <AngleRightIcon *ngIf=\"!tieredMenu.submenuIconTemplate\" [styleClass]=\"'p-submenu-icon'\" />\n                            <ng-template *ngTemplateOutlet=\"tieredMenu.submenuIconTemplate\"></ng-template>\n                        </ng-container>\n                    </a>\n                    <p-tieredMenuSub\n                        (keydownItem)=\"onChildItemKeyDown($event)\"\n                        [parentActive]=\"child === activeItem\"\n                        [item]=\"child\"\n                        *ngIf=\"child.items\"\n                        [mobileActive]=\"mobileActive\"\n                        [autoDisplay]=\"autoDisplay\"\n                        (leafClick)=\"onLeafClick()\"\n                        [popup]=\"popup\"\n                    ></p-tieredMenuSub>\n                </li>\n            </ng-template>\n        </ul>\n    `,\n    encapsulation: ViewEncapsulation.None,\n    host: {\n        class: 'p-element'\n    }\n})\nexport class TieredMenuSub implements OnDestroy {\n    @Input() item: MenuItem | undefined;\n\n    @Input() root: boolean | undefined;\n\n    @Input() autoDisplay: boolean | undefined;\n\n    @Input() autoZIndex: boolean = true;\n\n    @Input() baseZIndex: number = 0;\n\n    @Input() mobileActive: boolean | undefined;\n\n    @Input() popup: boolean | undefined;\n\n    @Input() get parentActive(): boolean {\n        return this._parentActive as boolean;\n    }\n    set parentActive(value) {\n        if (!this.root) {\n            this._parentActive = value;\n\n            if (!value) this.activeItem = null;\n            else this.positionSubmenu();\n        }\n    }\n\n    @ViewChild('sublist') sublistViewChild: ElementRef | undefined;\n\n    @Output() leafClick: EventEmitter<any> = new EventEmitter();\n\n    @Output() keydownItem: EventEmitter<any> = new EventEmitter();\n\n    _parentActive: boolean | undefined;\n\n    documentClickListener: VoidListener;\n\n    menuHoverActive: boolean = false;\n\n    activeItem: any;\n\n    constructor(@Inject(DOCUMENT) private document: Document, public el: ElementRef, public renderer: Renderer2, private cd: ChangeDetectorRef, public tieredMenu: TieredMenu) {}\n\n    onItemClick(event: Event, item: MenuItem) {\n        if (item.disabled) {\n            event.preventDefault();\n            return;\n        }\n\n        if (!item.url && !item.routerLink) {\n            event.preventDefault();\n        }\n\n        if (item.command) {\n            item.command({\n                originalEvent: event,\n                item: item\n            });\n        }\n\n        if (item.items) {\n            if (this.activeItem && item === this.activeItem) {\n                this.activeItem = null;\n                this.unbindDocumentClickListener();\n            } else {\n                this.activeItem = item;\n                if (this.root) {\n                    this.bindDocumentClickListener();\n                }\n            }\n        }\n\n        if (!item.items) {\n            this.onLeafClick();\n        }\n    }\n\n    onItemMouseEnter(event: MouseEvent, item: MenuItem) {\n        if (item.disabled || this.mobileActive) {\n            event.preventDefault();\n            return;\n        }\n\n        if (this.root) {\n            if (this.activeItem || this.autoDisplay || this.popup) {\n                this.activeItem = item;\n                this.bindDocumentClickListener();\n            }\n        } else {\n            this.activeItem = item;\n            this.bindDocumentClickListener();\n        }\n    }\n\n    onLeafClick() {\n        this.activeItem = null;\n        if (this.root) {\n            this.unbindDocumentClickListener();\n        }\n\n        this.leafClick.emit();\n    }\n\n    onItemKeyDown(event: KeyboardEvent, item: MenuItem) {\n        let listItem = (event.currentTarget as HTMLElement).parentElement;\n\n        switch (event.key) {\n            case 'ArrowDown':\n                const nextItem = this.findNextItem(listItem!);\n                if (nextItem) {\n                    nextItem.children[0].focus();\n                }\n\n                event.preventDefault();\n                break;\n\n            case 'ArrowUp':\n                const prevItem = this.findPrevItem(listItem!);\n                if (prevItem) {\n                    prevItem.children[0].focus();\n                }\n\n                event.preventDefault();\n                break;\n\n            case 'ArrowRight':\n                if (item.items) {\n                    this.activeItem = item;\n\n                    if (this.root) {\n                        this.bindDocumentClickListener();\n                    }\n\n                    setTimeout(() => {\n                        (listItem?.children[1].children[0].children[0].children[0] as HTMLElement).focus();\n                    }, 50);\n                }\n\n                event.preventDefault();\n                break;\n\n            case 'Enter':\n                if (!item.routerLink) {\n                    this.onItemClick(event, item);\n                }\n\n                break;\n\n            default:\n                break;\n        }\n\n        this.keydownItem.emit({\n            originalEvent: event,\n            element: listItem\n        });\n    }\n\n    positionSubmenu() {\n        let sublist = this.sublistViewChild && this.sublistViewChild.nativeElement;\n\n        if (sublist) {\n            const parentItem = sublist.parentElement.parentElement;\n            const containerOffset = DomHandler.getOffset(parentItem);\n            const viewport = DomHandler.getViewport();\n            const sublistWidth = sublist.offsetParent ? sublist.offsetWidth : DomHandler.getHiddenElementOuterWidth(sublist);\n            const itemOuterWidth = DomHandler.getOuterWidth(parentItem.children[0]);\n\n            if (parseInt(containerOffset.left, 10) + itemOuterWidth + sublistWidth > viewport.width - DomHandler.calculateScrollbarWidth()) {\n                DomHandler.addClass(sublist, 'p-submenu-list-flipped');\n            }\n        }\n    }\n\n    findNextItem(item: Element): any {\n        let nextItem = item.nextElementSibling;\n\n        if (nextItem) return DomHandler.hasClass(nextItem, 'p-disabled') || !DomHandler.hasClass(nextItem, 'p-menuitem') ? this.findNextItem(nextItem) : nextItem;\n        else return null;\n    }\n\n    findPrevItem(item: Element): any {\n        let prevItem = item.previousElementSibling;\n\n        if (prevItem) return DomHandler.hasClass(prevItem, 'p-disabled') || !DomHandler.hasClass(prevItem, 'p-menuitem') ? this.findPrevItem(prevItem) : prevItem;\n        else return null;\n    }\n\n    onChildItemKeyDown(event: KeyboardEvent) {\n        if (event.key === 'ArrowLeft') {\n            this.activeItem = null;\n\n            if (this.root) {\n                this.unbindDocumentClickListener();\n            }\n            if (event.target) {\n                const parent = (event.target as HTMLElement).parentElement;\n                if (parent && parent.parentElement && parent.parentElement.parentElement) {\n                    (parent.parentElement.parentElement.children[0] as HTMLElement).focus();\n                }\n            }\n        }\n    }\n\n    bindDocumentClickListener() {\n        if (!this.documentClickListener) {\n            this.documentClickListener = this.renderer.listen(this.document, 'click', (event) => {\n                if (this.el && !this.el.nativeElement.contains(event.target)) {\n                    this.activeItem = null;\n                    this.cd.markForCheck();\n                    this.unbindDocumentClickListener();\n                }\n            });\n        }\n    }\n\n    unbindDocumentClickListener() {\n        if (this.documentClickListener) {\n            this.documentClickListener();\n            this.documentClickListener = null;\n        }\n    }\n\n    ngOnDestroy() {\n        this.unbindDocumentClickListener();\n    }\n}\n/**\n * TieredMenu displays submenus in nested overlays.\n * @group Components\n */\n@Component({\n    selector: 'p-tieredMenu',\n    template: `\n        <div\n            [ngClass]=\"{ 'p-tieredmenu p-component': true, 'p-tieredmenu-overlay': popup }\"\n            [class]=\"styleClass\"\n            [ngStyle]=\"style\"\n            (click)=\"onOverlayClick($event)\"\n            [@overlayAnimation]=\"{ value: 'visible', params: { showTransitionParams: showTransitionOptions, hideTransitionParams: hideTransitionOptions } }\"\n            [@.disabled]=\"popup !== true\"\n            (@overlayAnimation.start)=\"onOverlayAnimationStart($event)\"\n            (@overlayAnimation.done)=\"onOverlayAnimationEnd($event)\"\n            *ngIf=\"!popup || visible\"\n        >\n            <p-tieredMenuSub [item]=\"model\" root=\"root\" [parentActive]=\"parentActive\" [baseZIndex]=\"baseZIndex\" [autoZIndex]=\"autoZIndex\" (leafClick)=\"onLeafClick()\" [autoDisplay]=\"autoDisplay\" [popup]=\"popup\"></p-tieredMenuSub>\n        </div>\n    `,\n    animations: [trigger('overlayAnimation', [transition(':enter', [style({ opacity: 0, transform: 'scaleY(0.8)' }), animate('{{showTransitionParams}}')]), transition(':leave', [animate('{{hideTransitionParams}}', style({ opacity: 0 }))])])],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    styleUrls: ['./tieredmenu.css'],\n    host: {\n        class: 'p-element'\n    }\n})\nexport class TieredMenu implements AfterContentInit, OnDestroy {\n    /**\n     * An array of menuitems.\n     * @group Props\n     */\n    @Input() model: MenuItem[] | undefined;\n    /**\n     * Defines if menu would displayed as a popup.\n     * @group Props\n     */\n    @Input() popup: boolean | undefined;\n    /**\n     * Inline style of the component.\n     * @group Props\n     */\n    @Input() style: { [klass: string]: any } | null | undefined;\n    /**\n     * Style class of the component.\n     * @group Props\n     */\n    @Input() styleClass: string | undefined;\n    /**\n     * Target element to attach the overlay, valid values are \"body\" or a local ng-template variable of another element.\n     * @group Props\n     */\n    @Input() appendTo: HTMLElement | ElementRef | TemplateRef<any> | string | null | undefined | any;\n    /**\n     * Whether to automatically manage layering.\n     * @group Props\n     */\n    @Input() autoZIndex: boolean = true;\n    /**\n     * Base zIndex value to use in layering.\n     * @group Props\n     */\n    @Input() baseZIndex: number = 0;\n    /**\n     * Whether to show a root submenu on mouse over.\n     * @group Props\n     */\n    @Input() autoDisplay: boolean | undefined;\n    /**\n     * Transition options of the show animation.\n     * @group Props\n     */\n    @Input() showTransitionOptions: string = '.12s cubic-bezier(0, 0, 0.2, 1)';\n    /**\n     * Transition options of the hide animation.\n     * @group Props\n     */\n    @Input() hideTransitionOptions: string = '.1s linear';\n    /**\n     * Callback to invoke when overlay menu is shown.\n     * @group Emits\n     */\n    @Output() onShow: EventEmitter<any> = new EventEmitter<any>();\n    /**\n     * Callback to invoke when overlay menu is hidden.\n     * @group Emits\n     */\n    @Output() onHide: EventEmitter<any> = new EventEmitter<any>();\n\n    @ContentChildren(PrimeTemplate) templates: QueryList<PrimeTemplate> | undefined;\n\n    submenuIconTemplate: Nullable<TemplateRef<any>>;\n\n    parentActive: boolean | undefined;\n\n    container: HTMLDivElement | undefined;\n\n    documentClickListener: VoidListener;\n\n    documentResizeListener: VoidListener;\n\n    preventDocumentDefault: boolean | undefined;\n\n    scrollHandler: Nullable<ConnectedOverlayScrollHandler>;\n\n    target: any;\n\n    visible: boolean | undefined;\n\n    relativeAlign: boolean | undefined;\n\n    private window: Window;\n\n    constructor(@Inject(DOCUMENT) private document: Document, public el: ElementRef, public renderer: Renderer2, public cd: ChangeDetectorRef, public config: PrimeNGConfig, public overlayService: OverlayService) {\n        this.window = this.document.defaultView as Window;\n    }\n\n    ngAfterContentInit() {\n        this.templates?.forEach((item) => {\n            switch (item.getType()) {\n                case 'submenuicon':\n                    this.submenuIconTemplate = item.template;\n                    break;\n            }\n        });\n    }\n    /**\n     * Toggles the visibility of the popup menu.\n     * @param {Event} event - Browser event.\n     * @group Method\n     */\n    toggle(event: any) {\n        if (this.visible) this.hide();\n        else this.show(event);\n\n        this.preventDocumentDefault = true;\n    }\n\n    /**\n     * Displays the popup menu.\n     * @param {Event} even - Browser event.\n     * @group Method\n     */\n    show(event: any) {\n        this.target = event.currentTarget;\n        this.relativeAlign = event.relativeAlign;\n        this.visible = true;\n        this.parentActive = true;\n        this.preventDocumentDefault = true;\n        this.cd.markForCheck();\n    }\n\n    onOverlayClick(event: MouseEvent) {\n        if (this.popup) {\n            this.overlayService.add({\n                originalEvent: event,\n                target: this.el.nativeElement\n            });\n        }\n\n        this.preventDocumentDefault = true;\n    }\n\n    onOverlayAnimationStart(event: AnimationEvent) {\n        switch (event.toState) {\n            case 'visible':\n                if (this.popup) {\n                    this.container = event.element;\n                    this.moveOnTop();\n                    this.onShow.emit({});\n                    this.appendOverlay();\n                    this.alignOverlay();\n                    this.bindDocumentClickListener();\n                    this.bindDocumentResizeListener();\n                    this.bindScrollListener();\n                }\n                break;\n\n            case 'void':\n                this.onOverlayHide();\n                this.onHide.emit({});\n                break;\n        }\n    }\n\n    alignOverlay() {\n        if (this.relativeAlign) DomHandler.relativePosition(this.container, this.target);\n        else DomHandler.absolutePosition(this.container, this.target);\n    }\n\n    onOverlayAnimationEnd(event: AnimationEvent) {\n        switch (event.toState) {\n            case 'void':\n                ZIndexUtils.clear(event.element);\n                break;\n        }\n    }\n\n    appendOverlay() {\n        if (this.appendTo) {\n            if (this.appendTo === 'body') this.renderer.appendChild(this.document.body, this.container);\n            else DomHandler.appendChild(this.container, this.appendTo);\n        }\n    }\n\n    restoreOverlayAppend() {\n        if (this.container && this.appendTo) {\n            this.renderer.appendChild(this.el.nativeElement, this.container);\n        }\n    }\n\n    moveOnTop() {\n        if (this.autoZIndex) {\n            ZIndexUtils.set('menu', this.container, this.baseZIndex + this.config.zIndex.menu);\n        }\n    }\n\n    /**\n     * Hides the popup menu.\n     * @group Method\n     */\n    hide() {\n        this.visible = false;\n        this.relativeAlign = false;\n        this.parentActive = false;\n        this.cd.markForCheck();\n    }\n\n    onWindowResize() {\n        if (this.visible && !DomHandler.isTouchDevice()) {\n            this.hide();\n        }\n    }\n\n    onLeafClick() {\n        if (this.popup) {\n            this.hide();\n        }\n\n        this.unbindDocumentClickListener();\n    }\n\n    bindDocumentClickListener() {\n        if (!this.documentClickListener) {\n            const documentTarget: any = this.el ? this.el.nativeElement.ownerDocument : 'document';\n\n            this.documentClickListener = this.renderer.listen(documentTarget, 'click', () => {\n                if (!this.preventDocumentDefault && this.popup) {\n                    this.hide();\n                }\n\n                this.preventDocumentDefault = false;\n            });\n        }\n    }\n\n    unbindDocumentClickListener() {\n        if (this.documentClickListener) {\n            this.documentClickListener();\n            this.documentClickListener = null;\n        }\n    }\n\n    bindDocumentResizeListener() {\n        if (!this.documentResizeListener) {\n            this.documentResizeListener = this.renderer.listen(this.window, 'resize', this.onWindowResize.bind(this));\n        }\n    }\n\n    unbindDocumentResizeListener() {\n        if (this.documentResizeListener) {\n            this.documentResizeListener();\n            this.documentResizeListener = null;\n        }\n    }\n\n    bindScrollListener() {\n        if (!this.scrollHandler) {\n            this.scrollHandler = new ConnectedOverlayScrollHandler(this.target, () => {\n                if (this.visible) {\n                    this.hide();\n                }\n            });\n        }\n\n        this.scrollHandler.bindScrollListener();\n    }\n\n    unbindScrollListener() {\n        if (this.scrollHandler) {\n            this.scrollHandler.unbindScrollListener();\n        }\n    }\n\n    onOverlayHide() {\n        this.unbindDocumentClickListener();\n        this.unbindDocumentResizeListener();\n        this.unbindScrollListener();\n        this.preventDocumentDefault = false;\n\n        if (!(this.cd as ViewRef).destroyed) {\n            this.target = null;\n        }\n    }\n\n    ngOnDestroy() {\n        if (this.popup) {\n            if (this.scrollHandler) {\n                this.scrollHandler.destroy();\n                this.scrollHandler = null;\n            }\n\n            if (this.container && this.autoZIndex) {\n                ZIndexUtils.clear(this.container);\n            }\n\n            this.restoreOverlayAppend();\n            this.onOverlayHide();\n        }\n    }\n}\n\n@NgModule({\n    imports: [CommonModule, RouterModule, RippleModule, TooltipModule, AngleRightIcon, SharedModule],\n    exports: [TieredMenu, RouterModule, TooltipModule, SharedModule],\n    declarations: [TieredMenu, TieredMenuSub]\n})\nexport class TieredMenuModule {}\n"]}
1251
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tieredmenu.js","sourceRoot":"","sources":["../../../src/app/components/tieredmenu/tieredmenu.ts"],"names":[],"mappings":"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","sourcesContent":["import { AnimationEvent, animate, style, transition, trigger } from '@angular/animations';\nimport { CommonModule, DOCUMENT, isPlatformBrowser } from '@angular/common';\nimport {\n    AfterContentInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    Inject,\n    Input,\n    NgModule,\n    OnDestroy,\n    OnInit,\n    Output,\n    PLATFORM_ID,\n    QueryList,\n    Renderer2,\n    TemplateRef,\n    ViewChild,\n    ViewEncapsulation,\n    ViewRef,\n    effect,\n    signal\n} from '@angular/core';\nimport { RouterModule } from '@angular/router';\nimport { MenuItem, OverlayService, PrimeNGConfig, PrimeTemplate, SharedModule } from 'primeng/api';\nimport { ConnectedOverlayScrollHandler, DomHandler } from 'primeng/dom';\nimport { AngleRightIcon } from 'primeng/icons/angleright';\nimport { RippleModule } from 'primeng/ripple';\nimport { TooltipModule } from 'primeng/tooltip';\nimport { ObjectUtils, UniqueComponentId, ZIndexUtils } from 'primeng/utils';\nimport { Nullable, VoidListener } from 'primeng/ts-helpers';\n\n@Component({\n    selector: 'p-tieredMenuSub',\n    template: `\n        <ul\n            #sublist\n            role=\"menu\"\n            [ngClass]=\"{ 'p-submenu-list': !root, 'p-tieredmenu-root-list': root }\"\n            [id]=\"menuId + '_list'\"\n            [tabindex]=\"tabindex\"\n            [attr.aria-label]=\"ariaLabel\"\n            [attr.aria-labelledBy]=\"ariaLabelledBy\"\n            [attr.aria-aria-activedescendant]=\"focusedItemId\"\n            [attr.aria-orientation]=\"'vertical'\"\n            [attr.data-pc-section]=\"'menu'\"\n            (keydown)=\"menuKeydown.emit($event)\"\n            (focus)=\"menuFocus.emit($event)\"\n            (blur)=\"menuBlur.emit($event)\"\n        >\n            <ng-template ngFor let-processedItem [ngForOf]=\"items\" let-index=\"index\">\n                <li\n                    *ngIf=\"isItemVisible(processedItem) && getItemProp(processedItem, 'separator')\"\n                    [id]=\"getItemId(processedItem)\"\n                    [style]=\"getItemProp(processedItem, 'style')\"\n                    [ngClass]=\"getSeparatorItemClass(processedItem)\"\n                    role=\"separator\"\n                    [attr.data-pc-section]=\"'separator'\"\n                ></li>\n                <li\n                    #listItem\n                    *ngIf=\"isItemVisible(processedItem) && !getItemProp(processedItem, 'separator')\"\n                    role=\"menuitem\"\n                    [id]=\"getItemId(processedItem)\"\n                    [attr.data-pc-section]=\"'menuitem'\"\n                    [attr.data-p-highlight]=\"isItemActive(processedItem)\"\n                    [attr.data-p-focused]=\"isItemFocused(processedItem)\"\n                    [attr.data-p-disabled]=\"isItemDisabled(processedItem)\"\n                    [attr.aria-label]=\"getItemLabel(processedItem)\"\n                    [attr.aria-disabled]=\"isItemDisabled(processedItem) || undefined\"\n                    [attr.aria-haspopup]=\"isItemGroup(processedItem) && !getItemProp(processedItem, 'to') ? 'menu' : undefined\"\n                    [attr.aria-expanded]=\"isItemGroup(processedItem) ? isItemActive(processedItem) : undefined\"\n                    [attr.aria-level]=\"level + 1\"\n                    [attr.aria-setsize]=\"getAriaSetSize()\"\n                    [attr.aria-posinset]=\"getAriaPosInset(index)\"\n                    [ngStyle]=\"getItemProp(processedItem, 'style')\"\n                    [ngClass]=\"getItemClass(processedItem)\"\n                    [class]=\"getItemProp(processedItem, 'styleClass')\"\n                    pTooltip\n                    [tooltipOptions]=\"getItemProp(processedItem, 'tooltipOptions')\"\n                >\n                    <div [attr.data-pc-section]=\"'content'\" class=\"p-menuitem-content\" (click)=\"onItemClick($event, processedItem)\" (mouseenter)=\"onItemMouseEnter({$event, processedItem})\">\n                        <a\n                            *ngIf=\"!getItemProp(processedItem, 'routerLink')\"\n                            [attr.href]=\"getItemProp(processedItem, 'url')\"\n                            [attr.aria-hidden]=\"true\"\n                            [attr.data-automationid]=\"getItemProp(processedItem, 'automationId')\"\n                            [attr.data-pc-section]=\"'action'\"\n                            [target]=\"getItemProp(processedItem, 'target')\"\n                            [ngClass]=\"{ 'p-menuitem-link': true, 'p-disabled': getItemProp(processedItem, 'disabled') }\"\n                            [attr.tabindex]=\"-1\"\n                            pRipple\n                        >\n                            <span\n                                *ngIf=\"getItemProp(processedItem, 'icon')\"\n                                class=\"p-menuitem-icon\"\n                                [ngClass]=\"getItemProp(processedItem, 'icon')\"\n                                [ngStyle]=\"getItemProp(processedItem, 'iconStyle')\"\n                                [attr.data-pc-section]=\"'icon'\"\n                                [attr.aria-hidden]=\"true\"\n                                [attr.tabindex]=\"-1\"\n                            >\n                            </span>\n                            <span *ngIf=\"getItemProp(processedItem, 'escape'); else htmlLabel\" class=\"p-menuitem-text\" [attr.data-pc-section]=\"'label'\">\n                                {{ getItemLabel(processedItem) }}\n                            </span>\n                            <ng-template #htmlLabel>\n                                <span class=\"p-menuitem-text\" [innerHTML]=\"getItemLabel(processedItem)\" [attr.data-pc-section]=\"'label'\"></span>\n                            </ng-template>\n                            <span class=\"p-menuitem-badge\" *ngIf=\"getItemProp(processedItem, 'badge')\" [ngClass]=\"getItemProp(processedItem, 'badgeStyleClass')\">{{ child.badge }}</span>\n\n                            <ng-container *ngIf=\"isItemGroup(processedItem)\">\n                                <AngleRightIcon *ngIf=\"!tieredMenu.submenuIconTemplate\" [styleClass]=\"'p-submenu-icon'\" [attr.data-pc-section]=\"'submenuicon'\" [attr.aria-hidden]=\"true\" />\n                                <ng-template *ngTemplateOutlet=\"tieredMenu.submenuIconTemplate\" [attr.data-pc-section]=\"'submenuicon'\" [attr.aria-hidden]=\"true\"></ng-template>\n                            </ng-container>\n                        </a>\n                        <a\n                            *ngIf=\"getItemProp(processedItem, 'routerLink')\"\n                            [routerLink]=\"getItemProp(processedItem, 'routerLink')\"\n                            [attr.data-automationid]=\"getItemProp(processedItem, 'automationId')\"\n                            [attr.tabindex]=\"-1\"\n                            [attr.aria-hidden]=\"true\"\n                            [attr.data-pc-section]=\"'action'\"\n                            [queryParams]=\"getItemProp(processedItem, 'queryParams')\"\n                            [routerLinkActive]=\"'p-menuitem-link-active'\"\n                            [routerLinkActiveOptions]=\"getItemProp(processedItem, 'routerLinkActiveOptions') || { exact: false }\"\n                            [target]=\"getItemProp(processedItem, 'target')\"\n                            [ngClass]=\"{ 'p-menuitem-link': true, 'p-disabled': getItemProp(processedItem, 'disabled') }\"\n                            [fragment]=\"getItemProp(processedItem, 'fragment')\"\n                            [queryParamsHandling]=\"getItemProp(processedItem, 'queryParamsHandling')\"\n                            [preserveFragment]=\"getItemProp(processedItem, 'preserveFragment')\"\n                            [skipLocationChange]=\"getItemProp(processedItem, 'skipLocationChange')\"\n                            [replaceUrl]=\"getItemProp(processedItem, 'replaceUrl')\"\n                            [state]=\"getItemProp(processedItem, 'state')\"\n                            pRipple\n                        >\n                            <span\n                                *ngIf=\"getItemProp(processedItem, 'icon')\"\n                                class=\"p-menuitem-icon\"\n                                [ngClass]=\"getItemProp(processedItem, 'icon')\"\n                                [ngStyle]=\"getItemProp(processedItem, 'iconStyle')\"\n                                [attr.data-pc-section]=\"'icon'\"\n                                [attr.aria-hidden]=\"true\"\n                                [attr.tabindex]=\"-1\"\n                            >\n                            </span>\n                            <span *ngIf=\"getItemProp(processedItem, 'escape'); else htmlLabel\" class=\"p-menuitem-text\" [attr.data-pc-section]=\"'label'\">\n                                {{ getItemLabel(processedItem) }}\n                            </span>\n                            <ng-template #htmlLabel>\n                                <span class=\"p-menuitem-text\" [innerHTML]=\"getItemLabel(processedItem)\" [attr.data-pc-section]=\"'label'\"></span>\n                            </ng-template>\n                            <span class=\"p-menuitem-badge\" *ngIf=\"getItemProp(processedItem, 'badge')\" [ngClass]=\"getItemProp(processedItem, 'badgeStyleClass')\">{{ child.badge }}</span>\n\n                            <ng-container *ngIf=\"isItemGroup(processedItem)\">\n                                <AngleRightIcon *ngIf=\"!tieredMenu.submenuIconTemplate\" [styleClass]=\"'p-submenu-icon'\" [attr.data-pc-section]=\"'submenuicon'\" [attr.aria-hidden]=\"true\" />\n                                <ng-template *ngTemplateOutlet=\"tieredMenu.submenuIconTemplate\" [attr.data-pc-section]=\"'submenuicon'\" [attr.aria-hidden]=\"true\"></ng-template>\n                            </ng-container>\n                        </a>\n                    </div>\n\n                    <p-tieredMenuSub\n                        *ngIf=\"isItemVisible(processedItem) && isItemGroup(processedItem)\"\n                        [items]=\"processedItem.items\"\n                        [autoDisplay]=\"autoDisplay\"\n                        [menuId]=\"menuId\"\n                        [activeItemPath]=\"activeItemPath\"\n                        [focusedItemId]=\"focusedItemId\"\n                        [level]=\"level + 1\"\n                        (itemClick)=\"itemClick.emit($event)\"\n                        (itemMouseEnter)=\"onItemMouseEnter($event)\"\n                    ></p-tieredMenuSub>\n                </li>\n            </ng-template>\n        </ul>\n    `,\n    encapsulation: ViewEncapsulation.None,\n    host: {\n        class: 'p-element'\n    }\n})\nexport class TieredMenuSub {\n    @Input() items: any[];\n\n    @Input() root: boolean | undefined = false;\n\n    @Input() autoDisplay: boolean | undefined;\n\n    @Input() autoZIndex: boolean = true;\n\n    @Input() baseZIndex: number = 0;\n\n    @Input() popup: boolean | undefined;\n\n    @Input() menuId: string | undefined;\n\n    @Input() ariaLabel: string | undefined;\n\n    @Input() ariaLabelledBy: string | undefined;\n\n    @Input() level: number = 0;\n\n    @Input() focusedItemId: string | undefined;\n\n    @Input() activeItemPath: any[];\n\n    @Input() tabindex: number = 0;\n\n    @Output() itemClick: EventEmitter<any> = new EventEmitter();\n\n    @Output() itemMouseEnter: EventEmitter<any> = new EventEmitter();\n\n    @Output() menuFocus: EventEmitter<any> = new EventEmitter();\n\n    @Output() menuBlur: EventEmitter<any> = new EventEmitter();\n\n    @Output() menuKeydown: EventEmitter<any> = new EventEmitter();\n\n    @ViewChild('sublist', { static: true }) sublistViewChild: ElementRef;\n\n    constructor(@Inject(DOCUMENT) private document: Document, public el: ElementRef, public renderer: Renderer2, private cd: ChangeDetectorRef, public tieredMenu: TieredMenu) {}\n\n    positionSubmenu() {\n        let sublist = this.sublistViewChild && this.sublistViewChild.nativeElement;\n\n        if (sublist) {\n            const parentItem = sublist.parentElement.parentElement;\n            const containerOffset = DomHandler.getOffset(parentItem);\n            const viewport = DomHandler.getViewport();\n            const sublistWidth = sublist.offsetParent ? sublist.offsetWidth : DomHandler.getHiddenElementOuterWidth(sublist);\n            const itemOuterWidth = DomHandler.getOuterWidth(parentItem.children[0]);\n\n            if (parseInt(containerOffset.left, 10) + itemOuterWidth + sublistWidth > viewport.width - DomHandler.calculateScrollbarWidth()) {\n                DomHandler.addClass(sublist, 'p-submenu-list-flipped');\n            }\n        }\n    }\n\n    getItemProp(processedItem: any, name: string, params: any | null = null) {\n        return processedItem && processedItem.item ? ObjectUtils.getItemValue(processedItem.item[name], params) : undefined;\n    }\n\n    getItemId(processedItem: any): string {\n        return `${this.menuId}_${processedItem.key}`;\n    }\n\n    getItemKey(processedItem: any): string {\n        return this.getItemId(processedItem);\n    }\n\n    getItemClass(processedItem: any) {\n        return {\n            ...this.getItemProp(processedItem, 'class'),\n            'p-menuitem': true,\n            'p-highlight': this.isItemActive(processedItem),\n            'p-menuitem-active': this.isItemActive(processedItem),\n            'p-focus': this.isItemFocused(processedItem),\n            'p-disabled': this.isItemDisabled(processedItem)\n        };\n    }\n\n    getItemLabel(processedItem: any): string {\n        return this.getItemProp(processedItem, 'label');\n    }\n\n    getSeparatorItemClass(processedItem: any) {\n        return {\n            ...this.getItemProp(processedItem, 'class'),\n            'p-menuitem-separator': true\n        };\n    }\n\n    getAriaSetSize() {\n        return this.items.filter((processedItem) => this.isItemVisible(processedItem) && !this.getItemProp(processedItem, 'separator')).length;\n    }\n\n    getAriaPosInset(index: number) {\n        return index - this.items.slice(0, index).filter((processedItem) => this.isItemVisible(processedItem) && this.getItemProp(processedItem, 'separator')).length + 1;\n    }\n\n    isItemVisible(processedItem: any): boolean {\n        return this.getItemProp(processedItem, 'visible') !== false;\n    }\n\n    isItemActive(processedItem: any): boolean {\n        if (this.activeItemPath) {\n            return this.activeItemPath.some((path) => path.key === processedItem.key);\n        }\n    }\n\n    isItemDisabled(processedItem: any): boolean {\n        return this.getItemProp(processedItem, 'disabled');\n    }\n\n    isItemFocused(processedItem: any): boolean {\n        return this.focusedItemId === this.getItemId(processedItem);\n    }\n\n    isItemGroup(processedItem: any): boolean {\n        return ObjectUtils.isNotEmpty(processedItem.items);\n    }\n\n    onItemMouseEnter(param: any) {\n        if (this.autoDisplay) {\n            const { event, processedItem } = param;\n            this.itemMouseEnter.emit({ originalEvent: event, processedItem });\n        }\n    }\n\n    onItemClick(event: any, processedItem: any) {\n        this.getItemProp(processedItem, 'command', { originalEvent: event, item: processedItem.item });\n        this.itemClick.emit({ originalEvent: event, processedItem, isFocus: true });\n    }\n}\n/**\n * TieredMenu displays submenus in nested overlays.\n * @group Components\n */\n@Component({\n    selector: 'p-tieredMenu',\n    template: `\n        <div\n            #container\n            [attr.data-pc-section]=\"'root'\"\n            [attr.data-pc-name]=\"'tieredmenu'\"\n            [id]=\"id\"\n            [ngClass]=\"{ 'p-tieredmenu p-component': true, 'p-tieredmenu-overlay': popup }\"\n            [class]=\"styleClass\"\n            [ngStyle]=\"style\"\n            (click)=\"onOverlayClick($event)\"\n            [@overlayAnimation]=\"{ value: 'visible', params: { showTransitionParams: showTransitionOptions, hideTransitionParams: hideTransitionOptions } }\"\n            [@.disabled]=\"popup !== true\"\n            (@overlayAnimation.start)=\"onOverlayAnimationStart($event)\"\n            (@overlayAnimation.done)=\"onOverlayAnimationEnd($event)\"\n            *ngIf=\"!popup || visible\"\n        >\n            <p-tieredMenuSub\n                #rootmenu\n                [root]=\"true\"\n                [items]=\"processedItems\"\n                [menuId]=\"id\"\n                [tabindex]=\"!disabled ? tabindex : -1\"\n                [ariaLabel]=\"ariaLabel\"\n                [ariaLabelledBy]=\"ariaLabelledBy\"\n                [baseZIndex]=\"baseZIndex\"\n                [autoZIndex]=\"autoZIndex\"\n                [autoDisplay]=\"autoDisplay\"\n                [popup]=\"popup\"\n                [focusedItemId]=\"focused ? focusedItemId : undefined\"\n                [activeItemPath]=\"activeItemPath()\"\n                (itemClick)=\"onItemClick($event)\"\n                (menuFocus)=\"onMenuFocus($event)\"\n                (menuBlur)=\"onMenuBlur($event)\"\n                (menuKeydown)=\"onKeyDown($event)\"\n                (itemMouseEnter)=\"onItemMouseEnter($event)\"\n            ></p-tieredMenuSub>\n        </div>\n    `,\n    animations: [trigger('overlayAnimation', [transition(':enter', [style({ opacity: 0, transform: 'scaleY(0.8)' }), animate('{{showTransitionParams}}')]), transition(':leave', [animate('{{hideTransitionParams}}', style({ opacity: 0 }))])])],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    styleUrls: ['./tieredmenu.css'],\n    host: {\n        class: 'p-element'\n    }\n})\nexport class TieredMenu implements OnInit, AfterContentInit, OnDestroy {\n    /**\n     * An array of menuitems.\n     * @group Props\n     */\n    @Input() model: MenuItem[] | undefined;\n    /**\n     * Defines if menu would displayed as a popup.\n     * @group Props\n     */\n    @Input() popup: boolean | undefined;\n    /**\n     * Inline style of the component.\n     * @group Props\n     */\n    @Input() style: { [klass: string]: any } | null | undefined;\n    /**\n     * Style class of the component.\n     * @group Props\n     */\n    @Input() styleClass: string | undefined;\n    /**\n     * Target element to attach the overlay, valid values are \"body\" or a local ng-template variable of another element.\n     * @group Props\n     */\n    @Input() appendTo: HTMLElement | ElementRef | TemplateRef<any> | string | null | undefined | any;\n    /**\n     * Whether to automatically manage layering.\n     * @group Props\n     */\n    @Input() autoZIndex: boolean = true;\n    /**\n     * Base zIndex value to use in layering.\n     * @group Props\n     */\n    @Input() baseZIndex: number = 0;\n    /**\n     * Whether to show a root submenu on mouse over.\n     * @defaultValue true\n     * @group Props\n     */\n    @Input() autoDisplay: boolean | undefined = true;\n    /**\n     * Transition options of the show animation.\n     * @group Props\n     */\n    @Input() showTransitionOptions: string = '.12s cubic-bezier(0, 0, 0.2, 1)';\n    /**\n     * Transition options of the hide animation.\n     * @group Props\n     */\n    @Input() hideTransitionOptions: string = '.1s linear';\n    /**\n     * Current id state as a string.\n     * @group Props\n     */\n    @Input() id: string | undefined;\n    /**\n     * Defines a string value that labels an interactive element.\n     * @group Props\n     */\n    @Input() ariaLabel: string | undefined;\n    /**\n     * Identifier of the underlying input element.\n     * @group Props\n     */\n    @Input() ariaLabelledBy: string | undefined;\n    /**\n     * When present, it specifies that the component should be disabled.\n     * @group Props\n     */\n    @Input() disabled: boolean = false;\n    /**\n     * Index of the element in tabbing order.\n     * @group Props\n     */\n    @Input() tabindex: number = 0;\n    /**\n     * Callback to invoke when overlay menu is shown.\n     * @group Emits\n     */\n    @Output() onShow: EventEmitter<any> = new EventEmitter<any>();\n    /**\n     * Callback to invoke when overlay menu is hidden.\n     * @group Emits\n     */\n    @Output() onHide: EventEmitter<any> = new EventEmitter<any>();\n\n    @ContentChildren(PrimeTemplate) templates: QueryList<PrimeTemplate> | undefined;\n\n    @ViewChild('rootmenu') rootmenu: TieredMenuSub | undefined;\n\n    @ViewChild('container') containerViewChild: ElementRef<any> | undefined;\n\n    submenuIconTemplate: Nullable<TemplateRef<any>>;\n\n    container: HTMLDivElement | undefined;\n\n    outsideClickListener: VoidListener;\n\n    resizeListener: VoidListener;\n\n    scrollHandler: Nullable<ConnectedOverlayScrollHandler>;\n\n    target: any;\n\n    relatedTarget: any;\n\n    visible: boolean | undefined;\n\n    relativeAlign: boolean | undefined;\n\n    private window: Window;\n\n    dirty: boolean = false;\n\n    focused: boolean = false;\n\n    activeItemPath = signal<any>([]);\n\n    number = signal<number>(0);\n\n    focusedItemInfo = signal<any>({ index: -1, level: 0, parentKey: '' });\n\n    searchValue: string = '';\n\n    searchTimeout: any;\n\n    _processedItems: any[];\n\n    get visibleItems() {\n        const processedItem = this.activeItemPath().find((p) => p.key === this.focusedItemInfo().parentKey);\n\n        return processedItem ? processedItem.items : this.processedItems;\n    }\n\n    get processedItems() {\n        if (!this._processedItems || !this._processedItems.length) {\n            this._processedItems = this.createProcessedItems(this.model || []);\n        }\n        return this._processedItems;\n    }\n\n    get focusedItemId() {\n        const focusedItemInfo = this.focusedItemInfo();\n        return focusedItemInfo.index !== -1 ? `${this.id}${ObjectUtils.isNotEmpty(focusedItemInfo.parentKey) ? '_' + focusedItemInfo.parentKey : ''}_${focusedItemInfo.index}` : null;\n    }\n\n    constructor(\n        @Inject(DOCUMENT) private document: Document,\n        @Inject(PLATFORM_ID) private platformId: any,\n        public el: ElementRef,\n        public renderer: Renderer2,\n        public cd: ChangeDetectorRef,\n        public config: PrimeNGConfig,\n        public overlayService: OverlayService\n    ) {\n        this.window = this.document.defaultView as Window;\n        effect(() => {\n            const path = this.activeItemPath();\n\n            if (ObjectUtils.isNotEmpty(path)) {\n                this.bindOutsideClickListener();\n                this.bindResizeListener();\n            } else {\n                this.unbindOutsideClickListener();\n                this.unbindResizeListener();\n            }\n        });\n    }\n\n    ngOnInit() {\n        this.id = this.id || UniqueComponentId();\n    }\n\n    ngAfterContentInit() {\n        this.templates?.forEach((item) => {\n            switch (item.getType()) {\n                case 'submenuicon':\n                    this.submenuIconTemplate = item.template;\n                    break;\n            }\n        });\n    }\n\n    createProcessedItems(items: any, level: number = 0, parent: any = {}, parentKey: any = '') {\n        const processedItems = [];\n\n        items &&\n            items.forEach((item, index) => {\n                const key = (parentKey !== '' ? parentKey + '_' : '') + index;\n                const newItem = {\n                    item,\n                    index,\n                    level,\n                    key,\n                    parent,\n                    parentKey\n                };\n\n                newItem['items'] = this.createProcessedItems(item.items, level + 1, newItem, key);\n                processedItems.push(newItem);\n            });\n\n        return processedItems;\n    }\n\n    getItemProp(item: any, name: string) {\n        return item ? ObjectUtils.getItemValue(item[name]) : undefined;\n    }\n\n    getProccessedItemLabel(processedItem: any) {\n        return processedItem ? this.getItemLabel(processedItem.item) : undefined;\n    }\n\n    getItemLabel(item: any) {\n        return this.getItemProp(item, 'label');\n    }\n\n    isProcessedItemGroup(processedItem: any): boolean {\n        return processedItem && ObjectUtils.isNotEmpty(processedItem.items);\n    }\n\n    isSelected(processedItem: any): boolean {\n        return this.activeItemPath().some((p) => p.key === processedItem.key);\n    }\n\n    isValidSelectedItem(processedItem: any): boolean {\n        return this.isValidItem(processedItem) && this.isSelected(processedItem);\n    }\n\n    isValidItem(processedItem: any): boolean {\n        return !!processedItem && !this.isItemDisabled(processedItem.item) && !this.isItemSeparator(processedItem.item);\n    }\n\n    isItemDisabled(item: any): boolean {\n        return this.getItemProp(item, 'disabled');\n    }\n\n    isItemSeparator(item: any): boolean {\n        return this.getItemProp(item, 'separator');\n    }\n\n    isItemMatched(processedItem: any): boolean {\n        return this.isValidItem(processedItem) && this.getProccessedItemLabel(processedItem).toLocaleLowerCase().startsWith(this.searchValue.toLocaleLowerCase());\n    }\n\n    isProccessedItemGroup(processedItem: any): boolean {\n        return processedItem && ObjectUtils.isNotEmpty(processedItem.items);\n    }\n\n    onOverlayClick(event: MouseEvent) {\n        if (this.popup) {\n            this.overlayService.add({\n                originalEvent: event,\n                target: this.el.nativeElement\n            });\n        }\n    }\n\n    onItemClick(event: any) {\n        const { originalEvent, processedItem } = event;\n        const grouped = this.isProcessedItemGroup(processedItem);\n        const root = ObjectUtils.isEmpty(processedItem.parent);\n        const selected = this.isSelected(processedItem);\n\n        if (selected) {\n            const { index, key, level, parentKey } = processedItem;\n\n            this.activeItemPath.set(this.activeItemPath().filter((p) => key !== p.key && key.startsWith(p.key)));\n            this.focusedItemInfo.set({ index, level, parentKey });\n\n            this.dirty = !root;\n            DomHandler.focus(this.rootmenu.sublistViewChild.nativeElement);\n        } else {\n            if (grouped) {\n                this.onItemChange(event);\n            } else {\n                const rootProcessedItem = root ? processedItem : this.activeItemPath().find((p) => p.parentKey === '');\n                this.hide(originalEvent);\n                this.changeFocusedItemIndex(originalEvent, rootProcessedItem ? rootProcessedItem.index : -1);\n\n                DomHandler.focus(this.rootmenu.sublistViewChild.nativeElement);\n            }\n        }\n    }\n\n    onItemMouseEnter(event: any) {\n        if (this.dirty) {\n            this.onItemChange(event);\n        }\n    }\n\n    onKeyDown(event: KeyboardEvent) {\n        const metaKey = event.metaKey || event.ctrlKey;\n\n        switch (event.code) {\n            case 'ArrowDown':\n                this.onArrowDownKey(event);\n                break;\n\n            case 'ArrowUp':\n                this.onArrowUpKey(event);\n                break;\n\n            case 'ArrowLeft':\n                this.onArrowLeftKey(event);\n                break;\n\n            case 'ArrowRight':\n                this.onArrowRightKey(event);\n                break;\n\n            case 'Home':\n                this.onHomeKey(event);\n                break;\n\n            case 'End':\n                this.onEndKey(event);\n                break;\n\n            case 'Space':\n                this.onSpaceKey(event);\n                break;\n\n            case 'Enter':\n                this.onEnterKey(event);\n                break;\n\n            case 'Escape':\n                this.onEscapeKey(event);\n                break;\n\n            case 'Tab':\n                this.onTabKey(event);\n                break;\n\n            case 'PageDown':\n            case 'PageUp':\n            case 'Backspace':\n            case 'ShiftLeft':\n            case 'ShiftRight':\n                //NOOP\n                break;\n\n            default:\n                if (!metaKey && ObjectUtils.isPrintableCharacter(event.key)) {\n                    this.searchItems(event, event.key);\n                }\n\n                break;\n        }\n    }\n\n    onArrowDownKey(event: KeyboardEvent) {\n        const itemIndex = this.focusedItemInfo().index !== -1 ? this.findNextItemIndex(this.focusedItemInfo().index) : this.findFirstFocusedItemIndex();\n\n        this.changeFocusedItemIndex(event, itemIndex);\n        event.preventDefault();\n    }\n\n    onArrowRightKey(event: KeyboardEvent) {\n        const processedItem = this.visibleItems[this.focusedItemInfo().index];\n        const grouped = this.isProccessedItemGroup(processedItem);\n\n        if (grouped) {\n            this.onItemChange({ originalEvent: event, processedItem });\n            this.focusedItemInfo.set({ index: -1, parentKey: processedItem.key });\n            this.searchValue = '';\n            this.onArrowDownKey(event);\n        }\n\n        event.preventDefault();\n    }\n\n    onArrowUpKey(event: KeyboardEvent) {\n        if (event.altKey) {\n            if (this.focusedItemInfo().index !== -1) {\n                const processedItem = this.visibleItems[this.focusedItemInfo().index];\n                const grouped = this.isProccessedItemGroup(processedItem);\n\n                !grouped && this.onItemChange({ originalEvent: event, processedItem });\n            }\n\n            this.popup && this.hide(event, true);\n            event.preventDefault();\n        } else {\n            const itemIndex = this.focusedItemInfo().index !== -1 ? this.findPrevItemIndex(this.focusedItemInfo().index) : this.findLastFocusedItemIndex();\n\n            this.changeFocusedItemIndex(event, itemIndex);\n            event.preventDefault();\n        }\n    }\n\n    onArrowLeftKey(event: KeyboardEvent) {\n        const processedItem = this.visibleItems[this.focusedItemInfo().index];\n        const parentItem = this.activeItemPath().find((p) => p.key === processedItem.parentKey);\n        const root = ObjectUtils.isEmpty(processedItem.parent);\n\n        if (!root) {\n            this.focusedItemInfo.set({ index: -1, parentKey: parentItem ? parentItem.parentKey : '' });\n            this.searchValue = '';\n            this.onArrowDownKey(event);\n        }\n\n        const activeItemPath = this.activeItemPath().filter((p) => p.parentKey !== this.focusedItemInfo().parentKey);\n        this.activeItemPath.set(activeItemPath);\n\n        event.preventDefault();\n    }\n\n    onHomeKey(event: KeyboardEvent) {\n        this.changeFocusedItemIndex(event, this.findFirstItemIndex());\n        event.preventDefault();\n    }\n\n    onEndKey(event: KeyboardEvent) {\n        this.changeFocusedItemIndex(event, this.findLastItemIndex());\n        event.preventDefault();\n    }\n\n    onSpaceKey(event: KeyboardEvent) {\n        this.onEnterKey(event);\n    }\n\n    onEscapeKey(event: KeyboardEvent) {\n        this.hide(event, true);\n        this.focusedItemInfo().index = this.findFirstFocusedItemIndex();\n\n        event.preventDefault();\n    }\n\n    onTabKey(event: KeyboardEvent) {\n        if (this.focusedItemInfo().index !== -1) {\n            const processedItem = this.visibleItems[this.focusedItemInfo().index];\n            const grouped = this.isProccessedItemGroup(processedItem);\n\n            !grouped && this.onItemChange({ originalEvent: event, processedItem });\n        }\n\n        this.hide();\n    }\n\n    onEnterKey(event: KeyboardEvent) {\n        if (this.focusedItemInfo().index !== -1) {\n            const element = DomHandler.findSingle(this.rootmenu.el.nativeElement, `li[id=\"${`${this.focusedItemId}`}\"]`);\n            const anchorElement = element && DomHandler.findSingle(element, 'a[data-pc-section=\"action\"]');\n\n            anchorElement ? anchorElement.click() : element && element.click();\n\n            const processedItem = this.visibleItems[this.focusedItemInfo().index];\n            if (!this.popup) {\n                const processedItem = this.visibleItems[this.focusedItemInfo().index];\n                const grouped = this.isProccessedItemGroup(processedItem);\n\n                !grouped && (this.focusedItemInfo().index = this.findFirstFocusedItemIndex());\n            }\n        }\n\n        event.preventDefault();\n    }\n\n    onItemChange(event: any) {\n        const { processedItem, isFocus } = event;\n\n        if (ObjectUtils.isEmpty(processedItem)) return;\n\n        const { index, key, level, parentKey, items } = processedItem;\n        const grouped = ObjectUtils.isNotEmpty(items);\n        const activeItemPath = this.activeItemPath().filter((p) => p.parentKey !== parentKey && p.parentKey !== key);\n\n        grouped && activeItemPath.push(processedItem);\n        this.focusedItemInfo.set({ index, level, parentKey });\n        this.activeItemPath.set(activeItemPath);\n\n        grouped && (this.dirty = true);\n        isFocus && DomHandler.focus(this.rootmenu.sublistViewChild.nativeElement);\n    }\n\n    onMenuFocus(event: any) {\n        this.focused = true;\n        const focusedItemInfo = this.focusedItemInfo().index !== -1 ? this.focusedItemInfo() : { index: this.findFirstFocusedItemIndex(), level: 0, parentKey: '' };\n\n        this.focusedItemInfo.set(focusedItemInfo);\n    }\n\n    onMenuBlur(event: any) {\n        this.focused = false;\n        this.focusedItemInfo.set({ index: -1, level: 0, parentKey: '' });\n        this.searchValue = '';\n        this.dirty = false;\n    }\n\n    onOverlayAnimationStart(event: AnimationEvent) {\n        switch (event.toState) {\n            case 'visible':\n                if (this.popup) {\n                    this.container = event.element;\n                    this.moveOnTop();\n                    this.onShow.emit({});\n                    this.appendOverlay();\n                    this.alignOverlay();\n                    this.bindOutsideClickListener();\n                    this.bindResizeListener();\n                    this.bindScrollListener();\n                    DomHandler.focus(this.rootmenu.sublistViewChild.nativeElement);\n                    this.scrollInView();\n                }\n                break;\n\n            case 'void':\n                this.onOverlayHide();\n                this.onHide.emit({});\n                break;\n        }\n    }\n\n    alignOverlay() {\n        if (this.relativeAlign) DomHandler.relativePosition(this.container, this.target);\n        else DomHandler.absolutePosition(this.container, this.target);\n    }\n\n    onOverlayAnimationEnd(event: AnimationEvent) {\n        switch (event.toState) {\n            case 'void':\n                ZIndexUtils.clear(event.element);\n                break;\n        }\n    }\n\n    appendOverlay() {\n        if (this.appendTo) {\n            if (this.appendTo === 'body') this.renderer.appendChild(this.document.body, this.container);\n            else DomHandler.appendChild(this.container, this.appendTo);\n        }\n    }\n\n    restoreOverlayAppend() {\n        if (this.container && this.appendTo) {\n            this.renderer.appendChild(this.el.nativeElement, this.container);\n        }\n    }\n\n    moveOnTop() {\n        if (this.autoZIndex) {\n            ZIndexUtils.set('menu', this.container, this.baseZIndex + this.config.zIndex.menu);\n        }\n    }\n\n    /**\n     * Hides the popup menu.\n     * @group Method\n     */\n    hide(event?, isFocus?: boolean) {\n        if (this.popup) {\n            this.onHide.emit({});\n            this.visible = false;\n        }\n        this.activeItemPath.set([]);\n        this.focusedItemInfo.set({ index: -1, level: 0, parentKey: '' });\n\n        isFocus && DomHandler.focus(this.relatedTarget || this.target || this.rootmenu.sublistViewChild.nativeElement);\n        this.dirty = false;\n    }\n\n    /**\n     * Toggles the visibility of the popup menu.\n     * @param {Event} event - Browser event.\n     * @group Method\n     */\n    toggle(event: any) {\n        this.visible ? this.hide(event, true) : this.show(event);\n    }\n\n    /**\n     * Displays the popup menu.\n     * @param {Event} even - Browser event.\n     * @group Method\n     */\n    show(event: any, isFocus?) {\n        if (this.popup) {\n            this.visible = true;\n            this.target = this.target || event.currentTarget;\n            this.relatedTarget = event.relatedTarget || null;\n        }\n\n        this.focusedItemInfo.set({ index: this.findFirstFocusedItemIndex(), level: 0, parentKey: '' });\n\n        if (!this.popup) {\n            isFocus && DomHandler.focus(this.rootmenu.sublistViewChild.nativeElement);\n        }\n        this.cd.markForCheck();\n    }\n\n    searchItems(event: any, char: string) {\n        this.searchValue = (this.searchValue || '') + char;\n\n        let itemIndex = -1;\n        let matched = false;\n\n        if (this.focusedItemInfo().index !== -1) {\n            itemIndex = this.visibleItems.slice(this.focusedItemInfo().index).findIndex((processedItem) => this.isItemMatched(processedItem));\n            itemIndex = itemIndex === -1 ? this.visibleItems.slice(0, this.focusedItemInfo().index).findIndex((processedItem) => this.isItemMatched(processedItem)) : itemIndex + this.focusedItemInfo().index;\n        } else {\n            itemIndex = this.visibleItems.findIndex((processedItem) => this.isItemMatched(processedItem));\n        }\n\n        if (itemIndex !== -1) {\n            matched = true;\n        }\n\n        if (itemIndex === -1 && this.focusedItemInfo().index === -1) {\n            itemIndex = this.findFirstFocusedItemIndex();\n        }\n\n        if (itemIndex !== -1) {\n            this.changeFocusedItemIndex(event, itemIndex);\n        }\n\n        if (this.searchTimeout) {\n            clearTimeout(this.searchTimeout);\n        }\n\n        this.searchTimeout = setTimeout(() => {\n            this.searchValue = '';\n            this.searchTimeout = null;\n        }, 500);\n\n        return matched;\n    }\n\n    findLastFocusedItemIndex() {\n        const selectedIndex = this.findSelectedItemIndex();\n        return selectedIndex < 0 ? this.findLastItemIndex() : selectedIndex;\n    }\n\n    findLastItemIndex() {\n        return ObjectUtils.findLastIndex(this.visibleItems, (processedItem) => this.isValidItem(processedItem));\n    }\n\n    findPrevItemIndex(index: number) {\n        const matchedItemIndex = index > 0 ? ObjectUtils.findLastIndex(this.visibleItems.slice(0, index), (processedItem) => this.isValidItem(processedItem)) : -1;\n\n        return matchedItemIndex > -1 ? matchedItemIndex : index;\n    }\n\n    findNextItemIndex(index: number) {\n        const matchedItemIndex = index < this.visibleItems.length - 1 ? this.visibleItems.slice(index + 1).findIndex((processedItem) => this.isValidItem(processedItem)) : -1;\n\n        return matchedItemIndex > -1 ? matchedItemIndex + index + 1 : index;\n    }\n\n    findFirstFocusedItemIndex() {\n        const selectedIndex = this.findSelectedItemIndex();\n\n        return selectedIndex < 0 ? this.findFirstItemIndex() : selectedIndex;\n    }\n\n    findFirstItemIndex() {\n        return this.visibleItems.findIndex((processedItem) => this.isValidItem(processedItem));\n    }\n\n    findSelectedItemIndex() {\n        return this.visibleItems.findIndex((processedItem) => this.isValidSelectedItem(processedItem));\n    }\n\n    changeFocusedItemIndex(event: any, index: number) {\n        if (this.focusedItemInfo().index !== index) {\n            this.focusedItemInfo.mutate((value) => {\n                value.index = index;\n            });\n            this.scrollInView();\n        }\n    }\n\n    scrollInView(index: number = -1) {\n        const id = index !== -1 ? `${this.id}_${index}` : this.focusedItemId;\n        const element = DomHandler.findSingle(this.rootmenu.el.nativeElement, `li[id=\"${id}\"]`);\n\n        if (element) {\n            element.scrollIntoView && element.scrollIntoView({ block: 'nearest', inline: 'start' });\n        }\n    }\n\n    bindScrollListener() {\n        if (!this.scrollHandler) {\n            this.scrollHandler = new ConnectedOverlayScrollHandler(this.target, (event) => {\n                if (this.visible) {\n                    this.hide(event, true);\n                }\n            });\n        }\n\n        this.scrollHandler.bindScrollListener();\n    }\n\n    unbindScrollListener() {\n        if (this.scrollHandler) {\n            this.scrollHandler.unbindScrollListener();\n            this.scrollHandler = null;\n        }\n    }\n\n    bindResizeListener() {\n        if (isPlatformBrowser(this.platformId)) {\n            if (!this.resizeListener) {\n                this.resizeListener = this.renderer.listen(this.document.defaultView, 'resize', (event) => {\n                    if (!DomHandler.isTouchDevice()) {\n                        this.hide(event, true);\n                    }\n                });\n            }\n        }\n    }\n\n    bindOutsideClickListener() {\n        if (isPlatformBrowser(this.platformId)) {\n            if (!this.outsideClickListener) {\n                this.outsideClickListener = this.renderer.listen(this.document, 'click', (event) => {\n                    const isOutsideContainer = this.containerViewChild && !this.containerViewChild.nativeElement.contains(event.target);\n                    const isOutsideTarget = this.popup ? !(this.target && (this.target === event.target || this.target.contains(event.target))) : true;\n                    if (isOutsideContainer && isOutsideTarget) {\n                        this.hide();\n                    }\n                });\n            }\n        }\n    }\n\n    unbindOutsideClickListener() {\n        if (this.outsideClickListener) {\n            this.outsideClickListener();\n            this.outsideClickListener = null;\n        }\n    }\n\n    unbindResizeListener() {\n        if (this.resizeListener) {\n            this.resizeListener();\n            this.resizeListener = null;\n        }\n    }\n\n    onOverlayHide() {\n        this.unbindOutsideClickListener();\n        this.unbindResizeListener();\n        this.unbindScrollListener();\n\n        if (!(this.cd as ViewRef).destroyed) {\n            this.target = null;\n        }\n    }\n\n    ngOnDestroy() {\n        if (this.popup) {\n            if (this.scrollHandler) {\n                this.scrollHandler.destroy();\n                this.scrollHandler = null;\n            }\n\n            if (this.container && this.autoZIndex) {\n                ZIndexUtils.clear(this.container);\n            }\n\n            this.restoreOverlayAppend();\n            this.onOverlayHide();\n        }\n    }\n}\n\n@NgModule({\n    imports: [CommonModule, RouterModule, RippleModule, TooltipModule, AngleRightIcon, SharedModule],\n    exports: [TieredMenu, RouterModule, TooltipModule, SharedModule],\n    declarations: [TieredMenu, TieredMenuSub]\n})\nexport class TieredMenuModule {}\n"]}