@huntsman-cancer-institute/dialog 12.11.9-SNAPSHOT

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 (53) hide show
  1. package/CHANGELOG.md +4 -0
  2. package/README.md +24 -0
  3. package/alert/alert-dialog.component.d.ts +31 -0
  4. package/bundles/huntsman-cancer-institute-dialog.umd.js +1049 -0
  5. package/bundles/huntsman-cancer-institute-dialog.umd.js.map +1 -0
  6. package/bundles/huntsman-cancer-institute-dialog.umd.min.js +2 -0
  7. package/bundles/huntsman-cancer-institute-dialog.umd.min.js.map +1 -0
  8. package/confirm/confirm-dialog.component.d.ts +18 -0
  9. package/custom/custom-dialog.component.d.ts +35 -0
  10. package/dialog.module.d.ts +27 -0
  11. package/esm2015/alert/alert-dialog.component.js +243 -0
  12. package/esm2015/confirm/confirm-dialog.component.js +130 -0
  13. package/esm2015/custom/custom-dialog.component.js +231 -0
  14. package/esm2015/dialog.module.js +157 -0
  15. package/esm2015/generic/generic-container-dialog.component.js +158 -0
  16. package/esm2015/huntsman-cancer-institute-dialog.js +5 -0
  17. package/esm2015/index.js +13 -0
  18. package/esm2015/model/base-generic-container-dialog.js +26 -0
  19. package/esm2015/model/confirm-type.model.js +12 -0
  20. package/esm2015/model/dialog-type.model.js +12 -0
  21. package/esm2015/model/generic-dialog-action.model.js +6 -0
  22. package/esm2015/save-footer/save-footer.component.js +135 -0
  23. package/esm2015/service/dialog.service.js +272 -0
  24. package/esm2015/spinner/spinner-dialog.component.js +69 -0
  25. package/esm5/alert/alert-dialog.component.js +105 -0
  26. package/esm5/confirm/confirm-dialog.component.js +101 -0
  27. package/esm5/custom/custom-dialog.component.js +118 -0
  28. package/esm5/dialog.module.js +161 -0
  29. package/esm5/generic/generic-container-dialog.component.js +128 -0
  30. package/esm5/huntsman-cancer-institute-dialog.js +5 -0
  31. package/esm5/index.js +13 -0
  32. package/esm5/model/base-generic-container-dialog.js +28 -0
  33. package/esm5/model/confirm-type.model.js +12 -0
  34. package/esm5/model/dialog-type.model.js +12 -0
  35. package/esm5/model/generic-dialog-action.model.js +6 -0
  36. package/esm5/save-footer/save-footer.component.js +86 -0
  37. package/esm5/service/dialog.service.js +307 -0
  38. package/esm5/spinner/spinner-dialog.component.js +47 -0
  39. package/fesm2015/huntsman-cancer-institute-dialog.js +1396 -0
  40. package/fesm2015/huntsman-cancer-institute-dialog.js.map +1 -0
  41. package/fesm5/huntsman-cancer-institute-dialog.js +1047 -0
  42. package/fesm5/huntsman-cancer-institute-dialog.js.map +1 -0
  43. package/generic/generic-container-dialog.component.d.ts +38 -0
  44. package/huntsman-cancer-institute-dialog.d.ts +5 -0
  45. package/index.d.ts +14 -0
  46. package/model/base-generic-container-dialog.d.ts +13 -0
  47. package/model/confirm-type.model.d.ts +10 -0
  48. package/model/dialog-type.model.d.ts +10 -0
  49. package/model/generic-dialog-action.model.d.ts +18 -0
  50. package/package.json +34 -0
  51. package/save-footer/save-footer.component.d.ts +24 -0
  52. package/service/dialog.service.d.ts +45 -0
  53. package/spinner/spinner-dialog.component.d.ts +12 -0
