@eqproject/eqp-dynamic-module 0.0.1
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 +24 -0
- package/bundles/eqproject-eqp-dynamic-module.umd.js +3117 -0
- package/bundles/eqproject-eqp-dynamic-module.umd.js.map +1 -0
- package/bundles/eqproject-eqp-dynamic-module.umd.min.js +17 -0
- package/bundles/eqproject-eqp-dynamic-module.umd.min.js.map +1 -0
- package/eqproject-eqp-dynamic-module.d.ts +5 -0
- package/eqproject-eqp-dynamic-module.metadata.json +1 -0
- package/esm2015/eqproject-eqp-dynamic-module.js +6 -0
- package/esm2015/lib/components/exported/eqp-dynamic-module/eqp-dynamic-module.component.js +65 -0
- package/esm2015/lib/components/exported/eqp-dynamic-module-configurator/eqp-dynamic-module-configurator.component.js +534 -0
- package/esm2015/lib/components/private/add-form-field/add-form-field.component.js +486 -0
- package/esm2015/lib/components/private/dynamic-module-field/dynamic-module-field.component.js +127 -0
- package/esm2015/lib/components/private/field-templates/attachment-field-template/attachment-field-template.component.js +181 -0
- package/esm2015/lib/components/private/field-templates/boolean-field-template/boolean-field-template.component.js +56 -0
- package/esm2015/lib/components/private/field-templates/date-field-template/date-field-template.component.js +71 -0
- package/esm2015/lib/components/private/field-templates/image-field-template/image-field-template.component.js +54 -0
- package/esm2015/lib/components/private/field-templates/list-value-field-template/list-value-field-template.component.js +118 -0
- package/esm2015/lib/components/private/field-templates/numeric-field-template/numeric-field-template.component.js +63 -0
- package/esm2015/lib/components/private/field-templates/text-field-template/text-field-template.component.js +51 -0
- package/esm2015/lib/components/private/field-templates/textarea-field-template/textarea-field-template.component.js +51 -0
- package/esm2015/lib/components/private/form-records/add-form-record/add-form-record.component.js +126 -0
- package/esm2015/lib/components/private/form-records/list-form-record/list-form-record.component.js +210 -0
- package/esm2015/lib/eqp-dynamic-module.module.js +67 -0
- package/esm2015/lib/interfaces/iBaseFieldComponent.interface.js +1 -0
- package/esm2015/lib/interfaces/iRootObject.interface.js +1 -0
- package/esm2015/lib/models/baseField.model.js +36 -0
- package/esm2015/lib/models/baseObj.model.js +9 -0
- package/esm2015/lib/models/context.model.js +8 -0
- package/esm2015/lib/models/entity.model.js +7 -0
- package/esm2015/lib/models/fields/attachmentField.model.js +22 -0
- package/esm2015/lib/models/fields/booleanField.model.js +12 -0
- package/esm2015/lib/models/fields/dateField.model.js +11 -0
- package/esm2015/lib/models/fields/imageField.model.js +4 -0
- package/esm2015/lib/models/fields/listValueField.model.js +12 -0
- package/esm2015/lib/models/fields/lookupField.model.js +5 -0
- package/esm2015/lib/models/fields/numericField.model.js +5 -0
- package/esm2015/lib/models/fields/testareaField.model.js +4 -0
- package/esm2015/lib/models/fields/textField.model.js +5 -0
- package/esm2015/lib/models/form.model.js +24 -0
- package/esm2015/lib/models/record.model.js +3 -0
- package/esm2015/lib/modules/material.module.js +108 -0
- package/esm2015/lib/services/custom-form-validators.service.js +19 -0
- package/esm2015/lib/services/eqp-dynamic-module-dialog.service.js +104 -0
- package/esm2015/lib/services/utilityHelper.services.js +220 -0
- package/esm2015/public-api.js +37 -0
- package/esm5/eqproject-eqp-dynamic-module.js +6 -0
- package/esm5/lib/components/exported/eqp-dynamic-module/eqp-dynamic-module.component.js +66 -0
- package/esm5/lib/components/exported/eqp-dynamic-module-configurator/eqp-dynamic-module-configurator.component.js +546 -0
- package/esm5/lib/components/private/add-form-field/add-form-field.component.js +497 -0
- package/esm5/lib/components/private/dynamic-module-field/dynamic-module-field.component.js +128 -0
- package/esm5/lib/components/private/field-templates/attachment-field-template/attachment-field-template.component.js +184 -0
- package/esm5/lib/components/private/field-templates/boolean-field-template/boolean-field-template.component.js +57 -0
- package/esm5/lib/components/private/field-templates/date-field-template/date-field-template.component.js +72 -0
- package/esm5/lib/components/private/field-templates/image-field-template/image-field-template.component.js +55 -0
- package/esm5/lib/components/private/field-templates/list-value-field-template/list-value-field-template.component.js +121 -0
- package/esm5/lib/components/private/field-templates/numeric-field-template/numeric-field-template.component.js +64 -0
- package/esm5/lib/components/private/field-templates/text-field-template/text-field-template.component.js +52 -0
- package/esm5/lib/components/private/field-templates/textarea-field-template/textarea-field-template.component.js +52 -0
- package/esm5/lib/components/private/form-records/add-form-record/add-form-record.component.js +129 -0
- package/esm5/lib/components/private/form-records/list-form-record/list-form-record.component.js +216 -0
- package/esm5/lib/eqp-dynamic-module.module.js +70 -0
- package/esm5/lib/interfaces/iBaseFieldComponent.interface.js +1 -0
- package/esm5/lib/interfaces/iRootObject.interface.js +1 -0
- package/esm5/lib/models/baseField.model.js +43 -0
- package/esm5/lib/models/baseObj.model.js +13 -0
- package/esm5/lib/models/context.model.js +14 -0
- package/esm5/lib/models/entity.model.js +14 -0
- package/esm5/lib/models/fields/attachmentField.model.js +29 -0
- package/esm5/lib/models/fields/booleanField.model.js +19 -0
- package/esm5/lib/models/fields/dateField.model.js +18 -0
- package/esm5/lib/models/fields/imageField.model.js +11 -0
- package/esm5/lib/models/fields/listValueField.model.js +19 -0
- package/esm5/lib/models/fields/lookupField.model.js +12 -0
- package/esm5/lib/models/fields/numericField.model.js +12 -0
- package/esm5/lib/models/fields/testareaField.model.js +11 -0
- package/esm5/lib/models/fields/textField.model.js +12 -0
- package/esm5/lib/models/form.model.js +39 -0
- package/esm5/lib/models/record.model.js +7 -0
- package/esm5/lib/modules/material.module.js +111 -0
- package/esm5/lib/services/custom-form-validators.service.js +23 -0
- package/esm5/lib/services/eqp-dynamic-module-dialog.service.js +113 -0
- package/esm5/lib/services/utilityHelper.services.js +225 -0
- package/esm5/public-api.js +37 -0
- package/fesm2015/eqproject-eqp-dynamic-module.js +2757 -0
- package/fesm2015/eqproject-eqp-dynamic-module.js.map +1 -0
- package/fesm5/eqproject-eqp-dynamic-module.js +2902 -0
- package/fesm5/eqproject-eqp-dynamic-module.js.map +1 -0
- package/lib/components/exported/eqp-dynamic-module/eqp-dynamic-module.component.d.ts +21 -0
- package/lib/components/exported/eqp-dynamic-module-configurator/eqp-dynamic-module-configurator.component.d.ts +186 -0
- package/lib/components/private/add-form-field/add-form-field.component.d.ts +160 -0
- package/lib/components/private/dynamic-module-field/dynamic-module-field.component.d.ts +55 -0
- package/lib/components/private/field-templates/attachment-field-template/attachment-field-template.component.d.ts +84 -0
- package/lib/components/private/field-templates/boolean-field-template/boolean-field-template.component.d.ts +21 -0
- package/lib/components/private/field-templates/date-field-template/date-field-template.component.d.ts +27 -0
- package/lib/components/private/field-templates/image-field-template/image-field-template.component.d.ts +16 -0
- package/lib/components/private/field-templates/list-value-field-template/list-value-field-template.component.d.ts +59 -0
- package/lib/components/private/field-templates/numeric-field-template/numeric-field-template.component.d.ts +26 -0
- package/lib/components/private/field-templates/text-field-template/text-field-template.component.d.ts +20 -0
- package/lib/components/private/field-templates/textarea-field-template/textarea-field-template.component.d.ts +20 -0
- package/lib/components/private/form-records/add-form-record/add-form-record.component.d.ts +50 -0
- package/lib/components/private/form-records/list-form-record/list-form-record.component.d.ts +59 -0
- package/lib/eqp-dynamic-module.module.d.ts +2 -0
- package/lib/interfaces/iBaseFieldComponent.interface.d.ts +8 -0
- package/lib/interfaces/iRootObject.interface.d.ts +10 -0
- package/lib/models/baseField.model.d.ts +56 -0
- package/lib/models/baseObj.model.d.ts +9 -0
- package/lib/models/context.model.d.ts +9 -0
- package/lib/models/entity.model.d.ts +10 -0
- package/lib/models/fields/attachmentField.model.d.ts +17 -0
- package/lib/models/fields/booleanField.model.d.ts +11 -0
- package/lib/models/fields/dateField.model.d.ts +12 -0
- package/lib/models/fields/imageField.model.d.ts +10 -0
- package/lib/models/fields/listValueField.model.d.ts +21 -0
- package/lib/models/fields/lookupField.model.d.ts +10 -0
- package/lib/models/fields/numericField.model.d.ts +9 -0
- package/lib/models/fields/testareaField.model.d.ts +7 -0
- package/lib/models/fields/textField.model.d.ts +7 -0
- package/lib/models/form.model.d.ts +45 -0
- package/lib/models/record.model.d.ts +5 -0
- package/lib/modules/material.module.d.ts +2 -0
- package/lib/services/custom-form-validators.service.d.ts +5 -0
- package/lib/services/eqp-dynamic-module-dialog.service.d.ts +28 -0
- package/lib/services/utilityHelper.services.d.ts +48 -0
- package/package.json +39 -0
- package/public-api.d.ts +35 -0
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { Component, EventEmitter, Input, Output, ViewChild, ViewChildren } from '@angular/core';
|
|
3
|
+
import { MatDialog, MatDialogRef } from '@angular/material/dialog';
|
|
4
|
+
import { FieldTypeEnum } from '../../../models/baseField.model';
|
|
5
|
+
import { Record } from '../../../models/record.model';
|
|
6
|
+
var DynamicModuleFieldComponent = /** @class */ (function () {
|
|
7
|
+
function DynamicModuleFieldComponent(dialog) {
|
|
8
|
+
this.dialog = dialog;
|
|
9
|
+
this.recordChange = new EventEmitter();
|
|
10
|
+
this.FieldTypeEnum = FieldTypeEnum;
|
|
11
|
+
this.onlyViewInnerFormRecord = false;
|
|
12
|
+
}
|
|
13
|
+
DynamicModuleFieldComponent.prototype.updateField = function () {
|
|
14
|
+
if (this.fieldTemplate && this.fieldTemplate.length > 0) {
|
|
15
|
+
this.fieldTemplate.forEach(function (f) { return f.updateField(); });
|
|
16
|
+
}
|
|
17
|
+
};
|
|
18
|
+
DynamicModuleFieldComponent.prototype.ngOnInit = function () {
|
|
19
|
+
};
|
|
20
|
+
/**
|
|
21
|
+
* Metodo invocato al cambio del valore di ogni proprietà dell'oggetto record.
|
|
22
|
+
* Serve ad aggiornare il valore di tutti i campi che hanno una formula.
|
|
23
|
+
*/
|
|
24
|
+
DynamicModuleFieldComponent.prototype.onRecordChange = function () {
|
|
25
|
+
this.recordChange.emit(this.record);
|
|
26
|
+
};
|
|
27
|
+
/**
|
|
28
|
+
* Metodo per recuperare una InnerForm a partire dal Field che la rappresenta.
|
|
29
|
+
* @param field Campo a partire dal quale si vuole recuperare la InnerForm.
|
|
30
|
+
* @returns Restituisce un oggetto di tipo Form.
|
|
31
|
+
*/
|
|
32
|
+
DynamicModuleFieldComponent.prototype.getInnerFormFromField = function (field) {
|
|
33
|
+
if (this.form.InnerForms && this.form.InnerForms.find(function (f) { return f.Name == field.Label; })) {
|
|
34
|
+
return this.form.InnerForms.find(function (f) { return f.Name == field.Label; });
|
|
35
|
+
}
|
|
36
|
+
else {
|
|
37
|
+
return null;
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
/**
|
|
41
|
+
* Metodo per aprire un dialog in cui aggiungere/modificare/visualizzare un record appartenente
|
|
42
|
+
* a una form di dettaglio.
|
|
43
|
+
* @param record Evento di output del componente list-form-record, contiene il record selezionato e un booleno che indica
|
|
44
|
+
* se l'utente vuole modificare o visualizzare l'elemento selezionato.
|
|
45
|
+
* @param innerForm Contiene la Form di dettaglio dalla quale è stato richiesto il record.
|
|
46
|
+
*/
|
|
47
|
+
DynamicModuleFieldComponent.prototype.onAddViewEditInnerFormRecord = function (record, field) {
|
|
48
|
+
this.selectedInnerForm = this.getInnerFormFromField(field);
|
|
49
|
+
if (record == null) {
|
|
50
|
+
this.selectedInnerFormRecord = new Record();
|
|
51
|
+
this.indexInnerFormRecord = null;
|
|
52
|
+
this.onlyViewInnerFormRecord = false;
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
this.selectedInnerFormRecord = JSON.parse(JSON.stringify(record.record));
|
|
56
|
+
this.indexInnerFormRecord = this.record[field.Name].indexOf(record);
|
|
57
|
+
this.onlyViewInnerFormRecord = record.onlyView;
|
|
58
|
+
}
|
|
59
|
+
this.dialogInnerFormRecordRef = this.dialog.open(this.dialogInnerFormRecord, {
|
|
60
|
+
disableClose: true,
|
|
61
|
+
hasBackdrop: true,
|
|
62
|
+
width: '75%'
|
|
63
|
+
});
|
|
64
|
+
};
|
|
65
|
+
/**
|
|
66
|
+
* Metodo invocato al salvataggio o alla chiusura del dialog di aggiunta/modifica/visualizzazione
|
|
67
|
+
* di un record di una form di dettaglio.
|
|
68
|
+
* @param record Oggetto restituito dal componente add-form-field (questo qui) contenente il Record
|
|
69
|
+
* aggiornato dall'utente. Se null allora l'utente non ha modificato nulla e ha chiuso il dialog.
|
|
70
|
+
*/
|
|
71
|
+
DynamicModuleFieldComponent.prototype.onSaveInnerFormRecord = function (record) {
|
|
72
|
+
if (record != null) {
|
|
73
|
+
var arrayName = this.selectedInnerForm.Name.split(' ').join('_');
|
|
74
|
+
if (this.indexInnerFormRecord != null && this.indexInnerFormRecord >= 0) {
|
|
75
|
+
this.record[arrayName][this.indexInnerFormRecord] = record;
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
if (!this.record[arrayName]) {
|
|
79
|
+
this.record[arrayName] = [];
|
|
80
|
+
}
|
|
81
|
+
this.record[arrayName].push(record);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
this.dialogInnerFormRecordRef.close();
|
|
85
|
+
// Ricarico la tabella dei record per visualizzare le modifiche fatte dall'utente.
|
|
86
|
+
if (this.listInnerFormRecords && this.listInnerFormRecords.length > 0) {
|
|
87
|
+
this.listInnerFormRecords.forEach(function (list) {
|
|
88
|
+
if (list && list.tableRecords) {
|
|
89
|
+
list.tableRecords.reloadDatatable();
|
|
90
|
+
}
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
};
|
|
94
|
+
DynamicModuleFieldComponent.ctorParameters = function () { return [
|
|
95
|
+
{ type: MatDialog }
|
|
96
|
+
]; };
|
|
97
|
+
__decorate([
|
|
98
|
+
Input()
|
|
99
|
+
], DynamicModuleFieldComponent.prototype, "field", void 0);
|
|
100
|
+
__decorate([
|
|
101
|
+
Input()
|
|
102
|
+
], DynamicModuleFieldComponent.prototype, "form", void 0);
|
|
103
|
+
__decorate([
|
|
104
|
+
Input()
|
|
105
|
+
], DynamicModuleFieldComponent.prototype, "record", void 0);
|
|
106
|
+
__decorate([
|
|
107
|
+
Output()
|
|
108
|
+
], DynamicModuleFieldComponent.prototype, "recordChange", void 0);
|
|
109
|
+
__decorate([
|
|
110
|
+
ViewChild('dialogInnerFormRecord', { static: true })
|
|
111
|
+
], DynamicModuleFieldComponent.prototype, "dialogInnerFormRecord", void 0);
|
|
112
|
+
__decorate([
|
|
113
|
+
ViewChildren("fieldTemplate")
|
|
114
|
+
], DynamicModuleFieldComponent.prototype, "fieldTemplate", void 0);
|
|
115
|
+
__decorate([
|
|
116
|
+
ViewChildren('listInnerFormRecords')
|
|
117
|
+
], DynamicModuleFieldComponent.prototype, "listInnerFormRecords", void 0);
|
|
118
|
+
DynamicModuleFieldComponent = __decorate([
|
|
119
|
+
Component({
|
|
120
|
+
selector: 'dynamic-module-field',
|
|
121
|
+
template: "<text-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Campo di testo']\"\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\n</text-field-template>\n\n<textarea-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Area di testo']\"\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\n</textarea-field-template>\n\n<boolean-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Booleano']\"\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\n</boolean-field-template>\n\n<date-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Data e/o ora']\"\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\n</date-field-template>\n\n<numeric-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Campo numerico']\"\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\n</numeric-field-template>\n\n<list-value-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Elenco generico']\"\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\n</list-value-field-template>\n\n<attachment-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Allegato']\"\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\n</attachment-field-template>\n\n<image-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Immagine']\"\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\n</image-field-template>\n\n<list-form-record #listInnerFormRecords *ngIf=\"field.FieldType == FieldTypeEnum['Form di dettaglio']\"\n [form]=\"getInnerFormFromField(field)\" [values]=\"record[field.Name]\"\n (onAddViewEditRecord)=\"onAddViewEditInnerFormRecord($event, field)\">\n</list-form-record>\n\n<!-- DIALOG PER AGGIUNGERE/MODIFICARE/VISUALIZZARE UN RECORD IN UNA FORM DI DETTAGLIO -->\n<ng-template #dialogInnerFormRecord>\n <add-form-record [form]=\"selectedInnerForm\" [record]=\"selectedInnerFormRecord\" [onlyView]=\"onlyViewInnerFormRecord\"\n (saveRecordEvent)=\"onSaveInnerFormRecord($event)\"></add-form-record>\n</ng-template>",
|
|
122
|
+
styles: [""]
|
|
123
|
+
})
|
|
124
|
+
], DynamicModuleFieldComponent);
|
|
125
|
+
return DynamicModuleFieldComponent;
|
|
126
|
+
}());
|
|
127
|
+
export { DynamicModuleFieldComponent };
|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-module-field.component.js","sourceRoot":"ng://@eqproject/eqp-dynamic-module/","sources":["lib/components/private/dynamic-module-field/dynamic-module-field.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, QueryList, TemplateRef, ViewChild, ViewChildren } from '@angular/core';\nimport { MatDialog, MatDialogRef } from '@angular/material/dialog';\nimport { IBaseFieldComponent } from '../../../interfaces/iBaseFieldComponent.interface';\nimport { BaseField, FieldTypeEnum } from '../../../models/baseField.model';\nimport { Form } from '../../../models/form.model';\nimport { Record } from '../../../models/record.model';\nimport { ListFormRecordComponent } from '../form-records/list-form-record/list-form-record.component';\n\n@Component({\n  selector: 'dynamic-module-field',\n  templateUrl: './dynamic-module-field.component.html',\n  styleUrls: ['./dynamic-module-field.component.scss']\n})\nexport class DynamicModuleFieldComponent implements OnInit, IBaseFieldComponent {\n\n  @Input() field: BaseField;\n  @Input() form: Form;\n  @Input() record: Record;\n  @Output() recordChange: EventEmitter<Record> = new EventEmitter<Record>();\n\n  FieldTypeEnum = FieldTypeEnum;\n\n  //#region Proprietà per aggiungere/modificare i record di una form di dettaglio\n  selectedInnerForm: Form;\n  selectedInnerFormRecord: Record;\n  indexInnerFormRecord: number;\n  onlyViewInnerFormRecord: boolean = false;\n  dialogInnerFormRecordRef: MatDialogRef<TemplateRef<any>>;\n  @ViewChild('dialogInnerFormRecord', { static: true }) dialogInnerFormRecord: TemplateRef<any>;\n  //#endregion\n\n  @ViewChildren(\"fieldTemplate\") fieldTemplate: QueryList<DynamicModuleFieldComponent>;\n  @ViewChildren('listInnerFormRecords') listInnerFormRecords: QueryList<ListFormRecordComponent>;\n\n  constructor(\n    private dialog: MatDialog\n  ) { }\n\n\n  updateField(): void {\n    if (this.fieldTemplate && this.fieldTemplate.length > 0) {\n      this.fieldTemplate.forEach(f => f.updateField());\n    }\n  }\n\n  ngOnInit(): void {\n  }\n\n  /**\n   * Metodo invocato al cambio del valore di ogni proprietà dell'oggetto record.\n   * Serve ad aggiornare il valore di tutti i campi che hanno una formula.\n   */\n  onRecordChange() {\n    this.recordChange.emit(this.record);\n  }\n\n  /**\n   * Metodo per recuperare una InnerForm a partire dal Field che la rappresenta.\n   * @param field Campo a partire dal quale si vuole recuperare la InnerForm.\n   * @returns Restituisce un oggetto di tipo Form.\n   */\n  getInnerFormFromField(field: BaseField): Form {\n    if (this.form.InnerForms && this.form.InnerForms.find(f => f.Name == field.Label)) {\n      return this.form.InnerForms.find(f => f.Name == field.Label);\n    } else {\n      return null;\n    }\n  }\n\n  /**\n * Metodo per aprire un dialog in cui aggiungere/modificare/visualizzare un record appartenente\n * a una form di dettaglio.\n * @param record Evento di output del componente list-form-record, contiene il record selezionato e un booleno che indica \n * se l'utente vuole modificare o visualizzare l'elemento selezionato.\n * @param innerForm Contiene la Form di dettaglio dalla quale è stato richiesto il record.\n */\n  onAddViewEditInnerFormRecord(record: { record: Record, onlyView: boolean }, field: BaseField) {\n    this.selectedInnerForm = this.getInnerFormFromField(field);\n    if (record == null) {\n      this.selectedInnerFormRecord = new Record();\n      this.indexInnerFormRecord = null;\n      this.onlyViewInnerFormRecord = false;\n    } else {\n      this.selectedInnerFormRecord = JSON.parse(JSON.stringify(record.record));\n      this.indexInnerFormRecord = this.record[field.Name].indexOf(record);\n      this.onlyViewInnerFormRecord = record.onlyView;\n    }\n\n    this.dialogInnerFormRecordRef = this.dialog.open(this.dialogInnerFormRecord, {\n      disableClose: true,\n      hasBackdrop: true,\n      width: '75%'\n    });\n  }\n\n  /**\n   * Metodo invocato al salvataggio o alla chiusura del dialog di aggiunta/modifica/visualizzazione\n   * di un record di una form di dettaglio.\n   * @param record Oggetto restituito dal componente add-form-field (questo qui) contenente il Record \n   * aggiornato dall'utente. Se null allora l'utente non ha modificato nulla e ha chiuso il dialog.\n   */\n  onSaveInnerFormRecord(record: Record) {\n    if (record != null) {\n      const arrayName: string = this.selectedInnerForm.Name.split(' ').join('_');\n      if (this.indexInnerFormRecord != null && this.indexInnerFormRecord >= 0) {\n        this.record[arrayName][this.indexInnerFormRecord] = record;\n      } else {\n        if (!this.record[arrayName]) {\n          this.record[arrayName] = [];\n        }\n        this.record[arrayName].push(record);\n      }\n    }\n    this.dialogInnerFormRecordRef.close();\n\n    // Ricarico la tabella dei record per visualizzare le modifiche fatte dall'utente.\n    if (this.listInnerFormRecords && this.listInnerFormRecords.length > 0) {\n      this.listInnerFormRecords.forEach(list => {\n        if (list && list.tableRecords) {\n          list.tableRecords.reloadDatatable();\n        }\n      });\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1,184 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { AfterViewInit, ChangeDetectorRef, Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, TemplateRef, ViewChild } from '@angular/core';
|
|
3
|
+
import { AvailableFileExtensions, AvailableImageExtensions } from '../../../../models/fields/attachmentField.model';
|
|
4
|
+
import { UtilityHelperService } from '../../../../services/utilityHelper.services';
|
|
5
|
+
import { TypeColumn } from '@eqproject/eqp-table';
|
|
6
|
+
var AttachmentFieldTemplateComponent = /** @class */ (function () {
|
|
7
|
+
//#endregion
|
|
8
|
+
function AttachmentFieldTemplateComponent(utilityService, cdr) {
|
|
9
|
+
this.utilityService = utilityService;
|
|
10
|
+
this.cdr = cdr;
|
|
11
|
+
this.onlyImages = false;
|
|
12
|
+
this.recordChange = new EventEmitter();
|
|
13
|
+
this.metadataFormGroups = new Array();
|
|
14
|
+
//#region Etichette per eqp-attachments
|
|
15
|
+
this.previewLabel = "Anteprima";
|
|
16
|
+
this.emptyTableMessage = "No record found";
|
|
17
|
+
this.downloadTooltipPosition = "below";
|
|
18
|
+
this.openLinkLabel = "Apri link";
|
|
19
|
+
this.addButtonLabel = "Aggiungi";
|
|
20
|
+
this.downloadLabel = "Download";
|
|
21
|
+
this.deleteLabel = "Elimina";
|
|
22
|
+
this.fileNameLabel = "Nome file";
|
|
23
|
+
this.uploadFileLabel = "Carica file";
|
|
24
|
+
this.confirmLabel = "Conferma";
|
|
25
|
+
this.abortLabel = "Annulla";
|
|
26
|
+
this.saveLabel = "Salva";
|
|
27
|
+
this.exitLabel = "Esci";
|
|
28
|
+
this.eqpTableSearchText = "Cerca...";
|
|
29
|
+
this.deleteDialogTitle = "Attenzione:";
|
|
30
|
+
this.deleteDialogMessage = "Sicuro di voler eliminare questo allegato?";
|
|
31
|
+
this.noImageSelectedErrorMessage = "Nessuna immagine selezionata!";
|
|
32
|
+
}
|
|
33
|
+
AttachmentFieldTemplateComponent.prototype.ngOnInit = function () {
|
|
34
|
+
// Nel caso in cui sono in modifica di un Record aggiorno il valore
|
|
35
|
+
// e il validator del FormControl. Se non viene eseguita questa riga
|
|
36
|
+
// l'utente deve modificare la selezione fatta per aggiornare la form.
|
|
37
|
+
this.setFormControlValue();
|
|
38
|
+
// Sempre nel caso in cui sono in modifica creo i FormGroup che rappresentano
|
|
39
|
+
// gli eventuali metadata degli allegati recuperati.
|
|
40
|
+
this.createMetadataFormGroups();
|
|
41
|
+
if (this.field.MetadataFields) {
|
|
42
|
+
this.field.MetadataFields.sort(function (a, b) { return (a.OrdinalPosition > b.OrdinalPosition) ? 1 : ((b.OrdinalPosition > a.OrdinalPosition) ? -1 : 0); });
|
|
43
|
+
}
|
|
44
|
+
if (!this.field.AllowedExtensions) {
|
|
45
|
+
this.field.AllowedExtensions = AvailableFileExtensions.concat(AvailableImageExtensions).map(function (ext) { return ext.key; });
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
AttachmentFieldTemplateComponent.prototype.ngAfterViewInit = function () {
|
|
49
|
+
// Dopo aver renderizzato il DOM, se il campo ammette molteplici allegati
|
|
50
|
+
// configuro le colonne della eqp-table in eqp-attachments.
|
|
51
|
+
if (this.field.IsMultiAttach) {
|
|
52
|
+
this.configureMultiAttachmentColumns();
|
|
53
|
+
}
|
|
54
|
+
};
|
|
55
|
+
AttachmentFieldTemplateComponent.prototype.ngOnChanges = function (changes) {
|
|
56
|
+
// Se viene modificato il valore di "ngModelInput" allora aggiorna l'input
|
|
57
|
+
if (changes['record'] != undefined && changes['record'].firstChange == false && JSON.stringify(changes['record'].currentValue) != JSON.stringify(changes['record'].previousValue)) {
|
|
58
|
+
this.record = changes['record'].currentValue;
|
|
59
|
+
this.updateField();
|
|
60
|
+
}
|
|
61
|
+
};
|
|
62
|
+
/**
|
|
63
|
+
* Metodo per aggiornare il valore del campo quando questo è rappresentato da una formula.
|
|
64
|
+
*/
|
|
65
|
+
AttachmentFieldTemplateComponent.prototype.updateField = function () {
|
|
66
|
+
if (this.field.Formula) {
|
|
67
|
+
this.record[this.field.Name] = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, null);
|
|
68
|
+
}
|
|
69
|
+
};
|
|
70
|
+
/**
|
|
71
|
+
* Metodo per intercettare le modifiche agli allegati caricati.
|
|
72
|
+
* Se il campo prevede dei metadata allora per ogni allegato caricato crea un FormGroup
|
|
73
|
+
* per gestire la validazione degli input che l'utente può/deve riempire. I FormGroup
|
|
74
|
+
* seguono lo stesso ordine degli allegati caricati.
|
|
75
|
+
* @param event Contiene la lista aggiornata degli Attachment caricati dall'utente.
|
|
76
|
+
*/
|
|
77
|
+
AttachmentFieldTemplateComponent.prototype.catchAttachmentList = function (event) {
|
|
78
|
+
this.record[this.field.Name] = event;
|
|
79
|
+
this.createMetadataFormGroups();
|
|
80
|
+
this.setFormControlValue();
|
|
81
|
+
this.onRecordValueChange();
|
|
82
|
+
this.cdr.detectChanges();
|
|
83
|
+
};
|
|
84
|
+
/**
|
|
85
|
+
* Metodo per aggiornare lo stato di validazione del FormControl che rappresenta
|
|
86
|
+
* il campo Allegato (non i metadata al suo interno). Se tra le form dei metadata
|
|
87
|
+
* ne trova una invalida allora marca il controllo come invalido.
|
|
88
|
+
*/
|
|
89
|
+
AttachmentFieldTemplateComponent.prototype.updateMetadataValidity = function () {
|
|
90
|
+
if (this.metadataFormGroups.find(function (form) { return form.invalid; })) {
|
|
91
|
+
this.field.FormFormGroup.controls[this.field.Name].setErrors({ 'incorrect': true });
|
|
92
|
+
}
|
|
93
|
+
else {
|
|
94
|
+
this.field.FormFormGroup.controls[this.field.Name].setErrors(null);
|
|
95
|
+
}
|
|
96
|
+
this.onRecordValueChange();
|
|
97
|
+
};
|
|
98
|
+
/**
|
|
99
|
+
* Metodo per recuperare il BaseField che rappresenta il metadata nella riga della eqp-table
|
|
100
|
+
* in base alla colonna e alla riga. Una volta trovato il BaseField gli viene associato il
|
|
101
|
+
* FormGroup di cui fa parte.
|
|
102
|
+
* @param col Colonna della eqp-table.
|
|
103
|
+
* @param row Riga della eqp-table (in questo caso eredita da IAttachment).
|
|
104
|
+
* @returns Restituisce un BaseField per renderizzare il campo nella eqp-table degli allegati multipli.
|
|
105
|
+
*/
|
|
106
|
+
AttachmentFieldTemplateComponent.prototype.getFieldFromMetadata = function (col, row) {
|
|
107
|
+
var baseField = JSON.parse(JSON.stringify(this.field.MetadataFields.find(function (metadata) { return metadata.Name === col.key; })));
|
|
108
|
+
baseField.FormFormGroup = this.metadataFormGroups[this.record[this.field.Name].indexOf(row)];
|
|
109
|
+
return baseField;
|
|
110
|
+
};
|
|
111
|
+
/**
|
|
112
|
+
* Metodo per aggiornare il valore e il validator del FormControl associato al campo.
|
|
113
|
+
*/
|
|
114
|
+
AttachmentFieldTemplateComponent.prototype.setFormControlValue = function () {
|
|
115
|
+
this.field.FormFormGroup.controls[this.field.Name].setValue(this.record[this.field.Name]);
|
|
116
|
+
};
|
|
117
|
+
/**
|
|
118
|
+
* Metodo per emettere l'evento che il valore del record è cambiato.
|
|
119
|
+
*/
|
|
120
|
+
AttachmentFieldTemplateComponent.prototype.onRecordValueChange = function () {
|
|
121
|
+
if (!this.field.Formula) {
|
|
122
|
+
this.recordChange.emit(this.record);
|
|
123
|
+
}
|
|
124
|
+
};
|
|
125
|
+
/**
|
|
126
|
+
* Metodo per aggiungere alle colonne di eqp-attachments le colonne per modificare i metadata
|
|
127
|
+
* configurati per il campo Allegato o Immagine.
|
|
128
|
+
*/
|
|
129
|
+
AttachmentFieldTemplateComponent.prototype.configureMultiAttachmentColumns = function () {
|
|
130
|
+
var _this = this;
|
|
131
|
+
if (this.eqpAttachments && this.eqpAttachments.attachmentsColumns && this.field.MetadataFields && this.field.MetadataFields.length > 0) {
|
|
132
|
+
this.field.MetadataFields.forEach(function (metadata) {
|
|
133
|
+
_this.eqpAttachments.attachmentsColumns.splice(_this.eqpAttachments.attachmentsColumns.length - 1, 0, { key: metadata.Name, display: metadata.Label, type: TypeColumn.ExternalTemplate, externalTemplate: _this.metadataColumnTemplate });
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
};
|
|
137
|
+
/**
|
|
138
|
+
* Metodo per creare i FormGroup che rappresentano i metadata degli allegati caricati.
|
|
139
|
+
*/
|
|
140
|
+
AttachmentFieldTemplateComponent.prototype.createMetadataFormGroups = function () {
|
|
141
|
+
var _this = this;
|
|
142
|
+
if (this.field.MetadataFields && this.field.MetadataFields.length > 0) {
|
|
143
|
+
this.metadataFormGroups = [];
|
|
144
|
+
if (this.record[this.field.Name] && this.record[this.field.Name].length > 0) {
|
|
145
|
+
this.record[this.field.Name].forEach(function (attachment) {
|
|
146
|
+
_this.metadataFormGroups.push(_this.utilityService.CreateFormFormGroup(_this.field.MetadataFields, attachment, _this.field.FormFormGroup.disabled, !_this.field.IsMultiAttach));
|
|
147
|
+
});
|
|
148
|
+
}
|
|
149
|
+
this.updateMetadataValidity();
|
|
150
|
+
}
|
|
151
|
+
};
|
|
152
|
+
AttachmentFieldTemplateComponent.ctorParameters = function () { return [
|
|
153
|
+
{ type: UtilityHelperService },
|
|
154
|
+
{ type: ChangeDetectorRef }
|
|
155
|
+
]; };
|
|
156
|
+
__decorate([
|
|
157
|
+
Input()
|
|
158
|
+
], AttachmentFieldTemplateComponent.prototype, "onlyImages", void 0);
|
|
159
|
+
__decorate([
|
|
160
|
+
Input()
|
|
161
|
+
], AttachmentFieldTemplateComponent.prototype, "field", void 0);
|
|
162
|
+
__decorate([
|
|
163
|
+
Input()
|
|
164
|
+
], AttachmentFieldTemplateComponent.prototype, "record", void 0);
|
|
165
|
+
__decorate([
|
|
166
|
+
Output()
|
|
167
|
+
], AttachmentFieldTemplateComponent.prototype, "recordChange", void 0);
|
|
168
|
+
__decorate([
|
|
169
|
+
ViewChild("eqpAttachments", { static: true })
|
|
170
|
+
], AttachmentFieldTemplateComponent.prototype, "eqpAttachments", void 0);
|
|
171
|
+
__decorate([
|
|
172
|
+
ViewChild('metadataColumnTemplate', { static: true })
|
|
173
|
+
], AttachmentFieldTemplateComponent.prototype, "metadataColumnTemplate", void 0);
|
|
174
|
+
AttachmentFieldTemplateComponent = __decorate([
|
|
175
|
+
Component({
|
|
176
|
+
selector: 'attachment-field-template',
|
|
177
|
+
template: "<p *ngIf=\"!field.IsMultiAttach\" class=\"mb-2\">\n {{field.Label + (field.Required ? \" *\" : \"\")}}\n</p>\n<div class=\"row\" *ngIf=\"!field.IsMultiAttach && record[field.Name] && record[field.Name][0]\">\n <div class=\"mt-2\" *ngFor=\"let metadata of field.MetadataFields\" [ngClass]=\"utilityService.getFieldSyleClass(metadata)\">\n <dynamic-module-field [field]=\"metadata\" [record]=\"record[field.Name][0]\"\n (recordChange)=\"updateMetadataValidity()\">\n </dynamic-module-field>\n </div>\n</div>\n\n\n\n<eqp-attachments [attachmentsList]=\"record[field.Name]\" [showMatCard]=\"true\" [allowOnlyImages]=\"onlyImages\"\n [isDisabled]=\"field.FormFormGroup.disabled\" [showInlinePreview]=\"true\" [multipleAttachment]=\"field.IsMultiAttach\"\n [disableAction]=\"field.FormFormGroup.disabled\" [acceptedFileTypes]=\"field.AllowedExtensions\" [showHeader]=\"true\"\n [headerTitle]=\"field.Label + (field.Required ? ' *' : '')\" [previewLabel]=\"previewLabel\"\n [emptyTableMessage]=\"emptyTableMessage\" [downloadTooltipPosition]=\"downloadTooltipPosition\"\n [openLinkLabel]=\"openLinkLabel\" [addButtonLabel]=\"addButtonLabel\" [downloadLabel]=\"downloadLabel\"\n [deleteLabel]=\"deleteLabel\" [fileNameLabel]=\"fileNameLabel\" [uploadFileLabel]=\"uploadFileLabel\"\n [confirmLabel]=\"confirmLabel\" [abortLabel]=\"abortLabel\" [saveLabel]=\"saveLabel\" [exitLabel]=\"exitLabel\"\n [eqpTableSearchText]=\"eqpTableSearchText\" [deleteDialogTitle]=\"deleteDialogTitle\"\n [deleteDialogMessage]=\"deleteDialogMessage\" [noImageSelectedErrorMessage]=\"noImageSelectedErrorMessage\"\n (localEditedAttachments)=\"catchAttachmentList($event)\" #eqpAttachments>\n</eqp-attachments>\n\n<!-- TEMPLATE PER VISUALIZZARE LA COLONNA DELLA SEZIONE NELLA TABELLA DEI FIELDS -->\n<ng-template #metadataColumnTemplate let-row=\"row\" let-col=\"col\">\n <dynamic-module-field [field]=\"getFieldFromMetadata(col, row)\" [record]=\"row\"\n (recordChange)=\"updateMetadataValidity()\">\n </dynamic-module-field>\n</ng-template>",
|
|
178
|
+
styles: [""]
|
|
179
|
+
})
|
|
180
|
+
], AttachmentFieldTemplateComponent);
|
|
181
|
+
return AttachmentFieldTemplateComponent;
|
|
182
|
+
}());
|
|
183
|
+
export { AttachmentFieldTemplateComponent };
|
|
184
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attachment-field-template.component.js","sourceRoot":"ng://@eqproject/eqp-dynamic-module/","sources":["lib/components/private/field-templates/attachment-field-template/attachment-field-template.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectorRef, Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, TemplateRef, ViewChild } from '@angular/core';\r\nimport { Record } from '../../../../models/record.model';\r\nimport { AttachmentField, AvailableFileExtensions, AvailableImageExtensions } from '../../../../models/fields/attachmentField.model';\r\nimport { IBaseFieldComponent } from '../../../../interfaces/iBaseFieldComponent.interface';\r\nimport { UtilityHelperService } from '../../../../services/utilityHelper.services';\r\nimport { EqpAttachmentsComponent } from '@eqproject/eqp-attachments';\r\nimport { FormGroup } from '@angular/forms';\r\nimport { ConfigColumn, TypeColumn } from '@eqproject/eqp-table';\r\n\r\n@Component({\r\n  selector: 'attachment-field-template',\r\n  templateUrl: './attachment-field-template.component.html',\r\n  styleUrls: ['./attachment-field-template.component.scss']\r\n})\r\nexport class AttachmentFieldTemplateComponent implements OnInit, OnChanges, IBaseFieldComponent, AfterViewInit {\r\n\r\n  @Input() onlyImages: boolean = false;\r\n  @Input() field: AttachmentField;\r\n  @Input() record: Record;\r\n  @Output() recordChange: EventEmitter<Record> = new EventEmitter<Record>();\r\n\r\n  @ViewChild(\"eqpAttachments\", { static: true }) eqpAttachments: EqpAttachmentsComponent;\r\n  @ViewChild('metadataColumnTemplate', { static: true }) metadataColumnTemplate: TemplateRef<any>;\r\n\r\n  metadataFormGroups: Array<FormGroup> = new Array<FormGroup>();\r\n\r\n  //#region Etichette per eqp-attachments\r\n  previewLabel = \"Anteprima\";\r\n  emptyTableMessage = \"No record found\";\r\n  downloadTooltipPosition = \"below\";\r\n  openLinkLabel = \"Apri link\";\r\n  addButtonLabel = \"Aggiungi\";\r\n  downloadLabel = \"Download\";\r\n  deleteLabel = \"Elimina\";\r\n  fileNameLabel = \"Nome file\";\r\n  uploadFileLabel = \"Carica file\";\r\n  confirmLabel = \"Conferma\";\r\n  abortLabel = \"Annulla\";\r\n  saveLabel = \"Salva\";\r\n  exitLabel = \"Esci\";\r\n  eqpTableSearchText = \"Cerca...\";\r\n  deleteDialogTitle = \"Attenzione:\";\r\n  deleteDialogMessage = \"Sicuro di voler eliminare questo allegato?\";\r\n  noImageSelectedErrorMessage = \"Nessuna immagine selezionata!\";\r\n  //#endregion\r\n\r\n  constructor(\r\n    public utilityService: UtilityHelperService,\r\n    private cdr: ChangeDetectorRef\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    // Nel caso in cui sono in modifica di un Record aggiorno il valore\r\n    // e il validator del FormControl. Se non viene eseguita questa riga\r\n    // l'utente deve modificare la selezione fatta per aggiornare la form.\r\n    this.setFormControlValue();\r\n\r\n    // Sempre nel caso in cui sono in modifica creo i FormGroup che rappresentano\r\n    // gli eventuali metadata degli allegati recuperati.\r\n    this.createMetadataFormGroups();\r\n    if (this.field.MetadataFields) {\r\n      this.field.MetadataFields.sort((a, b) => (a.OrdinalPosition > b.OrdinalPosition) ? 1 : ((b.OrdinalPosition > a.OrdinalPosition) ? -1 : 0));\r\n    }\r\n\r\n    if (!this.field.AllowedExtensions) {\r\n      this.field.AllowedExtensions = AvailableFileExtensions.concat(AvailableImageExtensions).map(ext => ext.key);\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    // Dopo aver renderizzato il DOM, se il campo ammette molteplici allegati\r\n    // configuro le colonne della eqp-table in eqp-attachments.\r\n    if (this.field.IsMultiAttach) {\r\n      this.configureMultiAttachmentColumns();\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    // Se viene modificato il valore di \"ngModelInput\" allora aggiorna l'input\r\n    if (changes['record'] != undefined && changes['record'].firstChange == false && JSON.stringify(changes['record'].currentValue) != JSON.stringify(changes['record'].previousValue)) {\r\n      this.record = changes['record'].currentValue;\r\n      this.updateField();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per aggiornare il valore del campo quando questo è rappresentato da una formula.\r\n   */\r\n  updateField() {\r\n    if (this.field.Formula) {\r\n      this.record[this.field.Name] = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, null);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per intercettare le modifiche agli allegati caricati.\r\n   * Se il campo prevede dei metadata allora per ogni allegato caricato crea un FormGroup\r\n   * per gestire la validazione degli input che l'utente può/deve riempire. I FormGroup \r\n   * seguono lo stesso ordine degli allegati caricati.\r\n   * @param event Contiene la lista aggiornata degli Attachment caricati dall'utente.\r\n   */\r\n  catchAttachmentList(event) {\r\n    this.record[this.field.Name] = event;\r\n\r\n    this.createMetadataFormGroups();\r\n\r\n    this.setFormControlValue();\r\n    this.onRecordValueChange();\r\n    \r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  /**\r\n   * Metodo per aggiornare lo stato di validazione del FormControl che rappresenta \r\n   * il campo Allegato (non i metadata al suo interno). Se tra le form dei metadata\r\n   * ne trova una invalida allora marca il controllo come invalido.\r\n   */\r\n  updateMetadataValidity() {\r\n    if (this.metadataFormGroups.find(form => form.invalid)) {\r\n      this.field.FormFormGroup.controls[this.field.Name].setErrors({ 'incorrect': true });\r\n    } else {\r\n      this.field.FormFormGroup.controls[this.field.Name].setErrors(null);\r\n    }\r\n    this.onRecordValueChange();\r\n  }\r\n\r\n  /**\r\n   * Metodo per recuperare il BaseField che rappresenta il metadata nella riga della eqp-table\r\n   * in base alla colonna e alla riga. Una volta trovato il BaseField gli viene associato il \r\n   * FormGroup di cui fa parte.\r\n   * @param col Colonna della eqp-table.\r\n   * @param row Riga della eqp-table (in questo caso eredita da IAttachment).\r\n   * @returns Restituisce un BaseField per renderizzare il campo nella eqp-table degli allegati multipli.\r\n   */\r\n  getFieldFromMetadata(col: ConfigColumn, row: any) {\r\n    var baseField = JSON.parse(JSON.stringify(this.field.MetadataFields.find(metadata => metadata.Name === col.key)));\r\n    baseField.FormFormGroup = this.metadataFormGroups[this.record[this.field.Name].indexOf(row)];\r\n    return baseField;\r\n  }\r\n\r\n  /**\r\n   * Metodo per aggiornare il valore e il validator del FormControl associato al campo.\r\n   */\r\n  private setFormControlValue() {\r\n    this.field.FormFormGroup.controls[this.field.Name].setValue(this.record[this.field.Name]);\r\n  }\r\n\r\n  /**\r\n   * Metodo per emettere l'evento che il valore del record è cambiato.\r\n   */\r\n  private onRecordValueChange() {\r\n    if (!this.field.Formula) {\r\n      this.recordChange.emit(this.record);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per aggiungere alle colonne di eqp-attachments le colonne per modificare i metadata\r\n   * configurati per il campo Allegato o Immagine.\r\n   */\r\n  private configureMultiAttachmentColumns() {\r\n    if (this.eqpAttachments && this.eqpAttachments.attachmentsColumns && this.field.MetadataFields && this.field.MetadataFields.length > 0) {\r\n      this.field.MetadataFields.forEach(metadata => {\r\n        this.eqpAttachments.attachmentsColumns.splice(\r\n          this.eqpAttachments.attachmentsColumns.length - 1, 0,\r\n          { key: metadata.Name, display: metadata.Label, type: TypeColumn.ExternalTemplate, externalTemplate: this.metadataColumnTemplate }\r\n        );\r\n      });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per creare i FormGroup che rappresentano i metadata degli allegati caricati.\r\n   */\r\n  private createMetadataFormGroups() {\r\n    if (this.field.MetadataFields && this.field.MetadataFields.length > 0) {\r\n      this.metadataFormGroups = [];\r\n      if (this.record[this.field.Name] && this.record[this.field.Name].length > 0) {\r\n        this.record[this.field.Name].forEach(attachment => {\r\n          this.metadataFormGroups.push(this.utilityService.CreateFormFormGroup(this.field.MetadataFields, attachment, this.field.FormFormGroup.disabled, !this.field.IsMultiAttach));\r\n        });\r\n      }\r\n\r\n      this.updateMetadataValidity();\r\n    }\r\n  }\r\n}"]}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
3
|
+
import { BoolPresentantioEnum } from '../../../../models/fields/booleanField.model';
|
|
4
|
+
import { UtilityHelperService } from '../../../../services/utilityHelper.services';
|
|
5
|
+
var BooleanFieldTemplateComponent = /** @class */ (function () {
|
|
6
|
+
function BooleanFieldTemplateComponent() {
|
|
7
|
+
this.recordChange = new EventEmitter();
|
|
8
|
+
this.BoolPresentantioEnum = BoolPresentantioEnum;
|
|
9
|
+
}
|
|
10
|
+
BooleanFieldTemplateComponent.prototype.ngOnInit = function () {
|
|
11
|
+
if (this.record[this.field.Name] == undefined || this.record[this.field.Name] == null) {
|
|
12
|
+
this.record[this.field.Name] = this.field.IsTristate ? null : false;
|
|
13
|
+
}
|
|
14
|
+
};
|
|
15
|
+
BooleanFieldTemplateComponent.prototype.ngOnChanges = function (changes) {
|
|
16
|
+
// Se viene modificato il valore di "ngModelInput" allora aggiorna l'input
|
|
17
|
+
if (changes['record'] != undefined && changes['record'].firstChange == false && JSON.stringify(changes['record'].currentValue) != JSON.stringify(changes['record'].previousValue)) {
|
|
18
|
+
this.record = changes['record'].currentValue;
|
|
19
|
+
this.updateField();
|
|
20
|
+
}
|
|
21
|
+
};
|
|
22
|
+
/**
|
|
23
|
+
* Metodo per aggiornare il valore del campo quando questo è rappresentato da una formula.
|
|
24
|
+
*/
|
|
25
|
+
BooleanFieldTemplateComponent.prototype.updateField = function () {
|
|
26
|
+
if (this.field.Formula) {
|
|
27
|
+
this.record[this.field.Name] = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, null);
|
|
28
|
+
}
|
|
29
|
+
};
|
|
30
|
+
/**
|
|
31
|
+
* Metodo per emettere l'evento che il valore del record è cambiato.
|
|
32
|
+
*/
|
|
33
|
+
BooleanFieldTemplateComponent.prototype.onRecordValueChange = function () {
|
|
34
|
+
if (!this.field.Formula) {
|
|
35
|
+
this.recordChange.emit(this.record);
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
__decorate([
|
|
39
|
+
Input()
|
|
40
|
+
], BooleanFieldTemplateComponent.prototype, "field", void 0);
|
|
41
|
+
__decorate([
|
|
42
|
+
Input()
|
|
43
|
+
], BooleanFieldTemplateComponent.prototype, "record", void 0);
|
|
44
|
+
__decorate([
|
|
45
|
+
Output()
|
|
46
|
+
], BooleanFieldTemplateComponent.prototype, "recordChange", void 0);
|
|
47
|
+
BooleanFieldTemplateComponent = __decorate([
|
|
48
|
+
Component({
|
|
49
|
+
selector: 'boolean-field-template',
|
|
50
|
+
template: "<div [formGroup]=\"field.FormFormGroup\">\n\n <!-- VISUALIZZAZIONE A TOGGLE -->\n <mat-slide-toggle color=\"primary\" *ngIf=\"field.PresetationType == BoolPresentantioEnum.Toggle\"\n [formControlName]=\"field.Name\" [disabled]=\"field.FormFormGroup.disabled\" [required]=\"field.Required\"\n [(ngModel)]=\"record[field.Name]\" (ngModelChange)=\"onRecordValueChange()\">\n {{field.Label + (field.Required ? \" *\" : \"\")}}\n </mat-slide-toggle>\n\n\n <!-- VISUALIZZAZIONE A RADIOBUTTON -->\n <mat-label class=\"mr-3\" *ngIf=\"field.PresetationType == BoolPresentantioEnum['Radio button']\">\n {{field.Label + (field.Required ? \" *\" : \"\")}}\n </mat-label>\n <mat-radio-group *ngIf=\"field.PresetationType == BoolPresentantioEnum['Radio button']\"\n [formControlName]=\"field.Name\" [disabled]=\"field.FormFormGroup.disabled\" [required]=\"field.Required\"\n [(ngModel)]=\"record[field.Name]\" (ngModelChange)=\"onRecordValueChange()\">\n <mat-radio-button class=\"mr-2\" [value]=\"true\" color=\"primary\"> Si </mat-radio-button>\n <mat-radio-button class=\"mr-2\" [value]=\"false\" color=\"primary\"> No </mat-radio-button>\n <mat-radio-button class=\"mr-2\" [value]=\"null\" color=\"primary\" *ngIf=\"field.IsTristate\"> ND\n </mat-radio-button>\n </mat-radio-group>\n\n <!-- VISUALIZZAZIONE A CHECKBOX -->\n <mat-checkbox class=\"mr-2\" *ngIf=\"field.PresetationType == BoolPresentantioEnum.Checkbox\"\n [disabled]=\"field.FormFormGroup.disabled\" [required]=\"field.Required\" [formControlName]=\"field.Name\"\n [(ngModel)]=\"record[field.Name]\" (ngModelChange)=\"onRecordValueChange()\">\n {{field.Label + (field.Required ? \" *\" : \"\")}}\n </mat-checkbox>\n\n <!-- TODO: Visualizzazione \"Stringa true o false\" e \"Numerico 0 o 1\" ?? -->\n</div>",
|
|
51
|
+
styles: [""]
|
|
52
|
+
})
|
|
53
|
+
], BooleanFieldTemplateComponent);
|
|
54
|
+
return BooleanFieldTemplateComponent;
|
|
55
|
+
}());
|
|
56
|
+
export { BooleanFieldTemplateComponent };
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm9vbGVhbi1maWVsZC10ZW1wbGF0ZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AZXFwcm9qZWN0L2VxcC1keW5hbWljLW1vZHVsZS8iLCJzb3VyY2VzIjpbImxpYi9jb21wb25lbnRzL3ByaXZhdGUvZmllbGQtdGVtcGxhdGVzL2Jvb2xlYW4tZmllbGQtdGVtcGxhdGUvYm9vbGVhbi1maWVsZC10ZW1wbGF0ZS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBcUIsTUFBTSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUV6RyxPQUFPLEVBQWdCLG9CQUFvQixFQUFFLE1BQU0sOENBQThDLENBQUM7QUFFbEcsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFPbkY7SUFRRTtRQUpVLGlCQUFZLEdBQXlCLElBQUksWUFBWSxFQUFVLENBQUM7UUFFMUUseUJBQW9CLEdBQUcsb0JBQW9CLENBQUM7SUFFNUIsQ0FBQztJQUVqQixnREFBUSxHQUFSO1FBQ0UsSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksU0FBUyxJQUFJLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxJQUFJLEVBQUU7WUFDckYsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQztTQUNyRTtJQUNILENBQUM7SUFFRCxtREFBVyxHQUFYLFVBQVksT0FBc0I7UUFDaEMsMEVBQTBFO1FBQzFFLElBQUksT0FBTyxDQUFDLFFBQVEsQ0FBQyxJQUFJLFNBQVMsSUFBSSxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUMsV0FBVyxJQUFJLEtBQUssSUFBSSxJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQyxZQUFZLENBQUMsSUFBSSxJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQyxhQUFhLENBQUMsRUFBRTtZQUNqTCxJQUFJLENBQUMsTUFBTSxHQUFHLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQyxZQUFZLENBQUM7WUFDN0MsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1NBQ3BCO0lBQ0gsQ0FBQztJQUVEOztPQUVHO0lBQ0gsbURBQVcsR0FBWDtRQUNFLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUU7WUFDdEIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxHQUFHLG9CQUFvQixDQUFDLG9CQUFvQixDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUM7U0FDakg7SUFDSCxDQUFDO0lBRUQ7O09BRUc7SUFDSCwyREFBbUIsR0FBbkI7UUFDRSxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUU7WUFDdkIsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1NBQ3JDO0lBQ0gsQ0FBQztJQXRDUTtRQUFSLEtBQUssRUFBRTtnRUFBcUI7SUFDcEI7UUFBUixLQUFLLEVBQUU7aUVBQWdCO0lBQ2Q7UUFBVCxNQUFNLEVBQUU7dUVBQWlFO0lBSi9ELDZCQUE2QjtRQUx6QyxTQUFTLENBQUM7WUFDVCxRQUFRLEVBQUUsd0JBQXdCO1lBQ2xDLDAyREFBc0Q7O1NBRXZELENBQUM7T0FDVyw2QkFBNkIsQ0F5Q3pDO0lBQUQsb0NBQUM7Q0FBQSxBQXpDRCxJQXlDQztTQXpDWSw2QkFBNkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uQ2hhbmdlcywgT25Jbml0LCBPdXRwdXQsIFNpbXBsZUNoYW5nZXMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgUmVjb3JkIH0gZnJvbSAnLi4vLi4vLi4vLi4vbW9kZWxzL3JlY29yZC5tb2RlbCc7XHJcbmltcG9ydCB7IEJvb2xlYW5GaWVsZCwgQm9vbFByZXNlbnRhbnRpb0VudW0gfSBmcm9tICcuLi8uLi8uLi8uLi9tb2RlbHMvZmllbGRzL2Jvb2xlYW5GaWVsZC5tb2RlbCc7XHJcbmltcG9ydCB7IElCYXNlRmllbGRDb21wb25lbnQgfSBmcm9tICcuLi8uLi8uLi8uLi9pbnRlcmZhY2VzL2lCYXNlRmllbGRDb21wb25lbnQuaW50ZXJmYWNlJztcclxuaW1wb3J0IHsgVXRpbGl0eUhlbHBlclNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi8uLi9zZXJ2aWNlcy91dGlsaXR5SGVscGVyLnNlcnZpY2VzJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYm9vbGVhbi1maWVsZC10ZW1wbGF0ZScsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2Jvb2xlYW4tZmllbGQtdGVtcGxhdGUuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2Jvb2xlYW4tZmllbGQtdGVtcGxhdGUuY29tcG9uZW50LnNjc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQm9vbGVhbkZpZWxkVGVtcGxhdGVDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uQ2hhbmdlcywgSUJhc2VGaWVsZENvbXBvbmVudCB7XHJcblxyXG4gIEBJbnB1dCgpIGZpZWxkOiBCb29sZWFuRmllbGQ7XHJcbiAgQElucHV0KCkgcmVjb3JkOiBSZWNvcmQ7XHJcbiAgQE91dHB1dCgpIHJlY29yZENoYW5nZTogRXZlbnRFbWl0dGVyPFJlY29yZD4gPSBuZXcgRXZlbnRFbWl0dGVyPFJlY29yZD4oKTtcclxuXHJcbiAgQm9vbFByZXNlbnRhbnRpb0VudW0gPSBCb29sUHJlc2VudGFudGlvRW51bTtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcbiAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICBpZiAodGhpcy5yZWNvcmRbdGhpcy5maWVsZC5OYW1lXSA9PSB1bmRlZmluZWQgfHwgdGhpcy5yZWNvcmRbdGhpcy5maWVsZC5OYW1lXSA9PSBudWxsKSB7XHJcbiAgICAgIHRoaXMucmVjb3JkW3RoaXMuZmllbGQuTmFtZV0gPSB0aGlzLmZpZWxkLklzVHJpc3RhdGUgPyBudWxsIDogZmFsc2U7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKSB7XHJcbiAgICAvLyBTZSB2aWVuZSBtb2RpZmljYXRvIGlsIHZhbG9yZSBkaSBcIm5nTW9kZWxJbnB1dFwiIGFsbG9yYSBhZ2dpb3JuYSBsJ2lucHV0XHJcbiAgICBpZiAoY2hhbmdlc1sncmVjb3JkJ10gIT0gdW5kZWZpbmVkICYmIGNoYW5nZXNbJ3JlY29yZCddLmZpcnN0Q2hhbmdlID09IGZhbHNlICYmIEpTT04uc3RyaW5naWZ5KGNoYW5nZXNbJ3JlY29yZCddLmN1cnJlbnRWYWx1ZSkgIT0gSlNPTi5zdHJpbmdpZnkoY2hhbmdlc1sncmVjb3JkJ10ucHJldmlvdXNWYWx1ZSkpIHtcclxuICAgICAgdGhpcy5yZWNvcmQgPSBjaGFuZ2VzWydyZWNvcmQnXS5jdXJyZW50VmFsdWU7XHJcbiAgICAgIHRoaXMudXBkYXRlRmllbGQoKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIE1ldG9kbyBwZXIgYWdnaW9ybmFyZSBpbCB2YWxvcmUgZGVsIGNhbXBvIHF1YW5kbyBxdWVzdG8gw6ggcmFwcHJlc2VudGF0byBkYSB1bmEgZm9ybXVsYS5cclxuICAgKi9cclxuICB1cGRhdGVGaWVsZCgpIHtcclxuICAgIGlmICh0aGlzLmZpZWxkLkZvcm11bGEpIHtcclxuICAgICAgdGhpcy5yZWNvcmRbdGhpcy5maWVsZC5OYW1lXSA9IFV0aWxpdHlIZWxwZXJTZXJ2aWNlLkV2YWx1YXRlRmllbGRGb3JtdWxhKHRoaXMuZmllbGQuRm9ybXVsYSwgdGhpcy5yZWNvcmQsIG51bGwpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogTWV0b2RvIHBlciBlbWV0dGVyZSBsJ2V2ZW50byBjaGUgaWwgdmFsb3JlIGRlbCByZWNvcmQgw6ggY2FtYmlhdG8uXHJcbiAgICovXHJcbiAgb25SZWNvcmRWYWx1ZUNoYW5nZSgpIHtcclxuICAgIGlmICghdGhpcy5maWVsZC5Gb3JtdWxhKSB7XHJcbiAgICAgIHRoaXMucmVjb3JkQ2hhbmdlLmVtaXQodGhpcy5yZWNvcmQpO1xyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
3
|
+
import { PickerModeEnum } from '@eqproject/eqp-datetimepicker';
|
|
4
|
+
import { DateTimeTypeEnum } from '../../../../models/fields/dateField.model';
|
|
5
|
+
import { UtilityHelperService } from '../../../../services/utilityHelper.services';
|
|
6
|
+
var DateFieldTemplateComponent = /** @class */ (function () {
|
|
7
|
+
function DateFieldTemplateComponent() {
|
|
8
|
+
this.recordChange = new EventEmitter();
|
|
9
|
+
}
|
|
10
|
+
DateFieldTemplateComponent.prototype.ngOnInit = function () {
|
|
11
|
+
this.setTimeType();
|
|
12
|
+
};
|
|
13
|
+
DateFieldTemplateComponent.prototype.ngOnChanges = function (changes) {
|
|
14
|
+
// Se viene modificato il valore di "ngModelInput" allora aggiorna l'input
|
|
15
|
+
if (changes['record'] != undefined && changes['record'].firstChange == false && JSON.stringify(changes['record'].currentValue) != JSON.stringify(changes['record'].previousValue)) {
|
|
16
|
+
this.record = changes['record'].currentValue;
|
|
17
|
+
this.updateField();
|
|
18
|
+
}
|
|
19
|
+
};
|
|
20
|
+
/**
|
|
21
|
+
* Metodo per aggiornare il valore del campo quando questo è rappresentato da una formula.
|
|
22
|
+
*/
|
|
23
|
+
DateFieldTemplateComponent.prototype.updateField = function () {
|
|
24
|
+
if (this.field.Formula) {
|
|
25
|
+
this.record[this.field.Name] = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, null);
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
/**
|
|
29
|
+
* Metodo per emettere l'evento che il valore del record è cambiato.
|
|
30
|
+
*/
|
|
31
|
+
DateFieldTemplateComponent.prototype.onRecordValueChange = function () {
|
|
32
|
+
if (!this.field.Formula) {
|
|
33
|
+
this.recordChange.emit(this.record);
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
/**
|
|
37
|
+
* In base al formato della data richiesta nel DateField (solo data, solo orario o data e ora)
|
|
38
|
+
* imposta la visualizzazione corretta del componente eqp-datetimepicker.
|
|
39
|
+
*/
|
|
40
|
+
DateFieldTemplateComponent.prototype.setTimeType = function () {
|
|
41
|
+
switch (this.field.IsOnlyDate) {
|
|
42
|
+
case DateTimeTypeEnum["Solo data"]:
|
|
43
|
+
this.pickerMode = PickerModeEnum.DATE;
|
|
44
|
+
break;
|
|
45
|
+
case DateTimeTypeEnum["Solo orario"]:
|
|
46
|
+
this.pickerMode = PickerModeEnum.TIME;
|
|
47
|
+
break;
|
|
48
|
+
case DateTimeTypeEnum["Data e ora"]:
|
|
49
|
+
this.pickerMode = PickerModeEnum.DATETIME;
|
|
50
|
+
break;
|
|
51
|
+
}
|
|
52
|
+
};
|
|
53
|
+
__decorate([
|
|
54
|
+
Input()
|
|
55
|
+
], DateFieldTemplateComponent.prototype, "field", void 0);
|
|
56
|
+
__decorate([
|
|
57
|
+
Input()
|
|
58
|
+
], DateFieldTemplateComponent.prototype, "record", void 0);
|
|
59
|
+
__decorate([
|
|
60
|
+
Output()
|
|
61
|
+
], DateFieldTemplateComponent.prototype, "recordChange", void 0);
|
|
62
|
+
DateFieldTemplateComponent = __decorate([
|
|
63
|
+
Component({
|
|
64
|
+
selector: 'date-field-template',
|
|
65
|
+
template: "<eqp-datetimepicker [placeholder]=\"field.Label\" [UTCDate]=\"true\" [pickerMode]=\"pickerMode\"\n [formGroupInput]=\"field.FormFormGroup\" [formControlNameInput]=\"field.Name\"\n [minDate]=\"field.MinDate ? field.MinDate : null\" [maxDate]=\"field.MaxDate ? field.MaxDate : null\"\n [isRequired]=\"field.Required\" [disabled]=\"field.FormFormGroup.disabled\" [(ngModelInput)]=\"record[field.Name]\"\n (ngModelInputChange)=\"onRecordValueChange()\">\n</eqp-datetimepicker>",
|
|
66
|
+
styles: [""]
|
|
67
|
+
})
|
|
68
|
+
], DateFieldTemplateComponent);
|
|
69
|
+
return DateFieldTemplateComponent;
|
|
70
|
+
}());
|
|
71
|
+
export { DateFieldTemplateComponent };
|
|
72
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1maWVsZC10ZW1wbGF0ZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AZXFwcm9qZWN0L2VxcC1keW5hbWljLW1vZHVsZS8iLCJzb3VyY2VzIjpbImxpYi9jb21wb25lbnRzL3ByaXZhdGUvZmllbGQtdGVtcGxhdGVzL2RhdGUtZmllbGQtdGVtcGxhdGUvZGF0ZS1maWVsZC10ZW1wbGF0ZS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBcUIsTUFBTSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUN6RyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFFL0QsT0FBTyxFQUFhLGdCQUFnQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFFeEYsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFPbkY7SUFRRTtRQUpVLGlCQUFZLEdBQXlCLElBQUksWUFBWSxFQUFVLENBQUM7SUFJMUQsQ0FBQztJQUVqQiw2Q0FBUSxHQUFSO1FBQ0UsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ3JCLENBQUM7SUFFRCxnREFBVyxHQUFYLFVBQVksT0FBc0I7UUFDaEMsMEVBQTBFO1FBQzFFLElBQUksT0FBTyxDQUFDLFFBQVEsQ0FBQyxJQUFJLFNBQVMsSUFBSSxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUMsV0FBVyxJQUFJLEtBQUssSUFBSSxJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQyxZQUFZLENBQUMsSUFBSSxJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQyxhQUFhLENBQUMsRUFBRTtZQUNqTCxJQUFJLENBQUMsTUFBTSxHQUFHLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQyxZQUFZLENBQUM7WUFDN0MsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1NBQ3BCO0lBQ0gsQ0FBQztJQUVEOztPQUVHO0lBQ0gsZ0RBQVcsR0FBWDtRQUNFLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUU7WUFDdEIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxHQUFHLG9CQUFvQixDQUFDLG9CQUFvQixDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUM7U0FDakg7SUFDSCxDQUFDO0lBRUQ7O09BRUc7SUFDSCx3REFBbUIsR0FBbkI7UUFDRSxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUU7WUFDdkIsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1NBQ3JDO0lBQ0gsQ0FBQztJQUVEOzs7T0FHRztJQUNLLGdEQUFXLEdBQW5CO1FBQ0UsUUFBUSxJQUFJLENBQUMsS0FBSyxDQUFDLFVBQVUsRUFBRTtZQUM3QixLQUFLLGdCQUFnQixDQUFDLFdBQVcsQ0FBQztnQkFDaEMsSUFBSSxDQUFDLFVBQVUsR0FBRyxjQUFjLENBQUMsSUFBSSxDQUFDO2dCQUN0QyxNQUFNO1lBQ1IsS0FBSyxnQkFBZ0IsQ0FBQyxhQUFhLENBQUM7Z0JBQ2xDLElBQUksQ0FBQyxVQUFVLEdBQUcsY0FBYyxDQUFDLElBQUksQ0FBQztnQkFDdEMsTUFBTTtZQUNSLEtBQUssZ0JBQWdCLENBQUMsWUFBWSxDQUFDO2dCQUNqQyxJQUFJLENBQUMsVUFBVSxHQUFHLGNBQWMsQ0FBQyxRQUFRLENBQUM7Z0JBQzFDLE1BQU07U0FDVDtJQUNILENBQUM7SUF0RFE7UUFBUixLQUFLLEVBQUU7NkRBQWtCO0lBQ2pCO1FBQVIsS0FBSyxFQUFFOzhEQUFnQjtJQUNkO1FBQVQsTUFBTSxFQUFFO29FQUFpRTtJQUovRCwwQkFBMEI7UUFMdEMsU0FBUyxDQUFDO1lBQ1QsUUFBUSxFQUFFLHFCQUFxQjtZQUMvQixnZkFBbUQ7O1NBRXBELENBQUM7T0FDVywwQkFBMEIsQ0F5RHRDO0lBQUQsaUNBQUM7Q0FBQSxBQXpERCxJQXlEQztTQXpEWSwwQkFBMEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uQ2hhbmdlcywgT25Jbml0LCBPdXRwdXQsIFNpbXBsZUNoYW5nZXMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgUGlja2VyTW9kZUVudW0gfSBmcm9tICdAZXFwcm9qZWN0L2VxcC1kYXRldGltZXBpY2tlcic7XHJcbmltcG9ydCB7IFJlY29yZCB9IGZyb20gJy4uLy4uLy4uLy4uL21vZGVscy9yZWNvcmQubW9kZWwnO1xyXG5pbXBvcnQgeyBEYXRlRmllbGQsIERhdGVUaW1lVHlwZUVudW0gfSBmcm9tICcuLi8uLi8uLi8uLi9tb2RlbHMvZmllbGRzL2RhdGVGaWVsZC5tb2RlbCc7XHJcbmltcG9ydCB7IElCYXNlRmllbGRDb21wb25lbnQgfSBmcm9tICcuLi8uLi8uLi8uLi9pbnRlcmZhY2VzL2lCYXNlRmllbGRDb21wb25lbnQuaW50ZXJmYWNlJztcclxuaW1wb3J0IHsgVXRpbGl0eUhlbHBlclNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi8uLi9zZXJ2aWNlcy91dGlsaXR5SGVscGVyLnNlcnZpY2VzJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnZGF0ZS1maWVsZC10ZW1wbGF0ZScsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2RhdGUtZmllbGQtdGVtcGxhdGUuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2RhdGUtZmllbGQtdGVtcGxhdGUuY29tcG9uZW50LnNjc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgRGF0ZUZpZWxkVGVtcGxhdGVDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uQ2hhbmdlcywgSUJhc2VGaWVsZENvbXBvbmVudCB7XHJcblxyXG4gIEBJbnB1dCgpIGZpZWxkOiBEYXRlRmllbGQ7XHJcbiAgQElucHV0KCkgcmVjb3JkOiBSZWNvcmQ7XHJcbiAgQE91dHB1dCgpIHJlY29yZENoYW5nZTogRXZlbnRFbWl0dGVyPFJlY29yZD4gPSBuZXcgRXZlbnRFbWl0dGVyPFJlY29yZD4oKTtcclxuXHJcbiAgcGlja2VyTW9kZTogUGlja2VyTW9kZUVudW07XHJcblxyXG4gIGNvbnN0cnVjdG9yKCkgeyB9XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgdGhpcy5zZXRUaW1lVHlwZSgpO1xyXG4gIH1cclxuXHJcbiAgbmdPbkNoYW5nZXMoY2hhbmdlczogU2ltcGxlQ2hhbmdlcykge1xyXG4gICAgLy8gU2UgdmllbmUgbW9kaWZpY2F0byBpbCB2YWxvcmUgZGkgXCJuZ01vZGVsSW5wdXRcIiBhbGxvcmEgYWdnaW9ybmEgbCdpbnB1dFxyXG4gICAgaWYgKGNoYW5nZXNbJ3JlY29yZCddICE9IHVuZGVmaW5lZCAmJiBjaGFuZ2VzWydyZWNvcmQnXS5maXJzdENoYW5nZSA9PSBmYWxzZSAmJiBKU09OLnN0cmluZ2lmeShjaGFuZ2VzWydyZWNvcmQnXS5jdXJyZW50VmFsdWUpICE9IEpTT04uc3RyaW5naWZ5KGNoYW5nZXNbJ3JlY29yZCddLnByZXZpb3VzVmFsdWUpKSB7XHJcbiAgICAgIHRoaXMucmVjb3JkID0gY2hhbmdlc1sncmVjb3JkJ10uY3VycmVudFZhbHVlO1xyXG4gICAgICB0aGlzLnVwZGF0ZUZpZWxkKCk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBNZXRvZG8gcGVyIGFnZ2lvcm5hcmUgaWwgdmFsb3JlIGRlbCBjYW1wbyBxdWFuZG8gcXVlc3RvIMOoIHJhcHByZXNlbnRhdG8gZGEgdW5hIGZvcm11bGEuXHJcbiAgICovXHJcbiAgdXBkYXRlRmllbGQoKSB7XHJcbiAgICBpZiAodGhpcy5maWVsZC5Gb3JtdWxhKSB7XHJcbiAgICAgIHRoaXMucmVjb3JkW3RoaXMuZmllbGQuTmFtZV0gPSBVdGlsaXR5SGVscGVyU2VydmljZS5FdmFsdWF0ZUZpZWxkRm9ybXVsYSh0aGlzLmZpZWxkLkZvcm11bGEsIHRoaXMucmVjb3JkLCBudWxsKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIE1ldG9kbyBwZXIgZW1ldHRlcmUgbCdldmVudG8gY2hlIGlsIHZhbG9yZSBkZWwgcmVjb3JkIMOoIGNhbWJpYXRvLlxyXG4gICAqL1xyXG4gIG9uUmVjb3JkVmFsdWVDaGFuZ2UoKSB7XHJcbiAgICBpZiAoIXRoaXMuZmllbGQuRm9ybXVsYSkge1xyXG4gICAgICB0aGlzLnJlY29yZENoYW5nZS5lbWl0KHRoaXMucmVjb3JkKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIEluIGJhc2UgYWwgZm9ybWF0byBkZWxsYSBkYXRhIHJpY2hpZXN0YSBuZWwgRGF0ZUZpZWxkIChzb2xvIGRhdGEsIHNvbG8gb3JhcmlvIG8gZGF0YSBlIG9yYSlcclxuICAgKiBpbXBvc3RhIGxhIHZpc3VhbGl6emF6aW9uZSBjb3JyZXR0YSBkZWwgY29tcG9uZW50ZSBlcXAtZGF0ZXRpbWVwaWNrZXIuXHJcbiAgICovXHJcbiAgcHJpdmF0ZSBzZXRUaW1lVHlwZSgpIHtcclxuICAgIHN3aXRjaCAodGhpcy5maWVsZC5Jc09ubHlEYXRlKSB7XHJcbiAgICAgIGNhc2UgRGF0ZVRpbWVUeXBlRW51bVtcIlNvbG8gZGF0YVwiXTpcclxuICAgICAgICB0aGlzLnBpY2tlck1vZGUgPSBQaWNrZXJNb2RlRW51bS5EQVRFO1xyXG4gICAgICAgIGJyZWFrO1xyXG4gICAgICBjYXNlIERhdGVUaW1lVHlwZUVudW1bXCJTb2xvIG9yYXJpb1wiXTpcclxuICAgICAgICB0aGlzLnBpY2tlck1vZGUgPSBQaWNrZXJNb2RlRW51bS5USU1FO1xyXG4gICAgICAgIGJyZWFrO1xyXG4gICAgICBjYXNlIERhdGVUaW1lVHlwZUVudW1bXCJEYXRhIGUgb3JhXCJdOlxyXG4gICAgICAgIHRoaXMucGlja2VyTW9kZSA9IFBpY2tlck1vZGVFbnVtLkRBVEVUSU1FO1xyXG4gICAgICAgIGJyZWFrO1xyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
3
|
+
import { AvailableImageExtensions } from '../../../../models/fields/attachmentField.model';
|
|
4
|
+
import { UtilityHelperService } from 'projects/eqp-dynamic-module/src/lib/services/utilityHelper.services';
|
|
5
|
+
var ImageFieldTemplateComponent = /** @class */ (function () {
|
|
6
|
+
function ImageFieldTemplateComponent() {
|
|
7
|
+
this.recordChange = new EventEmitter();
|
|
8
|
+
}
|
|
9
|
+
ImageFieldTemplateComponent.prototype.ngOnInit = function () {
|
|
10
|
+
this.field.AttachDefinition.FormFormGroup = this.field.FormFormGroup;
|
|
11
|
+
if (!this.field.AttachDefinition.AllowedExtensions) {
|
|
12
|
+
this.field.AttachDefinition.AllowedExtensions = AvailableImageExtensions.map(function (ext) { return ext.key; });
|
|
13
|
+
}
|
|
14
|
+
this.field.AttachDefinition.Name = this.field.Name;
|
|
15
|
+
this.field.AttachDefinition.Label = this.field.Label;
|
|
16
|
+
this.field.AttachDefinition.Description = this.field.Description;
|
|
17
|
+
this.field.AttachDefinition.Required = this.field.Required;
|
|
18
|
+
this.field.AttachDefinition.Formula = this.field.Formula;
|
|
19
|
+
this.field.AttachDefinition.FieldValue = this.field.FieldValue;
|
|
20
|
+
};
|
|
21
|
+
ImageFieldTemplateComponent.prototype.ngOnChanges = function (changes) {
|
|
22
|
+
// Se viene modificato il valore di "ngModelInput" allora aggiorna l'input
|
|
23
|
+
if (changes['record'] != undefined && changes['record'].firstChange == false && JSON.stringify(changes['record'].currentValue) != JSON.stringify(changes['record'].previousValue)) {
|
|
24
|
+
this.record = changes['record'].currentValue;
|
|
25
|
+
this.updateField();
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
/**
|
|
29
|
+
* Metodo per aggiornare il valore del campo quando questo è rappresentato da una formula.
|
|
30
|
+
*/
|
|
31
|
+
ImageFieldTemplateComponent.prototype.updateField = function () {
|
|
32
|
+
if (this.field.Formula) {
|
|
33
|
+
this.record[this.field.Name] = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, null);
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
__decorate([
|
|
37
|
+
Input()
|
|
38
|
+
], ImageFieldTemplateComponent.prototype, "record", void 0);
|
|
39
|
+
__decorate([
|
|
40
|
+
Input()
|
|
41
|
+
], ImageFieldTemplateComponent.prototype, "field", void 0);
|
|
42
|
+
__decorate([
|
|
43
|
+
Output()
|
|
44
|
+
], ImageFieldTemplateComponent.prototype, "recordChange", void 0);
|
|
45
|
+
ImageFieldTemplateComponent = __decorate([
|
|
46
|
+
Component({
|
|
47
|
+
selector: 'image-field-template',
|
|
48
|
+
template: "<attachment-field-template [(record)]=\"record\" [field]=\"field.AttachDefinition\"\n [onlyImages]=\"true\">\n</attachment-field-template>",
|
|
49
|
+
styles: [""]
|
|
50
|
+
})
|
|
51
|
+
], ImageFieldTemplateComponent);
|
|
52
|
+
return ImageFieldTemplateComponent;
|
|
53
|
+
}());
|
|
54
|
+
export { ImageFieldTemplateComponent };
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UtZmllbGQtdGVtcGxhdGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vQGVxcHJvamVjdC9lcXAtZHluYW1pYy1tb2R1bGUvIiwic291cmNlcyI6WyJsaWIvY29tcG9uZW50cy9wcml2YXRlL2ZpZWxkLXRlbXBsYXRlcy9pbWFnZS1maWVsZC10ZW1wbGF0ZS9pbWFnZS1maWVsZC10ZW1wbGF0ZS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBcUIsTUFBTSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUV6RyxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxpREFBaUQsQ0FBQztBQUczRixPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxxRUFBcUUsQ0FBQztBQU8zRztJQU1FO1FBRlUsaUJBQVksR0FBeUIsSUFBSSxZQUFZLEVBQVUsQ0FBQztJQUUxRCxDQUFDO0lBRWpCLDhDQUFRLEdBQVI7UUFDRSxJQUFJLENBQUMsS0FBSyxDQUFDLGdCQUFnQixDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLGFBQWEsQ0FBQztRQUVyRSxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxnQkFBZ0IsQ0FBQyxpQkFBaUIsRUFBRTtZQUNsRCxJQUFJLENBQUMsS0FBSyxDQUFDLGdCQUFnQixDQUFDLGlCQUFpQixHQUFHLHdCQUF3QixDQUFDLEdBQUcsQ0FBQyxVQUFBLEdBQUcsSUFBSSxPQUFBLEdBQUcsQ0FBQyxHQUFHLEVBQVAsQ0FBTyxDQUFDLENBQUM7U0FDOUY7UUFFRCxJQUFJLENBQUMsS0FBSyxDQUFDLGdCQUFnQixDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQztRQUNuRCxJQUFJLENBQUMsS0FBSyxDQUFDLGdCQUFnQixDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQztRQUNyRCxJQUFJLENBQUMsS0FBSyxDQUFDLGdCQUFnQixDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQztRQUNqRSxJQUFJLENBQUMsS0FBSyxDQUFDLGdCQUFnQixDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQztRQUMzRCxJQUFJLENBQUMsS0FBSyxDQUFDLGdCQUFnQixDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQztRQUN6RCxJQUFJLENBQUMsS0FBSyxDQUFDLGdCQUFnQixDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFVBQVUsQ0FBQztJQUNqRSxDQUFDO0lBR0QsaURBQVcsR0FBWCxVQUFZLE9BQXNCO1FBQ2hDLDBFQUEwRTtRQUMxRSxJQUFJLE9BQU8sQ0FBQyxRQUFRLENBQUMsSUFBSSxTQUFTLElBQUksT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDLFdBQVcsSUFBSSxLQUFLLElBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUMsWUFBWSxDQUFDLElBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUMsYUFBYSxDQUFDLEVBQUU7WUFDakwsSUFBSSxDQUFDLE1BQU0sR0FBRyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUMsWUFBWSxDQUFDO1lBQzdDLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztTQUNwQjtJQUNILENBQUM7SUFFRDs7T0FFRztJQUNILGlEQUFXLEdBQVg7UUFDRSxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxFQUFFO1lBQ3RCLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsR0FBRyxvQkFBb0IsQ0FBQyxvQkFBb0IsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxDQUFDO1NBQ2pIO0lBQ0gsQ0FBQztJQXJDUTtRQUFSLEtBQUssRUFBRTsrREFBZ0I7SUFDZjtRQUFSLEtBQUssRUFBRTs4REFBbUI7SUFDakI7UUFBVCxNQUFNLEVBQUU7cUVBQWlFO0lBSi9ELDJCQUEyQjtRQUx2QyxTQUFTLENBQUM7WUFDVCxRQUFRLEVBQUUsc0JBQXNCO1lBQ2hDLDBKQUFvRDs7U0FFckQsQ0FBQztPQUNXLDJCQUEyQixDQXdDdkM7SUFBRCxrQ0FBQztDQUFBLEFBeENELElBd0NDO1NBeENZLDJCQUEyQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25DaGFuZ2VzLCBPbkluaXQsIE91dHB1dCwgU2ltcGxlQ2hhbmdlcyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBJbWFnZUZpZWxkIH0gZnJvbSAnLi4vLi4vLi4vLi4vbW9kZWxzL2ZpZWxkcy9pbWFnZUZpZWxkLm1vZGVsJztcclxuaW1wb3J0IHsgQXZhaWxhYmxlSW1hZ2VFeHRlbnNpb25zIH0gZnJvbSAnLi4vLi4vLi4vLi4vbW9kZWxzL2ZpZWxkcy9hdHRhY2htZW50RmllbGQubW9kZWwnO1xyXG5pbXBvcnQgeyBSZWNvcmQgfSBmcm9tICcuLi8uLi8uLi8uLi9tb2RlbHMvcmVjb3JkLm1vZGVsJztcclxuaW1wb3J0IHsgSUJhc2VGaWVsZENvbXBvbmVudCB9IGZyb20gJy4uLy4uLy4uLy4uL2ludGVyZmFjZXMvaUJhc2VGaWVsZENvbXBvbmVudC5pbnRlcmZhY2UnO1xyXG5pbXBvcnQgeyBVdGlsaXR5SGVscGVyU2VydmljZSB9IGZyb20gJ3Byb2plY3RzL2VxcC1keW5hbWljLW1vZHVsZS9zcmMvbGliL3NlcnZpY2VzL3V0aWxpdHlIZWxwZXIuc2VydmljZXMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdpbWFnZS1maWVsZC10ZW1wbGF0ZScsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2ltYWdlLWZpZWxkLXRlbXBsYXRlLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9pbWFnZS1maWVsZC10ZW1wbGF0ZS5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBJbWFnZUZpZWxkVGVtcGxhdGVDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uQ2hhbmdlcywgSUJhc2VGaWVsZENvbXBvbmVudCB7XHJcblxyXG4gIEBJbnB1dCgpIHJlY29yZDogUmVjb3JkO1xyXG4gIEBJbnB1dCgpIGZpZWxkOiBJbWFnZUZpZWxkO1xyXG4gIEBPdXRwdXQoKSByZWNvcmRDaGFuZ2U6IEV2ZW50RW1pdHRlcjxSZWNvcmQ+ID0gbmV3IEV2ZW50RW1pdHRlcjxSZWNvcmQ+KCk7XHJcblxyXG4gIGNvbnN0cnVjdG9yKCkgeyB9XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgdGhpcy5maWVsZC5BdHRhY2hEZWZpbml0aW9uLkZvcm1Gb3JtR3JvdXAgPSB0aGlzLmZpZWxkLkZvcm1Gb3JtR3JvdXA7XHJcblxyXG4gICAgaWYgKCF0aGlzLmZpZWxkLkF0dGFjaERlZmluaXRpb24uQWxsb3dlZEV4dGVuc2lvbnMpIHtcclxuICAgICAgdGhpcy5maWVsZC5BdHRhY2hEZWZpbml0aW9uLkFsbG93ZWRFeHRlbnNpb25zID0gQXZhaWxhYmxlSW1hZ2VFeHRlbnNpb25zLm1hcChleHQgPT4gZXh0LmtleSk7XHJcbiAgICB9XHJcblxyXG4gICAgdGhpcy5maWVsZC5BdHRhY2hEZWZpbml0aW9uLk5hbWUgPSB0aGlzLmZpZWxkLk5hbWU7XHJcbiAgICB0aGlzLmZpZWxkLkF0dGFjaERlZmluaXRpb24uTGFiZWwgPSB0aGlzLmZpZWxkLkxhYmVsO1xyXG4gICAgdGhpcy5maWVsZC5BdHRhY2hEZWZpbml0aW9uLkRlc2NyaXB0aW9uID0gdGhpcy5maWVsZC5EZXNjcmlwdGlvbjtcclxuICAgIHRoaXMuZmllbGQuQXR0YWNoRGVmaW5pdGlvbi5SZXF1aXJlZCA9IHRoaXMuZmllbGQuUmVxdWlyZWQ7XHJcbiAgICB0aGlzLmZpZWxkLkF0dGFjaERlZmluaXRpb24uRm9ybXVsYSA9IHRoaXMuZmllbGQuRm9ybXVsYTtcclxuICAgIHRoaXMuZmllbGQuQXR0YWNoRGVmaW5pdGlvbi5GaWVsZFZhbHVlID0gdGhpcy5maWVsZC5GaWVsZFZhbHVlO1xyXG4gIH1cclxuXHJcblxyXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpIHtcclxuICAgIC8vIFNlIHZpZW5lIG1vZGlmaWNhdG8gaWwgdmFsb3JlIGRpIFwibmdNb2RlbElucHV0XCIgYWxsb3JhIGFnZ2lvcm5hIGwnaW5wdXRcclxuICAgIGlmIChjaGFuZ2VzWydyZWNvcmQnXSAhPSB1bmRlZmluZWQgJiYgY2hhbmdlc1sncmVjb3JkJ10uZmlyc3RDaGFuZ2UgPT0gZmFsc2UgJiYgSlNPTi5zdHJpbmdpZnkoY2hhbmdlc1sncmVjb3JkJ10uY3VycmVudFZhbHVlKSAhPSBKU09OLnN0cmluZ2lmeShjaGFuZ2VzWydyZWNvcmQnXS5wcmV2aW91c1ZhbHVlKSkge1xyXG4gICAgICB0aGlzLnJlY29yZCA9IGNoYW5nZXNbJ3JlY29yZCddLmN1cnJlbnRWYWx1ZTtcclxuICAgICAgdGhpcy51cGRhdGVGaWVsZCgpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogTWV0b2RvIHBlciBhZ2dpb3JuYXJlIGlsIHZhbG9yZSBkZWwgY2FtcG8gcXVhbmRvIHF1ZXN0byDDqCByYXBwcmVzZW50YXRvIGRhIHVuYSBmb3JtdWxhLlxyXG4gICAqL1xyXG4gIHVwZGF0ZUZpZWxkKCkge1xyXG4gICAgaWYgKHRoaXMuZmllbGQuRm9ybXVsYSkge1xyXG4gICAgICB0aGlzLnJlY29yZFt0aGlzLmZpZWxkLk5hbWVdID0gVXRpbGl0eUhlbHBlclNlcnZpY2UuRXZhbHVhdGVGaWVsZEZvcm11bGEodGhpcy5maWVsZC5Gb3JtdWxhLCB0aGlzLnJlY29yZCwgbnVsbCk7XHJcbiAgICB9XHJcbiAgfVxyXG59Il19
|