@eqproject/eqp-dynamic-module 2.10.30 → 2.10.32

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.
@@ -66,16 +66,24 @@ export class ImageFieldSelectorTemplateComponent {
66
66
  }
67
67
  /**
68
68
  * Metodo per emettere l'evento che il valore del record è cambiato.
69
+ * @param event ID dell'attachment della lista
69
70
  */
70
71
  onRecordValueChange(event) {
72
+ // spiano i valori di risposta
71
73
  this.record[this.field.Name] = new Array();
72
74
  if (!this.field.IsMultiChoiche) {
73
- var dynAttachment = JSON.parse(JSON.stringify(this.field.AttachmentList.find(x => x.ID == event)));
74
- dynAttachment.FileDataBase64 = null;
75
- this.record[this.field.Name] = dynAttachment;
75
+ // se non è multiscelta
76
+ if (event) {
77
+ // se c'è un valore ho selezionato un'immagine, la recupero e la assegna al valore della risposta
78
+ var dynAttachment = JSON.parse(JSON.stringify(this.field.AttachmentList.find(x => x.ID == event)));
79
+ dynAttachment.FileDataBase64 = null;
80
+ this.record[this.field.Name] = dynAttachment;
81
+ }
76
82
  }
77
83
  else {
78
- this.transformedRecord.forEach((element) => {
84
+ // se è una multiscelta
85
+ // per ogni elemento selezionato lo aggiungo alla lista dei valori di risposta
86
+ this.transformedRecord?.forEach((element) => {
79
87
  var dynAttachment = JSON.parse(JSON.stringify(this.field.AttachmentList.find(x => x.ID == element)));
80
88
  dynAttachment.FileDataBase64 = null;
81
89
  this.record[this.field.Name].push(dynAttachment);
@@ -100,4 +108,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
100
108
  }], recordChange: [{
101
109
  type: Output
102
110
  }] } });
103
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-field-selector-template.component.js","sourceRoot":"","sources":["../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/image-field-selector-template/image-field-selector-template.component.ts","../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/image-field-selector-template/image-field-selector-template.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, SimpleChanges } from '@angular/core';\r\nimport { MatDialog, MatDialogRef } from '@angular/material/dialog';\r\nimport { Record } from '../../../../models/record.model';\r\nimport { ImageSelectorField } from '../../../../models/fields/imageSelectorField.model';\r\nimport { UtilityHelperService } from '../../../../services/utilityHelper.services';\r\nimport { DynAttachment, DynAttachmentSelectObject } from '../../../../models/dynAttachment';\r\nimport { GlobalService } from '../../../../services/global.service';\r\n\r\n@Component({\r\n  selector: 'image-field-selector-template',\r\n  templateUrl: './image-field-selector-template.component.html',\r\n  styleUrls: ['./image-field-selector-template.component.scss']\r\n})\r\nexport class ImageFieldSelectorTemplateComponent {\r\n\r\n  @Input() record: Record;\r\n  @Input() formulaObject: any = {};\r\n  @Input() field: ImageSelectorField;\r\n  @Input() inConfig: boolean = false;\r\n  @Output() recordChange: EventEmitter<Record> = new EventEmitter<Record>();\r\n\r\n  FieldstyleObj: any;\r\n  LabelstyleObj: any;\r\n  transformedRecord: any;\r\n \r\n  constructor(\r\n    private dialog: MatDialog,\r\n    public utilityService: UtilityHelperService\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n\r\n    GlobalService.debugLog(\"ImageFieldSelectorTemplateComponent - RECORD ngOnInit() - record\", this.record[this.field.Name]);\r\n    GlobalService.debugLog(\"ImageFieldSelectorTemplateComponent - RECORD ngOnInit() - field\", this.field);\r\n\r\n    this.initStyles();\r\n    this.initializeAttachments();\r\n    \r\n  }\r\n\r\n  initStyles() {\r\n    //Funzione per parsare il campo stylecss dell'oggetto field ed applicarlo all'html\r\n  if(this.field.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)   \r\n    this.FieldstyleObj= UtilityHelperService.initStyles(this.field.FieldstyleCSS);\r\n  if(this.field.LabelstyleCSS != null || this.field.LabelstyleCSS != undefined)   \r\n    this.LabelstyleObj = UtilityHelperService.initStyles(this.field.LabelstyleCSS);\r\n}  \r\n\r\n  ToLowerCase(el:string){\r\n    return el.toLowerCase();\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\r\n  }\r\n\r\n  initializeAttachments(){\r\n    this.field.AttachmentList.forEach((attachment) => {\r\n      attachment.objectToSelect = new DynAttachmentSelectObject();\r\n      attachment.objectToSelect.ID = attachment.ID;\r\n      attachment.objectToSelect.ButtonKey = attachment.ButtonKey;\r\n      attachment.objectToSelect.ButtonValue = attachment.ButtonValue;\r\n    });\r\n\r\n    if (this.record[this.field.Name] != null){\r\n      if (!this.field.IsMultiChoiche){\r\n        this.transformedRecord = this.record[this.field.Name].ID;\r\n      } else {\r\n        (this.record[this.field.Name] as Array<DynAttachment>).forEach((element) => {\r\n          this.transformedRecord.push(Number(element.ID));\r\n        });\r\n      }\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(event: number) {\r\n\r\n      this.record[this.field.Name] = new Array<DynAttachment>();\r\n\r\n      if (!this.field.IsMultiChoiche){\r\n\r\n        var dynAttachment: DynAttachment = JSON.parse(JSON.stringify(this.field.AttachmentList.find(x => x.ID == event)));\r\n        dynAttachment.FileDataBase64 = null;\r\n        this.record[this.field.Name] = dynAttachment;\r\n\r\n      } else {\r\n        this.transformedRecord.forEach((element) => {\r\n          var dynAttachment: DynAttachment = JSON.parse(JSON.stringify(this.field.AttachmentList.find(x => x.ID == element)));\r\n          dynAttachment.FileDataBase64 = null;\r\n          this.record[this.field.Name].push(dynAttachment);\r\n        });\r\n      }\r\n\r\n      this.recordChange.emit(this.record);\r\n    }\r\n}\r\n","<mat-form-field [formGroup]=\"field.FormFormGroup\" appearance=\"outline\">\r\n  <mat-label class=\"pt-1\" [ngStyle]=\"LabelstyleObj\">{{field.Description}}</mat-label>\r\n\r\n  <!-- Mat-Select SINGOLA -->\r\n  <mat-select *ngIf=\"!field.IsMultiChoiche\" class=\"imageFieldSelectorImages\" [formControlName]=\"field.Name\"\r\n  [required]=\"field.Required\" [(ngModel)]=\"transformedRecord\" (ngModelChange)=\"onRecordValueChange($event)\">\r\n    <mat-option *ngFor=\"let attachment of field.AttachmentList\" [value]=\"attachment.ID\">\r\n      <img src='data:image/{{ToLowerCase(attachment.FileExtension)}};base64,{{attachment.FileDataBase64}}' [height]=\"attachment.ResizedImageHeightPx != null ? attachment.ResizedImageHeightPx : 128\"> \r\n      <span>{{ attachment.ButtonKey }}</span>\r\n    </mat-option>\r\n  </mat-select>\r\n\r\n  <!-- Mat-Select MULTIPLA -->\r\n  <mat-select *ngIf=\"field.IsMultiChoiche\" class=\"imageFieldSelectorImages\" [formControlName]=\"field.Name\"\r\n  [required]=\"field.Required\" [(ngModel)]=\"transformedRecord\" (ngModelChange)=\"onRecordValueChange($event)\" multiple>\r\n    <mat-option *ngFor=\"let attachment of field.AttachmentList\" [value]=\"attachment.ID\">\r\n      <img src='data:image/{{ToLowerCase(attachment.FileExtension)}};base64,{{attachment.FileDataBase64}}' [height]=\"attachment.ResizedImageHeightPx != null ? attachment.ResizedImageHeightPx : 128\"> \r\n      <span>{{ attachment.ButtonKey }}</span>\r\n    </mat-option>\r\n  </mat-select>\r\n\r\n</mat-form-field>"]}
111
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-field-selector-template.component.js","sourceRoot":"","sources":["../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/image-field-selector-template/image-field-selector-template.component.ts","../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/image-field-selector-template/image-field-selector-template.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, SimpleChanges } from '@angular/core';\r\nimport { MatDialog, MatDialogRef } from '@angular/material/dialog';\r\nimport { Record } from '../../../../models/record.model';\r\nimport { ImageSelectorField } from '../../../../models/fields/imageSelectorField.model';\r\nimport { UtilityHelperService } from '../../../../services/utilityHelper.services';\r\nimport { DynAttachment, DynAttachmentSelectObject } from '../../../../models/dynAttachment';\r\nimport { GlobalService } from '../../../../services/global.service';\r\n\r\n@Component({\r\n  selector: 'image-field-selector-template',\r\n  templateUrl: './image-field-selector-template.component.html',\r\n  styleUrls: ['./image-field-selector-template.component.scss']\r\n})\r\nexport class ImageFieldSelectorTemplateComponent {\r\n\r\n  @Input() record: Record;\r\n  @Input() formulaObject: any = {};\r\n  @Input() field: ImageSelectorField;\r\n  @Input() inConfig: boolean = false;\r\n  @Output() recordChange: EventEmitter<Record> = new EventEmitter<Record>();\r\n\r\n  FieldstyleObj: any;\r\n  LabelstyleObj: any;\r\n  transformedRecord: any;\r\n \r\n  constructor(\r\n    private dialog: MatDialog,\r\n    public utilityService: UtilityHelperService\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n\r\n    GlobalService.debugLog(\"ImageFieldSelectorTemplateComponent - RECORD ngOnInit() - record\", this.record[this.field.Name]);\r\n    GlobalService.debugLog(\"ImageFieldSelectorTemplateComponent - RECORD ngOnInit() - field\", this.field);\r\n\r\n    this.initStyles();\r\n    this.initializeAttachments();\r\n    \r\n  }\r\n\r\n  initStyles() {\r\n    //Funzione per parsare il campo stylecss dell'oggetto field ed applicarlo all'html\r\n  if(this.field.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)   \r\n    this.FieldstyleObj= UtilityHelperService.initStyles(this.field.FieldstyleCSS);\r\n  if(this.field.LabelstyleCSS != null || this.field.LabelstyleCSS != undefined)   \r\n    this.LabelstyleObj = UtilityHelperService.initStyles(this.field.LabelstyleCSS);\r\n}  \r\n\r\n  ToLowerCase(el:string){\r\n    return el.toLowerCase();\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\r\n  }\r\n\r\n  initializeAttachments(){\r\n    this.field.AttachmentList.forEach((attachment) => {\r\n      attachment.objectToSelect = new DynAttachmentSelectObject();\r\n      attachment.objectToSelect.ID = attachment.ID;\r\n      attachment.objectToSelect.ButtonKey = attachment.ButtonKey;\r\n      attachment.objectToSelect.ButtonValue = attachment.ButtonValue;\r\n    });\r\n\r\n    if (this.record[this.field.Name] != null){\r\n      if (!this.field.IsMultiChoiche){\r\n        this.transformedRecord = this.record[this.field.Name].ID;\r\n      } else {\r\n        (this.record[this.field.Name] as Array<DynAttachment>).forEach((element) => {\r\n          this.transformedRecord.push(Number(element.ID));\r\n        });\r\n      }\r\n    }\r\n  }\r\n\r\n    /**\r\n   * Metodo per emettere l'evento che il valore del record è cambiato.\r\n   * @param event ID dell'attachment della lista\r\n   */\r\n    onRecordValueChange(event: number) {\r\n\r\n      // spiano i valori di risposta\r\n      this.record[this.field.Name] = new Array<DynAttachment>();\r\n      \r\n      if (!this.field.IsMultiChoiche){\r\n        // se non è multiscelta\r\n        if(event){\r\n          // se c'è un valore ho selezionato un'immagine, la recupero e la assegna al valore della risposta\r\n          var dynAttachment: DynAttachment = JSON.parse(JSON.stringify(this.field.AttachmentList.find(x => x.ID == event)));\r\n          dynAttachment.FileDataBase64 = null;\r\n          this.record[this.field.Name] = dynAttachment;\r\n        }\r\n\r\n      } else {\r\n        // se è una multiscelta\r\n        // per ogni elemento selezionato lo aggiungo alla lista dei valori di risposta\r\n        this.transformedRecord?.forEach((element) => {\r\n          var dynAttachment: DynAttachment = JSON.parse(JSON.stringify(this.field.AttachmentList.find(x => x.ID == element)));\r\n          dynAttachment.FileDataBase64 = null;\r\n          this.record[this.field.Name].push(dynAttachment);\r\n        });\r\n      }\r\n\r\n      this.recordChange.emit(this.record);\r\n    }\r\n}\r\n","<mat-form-field [formGroup]=\"field.FormFormGroup\" appearance=\"outline\">\r\n  <mat-label class=\"pt-1\" [ngStyle]=\"LabelstyleObj\">{{field.Description}}</mat-label>\r\n\r\n  <!-- Mat-Select SINGOLA -->\r\n  <mat-select *ngIf=\"!field.IsMultiChoiche\" class=\"imageFieldSelectorImages\" [formControlName]=\"field.Name\"\r\n  [required]=\"field.Required\" [(ngModel)]=\"transformedRecord\" (ngModelChange)=\"onRecordValueChange($event)\">\r\n    <mat-option *ngFor=\"let attachment of field.AttachmentList\" [value]=\"attachment.ID\">\r\n      <img src='data:image/{{ToLowerCase(attachment.FileExtension)}};base64,{{attachment.FileDataBase64}}' [height]=\"attachment.ResizedImageHeightPx != null ? attachment.ResizedImageHeightPx : 128\"> \r\n      <span>{{ attachment.ButtonKey }}</span>\r\n    </mat-option>\r\n  </mat-select>\r\n\r\n  <!-- Mat-Select MULTIPLA -->\r\n  <mat-select *ngIf=\"field.IsMultiChoiche\" class=\"imageFieldSelectorImages\" [formControlName]=\"field.Name\"\r\n  [required]=\"field.Required\" [(ngModel)]=\"transformedRecord\" (ngModelChange)=\"onRecordValueChange($event)\" multiple>\r\n    <mat-option *ngFor=\"let attachment of field.AttachmentList\" [value]=\"attachment.ID\">\r\n      <img src='data:image/{{ToLowerCase(attachment.FileExtension)}};base64,{{attachment.FileDataBase64}}' [height]=\"attachment.ResizedImageHeightPx != null ? attachment.ResizedImageHeightPx : 128\"> \r\n      <span>{{ attachment.ButtonKey }}</span>\r\n    </mat-option>\r\n  </mat-select>\r\n\r\n</mat-form-field>"]}