primeng 16.5.1 → 16.6.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 (67) hide show
  1. package/api/menuitem.d.ts +5 -1
  2. package/breadcrumb/breadcrumb.d.ts +1 -0
  3. package/contextmenu/contextmenu.d.ts +3 -1
  4. package/esm2022/api/menuitem.mjs +1 -1
  5. package/esm2022/breadcrumb/breadcrumb.mjs +44 -17
  6. package/esm2022/button/button.mjs +2 -2
  7. package/esm2022/carousel/carousel.mjs +2 -1
  8. package/esm2022/contextmenu/contextmenu.mjs +168 -144
  9. package/esm2022/galleria/galleria.mjs +3 -3
  10. package/esm2022/image/image.mjs +11 -4
  11. package/esm2022/megamenu/megamenu.mjs +168 -144
  12. package/esm2022/menu/menu.mjs +146 -94
  13. package/esm2022/menubar/menubar.mjs +168 -144
  14. package/esm2022/multiselect/multiselect.mjs +2 -1
  15. package/esm2022/overlaypanel/overlaypanel.mjs +9 -3
  16. package/esm2022/panelmenu/panelmenu.mjs +135 -106
  17. package/esm2022/splitbutton/splitbutton.interface.mjs +1 -1
  18. package/esm2022/splitbutton/splitbutton.mjs +70 -14
  19. package/esm2022/tabmenu/tabmenu.mjs +17 -25
  20. package/esm2022/tabview/tabview.mjs +3 -3
  21. package/esm2022/tieredmenu/tieredmenu.mjs +168 -144
  22. package/esm2022/treetable/treetable.mjs +1 -1
  23. package/fesm2022/primeng-breadcrumb.mjs +43 -16
  24. package/fesm2022/primeng-breadcrumb.mjs.map +1 -1
  25. package/fesm2022/primeng-button.mjs +1 -1
  26. package/fesm2022/primeng-button.mjs.map +1 -1
  27. package/fesm2022/primeng-carousel.mjs +1 -0
  28. package/fesm2022/primeng-carousel.mjs.map +1 -1
  29. package/fesm2022/primeng-contextmenu.mjs +167 -143
  30. package/fesm2022/primeng-contextmenu.mjs.map +1 -1
  31. package/fesm2022/primeng-galleria.mjs +2 -2
  32. package/fesm2022/primeng-galleria.mjs.map +1 -1
  33. package/fesm2022/primeng-image.mjs +10 -3
  34. package/fesm2022/primeng-image.mjs.map +1 -1
  35. package/fesm2022/primeng-megamenu.mjs +167 -143
  36. package/fesm2022/primeng-megamenu.mjs.map +1 -1
  37. package/fesm2022/primeng-menu.mjs +146 -94
  38. package/fesm2022/primeng-menu.mjs.map +1 -1
  39. package/fesm2022/primeng-menubar.mjs +167 -143
  40. package/fesm2022/primeng-menubar.mjs.map +1 -1
  41. package/fesm2022/primeng-multiselect.mjs +1 -0
  42. package/fesm2022/primeng-multiselect.mjs.map +1 -1
  43. package/fesm2022/primeng-overlaypanel.mjs +8 -2
  44. package/fesm2022/primeng-overlaypanel.mjs.map +1 -1
  45. package/fesm2022/primeng-panelmenu.mjs +134 -105
  46. package/fesm2022/primeng-panelmenu.mjs.map +1 -1
  47. package/fesm2022/primeng-splitbutton.mjs +69 -13
  48. package/fesm2022/primeng-splitbutton.mjs.map +1 -1
  49. package/fesm2022/primeng-tabmenu.mjs +16 -24
  50. package/fesm2022/primeng-tabmenu.mjs.map +1 -1
  51. package/fesm2022/primeng-tabview.mjs +2 -2
  52. package/fesm2022/primeng-tabview.mjs.map +1 -1
  53. package/fesm2022/primeng-tieredmenu.mjs +167 -143
  54. package/fesm2022/primeng-tieredmenu.mjs.map +1 -1
  55. package/fesm2022/primeng-treetable.mjs.map +1 -1
  56. package/image/image.d.ts +6 -1
  57. package/megamenu/megamenu.d.ts +3 -1
  58. package/menu/menu.d.ts +11 -5
  59. package/menubar/menubar.d.ts +3 -1
  60. package/overlaypanel/overlaypanel.d.ts +1 -0
  61. package/package.json +90 -90
  62. package/panelmenu/panelmenu.d.ts +5 -2
  63. package/splitbutton/splitbutton.d.ts +10 -1
  64. package/splitbutton/splitbutton.interface.d.ts +15 -0
  65. package/tabmenu/tabmenu.d.ts +2 -2
  66. package/tieredmenu/tieredmenu.d.ts +3 -1
  67. package/treetable/treetable.d.ts +1 -1
