@eqproject/eqp-dynamic-module 2.8.38 → 2.9.0
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/esm2020/lib/components/exported/eqp-dynamic-module/eqp-dynamic-module.component.mjs +3 -9
- package/esm2020/lib/components/exported/eqp-dynamic-module-configurator/eqp-dynamic-module-configurator.component.mjs +42 -43
- package/esm2020/lib/components/private/action-button-creator/action-button-creator.component.mjs +204 -0
- package/esm2020/lib/components/private/add-form-field/add-form-field.component.mjs +38 -78
- package/esm2020/lib/components/private/dynamic-module-field-fix/dynamic-module-field.component.mjs +12 -3
- package/esm2020/lib/components/private/field-templates/action-button-field-template/action-button-field-template.component.mjs +52 -0
- package/esm2020/lib/components/private/form-records/add-form-record/add-form-record.component.mjs +19 -17
- package/esm2020/lib/components/private/form-records/hlist-form-record/hlist-form-record.component.mjs +2 -9
- package/esm2020/lib/components/private/form-records/list-form-record/list-form-record.component.mjs +2 -8
- package/esm2020/lib/components/private/form-records/list-view-form-record/list-view-form-record.component.mjs +45 -17
- package/esm2020/lib/components/private/form-records/list-view-form-record/single-record/single-record.component.mjs +3 -9
- package/esm2020/lib/components/private/form-records/view-form-record/view-form-record.component.mjs +2 -8
- package/esm2020/lib/components/private/form-statistics/filter-form-statistic/filter-form-statistic.component.mjs +4 -7
- package/esm2020/lib/components/private/graphs/graphs.component.mjs +4 -7
- package/esm2020/lib/components/private/trigger-creator/trigger-creator.component.mjs +1 -1
- package/esm2020/lib/eqp-dynamic-module.module.mjs +9 -3
- package/esm2020/lib/models/baseField.model.mjs +2 -1
- package/esm2020/lib/models/fields/actionButton.model.mjs +6 -0
- package/esm2020/lib/models/trigger.model.mjs +5 -7
- package/fesm2015/eqproject-eqp-dynamic-module.mjs +408 -209
- package/fesm2015/eqproject-eqp-dynamic-module.mjs.map +1 -1
- package/fesm2020/eqproject-eqp-dynamic-module.mjs +408 -209
- package/fesm2020/eqproject-eqp-dynamic-module.mjs.map +1 -1
- package/lib/components/exported/eqp-dynamic-module/eqp-dynamic-module.component.d.ts +2 -4
- package/lib/components/exported/eqp-dynamic-module-configurator/eqp-dynamic-module-configurator.component.d.ts +8 -5
- package/lib/components/private/action-button-creator/action-button-creator.component.d.ts +42 -0
- package/lib/components/private/add-form-field/add-form-field.component.d.ts +5 -12
- package/lib/components/private/dynamic-module-field-fix/dynamic-module-field.component.d.ts +4 -1
- package/lib/components/private/field-templates/action-button-field-template/action-button-field-template.component.d.ts +19 -0
- package/lib/components/private/form-records/add-form-record/add-form-record.component.d.ts +3 -4
- package/lib/components/private/form-records/hlist-form-record/hlist-form-record.component.d.ts +2 -4
- package/lib/components/private/form-records/list-form-record/list-form-record.component.d.ts +2 -4
- package/lib/components/private/form-records/list-view-form-record/list-view-form-record.component.d.ts +2 -4
- package/lib/components/private/form-records/list-view-form-record/single-record/single-record.component.d.ts +2 -4
- package/lib/components/private/form-records/view-form-record/view-form-record.component.d.ts +2 -4
- package/lib/components/private/form-statistics/filter-form-statistic/filter-form-statistic.component.d.ts +3 -4
- package/lib/components/private/graphs/graphs.component.d.ts +3 -4
- package/lib/eqp-dynamic-module.module.d.ts +16 -14
- package/lib/models/baseField.model.d.ts +2 -1
- package/lib/models/fields/actionButton.model.d.ts +17 -0
- package/lib/models/trigger.model.d.ts +7 -14
- package/package.json +1 -1
package/esm2020/lib/components/private/action-button-creator/action-button-creator.component.mjs
ADDED
|
@@ -0,0 +1,204 @@
|
|
|
1
|
+
import { Component, Input, EventEmitter, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { ActionButton, ActionFlagEnum, TriggerPropertyTypeEnum } from '../../../models/trigger.model';
|
|
3
|
+
import { ParamTypeEnum } from '../../../models/endPointConfiguration.model';
|
|
4
|
+
import { FieldTypeEnum } from '../../../models/baseField.model';
|
|
5
|
+
import { GlobalService } from '../../../services/global.service';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/material/dialog";
|
|
8
|
+
import * as i2 from "../../../services/utilityHelper.services";
|
|
9
|
+
import * as i3 from "@angular/material/button";
|
|
10
|
+
import * as i4 from "@angular/material/input";
|
|
11
|
+
import * as i5 from "@angular/material/form-field";
|
|
12
|
+
import * as i6 from "@angular/material/card";
|
|
13
|
+
import * as i7 from "@angular/material/tooltip";
|
|
14
|
+
import * as i8 from "@angular/forms";
|
|
15
|
+
import * as i9 from "@angular/common";
|
|
16
|
+
import * as i10 from "@eqproject/eqp-select";
|
|
17
|
+
import * as i11 from "../add-formula-field/add-formula-field.component";
|
|
18
|
+
export class ActionButtonCreatorComponent {
|
|
19
|
+
constructor(dialog, utilityHelperService) {
|
|
20
|
+
this.dialog = dialog;
|
|
21
|
+
this.utilityHelperService = utilityHelperService;
|
|
22
|
+
this.actionButton = null;
|
|
23
|
+
this.actionButtonField = null;
|
|
24
|
+
this.formulas = null;
|
|
25
|
+
this.InField = false;
|
|
26
|
+
this.onSaveRecord = new EventEmitter();
|
|
27
|
+
this.onChangeSomething = new EventEmitter();
|
|
28
|
+
this.FieldTypeEnum = FieldTypeEnum;
|
|
29
|
+
this.isSaving = false;
|
|
30
|
+
this.formulaKeys = new Array();
|
|
31
|
+
this.formulaFieldsStructure = new Array();
|
|
32
|
+
this.actionsFlag = ActionFlagEnum;
|
|
33
|
+
this.triggerPropertyType = TriggerPropertyTypeEnum;
|
|
34
|
+
}
|
|
35
|
+
ngOnInit() {
|
|
36
|
+
///
|
|
37
|
+
/// Questo componente funziona sia per i bottoni dei fields sia per i bottoni sugli header (addrecord, listview eccetera)
|
|
38
|
+
/// Se si sta lavorando sui fields è popolato 'this.actionButtonField' altrimenti è null.
|
|
39
|
+
///
|
|
40
|
+
if (this.actionButtonField != null) {
|
|
41
|
+
this.actionButton = this.actionButtonField;
|
|
42
|
+
}
|
|
43
|
+
if (this.actionButton != null && this.actionButton.execution != null) {
|
|
44
|
+
this.selectedFormula = {};
|
|
45
|
+
this.selectedFormula.key = this.actionButton.execution;
|
|
46
|
+
if (this.actionButtonField == null) {
|
|
47
|
+
this.formulaFieldsStructure = new Array();
|
|
48
|
+
Object.keys(this.formulas[this.selectedFormula.key]).forEach((res) => {
|
|
49
|
+
this.formulaFieldsStructure.push({ "key": res, "type": this.formulas[this.selectedFormula.key][res].type, "tooltip": this.formulas[this.selectedFormula.key][res].tooltip });
|
|
50
|
+
});
|
|
51
|
+
Object.keys(this.actionButton.formulasTemp).forEach((res) => {
|
|
52
|
+
this.formulaFieldsStructure.find(x => x.key == res).value = this.actionButton.formulasTemp[res].value;
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
this.formulaFieldsStructure.push(this.actionButton.formulas);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
if (this.actionButton == null) {
|
|
60
|
+
this.actionButton = new ActionButton();
|
|
61
|
+
}
|
|
62
|
+
var executeGetModules = false;
|
|
63
|
+
Object.keys(this.formulas).forEach((res) => {
|
|
64
|
+
this.formulaKeys.push({ "key": res });
|
|
65
|
+
Object.keys(this.formulas[res]).forEach((property) => {
|
|
66
|
+
if (this.formulas[res][property].type == TriggerPropertyTypeEnum.DMMODULE) {
|
|
67
|
+
executeGetModules = true;
|
|
68
|
+
}
|
|
69
|
+
});
|
|
70
|
+
});
|
|
71
|
+
if (executeGetModules) {
|
|
72
|
+
this.getAllModules();
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
openFormulaDialog(formulaField) {
|
|
76
|
+
this.dialogFormulaRef = this.dialog.open(this.dialogFormula, {
|
|
77
|
+
disableClose: true,
|
|
78
|
+
hasBackdrop: true,
|
|
79
|
+
width: "75%",
|
|
80
|
+
data: {
|
|
81
|
+
formula: this.formulaFieldsStructure.find(x => x.key == formulaField.key).value,
|
|
82
|
+
fields: this.form.Fields
|
|
83
|
+
},
|
|
84
|
+
});
|
|
85
|
+
this.dialogFormulaRef.afterClosed().subscribe((result) => {
|
|
86
|
+
var formulaToChange = this.formulaFieldsStructure.find(x => x.key == formulaField.key);
|
|
87
|
+
formulaToChange.value = result.formula.toString() == "" ? null : result.formula.toString();
|
|
88
|
+
this.onFormulaFieldChange(formulaToChange);
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
onFormulaFieldChange(formulaField) {
|
|
92
|
+
this.changeSomething();
|
|
93
|
+
}
|
|
94
|
+
onEqpSelectModule(ev, formulaField) {
|
|
95
|
+
formulaField.value = ev.ID;
|
|
96
|
+
this.changeSomething();
|
|
97
|
+
}
|
|
98
|
+
saveOrExitForm(exit) {
|
|
99
|
+
GlobalService.debugLog('add-form-record saveRecordEvent');
|
|
100
|
+
if (exit) {
|
|
101
|
+
this.onSaveRecord.emit(null);
|
|
102
|
+
}
|
|
103
|
+
else {
|
|
104
|
+
this.actionButton.ButtonCode = this.selectedFormula.key;
|
|
105
|
+
this.formulaFieldsStructure.forEach((formulaField) => {
|
|
106
|
+
if (typeof this.actionButton.formulas == "undefined") {
|
|
107
|
+
this.actionButton.formulas = {};
|
|
108
|
+
}
|
|
109
|
+
this.actionButton.formulasTemp[formulaField.key] = formulaField;
|
|
110
|
+
this.actionButton.execution = this.selectedFormula.key;
|
|
111
|
+
});
|
|
112
|
+
this.isSaving = true;
|
|
113
|
+
this.onSaveRecord.emit(this.actionButton);
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
changeSomething() {
|
|
117
|
+
this.actionButton.ButtonCode = this.selectedFormula.key;
|
|
118
|
+
if (!this.actionButton.formulasTemp) {
|
|
119
|
+
this.actionButton.formulasTemp = {};
|
|
120
|
+
}
|
|
121
|
+
console.log("CHANGE SOMETHING", this.actionButton, this.formulaFieldsStructure);
|
|
122
|
+
this.formulaFieldsStructure.forEach((formulaField) => {
|
|
123
|
+
if (typeof this.actionButton.formulas == "undefined") {
|
|
124
|
+
this.actionButton.formulas = {};
|
|
125
|
+
}
|
|
126
|
+
this.actionButton.formulasTemp[formulaField.key] = formulaField;
|
|
127
|
+
this.actionButton.execution = this.selectedFormula.key;
|
|
128
|
+
});
|
|
129
|
+
this.onChangeSomething.emit(this.actionButton);
|
|
130
|
+
}
|
|
131
|
+
getAllModules() {
|
|
132
|
+
const dynamicModuleParams = new Array();
|
|
133
|
+
dynamicModuleParams.push({
|
|
134
|
+
ParamName: "orgaid",
|
|
135
|
+
ParamValue: this.form.OrgaID,
|
|
136
|
+
ParamType: ParamTypeEnum["Query param"],
|
|
137
|
+
});
|
|
138
|
+
this.utilityHelperService.RunEndPointCall(this.endPointConfiguration.Forms.GetAllFormEndPoint, dynamicModuleParams, (res) => {
|
|
139
|
+
this.forms = res;
|
|
140
|
+
this.forms = this.forms.sort((uno, due) => uno.Name.localeCompare(due.Name));
|
|
141
|
+
this.formulaFieldsStructure.forEach((res) => {
|
|
142
|
+
if (res.type == TriggerPropertyTypeEnum.DMMODULE) {
|
|
143
|
+
res.object = this.forms.find(x => x.ID == res.value);
|
|
144
|
+
}
|
|
145
|
+
});
|
|
146
|
+
}, (err) => { });
|
|
147
|
+
}
|
|
148
|
+
onChangeFormula(formula) {
|
|
149
|
+
if (formula == null) {
|
|
150
|
+
this.changeSomething();
|
|
151
|
+
return;
|
|
152
|
+
}
|
|
153
|
+
GlobalService.debugLog('@@trigger-creator:onChangeFormula selected formula', formula);
|
|
154
|
+
GlobalService.debugLog('@@trigger-creator:onChangeFormula formulas', this.formulas);
|
|
155
|
+
this.formulaFieldsStructure = new Array();
|
|
156
|
+
console.log("onChangeFormula", this.formulas, formula.key);
|
|
157
|
+
//------------
|
|
158
|
+
Object.keys(this.formulas[formula.key]).forEach((res) => {
|
|
159
|
+
this.formulaFieldsStructure.push({ "key": res, "type": this.formulas[formula.key][res].type,
|
|
160
|
+
"tooltip": this.formulas[formula.key][res].tooltip });
|
|
161
|
+
});
|
|
162
|
+
//------------
|
|
163
|
+
/* *** originale ***
|
|
164
|
+
Object.keys(this.formulas[formula.key]).forEach((res) => {
|
|
165
|
+
this.formulaFieldsStructure.push({"key": res, "type": this.formulas[formula.key][res].type
|
|
166
|
+
});
|
|
167
|
+
});
|
|
168
|
+
*** */
|
|
169
|
+
GlobalService.debugLog('@@trigger-creator:onChangeFormula formulaFieldsStructure', this.formulaFieldsStructure);
|
|
170
|
+
this.changeSomething();
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
ActionButtonCreatorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ActionButtonCreatorComponent, deps: [{ token: i1.MatDialog }, { token: i2.UtilityHelperService }], target: i0.ɵɵFactoryTarget.Component });
|
|
174
|
+
ActionButtonCreatorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: ActionButtonCreatorComponent, selector: "action-button-creator", inputs: { form: "form", actionButton: "actionButton", actionButtonField: "actionButtonField", formulas: "formulas", endPointConfiguration: "endPointConfiguration", InField: "InField" }, outputs: { onSaveRecord: "onSaveRecord", onChangeSomething: "onChangeSomething" }, viewQueries: [{ propertyName: "dialogFormula", first: true, predicate: ["dialogFormula"], descendants: true, static: true }], ngImport: i0, template: "\r\n<mat-card class=\"add-form-field\">\r\n <mat-card-header *ngIf=\"!InField\">\r\n <mat-card-title>\r\n {{actionButton != null ? \"Modifica\" : \"Aggiungi\"}} actionButton\r\n </mat-card-title>\r\n </mat-card-header>\r\n\r\n <mat-card-content>\r\n\r\n <div class=\"container-fluid containerContent padder\">\r\n\r\n <div class=\"row\">\r\n <div class=\"col-3\">Tipo Action Button</div>\r\n <div class=\"col-9\">\r\n <eqp-select [arrayData]=\"formulaKeys\" [(ngModelInput)]=\"selectedFormula\"\r\n [arrayKeyProperty]=\"'key'\" [arrayValueProperty]=\"'key'\" [showCancelButton]=\"true\" (ngModelInputChange)=\"onChangeFormula($event)\">\r\n </eqp-select> \r\n </div>\r\n </div>\r\n \r\n <div class=\"row\">\r\n <div class=\"col-3\">Etichetta</div>\r\n <div class=\"col-9\">\r\n <mat-form-field>\r\n <mat-label class=\"pt-1\"> Etichetta </mat-label>\r\n <input matInput [(ngModel)]=\"actionButton.ButtonLabel\" [readonly]=\"false\" [required]=\"true\" (keyup)=\"changeSomething()\">\r\n </mat-form-field>\r\n </div>\r\n </div>\r\n \r\n <div class=\"row\">\r\n <div class=\"col-3\">Icona (<a href='https://www.angularjswiki.com/angular/angular-material-icons-list-mat-icon-list' target=\"_blank\">lista</a>)</div>\r\n <div class=\"col-9\">\r\n <mat-form-field>\r\n <mat-label class=\"pt-1\"> Icona Material (<a href='https://www.angularjswiki.com/angular/angular-material-icons-list-mat-icon-list' target=\"_blank\">lista</a>) </mat-label>\r\n <input matInput [(ngModel)]=\"actionButton.Icon\" [readonly]=\"false\" [required]=\"true\" (keyup)=\"changeSomething()\">\r\n </mat-form-field>\r\n </div>\r\n </div> \r\n \r\n <div class=\"row\" *ngIf=\"!InField\">\r\n <div class=\"col-3\">Sezioni</div>\r\n <div class=\"col-9\">\r\n <mat-label class=\"pt-1\"> Sezioni </mat-label>\r\n <eqp-select\r\n [enumData]=\"actionsFlag\"\r\n [isSearchable]=\"true\"\r\n [isMultiSelect] = \"true\"\r\n [(ngModelInput)]=\"actionButton.ShowIn\" \r\n (ngModelInputChange)=\"changeSomething()\" \r\n >\r\n </eqp-select>\r\n </div>\r\n </div> \r\n\r\n <div class=\"row\" *ngFor=\"let formulaField of formulaFieldsStructure\">\r\n <div class=\"col-3\">{{formulaField.key}}</div>\r\n <div class=\"col-9\" *ngIf=\"formulaField.type == triggerPropertyType.STRING\">\r\n <mat-form-field>\r\n <mat-label class=\"pt-1\"> {{formulaField.key}}</mat-label>\r\n <input matInput [readonly]=\"false\" [required]=\"false\" [matTooltip]=\"formulaField.tooltip\" (click)=\"openFormulaDialog(formulaField)\" [(ngModel)]=\"formulaField.value\" (ngModelChange)=\"onFormulaFieldChange(formulaField)\">\r\n </mat-form-field>\r\n </div>\r\n <div class=\"col-9\" *ngIf=\"formulaField.type == triggerPropertyType.DMMODULE\">\r\n <eqp-select [placeholder]=\"'Seleziona modulo'\" [arrayData]=\"forms\" [(ngModelInput)]=\"formulaField.object\" [isSearchable]=\"true\"\r\n [arrayKeyProperty]=\"'ID'\" [arrayValueProperty]=\"'Name'\" [ngModelOptions]=\"{ standalone: true }\" (ngModelInputChange)=\"onEqpSelectModule($event, formulaField)\">\r\n </eqp-select>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n\r\n </mat-card-content>\r\n <mat-card-footer *ngIf=\"!InField\">\r\n <div class=\"d-flex justify-content-end mt-2 mb-1 me-3\"> \r\n <button class=\"mr-2\" mat-raised-button type=\"button\" (click)=\"saveOrExitForm(true)\">\r\n Annulla\r\n </button>\r\n <button class=\"mr-2\" mat-raised-button color=\"primary\" type=\"button\"\r\n (click)=\"saveOrExitForm(false)\" [disabled]=\"isSaving\">\r\n <span *ngIf=\"!isSaving\">Salva</span>\r\n <span *ngIf=\"isSaving\">Salvataggio in Corso...</span>\r\n </button>\r\n </div>\r\n </mat-card-footer>\r\n\r\n</mat-card>\r\n\r\n<!--DIALOG PER SEMPLIFICARE LA SCRITTURA DEL CAMPO FORMULA-->\r\n<ng-template #dialogFormula>\r\n <eqp-dynamic-module-add-formula-component>\r\n </eqp-dynamic-module-add-formula-component>\r\n</ng-template>", styles: [""], dependencies: [{ kind: "component", type: i3.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i5.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i5.MatLabel, selector: "mat-label" }, { kind: "component", type: i6.MatCard, selector: "mat-card", inputs: ["appearance"], exportAs: ["matCard"] }, { kind: "directive", type: i6.MatCardContent, selector: "mat-card-content" }, { kind: "directive", type: i6.MatCardFooter, selector: "mat-card-footer" }, { kind: "component", type: i6.MatCardHeader, selector: "mat-card-header" }, { kind: "directive", type: i6.MatCardTitle, selector: "mat-card-title, [mat-card-title], [matCardTitle]" }, { kind: "directive", type: i7.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "directive", type: i8.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: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i8.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i8.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i9.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i10.EqpSelectComponent, selector: "eqp-select", inputs: ["placeholder", "enumData", "enumDataToExclude", "arrayData", "arrayKeyProperty", "arrayValueProperty", "ngModelOptions", "ngModelInput", "formGroupInput", "formControlNameInput", "isRequired", "isDisabled", "isMultiLanguage", "multilanguagePrefixKey", "isAlphabeticalOrderable", "suffixIcon", "prefixIcon", "isMultiSelect", "includeFullObject", "showCancelButton", "isSearchable", "searchText", "noResultSearchText", "data"], outputs: ["ngModelInputChange"] }, { kind: "component", type: i11.AddFormulaComponent, selector: "eqp-dynamic-module-add-formula-component" }] });
|
|
175
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ActionButtonCreatorComponent, decorators: [{
|
|
176
|
+
type: Component,
|
|
177
|
+
args: [{ selector: 'action-button-creator', template: "\r\n<mat-card class=\"add-form-field\">\r\n <mat-card-header *ngIf=\"!InField\">\r\n <mat-card-title>\r\n {{actionButton != null ? \"Modifica\" : \"Aggiungi\"}} actionButton\r\n </mat-card-title>\r\n </mat-card-header>\r\n\r\n <mat-card-content>\r\n\r\n <div class=\"container-fluid containerContent padder\">\r\n\r\n <div class=\"row\">\r\n <div class=\"col-3\">Tipo Action Button</div>\r\n <div class=\"col-9\">\r\n <eqp-select [arrayData]=\"formulaKeys\" [(ngModelInput)]=\"selectedFormula\"\r\n [arrayKeyProperty]=\"'key'\" [arrayValueProperty]=\"'key'\" [showCancelButton]=\"true\" (ngModelInputChange)=\"onChangeFormula($event)\">\r\n </eqp-select> \r\n </div>\r\n </div>\r\n \r\n <div class=\"row\">\r\n <div class=\"col-3\">Etichetta</div>\r\n <div class=\"col-9\">\r\n <mat-form-field>\r\n <mat-label class=\"pt-1\"> Etichetta </mat-label>\r\n <input matInput [(ngModel)]=\"actionButton.ButtonLabel\" [readonly]=\"false\" [required]=\"true\" (keyup)=\"changeSomething()\">\r\n </mat-form-field>\r\n </div>\r\n </div>\r\n \r\n <div class=\"row\">\r\n <div class=\"col-3\">Icona (<a href='https://www.angularjswiki.com/angular/angular-material-icons-list-mat-icon-list' target=\"_blank\">lista</a>)</div>\r\n <div class=\"col-9\">\r\n <mat-form-field>\r\n <mat-label class=\"pt-1\"> Icona Material (<a href='https://www.angularjswiki.com/angular/angular-material-icons-list-mat-icon-list' target=\"_blank\">lista</a>) </mat-label>\r\n <input matInput [(ngModel)]=\"actionButton.Icon\" [readonly]=\"false\" [required]=\"true\" (keyup)=\"changeSomething()\">\r\n </mat-form-field>\r\n </div>\r\n </div> \r\n \r\n <div class=\"row\" *ngIf=\"!InField\">\r\n <div class=\"col-3\">Sezioni</div>\r\n <div class=\"col-9\">\r\n <mat-label class=\"pt-1\"> Sezioni </mat-label>\r\n <eqp-select\r\n [enumData]=\"actionsFlag\"\r\n [isSearchable]=\"true\"\r\n [isMultiSelect] = \"true\"\r\n [(ngModelInput)]=\"actionButton.ShowIn\" \r\n (ngModelInputChange)=\"changeSomething()\" \r\n >\r\n </eqp-select>\r\n </div>\r\n </div> \r\n\r\n <div class=\"row\" *ngFor=\"let formulaField of formulaFieldsStructure\">\r\n <div class=\"col-3\">{{formulaField.key}}</div>\r\n <div class=\"col-9\" *ngIf=\"formulaField.type == triggerPropertyType.STRING\">\r\n <mat-form-field>\r\n <mat-label class=\"pt-1\"> {{formulaField.key}}</mat-label>\r\n <input matInput [readonly]=\"false\" [required]=\"false\" [matTooltip]=\"formulaField.tooltip\" (click)=\"openFormulaDialog(formulaField)\" [(ngModel)]=\"formulaField.value\" (ngModelChange)=\"onFormulaFieldChange(formulaField)\">\r\n </mat-form-field>\r\n </div>\r\n <div class=\"col-9\" *ngIf=\"formulaField.type == triggerPropertyType.DMMODULE\">\r\n <eqp-select [placeholder]=\"'Seleziona modulo'\" [arrayData]=\"forms\" [(ngModelInput)]=\"formulaField.object\" [isSearchable]=\"true\"\r\n [arrayKeyProperty]=\"'ID'\" [arrayValueProperty]=\"'Name'\" [ngModelOptions]=\"{ standalone: true }\" (ngModelInputChange)=\"onEqpSelectModule($event, formulaField)\">\r\n </eqp-select>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n\r\n </mat-card-content>\r\n <mat-card-footer *ngIf=\"!InField\">\r\n <div class=\"d-flex justify-content-end mt-2 mb-1 me-3\"> \r\n <button class=\"mr-2\" mat-raised-button type=\"button\" (click)=\"saveOrExitForm(true)\">\r\n Annulla\r\n </button>\r\n <button class=\"mr-2\" mat-raised-button color=\"primary\" type=\"button\"\r\n (click)=\"saveOrExitForm(false)\" [disabled]=\"isSaving\">\r\n <span *ngIf=\"!isSaving\">Salva</span>\r\n <span *ngIf=\"isSaving\">Salvataggio in Corso...</span>\r\n </button>\r\n </div>\r\n </mat-card-footer>\r\n\r\n</mat-card>\r\n\r\n<!--DIALOG PER SEMPLIFICARE LA SCRITTURA DEL CAMPO FORMULA-->\r\n<ng-template #dialogFormula>\r\n <eqp-dynamic-module-add-formula-component>\r\n </eqp-dynamic-module-add-formula-component>\r\n</ng-template>" }]
|
|
178
|
+
}], ctorParameters: function () { return [{ type: i1.MatDialog }, { type: i2.UtilityHelperService }]; }, propDecorators: { form: [{
|
|
179
|
+
type: Input,
|
|
180
|
+
args: ["form"]
|
|
181
|
+
}], actionButton: [{
|
|
182
|
+
type: Input,
|
|
183
|
+
args: ["actionButton"]
|
|
184
|
+
}], actionButtonField: [{
|
|
185
|
+
type: Input,
|
|
186
|
+
args: ["actionButtonField"]
|
|
187
|
+
}], formulas: [{
|
|
188
|
+
type: Input,
|
|
189
|
+
args: ["formulas"]
|
|
190
|
+
}], endPointConfiguration: [{
|
|
191
|
+
type: Input,
|
|
192
|
+
args: ["endPointConfiguration"]
|
|
193
|
+
}], InField: [{
|
|
194
|
+
type: Input,
|
|
195
|
+
args: ["InField"]
|
|
196
|
+
}], onSaveRecord: [{
|
|
197
|
+
type: Output
|
|
198
|
+
}], onChangeSomething: [{
|
|
199
|
+
type: Output
|
|
200
|
+
}], dialogFormula: [{
|
|
201
|
+
type: ViewChild,
|
|
202
|
+
args: ["dialogFormula", { static: true }]
|
|
203
|
+
}] } });
|
|
204
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-button-creator.component.js","sourceRoot":"","sources":["../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/action-button-creator/action-button-creator.component.ts","../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/action-button-creator/action-button-creator.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, EventEmitter, Output, TemplateRef, ViewChild } from '@angular/core';\r\nimport { ActionButton, ActionFlagEnum, TriggerPropertyTypeEnum } from '../../../models/trigger.model';\r\nimport { Form } from '../../../models/form.model';\r\nimport { EndPointConfiguration, EndPointDataParams, ParamTypeEnum } from '../../../models/endPointConfiguration.model';\r\nimport { FieldTypeEnum } from '../../../models/baseField.model';\r\nimport { MatDialog, MatDialogRef } from '@angular/material/dialog';\r\n\r\nimport { GlobalService } from '../../../services/global.service';\r\nimport { UtilityHelperService } from '../../../services/utilityHelper.services';\r\nimport { ActionButtonField } from '../../../models/fields/actionButton.model';\r\n\r\n@Component({\r\n  selector: 'action-button-creator',\r\n  templateUrl: './action-button-creator.component.html',\r\n  styleUrls: ['./action-button-creator.component.scss']\r\n})\r\nexport class ActionButtonCreatorComponent {\r\n\r\n  @Input(\"form\") form: Form;\r\n  @Input(\"actionButton\") actionButton: ActionButton = null;\r\n  @Input(\"actionButtonField\") actionButtonField: ActionButtonField = null;\r\n  @Input(\"formulas\") formulas: any = null;\r\n  @Input(\"endPointConfiguration\") endPointConfiguration: EndPointConfiguration;\r\n  @Input(\"InField\") InField: boolean = false;\r\n\r\n  @Output() onSaveRecord: EventEmitter<ActionButton> = new EventEmitter<ActionButton>();\r\n  @Output() onChangeSomething: EventEmitter<ActionButton> = new EventEmitter<ActionButton>();\r\n\r\n    FieldTypeEnum = FieldTypeEnum;\r\n    isSaving: boolean = false;\r\n    selectedFormula: any;\r\n    formulaKeys: Array<any> = new Array<any>();\r\n    formulaFieldsStructure: Array<any> = new Array<any>();\r\n    actionsFlag = ActionFlagEnum;\r\n    triggerPropertyType = TriggerPropertyTypeEnum;\r\n  \r\n    dialogFormulaRef: MatDialogRef<TemplateRef<any>>;\r\n    @ViewChild(\"dialogFormula\", { static: true }) dialogFormula: TemplateRef<any>;\r\n  \r\n    forms: Array<Form>;\r\n  \r\n    constructor(private dialog: MatDialog, private utilityHelperService: UtilityHelperService){}\r\n    \r\n    ngOnInit(){\r\n\r\n      ///\r\n      /// Questo componente funziona sia per i bottoni dei fields sia per i bottoni sugli header (addrecord, listview eccetera)\r\n      /// Se si sta lavorando sui fields è popolato 'this.actionButtonField' altrimenti è null.\r\n      ///\r\n\r\n      if (this.actionButtonField != null){\r\n        this.actionButton = <ActionButton>this.actionButtonField;\r\n      }\r\n      \r\n      if (this.actionButton != null && this.actionButton.execution != null) {\r\n        this.selectedFormula = {};\r\n        this.selectedFormula.key = this.actionButton.execution;\r\n\r\n        if (this.actionButtonField == null){\r\n          this.formulaFieldsStructure = new Array<any>();\r\n          Object.keys(this.formulas[this.selectedFormula.key]).forEach((res) => {\r\n            this.formulaFieldsStructure.push({\"key\": res, \"type\": this.formulas[this.selectedFormula.key][res].type, \"tooltip\": this.formulas[this.selectedFormula.key][res].tooltip});\r\n          });   \r\n\r\n          Object.keys(this.actionButton.formulasTemp).forEach((res) => {\r\n            this.formulaFieldsStructure.find(x => x.key == res).value = this.actionButton.formulasTemp[res].value;\r\n          });\r\n        } else {\r\n          this.formulaFieldsStructure.push(this.actionButton.formulas);\r\n        }\r\n\r\n      }\r\n\r\n      if (this.actionButton == null){\r\n        this.actionButton = new ActionButton();\r\n      }\r\n\r\n      var executeGetModules: boolean = false;\r\n      Object.keys(this.formulas).forEach((res) => {\r\n        this.formulaKeys.push({\"key\": res});\r\n        Object.keys(this.formulas[res]).forEach((property) => {\r\n          if (this.formulas[res][property].type == TriggerPropertyTypeEnum.DMMODULE){\r\n            executeGetModules = true;\r\n          }\r\n        });\r\n      });\r\n\r\n      if (executeGetModules){\r\n        this.getAllModules();\r\n      }\r\n\r\n    }\r\n\r\n    openFormulaDialog(formulaField: any) {\r\n      this.dialogFormulaRef = this.dialog.open(this.dialogFormula, {\r\n        disableClose: true,\r\n        hasBackdrop: true,\r\n        width: \"75%\",\r\n        data: {\r\n          formula: this.formulaFieldsStructure.find(x => x.key == formulaField.key).value,\r\n          fields: this.form.Fields\r\n        },\r\n      });\r\n      this.dialogFormulaRef.afterClosed().subscribe((result) => {\r\n        var formulaToChange = this.formulaFieldsStructure.find(x => x.key == formulaField.key);\r\n        formulaToChange.value = result.formula.toString() == \"\" ? null : result.formula.toString();\r\n        this.onFormulaFieldChange(formulaToChange);\r\n      });\r\n    }\r\n\r\n    onFormulaFieldChange(formulaField: any){\r\n       this.changeSomething();\r\n    }    \r\n\r\n    onEqpSelectModule(ev, formulaField){\r\n      formulaField.value = ev.ID;    \r\n      this.changeSomething();\r\n    }    \r\n\r\n  saveOrExitForm(exit: boolean) {\r\n    GlobalService.debugLog('add-form-record saveRecordEvent')\r\n    if (exit) {\r\n      this.onSaveRecord.emit(null);\r\n    } else {\r\n\r\n      this.actionButton.ButtonCode = this.selectedFormula.key;\r\n\r\n      this.formulaFieldsStructure.forEach((formulaField) => {\r\n        if (typeof this.actionButton.formulas == \"undefined\"){ this.actionButton.formulas = {}; }\r\n        this.actionButton.formulasTemp[formulaField.key] = formulaField;\r\n        this.actionButton.execution = this.selectedFormula.key;\r\n      });\r\n      this.isSaving = true;\r\n\r\n      this.onSaveRecord.emit(this.actionButton);\r\n    }\r\n  }    \r\n\r\n  changeSomething(){\r\n    this.actionButton.ButtonCode = this.selectedFormula.key;\r\n\r\n    if (!this.actionButton.formulasTemp){ this.actionButton.formulasTemp = {}; }\r\n\r\n    console.log(\"CHANGE SOMETHING\", this.actionButton, this.formulaFieldsStructure);\r\n    this.formulaFieldsStructure.forEach((formulaField) => {\r\n      if (typeof this.actionButton.formulas == \"undefined\"){ this.actionButton.formulas = {}; }\r\n      this.actionButton.formulasTemp[formulaField.key] = formulaField;\r\n      this.actionButton.execution = this.selectedFormula.key;\r\n    });\r\n\r\n    this.onChangeSomething.emit(this.actionButton);\r\n  }\r\n\r\n  getAllModules(){\r\n\r\n    const dynamicModuleParams: Array<EndPointDataParams> =\r\n      new Array<EndPointDataParams>();\r\n    dynamicModuleParams.push({\r\n      ParamName: \"orgaid\",\r\n      ParamValue: this.form.OrgaID,\r\n      ParamType: ParamTypeEnum[\"Query param\"],\r\n    });\r\n    this.utilityHelperService.RunEndPointCall(\r\n      this.endPointConfiguration.Forms.GetAllFormEndPoint,\r\n      dynamicModuleParams,\r\n      (res: Array<Form>) => {\r\n        this.forms = res;\r\n        this.forms = this.forms.sort((uno, due) => uno.Name.localeCompare(due.Name));\r\n\r\n        this.formulaFieldsStructure.forEach((res) => {\r\n          if (res.type == TriggerPropertyTypeEnum.DMMODULE){\r\n            res.object = this.forms.find(x => x.ID == res.value);\r\n          }\r\n        });\r\n\r\n      },\r\n      (err) => { }\r\n    );    \r\n  }  \r\n\r\n  onChangeFormula(formula: any){\r\n\r\n    \r\n    if (formula == null){  \r\n      this.changeSomething();\r\n      return;\r\n    }\r\n\r\n    GlobalService.debugLog('@@trigger-creator:onChangeFormula selected formula',formula)\r\n    GlobalService.debugLog('@@trigger-creator:onChangeFormula formulas',this.formulas)\r\n\r\n    this.formulaFieldsStructure = new Array<any>();\r\n\r\n    console.log(\"onChangeFormula\", this.formulas, formula.key);\r\n\r\n    //------------\r\n    Object.keys(this.formulas[formula.key]).forEach((res) => {\r\n      this.formulaFieldsStructure.push({\"key\": res, \"type\": this.formulas[formula.key][res].type, \r\n        \"tooltip\": this.formulas[formula.key][res].tooltip});\r\n    });  \r\n    //------------\r\n    /* *** originale ***\r\n    Object.keys(this.formulas[formula.key]).forEach((res) => {\r\n      this.formulaFieldsStructure.push({\"key\": res, \"type\": this.formulas[formula.key][res].type\r\n      });\r\n    });\r\n    *** */\r\n    GlobalService.debugLog('@@trigger-creator:onChangeFormula formulaFieldsStructure',this.formulaFieldsStructure)\r\n\r\n\r\n    this.changeSomething();\r\n  }  \r\n\r\n}\r\n","\r\n<mat-card class=\"add-form-field\">\r\n    <mat-card-header *ngIf=\"!InField\">\r\n        <mat-card-title>\r\n            {{actionButton != null ? \"Modifica\" : \"Aggiungi\"}} actionButton\r\n        </mat-card-title>\r\n    </mat-card-header>\r\n\r\n    <mat-card-content>\r\n\r\n    <div class=\"container-fluid containerContent padder\">\r\n\r\n        <div class=\"row\">\r\n            <div class=\"col-3\">Tipo Action Button</div>\r\n            <div class=\"col-9\">\r\n                <eqp-select [arrayData]=\"formulaKeys\" [(ngModelInput)]=\"selectedFormula\"\r\n                [arrayKeyProperty]=\"'key'\" [arrayValueProperty]=\"'key'\" [showCancelButton]=\"true\" (ngModelInputChange)=\"onChangeFormula($event)\">\r\n                </eqp-select>            \r\n            </div>\r\n        </div>\r\n  \r\n          <div class=\"row\">\r\n            <div class=\"col-3\">Etichetta</div>\r\n            <div class=\"col-9\">\r\n                <mat-form-field>\r\n                    <mat-label  class=\"pt-1\"> Etichetta </mat-label>\r\n                    <input matInput [(ngModel)]=\"actionButton.ButtonLabel\" [readonly]=\"false\" [required]=\"true\" (keyup)=\"changeSomething()\">\r\n                </mat-form-field>\r\n            </div>\r\n          </div>\r\n  \r\n          <div class=\"row\">\r\n            <div class=\"col-3\">Icona (<a href='https://www.angularjswiki.com/angular/angular-material-icons-list-mat-icon-list' target=\"_blank\">lista</a>)</div>\r\n            <div class=\"col-9\">\r\n                <mat-form-field>\r\n                    <mat-label  class=\"pt-1\"> Icona Material (<a href='https://www.angularjswiki.com/angular/angular-material-icons-list-mat-icon-list' target=\"_blank\">lista</a>) </mat-label>\r\n                    <input matInput [(ngModel)]=\"actionButton.Icon\" [readonly]=\"false\" [required]=\"true\" (keyup)=\"changeSomething()\">\r\n                </mat-form-field>\r\n            </div>\r\n          </div>   \r\n          \r\n          <div class=\"row\" *ngIf=\"!InField\">\r\n            <div class=\"col-3\">Sezioni</div>\r\n            <div class=\"col-9\">\r\n                <mat-label  class=\"pt-1\"> Sezioni </mat-label>\r\n                <eqp-select\r\n                  [enumData]=\"actionsFlag\"\r\n                  [isSearchable]=\"true\"\r\n                  [isMultiSelect] = \"true\"\r\n                  [(ngModelInput)]=\"actionButton.ShowIn\"        \r\n                  (ngModelInputChange)=\"changeSomething()\"             \r\n                >\r\n                </eqp-select>\r\n            </div>\r\n          </div>   \r\n\r\n        <div class=\"row\" *ngFor=\"let formulaField of formulaFieldsStructure\">\r\n            <div class=\"col-3\">{{formulaField.key}}</div>\r\n            <div class=\"col-9\" *ngIf=\"formulaField.type == triggerPropertyType.STRING\">\r\n                <mat-form-field>\r\n                    <mat-label  class=\"pt-1\"> {{formulaField.key}}</mat-label>\r\n                    <input matInput [readonly]=\"false\" [required]=\"false\" [matTooltip]=\"formulaField.tooltip\" (click)=\"openFormulaDialog(formulaField)\" [(ngModel)]=\"formulaField.value\" (ngModelChange)=\"onFormulaFieldChange(formulaField)\">\r\n                </mat-form-field>\r\n            </div>\r\n            <div class=\"col-9\" *ngIf=\"formulaField.type == triggerPropertyType.DMMODULE\">\r\n                <eqp-select [placeholder]=\"'Seleziona modulo'\" [arrayData]=\"forms\" [(ngModelInput)]=\"formulaField.object\" [isSearchable]=\"true\"\r\n                [arrayKeyProperty]=\"'ID'\" [arrayValueProperty]=\"'Name'\" [ngModelOptions]=\"{ standalone: true }\" (ngModelInputChange)=\"onEqpSelectModule($event, formulaField)\">\r\n                </eqp-select>\r\n            </div>\r\n        </div>\r\n\r\n    </div>\r\n\r\n    </mat-card-content>\r\n    <mat-card-footer *ngIf=\"!InField\">\r\n        <div class=\"d-flex justify-content-end mt-2 mb-1 me-3\"> \r\n            <button class=\"mr-2\" mat-raised-button type=\"button\" (click)=\"saveOrExitForm(true)\">\r\n                Annulla\r\n            </button>\r\n            <button class=\"mr-2\" mat-raised-button color=\"primary\" type=\"button\"\r\n                (click)=\"saveOrExitForm(false)\" [disabled]=\"isSaving\">\r\n                <span *ngIf=\"!isSaving\">Salva</span>\r\n                <span *ngIf=\"isSaving\">Salvataggio in Corso...</span>\r\n            </button>\r\n        </div>\r\n    </mat-card-footer>\r\n\r\n</mat-card>\r\n\r\n<!--DIALOG PER SEMPLIFICARE LA SCRITTURA DEL CAMPO FORMULA-->\r\n<ng-template #dialogFormula>\r\n    <eqp-dynamic-module-add-formula-component>\r\n    </eqp-dynamic-module-add-formula-component>\r\n</ng-template>"]}
|