@eqproject/eqp-dynamic-module 2.5.5 → 2.5.7
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/private/dbgetter/dbgetter.component.mjs +3 -3
- package/esm2020/lib/components/private/dynamic-module-field-fix/dynamic-module-field.component.mjs +3 -3
- package/esm2020/lib/components/private/field-templates/date-field-template/date-field-template.component.mjs +3 -3
- package/esm2020/lib/components/private/form-statistics/filter-templates/date-filter-template/date-filter-template.component.mjs +3 -3
- package/esm2020/lib/components/private/graphs/graphs.component.mjs +3 -3
- package/fesm2015/eqproject-eqp-dynamic-module.mjs +10 -10
- package/fesm2015/eqproject-eqp-dynamic-module.mjs.map +1 -1
- package/fesm2020/eqproject-eqp-dynamic-module.mjs +10 -10
- package/fesm2020/eqproject-eqp-dynamic-module.mjs.map +1 -1
- package/package.json +2 -2
|
@@ -128,10 +128,10 @@ export class DbgetterComponent {
|
|
|
128
128
|
}
|
|
129
129
|
}
|
|
130
130
|
DbgetterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DbgetterComponent, deps: [{ token: i1.HttpClient }], target: i0.ɵɵFactoryTarget.Component });
|
|
131
|
-
DbgetterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DbgetterComponent, selector: "dbgetter", inputs: { field: "field", record: "record", inConfig: "inConfig", DirectlyOpenTable: "DirectlyOpenTable", QueryEditorComponent: "QueryEditorComponent", data: "data" }, outputs: { out: "out", selectedValue: "selectedValue" }, ngImport: i0, template: "<div [hidden]=\"!showQE\">\r\n <ng-template [appDynamicLoader] [data]=\"QueryEditorComponent\" (out)=\"onExternalSQLResultOut($event);\" *ngIf=\"QueryEditorComponent != null\"></ng-template>\r\n</div>\r\n\r\n\r\n<div class=\"flex dbgetterfield\" *ngIf=\"showButtonReply\">\r\n <button class=\"btn btn-primary\" (click)=\"onClickButtonReply()\"> {{field.Name}} <mat-icon>edit</mat-icon></button>\r\n</div>\r\n\r\n<div class=\"floatingtable draggable\" cdkDrag *ngIf=\"showTable\">\r\n <div class=\"header\">\r\n <div class=\"left\"><button class=\"btn btn-small btn-danger\" (click)=\"close()\">Chiudi finestra <mat-icon>close</mat-icon></button></div>\r\n <div class=\"left\"><button class=\"btn btn-small btn-danger\" (click)=\"delete()\">Cancella valore <mat-icon>delete</mat-icon></button></div>\r\n <div class=\"right\"><mat-icon>drag_indicator</mat-icon> Seleziona il valore da registrare. Clicca su questa barra per trascinare.</div>\r\n </div>\r\n <table class=\"table table-notforced\" *ngIf=\"field.DataGetter.DataGetterColumnForce == null\">\r\n <tr><th *ngFor=\"let key of keys; let first = first\">\r\n <span *ngIf=\"first\">{{key}}</span>\r\n <span *ngIf=\"!first\">{{key.split(\"__\")[1]}}</span>\r\n </th></tr>\r\n <tr *ngFor=\"let row of data\" class=\"rows\">\r\n <td *ngFor=\"let key of keys\" (click)=\"selectValueNotForced(row[key])\">\r\n {{row[key] != null ? row[key].toString().substring(0,100) : ''}}<span *ngIf=\"row[key] != null && row[key].toString().length > 100\">...</span>\r\n </td>\r\n </tr>\r\n </table>\r\n <table class=\"table table-forced\" *ngIf=\"field.DataGetter.DataGetterColumnForce != null\">\r\n <tr><th *ngFor=\"let key of keys; let first = first\">\r\n <span *ngIf=\"first\">{{key}}</span>\r\n <span *ngIf=\"!first\">{{key.split(\"__\")[1]}}</span>\r\n </th></tr>\r\n <tr *ngFor=\"let row of data\" class=\"rows\" (click)=\"selectValueForced(row)\">\r\n <td *ngFor=\"let key of keys\">{{row[key] != null ? row[key].toString().substring(0,100) : ''}}<span *ngIf=\"row[key] != null && row[key].toString().length > 100\">...</span></td>\r\n </tr>\r\n </table> \r\n</div>\r\n\r\n<span *ngIf=\"value != null\">{{value}}</span>", styles: [".floatingtable{position:fixed;bottom:10%;left:30%;width:50%;background-color:#fff;border:1px solid black;border-radius:10px;margin:0;z-index:9000000000;padding:2px}.floatingtable .header{cursor:move;display:flex;justify-content:flex-start;height:40px;background-color:#4fa2c0;color:#fff;align-items:center;font-size:19px;padding-right:15px;margin-bottom:10px}.floatingtable .header>*{margin-right:10px}.floatingtable .header .left mat-icon{position:relative;top:5px;left:10px;cursor:pointer!important;background-color:red!important;color:#fff}.floatingtable .header .right mat-icon{position:relative;top:5px}.floatingtable .table.table-notforced{width:99%;margin:0 5px}.floatingtable .table.table-notforced td,.floatingtable .table.table-notforced th{padding:2px 2px 2px 0}.floatingtable .table.table-notforced td span,.floatingtable .table.table-notforced th span{padding:0!important}.floatingtable .table.table-notforced td:hover{cursor:pointer;background-color:#d3d3d3;color:#000}.floatingtable .table.table-forced{width:99%;margin:0 5px}.floatingtable .table.table-forced td,.floatingtable .table.table-forced th{padding:2px 2px 2px 0}.floatingtable .table.table-forced td span,.floatingtable .table.table-forced th span{padding:0!important}.floatingtable .table.table-forced tr.rows:hover{cursor:pointer;background-color:#d3d3d3;color:#000}.btn-small{margin:0;padding:0 16px}\n"], dependencies: [{ kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i5.DynamicLoaderDirective, selector: "[appDynamicLoader]", inputs: ["data"], outputs: ["out"] }] });
|
|
131
|
+
DbgetterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DbgetterComponent, selector: "dbgetter", inputs: { field: "field", record: "record", inConfig: "inConfig", DirectlyOpenTable: "DirectlyOpenTable", QueryEditorComponent: "QueryEditorComponent", data: "data" }, outputs: { out: "out", selectedValue: "selectedValue" }, ngImport: i0, template: "<div [hidden]=\"!showQE\">\r\n <ng-template [appDynamicLoader] [data]=\"QueryEditorComponent\" (out)=\"onExternalSQLResultOut($event);\" *ngIf=\"QueryEditorComponent != null\"></ng-template>\r\n</div>\r\n\r\n\r\n<div class=\"flex dbgetterfield\" *ngIf=\"showButtonReply\">\r\n <button class=\"btn btn-primary\" (click)=\"onClickButtonReply()\"> {{field.Name}} <mat-icon>edit</mat-icon></button>\r\n</div>\r\n\r\n\r\n\r\n<div class=\"floatingtable draggable\" cdkDrag *ngIf=\"showTable\">\r\n <div class=\"header\">\r\n <div class=\"left\"><button class=\"btn btn-small btn-danger\" (click)=\"close()\">Chiudi finestra <mat-icon>close</mat-icon></button></div>\r\n <div class=\"left\"><button class=\"btn btn-small btn-danger\" (click)=\"delete()\">Cancella valore <mat-icon>delete</mat-icon></button></div>\r\n <div class=\"right\"><mat-icon>drag_indicator</mat-icon> Seleziona il valore da registrare. Clicca su questa barra per trascinare.</div>\r\n </div>\r\n <table class=\"table table-notforced\" *ngIf=\"field.DataGetter.DataGetterColumnForce == null\">\r\n <tr><th *ngFor=\"let key of keys; let first = first\">\r\n <span *ngIf=\"first\">{{key}}</span>\r\n <span *ngIf=\"!first\">{{key.split(\"__\")[1]}}</span>\r\n </th></tr>\r\n <tr *ngFor=\"let row of data\" class=\"rows\">\r\n <td *ngFor=\"let key of keys\" (click)=\"selectValueNotForced(row[key])\">\r\n {{row[key] != null ? row[key].toString().substring(0,100) : ''}}<span *ngIf=\"row[key] != null && row[key].toString().length > 100\">...</span>\r\n </td>\r\n </tr>\r\n </table>\r\n <table class=\"table table-forced\" *ngIf=\"field.DataGetter.DataGetterColumnForce != null\">\r\n <tr><th *ngFor=\"let key of keys; let first = first\">\r\n <span *ngIf=\"first\">{{key}}</span>\r\n <span *ngIf=\"!first\">{{key.split(\"__\")[1]}}</span>\r\n </th></tr>\r\n <tr *ngFor=\"let row of data\" class=\"rows\" (click)=\"selectValueForced(row)\">\r\n <td *ngFor=\"let key of keys\">{{row[key] != null ? row[key].toString().substring(0,100) : ''}}<span *ngIf=\"row[key] != null && row[key].toString().length > 100\">...</span></td>\r\n </tr>\r\n </table> \r\n</div>\r\n\r\n<span *ngIf=\"value != null\">{{value}}</span>", styles: [".floatingtable{position:fixed;bottom:10%;left:30%;width:50%;background-color:#fff;border:1px solid black;border-radius:10px;margin:0;z-index:9000000000;padding:2px}.floatingtable .header{cursor:move;display:flex;justify-content:flex-start;height:40px;background-color:#4fa2c0;color:#fff;align-items:center;font-size:19px;padding-right:15px;margin-bottom:10px}.floatingtable .header>*{margin-right:10px}.floatingtable .header .left mat-icon{position:relative;top:5px;left:10px;cursor:pointer!important;background-color:red!important;color:#fff}.floatingtable .header .right mat-icon{position:relative;top:5px}.floatingtable .table.table-notforced{width:99%;margin:0 5px}.floatingtable .table.table-notforced td,.floatingtable .table.table-notforced th{padding:2px 2px 2px 0}.floatingtable .table.table-notforced td span,.floatingtable .table.table-notforced th span{padding:0!important}.floatingtable .table.table-notforced td:hover{cursor:pointer;background-color:#d3d3d3;color:#000}.floatingtable .table.table-forced{width:99%;margin:0 5px}.floatingtable .table.table-forced td,.floatingtable .table.table-forced th{padding:2px 2px 2px 0}.floatingtable .table.table-forced td span,.floatingtable .table.table-forced th span{padding:0!important}.floatingtable .table.table-forced tr.rows:hover{cursor:pointer;background-color:#d3d3d3;color:#000}.btn-small{margin:0;padding:0 16px}\n"], dependencies: [{ kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i5.DynamicLoaderDirective, selector: "[appDynamicLoader]", inputs: ["data"], outputs: ["out"] }] });
|
|
132
132
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DbgetterComponent, decorators: [{
|
|
133
133
|
type: Component,
|
|
134
|
-
args: [{ selector: 'dbgetter', template: "<div [hidden]=\"!showQE\">\r\n <ng-template [appDynamicLoader] [data]=\"QueryEditorComponent\" (out)=\"onExternalSQLResultOut($event);\" *ngIf=\"QueryEditorComponent != null\"></ng-template>\r\n</div>\r\n\r\n\r\n<div class=\"flex dbgetterfield\" *ngIf=\"showButtonReply\">\r\n <button class=\"btn btn-primary\" (click)=\"onClickButtonReply()\"> {{field.Name}} <mat-icon>edit</mat-icon></button>\r\n</div>\r\n\r\n<div class=\"floatingtable draggable\" cdkDrag *ngIf=\"showTable\">\r\n <div class=\"header\">\r\n <div class=\"left\"><button class=\"btn btn-small btn-danger\" (click)=\"close()\">Chiudi finestra <mat-icon>close</mat-icon></button></div>\r\n <div class=\"left\"><button class=\"btn btn-small btn-danger\" (click)=\"delete()\">Cancella valore <mat-icon>delete</mat-icon></button></div>\r\n <div class=\"right\"><mat-icon>drag_indicator</mat-icon> Seleziona il valore da registrare. Clicca su questa barra per trascinare.</div>\r\n </div>\r\n <table class=\"table table-notforced\" *ngIf=\"field.DataGetter.DataGetterColumnForce == null\">\r\n <tr><th *ngFor=\"let key of keys; let first = first\">\r\n <span *ngIf=\"first\">{{key}}</span>\r\n <span *ngIf=\"!first\">{{key.split(\"__\")[1]}}</span>\r\n </th></tr>\r\n <tr *ngFor=\"let row of data\" class=\"rows\">\r\n <td *ngFor=\"let key of keys\" (click)=\"selectValueNotForced(row[key])\">\r\n {{row[key] != null ? row[key].toString().substring(0,100) : ''}}<span *ngIf=\"row[key] != null && row[key].toString().length > 100\">...</span>\r\n </td>\r\n </tr>\r\n </table>\r\n <table class=\"table table-forced\" *ngIf=\"field.DataGetter.DataGetterColumnForce != null\">\r\n <tr><th *ngFor=\"let key of keys; let first = first\">\r\n <span *ngIf=\"first\">{{key}}</span>\r\n <span *ngIf=\"!first\">{{key.split(\"__\")[1]}}</span>\r\n </th></tr>\r\n <tr *ngFor=\"let row of data\" class=\"rows\" (click)=\"selectValueForced(row)\">\r\n <td *ngFor=\"let key of keys\">{{row[key] != null ? row[key].toString().substring(0,100) : ''}}<span *ngIf=\"row[key] != null && row[key].toString().length > 100\">...</span></td>\r\n </tr>\r\n </table> \r\n</div>\r\n\r\n<span *ngIf=\"value != null\">{{value}}</span>", styles: [".floatingtable{position:fixed;bottom:10%;left:30%;width:50%;background-color:#fff;border:1px solid black;border-radius:10px;margin:0;z-index:9000000000;padding:2px}.floatingtable .header{cursor:move;display:flex;justify-content:flex-start;height:40px;background-color:#4fa2c0;color:#fff;align-items:center;font-size:19px;padding-right:15px;margin-bottom:10px}.floatingtable .header>*{margin-right:10px}.floatingtable .header .left mat-icon{position:relative;top:5px;left:10px;cursor:pointer!important;background-color:red!important;color:#fff}.floatingtable .header .right mat-icon{position:relative;top:5px}.floatingtable .table.table-notforced{width:99%;margin:0 5px}.floatingtable .table.table-notforced td,.floatingtable .table.table-notforced th{padding:2px 2px 2px 0}.floatingtable .table.table-notforced td span,.floatingtable .table.table-notforced th span{padding:0!important}.floatingtable .table.table-notforced td:hover{cursor:pointer;background-color:#d3d3d3;color:#000}.floatingtable .table.table-forced{width:99%;margin:0 5px}.floatingtable .table.table-forced td,.floatingtable .table.table-forced th{padding:2px 2px 2px 0}.floatingtable .table.table-forced td span,.floatingtable .table.table-forced th span{padding:0!important}.floatingtable .table.table-forced tr.rows:hover{cursor:pointer;background-color:#d3d3d3;color:#000}.btn-small{margin:0;padding:0 16px}\n"] }]
|
|
134
|
+
args: [{ selector: 'dbgetter', template: "<div [hidden]=\"!showQE\">\r\n <ng-template [appDynamicLoader] [data]=\"QueryEditorComponent\" (out)=\"onExternalSQLResultOut($event);\" *ngIf=\"QueryEditorComponent != null\"></ng-template>\r\n</div>\r\n\r\n\r\n<div class=\"flex dbgetterfield\" *ngIf=\"showButtonReply\">\r\n <button class=\"btn btn-primary\" (click)=\"onClickButtonReply()\"> {{field.Name}} <mat-icon>edit</mat-icon></button>\r\n</div>\r\n\r\n\r\n\r\n<div class=\"floatingtable draggable\" cdkDrag *ngIf=\"showTable\">\r\n <div class=\"header\">\r\n <div class=\"left\"><button class=\"btn btn-small btn-danger\" (click)=\"close()\">Chiudi finestra <mat-icon>close</mat-icon></button></div>\r\n <div class=\"left\"><button class=\"btn btn-small btn-danger\" (click)=\"delete()\">Cancella valore <mat-icon>delete</mat-icon></button></div>\r\n <div class=\"right\"><mat-icon>drag_indicator</mat-icon> Seleziona il valore da registrare. Clicca su questa barra per trascinare.</div>\r\n </div>\r\n <table class=\"table table-notforced\" *ngIf=\"field.DataGetter.DataGetterColumnForce == null\">\r\n <tr><th *ngFor=\"let key of keys; let first = first\">\r\n <span *ngIf=\"first\">{{key}}</span>\r\n <span *ngIf=\"!first\">{{key.split(\"__\")[1]}}</span>\r\n </th></tr>\r\n <tr *ngFor=\"let row of data\" class=\"rows\">\r\n <td *ngFor=\"let key of keys\" (click)=\"selectValueNotForced(row[key])\">\r\n {{row[key] != null ? row[key].toString().substring(0,100) : ''}}<span *ngIf=\"row[key] != null && row[key].toString().length > 100\">...</span>\r\n </td>\r\n </tr>\r\n </table>\r\n <table class=\"table table-forced\" *ngIf=\"field.DataGetter.DataGetterColumnForce != null\">\r\n <tr><th *ngFor=\"let key of keys; let first = first\">\r\n <span *ngIf=\"first\">{{key}}</span>\r\n <span *ngIf=\"!first\">{{key.split(\"__\")[1]}}</span>\r\n </th></tr>\r\n <tr *ngFor=\"let row of data\" class=\"rows\" (click)=\"selectValueForced(row)\">\r\n <td *ngFor=\"let key of keys\">{{row[key] != null ? row[key].toString().substring(0,100) : ''}}<span *ngIf=\"row[key] != null && row[key].toString().length > 100\">...</span></td>\r\n </tr>\r\n </table> \r\n</div>\r\n\r\n<span *ngIf=\"value != null\">{{value}}</span>", styles: [".floatingtable{position:fixed;bottom:10%;left:30%;width:50%;background-color:#fff;border:1px solid black;border-radius:10px;margin:0;z-index:9000000000;padding:2px}.floatingtable .header{cursor:move;display:flex;justify-content:flex-start;height:40px;background-color:#4fa2c0;color:#fff;align-items:center;font-size:19px;padding-right:15px;margin-bottom:10px}.floatingtable .header>*{margin-right:10px}.floatingtable .header .left mat-icon{position:relative;top:5px;left:10px;cursor:pointer!important;background-color:red!important;color:#fff}.floatingtable .header .right mat-icon{position:relative;top:5px}.floatingtable .table.table-notforced{width:99%;margin:0 5px}.floatingtable .table.table-notforced td,.floatingtable .table.table-notforced th{padding:2px 2px 2px 0}.floatingtable .table.table-notforced td span,.floatingtable .table.table-notforced th span{padding:0!important}.floatingtable .table.table-notforced td:hover{cursor:pointer;background-color:#d3d3d3;color:#000}.floatingtable .table.table-forced{width:99%;margin:0 5px}.floatingtable .table.table-forced td,.floatingtable .table.table-forced th{padding:2px 2px 2px 0}.floatingtable .table.table-forced td span,.floatingtable .table.table-forced th span{padding:0!important}.floatingtable .table.table-forced tr.rows:hover{cursor:pointer;background-color:#d3d3d3;color:#000}.btn-small{margin:0;padding:0 16px}\n"] }]
|
|
135
135
|
}], ctorParameters: function () { return [{ type: i1.HttpClient }]; }, propDecorators: { field: [{
|
|
136
136
|
type: Input
|
|
137
137
|
}], record: [{
|
|
@@ -156,4 +156,4 @@ export var QueryEditorModeEnum;
|
|
|
156
156
|
QueryEditorModeEnum[QueryEditorModeEnum["COMPOSER"] = 2] = "COMPOSER";
|
|
157
157
|
QueryEditorModeEnum[QueryEditorModeEnum["RESULT"] = 3] = "RESULT";
|
|
158
158
|
})(QueryEditorModeEnum || (QueryEditorModeEnum = {}));
|
|
159
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dbgetter.component.js","sourceRoot":"","sources":["../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/dbgetter/dbgetter.component.ts","../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/dbgetter/dbgetter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport { Form } from '@angular/forms';\r\nimport { DynamicLoaderDirectiveData, eventOut } from '../../../directives/dynamic-loader/dynamic-loader.directive';\r\nimport { BaseField } from '../../../models/baseField.model';\r\nimport { Record } from '../../../models/record.model';\r\nimport { EndPointConfiguration } from '../../../models/endPointConfiguration.model';\r\nimport { HttpClient } from '@angular/common/http';\r\n\r\n@Component({\r\n  selector: 'dbgetter',\r\n  templateUrl: './dbgetter.component.html',\r\n  styleUrls: ['./dbgetter.component.scss']\r\n})\r\nexport class DbgetterComponent {\r\n\r\n  @Input() field: BaseField;\r\n  @Input() record: Record;\r\n  @Input() inConfig: boolean = false;\r\n  @Input() DirectlyOpenTable: boolean = false;\r\n  @Input() QueryEditorComponent: DynamicLoaderDirectiveData = null; // L'intero componente query Editor\r\n  @Input() data: any = null; // Lo facciamo funzionare tipo EQP-TABLE\r\n\r\n  @Output() out: EventEmitter<eventOut> = new EventEmitter<eventOut>();\r\n  @Output() selectedValue: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  keys: Array<string> = null;\r\n  loaded: boolean = false;\r\n  value: any;\r\n\r\n  showButtonReply: boolean = false;\r\n  showTable: boolean = false;\r\n  showQE: boolean = true;\r\n\r\n  haveQuestions: boolean = false;\r\n\r\n  constructor(private httpClient: HttpClient) {}\r\n\r\n  ngOnInit(): void {\r\n\r\n    console.log(\"Welcome to DBGETTER Country\");\r\n    console.log(\"field\", this.field);\r\n    console.log(\"record\", this.record);\r\n    console.log(\"inConfig\", this.inConfig);\r\n    console.log(\"QueryEditorComponent\", this.QueryEditorComponent);\r\n\r\n\r\n    if (this.QueryEditorComponent != null){\r\n      this.QueryEditorComponent.inputParams.config.mode = QueryEditorModeEnum.RESULT;\r\n      this.QueryEditorComponent.inputParams.config.field = this.field;\r\n      this.QueryEditorComponent.inputParams.config.record = this.record;\r\n      this.QueryEditorComponent.inputParams.config.inConfig = this.inConfig;\r\n\r\n      if (this.field.DataGetter.DataGetterValue.openedFields.find(x => x.QueryPropertyValue == '?') != null){\r\n        \r\n        // Il modulo ha almeno una risposta con \"?\"\r\n        this.haveQuestions = true;\r\n\r\n      }\r\n    } else {\r\n\r\n      if (this.data == null){\r\n\r\n      this.httpClient.get('./assets/mockups/mockedFromQueryEditor_RESULT_MANY.txt', {responseType: 'text'})\r\n      .subscribe(mockedFromQueryEditor => {\r\n        this.data = JSON.parse(mockedFromQueryEditor);\r\n        this.data = JSON.parse(this.data.result);\r\n        this.processResult(this.data,[]);\r\n       });      \r\n\r\n      }\r\n\r\n    }\r\n\r\n  }\r\n\r\n  onExternalSQLResultOut(ev: eventOut){\r\n    console.log(\"La query del Query Editor è stata eseguita, ed ha restituito il seguente risultato: \",ev);\r\n    if (ev.Behaviours.indexOf(\"send-out\") != -1){ this.out.emit(ev); }\r\n\r\n    this.data = JSON.parse(ev.Params.result);\r\n    this.processResult(this.data,ev.Behaviours);\r\n\r\n  }\r\n\r\n  processResult(data: any, behaviours: Array<string> = []){\r\n    \r\n    if (data.length > 0){\r\n      this.keys = Object.keys(data[0]);\r\n      if (this.keys.length == 2 && data.length == 1){\r\n        // Se ho un solo occhietto selezionato e la query restituisce un solo valore, lo butto fuori automaticamente\r\n        this.showButtonReply = false;\r\n        this.showTable = false;\r\n        this.record[this.field.Name] = data[0][this.keys[1]];\r\n        this.selectedValue.emit([data[0][this.keys[1]],true]);\r\n      } else if (data.length == 1 && this.field.DataGetter.DataGetterColumnForce != null){\r\n        this.showButtonReply = false;\r\n        this.showTable = false;\r\n        this.record[this.field.Name] = data[0][this.field.DataGetter.DataGetterColumnForce.key];\r\n        this.selectedValue.emit([data[0][this.keys[1]],true]);\r\n      } else {\r\n\r\n        if (behaviours.indexOf(\"manage-question-in-dbgetter\") != -1){\r\n            this.showButtonReply = false;\r\n            this.showTable = true;\r\n        } else {\r\n\r\n          if (!this.DirectlyOpenTable){\r\n            this.showButtonReply = true;\r\n            this.showTable = false;\r\n          } else {\r\n            this.showButtonReply = false;\r\n            this.showTable = true;          \r\n          }\r\n\r\n        }\r\n\r\n      }\r\n    } else {\r\n      this.showQE = true;\r\n    }\r\n    \r\n  }\r\n\r\n  onClickButtonReply(){\r\n    this.showTable = true;\r\n    this.showQE = true;\r\n  }\r\n\r\n  selectValueNotForced(value){\r\n    if (value == null){ value = \"\"; }\r\n    \r\n    this.record[this.field.Name] = value;\r\n    this.showTable = false;\r\n    this.showQE = false;\r\n    this.showButtonReply = true;\r\n    this.selectedValue.emit([value,false]);\r\n  }\r\n\r\n  selectValueForced(row){\r\n    var valueToBeSet = row[this.field.DataGetter.DataGetterColumnForce.key];\r\n    if (valueToBeSet == null){ valueToBeSet = \"\"; }\r\n\r\n    this.record[this.field.Name] = valueToBeSet;\r\n    this.showTable = false;\r\n    this.showQE = false;\r\n    this.showButtonReply = true;\r\n    this.selectedValue.emit([valueToBeSet,false]);\r\n  }  \r\n\r\n  close(){\r\n    this.selectedValue.emit([\"****CLOSE****\",true]);\r\n    this.showTable = false;\r\n  }\r\n  \r\n  delete(){\r\n    this.selectedValue.emit([null,true]);\r\n    this.showTable = false;\r\n  }  \r\n}\r\n\r\n// O così o schiantato a mano\r\nexport enum QueryEditorModeEnum {\r\n  \"CONFIGURATOR\" = 1,\r\n  \"COMPOSER\" = 2,\r\n  \"RESULT\" = 3\r\n}","<div [hidden]=\"!showQE\">\r\n    <ng-template [appDynamicLoader] [data]=\"QueryEditorComponent\" (out)=\"onExternalSQLResultOut($event);\" *ngIf=\"QueryEditorComponent != null\"></ng-template>\r\n</div>\r\n\r\n\r\n<div class=\"flex dbgetterfield\" *ngIf=\"showButtonReply\">\r\n    <button class=\"btn btn-primary\" (click)=\"onClickButtonReply()\"> {{field.Name}} <mat-icon>edit</mat-icon></button>\r\n</div>\r\n\r\n<div class=\"floatingtable draggable\" cdkDrag *ngIf=\"showTable\">\r\n    <div class=\"header\">\r\n        <div class=\"left\"><button class=\"btn btn-small btn-danger\" (click)=\"close()\">Chiudi finestra <mat-icon>close</mat-icon></button></div>\r\n        <div class=\"left\"><button class=\"btn btn-small btn-danger\" (click)=\"delete()\">Cancella valore <mat-icon>delete</mat-icon></button></div>\r\n        <div class=\"right\"><mat-icon>drag_indicator</mat-icon> Seleziona il valore da registrare. Clicca su questa barra per trascinare.</div>\r\n    </div>\r\n    <table class=\"table table-notforced\" *ngIf=\"field.DataGetter.DataGetterColumnForce == null\">\r\n        <tr><th *ngFor=\"let key of keys; let first = first\">\r\n            <span *ngIf=\"first\">{{key}}</span>\r\n            <span *ngIf=\"!first\">{{key.split(\"__\")[1]}}</span>\r\n        </th></tr>\r\n        <tr *ngFor=\"let row of data\" class=\"rows\">\r\n            <td *ngFor=\"let key of keys\" (click)=\"selectValueNotForced(row[key])\">\r\n                {{row[key] != null ? row[key].toString().substring(0,100) : ''}}<span *ngIf=\"row[key] != null && row[key].toString().length > 100\">...</span>\r\n            </td>\r\n        </tr>\r\n    </table>\r\n    <table class=\"table table-forced\" *ngIf=\"field.DataGetter.DataGetterColumnForce != null\">\r\n        <tr><th *ngFor=\"let key of keys; let first = first\">\r\n            <span *ngIf=\"first\">{{key}}</span>\r\n            <span *ngIf=\"!first\">{{key.split(\"__\")[1]}}</span>\r\n        </th></tr>\r\n        <tr *ngFor=\"let row of data\" class=\"rows\" (click)=\"selectValueForced(row)\">\r\n            <td *ngFor=\"let key of keys\">{{row[key] != null ? row[key].toString().substring(0,100) : ''}}<span *ngIf=\"row[key] != null && row[key].toString().length > 100\">...</span></td>\r\n        </tr>\r\n    </table>    \r\n</div>\r\n\r\n<span *ngIf=\"value != null\">{{value}}</span>"]}
|
|
159
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dbgetter.component.js","sourceRoot":"","sources":["../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/dbgetter/dbgetter.component.ts","../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/dbgetter/dbgetter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport { Form } from '@angular/forms';\r\nimport { DynamicLoaderDirectiveData, eventOut } from '../../../directives/dynamic-loader/dynamic-loader.directive';\r\nimport { BaseField } from '../../../models/baseField.model';\r\nimport { Record } from '../../../models/record.model';\r\nimport { EndPointConfiguration } from '../../../models/endPointConfiguration.model';\r\nimport { HttpClient } from '@angular/common/http';\r\n\r\n@Component({\r\n  selector: 'dbgetter',\r\n  templateUrl: './dbgetter.component.html',\r\n  styleUrls: ['./dbgetter.component.scss']\r\n})\r\nexport class DbgetterComponent {\r\n\r\n  @Input() field: BaseField;\r\n  @Input() record: Record;\r\n  @Input() inConfig: boolean = false;\r\n  @Input() DirectlyOpenTable: boolean = false;\r\n  @Input() QueryEditorComponent: DynamicLoaderDirectiveData = null; // L'intero componente query Editor\r\n  @Input() data: any = null; // Lo facciamo funzionare tipo EQP-TABLE\r\n\r\n  @Output() out: EventEmitter<eventOut> = new EventEmitter<eventOut>();\r\n  @Output() selectedValue: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  keys: Array<string> = null;\r\n  loaded: boolean = false;\r\n  value: any;\r\n\r\n  showButtonReply: boolean = false;\r\n  showTable: boolean = false;\r\n  showQE: boolean = true;\r\n\r\n  haveQuestions: boolean = false;\r\n\r\n  constructor(private httpClient: HttpClient) {}\r\n\r\n  ngOnInit(): void {\r\n\r\n    console.log(\"Welcome to DBGETTER Country\");\r\n    console.log(\"field\", this.field);\r\n    console.log(\"record\", this.record);\r\n    console.log(\"inConfig\", this.inConfig);\r\n    console.log(\"QueryEditorComponent\", this.QueryEditorComponent);\r\n\r\n\r\n    if (this.QueryEditorComponent != null){\r\n      this.QueryEditorComponent.inputParams.config.mode = QueryEditorModeEnum.RESULT;\r\n      this.QueryEditorComponent.inputParams.config.field = this.field;\r\n      this.QueryEditorComponent.inputParams.config.record = this.record;\r\n      this.QueryEditorComponent.inputParams.config.inConfig = this.inConfig;\r\n\r\n      if (this.field.DataGetter.DataGetterValue.openedFields.find(x => x.QueryPropertyValue == '?') != null){\r\n        \r\n        // Il modulo ha almeno una risposta con \"?\"\r\n        this.haveQuestions = true;\r\n\r\n      }\r\n    } else {\r\n\r\n      if (this.data == null){\r\n\r\n      this.httpClient.get('./assets/mockups/mockedFromQueryEditor_RESULT_MANY.txt', {responseType: 'text'})\r\n      .subscribe(mockedFromQueryEditor => {\r\n        this.data = JSON.parse(mockedFromQueryEditor);\r\n        this.data = JSON.parse(this.data.result);\r\n        this.processResult(this.data,[]);\r\n       });      \r\n\r\n      }\r\n\r\n    }\r\n\r\n  }\r\n\r\n  onExternalSQLResultOut(ev: eventOut){\r\n    console.log(\"La query del Query Editor è stata eseguita, ed ha restituito il seguente risultato: \",ev);\r\n    if (ev.Behaviours.indexOf(\"send-out\") != -1){ this.out.emit(ev); }\r\n\r\n    this.data = JSON.parse(ev.Params.result);\r\n    this.processResult(this.data,ev.Behaviours);\r\n\r\n  }\r\n\r\n  processResult(data: any, behaviours: Array<string> = []){\r\n    \r\n    if (data.length > 0){\r\n      this.keys = Object.keys(data[0]);\r\n      if (this.keys.length == 2 && data.length == 1){\r\n        // Se ho un solo occhietto selezionato e la query restituisce un solo valore, lo butto fuori automaticamente\r\n        this.showButtonReply = false;\r\n        this.showTable = false;\r\n        this.record[this.field.Name] = data[0][this.keys[1]];\r\n        this.selectedValue.emit([data[0][this.keys[1]],true]);\r\n      } else if (data.length == 1 && this.field.DataGetter.DataGetterColumnForce != null){\r\n        this.showButtonReply = false;\r\n        this.showTable = false;\r\n        this.record[this.field.Name] = data[0][this.field.DataGetter.DataGetterColumnForce.key];\r\n        this.selectedValue.emit([data[0][this.keys[1]],true]);\r\n      } else {\r\n\r\n        if (behaviours.indexOf(\"manage-question-in-dbgetter\") != -1){\r\n            this.showButtonReply = false;\r\n            this.showTable = true;\r\n        } else {\r\n\r\n          if (!this.DirectlyOpenTable){\r\n            this.showButtonReply = true;\r\n            this.showTable = false;\r\n          } else {\r\n            this.showButtonReply = false;\r\n            this.showTable = true;          \r\n          }\r\n\r\n        }\r\n\r\n      }\r\n    } else {\r\n      this.showQE = true;\r\n    }\r\n    \r\n  }\r\n\r\n  onClickButtonReply(){\r\n    this.showTable = true;\r\n    this.showQE = true;\r\n  }\r\n\r\n  selectValueNotForced(value){\r\n    if (value == null){ value = \"\"; }\r\n    \r\n    this.record[this.field.Name] = value;\r\n    this.showTable = false;\r\n    this.showQE = false;\r\n    this.showButtonReply = true;\r\n    this.selectedValue.emit([value,false]);\r\n  }\r\n\r\n  selectValueForced(row){\r\n    var valueToBeSet = row[this.field.DataGetter.DataGetterColumnForce.key];\r\n    if (valueToBeSet == null){ valueToBeSet = \"\"; }\r\n\r\n    this.record[this.field.Name] = valueToBeSet;\r\n    this.showTable = false;\r\n    this.showQE = false;\r\n    this.showButtonReply = true;\r\n    this.selectedValue.emit([valueToBeSet,false]);\r\n  }  \r\n\r\n  close(){\r\n    this.selectedValue.emit([\"****CLOSE****\",true]);\r\n    this.showTable = false;\r\n  }\r\n  \r\n  delete(){\r\n    this.selectedValue.emit([null,true]);\r\n    this.showTable = false;\r\n  }  \r\n}\r\n\r\n// O così o schiantato a mano\r\nexport enum QueryEditorModeEnum {\r\n  \"CONFIGURATOR\" = 1,\r\n  \"COMPOSER\" = 2,\r\n  \"RESULT\" = 3\r\n}","<div [hidden]=\"!showQE\">\r\n    <ng-template [appDynamicLoader] [data]=\"QueryEditorComponent\" (out)=\"onExternalSQLResultOut($event);\" *ngIf=\"QueryEditorComponent != null\"></ng-template>\r\n</div>\r\n\r\n\r\n<div class=\"flex dbgetterfield\" *ngIf=\"showButtonReply\">\r\n    <button class=\"btn btn-primary\" (click)=\"onClickButtonReply()\"> {{field.Name}} <mat-icon>edit</mat-icon></button>\r\n</div>\r\n\r\n\r\n\r\n<div class=\"floatingtable draggable\" cdkDrag *ngIf=\"showTable\">\r\n    <div class=\"header\">\r\n        <div class=\"left\"><button class=\"btn btn-small btn-danger\" (click)=\"close()\">Chiudi finestra <mat-icon>close</mat-icon></button></div>\r\n        <div class=\"left\"><button class=\"btn btn-small btn-danger\" (click)=\"delete()\">Cancella valore <mat-icon>delete</mat-icon></button></div>\r\n        <div class=\"right\"><mat-icon>drag_indicator</mat-icon> Seleziona il valore da registrare. Clicca su questa barra per trascinare.</div>\r\n    </div>\r\n    <table class=\"table table-notforced\" *ngIf=\"field.DataGetter.DataGetterColumnForce == null\">\r\n        <tr><th *ngFor=\"let key of keys; let first = first\">\r\n            <span *ngIf=\"first\">{{key}}</span>\r\n            <span *ngIf=\"!first\">{{key.split(\"__\")[1]}}</span>\r\n        </th></tr>\r\n        <tr *ngFor=\"let row of data\" class=\"rows\">\r\n            <td *ngFor=\"let key of keys\" (click)=\"selectValueNotForced(row[key])\">\r\n                {{row[key] != null ? row[key].toString().substring(0,100) : ''}}<span *ngIf=\"row[key] != null && row[key].toString().length > 100\">...</span>\r\n            </td>\r\n        </tr>\r\n    </table>\r\n    <table class=\"table table-forced\" *ngIf=\"field.DataGetter.DataGetterColumnForce != null\">\r\n        <tr><th *ngFor=\"let key of keys; let first = first\">\r\n            <span *ngIf=\"first\">{{key}}</span>\r\n            <span *ngIf=\"!first\">{{key.split(\"__\")[1]}}</span>\r\n        </th></tr>\r\n        <tr *ngFor=\"let row of data\" class=\"rows\" (click)=\"selectValueForced(row)\">\r\n            <td *ngFor=\"let key of keys\">{{row[key] != null ? row[key].toString().substring(0,100) : ''}}<span *ngIf=\"row[key] != null && row[key].toString().length > 100\">...</span></td>\r\n        </tr>\r\n    </table>    \r\n</div>\r\n\r\n<span *ngIf=\"value != null\">{{value}}</span>"]}
|
package/esm2020/lib/components/private/dynamic-module-field-fix/dynamic-module-field.component.mjs
CHANGED
|
@@ -148,10 +148,10 @@ export class DynamicModuleFieldFixComponent {
|
|
|
148
148
|
}
|
|
149
149
|
}
|
|
150
150
|
DynamicModuleFieldFixComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DynamicModuleFieldFixComponent, deps: [{ token: i1.MatDialog }], target: i0.ɵɵFactoryTarget.Component });
|
|
151
|
-
DynamicModuleFieldFixComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DynamicModuleFieldFixComponent, selector: "dynamic-module-field-fix", inputs: { endPointConfiguration: "endPointConfiguration", field: "field", form: "form", record: "record", inConfig: "inConfig", QueryEditorComponent: "QueryEditorComponent" }, outputs: { recordChange: "recordChange", out: "out" }, viewQueries: [{ propertyName: "dialogInnerFormRecord", first: true, predicate: ["dialogInnerFormRecord"], descendants: true, static: true }, { propertyName: "fieldTemplate", predicate: ["fieldTemplate"], descendants: true }, { propertyName: "listInnerFormRecords", predicate: ["listInnerFormRecords"], descendants: true }], ngImport: i0, template: "<div *ngIf=\"field.DataGetter.DataGetterType == DataGetterTypeEnum['Manuale'] || field.DataGetter.DataGetterType == DataGetterTypeEnum['Formula']\"> \r\n <ng-container [ngTemplateOutlet]=\"fieldsTemplate\" [ngTemplateOutletContext]=\"{ field: field, record: record }\"></ng-container>\r\n</div>\r\n\r\n<div *ngIf=\"field.DataGetter.DataGetterType == DataGetterTypeEnum['Da database']\"> \r\n \r\n <div class=\"row\">\r\n <div class=\"col-
|
|
151
|
+
DynamicModuleFieldFixComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DynamicModuleFieldFixComponent, selector: "dynamic-module-field-fix", inputs: { endPointConfiguration: "endPointConfiguration", field: "field", form: "form", record: "record", inConfig: "inConfig", QueryEditorComponent: "QueryEditorComponent" }, outputs: { recordChange: "recordChange", out: "out" }, viewQueries: [{ propertyName: "dialogInnerFormRecord", first: true, predicate: ["dialogInnerFormRecord"], descendants: true, static: true }, { propertyName: "fieldTemplate", predicate: ["fieldTemplate"], descendants: true }, { propertyName: "listInnerFormRecords", predicate: ["listInnerFormRecords"], descendants: true }], ngImport: i0, template: "<div *ngIf=\"field.DataGetter.DataGetterType == DataGetterTypeEnum['Manuale'] || field.DataGetter.DataGetterType == DataGetterTypeEnum['Formula']\"> \r\n <ng-container [ngTemplateOutlet]=\"fieldsTemplate\" [ngTemplateOutletContext]=\"{ field: field, record: record }\"></ng-container>\r\n</div>\r\n\r\n<div *ngIf=\"field.DataGetter.DataGetterType == DataGetterTypeEnum['Da database']\"> \r\n \r\n <div class=\"row\">\r\n <div class=\"col-12\">\r\n <ng-container [ngTemplateOutlet]=\"fieldsTemplate\" [ngTemplateOutletContext]=\"{ field: field, record: record }\" *ngIf=\"DBGetterValue != null || record[field.Name] != null\"></ng-container>\r\n </div>\r\n <div class=\"col-12 mt-2\">\r\n <dbgetter class=\"flex\" [(record)]=\"record\" [field]=\"field\" [DirectlyOpenTable]=\"directlyOpenTable\" [QueryEditorComponent]=\"QueryEditorComponent\" [inConfig]=\"inConfig\" (out)=\"onExternalComponentOut($event)\" (selectedValue)=\"onSelectedValue($event)\"></dbgetter>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<ng-template #fieldsTemplate>\r\n\r\n <text-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Campo di testo']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </text-field-template>\r\n\r\n <textarea-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Area di testo']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </textarea-field-template>\r\n\r\n <boolean-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Booleano']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </boolean-field-template>\r\n\r\n <date-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Data e/o ora']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </date-field-template>\r\n\r\n <numeric-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Campo numerico']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </numeric-field-template>\r\n\r\n <list-value-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Elenco generico']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </list-value-field-template>\r\n\r\n <attachment-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Allegato']\"\r\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </attachment-field-template>\r\n\r\n <image-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Immagine']\" [endPointConfiguration]=\"endPointConfiguration\" [inConfig]=\"inConfig\"\r\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\" (imageDraw)=\"onImageDraw($event)\">\r\n </image-field-template> \r\n\r\n <image-with-markers-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Immagine con markers']\" [endPointConfiguration]=\"endPointConfiguration\" [inConfig]=\"inConfig\"\r\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\" (imageMark)=\"onImageMark($event)\">\r\n </image-with-markers-field-template> \r\n\r\n <image-field-selector-template #imageSelectorTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Elenco immagini']\"\r\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\"\r\n >\r\n </image-field-selector-template>\r\n\r\n <list-form-record #listInnerFormRecords *ngIf=\"field.FieldType == FieldTypeEnum['Form di dettaglio']\"\r\n [form]=\"getInnerFormFromField(field)\" [configurations]=\"configList\"\r\n (onAddViewEditRecord)=\"onAddViewEditInnerFormRecord($event, field)\">\r\n </list-form-record>\r\n\r\n <label-field-template #labelTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Etichetta']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </label-field-template>\r\n\r\n</ng-template>", styles: [".dbgetterfield{align-items:center;justify-content:flex-start;height:80px}.dbgetterfield span{margin-right:15px}\n"], dependencies: [{ kind: "directive", type: i2.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.TextFieldTemplateComponent, selector: "text-field-template", inputs: ["field", "record"], outputs: ["recordChange"] }, { kind: "component", type: i5.BooleanFieldTemplateComponent, selector: "boolean-field-template", inputs: ["field", "record"], outputs: ["recordChange"] }, { kind: "component", type: i6.DateFieldTemplateComponent, selector: "date-field-template", inputs: ["field", "record"], outputs: ["recordChange"] }, { kind: "component", type: i7.TextareaFieldTemplateComponent, selector: "textarea-field-template", inputs: ["field", "record"], outputs: ["recordChange"] }, { kind: "component", type: i8.NumericFieldTemplateComponent, selector: "numeric-field-template", inputs: ["field", "record"], outputs: ["recordChange"] }, { kind: "component", type: i9.ListValueFieldTemplateComponent, selector: "list-value-field-template", inputs: ["field", "record"], outputs: ["recordChange"] }, { kind: "component", type: i10.AttachmentFieldTemplateComponent, selector: "attachment-field-template", inputs: ["onlyImages", "field", "record"], outputs: ["recordChange", "onAttachmentsChange"] }, { kind: "component", type: i11.ImageFieldTemplateComponent, selector: "image-field-template", inputs: ["endPointConfiguration", "record", "field", "inConfig"], outputs: ["recordChange", "imageDraw"] }, { kind: "component", type: i12.ListFormRecordComponent, selector: "list-form-record", inputs: ["configurations", "endPointConfiguration", "formID", "form", "externalButtons"], outputs: ["onViewRecord", "onAddViewEditRecord", "onDeleteRecord", "onAfterDeleteRecord"] }, { kind: "component", type: i13.ImageFieldSelectorTemplateComponent, selector: "image-field-selector-template", inputs: ["record", "field"], outputs: ["recordChange"] }, { kind: "component", type: i14.LabelFieldTemplateComponent, selector: "label-field-template", inputs: ["field", "record"], outputs: ["recordChange"] }, { kind: "component", type: i15.ImageWithMarkersFieldTemplateComponent, selector: "image-with-markers-field-template", inputs: ["endPointConfiguration", "record", "field", "inConfig"], outputs: ["recordChange", "imageMark"] }, { kind: "component", type: i16.DbgetterComponent, selector: "dbgetter", inputs: ["field", "record", "inConfig", "DirectlyOpenTable", "QueryEditorComponent", "data"], outputs: ["out", "selectedValue"] }] });
|
|
152
152
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DynamicModuleFieldFixComponent, decorators: [{
|
|
153
153
|
type: Component,
|
|
154
|
-
args: [{ selector: 'dynamic-module-field-fix', template: "<div *ngIf=\"field.DataGetter.DataGetterType == DataGetterTypeEnum['Manuale'] || field.DataGetter.DataGetterType == DataGetterTypeEnum['Formula']\"> \r\n <ng-container [ngTemplateOutlet]=\"fieldsTemplate\" [ngTemplateOutletContext]=\"{ field: field, record: record }\"></ng-container>\r\n</div>\r\n\r\n<div *ngIf=\"field.DataGetter.DataGetterType == DataGetterTypeEnum['Da database']\"> \r\n \r\n <div class=\"row\">\r\n <div class=\"col-
|
|
154
|
+
args: [{ selector: 'dynamic-module-field-fix', template: "<div *ngIf=\"field.DataGetter.DataGetterType == DataGetterTypeEnum['Manuale'] || field.DataGetter.DataGetterType == DataGetterTypeEnum['Formula']\"> \r\n <ng-container [ngTemplateOutlet]=\"fieldsTemplate\" [ngTemplateOutletContext]=\"{ field: field, record: record }\"></ng-container>\r\n</div>\r\n\r\n<div *ngIf=\"field.DataGetter.DataGetterType == DataGetterTypeEnum['Da database']\"> \r\n \r\n <div class=\"row\">\r\n <div class=\"col-12\">\r\n <ng-container [ngTemplateOutlet]=\"fieldsTemplate\" [ngTemplateOutletContext]=\"{ field: field, record: record }\" *ngIf=\"DBGetterValue != null || record[field.Name] != null\"></ng-container>\r\n </div>\r\n <div class=\"col-12 mt-2\">\r\n <dbgetter class=\"flex\" [(record)]=\"record\" [field]=\"field\" [DirectlyOpenTable]=\"directlyOpenTable\" [QueryEditorComponent]=\"QueryEditorComponent\" [inConfig]=\"inConfig\" (out)=\"onExternalComponentOut($event)\" (selectedValue)=\"onSelectedValue($event)\"></dbgetter>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<ng-template #fieldsTemplate>\r\n\r\n <text-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Campo di testo']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </text-field-template>\r\n\r\n <textarea-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Area di testo']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </textarea-field-template>\r\n\r\n <boolean-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Booleano']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </boolean-field-template>\r\n\r\n <date-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Data e/o ora']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </date-field-template>\r\n\r\n <numeric-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Campo numerico']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </numeric-field-template>\r\n\r\n <list-value-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Elenco generico']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </list-value-field-template>\r\n\r\n <attachment-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Allegato']\"\r\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </attachment-field-template>\r\n\r\n <image-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Immagine']\" [endPointConfiguration]=\"endPointConfiguration\" [inConfig]=\"inConfig\"\r\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\" (imageDraw)=\"onImageDraw($event)\">\r\n </image-field-template> \r\n\r\n <image-with-markers-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Immagine con markers']\" [endPointConfiguration]=\"endPointConfiguration\" [inConfig]=\"inConfig\"\r\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\" (imageMark)=\"onImageMark($event)\">\r\n </image-with-markers-field-template> \r\n\r\n <image-field-selector-template #imageSelectorTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Elenco immagini']\"\r\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\"\r\n >\r\n </image-field-selector-template>\r\n\r\n <list-form-record #listInnerFormRecords *ngIf=\"field.FieldType == FieldTypeEnum['Form di dettaglio']\"\r\n [form]=\"getInnerFormFromField(field)\" [configurations]=\"configList\"\r\n (onAddViewEditRecord)=\"onAddViewEditInnerFormRecord($event, field)\">\r\n </list-form-record>\r\n\r\n <label-field-template #labelTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Etichetta']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </label-field-template>\r\n\r\n</ng-template>", styles: [".dbgetterfield{align-items:center;justify-content:flex-start;height:80px}.dbgetterfield span{margin-right:15px}\n"] }]
|
|
155
155
|
}], ctorParameters: function () { return [{ type: i1.MatDialog }]; }, propDecorators: { endPointConfiguration: [{
|
|
156
156
|
type: Input
|
|
157
157
|
}], field: [{
|
|
@@ -178,4 +178,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
178
178
|
type: ViewChildren,
|
|
179
179
|
args: ['listInnerFormRecords']
|
|
180
180
|
}] } });
|
|
181
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-module-field.component.js","sourceRoot":"","sources":["../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/dynamic-module-field-fix/dynamic-module-field.component.ts","../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/dynamic-module-field-fix/dynamic-module-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, QueryList, TemplateRef, ViewChild, ViewChildren } from '@angular/core';\r\nimport { MatDialog, MatDialogRef } from '@angular/material/dialog';\r\nimport { IBaseFieldComponent } from '../../../interfaces/iBaseFieldComponent.interface';\r\nimport { BaseField, FieldTypeEnum, DataGetterTypeEnum } from '../../../models/baseField.model';\r\nimport { DynamicModuleListConfig } from '../../../models/dynamicModuleListConfig.model';\r\nimport { Form } from '../../../models/form.model';\r\nimport { DynamicModuleListFormRecordActionsDefault } from '../../../models/dynamicModuleListFormRecordActionsDefault';\r\nimport { Record } from '../../../models/record.model';\r\nimport { ListFormRecordComponent } from '../form-records/list-form-record/list-form-record.component';\r\nimport { EndPointConfiguration } from '../../../models/endPointConfiguration.model';\r\nimport { DynAttachment } from '../../../models/dynAttachment';\r\nimport { DynamicLoaderDirectiveData, eventOut } from '../../../directives/dynamic-loader/dynamic-loader.directive';\r\n\r\n@Component({\r\n  selector: 'dynamic-module-field-fix',\r\n  templateUrl: './dynamic-module-field.component.html',\r\n  styleUrls: ['./dynamic-module-field.component.scss']\r\n})\r\nexport class DynamicModuleFieldFixComponent implements OnInit, IBaseFieldComponent {\r\n\r\n  @Input() endPointConfiguration: EndPointConfiguration;\r\n  @Input() field: BaseField;\r\n  @Input() form: Form;\r\n  @Input() record: Record;\r\n  @Input() inConfig: boolean = false;\r\n  @Input() QueryEditorComponent: DynamicLoaderDirectiveData; // L'intero componente query Editor\r\n\r\n  @Output() recordChange: EventEmitter<Record> = new EventEmitter<Record>();\r\n  @Output() out: EventEmitter<eventOut> = new EventEmitter<eventOut>();\r\n\r\n\r\n  configList: DynamicModuleListConfig = new DynamicModuleListConfig();\r\n  FieldTypeEnum = FieldTypeEnum;\r\n  DataGetterTypeEnum = DataGetterTypeEnum;\r\n  DBGetterValue: any = null;\r\n  DBGetterLoaded: boolean = false;\r\n  DBGetterExact: boolean = false;\r\n  DBGetterHaveQuestions: boolean = false;\r\n  directlyOpenTable: boolean = false;\r\n\r\n  //#region Proprietà per aggiungere/modificare i record di una form di dettaglio\r\n  selectedInnerForm: Form;\r\n  selectedInnerFormRecord: Record;\r\n  indexInnerFormRecord: number;\r\n  onlyViewInnerFormRecord: boolean = false;\r\n  dialogInnerFormRecordRef: MatDialogRef<TemplateRef<any>>;\r\n  @ViewChild('dialogInnerFormRecord', { static: true }) dialogInnerFormRecord: TemplateRef<any>;\r\n  //#endregion\r\n\r\n  @ViewChildren(\"fieldTemplate\") fieldTemplate: QueryList<DynamicModuleFieldFixComponent>;\r\n  @ViewChildren('listInnerFormRecords') listInnerFormRecords: QueryList<ListFormRecordComponent>;\r\n\r\n  constructor(\r\n    private dialog: MatDialog\r\n  ) { }\r\n\r\n\r\n  updateField(): void {\r\n    if (this.fieldTemplate && this.fieldTemplate.length > 0) {\r\n      this.fieldTemplate.forEach(f => f.updateField());\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n\r\n    console.log(\"dynamic-module-field\",this.field);\r\n\r\n    this.configList.values = this.record[this.field.Name]\r\n    this.configList.showTitle = true;\r\n    this.configList.defaultListActions = new DynamicModuleListFormRecordActionsDefault()\r\n  }\r\n\r\n  /**\r\n   * Metodo invocato al cambio del valore di ogni proprietà dell'oggetto record.\r\n   * Serve ad aggiornare il valore di tutti i campi che hanno una formula.\r\n   */\r\n  onRecordChange() {\r\n    this.recordChange.emit(this.record);\r\n  }\r\n\r\n  /**\r\n   * Metodo per recuperare una InnerForm a partire dal Field che la rappresenta.\r\n   * @param field Campo a partire dal quale si vuole recuperare la InnerForm.\r\n   * @returns Restituisce un oggetto di tipo Form.\r\n   */\r\n  getInnerFormFromField(field: BaseField): Form {\r\n    if (this.form.InnerForms && this.form.InnerForms.find(f => f.Name == field.Label)) {\r\n      return this.form.InnerForms.find(f => f.Name == field.Label);\r\n    } else {\r\n      return null;\r\n    }\r\n  }\r\n\r\n  /**\r\n * Metodo per aprire un dialog in cui aggiungere/modificare/visualizzare un record appartenente\r\n * a una form di dettaglio.\r\n * @param record Evento di output del componente list-form-record, contiene il record selezionato e un booleno che indica \r\n * se l'utente vuole modificare o visualizzare l'elemento selezionato.\r\n * @param innerForm Contiene la Form di dettaglio dalla quale è stato richiesto il record.\r\n */\r\n  onAddViewEditInnerFormRecord(record: { record: Record, onlyView: boolean }, field: BaseField) {\r\n    this.selectedInnerForm = this.getInnerFormFromField(field);\r\n    if (record == null) {\r\n      this.selectedInnerFormRecord = new Record();\r\n      this.indexInnerFormRecord = null;\r\n      this.onlyViewInnerFormRecord = false;\r\n    } else {\r\n      this.selectedInnerFormRecord = JSON.parse(JSON.stringify(record.record));\r\n      this.indexInnerFormRecord = this.record[field.Name].indexOf(record);\r\n      this.onlyViewInnerFormRecord = record.onlyView;\r\n    }\r\n\r\n    this.dialogInnerFormRecordRef = this.dialog.open(this.dialogInnerFormRecord, {\r\n      disableClose: true,\r\n      hasBackdrop: true,\r\n      width: '75%'\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Metodo invocato al salvataggio o alla chiusura del dialog di aggiunta/modifica/visualizzazione\r\n   * di un record di una form di dettaglio.\r\n   * @param record Oggetto restituito dal componente add-form-field (questo qui) contenente il Record \r\n   * aggiornato dall'utente. Se null allora l'utente non ha modificato nulla e ha chiuso il dialog.\r\n   */\r\n  onSaveInnerFormRecord(record: Record) {\r\n    if (record != null) {\r\n      const arrayName: string = this.selectedInnerForm.Name.split(' ').join('_');\r\n      if (this.indexInnerFormRecord != null && this.indexInnerFormRecord >= 0) {\r\n        this.record[arrayName][this.indexInnerFormRecord] = record;\r\n      } else {\r\n        if (!this.record[arrayName]) {\r\n          this.record[arrayName] = [];\r\n        }\r\n        this.record[arrayName].push(record);\r\n      }\r\n    }\r\n    this.dialogInnerFormRecordRef.close();\r\n\r\n    // Ricarico la tabella dei record per visualizzare le modifiche fatte dall'utente.\r\n    if (this.listInnerFormRecords && this.listInnerFormRecords.length > 0) {\r\n      this.listInnerFormRecords.forEach(list => {\r\n        if (list && list.tableRecords) {\r\n          list.tableRecords.reloadDatatable();\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  // Passo l'immagine disegnata al livello superiore\r\n  onImageDraw(event: DynAttachment){\r\n    this.record[this.field.Name] = event;\r\n    this.recordChange.emit(this.record);\r\n  }\r\n\r\n    // Passo l'immagine disegnata al livello superiore\r\n    onImageMark(event: DynAttachment){\r\n      this.record[this.field.Name] = event;\r\n      this.recordChange.emit(this.record);\r\n    }\r\n\r\n    onExternalComponentOut(ev: eventOut){\r\n      this.out.emit(ev);\r\n    }\r\n\r\n    onSelectedValue(value: any){\r\n      \r\n      this.DBGetterLoaded = false;\r\n      if (value[0] == \"****CLOSE****\"){ return; }\r\n\r\n      this.record[this.field.Name] = value[0];\r\n      this.DBGetterValue = value[0];\r\n      this.DBGetterExact = value[1];\r\n      if (this.field.DataGetter.DataGetterValue.openedFields.find(x => x.QueryPropertyValue == '?') != null){ this.DBGetterHaveQuestions = true; }\r\n\r\n    }\r\n    \r\n}\r\n","<div *ngIf=\"field.DataGetter.DataGetterType == DataGetterTypeEnum['Manuale'] || field.DataGetter.DataGetterType == DataGetterTypeEnum['Formula']\"> \r\n    <ng-container [ngTemplateOutlet]=\"fieldsTemplate\" [ngTemplateOutletContext]=\"{ field: field, record: record }\"></ng-container>\r\n</div>\r\n\r\n<div *ngIf=\"field.DataGetter.DataGetterType == DataGetterTypeEnum['Da database']\"> \r\n    \r\n    <div class=\"row\">\r\n        <div class=\"col-3\">\r\n            <dbgetter class=\"flex\" [(record)]=\"record\" [field]=\"field\" [DirectlyOpenTable]=\"directlyOpenTable\" [QueryEditorComponent]=\"QueryEditorComponent\" [inConfig]=\"inConfig\" (out)=\"onExternalComponentOut($event)\" (selectedValue)=\"onSelectedValue($event)\"></dbgetter>\r\n        </div>\r\n        <div class=\"col-9\">\r\n            <ng-container [ngTemplateOutlet]=\"fieldsTemplate\" [ngTemplateOutletContext]=\"{ field: field, record: record }\" *ngIf=\"DBGetterValue != null || record[field.Name] != null\"></ng-container>\r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n<ng-template #fieldsTemplate>\r\n\r\n    <text-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Campo di testo']\"\r\n    [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n    </text-field-template>\r\n\r\n    <textarea-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Area di testo']\"\r\n        [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n    </textarea-field-template>\r\n\r\n    <boolean-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Booleano']\"\r\n        [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n    </boolean-field-template>\r\n\r\n    <date-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Data e/o ora']\"\r\n        [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n    </date-field-template>\r\n\r\n    <numeric-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Campo numerico']\"\r\n        [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n    </numeric-field-template>\r\n\r\n    <list-value-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Elenco generico']\"\r\n        [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n    </list-value-field-template>\r\n\r\n    <attachment-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Allegato']\"\r\n        [matTooltip]=\"field.Description\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n    </attachment-field-template>\r\n\r\n    <image-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Immagine']\" [endPointConfiguration]=\"endPointConfiguration\" [inConfig]=\"inConfig\"\r\n        [matTooltip]=\"field.Description\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\" (imageDraw)=\"onImageDraw($event)\">\r\n    </image-field-template> \r\n\r\n    <image-with-markers-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Immagine con markers']\" [endPointConfiguration]=\"endPointConfiguration\" [inConfig]=\"inConfig\"\r\n        [matTooltip]=\"field.Description\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\" (imageMark)=\"onImageMark($event)\">\r\n    </image-with-markers-field-template> \r\n\r\n    <image-field-selector-template #imageSelectorTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Elenco immagini']\"\r\n    [matTooltip]=\"field.Description\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\"\r\n    >\r\n    </image-field-selector-template>\r\n\r\n    <list-form-record #listInnerFormRecords *ngIf=\"field.FieldType == FieldTypeEnum['Form di dettaglio']\"\r\n        [form]=\"getInnerFormFromField(field)\" [configurations]=\"configList\"\r\n        (onAddViewEditRecord)=\"onAddViewEditInnerFormRecord($event, field)\">\r\n    </list-form-record>\r\n\r\n    <label-field-template #labelTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Etichetta']\"\r\n        [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n    </label-field-template>\r\n\r\n</ng-template>"]}
|
|
181
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-module-field.component.js","sourceRoot":"","sources":["../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/dynamic-module-field-fix/dynamic-module-field.component.ts","../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/dynamic-module-field-fix/dynamic-module-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, QueryList, TemplateRef, ViewChild, ViewChildren } from '@angular/core';\r\nimport { MatDialog, MatDialogRef } from '@angular/material/dialog';\r\nimport { IBaseFieldComponent } from '../../../interfaces/iBaseFieldComponent.interface';\r\nimport { BaseField, FieldTypeEnum, DataGetterTypeEnum } from '../../../models/baseField.model';\r\nimport { DynamicModuleListConfig } from '../../../models/dynamicModuleListConfig.model';\r\nimport { Form } from '../../../models/form.model';\r\nimport { DynamicModuleListFormRecordActionsDefault } from '../../../models/dynamicModuleListFormRecordActionsDefault';\r\nimport { Record } from '../../../models/record.model';\r\nimport { ListFormRecordComponent } from '../form-records/list-form-record/list-form-record.component';\r\nimport { EndPointConfiguration } from '../../../models/endPointConfiguration.model';\r\nimport { DynAttachment } from '../../../models/dynAttachment';\r\nimport { DynamicLoaderDirectiveData, eventOut } from '../../../directives/dynamic-loader/dynamic-loader.directive';\r\n\r\n@Component({\r\n  selector: 'dynamic-module-field-fix',\r\n  templateUrl: './dynamic-module-field.component.html',\r\n  styleUrls: ['./dynamic-module-field.component.scss']\r\n})\r\nexport class DynamicModuleFieldFixComponent implements OnInit, IBaseFieldComponent {\r\n\r\n  @Input() endPointConfiguration: EndPointConfiguration;\r\n  @Input() field: BaseField;\r\n  @Input() form: Form;\r\n  @Input() record: Record;\r\n  @Input() inConfig: boolean = false;\r\n  @Input() QueryEditorComponent: DynamicLoaderDirectiveData; // L'intero componente query Editor\r\n\r\n  @Output() recordChange: EventEmitter<Record> = new EventEmitter<Record>();\r\n  @Output() out: EventEmitter<eventOut> = new EventEmitter<eventOut>();\r\n\r\n\r\n  configList: DynamicModuleListConfig = new DynamicModuleListConfig();\r\n  FieldTypeEnum = FieldTypeEnum;\r\n  DataGetterTypeEnum = DataGetterTypeEnum;\r\n  DBGetterValue: any = null;\r\n  DBGetterLoaded: boolean = false;\r\n  DBGetterExact: boolean = false;\r\n  DBGetterHaveQuestions: boolean = false;\r\n  directlyOpenTable: boolean = false;\r\n\r\n  //#region Proprietà per aggiungere/modificare i record di una form di dettaglio\r\n  selectedInnerForm: Form;\r\n  selectedInnerFormRecord: Record;\r\n  indexInnerFormRecord: number;\r\n  onlyViewInnerFormRecord: boolean = false;\r\n  dialogInnerFormRecordRef: MatDialogRef<TemplateRef<any>>;\r\n  @ViewChild('dialogInnerFormRecord', { static: true }) dialogInnerFormRecord: TemplateRef<any>;\r\n  //#endregion\r\n\r\n  @ViewChildren(\"fieldTemplate\") fieldTemplate: QueryList<DynamicModuleFieldFixComponent>;\r\n  @ViewChildren('listInnerFormRecords') listInnerFormRecords: QueryList<ListFormRecordComponent>;\r\n\r\n  constructor(\r\n    private dialog: MatDialog\r\n  ) { }\r\n\r\n\r\n  updateField(): void {\r\n    if (this.fieldTemplate && this.fieldTemplate.length > 0) {\r\n      this.fieldTemplate.forEach(f => f.updateField());\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n\r\n    console.log(\"dynamic-module-field\",this.field);\r\n\r\n    this.configList.values = this.record[this.field.Name]\r\n    this.configList.showTitle = true;\r\n    this.configList.defaultListActions = new DynamicModuleListFormRecordActionsDefault()\r\n  }\r\n\r\n  /**\r\n   * Metodo invocato al cambio del valore di ogni proprietà dell'oggetto record.\r\n   * Serve ad aggiornare il valore di tutti i campi che hanno una formula.\r\n   */\r\n  onRecordChange() {\r\n    this.recordChange.emit(this.record);\r\n  }\r\n\r\n  /**\r\n   * Metodo per recuperare una InnerForm a partire dal Field che la rappresenta.\r\n   * @param field Campo a partire dal quale si vuole recuperare la InnerForm.\r\n   * @returns Restituisce un oggetto di tipo Form.\r\n   */\r\n  getInnerFormFromField(field: BaseField): Form {\r\n    if (this.form.InnerForms && this.form.InnerForms.find(f => f.Name == field.Label)) {\r\n      return this.form.InnerForms.find(f => f.Name == field.Label);\r\n    } else {\r\n      return null;\r\n    }\r\n  }\r\n\r\n  /**\r\n * Metodo per aprire un dialog in cui aggiungere/modificare/visualizzare un record appartenente\r\n * a una form di dettaglio.\r\n * @param record Evento di output del componente list-form-record, contiene il record selezionato e un booleno che indica \r\n * se l'utente vuole modificare o visualizzare l'elemento selezionato.\r\n * @param innerForm Contiene la Form di dettaglio dalla quale è stato richiesto il record.\r\n */\r\n  onAddViewEditInnerFormRecord(record: { record: Record, onlyView: boolean }, field: BaseField) {\r\n    this.selectedInnerForm = this.getInnerFormFromField(field);\r\n    if (record == null) {\r\n      this.selectedInnerFormRecord = new Record();\r\n      this.indexInnerFormRecord = null;\r\n      this.onlyViewInnerFormRecord = false;\r\n    } else {\r\n      this.selectedInnerFormRecord = JSON.parse(JSON.stringify(record.record));\r\n      this.indexInnerFormRecord = this.record[field.Name].indexOf(record);\r\n      this.onlyViewInnerFormRecord = record.onlyView;\r\n    }\r\n\r\n    this.dialogInnerFormRecordRef = this.dialog.open(this.dialogInnerFormRecord, {\r\n      disableClose: true,\r\n      hasBackdrop: true,\r\n      width: '75%'\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Metodo invocato al salvataggio o alla chiusura del dialog di aggiunta/modifica/visualizzazione\r\n   * di un record di una form di dettaglio.\r\n   * @param record Oggetto restituito dal componente add-form-field (questo qui) contenente il Record \r\n   * aggiornato dall'utente. Se null allora l'utente non ha modificato nulla e ha chiuso il dialog.\r\n   */\r\n  onSaveInnerFormRecord(record: Record) {\r\n    if (record != null) {\r\n      const arrayName: string = this.selectedInnerForm.Name.split(' ').join('_');\r\n      if (this.indexInnerFormRecord != null && this.indexInnerFormRecord >= 0) {\r\n        this.record[arrayName][this.indexInnerFormRecord] = record;\r\n      } else {\r\n        if (!this.record[arrayName]) {\r\n          this.record[arrayName] = [];\r\n        }\r\n        this.record[arrayName].push(record);\r\n      }\r\n    }\r\n    this.dialogInnerFormRecordRef.close();\r\n\r\n    // Ricarico la tabella dei record per visualizzare le modifiche fatte dall'utente.\r\n    if (this.listInnerFormRecords && this.listInnerFormRecords.length > 0) {\r\n      this.listInnerFormRecords.forEach(list => {\r\n        if (list && list.tableRecords) {\r\n          list.tableRecords.reloadDatatable();\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  // Passo l'immagine disegnata al livello superiore\r\n  onImageDraw(event: DynAttachment){\r\n    this.record[this.field.Name] = event;\r\n    this.recordChange.emit(this.record);\r\n  }\r\n\r\n    // Passo l'immagine disegnata al livello superiore\r\n    onImageMark(event: DynAttachment){\r\n      this.record[this.field.Name] = event;\r\n      this.recordChange.emit(this.record);\r\n    }\r\n\r\n    onExternalComponentOut(ev: eventOut){\r\n      this.out.emit(ev);\r\n    }\r\n\r\n    onSelectedValue(value: any){\r\n      \r\n      this.DBGetterLoaded = false;\r\n      if (value[0] == \"****CLOSE****\"){ return; }\r\n\r\n      this.record[this.field.Name] = value[0];\r\n      this.DBGetterValue = value[0];\r\n      this.DBGetterExact = value[1];\r\n      if (this.field.DataGetter.DataGetterValue.openedFields.find(x => x.QueryPropertyValue == '?') != null){ this.DBGetterHaveQuestions = true; }\r\n\r\n    }\r\n    \r\n}\r\n","<div *ngIf=\"field.DataGetter.DataGetterType == DataGetterTypeEnum['Manuale'] || field.DataGetter.DataGetterType == DataGetterTypeEnum['Formula']\"> \r\n    <ng-container [ngTemplateOutlet]=\"fieldsTemplate\" [ngTemplateOutletContext]=\"{ field: field, record: record }\"></ng-container>\r\n</div>\r\n\r\n<div *ngIf=\"field.DataGetter.DataGetterType == DataGetterTypeEnum['Da database']\"> \r\n    \r\n    <div class=\"row\">\r\n        <div class=\"col-12\">\r\n            <ng-container [ngTemplateOutlet]=\"fieldsTemplate\" [ngTemplateOutletContext]=\"{ field: field, record: record }\" *ngIf=\"DBGetterValue != null || record[field.Name] != null\"></ng-container>\r\n        </div>\r\n        <div class=\"col-12 mt-2\">\r\n            <dbgetter class=\"flex\" [(record)]=\"record\" [field]=\"field\" [DirectlyOpenTable]=\"directlyOpenTable\" [QueryEditorComponent]=\"QueryEditorComponent\" [inConfig]=\"inConfig\" (out)=\"onExternalComponentOut($event)\" (selectedValue)=\"onSelectedValue($event)\"></dbgetter>\r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n<ng-template #fieldsTemplate>\r\n\r\n    <text-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Campo di testo']\"\r\n    [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n    </text-field-template>\r\n\r\n    <textarea-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Area di testo']\"\r\n        [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n    </textarea-field-template>\r\n\r\n    <boolean-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Booleano']\"\r\n        [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n    </boolean-field-template>\r\n\r\n    <date-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Data e/o ora']\"\r\n        [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n    </date-field-template>\r\n\r\n    <numeric-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Campo numerico']\"\r\n        [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n    </numeric-field-template>\r\n\r\n    <list-value-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Elenco generico']\"\r\n        [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n    </list-value-field-template>\r\n\r\n    <attachment-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Allegato']\"\r\n        [matTooltip]=\"field.Description\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n    </attachment-field-template>\r\n\r\n    <image-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Immagine']\" [endPointConfiguration]=\"endPointConfiguration\" [inConfig]=\"inConfig\"\r\n        [matTooltip]=\"field.Description\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\" (imageDraw)=\"onImageDraw($event)\">\r\n    </image-field-template> \r\n\r\n    <image-with-markers-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Immagine con markers']\" [endPointConfiguration]=\"endPointConfiguration\" [inConfig]=\"inConfig\"\r\n        [matTooltip]=\"field.Description\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\" (imageMark)=\"onImageMark($event)\">\r\n    </image-with-markers-field-template> \r\n\r\n    <image-field-selector-template #imageSelectorTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Elenco immagini']\"\r\n    [matTooltip]=\"field.Description\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\"\r\n    >\r\n    </image-field-selector-template>\r\n\r\n    <list-form-record #listInnerFormRecords *ngIf=\"field.FieldType == FieldTypeEnum['Form di dettaglio']\"\r\n        [form]=\"getInnerFormFromField(field)\" [configurations]=\"configList\"\r\n        (onAddViewEditRecord)=\"onAddViewEditInnerFormRecord($event, field)\">\r\n    </list-form-record>\r\n\r\n    <label-field-template #labelTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Etichetta']\"\r\n        [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n    </label-field-template>\r\n\r\n</ng-template>"]}
|
|
@@ -81,10 +81,10 @@ export class DateFieldTemplateComponent {
|
|
|
81
81
|
}
|
|
82
82
|
}
|
|
83
83
|
DateFieldTemplateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DateFieldTemplateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
84
|
-
DateFieldTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DateFieldTemplateComponent, selector: "date-field-template", inputs: { field: "field", record: "record" }, outputs: { recordChange: "recordChange" }, usesOnChanges: true, ngImport: i0, template: "<tmw-datetimepicker [placeholder]=\"field.Description\" [pickerMode]=\"mode\"\r\n [formGroupInput]=\"field.FormFormGroup\" [formControlNameInput]=\"field.Name\"\r\n [minDate]=\"field.MinDate ? field.MinDate : null\" [maxDate]=\"field.MaxDate ? field.MaxDate : null\"\r\n [disabled]=\"field.FormFormGroup.disabled\" [(ngModelInput)]=\"record[field.Name]\"\r\n (ngModelInputChange)=\"onRecordValueChange()\" [outputFormat]=\"outputFormat\">\r\n</tmw-datetimepicker>", styles: [""], dependencies: [{ kind: "component", type: i1.TmwDateTimePickerComponent, selector: "tmw-datetimepicker", inputs: ["debugMode", "ngModelInput", "formGroupInput", "formControlNameInput", "pickerMode", "timeType", "label", "placeholder", "hint", "minDate", "maxDate", "locale", "inputFormat", "outputFormat", "forSaveLocalOnDB", "disabled", "readonly", "currentDateAsDefault", "showSpinners", "touchUi", "enableMeridian", "hideTime", "stepHour", "showHours", "hourLabel", "stepMinute", "showMinutes", "minuteLabel", "stepSecond", "showSeconds", "secondLabel", "disableMinute", "dayLabel", "monthLabel", "yearLabel", "highLightedDates", "highLightedAriaFormat"], outputs: ["ngModelInputChange"] }] });
|
|
84
|
+
DateFieldTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DateFieldTemplateComponent, selector: "date-field-template", inputs: { field: "field", record: "record" }, outputs: { recordChange: "recordChange" }, usesOnChanges: true, ngImport: i0, template: "<tmw-datetimepicker [placeholder]=\"field.Description\" [label]=\"field.Description\" [pickerMode]=\"mode\"\r\n [formGroupInput]=\"field.FormFormGroup\" [formControlNameInput]=\"field.Name\"\r\n [minDate]=\"field.MinDate ? field.MinDate : null\" [maxDate]=\"field.MaxDate ? field.MaxDate : null\"\r\n [disabled]=\"field.FormFormGroup.disabled\" [(ngModelInput)]=\"record[field.Name]\"\r\n (ngModelInputChange)=\"onRecordValueChange()\" [outputFormat]=\"outputFormat\">\r\n</tmw-datetimepicker>", styles: [""], dependencies: [{ kind: "component", type: i1.TmwDateTimePickerComponent, selector: "tmw-datetimepicker", inputs: ["debugMode", "ngModelInput", "formGroupInput", "formControlNameInput", "pickerMode", "timeType", "label", "placeholder", "hint", "minDate", "maxDate", "locale", "inputFormat", "outputFormat", "forSaveLocalOnDB", "disabled", "readonly", "currentDateAsDefault", "showSpinners", "touchUi", "enableMeridian", "hideTime", "stepHour", "showHours", "hourLabel", "stepMinute", "showMinutes", "minuteLabel", "stepSecond", "showSeconds", "secondLabel", "disableMinute", "dayLabel", "monthLabel", "yearLabel", "highLightedDates", "highLightedAriaFormat"], outputs: ["ngModelInputChange"] }] });
|
|
85
85
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DateFieldTemplateComponent, decorators: [{
|
|
86
86
|
type: Component,
|
|
87
|
-
args: [{ selector: 'date-field-template', template: "<tmw-datetimepicker [placeholder]=\"field.Description\" [pickerMode]=\"mode\"\r\n [formGroupInput]=\"field.FormFormGroup\" [formControlNameInput]=\"field.Name\"\r\n [minDate]=\"field.MinDate ? field.MinDate : null\" [maxDate]=\"field.MaxDate ? field.MaxDate : null\"\r\n [disabled]=\"field.FormFormGroup.disabled\" [(ngModelInput)]=\"record[field.Name]\"\r\n (ngModelInputChange)=\"onRecordValueChange()\" [outputFormat]=\"outputFormat\">\r\n</tmw-datetimepicker>" }]
|
|
87
|
+
args: [{ selector: 'date-field-template', template: "<tmw-datetimepicker [placeholder]=\"field.Description\" [label]=\"field.Description\" [pickerMode]=\"mode\"\r\n [formGroupInput]=\"field.FormFormGroup\" [formControlNameInput]=\"field.Name\"\r\n [minDate]=\"field.MinDate ? field.MinDate : null\" [maxDate]=\"field.MaxDate ? field.MaxDate : null\"\r\n [disabled]=\"field.FormFormGroup.disabled\" [(ngModelInput)]=\"record[field.Name]\"\r\n (ngModelInputChange)=\"onRecordValueChange()\" [outputFormat]=\"outputFormat\">\r\n</tmw-datetimepicker>" }]
|
|
88
88
|
}], ctorParameters: function () { return []; }, propDecorators: { field: [{
|
|
89
89
|
type: Input
|
|
90
90
|
}], record: [{
|
|
@@ -92,4 +92,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
92
92
|
}], recordChange: [{
|
|
93
93
|
type: Output
|
|
94
94
|
}] } });
|
|
95
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-field-template.component.js","sourceRoot":"","sources":["../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/date-field-template/date-field-template.component.ts","../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/date-field-template/date-field-template.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { Record } from '../../../../models/record.model';\r\nimport { DateField, DateTimeTypeEnum } from '../../../../models/fields/dateField.model';\r\nimport { IBaseFieldComponent } from '../../../../interfaces/iBaseFieldComponent.interface';\r\nimport { UtilityHelperService } from '../../../../services/utilityHelper.services';\r\nimport { DataGetterTypeEnum } from '../../../../models/baseField.model';\r\nimport { ModeEnum, TimeTypeEnum } from \"tmw-picker\";\r\n\r\n@Component({\r\n  selector: 'date-field-template',\r\n  templateUrl: './date-field-template.component.html',\r\n  styleUrls: ['./date-field-template.component.scss']\r\n})\r\nexport class DateFieldTemplateComponent implements OnInit, OnChanges, IBaseFieldComponent {\r\n\r\n  @Input() field: DateField;\r\n  @Input() record: Record;\r\n  @Output() recordChange: EventEmitter<Record> = new EventEmitter<Record>();\r\n\r\n  modes = ModeEnum;\r\n  timeType = TimeTypeEnum;\r\n  mode: ModeEnum;\r\n\r\n  outputFormat: string = null;\r\n\r\n  constructor() { }\r\n\r\n  ngOnInit(): void {\r\n    this.setTimeType();\r\n    this.setOutputFormat();\r\n    this.updateField();\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    if (this.field.VisibleIf) {\r\n      this.field.InListView = UtilityHelperService.EvaluateFieldFormula(this.field.VisibleIf, this.record, null);\r\n    }\r\n    if (this.field.DataGetter.DataGetterType == DataGetterTypeEnum.Manuale && this.record[this.field.Name] == null) {\r\n      this.record[this.field.Name] = this.field.DataGetter.DataGetterValue;\r\n    }       \r\n  }\r\n\r\n  /**\r\n   * Metodo per emettere l'evento che il valore del record è cambiato.\r\n   */\r\n  onRecordValueChange() {\r\n    if (!this.field.Formula) {\r\n      this.recordChange.emit(this.record);\r\n    }\r\n  }\r\n\r\n  setOutputFormat(){\r\n    if (this.outputFormat != null){\r\n      this.outputFormat = this.field.DateFormat;  \r\n    } else {\r\n      if (this.field.IsOnlyDate == DateTimeTypeEnum['Solo data']){\r\n        this.outputFormat = 'DD/MM/YYYY';\r\n      }\r\n      if (this.field.IsOnlyDate == DateTimeTypeEnum['Data e ora']){\r\n        this.outputFormat = 'DD/MM/YYYY HH:mm';\r\n      }      \r\n      if (this.field.IsOnlyDate == DateTimeTypeEnum['Solo orario']){\r\n        this.outputFormat = 'HH:mm';\r\n      }          \r\n    }\r\n    \r\n  }\r\n\r\n  /**\r\n   * In base al formato della data richiesta nel DateField (solo data, solo orario o data e ora)\r\n   * imposta la visualizzazione corretta del componente eqp-datetimepicker.\r\n   */\r\n  private setTimeType() {\r\n    switch (this.field.IsOnlyDate) {\r\n      case DateTimeTypeEnum[\"Solo data\"]:\r\n        this.mode = ModeEnum.DATEPICKER;\r\n        break;\r\n      case DateTimeTypeEnum[\"Solo orario\"]:\r\n        this.mode = ModeEnum.TIMEPICKER;\r\n        break;\r\n      case DateTimeTypeEnum[\"Data e ora\"]:\r\n        this.mode = ModeEnum.DATETIMEPICKER;\r\n        break;\r\n    }\r\n  }\r\n}\r\n","<tmw-datetimepicker  [placeholder]=\"field.Description\" [label]=\"field.Description\"  [pickerMode]=\"mode\"\r\n    [formGroupInput]=\"field.FormFormGroup\" [formControlNameInput]=\"field.Name\"\r\n    [minDate]=\"field.MinDate ? field.MinDate : null\" [maxDate]=\"field.MaxDate ? field.MaxDate : null\"\r\n    [disabled]=\"field.FormFormGroup.disabled\" [(ngModelInput)]=\"record[field.Name]\"\r\n    (ngModelInputChange)=\"onRecordValueChange()\" [outputFormat]=\"outputFormat\">\r\n</tmw-datetimepicker>"]}
|
|
@@ -91,10 +91,10 @@ export class DateFilterTemplateComponent {
|
|
|
91
91
|
}
|
|
92
92
|
}
|
|
93
93
|
DateFilterTemplateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DateFilterTemplateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
94
|
-
DateFilterTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DateFilterTemplateComponent, selector: "date-filter-template", inputs: { field: "field", record: "record" }, outputs: { filterChange: "filterChange" }, ngImport: i0, template: "<div class=\"row\">\r\n <div class=\"col-md-9 valueCol\">\r\n <tmw-datetimepicker [placeholder]=\"field.Description\" [pickerMode]=\"mode\"\r\n [formGroupInput]=\"field.FormFormGroup\" [formControlNameInput]=\"field.Name\"\r\n [minDate]=\"field.MinDate ? field.MinDate : null\" [maxDate]=\"field.MaxDate ? field.MaxDate : null\"\r\n [disabled]=\"field.FormFormGroup.disabled\" [(ngModelInput)]=\"record[field.Name]\"\r\n (ngModelInputChange)=\"onFilterChange()\" [outputFormat]=\"outputFormat\">\r\n </tmw-datetimepicker>\r\n </div>\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"logicOperatorNumeric\" [(ngModel)]=\"selectedLogicOperator\" (ngModelChange)=\"onFilterChange()\"></eqp-select>\r\n </div>\r\n</div>", styles: [".valueCol{padding-right:0}.operatorCol{padding-left:0}::ng-deep .operatorCol .mdc-text-field--filled:not(.mdc-text-field--disabled){background-color:#a5afc0!important}::ng-deep .operatorCol .mat-mdc-select-value{color:#081c45;font-size:16px;font-weight:700;position:relative;top:-6px}\n"], dependencies: [{ kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i2.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: i3.TmwDateTimePickerComponent, selector: "tmw-datetimepicker", inputs: ["debugMode", "ngModelInput", "formGroupInput", "formControlNameInput", "pickerMode", "timeType", "label", "placeholder", "hint", "minDate", "maxDate", "locale", "inputFormat", "outputFormat", "forSaveLocalOnDB", "disabled", "readonly", "currentDateAsDefault", "showSpinners", "touchUi", "enableMeridian", "hideTime", "stepHour", "showHours", "hourLabel", "stepMinute", "showMinutes", "minuteLabel", "stepSecond", "showSeconds", "secondLabel", "disableMinute", "dayLabel", "monthLabel", "yearLabel", "highLightedDates", "highLightedAriaFormat"], outputs: ["ngModelInputChange"] }] });
|
|
94
|
+
DateFilterTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DateFilterTemplateComponent, selector: "date-filter-template", inputs: { field: "field", record: "record" }, outputs: { filterChange: "filterChange" }, ngImport: i0, template: "<div class=\"row\">\r\n <div class=\"col-md-9 valueCol\">\r\n <tmw-datetimepicker [placeholder]=\"field.Description\" [label]=\"field.Description\" [pickerMode]=\"mode\"\r\n [formGroupInput]=\"field.FormFormGroup\" [formControlNameInput]=\"field.Name\"\r\n [minDate]=\"field.MinDate ? field.MinDate : null\" [maxDate]=\"field.MaxDate ? field.MaxDate : null\"\r\n [disabled]=\"field.FormFormGroup.disabled\" [(ngModelInput)]=\"record[field.Name]\"\r\n (ngModelInputChange)=\"onFilterChange()\" [outputFormat]=\"outputFormat\" >\r\n </tmw-datetimepicker>\r\n </div>\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"logicOperatorNumeric\" [(ngModel)]=\"selectedLogicOperator\" (ngModelChange)=\"onFilterChange()\"></eqp-select>\r\n </div>\r\n</div>", styles: [".valueCol{padding-right:0}.operatorCol{padding-left:0}::ng-deep .operatorCol .mdc-text-field--filled:not(.mdc-text-field--disabled){background-color:#a5afc0!important}::ng-deep .operatorCol .mat-mdc-select-value{color:#081c45;font-size:16px;font-weight:700;position:relative;top:-6px}\n"], dependencies: [{ kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i2.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: i3.TmwDateTimePickerComponent, selector: "tmw-datetimepicker", inputs: ["debugMode", "ngModelInput", "formGroupInput", "formControlNameInput", "pickerMode", "timeType", "label", "placeholder", "hint", "minDate", "maxDate", "locale", "inputFormat", "outputFormat", "forSaveLocalOnDB", "disabled", "readonly", "currentDateAsDefault", "showSpinners", "touchUi", "enableMeridian", "hideTime", "stepHour", "showHours", "hourLabel", "stepMinute", "showMinutes", "minuteLabel", "stepSecond", "showSeconds", "secondLabel", "disableMinute", "dayLabel", "monthLabel", "yearLabel", "highLightedDates", "highLightedAriaFormat"], outputs: ["ngModelInputChange"] }] });
|
|
95
95
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DateFilterTemplateComponent, decorators: [{
|
|
96
96
|
type: Component,
|
|
97
|
-
args: [{ selector: 'date-filter-template', template: "<div class=\"row\">\r\n <div class=\"col-md-9 valueCol\">\r\n <tmw-datetimepicker [placeholder]=\"field.Description\" [pickerMode]=\"mode\"\r\n [formGroupInput]=\"field.FormFormGroup\" [formControlNameInput]=\"field.Name\"\r\n [minDate]=\"field.MinDate ? field.MinDate : null\" [maxDate]=\"field.MaxDate ? field.MaxDate : null\"\r\n [disabled]=\"field.FormFormGroup.disabled\" [(ngModelInput)]=\"record[field.Name]\"\r\n (ngModelInputChange)=\"onFilterChange()\" [outputFormat]=\"outputFormat\">\r\n </tmw-datetimepicker>\r\n </div>\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"logicOperatorNumeric\" [(ngModel)]=\"selectedLogicOperator\" (ngModelChange)=\"onFilterChange()\"></eqp-select>\r\n </div>\r\n</div>", styles: [".valueCol{padding-right:0}.operatorCol{padding-left:0}::ng-deep .operatorCol .mdc-text-field--filled:not(.mdc-text-field--disabled){background-color:#a5afc0!important}::ng-deep .operatorCol .mat-mdc-select-value{color:#081c45;font-size:16px;font-weight:700;position:relative;top:-6px}\n"] }]
|
|
97
|
+
args: [{ selector: 'date-filter-template', template: "<div class=\"row\">\r\n <div class=\"col-md-9 valueCol\">\r\n <tmw-datetimepicker [placeholder]=\"field.Description\" [label]=\"field.Description\" [pickerMode]=\"mode\"\r\n [formGroupInput]=\"field.FormFormGroup\" [formControlNameInput]=\"field.Name\"\r\n [minDate]=\"field.MinDate ? field.MinDate : null\" [maxDate]=\"field.MaxDate ? field.MaxDate : null\"\r\n [disabled]=\"field.FormFormGroup.disabled\" [(ngModelInput)]=\"record[field.Name]\"\r\n (ngModelInputChange)=\"onFilterChange()\" [outputFormat]=\"outputFormat\" >\r\n </tmw-datetimepicker>\r\n </div>\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"logicOperatorNumeric\" [(ngModel)]=\"selectedLogicOperator\" (ngModelChange)=\"onFilterChange()\"></eqp-select>\r\n </div>\r\n</div>", styles: [".valueCol{padding-right:0}.operatorCol{padding-left:0}::ng-deep .operatorCol .mdc-text-field--filled:not(.mdc-text-field--disabled){background-color:#a5afc0!important}::ng-deep .operatorCol .mat-mdc-select-value{color:#081c45;font-size:16px;font-weight:700;position:relative;top:-6px}\n"] }]
|
|
98
98
|
}], ctorParameters: function () { return []; }, propDecorators: { field: [{
|
|
99
99
|
type: Input
|
|
100
100
|
}], record: [{
|
|
@@ -102,4 +102,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
102
102
|
}], filterChange: [{
|
|
103
103
|
type: Output
|
|
104
104
|
}] } });
|
|
105
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
105
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-filter-template.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/form-statistics/filter-templates/date-filter-template/date-filter-template.component.ts","../../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/form-statistics/filter-templates/date-filter-template/date-filter-template.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { Record } from '../../../../../models/record.model';\r\nimport { DateField, DateTimeTypeEnum } from '../../../../../models/fields/dateField.model';\r\nimport { LogicOperatorDate } from '../../../../../models/logicOperator.model';\r\nimport { Statistic } from '../../../../../models/statistic.model';\r\nimport { ModeEnum, TimeTypeEnum } from 'tmw-picker';\r\n\r\n@Component({\r\n  selector: 'date-filter-template',\r\n  templateUrl: './date-filter-template.component.html',\r\n  styleUrls: ['./date-filter-template.component.scss']\r\n})\r\nexport class DateFilterTemplateComponent {\r\n\r\n  @Input() field: DateField;\r\n  @Input() record: Record;\r\n  @Output() filterChange: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  logicOperatorNumeric = LogicOperatorDate;\r\n  selectedLogicOperator: LogicOperatorDate;\r\n  activeCondition: boolean = false;  \r\n\r\n  modes = ModeEnum;\r\n  timeType = TimeTypeEnum;\r\n  mode: ModeEnum;\r\n\r\n  outputFormat: string = null;\r\n\r\n  constructor() { }\r\n\r\n  ngOnInit(): void {\r\n    this.setTimeType();\r\n    this.setOutputFormat();\r\n  }\r\n\r\n  /**\r\n   * In base al formato della data richiesta nel DateField (solo data, solo orario o data e ora)\r\n   * imposta la visualizzazione corretta del componente eqp-datetimepicker.\r\n   */\r\n  private setTimeType() {\r\n    switch (this.field.IsOnlyDate) {\r\n      case DateTimeTypeEnum[\"Solo data\"]:\r\n        this.mode = ModeEnum.DATEPICKER;\r\n        break;\r\n      case DateTimeTypeEnum[\"Solo orario\"]:\r\n        this.mode = ModeEnum.TIMEPICKER;\r\n        break;\r\n      case DateTimeTypeEnum[\"Data e ora\"]:\r\n        this.mode = ModeEnum.DATETIMEPICKER;\r\n        break;\r\n    }\r\n  }\r\n\r\n/**\r\n* Metodo per emettere l'evento che il valore del record è cambiato.\r\n*/\r\nonFilterChange() {\r\n  if (this.record[this.field.Name] != null && this.selectedLogicOperator != null){\r\n    this.activeCondition = true;\r\n    this.filterChange.emit(this.generateCondition(\"active\"));\r\n  }\r\n  if (this.activeCondition && (this.record[this.field.Name] == null || this.record[this.field.Name] == \"\" || this.selectedLogicOperator == null)){\r\n    this.activeCondition = false;\r\n    this.filterChange.emit(this.generateCondition(\"deactivated\"));\r\n  }\r\n}\r\n\r\n/**\r\n * Metodo che genera l'oggetto da inviare all'esterno\r\n */\r\n\r\ngenerateCondition(mode){\r\n  let output:Statistic = new Statistic();\r\n  if (mode == \"active\"){\r\n    output = {\r\n      key: this.field.Name,\r\n      value: this.record[this.field.Name],\r\n      logicoperator: this.selectedLogicOperator,\r\n      fieldtype: this.field.FieldType\r\n    };\r\n  } else {\r\n    output = {\r\n      key: this.field.Name,\r\n      value: null,\r\n      logicoperator: null,\r\n      fieldtype: null\r\n    };\r\n  }\r\n\r\n  return output;\r\n}  \r\n\r\nsetOutputFormat(){\r\n  if (this.outputFormat != null){\r\n    this.outputFormat = this.field.DateFormat;  \r\n  } else {\r\n    if (this.field.IsOnlyDate == DateTimeTypeEnum['Solo data']){\r\n      this.outputFormat = 'DD/MM/YYYY';\r\n    }\r\n    if (this.field.IsOnlyDate == DateTimeTypeEnum['Data e ora']){\r\n      this.outputFormat = 'DD/MM/YYYY HH:mm';\r\n    }      \r\n    if (this.field.IsOnlyDate == DateTimeTypeEnum['Solo orario']){\r\n      this.outputFormat = 'HH:mm';\r\n    }          \r\n  }\r\n  \r\n}\r\n\r\n}\r\n","<div class=\"row\">\r\n    <div class=\"col-md-9 valueCol\">\r\n        <tmw-datetimepicker  [placeholder]=\"field.Description\" [label]=\"field.Description\" [pickerMode]=\"mode\"\r\n        [formGroupInput]=\"field.FormFormGroup\" [formControlNameInput]=\"field.Name\"\r\n        [minDate]=\"field.MinDate ? field.MinDate : null\" [maxDate]=\"field.MaxDate ? field.MaxDate : null\"\r\n        [disabled]=\"field.FormFormGroup.disabled\" [(ngModelInput)]=\"record[field.Name]\"\r\n        (ngModelInputChange)=\"onFilterChange()\" [outputFormat]=\"outputFormat\" >\r\n        </tmw-datetimepicker>\r\n    </div>\r\n    <div class=\"col-md-3 operatorCol\">\r\n        <eqp-select [enumData]=\"logicOperatorNumeric\" [(ngModel)]=\"selectedLogicOperator\" (ngModelChange)=\"onFilterChange()\"></eqp-select>\r\n    </div>\r\n</div>"]}
|