@@ -24,6 +24,7 @@ class ContextMenuSub {
24
24
  ref;
25
25
  visible = false;
26
26
  items;
27
+ itemTemplate;
27
28
  root = false;
28
29
  autoZIndex = true;
29
30
  baseZIndex = 0;
@@ -129,7 +130,7 @@ class ContextMenuSub {
129
130
  }
130
131
  }
131
132
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: ContextMenuSub, deps: [{ token: DOCUMENT }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }, { token: forwardRef(() => ContextMenu) }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component });
132
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: ContextMenuSub, selector: "p-contextMenuSub", inputs: { visible: "visible", items: "items", root: "root", 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 }], ngImport: i0, template: `
133
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.2", type: ContextMenuSub, selector: "p-contextMenuSub", inputs: { visible: "visible", items: "items", itemTemplate: "itemTemplate", root: "root", 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 }], ngImport: i0, template: `
133
134
  <ul
134
135
  *ngIf="root ? true : visible"
135
136
  #sublist
@@ -180,88 +181,94 @@ class ContextMenuSub {
180
181
  [tooltipOptions]="getItemProp(processedItem, 'tooltipOptions')"
181
182
  >
182
183
  <div [attr.data-pc-section]="'content'" class="p-menuitem-content" (click)="onItemClick($event, processedItem)" (mouseenter)="onItemMouseEnter({$event, processedItem})">
183
- <a
184
- *ngIf="!getItemProp(processedItem, 'routerLink')"
185
- [attr.href]="getItemProp(processedItem, 'url')"
186
- [attr.aria-hidden]="true"
187
- [attr.data-automationid]="getItemProp(processedItem, 'automationId')"
188
- [attr.data-pc-section]="'action'"
189
- [target]="getItemProp(processedItem, 'target')"
190
- [ngClass]="{ 'p-menuitem-link': true, 'p-disabled': getItemProp(processedItem, 'disabled') }"
191
- [attr.tabindex]="-1"
192
- pRipple
193
- >
194
- <span
195
- *ngIf="getItemProp(processedItem, 'icon')"
196
- class="p-menuitem-icon"
197
- [ngClass]="getItemProp(processedItem, 'icon')"
198
- [ngStyle]="getItemProp(processedItem, 'iconStyle')"
199
- [attr.data-pc-section]="'icon'"
184
+ <ng-container *ngIf="!itemTemplate">
185
+ <a
186
+ *ngIf="!getItemProp(processedItem, 'routerLink')"
187
+ [attr.href]="getItemProp(processedItem, 'url')"
200
188
  [attr.aria-hidden]="true"
189
+ [attr.data-automationid]="getItemProp(processedItem, 'automationId')"
190
+ [attr.data-pc-section]="'action'"
191
+ [target]="getItemProp(processedItem, 'target')"
192
+ [ngClass]="{ 'p-menuitem-link': true, 'p-disabled': getItemProp(processedItem, 'disabled') }"
201
193
  [attr.tabindex]="-1"
194
+ pRipple
202
195
  >
203
- </span>
204
- <span *ngIf="getItemProp(processedItem, 'escape'); else htmlLabel" class="p-menuitem-text" [attr.data-pc-section]="'label'">
205
- {{ getItemLabel(processedItem) }}
206
- </span>
207
- <ng-template #htmlLabel>
208
- <span class="p-menuitem-text" [innerHTML]="getItemLabel(processedItem)" [attr.data-pc-section]="'label'"></span>
209
- </ng-template>
210
- <span class="p-menuitem-badge" *ngIf="getItemProp(processedItem, 'badge')" [ngClass]="getItemProp(processedItem, 'badgeStyleClass')">{{ getItemProp(processedItem, 'badge') }}</span>
196
+ <span
197
+ *ngIf="getItemProp(processedItem, 'icon')"
198
+ class="p-menuitem-icon"
199
+ [ngClass]="getItemProp(processedItem, 'icon')"
200
+ [ngStyle]="getItemProp(processedItem, 'iconStyle')"
201
+ [attr.data-pc-section]="'icon'"
202
+ [attr.aria-hidden]="true"
203
+ [attr.tabindex]="-1"
204
+ >
205
+ </span>
206
+ <span *ngIf="getItemProp(processedItem, 'escape'); else htmlLabel" class="p-menuitem-text" [attr.data-pc-section]="'label'">
207
+ {{ getItemLabel(processedItem) }}
208
+ </span>
209
+ <ng-template #htmlLabel>
210
+ <span class="p-menuitem-text" [innerHTML]="getItemLabel(processedItem)" [attr.data-pc-section]="'label'"></span>
211
+ </ng-template>
212
+ <span class="p-menuitem-badge" *ngIf="getItemProp(processedItem, 'badge')" [ngClass]="getItemProp(processedItem, 'badgeStyleClass')">{{ getItemProp(processedItem, 'badge') }}</span>
211
213
 
212
- <ng-container *ngIf="isItemGroup(processedItem)">
213
- <AngleRightIcon *ngIf="!contextMenu.submenuIconTemplate" [styleClass]="'p-submenu-icon'" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true" />
214
- <ng-template *ngTemplateOutlet="contextMenu.submenuIconTemplate" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true"></ng-template>
215
- </ng-container>
216
- </a>
217
- <a
218
- *ngIf="getItemProp(processedItem, 'routerLink')"
219
- [routerLink]="getItemProp(processedItem, 'routerLink')"
220
- [attr.data-automationid]="getItemProp(processedItem, 'automationId')"
221
- [attr.tabindex]="-1"
222
- [attr.aria-hidden]="true"
223
- [attr.data-pc-section]="'action'"
224
- [queryParams]="getItemProp(processedItem, 'queryParams')"
225
- [routerLinkActive]="'p-menuitem-link-active'"
226
- [routerLinkActiveOptions]="getItemProp(processedItem, 'routerLinkActiveOptions') || { exact: false }"
227
- [target]="getItemProp(processedItem, 'target')"
228
- [ngClass]="{ 'p-menuitem-link': true, 'p-disabled': getItemProp(processedItem, 'disabled') }"
229
- [fragment]="getItemProp(processedItem, 'fragment')"
230
- [queryParamsHandling]="getItemProp(processedItem, 'queryParamsHandling')"
231
- [preserveFragment]="getItemProp(processedItem, 'preserveFragment')"
232
- [skipLocationChange]="getItemProp(processedItem, 'skipLocationChange')"
233
- [replaceUrl]="getItemProp(processedItem, 'replaceUrl')"
234
- [state]="getItemProp(processedItem, 'state')"
235
- pRipple
236
- >
237
- <span
238
- *ngIf="getItemProp(processedItem, 'icon')"
239
- class="p-menuitem-icon"
240
- [ngClass]="getItemProp(processedItem, 'icon')"
241
- [ngStyle]="getItemProp(processedItem, 'iconStyle')"
242
- [attr.data-pc-section]="'icon'"
243
- [attr.aria-hidden]="true"
214
+ <ng-container *ngIf="isItemGroup(processedItem)">
215
+ <AngleRightIcon *ngIf="!contextMenu.submenuIconTemplate" [styleClass]="'p-submenu-icon'" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true" />
216
+ <ng-template *ngTemplateOutlet="contextMenu.submenuIconTemplate" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true"></ng-template>
217
+ </ng-container>
218
+ </a>
219
+ <a
220
+ *ngIf="getItemProp(processedItem, 'routerLink')"
221
+ [routerLink]="getItemProp(processedItem, 'routerLink')"
222
+ [attr.data-automationid]="getItemProp(processedItem, 'automationId')"
244
223
  [attr.tabindex]="-1"
224
+ [attr.aria-hidden]="true"
225
+ [attr.data-pc-section]="'action'"
226
+ [queryParams]="getItemProp(processedItem, 'queryParams')"
227
+ [routerLinkActive]="'p-menuitem-link-active'"
228
+ [routerLinkActiveOptions]="getItemProp(processedItem, 'routerLinkActiveOptions') || { exact: false }"
229
+ [target]="getItemProp(processedItem, 'target')"
230
+ [ngClass]="{ 'p-menuitem-link': true, 'p-disabled': getItemProp(processedItem, 'disabled') }"
231
+ [fragment]="getItemProp(processedItem, 'fragment')"
232
+ [queryParamsHandling]="getItemProp(processedItem, 'queryParamsHandling')"
233
+ [preserveFragment]="getItemProp(processedItem, 'preserveFragment')"
234
+ [skipLocationChange]="getItemProp(processedItem, 'skipLocationChange')"
235
+ [replaceUrl]="getItemProp(processedItem, 'replaceUrl')"
236
+ [state]="getItemProp(processedItem, 'state')"
237
+ pRipple
245
238
  >
246
- </span>
247
- <span *ngIf="getItemProp(processedItem, 'escape'); else htmlLabel" class="p-menuitem-text" [attr.data-pc-section]="'label'">
248
- {{ getItemLabel(processedItem) }}
249
- </span>
250
- <ng-template #htmlLabel>
251
- <span class="p-menuitem-text" [innerHTML]="getItemLabel(processedItem)" [attr.data-pc-section]="'label'"></span>
252
- </ng-template>
253
- <span class="p-menuitem-badge" *ngIf="getItemProp(processedItem, 'badge')" [ngClass]="getItemProp(processedItem, 'badgeStyleClass')">{{ getItemProp(processedItem, 'badge') }}</span>
239
+ <span
240
+ *ngIf="getItemProp(processedItem, 'icon')"
241
+ class="p-menuitem-icon"
242
+ [ngClass]="getItemProp(processedItem, 'icon')"
243
+ [ngStyle]="getItemProp(processedItem, 'iconStyle')"
244
+ [attr.data-pc-section]="'icon'"
245
+ [attr.aria-hidden]="true"
246
+ [attr.tabindex]="-1"
247
+ >
248
+ </span>
249
+ <span *ngIf="getItemProp(processedItem, 'escape'); else htmlLabel" class="p-menuitem-text" [attr.data-pc-section]="'label'">
250
+ {{ getItemLabel(processedItem) }}
251
+ </span>
252
+ <ng-template #htmlLabel>
253
+ <span class="p-menuitem-text" [innerHTML]="getItemLabel(processedItem)" [attr.data-pc-section]="'label'"></span>
254
+ </ng-template>
255
+ <span class="p-menuitem-badge" *ngIf="getItemProp(processedItem, 'badge')" [ngClass]="getItemProp(processedItem, 'badgeStyleClass')">{{ getItemProp(processedItem, 'badge') }}</span>
254
256
 
255
- <ng-container *ngIf="isItemGroup(processedItem)">
256
- <AngleRightIcon *ngIf="!contextMenu.submenuIconTemplate" [styleClass]="'p-submenu-icon'" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true" />
257
- <ng-template *ngTemplateOutlet="contextMenu.submenuIconTemplate" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true"></ng-template>
258
- </ng-container>
259
- </a>
257
+ <ng-container *ngIf="isItemGroup(processedItem)">
258
+ <AngleRightIcon *ngIf="!contextMenu.submenuIconTemplate" [styleClass]="'p-submenu-icon'" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true" />
259
+ <ng-template *ngTemplateOutlet="contextMenu.submenuIconTemplate" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true"></ng-template>
260
+ </ng-container>
261
+ </a>
262
+ </ng-container>
263
+ <ng-container *ngIf="itemTemplate">
264
+ <ng-template *ngTemplateOutlet="itemTemplate; context: { $implicit: processedItem.item }"></ng-template>
265
+ </ng-container>
260
266
  </div>
261
267
 
262
268
  <p-contextMenuSub
263
269
  *ngIf="isItemVisible(processedItem) && isItemGroup(processedItem)"
264
270
  [items]="processedItem.items"
271
+ [itemTemplate]="itemTemplate"
265
272
  [menuId]="menuId"
266
273
  [visible]="isItemActive(processedItem) && isItemGroup(processedItem)"
267
274
  [activeItemPath]="activeItemPath"
@@ -273,7 +280,7 @@ class ContextMenuSub {
273
280
  </li>
274
281
  </ng-template>
275
282
  </ul>
276
- `, 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 ContextMenuSub; }), selector: "p-contextMenuSub", inputs: ["visible", "items", "root", "autoZIndex", "baseZIndex", "popup", "menuId", "ariaLabel", "ariaLabelledBy", "level", "focusedItemId", "activeItemPath", "tabindex"], outputs: ["itemClick", "itemMouseEnter", "menuFocus", "menuBlur", "menuKeydown"] }], animations: [trigger('overlayAnimation', [transition(':enter', [style({ opacity: 0 })]), transition(':leave', [style({ opacity: 0 })])])], encapsulation: i0.ViewEncapsulation.None });
283
+ `, 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 ContextMenuSub; }), selector: "p-contextMenuSub", inputs: ["visible", "items", "itemTemplate", "root", "autoZIndex", "baseZIndex", "popup", "menuId", "ariaLabel", "ariaLabelledBy", "level", "focusedItemId", "activeItemPath", "tabindex"], outputs: ["itemClick", "itemMouseEnter", "menuFocus", "menuBlur", "menuKeydown"] }], animations: [trigger('overlayAnimation', [transition(':enter', [style({ opacity: 0 })]), transition(':leave', [style({ opacity: 0 })])])], encapsulation: i0.ViewEncapsulation.None });
277
284
  }
