ng-prime-tools 1.0.24 → 1.0.26

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.
Files changed (46) hide show
  1. package/README.md +8 -0
  2. package/esm2022/lib/enums/public-api.mjs +2 -1
  3. package/esm2022/lib/enums/severity.enum.mjs +8 -0
  4. package/esm2022/lib/models/button.model.mjs +1 -1
  5. package/esm2022/lib/models/chart-config.model.mjs +1 -1
  6. package/esm2022/lib/models/dialog-config.model.mjs +2 -0
  7. package/esm2022/lib/models/public-api.mjs +3 -2
  8. package/esm2022/lib/models/toast-message.model.mjs +2 -0
  9. package/esm2022/lib/pt-chart-comparison/index.mjs +2 -0
  10. package/esm2022/lib/pt-chart-comparison/pt-chart-comparison.component.mjs +153 -0
  11. package/esm2022/lib/pt-chart-comparison/pt-chart-comparison.module.mjs +18 -0
  12. package/esm2022/lib/pt-chart-comparison/public-api.mjs +3 -0
  13. package/esm2022/lib/pt-dialog/pt-dialog.component.mjs +219 -48
  14. package/esm2022/public-api.mjs +2 -1
  15. package/fesm2022/ng-prime-tools.mjs +388 -48
  16. package/fesm2022/ng-prime-tools.mjs.map +1 -1
  17. package/lib/enums/public-api.d.ts +1 -0
  18. package/lib/enums/public-api.d.ts.map +1 -1
  19. package/lib/enums/severity.enum.d.ts +7 -0
  20. package/lib/enums/severity.enum.d.ts.map +1 -0
  21. package/lib/models/button.model.d.ts +2 -0
  22. package/lib/models/button.model.d.ts.map +1 -1
  23. package/lib/models/chart-config.model.d.ts +15 -0
  24. package/lib/models/chart-config.model.d.ts.map +1 -1
  25. package/lib/models/dialog-config.model.d.ts +18 -0
  26. package/lib/models/dialog-config.model.d.ts.map +1 -0
  27. package/lib/models/public-api.d.ts +2 -1
  28. package/lib/models/public-api.d.ts.map +1 -1
  29. package/lib/models/toast-message.model.d.ts +7 -0
  30. package/lib/models/toast-message.model.d.ts.map +1 -0
  31. package/lib/pt-chart-comparison/index.d.ts +2 -0
  32. package/lib/pt-chart-comparison/index.d.ts.map +1 -0
  33. package/lib/pt-chart-comparison/pt-chart-comparison.component.d.ts +42 -0
  34. package/lib/pt-chart-comparison/pt-chart-comparison.component.d.ts.map +1 -0
  35. package/lib/pt-chart-comparison/pt-chart-comparison.module.d.ts +9 -0
  36. package/lib/pt-chart-comparison/pt-chart-comparison.module.d.ts.map +1 -0
  37. package/lib/pt-chart-comparison/public-api.d.ts +3 -0
  38. package/lib/pt-chart-comparison/public-api.d.ts.map +1 -0
  39. package/lib/pt-dialog/pt-dialog.component.d.ts +11 -3
  40. package/lib/pt-dialog/pt-dialog.component.d.ts.map +1 -1
  41. package/package.json +1 -1
  42. package/public-api.d.ts +1 -0
  43. package/public-api.d.ts.map +1 -1
  44. package/esm2022/lib/models/dialog.model.mjs +0 -2
  45. package/lib/models/dialog.model.d.ts +0 -13
  46. package/lib/models/dialog.model.d.ts.map +0 -1
@@ -1,66 +1,115 @@
1
1
  import { Component, Input, Output, EventEmitter, } from '@angular/core';
2
2
  import { ConfirmationService, ConfirmEventType, MessageService, } from 'primeng/api';
3
+ import { SeverityEnum } from '../enums';
3
4
  import * as i0 from "@angular/core";
4
5
  import * as i1 from "primeng/api";
