primeng 16.9.13-lts → 16.9.15-lts

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 (52) hide show
  1. package/badge/badge.d.ts +37 -16
  2. package/esm2022/autocomplete/autocomplete.mjs +7 -6
  3. package/esm2022/badge/badge.mjs +145 -68
  4. package/esm2022/breadcrumb/breadcrumb.mjs +31 -11
  5. package/esm2022/calendar/calendar.mjs +10 -4
  6. package/esm2022/colorpicker/colorpicker.mjs +6 -4
  7. package/esm2022/listbox/listbox.mjs +24 -44
  8. package/esm2022/menu/menu.mjs +2 -6
  9. package/esm2022/menubar/menubar.mjs +13 -21
  10. package/esm2022/overlay/overlay.mjs +8 -7
  11. package/esm2022/scroller/scroller.mjs +2 -2
  12. package/esm2022/sidebar/sidebar.mjs +5 -2
  13. package/esm2022/slider/slider.mjs +3 -1
  14. package/esm2022/table/table.mjs +34 -31
  15. package/esm2022/tieredmenu/tieredmenu.mjs +4 -1
  16. package/esm2022/tooltip/tooltip.mjs +4 -10
  17. package/esm2022/tree/tree.mjs +6 -4
  18. package/fesm2022/primeng-autocomplete.mjs +6 -5
  19. package/fesm2022/primeng-autocomplete.mjs.map +1 -1
  20. package/fesm2022/primeng-badge.mjs +144 -67
  21. package/fesm2022/primeng-badge.mjs.map +1 -1
  22. package/fesm2022/primeng-breadcrumb.mjs +30 -10
  23. package/fesm2022/primeng-breadcrumb.mjs.map +1 -1
  24. package/fesm2022/primeng-calendar.mjs +9 -3
  25. package/fesm2022/primeng-calendar.mjs.map +1 -1
  26. package/fesm2022/primeng-colorpicker.mjs +5 -3
  27. package/fesm2022/primeng-colorpicker.mjs.map +1 -1
  28. package/fesm2022/primeng-listbox.mjs +23 -43
  29. package/fesm2022/primeng-listbox.mjs.map +1 -1
  30. package/fesm2022/primeng-menu.mjs +1 -5
  31. package/fesm2022/primeng-menu.mjs.map +1 -1
  32. package/fesm2022/primeng-menubar.mjs +12 -20
  33. package/fesm2022/primeng-menubar.mjs.map +1 -1
  34. package/fesm2022/primeng-overlay.mjs +7 -6
  35. package/fesm2022/primeng-overlay.mjs.map +1 -1
  36. package/fesm2022/primeng-scroller.mjs +1 -1
  37. package/fesm2022/primeng-scroller.mjs.map +1 -1
  38. package/fesm2022/primeng-sidebar.mjs +4 -1
  39. package/fesm2022/primeng-sidebar.mjs.map +1 -1
  40. package/fesm2022/primeng-slider.mjs +2 -0
  41. package/fesm2022/primeng-slider.mjs.map +1 -1
  42. package/fesm2022/primeng-table.mjs +33 -30
  43. package/fesm2022/primeng-table.mjs.map +1 -1
  44. package/fesm2022/primeng-tieredmenu.mjs +3 -0
  45. package/fesm2022/primeng-tieredmenu.mjs.map +1 -1
  46. package/fesm2022/primeng-tooltip.mjs +3 -9
  47. package/fesm2022/primeng-tooltip.mjs.map +1 -1
  48. package/fesm2022/primeng-tree.mjs +5 -3
  49. package/fesm2022/primeng-tree.mjs.map +1 -1
  50. package/listbox/listbox.d.ts +3 -0
  51. package/package.json +72 -72
  52. package/table/table.d.ts +3 -1