278
285
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: ContextMenuSub, decorators: [{
279
286
  type: Component,
@@ -330,88 +337,94 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
330
337
  [tooltipOptions]="getItemProp(processedItem, 'tooltipOptions')"
331
338
  >
332
339
  <div [attr.data-pc-section]="'content'" class="p-menuitem-content" (click)="onItemClick($event, processedItem)" (mouseenter)="onItemMouseEnter({$event, processedItem})">
333
- <a
334
- *ngIf="!getItemProp(processedItem, 'routerLink')"
335
- [attr.href]="getItemProp(processedItem, 'url')"
336
- [attr.aria-hidden]="true"
337
- [attr.data-automationid]="getItemProp(processedItem, 'automationId')"
338
- [attr.data-pc-section]="'action'"
339
- [target]="getItemProp(processedItem, 'target')"
340
- [ngClass]="{ 'p-menuitem-link': true, 'p-disabled': getItemProp(processedItem, 'disabled') }"
341
- [attr.tabindex]="-1"
342
- pRipple
343
- >
344
- <span
345
- *ngIf="getItemProp(processedItem, 'icon')"
346
- class="p-menuitem-icon"
347
- [ngClass]="getItemProp(processedItem, 'icon')"
348
- [ngStyle]="getItemProp(processedItem, 'iconStyle')"
349
- [attr.data-pc-section]="'icon'"
340
+ <ng-container *ngIf="!itemTemplate">
341
+ <a
342
+ *ngIf="!getItemProp(processedItem, 'routerLink')"
343
+ [attr.href]="getItemProp(processedItem, 'url')"
350
344
  [attr.aria-hidden]="true"
345
+ [attr.data-automationid]="getItemProp(processedItem, 'automationId')"
346
+ [attr.data-pc-section]="'action'"
347
+ [target]="getItemProp(processedItem, 'target')"
348
+ [ngClass]="{ 'p-menuitem-link': true, 'p-disabled': getItemProp(processedItem, 'disabled') }"
351
349
  [attr.tabindex]="-1"
350
+ pRipple
352
351
  >
353
- </span>
354
- <span *ngIf="getItemProp(processedItem, 'escape'); else htmlLabel" class="p-menuitem-text" [attr.data-pc-section]="'label'">
355
- {{ getItemLabel(processedItem) }}
356
- </span>
357
- <ng-template #htmlLabel>
358
- <span class="p-menuitem-text" [innerHTML]="getItemLabel(processedItem)" [attr.data-pc-section]="'label'"></span>
359
- </ng-template>
360
- <span class="p-menuitem-badge" *ngIf="getItemProp(processedItem, 'badge')" [ngClass]="getItemProp(processedItem, 'badgeStyleClass')">{{ getItemProp(processedItem, 'badge') }}</span>
352
+ <span
353
+ *ngIf="getItemProp(processedItem, 'icon')"
354
+ class="p-menuitem-icon"
355
+ [ngClass]="getItemProp(processedItem, 'icon')"
356
+ [ngStyle]="getItemProp(processedItem, 'iconStyle')"
357
+ [attr.data-pc-section]="'icon'"
358
+ [attr.aria-hidden]="true"
359
+ [attr.tabindex]="-1"
360
+ >
361
+ </span>
362
+ <span *ngIf="getItemProp(processedItem, 'escape'); else htmlLabel" class="p-menuitem-text" [attr.data-pc-section]="'label'">
363
+ {{ getItemLabel(processedItem) }}
364
+ </span>
365
+ <ng-template #htmlLabel>
366
+ <span class="p-menuitem-text" [innerHTML]="getItemLabel(processedItem)" [attr.data-pc-section]="'label'"></span>
367
+ </ng-template>
368
+ <span class="p-menuitem-badge" *ngIf="getItemProp(processedItem, 'badge')" [ngClass]="getItemProp(processedItem, 'badgeStyleClass')">{{ getItemProp(processedItem, 'badge') }}</span>
361
369
 
362
- <ng-container *ngIf="isItemGroup(processedItem)">
363
- <AngleRightIcon *ngIf="!contextMenu.submenuIconTemplate" [styleClass]="'p-submenu-icon'" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true" />
364
- <ng-template *ngTemplateOutlet="contextMenu.submenuIconTemplate" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true"></ng-template>
365
- </ng-container>
366
- </a>
367
- <a
368
- *ngIf="getItemProp(processedItem, 'routerLink')"
369
- [routerLink]="getItemProp(processedItem, 'routerLink')"
370
- [attr.data-automationid]="getItemProp(processedItem, 'automationId')"
371
- [attr.tabindex]="-1"
372
- [attr.aria-hidden]="true"
373
- [attr.data-pc-section]="'action'"
374
- [queryParams]="getItemProp(processedItem, 'queryParams')"
375
- [routerLinkActive]="'p-menuitem-link-active'"
376
- [routerLinkActiveOptions]="getItemProp(processedItem, 'routerLinkActiveOptions') || { exact: false }"
377
- [target]="getItemProp(processedItem, 'target')"
378
- [ngClass]="{ 'p-menuitem-link': true, 'p-disabled': getItemProp(processedItem, 'disabled') }"
379
- [fragment]="getItemProp(processedItem, 'fragment')"
380
- [queryParamsHandling]="getItemProp(processedItem, 'queryParamsHandling')"
381
- [preserveFragment]="getItemProp(processedItem, 'preserveFragment')"
382
- [skipLocationChange]="getItemProp(processedItem, 'skipLocationChange')"
383
- [replaceUrl]="getItemProp(processedItem, 'replaceUrl')"
384
- [state]="getItemProp(processedItem, 'state')"
385
- pRipple
386
- >
387
- <span
388
- *ngIf="getItemProp(processedItem, 'icon')"
389
- class="p-menuitem-icon"
390
- [ngClass]="getItemProp(processedItem, 'icon')"
391
- [ngStyle]="getItemProp(processedItem, 'iconStyle')"
392
- [attr.data-pc-section]="'icon'"
393
- [attr.aria-hidden]="true"
370
+ <ng-container *ngIf="isItemGroup(processedItem)">
371
+ <AngleRightIcon *ngIf="!contextMenu.submenuIconTemplate" [styleClass]="'p-submenu-icon'" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true" />
372
+ <ng-template *ngTemplateOutlet="contextMenu.submenuIconTemplate" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true"></ng-template>
373
+ </ng-container>
374
+ </a>
375
+ <a
376
+ *ngIf="getItemProp(processedItem, 'routerLink')"
377
+ [routerLink]="getItemProp(processedItem, 'routerLink')"
378
+ [attr.data-automationid]="getItemProp(processedItem, 'automationId')"
394
379
  [attr.tabindex]="-1"
380
+ [attr.aria-hidden]="true"
381
+ [attr.data-pc-section]="'action'"
382
+ [queryParams]="getItemProp(processedItem, 'queryParams')"
383
+ [routerLinkActive]="'p-menuitem-link-active'"
384
+ [routerLinkActiveOptions]="getItemProp(processedItem, 'routerLinkActiveOptions') || { exact: false }"
385
+ [target]="getItemProp(processedItem, 'target')"
386
+ [ngClass]="{ 'p-menuitem-link': true, 'p-disabled': getItemProp(processedItem, 'disabled') }"
387
+ [fragment]="getItemProp(processedItem, 'fragment')"
388
+ [queryParamsHandling]="getItemProp(processedItem, 'queryParamsHandling')"
389
+ [preserveFragment]="getItemProp(processedItem, 'preserveFragment')"
390
+ [skipLocationChange]="getItemProp(processedItem, 'skipLocationChange')"
391
+ [replaceUrl]="getItemProp(processedItem, 'replaceUrl')"
392
+ [state]="getItemProp(processedItem, 'state')"
393
+ pRipple
395
394
  >
396
- </span>
397
- <span *ngIf="getItemProp(processedItem, 'escape'); else htmlLabel" class="p-menuitem-text" [attr.data-pc-section]="'label'">
398
- {{ getItemLabel(processedItem) }}
399
- </span>
400
- <ng-template #htmlLabel>
401
- <span class="p-menuitem-text" [innerHTML]="getItemLabel(processedItem)" [attr.data-pc-section]="'label'"></span>
402
- </ng-template>
403
- <span class="p-menuitem-badge" *ngIf="getItemProp(processedItem, 'badge')" [ngClass]="getItemProp(processedItem, 'badgeStyleClass')">{{ getItemProp(processedItem, 'badge') }}</span>
395
+ <span
396
+ *ngIf="getItemProp(processedItem, 'icon')"
397
+ class="p-menuitem-icon"
398
+ [ngClass]="getItemProp(processedItem, 'icon')"
399
+ [ngStyle]="getItemProp(processedItem, 'iconStyle')"
400
+ [attr.data-pc-section]="'icon'"
401
+ [attr.aria-hidden]="true"
402
+ [attr.tabindex]="-1"
403
+ >
404
+ </span>
405
+ <span *ngIf="getItemProp(processedItem, 'escape'); else htmlLabel" class="p-menuitem-text" [attr.data-pc-section]="'label'">
406
+ {{ getItemLabel(processedItem) }}
407
+ </span>
408
+ <ng-template #htmlLabel>
409
+ <span class="p-menuitem-text" [innerHTML]="getItemLabel(processedItem)" [attr.data-pc-section]="'label'"></span>
410
+ </ng-template>
411
+ <span class="p-menuitem-badge" *ngIf="getItemProp(processedItem, 'badge')" [ngClass]="getItemProp(processedItem, 'badgeStyleClass')">{{ getItemProp(processedItem, 'badge') }}</span>
404
412
 
405
- <ng-container *ngIf="isItemGroup(processedItem)">
406
- <AngleRightIcon *ngIf="!contextMenu.submenuIconTemplate" [styleClass]="'p-submenu-icon'" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true" />
407
- <ng-template *ngTemplateOutlet="contextMenu.submenuIconTemplate" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true"></ng-template>
408
- </ng-container>
409
- </a>
413
+ <ng-container *ngIf="isItemGroup(processedItem)">
414
+ <AngleRightIcon *ngIf="!contextMenu.submenuIconTemplate" [styleClass]="'p-submenu-icon'" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true" />
415
+ <ng-template *ngTemplateOutlet="contextMenu.submenuIconTemplate" [attr.data-pc-section]="'submenuicon'" [attr.aria-hidden]="true"></ng-template>
416
+ </ng-container>
417
+ </a>
418
+ </ng-container>
419
+ <ng-container *ngIf="itemTemplate">
420
+ <ng-template *ngTemplateOutlet="itemTemplate; context: { $implicit: processedItem.item }"></ng-template>
421
+ </ng-container>
410
422
  </div>
411
423
 
412
424
  <p-contextMenuSub
413
425
  *ngIf="isItemVisible(processedItem) && isItemGroup(processedItem)"
414
426
  [items]="processedItem.items"
427
+ [itemTemplate]="itemTemplate"
415
428
  [menuId]="menuId"
416
429
  [visible]="isItemActive(processedItem) && isItemGroup(processedItem)"
417
430
  [activeItemPath]="activeItemPath"
@@ -440,6 +453,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
440
453
  type: Input
441
454
  }], items: [{
442
455
  type: Input
456
+ }], itemTemplate: [{
457
+ type: Input
443
458
  }], root: [{
444
459
  type: Input
445
460
  }], autoZIndex: [{
@@ -568,6 +583,7 @@ class ContextMenu {
568
583
  rootmenu;
569
584
  containerViewChild;
570
585
  submenuIconTemplate;
586
+ itemTemplate;
571
587
  container;
572
588
  outsideClickListener;
573
589
  resizeListener;
@@ -668,6 +684,12 @@ class ContextMenu {
668
684
  case 'submenuicon':
669
685
  this.submenuIconTemplate = item.template;
670
686
  break;
687
+ case 'item':
688
+ this.itemTemplate = item.template;
689
+ break;
690
+ default:
691
+ this.itemTemplate = item.template;
692
+ break;
671
693
  }
672
694
  });
673
695
  }