5
- import * as i2 from "primeng/toast";
6
- import * as i3 from "primeng/confirmdialog";
6
+ import * as i2 from "@angular/common";
7
+ import * as i3 from "primeng/toast";
8
+ import * as i4 from "primeng/confirmdialog";
9
+ // Default Styles for Different Dialog Types
10
+ const DIALOG_STYLES = {
11
+ [SeverityEnum.WARNING]: {
12
+ header: { text: 'Warning', color: '#d98300' },
13
+ content: { text: 'This is a warning message!', color: '#d98300' },
14
+ confirmButtonConfig: { backgroundColor: '#d98300', fontColor: '#fff' },
15
+ cancelButtonConfig: { backgroundColor: '#6c757d', fontColor: '#fff' },
16
+ },
17
+ [SeverityEnum.SUCCESS]: {
18
+ header: { text: 'Success', color: '#28a745' },
19
+ content: { text: 'Operation was successful!', color: '#28a745' },
20
+ confirmButtonConfig: { backgroundColor: '#28a745', fontColor: '#fff' },
21
+ cancelButtonConfig: { backgroundColor: '#6c757d', fontColor: '#fff' },
22
+ },
23
+ [SeverityEnum.DANGER]: {
24
+ header: { text: 'Error', color: '#dc3545' },
25
+ content: { text: 'An error occurred!', color: '#dc3545' },
26
+ confirmButtonConfig: { backgroundColor: '#dc3545', fontColor: '#fff' },
27
+ cancelButtonConfig: { backgroundColor: '#6c757d', fontColor: '#fff' },
28
+ },
29
+ [SeverityEnum.INFO]: {
30
+ header: { text: 'Information', color: '#007bff' },
31
+ content: { text: 'Here is some important information.', color: '#007bff' },
32
+ confirmButtonConfig: { backgroundColor: '#007bff', fontColor: '#fff' },
33
+ cancelButtonConfig: { backgroundColor: '#6c757d', fontColor: '#fff' },
34
+ },
35
+ };
36
+ // Centralized Default Values
37
+ const DEFAULT_DIALOG_CONFIG = {
38
+ header: { text: 'Confirmation' },
39
+ visible: false,
40
+ width: '400px',
41
+ height: 'auto',
42
+ content: 'Do you want to proceed?',
43
+ confirmButtonConfig: {
44
+ label: 'Confirm',
45
+ fontColor: '#fff',
46
+ backgroundColor: '#007bff',
47
+ },
48
+ cancelButtonConfig: {
49
+ label: 'Cancel',
50
+ fontColor: '#fff',
51
+ backgroundColor: '#6c757d',
52
+ },
53
+ dialogStyle: SeverityEnum.INFO,
54
+ };
7
55
  export class PTDialogComponent {
8
56
  constructor(confirmationService, messageService, renderer, el) {
9
57
  this.confirmationService = confirmationService;
10
58
  this.messageService = messageService;
11
59
  this.renderer = renderer;
12
60
  this.el = el;
13
- this.dialogModel = {
14
- header: { text: 'Confirmation' },
15
- visible: false,
16
- width: '400px',
17
- height: 'auto',
18
- content: 'Do you want to proceed?',
19
- confirmButtonConfig: {
20
- label: 'Confirm',
21
- fontColor: '#fff',
22
- backgroundColor: '#007bff',
23
- },
24
- cancelButtonConfig: {
25
- label: 'Cancel',
26
- fontColor: '#fff',
27
- backgroundColor: '#6c757d',
28
- },
29
- };
61
+ this.dialogConfig = { ...DEFAULT_DIALOG_CONFIG };
30
62
  this.confirm = new EventEmitter();
31
63
  this.cancel = new EventEmitter();
32
64
  }
33
65
  ngOnChanges(changes) {
34
- if (changes['dialogModel'] && this.dialogModel.visible) {
35
- this.showDialog();
66
+ if (changes['dialogConfig']) {
67
+ if (changes['dialogConfig'].currentValue?.dialogStyle !==
68
+ changes['dialogConfig'].previousValue?.dialogStyle) {
69
+ this.applyDialogStyle();
70
+ }
71
+ if (this.dialogConfig.visible) {
72
+ this.showDialog();
73
+ }
36
74
  }
37
75
  }
76
+ applyDialogStyle() {
77
+ const dialogStyle = this.dialogConfig.dialogStyle || SeverityEnum.INFO; // ✅ Ensure dialogStyle is always defined
78
+ const styleConfig = DIALOG_STYLES[dialogStyle] || {}; // ✅ Get the styles for the selected dialogStyle
79
+ this.dialogConfig = {
80
+ ...DEFAULT_DIALOG_CONFIG, // ✅ Start with the default values
81
+ ...styleConfig, // ✅ Override with the selected dialogStyle values
82
+ confirmButtonConfig: {
83
+ ...DEFAULT_DIALOG_CONFIG.confirmButtonConfig, // ✅ Start with default confirm button styles
84
+ ...styleConfig.confirmButtonConfig, // ✅ Override with the confirm button styles for the selected dialogStyle
85
+ },
86
+ cancelButtonConfig: {
87
+ ...DEFAULT_DIALOG_CONFIG.cancelButtonConfig, // ✅ Start with default cancel button styles
88
+ ...styleConfig.cancelButtonConfig, // ✅ Override with the cancel button styles for the selected dialogStyle
89
+ },
90
+ };
91
+ }
38
92
  showDialog() {
39
93
  this.confirmationService.confirm({
40
- header: this.dialogModel.header?.text || 'Confirmation',
41
- message: this.dialogModel.content || 'Are you sure?',
42
- acceptButtonStyleClass: this.getButtonStyle(this.dialogModel.confirmButtonConfig),
43
- rejectButtonStyleClass: this.getButtonStyle(this.dialogModel.cancelButtonConfig),
44
- acceptIcon: this.dialogModel.confirmButtonConfig?.icon || 'pi pi-check',
45
- rejectIcon: this.dialogModel.cancelButtonConfig?.icon || 'pi pi-times',
94
+ header: this.getDialogHeaderText(),
95
+ message: this.getDialogContentText(),
96
+ acceptLabel: this.dialogConfig.confirmButtonConfig?.label || 'Confirm',
97
+ rejectLabel: this.dialogConfig.cancelButtonConfig?.label || 'Cancel',
98
+ acceptButtonStyleClass: this.getButtonStyle(this.dialogConfig.confirmButtonConfig, true),
99
+ rejectButtonStyleClass: this.getButtonStyle(this.dialogConfig.cancelButtonConfig, false),
100
+ acceptIcon: this.dialogConfig.confirmButtonConfig?.icon || 'pi pi-check',
101
+ rejectIcon: this.dialogConfig.cancelButtonConfig?.icon || 'pi pi-times',
46
102
  accept: () => {
47
103
  this.confirm.emit();
48
- this.messageService.add({
49
- severity: 'info',
50
- summary: 'Confirmed',
51
- detail: 'Action confirmed',
52
- life: 3000,
53
- });
104
+ if (this.dialogConfig.toastOnConfirm) {
105
+ this.showToast(this.dialogConfig.toastOnConfirm);
106
+ }
54
107
  },
55
108
  reject: (type) => {
56
109
  this.cancel.emit();
57
- if (type === ConfirmEventType.REJECT) {
58
- this.messageService.add({
59
- severity: 'error',
60
- summary: 'Rejected',
61
- detail: 'Action cancelled',
62
- life: 3000,
63
- });
110
+ if (type === ConfirmEventType.REJECT &&
111
+ this.dialogConfig.toastOnCancel) {
112
+ this.showToast(this.dialogConfig.toastOnCancel);
64
113
  }
65
114
  },
66
115
  });
@@ -68,25 +117,147 @@ export class PTDialogComponent {
68
117
  setTimeout(() => {
69
118
  const dialogElement = this.el.nativeElement.querySelector('.p-dialog');
70
119
  if (dialogElement) {
71
- this.renderer.setStyle(dialogElement, 'width', this.dialogModel.width || '400px');
72
- this.renderer.setStyle(dialogElement, 'height', this.dialogModel.height || 'auto');
120
+ this.renderer.setStyle(dialogElement, 'width', this.dialogConfig.width || '400px');
121
+ this.renderer.setStyle(dialogElement, 'height', this.dialogConfig.height || 'auto');
73
122
  }
74
123
  }, 0);
75
124
  }
76
- getButtonStyle(buttonConfig) {
77
- return buttonConfig?.styleClass || 'p-button-sm'; // Default to small button style
125
+ showToast(toast) {
126
+ if (toast) {
127
+ this.messageService.add({
128
+ severity: toast.severity,
129
+ summary: toast.summary,
130
+ detail: toast.detail,
131
+ life: toast.life || 3000,
132
+ });
133
+ }
134
+ }
135
+ getButtonStyle(buttonConfig, isConfirm = false) {
136
+ let styleClass = buttonConfig?.styleClass ?? 'p-button-sm'; // ✅ Default button size
137
+ // ✅ Apply width dynamically if provided, otherwise default to 100%
138
+ const buttonWidth = buttonConfig?.width ?? '100%';
139
+ // ✅ Set default severity: SUCCESS for confirm, SECONDARY for cancel
140
+ const defaultSeverity = isConfirm ? SeverityEnum.DANGER : SeverityEnum.INFO;
141
+ const severity = buttonConfig?.severity ?? defaultSeverity;
142
+ // ✅ Apply severity-based styles only if no custom background color is set
143
+ if (!buttonConfig?.backgroundColor) {
144
+ switch (severity) {
145
+ case SeverityEnum.WARNING:
146
+ styleClass += ' p-button-warning';
147
+ break;
148
+ case SeverityEnum.DANGER:
149
+ styleClass += ' p-button-danger';
150
+ break;
151
+ case SeverityEnum.SUCCESS:
152
+ styleClass += ' p-button-success';
153
+ break;
154
+ case SeverityEnum.INFO:
155
+ default:
156
+ styleClass += ' p-button-secondary';
157
+ break;
158
+ }
159
+ }
160
+ return `${styleClass.trim()} width-${buttonWidth.replace('%', '')}`;
161
+ }
162
+ getDialogHeaderText() {
163
+ const header = this.dialogConfig.header;
164
+ const dialogStyle = this.dialogConfig.dialogStyle ?? SeverityEnum.INFO;
165
+ const styleHeader = DIALOG_STYLES[dialogStyle]?.header;
166
+ return typeof header === 'object' && header !== null && 'text' in header
167
+ ? header.text
168
+ : typeof header === 'string'
169
+ ? header
170
+ : typeof styleHeader === 'object' &&
171
+ styleHeader !== null &&
172
+ 'text' in styleHeader
173
+ ? styleHeader.text
174
+ : 'Confirmation'; // ✅ Default value
175
+ }
176
+ getDialogHeaderStyle() {
177
+ const header = this.dialogConfig.header;
178
+ const dialogStyle = this.dialogConfig.dialogStyle ?? SeverityEnum.INFO; // ✅ Ensure dialogStyle is always defined
179
+ const styleHeader = DIALOG_STYLES[dialogStyle]?.header; // ✅ Store the style header separately
180
+ return typeof header === 'object' && header !== null
181
+ ? {
182
+ color: header.color ||
183
+ (typeof styleHeader === 'object' ? styleHeader?.color : '#333'),
184
+ fontSize: header.fontSize || '25px',
185
+ }
186
+ : {
187
+ color: typeof styleHeader === 'object' ? styleHeader?.color : '#333',
188
+ fontSize: '25px',
189
+ };
190
+ }
191
+ getDialogIconClass() {
192
+ const header = this.dialogConfig.header;
193
+ const dialogStyle = this.dialogConfig.dialogStyle ?? SeverityEnum.INFO; // ✅ Ensure dialogStyle is always defined
194
+ const styleHeader = DIALOG_STYLES[dialogStyle]?.header; // ✅ Store the style header separately
195
+ // ✅ Ensure header.icon exists and is an object before accessing .code
196
+ const icon = typeof header === 'object' && header !== null && 'icon' in header
197
+ ? header.icon
198
+ : typeof styleHeader === 'object' && 'icon' in styleHeader
199
+ ? styleHeader.icon
200
+ : undefined;
201
+ // ✅ If `icon` is an object, extract `.code`, otherwise return as string or default value
202
+ return typeof icon === 'string'
203
+ ? icon
204
+ : icon?.code || 'pi pi-exclamation-circle';
205
+ }
206
+ getDialogIconStyle() {
207
+ const header = this.dialogConfig.header;
208
+ const dialogStyle = this.dialogConfig.dialogStyle ?? SeverityEnum.INFO;
209
+ const styleHeader = DIALOG_STYLES[dialogStyle]?.header;
210
+ const icon = typeof header === 'object' && header !== null && 'icon' in header
211
+ ? header.icon
212
+ : undefined;
213
+ return {
214
+ color: icon?.color ||
215
+ (typeof styleHeader === 'object' ? styleHeader?.color : '#f39c12'),
216
+ fontSize: icon?.fontSize || '1.5rem',
217
+ backgroundColor: icon?.backgroundColor || 'transparent',
218
+ borderRadius: icon?.shape === 'circular' ? '50%' : '4px',
219
+ padding: '5px',
220
+ };
221
+ }
222
+ getDialogContentText() {
223
+ const content = this.dialogConfig.content;
224
+ const dialogStyle = this.dialogConfig.dialogStyle ?? SeverityEnum.INFO;
225
+ const styleContent = DIALOG_STYLES[dialogStyle]?.content;
226
+ return typeof content === 'string'
227
+ ? content
228
+ : content?.text ||
229
+ (typeof styleContent === 'object'
230
+ ? styleContent?.text
231
+ : 'Are you sure?');
232
+ }
233
+ getDialogContentStyle() {
234
+ const content = this.dialogConfig.content;
235
+ const dialogStyle = this.dialogConfig.dialogStyle ?? SeverityEnum.INFO;
236
+ const styleContent = DIALOG_STYLES[dialogStyle]?.content;
237
+ return typeof content === 'object' && content !== null
238
+ ? {
239
+ color: content.color ||
240
+ (typeof styleContent === 'object' ? styleContent?.color : '#333'),
241
+ fontSize: content.fontSize || '20px',
242
+ textAlign: content.position || 'left',
243
+ }
244
+ : {
245
+ color: typeof styleContent === 'object' ? styleContent?.color : '#333',
246
+ fontSize: '20px',
247
+ textAlign: 'left',
248
+ };
78
249
  }
79
250
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTDialogComponent, deps: [{ token: i1.ConfirmationService }, { token: i1.MessageService }, { token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
80
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PTDialogComponent, selector: "pt-dialog", inputs: { dialogModel: "dialogModel" }, outputs: { confirm: "confirm", cancel: "cancel" }, providers: [ConfirmationService, MessageService], usesOnChanges: true, ngImport: i0, template: "<div>\n <p-toast></p-toast>\n <p-confirmDialog>\n <ng-template pTemplate=\"message\" let-message>\n <div\n class=\"flex flex-column align-items-center w-full gap-3 border-bottom-1 surface-border\"\n >\n <i [class]=\"dialogModel.header?.icon || 'pi pi-exclamation-circle'\"></i>\n <p>{{ message.message }}</p>\n </div>\n </ng-template>\n </p-confirmDialog>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "component", type: i2.Toast, selector: "p-toast", inputs: ["key", "autoZIndex", "baseZIndex", "life", "style", "styleClass", "position", "preventOpenDuplicates", "preventDuplicates", "showTransformOptions", "hideTransformOptions", "showTransitionOptions", "hideTransitionOptions", "breakpoints"], outputs: ["onClose"] }, { kind: "component", type: i3.ConfirmDialog, selector: "p-confirmDialog", inputs: ["header", "icon", "message", "style", "styleClass", "maskStyleClass", "acceptIcon", "acceptLabel", "closeAriaLabel", "acceptAriaLabel", "acceptVisible", "rejectIcon", "rejectLabel", "rejectAriaLabel", "rejectVisible", "acceptButtonStyleClass", "rejectButtonStyleClass", "closeOnEscape", "dismissableMask", "blockScroll", "rtl", "closable", "appendTo", "key", "autoZIndex", "baseZIndex", "transitionOptions", "focusTrap", "defaultFocus", "breakpoints", "visible", "position"], outputs: ["onHide"] }] }); }
251
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PTDialogComponent, selector: "pt-dialog", inputs: { dialogConfig: "dialogConfig" }, outputs: { confirm: "confirm", cancel: "cancel" }, providers: [ConfirmationService, MessageService], usesOnChanges: true, ngImport: i0, template: "<div class=\"pt-dialog\">\n <p-toast></p-toast>\n <p-confirmDialog>\n <!-- Header with Icon and Title aligned horizontally -->\n <ng-template pTemplate=\"header\">\n <div class=\"popup-header bordered-section\">\n <i [class]=\"getDialogIconClass()\" [ngStyle]=\"getDialogIconStyle()\"></i>\n <span class=\"popup-title\" [ngStyle]=\"getDialogHeaderStyle()\">\n {{ getDialogHeaderText() }}\n </span>\n </div>\n </ng-template>\n\n <!-- Message Content with Divider -->\n <ng-template pTemplate=\"message\" let-message>\n <div\n class=\"popup-content bordered-section\"\n [ngStyle]=\"getDialogContentStyle()\"\n >\n <p>{{ getDialogContentText() }}</p>\n </div>\n </ng-template>\n </p-confirmDialog>\n</div>\n", styles: ["::ng-deep .pt-dialog .p-dialog .p-dialog-header{padding-bottom:0}::ng-deep .pt-dialog .p-dialog .p-dialog-content{padding:0}::ng-deep .pt-dialog .full-width-button{width:100%;display:block;text-align:center}::ng-deep .pt-dialog .p-dialog-footer{display:flex;justify-content:center;gap:10px;width:100%;padding:10px}::ng-deep .pt-dialog .p-confirm-dialog-accept,::ng-deep .pt-dialog .p-confirm-dialog-reject{flex:1;max-width:50%;text-align:center;display:flex;justify-content:center;align-items:center;height:40px}::ng-deep .pt-dialog .p-confirm-dialog-accept i,::ng-deep .pt-dialog .p-confirm-dialog-reject i{margin-right:5px}::ng-deep .pt-dialog .p-confirm-dialog-accept .p-button-label,::ng-deep .pt-dialog .p-confirm-dialog-reject .p-button-label{font-weight:700;flex-grow:1;text-align:center}.pt-dialog .popup-header{display:flex;align-items:center;gap:10px;font-size:1.2rem;font-weight:700;padding-bottom:10px;width:100%}.pt-dialog .popup-title{color:#333;font-size:1.2rem}.pt-dialog .bordered-section{width:100%;border-bottom:1px solid rgba(0,0,0,.2);padding-bottom:10px;margin-bottom:10px}.pt-dialog .popup-content{display:flex;justify-content:center;text-align:center;padding:15px;width:100%}\n"], dependencies: [{ kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i1.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "component", type: i3.Toast, selector: "p-toast", inputs: ["key", "autoZIndex", "baseZIndex", "life", "style", "styleClass", "position", "preventOpenDuplicates", "preventDuplicates", "showTransformOptions", "hideTransformOptions", "showTransitionOptions", "hideTransitionOptions", "breakpoints"], outputs: ["onClose"] }, { kind: "component", type: i4.ConfirmDialog, selector: "p-confirmDialog", inputs: ["header", "icon", "message", "style", "styleClass", "maskStyleClass", "acceptIcon", "acceptLabel", "closeAriaLabel", "acceptAriaLabel", "acceptVisible", "rejectIcon", "rejectLabel", "rejectAriaLabel", "rejectVisible", "acceptButtonStyleClass", "rejectButtonStyleClass", "closeOnEscape", "dismissableMask", "blockScroll", "rtl", "closable", "appendTo", "key", "autoZIndex", "baseZIndex", "transitionOptions", "focusTrap", "defaultFocus", "breakpoints", "visible", "position"], outputs: ["onHide"] }] }); }
81
252
  }
82
253
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTDialogComponent, decorators: [{
83
254
  type: Component,
84
- args: [{ selector: 'pt-dialog', providers: [ConfirmationService, MessageService], template: "<div>\n <p-toast></p-toast>\n <p-confirmDialog>\n <ng-template pTemplate=\"message\" let-message>\n <div\n class=\"flex flex-column align-items-center w-full gap-3 border-bottom-1 surface-border\"\n >\n <i [class]=\"dialogModel.header?.icon || 'pi pi-exclamation-circle'\"></i>\n <p>{{ message.message }}</p>\n </div>\n </ng-template>\n </p-confirmDialog>\n</div>\n" }]
85
- }], ctorParameters: () => [{ type: i1.ConfirmationService }, { type: i1.MessageService }, { type: i0.Renderer2 }, { type: i0.ElementRef }], propDecorators: { dialogModel: [{
255
+ args: [{ selector: 'pt-dialog', providers: [ConfirmationService, MessageService], template: "<div class=\"pt-dialog\">\n <p-toast></p-toast>\n <p-confirmDialog>\n <!-- Header with Icon and Title aligned horizontally -->\n <ng-template pTemplate=\"header\">\n <div class=\"popup-header bordered-section\">\n <i [class]=\"getDialogIconClass()\" [ngStyle]=\"getDialogIconStyle()\"></i>\n <span class=\"popup-title\" [ngStyle]=\"getDialogHeaderStyle()\">\n {{ getDialogHeaderText() }}\n </span>\n </div>\n </ng-template>\n\n <!-- Message Content with Divider -->\n <ng-template pTemplate=\"message\" let-message>\n <div\n class=\"popup-content bordered-section\"\n [ngStyle]=\"getDialogContentStyle()\"\n >\n <p>{{ getDialogContentText() }}</p>\n </div>\n </ng-template>\n </p-confirmDialog>\n</div>\n", styles: ["::ng-deep .pt-dialog .p-dialog .p-dialog-header{padding-bottom:0}::ng-deep .pt-dialog .p-dialog .p-dialog-content{padding:0}::ng-deep .pt-dialog .full-width-button{width:100%;display:block;text-align:center}::ng-deep .pt-dialog .p-dialog-footer{display:flex;justify-content:center;gap:10px;width:100%;padding:10px}::ng-deep .pt-dialog .p-confirm-dialog-accept,::ng-deep .pt-dialog .p-confirm-dialog-reject{flex:1;max-width:50%;text-align:center;display:flex;justify-content:center;align-items:center;height:40px}::ng-deep .pt-dialog .p-confirm-dialog-accept i,::ng-deep .pt-dialog .p-confirm-dialog-reject i{margin-right:5px}::ng-deep .pt-dialog .p-confirm-dialog-accept .p-button-label,::ng-deep .pt-dialog .p-confirm-dialog-reject .p-button-label{font-weight:700;flex-grow:1;text-align:center}.pt-dialog .popup-header{display:flex;align-items:center;gap:10px;font-size:1.2rem;font-weight:700;padding-bottom:10px;width:100%}.pt-dialog .popup-title{color:#333;font-size:1.2rem}.pt-dialog .bordered-section{width:100%;border-bottom:1px solid rgba(0,0,0,.2);padding-bottom:10px;margin-bottom:10px}.pt-dialog .popup-content{display:flex;justify-content:center;text-align:center;padding:15px;width:100%}\n"] }]
256
+ }], ctorParameters: () => [{ type: i1.ConfirmationService }, { type: i1.MessageService }, { type: i0.Renderer2 }, { type: i0.ElementRef }], propDecorators: { dialogConfig: [{
86
257
  type: Input
87
258
  }], confirm: [{
88
259
  type: Output
89
260
  }], cancel: [{
90
261
  type: Output
91
262
  }] } });
92
- //# 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  OnInit,\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 { DialogModel } from '../models/dialog.model';\nimport { ButtonModel } from '../models/button.model';\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() dialogModel: DialogModel = {\n    header: { text: 'Confirmation' },\n    visible: false,\n    width: '400px',\n    height: 'auto',\n    content: 'Do you want to proceed?',\n    confirmButtonConfig: {\n      label: 'Confirm',\n      fontColor: '#fff',\n      backgroundColor: '#007bff',\n    },\n    cancelButtonConfig: {\n      label: 'Cancel',\n      fontColor: '#fff',\n      backgroundColor: '#6c757d',\n    },\n  };\n\n  @Output() confirm: EventEmitter<void> = new EventEmitter();\n  @Output() cancel: EventEmitter<void> = new EventEmitter();\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['dialogModel'] && this.dialogModel.visible) {\n      this.showDialog();\n    }\n  }\n\n  showDialog(): void {\n    this.confirmationService.confirm({\n      header: this.dialogModel.header?.text || 'Confirmation',\n      message: this.dialogModel.content || 'Are you sure?',\n      acceptButtonStyleClass: this.getButtonStyle(\n        this.dialogModel.confirmButtonConfig\n      ),\n      rejectButtonStyleClass: this.getButtonStyle(\n        this.dialogModel.cancelButtonConfig\n      ),\n      acceptIcon: this.dialogModel.confirmButtonConfig?.icon || 'pi pi-check',\n      rejectIcon: this.dialogModel.cancelButtonConfig?.icon || 'pi pi-times',\n      accept: () => {\n        this.confirm.emit();\n        this.messageService.add({\n          severity: 'info',\n          summary: 'Confirmed',\n          detail: 'Action confirmed',\n          life: 3000,\n        });\n      },\n      reject: (type: ConfirmEventType) => {\n        this.cancel.emit();\n        if (type === ConfirmEventType.REJECT) {\n          this.messageService.add({\n            severity: 'error',\n            summary: 'Rejected',\n            detail: 'Action cancelled',\n            life: 3000,\n          });\n        }\n      },\n    });\n\n    // Use renderer to apply dynamic styles\n    setTimeout(() => {\n      const dialogElement = this.el.nativeElement.querySelector('.p-dialog');\n      if (dialogElement) {\n        this.renderer.setStyle(\n          dialogElement,\n          'width',\n          this.dialogModel.width || '400px'\n        );\n        this.renderer.setStyle(\n          dialogElement,\n          'height',\n          this.dialogModel.height || 'auto'\n        );\n      }\n    }, 0);\n  }\n\n  private getButtonStyle(buttonConfig?: ButtonModel): string {\n    return buttonConfig?.styleClass || 'p-button-sm'; // Default to small button style\n  }\n}\n","<div>\n  <p-toast></p-toast>\n  <p-confirmDialog>\n    <ng-template pTemplate=\"message\" let-message>\n      <div\n        class=\"flex flex-column align-items-center w-full gap-3 border-bottom-1 surface-border\"\n      >\n        <i [class]=\"dialogModel.header?.icon || 'pi pi-exclamation-circle'\"></i>\n        <p>{{ message.message }}</p>\n      </div>\n    </ng-template>\n  </p-confirmDialog>\n</div>\n"]}
263
+ //# 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, ToastMessage } from '../models';\nimport { SeverityEnum } from '../enums';\n\n// Default Styles for Different Dialog Types\nconst DIALOG_STYLES: Record<SeverityEnum, Partial<DialogConfig>> = {\n  [SeverityEnum.WARNING]: {\n    header: { text: 'Warning', color: '#d98300' },\n    content: { text: 'This is a warning message!', color: '#d98300' },\n    confirmButtonConfig: { backgroundColor: '#d98300', fontColor: '#fff' },\n    cancelButtonConfig: { backgroundColor: '#6c757d', fontColor: '#fff' },\n  },\n  [SeverityEnum.SUCCESS]: {\n    header: { text: 'Success', color: '#28a745' },\n    content: { text: 'Operation was successful!', color: '#28a745' },\n    confirmButtonConfig: { backgroundColor: '#28a745', fontColor: '#fff' },\n    cancelButtonConfig: { backgroundColor: '#6c757d', fontColor: '#fff' },\n  },\n  [SeverityEnum.DANGER]: {\n    header: { text: 'Error', color: '#dc3545' },\n    content: { text: 'An error occurred!', color: '#dc3545' },\n    confirmButtonConfig: { backgroundColor: '#dc3545', fontColor: '#fff' },\n    cancelButtonConfig: { backgroundColor: '#6c757d', fontColor: '#fff' },\n  },\n  [SeverityEnum.INFO]: {\n    header: { text: 'Information', color: '#007bff' },\n    content: { text: 'Here is some important information.', color: '#007bff' },\n    confirmButtonConfig: { backgroundColor: '#007bff', fontColor: '#fff' },\n    cancelButtonConfig: { backgroundColor: '#6c757d', fontColor: '#fff' },\n  },\n};\n\n// Centralized Default Values\nconst DEFAULT_DIALOG_CONFIG: DialogConfig = {\n  header: { text: 'Confirmation' },\n  visible: false,\n  width: '400px',\n  height: 'auto',\n  content: 'Do you want to proceed?',\n  confirmButtonConfig: {\n    label: 'Confirm',\n    fontColor: '#fff',\n    backgroundColor: '#007bff',\n  },\n  cancelButtonConfig: {\n    label: 'Cancel',\n    fontColor: '#fff',\n    backgroundColor: '#6c757d',\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: EventEmitter<void> = new EventEmitter();\n  @Output() cancel: EventEmitter<void> = new EventEmitter();\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      if (\n        changes['dialogConfig'].currentValue?.dialogStyle !==\n        changes['dialogConfig'].previousValue?.dialogStyle\n      ) {\n        this.applyDialogStyle();\n      }\n\n      if (this.dialogConfig.visible) {\n        this.showDialog();\n      }\n    }\n  }\n\n  private applyDialogStyle(): void {\n    const dialogStyle = this.dialogConfig.dialogStyle || SeverityEnum.INFO; // ✅ Ensure dialogStyle is always defined\n    const styleConfig = DIALOG_STYLES[dialogStyle] || {}; // ✅ Get the styles for the selected dialogStyle\n\n    this.dialogConfig = {\n      ...DEFAULT_DIALOG_CONFIG, // ✅ Start with the default values\n      ...styleConfig, // ✅ Override with the selected dialogStyle values\n      confirmButtonConfig: {\n        ...DEFAULT_DIALOG_CONFIG.confirmButtonConfig, // ✅ Start with default confirm button styles\n        ...styleConfig.confirmButtonConfig, // ✅ Override with the confirm button styles for the selected dialogStyle\n      },\n      cancelButtonConfig: {\n        ...DEFAULT_DIALOG_CONFIG.cancelButtonConfig, // ✅ Start with default cancel button styles\n        ...styleConfig.cancelButtonConfig, // ✅ Override with the cancel button styles for the selected dialogStyle\n      },\n    };\n  }\n\n  showDialog(): void {\n    this.confirmationService.confirm({\n      header: this.getDialogHeaderText(),\n      message: this.getDialogContentText(),\n      acceptLabel: this.dialogConfig.confirmButtonConfig?.label || 'Confirm',\n      rejectLabel: this.dialogConfig.cancelButtonConfig?.label || 'Cancel',\n      acceptButtonStyleClass: this.getButtonStyle(\n        this.dialogConfig.confirmButtonConfig,\n        true\n      ),\n      rejectButtonStyleClass: this.getButtonStyle(\n        this.dialogConfig.cancelButtonConfig,\n        false\n      ),\n      acceptIcon: this.dialogConfig.confirmButtonConfig?.icon || 'pi pi-check',\n      rejectIcon: this.dialogConfig.cancelButtonConfig?.icon || 'pi pi-times',\n      accept: () => {\n        this.confirm.emit();\n        if (this.dialogConfig.toastOnConfirm) {\n          this.showToast(this.dialogConfig.toastOnConfirm);\n        }\n      },\n      reject: (type: ConfirmEventType) => {\n        this.cancel.emit();\n        if (\n          type === ConfirmEventType.REJECT &&\n          this.dialogConfig.toastOnCancel\n        ) {\n          this.showToast(this.dialogConfig.toastOnCancel);\n        }\n      },\n    });\n\n    // Use renderer to apply dynamic styles\n    setTimeout(() => {\n      const dialogElement = this.el.nativeElement.querySelector('.p-dialog');\n      if (dialogElement) {\n        this.renderer.setStyle(\n          dialogElement,\n          'width',\n          this.dialogConfig.width || '400px'\n        );\n        this.renderer.setStyle(\n          dialogElement,\n          'height',\n          this.dialogConfig.height || 'auto'\n        );\n      }\n    }, 0);\n  }\n\n  private showToast(toast?: ToastMessage) {\n    if (toast) {\n      this.messageService.add({\n        severity: toast.severity,\n        summary: toast.summary,\n        detail: toast.detail,\n        life: toast.life || 3000,\n      });\n    }\n  }\n\n  private getButtonStyle(\n    buttonConfig?: ButtonModel,\n    isConfirm: boolean = false\n  ): string {\n    let styleClass = buttonConfig?.styleClass ?? 'p-button-sm'; // ✅ Default button size\n\n    // ✅ Apply width dynamically if provided, otherwise default to 100%\n    const buttonWidth = buttonConfig?.width ?? '100%';\n\n    // ✅ Set default severity: SUCCESS for confirm, SECONDARY for cancel\n    const defaultSeverity = isConfirm ? SeverityEnum.DANGER : SeverityEnum.INFO;\n    const severity = buttonConfig?.severity ?? defaultSeverity;\n\n    // ✅ Apply severity-based styles only if no custom background color is set\n    if (!buttonConfig?.backgroundColor) {\n      switch (severity) {\n        case SeverityEnum.WARNING:\n          styleClass += ' p-button-warning';\n          break;\n        case SeverityEnum.DANGER:\n          styleClass += ' p-button-danger';\n          break;\n        case SeverityEnum.SUCCESS:\n          styleClass += ' p-button-success';\n          break;\n        case SeverityEnum.INFO:\n        default:\n          styleClass += ' p-button-secondary';\n          break;\n      }\n    }\n\n    return `${styleClass.trim()} width-${buttonWidth.replace('%', '')}`;\n  }\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'; // ✅ Default value\n  }\n\n  getDialogHeaderStyle(): any {\n    const header = this.dialogConfig.header;\n    const dialogStyle = this.dialogConfig.dialogStyle ?? SeverityEnum.INFO; // ✅ Ensure dialogStyle is always defined\n    const styleHeader = DIALOG_STYLES[dialogStyle]?.header; // ✅ Store the style header separately\n\n    return typeof header === 'object' && header !== null\n      ? {\n          color:\n            header.color ||\n            (typeof styleHeader === 'object' ? styleHeader?.color : '#333'),\n          fontSize: header.fontSize || '25px',\n        }\n      : {\n          color: typeof styleHeader === 'object' ? styleHeader?.color : '#333',\n          fontSize: '25px',\n        };\n  }\n\n  getDialogIconClass(): string {\n    const header = this.dialogConfig.header;\n    const dialogStyle = this.dialogConfig.dialogStyle ?? SeverityEnum.INFO; // ✅ Ensure dialogStyle is always defined\n    const styleHeader = DIALOG_STYLES[dialogStyle]?.header; // ✅ Store the style header separately\n\n    // ✅ Ensure header.icon exists and is an object before accessing .code\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    // ✅ If `icon` is an object, extract `.code`, otherwise return as string or default value\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 dialogStyle = this.dialogConfig.dialogStyle ?? SeverityEnum.INFO;\n    const styleHeader = DIALOG_STYLES[dialogStyle]?.header;\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:\n        icon?.color ||\n        (typeof styleHeader === 'object' ? styleHeader?.color : '#f39c12'),\n      fontSize: icon?.fontSize || '1.5rem',\n      backgroundColor: icon?.backgroundColor || 'transparent',\n      borderRadius: icon?.shape === 'circular' ? '50%' : '4px',\n      padding: '5px',\n    };\n  }\n\n  getDialogContentText(): string {\n    const content = this.dialogConfig.content;\n    const dialogStyle = this.dialogConfig.dialogStyle ?? SeverityEnum.INFO;\n    const styleContent = DIALOG_STYLES[dialogStyle]?.content;\n\n    return typeof content === 'string'\n      ? content\n      : content?.text ||\n          (typeof styleContent === 'object'\n            ? styleContent?.text\n            : 'Are you sure?');\n  }\n\n  getDialogContentStyle(): any {\n    const content = this.dialogConfig.content;\n    const dialogStyle = this.dialogConfig.dialogStyle ?? SeverityEnum.INFO;\n    const styleContent = DIALOG_STYLES[dialogStyle]?.content;\n\n    return typeof content === 'object' && content !== null\n      ? {\n          color:\n            content.color ||\n            (typeof styleContent === 'object' ? styleContent?.color : '#333'),\n          fontSize: content.fontSize || '20px',\n          textAlign: content.position || 'left',\n        }\n      : {\n          color:\n            typeof styleContent === 'object' ? styleContent?.color : '#333',\n          fontSize: '20px',\n          textAlign: 'left',\n        };\n  }\n}\n","<div class=\"pt-dialog\">\n  <p-toast></p-toast>\n  <p-confirmDialog>\n    <!-- Header with Icon and Title aligned horizontally -->\n    <ng-template pTemplate=\"header\">\n      <div class=\"popup-header bordered-section\">\n        <i [class]=\"getDialogIconClass()\" [ngStyle]=\"getDialogIconStyle()\"></i>\n        <span class=\"popup-title\" [ngStyle]=\"getDialogHeaderStyle()\">\n          {{ getDialogHeaderText() }}\n        </span>\n      </div>\n    </ng-template>\n\n    <!-- Message Content with Divider -->\n    <ng-template pTemplate=\"message\" let-message>\n      <div\n        class=\"popup-content bordered-section\"\n        [ngStyle]=\"getDialogContentStyle()\"\n      >\n        <p>{{ getDialogContentText() }}</p>\n      </div>\n    </ng-template>\n  </p-confirmDialog>\n</div>\n"]}
@@ -17,6 +17,7 @@ export * from './lib/pt-metric-card';
17
17
  export * from './lib/pt-metric-card-group';
18
18
  // Chart
19
19
  export * from './lib/pt-chart';
20
+ export * from './lib/pt-chart-comparison';
20
21
  export * from './lib/pt-line-chart';
21
22
  // Cards
22
23
  export * from './lib/pt-card';
@@ -44,4 +45,4 @@ export * from './lib/models';
44
45
  export * from './lib/enums';
45
46
  export * from './lib/types';
46
47
  export * from './lib/pt-group';
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsNkJBQTZCLENBQUM7QUFFNUMsaUJBQWlCO0FBQ2pCLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyw2QkFBNkIsQ0FBQztBQUU1QyxTQUFTO0FBQ1QsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLHFCQUFxQixDQUFDO0FBRXBDLFlBQVk7QUFDWixjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyw0QkFBNEIsQ0FBQztBQUUzQyxRQUFRO0FBQ1IsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLHFCQUFxQixDQUFDO0FBRXBDLFFBQVE7QUFDUixjQUFjLGVBQWUsQ0FBQztBQUU5QixPQUFPO0FBQ1AsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxxQkFBcUIsQ0FBQztBQUVwQyxTQUFTO0FBQ1QsY0FBYyx1QkFBdUIsQ0FBQztBQUV0QyxTQUFTO0FBQ1QsY0FBYyx3QkFBd0IsQ0FBQztBQUV2QyxnQkFBZ0I7QUFDaEIsY0FBYyx3QkFBd0IsQ0FBQztBQUV2QyxTQUFTO0FBQ1QsY0FBYyxpQkFBaUIsQ0FBQztBQUVoQyxjQUFjO0FBQ2QsY0FBYyxzQkFBc0IsQ0FBQztBQUVyQyxhQUFhO0FBQ2IsY0FBYyxxQkFBcUIsQ0FBQztBQUVwQyxTQUFTO0FBQ1QsY0FBYyxpQkFBaUIsQ0FBQztBQUVoQyxTQUFTO0FBQ1QsY0FBYyxpQkFBaUIsQ0FBQztBQUVoQyxVQUFVO0FBQ1YsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxnQkFBZ0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL25nLXByaW1lLXRvb2xzLm1vZHVsZSc7XG5cbi8vIEFkdmFuY2VkIHRhYmxlXG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1hZHZhbmNlZC1wcmltZS10YWJsZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tdWx0aS1zZWFyY2gtY3JpdGVyaWEnO1xuXG4vLyBJbnB1dHNcbmV4cG9ydCAqIGZyb20gJy4vbGliL3B0LWNoZWNrLWJveC1pbnB1dCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1kYXRlLWlucHV0JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3B0LWRyb3Bkb3duJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3B0LWZvcm0tYnVpbGRlcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1udW1iZXItaW5wdXQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtc3dpdGNoLWlucHV0JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3B0LXRleHQtYXJlYS1pbnB1dCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC10ZXh0LWlucHV0JztcblxuLy8gRGFzaGJvYXJkXG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1tZXRyaWMtcGFuZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtbWV0cmljLWNhcmQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtbWV0cmljLWNhcmQtZ3JvdXAnO1xuXG4vLyBDaGFydFxuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtY2hhcnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtbGluZS1jaGFydCc7XG5cbi8vIENhcmRzXG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1jYXJkJztcblxuLy8gTWVudVxuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtbWVudSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1tZW51LWZhbmN5JztcblxuLy8gTmF2YmFyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1uYXYtYmFyLW1lbnUnO1xuXG4vLyBOYXZiYXJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3B0LXNpZGUtYmFyLW1lbnUnO1xuXG4vLyBQYWdlIHNrZWxldG9uXG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1wYWdlLXNrZWxldG9uJztcblxuLy8gZm9vdGVyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1mb290ZXInO1xuXG4vLyBicmVhZCBjcnVtYlxuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtYnJlYWQtY3J1bWInO1xuXG4vLyBsb2dpbiBwYWdlXG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1sb2dpbi1wYWdlJztcblxuLy8gYnV0dG9uXG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1idXR0b24nO1xuXG4vLyBkaWFsb2dcbmV4cG9ydCAqIGZyb20gJy4vbGliL3B0LWRpYWxvZyc7XG5cbi8vIEdlbmVyaWNcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbnVtcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1ncm91cCc7XG4iXX0=
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsNkJBQTZCLENBQUM7QUFFNUMsaUJBQWlCO0FBQ2pCLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyw2QkFBNkIsQ0FBQztBQUU1QyxTQUFTO0FBQ1QsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLHFCQUFxQixDQUFDO0FBRXBDLFlBQVk7QUFDWixjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyw0QkFBNEIsQ0FBQztBQUUzQyxRQUFRO0FBQ1IsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMscUJBQXFCLENBQUM7QUFFcEMsUUFBUTtBQUNSLGNBQWMsZUFBZSxDQUFDO0FBRTlCLE9BQU87QUFDUCxjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLHFCQUFxQixDQUFDO0FBRXBDLFNBQVM7QUFDVCxjQUFjLHVCQUF1QixDQUFDO0FBRXRDLFNBQVM7QUFDVCxjQUFjLHdCQUF3QixDQUFDO0FBRXZDLGdCQUFnQjtBQUNoQixjQUFjLHdCQUF3QixDQUFDO0FBRXZDLFNBQVM7QUFDVCxjQUFjLGlCQUFpQixDQUFDO0FBRWhDLGNBQWM7QUFDZCxjQUFjLHNCQUFzQixDQUFDO0FBRXJDLGFBQWE7QUFDYixjQUFjLHFCQUFxQixDQUFDO0FBRXBDLFNBQVM7QUFDVCxjQUFjLGlCQUFpQixDQUFDO0FBRWhDLFNBQVM7QUFDVCxjQUFjLGlCQUFpQixDQUFDO0FBRWhDLFVBQVU7QUFDVixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLGdCQUFnQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvbmctcHJpbWUtdG9vbHMubW9kdWxlJztcblxuLy8gQWR2YW5jZWQgdGFibGVcbmV4cG9ydCAqIGZyb20gJy4vbGliL3B0LWFkdmFuY2VkLXByaW1lLXRhYmxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL211bHRpLXNlYXJjaC1jcml0ZXJpYSc7XG5cbi8vIElucHV0c1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtY2hlY2stYm94LWlucHV0JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3B0LWRhdGUtaW5wdXQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtZHJvcGRvd24nO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtZm9ybS1idWlsZGVyJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3B0LW51bWJlci1pbnB1dCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1zd2l0Y2gtaW5wdXQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtdGV4dC1hcmVhLWlucHV0JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3B0LXRleHQtaW5wdXQnO1xuXG4vLyBEYXNoYm9hcmRcbmV4cG9ydCAqIGZyb20gJy4vbGliL3B0LW1ldHJpYy1wYW5lbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1tZXRyaWMtY2FyZCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1tZXRyaWMtY2FyZC1ncm91cCc7XG5cbi8vIENoYXJ0XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1jaGFydCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1jaGFydC1jb21wYXJpc29uJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3B0LWxpbmUtY2hhcnQnO1xuXG4vLyBDYXJkc1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtY2FyZCc7XG5cbi8vIE1lbnVcbmV4cG9ydCAqIGZyb20gJy4vbGliL3B0LW1lbnUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtbWVudS1mYW5jeSc7XG5cbi8vIE5hdmJhclxuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtbmF2LWJhci1tZW51JztcblxuLy8gTmF2YmFyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1zaWRlLWJhci1tZW51JztcblxuLy8gUGFnZSBza2VsZXRvblxuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtcGFnZS1za2VsZXRvbic7XG5cbi8vIGZvb3RlclxuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtZm9vdGVyJztcblxuLy8gYnJlYWQgY3J1bWJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3B0LWJyZWFkLWNydW1iJztcblxuLy8gbG9naW4gcGFnZVxuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtbG9naW4tcGFnZSc7XG5cbi8vIGJ1dHRvblxuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtYnV0dG9uJztcblxuLy8gZGlhbG9nXG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1kaWFsb2cnO1xuXG4vLyBHZW5lcmljXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2RlbHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZW51bXMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdHlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtZ3JvdXAnO1xuIl19