ng-prime-tools 1.0.32 → 1.0.33
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/README.md +3 -3
- package/esm2022/lib/enums/form-input-type.enum.mjs +2 -1
- package/esm2022/lib/enums/input-validation.enum.mjs +2 -1
- package/esm2022/lib/ng-prime-tools.module.mjs +9 -5
- package/esm2022/lib/pt-advanced-prime-table/pt-advanced-prime-table.component.mjs +77 -48
- package/esm2022/lib/pt-confirm-dialog/index.mjs +2 -0
- package/esm2022/lib/pt-confirm-dialog/pt-confirm-dialog.component.mjs +285 -0
- package/esm2022/lib/pt-confirm-dialog/pt-confirm-dialog.module.mjs +21 -0
- package/esm2022/lib/pt-confirm-dialog/public-api.mjs +3 -0
- package/esm2022/lib/pt-dialog/pt-dialog.component.mjs +96 -268
- package/esm2022/lib/pt-dialog/pt-dialog.module.mjs +5 -7
- package/esm2022/lib/pt-form-builder/pt-dynamic-form-field/pt-dynamic-form-field.component.mjs +3 -3
- package/esm2022/lib/pt-form-builder/pt-form-builder.component.mjs +67 -4
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/ng-prime-tools.mjs +298 -78
- package/fesm2022/ng-prime-tools.mjs.map +1 -1
- package/lib/enums/form-input-type.enum.d.ts +1 -0
- package/lib/enums/form-input-type.enum.d.ts.map +1 -1
- package/lib/enums/input-validation.enum.d.ts +2 -1
- package/lib/enums/input-validation.enum.d.ts.map +1 -1
- package/lib/ng-prime-tools.module.d.ts +3 -2
- package/lib/ng-prime-tools.module.d.ts.map +1 -1
- package/lib/pt-advanced-prime-table/pt-advanced-prime-table.component.d.ts +36 -11
- package/lib/pt-advanced-prime-table/pt-advanced-prime-table.component.d.ts.map +1 -1
- package/lib/pt-confirm-dialog/index.d.ts +2 -0
- package/lib/pt-confirm-dialog/index.d.ts.map +1 -0
- package/lib/pt-confirm-dialog/pt-confirm-dialog.component.d.ts +44 -0
- package/lib/pt-confirm-dialog/pt-confirm-dialog.component.d.ts.map +1 -0
- package/lib/pt-confirm-dialog/pt-confirm-dialog.module.d.ts +12 -0
- package/lib/pt-confirm-dialog/pt-confirm-dialog.module.d.ts.map +1 -0
- package/lib/pt-confirm-dialog/public-api.d.ts +3 -0
- package/lib/pt-confirm-dialog/public-api.d.ts.map +1 -0
- package/lib/pt-dialog/pt-dialog.component.d.ts +47 -40
- package/lib/pt-dialog/pt-dialog.component.d.ts.map +1 -1
- package/lib/pt-dialog/pt-dialog.module.d.ts +1 -3
- package/lib/pt-dialog/pt-dialog.module.d.ts.map +1 -1
- package/lib/pt-form-builder/pt-form-builder.component.d.ts +5 -1
- package/lib/pt-form-builder/pt-form-builder.component.d.ts.map +1 -1
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/public-api.d.ts.map +1 -1
|
@@ -1,285 +1,113 @@
|
|
|
1
|
-
import { Component, Input, Output
|
|
2
|
-
import { ConfirmationService, MessageService, } from 'primeng/api';
|
|
3
|
-
import { SeverityEnum } from '../enums';
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
4
2
|
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "
|
|
6
|
-
import * as i2 from "
|
|
7
|
-
import * as i3 from "
|
|
8
|
-
import * as i4 from "primeng/confirmdialog";
|
|
9
|
-
/**
|
|
10
|
-
* Styles per severity:
|
|
11
|
-
* - Only header (text/color) is provided here.
|
|
12
|
-
* - No default "content" text anymore.
|
|
13
|
-
*/
|
|
14
|
-
const DIALOG_STYLES = {
|
|
15
|
-
[SeverityEnum.WARNING]: {
|
|
16
|
-
header: { text: 'Avertissement', color: '#8a4b00' },
|
|
17
|
-
},
|
|
18
|
-
[SeverityEnum.SUCCESS]: {
|
|
19
|
-
header: { text: 'Succès', color: '#166534' },
|
|
20
|
-
},
|
|
21
|
-
[SeverityEnum.DANGER]: {
|
|
22
|
-
header: { text: 'Erreur', color: '#7f1d1d' },
|
|
23
|
-
},
|
|
24
|
-
[SeverityEnum.INFO]: {
|
|
25
|
-
header: { text: 'Information', color: '#2563eb' },
|
|
26
|
-
},
|
|
27
|
-
};
|
|
28
|
-
/**
|
|
29
|
-
* Default config:
|
|
30
|
-
* - content is now empty string (no default message).
|
|
31
|
-
*/
|
|
32
|
-
const DEFAULT_DIALOG_CONFIG = {
|
|
33
|
-
header: { text: 'Confirmation' },
|
|
34
|
-
visible: false,
|
|
35
|
-
width: '720px',
|
|
36
|
-
height: 'auto',
|
|
37
|
-
content: '', // no default message
|
|
38
|
-
confirmButtonConfig: {
|
|
39
|
-
label: 'Confirmer',
|
|
40
|
-
},
|
|
41
|
-
cancelButtonConfig: {
|
|
42
|
-
label: 'Annuler',
|
|
43
|
-
},
|
|
44
|
-
dialogStyle: SeverityEnum.INFO,
|
|
45
|
-
};
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "primeng/dialog";
|
|
5
|
+
import * as i3 from "primeng/api";
|
|
46
6
|
export class PTDialogComponent {
|
|
47
|
-
constructor(
|
|
48
|
-
|
|
49
|
-
this.
|
|
50
|
-
|
|
51
|
-
this.
|
|
52
|
-
this.
|
|
53
|
-
this.
|
|
54
|
-
this.
|
|
55
|
-
this.
|
|
7
|
+
constructor() {
|
|
8
|
+
/** Enable scroll when body exceeds given height/width */
|
|
9
|
+
this.bodyScrollable = true;
|
|
10
|
+
/** Control footer visibility (default: true) */
|
|
11
|
+
this.showFooter = true;
|
|
12
|
+
this.modal = true;
|
|
13
|
+
this.closable = true;
|
|
14
|
+
this.draggable = true;
|
|
15
|
+
this.resizable = true;
|
|
16
|
+
this.maximizable = false;
|
|
17
|
+
this.dismissableMask = false;
|
|
18
|
+
this.closeOnEscape = true;
|
|
19
|
+
this.blockScroll = true;
|
|
20
|
+
this.position = 'center';
|
|
21
|
+
/** internal visible flag used by p-dialog */
|
|
22
|
+
this._visible = false;
|
|
23
|
+
this.visibleChange = new EventEmitter();
|
|
56
24
|
}
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
const current = changes['dialogConfig'].currentValue;
|
|
60
|
-
if (changes['dialogConfig'].previousValue?.dialogStyle !==
|
|
61
|
-
current?.dialogStyle) {
|
|
62
|
-
this.applyDialogStyle();
|
|
63
|
-
}
|
|
64
|
-
if (this.dialogConfig.visible) {
|
|
65
|
-
this.showDialog();
|
|
66
|
-
}
|
|
67
|
-
}
|
|
25
|
+
get visible() {
|
|
26
|
+
return this._visible;
|
|
68
27
|
}
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
* We are careful NOT to spread header (it can be string or object).
|
|
72
|
-
*/
|
|
73
|
-
applyDialogStyle() {
|
|
74
|
-
const dialogStyle = this.dialogConfig.dialogStyle || SeverityEnum.INFO;
|
|
75
|
-
const styleConfig = DIALOG_STYLES[dialogStyle] || {};
|
|
76
|
-
const current = this.dialogConfig;
|
|
77
|
-
// Decide which header to use without spreading non-object types
|
|
78
|
-
const mergedHeader = current.header !== undefined
|
|
79
|
-
? current.header
|
|
80
|
-
: styleConfig.header !== undefined
|
|
81
|
-
? styleConfig.header
|
|
82
|
-
: DEFAULT_DIALOG_CONFIG.header;
|
|
83
|
-
this.dialogConfig = {
|
|
84
|
-
...DEFAULT_DIALOG_CONFIG,
|
|
85
|
-
...current,
|
|
86
|
-
...styleConfig,
|
|
87
|
-
header: mergedHeader,
|
|
88
|
-
confirmButtonConfig: {
|
|
89
|
-
...DEFAULT_DIALOG_CONFIG.confirmButtonConfig,
|
|
90
|
-
...current.confirmButtonConfig,
|
|
91
|
-
},
|
|
92
|
-
cancelButtonConfig: {
|
|
93
|
-
...DEFAULT_DIALOG_CONFIG.cancelButtonConfig,
|
|
94
|
-
...current.cancelButtonConfig,
|
|
95
|
-
},
|
|
96
|
-
visible: current.visible,
|
|
97
|
-
};
|
|
28
|
+
set visible(v) {
|
|
29
|
+
this._visible = v;
|
|
98
30
|
}
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
return 'pt-dialog-info';
|
|
111
|
-
}
|
|
31
|
+
/** Final class applied to p-dialog */
|
|
32
|
+
get dialogStyleClass() {
|
|
33
|
+
return [
|
|
34
|
+
'border-round-3xl',
|
|
35
|
+
'shadow-6',
|
|
36
|
+
'overflow-hidden',
|
|
37
|
+
'pt-dialog-header-blue', // for header/footer colors
|
|
38
|
+
this.styleClass,
|
|
39
|
+
]
|
|
40
|
+
.filter(Boolean)
|
|
41
|
+
.join(' ');
|
|
112
42
|
}
|
|
113
|
-
/**
|
|
114
|
-
|
|
115
|
-
const style =
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
return { header: '#b91c1c', message: '#4b5563' };
|
|
119
|
-
case SeverityEnum.WARNING:
|
|
120
|
-
return { header: '#b45309', message: '#92400e' };
|
|
121
|
-
case SeverityEnum.SUCCESS:
|
|
122
|
-
return { header: '#15803d', message: '#166534' };
|
|
123
|
-
case SeverityEnum.INFO:
|
|
124
|
-
default:
|
|
125
|
-
return { header: '#2563eb', message: '#2563eb' };
|
|
43
|
+
/** Style applied to the body wrapper */
|
|
44
|
+
get bodyStyle() {
|
|
45
|
+
const style = {};
|
|
46
|
+
if (this.bodyWidth) {
|
|
47
|
+
style['max-width'] = this.bodyWidth;
|
|
126
48
|
}
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
? SeverityEnum.DANGER
|
|
133
|
-
: style === SeverityEnum.WARNING
|
|
134
|
-
? SeverityEnum.WARNING
|
|
135
|
-
: style === SeverityEnum.SUCCESS
|
|
136
|
-
? SeverityEnum.SUCCESS
|
|
137
|
-
: SeverityEnum.INFO;
|
|
138
|
-
return {
|
|
139
|
-
label: this.dialogConfig.confirmButtonConfig?.label ?? 'Confirmer',
|
|
140
|
-
icon: this.dialogConfig.confirmButtonConfig?.icon ?? 'pi pi-check',
|
|
141
|
-
iconPos: 'left',
|
|
142
|
-
type: 'button',
|
|
143
|
-
outlined: true,
|
|
144
|
-
severity: confirmSeverity,
|
|
145
|
-
styleClass: (this.dialogConfig.confirmButtonConfig?.styleClass || '') +
|
|
146
|
-
' pt-dialog-confirm-btn',
|
|
147
|
-
width: 'auto',
|
|
148
|
-
};
|
|
149
|
-
}
|
|
150
|
-
get cancelButtonModel() {
|
|
151
|
-
return {
|
|
152
|
-
label: this.dialogConfig.cancelButtonConfig?.label ?? 'Annuler',
|
|
153
|
-
icon: this.dialogConfig.cancelButtonConfig?.icon ?? 'pi pi-times',
|
|
154
|
-
iconPos: 'left',
|
|
155
|
-
type: 'button',
|
|
156
|
-
outlined: true,
|
|
157
|
-
severity: SeverityEnum.INFO,
|
|
158
|
-
styleClass: (this.dialogConfig.cancelButtonConfig?.styleClass || '') +
|
|
159
|
-
' pt-dialog-cancel-btn',
|
|
160
|
-
width: 'auto',
|
|
161
|
-
};
|
|
162
|
-
}
|
|
163
|
-
showDialog() {
|
|
164
|
-
this.confirmationService.confirm({
|
|
165
|
-
header: '',
|
|
166
|
-
// message is not really used visually, but kept here
|
|
167
|
-
message: this.getDialogContentText(),
|
|
168
|
-
accept: () => this.confirm.emit(),
|
|
169
|
-
reject: (_type) => this.cancel.emit(),
|
|
170
|
-
});
|
|
171
|
-
setTimeout(() => {
|
|
172
|
-
const dialogElement = document.querySelector('.p-confirm-dialog');
|
|
173
|
-
if (dialogElement) {
|
|
174
|
-
this.renderer.addClass(dialogElement, 'pt-dialog-overlay');
|
|
175
|
-
this.renderer.removeClass(dialogElement, 'pt-dialog-danger');
|
|
176
|
-
this.renderer.removeClass(dialogElement, 'pt-dialog-warning');
|
|
177
|
-
this.renderer.removeClass(dialogElement, 'pt-dialog-success');
|
|
178
|
-
this.renderer.removeClass(dialogElement, 'pt-dialog-info');
|
|
179
|
-
const severityClass = this.getSeverityClass();
|
|
180
|
-
this.renderer.addClass(dialogElement, severityClass);
|
|
181
|
-
this.renderer.setStyle(dialogElement, 'width', this.dialogConfig.width || '720px');
|
|
182
|
-
this.renderer.setStyle(dialogElement, 'height', this.dialogConfig.height || 'auto');
|
|
49
|
+
if (this.bodyHeight) {
|
|
50
|
+
style['max-height'] = this.bodyHeight;
|
|
51
|
+
if (this.bodyScrollable) {
|
|
52
|
+
style['overflow-y'] = 'auto';
|
|
53
|
+
style['overflow-x'] = 'auto';
|
|
183
54
|
}
|
|
184
|
-
}, 0);
|
|
185
|
-
}
|
|
186
|
-
// ── header / icon / content helpers ───────────────────────────────
|
|
187
|
-
getDialogHeaderText() {
|
|
188
|
-
const header = this.dialogConfig.header;
|
|
189
|
-
const dialogStyle = this.dialogConfig.dialogStyle ?? SeverityEnum.INFO;
|
|
190
|
-
const styleHeader = DIALOG_STYLES[dialogStyle]?.header;
|
|
191
|
-
return typeof header === 'object' && header !== null && 'text' in header
|
|
192
|
-
? header.text
|
|
193
|
-
: typeof header === 'string'
|
|
194
|
-
? header
|
|
195
|
-
: typeof styleHeader === 'object' &&
|
|
196
|
-
styleHeader !== null &&
|
|
197
|
-
'text' in styleHeader
|
|
198
|
-
? styleHeader.text
|
|
199
|
-
: 'Confirmation';
|
|
200
|
-
}
|
|
201
|
-
getDialogHeaderStyle() {
|
|
202
|
-
const header = this.dialogConfig.header;
|
|
203
|
-
const { header: color } = this.getSeverityColors();
|
|
204
|
-
const fontSize = typeof header === 'object' && header !== null && header.fontSize
|
|
205
|
-
? header.fontSize
|
|
206
|
-
: '20px';
|
|
207
|
-
return {
|
|
208
|
-
color,
|
|
209
|
-
fontSize,
|
|
210
|
-
fontWeight: 700,
|
|
211
|
-
};
|
|
212
|
-
}
|
|
213
|
-
getDialogIconClass() {
|
|
214
|
-
const header = this.dialogConfig.header;
|
|
215
|
-
const dialogStyle = this.dialogConfig.dialogStyle ?? SeverityEnum.INFO;
|
|
216
|
-
const styleHeader = DIALOG_STYLES[dialogStyle]?.header;
|
|
217
|
-
const icon = typeof header === 'object' && header !== null && 'icon' in header
|
|
218
|
-
? header.icon
|
|
219
|
-
: typeof styleHeader === 'object' && 'icon' in styleHeader
|
|
220
|
-
? styleHeader.icon
|
|
221
|
-
: undefined;
|
|
222
|
-
return typeof icon === 'string'
|
|
223
|
-
? icon
|
|
224
|
-
: icon?.code || 'pi pi-exclamation-circle';
|
|
225
|
-
}
|
|
226
|
-
getDialogIconStyle() {
|
|
227
|
-
const header = this.dialogConfig.header;
|
|
228
|
-
const { header: defaultColor } = this.getSeverityColors();
|
|
229
|
-
const icon = typeof header === 'object' && header !== null && 'icon' in header
|
|
230
|
-
? header.icon
|
|
231
|
-
: undefined;
|
|
232
|
-
return {
|
|
233
|
-
color: icon?.color || defaultColor,
|
|
234
|
-
fontSize: icon?.fontSize || '2.2rem',
|
|
235
|
-
};
|
|
236
|
-
}
|
|
237
|
-
/**
|
|
238
|
-
* No default text anymore.
|
|
239
|
-
* - If dialogConfig.content is a string, we return it.
|
|
240
|
-
* - If it is an object with text, we use that.
|
|
241
|
-
* - Otherwise we return '' (empty) so the body is blank.
|
|
242
|
-
*/
|
|
243
|
-
getDialogContentText() {
|
|
244
|
-
const content = this.dialogConfig.content;
|
|
245
|
-
if (typeof content === 'string') {
|
|
246
|
-
return content;
|
|
247
|
-
}
|
|
248
|
-
if (content && typeof content === 'object' && 'text' in content) {
|
|
249
|
-
return content.text ?? '';
|
|
250
55
|
}
|
|
251
|
-
return
|
|
56
|
+
return style;
|
|
252
57
|
}
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
if (typeof content === 'object' && content !== null) {
|
|
259
|
-
if (content.fontSize) {
|
|
260
|
-
fontSize = content.fontSize;
|
|
261
|
-
}
|
|
262
|
-
if (content.position) {
|
|
263
|
-
textAlign = content.position;
|
|
264
|
-
}
|
|
265
|
-
}
|
|
266
|
-
return {
|
|
267
|
-
color: message,
|
|
268
|
-
fontSize,
|
|
269
|
-
...(textAlign ? { textAlign } : {}),
|
|
270
|
-
};
|
|
58
|
+
onShow() {
|
|
59
|
+
this.visibleChange.emit(true);
|
|
60
|
+
}
|
|
61
|
+
onHide() {
|
|
62
|
+
this.visibleChange.emit(false);
|
|
271
63
|
}
|
|
272
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTDialogComponent, deps: [
|
|
273
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PTDialogComponent, selector: "pt-dialog", inputs: {
|
|
64
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTDialogComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
65
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PTDialogComponent, selector: "pt-dialog", inputs: { header: "header", style: "style", styleClass: "styleClass", headerIconClass: "headerIconClass", bodyWidth: "bodyWidth", bodyHeight: "bodyHeight", bodyScrollable: "bodyScrollable", showFooter: "showFooter", modal: "modal", closable: "closable", draggable: "draggable", resizable: "resizable", maximizable: "maximizable", dismissableMask: "dismissableMask", closeOnEscape: "closeOnEscape", blockScroll: "blockScroll", breakpoints: "breakpoints", position: "position", contentStyle: "contentStyle", visible: "visible" }, outputs: { visibleChange: "visibleChange" }, ngImport: i0, template: "<p-dialog\n [(visible)]=\"_visible\"\n [header]=\"header\"\n [modal]=\"modal\"\n [style]=\"style\"\n [breakpoints]=\"breakpoints\"\n [closable]=\"closable\"\n [draggable]=\"draggable\"\n [resizable]=\"resizable\"\n [maximizable]=\"maximizable\"\n [dismissableMask]=\"dismissableMask\"\n [closeOnEscape]=\"closeOnEscape\"\n [blockScroll]=\"blockScroll\"\n [position]=\"position\"\n [contentStyle]=\"contentStyle\"\n [styleClass]=\"dialogStyleClass\"\n (onShow)=\"onShow()\"\n (onHide)=\"onHide()\"\n>\n <!-- HEADER -->\n <ng-template pTemplate=\"header\">\n <div\n class=\"flex align-items-center justify-content-between w-full px-4 pt-3 pb-2\"\n >\n <div class=\"flex align-items-center gap-2\">\n <!-- optional icon -->\n <i *ngIf=\"headerIconClass\" [ngClass]=\"headerIconClass\"></i>\n\n <!-- projected custom header -->\n <ng-content select=\"[ptDialogHeader]\"></ng-content>\n\n <!-- fallback header text -->\n <span *ngIf=\"header\" class=\"font-bold text-lg\">\n {{ header }}\n </span>\n </div>\n <!-- close icon from PrimeNG (X) is rendered automatically -->\n </div>\n </ng-template>\n\n <!-- BODY -->\n <div\n class=\"surface-50 px-4 py-4 flex flex-column gap-3\"\n [ngStyle]=\"bodyStyle\"\n >\n <ng-content select=\"[ptDialogContent]\"></ng-content>\n <ng-content></ng-content>\n </div>\n\n <!-- FOOTER (optional) -->\n <ng-template pTemplate=\"footer\" *ngIf=\"showFooter\">\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}\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"] }] }); }
|
|
274
66
|
}
|
|
275
67
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTDialogComponent, decorators: [{
|
|
276
68
|
type: Component,
|
|
277
|
-
args: [{ selector: 'pt-dialog',
|
|
278
|
-
}],
|
|
69
|
+
args: [{ selector: 'pt-dialog', template: "<p-dialog\n [(visible)]=\"_visible\"\n [header]=\"header\"\n [modal]=\"modal\"\n [style]=\"style\"\n [breakpoints]=\"breakpoints\"\n [closable]=\"closable\"\n [draggable]=\"draggable\"\n [resizable]=\"resizable\"\n [maximizable]=\"maximizable\"\n [dismissableMask]=\"dismissableMask\"\n [closeOnEscape]=\"closeOnEscape\"\n [blockScroll]=\"blockScroll\"\n [position]=\"position\"\n [contentStyle]=\"contentStyle\"\n [styleClass]=\"dialogStyleClass\"\n (onShow)=\"onShow()\"\n (onHide)=\"onHide()\"\n>\n <!-- HEADER -->\n <ng-template pTemplate=\"header\">\n <div\n class=\"flex align-items-center justify-content-between w-full px-4 pt-3 pb-2\"\n >\n <div class=\"flex align-items-center gap-2\">\n <!-- optional icon -->\n <i *ngIf=\"headerIconClass\" [ngClass]=\"headerIconClass\"></i>\n\n <!-- projected custom header -->\n <ng-content select=\"[ptDialogHeader]\"></ng-content>\n\n <!-- fallback header text -->\n <span *ngIf=\"header\" class=\"font-bold text-lg\">\n {{ header }}\n </span>\n </div>\n <!-- close icon from PrimeNG (X) is rendered automatically -->\n </div>\n </ng-template>\n\n <!-- BODY -->\n <div\n class=\"surface-50 px-4 py-4 flex flex-column gap-3\"\n [ngStyle]=\"bodyStyle\"\n >\n <ng-content select=\"[ptDialogContent]\"></ng-content>\n <ng-content></ng-content>\n </div>\n\n <!-- FOOTER (optional) -->\n <ng-template pTemplate=\"footer\" *ngIf=\"showFooter\">\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}\n"] }]
|
|
70
|
+
}], propDecorators: { header: [{
|
|
279
71
|
type: Input
|
|
280
|
-
}],
|
|
281
|
-
type:
|
|
282
|
-
}],
|
|
72
|
+
}], style: [{
|
|
73
|
+
type: Input
|
|
74
|
+
}], styleClass: [{
|
|
75
|
+
type: Input
|
|
76
|
+
}], headerIconClass: [{
|
|
77
|
+
type: Input
|
|
78
|
+
}], bodyWidth: [{
|
|
79
|
+
type: Input
|
|
80
|
+
}], bodyHeight: [{
|
|
81
|
+
type: Input
|
|
82
|
+
}], bodyScrollable: [{
|
|
83
|
+
type: Input
|
|
84
|
+
}], showFooter: [{
|
|
85
|
+
type: Input
|
|
86
|
+
}], modal: [{
|
|
87
|
+
type: Input
|
|
88
|
+
}], closable: [{
|
|
89
|
+
type: Input
|
|
90
|
+
}], draggable: [{
|
|
91
|
+
type: Input
|
|
92
|
+
}], resizable: [{
|
|
93
|
+
type: Input
|
|
94
|
+
}], maximizable: [{
|
|
95
|
+
type: Input
|
|
96
|
+
}], dismissableMask: [{
|
|
97
|
+
type: Input
|
|
98
|
+
}], closeOnEscape: [{
|
|
99
|
+
type: Input
|
|
100
|
+
}], blockScroll: [{
|
|
101
|
+
type: Input
|
|
102
|
+
}], breakpoints: [{
|
|
103
|
+
type: Input
|
|
104
|
+
}], position: [{
|
|
105
|
+
type: Input
|
|
106
|
+
}], contentStyle: [{
|
|
107
|
+
type: Input
|
|
108
|
+
}], visible: [{
|
|
109
|
+
type: Input
|
|
110
|
+
}], visibleChange: [{
|
|
283
111
|
type: Output
|
|
284
112
|
}] } });
|
|
285
|
-
//# 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 {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  Renderer2,\n  ElementRef,\n  SimpleChanges,\n  OnChanges,\n} from '@angular/core';\nimport {\n  ConfirmationService,\n  ConfirmEventType,\n  MessageService,\n} from 'primeng/api';\nimport { DialogConfig } from '../models/dialog-config.model';\nimport { ButtonModel } from '../models/button.model';\nimport { IconStyle } from '../models';\nimport { SeverityEnum } from '../enums';\n\n/**\n * Styles per severity:\n *  - Only header (text/color) is provided here.\n *  - No default \"content\" text anymore.\n */\nconst DIALOG_STYLES: Record<SeverityEnum, Partial<DialogConfig>> = {\n  [SeverityEnum.WARNING]: {\n    header: { text: 'Avertissement', color: '#8a4b00' },\n  },\n  [SeverityEnum.SUCCESS]: {\n    header: { text: 'Succès', color: '#166534' },\n  },\n  [SeverityEnum.DANGER]: {\n    header: { text: 'Erreur', color: '#7f1d1d' },\n  },\n  [SeverityEnum.INFO]: {\n    header: { text: 'Information', color: '#2563eb' },\n  },\n};\n\n/**\n * Default config:\n *  - content is now empty string (no default message).\n */\nconst DEFAULT_DIALOG_CONFIG: DialogConfig = {\n  header: { text: 'Confirmation' },\n  visible: false,\n  width: '720px',\n  height: 'auto',\n  content: '', // no default message\n  confirmButtonConfig: {\n    label: 'Confirmer',\n  },\n  cancelButtonConfig: {\n    label: 'Annuler',\n  },\n  dialogStyle: SeverityEnum.INFO,\n};\n\n@Component({\n  selector: 'pt-dialog',\n  templateUrl: './pt-dialog.component.html',\n  styleUrls: ['./pt-dialog.component.css'],\n  providers: [ConfirmationService, MessageService],\n})\nexport class PTDialogComponent implements OnChanges {\n  @Input() dialogConfig: DialogConfig = { ...DEFAULT_DIALOG_CONFIG };\n  @Output() confirm = new EventEmitter<void>();\n  @Output() cancel = new EventEmitter<void>();\n\n  SeverityEnum = SeverityEnum;\n\n  constructor(\n    private confirmationService: ConfirmationService,\n    private messageService: MessageService,\n    private renderer: Renderer2,\n    private el: ElementRef\n  ) {}\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['dialogConfig']) {\n      const current = changes['dialogConfig'].currentValue as DialogConfig;\n\n      if (\n        changes['dialogConfig'].previousValue?.dialogStyle !==\n        current?.dialogStyle\n      ) {\n        this.applyDialogStyle();\n      }\n\n      if (this.dialogConfig.visible) {\n        this.showDialog();\n      }\n    }\n  }\n\n  /**\n   * Merge defaults + current config + severity style.\n   * We are careful NOT to spread header (it can be string or object).\n   */\n  private applyDialogStyle(): void {\n    const dialogStyle = this.dialogConfig.dialogStyle || SeverityEnum.INFO;\n    const styleConfig = DIALOG_STYLES[dialogStyle] || {};\n    const current = this.dialogConfig;\n\n    // Decide which header to use without spreading non-object types\n    const mergedHeader =\n      current.header !== undefined\n        ? current.header\n        : styleConfig.header !== undefined\n        ? styleConfig.header\n        : DEFAULT_DIALOG_CONFIG.header;\n\n    this.dialogConfig = {\n      ...DEFAULT_DIALOG_CONFIG,\n      ...current,\n      ...styleConfig,\n      header: mergedHeader,\n      confirmButtonConfig: {\n        ...DEFAULT_DIALOG_CONFIG.confirmButtonConfig,\n        ...current.confirmButtonConfig,\n      },\n      cancelButtonConfig: {\n        ...DEFAULT_DIALOG_CONFIG.cancelButtonConfig,\n        ...current.cancelButtonConfig,\n      },\n      visible: current.visible,\n    };\n  }\n\n  private getSeverityClass(): string {\n    const style = this.dialogConfig.dialogStyle ?? SeverityEnum.INFO;\n    switch (style) {\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  /** SUCCESS & INFO share same behaviour, only color differs */\n  private getSeverityColors(): { header: string; message: string } {\n    const style = this.dialogConfig.dialogStyle ?? SeverityEnum.INFO;\n\n    switch (style) {\n      case SeverityEnum.DANGER:\n        return { header: '#b91c1c', message: '#4b5563' };\n      case SeverityEnum.WARNING:\n        return { header: '#b45309', message: '#92400e' };\n      case SeverityEnum.SUCCESS:\n        return { header: '#15803d', message: '#166534' };\n      case SeverityEnum.INFO:\n      default:\n        return { header: '#2563eb', message: '#2563eb' };\n    }\n  }\n\n  // ───────────── Button models for pt-button ─────────────\n\n  get confirmButtonModel(): ButtonModel {\n    const style = this.dialogConfig.dialogStyle ?? SeverityEnum.INFO;\n\n    const confirmSeverity =\n      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    return {\n      label: this.dialogConfig.confirmButtonConfig?.label ?? 'Confirmer',\n      icon: this.dialogConfig.confirmButtonConfig?.icon ?? 'pi pi-check',\n      iconPos: 'left',\n      type: 'button',\n      outlined: true,\n      severity: confirmSeverity,\n      styleClass:\n        (this.dialogConfig.confirmButtonConfig?.styleClass || '') +\n        ' pt-dialog-confirm-btn',\n      width: 'auto',\n    };\n  }\n\n  get cancelButtonModel(): ButtonModel {\n    return {\n      label: this.dialogConfig.cancelButtonConfig?.label ?? 'Annuler',\n      icon: this.dialogConfig.cancelButtonConfig?.icon ?? 'pi pi-times',\n      iconPos: 'left',\n      type: 'button',\n      outlined: true,\n      severity: SeverityEnum.INFO,\n      styleClass:\n        (this.dialogConfig.cancelButtonConfig?.styleClass || '') +\n        ' pt-dialog-cancel-btn',\n      width: 'auto',\n    };\n  }\n\n  showDialog(): void {\n    this.confirmationService.confirm({\n      header: '',\n      // message is not really used visually, but kept here\n      message: this.getDialogContentText(),\n      accept: () => this.confirm.emit(),\n      reject: (_type: ConfirmEventType) => this.cancel.emit(),\n    });\n\n    setTimeout(() => {\n      const dialogElement = document.querySelector(\n        '.p-confirm-dialog'\n      ) as HTMLElement | null;\n\n      if (dialogElement) {\n        this.renderer.addClass(dialogElement, 'pt-dialog-overlay');\n\n        this.renderer.removeClass(dialogElement, 'pt-dialog-danger');\n        this.renderer.removeClass(dialogElement, 'pt-dialog-warning');\n        this.renderer.removeClass(dialogElement, 'pt-dialog-success');\n        this.renderer.removeClass(dialogElement, 'pt-dialog-info');\n\n        const severityClass = this.getSeverityClass();\n        this.renderer.addClass(dialogElement, severityClass);\n\n        this.renderer.setStyle(\n          dialogElement,\n          'width',\n          this.dialogConfig.width || '720px'\n        );\n        this.renderer.setStyle(\n          dialogElement,\n          'height',\n          this.dialogConfig.height || 'auto'\n        );\n      }\n    }, 0);\n  }\n\n  // ── header / icon / content helpers ───────────────────────────────\n\n  getDialogHeaderText(): string {\n    const header = this.dialogConfig.header;\n    const dialogStyle = this.dialogConfig.dialogStyle ?? SeverityEnum.INFO;\n    const styleHeader = DIALOG_STYLES[dialogStyle]?.header;\n\n    return typeof header === 'object' && header !== null && 'text' in header\n      ? header.text\n      : typeof header === 'string'\n      ? header\n      : typeof styleHeader === 'object' &&\n        styleHeader !== null &&\n        'text' in styleHeader\n      ? styleHeader.text\n      : 'Confirmation';\n  }\n\n  getDialogHeaderStyle(): any {\n    const header = this.dialogConfig.header;\n    const { header: color } = this.getSeverityColors();\n\n    const fontSize =\n      typeof header === 'object' && header !== null && header.fontSize\n        ? header.fontSize\n        : '20px';\n\n    return {\n      color,\n      fontSize,\n      fontWeight: 700,\n    };\n  }\n\n  getDialogIconClass(): string {\n    const header = this.dialogConfig.header;\n    const dialogStyle = this.dialogConfig.dialogStyle ?? SeverityEnum.INFO;\n    const styleHeader = DIALOG_STYLES[dialogStyle]?.header;\n\n    const icon =\n      typeof header === 'object' && header !== null && 'icon' in header\n        ? header.icon\n        : typeof styleHeader === 'object' && 'icon' in styleHeader\n        ? styleHeader.icon\n        : undefined;\n\n    return typeof icon === 'string'\n      ? icon\n      : (icon as IconStyle)?.code || 'pi pi-exclamation-circle';\n  }\n\n  getDialogIconStyle(): any {\n    const header = this.dialogConfig.header;\n    const { header: defaultColor } = this.getSeverityColors();\n\n    const icon: IconStyle | undefined =\n      typeof header === 'object' && header !== null && 'icon' in header\n        ? (header.icon as IconStyle)\n        : undefined;\n\n    return {\n      color: icon?.color || defaultColor,\n      fontSize: icon?.fontSize || '2.2rem',\n    };\n  }\n\n  /**\n   * No default text anymore.\n   * - If dialogConfig.content is a string, we return it.\n   * - If it is an object with text, we use that.\n   * - Otherwise we return '' (empty) so the body is blank.\n   */\n  getDialogContentText(): string {\n    const content = this.dialogConfig.content;\n\n    if (typeof content === 'string') {\n      return content;\n    }\n\n    if (content && typeof content === 'object' && 'text' in content) {\n      return content.text ?? '';\n    }\n\n    return '';\n  }\n\n  getDialogContentStyle(): any {\n    const content = this.dialogConfig.content;\n    const { message } = this.getSeverityColors();\n\n    let fontSize = '18px';\n    let textAlign: string | undefined;\n\n    if (typeof content === 'object' && content !== null) {\n      if (content.fontSize) {\n        fontSize = content.fontSize;\n      }\n      if (content.position) {\n        textAlign = content.position;\n      }\n    }\n\n    return {\n      color: message,\n      fontSize,\n      ...(textAlign ? { textAlign } : {}),\n    };\n  }\n}\n","<div class=\"pt-dialog\">\n  <p-confirmDialog #cd>\n    <ng-template pTemplate=\"header\"></ng-template>\n\n    <ng-template pTemplate=\"message\">\n      <div class=\"pt-dialog-card\">\n        <div class=\"pt-dialog-card-top\">\n          <div class=\"pt-dialog-icon-wrapper\">\n            <i\n              class=\"pt-dialog-icon\"\n              [class]=\"getDialogIconClass()\"\n              [ngStyle]=\"getDialogIconStyle()\"\n            ></i>\n          </div>\n\n          <div class=\"pt-dialog-text-wrapper\">\n            <div class=\"pt-dialog-title\" [ngStyle]=\"getDialogHeaderStyle()\">\n              {{ getDialogHeaderText() }}\n            </div>\n\n            <div class=\"pt-dialog-message\" [ngStyle]=\"getDialogContentStyle()\">\n              {{ getDialogContentText() }}\n            </div>\n          </div>\n        </div>\n      </div>\n    </ng-template>\n\n    <ng-template pTemplate=\"footer\">\n      <div class=\"pt-dialog-footer-buttons\">\n        <pt-button\n          *ngIf=\"dialogConfig.cancelButtonConfig\"\n          [buttonConfig]=\"cancelButtonModel\"\n          (click)=\"cd.reject()\"\n        ></pt-button>\n\n        <pt-button\n          *ngIf=\"dialogConfig.confirmButtonConfig\"\n          [buttonConfig]=\"confirmButtonModel\"\n          (click)=\"cd.accept()\"\n        ></pt-button>\n      </div>\n    </ng-template>\n  </p-confirmDialog>\n</div>\n"]}
|
|
113
|
+
//# 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;;;;;AAkBvE,MAAM,OAAO,iBAAiB;IAL9B;QAiBE,yDAAyD;QAChD,mBAAc,GAAG,IAAI,CAAC;QAE/B,gDAAgD;QACvC,eAAU,GAAG,IAAI,CAAC;QAElB,UAAK,GAAG,IAAI,CAAC;QACb,aAAQ,GAAG,IAAI,CAAC;QAChB,cAAS,GAAG,IAAI,CAAC;QACjB,cAAS,GAAG,IAAI,CAAC;QACjB,gBAAW,GAAG,KAAK,CAAC;QACpB,oBAAe,GAAG,KAAK,CAAC;QACxB,kBAAa,GAAG,IAAI,CAAC;QACrB,gBAAW,GAAG,IAAI,CAAC;QAEnB,aAAQ,GAAmB,QAAQ,CAAC;QAG7C,6CAA6C;QAC7C,aAAQ,GAAG,KAAK,CAAC;QAUP,kBAAa,GAAG,IAAI,YAAY,EAAW,CAAC;KAyCvD;IAjDC,IACI,OAAO;QACT,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IACD,IAAI,OAAO,CAAC,CAAU;QACpB,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC;IACpB,CAAC;IAID,sCAAsC;IACtC,IAAI,gBAAgB;QAClB,OAAO;YACL,kBAAkB;YAClB,UAAU;YACV,iBAAiB;YACjB,uBAAuB,EAAE,2BAA2B;YACpD,IAAI,CAAC,UAAU;SAChB;aACE,MAAM,CAAC,OAAO,CAAC;aACf,IAAI,CAAC,GAAG,CAAC,CAAC;IACf,CAAC;IAED,wCAAwC;IACxC,IAAI,SAAS;QACX,MAAM,KAAK,GAA2B,EAAE,CAAC;QAEzC,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,KAAK,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC;QACtC,CAAC;QAED,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,KAAK,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC;YACtC,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;gBACxB,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,MAAM;QACJ,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;+GAjFU,iBAAiB;mGAAjB,iBAAiB,8mBClB9B,6pDAwDA;;4FDtCa,iBAAiB;kBAL7B,SAAS;+BACE,WAAW;8BAKZ,MAAM;sBAAd,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBAGG,eAAe;sBAAvB,KAAK;gBAGG,SAAS;sBAAjB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBAGG,cAAc;sBAAtB,KAAK;gBAGG,UAAU;sBAAlB,KAAK;gBAEG,KAAK;sBAAb,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBAMF,OAAO;sBADV,KAAK;gBAQI,aAAa;sBAAtB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\n\ntype DialogPosition =\n  | 'right'\n  | 'left'\n  | 'center'\n  | 'top'\n  | 'bottom'\n  | 'topleft'\n  | 'topright'\n  | 'bottomleft'\n  | 'bottomright';\n\n@Component({\n  selector: 'pt-dialog',\n  templateUrl: './pt-dialog.component.html',\n  styleUrls: ['./pt-dialog.component.css'],\n})\nexport class PTDialogComponent {\n  @Input() header?: string;\n  @Input() style?: { [key: string]: any };\n  @Input() styleClass?: string;\n\n  /** Optional icon in the header (e.g. \"pi pi-info-circle text-blue-500\") */\n  @Input() headerIconClass?: string;\n\n  /** Optional body max width / height (e.g. \"500px\", \"60vh\") */\n  @Input() bodyWidth?: string;\n  @Input() bodyHeight?: string;\n\n  /** Enable scroll when body exceeds given height/width */\n  @Input() bodyScrollable = true;\n\n  /** Control footer visibility (default: true) */\n  @Input() showFooter = true;\n\n  @Input() modal = true;\n  @Input() closable = true;\n  @Input() draggable = true;\n  @Input() resizable = true;\n  @Input() maximizable = false;\n  @Input() dismissableMask = false;\n  @Input() closeOnEscape = true;\n  @Input() blockScroll = true;\n  @Input() breakpoints?: { [key: string]: string };\n  @Input() position: DialogPosition = 'center';\n  @Input() contentStyle?: { [key: string]: any };\n\n  /** internal visible flag used by p-dialog */\n  _visible = false;\n\n  @Input()\n  get visible(): boolean {\n    return this._visible;\n  }\n  set visible(v: boolean) {\n    this._visible = v;\n  }\n\n  @Output() visibleChange = new EventEmitter<boolean>();\n\n  /** Final class applied to p-dialog */\n  get dialogStyleClass(): string {\n    return [\n      'border-round-3xl',\n      'shadow-6',\n      'overflow-hidden',\n      'pt-dialog-header-blue', // for header/footer colors\n      this.styleClass,\n    ]\n      .filter(Boolean)\n      .join(' ');\n  }\n\n  /** Style applied to the body wrapper */\n  get bodyStyle(): { [key: string]: any } {\n    const style: { [key: string]: any } = {};\n\n    if (this.bodyWidth) {\n      style['max-width'] = this.bodyWidth;\n    }\n\n    if (this.bodyHeight) {\n      style['max-height'] = this.bodyHeight;\n      if (this.bodyScrollable) {\n        style['overflow-y'] = 'auto';\n        style['overflow-x'] = 'auto';\n      }\n    }\n\n    return style;\n  }\n\n  onShow(): void {\n    this.visibleChange.emit(true);\n  }\n\n  onHide(): void {\n    this.visibleChange.emit(false);\n  }\n}\n","<p-dialog\n  [(visible)]=\"_visible\"\n  [header]=\"header\"\n  [modal]=\"modal\"\n  [style]=\"style\"\n  [breakpoints]=\"breakpoints\"\n  [closable]=\"closable\"\n  [draggable]=\"draggable\"\n  [resizable]=\"resizable\"\n  [maximizable]=\"maximizable\"\n  [dismissableMask]=\"dismissableMask\"\n  [closeOnEscape]=\"closeOnEscape\"\n  [blockScroll]=\"blockScroll\"\n  [position]=\"position\"\n  [contentStyle]=\"contentStyle\"\n  [styleClass]=\"dialogStyleClass\"\n  (onShow)=\"onShow()\"\n  (onHide)=\"onHide()\"\n>\n  <!-- HEADER -->\n  <ng-template pTemplate=\"header\">\n    <div\n      class=\"flex align-items-center justify-content-between w-full px-4 pt-3 pb-2\"\n    >\n      <div class=\"flex align-items-center gap-2\">\n        <!-- optional icon -->\n        <i *ngIf=\"headerIconClass\" [ngClass]=\"headerIconClass\"></i>\n\n        <!-- projected custom header -->\n        <ng-content select=\"[ptDialogHeader]\"></ng-content>\n\n        <!-- fallback header text -->\n        <span *ngIf=\"header\" class=\"font-bold text-lg\">\n          {{ header }}\n        </span>\n      </div>\n      <!-- close icon from PrimeNG (X) is rendered automatically -->\n    </div>\n  </ng-template>\n\n  <!-- BODY -->\n  <div\n    class=\"surface-50 px-4 py-4 flex flex-column gap-3\"\n    [ngStyle]=\"bodyStyle\"\n  >\n    <ng-content select=\"[ptDialogContent]\"></ng-content>\n    <ng-content></ng-content>\n  </div>\n\n  <!-- FOOTER (optional) -->\n  <ng-template pTemplate=\"footer\" *ngIf=\"showFooter\">\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"]}
|
|
@@ -1,21 +1,19 @@
|
|
|
1
1
|
import { NgModule } from '@angular/core';
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
|
-
import { PTDialogComponent } from './pt-dialog.component';
|
|
4
3
|
import { DialogModule } from 'primeng/dialog';
|
|
5
|
-
import {
|
|
6
|
-
import { ConfirmDialogModule } from 'primeng/confirmdialog';
|
|
4
|
+
import { PTDialogComponent } from './pt-dialog.component';
|
|
7
5
|
import * as i0 from "@angular/core";
|
|
8
6
|
export class PTDialogModule {
|
|
9
7
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTDialogModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
10
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.11", ngImport: i0, type: PTDialogModule, declarations: [PTDialogComponent], imports: [CommonModule, DialogModule
|
|
11
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTDialogModule, imports: [CommonModule, DialogModule
|
|
8
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.11", ngImport: i0, type: PTDialogModule, declarations: [PTDialogComponent], imports: [CommonModule, DialogModule], exports: [PTDialogComponent] }); }
|
|
9
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTDialogModule, imports: [CommonModule, DialogModule] }); }
|
|
12
10
|
}
|
|
13
11
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTDialogModule, decorators: [{
|
|
14
12
|
type: NgModule,
|
|
15
13
|
args: [{
|
|
16
14
|
declarations: [PTDialogComponent],
|
|
17
|
-
imports: [CommonModule, DialogModule
|
|
15
|
+
imports: [CommonModule, DialogModule],
|
|
18
16
|
exports: [PTDialogComponent],
|
|
19
17
|
}]
|
|
20
18
|
}] });
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHQtZGlhbG9nLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvcHQtZGlhbG9nL3B0LWRpYWxvZy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzlDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDOztBQU8xRCxNQUFNLE9BQU8sY0FBYzsrR0FBZCxjQUFjO2dIQUFkLGNBQWMsaUJBSlYsaUJBQWlCLGFBQ3RCLFlBQVksRUFBRSxZQUFZLGFBQzFCLGlCQUFpQjtnSEFFaEIsY0FBYyxZQUhmLFlBQVksRUFBRSxZQUFZOzs0RkFHekIsY0FBYztrQkFMMUIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztvQkFDakMsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLFlBQVksQ0FBQztvQkFDckMsT0FBTyxFQUFFLENBQUMsaUJBQWlCLENBQUM7aUJBQzdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBEaWFsb2dNb2R1bGUgfSBmcm9tICdwcmltZW5nL2RpYWxvZyc7XG5pbXBvcnQgeyBQVERpYWxvZ0NvbXBvbmVudCB9IGZyb20gJy4vcHQtZGlhbG9nLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1BURGlhbG9nQ29tcG9uZW50XSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgRGlhbG9nTW9kdWxlXSxcbiAgZXhwb3J0czogW1BURGlhbG9nQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgUFREaWFsb2dNb2R1bGUge31cbiJdfQ==
|