@@ -1120,6 +1142,7 @@ class ContextMenu {
1120
1142
  #rootmenu
1121
1143
  [root]="true"
1122
1144
  [items]="processedItems"
1145
+ [itemTemplate]="itemTemplate"
1123
1146
  [menuId]="id"
1124
1147
  [tabindex]="!disabled ? tabindex : -1"
1125
1148
  [ariaLabel]="ariaLabel"
@@ -1136,7 +1159,7 @@ class ContextMenu {
1136
1159
  (itemMouseEnter)="onItemMouseEnter($event)"
1137
1160
  ></p-contextMenuSub>
1138
1161
  </div>
1139
- `, isInline: true, styles: ["@layer primeng{.p-contextmenu{position:absolute}.p-contextmenu ul{margin:0;padding:0;list-style:none}.p-contextmenu .p-submenu-list{position:absolute;min-width:100%;z-index:1}.p-contextmenu .p-menuitem-link{cursor:pointer;display:flex;align-items:center;text-decoration:none;overflow:hidden;position:relative}.p-contextmenu .p-menuitem-text{line-height:1}.p-contextmenu .p-menuitem{position:relative}.p-contextmenu .p-menuitem-link .p-submenu-icon:not(svg){margin-left:auto}.p-contextmenu .p-menuitem-link .p-icon-wrapper{margin-left:auto}}\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: ContextMenuSub, selector: "p-contextMenuSub", inputs: ["visible", "items", "root", "autoZIndex", "baseZIndex", "popup", "menuId", "ariaLabel", "ariaLabelledBy", "level", "focusedItemId", "activeItemPath", "tabindex"], outputs: ["itemClick", "itemMouseEnter", "menuFocus", "menuBlur", "menuKeydown"] }], animations: [trigger('overlayAnimation', [transition(':enter', [style({ opacity: 0 }), animate('250ms')]), transition(':leave', [animate('.1s linear', style({ opacity: 0 }))])])], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
1162
+ `, isInline: true, styles: ["@layer primeng{.p-contextmenu{position:absolute}.p-contextmenu ul{margin:0;padding:0;list-style:none}.p-contextmenu .p-submenu-list{position:absolute;min-width:100%;z-index:1}.p-contextmenu .p-menuitem-link{cursor:pointer;display:flex;align-items:center;text-decoration:none;overflow:hidden;position:relative}.p-contextmenu .p-menuitem-text{line-height:1}.p-contextmenu .p-menuitem{position:relative}.p-contextmenu .p-menuitem-link .p-submenu-icon:not(svg){margin-left:auto}.p-contextmenu .p-menuitem-link .p-icon-wrapper{margin-left:auto}}\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: ContextMenuSub, selector: "p-contextMenuSub", inputs: ["visible", "items", "itemTemplate", "root", "autoZIndex", "baseZIndex", "popup", "menuId", "ariaLabel", "ariaLabelledBy", "level", "focusedItemId", "activeItemPath", "tabindex"], outputs: ["itemClick", "itemMouseEnter", "menuFocus", "menuBlur", "menuKeydown"] }], animations: [trigger('overlayAnimation', [transition(':enter', [style({ opacity: 0 }), animate('250ms')]), transition(':leave', [animate('.1s linear', style({ opacity: 0 }))])])], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
1140
1163
  }
1141
1164
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: ContextMenu, decorators: [{
1142
1165
  type: Component,
@@ -1158,6 +1181,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
1158
1181
  #rootmenu
1159
1182
  [root]="true"
1160
1183
  [items]="processedItems"
1184
+ [itemTemplate]="itemTemplate"
1161
1185
  [menuId]="id"
1162
1186
  [tabindex]="!disabled ? tabindex : -1"
1163
1187
  [ariaLabel]="ariaLabel"