@@ -22,107 +22,129 @@ class BadgeDirective {
22
22
  * When specified, disables the component.
23
23
  * @group Props
24
24
  */
25
- get disabled() {
26
- return this._disabled;
27
- }
28
- set disabled(val) {
29
- this._disabled = val;
30
- }
25
+ disabled;
31
26
  /**
32
27
  * Size of the badge, valid options are "large" and "xlarge".
33
28
  * @group Props
34
29
  */
35
- get size() {
36
- return this._size;
37
- }
38
- set size(val) {
39
- this._size = val;
40
- if (this.initialized) {
41
- this.setSizeClasses();
42
- }
43
- }
30
+ badgeSize;
44
31
  /**
45
- * Value to display inside the badge.
32
+ * Size of the badge, valid options are "large" and "xlarge".
46
33
  * @group Props
34
+ * @deprecated use badgeSize instead.
47
35
  */
48
- get value() {
49
- return this._value;
36
+ set size(value) {
37
+ this._size = value;
38
+ console.warn('size property is deprecated and will removed in v18, use badgeSize instead.');
50
39
  }
51
- set value(val) {
52
- if (val !== this._value) {
53
- this._value = val;
54
- if (this.initialized) {
55
- let badge = document.getElementById(this.id);
56
- if (this._value) {
57
- if (DomHandler.hasClass(badge, 'p-badge-dot'))
58
- DomHandler.removeClass(badge, 'p-badge-dot');
59
- if (String(this._value).length === 1) {
60
- DomHandler.addClass(badge, 'p-badge-no-gutter');
61
- }
62
- else {
63
- DomHandler.removeClass(badge, 'p-badge-no-gutter');
64
- }
65
- }
66
- else if (!this._value && !DomHandler.hasClass(badge, 'p-badge-dot')) {
67
- DomHandler.addClass(badge, 'p-badge-dot');
68
- }
69
- badge.innerHTML = '';
70
- this.renderer.appendChild(badge, document.createTextNode(this._value));
71
- }
72
- }
40
+ get size() {
41
+ return this._size;
73
42
  }
43
+ _size;
74
44
  /**
75
45
  * Severity type of the badge.
76
46
  * @group Props
77
47
  */
78
48
  severity;
79
- _value;
80
- initialized = false;
49
+ /**
50
+ * Value to display inside the badge.
51
+ * @group Props
52
+ */
53
+ value;
54
+ /**
55
+ * Inline style of the element.
56
+ * @group Props
57
+ */
58
+ badgeStyle;
59
+ /**
60
+ * Class of the element.
61
+ * @group Props
62
+ */
63
+ badgeStyleClass;
81
64
  id;
82
- _disabled = false;
83
- _size;
65
+ badgeEl;
66
+ get activeElement() {
67
+ return this.el.nativeElement.nodeName.indexOf('-') != -1 ? this.el.nativeElement.firstChild : this.el.nativeElement;
68
+ }
69
+ get canUpdateBadge() {
70
+ return this.id && !this.disabled;
71
+ }
84
72
  constructor(document, el, renderer) {
85
73
  this.document = document;
86
74
  this.el = el;
87
75
  this.renderer = renderer;
88
76
  }
77
+ ngOnChanges({ value, size, severity, disabled, badgeStyle, badgeStyleClass }) {
78
+ if (disabled) {
79
+ this.toggleDisableState();
80
+ }
81
+ if (!this.canUpdateBadge) {
82
+ return;
83
+ }
84
+ if (severity) {
85
+ this.setSeverity(severity.previousValue);
86
+ }
87
+ if (size) {
88
+ this.setSizeClasses();
89
+ }
90
+ if (value) {
91
+ this.setValue();
92
+ }
93
+ if (badgeStyle || badgeStyleClass) {
94
+ this.applyStyles();
95
+ }
96
+ }
89
97
  ngAfterViewInit() {
90
98
  this.id = UniqueComponentId() + '_badge';
91
- let el = this.el.nativeElement.nodeName.indexOf('-') != -1 ? this.el.nativeElement.firstChild : this.el.nativeElement;
92
- if (this._disabled) {
93
- return null;
94
- }
95
- let badge = this.document.createElement('span');
96
- badge.id = this.id;
97
- badge.className = 'p-badge p-component';
98
- if (this.severity) {
99
- DomHandler.addClass(badge, 'p-badge-' + this.severity);
99
+ this.renderBadgeContent();
100
+ }
101
+ setValue(element) {
102
+ const badge = element ?? this.document.getElementById(this.id);
103
+ if (!badge) {
104
+ return;
100
105
  }
101
- this.setSizeClasses(badge);
102
106
  if (this.value != null) {
103
- this.renderer.appendChild(badge, this.document.createTextNode(this.value));
104
- if (String(this.value).length === 1) {
107
+ if (DomHandler.hasClass(badge, 'p-badge-dot')) {
108
+ DomHandler.removeClass(badge, 'p-badge-dot');
109
+ }
110
+ if (this.value && String(this.value).length === 1) {
105
111
  DomHandler.addClass(badge, 'p-badge-no-gutter');
106
112
  }
113
+ else {
114
+ DomHandler.removeClass(badge, 'p-badge-no-gutter');
115
+ }
107
116
  }
108
117
  else {
109
- DomHandler.addClass(badge, 'p-badge-dot');
118
+ if (!DomHandler.hasClass(badge, 'p-badge-dot')) {
119
+ DomHandler.addClass(badge, 'p-badge-dot');
120
+ }
121
+ DomHandler.removeClass(badge, 'p-badge-no-gutter');
110
122
  }
111
- DomHandler.addClass(el, 'p-overlay-badge');
112
- this.renderer.appendChild(el, badge);
113
- this.initialized = true;
123
+ badge.innerHTML = '';
124
+ const badgeValue = this.value != null ? String(this.value) : '';
125
+ this.renderer.appendChild(badge, this.document.createTextNode(badgeValue));
114
126
  }
115
127
  setSizeClasses(element) {
116
128
  const badge = element ?? this.document.getElementById(this.id);
117
129
  if (!badge) {
118
130
  return;
119
131
  }
120
- if (this._size) {
121
- if (this._size === 'large') {
132
+ if (this.badgeSize) {
133
+ if (this.badgeSize === 'large') {
134
+ DomHandler.addClass(badge, 'p-badge-lg');
135
+ DomHandler.removeClass(badge, 'p-badge-xl');
136
+ }
137
+ if (this.badgeSize === 'xlarge') {
138
+ DomHandler.addClass(badge, 'p-badge-xl');
139
+ DomHandler.removeClass(badge, 'p-badge-lg');
140
+ }
141
+ }
142
+ else if (this.size && !this.badgeSize) {
143
+ if (this.size === 'large') {
122
144
  DomHandler.addClass(badge, 'p-badge-lg');
123
145
  DomHandler.removeClass(badge, 'p-badge-xl');
124
146
  }
125
- if (this._size === 'xlarge') {
147
+ if (this.size === 'xlarge') {
126
148
  DomHandler.addClass(badge, 'p-badge-xl');
127
149
  DomHandler.removeClass(badge, 'p-badge-lg');
128
150
  }
@@ -132,11 +154,60 @@ class BadgeDirective {
132
154
  DomHandler.removeClass(badge, 'p-badge-xl');
133
155
  }
134
156
  }
135
- ngOnDestroy() {
136
- this.initialized = false;
157
+ renderBadgeContent() {
158
+ if (this.disabled) {
159
+ return null;
160
+ }
161
+ const el = this.activeElement;
162
+ const badge = this.document.createElement('span');
163
+ badge.id = this.id;
164
+ badge.className = 'p-badge p-component';
165
+ this.setSeverity(null, badge);
166
+ this.setSizeClasses(badge);
167
+ this.setValue(badge);
168
+ DomHandler.addClass(el, 'p-overlay-badge');
169
+ this.renderer.appendChild(el, badge);
170
+ this.badgeEl = badge;
171
+ this.applyStyles();
172
+ }
173
+ applyStyles() {
174
+ if (this.badgeEl && this.badgeStyle && typeof this.badgeStyle === 'object') {
175
+ for (const [key, value] of Object.entries(this.badgeStyle)) {
176
+ this.renderer.setStyle(this.badgeEl, key, value);
177
+ }
178
+ }
179
+ if (this.badgeEl && this.badgeStyleClass) {
180
+ this.badgeEl.classList.add(...this.badgeStyleClass.split(' '));
181
+ }
182
+ }
183
+ setSeverity(oldSeverity, element) {
184
+ const badge = element ?? this.document.getElementById(this.id);
185
+ if (!badge) {
186
+ return;
187
+ }
188
+ if (this.severity) {
189
+ DomHandler.addClass(badge, `p-badge-${this.severity}`);
190
+ }
191
+ if (oldSeverity) {
192
+ DomHandler.removeClass(badge, `p-badge-${oldSeverity}`);
193
+ }
194
+ }
195
+ toggleDisableState() {
196
+ if (!this.id) {
197
+ return;
198
+ }
199
+ if (this.disabled) {
200
+ const badge = this.activeElement?.querySelector(`#${this.id}`);
201
+ if (badge) {
202
+ this.renderer.removeChild(this.activeElement, badge);
203
+ }
204
+ }
205
+ else {
206
+ this.renderBadgeContent();
207
+ }
137
208
  }
138
209
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: BadgeDirective, deps: [{ token: DOCUMENT }, { token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
139
- static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.0", type: BadgeDirective, selector: "[pBadge]", inputs: { iconPos: "iconPos", disabled: ["badgeDisabled", "disabled"], size: "size", value: "value", severity: "severity" }, host: { classAttribute: "p-element" }, ngImport: i0 });
210
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.0", type: BadgeDirective, selector: "[pBadge]", inputs: { iconPos: "iconPos", disabled: ["badgeDisabled", "disabled"], badgeSize: "badgeSize", size: "size", severity: "severity", value: "value", badgeStyle: "badgeStyle", badgeStyleClass: "badgeStyleClass" }, host: { classAttribute: "p-element" }, usesOnChanges: true, ngImport: i0 });
140
211
  }
141
212
  export { BadgeDirective };
142
213
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: BadgeDirective, decorators: [{
@@ -155,11 +226,17 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImpor
155
226
  }], disabled: [{
156
227
  type: Input,
157
228
  args: ['badgeDisabled']
229
+ }], badgeSize: [{
230
+ type: Input
158
231
  }], size: [{
159
232
  type: Input
233
+ }], severity: [{
234
+ type: Input
160
235
  }], value: [{
161
236
  type: Input
162
- }], severity: [{
237
+ }], badgeStyle: [{
238
+ type: Input
239
+ }], badgeStyleClass: [{
163
240
  type: Input
164
241
  }] } });
165
242
  /**
@@ -248,4 +325,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImpor
248
325
  declarations: [Badge, BadgeDirective]
249
326
  }]
250
327
  }] });
251
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"badge.js","sourceRoot":"","sources":["../../../src/app/components/badge/badge.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, DOCUMENT } from '@angular/common';\nimport { AfterViewInit, ChangeDetectionStrategy, Component, Directive, ElementRef, Inject, Input, NgModule, OnDestroy, Renderer2, ViewEncapsulation } from '@angular/core';\nimport { SharedModule, LicenseManager } from 'primeng/api';\nimport { DomHandler } from 'primeng/dom';\nimport { UniqueComponentId } from 'primeng/utils';\n/**\n * Badge Directive is directive usage of badge component.\n * @group Components\n */\n@Directive({\n    selector: '[pBadge]',\n    host: {\n        class: 'p-element'\n    }\n})\nexport class BadgeDirective implements AfterViewInit, OnDestroy {\n    /**\n     * Icon position of the component.\n     * @group Props\n     */\n    @Input() iconPos: 'left' | 'right' | 'top' | 'bottom' = 'left';\n    /**\n     * When specified, disables the component.\n     * @group Props\n     */\n    @Input('badgeDisabled') get disabled(): boolean {\n        return this._disabled;\n    }\n    set disabled(val: boolean) {\n        this._disabled = val;\n    }\n    /**\n     * Size of the badge, valid options are \"large\" and \"xlarge\".\n     * @group Props\n     */\n    @Input() public get size(): 'large' | 'xlarge' {\n        return this._size;\n    }\n    set size(val: 'large' | 'xlarge') {\n        this._size = val;\n\n        if (this.initialized) {\n            this.setSizeClasses();\n        }\n    }\n    /**\n     * Value to display inside the badge.\n     * @group Props\n     */\n    @Input() get value(): string {\n        return this._value;\n    }\n    set value(val: string) {\n        if (val !== this._value) {\n            this._value = val;\n\n            if (this.initialized) {\n                let badge: HTMLElement = document.getElementById(this.id) as HTMLElement;\n\n                if (this._value) {\n                    if (DomHandler.hasClass(badge, 'p-badge-dot')) DomHandler.removeClass(badge, 'p-badge-dot');\n\n                    if (String(this._value).length === 1) {\n                        DomHandler.addClass(badge, 'p-badge-no-gutter');\n                    } else {\n                        DomHandler.removeClass(badge, 'p-badge-no-gutter');\n                    }\n                } else if (!this._value && !DomHandler.hasClass(badge, 'p-badge-dot')) {\n                    DomHandler.addClass(badge, 'p-badge-dot');\n                }\n\n                badge.innerHTML = '';\n                this.renderer.appendChild(badge, document.createTextNode(this._value));\n            }\n        }\n    }\n    /**\n     * Severity type of the badge.\n     * @group Props\n     */\n    @Input() severity: 'success' | 'info' | 'warning' | 'danger' | null | undefined;\n\n    public _value!: string;\n\n    public initialized: boolean = false;\n\n    private id!: string;\n\n    private _disabled: boolean = false;\n\n    private _size!: 'large' | 'xlarge';\n\n    constructor(@Inject(DOCUMENT) private document: Document, public el: ElementRef, private renderer: Renderer2) {}\n\n    ngAfterViewInit() {\n        this.id = UniqueComponentId() + '_badge';\n        let el = this.el.nativeElement.nodeName.indexOf('-') != -1 ? this.el.nativeElement.firstChild : this.el.nativeElement;\n\n        if (this._disabled) {\n            return null;\n        }\n\n        let badge = this.document.createElement('span');\n        badge.id = this.id;\n        badge.className = 'p-badge p-component';\n\n        if (this.severity) {\n            DomHandler.addClass(badge, 'p-badge-' + this.severity);\n        }\n\n        this.setSizeClasses(badge);\n\n        if (this.value != null) {\n            this.renderer.appendChild(badge, this.document.createTextNode(this.value));\n\n            if (String(this.value).length === 1) {\n                DomHandler.addClass(badge, 'p-badge-no-gutter');\n            }\n        } else {\n            DomHandler.addClass(badge, 'p-badge-dot');\n        }\n\n        DomHandler.addClass(el, 'p-overlay-badge');\n        this.renderer.appendChild(el, badge);\n\n        this.initialized = true;\n    }\n\n    private setSizeClasses(element?: HTMLElement): void {\n        const badge = element ?? this.document.getElementById(this.id);\n\n        if (!badge) {\n            return;\n        }\n\n        if (this._size) {\n            if (this._size === 'large') {\n                DomHandler.addClass(badge, 'p-badge-lg');\n                DomHandler.removeClass(badge, 'p-badge-xl');\n            }\n\n            if (this._size === 'xlarge') {\n                DomHandler.addClass(badge, 'p-badge-xl');\n                DomHandler.removeClass(badge, 'p-badge-lg');\n            }\n        } else {\n            DomHandler.removeClass(badge, 'p-badge-lg');\n            DomHandler.removeClass(badge, 'p-badge-xl');\n        }\n    }\n\n    ngOnDestroy() {\n        this.initialized = false;\n    }\n}\n/**\n * Badge is a small status indicator for another element.\n * @group Components\n */\n@Component({\n    selector: 'p-badge',\n    template: ` <span *ngIf=\"!badgeDisabled\" [ngClass]=\"containerClass()\" [class]=\"styleClass\" [ngStyle]=\"style\">{{ value }}</span> `,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    styleUrls: ['./badge.css'],\n    host: {\n        class: 'p-element'\n    }\n})\nexport class Badge {\n    /**\n     * Class of the element.\n     * @group Props\n     */\n    @Input() styleClass: string | undefined;\n    /**\n     * Inline style of the element.\n     * @group Props\n     */\n    @Input() style: { [klass: string]: any } | null | undefined;\n    /**\n     * Size of the badge, valid options are \"large\" and \"xlarge\".\n     * @group Props\n     */\n    @Input() size: 'large' | 'xlarge' | undefined;\n    /**\n     * Severity type of the badge.\n     * @group Props\n     */\n    @Input() severity: 'success' | 'info' | 'warning' | 'danger' | null | undefined;\n    /**\n     * Value to display inside the badge.\n     * @group Props\n     */\n    @Input() value: string | null | undefined;\n    /**\n     * When specified, disables the component.\n     * @group Props\n     */\n    @Input() badgeDisabled: boolean = false;\n\n    containerClass() {\n        return {\n            'p-badge p-component': true,\n            'p-badge-no-gutter': this.value != undefined && String(this.value).length === 1,\n            'p-badge-lg': this.size === 'large',\n            'p-badge-xl': this.size === 'xlarge',\n            'p-badge-info': this.severity === 'info',\n            'p-badge-success': this.severity === 'success',\n            'p-badge-warning': this.severity === 'warning',\n            'p-badge-danger': this.severity === 'danger'\n        };\n    }\n\n    ngAfterViewInit() {\n        LicenseManager.check();\n    }\n}\n\n@NgModule({\n    imports: [CommonModule],\n    exports: [Badge, BadgeDirective, SharedModule],\n    declarations: [Badge, BadgeDirective]\n})\nexport class BadgeModule {}\n"]}
328
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"badge.js","sourceRoot":"","sources":["../../../src/app/components/badge/badge.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, DOCUMENT } from '@angular/common';\nimport { AfterViewInit, ChangeDetectionStrategy, Component, Directive, ElementRef, Inject, Input, NgModule, OnChanges, OnDestroy, Renderer2, SimpleChanges, ViewEncapsulation } from '@angular/core';\nimport { SharedModule, LicenseManager } from 'primeng/api';\nimport { DomHandler } from 'primeng/dom';\nimport { UniqueComponentId } from 'primeng/utils';\n/**\n * Badge Directive is directive usage of badge component.\n * @group Components\n */\n@Directive({\n    selector: '[pBadge]',\n    host: {\n        class: 'p-element'\n    }\n})\nexport class BadgeDirective implements OnChanges, AfterViewInit {\n    /**\n     * Icon position of the component.\n     * @group Props\n     */\n    @Input() iconPos: 'left' | 'right' | 'top' | 'bottom' = 'left';\n    /**\n     * When specified, disables the component.\n     * @group Props\n     */\n    @Input('badgeDisabled') public disabled: boolean;\n    /**\n     * Size of the badge, valid options are \"large\" and \"xlarge\".\n     * @group Props\n     */\n    @Input() public badgeSize: 'large' | 'xlarge' | undefined;\n    /**\n     * Size of the badge, valid options are \"large\" and \"xlarge\".\n     * @group Props\n     * @deprecated use badgeSize instead.\n     */\n    @Input() public set size(value: 'large' | 'xlarge') {\n        this._size = value;\n        console.warn('size property is deprecated and will removed in v18, use badgeSize instead.');\n    }\n    get size() {\n        return this._size;\n    }\n    _size: 'large' | 'xlarge';\n    /**\n     * Severity type of the badge.\n     * @group Props\n     */\n    @Input() public severity: 'success' | 'info' | 'warning' | 'danger' | null | undefined;\n    /**\n     * Value to display inside the badge.\n     * @group Props\n     */\n    @Input() public value: string | number;\n    /**\n     * Inline style of the element.\n     * @group Props\n     */\n    @Input() badgeStyle: { [klass: string]: any } | null | undefined;\n    /**\n     * Class of the element.\n     * @group Props\n     */\n    @Input() badgeStyleClass: string;\n\n    private id!: string;\n\n    badgeEl: HTMLElement;\n\n    private get activeElement(): HTMLElement {\n        return this.el.nativeElement.nodeName.indexOf('-') != -1 ? this.el.nativeElement.firstChild : this.el.nativeElement;\n    }\n\n    private get canUpdateBadge(): boolean {\n        return this.id && !this.disabled;\n    }\n\n    constructor(@Inject(DOCUMENT) private document: Document, public el: ElementRef, private renderer: Renderer2) {}\n\n    public ngOnChanges({ value, size, severity, disabled, badgeStyle, badgeStyleClass }: SimpleChanges): void {\n        if (disabled) {\n            this.toggleDisableState();\n        }\n\n        if (!this.canUpdateBadge) {\n            return;\n        }\n\n        if (severity) {\n            this.setSeverity(severity.previousValue);\n        }\n\n        if (size) {\n            this.setSizeClasses();\n        }\n\n        if (value) {\n            this.setValue();\n        }\n\n        if (badgeStyle || badgeStyleClass) {\n            this.applyStyles();\n        }\n    }\n\n    public ngAfterViewInit(): void {\n        this.id = UniqueComponentId() + '_badge';\n        this.renderBadgeContent();\n    }\n\n    private setValue(element?: HTMLElement): void {\n        const badge = element ?? this.document.getElementById(this.id);\n\n        if (!badge) {\n            return;\n        }\n\n        if (this.value != null) {\n            if (DomHandler.hasClass(badge, 'p-badge-dot')) {\n                DomHandler.removeClass(badge, 'p-badge-dot');\n            }\n\n            if (this.value && String(this.value).length === 1) {\n                DomHandler.addClass(badge, 'p-badge-no-gutter');\n            } else {\n                DomHandler.removeClass(badge, 'p-badge-no-gutter');\n            }\n        } else {\n            if (!DomHandler.hasClass(badge, 'p-badge-dot')) {\n                DomHandler.addClass(badge, 'p-badge-dot');\n            }\n\n            DomHandler.removeClass(badge, 'p-badge-no-gutter');\n        }\n\n        badge.innerHTML = '';\n        const badgeValue = this.value != null ? String(this.value) : '';\n        this.renderer.appendChild(badge, this.document.createTextNode(badgeValue));\n    }\n\n    private setSizeClasses(element?: HTMLElement): void {\n        const badge = element ?? this.document.getElementById(this.id);\n\n        if (!badge) {\n            return;\n        }\n\n        if (this.badgeSize) {\n            if (this.badgeSize === 'large') {\n                DomHandler.addClass(badge, 'p-badge-lg');\n                DomHandler.removeClass(badge, 'p-badge-xl');\n            }\n\n            if (this.badgeSize === 'xlarge') {\n                DomHandler.addClass(badge, 'p-badge-xl');\n                DomHandler.removeClass(badge, 'p-badge-lg');\n            }\n        } else if (this.size && !this.badgeSize) {\n            if (this.size === 'large') {\n                DomHandler.addClass(badge, 'p-badge-lg');\n                DomHandler.removeClass(badge, 'p-badge-xl');\n            }\n\n            if (this.size === 'xlarge') {\n                DomHandler.addClass(badge, 'p-badge-xl');\n                DomHandler.removeClass(badge, 'p-badge-lg');\n            }\n        } else {\n            DomHandler.removeClass(badge, 'p-badge-lg');\n            DomHandler.removeClass(badge, 'p-badge-xl');\n        }\n    }\n\n    private renderBadgeContent(): void {\n        if (this.disabled) {\n            return null;\n        }\n\n        const el = this.activeElement;\n        const badge = this.document.createElement('span');\n        badge.id = this.id;\n        badge.className = 'p-badge p-component';\n\n        this.setSeverity(null, badge);\n        this.setSizeClasses(badge);\n        this.setValue(badge);\n        DomHandler.addClass(el, 'p-overlay-badge');\n        this.renderer.appendChild(el, badge);\n        this.badgeEl = badge;\n        this.applyStyles();\n    }\n\n    private applyStyles(): void {\n        if (this.badgeEl && this.badgeStyle && typeof this.badgeStyle === 'object') {\n            for (const [key, value] of Object.entries(this.badgeStyle)) {\n                this.renderer.setStyle(this.badgeEl, key, value);\n            }\n        }\n        if (this.badgeEl && this.badgeStyleClass) {\n            this.badgeEl.classList.add(...this.badgeStyleClass.split(' '));\n        }\n    }\n\n    private setSeverity(oldSeverity?: 'success' | 'info' | 'warning' | 'danger' | null, element?: HTMLElement): void {\n        const badge = element ?? this.document.getElementById(this.id);\n\n        if (!badge) {\n            return;\n        }\n\n        if (this.severity) {\n            DomHandler.addClass(badge, `p-badge-${this.severity}`);\n        }\n\n        if (oldSeverity) {\n            DomHandler.removeClass(badge, `p-badge-${oldSeverity}`);\n        }\n    }\n\n    private toggleDisableState(): void {\n        if (!this.id) {\n            return;\n        }\n\n        if (this.disabled) {\n            const badge = this.activeElement?.querySelector(`#${this.id}`);\n\n            if (badge) {\n                this.renderer.removeChild(this.activeElement, badge);\n            }\n        } else {\n            this.renderBadgeContent();\n        }\n    }\n}\n/**\n * Badge is a small status indicator for another element.\n * @group Components\n */\n@Component({\n    selector: 'p-badge',\n    template: ` <span *ngIf=\"!badgeDisabled\" [ngClass]=\"containerClass()\" [class]=\"styleClass\" [ngStyle]=\"style\">{{ value }}</span> `,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    styleUrls: ['./badge.css'],\n    host: {\n        class: 'p-element'\n    }\n})\nexport class Badge {\n    /**\n     * Class of the element.\n     * @group Props\n     */\n    @Input() styleClass: string | undefined;\n    /**\n     * Inline style of the element.\n     * @group Props\n     */\n    @Input() style: { [klass: string]: any } | null | undefined;\n    /**\n     * Size of the badge, valid options are \"large\" and \"xlarge\".\n     * @group Props\n     */\n    @Input() size: 'large' | 'xlarge' | undefined;\n    /**\n     * Severity type of the badge.\n     * @group Props\n     */\n    @Input() severity: 'success' | 'info' | 'warning' | 'danger' | null | undefined;\n    /**\n     * Value to display inside the badge.\n     * @group Props\n     */\n    @Input() value: string | null | undefined;\n    /**\n     * When specified, disables the component.\n     * @group Props\n     */\n    @Input() badgeDisabled: boolean = false;\n\n    containerClass() {\n        return {\n            'p-badge p-component': true,\n            'p-badge-no-gutter': this.value != undefined && String(this.value).length === 1,\n            'p-badge-lg': this.size === 'large',\n            'p-badge-xl': this.size === 'xlarge',\n            'p-badge-info': this.severity === 'info',\n            'p-badge-success': this.severity === 'success',\n            'p-badge-warning': this.severity === 'warning',\n            'p-badge-danger': this.severity === 'danger'\n        };\n    }\n\n    ngAfterViewInit() {\n        LicenseManager.check();\n    }\n}\n\n@NgModule({\n    imports: [CommonModule],\n    exports: [Badge, BadgeDirective, SharedModule],\n    declarations: [Badge, BadgeDirective]\n})\nexport class BadgeModule {}\n"]}
@@ -112,6 +112,7 @@ class Breadcrumb {
112
112
  pTooltip
113
113
  [tooltipOptions]="home.tooltipOptions"
114
114
  [attr.data-pc-section]="'home'"
115
+ [attr.aria-disabled]="home.disabled"
115
116
  >
116
117
  <a
117
118
  [href]="home.url ? home.url : null"
@@ -121,7 +122,7 @@ class Breadcrumb {
121
122
  (click)="onClick($event, home)"
122
123
  [target]="home.target"
123
124
  [attr.title]="home.title"
124
- [attr.tabindex]="home.disabled ? null : '0'"
125
+ [attr.tabindex]="home.disabled ? '-1' : home.tabindex || '0'"
125
126
  [ariaCurrentWhenActive]="isCurrentUrl(home)"
126
127
  >
127
128
  <span *ngIf="home.icon" class="p-menuitem-icon" [ngClass]="home.icon" [ngStyle]="home.iprivateyle"></span>
@@ -142,7 +143,7 @@ class Breadcrumb {
142
143
  (click)="onClick($event, home)"
143
144
  [target]="home.target"
144
145
  [attr.title]="home.title"
145
- [attr.tabindex]="home.disabled ? null : '0'"
146
+ [attr.tabindex]="home.disabled ? '-1' : home.tabindex || '0'"
146
147
  [ariaCurrentWhenActive]="isCurrentUrl(home)"
147
148
  [fragment]="home.fragment"
148
149
  [queryParamsHandling]="home.queryParamsHandling"
@@ -164,7 +165,16 @@ class Breadcrumb {
164
165
  <ng-template *ngTemplateOutlet="separatorTemplate"></ng-template>
165
166
  </li>
166
167
  <ng-template ngFor let-item let-end="last" [ngForOf]="model">
167
- <li [class]="item.styleClass" [attr.id]="item.id" [ngStyle]="item.style" [ngClass]="{ 'p-disabled': item.disabled }" pTooltip [tooltipOptions]="item.tooltipOptions" [attr.data-pc-section]="'menuitem'">
168
+ <li
169
+ [class]="item.styleClass"
170
+ [attr.id]="item.id"
171
+ [ngStyle]="item.style"
172
+ [ngClass]="{ 'p-disabled': item.disabled }"
173
+ [attr.aria-disabled]="item.disabled"
174
+ pTooltip
175
+ [tooltipOptions]="item.tooltipOptions"
176
+ [attr.data-pc-section]="'menuitem'"
177
+ >
168
178
  <a
169
179
  *ngIf="!item.routerLink"
170
180
  [attr.href]="item.url ? item.url : null"
@@ -172,7 +182,7 @@ class Breadcrumb {
172
182
  (click)="onClick($event, item)"
173
183
  [target]="item.target"
174
184
  [attr.title]="item.title"
175
- [attr.tabindex]="item.disabled ? null : '0'"
185
+ [attr.tabindex]="item.disabled ? '-1' : item.tabindex || '0'"
176
186
  [ariaCurrentWhenActive]="isCurrentUrl(item)"
177
187
  >
178
188
  <ng-container *ngIf="!itemTemplate">
@@ -196,7 +206,7 @@ class Breadcrumb {
196
206
  (click)="onClick($event, item)"
197
207
  [target]="item.target"
198
208
  [attr.title]="item.title"
199
- [attr.tabindex]="item.disabled ? null : '0'"
209
+ [attr.tabindex]="item.disabled ? '-1' : item.tabindex || '0'"
200
210
  [fragment]="item.fragment"
201
211
  [queryParamsHandling]="item.queryParamsHandling"
202
212
  [preserveFragment]="item.preserveFragment"
@@ -241,6 +251,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImpor
241
251
  pTooltip
242
252
  [tooltipOptions]="home.tooltipOptions"
243
253
  [attr.data-pc-section]="'home'"
254
+ [attr.aria-disabled]="home.disabled"
244
255
  >
245
256
  <a
246
257
  [href]="home.url ? home.url : null"
@@ -250,7 +261,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImpor
250
261
  (click)="onClick($event, home)"
251
262
  [target]="home.target"
252
263
  [attr.title]="home.title"
253
- [attr.tabindex]="home.disabled ? null : '0'"
264
+ [attr.tabindex]="home.disabled ? '-1' : home.tabindex || '0'"
254
265
  [ariaCurrentWhenActive]="isCurrentUrl(home)"
255
266
  >
256
267
  <span *ngIf="home.icon" class="p-menuitem-icon" [ngClass]="home.icon" [ngStyle]="home.iprivateyle"></span>
@@ -271,7 +282,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImpor
271
282
  (click)="onClick($event, home)"
272
283
  [target]="home.target"
273
284
  [attr.title]="home.title"
274
- [attr.tabindex]="home.disabled ? null : '0'"
285
+ [attr.tabindex]="home.disabled ? '-1' : home.tabindex || '0'"
275
286
  [ariaCurrentWhenActive]="isCurrentUrl(home)"
276
287
  [fragment]="home.fragment"
277
288
  [queryParamsHandling]="home.queryParamsHandling"
@@ -293,7 +304,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImpor
293
304
  <ng-template *ngTemplateOutlet="separatorTemplate"></ng-template>
294
305
  </li>
295
306
  <ng-template ngFor let-item let-end="last" [ngForOf]="model">
296
- <li [class]="item.styleClass" [attr.id]="item.id" [ngStyle]="item.style" [ngClass]="{ 'p-disabled': item.disabled }" pTooltip [tooltipOptions]="item.tooltipOptions" [attr.data-pc-section]="'menuitem'">
307
+ <li
308
+ [class]="item.styleClass"
309
+ [attr.id]="item.id"
310
+ [ngStyle]="item.style"
311
+ [ngClass]="{ 'p-disabled': item.disabled }"
312
+ [attr.aria-disabled]="item.disabled"
313
+ pTooltip
314
+ [tooltipOptions]="item.tooltipOptions"
315
+ [attr.data-pc-section]="'menuitem'"
316
+ >
297
317
  <a
298
318
  *ngIf="!item.routerLink"
299
319
  [attr.href]="item.url ? item.url : null"
@@ -301,7 +321,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImpor
301
321
  (click)="onClick($event, item)"
302
322
  [target]="item.target"
303
323
  [attr.title]="item.title"
304
- [attr.tabindex]="item.disabled ? null : '0'"
324
+ [attr.tabindex]="item.disabled ? '-1' : item.tabindex || '0'"
305
325
  [ariaCurrentWhenActive]="isCurrentUrl(item)"
306
326
  >
307
327
  <ng-container *ngIf="!itemTemplate">
@@ -325,7 +345,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImpor
325
345
  (click)="onClick($event, item)"
326
346
  [target]="item.target"
327
347
  [attr.title]="item.title"
328
- [attr.tabindex]="item.disabled ? null : '0'"
348
+ [attr.tabindex]="item.disabled ? '-1' : item.tabindex || '0'"
329
349
  [fragment]="item.fragment"
330
350
  [queryParamsHandling]="item.queryParamsHandling"
331
351
  [preserveFragment]="item.preserveFragment"
@@ -386,4 +406,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImpor
386
406
  declarations: [Breadcrumb]
387
407
  }]
388
408
  }] });
389
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"breadcrumb.js","sourceRoot":"","sources":["../../../src/app/components/breadcrumb/breadcrumb.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAoB,uBAAuB,EAAE,SAAS,EAAE,eAAe,EAAE,YAAY,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAA0B,iBAAiB,EAAE,MAAM,eAAe,CAAC;AACxL,OAAO,EAAU,YAAY,EAAE,MAAM,iBAAiB,CAAC;AACvD,OAAO,EAAY,aAAa,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AACpF,OAAO,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAC;AAC9D,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;;;;;AAEhD;;;GAGG;AACH,MAsIa,UAAU;IAuCC;IAtCpB;;;OAGG;IACM,KAAK,CAAyB;IACvC;;;OAGG;IACM,KAAK,CAA8C;IAC5D;;;OAGG;IACM,UAAU,CAAqB;IACxC;;;OAGG;IACM,IAAI,CAAuB;IACpC;;;OAGG;IACM,aAAa,CAAqB;IAC3C;;;;OAIG;IACO,WAAW,GAA2C,IAAI,YAAY,EAA4B,CAAC;IAE7E,SAAS,CAAuC;IAEhF,iBAAiB,CAA+B;IAEhD,YAAY,CAA+B;IAE3C,YAAoB,MAAc;QAAd,WAAM,GAAN,MAAM,CAAQ;IAAG,CAAC;IAEtC,OAAO,CAAC,KAAiB,EAAE,IAAc;QACrC,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,OAAO;SACV;QAED,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YAC/B,KAAK,CAAC,cAAc,EAAE,CAAC;SAC1B;QAED,IAAI,IAAI,CAAC,OAAO,EAAE;YACd,IAAI,CAAC,OAAO,CAAC;gBACT,aAAa,EAAE,KAAK;gBACpB,IAAI,EAAE,IAAI;aACb,CAAC,CAAC;SACN;QAED,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;YAClB,aAAa,EAAE,KAAK;YACpB,IAAI,EAAE,IAAI;SACb,CAAC,CAAC;IACP,CAAC;IAED,WAAW,CAAC,KAAuB;QAC/B,IAAI,IAAI,CAAC,IAAI,EAAE;YACX,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;SAClC;IACL,CAAC;IAED,kBAAkB;QACd,IAAI,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YAC7B,QAAQ,IAAI,CAAC,OAAO,EAAE,EAAE;gBACpB,KAAK,WAAW;oBACZ,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,QAAQ,CAAC;oBACvC,MAAM;gBACV,KAAK,MAAM;oBACP,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC;oBAClC,MAAM;gBACV;oBACI,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC;oBAClC,MAAM;aACb;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED,YAAY,CAAC,IAAI;QACb,MAAM,EAAE,UAAU,EAAE,GAAG,IAAI,CAAC;QAC5B,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;QAEpD,OAAO,UAAU,KAAK,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC;IACxD,CAAC;IAED,eAAe;QACX,cAAc,CAAC,KAAK,EAAE,CAAC;IAC3B,CAAC;uGA/FQ,UAAU;2FAAV,UAAU,kRAiCF,aAAa,6BArKpB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KA4HT,8pEA2GoD,gBAAgB,oGAAE,QAAQ;;SAnGtE,UAAU;2FAAV,UAAU;kBAtItB,SAAS;+BACI,cAAc,YACd;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KA4HT,mBACgB,uBAAuB,CAAC,MAAM,iBAChC,iBAAiB,CAAC,IAAI,QAE/B;wBACF,KAAK,EAAE,WAAW;qBACrB;6FAOQ,KAAK;sBAAb,KAAK;gBAKG,KAAK;sBAAb,KAAK;gBAKG,UAAU;sBAAlB,KAAK;gBAKG,IAAI;sBAAZ,KAAK;gBAKG,aAAa;sBAArB,KAAK;gBAMI,WAAW;sBAApB,MAAM;gBAEyB,SAAS;sBAAxC,eAAe;uBAAC,aAAa;;AAiElC,MAKa,gBAAgB;uGAAhB,gBAAgB;wGAAhB,gBAAgB,iBAvGhB,UAAU,aAmGT,YAAY,EAAE,YAAY,EAAE,aAAa,EAAE,gBAAgB,EAAE,QAAQ,EAAE,YAAY,aAnGpF,UAAU,EAoGG,YAAY,EAAE,aAAa,EAAE,YAAY;wGAGtD,gBAAgB,YAJf,YAAY,EAAE,YAAY,EAAE,aAAa,EAAE,gBAAgB,EAAE,QAAQ,EAAE,YAAY,EACvE,YAAY,EAAE,aAAa,EAAE,YAAY;;SAGtD,gBAAgB;2FAAhB,gBAAgB;kBAL5B,QAAQ;mBAAC;oBACN,OAAO,EAAE,CAAC,YAAY,EAAE,YAAY,EAAE,aAAa,EAAE,gBAAgB,EAAE,QAAQ,EAAE,YAAY,CAAC;oBAC9F,OAAO,EAAE,CAAC,UAAU,EAAE,YAAY,EAAE,aAAa,EAAE,YAAY,CAAC;oBAChE,YAAY,EAAE,CAAC,UAAU,CAAC;iBAC7B","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { AfterContentInit, ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Input, NgModule, Output, QueryList, TemplateRef, ViewEncapsulation } from '@angular/core';\nimport { Router, RouterModule } from '@angular/router';\nimport { MenuItem, PrimeTemplate, SharedModule, LicenseManager } from 'primeng/api';\nimport { ChevronRightIcon } from 'primeng/icons/chevronright';\nimport { HomeIcon } from 'primeng/icons/home';\nimport { TooltipModule } from 'primeng/tooltip';\nimport { BreadcrumbItemClickEvent } from './breadcrumb.interface';\n/**\n * Breadcrumb provides contextual information about page hierarchy.\n * @group Components\n */\n@Component({\n    selector: 'p-breadcrumb',\n    template: `\n        <nav [class]=\"styleClass\" [ngStyle]=\"style\" [ngClass]=\"'p-breadcrumb p-component'\" [attr.data-pc-name]=\"'breadcrumb'\" [attr.data-pc-section]=\"'root'\">\n            <ol [attr.data-pc-section]=\"'menu'\" class=\"p-breadcrumb-list\">\n                <li\n                    [class]=\"home.styleClass\"\n                    [attr.id]=\"home.id\"\n                    [ngClass]=\"{ 'p-breadcrumb-home': true, 'p-disabled': home.disabled }\"\n                    [ngStyle]=\"home.style\"\n                    *ngIf=\"home\"\n                    pTooltip\n                    [tooltipOptions]=\"home.tooltipOptions\"\n                    [attr.data-pc-section]=\"'home'\"\n                >\n                    <a\n                        [href]=\"home.url ? home.url : null\"\n                        *ngIf=\"!home.routerLink\"\n                        [attr.aria-label]=\"homeAriaLabel\"\n                        class=\"p-menuitem-link\"\n                        (click)=\"onClick($event, home)\"\n                        [target]=\"home.target\"\n                        [attr.title]=\"home.title\"\n                        [attr.tabindex]=\"home.disabled ? null : '0'\"\n                        [ariaCurrentWhenActive]=\"isCurrentUrl(home)\"\n                    >\n                        <span *ngIf=\"home.icon\" class=\"p-menuitem-icon\" [ngClass]=\"home.icon\" [ngStyle]=\"home.iprivateyle\"></span>\n                        <HomeIcon *ngIf=\"!home.icon\" [styleClass]=\"'p-menuitem-icon'\" />\n                        <ng-container *ngIf=\"home.label\">\n                            <span *ngIf=\"home.escape !== false; else htmlHomeLabel\" class=\"p-menuitem-text\">{{ home.label }}</span>\n                            <ng-template #htmlHomeLabel><span class=\"p-menuitem-text\" [innerHTML]=\"home.label\"></span></ng-template>\n                        </ng-container>\n                    </a>\n                    <a\n                        *ngIf=\"home.routerLink\"\n                        [routerLink]=\"home.routerLink\"\n                        [attr.aria-label]=\"homeAriaLabel\"\n                        [queryParams]=\"home.queryParams\"\n                        [routerLinkActive]=\"'p-menuitem-link-active'\"\n                        [routerLinkActiveOptions]=\"home.routerLinkActiveOptions || { exact: false }\"\n                        class=\"p-menuitem-link\"\n                        (click)=\"onClick($event, home)\"\n                        [target]=\"home.target\"\n                        [attr.title]=\"home.title\"\n                        [attr.tabindex]=\"home.disabled ? null : '0'\"\n                        [ariaCurrentWhenActive]=\"isCurrentUrl(home)\"\n                        [fragment]=\"home.fragment\"\n                        [queryParamsHandling]=\"home.queryParamsHandling\"\n                        [preserveFragment]=\"home.preserveFragment\"\n                        [skipLocationChange]=\"home.skipLocationChange\"\n                        [replaceUrl]=\"home.replaceUrl\"\n                        [state]=\"home.state\"\n                    >\n                        <span *ngIf=\"home.icon\" class=\"p-menuitem-icon\" [ngClass]=\"home.icon\" [ngStyle]=\"home.iconStyle\"></span>\n                        <HomeIcon *ngIf=\"!home.icon\" [styleClass]=\"'p-menuitem-icon'\" />\n                        <ng-container *ngIf=\"home.label\">\n                            <span *ngIf=\"home.escape !== false; else htmlHomeRouteLabel\" class=\"p-menuitem-text\">{{ home.label }}</span>\n                            <ng-template #htmlHomeRouteLabel><span class=\"p-menuitem-text\" [innerHTML]=\"home.label\"></span></ng-template>\n                        </ng-container>\n                    </a>\n                </li>\n                <li *ngIf=\"model && home\" class=\"p-menuitem-separator\" [attr.data-pc-section]=\"'separator'\">\n                    <ChevronRightIcon *ngIf=\"!separatorTemplate\" />\n                    <ng-template *ngTemplateOutlet=\"separatorTemplate\"></ng-template>\n                </li>\n                <ng-template ngFor let-item let-end=\"last\" [ngForOf]=\"model\">\n                    <li [class]=\"item.styleClass\" [attr.id]=\"item.id\" [ngStyle]=\"item.style\" [ngClass]=\"{ 'p-disabled': item.disabled }\" pTooltip [tooltipOptions]=\"item.tooltipOptions\" [attr.data-pc-section]=\"'menuitem'\">\n                        <a\n                            *ngIf=\"!item.routerLink\"\n                            [attr.href]=\"item.url ? item.url : null\"\n                            class=\"p-menuitem-link\"\n                            (click)=\"onClick($event, item)\"\n                            [target]=\"item.target\"\n                            [attr.title]=\"item.title\"\n                            [attr.tabindex]=\"item.disabled ? null : '0'\"\n                            [ariaCurrentWhenActive]=\"isCurrentUrl(item)\"\n                        >\n                            <ng-container *ngIf=\"!itemTemplate\">\n                                <span *ngIf=\"item.icon\" class=\"p-menuitem-icon\" [ngClass]=\"item.icon\" [ngStyle]=\"item.iconStyle\"></span>\n                                <ng-container *ngIf=\"item.label\">\n                                    <span *ngIf=\"item.escape !== false; else htmlLabel\" class=\"p-menuitem-text\">{{ item.label }}</span>\n                                    <ng-template #htmlLabel><span class=\"p-menuitem-text\" [innerHTML]=\"item.label\"></span></ng-template>\n                                </ng-container>\n                            </ng-container>\n                            <ng-container *ngIf=\"itemTemplate\">\n                                <ng-template *ngTemplateOutlet=\"itemTemplate; context: { $implicit: item }\"></ng-template>\n                            </ng-container>\n                        </a>\n                        <a\n                            *ngIf=\"item.routerLink\"\n                            [routerLink]=\"item.routerLink\"\n                            [queryParams]=\"item.queryParams\"\n                            [routerLinkActive]=\"'p-menuitem-link-active'\"\n                            [routerLinkActiveOptions]=\"item.routerLinkActiveOptions || { exact: false }\"\n                            class=\"p-menuitem-link\"\n                            (click)=\"onClick($event, item)\"\n                            [target]=\"item.target\"\n                            [attr.title]=\"item.title\"\n                            [attr.tabindex]=\"item.disabled ? null : '0'\"\n                            [fragment]=\"item.fragment\"\n                            [queryParamsHandling]=\"item.queryParamsHandling\"\n                            [preserveFragment]=\"item.preserveFragment\"\n                            [skipLocationChange]=\"item.skipLocationChange\"\n                            [replaceUrl]=\"item.replaceUrl\"\n                            [state]=\"item.state\"\n                            [ariaCurrentWhenActive]=\"isCurrentUrl(item)\"\n                        >\n                            <ng-container *ngIf=\"!itemTemplate\">\n                                <span *ngIf=\"item.icon\" class=\"p-menuitem-icon\" [ngClass]=\"item.icon\" [ngStyle]=\"item.iconStyle\"></span>\n                                <ng-container *ngIf=\"item.label\">\n                                    <span *ngIf=\"item.escape !== false; else htmlRouteLabel\" class=\"p-menuitem-text\">{{ item.label }}</span>\n                                    <ng-template #htmlRouteLabel><span class=\"p-menuitem-text\" [innerHTML]=\"item.label\"></span></ng-template>\n                                </ng-container>\n                            </ng-container>\n                            <ng-container *ngIf=\"itemTemplate\">\n                                <ng-template *ngTemplateOutlet=\"itemTemplate; context: { $implicit: item }\"></ng-template>\n                            </ng-container>\n                        </a>\n                    </li>\n                    <li *ngIf=\"!end\" class=\"p-menuitem-separator\" [attr.data-pc-section]=\"'separator'\">\n                        <ChevronRightIcon *ngIf=\"!separatorTemplate\" />\n                        <ng-template *ngTemplateOutlet=\"separatorTemplate\"></ng-template>\n                    </li>\n                </ng-template>\n            </ol>\n        </nav>\n    `,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    styleUrls: ['./breadcrumb.css'],\n    host: {\n        class: 'p-element'\n    }\n})\nexport class Breadcrumb implements AfterContentInit {\n    /**\n     * An array of menuitems.\n     * @group Props\n     */\n    @Input() model: MenuItem[] | 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     * MenuItem configuration for the home icon.\n     * @group Props\n     */\n    @Input() home: MenuItem | undefined;\n    /**\n     * Defines a string that labels the home icon for accessibility.\n     * @group Props\n     */\n    @Input() homeAriaLabel: string | undefined;\n    /**\n     * Fired when an item is selected.\n     * @param {BreadcrumbItemClickEvent} event - custom click event.\n     * @group Emits\n     */\n    @Output() onItemClick: EventEmitter<BreadcrumbItemClickEvent> = new EventEmitter<BreadcrumbItemClickEvent>();\n\n    @ContentChildren(PrimeTemplate) templates: QueryList<PrimeTemplate> | undefined;\n\n    separatorTemplate: TemplateRef<any> | undefined;\n\n    itemTemplate: TemplateRef<any> | undefined;\n\n    constructor(private router: Router) {}\n\n    onClick(event: MouseEvent, 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        this.onItemClick.emit({\n            originalEvent: event,\n            item: item\n        });\n    }\n\n    onHomeClick(event: MouseEvent | any) {\n        if (this.home) {\n            this.onClick(event, this.home);\n        }\n    }\n\n    ngAfterContentInit() {\n        this.templates?.forEach((item) => {\n            switch (item.getType()) {\n                case 'separator':\n                    this.separatorTemplate = item.template;\n                    break;\n                case 'item':\n                    this.itemTemplate = item.template;\n                    break;\n                default:\n                    this.itemTemplate = item.template;\n                    break;\n            }\n        });\n    }\n\n    isCurrentUrl(item) {\n        const { routerLink } = item;\n        const lastPath = this.router ? this.router.url : '';\n\n        return routerLink === lastPath ? 'page' : undefined;\n    }\n\n    ngAfterViewInit() {\n        LicenseManager.check();\n    }\n}\n\n@NgModule({\n    imports: [CommonModule, RouterModule, TooltipModule, ChevronRightIcon, HomeIcon, SharedModule],\n    exports: [Breadcrumb, RouterModule, TooltipModule, SharedModule],\n    declarations: [Breadcrumb]\n})\nexport class BreadcrumbModule {}\n"]}
409
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"breadcrumb.js","sourceRoot":"","sources":["../../../src/app/components/breadcrumb/breadcrumb.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { AfterContentInit, ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Input, NgModule, Output, QueryList, TemplateRef, ViewEncapsulation } from '@angular/core';\nimport { Router, RouterModule } from '@angular/router';\nimport { MenuItem, PrimeTemplate, SharedModule, LicenseManager } from 'primeng/api';\nimport { ChevronRightIcon } from 'primeng/icons/chevronright';\nimport { HomeIcon } from 'primeng/icons/home';\nimport { TooltipModule } from 'primeng/tooltip';\nimport { BreadcrumbItemClickEvent } from './breadcrumb.interface';\n/**\n * Breadcrumb provides contextual information about page hierarchy.\n * @group Components\n */\n@Component({\n    selector: 'p-breadcrumb',\n    template: `\n        <nav [class]=\"styleClass\" [ngStyle]=\"style\" [ngClass]=\"'p-breadcrumb p-component'\" [attr.data-pc-name]=\"'breadcrumb'\" [attr.data-pc-section]=\"'root'\">\n            <ol [attr.data-pc-section]=\"'menu'\" class=\"p-breadcrumb-list\">\n                <li\n                    [class]=\"home.styleClass\"\n                    [attr.id]=\"home.id\"\n                    [ngClass]=\"{ 'p-breadcrumb-home': true, 'p-disabled': home.disabled }\"\n                    [ngStyle]=\"home.style\"\n                    *ngIf=\"home\"\n                    pTooltip\n                    [tooltipOptions]=\"home.tooltipOptions\"\n                    [attr.data-pc-section]=\"'home'\"\n                    [attr.aria-disabled]=\"home.disabled\"\n                >\n                    <a\n                        [href]=\"home.url ? home.url : null\"\n                        *ngIf=\"!home.routerLink\"\n                        [attr.aria-label]=\"homeAriaLabel\"\n                        class=\"p-menuitem-link\"\n                        (click)=\"onClick($event, home)\"\n                        [target]=\"home.target\"\n                        [attr.title]=\"home.title\"\n                        [attr.tabindex]=\"home.disabled ? '-1' : home.tabindex || '0'\"\n                        [ariaCurrentWhenActive]=\"isCurrentUrl(home)\"\n                    >\n                        <span *ngIf=\"home.icon\" class=\"p-menuitem-icon\" [ngClass]=\"home.icon\" [ngStyle]=\"home.iprivateyle\"></span>\n                        <HomeIcon *ngIf=\"!home.icon\" [styleClass]=\"'p-menuitem-icon'\" />\n                        <ng-container *ngIf=\"home.label\">\n                            <span *ngIf=\"home.escape !== false; else htmlHomeLabel\" class=\"p-menuitem-text\">{{ home.label }}</span>\n                            <ng-template #htmlHomeLabel><span class=\"p-menuitem-text\" [innerHTML]=\"home.label\"></span></ng-template>\n                        </ng-container>\n                    </a>\n                    <a\n                        *ngIf=\"home.routerLink\"\n                        [routerLink]=\"home.routerLink\"\n                        [attr.aria-label]=\"homeAriaLabel\"\n                        [queryParams]=\"home.queryParams\"\n                        [routerLinkActive]=\"'p-menuitem-link-active'\"\n                        [routerLinkActiveOptions]=\"home.routerLinkActiveOptions || { exact: false }\"\n                        class=\"p-menuitem-link\"\n                        (click)=\"onClick($event, home)\"\n                        [target]=\"home.target\"\n                        [attr.title]=\"home.title\"\n                        [attr.tabindex]=\"home.disabled ? '-1' : home.tabindex || '0'\"\n                        [ariaCurrentWhenActive]=\"isCurrentUrl(home)\"\n                        [fragment]=\"home.fragment\"\n                        [queryParamsHandling]=\"home.queryParamsHandling\"\n                        [preserveFragment]=\"home.preserveFragment\"\n                        [skipLocationChange]=\"home.skipLocationChange\"\n                        [replaceUrl]=\"home.replaceUrl\"\n                        [state]=\"home.state\"\n                    >\n                        <span *ngIf=\"home.icon\" class=\"p-menuitem-icon\" [ngClass]=\"home.icon\" [ngStyle]=\"home.iconStyle\"></span>\n                        <HomeIcon *ngIf=\"!home.icon\" [styleClass]=\"'p-menuitem-icon'\" />\n                        <ng-container *ngIf=\"home.label\">\n                            <span *ngIf=\"home.escape !== false; else htmlHomeRouteLabel\" class=\"p-menuitem-text\">{{ home.label }}</span>\n                            <ng-template #htmlHomeRouteLabel><span class=\"p-menuitem-text\" [innerHTML]=\"home.label\"></span></ng-template>\n                        </ng-container>\n                    </a>\n                </li>\n                <li *ngIf=\"model && home\" class=\"p-menuitem-separator\" [attr.data-pc-section]=\"'separator'\">\n                    <ChevronRightIcon *ngIf=\"!separatorTemplate\" />\n                    <ng-template *ngTemplateOutlet=\"separatorTemplate\"></ng-template>\n                </li>\n                <ng-template ngFor let-item let-end=\"last\" [ngForOf]=\"model\">\n                    <li\n                        [class]=\"item.styleClass\"\n                        [attr.id]=\"item.id\"\n                        [ngStyle]=\"item.style\"\n                        [ngClass]=\"{ 'p-disabled': item.disabled }\"\n                        [attr.aria-disabled]=\"item.disabled\"\n                        pTooltip\n                        [tooltipOptions]=\"item.tooltipOptions\"\n                        [attr.data-pc-section]=\"'menuitem'\"\n                    >\n                        <a\n                            *ngIf=\"!item.routerLink\"\n                            [attr.href]=\"item.url ? item.url : null\"\n                            class=\"p-menuitem-link\"\n                            (click)=\"onClick($event, item)\"\n                            [target]=\"item.target\"\n                            [attr.title]=\"item.title\"\n                            [attr.tabindex]=\"item.disabled ? '-1' : item.tabindex || '0'\"\n                            [ariaCurrentWhenActive]=\"isCurrentUrl(item)\"\n                        >\n                            <ng-container *ngIf=\"!itemTemplate\">\n                                <span *ngIf=\"item.icon\" class=\"p-menuitem-icon\" [ngClass]=\"item.icon\" [ngStyle]=\"item.iconStyle\"></span>\n                                <ng-container *ngIf=\"item.label\">\n                                    <span *ngIf=\"item.escape !== false; else htmlLabel\" class=\"p-menuitem-text\">{{ item.label }}</span>\n                                    <ng-template #htmlLabel><span class=\"p-menuitem-text\" [innerHTML]=\"item.label\"></span></ng-template>\n                                </ng-container>\n                            </ng-container>\n                            <ng-container *ngIf=\"itemTemplate\">\n                                <ng-template *ngTemplateOutlet=\"itemTemplate; context: { $implicit: item }\"></ng-template>\n                            </ng-container>\n                        </a>\n                        <a\n                            *ngIf=\"item.routerLink\"\n                            [routerLink]=\"item.routerLink\"\n                            [queryParams]=\"item.queryParams\"\n                            [routerLinkActive]=\"'p-menuitem-link-active'\"\n                            [routerLinkActiveOptions]=\"item.routerLinkActiveOptions || { exact: false }\"\n                            class=\"p-menuitem-link\"\n                            (click)=\"onClick($event, item)\"\n                            [target]=\"item.target\"\n                            [attr.title]=\"item.title\"\n                            [attr.tabindex]=\"item.disabled ? '-1' : item.tabindex || '0'\"\n                            [fragment]=\"item.fragment\"\n                            [queryParamsHandling]=\"item.queryParamsHandling\"\n                            [preserveFragment]=\"item.preserveFragment\"\n                            [skipLocationChange]=\"item.skipLocationChange\"\n                            [replaceUrl]=\"item.replaceUrl\"\n                            [state]=\"item.state\"\n                            [ariaCurrentWhenActive]=\"isCurrentUrl(item)\"\n                        >\n                            <ng-container *ngIf=\"!itemTemplate\">\n                                <span *ngIf=\"item.icon\" class=\"p-menuitem-icon\" [ngClass]=\"item.icon\" [ngStyle]=\"item.iconStyle\"></span>\n                                <ng-container *ngIf=\"item.label\">\n                                    <span *ngIf=\"item.escape !== false; else htmlRouteLabel\" class=\"p-menuitem-text\">{{ item.label }}</span>\n                                    <ng-template #htmlRouteLabel><span class=\"p-menuitem-text\" [innerHTML]=\"item.label\"></span></ng-template>\n                                </ng-container>\n                            </ng-container>\n                            <ng-container *ngIf=\"itemTemplate\">\n                                <ng-template *ngTemplateOutlet=\"itemTemplate; context: { $implicit: item }\"></ng-template>\n                            </ng-container>\n                        </a>\n                    </li>\n                    <li *ngIf=\"!end\" class=\"p-menuitem-separator\" [attr.data-pc-section]=\"'separator'\">\n                        <ChevronRightIcon *ngIf=\"!separatorTemplate\" />\n                        <ng-template *ngTemplateOutlet=\"separatorTemplate\"></ng-template>\n                    </li>\n                </ng-template>\n            </ol>\n        </nav>\n    `,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    styleUrls: ['./breadcrumb.css'],\n    host: {\n        class: 'p-element'\n    }\n})\nexport class Breadcrumb implements AfterContentInit {\n    /**\n     * An array of menuitems.\n     * @group Props\n     */\n    @Input() model: MenuItem[] | 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     * MenuItem configuration for the home icon.\n     * @group Props\n     */\n    @Input() home: MenuItem | undefined;\n    /**\n     * Defines a string that labels the home icon for accessibility.\n     * @group Props\n     */\n    @Input() homeAriaLabel: string | undefined;\n    /**\n     * Fired when an item is selected.\n     * @param {BreadcrumbItemClickEvent} event - custom click event.\n     * @group Emits\n     */\n    @Output() onItemClick: EventEmitter<BreadcrumbItemClickEvent> = new EventEmitter<BreadcrumbItemClickEvent>();\n\n    @ContentChildren(PrimeTemplate) templates: QueryList<PrimeTemplate> | undefined;\n\n    separatorTemplate: TemplateRef<any> | undefined;\n\n    itemTemplate: TemplateRef<any> | undefined;\n\n    constructor(private router: Router) {}\n\n    onClick(event: MouseEvent, 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        this.onItemClick.emit({\n            originalEvent: event,\n            item: item\n        });\n    }\n\n    onHomeClick(event: MouseEvent | any) {\n        if (this.home) {\n            this.onClick(event, this.home);\n        }\n    }\n\n    ngAfterContentInit() {\n        this.templates?.forEach((item) => {\n            switch (item.getType()) {\n                case 'separator':\n                    this.separatorTemplate = item.template;\n                    break;\n                case 'item':\n                    this.itemTemplate = item.template;\n                    break;\n                default:\n                    this.itemTemplate = item.template;\n                    break;\n            }\n        });\n    }\n\n    isCurrentUrl(item) {\n        const { routerLink } = item;\n        const lastPath = this.router ? this.router.url : '';\n\n        return routerLink === lastPath ? 'page' : undefined;\n    }\n\n    ngAfterViewInit() {\n        LicenseManager.check();\n    }\n}\n\n@NgModule({\n    imports: [CommonModule, RouterModule, TooltipModule, ChevronRightIcon, HomeIcon, SharedModule],\n    exports: [Breadcrumb, RouterModule, TooltipModule, SharedModule],\n    declarations: [Breadcrumb]\n})\nexport class BreadcrumbModule {}\n"]}