ng-prime-tools 1.0.51 → 1.0.52

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.
@@ -1,3 +1,3 @@
1
1
  // src/lib/models/pt-dialog-config.model.ts
2
2
  export {};
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHQtZGlhbG9nLWNvbmZpZy5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvbW9kZWxzL3B0LWRpYWxvZy1jb25maWcubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsMkNBQTJDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gc3JjL2xpYi9tb2RlbHMvcHQtZGlhbG9nLWNvbmZpZy5tb2RlbC50c1xuXG5leHBvcnQgdHlwZSBEaWFsb2dQb3NpdGlvbiA9XG4gIHwgJ3JpZ2h0J1xuICB8ICdsZWZ0J1xuICB8ICdjZW50ZXInXG4gIHwgJ3RvcCdcbiAgfCAnYm90dG9tJ1xuICB8ICd0b3BsZWZ0J1xuICB8ICd0b3ByaWdodCdcbiAgfCAnYm90dG9tbGVmdCdcbiAgfCAnYm90dG9tcmlnaHQnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFBURGlhbG9nQ29uZmlnIHtcbiAgLyoqIFRpdGxlIHRleHQgaW4gdGhlIGhlYWRlciAqL1xuICBoZWFkZXI/OiBzdHJpbmc7XG5cbiAgLyoqIElubGluZSBzdHlsZSBmb3IgdGhlIHdob2xlIGRpYWxvZyBjb250YWluZXIgKFByaW1lTkcgW3N0eWxlXSkgKi9cbiAgc3R5bGU/OiB7IFtrZXk6IHN0cmluZ106IGFueSB9O1xuXG4gIC8qKiBFeHRyYSBjbGFzc2VzIGFwcGxpZWQgdG8gUHJpbWVORyBkaWFsb2cgKi9cbiAgc3R5bGVDbGFzcz86IHN0cmluZztcblxuICAvKiogT3B0aW9uYWwgaWNvbiBpbiB0aGUgaGVhZGVyIChlLmcuICdwaSBwaS1pbmZvLWNpcmNsZSB0ZXh0LWJsdWUtNTAwJykgKi9cbiAgaGVhZGVySWNvbkNsYXNzPzogc3RyaW5nO1xuXG4gIC8qKiBPcHRpb25hbCBib2R5IG1heCB3aWR0aCAvIGhlaWdodCAoZS5nLiAnNTAwcHgnLCAnNjB2aCcpICovXG4gIGJvZHlXaWR0aD86IHN0cmluZztcbiAgYm9keUhlaWdodD86IHN0cmluZztcblxuICAvKiogRW5hYmxlIHNjcm9sbCB3aGVuIGJvZHkgZXhjZWVkcyBnaXZlbiBoZWlnaHQvd2lkdGggKGRlZmF1bHQ6IHRydWUpICovXG4gIGJvZHlTY3JvbGxhYmxlPzogYm9vbGVhbjtcblxuICAvKiogQ29udHJvbCBmb290ZXIgdmlzaWJpbGl0eSAoZGVmYXVsdDogdHJ1ZSkgKi9cbiAgc2hvd0Zvb3Rlcj86IGJvb2xlYW47XG5cbiAgLyoqIFByaW1lTkcgZGlhbG9nIGJlaGF2aW9yIGZsYWdzICovXG4gIG1vZGFsPzogYm9vbGVhbjtcbiAgY2xvc2FibGU/OiBib29sZWFuO1xuICBkcmFnZ2FibGU/OiBib29sZWFuO1xuICByZXNpemFibGU/OiBib29sZWFuO1xuICBtYXhpbWl6YWJsZT86IGJvb2xlYW47XG4gIGRpc21pc3NhYmxlTWFzaz86IGJvb2xlYW47XG4gIGNsb3NlT25Fc2NhcGU/OiBib29sZWFuO1xuICBibG9ja1Njcm9sbD86IGJvb2xlYW47XG5cbiAgLyoqIFJlc3BvbnNpdmUgYnJlYWtwb2ludHMgKi9cbiAgYnJlYWtwb2ludHM/OiB7IFtrZXk6IHN0cmluZ106IHN0cmluZyB9O1xuXG4gIC8qKiBEaWFsb2cgcG9zaXRpb24gKFByaW1lTkcgPHAtZGlhbG9nPiBwb3NpdGlvbikgKi9cbiAgcG9zaXRpb24/OiBEaWFsb2dQb3NpdGlvbjtcblxuICAvKiogRXh0cmEgc3R5bGUgZm9yIGNvbnRlbnQgKFByaW1lTkcgW2NvbnRlbnRTdHlsZV0pICovXG4gIGNvbnRlbnRTdHlsZT86IHsgW2tleTogc3RyaW5nXTogYW55IH07XG59XG4iXX0=
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHQtZGlhbG9nLWNvbmZpZy5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvbW9kZWxzL3B0LWRpYWxvZy1jb25maWcubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsMkNBQTJDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gc3JjL2xpYi9tb2RlbHMvcHQtZGlhbG9nLWNvbmZpZy5tb2RlbC50c1xuXG5pbXBvcnQgeyBTZXZlcml0eUVudW0gfSBmcm9tICcuLi9lbnVtcyc7XG5cbmV4cG9ydCB0eXBlIERpYWxvZ1Bvc2l0aW9uID1cbiAgfCAncmlnaHQnXG4gIHwgJ2xlZnQnXG4gIHwgJ2NlbnRlcidcbiAgfCAndG9wJ1xuICB8ICdib3R0b20nXG4gIHwgJ3RvcGxlZnQnXG4gIHwgJ3RvcHJpZ2h0J1xuICB8ICdib3R0b21sZWZ0J1xuICB8ICdib3R0b21yaWdodCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUFREaWFsb2dDb25maWcge1xuICAvKiogVGl0bGUgdGV4dCBpbiB0aGUgaGVhZGVyICovXG4gIGhlYWRlcj86IHN0cmluZztcblxuICAvKiogSW5saW5lIHN0eWxlIGZvciB0aGUgd2hvbGUgZGlhbG9nIGNvbnRhaW5lciAoUHJpbWVORyBbc3R5bGVdKSAqL1xuICBzdHlsZT86IHsgW2tleTogc3RyaW5nXTogYW55IH07XG5cbiAgLyoqIEV4dHJhIGNsYXNzZXMgYXBwbGllZCB0byBQcmltZU5HIGRpYWxvZyAqL1xuICBzdHlsZUNsYXNzPzogc3RyaW5nO1xuXG4gIC8qKiBPcHRpb25hbCBpY29uIGluIHRoZSBoZWFkZXIgKGUuZy4gJ3BpIHBpLWluZm8tY2lyY2xlIHRleHQtYmx1ZS01MDAnKSAqL1xuICBoZWFkZXJJY29uQ2xhc3M/OiBzdHJpbmc7XG5cbiAgLyoqIE9wdGlvbmFsIGJvZHkgbWF4IHdpZHRoIC8gaGVpZ2h0IChlLmcuICc1MDBweCcsICc2MHZoJykgKi9cbiAgYm9keVdpZHRoPzogc3RyaW5nO1xuICBib2R5SGVpZ2h0Pzogc3RyaW5nO1xuXG4gIC8qKiBFbmFibGUgc2Nyb2xsIHdoZW4gYm9keSBleGNlZWRzIGdpdmVuIGhlaWdodC93aWR0aCAoZGVmYXVsdDogdHJ1ZSkgKi9cbiAgYm9keVNjcm9sbGFibGU/OiBib29sZWFuO1xuXG4gIC8qKiBDb250cm9sIGZvb3RlciB2aXNpYmlsaXR5IChkZWZhdWx0OiB0cnVlKSAqL1xuICBzaG93Rm9vdGVyPzogYm9vbGVhbjtcblxuICAvKiogUHJpbWVORyBkaWFsb2cgYmVoYXZpb3IgZmxhZ3MgKi9cbiAgbW9kYWw/OiBib29sZWFuO1xuICBjbG9zYWJsZT86IGJvb2xlYW47XG4gIGRyYWdnYWJsZT86IGJvb2xlYW47XG4gIHJlc2l6YWJsZT86IGJvb2xlYW47XG4gIG1heGltaXphYmxlPzogYm9vbGVhbjtcbiAgZGlzbWlzc2FibGVNYXNrPzogYm9vbGVhbjtcbiAgY2xvc2VPbkVzY2FwZT86IGJvb2xlYW47XG4gIGJsb2NrU2Nyb2xsPzogYm9vbGVhbjtcblxuICAvKiogUmVzcG9uc2l2ZSBicmVha3BvaW50cyAqL1xuICBicmVha3BvaW50cz86IHsgW2tleTogc3RyaW5nXTogc3RyaW5nIH07XG5cbiAgLyoqIERpYWxvZyBwb3NpdGlvbiAoUHJpbWVORyA8cC1kaWFsb2c+IHBvc2l0aW9uKSAqL1xuICBwb3NpdGlvbj86IERpYWxvZ1Bvc2l0aW9uO1xuXG4gIC8qKiBFeHRyYSBzdHlsZSBmb3IgY29udGVudCAoUHJpbWVORyBbY29udGVudFN0eWxlXSkgKi9cbiAgY29udGVudFN0eWxlPzogeyBba2V5OiBzdHJpbmddOiBhbnkgfTtcblxuICBkaWFsb2dTdHlsZT86IFNldmVyaXR5RW51bTtcbn1cbiJdfQ==
@@ -1,9 +1,11 @@
1
1
  import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { SeverityEnum } from '../enums';
