@eqproject/eqp-dynamic-module 2.3.12 → 2.3.13
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/field-templates/list-value-field-template/list-value-field-template.component.mjs +3 -4
- package/fesm2015/eqproject-eqp-dynamic-module.mjs +2 -3
- package/fesm2015/eqproject-eqp-dynamic-module.mjs.map +1 -1
- package/fesm2020/eqproject-eqp-dynamic-module.mjs +2 -3
- package/fesm2020/eqproject-eqp-dynamic-module.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -29,9 +29,8 @@ export class ListValueFieldTemplateComponent {
|
|
|
29
29
|
this.LabelstyleObj = UtilityHelperService.initStyles(this.field.LabelstyleCSS);
|
|
30
30
|
}
|
|
31
31
|
ngOnInit() {
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
alert("meeee");
|
|
32
|
+
this.debugLog("combobox debugMode", this.debugMode);
|
|
33
|
+
this.debugLog("combobox filed", this.field);
|
|
35
34
|
this.updateField();
|
|
36
35
|
this.setArrayData();
|
|
37
36
|
if (this.field.IsMultiChoiche && !this.record[this.field.Name]) {
|
|
@@ -198,4 +197,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
198
197
|
}], recordChange: [{
|
|
199
198
|
type: Output
|
|
200
199
|
}] } });
|
|
201
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-value-field-template.component.js","sourceRoot":"","sources":["../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/list-value-field-template/list-value-field-template.component.ts","../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/list-value-field-template/list-value-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 { ListPresentationEnum, ListValueField } from '../../../../models/fields/listValueField.model';\r\nimport { IBaseFieldComponent } from '../../../../interfaces/iBaseFieldComponent.interface';\r\nimport { UtilityHelperService } from '../../../../services/utilityHelper.services';\r\n\r\n@Component({\r\n  selector: 'list-value-field-template',\r\n  templateUrl: './list-value-field-template.component.html',\r\n  styleUrls: ['./list-value-field-template.component.scss']\r\n})\r\nexport class ListValueFieldTemplateComponent implements OnInit, OnChanges, IBaseFieldComponent {\r\n\r\n  @Input() debugMode: boolean = false;\r\n  debugLog(message: string, element?: any) {\r\n    if (this.debugMode) {\r\n      console.log(message, element)\r\n    }\r\n  }\r\n\r\n  @Input() field: ListValueField;\r\n  @Input() record: Record;\r\n  @Output() recordChange: EventEmitter<Record> = new EventEmitter<Record>();\r\n  ListPresentationEnum = ListPresentationEnum;\r\n  arrayData: { Key: string, Value: any, Selected?: boolean, ImgUrl?: string }[] = [];\r\n  //variabili per gestire il css della label e del field\r\n  FieldstyleObj: any;\r\n  LabelstyleObj: any;\r\n  constructor() { }\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.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)\r\n      this.LabelstyleObj = UtilityHelperService.initStyles(this.field.LabelstyleCSS);\r\n  }\r\n  ngOnInit(): void {\r\n    console.log(\"combobox debugMode\", this.debugMode);\r\n    console.log(\"combobox filed\", this.field);\r\n    alert(\"meeee\")\r\n    this.updateField();\r\n    this.setArrayData();\r\n    if (this.field.IsMultiChoiche && !this.record[this.field.Name]) {\r\n      this.record[this.field.Name] = [];\r\n    }\r\n    // Nel caso in cui sono in modifica di un Record aggiorno il valore\r\n    // e il validator del FormControl. Se non viene eseguita questa riga\r\n    // l'utente deve modificare la selezione fatta per aggiornare la form.\r\n    this.setFormControlValue();\r\n    this.initStyles();\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    // devo controllare se ho la stringa (ValueString) o il dizionario (ValuePairs)\r\n    this.debugLog(\"list-value-field updateField\", this.field)\r\n    if (this.field.Formula) {\r\n      this.debugLog(\"list-value-field - updateField - Formula\")\r\n      this.field.ValuePairs = {};\r\n      const temp: string = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, null);\r\n      // temp dovrebbe essere una stringa del tipo \"chiave1! valore 1 ; chiave2 | valore 2 \"\r\n      // dobbiamo ottenere un dizionario di quei valori\r\n      this.field.ValuePairs = this.stringToValuePairs(temp);\r\n\r\n      // for (var key in matches) {\r\n      //   if(UtilityHelperService.isNumeric(temp[key])){\r\n      //     this.field.ValuePairs[key] = Number(temp[key]);\r\n      //   }else{\r\n      //     this.field.ValuePairs[key] = temp[key];\r\n      //   }\r\n      // }\r\n\r\n      //   this.setArrayData();\r\n      //this.record[this.field.Name] = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, null);\r\n    } else if (this.field.ValuePairs != null && this.field.ValuePairs.lenght > 0) {\r\n      this.debugLog(\"list-value-field - updateField - ValuePairs\")\r\n\r\n    } else if (this.field.ValueString != null && this.field.ValueString != \"\") {\r\n      this.debugLog(\"list-value-field - updateField - ValueString\")\r\n      this.field.ValuePairs = this.stringToValuePairs(this.field.ValueString);\r\n\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  }\r\n\r\n  /**\r\n   * Metodo invocato quando viene selezionata un'opzione nella visualizzazione a button\r\n   * @param data Rappresenta l'oggetto selezionato\r\n   */\r\n  buttonSelectClick(data: { Key: string, Value: string, Selected?: boolean, ImgUrl?: string }) {\r\n    data.Selected = !data.Selected;\r\n    if (this.field.IsMultiChoiche) {\r\n      this.updateSelected(false);\r\n    } else {\r\n      this.arrayData.filter(d => d.Key != data.Key && d.Value != data.Value).forEach(d => d.Selected = false);\r\n\r\n      if (UtilityHelperService.isNumeric(data.Value)) {\r\n\r\n        this.record[this.field.Name] = Number(data.Value);\r\n      }\r\n      else {\r\n        this.record[this.field.Name] = data.Value;\r\n      }\r\n\r\n    }\r\n    this.onRecordValueChange();\r\n  }\r\n\r\n  /**\r\n   * Metodo per aggiornare il/i valore/i selezionato/i dall'utente.\r\n   * @param emitChange Se true scatena l'evento di output della modifica del valore di record\r\n   */\r\n  updateSelected(emitChange: boolean = true) {\r\n    this.record[this.field.Name] = this.arrayData.filter(data => data.Selected).map(data => data.Value);\r\n    this.setFormControlValue();\r\n    if (emitChange) {\r\n      this.onRecordValueChange();\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    this.recordChange.emit(this.record);\r\n  }\r\n\r\n  /**\r\n   * Metodo per creare un array di oggetti del tipo { Key: string, Value: any } da usare come sorgente dati per la eqp-select.\r\n   */\r\n  private setArrayData() {\r\n    if (this.field.PresentationMode != ListPresentationEnum.Immagini) {\r\n      if (UtilityHelperService.isNumeric(this.field.ValuePairs[Object.keys(this.field.ValuePairs)[0]])) {\r\n        Object.keys(this.field.ValuePairs).forEach\r\n          (k => this.createNumberArrayDataElement(k, Number(this.field.ValuePairs[k])));\r\n      } else {\r\n        Object.keys(this.field.ValuePairs).forEach\r\n          (k => this.createArrayDataElement(k, this.field.ValuePairs[k]));\r\n      }\r\n\r\n    } else {\r\n      this.field.ButtonImageList.forEach(i => { this.createArrayDataElement(i.ButtonKey, i.ButtonValue, 'data:' + i.FileContentType + ';base64,' + i.FileDataBase64); });\r\n    }\r\n  }\r\n\r\n  private createArrayDataElement(key: string, value: string, imgUrl: string = null) {\r\n    let isOptionSelected: boolean;\r\n    if (this.field.IsMultiChoiche && this.record[this.field.Name] && this.record[this.field.Name].length > 0) {\r\n      isOptionSelected = !!this.record[this.field.Name].find(v => v == value);\r\n    } else {\r\n      isOptionSelected = this.record[this.field.Name] === value;\r\n    }\r\n    this.arrayData.push({ Key: key, Value: value, Selected: isOptionSelected, ImgUrl: imgUrl });\r\n  }\r\n\r\n  private createNumberArrayDataElement(key: string, value: number, imgUrl: string = null) {\r\n    let isOptionSelected: boolean;\r\n    if (this.field.IsMultiChoiche && this.record[this.field.Name] && this.record[this.field.Name].length > 0) {\r\n      isOptionSelected = !!this.record[this.field.Name].find(v => v == value);\r\n    } else {\r\n      isOptionSelected = this.record[this.field.Name] === value;\r\n    }\r\n    this.arrayData.push({ Key: key, Value: value, Selected: isOptionSelected, ImgUrl: imgUrl });\r\n  }\r\n  /**\r\n   * Metodo per aggiornare il valore e il validator del FormControl associato al campo.\r\n   */\r\n  private setFormControlValue() {\r\n    this.field.FormFormGroup.controls[this.field.Name].setValue(this.record[this.field.Name]);\r\n  }\r\n\r\n\r\n  private stringToValuePairs(valueString: string) {\r\n    const valuePairs: { [key: string]: string } = {};\r\n    this.debugLog('stringToValuePair() - this.field.Formula temp', valueString)\r\n    const keyvals = valueString.split(\";\");\r\n    keyvals.forEach((x) => {\r\n      const parts = x.split(\"|\");\r\n      this.debugLog('stringToValuePair() - parts', parts);\r\n      this.debugLog('stringToValuePair() - parts.lenght', parts.length);\r\n      if(parts.length == 1){\r\n        valuePairs[parts[0].trim()] = parts[0].trim();\r\n      } else if (parts.length > 1){\r\n        this.debugLog('stringToValuePair() - parts[0].trim()', parts[0].trim());\r\n        this.debugLog('stringToValuePair() - parts[1].trim()', parts[1].trim());\r\n        valuePairs[parts[0].trim()] = parts[1].trim();\r\n      }\r\n    })\r\n    this.debugLog('stringToValuePair() - valuePairs', valuePairs)\r\n    return valuePairs;\r\n  }\r\n\r\n}\r\n","<eqp-select [ngStyle]=\"FieldstyleObj\" *ngIf=\"field.PresentationMode == ListPresentationEnum['Combo box']\" [arrayData]=\"arrayData\"\r\n    [arrayKeyProperty]=\"'Value'\" [showCancelButton]=\"!field.Required\" [arrayValueProperty]=\"'Key'\"\r\n    [formGroupInput]=\"field.FormFormGroup\" [formControlNameInput]=\"field.Name\" [placeholder]=\"field.Description\"\r\n    [includeFullObject]=\"false\" [isRequired]=\"field.Required\" [isDisabled]=\"field.FormFormGroup.disabled\"\r\n    [(ngModelInput)]=\"record[field.Name]\" [isMultiSelect]=\"field.IsMultiChoiche\"\r\n    (ngModelInputChange)=\"onRecordValueChange()\">\r\n</eqp-select>\r\n\r\n<div *ngIf=\"field.PresentationMode != ListPresentationEnum['Combo box']\" [formGroup]=\"field.FormFormGroup\">\r\n\r\n    <mat-label class=\"mr-3 ps-3\" [ngStyle]=\"LabelstyleObj\"> {{field.Description + (field.Required ? \" *\" : \"\")}} </mat-label>\r\n    <!-- VISUALIZZAZIONE A RADIO BUTTON (SENZA SELEZIONE MULTIPLA) -->\r\n    <mat-radio-group [ngStyle]=\"FieldstyleObj\" *ngIf=\"field.PresentationMode == ListPresentationEnum['Radio button'] && !field.IsMultiChoiche\"\r\n        [formControlName]=\"field.Name\" [disabled]=\"field.FormFormGroup.disabled\" [required]=\"field.Required\"\r\n        [(ngModel)]=\"record[field.Name]\" (ngModelChange)=\"onRecordValueChange()\">\r\n        <mat-radio-button class=\"ms-3 d-block\" *ngFor=\"let data of arrayData\" [value]=\"data.Value\" color=\"primary\">\r\n            {{data.Key}}\r\n        </mat-radio-button>\r\n    </mat-radio-group>\r\n\r\n    <!-- VISUALIZZAZIONE A CHECKBOX (SELEZIONE MULTIPLA) -->\r\n    <div class=\"d-inline-block\"\r\n        *ngIf=\"field.PresentationMode == ListPresentationEnum['Radio button'] && field.IsMultiChoiche\">\r\n        <mat-checkbox  [ngStyle]=\"FieldstyleObj\" class=\"mr-2\" *ngFor=\"let data of arrayData\" [disabled]=\"field.FormFormGroup.disabled\"\r\n            [formControlName]=\"field.Name\" [(ngModel)]=\"data.Selected\" (ngModelChange)=\"updateSelected()\">\r\n            {{data.Key}}\r\n        </mat-checkbox>\r\n    </div>\r\n\r\n    <!-- VISUALIZZAZIONE A PULSANTI (CON TESTO O IMMAGINI) -->\r\n    <div class=\"d-inline-block\"\r\n        *ngIf=\"[ListPresentationEnum['Pulsante con testo'], ListPresentationEnum.Immagini].includes(field.PresentationMode)\">\r\n        <button [ngStyle]=\"FieldstyleObj\" mat-raised-button color=\"primary\" class=\"btn btn-primary m-1 data-button\" *ngFor=\"let data of arrayData\"\r\n            [ngClass]=\"{'selected-button': data.Selected == true, 'p-0': field.PresentationMode == ListPresentationEnum.Immagini}\"\r\n            (click)=\"buttonSelectClick(data)\" [disabled]=\"field.FormFormGroup.disabled\">\r\n\r\n            <!-- TESTO DEL PULSANTE -->\r\n            <span *ngIf=\"field.PresentationMode == ListPresentationEnum['Pulsante con testo']\"> {{data.Key}}</span>\r\n\r\n            <!-- IMMAGINE DEL PULSANTE -->\r\n            <img *ngIf=\"field.PresentationMode == ListPresentationEnum.Immagini\" [src]=\"data.ImgUrl\">\r\n        </button>\r\n    </div>\r\n\r\n</div>"]}
|
|
200
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-value-field-template.component.js","sourceRoot":"","sources":["../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/list-value-field-template/list-value-field-template.component.ts","../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/list-value-field-template/list-value-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 { ListPresentationEnum, ListValueField } from '../../../../models/fields/listValueField.model';\r\nimport { IBaseFieldComponent } from '../../../../interfaces/iBaseFieldComponent.interface';\r\nimport { UtilityHelperService } from '../../../../services/utilityHelper.services';\r\n\r\n@Component({\r\n  selector: 'list-value-field-template',\r\n  templateUrl: './list-value-field-template.component.html',\r\n  styleUrls: ['./list-value-field-template.component.scss']\r\n})\r\nexport class ListValueFieldTemplateComponent implements OnInit, OnChanges, IBaseFieldComponent {\r\n\r\n  @Input() debugMode: boolean = false;\r\n  debugLog(message: string, element?: any) {\r\n    if (this.debugMode) {\r\n      console.log(message, element)\r\n    }\r\n  }\r\n\r\n  @Input() field: ListValueField;\r\n  @Input() record: Record;\r\n  @Output() recordChange: EventEmitter<Record> = new EventEmitter<Record>();\r\n  ListPresentationEnum = ListPresentationEnum;\r\n  arrayData: { Key: string, Value: any, Selected?: boolean, ImgUrl?: string }[] = [];\r\n  //variabili per gestire il css della label e del field\r\n  FieldstyleObj: any;\r\n  LabelstyleObj: any;\r\n  constructor() { }\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.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)\r\n      this.LabelstyleObj = UtilityHelperService.initStyles(this.field.LabelstyleCSS);\r\n  }\r\n  ngOnInit(): void {\r\n    this.debugLog(\"combobox debugMode\", this.debugMode);\r\n    this.debugLog(\"combobox filed\", this.field);\r\n    this.updateField();\r\n    this.setArrayData();\r\n    if (this.field.IsMultiChoiche && !this.record[this.field.Name]) {\r\n      this.record[this.field.Name] = [];\r\n    }\r\n    // Nel caso in cui sono in modifica di un Record aggiorno il valore\r\n    // e il validator del FormControl. Se non viene eseguita questa riga\r\n    // l'utente deve modificare la selezione fatta per aggiornare la form.\r\n    this.setFormControlValue();\r\n    this.initStyles();\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    // devo controllare se ho la stringa (ValueString) o il dizionario (ValuePairs)\r\n    this.debugLog(\"list-value-field updateField\", this.field)\r\n    if (this.field.Formula) {\r\n      this.debugLog(\"list-value-field - updateField - Formula\")\r\n      this.field.ValuePairs = {};\r\n      const temp: string = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, null);\r\n      // temp dovrebbe essere una stringa del tipo \"chiave1! valore 1 ; chiave2 | valore 2 \"\r\n      // dobbiamo ottenere un dizionario di quei valori\r\n      this.field.ValuePairs = this.stringToValuePairs(temp);\r\n\r\n      // for (var key in matches) {\r\n      //   if(UtilityHelperService.isNumeric(temp[key])){\r\n      //     this.field.ValuePairs[key] = Number(temp[key]);\r\n      //   }else{\r\n      //     this.field.ValuePairs[key] = temp[key];\r\n      //   }\r\n      // }\r\n\r\n      //   this.setArrayData();\r\n      //this.record[this.field.Name] = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, null);\r\n    } else if (this.field.ValuePairs != null && this.field.ValuePairs.lenght > 0) {\r\n      this.debugLog(\"list-value-field - updateField - ValuePairs\")\r\n\r\n    } else if (this.field.ValueString != null && this.field.ValueString != \"\") {\r\n      this.debugLog(\"list-value-field - updateField - ValueString\")\r\n      this.field.ValuePairs = this.stringToValuePairs(this.field.ValueString);\r\n\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  }\r\n\r\n  /**\r\n   * Metodo invocato quando viene selezionata un'opzione nella visualizzazione a button\r\n   * @param data Rappresenta l'oggetto selezionato\r\n   */\r\n  buttonSelectClick(data: { Key: string, Value: string, Selected?: boolean, ImgUrl?: string }) {\r\n    data.Selected = !data.Selected;\r\n    if (this.field.IsMultiChoiche) {\r\n      this.updateSelected(false);\r\n    } else {\r\n      this.arrayData.filter(d => d.Key != data.Key && d.Value != data.Value).forEach(d => d.Selected = false);\r\n\r\n      if (UtilityHelperService.isNumeric(data.Value)) {\r\n\r\n        this.record[this.field.Name] = Number(data.Value);\r\n      }\r\n      else {\r\n        this.record[this.field.Name] = data.Value;\r\n      }\r\n\r\n    }\r\n    this.onRecordValueChange();\r\n  }\r\n\r\n  /**\r\n   * Metodo per aggiornare il/i valore/i selezionato/i dall'utente.\r\n   * @param emitChange Se true scatena l'evento di output della modifica del valore di record\r\n   */\r\n  updateSelected(emitChange: boolean = true) {\r\n    this.record[this.field.Name] = this.arrayData.filter(data => data.Selected).map(data => data.Value);\r\n    this.setFormControlValue();\r\n    if (emitChange) {\r\n      this.onRecordValueChange();\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    this.recordChange.emit(this.record);\r\n  }\r\n\r\n  /**\r\n   * Metodo per creare un array di oggetti del tipo { Key: string, Value: any } da usare come sorgente dati per la eqp-select.\r\n   */\r\n  private setArrayData() {\r\n    if (this.field.PresentationMode != ListPresentationEnum.Immagini) {\r\n      if (UtilityHelperService.isNumeric(this.field.ValuePairs[Object.keys(this.field.ValuePairs)[0]])) {\r\n        Object.keys(this.field.ValuePairs).forEach\r\n          (k => this.createNumberArrayDataElement(k, Number(this.field.ValuePairs[k])));\r\n      } else {\r\n        Object.keys(this.field.ValuePairs).forEach\r\n          (k => this.createArrayDataElement(k, this.field.ValuePairs[k]));\r\n      }\r\n\r\n    } else {\r\n      this.field.ButtonImageList.forEach(i => { this.createArrayDataElement(i.ButtonKey, i.ButtonValue, 'data:' + i.FileContentType + ';base64,' + i.FileDataBase64); });\r\n    }\r\n  }\r\n\r\n  private createArrayDataElement(key: string, value: string, imgUrl: string = null) {\r\n    let isOptionSelected: boolean;\r\n    if (this.field.IsMultiChoiche && this.record[this.field.Name] && this.record[this.field.Name].length > 0) {\r\n      isOptionSelected = !!this.record[this.field.Name].find(v => v == value);\r\n    } else {\r\n      isOptionSelected = this.record[this.field.Name] === value;\r\n    }\r\n    this.arrayData.push({ Key: key, Value: value, Selected: isOptionSelected, ImgUrl: imgUrl });\r\n  }\r\n\r\n  private createNumberArrayDataElement(key: string, value: number, imgUrl: string = null) {\r\n    let isOptionSelected: boolean;\r\n    if (this.field.IsMultiChoiche && this.record[this.field.Name] && this.record[this.field.Name].length > 0) {\r\n      isOptionSelected = !!this.record[this.field.Name].find(v => v == value);\r\n    } else {\r\n      isOptionSelected = this.record[this.field.Name] === value;\r\n    }\r\n    this.arrayData.push({ Key: key, Value: value, Selected: isOptionSelected, ImgUrl: imgUrl });\r\n  }\r\n  /**\r\n   * Metodo per aggiornare il valore e il validator del FormControl associato al campo.\r\n   */\r\n  private setFormControlValue() {\r\n    this.field.FormFormGroup.controls[this.field.Name].setValue(this.record[this.field.Name]);\r\n  }\r\n\r\n\r\n  private stringToValuePairs(valueString: string) {\r\n    const valuePairs: { [key: string]: string } = {};\r\n    this.debugLog('stringToValuePair() - this.field.Formula temp', valueString)\r\n    const keyvals = valueString.split(\";\");\r\n    keyvals.forEach((x) => {\r\n      const parts = x.split(\"|\");\r\n      this.debugLog('stringToValuePair() - parts', parts);\r\n      this.debugLog('stringToValuePair() - parts.lenght', parts.length);\r\n      if(parts.length == 1){\r\n        valuePairs[parts[0].trim()] = parts[0].trim();\r\n      } else if (parts.length > 1){\r\n        this.debugLog('stringToValuePair() - parts[0].trim()', parts[0].trim());\r\n        this.debugLog('stringToValuePair() - parts[1].trim()', parts[1].trim());\r\n        valuePairs[parts[0].trim()] = parts[1].trim();\r\n      }\r\n    })\r\n    this.debugLog('stringToValuePair() - valuePairs', valuePairs)\r\n    return valuePairs;\r\n  }\r\n\r\n}\r\n","<eqp-select [ngStyle]=\"FieldstyleObj\" *ngIf=\"field.PresentationMode == ListPresentationEnum['Combo box']\" [arrayData]=\"arrayData\"\r\n    [arrayKeyProperty]=\"'Value'\" [showCancelButton]=\"!field.Required\" [arrayValueProperty]=\"'Key'\"\r\n    [formGroupInput]=\"field.FormFormGroup\" [formControlNameInput]=\"field.Name\" [placeholder]=\"field.Description\"\r\n    [includeFullObject]=\"false\" [isRequired]=\"field.Required\" [isDisabled]=\"field.FormFormGroup.disabled\"\r\n    [(ngModelInput)]=\"record[field.Name]\" [isMultiSelect]=\"field.IsMultiChoiche\"\r\n    (ngModelInputChange)=\"onRecordValueChange()\">\r\n</eqp-select>\r\n\r\n<div *ngIf=\"field.PresentationMode != ListPresentationEnum['Combo box']\" [formGroup]=\"field.FormFormGroup\">\r\n\r\n    <mat-label class=\"mr-3 ps-3\" [ngStyle]=\"LabelstyleObj\"> {{field.Description + (field.Required ? \" *\" : \"\")}} </mat-label>\r\n    <!-- VISUALIZZAZIONE A RADIO BUTTON (SENZA SELEZIONE MULTIPLA) -->\r\n    <mat-radio-group [ngStyle]=\"FieldstyleObj\" *ngIf=\"field.PresentationMode == ListPresentationEnum['Radio button'] && !field.IsMultiChoiche\"\r\n        [formControlName]=\"field.Name\" [disabled]=\"field.FormFormGroup.disabled\" [required]=\"field.Required\"\r\n        [(ngModel)]=\"record[field.Name]\" (ngModelChange)=\"onRecordValueChange()\">\r\n        <mat-radio-button class=\"ms-3 d-block\" *ngFor=\"let data of arrayData\" [value]=\"data.Value\" color=\"primary\">\r\n            {{data.Key}}\r\n        </mat-radio-button>\r\n    </mat-radio-group>\r\n\r\n    <!-- VISUALIZZAZIONE A CHECKBOX (SELEZIONE MULTIPLA) -->\r\n    <div class=\"d-inline-block\"\r\n        *ngIf=\"field.PresentationMode == ListPresentationEnum['Radio button'] && field.IsMultiChoiche\">\r\n        <mat-checkbox  [ngStyle]=\"FieldstyleObj\" class=\"mr-2\" *ngFor=\"let data of arrayData\" [disabled]=\"field.FormFormGroup.disabled\"\r\n            [formControlName]=\"field.Name\" [(ngModel)]=\"data.Selected\" (ngModelChange)=\"updateSelected()\">\r\n            {{data.Key}}\r\n        </mat-checkbox>\r\n    </div>\r\n\r\n    <!-- VISUALIZZAZIONE A PULSANTI (CON TESTO O IMMAGINI) -->\r\n    <div class=\"d-inline-block\"\r\n        *ngIf=\"[ListPresentationEnum['Pulsante con testo'], ListPresentationEnum.Immagini].includes(field.PresentationMode)\">\r\n        <button [ngStyle]=\"FieldstyleObj\" mat-raised-button color=\"primary\" class=\"btn btn-primary m-1 data-button\" *ngFor=\"let data of arrayData\"\r\n            [ngClass]=\"{'selected-button': data.Selected == true, 'p-0': field.PresentationMode == ListPresentationEnum.Immagini}\"\r\n            (click)=\"buttonSelectClick(data)\" [disabled]=\"field.FormFormGroup.disabled\">\r\n\r\n            <!-- TESTO DEL PULSANTE -->\r\n            <span *ngIf=\"field.PresentationMode == ListPresentationEnum['Pulsante con testo']\"> {{data.Key}}</span>\r\n\r\n            <!-- IMMAGINE DEL PULSANTE -->\r\n            <img *ngIf=\"field.PresentationMode == ListPresentationEnum.Immagini\" [src]=\"data.ImgUrl\">\r\n        </button>\r\n    </div>\r\n\r\n</div>"]}
|
|
@@ -2052,9 +2052,8 @@ class ListValueFieldTemplateComponent {
|
|
|
2052
2052
|
this.LabelstyleObj = UtilityHelperService.initStyles(this.field.LabelstyleCSS);
|
|
2053
2053
|
}
|
|
2054
2054
|
ngOnInit() {
|
|
2055
|
-
|
|
2056
|
-
|
|
2057
|
-
alert("meeee");
|
|
2055
|
+
this.debugLog("combobox debugMode", this.debugMode);
|
|
2056
|
+
this.debugLog("combobox filed", this.field);
|
|
2058
2057
|
this.updateField();
|
|
2059
2058
|
this.setArrayData();
|
|
2060
2059
|
if (this.field.IsMultiChoiche && !this.record[this.field.Name]) {
|