form-dynamic-ajax 7.0.3 → 7.0.8
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/README.md +58 -61
- package/esm2022/form-dynamic-ajax.mjs +5 -0
- package/esm2022/lib/form-dynamic-angular.component.mjs +184 -0
- package/esm2022/lib/form-dynamic-angular.module.mjs +132 -0
- package/esm2022/public-api.mjs +6 -0
- package/fesm2022/form-dynamic-ajax.mjs +323 -0
- package/fesm2022/form-dynamic-ajax.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/form-dynamic-angular.component.d.ts +111 -0
- package/lib/form-dynamic-angular.module.d.ts +34 -0
- package/package.json +25 -14
- package/{src/public-api.ts → public-api.d.ts} +2 -6
- package/ng-package.json +0 -10
- package/src/lib/form-dynamic-angular.component.css +0 -132
- package/src/lib/form-dynamic-angular.component.html +0 -412
- package/src/lib/form-dynamic-angular.component.spec.ts +0 -23
- package/src/lib/form-dynamic-angular.component.ts +0 -288
- package/src/lib/form-dynamic-angular.module.ts +0 -73
- package/tsconfig.lib.json +0 -14
- package/tsconfig.lib.prod.json +0 -10
- package/tsconfig.spec.json +0 -14
|
@@ -0,0 +1,184 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@ngx-translate/core";
|
|
4
|
+
import * as i2 from "@angular/forms";
|
|
5
|
+
import * as i3 from "primeng/inputmask";
|
|
6
|
+
import * as i4 from "primeng/api";
|
|
7
|
+
import * as i5 from "primeng/inputnumber";
|
|
8
|
+
import * as i6 from "primeng/password";
|
|
9
|
+
import * as i7 from "primeng/button";
|
|
10
|
+
import * as i8 from "primeng/table";
|
|
11
|
+
import * as i9 from "primeng/multiselect";
|
|
12
|
+
import * as i10 from "@angular/common";
|
|
13
|
+
import * as i11 from "primeng/selectbutton";
|
|
14
|
+
import * as i12 from "primeng/inputswitch";
|
|
15
|
+
import * as i13 from "primeng/checkbox";
|
|
16
|
+
import * as i14 from "primeng/inputtextarea";
|
|
17
|
+
import * as i15 from "primeng/inputtext";
|
|
18
|
+
import * as i16 from "primeng/divider";
|
|
19
|
+
import * as i17 from "primeng/calendar";
|
|
20
|
+
import * as i18 from "primeng/dropdown";
|
|
21
|
+
import * as i19 from "primeng/treeselect";
|
|
22
|
+
import * as i20 from "primeng/radiobutton";
|
|
23
|
+
import * as i21 from "primeng/autocomplete";
|
|
24
|
+
import * as i22 from "primeng/overlaypanel";
|
|
25
|
+
import * as i23 from "primeng/editor";
|
|
26
|
+
export class FormDynamicAngularComponent {
|
|
27
|
+
constructor(translate, formBuilder) {
|
|
28
|
+
this.translate = translate;
|
|
29
|
+
this.formBuilder = formBuilder;
|
|
30
|
+
this.validateForm = false;
|
|
31
|
+
this.form = [];
|
|
32
|
+
this.files = [];
|
|
33
|
+
this.filesView = [];
|
|
34
|
+
this.filteredAutoComplete = [];
|
|
35
|
+
this.toBase64 = async (file) => {
|
|
36
|
+
return new Promise((resolve, _) => {
|
|
37
|
+
const reader = new FileReader();
|
|
38
|
+
reader.onloadend = () => resolve(reader.result);
|
|
39
|
+
reader.readAsDataURL(file);
|
|
40
|
+
});
|
|
41
|
+
};
|
|
42
|
+
this.control = this.formBuilder.group({});
|
|
43
|
+
}
|
|
44
|
+
ngOnInit() {
|
|
45
|
+
this.files.map(f => {
|
|
46
|
+
this.filesView.push({ ...f, type: f.contentType });
|
|
47
|
+
});
|
|
48
|
+
if (window.location.protocol === "https") {
|
|
49
|
+
navigator.mediaDevices.getUserMedia({ video: true })
|
|
50
|
+
.then(function (mediaStream) {
|
|
51
|
+
const video = document.querySelector('#video');
|
|
52
|
+
if (video) {
|
|
53
|
+
video.srcObject = mediaStream;
|
|
54
|
+
video.play();
|
|
55
|
+
}
|
|
56
|
+
})
|
|
57
|
+
.catch(function (err) { });
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
numberOfMonthsDate(numberOfMonthsDate) {
|
|
61
|
+
return numberOfMonthsDate ?? 1;
|
|
62
|
+
}
|
|
63
|
+
selectionMode(selectionMode) {
|
|
64
|
+
return selectionMode ?? "single";
|
|
65
|
+
}
|
|
66
|
+
async capturePhoto(fileName) {
|
|
67
|
+
const canvas = document.querySelector("#canvas");
|
|
68
|
+
const icon = document.querySelector("#icon-remove");
|
|
69
|
+
const video = document.querySelector('#video');
|
|
70
|
+
const button = document.querySelector('#button');
|
|
71
|
+
if (canvas && video) {
|
|
72
|
+
canvas.height = video.videoHeight;
|
|
73
|
+
canvas.width = video.videoWidth;
|
|
74
|
+
const context = canvas.getContext('2d');
|
|
75
|
+
if (context && icon && button) {
|
|
76
|
+
context.drawImage(video, 0, 0);
|
|
77
|
+
video.style.display = "none";
|
|
78
|
+
button.disabled = true;
|
|
79
|
+
canvas.style.display = "block";
|
|
80
|
+
icon.style.visibility = "visible";
|
|
81
|
+
let aux = {
|
|
82
|
+
name: "photo user",
|
|
83
|
+
contentType: "image/png",
|
|
84
|
+
content: canvas.toDataURL("image/png")
|
|
85
|
+
};
|
|
86
|
+
this.control.get(fileName)?.setValue(aux);
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
removePhoto() {
|
|
91
|
+
const canvas = document.querySelector("#canvas");
|
|
92
|
+
const icon = document.querySelector("#icon-remove");
|
|
93
|
+
const video = document.querySelector('#video');
|
|
94
|
+
const button = document.querySelector('#button');
|
|
95
|
+
if (canvas && video) {
|
|
96
|
+
const context = canvas.getContext('2d');
|
|
97
|
+
if (context && icon && button) {
|
|
98
|
+
video.style.display = "block";
|
|
99
|
+
button.disabled = false;
|
|
100
|
+
canvas.style.display = "none";
|
|
101
|
+
icon.style.visibility = "collapse";
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
getUrl(file) {
|
|
106
|
+
return window.URL.createObjectURL(file);
|
|
107
|
+
}
|
|
108
|
+
async onSelectFile(fileName, event, multiple) {
|
|
109
|
+
const file = event.target.files;
|
|
110
|
+
// if (!multiple) {
|
|
111
|
+
// this.filesView = [];
|
|
112
|
+
// }
|
|
113
|
+
this.filesView.push(...file);
|
|
114
|
+
const newFIles = file;
|
|
115
|
+
let arr = [];
|
|
116
|
+
for (const item of newFIles) {
|
|
117
|
+
let aux = {
|
|
118
|
+
name: item.name,
|
|
119
|
+
contentType: item?.type,
|
|
120
|
+
content: await this.toBase64(item)
|
|
121
|
+
};
|
|
122
|
+
arr.push(aux);
|
|
123
|
+
}
|
|
124
|
+
this.control.get(fileName)?.setValue(arr);
|
|
125
|
+
}
|
|
126
|
+
onRemove(event, fileName) {
|
|
127
|
+
this.filesView.splice(this.filesView.indexOf(event), 1);
|
|
128
|
+
var input = document.getElementById('fileInput');
|
|
129
|
+
if (input) {
|
|
130
|
+
input.value = '';
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
filterAutoComplete(event, suggestionsAutoComplete) {
|
|
134
|
+
let filtered = [];
|
|
135
|
+
let query = event.query;
|
|
136
|
+
if (suggestionsAutoComplete) {
|
|
137
|
+
for (let i = 0; i < suggestionsAutoComplete.length; i++) {
|
|
138
|
+
let dados = suggestionsAutoComplete[i];
|
|
139
|
+
if (dados.description.toLowerCase().normalize('NFD').replace(/\p{M}/ug, '').indexOf(query.toLowerCase().normalize('NFD').replace(/\p{M}/ug, '')) != -1) {
|
|
140
|
+
filtered.push(dados);
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
this.filteredAutoComplete = filtered;
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
onChange(change) {
|
|
147
|
+
if (change) {
|
|
148
|
+
change();
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
clickCLear(clear) {
|
|
152
|
+
if (clear) {
|
|
153
|
+
clear();
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
onBlur(blur) {
|
|
157
|
+
if (blur) {
|
|
158
|
+
blur();
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: FormDynamicAngularComponent, deps: [{ token: i1.TranslateService }, { token: i2.FormBuilder }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
162
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.0", type: FormDynamicAngularComponent, selector: "form-dynamic-angular", inputs: { title: "title", subTitle: "subTitle", validateForm: "validateForm", form: "form", control: "control", buttonsStandard: "buttonsStandard", buttonsOptional: "buttonsOptional", files: "files" }, ngImport: i0, template: "<div>\r\n <div *ngIf=\"title\" class=\"div-title\">\r\n <span translate=\"{{ title }}\"></span>\r\n <div *ngIf=\"subTitle\" class=\"flex subtitle\">\r\n <span translate=\"{{ subTitle }}\"></span>\r\n </div>\r\n <p-divider></p-divider>\r\n </div>\r\n <form *ngIf=\"control\" [formGroup]=\"control\">\r\n <div class=\"grid\">\r\n <div *ngFor=\"let item of form\" class=\"{{ item.col }} col-12\">\r\n <label *ngIf=\"item.label && !item.hideLabelTop\">{{ item.label }}</label>\r\n <label *ngIf=\"item.required && item.label\" class=\"danger-text ml-2\"\r\n >*</label\r\n >\r\n\r\n <div class=\"mt-2\">\r\n <!-- text -->\r\n <input\r\n id=\"{{ item.id }}\"\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n pInputText\r\n placeholder=\"{{ item.placeholder }}\"\r\n *ngIf=\"item.type == 'text' || item.type == 'number'\"\r\n type=\"{{ item.type }}\"\r\n formControlName=\"{{ item.formControl }}\"\r\n class=\"w-full\"\r\n />\r\n\r\n <p-editor\r\n *ngIf=\"item.type == 'editor'\"\r\n formControlName=\"{{ item.formControl }}\"\r\n [style]=\"{ height: '320px' }\"\r\n />\r\n\r\n <!-- select -->\r\n <p-dropdown\r\n id=\"{{ item.id }}\"\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n [filter]=\"item.search\"\r\n emptyFilterMessage=\"Nenhum dado encontrado\"\r\n emptyMessage=\"Nenhum dado encontrado\"\r\n placeholder=\"{{ item.placeholder }}\"\r\n styleClass=\"w-full p-0\"\r\n (onChange)=\"onChange(item.onChange)\"\r\n *ngIf=\"item.type === 'select'\"\r\n [showClear]=\"true\"\r\n [options]=\"item.options\"\r\n formControlName=\"{{ item.formControl }}\"\r\n optionLabel=\"description\"\r\n (onClear)=\"clickCLear(item.onCLear)\"\r\n ></p-dropdown>\r\n\r\n <!-- currency -->\r\n <p-inputNumber\r\n id=\"{{ item.id }}\"\r\n *ngIf=\"item.type === 'currency'\"\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n formControlName=\"{{ item.formControl }}\"\r\n placeholder=\"{{ item.placeholder }}\"\r\n inputStyleClass=\"w-full\"\r\n styleClass=\"w-full\"\r\n (onKeyDown)=\"onChange(item.onChange)\"\r\n mode=\"currency\"\r\n [min]=\"0\"\r\n currency=\"BRL\"\r\n >\r\n </p-inputNumber>\r\n\r\n <!-- mask -->\r\n <p-inputMask\r\n id=\"{{ item.id }}\"\r\n *ngIf=\"item.type === 'mask'\"\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n formControlName=\"{{ item.formControl }}\"\r\n placeholder=\"{{ item.placeholder }}\"\r\n styleClass=\"w-full\"\r\n (onComplete)=\"onChange(item.onChange)\"\r\n mask=\"{{ item.mask }}\"\r\n unmask=\"{{ item.unmask }}\"\r\n (onClear)=\"clickCLear(item.onCLear)\"\r\n showClear=\"true\"\r\n ></p-inputMask>\r\n\r\n <!-- treeSelect -->\r\n <p-treeSelect\r\n id=\"{{ item.id }}\"\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n placeholder=\"{{ item.placeholder }}\"\r\n (onNodeSelect)=\"onChange(item.onChange)\"\r\n *ngIf=\"item.type === 'tree-select'\"\r\n containerStyleClass=\"w-full p-0\"\r\n formControlName=\"{{ item.formControl }}\"\r\n [options]=\"item.treeSelectOptions\"\r\n [filter]=\"true\"\r\n [filterInputAutoFocus]=\"true\"\r\n emptyMessage=\"Nenhum dado encontrado\"\r\n [showClear]=\"true\"\r\n (onClear)=\"clickCLear(item.onCLear)\"\r\n ></p-treeSelect>\r\n\r\n <!-- autoComplete -->\r\n <p-autoComplete\r\n inputId=\"{{ item.id }}\"\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n placeholder=\"{{ item.placeholder }}\"\r\n styleClass=\"w-full p-0\"\r\n [inputStyle]=\"{ width: '100%' }\"\r\n *ngIf=\"item.type === 'autocomplete'\"\r\n (onSelect)=\"onChange(item.onChange)\"\r\n formControlName=\"{{ item.formControl }}\"\r\n [suggestions]=\"filteredAutoComplete\"\r\n (completeMethod)=\"filterAutoComplete($event, item.options)\"\r\n [forceSelection]=\"false\"\r\n [showEmptyMessage]=\"true\"\r\n emptyMessage=\"Nenhum dado encontrado\"\r\n dataKey=\"code\"\r\n field=\"description\"\r\n showClear=\"true\"\r\n (onClear)=\"clickCLear(item.onCLear)\"\r\n ></p-autoComplete>\r\n\r\n <!-- date -->\r\n <p-calendar\r\n id=\"{{ item.id }}\"\r\n view=\"{{ item.viewDate }}\"\r\n *ngIf=\"item.type === 'date'\"\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n formControlName=\"{{ item.formControl }}\"\r\n styleClass=\"w-full\"\r\n [numberOfMonths]=\"numberOfMonthsDate(item.numberOfMonthsDate)\"\r\n [selectionMode]=\"selectionMode(item.selectionMode)\"\r\n (onFocus)=\"onChange(item.onFocusDate)\"\r\n [maxDate]=\"item.maxDate\"\r\n [minDate]=\"item.minDate\"\r\n dateFormat=\"{{ item.dateFormat }}\"\r\n (onSelect)=\"onChange(item.onChange)\"\r\n [iconDisplay]=\"'input'\"\r\n placeholder=\"{{ item.placeholder }}\"\r\n [showIcon]=\"true\"\r\n [showTime]=\"item.showTime\"\r\n [timeOnly]=\"item.timeOnly\"\r\n ></p-calendar>\r\n\r\n <!-- textarea -->\r\n <div *ngIf=\"item.type === 'text-area'\" class=\"text-right\">\r\n <textarea\r\n id=\"{{ item.id }}\"\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n placeholder=\"{{ item.placeholder }}\"\r\n class=\"w-full\"\r\n maxlength=\"{{ item.maxlength }}\"\r\n counterTemplate=\"{1} of 50, {0} remaining\"\r\n counter=\"display\"\r\n (attr.change)=\"onChange(item.onChange)\"\r\n pInputTextarea\r\n formControlName=\"{{ item.formControl }}\"\r\n rows=\"{{ item.rowsTextArea }}\"\r\n ></textarea>\r\n <small *ngIf=\"item.maxlength\" id=\"username-help\">\r\n {{ control.controls[item.formControl].value.length }}/{{\r\n item.maxlength\r\n }}\r\n </small>\r\n </div>\r\n\r\n <!-- checkbox -->\r\n <div *ngIf=\"item.type == 'check-box'\">\r\n <p-checkbox\r\n id=\"{{ item.id }}\"\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n (onChange)=\"onChange(item.onChange)\"\r\n binary=\"true\"\r\n formControlName=\"{{ item.formControl }}\"\r\n value=\"{{ item.formControl }}\"\r\n label=\"{{ item.label }}\"\r\n ></p-checkbox>\r\n </div>\r\n\r\n <!-- checkbox multiple -->\r\n <div\r\n id=\"{{ item.id }}\"\r\n *ngIf=\"item.type === 'check-box-multi'\"\r\n class=\"flex gap-3\"\r\n >\r\n <div\r\n formArrayName=\"{{ item.formControl }}\"\r\n *ngFor=\"let list of item.options; let i = index\"\r\n class=\"flex align-items-center gap-2\"\r\n >\r\n <div [formGroupName]=\"i\">\r\n <p-checkbox\r\n id=\"{{ item.id }}\"\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n (onChange)=\"onChange(item.onChange)\"\r\n binary=\"true\"\r\n formControlName=\"{{ list.code }}\"\r\n label=\"{{ list.description }}\"\r\n ></p-checkbox>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- button -->\r\n <p-button\r\n id=\"{{ item.id }}\"\r\n *ngIf=\"item.type == 'button'\"\r\n styleClass=\"{{ item.buttonClass }} w-full mt-3\"\r\n (click)=\"item.onCLick()\"\r\n [disabled]=\"item.disabled\"\r\n icon=\"{{ item.iconButton }}\"\r\n label=\"{{ item.label }}\"\r\n ></p-button>\r\n\r\n <!-- can -->\r\n <div id=\"{{ item.id }}\" class=\"area\" *ngIf=\"item.type == 'can'\">\r\n <video autoplay=\"true\" id=\"webCamera\"></video>\r\n\r\n <input type=\"text\" id=\"base_img\" name=\"base_img\" />\r\n <button type=\"button\" onclick=\"takeSnapShot()\">\r\n Tirar foto e salvar\r\n </button>\r\n\r\n <img id=\"imagemConvertida\" />\r\n <p id=\"caminhoImagem\" class=\"caminho-imagem\">\r\n <a href=\"\" target=\"_blank\" rel=\"noopener\"></a>\r\n </p>\r\n <script src=\"script.js\"></script>\r\n </div>\r\n\r\n <!-- upload files -->\r\n <div\r\n id=\"{{ item.id }}\"\r\n *ngIf=\"item.type === 'upload-files' && !item.disabled\"\r\n class=\"drag-image\"\r\n [style.border]=\"\r\n validateForm && control.controls[item.formControl].errors\r\n ? ' 1px dashed #f18282'\r\n : ' 1px dashed #d1d5db'\r\n \"\r\n >\r\n <i *ngIf=\"filesView.length === 0\" class=\"pi pi-cloud-upload\"></i>\r\n <p *ngIf=\"filesView.length === 0\">\r\n Clique ou arraste e solte um arquivo para anexar\r\n </p>\r\n <span *ngIf=\"filesView.length === 0\">{{\r\n item.msgAcceptFiles\r\n }}</span>\r\n <input\r\n id=\"fileInput\"\r\n type=\"file\"\r\n [multiple]=\"item.multileFile\"\r\n [accept]=\"item.acceptFiles\"\r\n (change)=\"\r\n onSelectFile(item.formControl, $event, item.multileFile)\r\n \"\r\n />\r\n <div *ngFor=\"let f of filesView\">\r\n <div *ngIf=\"f.type && f.type.includes('image')\">\r\n <label class=\"preview-img\">\r\n <img *ngIf=\"!f.content\" src=\"{{ getUrl(f) }}\" />\r\n <img *ngIf=\"f.content\" src=\"{{ f.content }}\" />\r\n <span *ngIf=\"item.viewNameFile\">{{ f.name }}</span>\r\n <input\r\n type=\"file\"\r\n [multiple]=\"item.multileFile\"\r\n [accept]=\"item.acceptFiles\"\r\n (change)=\"\r\n onSelectFile(item.formControl, $event, item.multileFile)\r\n \"\r\n />\r\n <label>\r\n <i\r\n class=\"pi pi-times remove-file absolute\"\r\n (click)=\"onRemove(item.formControl, f)\"\r\n ></i\r\n ></label>\r\n </label>\r\n </div>\r\n <div *ngIf=\"f.type && !f.type.includes('image')\">\r\n <label class=\"preview-img h-0 max-w-0 mh-75 m-0\">\r\n <label class=\"mr-3\">{{ f.name }}</label>\r\n <input\r\n type=\"file\"\r\n [multiple]=\"item.multileFile\"\r\n [accept]=\"item.acceptFiles\"\r\n (change)=\"\r\n onSelectFile(item.formControl, $event, item.multileFile)\r\n \"\r\n />\r\n <label>\r\n <i\r\n class=\"pi pi-times remove-file absolute\"\r\n (click)=\"onRemove(f)\"\r\n ></i\r\n ></label>\r\n </label>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- upload files disabled -->\r\n <!-- <p-fileUpload mode=\"basic\" formControlName=\"{{item.formControl}}\" chooseLabel=\"Choose\"\r\n chooseIcon=\"pi pi-upload\" accept=\"image/*\" maxFileSize=\"1000000\" /> -->\r\n\r\n <div\r\n id=\"{{ item.id }}\"\r\n *ngIf=\"item.type === 'upload-files' && item.disabled\"\r\n >\r\n <p-button\r\n (click)=\"op.toggle($event)\"\r\n icon=\"pi pi-paperclip\"\r\n label=\"Arquivos anexados\"\r\n ></p-button>\r\n\r\n <p-overlayPanel\r\n #op\r\n [style]=\"{ width: '450px' }\"\r\n [showCloseIcon]=\"true\"\r\n >\r\n <ng-template pTemplate=\"content\">\r\n <p-table\r\n *ngIf=\"files.length > 0\"\r\n [value]=\"files\"\r\n selectionMode=\"single\"\r\n [(selection)]=\"selectedProduct\"\r\n (onRowSelect)=\"onRowSelect($event, op)\"\r\n responsiveLayout=\"scroll\"\r\n >\r\n <ng-template pTemplate=\"header\">\r\n <tr>\r\n <th pSortableColumn=\"name\">\r\n Nome<p-sortIcon field=\"name\"></p-sortIcon>\r\n </th>\r\n <th></th>\r\n </tr>\r\n </ng-template>\r\n <ng-template pTemplate=\"body\" let-rowData let-file>\r\n <tr>\r\n <td *ngIf=\"item.viewNameFile\">{{ file.name }}</td>\r\n <td>\r\n <p-button\r\n *ngIf=\"item.onCLick\"\r\n icon=\"pi pi-download\"\r\n (click)=\"item.onCLick(file)\"\r\n ></p-button>\r\n </td>\r\n </tr>\r\n </ng-template>\r\n </p-table>\r\n <div *ngIf=\"files.length === 0\" class=\"p-10\">\r\n <label>Nenhum arquivo anexado</label>\r\n </div>\r\n </ng-template>\r\n </p-overlayPanel>\r\n </div>\r\n\r\n <!-- list -->\r\n <ul id=\"{{ item.id }}\" *ngIf=\"item.type === 'list' && item.options\">\r\n <li *ngFor=\"let list of item.options\">{{ list.description }}</li>\r\n </ul>\r\n\r\n <!-- multi -->\r\n <p-multiSelect\r\n id=\"{{ item.id }}\"\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n placeholder=\"{{ item.placeholder }}\"\r\n *ngIf=\"item.type === 'multi'\"\r\n [options]=\"item.options\"\r\n formControlName=\"{{ item.formControl }}\"\r\n styleClass=\"p-0 w-full\"\r\n optionLabel=\"description\"\r\n (onChange)=\"onChange(item.onChange)\"\r\n maxSelectedLabels=\"100\"\r\n ></p-multiSelect>\r\n\r\n <!-- radioButton -->\r\n <div\r\n id=\"{{ item.id }}\"\r\n *ngIf=\"item.type === 'radio-button'\"\r\n class=\"flex gap-3\"\r\n >\r\n <div\r\n *ngFor=\"let listRadioButton of item.options\"\r\n class=\"flex align-items-center gap-2\"\r\n >\r\n <p-radioButton\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n [value]=\"listRadioButton.code\"\r\n formControlName=\"{{ item.formControl }}\"\r\n (onClick)=\"onChange(item.onChange)\"\r\n ></p-radioButton>\r\n <label>{{ listRadioButton.description }}</label>\r\n </div>\r\n @if(control.controls[item.formControl].value == 'other'){\r\n <input\r\n pInputText\r\n type=\"text\"\r\n formControlName=\"{{ item.formControlOther }}\"\r\n />\r\n }\r\n </div>\r\n\r\n <!-- selectButton -->\r\n <div class=\"d-flex\" *ngIf=\"item.type === 'select-button'\">\r\n <p-selectButton\r\n id=\"{{ item.id }}\"\r\n (onChange)=\"onChange(item.onChange)\"\r\n [options]=\"item.options\"\r\n formControlName=\"{{ item.formControl }}\"\r\n optionValue=\"code\"\r\n >\r\n <ng-template let-item>\r\n <span>{{ item.description }}</span>\r\n </ng-template>\r\n </p-selectButton>\r\n <!-- <input type=\"text\" pInputText [attr.disabled]=\"item.disabled\"\r\n formControlName={{item.formControlSecondary}}> -->\r\n </div>\r\n\r\n <!-- table -->\r\n <p-table\r\n id=\"{{ item.id }}\"\r\n *ngIf=\"item.type === 'table'\"\r\n [scrollable]=\"true\"\r\n scrollHeight=\"{{ item.scrollHeight }}\"\r\n [columns]=\"item.colsTable\"\r\n styleClass=\"p-datatable-striped p-datatable-sm\"\r\n [value]=\"item.rowsTable\"\r\n >\r\n <ng-template pTemplate=\"header\" let-columns>\r\n <tr>\r\n <th *ngFor=\"let col of columns\">\r\n <span *ngIf=\"col.filed !== 'action'\">{{ col.header }}</span>\r\n <span *ngIf=\"col.filed === 'action'\">A\u00E7\u00E3o</span>\r\n </th>\r\n </tr>\r\n </ng-template>\r\n <ng-template pTemplate=\"body\" let-rowData let-columns=\"columns\">\r\n <tr>\r\n <td *ngFor=\"let col of columns\">\r\n <div *ngIf=\"col.field !== 'button'\">\r\n {{ rowData[col.field] }}\r\n </div>\r\n <div *ngIf=\"col.field === 'action'\">\r\n <p-button\r\n *ngFor=\"let action of item.buttonsTable\"\r\n styleClass=\"{{ action.styleClass }}\"\r\n label=\"{{ action.label }}\"\r\n (click)=\"action.onCLick(rowData)\"\r\n icon=\"{{ action.icon }}\"\r\n ></p-button>\r\n </div>\r\n </td>\r\n </tr>\r\n </ng-template>\r\n <ng-template pTemplate=\"footer\" let-columns>\r\n <tr *ngFor=\"let footer of item.rowsFooter\">\r\n <td colspan=\"12\">\r\n <span class=\"font-normal\">{{ footer.text }}:</span>\r\n {{ footer.value }}\r\n </td>\r\n </tr>\r\n </ng-template>\r\n </p-table>\r\n\r\n <!-- inputSwitch -->\r\n <div class=\"d-flex\" *ngIf=\"item.type === 'switch'\">\r\n <p-inputSwitch\r\n id=\"{{ item.id }}\"\r\n formControlName=\"{{ item.formControl }}\"\r\n class=\"mr-10\"\r\n (onChange)=\"onChange(item.onChange)\"\r\n ></p-inputSwitch>\r\n <p translate=\"{{ item.label }}\"></p>\r\n </div>\r\n\r\n <!-- password -->\r\n <p-password\r\n id=\"{{ item.id }}\"\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n placeholder=\"{{ item.placeholder }}\"\r\n *ngIf=\"item.type === 'password'\"\r\n [feedback]=\"false\"\r\n formControlName=\"{{ item.formControl }}\"\r\n (onChange)=\"onChange(item.onChange)\"\r\n styleClass=\"w-full\"\r\n [toggleMask]=\"true\"\r\n ></p-password>\r\n\r\n <!-- photo -->\r\n <div id=\"{{ item.id }}\" class=\"camera\" *ngIf=\"item.type === 'photo'\">\r\n <video id=\"video\" class=\"foto\" autoplay>\r\n V\u00EDdeo n\u00E3o dispon\u00EDvel.\r\n </video>\r\n <canvas id=\"canvas\" class=\"foto\" style=\"display: none\"></canvas>\r\n <button\r\n pButton\r\n icon=\"pi pi-times\"\r\n class=\"remove-file\"\r\n id=\"icon-remove\"\r\n [rounded]=\"true\"\r\n style=\"visibility: collapse\"\r\n (click)=\"removePhoto()\"\r\n ></button>\r\n <button\r\n pButton\r\n icon=\"pi pi-camera\"\r\n [rounded]=\"true\"\r\n (click)=\"capturePhoto(item.formControl)\"\r\n id=\"button\"\r\n ></button>\r\n </div>\r\n\r\n <!-- likert -->\r\n <p-table\r\n id=\"{{ item.id }}\"\r\n *ngIf=\"item.type === 'likert'\"\r\n [scrollable]=\"true\"\r\n scrollHeight=\"{{ item.scrollHeight }}\"\r\n [columns]=\"item.colsTable\"\r\n styleClass=\"p-datatable-striped p-datatable-sm\"\r\n [value]=\"item.rowsTable\"\r\n >\r\n <ng-template pTemplate=\"header\" let-columns>\r\n <tr>\r\n <th style=\"width: 4rem\"></th>\r\n <th *ngFor=\"let col of columns\">\r\n <span>{{ col.header }}</span>\r\n </th>\r\n </tr>\r\n </ng-template>\r\n <ng-template\r\n pTemplate=\"body\"\r\n let-row\r\n let-rowIndex=\"rowIndex\"\r\n let-columns=\"columns\"\r\n formArrayName=\"{{ item.formControl }}\"\r\n >\r\n <tr>\r\n <td>\r\n {{ row }}\r\n </td>\r\n @for (control of columns; track item; let index = $index) {\r\n <td [formGroupName]=\"rowIndex\">\r\n <p-radioButton\r\n value=\"{{ columns[index].field }}+{{ row }}\"\r\n formControlName=\"question{{ rowIndex }}\"\r\n />\r\n </td>\r\n }\r\n </tr>\r\n </ng-template>\r\n </p-table>\r\n\r\n <!-- editable table -->\r\n <p-table\r\n id=\"{{ item.id }}\"\r\n *ngIf=\"item.type === 'editable-table'\"\r\n [scrollable]=\"true\"\r\n scrollHeight=\"{{ item.scrollHeight }}\"\r\n [columns]=\"item.colsTable\"\r\n styleClass=\"p-datatable-striped p-datatable-sm\"\r\n [value]=\"item.rowsTable\"\r\n editMode=\"cell\"\r\n >\r\n <!-- Cabe\u00E7alho da tabela -->\r\n <ng-template pTemplate=\"header\" let-columns>\r\n <tr>\r\n <th style=\"width: 4rem\"></th>\r\n <th *ngFor=\"let col of columns\">\r\n <span>{{ col.header }}</span>\r\n </th>\r\n </tr>\r\n </ng-template>\r\n\r\n <!-- Corpo da tabela -->\r\n <ng-template\r\n pTemplate=\"body\"\r\n let-row\r\n let-rowIndex=\"rowIndex\"\r\n let-columns=\"columns\"\r\n formArrayName=\"{{ item.formControl }}\"\r\n let-editing=\"editing\"\r\n >\r\n <tr>\r\n <td>{{ row }}</td>\r\n @for (control of columns; track item; let index = $index) {\r\n <td\r\n [formGroupName]=\"rowIndex\"\r\n [pEditableColumn]=\"row\"\r\n pEditableColumnField=\"row\"\r\n >\r\n <p-cellEditor>\r\n <ng-template pTemplate=\"input\">\r\n <input\r\n pInputText\r\n type=\"text\"\r\n formControlName=\"_{{ control.field }}question{{\r\n rowIndex\r\n }}\"\r\n />\r\n </ng-template>\r\n <ng-template pTemplate=\"output\">\r\n <input\r\n pInputText\r\n type=\"text\"\r\n formControlName=\"_{{ control.field }}question{{\r\n rowIndex\r\n }}\"\r\n />\r\n </ng-template>\r\n </p-cellEditor>\r\n </td>\r\n }\r\n </tr>\r\n </ng-template>\r\n </p-table>\r\n\r\n <!-- valida\u00E7\u00E3o de item -->\r\n <div>\r\n <small\r\n class=\"danger-text\"\r\n *ngIf=\"validateForm && control.controls[item.formControl] && control.controls[item.formControl].errors?.['required']\"\r\n >\r\n Campo obrigat\u00F3rio\r\n </small>\r\n <small\r\n class=\"danger-text\"\r\n *ngIf=\"validateForm && control.controls[item.formControl] && control.controls[item.formControl].errors?.['email']\"\r\n >\r\n Email inv\u00E1lido\r\n </small>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <p-divider\r\n *ngIf=\"\r\n (buttonsStandard && buttonsStandard.length > 0) ||\r\n (buttonsOptional && buttonsOptional.length > 0)\r\n \"\r\n ></p-divider>\r\n\r\n <div class=\"buttons-form\">\r\n <div *ngFor=\"let button of buttonsStandard\">\r\n <p-button\r\n *ngIf=\"button.type === 'clean'\"\r\n styleClass=\"p-button-warning {{ button.styleClass }}\"\r\n label=\"Limpar\"\r\n (click)=\"button.onCLick()\"\r\n icon=\"pi pi-times\"\r\n ></p-button>\r\n <p-button\r\n *ngIf=\"button.type === 'filter'\"\r\n styleClass=\"{{ button.styleClass }}\"\r\n label=\"Filtrar\"\r\n (click)=\"button.onCLick()\"\r\n icon=\"pi pi-search\"\r\n ></p-button>\r\n <p-button\r\n *ngIf=\"button.type === 'save'\"\r\n styleClass=\"p-button-success {{ button.styleClass }}\"\r\n label=\"Salvar\"\r\n (click)=\"button.onCLick()\"\r\n icon=\"pi pi-save\"\r\n ></p-button>\r\n <p-button\r\n *ngIf=\"button.type === 'cancel'\"\r\n styleClass=\"p-button-danger {{ button.styleClass }}\"\r\n label=\"Cancelar\"\r\n (click)=\"button.onCLick()\"\r\n icon=\"pi pi-times\"\r\n ></p-button>\r\n </div>\r\n <div *ngFor=\"let button of buttonsOptional\">\r\n <p-button\r\n styleClass=\"{{ button.styleClass }}\"\r\n label=\"{{ button.label }}\"\r\n (click)=\"button.onCLick()\"\r\n icon=\"{{ button.icon }}\"\r\n ></p-button>\r\n </div>\r\n </div>\r\n </div>\r\n </form>\r\n</div>\r\n", styles: [".div-title span{font-size:20px;font-weight:500}.buttons-form{display:flex;gap:10px;justify-content:flex-end}.danger-text{color:#f18282}.drag-image{height:auto;width:100%;border-radius:10px;font-weight:400;display:flex;align-items:center;flex-direction:column;top:20px;max-height:250px;color:#000;padding:20px;text-align:center;overflow:auto}.drag-image h6{font-size:20px}.drag-image .file-name{font-size:14px}.drag-image i{font-size:3rem}.subtitle span{font-size:14px;margin-right:5px}.subtitle{align-items:baseline}.mh-75{min-height:75px!important}input[type=file]{position:absolute;width:100%;height:100%;inset:0;opacity:0;cursor:pointer}.preview-img{align-items:center;border-radius:5px;display:flex;height:140px;justify-content:center;margin:10px;max-width:180px;min-height:140px;min-width:180px;padding:0 20px;position:relative}.preview-img span{position:absolute;overflow-wrap:break-word}.remove-file{display:flex;justify-content:center;align-items:center;height:22px;width:22px;top:5px;right:5px;border-radius:50%;background:#bbb;color:#333;cursor:pointer;font-size:.8rem!important}.preview-img img{max-width:100%;opacity:.8}.camera{display:flex;flex-direction:column;align-items:center;position:relative}.foto{max-width:186px;min-height:140px;min-width:180px;border:1px dashed #000;border-radius:5px;margin-bottom:1em}.preview-photo{position:relative}.h-0{height:0}\n"], dependencies: [{ kind: "component", type: i3.InputMask, selector: "p-inputMask", inputs: ["type", "slotChar", "autoClear", "showClear", "style", "inputId", "styleClass", "placeholder", "size", "maxlength", "tabindex", "title", "ariaLabel", "ariaLabelledBy", "ariaRequired", "disabled", "readonly", "unmask", "name", "required", "characterPattern", "autoFocus", "autocomplete", "keepBuffer", "mask"], outputs: ["onComplete", "onFocus", "onBlur", "onInput", "onKeydown", "onClear"] }, { kind: "directive", type: i4.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "component", type: i5.InputNumber, selector: "p-inputNumber", inputs: ["showButtons", "format", "buttonLayout", "inputId", "styleClass", "style", "placeholder", "size", "maxlength", "tabindex", "title", "ariaLabelledBy", "ariaLabel", "ariaRequired", "name", "required", "autocomplete", "min", "max", "incrementButtonClass", "decrementButtonClass", "incrementButtonIcon", "decrementButtonIcon", "readonly", "step", "allowEmpty", "locale", "localeMatcher", "mode", "currency", "currencyDisplay", "useGrouping", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "inputStyle", "inputStyleClass", "showClear", "disabled"], outputs: ["onInput", "onFocus", "onBlur", "onKeyDown", "onClear"] }, { kind: "component", type: i6.Password, selector: "p-password", inputs: ["ariaLabel", "ariaLabelledBy", "label", "disabled", "promptLabel", "mediumRegex", "strongRegex", "weakLabel", "mediumLabel", "maxLength", "strongLabel", "inputId", "feedback", "appendTo", "toggleMask", "inputStyleClass", "styleClass", "style", "inputStyle", "showTransitionOptions", "hideTransitionOptions", "autocomplete", "placeholder", "showClear"], outputs: ["onFocus", "onBlur", "onClear"] }, { kind: "directive", type: i7.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "component", type: i7.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "size", "style", "styleClass", "badgeClass", "ariaLabel"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "component", type: i8.Table, selector: "p-table", inputs: ["frozenColumns", "frozenValue", "style", "styleClass", "tableStyle", "tableStyleClass", "paginator", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "paginatorStyleClass", "paginatorDropdownAppendTo", "paginatorDropdownScrollHeight", "currentPageReportTemplate", "showCurrentPageReport", "showJumpToPageDropdown", "showJumpToPageInput", "showFirstLastIcon", "showPageLinks", "defaultSortOrder", "sortMode", "resetPageOnSort", "selectionMode", "selectionPageOnly", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "rowSelectable", "rowTrackBy", "lazy", "lazyLoadOnInit", "compareSelectionBy", "csvSeparator", "exportFilename", "filters", "globalFilterFields", "filterDelay", "filterLocale", "expandedRowKeys", "editingRowKeys", "rowExpandMode", "scrollable", "scrollDirection", "rowGroupMode", "scrollHeight", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "virtualScrollDelay", "frozenWidth", "responsive", "contextMenu", "resizableColumns", "columnResizeMode", "reorderableColumns", "loading", "loadingIcon", "showLoader", "rowHover", "customSort", "showInitialSortBadge", "autoLayout", "exportFunction", "exportHeader", "stateKey", "stateStorage", "editMode", "groupRowsBy", "groupRowsByOrder", "responsiveLayout", "breakpoint", "paginatorLocale", "value", "columns", "first", "rows", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "selectAll", "virtualRowHeight"], outputs: ["contextMenuSelectionChange", "selectAllChange", "selectionChange", "onRowSelect", "onRowUnselect", "onPage", "onSort", "onFilter", "onLazyLoad", "onRowExpand", "onRowCollapse", "onContextMenuSelect", "onColResize", "onColReorder", "onRowReorder", "onEditInit", "onEditComplete", "onEditCancel", "onHeaderCheckboxToggle", "sortFunction", "firstChange", "rowsChange", "onStateSave", "onStateRestore"] }, { kind: "directive", type: i8.SortableColumn, selector: "[pSortableColumn]", inputs: ["pSortableColumn", "pSortableColumnDisabled"] }, { kind: "directive", type: i8.EditableColumn, selector: "[pEditableColumn]", inputs: ["pEditableColumn", "pEditableColumnField", "pEditableColumnRowIndex", "pEditableColumnDisabled", "pFocusCellSelector"] }, { kind: "component", type: i8.CellEditor, selector: "p-cellEditor" }, { kind: "component", type: i8.SortIcon, selector: "p-sortIcon", inputs: ["field"] }, { kind: "component", type: i9.MultiSelect, selector: "p-multiSelect", inputs: ["id", "ariaLabel", "style", "styleClass", "panelStyle", "panelStyleClass", "inputId", "disabled", "readonly", "group", "filter", "filterPlaceHolder", "filterLocale", "overlayVisible", "tabindex", "appendTo", "dataKey", "name", "ariaLabelledBy", "displaySelectedLabel", "maxSelectedLabels", "selectionLimit", "selectedItemsLabel", "showToggleAll", "emptyFilterMessage", "emptyMessage", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "showHeader", "filterBy", "scrollHeight", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "display", "autocomplete", "showClear", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "defaultLabel", "placeholder", "options", "filterValue", "itemSize", "selectAll", "focusOnHover", "filterFields", "selectOnFocus", "autoOptionFocus"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onClear", "onPanelShow", "onPanelHide", "onLazyLoad", "onRemove", "onSelectAllChange"] }, { kind: "directive", type: i10.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i10.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i11.SelectButton, selector: "p-selectButton", inputs: ["options", "optionLabel", "optionValue", "optionDisabled", "unselectable", "tabindex", "multiple", "allowEmpty", "style", "styleClass", "ariaLabelledBy", "disabled", "dataKey"], outputs: ["onOptionClick", "onChange"] }, { kind: "component", type: i12.InputSwitch, selector: "p-inputSwitch", inputs: ["style", "styleClass", "tabindex", "inputId", "name", "disabled", "readonly", "trueValue", "falseValue", "ariaLabel", "ariaLabelledBy"], outputs: ["onChange"] }, { kind: "component", type: i13.Checkbox, selector: "p-checkbox", inputs: ["value", "name", "disabled", "binary", "label", "ariaLabelledBy", "ariaLabel", "tabindex", "inputId", "style", "styleClass", "labelStyleClass", "formControl", "checkboxIcon", "readonly", "required", "trueValue", "falseValue"], outputs: ["onChange", "onFocus", "onBlur"] }, { kind: "directive", type: i14.InputTextarea, selector: "[pInputTextarea]", inputs: ["autoResize"], outputs: ["onResize"] }, { kind: "directive", type: i15.InputText, selector: "[pInputText]" }, { kind: "component", type: i16.Divider, selector: "p-divider", inputs: ["style", "styleClass", "layout", "type", "align"] }, { kind: "component", type: i17.Calendar, selector: "p-calendar", inputs: ["iconDisplay", "style", "styleClass", "inputStyle", "inputId", "name", "inputStyleClass", "placeholder", "ariaLabelledBy", "ariaLabel", "iconAriaLabel", "disabled", "dateFormat", "multipleSeparator", "rangeSeparator", "inline", "showOtherMonths", "selectOtherMonths", "showIcon", "icon", "appendTo", "readonlyInput", "shortYearCutoff", "monthNavigator", "yearNavigator", "hourFormat", "timeOnly", "stepHour", "stepMinute", "stepSecond", "showSeconds", "required", "showOnFocus", "showWeek", "showClear", "dataType", "selectionMode", "maxDateCount", "showButtonBar", "todayButtonStyleClass", "clearButtonStyleClass", "autoZIndex", "baseZIndex", "panelStyleClass", "panelStyle", "keepInvalid", "hideOnDateTimeSelect", "touchUI", "timeSeparator", "focusTrap", "showTransitionOptions", "hideTransitionOptions", "tabindex", "minDate", "maxDate", "disabledDates", "disabledDays", "yearRange", "showTime", "responsiveOptions", "numberOfMonths", "firstDayOfWeek", "locale", "view", "defaultDate"], outputs: ["onFocus", "onBlur", "onClose", "onSelect", "onClear", "onInput", "onTodayClick", "onClearClick", "onMonthChange", "onYearChange", "onClickOutside", "onShow"] }, { kind: "component", type: i18.Dropdown, selector: "p-dropdown", inputs: ["id", "scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "filterPlaceholder", "filterLocale", "inputId", "dataKey", "filterBy", "filterFields", "autofocus", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "ariaLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "focusOnHover", "selectOnFocus", "autoOptionFocus", "autofocusFilter", "disabled", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "filterValue", "options"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear", "onLazyLoad"] }, { kind: "component", type: i19.TreeSelect, selector: "p-treeSelect", inputs: ["inputId", "scrollHeight", "disabled", "metaKeySelection", "display", "selectionMode", "tabindex", "ariaLabel", "ariaLabelledBy", "placeholder", "panelClass", "panelStyle", "panelStyleClass", "containerStyle", "containerStyleClass", "labelStyle", "labelStyleClass", "overlayOptions", "emptyMessage", "appendTo", "filter", "filterBy", "filterMode", "filterPlaceholder", "filterLocale", "filterInputAutoFocus", "propagateSelectionDown", "propagateSelectionUp", "showClear", "resetFilterOnHide", "options", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onNodeExpand", "onNodeCollapse", "onShow", "onHide", "onClear", "onFilter", "onNodeUnselect", "onNodeSelect"] }, { kind: "component", type: i20.RadioButton, selector: "p-radioButton", inputs: ["value", "formControlName", "name", "disabled", "label", "tabindex", "inputId", "ariaLabelledBy", "ariaLabel", "style", "styleClass", "labelStyleClass"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "component", type: i21.AutoComplete, selector: "p-autoComplete", inputs: ["minLength", "delay", "style", "panelStyle", "styleClass", "panelStyleClass", "inputStyle", "inputId", "inputStyleClass", "placeholder", "readonly", "disabled", "scrollHeight", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "maxlength", "name", "required", "size", "appendTo", "autoHighlight", "forceSelection", "type", "autoZIndex", "baseZIndex", "ariaLabel", "dropdownAriaLabel", "ariaLabelledBy", "dropdownIcon", "unique", "group", "completeOnFocus", "showClear", "field", "dropdown", "showEmptyMessage", "dropdownMode", "multiple", "tabindex", "dataKey", "emptyMessage", "showTransitionOptions", "hideTransitionOptions", "autofocus", "autocomplete", "optionGroupChildren", "optionGroupLabel", "overlayOptions", "suggestions", "itemSize", "optionLabel", "id", "searchMessage", "emptySelectionMessage", "selectionMessage", "autoOptionFocus", "selectOnFocus", "searchLocale", "optionDisabled", "focusOnHover"], outputs: ["completeMethod", "onSelect", "onUnselect", "onFocus", "onBlur", "onDropdownClick", "onClear", "onKeyUp", "onShow", "onHide", "onLazyLoad"] }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i2.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "directive", type: i2.FormArrayName, selector: "[formArrayName]", inputs: ["formArrayName"] }, { kind: "component", type: i22.OverlayPanel, selector: "p-overlayPanel", inputs: ["ariaLabel", "ariaLabelledBy", "dismissable", "showCloseIcon", "style", "styleClass", "appendTo", "autoZIndex", "ariaCloseLabel", "baseZIndex", "focusOnShow", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onShow", "onHide"] }, { kind: "component", type: i23.Editor, selector: "p-editor", inputs: ["style", "styleClass", "placeholder", "formats", "modules", "bounds", "scrollingContainer", "debug", "readonly"], outputs: ["onInit", "onTextChange", "onSelectionChange"] }, { kind: "directive", type: i1.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
163
|
+
}
|
|
164
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: FormDynamicAngularComponent, decorators: [{
|
|
165
|
+
type: Component,
|
|
166
|
+
args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'form-dynamic-angular', template: "<div>\r\n <div *ngIf=\"title\" class=\"div-title\">\r\n <span translate=\"{{ title }}\"></span>\r\n <div *ngIf=\"subTitle\" class=\"flex subtitle\">\r\n <span translate=\"{{ subTitle }}\"></span>\r\n </div>\r\n <p-divider></p-divider>\r\n </div>\r\n <form *ngIf=\"control\" [formGroup]=\"control\">\r\n <div class=\"grid\">\r\n <div *ngFor=\"let item of form\" class=\"{{ item.col }} col-12\">\r\n <label *ngIf=\"item.label && !item.hideLabelTop\">{{ item.label }}</label>\r\n <label *ngIf=\"item.required && item.label\" class=\"danger-text ml-2\"\r\n >*</label\r\n >\r\n\r\n <div class=\"mt-2\">\r\n <!-- text -->\r\n <input\r\n id=\"{{ item.id }}\"\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n pInputText\r\n placeholder=\"{{ item.placeholder }}\"\r\n *ngIf=\"item.type == 'text' || item.type == 'number'\"\r\n type=\"{{ item.type }}\"\r\n formControlName=\"{{ item.formControl }}\"\r\n class=\"w-full\"\r\n />\r\n\r\n <p-editor\r\n *ngIf=\"item.type == 'editor'\"\r\n formControlName=\"{{ item.formControl }}\"\r\n [style]=\"{ height: '320px' }\"\r\n />\r\n\r\n <!-- select -->\r\n <p-dropdown\r\n id=\"{{ item.id }}\"\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n [filter]=\"item.search\"\r\n emptyFilterMessage=\"Nenhum dado encontrado\"\r\n emptyMessage=\"Nenhum dado encontrado\"\r\n placeholder=\"{{ item.placeholder }}\"\r\n styleClass=\"w-full p-0\"\r\n (onChange)=\"onChange(item.onChange)\"\r\n *ngIf=\"item.type === 'select'\"\r\n [showClear]=\"true\"\r\n [options]=\"item.options\"\r\n formControlName=\"{{ item.formControl }}\"\r\n optionLabel=\"description\"\r\n (onClear)=\"clickCLear(item.onCLear)\"\r\n ></p-dropdown>\r\n\r\n <!-- currency -->\r\n <p-inputNumber\r\n id=\"{{ item.id }}\"\r\n *ngIf=\"item.type === 'currency'\"\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n formControlName=\"{{ item.formControl }}\"\r\n placeholder=\"{{ item.placeholder }}\"\r\n inputStyleClass=\"w-full\"\r\n styleClass=\"w-full\"\r\n (onKeyDown)=\"onChange(item.onChange)\"\r\n mode=\"currency\"\r\n [min]=\"0\"\r\n currency=\"BRL\"\r\n >\r\n </p-inputNumber>\r\n\r\n <!-- mask -->\r\n <p-inputMask\r\n id=\"{{ item.id }}\"\r\n *ngIf=\"item.type === 'mask'\"\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n formControlName=\"{{ item.formControl }}\"\r\n placeholder=\"{{ item.placeholder }}\"\r\n styleClass=\"w-full\"\r\n (onComplete)=\"onChange(item.onChange)\"\r\n mask=\"{{ item.mask }}\"\r\n unmask=\"{{ item.unmask }}\"\r\n (onClear)=\"clickCLear(item.onCLear)\"\r\n showClear=\"true\"\r\n ></p-inputMask>\r\n\r\n <!-- treeSelect -->\r\n <p-treeSelect\r\n id=\"{{ item.id }}\"\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n placeholder=\"{{ item.placeholder }}\"\r\n (onNodeSelect)=\"onChange(item.onChange)\"\r\n *ngIf=\"item.type === 'tree-select'\"\r\n containerStyleClass=\"w-full p-0\"\r\n formControlName=\"{{ item.formControl }}\"\r\n [options]=\"item.treeSelectOptions\"\r\n [filter]=\"true\"\r\n [filterInputAutoFocus]=\"true\"\r\n emptyMessage=\"Nenhum dado encontrado\"\r\n [showClear]=\"true\"\r\n (onClear)=\"clickCLear(item.onCLear)\"\r\n ></p-treeSelect>\r\n\r\n <!-- autoComplete -->\r\n <p-autoComplete\r\n inputId=\"{{ item.id }}\"\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n placeholder=\"{{ item.placeholder }}\"\r\n styleClass=\"w-full p-0\"\r\n [inputStyle]=\"{ width: '100%' }\"\r\n *ngIf=\"item.type === 'autocomplete'\"\r\n (onSelect)=\"onChange(item.onChange)\"\r\n formControlName=\"{{ item.formControl }}\"\r\n [suggestions]=\"filteredAutoComplete\"\r\n (completeMethod)=\"filterAutoComplete($event, item.options)\"\r\n [forceSelection]=\"false\"\r\n [showEmptyMessage]=\"true\"\r\n emptyMessage=\"Nenhum dado encontrado\"\r\n dataKey=\"code\"\r\n field=\"description\"\r\n showClear=\"true\"\r\n (onClear)=\"clickCLear(item.onCLear)\"\r\n ></p-autoComplete>\r\n\r\n <!-- date -->\r\n <p-calendar\r\n id=\"{{ item.id }}\"\r\n view=\"{{ item.viewDate }}\"\r\n *ngIf=\"item.type === 'date'\"\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n formControlName=\"{{ item.formControl }}\"\r\n styleClass=\"w-full\"\r\n [numberOfMonths]=\"numberOfMonthsDate(item.numberOfMonthsDate)\"\r\n [selectionMode]=\"selectionMode(item.selectionMode)\"\r\n (onFocus)=\"onChange(item.onFocusDate)\"\r\n [maxDate]=\"item.maxDate\"\r\n [minDate]=\"item.minDate\"\r\n dateFormat=\"{{ item.dateFormat }}\"\r\n (onSelect)=\"onChange(item.onChange)\"\r\n [iconDisplay]=\"'input'\"\r\n placeholder=\"{{ item.placeholder }}\"\r\n [showIcon]=\"true\"\r\n [showTime]=\"item.showTime\"\r\n [timeOnly]=\"item.timeOnly\"\r\n ></p-calendar>\r\n\r\n <!-- textarea -->\r\n <div *ngIf=\"item.type === 'text-area'\" class=\"text-right\">\r\n <textarea\r\n id=\"{{ item.id }}\"\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n placeholder=\"{{ item.placeholder }}\"\r\n class=\"w-full\"\r\n maxlength=\"{{ item.maxlength }}\"\r\n counterTemplate=\"{1} of 50, {0} remaining\"\r\n counter=\"display\"\r\n (attr.change)=\"onChange(item.onChange)\"\r\n pInputTextarea\r\n formControlName=\"{{ item.formControl }}\"\r\n rows=\"{{ item.rowsTextArea }}\"\r\n ></textarea>\r\n <small *ngIf=\"item.maxlength\" id=\"username-help\">\r\n {{ control.controls[item.formControl].value.length }}/{{\r\n item.maxlength\r\n }}\r\n </small>\r\n </div>\r\n\r\n <!-- checkbox -->\r\n <div *ngIf=\"item.type == 'check-box'\">\r\n <p-checkbox\r\n id=\"{{ item.id }}\"\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n (onChange)=\"onChange(item.onChange)\"\r\n binary=\"true\"\r\n formControlName=\"{{ item.formControl }}\"\r\n value=\"{{ item.formControl }}\"\r\n label=\"{{ item.label }}\"\r\n ></p-checkbox>\r\n </div>\r\n\r\n <!-- checkbox multiple -->\r\n <div\r\n id=\"{{ item.id }}\"\r\n *ngIf=\"item.type === 'check-box-multi'\"\r\n class=\"flex gap-3\"\r\n >\r\n <div\r\n formArrayName=\"{{ item.formControl }}\"\r\n *ngFor=\"let list of item.options; let i = index\"\r\n class=\"flex align-items-center gap-2\"\r\n >\r\n <div [formGroupName]=\"i\">\r\n <p-checkbox\r\n id=\"{{ item.id }}\"\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n (onChange)=\"onChange(item.onChange)\"\r\n binary=\"true\"\r\n formControlName=\"{{ list.code }}\"\r\n label=\"{{ list.description }}\"\r\n ></p-checkbox>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- button -->\r\n <p-button\r\n id=\"{{ item.id }}\"\r\n *ngIf=\"item.type == 'button'\"\r\n styleClass=\"{{ item.buttonClass }} w-full mt-3\"\r\n (click)=\"item.onCLick()\"\r\n [disabled]=\"item.disabled\"\r\n icon=\"{{ item.iconButton }}\"\r\n label=\"{{ item.label }}\"\r\n ></p-button>\r\n\r\n <!-- can -->\r\n <div id=\"{{ item.id }}\" class=\"area\" *ngIf=\"item.type == 'can'\">\r\n <video autoplay=\"true\" id=\"webCamera\"></video>\r\n\r\n <input type=\"text\" id=\"base_img\" name=\"base_img\" />\r\n <button type=\"button\" onclick=\"takeSnapShot()\">\r\n Tirar foto e salvar\r\n </button>\r\n\r\n <img id=\"imagemConvertida\" />\r\n <p id=\"caminhoImagem\" class=\"caminho-imagem\">\r\n <a href=\"\" target=\"_blank\" rel=\"noopener\"></a>\r\n </p>\r\n <script src=\"script.js\"></script>\r\n </div>\r\n\r\n <!-- upload files -->\r\n <div\r\n id=\"{{ item.id }}\"\r\n *ngIf=\"item.type === 'upload-files' && !item.disabled\"\r\n class=\"drag-image\"\r\n [style.border]=\"\r\n validateForm && control.controls[item.formControl].errors\r\n ? ' 1px dashed #f18282'\r\n : ' 1px dashed #d1d5db'\r\n \"\r\n >\r\n <i *ngIf=\"filesView.length === 0\" class=\"pi pi-cloud-upload\"></i>\r\n <p *ngIf=\"filesView.length === 0\">\r\n Clique ou arraste e solte um arquivo para anexar\r\n </p>\r\n <span *ngIf=\"filesView.length === 0\">{{\r\n item.msgAcceptFiles\r\n }}</span>\r\n <input\r\n id=\"fileInput\"\r\n type=\"file\"\r\n [multiple]=\"item.multileFile\"\r\n [accept]=\"item.acceptFiles\"\r\n (change)=\"\r\n onSelectFile(item.formControl, $event, item.multileFile)\r\n \"\r\n />\r\n <div *ngFor=\"let f of filesView\">\r\n <div *ngIf=\"f.type && f.type.includes('image')\">\r\n <label class=\"preview-img\">\r\n <img *ngIf=\"!f.content\" src=\"{{ getUrl(f) }}\" />\r\n <img *ngIf=\"f.content\" src=\"{{ f.content }}\" />\r\n <span *ngIf=\"item.viewNameFile\">{{ f.name }}</span>\r\n <input\r\n type=\"file\"\r\n [multiple]=\"item.multileFile\"\r\n [accept]=\"item.acceptFiles\"\r\n (change)=\"\r\n onSelectFile(item.formControl, $event, item.multileFile)\r\n \"\r\n />\r\n <label>\r\n <i\r\n class=\"pi pi-times remove-file absolute\"\r\n (click)=\"onRemove(item.formControl, f)\"\r\n ></i\r\n ></label>\r\n </label>\r\n </div>\r\n <div *ngIf=\"f.type && !f.type.includes('image')\">\r\n <label class=\"preview-img h-0 max-w-0 mh-75 m-0\">\r\n <label class=\"mr-3\">{{ f.name }}</label>\r\n <input\r\n type=\"file\"\r\n [multiple]=\"item.multileFile\"\r\n [accept]=\"item.acceptFiles\"\r\n (change)=\"\r\n onSelectFile(item.formControl, $event, item.multileFile)\r\n \"\r\n />\r\n <label>\r\n <i\r\n class=\"pi pi-times remove-file absolute\"\r\n (click)=\"onRemove(f)\"\r\n ></i\r\n ></label>\r\n </label>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- upload files disabled -->\r\n <!-- <p-fileUpload mode=\"basic\" formControlName=\"{{item.formControl}}\" chooseLabel=\"Choose\"\r\n chooseIcon=\"pi pi-upload\" accept=\"image/*\" maxFileSize=\"1000000\" /> -->\r\n\r\n <div\r\n id=\"{{ item.id }}\"\r\n *ngIf=\"item.type === 'upload-files' && item.disabled\"\r\n >\r\n <p-button\r\n (click)=\"op.toggle($event)\"\r\n icon=\"pi pi-paperclip\"\r\n label=\"Arquivos anexados\"\r\n ></p-button>\r\n\r\n <p-overlayPanel\r\n #op\r\n [style]=\"{ width: '450px' }\"\r\n [showCloseIcon]=\"true\"\r\n >\r\n <ng-template pTemplate=\"content\">\r\n <p-table\r\n *ngIf=\"files.length > 0\"\r\n [value]=\"files\"\r\n selectionMode=\"single\"\r\n [(selection)]=\"selectedProduct\"\r\n (onRowSelect)=\"onRowSelect($event, op)\"\r\n responsiveLayout=\"scroll\"\r\n >\r\n <ng-template pTemplate=\"header\">\r\n <tr>\r\n <th pSortableColumn=\"name\">\r\n Nome<p-sortIcon field=\"name\"></p-sortIcon>\r\n </th>\r\n <th></th>\r\n </tr>\r\n </ng-template>\r\n <ng-template pTemplate=\"body\" let-rowData let-file>\r\n <tr>\r\n <td *ngIf=\"item.viewNameFile\">{{ file.name }}</td>\r\n <td>\r\n <p-button\r\n *ngIf=\"item.onCLick\"\r\n icon=\"pi pi-download\"\r\n (click)=\"item.onCLick(file)\"\r\n ></p-button>\r\n </td>\r\n </tr>\r\n </ng-template>\r\n </p-table>\r\n <div *ngIf=\"files.length === 0\" class=\"p-10\">\r\n <label>Nenhum arquivo anexado</label>\r\n </div>\r\n </ng-template>\r\n </p-overlayPanel>\r\n </div>\r\n\r\n <!-- list -->\r\n <ul id=\"{{ item.id }}\" *ngIf=\"item.type === 'list' && item.options\">\r\n <li *ngFor=\"let list of item.options\">{{ list.description }}</li>\r\n </ul>\r\n\r\n <!-- multi -->\r\n <p-multiSelect\r\n id=\"{{ item.id }}\"\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n placeholder=\"{{ item.placeholder }}\"\r\n *ngIf=\"item.type === 'multi'\"\r\n [options]=\"item.options\"\r\n formControlName=\"{{ item.formControl }}\"\r\n styleClass=\"p-0 w-full\"\r\n optionLabel=\"description\"\r\n (onChange)=\"onChange(item.onChange)\"\r\n maxSelectedLabels=\"100\"\r\n ></p-multiSelect>\r\n\r\n <!-- radioButton -->\r\n <div\r\n id=\"{{ item.id }}\"\r\n *ngIf=\"item.type === 'radio-button'\"\r\n class=\"flex gap-3\"\r\n >\r\n <div\r\n *ngFor=\"let listRadioButton of item.options\"\r\n class=\"flex align-items-center gap-2\"\r\n >\r\n <p-radioButton\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n [value]=\"listRadioButton.code\"\r\n formControlName=\"{{ item.formControl }}\"\r\n (onClick)=\"onChange(item.onChange)\"\r\n ></p-radioButton>\r\n <label>{{ listRadioButton.description }}</label>\r\n </div>\r\n @if(control.controls[item.formControl].value == 'other'){\r\n <input\r\n pInputText\r\n type=\"text\"\r\n formControlName=\"{{ item.formControlOther }}\"\r\n />\r\n }\r\n </div>\r\n\r\n <!-- selectButton -->\r\n <div class=\"d-flex\" *ngIf=\"item.type === 'select-button'\">\r\n <p-selectButton\r\n id=\"{{ item.id }}\"\r\n (onChange)=\"onChange(item.onChange)\"\r\n [options]=\"item.options\"\r\n formControlName=\"{{ item.formControl }}\"\r\n optionValue=\"code\"\r\n >\r\n <ng-template let-item>\r\n <span>{{ item.description }}</span>\r\n </ng-template>\r\n </p-selectButton>\r\n <!-- <input type=\"text\" pInputText [attr.disabled]=\"item.disabled\"\r\n formControlName={{item.formControlSecondary}}> -->\r\n </div>\r\n\r\n <!-- table -->\r\n <p-table\r\n id=\"{{ item.id }}\"\r\n *ngIf=\"item.type === 'table'\"\r\n [scrollable]=\"true\"\r\n scrollHeight=\"{{ item.scrollHeight }}\"\r\n [columns]=\"item.colsTable\"\r\n styleClass=\"p-datatable-striped p-datatable-sm\"\r\n [value]=\"item.rowsTable\"\r\n >\r\n <ng-template pTemplate=\"header\" let-columns>\r\n <tr>\r\n <th *ngFor=\"let col of columns\">\r\n <span *ngIf=\"col.filed !== 'action'\">{{ col.header }}</span>\r\n <span *ngIf=\"col.filed === 'action'\">A\u00E7\u00E3o</span>\r\n </th>\r\n </tr>\r\n </ng-template>\r\n <ng-template pTemplate=\"body\" let-rowData let-columns=\"columns\">\r\n <tr>\r\n <td *ngFor=\"let col of columns\">\r\n <div *ngIf=\"col.field !== 'button'\">\r\n {{ rowData[col.field] }}\r\n </div>\r\n <div *ngIf=\"col.field === 'action'\">\r\n <p-button\r\n *ngFor=\"let action of item.buttonsTable\"\r\n styleClass=\"{{ action.styleClass }}\"\r\n label=\"{{ action.label }}\"\r\n (click)=\"action.onCLick(rowData)\"\r\n icon=\"{{ action.icon }}\"\r\n ></p-button>\r\n </div>\r\n </td>\r\n </tr>\r\n </ng-template>\r\n <ng-template pTemplate=\"footer\" let-columns>\r\n <tr *ngFor=\"let footer of item.rowsFooter\">\r\n <td colspan=\"12\">\r\n <span class=\"font-normal\">{{ footer.text }}:</span>\r\n {{ footer.value }}\r\n </td>\r\n </tr>\r\n </ng-template>\r\n </p-table>\r\n\r\n <!-- inputSwitch -->\r\n <div class=\"d-flex\" *ngIf=\"item.type === 'switch'\">\r\n <p-inputSwitch\r\n id=\"{{ item.id }}\"\r\n formControlName=\"{{ item.formControl }}\"\r\n class=\"mr-10\"\r\n (onChange)=\"onChange(item.onChange)\"\r\n ></p-inputSwitch>\r\n <p translate=\"{{ item.label }}\"></p>\r\n </div>\r\n\r\n <!-- password -->\r\n <p-password\r\n id=\"{{ item.id }}\"\r\n [ngClass]=\"{\r\n 'ng-invalid ng-dirty':\r\n validateForm && control.controls[item.formControl].errors\r\n }\"\r\n placeholder=\"{{ item.placeholder }}\"\r\n *ngIf=\"item.type === 'password'\"\r\n [feedback]=\"false\"\r\n formControlName=\"{{ item.formControl }}\"\r\n (onChange)=\"onChange(item.onChange)\"\r\n styleClass=\"w-full\"\r\n [toggleMask]=\"true\"\r\n ></p-password>\r\n\r\n <!-- photo -->\r\n <div id=\"{{ item.id }}\" class=\"camera\" *ngIf=\"item.type === 'photo'\">\r\n <video id=\"video\" class=\"foto\" autoplay>\r\n V\u00EDdeo n\u00E3o dispon\u00EDvel.\r\n </video>\r\n <canvas id=\"canvas\" class=\"foto\" style=\"display: none\"></canvas>\r\n <button\r\n pButton\r\n icon=\"pi pi-times\"\r\n class=\"remove-file\"\r\n id=\"icon-remove\"\r\n [rounded]=\"true\"\r\n style=\"visibility: collapse\"\r\n (click)=\"removePhoto()\"\r\n ></button>\r\n <button\r\n pButton\r\n icon=\"pi pi-camera\"\r\n [rounded]=\"true\"\r\n (click)=\"capturePhoto(item.formControl)\"\r\n id=\"button\"\r\n ></button>\r\n </div>\r\n\r\n <!-- likert -->\r\n <p-table\r\n id=\"{{ item.id }}\"\r\n *ngIf=\"item.type === 'likert'\"\r\n [scrollable]=\"true\"\r\n scrollHeight=\"{{ item.scrollHeight }}\"\r\n [columns]=\"item.colsTable\"\r\n styleClass=\"p-datatable-striped p-datatable-sm\"\r\n [value]=\"item.rowsTable\"\r\n >\r\n <ng-template pTemplate=\"header\" let-columns>\r\n <tr>\r\n <th style=\"width: 4rem\"></th>\r\n <th *ngFor=\"let col of columns\">\r\n <span>{{ col.header }}</span>\r\n </th>\r\n </tr>\r\n </ng-template>\r\n <ng-template\r\n pTemplate=\"body\"\r\n let-row\r\n let-rowIndex=\"rowIndex\"\r\n let-columns=\"columns\"\r\n formArrayName=\"{{ item.formControl }}\"\r\n >\r\n <tr>\r\n <td>\r\n {{ row }}\r\n </td>\r\n @for (control of columns; track item; let index = $index) {\r\n <td [formGroupName]=\"rowIndex\">\r\n <p-radioButton\r\n value=\"{{ columns[index].field }}+{{ row }}\"\r\n formControlName=\"question{{ rowIndex }}\"\r\n />\r\n </td>\r\n }\r\n </tr>\r\n </ng-template>\r\n </p-table>\r\n\r\n <!-- editable table -->\r\n <p-table\r\n id=\"{{ item.id }}\"\r\n *ngIf=\"item.type === 'editable-table'\"\r\n [scrollable]=\"true\"\r\n scrollHeight=\"{{ item.scrollHeight }}\"\r\n [columns]=\"item.colsTable\"\r\n styleClass=\"p-datatable-striped p-datatable-sm\"\r\n [value]=\"item.rowsTable\"\r\n editMode=\"cell\"\r\n >\r\n <!-- Cabe\u00E7alho da tabela -->\r\n <ng-template pTemplate=\"header\" let-columns>\r\n <tr>\r\n <th style=\"width: 4rem\"></th>\r\n <th *ngFor=\"let col of columns\">\r\n <span>{{ col.header }}</span>\r\n </th>\r\n </tr>\r\n </ng-template>\r\n\r\n <!-- Corpo da tabela -->\r\n <ng-template\r\n pTemplate=\"body\"\r\n let-row\r\n let-rowIndex=\"rowIndex\"\r\n let-columns=\"columns\"\r\n formArrayName=\"{{ item.formControl }}\"\r\n let-editing=\"editing\"\r\n >\r\n <tr>\r\n <td>{{ row }}</td>\r\n @for (control of columns; track item; let index = $index) {\r\n <td\r\n [formGroupName]=\"rowIndex\"\r\n [pEditableColumn]=\"row\"\r\n pEditableColumnField=\"row\"\r\n >\r\n <p-cellEditor>\r\n <ng-template pTemplate=\"input\">\r\n <input\r\n pInputText\r\n type=\"text\"\r\n formControlName=\"_{{ control.field }}question{{\r\n rowIndex\r\n }}\"\r\n />\r\n </ng-template>\r\n <ng-template pTemplate=\"output\">\r\n <input\r\n pInputText\r\n type=\"text\"\r\n formControlName=\"_{{ control.field }}question{{\r\n rowIndex\r\n }}\"\r\n />\r\n </ng-template>\r\n </p-cellEditor>\r\n </td>\r\n }\r\n </tr>\r\n </ng-template>\r\n </p-table>\r\n\r\n <!-- valida\u00E7\u00E3o de item -->\r\n <div>\r\n <small\r\n class=\"danger-text\"\r\n *ngIf=\"validateForm && control.controls[item.formControl] && control.controls[item.formControl].errors?.['required']\"\r\n >\r\n Campo obrigat\u00F3rio\r\n </small>\r\n <small\r\n class=\"danger-text\"\r\n *ngIf=\"validateForm && control.controls[item.formControl] && control.controls[item.formControl].errors?.['email']\"\r\n >\r\n Email inv\u00E1lido\r\n </small>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <p-divider\r\n *ngIf=\"\r\n (buttonsStandard && buttonsStandard.length > 0) ||\r\n (buttonsOptional && buttonsOptional.length > 0)\r\n \"\r\n ></p-divider>\r\n\r\n <div class=\"buttons-form\">\r\n <div *ngFor=\"let button of buttonsStandard\">\r\n <p-button\r\n *ngIf=\"button.type === 'clean'\"\r\n styleClass=\"p-button-warning {{ button.styleClass }}\"\r\n label=\"Limpar\"\r\n (click)=\"button.onCLick()\"\r\n icon=\"pi pi-times\"\r\n ></p-button>\r\n <p-button\r\n *ngIf=\"button.type === 'filter'\"\r\n styleClass=\"{{ button.styleClass }}\"\r\n label=\"Filtrar\"\r\n (click)=\"button.onCLick()\"\r\n icon=\"pi pi-search\"\r\n ></p-button>\r\n <p-button\r\n *ngIf=\"button.type === 'save'\"\r\n styleClass=\"p-button-success {{ button.styleClass }}\"\r\n label=\"Salvar\"\r\n (click)=\"button.onCLick()\"\r\n icon=\"pi pi-save\"\r\n ></p-button>\r\n <p-button\r\n *ngIf=\"button.type === 'cancel'\"\r\n styleClass=\"p-button-danger {{ button.styleClass }}\"\r\n label=\"Cancelar\"\r\n (click)=\"button.onCLick()\"\r\n icon=\"pi pi-times\"\r\n ></p-button>\r\n </div>\r\n <div *ngFor=\"let button of buttonsOptional\">\r\n <p-button\r\n styleClass=\"{{ button.styleClass }}\"\r\n label=\"{{ button.label }}\"\r\n (click)=\"button.onCLick()\"\r\n icon=\"{{ button.icon }}\"\r\n ></p-button>\r\n </div>\r\n </div>\r\n </div>\r\n </form>\r\n</div>\r\n", styles: [".div-title span{font-size:20px;font-weight:500}.buttons-form{display:flex;gap:10px;justify-content:flex-end}.danger-text{color:#f18282}.drag-image{height:auto;width:100%;border-radius:10px;font-weight:400;display:flex;align-items:center;flex-direction:column;top:20px;max-height:250px;color:#000;padding:20px;text-align:center;overflow:auto}.drag-image h6{font-size:20px}.drag-image .file-name{font-size:14px}.drag-image i{font-size:3rem}.subtitle span{font-size:14px;margin-right:5px}.subtitle{align-items:baseline}.mh-75{min-height:75px!important}input[type=file]{position:absolute;width:100%;height:100%;inset:0;opacity:0;cursor:pointer}.preview-img{align-items:center;border-radius:5px;display:flex;height:140px;justify-content:center;margin:10px;max-width:180px;min-height:140px;min-width:180px;padding:0 20px;position:relative}.preview-img span{position:absolute;overflow-wrap:break-word}.remove-file{display:flex;justify-content:center;align-items:center;height:22px;width:22px;top:5px;right:5px;border-radius:50%;background:#bbb;color:#333;cursor:pointer;font-size:.8rem!important}.preview-img img{max-width:100%;opacity:.8}.camera{display:flex;flex-direction:column;align-items:center;position:relative}.foto{max-width:186px;min-height:140px;min-width:180px;border:1px dashed #000;border-radius:5px;margin-bottom:1em}.preview-photo{position:relative}.h-0{height:0}\n"] }]
|
|
167
|
+
}], ctorParameters: () => [{ type: i1.TranslateService }, { type: i2.FormBuilder }], propDecorators: { title: [{
|
|
168
|
+
type: Input
|
|
169
|
+
}], subTitle: [{
|
|
170
|
+
type: Input
|
|
171
|
+
}], validateForm: [{
|
|
172
|
+
type: Input
|
|
173
|
+
}], form: [{
|
|
174
|
+
type: Input
|
|
175
|
+
}], control: [{
|
|
176
|
+
type: Input
|
|
177
|
+
}], buttonsStandard: [{
|
|
178
|
+
type: Input
|
|
179
|
+
}], buttonsOptional: [{
|
|
180
|
+
type: Input
|
|
181
|
+
}], files: [{
|
|
182
|
+
type: Input
|
|
183
|
+
}] } });
|
|
184
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1keW5hbWljLWFuZ3VsYXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvZm9ybS1keW5hbWljLWFqYXgvc3JjL2xpYi9mb3JtLWR5bmFtaWMtYW5ndWxhci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi9wcm9qZWN0cy9mb3JtLWR5bmFtaWMtYWpheC9zcmMvbGliL2Zvcm0tZHluYW1pYy1hbmd1bGFyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBc0hsRixNQUFNLE9BQU8sMkJBQTJCO0lBZ0J0QyxZQUNTLFNBQTJCLEVBQzFCLFdBQXdCO1FBRHpCLGNBQVMsR0FBVCxTQUFTLENBQWtCO1FBQzFCLGdCQUFXLEdBQVgsV0FBVyxDQUFhO1FBZnpCLGlCQUFZLEdBQVksS0FBSyxDQUFDO1FBRTlCLFNBQUksR0FBWSxFQUFFLENBQUE7UUFNbEIsVUFBSyxHQUFVLEVBQUUsQ0FBQztRQUUzQixjQUFTLEdBQVUsRUFBRSxDQUFDO1FBQ3RCLHlCQUFvQixHQUFVLEVBQUUsQ0FBQztRQWlJakMsYUFBUSxHQUFHLEtBQUssRUFBRSxJQUFVLEVBQUUsRUFBRTtZQUM5QixPQUFPLElBQUksT0FBTyxDQUFDLENBQUMsT0FBTyxFQUFFLENBQUMsRUFBRSxFQUFFO2dCQUNoQyxNQUFNLE1BQU0sR0FBRyxJQUFJLFVBQVUsRUFBRSxDQUFDO2dCQUNoQyxNQUFNLENBQUMsU0FBUyxHQUFHLEdBQUcsRUFBRSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUM7Z0JBQ2hELE1BQU0sQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDN0IsQ0FBQyxDQUFDLENBQUM7UUFDTCxDQUFDLENBQUE7UUFq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IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgVHJhbnNsYXRlU2VydmljZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xyXG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmV4cG9ydCBpbnRlcmZhY2UgSVRyZWVTZWxlY3RPcHRpb25zIHtcclxuICBrZXk6IHN0cmluZyxcclxuICBsYWJlbDogc3RyaW5nLFxyXG4gIGljb246IHN0cmluZyxcclxuICBjaGlsZHJlbj86IElUcmVlU2VsZWN0T3B0aW9uc1tdXHJcbn1cclxuZXhwb3J0IGludGVyZmFjZSBJT3B0aW9ucyB7XHJcbiAgZGVzY3JpcHRpb246IHN0cmluZyxcclxuICBjb2RlOiBudW1iZXIgfCBzdHJpbmdcclxufVxyXG5leHBvcnQgaW50ZXJmYWNlIElDb2xzIHtcclxuICBmaWVsZDogc3RyaW5nLFxyXG4gIGhlYWRlcjogc3RyaW5nXHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIFRUeXBlcyA9XHJcbiAgXCJhdXRvY29tcGxldGVcIiB8XHJcbiAgXCJidXR0b25cIiB8XHJcbiAgXCJjaGVjay1ib3hcIiB8XHJcbiAgXCJjdXJyZW5jeVwiIHxcclxuICBcImNoZWNrLWJveC1tdWx0aVwiIHxcclxuICBcImRhdGVcIiB8XHJcbiAgXCJzd2l0Y2hcIiB8XHJcbiAgXCJsaXN0XCIgfFxyXG4gIFwibGlrZXJ0XCIgfFxyXG4gIFwibWFza1wiIHxcclxuICBcIm11bHRpXCIgfFxyXG4gIFwibnVtYmVyXCIgfFxyXG4gIFwicGFzc3dvcmRcIiB8XHJcbiAgXCJwaG90b1wiIHxcclxuICBcInJhZGlvLWJ1dHRvblwiIHxcclxuICBcInNlbGVjdFwiIHxcclxuICBcInNlbGVjdC1idXR0b25cIiB8XHJcbiAgXCJ0YWJsZVwiIHxcclxuICBcInRleHRcIiB8XHJcbiAgXCJ0ZXh0LWFyZWFcIiB8XHJcbiAgXCJ0cmVlLXNlbGVjdFwiIHxcclxuICBcInVwbG9hZC1maWxlc1wiIHxcclxuICBcImVkaXRhYmxlLXRhYmxlXCIgfCBcclxuICBcImVkaXRvclwiXHJcbmV4cG9ydCBpbnRlcmZhY2UgSUZvcm0ge1xyXG4gIGlkOiBudW1iZXIgfCBzdHJpbmcsXHJcbiAgbGFiZWw/OiBzdHJpbmcsXHJcbiAgdHlwZTogVFR5cGVzLFxyXG4gIGNvbD86IHN0cmluZyxcclxuICBkaXNhYmxlZD86IGJvb2xlYW4gfCBudWxsLFxyXG4gIGZvcm1Db250cm9sPzogc3RyaW5nLFxyXG4gIHJlcXVpcmVkPzogYm9vbGVhbixcclxuICBwbGFjZWhvbGRlcj86IHN0cmluZyxcclxuXHJcbiAgbnVtYmVyT2ZNb250aHNEYXRlPzogbnVtYmVyO1xyXG4gIHNlbGVjdGlvbk1vZGU/OiBcIm11bHRpcGxlXCIgfCBcInJhbmdlXCIgfCBcInNpbmdsZVwiXHJcbiAgbWluRGF0ZT86IERhdGUsXHJcbiAgbWF4RGF0ZT86IERhdGUsXHJcbiAgdmlld0RhdGU/OiAnbW9udGgnIHwgJ2RhdGUnLFxyXG4gIGRhdGVGb3JtYXQ/OiBzdHJpbmdcclxuICB0aW1lT25seT86IGJvb2xlYW5cclxuICBzaG93VGltZT86IGJvb2xlYW4sXHJcblxyXG4gIG1heGxlbmd0aD86IG51bWJlcixcclxuICByb3dzVGV4dEFyZWE/OiBudW1iZXIsXHJcblxyXG4gIG1hc2s/OiBzdHJpbmcsXHJcbiAgdW5tYXNrPzogYm9vbGVhbixcclxuXHJcbiAgc2VhcmNoPzogYm9vbGVhbixcclxuICBvcHRpb25zPzogSU9wdGlvbnNbXVxyXG4gIHRyZWVTZWxlY3RPcHRpb25zPzogSVRyZWVTZWxlY3RPcHRpb25zW10sXHJcblxyXG4gIGJ1dHRvbkNsYXNzPzogc3RyaW5nLFxyXG4gIGljb25CdXR0b24/OiBzdHJpbmcsXHJcblxyXG4gIGZvcm1Db250cm9sT3RoZXI/OiBzdHJpbmcsXHJcbiAgaGlkZUxhYmVsVG9wPzogYm9vbGVhbixcclxuXHJcbiAgc2Nyb2xsSGVpZ2h0Pzogc3RyaW5nLFxyXG4gIGNvbHNUYWJsZT86IElDb2xzW10sXHJcbiAgcm93c1RhYmxlPzogYW55W10sXHJcbiAgcm93c0Zvb3Rlcj86IGFueVtdLFxyXG4gIGJ1dHRvbnNUYWJsZT86IElCdXR0b25zVGFibGVbXSxcclxuXHJcbiAgYWNjZXB0RmlsZXM/OiBzdHJpbmcsXHJcbiAgbXNnQWNjZXB0RmlsZXM/OiBzdHJpbmcsXHJcbiAgdmlld05hbWVGaWxlPzogYm9vbGVhbixcclxuICBtdWx0aWxlRmlsZT86IGJvb2xlYW4sXHJcblxyXG4gIG9uQ2hhbmdlPzogRnVuY3Rpb24sXHJcbiAgb25DTGljaz86IEZ1bmN0aW9uLFxyXG4gIG9uQ0xlYXI/OiBGdW5jdGlvbixcclxuICBvbkZvY3VzRGF0ZT86IEZ1bmN0aW9uLFxyXG59XHJcbmV4cG9ydCBpbnRlcmZhY2UgSUJ1dHRvbnNTdGFuZGFyZCB7XHJcbiAgdHlwZTogJ2NsZWFuJyB8ICdmaWx0ZXInIHwgJ3NhdmUnIHwgJ2NhbmNlbCcsXHJcbiAgb25DTGljazogRnVuY3Rpb24sXHJcbiAgc3R5bGVDbGFzcz86IHN0cmluZ1xyXG59XHJcbmV4cG9ydCBpbnRlcmZhY2UgSUJ1dHRvbnNPcHRpb25hbCB7XHJcbiAgbGFiZWw6IHN0cmluZyxcclxuICBvbkNMaWNrOiBGdW5jdGlvbixcclxuICBpY29uOiBzdHJpbmcsXHJcbiAgc3R5bGVDbGFzczogc3RyaW5nLFxyXG4gIHZpZXc/OiBGdW5jdGlvbjtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBJQnV0dG9uc1RhYmxlIHtcclxuICBzdHlsZUNsYXNzOiBzdHJpbmcsXHJcbiAgbGFiZWw6IHN0cmluZyxcclxuICBpY29uOiBzdHJpbmcsXHJcbiAgb25DTGljazogRnVuY3Rpb25cclxufVxyXG5AQ29tcG9uZW50KHtcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICBzZWxlY3RvcjogJ2Zvcm0tZHluYW1pYy1hbmd1bGFyJyxcclxuICB0ZW1wbGF0ZVVybDogJ2Zvcm0tZHluYW1pYy1hbmd1bGFyLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnZm9ybS1keW5hbWljLWFuZ3VsYXIuY29tcG9uZW50LmNzcyddXHJcbn0pXHJcblxyXG5leHBvcnQgY2xhc3MgRm9ybUR5bmFtaWNBbmd1bGFyQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcclxuICBASW5wdXQoKSB0aXRsZSE6IHN0cmluZztcclxuICBASW5wdXQoKSBzdWJUaXRsZSE6IHN0cmluZztcclxuICBASW5wdXQoKSB2YWxpZGF0ZUZvcm06IGJvb2xlYW4gPSBmYWxzZTtcclxuXHJcbiAgQElucHV0KCkgZm9ybTogSUZvcm1bXSA9IFtdXHJcbiAgQElucHV0KCkgY29udHJvbDogRm9ybUdyb3VwO1xyXG5cclxuICBASW5wdXQoKSBidXR0b25zU3RhbmRhcmQ6IElCdXR0b25zU3RhbmRhcmRbXVxyXG4gIEBJbnB1dCgpIGJ1dHRvbnNPcHRpb25hbDogSUJ1dHRvbnNPcHRpb25hbFtdXHJcblxyXG4gIEBJbnB1dCgpIGZpbGVzOiBhbnlbXSA9IFtdO1xyXG5cclxuICBmaWxlc1ZpZXc6IGFueVtdID0gW107XHJcbiAgZmlsdGVyZWRBdXRvQ29tcGxldGU6IGFueVtdID0gW107XHJcblxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcHVibGljIHRyYW5zbGF0ZTogVHJhbnNsYXRlU2VydmljZSxcclxuICAgIHByaXZhdGUgZm9ybUJ1aWxkZXI6IEZvcm1CdWlsZGVyXHJcbiAgKSB7XHJcbiAgICB0aGlzLmNvbnRyb2wgPSB0aGlzLmZvcm1CdWlsZGVyLmdyb3VwKHt9KTtcclxuICB9XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgdGhpcy5maWxlcy5tYXAoZiA9PiB7XHJcbiAgICAgIHRoaXMuZmlsZXNWaWV3LnB1c2goeyAuLi5mLCB0eXBlOiBmLmNvbnRlbnRUeXBlIH0pXHJcbiAgICB9KVxyXG5cclxuICAgIGlmICh3aW5kb3cubG9jYXRpb24ucHJvdG9jb2wgPT09IFwiaHR0cHNcIikge1xyXG4gICAgICBuYXZpZ2F0b3IubWVkaWFEZXZpY2VzLmdldFVzZXJNZWRpYSh7IHZpZGVvOiB0cnVlIH0pXHJcbiAgICAgICAgLnRoZW4oZnVuY3Rpb24gKG1lZGlhU3RyZWFtKSB7XHJcbiAgICAgICAgICBjb25zdCB2aWRlbzogSFRNTFZpZGVvRWxlbWVudCB8IG51bGwgPSBkb2N1bWVudC5xdWVyeVNlbGVjdG9yKCcjdmlkZW8nKTtcclxuICAgICAgICAgIGlmICh2aWRlbykge1xyXG4gICAgICAgICAgICB2aWRlby5zcmNPYmplY3QgPSBtZWRpYVN0cmVhbTtcclxuICAgICAgICAgICAgdmlkZW8ucGxheSgpO1xyXG4gICAgICAgICAgfVxyXG4gICAgICAgIH0pXHJcbiAgICAgICAgLmNhdGNoKGZ1bmN0aW9uIChlcnIpIHsgfSlcclxuICAgIH1cclxuICB9XHJcblxyXG4gIG51bWJlck9mTW9udGhzRGF0ZShudW1iZXJPZk1vbnRoc0RhdGU6IG51bWJlcikge1xyXG4gICAgcmV0dXJuIG51bWJlck9mTW9udGhzRGF0ZSA/PyAxXHJcbiAgfVxyXG5cclxuICBzZWxlY3Rpb25Nb2RlKHNlbGVjdGlvbk1vZGU6IHN0cmluZykge1xyXG4gICAgcmV0dXJuIHNlbGVjdGlvbk1vZGUgPz8gXCJzaW5nbGVcIlxyXG4gIH1cclxuXHJcbiAgYXN5bmMgY2FwdHVyZVBob3RvKGZpbGVOYW1lOiBzdHJpbmcpIHtcclxuICAgIGNvbnN0IGNhbnZhczogSFRNTENhbnZhc0VsZW1lbnQgfCBudWxsID0gZG9jdW1lbnQucXVlcnlTZWxlY3RvcihcIiNjYW52YXNcIik7XHJcbiAgICBjb25zdCBpY29uOiBIVE1MQnV0dG9uRWxlbWVudCB8IG51bGwgPSBkb2N1bWVudC5xdWVyeVNlbGVjdG9yKFwiI2ljb24tcmVtb3ZlXCIpO1xyXG4gICAgY29uc3QgdmlkZW86IEhUTUxWaWRlb0VsZW1lbnQgfCBudWxsID0gZG9jdW1lbnQucXVlcnlTZWxlY3RvcignI3ZpZGVvJyk7XHJcbiAgICBjb25zdCBidXR0b246IEhUTUxCdXR0b25FbGVtZW50IHwgbnVsbCA9IGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3IoJyNidXR0b24nKTtcclxuXHJcblxyXG4gICAgaWYgKGNhbnZhcyAmJiB2aWRlbykge1xyXG4gICAgICBjYW52YXMuaGVpZ2h0ID0gdmlkZW8udmlkZW9IZWlnaHQ7XHJcbiAgICAgIGNhbnZhcy53aWR0aCA9IHZpZGVvLnZpZGVvV2lkdGg7XHJcbiAgICAgIGNvbnN0IGNvbnRleHQgPSBjYW52YXMuZ2V0Q29udGV4dCgnMmQnKTtcclxuICAgICAgaWYgKGNvbnRleHQgJiYgaWNvbiAmJiBidXR0b24pIHtcclxuICAgICAgICBjb250ZXh0LmRyYXdJbWFnZSh2aWRlbywgMCwgMClcclxuICAgICAgICB2aWRlby5zdHlsZS5kaXNwbGF5ID0gXCJub25lXCJcclxuICAgICAgICBidXR0b24uZGlzYWJsZWQgPSB0cnVlXHJcbiAgICAgICAgY2FudmFzLnN0eWxlLmRpc3BsYXkgPSBcImJsb2NrXCJcclxuICAgICAgICBpY29uLnN0eWxlLnZpc2liaWxpdHkgPSBcInZpc2libGVcIlxyXG5cclxuICAgICAgICBsZXQgYXV4ID0ge1xyXG4gICAgICAgICAgbmFtZTogXCJwaG90byB1c2VyXCIsXHJcbiAgICAgICAgICBjb250ZW50VHlwZTogXCJpbWFnZS9wbmdcIixcclxuICAgICAgICAgIGNvbnRlbnQ6IGNhbnZhcy50b0RhdGFVUkwoXCJpbWFnZS9wbmdcIilcclxuICAgICAgICB9O1xyXG5cclxuICAgICAgICB0aGlzLmNvbnRyb2wuZ2V0KGZpbGVOYW1lKT8uc2V0VmFsdWUoYXV4KTtcclxuICAgICAgfVxyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgcmVtb3ZlUGhvdG8oKSB7XHJcbiAgICBjb25zdCBjYW52YXM6IEhUTUxDYW52YXNFbGVtZW50IHwgbnVsbCA9IGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3IoXCIjY2FudmFzXCIpO1xyXG4gICAgY29uc3QgaWNvbjogSFRNTEJ1dHRvbkVsZW1lbnQgfCBudWxsID0gZG9jdW1lbnQucXVlcnlTZWxlY3RvcihcIiNpY29uLXJlbW92ZVwiKTtcclxuICAgIGNvbnN0IHZpZGVvOiBIVE1MVmlkZW9FbGVtZW50IHwgbnVsbCA9IGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3IoJyN2aWRlbycpO1xyXG4gICAgY29uc3QgYnV0dG9uOiBIVE1MQnV0dG9uRWxlbWVudCB8IG51bGwgPSBkb2N1bWVudC5xdWVyeVNlbGVjdG9yKCcjYnV0dG9uJyk7XHJcblxyXG4gICAgaWYgKGNhbnZhcyAmJiB2aWRlbykge1xyXG4gICAgICBjb25zdCBjb250ZXh0ID0gY2FudmFzLmdldENvbnRleHQoJzJkJyk7XHJcbiAgICAgIGlmIChjb250ZXh0ICYmIGljb24gJiYgYnV0dG9uKSB7XHJcbiAgICAgICAgdmlkZW8uc3R5bGUuZGlzcGxheSA9IFwiYmxvY2tcIlxyXG4gICAgICAgIGJ1dHRvbi5kaXNhYmxlZCA9IGZhbHNlXHJcbiAgICAgICAgY2FudmFzLnN0eWxlLmRpc3BsYXkgPSBcIm5vbmVcIlxyXG4gICAgICAgIGljb24uc3R5bGUudmlzaWJpbGl0eSA9IFwiY29sbGFwc2VcIlxyXG4gICAgICB9XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBnZXRVcmwoZmlsZTogRmlsZSkge1xyXG4gICAgcmV0dXJuIHdpbmRvdy5VUkwuY3JlYXRlT2JqZWN0VVJMKGZpbGUpXHJcbiAgfVxyXG5cclxuICBhc3luYyBvblNlbGVjdEZpbGUoZmlsZU5hbWU6IHN0cmluZywgZXZlbnQ6IGFueSwgbXVsdGlwbGU6IGJvb2xlYW4pIHtcclxuICAgIGNvbnN0IGZpbGUgPSBldmVudC50YXJnZXQuZmlsZXNcclxuICAgIC8vIGlmICghbXVsdGlwbGUpIHtcclxuICAgIC8vICAgdGhpcy5maWxlc1ZpZXcgPSBbXTtcclxuICAgIC8vIH1cclxuICAgIHRoaXMuZmlsZXNWaWV3LnB1c2goLi4uZmlsZSk7XHJcblxyXG4gICAgY29uc3QgbmV3RklsZXMgPSBmaWxlXHJcbiAgICBsZXQgYXJyID0gW107XHJcbiAgICBmb3IgKGNvbnN0IGl0ZW0gb2YgbmV3RklsZXMpIHtcclxuICAgICAgbGV0IGF1eCA9IHtcclxuICAgICAgICBuYW1lOiBpdGVtLm5hbWUsXHJcbiAgICAgICAgY29udGVudFR5cGU6IGl0ZW0/LnR5cGUsXHJcbiAgICAgICAgY29udGVudDogYXdhaXQgdGhpcy50b0Jhc2U2NChpdGVtKVxyXG4gICAgICB9O1xyXG4gICAgICBhcnIucHVzaChhdXgpO1xyXG4gICAgfVxyXG4gICAgdGhpcy5jb250cm9sLmdldChmaWxlTmFtZSk/LnNldFZhbHVlKGFycik7XHJcbiAgfVxyXG5cclxuICBvblJlbW92ZShldmVudDogRmlsZSwgZmlsZU5hbWU6IHN0cmluZykge1xyXG4gICAgdGhpcy5maWxlc1ZpZXcuc3BsaWNlKHRoaXMuZmlsZXNWaWV3LmluZGV4T2YoZXZlbnQpLCAxKTtcclxuICAgIHZhciBpbnB1dCA9IGRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCdmaWxlSW5wdXQnKSBhcyBIVE1MSW5wdXRFbGVtZW50XHJcbiAgICBpZiAoaW5wdXQpIHtcclxuICAgICAgaW5wdXQudmFsdWUgPSAnJ1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgZmlsdGVyQXV0b0NvbXBsZXRlKGV2ZW50OiB7IHF1ZXJ5OiBhbnk7IH0sIHN1Z2dlc3Rpb25zQXV0b0NvbXBsZXRlOiBhbnkpIHtcclxuICAgIGxldCBmaWx0ZXJlZDogYW55W10gPSBbXTtcclxuICAgIGxldCBxdWVyeSA9IGV2ZW50LnF1ZXJ5O1xyXG5cclxuICAgIGlmIChzdWdnZXN0aW9uc0F1dG9Db21wbGV0ZSkge1xyXG4gICAgICBmb3IgKGxldCBpID0gMDsgaSA8IHN1Z2dlc3Rpb25zQXV0b0NvbXBsZXRlLmxlbmd0aDsgaSsrKSB7XHJcbiAgICAgICAgbGV0IGRhZG9zID0gc3VnZ2VzdGlvbnNBdXRvQ29tcGxldGVbaV07XHJcbiAgICAgICAgaWYgKGRhZG9zLmRlc2NyaXB0aW9uLnRvTG93ZXJDYXNlKCkubm9ybWFsaXplKCdORkQnKS5yZXBsYWNlKC9cXHB7TX0vdWcsICcnKS5pbmRleE9mKHF1ZXJ5LnRvTG93ZXJDYXNlKCkubm9ybWFsaXplKCdORkQnKS5yZXBsYWNlKC9cXHB7TX0vdWcsICcnKSkgIT0gLTEpIHtcclxuICAgICAgICAgIGZpbHRlcmVkLnB1c2goZGFkb3MpO1xyXG4gICAgICAgIH1cclxuICAgICAgfVxyXG5cclxuICAgICAgdGhpcy5maWx0ZXJlZEF1dG9Db21wbGV0ZSA9IGZpbHRlcmVkO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgdG9CYXNlNjQgPSBhc3luYyAoZmlsZTogRmlsZSkgPT4ge1xyXG4gICAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCBfKSA9PiB7XHJcbiAgICAgIGNvbnN0IHJlYWRlciA9IG5ldyBGaWxlUmVhZGVyKCk7XHJcbiAgICAgIHJlYWRlci5vbmxvYWRlbmQgPSAoKSA9PiByZXNvbHZlKHJlYWRlci5yZXN1bHQpO1xyXG4gICAgICByZWFkZXIucmVhZEFzRGF0YVVSTChmaWxlKTtcclxuICAgIH0pO1xyXG4gIH1cclxuXHJcbiAgb25DaGFuZ2UoY2hhbmdlPzogRnVuY3Rpb24pIHtcclxuICAgIGlmIChjaGFuZ2UpIHtcclxuICAgICAgY2hhbmdlKClcclxuICAgIH1cclxuICB9XHJcblxyXG4gIGNsaWNrQ0xlYXIoY2xlYXI/OiBGdW5jdGlvbikge1xyXG4gICAgaWYgKGNsZWFyKSB7XHJcbiAgICAgIGNsZWFyKClcclxuICAgIH1cclxuICB9XHJcblxyXG4gIG9uQmx1cihibHVyPzogRnVuY3Rpb24pIHtcclxuICAgIGlmIChibHVyKSB7XHJcbiAgICAgIGJsdXIoKVxyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iLCI8ZGl2PlxyXG4gIDxkaXYgKm5nSWY9XCJ0aXRsZVwiIGNsYXNzPVwiZGl2LXRpdGxlXCI+XHJcbiAgICA8c3BhbiB0cmFuc2xhdGU9XCJ7eyB0aXRsZSB9fVwiPjwvc3Bhbj5cclxuICAgIDxkaXYgKm5nSWY9XCJzdWJUaXRsZVwiIGNsYXNzPVwiZmxleCBzdWJ0aXRsZVwiPlxyXG4gICAgICA8c3BhbiB0cmFuc2xhdGU9XCJ7eyBzdWJUaXRsZSB9fVwiPjwvc3Bhbj5cclxuICAgIDwvZGl2PlxyXG4gICAgPHAtZGl2aWRlcj48L3AtZGl2aWRlcj5cclxuICA8L2Rpdj5cclxuICA8Zm9ybSAqbmdJZj1cImNvbnRyb2xcIiBbZm9ybUdyb3VwXT1cImNvbnRyb2xcIj5cclxuICAgIDxkaXYgY2xhc3M9XCJncmlkXCI+XHJcbiAgICAgIDxkaXYgKm5nRm9yPVwibGV0IGl0ZW0gb2YgZm9ybVwiIGNsYXNzPVwie3sgaXRlbS5jb2wgfX0gY29sLTEyXCI+XHJcbiAgICAgICAgPGxhYmVsICpuZ0lmPVwiaXRlbS5sYWJlbCAmJiAhaXRlbS5oaWRlTGFiZWxUb3BcIj57eyBpdGVtLmxhYmVsIH19PC9sYWJlbD5cclxuICAgICAgICA8bGFiZWwgKm5nSWY9XCJpdGVtLnJlcXVpcmVkICYmIGl0ZW0ubGFiZWxcIiBjbGFzcz1cImRhbmdlci10ZXh0IG1sLTJcIlxyXG4gICAgICAgICAgPio8L2xhYmVsXHJcbiAgICAgICAgPlxyXG5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwibXQtMlwiPlxyXG4gICAgICAgICAgPCEtLSB0ZXh0IC0tPlxyXG4gICAgICAgICAgPGlucHV0XHJcbiAgICAgICAgICAgIGlkPVwie3sgaXRlbS5pZCB9fVwiXHJcbiAgICAgICAgICAgIFtuZ0NsYXNzXT1cIntcclxuICAgICAgICAgICAgICAnbmctaW52YWxpZCBuZy1kaXJ0eSc6XHJcbiAgICAgICAgICAgICAgICB2YWxpZGF0ZUZvcm0gJiYgY29udHJvbC5jb250cm9sc1tpdGVtLmZvcm1Db250cm9sXS5lcnJvcnNcclxuICAgICAgICAgICAgfVwiXHJcbiAgICAgICAgICAgIHBJbnB1dFRleHRcclxuICAgICAgICAgICAgcGxhY2Vob2xkZXI9XCJ7eyBpdGVtLnBsYWNlaG9sZGVyIH19XCJcclxuICAgICAgICAgICAgKm5nSWY9XCJpdGVtLnR5cGUgPT0gJ3RleHQnIHx8IGl0ZW0udHlwZSA9PSAnbnVtYmVyJ1wiXHJcbiAgICAgICAgICAgIHR5cGU9XCJ7eyBpdGVtLnR5cGUgfX1cIlxyXG4gICAgICAgICAgICBmb3JtQ29udHJvbE5hbWU9XCJ7eyBpdGVtLmZvcm1Db250cm9sIH19XCJcclxuICAgICAgICAgICAgY2xhc3M9XCJ3LWZ1bGxcIlxyXG4gICAgICAgICAgLz5cclxuXHJcbiAgICAgICAgICA8cC1lZGl0b3JcclxuICAgICAgICAgICAgKm5nSWY9XCJpdGVtLnR5cGUgPT0gJ2VkaXRvcidcIlxyXG4gICAgICAgICAgICBmb3JtQ29udHJvbE5hbWU9XCJ7eyBpdGVtLmZvcm1Db250cm9sIH19XCJcclxuICAgICAgICAgICAgW3N0eWxlXT1cInsgaGVpZ2h0OiAnMzIwcHgnIH1cIlxyXG4gICAgICAgICAgLz5cclxuXHJcbiAgICAgICAgICA8IS0tIHNlbGVjdCAtLT5cclxuICAgICAgICAgIDxwLWRyb3Bkb3duXHJcbiAgICAgICAgICAgIGlkPVwie3sgaXRlbS5pZCB9fVwiXHJcbiAgICAgICAgICAgIFtuZ0NsYXNzXT1cIntcclxuICAgICAgICAgICAgICAnbmctaW52YWxpZCBuZy1kaXJ0eSc6XHJcbiAgICAgICAgICAgICAgICB2YWxpZGF0ZUZvcm0gJiYgY29udHJvbC5jb250cm9sc1tpdGVtLmZvcm1Db250cm9sXS5lcnJvcnNcclxuICAgICAgICAgICAgfVwiXHJcbiAgICAgICAgICAgIFtmaWx0ZXJdPVwiaXRlbS5zZWFyY2hcIlxyXG4gICAgICAgICAgICBlbXB0eUZpbHRlck1lc3NhZ2U9XCJOZW5odW0gZGFkbyBlbmNvbnRyYWRvXCJcclxuICAgICAgICAgICAgZW1wdHlNZXNzYWdlPVwiTmVuaHVtIGRhZG8gZW5jb250cmFkb1wiXHJcbiAgICAgICAgICAgIHBsYWNlaG9sZGVyPVwie3sgaXRlbS5wbGFjZWhvbGRlciB9fVwiXHJcbiAgICAgICAgICAgIHN0eWxlQ2xhc3M9XCJ3LWZ1bGwgcC0wXCJcclxuICAgICAgICAgICAgKG9uQ2hhbmdlKT1cIm9uQ2hhbmdlKGl0ZW0ub25DaGFuZ2UpXCJcclxuICAgICAgICAgICAgKm5nSWY9XCJpdGVtLnR5cGUgPT09ICdzZWxlY3QnXCJcclxuICAgICAgICAgICAgW3Nob3dDbGVhcl09XCJ0cnVlXCJcclxuICAgICAgICAgICAgW29wdGlvbnNdPVwiaXRlbS5vcHRpb25zXCJcclxuICAgICAgICAgICAgZm9ybUNvbnRyb2xOYW1lPVwie3sgaXRlbS5mb3JtQ29udHJvbCB9fVwiXHJcbiAgICAgICAgICAgIG9wdGlvbkxhYmVsPVwiZGVzY3JpcHRpb25cIlxyXG4gICAgICAgICAgICAob25DbGVhcik9XCJjbGlja0NMZWFyKGl0ZW0ub25DTGVhcilcIlxyXG4gICAgICAgICAgPjwvcC1kcm9wZG93bj5cclxuXHJcbiAgICAgICAgICA8IS0tIGN1cnJlbmN5ICAtLT5cclxuICAgICAgICAgIDxwLWlucHV0TnVtYmVyXHJcbiAgICAgICAgICAgIGlkPVwie3sgaXRlbS5pZCB9fVwiXHJcbiAgICAgICAgICAgICpuZ0lmPVwiaXRlbS50eXBlID09PSAnY3VycmVuY3knXCJcclxuICAgICAgICAgICAgW25nQ2xhc3NdPVwie1xyXG4gICAgICAgICAgICAgICduZy1pbnZhbGlkIG5nLWRpcnR5JzpcclxuICAgICAgICAgICAgICAgIHZhbGlkYXRlRm9ybSAmJiBjb250cm9sLmNvbnRyb2xzW2l0ZW0uZm9ybUNvbnRyb2xdLmVycm9yc1xyXG4gICAgICAgICAgICB9XCJcclxuICAgICAgICAgICAgZm9ybUNvbnRyb2xOYW1lPVwie3sgaXRlbS5mb3JtQ29udHJvbCB9fVwiXHJcbiAgICAgICAgICAgIHBsYWNlaG9sZGVyPVwie3sgaXRlbS5wbGFjZWhvbGRlciB9fVwiXHJcbiAgICAgICAgICAgIGlucHV0U3R5bGVDbGFzcz1cInctZnVsbFwiXHJcbiAgICAgICAgICAgIHN0eWxlQ2xhc3M9XCJ3LWZ1bGxcIlxyXG4gICAgICAgICAgICAob25LZXlEb3duKT1cIm9uQ2hhbmdlKGl0ZW0ub25DaGFuZ2UpXCJcclxuICAgICAgICAgICAgbW9kZT1cImN1cnJlbmN5XCJcclxuICAgICAgICAgICAgW21pbl09XCIwXCJcclxuICAgICAgICAgICAgY3VycmVuY3k9XCJCUkxcIlxyXG4gICAgICAgICAgPlxyXG4gICAgICAgICAgPC9wLWlucHV0TnVtYmVyPlxyXG5cclxuICAgICAgICAgIDwhLS0gbWFzayAgLS0+XHJcbiAgICAgICAgICA8cC1pbnB1dE1hc2tcclxuICAgICAgICAgICAgaWQ9XCJ7eyBpdGVtLmlkIH19XCJcclxuICAgICAgICAgICAgKm5nSWY9XCJpdGVtLnR5cGUgPT09ICdtYXNrJ1wiXHJcbiAgICAgICAgICAgIFtuZ0NsYXNzXT1cIntcclxuICAgICAgICAgICAgICAnbmctaW52YWxpZCBuZy1kaXJ0eSc6XHJcbiAgICAgICAgICAgICAgICB2YWxpZGF0ZUZvcm0gJiYgY29udHJvbC5jb250cm9sc1tpdGVtLmZvcm1Db250cm9sXS5lcnJvcnNcclxuICAgICAgICAgICAgfVwiXHJcbiAgICAgICAgICAgIGZvcm1Db250cm9sTmFtZT1cInt7IGl0ZW0uZm9ybUNvbnRyb2wgfX1cIlxyXG4gICAgICAgICAgICBwbGFjZWhvbGRlcj1cInt7IGl0ZW0ucGxhY2Vob2xkZXIgfX1cIlxyXG4gICAgICAgICAgICBzdHlsZUNsYXNzPVwidy1mdWxsXCJcclxuICAgICAgICAgICAgKG9uQ29tcGxldGUpPVwib25DaGFuZ2UoaXRlbS5vbkNoYW5nZSlcIlxyXG4gICAgICAgICAgICBtYXNrPVwie3sgaXRlbS5tYXNrIH19XCJcclxuICAgICAgICAgICAgdW5tYXNrPVwie3sgaXRlbS51bm1hc2sgfX1cIlxyXG4gICAgICAgICAgICAob25DbGVhcik9XCJjbGlja0NMZWFyKGl0ZW0ub25DTGVhcilcIlxyXG4gICAgICAgICAgICBzaG93Q2xlYXI9XCJ0cnVlXCJcclxuICAgICAgICAgID48L3AtaW5wdXRNYXNrPlxyXG5cclxuICAgICAgICAgIDwhLS0gdHJlZVNlbGVjdCAtLT5cclxuICAgICAgICAgIDxwLXRyZWVTZWxlY3RcclxuICAgICAgICAgICAgaWQ9XCJ7eyBpdGVtLmlkIH19XCJcclxuICAgICAgICAgICAgW25nQ2xhc3NdPVwie1xyXG4gICAgICAgICAgICAgICduZy1pbnZhbGlkIG5nLWRpcnR5JzpcclxuICAgICAgICAgICAgICAgIHZhbGlkYXRlRm9ybSAmJiBjb250cm9sLmNvbnRyb2xzW2l0ZW0uZm9ybUNvbnRyb2xdLmVycm9yc1xyXG4gICAgICAgICAgICB9XCJcclxuICAgICAgICAgICAgcGxhY2Vob2xkZXI9XCJ7eyBpdGVtLnBsYWNlaG9sZGVyIH19XCJcclxuICAgICAgICAgICAgKG9uTm9kZVNlbGVjdCk9XCJvbkNoYW5nZShpdGVtLm9uQ2hhbmdlKVwiXHJcbiAgICAgICAgICAgICpuZ0lmPVwiaXRlbS50eXBlID09PSAndHJlZS1zZWxlY3QnXCJcclxuICAgICAgICAgICAgY29udGFpbmVyU3R5bGVDbGFzcz1cInctZnVsbCBwLTBcIlxyXG4gICAgICAgICAgICBmb3JtQ29udHJvbE5hbWU9XCJ7eyBpdGVtLmZvcm1Db250cm9sIH19XCJcclxuICAgICAgICAgICAgW29wdGlvbnNdPVwiaXRlbS50cmVlU2VsZWN0T3B0aW9uc1wiXHJcbiAgICAgICAgICAgIFtmaWx0ZXJdPVwidHJ1ZVwiXHJcbiAgICAgICAgICAgIFtmaWx0ZXJJbnB1dEF1dG9Gb2N1c109XCJ0cnVlXCJcclxuICAgICAgICAgICAgZW1wdHlNZXNzYWdlPVwiTmVuaHVtIGRhZG8gZW5jb250cmFkb1wiXHJcbiAgICAgICAgICAgIFtzaG93Q2xlYXJdPVwidHJ1ZVwiXHJcbiAgICAgICAgICAgIChvbkNsZWFyKT1cImNsaWNrQ0xlYXIoaXRlbS5vbkNMZWFyKVwiXHJcbiAgICAgICAgICA+PC9wLXRyZWVTZWxlY3Q+XHJcblxyXG4gICAgICAgICAgPCEtLSBhdXRvQ29tcGxldGUgLS0+XHJcbiAgICAgICAgICA8cC1hdXRvQ29tcGxldGVcclxuICAgICAgICAgICAgaW5wdXRJZD1cInt7IGl0ZW0uaWQgfX1cIlxyXG4gICAgICAgICAgICBbbmdDbGFzc109XCJ7XHJcbiAgICAgICAgICAgICAgJ25nLWludmFsaWQgbmctZGlydHknOlxyXG4gICAgICAgICAgICAgICAgdmFsaWRhdGVGb3JtICYmIGNvbnRyb2wuY29udHJvbHNbaXRlbS5mb3JtQ29udHJvbF0uZXJyb3JzXHJcbiAgICAgICAgICAgIH1cIlxyXG4gICAgICAgICAgICBwbGFjZWhvbGRlcj1cInt7IGl0ZW0ucGxhY2Vob2xkZXIgfX1cIlxyXG4gICAgICAgICAgICBzdHlsZUNsYXNzPVwidy1mdWxsIHAtMFwiXHJcbiAgICAgICAgICAgIFtpbnB1dFN0eWxlXT1cInsgd2lkdGg6ICcxMDAlJyB9XCJcclxuICAgICAgICAgICAgKm5nSWY9XCJpdGVtLnR5cGUgPT09ICdhdXRvY29tcGxldGUnXCJcclxuICAgICAgICAgICAgKG9uU2VsZWN0KT1cIm9uQ2hhbmdlKGl0ZW0ub25DaGFuZ2UpXCJcclxuICAgICAgICAgICAgZm9ybUNvbnRyb2xOYW1lPVwie3sgaXRlbS5mb3JtQ29udHJvbCB9fVwiXHJcbiAgICAgICAgICAgIFtzdWdnZXN0aW9uc109XCJmaWx0ZXJlZEF1dG9Db21wbGV0ZVwiXHJcbiAgICAgICAgICAgIChjb21wbGV0ZU1ldGhvZCk9XCJmaWx0ZXJBdXRvQ29tcGxldGUoJGV2ZW50LCBpdGVtLm9wdGlvbnMpXCJcclxuICAgICAgICAgICAgW2ZvcmNlU2VsZWN0aW9uXT1cImZhbHNlXCJcclxuICAgICAgICAgICAgW3Nob3dFbXB0eU1lc3NhZ2VdPVwidHJ1ZVwiXHJcbiAgICAgICAgICAgIGVtcHR5TWVzc2FnZT1cIk5lbmh1bSBkYWRvIGVuY29udHJhZG9cIlxyXG4gICAgICAgICAgICBkYXRhS2V5PVwiY29kZVwiXHJcbiAgICAgICAgICAgIGZpZWxkPVwiZGVzY3JpcHRpb25cIlxyXG4gICAgICAgICAgICBzaG93Q2xlYXI9XCJ0cnVlXCJcclxuICAgICAgICAgICAgKG9uQ2xlYXIpPVwiY2xpY2tDTGVhcihpdGVtLm9uQ0xlYXIpXCJcclxuICAgICAgICAgID48L3AtYXV0b0NvbXBsZXRlPlxyXG5cclxuICAgICAgICAgIDwhLS0gZGF0ZSAtLT5cclxuICAgICAgICAgIDxwLWNhbGVuZGFyXHJcbiAgICAgICAgICAgIGlkPVwie3sgaXRlbS5pZCB9fVwiXHJcbiAgICAgICAgICAgIHZpZXc9XCJ7eyBpdGVtLnZpZXdEYXRlIH19XCJcclxuICAgICAgICAgICAgKm5nSWY9XCJpdGVtLnR5cGUgPT09ICdkYXRlJ1wiXHJcbiAgICAgICAgICAgIFtuZ0NsYXNzXT1cIntcclxuICAgICAgICAgICAgICAnbmctaW52YWxpZCBuZy1kaXJ0eSc6XHJcbiAgICAgICAgICAgICAgICB2YWxpZGF0ZUZvcm0gJiYgY29udHJvbC5jb250cm9sc1tpdGVtLmZvcm1Db250cm9sXS5lcnJvcnNcclxuICAgICAgICAgICAgfVwiXHJcbiAgICAgICAgICAgIGZvcm1Db250cm9sTmFtZT1cInt7IGl0ZW0uZm9ybUNvbnRyb2wgfX1cIlxyXG4gICAgICAgICAgICBzdHlsZUNsYXNzPVwidy1mdWxsXCJcclxuICAgICAgICAgICAgW251bWJlck9mTW9udGhzXT1cIm51bWJlck9mTW9udGhzRGF0ZShpdGVtLm51bWJlck9mTW9udGhzRGF0ZSlcIlxyXG4gICAgICAgICAgICBbc2VsZWN0aW9uTW9kZV09XCJzZWxlY3Rpb25Nb2RlKGl0ZW0uc2VsZWN0aW9uTW9kZSlcIlxyXG4gICAgICAgICAgICAob25Gb2N1cyk9XCJvbkNoYW5nZShpdGVtLm9uRm9jdXNEYXRlKVwiXHJcbiAgICAgICAgICAgIFttYXhEYXRlXT1cIml0ZW0ubWF4RGF0ZVwiXHJcbiAgICAgICAgICAgIFttaW5EYXRlXT1cIml0ZW0ubWluRGF0ZVwiXHJcbiAgICAgICAgICAgIGRhdGVGb3JtYXQ9XCJ7eyBpdGVtLmRhdGVGb3JtYXQgfX1cIlxyXG4gICAgICAgICAgICAob25TZWxlY3QpPVwib25DaGFuZ2UoaXRlbS5vbkNoYW5nZSlcIlxyXG4gICAgICAgICAgICBbaWNvbkRpc3BsYXldPVwiJ2lucHV0J1wiXHJcbiAgICAgICAgICAgIHBsYWNlaG9sZGVyPVwie3sgaXRlbS5wbGFjZWhvbGRlciB9fVwiXHJcbiAgICAgICAgICAgIFtzaG93SWNvbl09XCJ0cnVlXCJcclxuICAgICAgICAgICAgW3Nob3dUaW1lXT1cIml0ZW0uc2hvd1RpbWVcIlxyXG4gICAgICAgICAgICBbdGltZU9ubHldPVwiaXRlbS50aW1lT25seVwiXHJcbiAgICAgICAgICA+PC9wLWNhbGVuZGFyPlxyXG5cclxuICAgICAgICAgIDwhLS0gdGV4dGFyZWEgLS0+XHJcbiAgICAgICAgICA8ZGl2ICpuZ0lmPVwiaXRlbS50eXBlID09PSAndGV4dC1hcmVhJ1wiIGNsYXNzPVwidGV4dC1yaWdodFwiPlxyXG4gICAgICAgICAgICA8dGV4dGFyZWFcclxuICAgICAgICAgICAgICBpZD1cInt7IGl0ZW0uaWQgfX1cIlxyXG4gICAgICAgICAgICAgIFtuZ0NsYXNzXT1cIntcclxuICAgICAgICAgICAgICAgICduZy1pbnZhbGlkIG5nLWRpcnR5JzpcclxuICAgICAgICAgICAgICAgICAgdmFsaWRhdGVGb3JtICYmIGNvbnRyb2wuY29udHJvbHNbaXRlbS5mb3JtQ29udHJvbF0uZXJyb3JzXHJcbiAgICAgICAgICAgICAgfVwiXHJcbiAgICAgICAgICAgICAgcGxhY2Vob2xkZXI9XCJ7eyBpdGVtLnBsYWNlaG9sZGVyIH19XCJcclxuICAgICAgICAgICAgICBjbGFzcz1cInctZnVsbFwiXHJcbiAgICAgICAgICAgICAgbWF4bGVuZ3RoPVwie3sgaXRlbS5tYXhsZW5ndGggfX1cIlxyXG4gICAgICAgICAgICAgIGNvdW50ZXJUZW1wbGF0ZT1cInsxfSBvZiA1MCwgezB9IHJlbWFpbmluZ1wiXHJcbiAgICAgICAgICAgICAgY291bnRlcj1cImRpc3BsYXlcIlxyXG4gICAgICAgICAgICAgIChhdHRyLmNoYW5nZSk9XCJvbkNoYW5nZShpdGVtLm9uQ2hhbmdlKVwiXHJcbiAgICAgICAgICAgICAgcElucHV0VGV4dGFyZWFcclxuICAgICAgICAgICAgICBmb3JtQ29udHJvbE5hbWU9XCJ7eyBpdGVtLmZvcm1Db250cm9sIH19XCJcclxuICAgICAgICAgICAgICByb3dzPVwie3sgaXRlbS5yb3dzVGV4dEFyZWEgfX1cIlxyXG4gICAgICAgICAgICA+PC90ZXh0YXJlYT5cclxuICAgICAgICAgICAgPHNtYWxsICpuZ0lmPVwiaXRlbS5tYXhsZW5ndGhcIiBpZD1cInVzZXJuYW1lLWhlbHBcIj5cclxuICAgICAgICAgICAgICB7eyBjb250cm9sLmNvbnRyb2xzW2l0ZW0uZm9ybUNvbnRyb2xdLnZhbHVlLmxlbmd0aCB9fS97e1xyXG4gICAgICAgICAgICAgICAgaXRlbS5tYXhsZW5ndGhcclxuICAgICAgICAgICAgICB9fVxyXG4gICAgICAgICAgICA8L3NtYWxsPlxyXG4gICAgICAgICAgPC9kaXY+XHJcblxyXG4gICAgICAgICAgPCEtLSBjaGVja2JveCAtLT5cclxuICAgICAgICAgIDxkaXYgKm5nSWY9XCJpdGVtLnR5cGUgPT0gJ2NoZWNrLWJveCdcIj5cclxuICAgICAgICAgICAgPHAtY2hlY2tib3hcclxuICAgICAgICAgICAgICBpZD1cInt7IGl0ZW0uaWQgfX1cIlxyXG4gICAgICAgICAgICAgIFtuZ0NsYXNzXT1cIntcclxuICAgICAgICAgICAgICAgICduZy1pbnZhbGlkIG5nLWRpcnR5JzpcclxuICAgICAgICAgICAgICAgICAgdmFsaWRhdGVGb3JtICYmIGNvbnRyb2wuY29udHJvbHNbaXRlbS5mb3JtQ29udHJvbF0uZXJyb3JzXHJcbiAgICAgICAgICAgICAgfVwiXHJcbiAgICAgICAgICAgICAgKG9uQ2hhbmdlKT1cIm9uQ2hhbmdlKGl0ZW0ub25DaGFuZ2UpXCJcclxuICAgICAgICAgICAgICBiaW5hcnk9XCJ0cnVlXCJcclxuICAgICAgICAgICAgICBmb3JtQ29udHJvbE5hbWU9XCJ7eyBpdGVtLmZvcm1Db250cm9sIH19XCJcclxuICAgICAgICAgICAgICB2YWx1ZT1cInt7IGl0ZW0uZm9ybUNvbnRyb2wgfX1cIlxyXG4gICAgICAgICAgICAgIGxhYmVsPVwie3sgaXRlbS5sYWJlbCB9fVwiXHJcbiAgICAgICAgICAgID48L3AtY2hlY2tib3g+XHJcbiAgICAgICAgICA8L2Rpdj5cclxuXHJcbiAgICAgICAgICA8IS0tIGNoZWNrYm94ICBtdWx0aXBsZSAtLT5cclxuICAgICAgICAgIDxkaXZcclxuICAgICAgICAgICAgaWQ9XCJ7eyBpdGVtLmlkIH19XCJcclxuICAgICAgICAgICAgKm5nSWY9XCJpdGVtLnR5cGUgPT09ICdjaGVjay1ib3gtbXVsdGknXCJcclxuICAgICAgICAgICAgY2xhc3M9XCJmbGV4IGdhcC0zXCJcclxuICAgICAgICAgID5cclxuICAgICAgICAgICAgPGRpdlxyXG4gICAgICAgICAgICAgIGZvcm1BcnJheU5hbWU9XCJ7eyBpdGVtLmZvcm1Db250cm9sIH19XCJcclxuICAgICAgICAgICAgICAqbmdGb3I9XCJsZXQgbGlzdCBvZiBpdGVtLm9wdGlvbnM7IGxldCBpID0gaW5kZXhcIlxyXG4gICAgICAgICAgICAgIGNsYXNzPVwiZmxleCBhbGlnbi1pdGVtcy1jZW50ZXIgZ2FwLTJcIlxyXG4gICAgICAgICAgICA+XHJcbiAgICAgICAgICAgICAgPGRpdiBbZm9ybUdyb3VwTmFtZV09XCJpXCI+XHJcbiAgICAgICAgICAgICAgICA8cC1jaGVja2JveFxyXG4gICAgICAgICAgICAgICAgICBpZD1cInt7IGl0ZW0uaWQgfX1cIlxyXG4gICAgICAgICAgICAgICAgICBbbmdDbGFzc109XCJ7XHJcbiAgICAgICAgICAgICAgICAgICAgJ25nLWludmFsaWQgbmctZGlydHknOlxyXG4gICAgICAgICAgICAgICAgICAgICAgdmFsaWRhdGVGb3JtICYmIGNvbnRyb2wuY29udHJvbHNbaXRlbS5mb3JtQ29udHJvbF0uZXJyb3JzXHJcbiAgICAgICAgICAgICAgICAgIH1cIlxyXG4gICAgICAgICAgICAgICAgICAob25DaGFuZ2UpPVwib25DaGFuZ2UoaXRlbS5vbkNoYW5nZSlcIlxyXG4gICAgICAgICAgICAgICAgICBiaW5hcnk9XCJ0cnVlXCJcclxuICAgICAgICAgICAgICAgICAgZm9ybUNvbnRyb2xOYW1lPVwie3sgbGlzdC5jb2RlIH19XCJcclxuICAgICAgICAgICAgICAgICAgbGFiZWw9XCJ7eyBsaXN0LmRlc2NyaXB0aW9uIH19XCJcclxuICAgICAgICAgICAgICAgID48L3AtY2hlY2tib3g+XHJcbiAgICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgPC9kaXY+XHJcblxyXG4gICAgICAgICAgPCEtLSBidXR0b24gLS0+XHJcbiAgICAgICAgICA8cC1idXR0b25cclxuICAgICAgICAgICAgaWQ9XCJ7eyBpdGVtLmlkIH19XCJcclxuICAgICAgICAgICAgKm5nSWY9XCJpdGVtLnR5cGUgPT0gJ2J1dHRvbidcIlxyXG4gICAgICAgICAgICBzdHlsZUNsYXNzPVwie3sgaXRlbS5idXR0b25DbGFzcyB9fSB3LWZ1bGwgbXQtM1wiXHJcbiAgICAgICAgICAgIChjbGljayk9XCJpdGVtLm9uQ0xpY2soKVwiXHJcbiAgICAgICAgICAgIFtkaXNhYmxlZF09XCJpdGVtLmRpc2FibGVkXCJcclxuICAgICAgICAgICAgaWNvbj1cInt7IGl0ZW0uaWNvbkJ1dHRvbiB9fVwiXHJcbiAgICAgICAgICAgIGxhYmVsPVwie3sgaXRlbS5sYWJlbCB9fVwiXHJcbiAgICAgICAgICA+PC9wLWJ1dHRvbj5cclxuXHJcbiAgICAgICAgICA8IS0tIGNhbiAgLS0+XHJcbiAgICAgICAgICA8ZGl2IGlkPVwie3sgaXRlbS5pZCB9fVwiIGNsYXNzPVwiYXJlYVwiICpuZ0lmPVwiaXRlbS50eXBlID09ICdjYW4nXCI+XHJcbiAgICAgICAgICAgIDx2aWRlbyBhdXRvcGxheT1cInRydWVcIiBpZD1cIndlYkNhbWVyYVwiPjwvdmlkZW8+XHJcblxyXG4gICAgICAgICAgICA8aW5wdXQgdHlwZT1cInRleHRcIiBpZD1cImJhc2VfaW1nXCIgbmFtZT1cImJhc2VfaW1nXCIgLz5cclxuICAgICAgICAgICAgPGJ1dHRvbiB0eXBlPVwiYnV0dG9uXCIgb25jbGljaz1cInRha2VTbmFwU2hvdCgpXCI+XHJcbiAgICAgICAgICAgICAgVGlyYXIgZm90byBlIHNhbHZhclxyXG4gICAgICAgICAgICA8L2J1dHRvbj5cclxuXHJcbiAgICAgICAgICAgIDxpbWcgaWQ9XCJpbWFnZW1Db252ZXJ0aWRhXCIgLz5cclxuICAgICAgICAgICAgPHAgaWQ9XCJjYW1pbmhvSW1hZ2VtXCIgY2xhc3M9XCJjYW1pbmhvLWltYWdlbVwiPlxyXG4gICAgICAgICAgICAgIDxhIGhyZWY9XCJcIiB0YXJnZXQ9XCJfYmxhbmtcIiByZWw9XCJub29wZW5lclwiPjwvYT5cclxuICAgICAgICAgICAgPC9wPlxyXG4gICAgICAgICAgICA8c2NyaXB0IHNyYz1cInNjcmlwdC5qc1wiPjwvc2NyaXB0PlxyXG4gICAgICAgICAgPC9kaXY+XHJcblxyXG4gICAgICAgICAgPCEtLSB1cGxvYWQgZmlsZXMgLS0+XHJcbiAgICAgICAgICA8ZGl2XHJcbiAgICAgICAgICAgIGlkPVwie3sgaXRlbS5pZCB9fVwiXHJcbiAgICAgICAgICAgICpuZ0lmPVwiaXRlbS50eXBlID09PSAndXBsb2FkLWZpbGVzJyAmJiAhaXRlbS5kaXNhYmxlZFwiXHJcbiAgICAgICAgICAgIGNsYXNzPVwiZHJhZy1pbWFnZVwiXHJcbiAgICAgICAgICAgIFtzdHlsZS5ib3JkZXJdPVwiXHJcbiAgICAgICAgICAgICAgdmFsaWRhdGVGb3JtICYmIGNvbnRyb2wuY29udHJvbHNbaXRlbS5mb3JtQ29udHJvbF0uZXJyb3JzXHJcbiAgICAgICAgICAgICAgICA/ICcgMXB4IGRhc2hlZCAjZjE4MjgyJ1xyXG4gICAgICAgICAgICAgICAgOiAnIDFweCBkYXNoZWQgI2QxZDVkYidcclxuICAgICAgICAgICAgXCJcclxuICAgICAgICAgID5cclxuICAgICAgICAgICAgPGkgKm5nSWY9XCJmaWxlc1ZpZXcubGVuZ3RoID09PSAwXCIgY2xhc3M9XCJwaSBwaS1jbG91ZC11cGxvYWRcIj48L2k+XHJcbiAgICAgICAgICAgIDxwICpuZ0lmPVwiZmlsZXNWaWV3Lmxlbmd0aCA9PT0gMFwiPlxyXG4gICAgICAgICAgICAgIENsaXF1ZSBvdSBhcnJhc3RlIGUgc29sdGUgdW0gYXJxdWl2byBwYXJhIGFuZXhhclxyXG4gICAgICAgICAgICA8L3A+XHJcbiAgICAgICAgICAgIDxzcGFuICpuZ0lmPVwiZmlsZXNWaWV3Lmxlbmd0aCA9PT0gMFwiPnt7XHJcbiAgICAgICAgICAgICAgaXRlbS5tc2dBY2NlcHRGaWxlc1xyXG4gICAgICAgICAgICB9fTwvc3Bhbj5cclxuICAgICAgICAgICAgPGlucHV0XHJcbiAgICAgICAgICAgICAgaWQ9XCJmaWxlSW5wdXRcIlxyXG4gICAgICAgICAgICAgIHR5cGU9XCJmaWxlXCJcclxuICAgICAgICAgICAgICBbbXVsdGlwbGVdPVwiaXRlbS5tdWx0aWxlRmlsZVwiXHJcbiAgICAgICAgICAgICAgW2FjY2VwdF09XCJpdGVtLmFjY2VwdEZpbGVzXCJcclxuICAgICAgICAgICAgICAoY2hhbmdlKT1cIlxyXG4gICAgICAgICAgICAgICAgb25TZWxlY3RGaWxlKGl0ZW0uZm9ybUNvbnRyb2wsICRldmVudCwgaXRlbS5tdWx0aWxlRmlsZSlcclxuICAgICAgICAgICAgICBcIlxyXG4gICAgICAgICAgICAvPlxyXG4gICAgICAgICAgICA8ZGl2ICpuZ0Zvcj1cImxldCBmIG9mIGZpbGVzVmlld1wiPlxyXG4gICAgICAgICAgICAgIDxkaXYgKm5nSWY9XCJmLnR5cGUgJiYgZi50eXBlLmluY2x1ZGVzKCdpbWFnZScpXCI+XHJcbiAgICAgICAgICAgICAgICA8bGFiZWwgY2xhc3M9XCJwcmV2aWV3LWltZ1wiPlxyXG4gICAgICAgICAgICAgICAgICA8aW1nICpuZ0lmPVwiIWYuY29udGVudFwiIHNyYz1cInt7IGdldFVybChmKSB9fVwiIC8+XHJcbiAgICAgICAgICAgICAgICAgIDxpbWcgKm5nSWY9XCJmLmNvbnRlbnRcIiBzcmM9XCJ7eyBmLmNvbnRlbnQgfX1cIiAvPlxyXG4gICAgICAgICAgICAgICAgICA8c3BhbiAqbmdJZj1cIml0ZW0udmlld05hbWVGaWxlXCI+e3sgZi5uYW1lIH19PC9zcGFuPlxyXG4gICAgICAgICAgICAgICAgICA8aW5wdXRcclxuICAgICAgICAgICAgICAgICAgICB0eXBlPVwiZmlsZVwiXHJcbiAgICAgICAgICAgICAgICAgICAgW211bHRpcGxlXT1cIml0ZW0ubXVsdGlsZUZpbGVcIlxyXG4gICAgICAgICAgICAgICAgICAgIFthY2NlcHRdPVwiaXRlbS5hY2NlcHRGaWxlc1wiXHJcbiAgICAgICAgICAgICAgICAgICAgKGNoYW5nZSk9XCJcclxuICAgICAgICAgICAgICAgICAgICAgIG9uU2VsZWN0RmlsZShpdGVtLmZvcm1Db250cm9sLCAkZXZlbnQsIGl0ZW0ubXVsdGlsZUZpbGUpXHJcbiAgICAgICAgICAgICAgICAgICAgXCJcclxuICAgICAgICAgICAgICAgICAgLz5cclxuICAgICAgICAgICAgICAgICAgPGxhYmVsPlxyXG4gICAgICAgICAgICAgICAgICAgIDxpXHJcbiAgICAgICAgICAgICAgICAgICAgICBjbGFzcz1cInBpIHBpLXRpbWVzIHJlbW92ZS1maWxlIGFic29sdXRlXCJcclxuICAgICAgICAgICAgICAgICAgICAgIChjbGljayk9XCJvblJlbW92ZShpdGVtLmZvcm1Db250cm9sLCBmKVwiXHJcbiAgICAgICAgICAgICAgICAgICAgPjwvaVxyXG4gICAgICAgICAgICAgICAgICA+PC9sYWJlbD5cclxuICAgICAgICAgICAgICAgIDwvbGFiZWw+XHJcbiAgICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICAgICAgPGRpdiAqbmdJZj1cImYudHlwZSAmJiAhZi50eXBlLmluY2x1ZGVzKCdpbWFnZScpXCI+XHJcbiAgICAgICAgICAgICAgICA8bGFiZWwgY2xhc3M9XCJwcmV2aWV3LWltZyBoLTAgbWF4LXctMCBtaC03NSBtLTBcIj5cclxuICAgICAgICAgICAgICAgICAgPGxhYmVsIGNsYXNzPVwibXItM1wiPnt7IGYubmFtZSB9fTwvbGFiZWw+XHJcbiAgICAgICAgICAgICAgICAgIDxpbnB1dFxyXG4gICAgICAgICAgICAgICAgICAgIHR5cGU9XCJmaWxlXCJcclxuICAgICAgICAgICAgICAgICAgICBbbXVsdGlwbGVdPVwiaXRlbS5tdWx0aWxlRmlsZVwiXHJcbiAgICAgICAgICAgICAgICAgICAgW2FjY2VwdF09XCJpdGVtLmFjY2VwdEZpbGVzXCJcclxuICAgICAgICAgICAgICAgICAgICAoY2hhbmdlKT1cIlxyXG4gICAgICAgICAgICAgICAgICAgICAgb25TZWxlY3RGaWxlKGl0ZW0uZm9ybUNvbnRyb2wsICRldmVudCwgaXRlbS5tdWx0aWxlRmlsZSlcclxuICAgICAgICAgICAgICAgICAgICBcIlxyXG4gICAgICAgICAgICAgICAgICAvPlxyXG4gICAgICAgICAgICAgICAgICA8bGFiZWw+XHJcbiAgICAgICAgICAgICAgICAgICAgPGlcclxuICAgICAgICAgICAgICAgICAgICAgIGNsYXNzPVwicGkgcGktdGltZXMgcmVtb3ZlLWZpbGUgYWJzb2x1dGVcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgKGNsaWNrKT1cIm9uUmVtb3ZlKGYpXCJcclxuICAgICAgICAgICAgICAgICAgICA+PC9pXHJcbiAgICAgICAgICAgICAgICAgID48L2xhYmVsPlxyXG4gICAgICAgICAgICAgICAgPC9sYWJlbD5cclxuICAgICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICA8L2Rpdj5cclxuXHJcbiAgICAgICAgICA8IS0tIHVwbG9hZCBmaWxlcyBkaXNhYmxlZCAtLT5cclxuICAgICAgICAgIDwhLS0gPHAtZmlsZVVwbG9hZCBtb2RlPVwiYmFzaWNcIiBmb3JtQ29udHJvbE5hbWU9XCJ7e2l0ZW0uZm9ybUNvbnRyb2x9fVwiIGNob29zZUxhYmVsPVwiQ2hvb3NlXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgY2hvb3NlSWNvbj1cInBpIHBpLXVwbG9hZFwiIGFjY2VwdD1cImltYWdlLypcIiBtYXhGaWxlU2l6ZT1cIjEwMDAwMDBcIiAvPiAtLT5cclxuXHJcbiAgICAgICAgICA8ZGl2XHJcbiAgICAgICAgICAgIGlkPVwie3sgaXRlbS5pZCB9fVwiXHJcbiAgICAgICAgICAgICpuZ0lmPVwiaXRlbS50eXBlID09PSAndXBsb2FkLWZpbGVzJyAmJiBpdGVtLmRpc2FibGVkXCJcclxuICAgICAgICAgID5cclxuICAgICAgICAgICAgPHAtYnV0dG9uXHJcbiAgICAgICAgICAgICAgKGNsaWNrKT1cIm9wLnRvZ2dsZSgkZXZlbnQpXCJcclxuICAgICAgICAgICAgICBpY29uPVwicGkgcGktcGFwZXJjbGlwXCJcclxuICAgICAgICAgICAgICBsYWJlbD1cIkFycXVpdm9zIGFuZXhhZG9zXCJcclxuICAgICAgICAgICAgPjwvcC1idXR0b24+XHJcblxyXG4gICAgICAgICAgICA8cC1vdmVybGF5UGFuZWxcclxuICAgICAgICAgICAgICAjb3BcclxuICAgICAgICAgICAgICBbc3R5bGVdPVwieyB3aWR0aDogJzQ1MHB4JyB9XCJcclxuICAgICAgICAgICAgICBbc2hvd0Nsb3NlSWNvbl09XCJ0cnVlXCJcclxuICAgICAgICAgICAgPlxyXG4gICAgICAgICAgICAgIDxuZy10ZW1wbGF0ZSBwVGVtcGxhdGU9XCJjb250ZW50XCI+XHJcbiAgICAgICAgICAgICAgICA8cC10YWJsZVxyXG4gICAgICAgICAgICAgICAgICAqbmdJZj1cImZpbGVzLmxlbmd0aCA+IDBcIlxyXG4gICAgICAgICAgICAgICAgICBbdmFsdWVdPVwiZmlsZXNcIlxyXG4gICAgICAgICAgICAgICAgICBzZWxlY3Rpb25Nb2RlPVwic2luZ2xlXCJcclxuICAgICAgICAgICAgICAgICAgWyhzZWxlY3Rpb24pXT1cInNlbGVjdGVkUHJvZHVjdFwiXHJcbiAgICAgICAgICAgICAgICAgIChvblJvd1NlbGVjdCk9XCJvblJvd1NlbGVjdCgkZXZlbnQsIG9wKVwiXHJcbiAgICAgICAgICAgICAgICAgIHJlc3BvbnNpdmVMYXlvdXQ9XCJzY3JvbGxcIlxyXG4gICAgICAgICAgICAgICAgPlxyXG4gICAgICAgICAgICAgICAgICA8bmctdGVtcGxhdGUgcFRlbXBsYXRlPVwiaGVhZGVyXCI+XHJcbiAgICAgICAgICAgICAgICAgICAgPHRyPlxyXG4gICAgICAgICAgICAgICAgICAgICAgPHRoIHBTb3J0YWJsZUNvbHVtbj1cIm5hbWVcIj5cclxuICAgICAgICAgICAgICAgICAgICAgICAgTm9tZTxwLXNvcnRJY29uIGZpZWxkPVwibmFtZVwiPjwvcC1zb3J0SWNvbj5cclxuICAgICAgICAgICAgICAgICAgICAgIDwvdGg+XHJcbiAgICAgICAgICAgICAgICAgICAgICA8dGg+PC90aD5cclxuICAgICAgICAgICAgICAgICAgICA8L3RyPlxyXG4gICAgICAgICAgICAgICAgICA8L25nLXRlbXBsYXRlPlxyXG4gICAgICAgICAgICAgICAgICA8bmctdGVtcGxhdGUgcFRlbXBsYXRlPVwiYm9keVwiIGxldC1yb3dEYXRhIGxldC1maWxlPlxyXG4gICAgICAgICAgICAgICAgICAgIDx0cj5cclxuICAgICAgICAgICAgICAgICAgICAgIDx0ZCAqbmdJZj1cIml0ZW0udmlld05hbWVGaWxlXCI+e3sgZmlsZS5uYW1lIH19PC90ZD5cclxuICAgICAgICAgICAgICAgICAgICAgIDx0ZD5cclxuICAgICAgICAgICAgICAgICAgICAgICAgPHAtYnV0dG9uXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgKm5nSWY9XCJpdGVtLm9uQ0xpY2tcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgIGljb249XCJwaSBwaS1kb3dubG9hZFwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgKGNsaWNrKT1cIml0ZW0ub25DTGljayhmaWxlKVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgID48L3AtYnV0dG9uPlxyXG4gICAgICAgICAgICAgICAgICAgICAgPC90ZD5cclxuICAgICAgICAgICAgICAgICAgICA8L3RyPlxyXG4gICAgICAgICAgICAgICAgICA8L25nLXRlbXBsYXRlPlxyXG4gICAgICAgICAgICAgICAgPC9wLXRhYmxlPlxyXG4gICAgICAgICAgICAgICAgPGRpdiAqbmdJZj1cImZpbGVzLmxlbmd0aCA9PT0gMFwiIGNsYXNzPVwicC0xMFwiPlxyXG4gICAgICAgICAgICAgICAgICA8bGFiZWw+TmVuaHVtIGFycXVpdm8gYW5leGFkbzwvbGFiZWw+XHJcbiAgICAgICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgICA8L25nLXRlbXBsYXRlPlxyXG4gICAgICAgICAgICA8L3Atb3ZlcmxheVBhbmVsPlxyXG4gICAgICAgICAgPC9kaXY+XHJcblxyXG4gICAgICAgICAgPCEtLSBsaXN0IC0tPlxyXG4gICAgICAgICAgPHVsIGlkPVwie3sgaXRlbS5pZCB9fVwiICpuZ0lmPVwiaXRlbS50eXBlID09PSAnbGlzdCcgJiYgaXRlbS5vcHRpb25zXCI+XHJcbiAgICAgICAgICAgIDxsaSAqbmdGb3I9XCJsZXQgbGlzdCBvZiBpdGVtLm9wdGlvbnNcIj57eyBsaXN0LmRlc2NyaXB0aW9uIH19PC9saT5cclxuICAgICAgICAgIDwvdWw+XHJcblxyXG4gICAgICAgICAgPCEtLSBtdWx0aSAtLT5cclxuICAgICAgICAgIDxwLW11bHRpU2VsZWN0XHJcbiAgICAgICAgICAgIGlkPVwie3sgaXRlbS5pZCB9fVwiXHJcbiAgICAgICAgICAgIFtuZ0NsYXNzXT1cIntcclxuICAgICAgICAgICAgICAnbmctaW52YWxpZCBuZy1kaXJ0eSc6XHJcbiAgICAgICAgICAgICAgICB2YWxpZGF0ZUZvcm0gJiYgY29udHJvbC5jb250cm9sc1tpdGVtLmZvcm1Db250cm9sXS5lcnJvcnNcclxuICAgICAgICAgICAgfVwiXHJcbiAgICAgICAgICAgIHBsYWNlaG9sZGVyPVwie3sgaXRlbS5wbGFjZWhvbGRlciB9fVwiXHJcbiAgICAgICAgICAgICpuZ0lmPVwiaXRlbS50eXBlID09PSAnbXVsdGknXCJcclxuICAgICAgICAgICAgW29wdGlvbnNdPVwiaXRlbS5vcHRpb25zXCJcclxuICAgICAgICAgICAgZm9ybUNvbnRyb2xOYW1lPVwie3sgaXRlbS5mb3JtQ29udHJvbCB9fVwiXHJcbiAgICAgICAgICAgIHN0eWxlQ2xhc3M9XCJwLTAgdy1mdWxsXCJcclxuICAgICAgICAgICAgb3B0aW9uTGFiZWw9XCJkZXNjcmlwdGlvblwiXHJcbiAgICAgICAgICAgIChvbkNoYW5nZSk9XCJvbkNoYW5nZShpdGVtLm9uQ2hhbmdlKVwiXHJcbiAgICAgICAgICAgIG1heFNlbGVjdGVkTGFiZWxzPVwiMTAwXCJcclxuICAgICAgICAgID48L3AtbXVsdGlTZWxlY3Q+XHJcblxyXG4gICAgICAgICAgPCEtLSByYWRpb0J1dHRvbiAtLT5cclxuICAgICAgICAgIDxkaXZcclxuICAgICAgICAgICAgaWQ9XCJ7eyBpdGVtLmlkIH19XCJcclxuICAgICAgICAgICAgKm5nSWY9XCJpdGVtLnR5cGUgPT09ICdyYWRpby1idXR0b24nXCJcclxuICAgICAgICAgICAgY2xhc3M9XCJmbGV4IGdhcC0zXCJcclxuICAgICAgICAgID5cclxuICAgICAgICAgICAgPGRpdlxyXG4gICAgICAgICAgICAgICpuZ0Zvcj1cImxldCBsaXN0UmFkaW9CdXR0b24gb2YgaXRlbS5vcHRpb25zXCJcclxuICAgICAgICAgICAgICBjbGFzcz1cImZsZXggYWxpZ24taXRlbXMtY2VudGVyIGdhcC0yXCJcclxuICAgICAgICAgICAgPlxyXG4gICAgICAgICAgICAgIDxwLXJhZGlvQnV0dG9uXHJcbiAgICAgICAgICAgICAgICBbbmdDbGFzc109XCJ7XHJcbiAgICAgICAgICAgICAgICAgICduZy1pbnZhbGlkIG5nLWRpcnR5JzpcclxuICAgICAgICAgICAgICAgICAgICB2YWxpZGF0ZUZvcm0gJiYgY29udHJvbC5jb250cm9sc1tpdGVtLmZvcm1Db250cm9sXS5lcnJvcnNcclxuICAgICAgICAgICAgICAgIH1cIlxyXG4gICAgICAgICAgICAgICAgW3ZhbHVlXT1cImxpc3RSYWRpb0J1dHRvbi5jb2RlXCJcclxuICAgICAgICAgICAgICAgIGZvcm1Db250cm9sTmFtZT1cInt7IGl0ZW0uZm9ybUNvbnRyb2wgfX1cIlxyXG4gICAgICAgICAgICAgICAgKG9uQ2xpY2spPVwib25DaGFuZ2UoaXRlbS5vbkNoYW5nZSlcIlxyXG4gICAgICAgICAgICAgID48L3AtcmFkaW9CdXR0b24+XHJcbiAgICAgICAgICAgICAgPGxhYmVsPnt7IGxpc3RSYWRpb0J1dHRvbi5kZXNjcmlwdGlvbiB9fTwvbGFiZWw+XHJcbiAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgICBAaWYoY29udHJvbC5jb250cm9sc1tpdGVtLmZvcm1Db250cm9sXS52YWx1ZSA9PSAnb3RoZXInKXtcclxuICAgICAgICAgICAgPGlucHV0XHJcbiAgICAgICAgICAgICAgcElucHV0VGV4dFxyXG4gICAgICAgICAgICAgIHR5cGU9XCJ0ZXh0XCJcclxuICAgICAgICAgICAgICBmb3JtQ29udHJvbE5hbWU9XCJ7eyBpdGVtLmZvcm1Db250cm9sT3RoZXIgfX1cIlxyXG4gICAgICAgICAgICAvPlxyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICA8L2Rpdj5cclxuXHJcbiAgICAgICAgICA8IS0tIHNlbGVjdEJ1dHRvbiAtLT5cclxuICAgICAgICAgIDxkaXYgY2xhc3M9XCJkLWZsZXhcIiAqbmdJZj1cIml0ZW0udHlwZSA9PT0gJ3NlbGVjdC1idXR0b24nXCI+XHJcbiAgICAgICAgICAgIDxwLXNlbGVjdEJ1dHRvblxyXG4gICAgICAgICAgICAgIGlkPVwie3sgaXRlbS5pZCB9fVwiXHJcbiAgICAgICAgICAgICAgKG9uQ2hhbmdlKT1cIm9uQ2hhbmdlKGl0ZW0ub25DaGFuZ2UpXCJcclxuICAgICAgICAgICAgICBbb3B0aW9uc109XCJpdGVtLm9wdGlvbnNcIlxyXG4gICAgICAgICAgICAgIGZvcm1Db250cm9sTmFtZT1cInt7IGl0ZW0uZm9ybUNvbnRyb2wgfX1cIlxyXG4gICAgICAgICAgICAgIG9wdGlvblZhbHVlPVwiY29kZVwiXHJcbiAgICAgICAgICAgID5cclxuICAgICAgICAgICAgICA8bmctdGVtcGxhdGUgbGV0LWl0ZW0+XHJcbiAgICAgICAgICAgICAgICA8c3Bhbj57eyBpdGVtLmRlc2NyaXB0aW9uIH19PC9zcGFuPlxyXG4gICAgICAgICAgICAgIDwvbmctdGVtcGxhdGU+XHJcbiAgICAgICAgICAgIDwvcC1zZWxlY3RCdXR0b24+XHJcbiAgICAgICAgICAgIDwhLS0gPGlucHV0IHR5cGU9XCJ0ZXh0XCIgcElucHV0VGV4dCBbYXR0ci5kaXNhYmxlZF09XCJpdGVtLmRpc2FibGVkXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgZm9ybUNvbnRyb2xOYW1lPXt7aXRlbS5mb3JtQ29udHJvbFNlY29uZGFyeX19PiAtLT5cclxuICAgICAgICAgIDwvZGl2PlxyXG5cclxuICAgICAgICAgIDwhLS0gdGFibGUgLS0+XHJcbiAgICAgICAgICA8cC10YWJsZVxyXG4gICAgICAgICAgICBpZD1cInt7IGl0ZW0uaWQgfX1cIlxyXG4gICAgICAgICAgICAqbmdJZj1cIml0ZW0udHlwZSA9PT0gJ3RhYmxlJ1wiXHJcbiAgICAgICAgICAgIFtzY3JvbGxhYmxlXT1cInRydWVcIlxyXG4gICAgICAgICAgICBzY3JvbGxIZWlnaHQ9XCJ7eyBpdGVtLnNjcm9sbEhlaWdodCB9fVwiXHJcbiAgICAgICAgICAgIFtjb2x1bW5zXT1cIml0ZW0uY29sc1RhYmxlXCJcclxuICAgICAgICAgICAgc3R5bGVDbGFzcz1cInAtZGF0YXRhYmxlLXN0cmlwZWQgcC1kYXRhdGFibGUtc21cIlxyXG4gICAgICAgICAgICBbdmFsdWVdPVwiaXRlbS5yb3dzVGFibGVcIlxyXG4gICAgICAgICAgPlxyXG4gICAgICAgICAgICA8bmctdGVtcGxhdGUgcFRlbXBsYXRlPVwiaGVhZGVyXCIgbGV0LWNvbHVtbnM+XHJcbiAgICAgICAgICAgICAgPHRyPlxyXG4gICAgICAgICAgICAgICAgPHRoICpuZ0Zvcj1cImxldCBjb2wgb2YgY29sdW1uc1wiPlxyXG4gICAgICAgICAgICAgICAgICA8c3BhbiAqbmdJZj1cImNvbC5maWxlZCAhPT0gJ2FjdGlvbidcIj57eyBjb2wuaGVhZGVyIH19PC9zcGFuPlxyXG4gICAgICAgICAgICAgICAgICA8c3BhbiAqbmdJZj1cImNvbC5maWxlZCA9PT0gJ2FjdGlvbidcIj5Bw6fDo288L3NwYW4+XHJcbiAgICAgICAgICAgICAgICA8L3RoPlxyXG4gICAgICAgICAgICAgIDwvdHI+XHJcbiAgICAgICAgICAgIDwvbmctdGVtcGxhdGU+XHJcbiAgICAgICAgICAgIDxuZy10ZW1wbGF0ZSBwVGVtcGxhdGU9XCJib2R5XCIgbGV0LXJvd0RhdGEgbGV0LWNvbHVtbnM9XCJjb2x1bW5zXCI+XHJcbiAgICAgICAgICAgICAgPHRyPlxyXG4gICAgICAgICAgICAgICAgPHRkICpuZ0Zvcj1cImxldCBjb2wgb2YgY29sdW1uc1wiPlxyXG4gICAgICAgICAgICAgICAgICA8ZGl2ICpuZ0lmPVwiY29sLmZpZWxkICE9PSAnYnV0dG9uJ1wiPlxyXG4gICAgICAgICAgICAgICAgICAgIHt7IHJvd0RhdGFbY29sLmZpZWxkXSB9fVxyXG4gICAgICAgICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgICAgICAgPGRpdiAqbmdJZj1cImNvbC5maWVsZCA9PT0gJ2FjdGlvbidcIj5cclxuICAgICAgICAgICAgICAgICAgICA8cC1idXR0b25cclxuICAgICAgICAgICAgICAgICAgICAgICpuZ0Zvcj1cImxldCBhY3Rpb24gb2YgaXRlbS5idXR0b25zVGFibGVcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgc3R5bGVDbGFzcz1cInt7IGFjdGlvbi5zdHlsZUNsYXNzIH19XCJcclxuICAgICAgICAgICAgICAgICAgICAgIGxhYmVsPVwie3sgYWN0aW9uLmxhYmVsIH19XCJcclxuICAgICAgICAgICAgICAgICAgICAgIChjbGljayk9XCJhY3Rpb24ub25DTGljayhyb3dEYXRhKVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICBpY29uPVwie3sgYWN0aW9uLmljb24gfX1cIlxyXG4gICAgICAgICAgICAgICAgICAgID48L3AtYnV0dG9uPlxyXG4gICAgICAgICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgICAgIDwvdGQ+XHJcbiAgICAgICAgICAgICAgPC90cj5cclxuICAgICAgICAgICAgPC9uZy10ZW1wbGF0ZT5cclxuICAgICAgICAgICAgPG5nLXRlbXBsYXRlIHBUZW1wbGF0ZT1cImZvb3RlclwiIGxldC1jb2x1bW5zPlxyXG4gICAgICAgICAgICAgIDx0ciAqbmdGb3I9XCJsZXQgZm9vdGVyIG9mIGl0ZW0ucm93c0Zvb3RlclwiPlxyXG4gICAgICAgICAgICAgICAgPHRkIGNvbHNwYW49XCIxMlwiPlxyXG4gICAgICAgICAgICAgICAgICA8c3BhbiBjbGFzcz1cImZvbnQtbm9ybWFsXCI+e3sgZm9vdGVyLnRleHQgfX06PC9zcGFuPlxyXG4gICAgICAgICAgICAgICAgICB7eyBmb290ZXIudmFsdWUgfX1cclxuICAgICAgICAgICAgICAgIDwvdGQ+XHJcbiAgICAgICAgICAgICAgPC90cj5cclxuICAgICAgICAgICAgPC9uZy10ZW1wbGF0ZT5cclxuICAgICAgICAgIDwvcC10YWJsZT5cclxuXHJcbiAgICAgICAgICA8IS0tIGlucHV0U3dpdGNoIC0tPlxyXG4gICAgICAgICAgPGRpdiBjbGFzcz1cImQtZmxleFwiICpuZ0lmPVwiaXRlbS50eXBlID09PSAnc3dpdGNoJ1wiPlxyXG4gICAgICAgICAgICA8cC1pbnB1dFN3aXRjaFxyXG4gICAgICAgICAgICAgIGlkPVwie3sgaXRlbS5pZCB9fVwiXHJcbiAgICAgICAgICAgICAgZm9ybUNvbnRyb2xOYW1lPVwie3sgaXRlbS5mb3JtQ29udHJvbCB9fVwiXHJcbiAgICAgICAgICAgICAgY2xhc3M9XCJtci0xMFwiXHJcbiAgICAgICAgICAgICAgKG9uQ2hhbmdlKT1cIm9uQ2hhbmdlKGl0ZW0ub25DaGFuZ2UpXCJcclxuICAgICAgICAgICAgPjwvcC1pbnB1dFN3aXRjaD5cclxuICAgICAgICAgICAgPHAgdHJhbnNsYXRlPVwie3sgaXRlbS5sYWJlbCB9fVwiPjwvcD5cclxuICAgICAgICAgIDwvZGl2PlxyXG5cclxuICAgICAgICAgIDwhLS0gcGFzc3dvcmQgLS0+XHJcbiAgICAgICAgICA8cC1wYXNzd29yZFxyXG4gICAgICAgICAgICBpZD1cInt7IGl0ZW0uaWQgfX1cIlxyXG4gICAgICAgICAgICBbbmdDbGFzc109XCJ7XHJcbiAgICAgICAgICAgICAgJ25nLWludmFsaWQgbmctZGlydHknOlxyXG4gICAgICAgICAgICAgICAgdmFsaWRhdGVGb3JtICYmIGNvbnRyb2wuY29udHJvbHNbaXRlbS5mb3JtQ29udHJvbF0uZXJyb3JzXHJcbiAgICAgICAgICAgIH1cIlxyXG4gICAgICAgICAgICBwbGFjZWhvbGRlcj1cInt7IGl0ZW0ucGxhY2Vob2xkZXIgfX1cIlxyXG4gICAgICAgICAgICAqbmdJZj1cIml0ZW0udHlwZSA9PT0gJ3Bhc3N3b3JkJ1wiXHJcbiAgICAgICAgICAgIFtmZWVkYmFja109XCJmYWxzZVwiXHJcbiAgICAgICAgICAgIGZvcm1Db250cm9sTmFtZT1cInt7IGl0ZW0uZm9ybUNvbnRyb2wgfX1cIlxyXG4gICAgICAgICAgICAob25DaGFuZ2UpPVwib25DaGFuZ2UoaXRlbS5vbkNoYW5nZSlcIlxyXG4gICAgICAgICAgICBzdHlsZUNsYXNzPVwidy1mdWxsXCJcclxuICAgICAgICAgICAgW3RvZ2dsZU1hc2tdPVwidHJ1ZVwiXHJcbiAgICAgICAgICA+PC9wLXBhc3N3b3JkPlxyXG5cclxuICAgICAgICAgIDwhLS0gcGhvdG8gIC0tPlxyXG4gICAgICAgICAgPGRpdiBpZD1cInt7IGl0ZW0uaWQgfX1cIiBjbGFzcz1cImNhbWVyYVwiICpuZ0lmPVwiaXRlbS50eXBlID09PSAncGhvdG8nXCI+XHJcbiAgICAgICAgICAgIDx2aWRlbyBpZD1cInZpZGVvXCIgY2xhc3M9XCJmb3RvXCIgYXV0b3BsYXk+XHJcbiAgICAgICAgICAgICAgVsOtZGVvIG7Do28gZGlzcG9uw612ZWwuXHJcbiAgICAgICAgICAgIDwvdmlkZW8+XHJcbiAgICAgICAgICAgIDxjYW52YXMgaWQ9XCJjYW52YXNcIiBjbGFzcz1cImZvdG9cIiBzdHlsZT1cImRpc3BsYXk6IG5vbmVcIj48L2NhbnZhcz5cclxuICAgICAgICAgICAgPGJ1dHRvblxyXG4gICAgICAgICAgICAgIHBCdXR0b25cclxuICAgICAgICAgICAgICBpY29uPVwicGkgcGktdGltZXNcIlxyXG4gICAgICAgICAgICAgIGNsYXNzPVwicmVtb3ZlLWZpbGVcIlxyXG4gICAgICAgICAgICAgIGlkPVwiaWNvbi1yZW1vdmVcIlxyXG4gICAgICAgICAgICAgIFtyb3VuZGVkXT1cInRydWVcIlxyXG4gICAgICAgICAgICAgIHN0eWxlPVwidmlzaWJpbGl0eTogY29sbGFwc2VcIlxyXG4gICAgICAgICAgICAgIChjbGljayk9XCJyZW1vdmVQaG90bygpXCJcclxuICAgICAgICAgICAgPjwvYnV0dG9uPlxyXG4gICAgICAgICAgICA8YnV0dG9uXHJcbiAgICAgICAgICAgICAgcEJ1dHRvblxyXG4gICAgICAgICAgICAgIGljb249XCJwaSBwaS1jYW1lcmFcIlxyXG4gICAgICAgICAgICAgIFtyb3VuZGVkXT1cInRydWVcIlxyXG4gICAgICAgICAgICAgIChjbGljayk9XCJjYXB0dXJlUGhvdG8oaXRlbS5mb3JtQ29udHJvbClcIlxyXG4gICAgICAgICAgICAgIGlkPVwiYnV0dG9uXCJcclxuICAgICAgICAgICAgPjwvYnV0dG9uPlxyXG4gICAgICAgICAgPC9kaXY+XHJcblxyXG4gICAgICAgICAgPCEtLSBsaWtlcnQgIC0tPlxyXG4gICAgICAgICAgPHAtdGFibGVcclxuICAgICAgICAgICAgaWQ9XCJ7eyBpdGVtLmlkIH19XCJcclxuICAgICAgICAgICAgKm5nSWY9XCJpdGVtLnR5cGUgPT09ICdsaWtlcnQnXCJcclxuICAgICAgICAgICAgW3Njcm9sbGFibGVdPVwidHJ1ZVwiXHJcbiAgICAgICAgICAgIHNjcm9sbEhlaWdodD1cInt7IGl0ZW0uc2Nyb2xsSGVpZ2h0IH19XCJcclxuICAgICAgICAgICAgW2NvbHVtbnNdPVwiaXRlbS5jb2xzVGFibGVcIlxyXG4gICAgICAgICAgICBzdHlsZUNsYXNzPVwicC1kYXRhdGFibGUtc3RyaXBlZCBwLWRhdGF0YWJsZS1zbVwiXHJcbiAgICAgICAgICAgIFt2YWx1ZV09XCJpdGVtLnJvd3NUYWJsZVwiXHJcbiAgICAgICAgICA+XHJcbiAgICAgICAgICAgIDxuZy10ZW1wbGF0ZSBwVGVtcGxhdGU9XCJoZWFkZXJcIiBsZXQtY29sdW1ucz5cclxuICAgICAgICAgICAgICA8dHI+XHJcbiAgICAgICAgICAgICAgICA8dGggc3R5bGU9XCJ3aWR0aDogNHJlbVwiPjwvdGg+XHJcbiAgICAgICAgICAgICAgICA8dGggKm5nRm9yPVwibGV0IGNvbCBvZiBjb2x1bW5zXCI+XHJcbiAgICAgICAgICAgICAgICAgIDxzcGFuPnt7IGNvbC5oZWFkZXIgfX08L3NwYW4+XHJcbiAgICAgICAgICAgICAgICA8L3RoPlxyXG4gICAgICAgICAgICAgIDwvdHI+XHJcbiAgICAgICAgICAgIDwvbmctdGVtcGxhdGU+XHJcbiAgICAgICAgICAgIDxuZy10ZW1wbGF0ZVxyXG4gICAgICAgICAgICAgIHBUZW1wbGF0ZT1cImJvZHlcIlxyXG4gICAgICAgICAgICAgIGxldC1yb3dcclxuICAgICAgICAgICAgICBsZXQtcm93SW5kZXg9XCJyb3dJbmRleFwiXHJcbiAgICAgICAgICAgICAgbGV0LWNvbHVtbnM9XCJjb2x1bW5zXCJcclxuICAgICAgICAgICAgICBmb3JtQXJyYXlOYW1lPVwie3sgaXRlbS5mb3JtQ29udHJvbCB9fVwiXHJcbiAgICAgICAgICAgID5cclxuICAgICAgICAgICAgICA8dHI+XHJcbiAgICAgICAgICAgICAgICA8dGQ+XHJcbiAgICAgICAgICAgICAgICAgIHt7IHJvdyB9fVxyXG4gICAgICAgICAgICAgICAgPC90ZD5cclxuICAgICAgICAgICAgICAgIEBmb3IgKGNvbnRyb2wgb2YgY29sdW1uczsgdHJhY2sgaXRlbTsgbGV0IGluZGV4ID0gJGluZGV4KSB7XHJcbiAgICAgICAgICAgICAgICA8dGQgW2Zvcm1Hcm91cE5hbWVdPVwicm93SW5kZXhcIj5cclxuICAgICAgICAgICAgICAgICAgPHAtcmFkaW9CdXR0b25cclxuICAgICAgICAgICAgICAgICAgICB2YWx1ZT1cInt7IGNvbHVtbnNbaW5kZXhdLmZpZWxkIH19K3t7IHJvdyB9fVwiXHJcbiAgICAgICAgICAgICAgICAgICAgZm9ybUNvbnRyb2xOYW1lPVwicXVlc3Rpb257eyByb3dJbmRleCB9fVwiXHJcbiAgICAgICAgICAgICAgICAgIC8+XHJcbiAgICAgICAgICAgICAgICA8L3RkPlxyXG4gICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgIDwvdHI+XHJcbiAgICAgICAgICAgIDwvbmctdGVtcGxhdGU+XHJcbiAgICAgICAgICA8L3AtdGFibGU+XHJcblxyXG4gICAgICAgICAgPCEtLSBlZGl0YWJsZSB0YWJsZSAtLT5cclxuICAgICAgICAgIDxwLXRhYmxlXHJcbiAgICAgICAgICAgIGlkPVwie3sgaXRlbS5pZCB9fVwiXHJcbiAgICAgICAgICAgICpuZ0lmPVwiaXRlbS50eXBlID09PSAnZWRpdGFibGUtdGFibGUnXCJcclxuICAgICAgICAgICAgW3Njcm9sbGFibGVdPVwidHJ1ZVwiXHJcbiAgICAgICAgICAgIHNjcm9sbEhlaWdodD1cInt7IGl0ZW0uc2Nyb2xsSGVpZ2h0IH19XCJcclxuICAgICAgICAgICAgW2NvbHVtbnNdPVwiaXRlbS5jb2xzVGFibGVcIlxyXG4gICAgICAgICAgICBzdHlsZUNsYXNzPVwicC1kYXRhdGFibGUtc3RyaXBlZCBwLWRhdGF0YWJsZS1zbVwiXHJcbiAgICAgICAgICAgIFt2YWx1ZV09XCJpdGVtLnJvd3NUYWJsZVwiXHJcbiAgICAgICAgICAgIGVkaXRNb2RlPVwiY2VsbFwiXHJcbiAgICAgICAgICA+XHJcbiAgICAgICAgICAgIDwhLS0gQ2FiZcOnYWxobyBkYSB0YWJlbGEgLS0+XHJcbiAgICAgICAgICAgIDxuZy10ZW1wbGF0ZSBwVGVtcGxhdGU9XCJoZWFkZXJcIiBsZXQtY29sdW1ucz5cclxuICAgICAgICAgICAgICA8dHI+XHJcbiAgICAgICAgICAgICAgICA8dGggc3R5bGU9XCJ3aWR0aDogNHJlbVwiPjwvdGg+XHJcbiAgICAgICAgICAgICAgICA8dGggKm5nRm9yPVwibGV0IGNvbCBvZiBjb2x1bW5zXCI+XHJcbiAgICAgICAgICAgICAgICAgIDxzcGFuPnt7IGNvbC5oZWFkZXIgfX08L3NwYW4+XHJcbiAgICAgICAgICAgICAgICA8L3RoPlxyXG4gICAgICAgICAgICAgIDwvdHI+XHJcbiAgICAgICAgICAgIDwvbmctdGVtcGxhdGU+XHJcblxyXG4gICAgICAgICAgICA8IS0tIENvcnBvIGRhIHRhYmVsYSAtLT5cclxuICAgICAgICAgICAgPG5nLXRlbXBsYXRlXHJcbiAgICAgICAgICAgICAgcFRlbXBsYXRlPVwiYm9keVwiXHJcbiAgICAgICAgICAgICAgbGV0LXJvd1xyXG4gICAgICAgICAgICAgIGxldC1yb3dJbmRleD1cInJvd0luZGV4XCJcclxuICAgICAgICAgICAgICBsZXQtY29sdW1ucz1cImNvbHVtbnNcIlxyXG4gICAgICAgICAgICAgIGZvcm1BcnJheU5hbWU9XCJ7eyBpdGVtLmZvcm1Db250cm9sIH19XCJcclxuICAgICAgICAgICAgICBsZXQtZWRpdGluZz1cImVkaXRpbmdcIlxyXG4gICAgICAgICAgICA+XHJcbiAgICAgICAgICAgICAgPHRyPlxyXG4gICAgICAgICAgICAgICAgPHRkPnt7IHJvdyB9fTwvdGQ+XHJcbiAgICAgICAgICAgICAgICBAZm9yIChjb250cm9sIG9mIGNvbHVtbnM7IHRyYWNrIGl0ZW07IGxldCBpbmRleCA9ICRpbmRleCkge1xyXG4gICAgICAgICAgICAgICAgPHRkXHJcbiAgICAgICAgICAgICAgICAgIFtmb3JtR3JvdXBOYW1lXT1cInJvd0luZGV4XCJcclxuICAgICAgICAgICAgICAgICAgW3BFZGl0YWJsZUNvbHVtbl09XCJyb3dcIlxyXG4gICAgICAgICAgICAgICAgICBwRWRpdGFibGVDb2x1bW5GaWVsZD1cInJvd1wiXHJcbiAgICAgICAgICAgICAgICA+XHJcbiAgICAgICAgICAgICAgICAgIDxwLWNlbGxFZGl0b3I+XHJcbiAgICAgICAgICAgICAgICAgICAgPG5nLXRlbXBsYXRlIHBUZW1wbGF0ZT1cImlucHV0XCI+XHJcbiAgICAgICAgICAgICAgICAgICAgICA8aW5wdXRcclxuICAgICAgICAgICAgICAgICAgICAgICAgcElucHV0VGV4dFxyXG4gICAgICAgICAgICAgICAgICAgICAgICB0eXBlPVwidGV4dFwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGZvcm1Db250cm9sTmFtZT1cIl97eyBjb250cm9sLmZpZWxkIH19cXVlc3Rpb257e1xyXG4gICAgICAgICAgICAgICAgICAgICAgICAgIHJvd0luZGV4XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIH19XCJcclxuICAgICAgICAgICAgICAgICAgICAgIC8+XHJcbiAgICAgICAgICAgICAgICAgICAgPC9uZy10ZW1wbGF0ZT5cclxuICAgICAgICAgICAgICAgICAgICA8bmctdGVtcGxhdGUgcFRlbXBsYXRlPVwib3V0cHV0XCI+XHJcbiAgICAgICAgICAgICAgICAgICAgICA8aW5wdXRcclxuICAgICAgICAgICAgICAgICAgICAgICAgcElucHV0VGV4dFxyXG4gICAgICAgICAgICAgICAgICAgICAgICB0eXBlPVwidGV4dFwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGZvcm1Db250cm9sTmFtZT1cIl97eyBjb250cm9sLmZpZWxkIH19cXVlc3Rpb257e1xyXG4gICAgICAgICAgICAgICAgICAgICAgICAgIHJvd0luZGV4XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIH19XCJcclxuICAgICAgICAgICAgICAgICAgICAgIC8+XHJcbiAgICAgICAgICAgICAgICAgICAgPC9uZy10ZW1wbGF0ZT5cclxuICAgICAgICAgICAgICAgICAgPC9wLWNlbGxFZGl0b3I+XHJcbiAgICAgICAgICAgICAgICA8L3RkPlxyXG4gICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgIDwvdHI+XHJcbiAgICAgICAgICAgIDwvbmctdGVtcGxhdGU+XHJcbiAgICAgICAgICA8L3AtdGFibGU+XHJcblxyXG4gICAgICAgICAgPCEtLSB2YWxpZGHDp8OjbyBkZSBpdGVtIC0tPlxyXG4gICAgICAgICAgPGRpdj5cclxuICAgICAgICAgICAgPHNtYWxsXHJcbiAgICAgICAgICAgICAgY2xhc3M9XCJkYW5nZXItdGV4dFwiXHJcbiAgICAgICAgICAgICAgKm5nSWY9XCJ2YWxpZGF0ZUZvcm0gJiYgY29udHJvbC5jb250cm9sc1tpdGVtLmZvcm1Db250cm9sXSAmJiBjb250cm9sLmNvbnRyb2xzW2l0ZW0uZm9ybUNvbnRyb2xdLmVycm9ycz8uWydyZXF1aXJlZCddXCJcclxuICAgICAgICAgICAgPlxyXG4gICAgICAgICAgICAgIENhbXBvIG9icmlnYXTDs3Jpb1xyXG4gICAgICAgICAgICA8L3NtYWxsPlxyXG4gICAgICAgICAgICA8c21hbGxcclxuICAgICAgICAgICAgICBjbGFzcz1cImRhbmdlci10ZXh0XCJcclxuICAgICAgICAgICAgICAqbmdJZj1cInZhbGlkYXRlRm9ybSAmJiBjb250cm9sLmNvbnRyb2xzW2l0ZW0uZm9ybUNvbnRyb2xdICYmIGNvbnRyb2wuY29udHJvbHNbaXRlbS5mb3JtQ29udHJvbF0uZXJyb3JzPy5bJ2VtYWlsJ11cIlxyXG4gICAgICAgICAgICA+XHJcbiAgICAgICAgICAgICAgRW1haWwgaW52w6FsaWRvXHJcbiAgICAgICAgICAgIDwvc21hbGw+XHJcbiAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8L2Rpdj5cclxuICAgICAgPC9kaXY+XHJcblxyXG4gICAgICA8cC1kaXZpZGVyXHJcbiAgICAgICAgKm5nSWY9XCJcclxuICAgICAgICAgIChidXR0b25zU3RhbmRhcmQgJiYgYnV0dG9uc1N0YW5kYXJkLmxlbmd0aCA+IDApIHx8XHJcbiAgICAgICAgICAoYnV0dG9uc09wdGlvbmFsICYmIGJ1dHRvbnNPcHRpb25hbC5sZW5ndGggPiAwKVxyXG4gICAgICAgIFwiXHJcbiAgICAgID48L3AtZGl2aWRlcj5cclxuXHJcbiAgICAgIDxkaXYgY2xhc3M9XCJidXR0b25zLWZvcm1cIj5cclxuICAgICAgICA8ZGl2ICpuZ0Zvcj1cImxldCBidXR0b24gb2YgYnV0dG9uc1N0YW5kYXJkXCI+XHJcbiAgICAgICAgICA8cC1idXR0b25cclxuICAgICAgICAgICAgKm5nSWY9XCJidXR0b24udHlwZSA9PT0gJ2NsZWFuJ1wiXHJcbiAgICAgICAgICAgIHN0eWxlQ2xhc3M9XCJwLWJ1dHRvbi13YXJuaW5nIHt7IGJ1dHRvbi5zdHlsZUNsYXNzIH19XCJcclxuICAgICAgICAgICAgbGFiZWw9XCJMaW1wYXJcIlxyXG4gICAgICAgICAgICAoY2xpY2spPVwiYnV0dG9uLm9uQ0xpY2soKVwiXHJcbiAgICAgICAgICAgIGljb249XCJwaSBwaS10aW1lc1wiXHJcbiAgICAgICAgICA+PC9wLWJ1dHRvbj5cclxuICAgICAgICAgIDxwLWJ1dHRvblxyXG4gICAgICAgICAgICAqbmdJZj1cImJ1dHRvbi50eXBlID09PSAnZmlsdGVyJ1wiXHJcbiAgICAgICAgICAgIHN0eWxlQ2xhc3M9XCJ7eyBidXR0b24uc3R5bGVDbGFzcyB9fVwiXHJcbiAgICAgICAgICAgIGxhYmVsPVwiRmlsdHJhclwiXHJcbiAgICAgICAgICAgIChjbGljayk9XCJidXR0b24ub25DTGljaygpXCJcclxuICAgICAgICAgICAgaWNvbj1cInBpIHBpLXNlYXJjaFwiXHJcbiAgICAgICAgICA+PC9wLWJ1dHRvbj5cclxuICAgICAgICAgIDxwLWJ1dHRvblxyXG4gICAgICAgICAgICAqbmdJZj1cImJ1dHRvbi50eXBlID09PSAnc2F2ZSdcIlxyXG4gICAgICAgICAgICBzdHlsZUNsYXNzPVwicC1idXR0b24tc3VjY2VzcyB7eyBidXR0b24uc3R5bGVDbGFzcyB9fVwiXHJcbiAgICAgICAgICAgIGxhYmVsPVwiU2FsdmFyXCJcclxuICAgICAgICAgICAgKGNsaWNrKT1cImJ1dHRvbi5vbkNMaWNrKClcIlxyXG4gICAgICAgICAgICBpY29uPVwicGkgcGktc2F2ZVwiXHJcbiAgICAgICAgICA+PC9wLWJ1dHRvbj5cclxuICAgICAgICAgIDxwLWJ1dHRvblxyXG4gICAgICAgICAgICAqbmdJZj1cImJ1dHRvbi50eXBlID09PSAnY2FuY2VsJ1wiXHJcbiAgICAgICAgICAgIHN0eWxlQ2xhc3M9XCJwLWJ1dHRvbi1kYW5nZXIge3sgYnV0dG9uLnN0eWxlQ2xhc3MgfX1cIlxyXG4gICAgICAgICAgICBsYWJlbD1cIkNhbmNlbGFyXCJcclxuICAgICAgICAgICAgKGNsaWNrKT1cImJ1dHRvbi5vbkNMaWNrKClcIlxyXG4gICAgICAgICAgICBpY29uPVwicGkgcGktdGltZXNcIlxyXG4gICAgICAgICAgPjwvcC1idXR0b24+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgPGRpdiAqbmdGb3I9XCJsZXQgYnV0dG9uIG9mIGJ1dHRvbnNPcHRpb25hbFwiPlxyXG4gICAgICAgICAgPHAtYnV0dG9uXHJcbiAgICAgICAgICAgIHN0eWxlQ2xhc3M9XCJ7eyBidXR0b24uc3R5bGVDbGFzcyB9fVwiXHJcbiAgICAgICAgICAgIGxhYmVsPVwie3sgYnV0dG9uLmxhYmVsIH19XCJcclxuICAgICAgICAgICAgKGNsaWNrKT1cImJ1dHRvbi5vbkNMaWNrKClcIlxyXG4gICAgICAgICAgICBpY29uPVwie3sgYnV0dG9uLmljb24gfX1cIlxyXG4gICAgICAgICAgPjwvcC1idXR0b24+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgPC9kaXY+XHJcbiAgPC9mb3JtPlxyXG48L2Rpdj5cclxuIl19
|