@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.
- package/CHANGELOG.md +4 -0
- package/README.md +24 -0
- package/alert/alert-dialog.component.d.ts +31 -0
- package/bundles/huntsman-cancer-institute-dialog.umd.js +1049 -0
- package/bundles/huntsman-cancer-institute-dialog.umd.js.map +1 -0
- package/bundles/huntsman-cancer-institute-dialog.umd.min.js +2 -0
- package/bundles/huntsman-cancer-institute-dialog.umd.min.js.map +1 -0
- package/confirm/confirm-dialog.component.d.ts +18 -0
- package/custom/custom-dialog.component.d.ts +35 -0
- package/dialog.module.d.ts +27 -0
- package/esm2015/alert/alert-dialog.component.js +243 -0
- package/esm2015/confirm/confirm-dialog.component.js +130 -0
- package/esm2015/custom/custom-dialog.component.js +231 -0
- package/esm2015/dialog.module.js +157 -0
- package/esm2015/generic/generic-container-dialog.component.js +158 -0
- package/esm2015/huntsman-cancer-institute-dialog.js +5 -0
- package/esm2015/index.js +13 -0
- package/esm2015/model/base-generic-container-dialog.js +26 -0
- package/esm2015/model/confirm-type.model.js +12 -0
- package/esm2015/model/dialog-type.model.js +12 -0
- package/esm2015/model/generic-dialog-action.model.js +6 -0
- package/esm2015/save-footer/save-footer.component.js +135 -0
- package/esm2015/service/dialog.service.js +272 -0
- package/esm2015/spinner/spinner-dialog.component.js +69 -0
- package/esm5/alert/alert-dialog.component.js +105 -0
- package/esm5/confirm/confirm-dialog.component.js +101 -0
- package/esm5/custom/custom-dialog.component.js +118 -0
- package/esm5/dialog.module.js +161 -0
- package/esm5/generic/generic-container-dialog.component.js +128 -0
- package/esm5/huntsman-cancer-institute-dialog.js +5 -0
- package/esm5/index.js +13 -0
- package/esm5/model/base-generic-container-dialog.js +28 -0
- package/esm5/model/confirm-type.model.js +12 -0
- package/esm5/model/dialog-type.model.js +12 -0
- package/esm5/model/generic-dialog-action.model.js +6 -0
- package/esm5/save-footer/save-footer.component.js +86 -0
- package/esm5/service/dialog.service.js +307 -0
- package/esm5/spinner/spinner-dialog.component.js +47 -0
- package/fesm2015/huntsman-cancer-institute-dialog.js +1396 -0
- package/fesm2015/huntsman-cancer-institute-dialog.js.map +1 -0
- package/fesm5/huntsman-cancer-institute-dialog.js +1047 -0
- package/fesm5/huntsman-cancer-institute-dialog.js.map +1 -0
- package/generic/generic-container-dialog.component.d.ts +38 -0
- package/huntsman-cancer-institute-dialog.d.ts +5 -0
- package/index.d.ts +14 -0
- package/model/base-generic-container-dialog.d.ts +13 -0
- package/model/confirm-type.model.d.ts +10 -0
- package/model/dialog-type.model.d.ts +10 -0
- package/model/generic-dialog-action.model.d.ts +18 -0
- package/package.json +34 -0
- package/save-footer/save-footer.component.d.ts +24 -0
- package/service/dialog.service.d.ts +45 -0
- 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":"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","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
|