ng-prime-tools 1.0.33 → 1.0.35
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 +5 -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 +57 -78
- 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-advanced-prime-table/pt-advanced-prime-table.component.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/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"]}
|
|
@@ -287,7 +287,10 @@ class PTAdvancedPrimeTableComponent {
|
|
|
287
287
|
/** Called when a custom action button is clicked */
|
|
288
288
|
onCustomActionClick(action, row) {
|
|
289
289
|
if (action && typeof action.action === 'function') {
|
|
290
|
-
|
|
290
|
+
// Defer to next macrotask → fresh change detection cycle
|
|
291
|
+
setTimeout(() => {
|
|
292
|
+
action.action(row);
|
|
293
|
+
}, 0);
|
|
291
294
|
}
|
|
292
295
|
}
|
|
293
296
|
// Initialize filters for composed columns
|
|
@@ -3799,7 +3802,7 @@ const DIALOG_STYLES = {
|
|
|
3799
3802
|
* Default config:
|
|
3800
3803
|
* - content is now empty string (no default message).
|
|
3801
3804
|
*/
|
|
3802
|
-
const DEFAULT_DIALOG_CONFIG = {
|
|
3805
|
+
const DEFAULT_DIALOG_CONFIG$1 = {
|
|
3803
3806
|
header: { text: 'Confirmation' },
|
|
3804
3807
|
visible: false,
|
|
3805
3808
|
width: '720px',
|
|
@@ -3819,14 +3822,15 @@ class PTConfirmDialogComponent {
|
|
|
3819
3822
|
this.messageService = messageService;
|
|
3820
3823
|
this.renderer = renderer;
|
|
3821
3824
|
this.el = el;
|
|
3822
|
-
this.dialogConfig = { ...DEFAULT_DIALOG_CONFIG };
|
|
3825
|
+
this.dialogConfig = { ...DEFAULT_DIALOG_CONFIG$1 };
|
|
3823
3826
|
this.confirm = new EventEmitter();
|
|
3824
3827
|
this.cancel = new EventEmitter();
|
|
3825
3828
|
this.SeverityEnum = SeverityEnum;
|
|
3826
3829
|
}
|
|
3827
3830
|
ngOnChanges(changes) {
|
|
3828
3831
|
if (changes['dialogConfig']) {
|
|
3829
|
-
const current = changes['dialogConfig']
|
|
3832
|
+
const current = changes['dialogConfig']
|
|
3833
|
+
.currentValue;
|
|
3830
3834
|
if (changes['dialogConfig'].previousValue?.dialogStyle !==
|
|
3831
3835
|
current?.dialogStyle) {
|
|
3832
3836
|
this.applyDialogStyle();
|
|
@@ -3849,18 +3853,18 @@ class PTConfirmDialogComponent {
|
|
|
3849
3853
|
? current.header
|
|
3850
3854
|
: styleConfig.header !== undefined
|
|
3851
3855
|
? styleConfig.header
|
|
3852
|
-
: DEFAULT_DIALOG_CONFIG.header;
|
|
3856
|
+
: DEFAULT_DIALOG_CONFIG$1.header;
|
|
3853
3857
|
this.dialogConfig = {
|
|
3854
|
-
...DEFAULT_DIALOG_CONFIG,
|
|
3858
|
+
...DEFAULT_DIALOG_CONFIG$1,
|
|
3855
3859
|
...current,
|
|
3856
3860
|
...styleConfig,
|
|
3857
3861
|
header: mergedHeader,
|
|
3858
3862
|
confirmButtonConfig: {
|
|
3859
|
-
...DEFAULT_DIALOG_CONFIG.confirmButtonConfig,
|
|
3863
|
+
...DEFAULT_DIALOG_CONFIG$1.confirmButtonConfig,
|
|
3860
3864
|
...current.confirmButtonConfig,
|
|
3861
3865
|
},
|
|
3862
3866
|
cancelButtonConfig: {
|
|
3863
|
-
...DEFAULT_DIALOG_CONFIG.cancelButtonConfig,
|
|
3867
|
+
...DEFAULT_DIALOG_CONFIG$1.cancelButtonConfig,
|
|
3864
3868
|
...current.cancelButtonConfig,
|
|
3865
3869
|
},
|
|
3866
3870
|
visible: current.visible,
|
|
@@ -4107,107 +4111,80 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
4107
4111
|
}]
|
|
4108
4112
|
}] });
|
|
4109
4113
|
|
|
4114
|
+
const DEFAULT_DIALOG_CONFIG = {
|
|
4115
|
+
modal: true,
|
|
4116
|
+
closable: true,
|
|
4117
|
+
draggable: true,
|
|
4118
|
+
resizable: true,
|
|
4119
|
+
maximizable: false,
|
|
4120
|
+
dismissableMask: false,
|
|
4121
|
+
closeOnEscape: true,
|
|
4122
|
+
blockScroll: true,
|
|
4123
|
+
bodyScrollable: true,
|
|
4124
|
+
showFooter: true,
|
|
4125
|
+
position: 'center',
|
|
4126
|
+
};
|
|
4110
4127
|
class PTDialogComponent {
|
|
4111
4128
|
constructor() {
|
|
4112
|
-
/**
|
|
4113
|
-
this.
|
|
4114
|
-
|
|
4115
|
-
this.
|
|
4116
|
-
this.modal = true;
|
|
4117
|
-
this.closable = true;
|
|
4118
|
-
this.draggable = true;
|
|
4119
|
-
this.resizable = true;
|
|
4120
|
-
this.maximizable = false;
|
|
4121
|
-
this.dismissableMask = false;
|
|
4122
|
-
this.closeOnEscape = true;
|
|
4123
|
-
this.blockScroll = true;
|
|
4124
|
-
this.position = 'center';
|
|
4125
|
-
/** internal visible flag used by p-dialog */
|
|
4126
|
-
this._visible = false;
|
|
4129
|
+
/** Single configuration object */
|
|
4130
|
+
this._config = { ...DEFAULT_DIALOG_CONFIG };
|
|
4131
|
+
// ---- Internal visible state (PUBLIC so template can read it) ----
|
|
4132
|
+
this._internalVisible = false;
|
|
4127
4133
|
this.visibleChange = new EventEmitter();
|
|
4128
4134
|
}
|
|
4135
|
+
set config(value) {
|
|
4136
|
+
this._config = { ...DEFAULT_DIALOG_CONFIG, ...(value || {}) };
|
|
4137
|
+
}
|
|
4138
|
+
get config() {
|
|
4139
|
+
return this._config;
|
|
4140
|
+
}
|
|
4141
|
+
/** Input visible from parent */
|
|
4129
4142
|
get visible() {
|
|
4130
|
-
return this.
|
|
4143
|
+
return this._internalVisible;
|
|
4131
4144
|
}
|
|
4132
4145
|
set visible(v) {
|
|
4133
|
-
this.
|
|
4146
|
+
this._internalVisible = v;
|
|
4134
4147
|
}
|
|
4135
|
-
/** Final class applied to p-dialog */
|
|
4136
4148
|
get dialogStyleClass() {
|
|
4137
4149
|
return [
|
|
4138
4150
|
'border-round-3xl',
|
|
4139
4151
|
'shadow-6',
|
|
4140
4152
|
'overflow-hidden',
|
|
4141
|
-
'pt-dialog-header-blue',
|
|
4142
|
-
this.styleClass,
|
|
4153
|
+
'pt-dialog-header-blue',
|
|
4154
|
+
this.config.styleClass,
|
|
4143
4155
|
]
|
|
4144
4156
|
.filter(Boolean)
|
|
4145
4157
|
.join(' ');
|
|
4146
4158
|
}
|
|
4147
|
-
|
|
4159
|
+
get primePosition() {
|
|
4160
|
+
return (this.config.position ?? 'center');
|
|
4161
|
+
}
|
|
4148
4162
|
get bodyStyle() {
|
|
4149
4163
|
const style = {};
|
|
4150
|
-
if (this.bodyWidth) {
|
|
4151
|
-
style['max-width'] = this.bodyWidth;
|
|
4164
|
+
if (this.config.bodyWidth) {
|
|
4165
|
+
style['max-width'] = this.config.bodyWidth;
|
|
4152
4166
|
}
|
|
4153
|
-
if (this.bodyHeight) {
|
|
4154
|
-
style['max-height'] = this.bodyHeight;
|
|
4155
|
-
if (this.bodyScrollable) {
|
|
4167
|
+
if (this.config.bodyHeight) {
|
|
4168
|
+
style['max-height'] = this.config.bodyHeight;
|
|
4169
|
+
if (this.config.bodyScrollable !== false) {
|
|
4156
4170
|
style['overflow-y'] = 'auto';
|
|
4157
4171
|
style['overflow-x'] = 'auto';
|
|
4158
4172
|
}
|
|
4159
4173
|
}
|
|
4160
4174
|
return style;
|
|
4161
4175
|
}
|
|
4162
|
-
|
|
4163
|
-
|
|
4164
|
-
|
|
4165
|
-
|
|
4166
|
-
this.visibleChange.emit(false);
|
|
4176
|
+
/** Sync <p-dialog> → parent */
|
|
4177
|
+
onInternalVisibleChange(v) {
|
|
4178
|
+
this._internalVisible = v;
|
|
4179
|
+
this.visibleChange.emit(v);
|
|
4167
4180
|
}
|
|
4168
4181
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTDialogComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
4169
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PTDialogComponent, selector: "pt-dialog", inputs: {
|
|
4182
|
+
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$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"] }] }); }
|
|
4170
4183
|
}
|
|
4171
4184
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTDialogComponent, decorators: [{
|
|
4172
4185
|
type: Component,
|
|
4173
|
-
args: [{ selector: 'pt-dialog', template: "<p-dialog\n [
|
|
4174
|
-
}], propDecorators: {
|
|
4175
|
-
type: Input
|
|
4176
|
-
}], style: [{
|
|
4177
|
-
type: Input
|
|
4178
|
-
}], styleClass: [{
|
|
4179
|
-
type: Input
|
|
4180
|
-
}], headerIconClass: [{
|
|
4181
|
-
type: Input
|
|
4182
|
-
}], bodyWidth: [{
|
|
4183
|
-
type: Input
|
|
4184
|
-
}], bodyHeight: [{
|
|
4185
|
-
type: Input
|
|
4186
|
-
}], bodyScrollable: [{
|
|
4187
|
-
type: Input
|
|
4188
|
-
}], showFooter: [{
|
|
4189
|
-
type: Input
|
|
4190
|
-
}], modal: [{
|
|
4191
|
-
type: Input
|
|
4192
|
-
}], closable: [{
|
|
4193
|
-
type: Input
|
|
4194
|
-
}], draggable: [{
|
|
4195
|
-
type: Input
|
|
4196
|
-
}], resizable: [{
|
|
4197
|
-
type: Input
|
|
4198
|
-
}], maximizable: [{
|
|
4199
|
-
type: Input
|
|
4200
|
-
}], dismissableMask: [{
|
|
4201
|
-
type: Input
|
|
4202
|
-
}], closeOnEscape: [{
|
|
4203
|
-
type: Input
|
|
4204
|
-
}], blockScroll: [{
|
|
4205
|
-
type: Input
|
|
4206
|
-
}], breakpoints: [{
|
|
4207
|
-
type: Input
|
|
4208
|
-
}], position: [{
|
|
4209
|
-
type: Input
|
|
4210
|
-
}], contentStyle: [{
|
|
4186
|
+
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"] }]
|
|
4187
|
+
}], propDecorators: { config: [{
|
|
4211
4188
|
type: Input
|
|
4212
4189
|
}], visible: [{
|
|
4213
4190
|
type: Input
|
|
@@ -4856,6 +4833,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
4856
4833
|
}]
|
|
4857
4834
|
}] });
|
|
4858
4835
|
|
|
4836
|
+
// src/lib/models/pt-dialog-config.model.ts
|
|
4837
|
+
|
|
4859
4838
|
// Advanced table
|
|
4860
4839
|
|
|
4861
4840
|
class PTGroupComponent {
|