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.
- package/esm2022/lib/models/pt-dialog-config.model.mjs +1 -1
- package/esm2022/lib/pt-dialog/pt-dialog.component.mjs +68 -4
- package/fesm2022/ng-prime-tools.mjs +66 -3
- package/fesm2022/ng-prime-tools.mjs.map +1 -1
- package/lib/models/pt-dialog-config.model.d.ts +2 -0
- package/lib/models/pt-dialog-config.model.d.ts.map +1 -1
- package/lib/pt-dialog/pt-dialog.component.d.ts +16 -0
- package/lib/pt-dialog/pt-dialog.component.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
// src/lib/models/pt-dialog-config.model.ts
|
|
2
2
|
export {};
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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-
|
|
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]=\"
|
|
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]=\"
|
|
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-
|
|
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]=\"
|
|
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]=\"
|
|
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: [{
|