2
3
  import * as i0 from "@angular/core";
3
4
  import * as i1 from "@angular/common";
4
5
  import * as i2 from "primeng/dialog";
5
6
  import * as i3 from "primeng/api";
6
7
  const DEFAULT_DIALOG_CONFIG = {
8
+ dialogStyle: SeverityEnum.INFO,
7
9
  modal: true,
8
10
  closable: true,
9
11
  draggable: true,
@@ -37,12 +39,38 @@ export class PTDialogComponent {
37
39
  set visible(v) {
38
40
  this._internalVisible = v;
39
41
  }
42
+ /** ✅ Same mapping logic as pt-confirm-dialog */
43
+ get dialogSeverity() {
44
+ const style = this.config.dialogStyle ?? SeverityEnum.INFO;
45
+ return style === SeverityEnum.DANGER
46
+ ? SeverityEnum.DANGER
47
+ : style === SeverityEnum.WARNING
48
+ ? SeverityEnum.WARNING
49
+ : style === SeverityEnum.SUCCESS
50
+ ? SeverityEnum.SUCCESS
51
+ : SeverityEnum.INFO;
52
+ }
53
+ /** ✅ Used in [styleClass] to apply CSS theme per severity */
54
+ getSeverityClass() {
55
+ switch (this.dialogSeverity) {
56
+ case SeverityEnum.DANGER:
57
+ return 'pt-dialog-danger';
58
+ case SeverityEnum.WARNING:
59
+ return 'pt-dialog-warning';
60
+ case SeverityEnum.SUCCESS:
61
+ return 'pt-dialog-success';
62
+ case SeverityEnum.INFO:
63
+ default:
64
+ return 'pt-dialog-info';
65
+ }
66
+ }
40
67
  get dialogStyleClass() {
41
68
  return [
42
69
  'border-round-3xl',
43
70
  'shadow-6',
44
71
  'overflow-hidden',
45
- 'pt-dialog-header-blue',
72
+ 'pt-dialog-overlay',
73
+ this.getSeverityClass(),
46
74
  this.config.styleClass,
47
75
  ]
48
76
  .filter(Boolean)
@@ -70,12 +98,48 @@ export class PTDialogComponent {
70
98
  this._internalVisible = v;
71
99
  this.visibleChange.emit(v);
72
100
  }
101
+ // ============================================================
102
+ // ✅ Severity colors for header elements (icon + title)
103
+ // ============================================================
104
+ getSeverityHeaderColor() {
105
+ switch (this.dialogSeverity) {
106
+ case SeverityEnum.DANGER:
107
+ return '#b91c1c';
108
+ case SeverityEnum.WARNING:
109
+ return '#b45309';
110
+ case SeverityEnum.SUCCESS:
111
+ return '#15803d';
112
+ case SeverityEnum.INFO:
113
+ default:
114
+ return '#2563eb';
115
+ }
116
+ }
117
+ /** ✅ Inline style to override text-primary / utility classes */
118
+ get headerIconStyle() {
119
+ return { color: this.getSeverityHeaderColor() };
120
+ }
121
+ /** ✅ Optional but recommended: keep title consistent with icon */
122
+ get headerTitleStyle() {
123
+ return { color: this.getSeverityHeaderColor() };
124
+ }
125
+ removeTextUtilityClasses(cls) {
126
+ if (!cls)
127
+ return '';
128
+ return cls
129
+ .split(/\s+/)
130
+ .filter(Boolean)
131
+ .filter((c) => !c.startsWith('text-')) // removes text-primary, text-danger, etc.
132
+ .join(' ');
133
+ }
134
+ get safeHeaderIconClass() {
135
+ return this.removeTextUtilityClasses(this.config.headerIconClass);
136
+ }
73
137
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTDialogComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
74
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PTDialogComponent, selector: "pt-dialog", inputs: { config: "config", visible: "visible" }, outputs: { visibleChange: "visibleChange" }, ngImport: i0, template: "<p-dialog\n [visible]=\"_internalVisible\"\n (visibleChange)=\"onInternalVisibleChange($event)\"\n [header]=\"config.header\"\n [modal]=\"config.modal\"\n [style]=\"config.style\"\n [breakpoints]=\"config.breakpoints\"\n [closable]=\"config.closable\"\n [draggable]=\"config.draggable\"\n [resizable]=\"config.resizable\"\n [maximizable]=\"config.maximizable\"\n [dismissableMask]=\"config.dismissableMask\"\n [closeOnEscape]=\"config.closeOnEscape\"\n [blockScroll]=\"config.blockScroll\"\n [position]=\"primePosition\"\n [contentStyle]=\"config.contentStyle\"\n [styleClass]=\"dialogStyleClass\"\n>\n <!-- HEADER -->\n <ng-template pTemplate=\"header\">\n <div class=\"pt-dialog-header-inner\">\n <div class=\"pt-dialog-header-left\">\n <i\n *ngIf=\"config.headerIconClass\"\n class=\"pt-dialog-header-icon\"\n [ngClass]=\"config.headerIconClass\"\n ></i>\n\n <ng-content select=\"[ptDialogHeader]\"></ng-content>\n\n <span *ngIf=\"config.header\" class=\"pt-dialog-header-title\">\n {{ config.header }}\n </span>\n </div>\n </div>\n </ng-template>\n\n <!-- BODY -->\n <div class=\"pt-dialog-body\" [ngStyle]=\"bodyStyle\">\n <div class=\"pt-dialog-body-inner\">\n <ng-content select=\"[ptDialogContent]\"></ng-content>\n <ng-content></ng-content>\n </div>\n </div>\n\n <!-- FOOTER -->\n <ng-template pTemplate=\"footer\" *ngIf=\"config.showFooter !== false\">\n <div class=\"surface-100 px-4 py-2 flex justify-content-end gap-2\">\n <ng-content select=\"[ptDialogFooter]\"></ng-content>\n </div>\n </ng-template>\n</p-dialog>\n", styles: [":host ::ng-deep .pt-dialog-header-blue .p-dialog-header{background-color:#e0f2ff;border-bottom:0}:host ::ng-deep .pt-dialog-header-blue .p-dialog-footer{background-color:#f5f6f8!important;border-top:0!important}.pt-dialog-header-inner{width:100%;padding:1rem 1rem .75rem;display:flex;align-items:center;justify-content:space-between}.pt-dialog-header-left{display:flex;align-items:center}.pt-dialog-header-icon{margin-right:.5rem}.pt-dialog-header-title{font-weight:700;font-size:1.125rem}.pt-dialog-body{padding:1.25rem 1rem 1rem;display:flex;justify-content:center}.pt-dialog-body-inner{width:100%;max-width:100%;display:flex;flex-direction:column;gap:.75rem}\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: i2.Dialog, selector: "p-dialog", inputs: ["header", "draggable", "resizable", "positionLeft", "positionTop", "contentStyle", "contentStyleClass", "modal", "closeOnEscape", "dismissableMask", "rtl", "closable", "responsive", "appendTo", "breakpoints", "styleClass", "maskStyleClass", "maskStyle", "showHeader", "breakpoint", "blockScroll", "autoZIndex", "baseZIndex", "minX", "minY", "focusOnShow", "maximizable", "keepInViewport", "focusTrap", "transitionOptions", "closeIcon", "closeAriaLabel", "closeTabindex", "minimizeIcon", "maximizeIcon", "visible", "style", "position"], outputs: ["onShow", "onHide", "visibleChange", "onResizeInit", "onResizeEnd", "onDragEnd", "onMaximize"] }, { kind: "directive", type: i3.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }] }); }
138
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PTDialogComponent, selector: "pt-dialog", inputs: { config: "config", visible: "visible" }, outputs: { visibleChange: "visibleChange" }, ngImport: i0, template: "<p-dialog\n [visible]=\"_internalVisible\"\n (visibleChange)=\"onInternalVisibleChange($event)\"\n [header]=\"config.header\"\n [modal]=\"config.modal\"\n [style]=\"config.style\"\n [breakpoints]=\"config.breakpoints\"\n [closable]=\"config.closable\"\n [draggable]=\"config.draggable\"\n [resizable]=\"config.resizable\"\n [maximizable]=\"config.maximizable\"\n [dismissableMask]=\"config.dismissableMask\"\n [closeOnEscape]=\"config.closeOnEscape\"\n [blockScroll]=\"config.blockScroll\"\n [position]=\"primePosition\"\n [contentStyle]=\"config.contentStyle\"\n [styleClass]=\"dialogStyleClass\"\n>\n <!-- HEADER -->\n <ng-template pTemplate=\"header\">\n <div class=\"pt-dialog-header-inner\">\n <div class=\"pt-dialog-header-left\">\n <i\n *ngIf=\"config.headerIconClass\"\n class=\"pt-dialog-header-icon\"\n [ngClass]=\"safeHeaderIconClass\"\n [ngStyle]=\"headerIconStyle\"\n ></i>\n\n <ng-content select=\"[ptDialogHeader]\"></ng-content>\n\n <span\n *ngIf=\"config.header\"\n class=\"pt-dialog-header-title\"\n [ngStyle]=\"headerTitleStyle\"\n >\n {{ config.header }}\n </span>\n </div>\n </div>\n </ng-template>\n\n <!-- BODY -->\n <div class=\"pt-dialog-body\" [ngStyle]=\"bodyStyle\">\n <div class=\"pt-dialog-body-inner\">\n <ng-content select=\"[ptDialogContent]\"></ng-content>\n <ng-content></ng-content>\n </div>\n </div>\n\n <!-- FOOTER -->\n <ng-template pTemplate=\"footer\" *ngIf=\"config.showFooter !== false\">\n <div class=\"surface-100 px-4 py-2 flex justify-content-end gap-2\">\n <ng-content select=\"[ptDialogFooter]\"></ng-content>\n </div>\n </ng-template>\n</p-dialog>\n", styles: [":host ::ng-deep .p-dialog.pt-dialog-overlay{border-radius:18px;overflow:hidden;box-shadow:0 20px 45px #0f172a59}:host ::ng-deep .p-dialog.pt-dialog-info .p-dialog-header{background-color:#e0f2fe;border-bottom:0}:host ::ng-deep .p-dialog.pt-dialog-success .p-dialog-header{background-color:#dcfce7;border-bottom:0}:host ::ng-deep .p-dialog.pt-dialog-warning .p-dialog-header{background-color:#fff4d1;border-bottom:0}:host ::ng-deep .p-dialog.pt-dialog-danger .p-dialog-header{background-color:#fde4e4;border-bottom:0}:host ::ng-deep .p-dialog.pt-dialog-overlay .p-dialog-footer{background:#fff!important;border-top:1px solid rgba(148,163,184,.25)!important;padding:16px 32px 22px!important}:host ::ng-deep .p-dialog.pt-dialog-overlay .p-dialog-footer .surface-100{background:transparent!important}.pt-dialog-header-inner{width:100%;padding:1rem 1rem .75rem;display:flex;align-items:center;justify-content:space-between}.pt-dialog-header-left{display:flex;align-items:center}.pt-dialog-header-icon{margin-right:.5rem}.pt-dialog-header-title{font-weight:700;font-size:1.125rem}:host ::ng-deep .p-dialog.pt-dialog-info .pt-dialog-header-title,:host ::ng-deep .p-dialog.pt-dialog-info .pt-dialog-header-icon{color:#2563eb}:host ::ng-deep .p-dialog.pt-dialog-success .pt-dialog-header-title,:host ::ng-deep .p-dialog.pt-dialog-success .pt-dialog-header-icon{color:#15803d}:host ::ng-deep .p-dialog.pt-dialog-warning .pt-dialog-header-title,:host ::ng-deep .p-dialog.pt-dialog-warning .pt-dialog-header-icon{color:#b45309}:host ::ng-deep .p-dialog.pt-dialog-danger .pt-dialog-header-title,:host ::ng-deep .p-dialog.pt-dialog-danger .pt-dialog-header-icon{color:#b91c1c}.pt-dialog-body{padding:1.25rem 1rem 1rem;display:flex;justify-content:center}.pt-dialog-body-inner{width:100%;max-width:100%;display:flex;flex-direction:column;gap:.75rem}\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: i2.Dialog, selector: "p-dialog", inputs: ["header", "draggable", "resizable", "positionLeft", "positionTop", "contentStyle", "contentStyleClass", "modal", "closeOnEscape", "dismissableMask", "rtl", "closable", "responsive", "appendTo", "breakpoints", "styleClass", "maskStyleClass", "maskStyle", "showHeader", "breakpoint", "blockScroll", "autoZIndex", "baseZIndex", "minX", "minY", "focusOnShow", "maximizable", "keepInViewport", "focusTrap", "transitionOptions", "closeIcon", "closeAriaLabel", "closeTabindex", "minimizeIcon", "maximizeIcon", "visible", "style", "position"], outputs: ["onShow", "onHide", "visibleChange", "onResizeInit", "onResizeEnd", "onDragEnd", "onMaximize"] }, { kind: "directive", type: i3.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }] }); }
75
139
  }
76
140
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTDialogComponent, decorators: [{
77
141
  type: Component,
78
- args: [{ selector: 'pt-dialog', template: "<p-dialog\n [visible]=\"_internalVisible\"\n (visibleChange)=\"onInternalVisibleChange($event)\"\n [header]=\"config.header\"\n [modal]=\"config.modal\"\n [style]=\"config.style\"\n [breakpoints]=\"config.breakpoints\"\n [closable]=\"config.closable\"\n [draggable]=\"config.draggable\"\n [resizable]=\"config.resizable\"\n [maximizable]=\"config.maximizable\"\n [dismissableMask]=\"config.dismissableMask\"\n [closeOnEscape]=\"config.closeOnEscape\"\n [blockScroll]=\"config.blockScroll\"\n [position]=\"primePosition\"\n [contentStyle]=\"config.contentStyle\"\n [styleClass]=\"dialogStyleClass\"\n>\n <!-- HEADER -->\n <ng-template pTemplate=\"header\">\n <div class=\"pt-dialog-header-inner\">\n <div class=\"pt-dialog-header-left\">\n <i\n *ngIf=\"config.headerIconClass\"\n class=\"pt-dialog-header-icon\"\n [ngClass]=\"config.headerIconClass\"\n ></i>\n\n <ng-content select=\"[ptDialogHeader]\"></ng-content>\n\n <span *ngIf=\"config.header\" class=\"pt-dialog-header-title\">\n {{ config.header }}\n </span>\n </div>\n </div>\n </ng-template>\n\n <!-- BODY -->\n <div class=\"pt-dialog-body\" [ngStyle]=\"bodyStyle\">\n <div class=\"pt-dialog-body-inner\">\n <ng-content select=\"[ptDialogContent]\"></ng-content>\n <ng-content></ng-content>\n </div>\n </div>\n\n <!-- FOOTER -->\n <ng-template pTemplate=\"footer\" *ngIf=\"config.showFooter !== false\">\n <div class=\"surface-100 px-4 py-2 flex justify-content-end gap-2\">\n <ng-content select=\"[ptDialogFooter]\"></ng-content>\n </div>\n </ng-template>\n</p-dialog>\n", styles: [":host ::ng-deep .pt-dialog-header-blue .p-dialog-header{background-color:#e0f2ff;border-bottom:0}:host ::ng-deep .pt-dialog-header-blue .p-dialog-footer{background-color:#f5f6f8!important;border-top:0!important}.pt-dialog-header-inner{width:100%;padding:1rem 1rem .75rem;display:flex;align-items:center;justify-content:space-between}.pt-dialog-header-left{display:flex;align-items:center}.pt-dialog-header-icon{margin-right:.5rem}.pt-dialog-header-title{font-weight:700;font-size:1.125rem}.pt-dialog-body{padding:1.25rem 1rem 1rem;display:flex;justify-content:center}.pt-dialog-body-inner{width:100%;max-width:100%;display:flex;flex-direction:column;gap:.75rem}\n"] }]
142
+ args: [{ selector: 'pt-dialog', template: "<p-dialog\n [visible]=\"_internalVisible\"\n (visibleChange)=\"onInternalVisibleChange($event)\"\n [header]=\"config.header\"\n [modal]=\"config.modal\"\n [style]=\"config.style\"\n [breakpoints]=\"config.breakpoints\"\n [closable]=\"config.closable\"\n [draggable]=\"config.draggable\"\n [resizable]=\"config.resizable\"\n [maximizable]=\"config.maximizable\"\n [dismissableMask]=\"config.dismissableMask\"\n [closeOnEscape]=\"config.closeOnEscape\"\n [blockScroll]=\"config.blockScroll\"\n [position]=\"primePosition\"\n [contentStyle]=\"config.contentStyle\"\n [styleClass]=\"dialogStyleClass\"\n>\n <!-- HEADER -->\n <ng-template pTemplate=\"header\">\n <div class=\"pt-dialog-header-inner\">\n <div class=\"pt-dialog-header-left\">\n <i\n *ngIf=\"config.headerIconClass\"\n class=\"pt-dialog-header-icon\"\n [ngClass]=\"safeHeaderIconClass\"\n [ngStyle]=\"headerIconStyle\"\n ></i>\n\n <ng-content select=\"[ptDialogHeader]\"></ng-content>\n\n <span\n *ngIf=\"config.header\"\n class=\"pt-dialog-header-title\"\n [ngStyle]=\"headerTitleStyle\"\n >\n {{ config.header }}\n </span>\n </div>\n </div>\n </ng-template>\n\n <!-- BODY -->\n <div class=\"pt-dialog-body\" [ngStyle]=\"bodyStyle\">\n <div class=\"pt-dialog-body-inner\">\n <ng-content select=\"[ptDialogContent]\"></ng-content>\n <ng-content></ng-content>\n </div>\n </div>\n\n <!-- FOOTER -->\n <ng-template pTemplate=\"footer\" *ngIf=\"config.showFooter !== false\">\n <div class=\"surface-100 px-4 py-2 flex justify-content-end gap-2\">\n <ng-content select=\"[ptDialogFooter]\"></ng-content>\n </div>\n </ng-template>\n</p-dialog>\n", styles: [":host ::ng-deep .p-dialog.pt-dialog-overlay{border-radius:18px;overflow:hidden;box-shadow:0 20px 45px #0f172a59}:host ::ng-deep .p-dialog.pt-dialog-info .p-dialog-header{background-color:#e0f2fe;border-bottom:0}:host ::ng-deep .p-dialog.pt-dialog-success .p-dialog-header{background-color:#dcfce7;border-bottom:0}:host ::ng-deep .p-dialog.pt-dialog-warning .p-dialog-header{background-color:#fff4d1;border-bottom:0}:host ::ng-deep .p-dialog.pt-dialog-danger .p-dialog-header{background-color:#fde4e4;border-bottom:0}:host ::ng-deep .p-dialog.pt-dialog-overlay .p-dialog-footer{background:#fff!important;border-top:1px solid rgba(148,163,184,.25)!important;padding:16px 32px 22px!important}:host ::ng-deep .p-dialog.pt-dialog-overlay .p-dialog-footer .surface-100{background:transparent!important}.pt-dialog-header-inner{width:100%;padding:1rem 1rem .75rem;display:flex;align-items:center;justify-content:space-between}.pt-dialog-header-left{display:flex;align-items:center}.pt-dialog-header-icon{margin-right:.5rem}.pt-dialog-header-title{font-weight:700;font-size:1.125rem}:host ::ng-deep .p-dialog.pt-dialog-info .pt-dialog-header-title,:host ::ng-deep .p-dialog.pt-dialog-info .pt-dialog-header-icon{color:#2563eb}:host ::ng-deep .p-dialog.pt-dialog-success .pt-dialog-header-title,:host ::ng-deep .p-dialog.pt-dialog-success .pt-dialog-header-icon{color:#15803d}:host ::ng-deep .p-dialog.pt-dialog-warning .pt-dialog-header-title,:host ::ng-deep .p-dialog.pt-dialog-warning .pt-dialog-header-icon{color:#b45309}:host ::ng-deep .p-dialog.pt-dialog-danger .pt-dialog-header-title,:host ::ng-deep .p-dialog.pt-dialog-danger .pt-dialog-header-icon{color:#b91c1c}.pt-dialog-body{padding:1.25rem 1rem 1rem;display:flex;justify-content:center}.pt-dialog-body-inner{width:100%;max-width:100%;display:flex;flex-direction:column;gap:.75rem}\n"] }]
79
143
  }], propDecorators: { config: [{
80
144
  type: Input
81
145
  }], visible: [{
@@ -83,4 +147,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
83
147
  }], visibleChange: [{
84
148
  type: Output
85
149
  }] } });
86
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pt-dialog.component.js","sourceRoot":"","sources":["../../../../../projects/ng-prime-tools/src/lib/pt-dialog/pt-dialog.component.ts","../../../../../projects/ng-prime-tools/src/lib/pt-dialog/pt-dialog.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;;;;;AAMvE,MAAM,qBAAqB,GAAmB;IAC5C,KAAK,EAAE,IAAI;IACX,QAAQ,EAAE,IAAI;IACd,SAAS,EAAE,IAAI;IACf,SAAS,EAAE,IAAI;IACf,WAAW,EAAE,KAAK;IAClB,eAAe,EAAE,KAAK;IACtB,aAAa,EAAE,IAAI;IACnB,WAAW,EAAE,IAAI;IACjB,cAAc,EAAE,IAAI;IACpB,UAAU,EAAE,IAAI;IAChB,QAAQ,EAAE,QAAQ;CACnB,CAAC;AAOF,MAAM,OAAO,iBAAiB;IAL9B;QAME,kCAAkC;QAC1B,YAAO,GAAmB,EAAE,GAAG,qBAAqB,EAAE,CAAC;QAU/D,oEAAoE;QACpE,qBAAgB,GAAG,KAAK,CAAC;QAWf,kBAAa,GAAG,IAAI,YAAY,EAAW,CAAC;KAyCvD;IA7DC,IACI,MAAM,CAAC,KAAiC;QAC1C,IAAI,CAAC,OAAO,GAAG,EAAE,GAAG,qBAAqB,EAAE,GAAG,CAAC,KAAK,IAAI,EAAE,CAAC,EAAE,CAAC;IAChE,CAAC;IACD,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAKD,gCAAgC;IAChC,IACI,OAAO;QACT,OAAO,IAAI,CAAC,gBAAgB,CAAC;IAC/B,CAAC;IACD,IAAI,OAAO,CAAC,CAAU;QACpB,IAAI,CAAC,gBAAgB,GAAG,CAAC,CAAC;IAC5B,CAAC;IAID,IAAI,gBAAgB;QAClB,OAAO;YACL,kBAAkB;YAClB,UAAU;YACV,iBAAiB;YACjB,uBAAuB;YACvB,IAAI,CAAC,MAAM,CAAC,UAAU;SACvB;aACE,MAAM,CAAC,OAAO,CAAC;aACf,IAAI,CAAC,GAAG,CAAC,CAAC;IACf,CAAC;IAED,IAAI,aAAa;QACf,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,IAAI,QAAQ,CAAmB,CAAC;IAC9D,CAAC;IAED,IAAI,SAAS;QACX,MAAM,KAAK,GAAQ,EAAE,CAAC;QAEtB,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC;YAC1B,KAAK,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC;QAC7C,CAAC;QAED,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC;YAC3B,KAAK,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC;YAC7C,IAAI,IAAI,CAAC,MAAM,CAAC,cAAc,KAAK,KAAK,EAAE,CAAC;gBACzC,KAAK,CAAC,YAAY,CAAC,GAAG,MAAM,CAAC;gBAC7B,KAAK,CAAC,YAAY,CAAC,GAAG,MAAM,CAAC;YAC/B,CAAC;QACH,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAED,+BAA+B;IAC/B,uBAAuB,CAAC,CAAU;QAChC,IAAI,CAAC,gBAAgB,GAAG,CAAC,CAAC;QAC1B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC7B,CAAC;+GAhEU,iBAAiB;mGAAjB,iBAAiB,gJCzB9B,uoDAoDA;;4FD3Ba,iBAAiB;kBAL7B,SAAS;+BACE,WAAW;8BASjB,MAAM;sBADT,KAAK;gBAaF,OAAO;sBADV,KAAK;gBAQI,aAAa;sBAAtB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport {\n  DialogPosition,\n  PTDialogConfig,\n} from '../models/pt-dialog-config.model';\n\nconst DEFAULT_DIALOG_CONFIG: PTDialogConfig = {\n  modal: true,\n  closable: true,\n  draggable: true,\n  resizable: true,\n  maximizable: false,\n  dismissableMask: false,\n  closeOnEscape: true,\n  blockScroll: true,\n  bodyScrollable: true,\n  showFooter: true,\n  position: 'center',\n};\n\n@Component({\n  selector: 'pt-dialog',\n  templateUrl: './pt-dialog.component.html',\n  styleUrls: ['./pt-dialog.component.css'],\n})\nexport class PTDialogComponent {\n  /** Single configuration object */\n  private _config: PTDialogConfig = { ...DEFAULT_DIALOG_CONFIG };\n\n  @Input()\n  set config(value: PTDialogConfig | undefined) {\n    this._config = { ...DEFAULT_DIALOG_CONFIG, ...(value || {}) };\n  }\n  get config(): PTDialogConfig {\n    return this._config;\n  }\n\n  // ---- Internal visible state (PUBLIC so template can read it) ----\n  _internalVisible = false;\n\n  /** Input visible from parent */\n  @Input()\n  get visible(): boolean {\n    return this._internalVisible;\n  }\n  set visible(v: boolean) {\n    this._internalVisible = v;\n  }\n\n  @Output() visibleChange = new EventEmitter<boolean>();\n\n  get dialogStyleClass(): string {\n    return [\n      'border-round-3xl',\n      'shadow-6',\n      'overflow-hidden',\n      'pt-dialog-header-blue',\n      this.config.styleClass,\n    ]\n      .filter(Boolean)\n      .join(' ');\n  }\n\n  get primePosition(): DialogPosition {\n    return (this.config.position ?? 'center') as DialogPosition;\n  }\n\n  get bodyStyle(): { [key: string]: any } {\n    const style: any = {};\n\n    if (this.config.bodyWidth) {\n      style['max-width'] = this.config.bodyWidth;\n    }\n\n    if (this.config.bodyHeight) {\n      style['max-height'] = this.config.bodyHeight;\n      if (this.config.bodyScrollable !== false) {\n        style['overflow-y'] = 'auto';\n        style['overflow-x'] = 'auto';\n      }\n    }\n\n    return style;\n  }\n\n  /** Sync <p-dialog> → parent */\n  onInternalVisibleChange(v: boolean): void {\n    this._internalVisible = v;\n    this.visibleChange.emit(v);\n  }\n}\n","<p-dialog\n  [visible]=\"_internalVisible\"\n  (visibleChange)=\"onInternalVisibleChange($event)\"\n  [header]=\"config.header\"\n  [modal]=\"config.modal\"\n  [style]=\"config.style\"\n  [breakpoints]=\"config.breakpoints\"\n  [closable]=\"config.closable\"\n  [draggable]=\"config.draggable\"\n  [resizable]=\"config.resizable\"\n  [maximizable]=\"config.maximizable\"\n  [dismissableMask]=\"config.dismissableMask\"\n  [closeOnEscape]=\"config.closeOnEscape\"\n  [blockScroll]=\"config.blockScroll\"\n  [position]=\"primePosition\"\n  [contentStyle]=\"config.contentStyle\"\n  [styleClass]=\"dialogStyleClass\"\n>\n  <!-- HEADER -->\n  <ng-template pTemplate=\"header\">\n    <div class=\"pt-dialog-header-inner\">\n      <div class=\"pt-dialog-header-left\">\n        <i\n          *ngIf=\"config.headerIconClass\"\n          class=\"pt-dialog-header-icon\"\n          [ngClass]=\"config.headerIconClass\"\n        ></i>\n\n        <ng-content select=\"[ptDialogHeader]\"></ng-content>\n\n        <span *ngIf=\"config.header\" class=\"pt-dialog-header-title\">\n          {{ config.header }}\n        </span>\n      </div>\n    </div>\n  </ng-template>\n\n  <!-- BODY -->\n  <div class=\"pt-dialog-body\" [ngStyle]=\"bodyStyle\">\n    <div class=\"pt-dialog-body-inner\">\n      <ng-content select=\"[ptDialogContent]\"></ng-content>\n      <ng-content></ng-content>\n    </div>\n  </div>\n\n  <!-- FOOTER -->\n  <ng-template pTemplate=\"footer\" *ngIf=\"config.showFooter !== false\">\n    <div class=\"surface-100 px-4 py-2 flex justify-content-end gap-2\">\n      <ng-content select=\"[ptDialogFooter]\"></ng-content>\n    </div>\n  </ng-template>\n</p-dialog>\n"]}
150
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pt-dialog.component.js","sourceRoot":"","sources":["../../../../../projects/ng-prime-tools/src/lib/pt-dialog/pt-dialog.component.ts","../../../../../projects/ng-prime-tools/src/lib/pt-dialog/pt-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport {\n  DialogPosition,\n  PTDialogConfig,\n} from '../models/pt-dialog-config.model';\nimport { SeverityEnum } from '../enums';\n\nconst DEFAULT_DIALOG_CONFIG: PTDialogConfig = {\n  dialogStyle: SeverityEnum.INFO,\n  modal: true,\n  closable: true,\n  draggable: true,\n  resizable: true,\n  maximizable: false,\n  dismissableMask: false,\n  closeOnEscape: true,\n  blockScroll: true,\n  bodyScrollable: true,\n  showFooter: true,\n  position: 'center',\n};\n\n@Component({\n  selector: 'pt-dialog',\n  templateUrl: './pt-dialog.component.html',\n  styleUrls: ['./pt-dialog.component.css'],\n})\nexport class PTDialogComponent {\n  /** Single configuration object */\n  private _config: PTDialogConfig = { ...DEFAULT_DIALOG_CONFIG };\n\n  @Input()\n  set config(value: PTDialogConfig | undefined) {\n    this._config = { ...DEFAULT_DIALOG_CONFIG, ...(value || {}) };\n  }\n  get config(): PTDialogConfig {\n    return this._config;\n  }\n\n  // ---- Internal visible state (PUBLIC so template can read it) ----\n  _internalVisible = false;\n\n  /** Input visible from parent */\n  @Input()\n  get visible(): boolean {\n    return this._internalVisible;\n  }\n  set visible(v: boolean) {\n    this._internalVisible = v;\n  }\n\n  @Output() visibleChange = new EventEmitter<boolean>();\n\n  /** ✅ Same mapping logic as pt-confirm-dialog */\n  get dialogSeverity(): SeverityEnum {\n    const style = this.config.dialogStyle ?? SeverityEnum.INFO;\n\n    return style === SeverityEnum.DANGER\n      ? SeverityEnum.DANGER\n      : style === SeverityEnum.WARNING\n        ? SeverityEnum.WARNING\n        : style === SeverityEnum.SUCCESS\n          ? SeverityEnum.SUCCESS\n          : SeverityEnum.INFO;\n  }\n\n  /** ✅ Used in [styleClass] to apply CSS theme per severity */\n  private getSeverityClass(): string {\n    switch (this.dialogSeverity) {\n      case SeverityEnum.DANGER:\n        return 'pt-dialog-danger';\n      case SeverityEnum.WARNING:\n        return 'pt-dialog-warning';\n      case SeverityEnum.SUCCESS:\n        return 'pt-dialog-success';\n      case SeverityEnum.INFO:\n      default:\n        return 'pt-dialog-info';\n    }\n  }\n\n  get dialogStyleClass(): string {\n    return [\n      'border-round-3xl',\n      'shadow-6',\n      'overflow-hidden',\n      'pt-dialog-overlay',\n      this.getSeverityClass(),\n      this.config.styleClass,\n    ]\n      .filter(Boolean)\n      .join(' ');\n  }\n\n  get primePosition(): DialogPosition {\n    return (this.config.position ?? 'center') as DialogPosition;\n  }\n\n  get bodyStyle(): { [key: string]: any } {\n    const style: any = {};\n\n    if (this.config.bodyWidth) {\n      style['max-width'] = this.config.bodyWidth;\n    }\n\n    if (this.config.bodyHeight) {\n      style['max-height'] = this.config.bodyHeight;\n      if (this.config.bodyScrollable !== false) {\n        style['overflow-y'] = 'auto';\n        style['overflow-x'] = 'auto';\n      }\n    }\n\n    return style;\n  }\n\n  /** Sync <p-dialog> → parent */\n  onInternalVisibleChange(v: boolean): void {\n    this._internalVisible = v;\n    this.visibleChange.emit(v);\n  }\n\n  // ============================================================\n  // ✅ Severity colors for header elements (icon + title)\n  // ============================================================\n  private getSeverityHeaderColor(): string {\n    switch (this.dialogSeverity) {\n      case SeverityEnum.DANGER:\n        return '#b91c1c';\n      case SeverityEnum.WARNING:\n        return '#b45309';\n      case SeverityEnum.SUCCESS:\n        return '#15803d';\n      case SeverityEnum.INFO:\n      default:\n        return '#2563eb';\n    }\n  }\n\n  /** ✅ Inline style to override text-primary / utility classes */\n  get headerIconStyle(): { [key: string]: any } {\n    return { color: this.getSeverityHeaderColor() };\n  }\n\n  /** ✅ Optional but recommended: keep title consistent with icon */\n  get headerTitleStyle(): { [key: string]: any } {\n    return { color: this.getSeverityHeaderColor() };\n  }\n  private removeTextUtilityClasses(cls: string | undefined): string {\n    if (!cls) return '';\n\n    return cls\n      .split(/\\s+/)\n      .filter(Boolean)\n      .filter((c) => !c.startsWith('text-')) // removes text-primary, text-danger, etc.\n      .join(' ');\n  }\n\n  get safeHeaderIconClass(): string {\n    return this.removeTextUtilityClasses(this.config.headerIconClass);\n  }\n}\n","<p-dialog\n  [visible]=\"_internalVisible\"\n  (visibleChange)=\"onInternalVisibleChange($event)\"\n  [header]=\"config.header\"\n  [modal]=\"config.modal\"\n  [style]=\"config.style\"\n  [breakpoints]=\"config.breakpoints\"\n  [closable]=\"config.closable\"\n  [draggable]=\"config.draggable\"\n  [resizable]=\"config.resizable\"\n  [maximizable]=\"config.maximizable\"\n  [dismissableMask]=\"config.dismissableMask\"\n  [closeOnEscape]=\"config.closeOnEscape\"\n  [blockScroll]=\"config.blockScroll\"\n  [position]=\"primePosition\"\n  [contentStyle]=\"config.contentStyle\"\n  [styleClass]=\"dialogStyleClass\"\n>\n  <!-- HEADER -->\n  <ng-template pTemplate=\"header\">\n    <div class=\"pt-dialog-header-inner\">\n      <div class=\"pt-dialog-header-left\">\n        <i\n          *ngIf=\"config.headerIconClass\"\n          class=\"pt-dialog-header-icon\"\n          [ngClass]=\"safeHeaderIconClass\"\n          [ngStyle]=\"headerIconStyle\"\n        ></i>\n\n        <ng-content select=\"[ptDialogHeader]\"></ng-content>\n\n        <span\n          *ngIf=\"config.header\"\n          class=\"pt-dialog-header-title\"\n          [ngStyle]=\"headerTitleStyle\"\n        >\n          {{ config.header }}\n        </span>\n      </div>\n    </div>\n  </ng-template>\n\n  <!-- BODY -->\n  <div class=\"pt-dialog-body\" [ngStyle]=\"bodyStyle\">\n    <div class=\"pt-dialog-body-inner\">\n      <ng-content select=\"[ptDialogContent]\"></ng-content>\n      <ng-content></ng-content>\n    </div>\n  </div>\n\n  <!-- FOOTER -->\n  <ng-template pTemplate=\"footer\" *ngIf=\"config.showFooter !== false\">\n    <div class=\"surface-100 px-4 py-2 flex justify-content-end gap-2\">\n      <ng-content select=\"[ptDialogFooter]\"></ng-content>\n    </div>\n  </ng-template>\n</p-dialog>\n"]}
@@ -4755,6 +4755,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
4755
4755
  }] });
