@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.
Files changed (42) hide show
  1. package/esm2020/lib/components/exported/eqp-dynamic-module/eqp-dynamic-module.component.mjs +3 -9
  2. package/esm2020/lib/components/exported/eqp-dynamic-module-configurator/eqp-dynamic-module-configurator.component.mjs +42 -43
  3. package/esm2020/lib/components/private/action-button-creator/action-button-creator.component.mjs +204 -0
  4. package/esm2020/lib/components/private/add-form-field/add-form-field.component.mjs +38 -78
  5. package/esm2020/lib/components/private/dynamic-module-field-fix/dynamic-module-field.component.mjs +12 -3
  6. package/esm2020/lib/components/private/field-templates/action-button-field-template/action-button-field-template.component.mjs +52 -0
  7. package/esm2020/lib/components/private/form-records/add-form-record/add-form-record.component.mjs +19 -17
  8. package/esm2020/lib/components/private/form-records/hlist-form-record/hlist-form-record.component.mjs +2 -9
  9. package/esm2020/lib/components/private/form-records/list-form-record/list-form-record.component.mjs +2 -8
  10. package/esm2020/lib/components/private/form-records/list-view-form-record/list-view-form-record.component.mjs +45 -17
  11. package/esm2020/lib/components/private/form-records/list-view-form-record/single-record/single-record.component.mjs +3 -9
  12. package/esm2020/lib/components/private/form-records/view-form-record/view-form-record.component.mjs +2 -8
  13. package/esm2020/lib/components/private/form-statistics/filter-form-statistic/filter-form-statistic.component.mjs +4 -7
  14. package/esm2020/lib/components/private/graphs/graphs.component.mjs +4 -7
  15. package/esm2020/lib/components/private/trigger-creator/trigger-creator.component.mjs +1 -1
  16. package/esm2020/lib/eqp-dynamic-module.module.mjs +9 -3
  17. package/esm2020/lib/models/baseField.model.mjs +2 -1
  18. package/esm2020/lib/models/fields/actionButton.model.mjs +6 -0
  19. package/esm2020/lib/models/trigger.model.mjs +5 -7
  20. package/fesm2015/eqproject-eqp-dynamic-module.mjs +408 -209
  21. package/fesm2015/eqproject-eqp-dynamic-module.mjs.map +1 -1
  22. package/fesm2020/eqproject-eqp-dynamic-module.mjs +408 -209
  23. package/fesm2020/eqproject-eqp-dynamic-module.mjs.map +1 -1
  24. package/lib/components/exported/eqp-dynamic-module/eqp-dynamic-module.component.d.ts +2 -4
  25. package/lib/components/exported/eqp-dynamic-module-configurator/eqp-dynamic-module-configurator.component.d.ts +8 -5
  26. package/lib/components/private/action-button-creator/action-button-creator.component.d.ts +42 -0
  27. package/lib/components/private/add-form-field/add-form-field.component.d.ts +5 -12
  28. package/lib/components/private/dynamic-module-field-fix/dynamic-module-field.component.d.ts +4 -1
  29. package/lib/components/private/field-templates/action-button-field-template/action-button-field-template.component.d.ts +19 -0
  30. package/lib/components/private/form-records/add-form-record/add-form-record.component.d.ts +3 -4
  31. package/lib/components/private/form-records/hlist-form-record/hlist-form-record.component.d.ts +2 -4
  32. package/lib/components/private/form-records/list-form-record/list-form-record.component.d.ts +2 -4
  33. package/lib/components/private/form-records/list-view-form-record/list-view-form-record.component.d.ts +2 -4
  34. package/lib/components/private/form-records/list-view-form-record/single-record/single-record.component.d.ts +2 -4
  35. package/lib/components/private/form-records/view-form-record/view-form-record.component.d.ts +2 -4
  36. package/lib/components/private/form-statistics/filter-form-statistic/filter-form-statistic.component.d.ts +3 -4
  37. package/lib/components/private/graphs/graphs.component.d.ts +3 -4
  38. package/lib/eqp-dynamic-module.module.d.ts +16 -14
  39. package/lib/models/baseField.model.d.ts +2 -1
  40. package/lib/models/fields/actionButton.model.d.ts +17 -0
  41. package/lib/models/trigger.model.d.ts +7 -14
  42. package/package.json +1 -1
@@ -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>"]}