@@ -0,0 +1,27 @@
1
+ import { ModuleWithProviders } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "./alert/alert-dialog.component";
4
+ import * as i2 from "./confirm/confirm-dialog.component";
5
+ import * as i3 from "./custom/custom-dialog.component";
6
+ import * as i4 from "./generic/generic-container-dialog.component";
7
+ import * as i5 from "./save-footer/save-footer.component";
8
+ import * as i6 from "./spinner/spinner-dialog.component";
9
+ import * as i7 from "@angular/common";
10
+ import * as i8 from "@angular/forms";
11
+ import * as i9 from "ng-dynamic-component";
12
+ import * as i10 from "@angular/material/button";
13
+ import * as i11 from "@angular/material/dialog";
14
+ import * as i12 from "@angular/material/expansion";
15
+ import * as i13 from "@angular/material/progress-spinner";
16
+ /**
17
+ * The main @huntsman-cancer-institute/dialog module. The module exports all components that an implementation might use
18
+ * and the forRoot() provides a global service for an implementing application.
19
+ *
20
+ * @since 1.0.0
21
+ */
22
+ export declare class DialogModule {
23
+ static forRoot(): ModuleWithProviders<DialogModule>;
24
+ static ɵfac: i0.ɵɵFactoryDeclaration<DialogModule, never>;
25
+ static ɵmod: i0.ɵɵNgModuleDeclaration<DialogModule, [typeof i1.AlertDialogComponent, typeof i2.ConfirmDialogComponent, typeof i3.CustomDialogComponent, typeof i4.GenericContainerDialogComponent, typeof i5.SaveFooterComponent, typeof i6.SpinnerDialogComponent], [typeof i7.CommonModule, typeof i8.FormsModule, typeof i9.DynamicModule, typeof i10.MatButtonModule, typeof i11.MatDialogModule, typeof i12.MatExpansionModule, typeof i13.MatProgressSpinnerModule], [typeof i1.AlertDialogComponent, typeof i2.ConfirmDialogComponent, typeof i3.CustomDialogComponent, typeof i4.GenericContainerDialogComponent, typeof i5.SaveFooterComponent, typeof i6.SpinnerDialogComponent]>;
26
+ static ɵinj: i0.ɵɵInjectorDeclaration<DialogModule>;
27
+ }
@@ -0,0 +1,243 @@
1
+ import { ChangeDetectorRef, Component, ElementRef, HostListener, Inject, ViewChild, } from '@angular/core';
2
+ import { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';
3
+ import { DialogType } from '../model/dialog-type.model';
4
+ import { ActionType } from '../model/generic-dialog-action.model';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/material/dialog";
7
+ import * as i2 from "@angular/common";
8
+ export class AlertDialogComponent {
9
+ constructor(dialogRef, data, changeDetector) {
10
+ this.dialogRef = dialogRef;
11
+ this.data = data;
12
+ this.changeDetector = changeDetector;
13
+ this.type = DialogType;
14
+ this.message = null;
15
+ this.title = '';
16
+ this.icon = '';
17
+ this.dialogType = '';
18
+ this.defaultTitle = '';
19
+ this.actionType = ActionType.SECONDARY;
20
+ this.originalXClick = 0;
21
+ this.originalYClick = 0;
22
+ this.positionX = 0;
23
+ this.positionY = 0;
24
+ this.movingDialog = false;
25
+ if (data) {
26
+ this.message = Array.isArray(data.message) ? data.message : [data.message];
27
+ this.title = data.title;
28
+ this.icon = data.icon;
29
+ this.dialogType = data.dialogType;
30
+ }
31
+ }
32
+ ngOnInit() {
33
+ if (this.dialogType) {
34
+ this.defaultTitle = this.dialogType;
35
+ }
36
+ for (let i = 0; i < this.message.length; i++) {
37
+ this.message[i] = this.message[i].replace(/\n/g, '<br>') + '<br>';
38
+ }
39
+ }
40
+ onClickOk() {
41
+ this.dialogRef.close(true);
42
+ }
43
+ onClickYes() {
44
+ this.dialogRef.close(true);
45
+ }
46
+ onClickNo() {
47
+ this.dialogRef.close();
48
+ }
49
+ onMouseDownHeader(event) {
50
+ if (!event) {
51
+ return;
52
+ }
53
+ this.positionX = this.topmostLeftmost.nativeElement.offsetLeft;
54
+ this.positionY = this.topmostLeftmost.nativeElement.offsetTop;
55
+ this.originalXClick = event.screenX;
56
+ this.originalYClick = event.screenY;
57
+ this.movingDialog = true;
58
+ this.changeDetector.detach();
59
+ }
60
+ onMouseMove(event) {
61
+ if (!event) {
62
+ return;
63
+ }
64
+ if (this.movingDialog) {
65
+ this.positionX += event.screenX - this.originalXClick;
66
+ this.positionY += event.screenY - this.originalYClick;
67
+ this.originalXClick = event.screenX;
68
+ this.originalYClick = event.screenY;
69
+ const newDialogPosition = {
70
+ left: '' + this.positionX + 'px',
71
+ top: '' + this.positionY + 'px',
72
+ };
73
+ this.dialogRef.updatePosition(newDialogPosition);
74
+ }
75
+ }
76
+ onMouseUp() {
77
+ this.movingDialog = false;
78
+ this.changeDetector.reattach();
79
+ }
80
+ }
81
+ AlertDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: AlertDialogComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
82
+ AlertDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: AlertDialogComponent, selector: "hci-alert-dialog", host: { listeners: { "window:mousemove": "onMouseMove($event)", "window:mouseup": "onMouseUp($event)" } }, viewQueries: [{ propertyName: "topmostLeftmost", first: true, predicate: ["topmostLeftmost"], descendants: true }], ngImport: i0, template: `
83
+ <div class="full-height full-width d-flex flex-column">
84
+ <div class="full-width dialog-header-colors no-margin no-padding">
85
+ <div #topmostLeftmost mat-dialog-title (mousedown)="onMouseDownHeader($event)"
86
+ class="force-flex-container-row align-center full-width padding {{ movingDialog ? 'grabbed' : 'grabbable' }}">
87
+ <div class="d-flex flex-row align-items-center padded">
88
+ <img *ngIf="icon" class="icon" [src]="this.icon">
89
+ <div *ngIf="!icon">
90
+ <i *ngIf="dialogType === type.ALERT" class="fa fa-exclamation fa-2x i-margin i-color-blue"></i>
91
+ <i *ngIf="dialogType === type.SUCCESS" class="fa fa-check-circle fa-2x i-margin i-color-blue"></i>
92
+ <i *ngIf="dialogType === type.FAILED || dialogType === type.ERROR" class="fa fa-exclamation-triangle fa-2x i-margin i-color-red"></i>
93
+ <i *ngIf="dialogType === type.WARNING || dialogType === type.VALIDATION" class="fa fa-exclamation-triangle fa-2x i-margin i-color-blue"></i>
94
+ <i *ngIf="dialogType === type.INFO" class="fa fa-info-circle fa-2x i-margin i-color-blue"></i>
95
+ <i *ngIf="dialogType === type.CONFIRM" class="fa fa-check fa-2x i-margin i-color-blue"></i>
96
+ </div>
97
+ <h1 *ngIf="dialogType !== type.ERROR"
98
+ style="margin:0;">{{this.title ? this.title : defaultTitle}}</h1>
99
+ <h1 *ngIf="dialogType === type.ERROR"
100
+ style="margin:0; color: Red">{{this.title ? this.title : defaultTitle}}</h1>
101
+ </div>
102
+ </div>
103
+ </div>
104
+ <mat-dialog-content class="flex-grow-1 no-margin no-padding">
105
+ <hr>
106
+ <div class="flex-grow-1 full-width extra-padded message">
107
+ <div *ngFor="let line of message" class="full-width"
108
+ [innerHTML]="line" style="white-space: pre-line">
109
+ </div>
110
+ </div>
111
+ <br>
112
+ </mat-dialog-content>
113
+ <mat-dialog-actions class="d-flex justify-content-center no-margin no-padding">
114
+ <save-footer *ngIf="dialogType !== type.CONFIRM" class="centered-text large-size"
115
+ (saveClicked)="onClickOk()" name="Ok"></save-footer>
116
+ <save-footer *ngIf="dialogType === type.CONFIRM" class="centered-text large-size"
117
+ (saveClicked)="onClickYes()" name="Yes"></save-footer>
118
+ <save-footer *ngIf="dialogType === type.CONFIRM" [actionType]="actionType"
119
+ class="centered-text large-size" (saveClicked)="onClickNo()"
120
+ name="No"></save-footer>
121
+ </mat-dialog-actions>
122
+ </div>
123
+ `, isInline: true, styles: ["\n hr {\n width: 98%;\n }\n\n .i-margin {\n margin-left: 0.3em;\n margin-right: 0.3em;\n }\n .i-color-blue {\n color: #0077B3FF;\n }\n .i-color-red {\n color: red;\n }\n\n .centered-text { text-align: center; }\n\n .no-padding{\n padding:0;\n\n }\n\n .no-margin{\n margin: 0;\n }\n\n .grabbable {\n cursor: move;\n cursor: grab;\n cursor: -moz-grab;\n cursor: -webkit-grab;\n }\n .grabbed {\n cursor: move;\n cursor: grabbing;\n cursor: -moz-grabbing;\n cursor: -webkit-grabbing;\n }\n\n .force-flex-container-row{\n display:flex !important;\n }\n .extra-padded {\n padding: 0.6em 0.9em 0.6em 0.9em;\n }\n .large-size {\n font-size: large;\n }\n .primary-action {\n font-size: large;\n }\n .secondary-action {\n font-size: large;\n }\n .message {\n color: #0F244DFF;\n }\n "], directives: [{ type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]" }] });
124
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: AlertDialogComponent, decorators: [{
125
+ type: Component,
126
+ args: [{
127
+ selector: 'hci-alert-dialog',
128
+ template: `
129
+ <div class="full-height full-width d-flex flex-column">
130
+ <div class="full-width dialog-header-colors no-margin no-padding">
131
+ <div #topmostLeftmost mat-dialog-title (mousedown)="onMouseDownHeader($event)"
132
+ class="force-flex-container-row align-center full-width padding {{ movingDialog ? 'grabbed' : 'grabbable' }}">
133
+ <div class="d-flex flex-row align-items-center padded">
134
+ <img *ngIf="icon" class="icon" [src]="this.icon">
135
+ <div *ngIf="!icon">
136
+ <i *ngIf="dialogType === type.ALERT" class="fa fa-exclamation fa-2x i-margin i-color-blue"></i>
137
+ <i *ngIf="dialogType === type.SUCCESS" class="fa fa-check-circle fa-2x i-margin i-color-blue"></i>
138
+ <i *ngIf="dialogType === type.FAILED || dialogType === type.ERROR" class="fa fa-exclamation-triangle fa-2x i-margin i-color-red"></i>
139
+ <i *ngIf="dialogType === type.WARNING || dialogType === type.VALIDATION" class="fa fa-exclamation-triangle fa-2x i-margin i-color-blue"></i>
140
+ <i *ngIf="dialogType === type.INFO" class="fa fa-info-circle fa-2x i-margin i-color-blue"></i>
141
+ <i *ngIf="dialogType === type.CONFIRM" class="fa fa-check fa-2x i-margin i-color-blue"></i>
142
+ </div>
143
+ <h1 *ngIf="dialogType !== type.ERROR"
144
+ style="margin:0;">{{this.title ? this.title : defaultTitle}}</h1>
145
+ <h1 *ngIf="dialogType === type.ERROR"
146
+ style="margin:0; color: Red">{{this.title ? this.title : defaultTitle}}</h1>
147
+ </div>
148
+ </div>
149
+ </div>
150
+ <mat-dialog-content class="flex-grow-1 no-margin no-padding">
151
+ <hr>
152
+ <div class="flex-grow-1 full-width extra-padded message">
153
+ <div *ngFor="let line of message" class="full-width"
154
+ [innerHTML]="line" style="white-space: pre-line">
155
+ </div>
156
+ </div>
157
+ <br>
158
+ </mat-dialog-content>
159
+ <mat-dialog-actions class="d-flex justify-content-center no-margin no-padding">
160
+ <save-footer *ngIf="dialogType !== type.CONFIRM" class="centered-text large-size"
161
+ (saveClicked)="onClickOk()" name="Ok"></save-footer>
162
+ <save-footer *ngIf="dialogType === type.CONFIRM" class="centered-text large-size"
163
+ (saveClicked)="onClickYes()" name="Yes"></save-footer>
164
+ <save-footer *ngIf="dialogType === type.CONFIRM" [actionType]="actionType"
165
+ class="centered-text large-size" (saveClicked)="onClickNo()"
166
+ name="No"></save-footer>
167
+ </mat-dialog-actions>
168
+ </div>
169
+ `,
170
+ styles: [`
171
+ hr {
172
+ width: 98%;
173
+ }
174
+
175
+ .i-margin {
176
+ margin-left: 0.3em;
177
+ margin-right: 0.3em;
178
+ }
179
+ .i-color-blue {
180
+ color: #0077B3FF;
181
+ }
182
+ .i-color-red {
183
+ color: red;
184
+ }
185
+
186
+ .centered-text { text-align: center; }
187
+
188
+ .no-padding{
189
+ padding:0;
190
+
191
+ }
192
+
193
+ .no-margin{
194
+ margin: 0;
195
+ }
196
+
197
+ .grabbable {
198
+ cursor: move;
199
+ cursor: grab;
200
+ cursor: -moz-grab;
201
+ cursor: -webkit-grab;
202
+ }
203
+ .grabbed {
204
+ cursor: move;
205
+ cursor: grabbing;
206
+ cursor: -moz-grabbing;
207
+ cursor: -webkit-grabbing;
208
+ }
209
+
210
+ .force-flex-container-row{
211
+ display:flex !important;
212
+ }
213
+ .extra-padded {
214
+ padding: 0.6em 0.9em 0.6em 0.9em;
215
+ }
216
+ .large-size {
217
+ font-size: large;
218
+ }
219
+ .primary-action {
220
+ font-size: large;
221
+ }
222
+ .secondary-action {
223
+ font-size: large;
224
+ }
225
+ .message {
226
+ color: #0F244DFF;
227
+ }
228
+ `]
229
+ }]
230
+ }], ctorParameters: function () { return [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
231
+ type: Inject,
232
+ args: [MAT_DIALOG_DATA]
233
+ }] }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { topmostLeftmost: [{
234
+ type: ViewChild,
235
+ args: ['topmostLeftmost', { static: false }]
236
+ }], onMouseMove: [{
237
+ type: HostListener,
238
+ args: ['window:mousemove', ['$event']]
239
+ }], onMouseUp: [{
240
+ type: HostListener,
241
+ args: ['window:mouseup', ['$event']]
242
+ }] } });
243
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alert-dialog.component.js","sourceRoot":"ng://@huntsman-cancer-institute/dialog/","sources":["alert/alert-dialog.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,YAAY,EACZ,MAAM,EACN,SAAS,GACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAiB,eAAe,EAAE,YAAY,EAAC,MAAM,0BAA0B,CAAC;AACvF,OAAO,EAAC,UAAU,EAAC,MAAM,4BAA4B,CAAC;AACtD,OAAO,EAAC,UAAU,EAAC,MAAM,sCAAsC,CAAC;;;;AAyG7D,MAAM,OAAO,oBAAoB;IAkBhC,YAAmB,SAA6C,EACnB,IAAI,EAC7B,cAAiC;QAFlC,cAAS,GAAT,SAAS,CAAoC;QACnB,SAAI,GAAJ,IAAI,CAAA;QAC7B,mBAAc,GAAd,cAAc,CAAmB;QAnB9C,SAAI,GAAQ,UAAU,CAAC;QAIvB,YAAO,GAAa,IAAI,CAAC;QACzB,UAAK,GAAG,EAAE,CAAC;QACX,SAAI,GAAG,EAAE,CAAC;QACV,eAAU,GAAG,EAAE,CAAC;QAChB,iBAAY,GAAG,EAAE,CAAC;QAClB,eAAU,GAAQ,UAAU,CAAC,SAAS,CAAC;QAE9C,mBAAc,GAAG,CAAC,CAAC;QACnB,mBAAc,GAAG,CAAC,CAAC;QACT,cAAS,GAAG,CAAC,CAAC;QACd,cAAS,GAAG,CAAC,CAAC;QACxB,iBAAY,GAAG,KAAK,CAAC;QAKjB,IAAI,IAAI,EAAE;YACN,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC3E,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;YACxB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;YACtB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC;SACrC;IACL,CAAC;IAED,QAAQ;QACJ,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC;SACvC;QACD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAC1C,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,MAAM,CAAC;SACrE;IACL,CAAC;IAED,SAAS;QACL,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC;IAED,UAAU;QACN,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC;IAED,SAAS;QACL,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;IAC3B,CAAC;IAED,iBAAiB,CAAC,KAAU;QACxB,IAAI,CAAC,KAAK,EAAE;YACR,OAAO;SACV;QAED,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,UAAU,CAAC;QAC/D,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,SAAS,CAAC;QAE9D,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC,OAAO,CAAC;QACpC,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC,OAAO,CAAC;QAEpC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,CAAC;IACjC,CAAC;IAED,WAAW,CAAC,KAAU;QAClB,IAAI,CAAC,KAAK,EAAE;YACR,OAAO;SACV;QAED,IAAI,IAAI,CAAC,YAAY,EAAE;YACnB,IAAI,CAAC,SAAS,IAAI,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC;YACtD,IAAI,CAAC,SAAS,IAAI,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC;YAEtD,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC,OAAO,CAAC;YACpC,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC,OAAO,CAAC;YAEpC,MAAM,iBAAiB,GAAmB;gBACtC,IAAI,EAAI,EAAE,GAAG,IAAI,CAAC,SAAS,GAAG,IAAI;gBAClC,GAAG,EAAK,EAAE,GAAG,IAAI,CAAC,SAAS,GAAG,IAAI;aACrC,CAAC;YAEF,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,iBAAiB,CAAC,CAAC;SACpD;IACL,CAAC;IAED,SAAS;QACL,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAC;IACnC,CAAC;;kHAzFW,oBAAoB,8CAmBZ,eAAe;sGAnBvB,oBAAoB,uRArGtB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAyCT;4FA4DW,oBAAoB;kBAvGnC,SAAS;mBAAC;oBACP,QAAQ,EAAE,kBAAkB;oBAC5B,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAyCT;oBACD,MAAM,EAAE,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KA0DR,CAAC;iBACL;;0BAmBgB,MAAM;2BAAC,eAAe;4EAhBY,eAAe;sBAA7D,SAAS;uBAAC,iBAAiB,EAAE,EAAC,MAAM,EAAE,KAAK,EAAC;gBA8D7C,WAAW;sBADV,YAAY;uBAAC,kBAAkB,EAAE,CAAC,QAAQ,CAAC;gBAsB5C,SAAS;sBADR,YAAY;uBAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import {\r\n    ChangeDetectorRef,\r\n    Component,\r\n    ElementRef,\r\n    HostListener,\r\n    Inject, OnInit,\r\n    ViewChild,\r\n} from '@angular/core';\r\nimport {DialogPosition, MAT_DIALOG_DATA, MatDialogRef} from '@angular/material/dialog';\r\nimport {DialogType} from '../model/dialog-type.model';\r\nimport {ActionType} from '../model/generic-dialog-action.model';\r\n\r\n@Component({\r\n    selector: 'hci-alert-dialog',\r\n    template: `\r\n        <div class=\"full-height full-width d-flex flex-column\">\r\n            <div class=\"full-width dialog-header-colors no-margin no-padding\">\r\n                <div #topmostLeftmost mat-dialog-title (mousedown)=\"onMouseDownHeader($event)\"\r\n                     class=\"force-flex-container-row align-center full-width padding   {{ movingDialog ? 'grabbed' : 'grabbable' }}\">\r\n                    <div class=\"d-flex flex-row align-items-center padded\">\r\n                        <img *ngIf=\"icon\" class=\"icon\" [src]=\"this.icon\">\r\n                        <div *ngIf=\"!icon\">\r\n                            <i *ngIf=\"dialogType === type.ALERT\" class=\"fa fa-exclamation fa-2x i-margin i-color-blue\"></i>\r\n                            <i *ngIf=\"dialogType === type.SUCCESS\" class=\"fa fa-check-circle fa-2x i-margin i-color-blue\"></i>\r\n                            <i *ngIf=\"dialogType === type.FAILED || dialogType === type.ERROR\" class=\"fa fa-exclamation-triangle fa-2x i-margin i-color-red\"></i>\r\n                            <i *ngIf=\"dialogType === type.WARNING || dialogType === type.VALIDATION\" class=\"fa fa-exclamation-triangle fa-2x i-margin i-color-blue\"></i>\r\n                            <i *ngIf=\"dialogType === type.INFO\" class=\"fa fa-info-circle fa-2x i-margin i-color-blue\"></i>\r\n                            <i *ngIf=\"dialogType === type.CONFIRM\" class=\"fa fa-check fa-2x i-margin i-color-blue\"></i>\r\n                        </div>\r\n                        <h1 *ngIf=\"dialogType !== type.ERROR\"\r\n                            style=\"margin:0;\">{{this.title ? this.title : defaultTitle}}</h1>\r\n                        <h1 *ngIf=\"dialogType === type.ERROR\"\r\n                            style=\"margin:0; color: Red\">{{this.title ? this.title : defaultTitle}}</h1>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <mat-dialog-content class=\"flex-grow-1 no-margin no-padding\">\r\n                <hr>\r\n                <div class=\"flex-grow-1 full-width extra-padded message\">\r\n                    <div *ngFor=\"let line of message\" class=\"full-width\"\r\n                        [innerHTML]=\"line\" style=\"white-space: pre-line\">\r\n                    </div>\r\n                </div>\r\n                <br>\r\n            </mat-dialog-content>\r\n            <mat-dialog-actions class=\"d-flex justify-content-center no-margin no-padding\">\r\n                <save-footer *ngIf=\"dialogType !== type.CONFIRM\" class=\"centered-text large-size\"\r\n                             (saveClicked)=\"onClickOk()\" name=\"Ok\"></save-footer>\r\n                <save-footer *ngIf=\"dialogType === type.CONFIRM\" class=\"centered-text large-size\"\r\n                             (saveClicked)=\"onClickYes()\" name=\"Yes\"></save-footer>\r\n                <save-footer *ngIf=\"dialogType === type.CONFIRM\" [actionType]=\"actionType\"\r\n                             class=\"centered-text large-size\" (saveClicked)=\"onClickNo()\"\r\n                             name=\"No\"></save-footer>\r\n            </mat-dialog-actions>\r\n        </div>\r\n    `,\r\n    styles: [`\r\n        hr {\r\n            width: 98%;\r\n        }\r\n\r\n        .i-margin {\r\n            margin-left:  0.3em;\r\n            margin-right: 0.3em;\r\n        }\r\n        .i-color-blue {\r\n            color: #0077B3FF;\r\n        }\r\n        .i-color-red  {\r\n            color: red;\r\n        }\r\n\r\n        .centered-text { text-align: center; }\r\n\r\n        .no-padding{\r\n            padding:0;\r\n\r\n        }\r\n\r\n        .no-margin{\r\n            margin: 0;\r\n        }\r\n\r\n        .grabbable {\r\n            cursor: move;\r\n            cursor: grab;\r\n            cursor: -moz-grab;\r\n            cursor: -webkit-grab;\r\n        }\r\n        .grabbed {\r\n            cursor: move;\r\n            cursor: grabbing;\r\n            cursor: -moz-grabbing;\r\n            cursor: -webkit-grabbing;\r\n        }\r\n\r\n        .force-flex-container-row{\r\n            display:flex !important;\r\n        }\r\n        .extra-padded {\r\n            padding: 0.6em 0.9em 0.6em 0.9em;\r\n        }\r\n        .large-size {\r\n            font-size: large;\r\n        }\r\n        .primary-action {\r\n            font-size: large;\r\n        }\r\n        .secondary-action {\r\n            font-size: large;\r\n        }\r\n        .message {\r\n            color: #0F244DFF;\r\n        }\r\n    `]\r\n}) export class AlertDialogComponent implements OnInit {\r\n    public type: any = DialogType;\r\n\r\n    @ViewChild('topmostLeftmost', {static: false}) topmostLeftmost: ElementRef;\r\n\r\n    public message: string[] = null;\r\n    public title = '';\r\n    public icon = '';\r\n    public dialogType = '';\r\n    public defaultTitle = '';\r\n    public actionType: any = ActionType.SECONDARY;\r\n\r\n    originalXClick = 0;\r\n    originalYClick = 0;\r\n    protected positionX = 0;\r\n    protected positionY = 0;\r\n    movingDialog = false;\r\n\r\n    constructor(public dialogRef: MatDialogRef<AlertDialogComponent>,\r\n                @Inject(MAT_DIALOG_DATA) private data,\r\n                private changeDetector: ChangeDetectorRef) {\r\n        if (data) {\r\n            this.message = Array.isArray(data.message) ? data.message : [data.message];\r\n            this.title = data.title;\r\n            this.icon = data.icon;\r\n            this.dialogType = data.dialogType;\r\n        }\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        if (this.dialogType) {\r\n            this.defaultTitle = this.dialogType;\r\n        }\r\n        for (let i = 0; i < this.message.length; i++) {\r\n            this.message[i] = this.message[i].replace(/\\n/g, '<br>') + '<br>';\r\n        }\r\n    }\r\n\r\n    onClickOk(): void {\r\n        this.dialogRef.close(true);\r\n    }\r\n\r\n    onClickYes(): void {\r\n        this.dialogRef.close(true);\r\n    }\r\n\r\n    onClickNo(): void {\r\n        this.dialogRef.close();\r\n    }\r\n\r\n    onMouseDownHeader(event: any): void {\r\n        if (!event) {\r\n            return;\r\n        }\r\n\r\n        this.positionX = this.topmostLeftmost.nativeElement.offsetLeft;\r\n        this.positionY = this.topmostLeftmost.nativeElement.offsetTop;\r\n\r\n        this.originalXClick = event.screenX;\r\n        this.originalYClick = event.screenY;\r\n\r\n        this.movingDialog = true;\r\n        this.changeDetector.detach();\r\n    }\r\n    @HostListener('window:mousemove', ['$event'])\r\n    onMouseMove(event: any): void {\r\n        if (!event) {\r\n            return;\r\n        }\r\n\r\n        if (this.movingDialog) {\r\n            this.positionX += event.screenX - this.originalXClick;\r\n            this.positionY += event.screenY - this.originalYClick;\r\n\r\n            this.originalXClick = event.screenX;\r\n            this.originalYClick = event.screenY;\r\n\r\n            const newDialogPosition: DialogPosition = {\r\n                left:   '' + this.positionX + 'px',\r\n                top:    '' + this.positionY + 'px',\r\n            };\r\n\r\n            this.dialogRef.updatePosition(newDialogPosition);\r\n        }\r\n    }\r\n    @HostListener('window:mouseup', ['$event'])\r\n    onMouseUp(): void {\r\n        this.movingDialog = false;\r\n        this.changeDetector.reattach();\r\n    }\r\n}\r\n"]}
@@ -0,0 +1,130 @@
1
+ import { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';
2
+ import { Component, Inject } from '@angular/core';
3
+ import { BaseGenericContainerDialog } from '../model/base-generic-container-dialog';
4
+ import { ConfirmType } from '../model/confirm-type.model';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/material/dialog";
7
+ import * as i2 from "@angular/material/expansion";
8
+ import * as i3 from "@angular/common";
9
+ export class ConfirmDialogComponent extends BaseGenericContainerDialog {
10
+ constructor(dialogRef, data) {
11
+ super();
12
+ this.dialogRef = dialogRef;
13
+ this.data = data;
14
+ this.ConfirmType = ConfirmType; // make enum available in template
15
+ this.prompt = '';
16
+ this.message1 = '';
17
+ this.message2 = '';
18
+ this.confirmType = ConfirmType.GENERIC;
19
+ const temp = data.confirmType ? data.confirmType : ConfirmType.GENERIC;
20
+ if (Object.values(ConfirmType).includes(temp)) {
21
+ this.confirmType = temp;
22
+ }
23
+ this.prompt = data.prompt ? data.prompt : '';
24
+ this.message1 = data.message1 ? data.message1 : '';
25
+ this.message2 = data.message2 ? data.message2 : '';
26
+ this.setupMessagesByType();
27
+ }
28
+ setupMessagesByType() {
29
+ // by enum type, setup the messages/prompt
30
+ switch (this.confirmType) {
31
+ case ConfirmType.DELETE:
32
+ this.prompt = 'The following will be deleted:';
33
+ this.message2 = 'Continue?';
34
+ break;
35
+ case ConfirmType.DELETE_W_MESSAGE:
36
+ this.prompt = 'The following will be deleted:';
37
+ break;
38
+ case ConfirmType.DELETE_W_PROMPT:
39
+ // noop, take all of what was passed in
40
+ break;
41
+ case ConfirmType.DISCARD:
42
+ this.prompt = '';
43
+ this.message2 = 'Continue?';
44
+ break;
45
+ case ConfirmType.CONFIRM_AND_CLOSE:
46
+ this.prompt = '';
47
+ this.message2 = '';
48
+ break;
49
+ case ConfirmType.ADD:
50
+ this.prompt = 'The following will be added:';
51
+ this.message2 = 'Continue?';
52
+ break;
53
+ case ConfirmType.ALERT:
54
+ // noop, will only use the message1 in a special template, and just ignore rest
55
+ break;
56
+ case ConfirmType.GENERIC:
57
+ // TODO: either only use message 1 or just take all passed in...
58
+ this.prompt = '';
59
+ this.message2 = '';
60
+ break;
61
+ default:
62
+ throw new Error('Confirm type doesn\'t exist');
63
+ }
64
+ }
65
+ onConfirmClick(value) {
66
+ this.dialogRef.close(value);
67
+ }
68
+ }
69
+ ConfirmDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: ConfirmDialogComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component });
70
+ ConfirmDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: ConfirmDialogComponent, selector: "hci-confirm-dialog", usesInheritance: true, ngImport: i0, template: `
71
+ <div class="ri-confirm-body">
72
+
73
+ <div *ngIf="confirmType !== ConfirmType.ALERT; else alertBlock">
74
+ {{prompt}}
75
+ <div class="ri-confirm-text-delete">{{ message1 }}</div>
76
+ {{message2}}
77
+ </div>
78
+
79
+
80
+ <div #alertBlock>
81
+ <p>We are working to correct it. Contact CODE support if the error persists.</p>
82
+ <mat-expansion-panel>
83
+ <mat-expansion-panel-header>
84
+ <mat-panel-title>
85
+ <strong>Show details</strong>
86
+ </mat-panel-title>
87
+ </mat-expansion-panel-header>
88
+ <div>{{ message1 }}</div>
89
+ </mat-expansion-panel>
90
+ </div>
91
+
92
+ </div>
93
+ `, isInline: true, styles: ["\n\n "], components: [{ type: i2.MatExpansionPanel, selector: "mat-expansion-panel", inputs: ["disabled", "expanded", "hideToggle", "togglePosition"], outputs: ["opened", "closed", "expandedChange", "afterExpand", "afterCollapse"], exportAs: ["matExpansionPanel"] }, { type: i2.MatExpansionPanelHeader, selector: "mat-expansion-panel-header", inputs: ["tabIndex", "expandedHeight", "collapsedHeight"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatExpansionPanelTitle, selector: "mat-panel-title" }] });
94
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: ConfirmDialogComponent, decorators: [{
95
+ type: Component,
96
+ args: [{
97
+ selector: 'hci-confirm-dialog',
98
+ template: `
99
+ <div class="ri-confirm-body">
100
+
101
+ <div *ngIf="confirmType !== ConfirmType.ALERT; else alertBlock">
102
+ {{prompt}}
103
+ <div class="ri-confirm-text-delete">{{ message1 }}</div>
104
+ {{message2}}
105
+ </div>
106
+
107
+
108
+ <div #alertBlock>
109
+ <p>We are working to correct it. Contact CODE support if the error persists.</p>
110
+ <mat-expansion-panel>
111
+ <mat-expansion-panel-header>
112
+ <mat-panel-title>
113
+ <strong>Show details</strong>
114
+ </mat-panel-title>
115
+ </mat-expansion-panel-header>
116
+ <div>{{ message1 }}</div>
117
+ </mat-expansion-panel>
118
+ </div>
119
+
120
+ </div>
121
+ `,
122
+ styles: [`
123
+
124
+ `]
125
+ }]
126
+ }], ctorParameters: function () { return [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
127
+ type: Inject,
128
+ args: [MAT_DIALOG_DATA]
129
+ }] }]; } });
130
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlybS1kaWFsb2cuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vQGh1bnRzbWFuLWNhbmNlci1pbnN0aXR1dGUvZGlhbG9nLyIsInNvdXJjZXMiOlsiY29uZmlybS9jb25maXJtLWRpYWxvZy5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLGVBQWUsRUFBRSxZQUFZLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUN2RSxPQUFPLEVBQUMsU0FBUyxFQUFFLE1BQU0sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNoRCxPQUFPLEVBQUMsMEJBQTBCLEVBQUMsTUFBTSx3Q0FBd0MsQ0FBQztBQUNsRixPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sNkJBQTZCLENBQUM7Ozs7O0FBZ0N4RCxNQUFNLE9BQU8sc0JBQXVCLFNBQVEsMEJBQTBCO0lBVXBFLFlBQW9CLFNBQStDLEVBQ3RCLElBQVM7UUFDcEQsS0FBSyxFQUFFLENBQUM7UUFGVSxjQUFTLEdBQVQsU0FBUyxDQUFzQztRQUN0QixTQUFJLEdBQUosSUFBSSxDQUFLO1FBVC9DLGdCQUFXLEdBQUcsV0FBVyxDQUFDLENBQUMsa0NBQWtDO1FBRXBFLFdBQU0sR0FBRyxFQUFFLENBQUM7UUFDWixhQUFRLEdBQUcsRUFBRSxDQUFDO1FBQ2QsYUFBUSxHQUFHLEVBQUUsQ0FBQztRQUVkLGdCQUFXLEdBQWdCLFdBQVcsQ0FBQyxPQUFPLENBQUM7UUFNN0MsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQztRQUN2RSxJQUFJLE1BQU0sQ0FBQyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUMsUUFBUSxDQUFDLElBQW1CLENBQUMsRUFBQztZQUMzRCxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQztTQUN6QjtRQUVELElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1FBQzdDLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1FBQ25ELElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1FBRW5ELElBQUksQ0FBQyxtQkFBbUIsRUFBRSxDQUFDO0lBQzdCLENBQUM7SUFFRCxtQkFBbUI7UUFFakIsMENBQTBDO1FBQzFDLFFBQVEsSUFBSSxDQUFDLFdBQVcsRUFBRTtZQUN4QixLQUFLLFdBQVcsQ0FBQyxNQUFNO2dCQUNyQixJQUFJLENBQUMsTUFBTSxHQUFHLGdDQUFnQyxDQUFDO2dCQUMvQyxJQUFJLENBQUMsUUFBUSxHQUFHLFdBQVcsQ0FBQztnQkFDNUIsTUFBTTtZQUNSLEtBQUssV0FBVyxDQUFDLGdCQUFnQjtnQkFDL0IsSUFBSSxDQUFDLE1BQU0sR0FBRyxnQ0FBZ0MsQ0FBQztnQkFDL0MsTUFBTTtZQUNSLEtBQUssV0FBVyxDQUFDLGVBQWU7Z0JBQzlCLHVDQUF1QztnQkFDdkMsTUFBTTtZQUNSLEtBQUssV0FBVyxDQUFDLE9BQU87Z0JBQ3RCLElBQUksQ0FBQyxNQUFNLEdBQUcsRUFBRSxDQUFDO2dCQUNqQixJQUFJLENBQUMsUUFBUSxHQUFHLFdBQVcsQ0FBQztnQkFDNUIsTUFBTTtZQUNSLEtBQUssV0FBVyxDQUFDLGlCQUFpQjtnQkFDaEMsSUFBSSxDQUFDLE1BQU0sR0FBRyxFQUFFLENBQUM7Z0JBQ2pCLElBQUksQ0FBQyxRQUFRLEdBQUcsRUFBRSxDQUFDO2dCQUNuQixNQUFNO1lBQ1IsS0FBSyxXQUFXLENBQUMsR0FBRztnQkFDbEIsSUFBSSxDQUFDLE1BQU0sR0FBRyw4QkFBOEIsQ0FBQztnQkFDN0MsSUFBSSxDQUFDLFFBQVEsR0FBRyxXQUFXLENBQUM7Z0JBQzVCLE1BQU07WUFDUixLQUFLLFdBQVcsQ0FBQyxLQUFLO2dCQUNwQiwrRUFBK0U7Z0JBQy9FLE1BQU07WUFDUixLQUFLLFdBQVcsQ0FBQyxPQUFPO2dCQUN0QixnRUFBZ0U7Z0JBQ2hFLElBQUksQ0FBQyxNQUFNLEdBQUcsRUFBRSxDQUFDO2dCQUNqQixJQUFJLENBQUMsUUFBUSxHQUFHLEVBQUUsQ0FBQztnQkFDbkIsTUFBTTtZQUNSO2dCQUNFLE1BQU0sSUFBSSxLQUFLLENBQUMsNkJBQTZCLENBQUMsQ0FBQztTQUNsRDtJQUdILENBQUM7SUFFRCxjQUFjLENBQUMsS0FBb0I7UUFDakMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDOUIsQ0FBQzs7b0hBckVVLHNCQUFzQiw4Q0FXYixlQUFlO3dHQVh4QixzQkFBc0IsaUZBNUJ2Qjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0F1QlQ7NEZBS1Usc0JBQXNCO2tCQTlCbEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsb0JBQW9CO29CQUM5QixRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBdUJUO29CQUNELE1BQU0sRUFBRSxDQUFDOztHQUVSLENBQUM7aUJBQ0g7OzBCQVljLE1BQU07MkJBQUMsZUFBZSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TUFUX0RJQUxPR19EQVRBLCBNYXREaWFsb2dSZWZ9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XHJcbmltcG9ydCB7Q29tcG9uZW50LCBJbmplY3R9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge0Jhc2VHZW5lcmljQ29udGFpbmVyRGlhbG9nfSBmcm9tICcuLi9tb2RlbC9iYXNlLWdlbmVyaWMtY29udGFpbmVyLWRpYWxvZyc7XHJcbmltcG9ydCB7Q29uZmlybVR5cGV9IGZyb20gJy4uL21vZGVsL2NvbmZpcm0tdHlwZS5tb2RlbCc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2hjaS1jb25maXJtLWRpYWxvZycsXHJcbiAgdGVtcGxhdGU6IGBcclxuICAgIDxkaXYgY2xhc3M9XCJyaS1jb25maXJtLWJvZHlcIj5cclxuXHJcbiAgICAgIDxkaXYgKm5nSWY9XCJjb25maXJtVHlwZSAhPT0gQ29uZmlybVR5cGUuQUxFUlQ7IGVsc2UgYWxlcnRCbG9ja1wiPlxyXG4gICAgICAgIHt7cHJvbXB0fX1cclxuICAgICAgICA8ZGl2IGNsYXNzPVwicmktY29uZmlybS10ZXh0LWRlbGV0ZVwiPnt7IG1lc3NhZ2UxIH19PC9kaXY+XHJcbiAgICAgICAge3ttZXNzYWdlMn19XHJcbiAgICAgIDwvZGl2PlxyXG5cclxuXHJcbiAgICAgIDxkaXYgI2FsZXJ0QmxvY2s+XHJcbiAgICAgICAgPHA+V2UgYXJlIHdvcmtpbmcgdG8gY29ycmVjdCBpdC4gQ29udGFjdCBDT0RFIHN1cHBvcnQgaWYgdGhlIGVycm9yIHBlcnNpc3RzLjwvcD5cclxuICAgICAgICA8bWF0LWV4cGFuc2lvbi1wYW5lbD5cclxuICAgICAgICAgIDxtYXQtZXhwYW5zaW9uLXBhbmVsLWhlYWRlcj5cclxuICAgICAgICAgICAgPG1hdC1wYW5lbC10aXRsZT5cclxuICAgICAgICAgICAgICA8c3Ryb25nPlNob3cgZGV0YWlsczwvc3Ryb25nPlxyXG4gICAgICAgICAgICA8L21hdC1wYW5lbC10aXRsZT5cclxuICAgICAgICAgIDwvbWF0LWV4cGFuc2lvbi1wYW5lbC1oZWFkZXI+XHJcbiAgICAgICAgICA8ZGl2Pnt7IG1lc3NhZ2UxIH19PC9kaXY+XHJcbiAgICAgICAgPC9tYXQtZXhwYW5zaW9uLXBhbmVsPlxyXG4gICAgICA8L2Rpdj5cclxuXHJcbiAgICA8L2Rpdj5cclxuICBgLFxyXG4gIHN0eWxlczogW2BcclxuXHJcbiAgYF1cclxufSlcclxuZXhwb3J0IGNsYXNzIENvbmZpcm1EaWFsb2dDb21wb25lbnQgZXh0ZW5kcyBCYXNlR2VuZXJpY0NvbnRhaW5lckRpYWxvZyB7XHJcblxyXG4gIHB1YmxpYyBDb25maXJtVHlwZSA9IENvbmZpcm1UeXBlOyAvLyBtYWtlIGVudW0gYXZhaWxhYmxlIGluIHRlbXBsYXRlXHJcblxyXG4gIHByb21wdCA9ICcnO1xyXG4gIG1lc3NhZ2UxID0gJyc7XHJcbiAgbWVzc2FnZTIgPSAnJztcclxuXHJcbiAgY29uZmlybVR5cGU6IENvbmZpcm1UeXBlID0gQ29uZmlybVR5cGUuR0VORVJJQztcclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBkaWFsb2dSZWY6IE1hdERpYWxvZ1JlZjxDb25maXJtRGlhbG9nQ29tcG9uZW50PixcclxuICAgICAgICAgICAgICBASW5qZWN0KE1BVF9ESUFMT0dfREFUQSkgcHJpdmF0ZSBkYXRhOiBhbnkpIHtcclxuICAgIHN1cGVyKCk7XHJcblxyXG4gICAgY29uc3QgdGVtcCA9IGRhdGEuY29uZmlybVR5cGUgPyBkYXRhLmNvbmZpcm1UeXBlIDogQ29uZmlybVR5cGUuR0VORVJJQztcclxuICAgIGlmIChPYmplY3QudmFsdWVzKENvbmZpcm1UeXBlKS5pbmNsdWRlcyh0ZW1wIGFzIENvbmZpcm1UeXBlKSl7XHJcbiAgICAgIHRoaXMuY29uZmlybVR5cGUgPSB0ZW1wO1xyXG4gICAgfVxyXG5cclxuICAgIHRoaXMucHJvbXB0ID0gZGF0YS5wcm9tcHQgPyBkYXRhLnByb21wdCA6ICcnO1xyXG4gICAgdGhpcy5tZXNzYWdlMSA9IGRhdGEubWVzc2FnZTEgPyBkYXRhLm1lc3NhZ2UxIDogJyc7XHJcbiAgICB0aGlzLm1lc3NhZ2UyID0gZGF0YS5tZXNzYWdlMiA/IGRhdGEubWVzc2FnZTIgOiAnJztcclxuXHJcbiAgICB0aGlzLnNldHVwTWVzc2FnZXNCeVR5cGUoKTtcclxuICB9XHJcblxyXG4gIHNldHVwTWVzc2FnZXNCeVR5cGUoKXtcclxuXHJcbiAgICAvLyBieSBlbnVtIHR5cGUsIHNldHVwIHRoZSBtZXNzYWdlcy9wcm9tcHRcclxuICAgIHN3aXRjaCAodGhpcy5jb25maXJtVHlwZSkge1xyXG4gICAgICBjYXNlIENvbmZpcm1UeXBlLkRFTEVURTpcclxuICAgICAgICB0aGlzLnByb21wdCA9ICdUaGUgZm9sbG93aW5nIHdpbGwgYmUgZGVsZXRlZDonO1xyXG4gICAgICAgIHRoaXMubWVzc2FnZTIgPSAnQ29udGludWU/JztcclxuICAgICAgICBicmVhaztcclxuICAgICAgY2FzZSBDb25maXJtVHlwZS5ERUxFVEVfV19NRVNTQUdFOlxyXG4gICAgICAgIHRoaXMucHJvbXB0ID0gJ1RoZSBmb2xsb3dpbmcgd2lsbCBiZSBkZWxldGVkOic7XHJcbiAgICAgICAgYnJlYWs7XHJcbiAgICAgIGNhc2UgQ29uZmlybVR5cGUuREVMRVRFX1dfUFJPTVBUOlxyXG4gICAgICAgIC8vIG5vb3AsIHRha2UgYWxsIG9mIHdoYXQgd2FzIHBhc3NlZCBpblxyXG4gICAgICAgIGJyZWFrO1xyXG4gICAgICBjYXNlIENvbmZpcm1UeXBlLkRJU0NBUkQ6XHJcbiAgICAgICAgdGhpcy5wcm9tcHQgPSAnJztcclxuICAgICAgICB0aGlzLm1lc3NhZ2UyID0gJ0NvbnRpbnVlPyc7XHJcbiAgICAgICAgYnJlYWs7XHJcbiAgICAgIGNhc2UgQ29uZmlybVR5cGUuQ09ORklSTV9BTkRfQ0xPU0U6XHJcbiAgICAgICAgdGhpcy5wcm9tcHQgPSAnJztcclxuICAgICAgICB0aGlzLm1lc3NhZ2UyID0gJyc7XHJcbiAgICAgICAgYnJlYWs7XHJcbiAgICAgIGNhc2UgQ29uZmlybVR5cGUuQUREOlxyXG4gICAgICAgIHRoaXMucHJvbXB0ID0gJ1RoZSBmb2xsb3dpbmcgd2lsbCBiZSBhZGRlZDonO1xyXG4gICAgICAgIHRoaXMubWVzc2FnZTIgPSAnQ29udGludWU/JztcclxuICAgICAgICBicmVhaztcclxuICAgICAgY2FzZSBDb25maXJtVHlwZS5BTEVSVDpcclxuICAgICAgICAvLyBub29wLCB3aWxsIG9ubHkgdXNlIHRoZSBtZXNzYWdlMSBpbiBhIHNwZWNpYWwgdGVtcGxhdGUsIGFuZCBqdXN0IGlnbm9yZSByZXN0XHJcbiAgICAgICAgYnJlYWs7XHJcbiAgICAgIGNhc2UgQ29uZmlybVR5cGUuR0VORVJJQzpcclxuICAgICAgICAvLyBUT0RPOiBlaXRoZXIgb25seSB1c2UgbWVzc2FnZSAxIG9yIGp1c3QgdGFrZSBhbGwgcGFzc2VkIGluLi4uXHJcbiAgICAgICAgdGhpcy5wcm9tcHQgPSAnJztcclxuICAgICAgICB0aGlzLm1lc3NhZ2UyID0gJyc7XHJcbiAgICAgICAgYnJlYWs7XHJcbiAgICAgIGRlZmF1bHQ6XHJcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdDb25maXJtIHR5cGUgZG9lc25cXCd0IGV4aXN0Jyk7XHJcbiAgICB9XHJcblxyXG5cclxuICB9XHJcblxyXG4gIG9uQ29uZmlybUNsaWNrKHZhbHVlOiBib29sZWFuIHwgYW55KXtcclxuICAgIHRoaXMuZGlhbG9nUmVmLmNsb3NlKHZhbHVlKTtcclxuICB9XHJcbn1cclxuIl19