ng-prime-tools 1.0.34 → 1.0.36
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-confirm-dialog-config.model.mjs +2 -0
- package/esm2022/lib/models/pt-dialog-config.model.mjs +3 -0
- package/esm2022/lib/models/public-api.mjs +3 -2
- package/esm2022/lib/pt-advanced-prime-table/pt-advanced-prime-table.component.mjs +2 -2
- package/esm2022/lib/pt-confirm-dialog/pt-confirm-dialog.component.mjs +3 -2
- package/esm2022/lib/pt-dialog/pt-dialog.component.mjs +44 -71
- package/fesm2022/ng-prime-tools.mjs +55 -79
- package/fesm2022/ng-prime-tools.mjs.map +1 -1
- package/lib/models/{dialog-config.model.d.ts → pt-confirm-dialog-config.model.d.ts} +2 -2
- package/lib/models/pt-confirm-dialog-config.model.d.ts.map +1 -0
- package/lib/models/pt-dialog-config.model.d.ts +40 -0
- package/lib/models/pt-dialog-config.model.d.ts.map +1 -0
- package/lib/models/public-api.d.ts +2 -1
- package/lib/models/public-api.d.ts.map +1 -1
- package/lib/pt-confirm-dialog/pt-confirm-dialog.component.d.ts +2 -2
- package/lib/pt-confirm-dialog/pt-confirm-dialog.component.d.ts.map +1 -1
- package/lib/pt-dialog/pt-dialog.component.d.ts +11 -38
- package/lib/pt-dialog/pt-dialog.component.d.ts.map +1 -1
- package/lib/pt-metric-panel/pt-metric-panel.component.d.ts +1 -1
- package/package.json +1 -1
- package/esm2022/lib/models/dialog-config.model.mjs +0 -2
- package/lib/models/dialog-config.model.d.ts.map +0 -1
|
@@ -3,111 +3,84 @@ import * as i0 from "@angular/core";
|
|
|
3
3
|
import * as i1 from "@angular/common";
|
|
4
4
|
import * as i2 from "primeng/dialog";
|
|
5
5
|
import * as i3 from "primeng/api";
|
|
6
|
+
const DEFAULT_DIALOG_CONFIG = {
|
|
7
|
+
modal: true,
|
|
8
|
+
closable: true,
|
|
9
|
+
draggable: true,
|
|
10
|
+
resizable: true,
|
|
11
|
+
maximizable: false,
|
|
12
|
+
dismissableMask: false,
|
|
13
|
+
closeOnEscape: true,
|
|
14
|
+
blockScroll: true,
|
|
15
|
+
bodyScrollable: true,
|
|
16
|
+
showFooter: true,
|
|
17
|
+
position: 'center',
|
|
18
|
+
};
|
|
6
19
|
export class PTDialogComponent {
|
|
7
20
|
constructor() {
|
|
8
|
-
/**
|
|
9
|
-
this.
|
|
10
|
-
|
|
11
|
-
this.
|
|
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;
|
|
21
|
+
/** Single configuration object */
|
|
22
|
+
this._config = { ...DEFAULT_DIALOG_CONFIG };
|
|
23
|
+
// ---- Internal visible state (PUBLIC so template can read it) ----
|
|
24
|
+
this._internalVisible = false;
|
|
23
25
|
this.visibleChange = new EventEmitter();
|
|
24
26
|
}
|
|
27
|
+
set config(value) {
|
|
28
|
+
this._config = { ...DEFAULT_DIALOG_CONFIG, ...(value || {}) };
|
|
29
|
+
}
|
|
30
|
+
get config() {
|
|
31
|
+
return this._config;
|
|
32
|
+
}
|
|
33
|
+
/** Input visible from parent */
|
|
25
34
|
get visible() {
|
|
26
|
-
return this.
|
|
35
|
+
return this._internalVisible;
|
|
27
36
|
}
|
|
28
37
|
set visible(v) {
|
|
29
|
-
this.
|
|
38
|
+
this._internalVisible = v;
|
|
30
39
|
}
|
|
31
|
-
/** Final class applied to p-dialog */
|
|
32
40
|
get dialogStyleClass() {
|
|
33
41
|
return [
|
|
34
42
|
'border-round-3xl',
|
|
35
43
|
'shadow-6',
|
|
36
44
|
'overflow-hidden',
|
|
37
|
-
'pt-dialog-header-blue',
|
|
38
|
-
this.styleClass,
|
|
45
|
+
'pt-dialog-header-blue',
|
|
46
|
+
this.config.styleClass,
|
|
39
47
|
]
|
|
40
48
|
.filter(Boolean)
|
|
41
49
|
.join(' ');
|
|
42
50
|
}
|
|
43
|
-
|
|
51
|
+
get primePosition() {
|
|
52
|
+
return (this.config.position ?? 'center');
|
|
53
|
+
}
|
|
44
54
|
get bodyStyle() {
|
|
45
55
|
const style = {};
|
|
46
|
-
if (this.bodyWidth) {
|
|
47
|
-
style['max-width'] = this.bodyWidth;
|
|
56
|
+
if (this.config.bodyWidth) {
|
|
57
|
+
style['max-width'] = this.config.bodyWidth;
|
|
48
58
|
}
|
|
49
|
-
if (this.bodyHeight) {
|
|
50
|
-
style['max-height'] = this.bodyHeight;
|
|
51
|
-
if (this.bodyScrollable) {
|
|
59
|
+
if (this.config.bodyHeight) {
|
|
60
|
+
style['max-height'] = this.config.bodyHeight;
|
|
61
|
+
if (this.config.bodyScrollable !== false) {
|
|
52
62
|
style['overflow-y'] = 'auto';
|
|
53
63
|
style['overflow-x'] = 'auto';
|
|
54
64
|
}
|
|
55
65
|
}
|
|
56
66
|
return style;
|
|
57
67
|
}
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
this.visibleChange.emit(false);
|
|
68
|
+
/** Sync <p-dialog> → parent */
|
|
69
|
+
onInternalVisibleChange(v) {
|
|
70
|
+
this._internalVisible = v;
|
|
71
|
+
this.visibleChange.emit(v);
|
|
63
72
|
}
|
|
64
73
|
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: {
|
|
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\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 <i\n *ngIf=\"config.headerIconClass\"\n [ngClass]=\"config.headerIconClass\"\n ></i>\n <ng-content select=\"[ptDialogHeader]\"></ng-content>\n <span *ngIf=\"config.header\" class=\"font-bold text-lg\">\n {{ config.header }}\n </span>\n </div>\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 -->\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}\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"] }] }); }
|
|
66
75
|
}
|
|
67
76
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTDialogComponent, decorators: [{
|
|
68
77
|
type: Component,
|
|
69
|
-
args: [{ selector: 'pt-dialog', template: "<p-dialog\n [
|
|
70
|
-
}], propDecorators: {
|
|
71
|
-
type: Input
|
|
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: [{
|
|
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\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 <i\n *ngIf=\"config.headerIconClass\"\n [ngClass]=\"config.headerIconClass\"\n ></i>\n <ng-content select=\"[ptDialogHeader]\"></ng-content>\n <span *ngIf=\"config.header\" class=\"font-bold text-lg\">\n {{ config.header }}\n </span>\n </div>\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 -->\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}\n"] }]
|
|
79
|
+
}], propDecorators: { config: [{
|
|
107
80
|
type: Input
|
|
108
81
|
}], visible: [{
|
|
109
82
|
type: Input
|
|
110
83
|
}], visibleChange: [{
|
|
111
84
|
type: Output
|
|
112
85
|
}] } });
|
|
113
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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,woDAoDA;;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\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        <i\n          *ngIf=\"config.headerIconClass\"\n          [ngClass]=\"config.headerIconClass\"\n        ></i>\n        <ng-content select=\"[ptDialogHeader]\"></ng-content>\n        <span *ngIf=\"config.header\" class=\"font-bold text-lg\">\n          {{ config.header }}\n        </span>\n      </div>\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 -->\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"]}
|