4756
4756
 
4757
4757
  const DEFAULT_DIALOG_CONFIG = {
4758
+ dialogStyle: SeverityEnum.INFO,
4758
4759
  modal: true,
4759
4760
  closable: true,
4760
4761
  draggable: true,
@@ -4788,12 +4789,38 @@ class PTDialogComponent {
4788
4789
  set visible(v) {
4789
4790
  this._internalVisible = v;
4790
4791
  }
4792
+ /** ✅ Same mapping logic as pt-confirm-dialog */
4793
+ get dialogSeverity() {
4794
+ const style = this.config.dialogStyle ?? SeverityEnum.INFO;
4795
+ return style === SeverityEnum.DANGER
4796
+ ? SeverityEnum.DANGER
4797
+ : style === SeverityEnum.WARNING
4798
+ ? SeverityEnum.WARNING
4799
+ : style === SeverityEnum.SUCCESS
4800
+ ? SeverityEnum.SUCCESS
4801
+ : SeverityEnum.INFO;
4802
+ }
4803
+ /** ✅ Used in [styleClass] to apply CSS theme per severity */
4804
+ getSeverityClass() {
4805
+ switch (this.dialogSeverity) {
4806
+ case SeverityEnum.DANGER:
4807
+ return 'pt-dialog-danger';
4808
+ case SeverityEnum.WARNING:
4809
+ return 'pt-dialog-warning';
4810
+ case SeverityEnum.SUCCESS:
4811
+ return 'pt-dialog-success';
4812
+ case SeverityEnum.INFO:
4813
+ default:
4814
+ return 'pt-dialog-info';
4815
+ }
4816
+ }
4791
4817
  get dialogStyleClass() {
4792
4818
  return [
4793
4819
  'border-round-3xl',
4794
4820
  'shadow-6',
4795
4821
  'overflow-hidden',
4796
- 'pt-dialog-header-blue',
4822
+ 'pt-dialog-overlay',
4823
+ this.getSeverityClass(),
4797
4824
  this.config.styleClass,
4798
4825
  ]
4799
4826
  .filter(Boolean)
@@ -4821,12 +4848,48 @@ class PTDialogComponent {
4821
4848
  this._internalVisible = v;
4822
4849
  this.visibleChange.emit(v);
4823
4850
  }
4851
+ // ============================================================
4852
+ // ✅ Severity colors for header elements (icon + title)
4853
+ // ============================================================
4854
+ getSeverityHeaderColor() {
4855
+ switch (this.dialogSeverity) {
4856
+ case SeverityEnum.DANGER:
4857
+ return '#b91c1c';
4858
+ case SeverityEnum.WARNING:
4859
+ return '#b45309';
4860
+ case SeverityEnum.SUCCESS:
4861
+ return '#15803d';
4862
+ case SeverityEnum.INFO:
4863
+ default:
4864
+ return '#2563eb';
4865
+ }
4866
+ }
4867
+ /** ✅ Inline style to override text-primary / utility classes */
4868
+ get headerIconStyle() {
4869
+ return { color: this.getSeverityHeaderColor() };
4870
+ }
4871
+ /** ✅ Optional but recommended: keep title consistent with icon */
4872
+ get headerTitleStyle() {
4873
+ return { color: this.getSeverityHeaderColor() };
4874
+ }
4875
+ removeTextUtilityClasses(cls) {
4876
+ if (!cls)
4877
+ return '';
4878
+ return cls
4879
+ .split(/\s+/)
4880
+ .filter(Boolean)
4881
+ .filter((c) => !c.startsWith('text-')) // removes text-primary, text-danger, etc.
4882
+ .join(' ');
4883
+ }
4884
+ get safeHeaderIconClass() {
4885
+ return this.removeTextUtilityClasses(this.config.headerIconClass);
4886
+ }
4824
4887
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTDialogComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
4825
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PTDialogComponent, selector: "pt-dialog", inputs: { config: "config", visible: "visible" }, outputs: { visibleChange: "visibleChange" }, ngImport: i0, template: "<p-dialog\n [visible]=\"_internalVisible\"\n (visibleChange)=\"onInternalVisibleChange($event)\"\n [header]=\"config.header\"\n [modal]=\"config.modal\"\n [style]=\"config.style\"\n [breakpoints]=\"config.breakpoints\"\n [closable]=\"config.closable\"\n [draggable]=\"config.draggable\"\n [resizable]=\"config.resizable\"\n [maximizable]=\"config.maximizable\"\n [dismissableMask]=\"config.dismissableMask\"\n [closeOnEscape]=\"config.closeOnEscape\"\n [blockScroll]=\"config.blockScroll\"\n [position]=\"primePosition\"\n [contentStyle]=\"config.contentStyle\"\n [styleClass]=\"dialogStyleClass\"\n>\n <!-- HEADER -->\n <ng-template pTemplate=\"header\">\n <div class=\"pt-dialog-header-inner\">\n <div class=\"pt-dialog-header-left\">\n <i\n *ngIf=\"config.headerIconClass\"\n class=\"pt-dialog-header-icon\"\n [ngClass]=\"config.headerIconClass\"\n ></i>\n\n <ng-content select=\"[ptDialogHeader]\"></ng-content>\n\n <span *ngIf=\"config.header\" class=\"pt-dialog-header-title\">\n {{ config.header }}\n </span>\n </div>\n </div>\n </ng-template>\n\n <!-- BODY -->\n <div class=\"pt-dialog-body\" [ngStyle]=\"bodyStyle\">\n <div class=\"pt-dialog-body-inner\">\n <ng-content select=\"[ptDialogContent]\"></ng-content>\n <ng-content></ng-content>\n </div>\n </div>\n\n <!-- FOOTER -->\n <ng-template pTemplate=\"footer\" *ngIf=\"config.showFooter !== false\">\n <div class=\"surface-100 px-4 py-2 flex justify-content-end gap-2\">\n <ng-content select=\"[ptDialogFooter]\"></ng-content>\n </div>\n </ng-template>\n</p-dialog>\n", styles: [":host ::ng-deep .pt-dialog-header-blue .p-dialog-header{background-color:#e0f2ff;border-bottom:0}:host ::ng-deep .pt-dialog-header-blue .p-dialog-footer{background-color:#f5f6f8!important;border-top:0!important}.pt-dialog-header-inner{width:100%;padding:1rem 1rem .75rem;display:flex;align-items:center;justify-content:space-between}.pt-dialog-header-left{display:flex;align-items:center}.pt-dialog-header-icon{margin-right:.5rem}.pt-dialog-header-title{font-weight:700;font-size:1.125rem}.pt-dialog-body{padding:1.25rem 1rem 1rem;display:flex;justify-content:center}.pt-dialog-body-inner{width:100%;max-width:100%;display:flex;flex-direction:column;gap:.75rem}\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: i2$3.Dialog, selector: "p-dialog", inputs: ["header", "draggable", "resizable", "positionLeft", "positionTop", "contentStyle", "contentStyleClass", "modal", "closeOnEscape", "dismissableMask", "rtl", "closable", "responsive", "appendTo", "breakpoints", "styleClass", "maskStyleClass", "maskStyle", "showHeader", "breakpoint", "blockScroll", "autoZIndex", "baseZIndex", "minX", "minY", "focusOnShow", "maximizable", "keepInViewport", "focusTrap", "transitionOptions", "closeIcon", "closeAriaLabel", "closeTabindex", "minimizeIcon", "maximizeIcon", "visible", "style", "position"], outputs: ["onShow", "onHide", "visibleChange", "onResizeInit", "onResizeEnd", "onDragEnd", "onMaximize"] }, { kind: "directive", type: i1$1.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }] }); }
4888
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PTDialogComponent, selector: "pt-dialog", inputs: { config: "config", visible: "visible" }, outputs: { visibleChange: "visibleChange" }, ngImport: i0, template: "<p-dialog\n [visible]=\"_internalVisible\"\n (visibleChange)=\"onInternalVisibleChange($event)\"\n [header]=\"config.header\"\n [modal]=\"config.modal\"\n [style]=\"config.style\"\n [breakpoints]=\"config.breakpoints\"\n [closable]=\"config.closable\"\n [draggable]=\"config.draggable\"\n [resizable]=\"config.resizable\"\n [maximizable]=\"config.maximizable\"\n [dismissableMask]=\"config.dismissableMask\"\n [closeOnEscape]=\"config.closeOnEscape\"\n [blockScroll]=\"config.blockScroll\"\n [position]=\"primePosition\"\n [contentStyle]=\"config.contentStyle\"\n [styleClass]=\"dialogStyleClass\"\n>\n <!-- HEADER -->\n <ng-template pTemplate=\"header\">\n <div class=\"pt-dialog-header-inner\">\n <div class=\"pt-dialog-header-left\">\n <i\n *ngIf=\"config.headerIconClass\"\n class=\"pt-dialog-header-icon\"\n [ngClass]=\"safeHeaderIconClass\"\n [ngStyle]=\"headerIconStyle\"\n ></i>\n\n <ng-content select=\"[ptDialogHeader]\"></ng-content>\n\n <span\n *ngIf=\"config.header\"\n class=\"pt-dialog-header-title\"\n [ngStyle]=\"headerTitleStyle\"\n >\n {{ config.header }}\n </span>\n </div>\n </div>\n </ng-template>\n\n <!-- BODY -->\n <div class=\"pt-dialog-body\" [ngStyle]=\"bodyStyle\">\n <div class=\"pt-dialog-body-inner\">\n <ng-content select=\"[ptDialogContent]\"></ng-content>\n <ng-content></ng-content>\n </div>\n </div>\n\n <!-- FOOTER -->\n <ng-template pTemplate=\"footer\" *ngIf=\"config.showFooter !== false\">\n <div class=\"surface-100 px-4 py-2 flex justify-content-end gap-2\">\n <ng-content select=\"[ptDialogFooter]\"></ng-content>\n </div>\n </ng-template>\n</p-dialog>\n", styles: [":host ::ng-deep .p-dialog.pt-dialog-overlay{border-radius:18px;overflow:hidden;box-shadow:0 20px 45px #0f172a59}:host ::ng-deep .p-dialog.pt-dialog-info .p-dialog-header{background-color:#e0f2fe;border-bottom:0}:host ::ng-deep .p-dialog.pt-dialog-success .p-dialog-header{background-color:#dcfce7;border-bottom:0}:host ::ng-deep .p-dialog.pt-dialog-warning .p-dialog-header{background-color:#fff4d1;border-bottom:0}:host ::ng-deep .p-dialog.pt-dialog-danger .p-dialog-header{background-color:#fde4e4;border-bottom:0}:host ::ng-deep .p-dialog.pt-dialog-overlay .p-dialog-footer{background:#fff!important;border-top:1px solid rgba(148,163,184,.25)!important;padding:16px 32px 22px!important}:host ::ng-deep .p-dialog.pt-dialog-overlay .p-dialog-footer .surface-100{background:transparent!important}.pt-dialog-header-inner{width:100%;padding:1rem 1rem .75rem;display:flex;align-items:center;justify-content:space-between}.pt-dialog-header-left{display:flex;align-items:center}.pt-dialog-header-icon{margin-right:.5rem}.pt-dialog-header-title{font-weight:700;font-size:1.125rem}:host ::ng-deep .p-dialog.pt-dialog-info .pt-dialog-header-title,:host ::ng-deep .p-dialog.pt-dialog-info .pt-dialog-header-icon{color:#2563eb}:host ::ng-deep .p-dialog.pt-dialog-success .pt-dialog-header-title,:host ::ng-deep .p-dialog.pt-dialog-success .pt-dialog-header-icon{color:#15803d}:host ::ng-deep .p-dialog.pt-dialog-warning .pt-dialog-header-title,:host ::ng-deep .p-dialog.pt-dialog-warning .pt-dialog-header-icon{color:#b45309}:host ::ng-deep .p-dialog.pt-dialog-danger .pt-dialog-header-title,:host ::ng-deep .p-dialog.pt-dialog-danger .pt-dialog-header-icon{color:#b91c1c}.pt-dialog-body{padding:1.25rem 1rem 1rem;display:flex;justify-content:center}.pt-dialog-body-inner{width:100%;max-width:100%;display:flex;flex-direction:column;gap:.75rem}\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: i2$3.Dialog, selector: "p-dialog", inputs: ["header", "draggable", "resizable", "positionLeft", "positionTop", "contentStyle", "contentStyleClass", "modal", "closeOnEscape", "dismissableMask", "rtl", "closable", "responsive", "appendTo", "breakpoints", "styleClass", "maskStyleClass", "maskStyle", "showHeader", "breakpoint", "blockScroll", "autoZIndex", "baseZIndex", "minX", "minY", "focusOnShow", "maximizable", "keepInViewport", "focusTrap", "transitionOptions", "closeIcon", "closeAriaLabel", "closeTabindex", "minimizeIcon", "maximizeIcon", "visible", "style", "position"], outputs: ["onShow", "onHide", "visibleChange", "onResizeInit", "onResizeEnd", "onDragEnd", "onMaximize"] }, { kind: "directive", type: i1$1.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }] }); }
4826
4889
  }
4827
4890
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTDialogComponent, decorators: [{
4828
4891
  type: Component,
4829
- args: [{ selector: 'pt-dialog', template: "<p-dialog\n [visible]=\"_internalVisible\"\n (visibleChange)=\"onInternalVisibleChange($event)\"\n [header]=\"config.header\"\n [modal]=\"config.modal\"\n [style]=\"config.style\"\n [breakpoints]=\"config.breakpoints\"\n [closable]=\"config.closable\"\n [draggable]=\"config.draggable\"\n [resizable]=\"config.resizable\"\n [maximizable]=\"config.maximizable\"\n [dismissableMask]=\"config.dismissableMask\"\n [closeOnEscape]=\"config.closeOnEscape\"\n [blockScroll]=\"config.blockScroll\"\n [position]=\"primePosition\"\n [contentStyle]=\"config.contentStyle\"\n [styleClass]=\"dialogStyleClass\"\n>\n <!-- HEADER -->\n <ng-template pTemplate=\"header\">\n <div class=\"pt-dialog-header-inner\">\n <div class=\"pt-dialog-header-left\">\n <i\n *ngIf=\"config.headerIconClass\"\n class=\"pt-dialog-header-icon\"\n [ngClass]=\"config.headerIconClass\"\n ></i>\n\n <ng-content select=\"[ptDialogHeader]\"></ng-content>\n\n <span *ngIf=\"config.header\" class=\"pt-dialog-header-title\">\n {{ config.header }}\n </span>\n </div>\n </div>\n </ng-template>\n\n <!-- BODY -->\n <div class=\"pt-dialog-body\" [ngStyle]=\"bodyStyle\">\n <div class=\"pt-dialog-body-inner\">\n <ng-content select=\"[ptDialogContent]\"></ng-content>\n <ng-content></ng-content>\n </div>\n </div>\n\n <!-- FOOTER -->\n <ng-template pTemplate=\"footer\" *ngIf=\"config.showFooter !== false\">\n <div class=\"surface-100 px-4 py-2 flex justify-content-end gap-2\">\n <ng-content select=\"[ptDialogFooter]\"></ng-content>\n </div>\n </ng-template>\n</p-dialog>\n", styles: [":host ::ng-deep .pt-dialog-header-blue .p-dialog-header{background-color:#e0f2ff;border-bottom:0}:host ::ng-deep .pt-dialog-header-blue .p-dialog-footer{background-color:#f5f6f8!important;border-top:0!important}.pt-dialog-header-inner{width:100%;padding:1rem 1rem .75rem;display:flex;align-items:center;justify-content:space-between}.pt-dialog-header-left{display:flex;align-items:center}.pt-dialog-header-icon{margin-right:.5rem}.pt-dialog-header-title{font-weight:700;font-size:1.125rem}.pt-dialog-body{padding:1.25rem 1rem 1rem;display:flex;justify-content:center}.pt-dialog-body-inner{width:100%;max-width:100%;display:flex;flex-direction:column;gap:.75rem}\n"] }]
4892
+ args: [{ selector: 'pt-dialog', template: "<p-dialog\n [visible]=\"_internalVisible\"\n (visibleChange)=\"onInternalVisibleChange($event)\"\n [header]=\"config.header\"\n [modal]=\"config.modal\"\n [style]=\"config.style\"\n [breakpoints]=\"config.breakpoints\"\n [closable]=\"config.closable\"\n [draggable]=\"config.draggable\"\n [resizable]=\"config.resizable\"\n [maximizable]=\"config.maximizable\"\n [dismissableMask]=\"config.dismissableMask\"\n [closeOnEscape]=\"config.closeOnEscape\"\n [blockScroll]=\"config.blockScroll\"\n [position]=\"primePosition\"\n [contentStyle]=\"config.contentStyle\"\n [styleClass]=\"dialogStyleClass\"\n>\n <!-- HEADER -->\n <ng-template pTemplate=\"header\">\n <div class=\"pt-dialog-header-inner\">\n <div class=\"pt-dialog-header-left\">\n <i\n *ngIf=\"config.headerIconClass\"\n class=\"pt-dialog-header-icon\"\n [ngClass]=\"safeHeaderIconClass\"\n [ngStyle]=\"headerIconStyle\"\n ></i>\n\n <ng-content select=\"[ptDialogHeader]\"></ng-content>\n\n <span\n *ngIf=\"config.header\"\n class=\"pt-dialog-header-title\"\n [ngStyle]=\"headerTitleStyle\"\n >\n {{ config.header }}\n </span>\n </div>\n </div>\n </ng-template>\n\n <!-- BODY -->\n <div class=\"pt-dialog-body\" [ngStyle]=\"bodyStyle\">\n <div class=\"pt-dialog-body-inner\">\n <ng-content select=\"[ptDialogContent]\"></ng-content>\n <ng-content></ng-content>\n </div>\n </div>\n\n <!-- FOOTER -->\n <ng-template pTemplate=\"footer\" *ngIf=\"config.showFooter !== false\">\n <div class=\"surface-100 px-4 py-2 flex justify-content-end gap-2\">\n <ng-content select=\"[ptDialogFooter]\"></ng-content>\n </div>\n </ng-template>\n</p-dialog>\n", styles: [":host ::ng-deep .p-dialog.pt-dialog-overlay{border-radius:18px;overflow:hidden;box-shadow:0 20px 45px #0f172a59}:host ::ng-deep .p-dialog.pt-dialog-info .p-dialog-header{background-color:#e0f2fe;border-bottom:0}:host ::ng-deep .p-dialog.pt-dialog-success .p-dialog-header{background-color:#dcfce7;border-bottom:0}:host ::ng-deep .p-dialog.pt-dialog-warning .p-dialog-header{background-color:#fff4d1;border-bottom:0}:host ::ng-deep .p-dialog.pt-dialog-danger .p-dialog-header{background-color:#fde4e4;border-bottom:0}:host ::ng-deep .p-dialog.pt-dialog-overlay .p-dialog-footer{background:#fff!important;border-top:1px solid rgba(148,163,184,.25)!important;padding:16px 32px 22px!important}:host ::ng-deep .p-dialog.pt-dialog-overlay .p-dialog-footer .surface-100{background:transparent!important}.pt-dialog-header-inner{width:100%;padding:1rem 1rem .75rem;display:flex;align-items:center;justify-content:space-between}.pt-dialog-header-left{display:flex;align-items:center}.pt-dialog-header-icon{margin-right:.5rem}.pt-dialog-header-title{font-weight:700;font-size:1.125rem}:host ::ng-deep .p-dialog.pt-dialog-info .pt-dialog-header-title,:host ::ng-deep .p-dialog.pt-dialog-info .pt-dialog-header-icon{color:#2563eb}:host ::ng-deep .p-dialog.pt-dialog-success .pt-dialog-header-title,:host ::ng-deep .p-dialog.pt-dialog-success .pt-dialog-header-icon{color:#15803d}:host ::ng-deep .p-dialog.pt-dialog-warning .pt-dialog-header-title,:host ::ng-deep .p-dialog.pt-dialog-warning .pt-dialog-header-icon{color:#b45309}:host ::ng-deep .p-dialog.pt-dialog-danger .pt-dialog-header-title,:host ::ng-deep .p-dialog.pt-dialog-danger .pt-dialog-header-icon{color:#b91c1c}.pt-dialog-body{padding:1.25rem 1rem 1rem;display:flex;justify-content:center}.pt-dialog-body-inner{width:100%;max-width:100%;display:flex;flex-direction:column;gap:.75rem}\n"] }]
4830
4893
  }], propDecorators: { config: [{
4831
4894
  type: Input
4832
4895
  }], visible: [{