@eqproject/eqp-dynamic-module 1.0.5 → 1.0.6

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.
@@ -201,6 +201,22 @@ export class AddFormFieldComponent {
201
201
  this.fieldFormGroup.controls["Formula"].enable();
202
202
  this.fieldFormGroup.controls["InListView"].enable();
203
203
  }
204
+ if ([FieldTypeEnum.Allegato, FieldTypeEnum.Immagine, FieldTypeEnum['Form di dettaglio'], FieldTypeEnum['Data e/o ora']].includes(this.field.FieldType)) {
205
+ this.field.Formula = null;
206
+ this.fieldFormGroup.controls["LabelstyleCSS"].disable();
207
+ this.fieldFormGroup.controls["FieldstyleCSS"].disable();
208
+ }
209
+ else {
210
+ this.fieldFormGroup.controls["LabelstyleCSS"].enable();
211
+ this.fieldFormGroup.controls["FieldstyleCSS"].enable();
212
+ }
213
+ if ([FieldTypeEnum.Booleano].includes(this.field.FieldType)) {
214
+ this.field.Formula = null;
215
+ this.fieldFormGroup.controls["LabelstyleCSS"].disable();
216
+ }
217
+ else {
218
+ this.fieldFormGroup.controls["LabelstyleCSS"].enable();
219
+ }
204
220
  }
205
221
  /**
206
222
  * Metodo invocato al cambio del valore della proprietà ImageIsContextualAttachment nel caso
@@ -606,4 +622,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.8", ngImpor
606
622
  type: ViewChild,
607
623
  args: ['buttonImagesKeyValueInputColumn', { static: true }]
608
624
  }] } });
609
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-form-field.component.js","sourceRoot":"","sources":["../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/add-form-field/add-form-field.component.ts","../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/add-form-field/add-form-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, EventEmitter, Input, OnInit, Output, TemplateRef, ViewChild } from '@angular/core';\r\nimport { UntypedFormBuilder, UntypedFormControl, UntypedFormGroup, Validators } from '@angular/forms';\r\nimport { MatDialog, MatDialogRef } from '@angular/material/dialog';\r\nimport { AttachmentType, EqpAttachmentsComponent, IAttachmentDTO } from '@eqproject/eqp-attachments';\r\nimport { PickerModeEnum } from '@eqproject/eqp-datetimepicker';\r\nimport { EnumHelper } from '@eqproject/eqp-select';\r\nimport { CellAlignmentEnum, ConfigColumn, EqpTableComponent, TypeColumn } from '@eqproject/eqp-table';\r\nimport { BaseField, ColSpanSizesEnum, FieldTypeEnum } from '../../../models/baseField.model';\r\nimport { AttachmentField, AvailableFileExtensions, AvailableImageExtensions } from '../../../models/fields/attachmentField.model';\r\nimport { BooleanField, BoolPresentantioEnum } from '../../../models/fields/booleanField.model';\r\nimport { DateField, DateTimeTypeEnum } from '../../../models/fields/dateField.model';\r\nimport { ImageField } from '../../../models/fields/imageField.model';\r\nimport { ButtonImage, ListPresentationEnum, ListValueField } from '../../../models/fields/listValueField.model';\r\nimport { LookupField } from '../../../models/fields/lookupField.model';\r\nimport { NumericField } from '../../../models/fields/numericField.model';\r\nimport { TextareaField } from '../../../models/fields/textareaField.model';\r\nimport { TextMaskEnum, TextField } from '../../../models/fields/textField.model';\r\nimport { FormFieldGroup } from '../../../models/form.model';\r\nimport { EqpDynamicModuleDialogService } from '../../../services/eqp-dynamic-module-dialog.service';\r\nimport { UtilityHelperService } from '../../../services/utilityHelper.services';\r\n\r\n@Component({\r\n  selector: 'eqp-dynamic-module-add-form-field',\r\n  templateUrl: './add-form-field.component.html',\r\n  styleUrls: ['./add-form-field.component.scss']\r\n})\r\nexport class AddFormFieldComponent implements OnInit {\r\n\r\n  @Input() field: BaseField | any;\r\n  @Input() indexField: number;\r\n  @Input() formFieldsGroups: Array<FormFieldGroup>;\r\n  /** Elenco dei Field creati nella form, usati per popolare l'autocomplete della proprietà Formula. */\r\n  @Input() availableFields: Array<BaseField>;\r\n  @Input() fieldTypesToExclude: Array<FieldTypeEnum> = [FieldTypeEnum['Form di dettaglio']];\r\n\r\n  fieldFormGroup: UntypedFormGroup;\r\n  keyValueObject: { key: string, value: string } = { key: '', value: '' };\r\n  availableColSpanSizes: Array<ColSpanSizesEnum> = [];\r\n  formulaAutocompleteOptions: Array<{ label: string, value: string }>;\r\n  VisibleIfAutocompleteOptions:Array<{ label: string, value: string }>;\r\n  AvailableFileExtensions = AvailableFileExtensions;\r\n  AvailableImageExtensions = AvailableImageExtensions;\r\n  \r\n  @Output() saveFieldEvent: EventEmitter<BaseField | any> = new EventEmitter<BaseField | any>();\r\n\r\n  //#region Template dei vari pezzi di form per la creazione di un campo(in base al tipo scelto).\r\n  fieldTypeFormTemplate: TemplateRef<any>;\r\n  @ViewChild('textFieldFormTemplate', { static: true }) textFieldFormTemplate: TemplateRef<any>;\r\n  @ViewChild('textareaFieldFormTemplate', { static: true }) textareaFieldFormTemplate: TemplateRef<any>;\r\n  @ViewChild('booleadFieldFormTemplate', { static: true }) booleadFieldFormTemplate: TemplateRef<any>;\r\n  @ViewChild('dateFieldFormTemplate', { static: true }) dateFieldFormTemplate: TemplateRef<any>;\r\n  @ViewChild('numericFieldFormTemplate', { static: true }) numericFieldFormTemplate: TemplateRef<any>;\r\n  @ViewChild('attachmentFieldFormTemplate', { static: true }) attachmentFieldFormTemplate: TemplateRef<any>;\r\n  @ViewChild('imageFieldFormTemplate', { static: true }) imageFieldFormTemplate: TemplateRef<any>;\r\n  @ViewChild('listValueFieldFormTemplate', { static: true }) listValueFieldFormTemplate: TemplateRef<any>;\r\n  @ViewChild('lookupFieldFormTemplate', { static: true }) lookupFieldFormTemplate: TemplateRef<any>;\r\n  //#endregion\r\n\r\n  //#region Proprietà per gestire i metadata nei campi ti dipo Allegato o Immagine\r\n  metadataColumns: Array<ConfigColumn>;\r\n  @ViewChild('metadataFieldsTable', { static: false }) metadataFieldsTable: EqpTableComponent;\r\n  selectedMetadata: BaseField;\r\n  indexSelectedMetadata: number;\r\n  dialogMetadataRef: MatDialogRef<TemplateRef<any>>;\r\n  @ViewChild('dialogMetadata', { static: true }) dialogMetadata: TemplateRef<any>;\r\n  //#endregion\r\n\r\n  //#region Proprietà per gestire le immagini nei capi di tipo elenco generico\r\n  @ViewChild('buttonImagesKeyValueInputColumn', { static: true }) buttonImagesKeyValueInputColumn: TemplateRef<any>;\r\n  //#endregion\r\n\r\n  //#region Enumeratori usati nell'html\r\n  FieldTypeEnum = FieldTypeEnum;\r\n  BoolPresentantioEnum = BoolPresentantioEnum;\r\n  DateTimeTypeEnum = DateTimeTypeEnum;\r\n  ListPresentationEnum = ListPresentationEnum;\r\n  TextMaskEnum = TextMaskEnum;\r\n  AttachmentType = AttachmentType;\r\n  pickerModeEnum = PickerModeEnum;\r\n  //#endregion\r\n\r\n  constructor(\r\n    private formBuilder: UntypedFormBuilder,\r\n    private enumHelper: EnumHelper,\r\n    private dialog: MatDialog,\r\n    private cdr: ChangeDetectorRef\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    if (!this.fieldTypesToExclude.includes(FieldTypeEnum['Form di dettaglio'])) {\r\n      this.fieldTypesToExclude.push(FieldTypeEnum['Form di dettaglio']);\r\n    }\r\n\r\n    this.onFieldTypeChange(false);\r\n    this.availableFields = this.availableFields ? this.availableFields.filter(f => f != this.field) : [];\r\n    this.configureColumns();\r\n  }\r\n\r\n  /**\r\n   * Metodo per impostare i valori da suggerire nell'autocomplete del campo Formula.\r\n   * Viene scatenato al focus (in questo caso viene passato il parametro a null per differenziarlo\r\n   * dall'evento di click sulla tastiera) e al keyup sull'input (il parametro è diverso da null).\r\n   * @param keyboardEvent Evento scatenato al keyup sulla tastiera. Se null allora il metodo è stato invocato dal focus sull'input.\r\n   * @summary Aggiorna l'elenco dei suggerimenti per l'autocomplete se l'utente esegue il focus sull'input\r\n   * oppure al keyup sulla tastiera di un tasto diverso dalle frecce.\r\n   */\r\n  setFormulaAutocompleteOptions(keyboardEvent: KeyboardEvent) {\r\n    // Creo l'array per l'autocomplete solo se sto facendo il focus sull'input o se sto premendo un tasto\r\n    // sulla tastiera diverso dalle frecce (in quest'ultimo caso, se non viene eseguito il filtro sull'evento,\r\n    // non si può selezionare un suggerimento dell'autocomplete perchè al click verrebbe ricaricato l'array e\r\n    // si prederebbe la selezione appena fatta).\r\n    if (!keyboardEvent || !keyboardEvent.code.includes(\"Arrow\")) {\r\n      this.formulaAutocompleteOptions = UtilityHelperService.GetAutocompleteOptions(this.availableFields, this.field.Formula);\r\n    }\r\n  }\r\n  setVisibleIfAutocompleteOptions(keyboardEvent: KeyboardEvent) {\r\n    // Creo l'array per l'autocomplete solo se sto facendo il focus sull'input o se sto premendo un tasto\r\n    // sulla tastiera diverso dalle frecce (in quest'ultimo caso, se non viene eseguito il filtro sull'evento,\r\n    // non si può selezionare un suggerimento dell'autocomplete perchè al click verrebbe ricaricato l'array e\r\n    // si prederebbe la selezione appena fatta).\r\n    if (!keyboardEvent || !keyboardEvent.code.includes(\"Arrow\")) {\r\n      this.VisibleIfAutocompleteOptions = UtilityHelperService.GetAutocompleteOptions(this.availableFields, this.field.VisibleIf);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Crea il FormGroup per l'aggiunta di un nuovo campo all'interno della form.\r\n   * Metodo richiamato ogni volta che cambia il tipo del campo scelto o viene aggiunto/modificato un Field\r\n   */\r\n  createFieldForm() {\r\n    this.fieldFormGroup = this.formBuilder.group({\r\n      Label: [this.field.Label, Validators.required],\r\n      Description: [this.field.Description, Validators.required],\r\n      Readonly: [this.field.Readonly],\r\n      Required: [this.field.Required],\r\n      VisibleIf: [this.field.VisibleIf],\r\n      Tooltip: [this.field.Tooltip],\r\n      LabelstyleCSS: [this.field.LabelstyleCSS],\r\n      FieldstyleCSS: [this.field.FieldstyleCSS],\r\n      FieldType: [this.field.FieldType, Validators.required],\r\n      Formula: [this.field.Formula],\r\n      ColSpanSizes: [this.field.ColSpanSizes],\r\n      InListView: [this.field.InListView],\r\n    });\r\n\r\n    if (this.formFieldsGroups) {\r\n      this.fieldFormGroup.addControl('FieldGroup', new UntypedFormControl(this.field.FieldGroup, Validators.required));\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo chiamato quando cambia il FieldType del BaseField che si sta aggiungendo/modificando.\r\n   * Ricrea l'oggetto field popolando solo le proprietà del BaseField inserite dall'utente\r\n   * (quelle comuni a tutte le tipologie di campo), ricrea la form e, in base al FieldType scelto,\r\n   * aggiunge alla form i FormControl necessari e seleziona il template corretto da usare.\r\n   * @param restoreField Se TRUE ripristina i valori base (ereditati dal modello BaseField) del campo aggiunto/modificato\r\n   */\r\n  onFieldTypeChange(restoreField: boolean = true) {\r\n    if (restoreField) {\r\n      this.restoreBaseFieldProperties();\r\n    } \r\n\r\n    this.createFieldForm();\r\n    this.onColSpanSizeSelect();\r\n    if ((this.field as BaseField).InListView == null) {\r\n      this.field.InListView = true;\r\n    }\r\n    this.fieldTypeFormTemplate = null;\r\n    switch (this.field.FieldType) {\r\n      case FieldTypeEnum['Campo di testo']:\r\n        this.fieldFormGroup.addControl('TextMask', new UntypedFormControl((this.field as TextField).TextMask));\r\n        this.fieldFormGroup.addControl('MaxLenght', new UntypedFormControl((this.field as TextField).MaxLenght));\r\n        this.fieldFormGroup.addControl('MinLenght', new UntypedFormControl((this.field as TextField).MinLenght));\r\n        this.fieldTypeFormTemplate = this.textFieldFormTemplate;\r\n        break;\r\n      case FieldTypeEnum['Area di testo']:\r\n        this.fieldFormGroup.addControl('Rows', new UntypedFormControl((this.field as TextareaField).Rows));\r\n        this.fieldFormGroup.addControl('MaxLenght', new UntypedFormControl((this.field as TextareaField).MaxLenght));\r\n        this.fieldFormGroup.addControl('MinLenght', new UntypedFormControl((this.field as TextareaField).MinLenght));\r\n        this.fieldTypeFormTemplate = this.textareaFieldFormTemplate;\r\n        break;\r\n      case FieldTypeEnum.Booleano:\r\n        this.fieldFormGroup.addControl('IsTristate', new UntypedFormControl((this.field as BooleanField).IsTristate));\r\n        this.fieldFormGroup.addControl(\r\n          'PresetationType',\r\n          new UntypedFormControl((this.field as BooleanField).PresetationType, Validators.required)\r\n        );\r\n        this.fieldTypeFormTemplate = this.booleadFieldFormTemplate;\r\n        break;\r\n      case FieldTypeEnum['Data e/o ora']:\r\n        if (this.field.IsOnlyDate == null ) {\r\n          this.field.IsOnlyDate = DateTimeTypeEnum['Solo data'];\r\n        }\r\n        this.fieldFormGroup.addControl('IsOnlyDate', new UntypedFormControl((this.field as DateField).IsOnlyDate, Validators.required));\r\n        this.fieldFormGroup.addControl('MinDate', new UntypedFormControl((this.field as DateField).MinDate));\r\n        this.fieldFormGroup.addControl('MaxDate', new UntypedFormControl((this.field as DateField).MaxDate));\r\n        this.fieldFormGroup.addControl('DateFormat', new UntypedFormControl((this.field as DateField).DateFormat));\r\n        this.fieldTypeFormTemplate = this.dateFieldFormTemplate;\r\n        break;\r\n      case FieldTypeEnum['Campo numerico']:\r\n        if ((this.field as NumericField).IsInteger == null) {\r\n          this.field.IsInteger = true;\r\n        }\r\n        this.fieldFormGroup.addControl('IsInteger', new UntypedFormControl((this.field as NumericField).IsInteger));\r\n        this.fieldFormGroup.addControl('MinValue', new UntypedFormControl((this.field as NumericField).MinValue));\r\n        this.fieldFormGroup.addControl('MaxValue', new UntypedFormControl((this.field as NumericField).MaxValue));\r\n        this.fieldFormGroup.addControl('DecimalSeparator', new UntypedFormControl((this.field as NumericField).DecimalSeparator));\r\n        this.fieldFormGroup.addControl('DecimalPrecision', new UntypedFormControl((this.field as NumericField).DecimalPrecision));\r\n        this.fieldFormGroup.addControl('ThousandsSeparator', new UntypedFormControl((this.field as NumericField).ThousandsSeparator));\r\n        this.fieldFormGroup.addControl('CurrencySymbol', new UntypedFormControl((this.field as NumericField).CurrencySymbol));\r\n        this.fieldTypeFormTemplate = this.numericFieldFormTemplate;\r\n        break;\r\n      case FieldTypeEnum.Allegato:\r\n        this.fieldFormGroup.addControl(\"AllowedExtensions\", new UntypedFormControl((this.field as AttachmentField).AllowedExtensions));\r\n        this.fieldFormGroup.addControl('IsMultiAttach', new UntypedFormControl((this.field as AttachmentField).IsMultiAttach));\r\n        this.fieldTypeFormTemplate = this.attachmentFieldFormTemplate;\r\n        break;\r\n      case FieldTypeEnum.Immagine:\r\n        (this.field as ImageField).AttachDefinition = new AttachmentField();\r\n        this.fieldFormGroup.addControl('EnableDrawing', new UntypedFormControl((this.field as ImageField).EnableDrawing));\r\n        this.fieldFormGroup.addControl('ImageIsContextualAttachment', new UntypedFormControl((this.field as ImageField).ImageIsContextualAttachment));\r\n        // Imposto i FormControl variabili.\r\n        this.onImageIsContextualAttachmentChange();\r\n        this.fieldTypeFormTemplate = this.imageFieldFormTemplate;\r\n        break;\r\n      case FieldTypeEnum['Elenco generico']:\r\n        if ((this.field as ListValueField).InListView == null) {\r\n          this.field.InListView = true;\r\n        }\r\n        this.fieldFormGroup.addControl('IsMultiChoiche', new UntypedFormControl((this.field as ListValueField).IsMultiChoiche));\r\n        this.fieldFormGroup.addControl(\r\n          'PresentationMode',\r\n          new UntypedFormControl((this.field as ListValueField).PresentationMode, Validators.required)\r\n        );\r\n        this.fieldTypeFormTemplate = this.listValueFieldFormTemplate;\r\n        break;\r\n      case FieldTypeEnum.Lookup:\r\n        this.fieldFormGroup.addControl(\r\n          'EntitySourceName',\r\n          new UntypedFormControl((this.field as LookupField).EntitySourceName, Validators.required)\r\n        );\r\n        this.fieldFormGroup.addControl('UseAsGetOrDiscard', new UntypedFormControl((this.field as LookupField).UseAsGetOrDiscard));\r\n        this.fieldTypeFormTemplate = this.lookupFieldFormTemplate;\r\n        break;\r\n    }\r\n    if ([FieldTypeEnum.Allegato, FieldTypeEnum.Immagine, FieldTypeEnum['Form di dettaglio']].includes(this.field.FieldType)) {\r\n      this.field.Formula = null;\r\n      this.fieldFormGroup.controls[\"Formula\"].disable();\r\n      this.fieldFormGroup.controls[\"InListView\"].disable();\r\n    } else {\r\n      this.fieldFormGroup.controls[\"Formula\"].enable();\r\n      this.fieldFormGroup.controls[\"InListView\"].enable();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo invocato al cambio del valore della proprietà ImageIsContextualAttachment nel caso\r\n   * di campi di tipo Immagine. Se TRUE allora rimuove i FormControl per le proprietà IsMultiAttach\r\n   * e AllowedExtensions e aggiunge i FormControl per le proprietà ImgName e ContextualAttachment, \r\n   * altrimenti il contrario.\r\n   */\r\n  onImageIsContextualAttachmentChange() {\r\n    (this.field as ImageField).ImgName = null;\r\n    (this.field as ImageField).AttachDefinition.AllowedExtensions = [];\r\n    (this.field as ImageField).AttachDefinition.IsMultiAttach = false;\r\n    (this.field as ImageField).ContextualAttachment = null;\r\n\r\n    if ((this.field as ImageField).ImageIsContextualAttachment) {\r\n      this.fieldFormGroup.removeControl(\"IsMultiAttach\");\r\n      this.fieldFormGroup.removeControl(\"AllowedExtensions\");\r\n      this.fieldFormGroup.addControl('ImgName', new UntypedFormControl((this.field as ImageField).ImgName, Validators.required));\r\n      this.fieldFormGroup.addControl('ContextualAttachment', new UntypedFormControl((this.field as ImageField).ContextualAttachment, Validators.required));\r\n    } else {\r\n      this.fieldFormGroup.removeControl(\"ImgName\");\r\n      this.fieldFormGroup.removeControl(\"ContextualAttachment\");\r\n      this.fieldFormGroup.addControl('IsMultiAttach', new UntypedFormControl((this.field as ImageField).AttachDefinition.IsMultiAttach));\r\n      this.fieldFormGroup.addControl(\"AllowedExtensions\", new UntypedFormControl((this.field as ImageField).AttachDefinition.AllowedExtensions));\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per intercettare l'aggiunta di un allegato nei campi di tipo Immagine per aggiornare\r\n   * il valore della proprietà ContextualAttachment e la validazione del relativo FormControl.\r\n   * @param event Array contenente l'elenco aggiornato degli allegati caricati (nel nostro caso ne contiene al più 1).\r\n   */\r\n  catchContextualAttachmentChange(event: Array<IAttachmentDTO>) {\r\n    if (event && event.length > 0) {\r\n      (this.field as ImageField).ContextualAttachment = event[0];\r\n    } else {\r\n      (this.field as ImageField).ContextualAttachment = null;\r\n    }\r\n    this.fieldFormGroup.controls['ContextualAttachment'].setValue((this.field as ImageField).ContextualAttachment);\r\n  }\r\n\r\n  /**\r\n   * Metodo invocato alla selezione di una classe nella select per le colonne di bootstrap\r\n   * da usare nella visualizzazione del campo. Questa funzione manipola la sorgente dati per\r\n   * la eqp-select in modo da escludere i valori dell'enumeratore che fanno riferimento ad\r\n   * una larghezza di schermo già selezionata. Esempio: per gli schermi piccoli (sm) l'utente\r\n   * seleziona la classe \"col-sm-6\", al change del valore questo metodo rimuove dalla select\r\n   * tutti gli altri valori per la grandezza di schermo selezionata.\r\n   */\r\n  onColSpanSizeSelect() {\r\n    // Recupero l'array degli oggetti chiave-valore che rappreseta l'enumeratore\r\n    let colSizeClassEnumArray = this.enumHelper.getEnumArray(ColSpanSizesEnum, false, null);\r\n    // Costruisco l'array delle classi selezionate dall'utente in formato stringa\r\n    let selectedDimensions: Array<string> = this.field.ColSpanSizes ? this.field.ColSpanSizes.map(col => ColSpanSizesEnum[col]) : [];\r\n    // Filtro i valori ottenuti dall'enumeratore per escludere tutti i valori per le\r\n    // grandezze di schermo già selezionatead esclusione dei valori selezionati.\r\n    this.availableColSpanSizes = colSizeClassEnumArray.filter((value: { key: number, value: string }) =>\r\n      !selectedDimensions.find(col => value.value.includes(col.substring(4, 6)) && value.value != col)\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Metodo invocato al cambio del tipo di visualizzazione scelta per i campi di tipo elenco generico.\r\n   * Se viene scelta la visualizzazione ad immagini svuota la lista delle coppie chiave-valore inserite\r\n   * in precedenza, altrimenti svuota la lista delle immagini caricate.\r\n   */\r\n  onPresentationModeChange() {\r\n    if ((this.field as ListValueField).PresentationMode === ListPresentationEnum.Immagini) {\r\n      (this.field as ListValueField).ValuePairs = null;\r\n    } else {\r\n      (this.field as ListValueField).ButtonImageList = null;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo invocato quando viene caricato il componente eqp-attachments per caricare le immagini da usare \r\n   * nella visualizzazione ad immagini dei campi di tipo \"Elenco generico\". Aggiunge due colonne a quelle\r\n   * configurate nel componente in cui l'utente può indicare chiave e valore della scelta.\r\n   * @param component Istanza del componente eqp-attachments in cui effettuare la modifica.\r\n   */\r\n  configureButtonImagesColumns(component: EqpAttachmentsComponent) {\r\n    component.attachmentsColumns.splice(\r\n      component.attachmentsColumns.length - 1, 0,\r\n      { key: \"ButtonKey\", display: \"Label\", type: TypeColumn.ExternalTemplate, externalTemplate: this.buttonImagesKeyValueInputColumn }\r\n    );\r\n\r\n    component.attachmentsColumns.splice(\r\n      component.attachmentsColumns.length - 1, 0,\r\n      { key: \"ButtonValue\", display: \"Valore\", type: TypeColumn.ExternalTemplate, externalTemplate: this.buttonImagesKeyValueInputColumn }\r\n    );\r\n\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  /**\r\n   * Metodo invocato al salvataggio degli allegati quando viene configurato un campo di tipo \"Elenco generico\"\r\n   * con il tipo di visualizzazione ad immagini. Intercetta l'elenco aggiornato delle immagini caricate e lo\r\n   * memorizza nell'oggetto field corrente.\r\n   * @param attachments Array aggiornato degli allegati caricati.\r\n   */\r\n  catchButtonImagesChange(attachments: Array<IAttachmentDTO>) {\r\n    (this.field as ListValueField).ButtonImageList = (attachments as Array<ButtonImage>);\r\n  }\r\n\r\n  /**\r\n   * Metodo chiamato al keyup degli input testuali che prevedono l'aggiunta del valore inserito in un array.\r\n   * Se l'utente preme il tasto invio, in base al tipo di campo che sta inserendo/modificando, questo metodo\r\n   * aggiunge il valore inserito dall'utente nella lista di stringhe corretta (in input viene passato il nome\r\n   * della proprietà in cui inserire la stringa).\r\n   * @param event Evento che rappresenta il keyup dell'utente\r\n   * @param propertyName Nome della proprietà del field in cui inserire la stringa digitata.\r\n   */\r\n  onMultiSelectInputKeyup(event, propertyName: string) {\r\n    if (event.code === 'Enter' || event.code === 'NumpadEnter') {\r\n      switch (this.field.FieldType) {\r\n        case FieldTypeEnum.Lookup:\r\n        case FieldTypeEnum.Allegato:\r\n          if (!this.field[propertyName]) {\r\n            this.field[propertyName] = new Array<string>();\r\n          }\r\n          this.field[propertyName].push(event.currentTarget.value);\r\n          break;\r\n        case FieldTypeEnum.Immagine:\r\n          if (!(this.field as ImageField).AttachDefinition[propertyName]) {\r\n            (this.field as ImageField).AttachDefinition[propertyName] = new Array<string>();\r\n          }\r\n          (this.field as ImageField).AttachDefinition[propertyName].push(event.currentTarget.value);\r\n          break;\r\n        case FieldTypeEnum['Elenco generico']:\r\n          if (!this.keyValueObject.key || !this.keyValueObject.value) {\r\n            return;\r\n          }\r\n          if (!(this.field as ListValueField).ValuePairs) {\r\n            (this.field as ListValueField).ValuePairs = {};\r\n          }\r\n          (this.field as ListValueField).ValuePairs[this.keyValueObject.key] = this.keyValueObject.value;\r\n          this.keyValueObject = { key: '', value: '' };\r\n          break;\r\n      }\r\n      event.currentTarget.value = null;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo chiamato per mostrare come elenco le opzioni aggiunte in un campo di tipo \"Elenco generico\".\r\n   * @returns Restituisce un array di oggetti del tipo { key: string, value: string } con i valori inseriti dall'utente.\r\n   */\r\n  getDictionaryKeyValue() {\r\n    if ((this.field as ListValueField).ValuePairs) {\r\n      \r\n      return Object.keys((this.field as ListValueField).ValuePairs).map(k => {\r\n        return {\r\n          key: k,\r\n          value: (this.field as ListValueField).ValuePairs[k]\r\n          \r\n        };\r\n      });\r\n     \r\n      \r\n    } else {\r\n      return [];\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per rimuovere una opzione aggiunta al campo di tipo \"Elenco generico\"\r\n   * @param key Nome della chiave da rimuovere\r\n   */\r\n  deleteKeyFromDictionary(key: string) {\r\n    delete (this.field as ListValueField).ValuePairs[key];\r\n  }\r\n\r\n  /**\r\n   * Metodo per aprire il dialog per aggiungere/modificare un metadata in un campo di tipo Allegato o Immagine.\r\n   * @param metadata Metadata da modificare, se null allora ne sto creando uno nuovo.\r\n   */\r\n  openMetadataDialog(field: BaseField = null) {\r\n    if (field) {\r\n      if (this.field.FieldType === FieldTypeEnum.Allegato) {\r\n        this.indexSelectedMetadata = (this.field as AttachmentField).MetadataFields.indexOf(field);\r\n        this.selectedMetadata = JSON.parse(JSON.stringify(field));\r\n      } else if (this.field.FieldType === FieldTypeEnum.Immagine) {\r\n        this.indexSelectedMetadata = (this.field as ImageField).AttachDefinition.MetadataFields.indexOf(field);\r\n        this.selectedMetadata = JSON.parse(JSON.stringify(field));\r\n      }\r\n    } else {\r\n      this.selectedMetadata = new BaseField();\r\n      this.indexSelectedMetadata = null;\r\n    }\r\n    this.dialogMetadataRef = this.dialog.open(this.dialogMetadata, {\r\n      disableClose: true,\r\n      hasBackdrop: true,\r\n      width: '75%'\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Metodo invocato dall'output dal dialog per aggiungere/modificare un metadata\r\n   * nei campi di tipo Allegato o Immagine. Prima di aggiungere il metadata nell'elenco\r\n   * contolla se esiste un altro metadata con lo stesso nome e nel caso genera un errore\r\n   * (i metadata, come per i campi della form, devono avere un nome univoco).\r\n   * @param metadata Metadata aggiunto o modificato, se null allora il dialog è stato chiuso senza fare modifiche.\r\n   */\r\n  onSaveMetadata(metadata: BaseField) {\r\n    if (metadata) {\r\n      if (\r\n        (this.field.FieldType === FieldTypeEnum.Allegato\r\n          && (this.field as AttachmentField).MetadataFields\r\n          && (this.field as AttachmentField).MetadataFields.find(\r\n            (m, i) => m.Label === metadata.Label\r\n              && (this.indexSelectedMetadata == null ? true : this.indexSelectedMetadata !== i)\r\n          )\r\n        ) ||\r\n        (this.field.FieldType === FieldTypeEnum.Immagine\r\n          && (this.field as ImageField).AttachDefinition.MetadataFields\r\n          && (this.field as ImageField).AttachDefinition.MetadataFields.find(\r\n            (m, i) => m.Label === metadata.Label\r\n              && (this.indexSelectedMetadata == null ? true : this.indexSelectedMetadata !== i)\r\n          )\r\n        )\r\n      ) {\r\n        EqpDynamicModuleDialogService.Warning('Impossibile inserire due metadata con la stessa label.');\r\n        throw new Error('Impossibile inserire due metadata con la stessa label.');\r\n      }\r\n\r\n      if (this.indexSelectedMetadata != null && this.indexSelectedMetadata >= 0) {\r\n        if (this.field.FieldType === FieldTypeEnum.Allegato) {\r\n          (this.field as AttachmentField).MetadataFields[this.indexSelectedMetadata] = metadata;\r\n        } else if (this.field.FieldType === FieldTypeEnum.Immagine) {\r\n          (this.field as ImageField).AttachDefinition.MetadataFields[this.indexSelectedMetadata] = metadata;\r\n        }\r\n      } else {\r\n        if (this.field.FieldType === FieldTypeEnum.Allegato) {\r\n          if (!(this.field as AttachmentField).MetadataFields) {\r\n            (this.field as AttachmentField).MetadataFields = new Array<BaseField>();\r\n          }\r\n          (this.field as AttachmentField).MetadataFields.push(metadata);\r\n        } else if (this.field.FieldType === FieldTypeEnum.Immagine) {\r\n          if (!(this.field as ImageField).AttachDefinition.MetadataFields) {\r\n            (this.field as ImageField).AttachDefinition.MetadataFields = new Array<BaseField>();\r\n          }\r\n          (this.field as ImageField).AttachDefinition.MetadataFields.push(metadata);\r\n        }\r\n      }\r\n    }\r\n    this.dialogMetadataRef.close();\r\n    this.setMetadataOrdinalPosition();\r\n    this.reloadMetadataTable();\r\n  }\r\n\r\n  /**\r\n   * Metodo per disabilitare il pulsante per salvare il campo inserito/modificato.\r\n   * @returns Restituisce un booleano, se true il salvataggio viene disabilitato.\r\n   */\r\n  disableSaveField(): boolean {\r\n    if (this.fieldFormGroup.invalid) {\r\n      return true;\r\n    }\r\n\r\n    switch (this.field.FieldType) {\r\n\r\n      case FieldTypeEnum['Elenco generico']:\r\n        if ((this.field as ListValueField).PresentationMode != ListPresentationEnum.Immagini) {\r\n          return !(this.field as ListValueField).ValuePairs || (this.field as ListValueField).ValuePairs.length === 0;\r\n        } else {\r\n          return (\r\n            !(this.field as ListValueField).ButtonImageList\r\n            || (this.field as ListValueField).ButtonImageList.length === 0\r\n            || !!(this.field as ListValueField).ButtonImageList.find(i => !i.ButtonKey || !i.ButtonValue)\r\n          );\r\n        }\r\n      case FieldTypeEnum.Lookup:\r\n        return !(this.field as LookupField).FieldNames || (this.field as LookupField).FieldNames.length === 0;\r\n      default:\r\n        return false;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per salvare il campo inserito/modificato.\r\n   * Se è stato inserito un field con la stessa label viene generato un errore (le label devono essere univoche).\r\n   * Una volta aggiunto/aggiornato il campo nell'elenco dei Field della Form chiude il dialog e ricarica la tabella\r\n   * che mostra l'elenco dei campi aggiunti alla form.\r\n   */\r\n  saveAndExitAddField(save: boolean) {\r\n    if (save) {\r\n      this.saveFieldEvent.emit(this.field);\r\n    } else {\r\n      this.saveFieldEvent.emit(null);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per ripristinare l'oggetto field al cambio del tipo selezionato.\r\n   * Lascia valorizzate solo le proprietà dell'oggetto BaseField comune a tutti i tipi di campo.\r\n   */\r\n  private restoreBaseFieldProperties() {\r\n    if (this.field) {\r\n      const tmpBaseField = JSON.parse(JSON.stringify(this.field));\r\n      this.field = new BaseField();\r\n      this.field.Label = tmpBaseField.Label;\r\n      this.field.Description = tmpBaseField.Description;\r\n      this.field.Required = tmpBaseField.Required;\r\n      this.field.FieldType = tmpBaseField.FieldType;\r\n      this.field.Formula = tmpBaseField.Formula;\r\n      this.field.ColSpanSizes = tmpBaseField.ColSpanSizes;\r\n      this.field.InListView = tmpBaseField.InListView;\r\n      this.field.Tooltip = tmpBaseField.Tooltip;\r\n      this.field.Readonly = tmpBaseField.Readonly;\r\n      this.field.FieldGroup = tmpBaseField.FieldGroup;\r\n      this.field.VisibleIf = tmpBaseField.VisibleIf;\r\n    }\r\n  }\r\n\r\n  private configureColumns() {\r\n    this.metadataColumns = [\r\n      {\r\n        key: 'action', display: '', type: TypeColumn.MenuAction, buttonMenuIcon: 'more_vert', styles: { flex: '0 0 6%' },\r\n        actions: [\r\n          { name: 'Modifica', icon: 'edit', fn: (element, index, col) => this.openMetadataDialog(element) },\r\n          { name: 'Elimina', icon: 'delete', fn: (element, index, col) => this.deleteMetadata(element) },\r\n        ]\r\n      },\r\n      { key: 'FieldType', display: 'Tipologia', type: TypeColumn.Enum, enumModel: FieldTypeEnum },\r\n      { key: 'Label', display: 'Label' },\r\n      { key: 'Description', display: 'Descrizione' },\r\n      {\r\n        key: 'Required', display: 'Obbligatorio',\r\n        value: (element) => !!element.Required,\r\n        type: TypeColumn.Boolean,\r\n        booleanValues: {\r\n          true: '<i class=\"fa fa-check success-color\"></i>',\r\n          false: '<i class=\"fa fa-close error-color\"></i>'\r\n        },\r\n        styles: { flex: '0 0 7%', cellAlignment: CellAlignmentEnum.CENTER }\r\n      },\r\n    ];\r\n  }\r\n\r\n  /**\r\n   * Metodo per eliminare un metadata aggiunto per un campo di tipo Allegato o Immagine.\r\n   * @param metadata Metadata da eliminare.\r\n   */\r\n  private deleteMetadata(metadata: BaseField) {\r\n    EqpDynamicModuleDialogService.Confirm('Eliminare il metadata selezionato?', () => {\r\n      if (this.field.FieldType === FieldTypeEnum.Allegato) {\r\n        (this.field as AttachmentField).MetadataFields.splice((this.field as AttachmentField).MetadataFields.indexOf(metadata), 1);\r\n      } else if (this.field.FieldType === FieldTypeEnum.Immagine) {\r\n        (this.field as ImageField).AttachDefinition.MetadataFields.splice((this.field as ImageField).AttachDefinition.MetadataFields.indexOf(metadata), 1);\r\n      }\r\n      this.setMetadataOrdinalPosition();\r\n      this.reloadMetadataTable();\r\n    }, false, 'Richiesta conferma');\r\n  }\r\n\r\n  /**\r\n   * Imposta l'ordinamento dei metadata all'interno dei campi di tipo Allegato e Immagine.\r\n   */\r\n  private setMetadataOrdinalPosition() {\r\n    if (this.field.FieldType === FieldTypeEnum.Allegato) {\r\n      if ((this.field as AttachmentField).MetadataFields) {\r\n        (this.field as AttachmentField).MetadataFields.forEach(metadata => {\r\n          metadata.OrdinalPosition = (this.field as AttachmentField).MetadataFields.indexOf(metadata);\r\n        });\r\n      }\r\n    } else if (this.field.FieldType === FieldTypeEnum.Immagine) {\r\n      if ((this.field as ImageField).AttachDefinition.MetadataFields) {\r\n        (this.field as ImageField).AttachDefinition.MetadataFields.forEach(metadata => {\r\n          metadata.OrdinalPosition = (this.field as ImageField).AttachDefinition.MetadataFields.indexOf(metadata);\r\n        });\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per ricaricare i dati della tabella dei metadata visualizzata nella creazione/modifica \r\n   * dei campi di tipo Allegato o Immagine.\r\n   */\r\n  private reloadMetadataTable() {\r\n    if (this.metadataFieldsTable) {\r\n      this.metadataFieldsTable.reloadDatatable();\r\n    }\r\n  }\r\n\r\n\r\n\r\n}\r\n","<div class=\"container-fluid\" style=\"max-height: 70vh !important; overflow-x: hidden; overflow-y: auto;\">\r\n    <div class=\"row title\">\r\n        <div class=\"header-title-standard\">{{indexField != null && indexField >= 0 ? \"Modifica\"\r\n            : \"Aggiungi\"}} campo</div>\r\n    </div>\r\n    <form [formGroup]=\"fieldFormGroup\">\r\n        <div class=\"row\">\r\n            <div class=\"col-sm-12 col-md-4 mt-2 tipoCampo\">\r\n                <mat-label>Tipo campo *</mat-label>\r\n                <eqp-select [enumData]=\"FieldTypeEnum\" [(ngModelInput)]=\"field.FieldType\" [showCancelButton]=\"false\"\r\n                    (ngModelInputChange)=\"onFieldTypeChange()\" [formGroupInput]=\"fieldFormGroup\"\r\n                    [formControlNameInput]=\"'FieldType'\" [enumDataToExclude]=\"fieldTypesToExclude\">\r\n                </eqp-select>\r\n            </div>\r\n\r\n            <div class=\"col-sm-12 col-md-4 mt-2\">\r\n                <mat-label> Codice * </mat-label>\r\n                <mat-form-field>\r\n                    <input formControlName=\"Label\" required matInput [(ngModel)]=\"field.Label\">\r\n                </mat-form-field>\r\n            </div>\r\n\r\n            <div class=\"col-sm-12 col-md-4 mt-2\">\r\n                <mat-label> Descrizione * </mat-label>\r\n                <mat-form-field>\r\n                    <input name=\"Description\" formControlName=\"Description\" required matInput\r\n                        [(ngModel)]=\"field.Description\">\r\n                </mat-form-field>\r\n            </div>\r\n\r\n            <div class=\"col-sm-12 col-md-4 mt-2\">\r\n                <mat-label> Tooltip </mat-label>\r\n                <mat-form-field>\r\n                    <input name=\"Tooltip\" formControlName=\"Tooltip\" matInput [(ngModel)]=\"field.Tooltip\" >\r\n                </mat-form-field>\r\n            </div>\r\n\r\n            <div class=\"col-sm-12 col-md-4 mt-2\">\r\n                <mat-label> Formula (Javascript) </mat-label>\r\n                <mat-form-field>\r\n                    <input formControlName=\"Formula\" matInput [(ngModel)]=\"field.Formula\"\r\n                        [matAutocomplete]=\"formulaAutocomplete\" (keyup)=\"setFormulaAutocompleteOptions($event)\"\r\n                        (focus)=\"setFormulaAutocompleteOptions(null)\">\r\n                    <mat-autocomplete #formulaAutocomplete=\"matAutocomplete\">\r\n                        <mat-option *ngFor=\"let option of formulaAutocompleteOptions\" [value]=\"option.value\">\r\n                            {{option.label}}\r\n                        </mat-option>\r\n                    </mat-autocomplete>\r\n                </mat-form-field>\r\n            </div>\r\n\r\n            <div class=\"col-sm-12 col-md-4 mt-2\" *ngIf=\"formFieldsGroups\">\r\n                <mat-label>Sezione</mat-label>\r\n                <eqp-select [arrayData]=\"formFieldsGroups\" [(ngModelInput)]=\"field.FieldGroup\"\r\n                    [arrayKeyProperty]=\"'Name'\" [arrayValueProperty]=\"'Name'\" [formGroupInput]=\"fieldFormGroup\"\r\n                    [formControlNameInput]=\"'FieldGroup'\" required [includeFullObject]=\"false\">\r\n                </eqp-select>\r\n            </div>\r\n            <div class=\"col-sm-12 col-md-4 mt-2\">\r\n                <mat-label>Larghezza campo</mat-label>\r\n                <eqp-select [arrayData]=\"availableColSpanSizes\" [(ngModelInput)]=\"field.ColSpanSizes\"\r\n                    [arrayKeyProperty]=\"'key'\" [arrayValueProperty]=\"'value'\"\r\n                    (ngModelInputChange)=\"onColSpanSizeSelect()\" [isMultiSelect]=\"true\"\r\n                    [formGroupInput]=\"fieldFormGroup\" [formControlNameInput]=\"'ColSpanSizes'\"\r\n                    [includeFullObject]=\"false\">\r\n                </eqp-select>\r\n            </div>\r\n            <div class=\"col-sm-12 col-md-4 mt-2\">\r\n                <mat-label> Label css </mat-label>\r\n                <mat-form-field>\r\n                    <input name=\"LabelstyleCSS\" formControlName=\"LabelstyleCSS\" matInput\r\n                        [(ngModel)]=\"field.LabelstyleCSS\">\r\n                </mat-form-field>\r\n            </div>\r\n            <div class=\"col-sm-12 col-md-4 mt-2\">\r\n                <mat-label> Field css </mat-label>\r\n                <mat-form-field>\r\n                    <input name=\"FieldstyleCSS\" formControlName=\"FieldstyleCSS\" matInput\r\n                        [(ngModel)]=\"field.FieldstyleCSS\">\r\n                </mat-form-field>\r\n            </div>\r\n\r\n            <div class=\"col-sm-12 col-md-4 mt-2 d-flex align-items-center\">\r\n                <mat-slide-toggle [(ngModel)]=\"field.Required\" formControlName=\"Required\" color=\"primary\">\r\n                    Obbligatorio\r\n                </mat-slide-toggle>\r\n            </div>\r\n            <div class=\"col-sm-12 col-md-4 mt-2 d-flex align-items-center\">\r\n                <mat-slide-toggle [(ngModel)]=\"field.Readonly\" formControlName=\"Readonly\" color=\"primary\">\r\n                    ReadOnly\r\n                </mat-slide-toggle>\r\n            </div>\r\n            <div class=\"col-sm-12 col-md-4 mt-2\">\r\n                <mat-label> VisibleIf </mat-label>\r\n                <mat-form-field>\r\n                    <input name=\"VisibleIf\" formControlName=\"VisibleIf\" matInput [(ngModel)]=\"field.VisibleIf\"  [matAutocomplete]=\"VisibleIfAutocomplete\" (keyup)=\"setVisibleIfAutocompleteOptions($event)\"\r\n                    (focus)=\"setVisibleIfAutocompleteOptions(null)\">\r\n                    <mat-autocomplete #VisibleIfAutocomplete=\"matAutocomplete\">\r\n                        <mat-option *ngFor=\"let option of VisibleIfAutocompleteOptions\" [value]=\"option.value\">\r\n                            {{option.label}}\r\n                        </mat-option>\r\n                    </mat-autocomplete>\r\n                </mat-form-field>\r\n            </div>\r\n            <div class=\"col-sm-12 col-md-4 mt-2 align-self-center\"\r\n                [hidden]=\"(field.VisibleIf != null || field.VisibleIf != undefined) && field.VisibleIf != ''\">\r\n                <div class=\"d-flex align-items-center\">\r\n                    <mat-slide-toggle [(ngModel)]=\"field.InListView\" formControlName=\"InListView\" color=\"primary\"\r\n                        [disabled]=\"fieldFormGroup.controls['InListView'].disabled\">\r\n                        Visibile\r\n                    </mat-slide-toggle>\r\n                </div>\r\n            </div>\r\n            <ng-container *ngTemplateOutlet=\"fieldTypeFormTemplate\">\r\n            </ng-container>\r\n        </div>\r\n    </form>\r\n</div>\r\n\r\n<div class=\"d-flex justify-content-end mt-2 mb-1\">\r\n    <div class=\"buttonsForm\">\r\n        <button class=\"btn mat-raised-button cancel\" (click)=\"saveAndExitAddField(false)\" type=\"button\">\r\n            Annulla\r\n        </button>\r\n        <button class=\"mr-2 save\" mat-raised-button color=\"primary\" (click)=\"saveAndExitAddField(true)\"\r\n            [disabled]=\"disableSaveField()\" type=\"button\">\r\n            Salva\r\n        </button>\r\n    </div>\r\n</div>\r\n\r\n\r\n<!-- FORM PROPRIETÀ CAMPI DI TESTO -->\r\n<ng-template #textFieldFormTemplate>\r\n    <div class=\"col-sm-12 col-md-4\">\r\n        <mat-label>Maschera</mat-label>\r\n        <eqp-select [enumData]=\"TextMaskEnum\" [(ngModelInput)]=\"field.TextMask\" [formGroupInput]=\"fieldFormGroup\"\r\n            [formControlNameInput]=\"'TextMask'\">\r\n        </eqp-select>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Lunghezza minima </mat-label>\r\n        <mat-form-field>\r\n            <input id=\"lengthMin\" formControlName=\"MinLenght\" type=\"number\" [min]=\"0\" matInput\r\n                [(ngModel)]=\"field.MinLenght\">\r\n        </mat-form-field>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Lunghezza massima </mat-label>\r\n        <mat-form-field>\r\n            <input id=\"lengthMax\" formControlName=\"MaxLenght\" type=\"number\" [min]=\"0\" matInput\r\n                [(ngModel)]=\"field.MaxLenght\">\r\n        </mat-form-field>\r\n    </div>\r\n</ng-template>\r\n\r\n<!-- FORM PROPRIETÀ CAMPI AREA DI TESTO -->\r\n<ng-template #textareaFieldFormTemplate>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Righe </mat-label>\r\n        <mat-form-field class=\"righe\">\r\n            <input id=\"rows\" formControlName=\"Rows\" type=\"number\" [min]=\"0\" matInput [(ngModel)]=\"field.Rows\">\r\n        </mat-form-field>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Lunghezza minima </mat-label>\r\n        <mat-form-field>\r\n            <input id=\"lengthMin\" formControlName=\"MinLenght\" type=\"number\" [min]=\"0\" matInput\r\n                [(ngModel)]=\"field.MinLenght\">\r\n        </mat-form-field>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Lunghezza massima </mat-label>\r\n        <mat-form-field>\r\n            <input id=\"lengthMax\" formControlName=\"MaxLenght\" type=\"number\" [min]=\"0\" matInput\r\n                [(ngModel)]=\"field.MaxLenght\">\r\n        </mat-form-field>\r\n    </div>\r\n</ng-template>\r\n\r\n<!-- FORM PROPRIETÀ CAMPI BOOLEANI -->\r\n<ng-template #booleadFieldFormTemplate>\r\n    <div class=\"col-sm-12 col-md-4 mt-2 d-flex align-items-center\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-slide-toggle [(ngModel)]=\"field.IsTristate\" formControlName=\"IsTristate\" color=\"primary\">\r\n            A tre stati\r\n        </mat-slide-toggle>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\">\r\n        <mat-label>Tipo di presentazione *</mat-label>\r\n        <eqp-select [enumData]=\"BoolPresentantioEnum\" [(ngModelInput)]=\"field.PresetationType\" required\r\n            [showCancelButton]=\"false\" [formGroupInput]=\"fieldFormGroup\" [formControlNameInput]=\"'PresetationType'\">\r\n        </eqp-select>\r\n    </div>\r\n</ng-template>\r\n\r\n<!-- FORM PROPRIETÀ CAMPI DATA -->\r\n<ng-template #dateFieldFormTemplate>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\">\r\n        <mat-label>Tipo di data</mat-label>\r\n        <eqp-select [enumData]=\"DateTimeTypeEnum\" [(ngModelInput)]=\"field.IsOnlyDate\" required\r\n            [showCancelButton]=\"false\" [formGroupInput]=\"fieldFormGroup\" [formControlNameInput]=\"'IsOnlyDate'\">\r\n        </eqp-select>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Formato </mat-label>\r\n        <mat-form-field>\r\n            <input formControlName=\"DateFormat\" matInput [(ngModel)]=\"field.DateFormat\"\r\n                [matTooltip]=\"'Indicare il formato seguendo la guida del pacchetto momentjs.'\">\r\n        </mat-form-field>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\">\r\n        <mat-label> Data minima </mat-label>\r\n        <eqp-datetimepicker *ngIf=\"field.IsOnlyDate == DateTimeTypeEnum['Solo data']\" class=\"date\"\r\n            [(ngModelInput)]=\"field.MinDate\" [formGroupInput]=\"fieldFormGroup\" [formControlNameInput]=\"'MinDate'\"\r\n            [pickerMode]=\"pickerModeEnum.DATE\" [UTCDate]=\"true\" [showSeconds]=\"false\">\r\n        </eqp-datetimepicker>\r\n        <eqp-datetimepicker *ngIf=\"field.IsOnlyDate == DateTimeTypeEnum['Data e ora']\" class=\"date\"\r\n            [(ngModelInput)]=\"field.MinDate\" [formGroupInput]=\"fieldFormGroup\" [formControlNameInput]=\"'MinDate'\"\r\n            [pickerMode]=\"pickerModeEnum.DATETIME\" [UTCDate]=\"true\" [showSeconds]=\"false\">\r\n        </eqp-datetimepicker>\r\n        <eqp-datetimepicker *ngIf=\"field.IsOnlyDate == DateTimeTypeEnum['Solo orario']\" class=\"date\"\r\n            [(ngModelInput)]=\"field.MinDate\" [formGroupInput]=\"fieldFormGroup\" [formControlNameInput]=\"'MinDate'\"\r\n            [pickerMode]=\"pickerModeEnum.TIME\" [UTCDate]=\"true\" [showSeconds]=\"false\">\r\n        </eqp-datetimepicker>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\">\r\n        <mat-label> Data massima </mat-label>\r\n        <eqp-datetimepicker *ngIf=\"field.IsOnlyDate == DateTimeTypeEnum['Solo data']\" class=\"date\"\r\n            [(ngModelInput)]=\"field.MaxDate\" [formGroupInput]=\"fieldFormGroup\" [formControlNameInput]=\"'MaxDate'\"\r\n            [pickerMode]=\"pickerModeEnum.DATE\" [UTCDate]=\"true\" [showSeconds]=\"false\">\r\n        </eqp-datetimepicker>\r\n        <eqp-datetimepicker *ngIf=\"field.IsOnlyDate == DateTimeTypeEnum['Data e ora']\" class=\"date\"\r\n            [(ngModelInput)]=\"field.MaxDate\" [formGroupInput]=\"fieldFormGroup\" [formControlNameInput]=\"'MaxDate'\"\r\n            [pickerMode]=\"pickerModeEnum.DATETIME\" [UTCDate]=\"true\" [showSeconds]=\"false\">\r\n        </eqp-datetimepicker>\r\n        <eqp-datetimepicker *ngIf=\"field.IsOnlyDate == DateTimeTypeEnum['Solo orario']\" class=\"date\"\r\n            [(ngModelInput)]=\"field.MaxDate\" [formGroupInput]=\"fieldFormGroup\" [formControlNameInput]=\"'MaxDate'\"\r\n            [pickerMode]=\"pickerModeEnum.TIME\" [UTCDate]=\"true\" [showSeconds]=\"false\">\r\n        </eqp-datetimepicker>\r\n    </div>\r\n</ng-template>\r\n\r\n<!-- FORM PROPRIETÀ CAMPI NUMERICI -->\r\n<ng-template #numericFieldFormTemplate>\r\n    <div class=\"col-sm-12 col-md-4 mt-2 d-flex align-items-center\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-slide-toggle [(ngModel)]=\"field.IsInteger\" formControlName=\"IsInteger\" color=\"primary\">\r\n            Valore intero\r\n        </mat-slide-toggle>\r\n    </div>\r\n    <div *ngIf=\"!field.IsInteger\" class=\"col-sm-12 col-md-4 mt-2\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Separatore decimali </mat-label>\r\n        <mat-form-field>\r\n            <input formControlName=\"DecimalSeparator\" matInput [(ngModel)]=\"field.DecimalSeparator\">\r\n        </mat-form-field>\r\n    </div>\r\n    <div *ngIf=\"!field.IsInteger\" class=\"col-sm-12 col-md-4 mt-2\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Precisione decimali </mat-label>\r\n        <mat-form-field>\r\n            <input formControlName=\"DecimalPrecision\" type=\"number\" [min]=\"0\" matInput\r\n                [(ngModel)]=\"field.DecimalPrecision\">\r\n        </mat-form-field>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Separatore migliaia </mat-label>\r\n        <mat-form-field>\r\n            <input formControlName=\"ThousandsSeparator\" matInput [(ngModel)]=\"field.ThousandsSeparator\">\r\n        </mat-form-field>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Simbolo valuta </mat-label>\r\n        <mat-form-field>\r\n            <input formControlName=\"CurrencySymbol\" matInput [(ngModel)]=\"field.CurrencySymbol\">\r\n        </mat-form-field>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Valore minimo </mat-label>\r\n        <mat-form-field>\r\n            <input formControlName=\"MinValue\" type=\"number\" [min]=\"0\" matInput [(ngModel)]=\"field.MinValue\">\r\n        </mat-form-field>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Valore massimo </mat-label>\r\n        <mat-form-field>\r\n            <input formControlName=\"MaxValue\" type=\"number\" [min]=\"0\" matInput [(ngModel)]=\"field.MaxValue\">\r\n        </mat-form-field>\r\n    </div>\r\n</ng-template>\r\n\r\n<!-- FORM PROPRIETÀ CAMPI ALLEGATO -->\r\n<ng-template #attachmentFieldFormTemplate>\r\n    <div class=\"col-sm-12 col-md-4 mt-2 d-flex align-items-center\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-slide-toggle [(ngModel)]=\"field.IsMultiAttach\" formControlName=\"IsMultiAttach\" color=\"primary\">\r\n            Allegati multipli\r\n        </mat-slide-toggle>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\">\r\n        <mat-label>Estensioni accettate</mat-label>\r\n        <eqp-select [arrayData]=\"AvailableFileExtensions.concat(AvailableImageExtensions)\"\r\n            [(ngModelInput)]=\"field.AllowedExtensions\" [arrayKeyProperty]=\"'key'\" [arrayValueProperty]=\"'value'\"\r\n            [isMultiSelect]=\"true\" [formGroupInput]=\"fieldFormGroup\" [formControlNameInput]=\"'AllowedExtensions'\"\r\n            [includeFullObject]=\"false\">\r\n        </eqp-select>\r\n    </div>\r\n    <div class=\"col-sm-12 mt-2\">\r\n        <div class=\"row mt-2\">\r\n            <div class=\"col-sm-12 col-md-6\">\r\n                <div class=\"header-title-standard\">\r\n                    Elenco metadata\r\n                </div>\r\n            </div>\r\n            <div class=\"col-sm-12 col-md-6 text-right buttonsForm\">\r\n                <button class=\"btn btn-primary save\" mat-raised-button color=\"primary\" type=\"button\"\r\n                    (click)=\"openMetadataDialog()\">\r\n                    <mat-icon>add</mat-icon>\r\n                    <span style=\"margin-left: 10px;\">Aggiungi allegato</span>\r\n                </button>\r\n            </div>\r\n        </div>\r\n        <eqp-table #metadataFieldsTable [createMatCard]=\"false\" [columns]=\"metadataColumns\"\r\n            [data]=\"field.MetadataFields\" [emptyTableMessage]=\"'Nessun metadata inserito'\" [searchText]=\"'Cerca'\">\r\n        </eqp-table>\r\n    </div>\r\n</ng-template>\r\n\r\n<!-- FORM PROPRIETÀ CAMPI IMMAGINE -->\r\n<ng-template #imageFieldFormTemplate>\r\n    <div class=\"col-sm-12 col-md-4 mt-2 mb-2 d-flex align-items-center\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-slide-toggle [(ngModel)]=\"field.ImageIsContextualAttachment\" formControlName=\"ImageIsContextualAttachment\"\r\n            color=\"primary\" (ngModelChange)=\"onImageIsContextualAttachmentChange()\">\r\n            Immagine pre-caricata nel campo\r\n        </mat-slide-toggle>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2 mb-2 d-flex align-items-center\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-slide-toggle [(ngModel)]=\"field.EnableDrawing\" formControlName=\"EnableDrawing\" color=\"primary\">\r\n            Abilita il disegno\r\n        </mat-slide-toggle>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2 d-flex align-items-center\" [formGroup]=\"fieldFormGroup\"\r\n        *ngIf=\"!field.ImageIsContextualAttachment\">\r\n        <mat-slide-toggle [(ngModel)]=\"field.AttachDefinition.IsMultiAttach\" formControlName=\"IsMultiAttach\"\r\n            color=\"primary\">\r\n            Immagini multiple\r\n        </mat-slide-toggle>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\" *ngIf=\"!field.ImageIsContextualAttachment\">\r\n        <mat-label>Estensioni accettate</mat-label>\r\n        <eqp-select [arrayData]=\"AvailableImageExtensions\" [(ngModelInput)]=\"field.AttachDefinition.AllowedExtensions\"\r\n            [arrayKeyProperty]=\"'key'\" [arrayValueProperty]=\"'value'\" [isMultiSelect]=\"true\"\r\n            [formGroupInput]=\"fieldFormGroup\" [formControlNameInput]=\"'AllowedExtensions'\" [includeFullObject]=\"false\">\r\n        </eqp-select>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\" [formGroup]=\"fieldFormGroup\" *ngIf=\"field.ImageIsContextualAttachment\">\r\n        <mat-label> Nome immagine </mat-label>\r\n        <mat-form-field>\r\n            <input formControlName=\"ImgName\" matInput [(ngModel)]=\"field.ImgName\" required>\r\n        </mat-form-field>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-8 mt-2\" [formGroup]=\"fieldFormGroup\" *ngIf=\"field.ImageIsContextualAttachment\">\r\n        <eqp-attachments [attachmentsList]=\"field._contextualAttachments\" [showMatCard]=\"false\" [allowOnlyImages]=\"true\"\r\n            [isDisabled]=\"false\" [showInlinePreview]=\"true\" [multipleAttachment]=\"false\" [showHeader]=\"false\"\r\n            (localEditedAttachments)=\"catchContextualAttachmentChange($event)\" #contextualAttachmentEqpAttachments>\r\n        </eqp-attachments>\r\n    </div>\r\n    <div class=\"col-sm-12 mt-2\">\r\n        <div class=\"row mt-2\">\r\n            <div class=\"col-sm-12 col-md-6\">\r\n                <div class=\"header-title-standard\">\r\n                    Elenco metadata\r\n                </div>\r\n            </div>\r\n            <div class=\"col-sm-12 col-md-6 text-right buttonsForm\">\r\n                <button class=\"btn btn-primary save\" mat-raised-button color=\"primary\" type=\"button\"\r\n                    (click)=\"openMetadataDialog()\">\r\n                    <mat-icon>add</mat-icon>\r\n                    <span style=\"margin-left: 10px;\">Aggiungi</span>\r\n                </button>\r\n            </div>\r\n        </div>\r\n        <eqp-table #metadataFieldsTable [createMatCard]=\"false\" [columns]=\"metadataColumns\"\r\n            [data]=\"field.AttachDefinition.MetadataFields\" [emptyTableMessage]=\"'Nessun metadata inserito'\"\r\n            [searchText]=\"'Cerca'\">\r\n        </eqp-table>\r\n    </div>\r\n</ng-template>\r\n\r\n<!-- FORM PROPRIETÀ CAMPI LISTA DI VALORI -->\r\n<ng-template #listValueFieldFormTemplate>\r\n    <div class=\"col-sm-12 col-md-4 mt-2 d-flex align-items-center\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-slide-toggle [(ngModel)]=\"field.IsMultiChoiche\" formControlName=\"IsMultiChoiche\" color=\"primary\">\r\n            Scelta multipla\r\n        </mat-slide-toggle>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\">\r\n        <mat-label>Tipo di presentazione*</mat-label>\r\n        <eqp-select [enumData]=\"ListPresentationEnum\" [(ngModelInput)]=\"field.PresentationMode\" required\r\n            [showCancelButton]=\"false\" [formGroupInput]=\"fieldFormGroup\" [formControlNameInput]=\"'PresentationMode'\"\r\n            (ngModelInputChange)=\"onPresentationModeChange()\">\r\n        </eqp-select>\r\n    </div>\r\n    <div class=\"col-sm-12 mt-2\" *ngIf=\"field.PresentationMode != ListPresentationEnum.Immagini\">\r\n        <div class=\"row\">\r\n            <h4 class=\"key-value-list-section-title\"> </h4>\r\n            <div class=\"col-md-4\">\r\n                <mat-label> Label opzione (invio per confermare)</mat-label>\r\n                <mat-form-field>\r\n                    <input matInput [(ngModel)]=\"keyValueObject.key\" (keyup)=\"onMultiSelectInputKeyup($event, null)\">\r\n                </mat-form-field>\r\n            </div>\r\n            <div class=\"col-md-4\">\r\n                <mat-label> Valore opzione (invio per confermare)</mat-label>\r\n                <mat-form-field>\r\n                    <input matInput [(ngModel)]=\"keyValueObject.value\" (keyup)=\"onMultiSelectInputKeyup($event, null)\">\r\n                </mat-form-field>\r\n            </div>\r\n            <div class=\"col-md-4 d-flex align-items-center\">\r\n                <span class=\"mr-3\">Opzioni inserite:</span>\r\n                <ul class=\"value-pairs-list\">\r\n                    <li *ngFor=\"let keyValuePair of getDictionaryKeyValue()\">\r\n                        <mat-icon class=\"mr-1\" (click)=\"deleteKeyFromDictionary(keyValuePair.key)\">close\r\n                        </mat-icon>\r\n                        <span><b>Label: </b> {{keyValuePair.key}} - <b>Valore: </b> {{keyValuePair.value}}</span>\r\n                    </li>\r\n                </ul>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-12 mt-2\" *ngIf=\"field.PresentationMode == ListPresentationEnum.Immagini\">\r\n        <eqp-attachments [attachmentsList]=\"field.ButtonImageList\" [showMatCard]=\"false\" [allowOnlyImages]=\"true\"\r\n            [isDisabled]=\"false\" [showInlinePreview]=\"true\" [multipleAttachment]=\"true\" [showHeader]=\"false\"\r\n            [allowedTypes]=\"[AttachmentType.FILE]\" (localEditedAttachments)=\"catchButtonImagesChange($event)\"\r\n            (onComponentLoaded)=\"configureButtonImagesColumns($event)\">\r\n        </eqp-attachments>\r\n    </div>\r\n</ng-template>\r\n\r\n<!-- FORM PROPRIETÀ CAMPI LOOKUP -->\r\n<ng-template #lookupFieldFormTemplate>\r\n    <div class=\"col-sm-12 col-md-4 mt-2 d-flex align-items-center\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-slide-toggle [(ngModel)]=\"field.UseAsGetOrDiscard\" formControlName=\"UseAsGetOrDiscard\" color=\"primary\"\r\n            matTooltip=\"Se true la lookup viene visualizzata in una modale per lo scegli scarta\">\r\n            Usa per scegli o scarta\r\n        </mat-slide-toggle>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Nome entità </mat-label>\r\n        <mat-form-field matTooltip=\"Nome dell'entità relazionata\">\r\n            <input formControlName=\"EntitySourceName\" required matInput [(ngModel)]=\"field.EntitySourceName\">\r\n        </mat-form-field>\r\n    </div>\r\n    <div class=\"col-sm-12 mt-2\">\r\n        <div class=\"row\">\r\n            <div class=\"col-md-4\">\r\n                <mat-label> Nomi dei campi (invio per confermare) </mat-label>\r\n                <mat-form-field\r\n                    matTooltip=\"Elenco di campi ordinato che verrà visualizzato nella lookup (premere invio per confermare)\">\r\n                    <input matInput (keyup)=\"onMultiSelectInputKeyup($event, 'FieldNames')\">\r\n                </mat-form-field>\r\n            </div>\r\n            <div class=\"col-md-8 d-flex align-items-center\">\r\n                <span class=\"mr-3\">Nomi selezionati:</span>\r\n                <div class=\"extension-container\" *ngFor=\"let extension of field.FieldNames; let i = index\">\r\n                    <span>{{extension}}</span>\r\n                    <mat-icon class=\"ml-1\" (click)=\"field.FieldNames.splice(i,1)\">close\r\n                    </mat-icon>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n\r\n<!-- DIALOG PER AGGIUNGERE UN METADATA NEI CAMPI DI TIPO ALLEGATO O IMMAGINE -->\r\n<ng-template #dialogMetadata>\r\n    <eqp-dynamic-module-add-form-field [field]=\"selectedMetadata\" [availableFields]=\"availableFields\"\r\n        [indexField]=\"indexSelectedMetadata\" (saveFieldEvent)=\"onSaveMetadata($event)\" [fieldTypesToExclude]=\"[6,7,10]\">\r\n    </eqp-dynamic-module-add-form-field>\r\n</ng-template>\r\n\r\n<ng-template #buttonImagesKeyValueInputColumn let-row=\"row\" let-col=\"col\">\r\n    <mat-form-field>\r\n        <mat-label> {{col.display}} </mat-label>\r\n        <input matInput [(ngModel)]=\"row[col.key]\" required>\r\n    </mat-form-field>\r\n</ng-template>"]}
625
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-form-field.component.js","sourceRoot":"","sources":["../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/add-form-field/add-form-field.component.ts","../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/add-form-field/add-form-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, EventEmitter, Input, OnInit, Output, TemplateRef, ViewChild } from '@angular/core';\r\nimport { UntypedFormBuilder, UntypedFormControl, UntypedFormGroup, Validators } from '@angular/forms';\r\nimport { MatDialog, MatDialogRef } from '@angular/material/dialog';\r\nimport { AttachmentType, EqpAttachmentsComponent, IAttachmentDTO } from '@eqproject/eqp-attachments';\r\nimport { PickerModeEnum } from '@eqproject/eqp-datetimepicker';\r\nimport { EnumHelper } from '@eqproject/eqp-select';\r\nimport { CellAlignmentEnum, ConfigColumn, EqpTableComponent, TypeColumn } from '@eqproject/eqp-table';\r\nimport { BaseField, ColSpanSizesEnum, FieldTypeEnum } from '../../../models/baseField.model';\r\nimport { AttachmentField, AvailableFileExtensions, AvailableImageExtensions } from '../../../models/fields/attachmentField.model';\r\nimport { BooleanField, BoolPresentantioEnum } from '../../../models/fields/booleanField.model';\r\nimport { DateField, DateTimeTypeEnum } from '../../../models/fields/dateField.model';\r\nimport { ImageField } from '../../../models/fields/imageField.model';\r\nimport { ButtonImage, ListPresentationEnum, ListValueField } from '../../../models/fields/listValueField.model';\r\nimport { LookupField } from '../../../models/fields/lookupField.model';\r\nimport { NumericField } from '../../../models/fields/numericField.model';\r\nimport { TextareaField } from '../../../models/fields/textareaField.model';\r\nimport { TextMaskEnum, TextField } from '../../../models/fields/textField.model';\r\nimport { FormFieldGroup } from '../../../models/form.model';\r\nimport { EqpDynamicModuleDialogService } from '../../../services/eqp-dynamic-module-dialog.service';\r\nimport { UtilityHelperService } from '../../../services/utilityHelper.services';\r\n\r\n@Component({\r\n  selector: 'eqp-dynamic-module-add-form-field',\r\n  templateUrl: './add-form-field.component.html',\r\n  styleUrls: ['./add-form-field.component.scss']\r\n})\r\nexport class AddFormFieldComponent implements OnInit {\r\n\r\n  @Input() field: BaseField | any;\r\n  @Input() indexField: number;\r\n  @Input() formFieldsGroups: Array<FormFieldGroup>;\r\n  /** Elenco dei Field creati nella form, usati per popolare l'autocomplete della proprietà Formula. */\r\n  @Input() availableFields: Array<BaseField>;\r\n  @Input() fieldTypesToExclude: Array<FieldTypeEnum> = [FieldTypeEnum['Form di dettaglio']];\r\n\r\n  fieldFormGroup: UntypedFormGroup;\r\n  keyValueObject: { key: string, value: string } = { key: '', value: '' };\r\n  availableColSpanSizes: Array<ColSpanSizesEnum> = [];\r\n  formulaAutocompleteOptions: Array<{ label: string, value: string }>;\r\n  VisibleIfAutocompleteOptions:Array<{ label: string, value: string }>;\r\n  AvailableFileExtensions = AvailableFileExtensions;\r\n  AvailableImageExtensions = AvailableImageExtensions;\r\n  \r\n  @Output() saveFieldEvent: EventEmitter<BaseField | any> = new EventEmitter<BaseField | any>();\r\n\r\n  //#region Template dei vari pezzi di form per la creazione di un campo(in base al tipo scelto).\r\n  fieldTypeFormTemplate: TemplateRef<any>;\r\n  @ViewChild('textFieldFormTemplate', { static: true }) textFieldFormTemplate: TemplateRef<any>;\r\n  @ViewChild('textareaFieldFormTemplate', { static: true }) textareaFieldFormTemplate: TemplateRef<any>;\r\n  @ViewChild('booleadFieldFormTemplate', { static: true }) booleadFieldFormTemplate: TemplateRef<any>;\r\n  @ViewChild('dateFieldFormTemplate', { static: true }) dateFieldFormTemplate: TemplateRef<any>;\r\n  @ViewChild('numericFieldFormTemplate', { static: true }) numericFieldFormTemplate: TemplateRef<any>;\r\n  @ViewChild('attachmentFieldFormTemplate', { static: true }) attachmentFieldFormTemplate: TemplateRef<any>;\r\n  @ViewChild('imageFieldFormTemplate', { static: true }) imageFieldFormTemplate: TemplateRef<any>;\r\n  @ViewChild('listValueFieldFormTemplate', { static: true }) listValueFieldFormTemplate: TemplateRef<any>;\r\n  @ViewChild('lookupFieldFormTemplate', { static: true }) lookupFieldFormTemplate: TemplateRef<any>;\r\n  //#endregion\r\n\r\n  //#region Proprietà per gestire i metadata nei campi ti dipo Allegato o Immagine\r\n  metadataColumns: Array<ConfigColumn>;\r\n  @ViewChild('metadataFieldsTable', { static: false }) metadataFieldsTable: EqpTableComponent;\r\n  selectedMetadata: BaseField;\r\n  indexSelectedMetadata: number;\r\n  dialogMetadataRef: MatDialogRef<TemplateRef<any>>;\r\n  @ViewChild('dialogMetadata', { static: true }) dialogMetadata: TemplateRef<any>;\r\n  //#endregion\r\n\r\n  //#region Proprietà per gestire le immagini nei capi di tipo elenco generico\r\n  @ViewChild('buttonImagesKeyValueInputColumn', { static: true }) buttonImagesKeyValueInputColumn: TemplateRef<any>;\r\n  //#endregion\r\n\r\n  //#region Enumeratori usati nell'html\r\n  FieldTypeEnum = FieldTypeEnum;\r\n  BoolPresentantioEnum = BoolPresentantioEnum;\r\n  DateTimeTypeEnum = DateTimeTypeEnum;\r\n  ListPresentationEnum = ListPresentationEnum;\r\n  TextMaskEnum = TextMaskEnum;\r\n  AttachmentType = AttachmentType;\r\n  pickerModeEnum = PickerModeEnum;\r\n  //#endregion\r\n\r\n  constructor(\r\n    private formBuilder: UntypedFormBuilder,\r\n    private enumHelper: EnumHelper,\r\n    private dialog: MatDialog,\r\n    private cdr: ChangeDetectorRef\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    if (!this.fieldTypesToExclude.includes(FieldTypeEnum['Form di dettaglio'])) {\r\n      this.fieldTypesToExclude.push(FieldTypeEnum['Form di dettaglio']);\r\n    }\r\n\r\n    this.onFieldTypeChange(false);\r\n    this.availableFields = this.availableFields ? this.availableFields.filter(f => f != this.field) : [];\r\n    this.configureColumns();\r\n  }\r\n\r\n  /**\r\n   * Metodo per impostare i valori da suggerire nell'autocomplete del campo Formula.\r\n   * Viene scatenato al focus (in questo caso viene passato il parametro a null per differenziarlo\r\n   * dall'evento di click sulla tastiera) e al keyup sull'input (il parametro è diverso da null).\r\n   * @param keyboardEvent Evento scatenato al keyup sulla tastiera. Se null allora il metodo è stato invocato dal focus sull'input.\r\n   * @summary Aggiorna l'elenco dei suggerimenti per l'autocomplete se l'utente esegue il focus sull'input\r\n   * oppure al keyup sulla tastiera di un tasto diverso dalle frecce.\r\n   */\r\n  setFormulaAutocompleteOptions(keyboardEvent: KeyboardEvent) {\r\n    // Creo l'array per l'autocomplete solo se sto facendo il focus sull'input o se sto premendo un tasto\r\n    // sulla tastiera diverso dalle frecce (in quest'ultimo caso, se non viene eseguito il filtro sull'evento,\r\n    // non si può selezionare un suggerimento dell'autocomplete perchè al click verrebbe ricaricato l'array e\r\n    // si prederebbe la selezione appena fatta).\r\n    if (!keyboardEvent || !keyboardEvent.code.includes(\"Arrow\")) {\r\n      this.formulaAutocompleteOptions = UtilityHelperService.GetAutocompleteOptions(this.availableFields, this.field.Formula);\r\n    }\r\n  }\r\n  setVisibleIfAutocompleteOptions(keyboardEvent: KeyboardEvent) {\r\n    // Creo l'array per l'autocomplete solo se sto facendo il focus sull'input o se sto premendo un tasto\r\n    // sulla tastiera diverso dalle frecce (in quest'ultimo caso, se non viene eseguito il filtro sull'evento,\r\n    // non si può selezionare un suggerimento dell'autocomplete perchè al click verrebbe ricaricato l'array e\r\n    // si prederebbe la selezione appena fatta).\r\n    if (!keyboardEvent || !keyboardEvent.code.includes(\"Arrow\")) {\r\n      this.VisibleIfAutocompleteOptions = UtilityHelperService.GetAutocompleteOptions(this.availableFields, this.field.VisibleIf);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Crea il FormGroup per l'aggiunta di un nuovo campo all'interno della form.\r\n   * Metodo richiamato ogni volta che cambia il tipo del campo scelto o viene aggiunto/modificato un Field\r\n   */\r\n  createFieldForm() {\r\n    this.fieldFormGroup = this.formBuilder.group({\r\n      Label: [this.field.Label, Validators.required],\r\n      Description: [this.field.Description, Validators.required],\r\n      Readonly: [this.field.Readonly],\r\n      Required: [this.field.Required],\r\n      VisibleIf: [this.field.VisibleIf],\r\n      Tooltip: [this.field.Tooltip],\r\n      LabelstyleCSS: [this.field.LabelstyleCSS],\r\n      FieldstyleCSS: [this.field.FieldstyleCSS],\r\n      FieldType: [this.field.FieldType, Validators.required],\r\n      Formula: [this.field.Formula],\r\n      ColSpanSizes: [this.field.ColSpanSizes],\r\n      InListView: [this.field.InListView],\r\n    });\r\n\r\n    if (this.formFieldsGroups) {\r\n      this.fieldFormGroup.addControl('FieldGroup', new UntypedFormControl(this.field.FieldGroup, Validators.required));\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo chiamato quando cambia il FieldType del BaseField che si sta aggiungendo/modificando.\r\n   * Ricrea l'oggetto field popolando solo le proprietà del BaseField inserite dall'utente\r\n   * (quelle comuni a tutte le tipologie di campo), ricrea la form e, in base al FieldType scelto,\r\n   * aggiunge alla form i FormControl necessari e seleziona il template corretto da usare.\r\n   * @param restoreField Se TRUE ripristina i valori base (ereditati dal modello BaseField) del campo aggiunto/modificato\r\n   */\r\n  onFieldTypeChange(restoreField: boolean = true) {\r\n    if (restoreField) {\r\n      this.restoreBaseFieldProperties();\r\n    } \r\n\r\n    this.createFieldForm();\r\n    this.onColSpanSizeSelect();\r\n    if ((this.field as BaseField).InListView == null) {\r\n      this.field.InListView = true;\r\n    }\r\n    this.fieldTypeFormTemplate = null;\r\n    switch (this.field.FieldType) {\r\n      case FieldTypeEnum['Campo di testo']:\r\n        this.fieldFormGroup.addControl('TextMask', new UntypedFormControl((this.field as TextField).TextMask));\r\n        this.fieldFormGroup.addControl('MaxLenght', new UntypedFormControl((this.field as TextField).MaxLenght));\r\n        this.fieldFormGroup.addControl('MinLenght', new UntypedFormControl((this.field as TextField).MinLenght));\r\n        this.fieldTypeFormTemplate = this.textFieldFormTemplate;\r\n        break;\r\n      case FieldTypeEnum['Area di testo']:\r\n        this.fieldFormGroup.addControl('Rows', new UntypedFormControl((this.field as TextareaField).Rows));\r\n        this.fieldFormGroup.addControl('MaxLenght', new UntypedFormControl((this.field as TextareaField).MaxLenght));\r\n        this.fieldFormGroup.addControl('MinLenght', new UntypedFormControl((this.field as TextareaField).MinLenght));\r\n        this.fieldTypeFormTemplate = this.textareaFieldFormTemplate;\r\n        break;\r\n      case FieldTypeEnum.Booleano:\r\n        this.fieldFormGroup.addControl('IsTristate', new UntypedFormControl((this.field as BooleanField).IsTristate));\r\n        this.fieldFormGroup.addControl(\r\n          'PresetationType',\r\n          new UntypedFormControl((this.field as BooleanField).PresetationType, Validators.required)\r\n        );\r\n        this.fieldTypeFormTemplate = this.booleadFieldFormTemplate;\r\n        break;\r\n      case FieldTypeEnum['Data e/o ora']:\r\n        if (this.field.IsOnlyDate == null ) {\r\n          this.field.IsOnlyDate = DateTimeTypeEnum['Solo data'];\r\n        }\r\n        this.fieldFormGroup.addControl('IsOnlyDate', new UntypedFormControl((this.field as DateField).IsOnlyDate, Validators.required));\r\n        this.fieldFormGroup.addControl('MinDate', new UntypedFormControl((this.field as DateField).MinDate));\r\n        this.fieldFormGroup.addControl('MaxDate', new UntypedFormControl((this.field as DateField).MaxDate));\r\n        this.fieldFormGroup.addControl('DateFormat', new UntypedFormControl((this.field as DateField).DateFormat));\r\n        this.fieldTypeFormTemplate = this.dateFieldFormTemplate;\r\n        break;\r\n      case FieldTypeEnum['Campo numerico']:\r\n        if ((this.field as NumericField).IsInteger == null) {\r\n          this.field.IsInteger = true;\r\n        }\r\n        this.fieldFormGroup.addControl('IsInteger', new UntypedFormControl((this.field as NumericField).IsInteger));\r\n        this.fieldFormGroup.addControl('MinValue', new UntypedFormControl((this.field as NumericField).MinValue));\r\n        this.fieldFormGroup.addControl('MaxValue', new UntypedFormControl((this.field as NumericField).MaxValue));\r\n        this.fieldFormGroup.addControl('DecimalSeparator', new UntypedFormControl((this.field as NumericField).DecimalSeparator));\r\n        this.fieldFormGroup.addControl('DecimalPrecision', new UntypedFormControl((this.field as NumericField).DecimalPrecision));\r\n        this.fieldFormGroup.addControl('ThousandsSeparator', new UntypedFormControl((this.field as NumericField).ThousandsSeparator));\r\n        this.fieldFormGroup.addControl('CurrencySymbol', new UntypedFormControl((this.field as NumericField).CurrencySymbol));\r\n        this.fieldTypeFormTemplate = this.numericFieldFormTemplate;\r\n        break;\r\n      case FieldTypeEnum.Allegato:\r\n        this.fieldFormGroup.addControl(\"AllowedExtensions\", new UntypedFormControl((this.field as AttachmentField).AllowedExtensions));\r\n        this.fieldFormGroup.addControl('IsMultiAttach', new UntypedFormControl((this.field as AttachmentField).IsMultiAttach));\r\n        this.fieldTypeFormTemplate = this.attachmentFieldFormTemplate;\r\n        break;\r\n      case FieldTypeEnum.Immagine:\r\n        (this.field as ImageField).AttachDefinition = new AttachmentField();\r\n        this.fieldFormGroup.addControl('EnableDrawing', new UntypedFormControl((this.field as ImageField).EnableDrawing));\r\n        this.fieldFormGroup.addControl('ImageIsContextualAttachment', new UntypedFormControl((this.field as ImageField).ImageIsContextualAttachment));\r\n        // Imposto i FormControl variabili.\r\n        this.onImageIsContextualAttachmentChange();\r\n        this.fieldTypeFormTemplate = this.imageFieldFormTemplate;\r\n        break;\r\n      case FieldTypeEnum['Elenco generico']:\r\n        if ((this.field as ListValueField).InListView == null) {\r\n          this.field.InListView = true;\r\n        }\r\n        this.fieldFormGroup.addControl('IsMultiChoiche', new UntypedFormControl((this.field as ListValueField).IsMultiChoiche));\r\n        this.fieldFormGroup.addControl(\r\n          'PresentationMode',\r\n          new UntypedFormControl((this.field as ListValueField).PresentationMode, Validators.required)\r\n        );\r\n        this.fieldTypeFormTemplate = this.listValueFieldFormTemplate;\r\n        break;\r\n      case FieldTypeEnum.Lookup:\r\n        this.fieldFormGroup.addControl(\r\n          'EntitySourceName',\r\n          new UntypedFormControl((this.field as LookupField).EntitySourceName, Validators.required)\r\n        );\r\n        this.fieldFormGroup.addControl('UseAsGetOrDiscard', new UntypedFormControl((this.field as LookupField).UseAsGetOrDiscard));\r\n        this.fieldTypeFormTemplate = this.lookupFieldFormTemplate;\r\n        break;\r\n    }\r\n    if ([FieldTypeEnum.Allegato, FieldTypeEnum.Immagine, FieldTypeEnum['Form di dettaglio']].includes(this.field.FieldType)) {\r\n      this.field.Formula = null;\r\n      this.fieldFormGroup.controls[\"Formula\"].disable();\r\n      this.fieldFormGroup.controls[\"InListView\"].disable();\r\n    } else {\r\n      this.fieldFormGroup.controls[\"Formula\"].enable();\r\n      this.fieldFormGroup.controls[\"InListView\"].enable();\r\n    }\r\n    if ([FieldTypeEnum.Allegato, FieldTypeEnum.Immagine, FieldTypeEnum['Form di dettaglio'], FieldTypeEnum['Data e/o ora']].includes(this.field.FieldType)) {\r\n      this.field.Formula = null;\r\n      this.fieldFormGroup.controls[\"LabelstyleCSS\"].disable();\r\n      this.fieldFormGroup.controls[\"FieldstyleCSS\"].disable();\r\n    } else {\r\n      this.fieldFormGroup.controls[\"LabelstyleCSS\"].enable();\r\n      this.fieldFormGroup.controls[\"FieldstyleCSS\"].enable();\r\n    }\r\n    if ([FieldTypeEnum.Booleano].includes(this.field.FieldType)) {\r\n      this.field.Formula = null;\r\n      this.fieldFormGroup.controls[\"LabelstyleCSS\"].disable();\r\n    } else {\r\n      this.fieldFormGroup.controls[\"LabelstyleCSS\"].enable();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo invocato al cambio del valore della proprietà ImageIsContextualAttachment nel caso\r\n   * di campi di tipo Immagine. Se TRUE allora rimuove i FormControl per le proprietà IsMultiAttach\r\n   * e AllowedExtensions e aggiunge i FormControl per le proprietà ImgName e ContextualAttachment, \r\n   * altrimenti il contrario.\r\n   */\r\n  onImageIsContextualAttachmentChange() {\r\n    (this.field as ImageField).ImgName = null;\r\n    (this.field as ImageField).AttachDefinition.AllowedExtensions = [];\r\n    (this.field as ImageField).AttachDefinition.IsMultiAttach = false;\r\n    (this.field as ImageField).ContextualAttachment = null;\r\n\r\n    if ((this.field as ImageField).ImageIsContextualAttachment) {\r\n      this.fieldFormGroup.removeControl(\"IsMultiAttach\");\r\n      this.fieldFormGroup.removeControl(\"AllowedExtensions\");\r\n      this.fieldFormGroup.addControl('ImgName', new UntypedFormControl((this.field as ImageField).ImgName, Validators.required));\r\n      this.fieldFormGroup.addControl('ContextualAttachment', new UntypedFormControl((this.field as ImageField).ContextualAttachment, Validators.required));\r\n    } else {\r\n      this.fieldFormGroup.removeControl(\"ImgName\");\r\n      this.fieldFormGroup.removeControl(\"ContextualAttachment\");\r\n      this.fieldFormGroup.addControl('IsMultiAttach', new UntypedFormControl((this.field as ImageField).AttachDefinition.IsMultiAttach));\r\n      this.fieldFormGroup.addControl(\"AllowedExtensions\", new UntypedFormControl((this.field as ImageField).AttachDefinition.AllowedExtensions));\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per intercettare l'aggiunta di un allegato nei campi di tipo Immagine per aggiornare\r\n   * il valore della proprietà ContextualAttachment e la validazione del relativo FormControl.\r\n   * @param event Array contenente l'elenco aggiornato degli allegati caricati (nel nostro caso ne contiene al più 1).\r\n   */\r\n  catchContextualAttachmentChange(event: Array<IAttachmentDTO>) {\r\n    if (event && event.length > 0) {\r\n      (this.field as ImageField).ContextualAttachment = event[0];\r\n    } else {\r\n      (this.field as ImageField).ContextualAttachment = null;\r\n    }\r\n    this.fieldFormGroup.controls['ContextualAttachment'].setValue((this.field as ImageField).ContextualAttachment);\r\n  }\r\n\r\n  /**\r\n   * Metodo invocato alla selezione di una classe nella select per le colonne di bootstrap\r\n   * da usare nella visualizzazione del campo. Questa funzione manipola la sorgente dati per\r\n   * la eqp-select in modo da escludere i valori dell'enumeratore che fanno riferimento ad\r\n   * una larghezza di schermo già selezionata. Esempio: per gli schermi piccoli (sm) l'utente\r\n   * seleziona la classe \"col-sm-6\", al change del valore questo metodo rimuove dalla select\r\n   * tutti gli altri valori per la grandezza di schermo selezionata.\r\n   */\r\n  onColSpanSizeSelect() {\r\n    // Recupero l'array degli oggetti chiave-valore che rappreseta l'enumeratore\r\n    let colSizeClassEnumArray = this.enumHelper.getEnumArray(ColSpanSizesEnum, false, null);\r\n    // Costruisco l'array delle classi selezionate dall'utente in formato stringa\r\n    let selectedDimensions: Array<string> = this.field.ColSpanSizes ? this.field.ColSpanSizes.map(col => ColSpanSizesEnum[col]) : [];\r\n    // Filtro i valori ottenuti dall'enumeratore per escludere tutti i valori per le\r\n    // grandezze di schermo già selezionatead esclusione dei valori selezionati.\r\n    this.availableColSpanSizes = colSizeClassEnumArray.filter((value: { key: number, value: string }) =>\r\n      !selectedDimensions.find(col => value.value.includes(col.substring(4, 6)) && value.value != col)\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Metodo invocato al cambio del tipo di visualizzazione scelta per i campi di tipo elenco generico.\r\n   * Se viene scelta la visualizzazione ad immagini svuota la lista delle coppie chiave-valore inserite\r\n   * in precedenza, altrimenti svuota la lista delle immagini caricate.\r\n   */\r\n  onPresentationModeChange() {\r\n    if ((this.field as ListValueField).PresentationMode === ListPresentationEnum.Immagini) {\r\n      (this.field as ListValueField).ValuePairs = null;\r\n    } else {\r\n      (this.field as ListValueField).ButtonImageList = null;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo invocato quando viene caricato il componente eqp-attachments per caricare le immagini da usare \r\n   * nella visualizzazione ad immagini dei campi di tipo \"Elenco generico\". Aggiunge due colonne a quelle\r\n   * configurate nel componente in cui l'utente può indicare chiave e valore della scelta.\r\n   * @param component Istanza del componente eqp-attachments in cui effettuare la modifica.\r\n   */\r\n  configureButtonImagesColumns(component: EqpAttachmentsComponent) {\r\n    component.attachmentsColumns.splice(\r\n      component.attachmentsColumns.length - 1, 0,\r\n      { key: \"ButtonKey\", display: \"Label\", type: TypeColumn.ExternalTemplate, externalTemplate: this.buttonImagesKeyValueInputColumn }\r\n    );\r\n\r\n    component.attachmentsColumns.splice(\r\n      component.attachmentsColumns.length - 1, 0,\r\n      { key: \"ButtonValue\", display: \"Valore\", type: TypeColumn.ExternalTemplate, externalTemplate: this.buttonImagesKeyValueInputColumn }\r\n    );\r\n\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  /**\r\n   * Metodo invocato al salvataggio degli allegati quando viene configurato un campo di tipo \"Elenco generico\"\r\n   * con il tipo di visualizzazione ad immagini. Intercetta l'elenco aggiornato delle immagini caricate e lo\r\n   * memorizza nell'oggetto field corrente.\r\n   * @param attachments Array aggiornato degli allegati caricati.\r\n   */\r\n  catchButtonImagesChange(attachments: Array<IAttachmentDTO>) {\r\n    (this.field as ListValueField).ButtonImageList = (attachments as Array<ButtonImage>);\r\n  }\r\n\r\n  /**\r\n   * Metodo chiamato al keyup degli input testuali che prevedono l'aggiunta del valore inserito in un array.\r\n   * Se l'utente preme il tasto invio, in base al tipo di campo che sta inserendo/modificando, questo metodo\r\n   * aggiunge il valore inserito dall'utente nella lista di stringhe corretta (in input viene passato il nome\r\n   * della proprietà in cui inserire la stringa).\r\n   * @param event Evento che rappresenta il keyup dell'utente\r\n   * @param propertyName Nome della proprietà del field in cui inserire la stringa digitata.\r\n   */\r\n  onMultiSelectInputKeyup(event, propertyName: string) {\r\n    if (event.code === 'Enter' || event.code === 'NumpadEnter') {\r\n      switch (this.field.FieldType) {\r\n        case FieldTypeEnum.Lookup:\r\n        case FieldTypeEnum.Allegato:\r\n          if (!this.field[propertyName]) {\r\n            this.field[propertyName] = new Array<string>();\r\n          }\r\n          this.field[propertyName].push(event.currentTarget.value);\r\n          break;\r\n        case FieldTypeEnum.Immagine:\r\n          if (!(this.field as ImageField).AttachDefinition[propertyName]) {\r\n            (this.field as ImageField).AttachDefinition[propertyName] = new Array<string>();\r\n          }\r\n          (this.field as ImageField).AttachDefinition[propertyName].push(event.currentTarget.value);\r\n          break;\r\n        case FieldTypeEnum['Elenco generico']:\r\n          if (!this.keyValueObject.key || !this.keyValueObject.value) {\r\n            return;\r\n          }\r\n          if (!(this.field as ListValueField).ValuePairs) {\r\n            (this.field as ListValueField).ValuePairs = {};\r\n          }\r\n          (this.field as ListValueField).ValuePairs[this.keyValueObject.key] = this.keyValueObject.value;\r\n          this.keyValueObject = { key: '', value: '' };\r\n          break;\r\n      }\r\n      event.currentTarget.value = null;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo chiamato per mostrare come elenco le opzioni aggiunte in un campo di tipo \"Elenco generico\".\r\n   * @returns Restituisce un array di oggetti del tipo { key: string, value: string } con i valori inseriti dall'utente.\r\n   */\r\n  getDictionaryKeyValue() {\r\n    if ((this.field as ListValueField).ValuePairs) {\r\n      \r\n      return Object.keys((this.field as ListValueField).ValuePairs).map(k => {\r\n        return {\r\n          key: k,\r\n          value: (this.field as ListValueField).ValuePairs[k]\r\n          \r\n        };\r\n      });\r\n     \r\n      \r\n    } else {\r\n      return [];\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per rimuovere una opzione aggiunta al campo di tipo \"Elenco generico\"\r\n   * @param key Nome della chiave da rimuovere\r\n   */\r\n  deleteKeyFromDictionary(key: string) {\r\n    delete (this.field as ListValueField).ValuePairs[key];\r\n  }\r\n\r\n  /**\r\n   * Metodo per aprire il dialog per aggiungere/modificare un metadata in un campo di tipo Allegato o Immagine.\r\n   * @param metadata Metadata da modificare, se null allora ne sto creando uno nuovo.\r\n   */\r\n  openMetadataDialog(field: BaseField = null) {\r\n    if (field) {\r\n      if (this.field.FieldType === FieldTypeEnum.Allegato) {\r\n        this.indexSelectedMetadata = (this.field as AttachmentField).MetadataFields.indexOf(field);\r\n        this.selectedMetadata = JSON.parse(JSON.stringify(field));\r\n      } else if (this.field.FieldType === FieldTypeEnum.Immagine) {\r\n        this.indexSelectedMetadata = (this.field as ImageField).AttachDefinition.MetadataFields.indexOf(field);\r\n        this.selectedMetadata = JSON.parse(JSON.stringify(field));\r\n      }\r\n    } else {\r\n      this.selectedMetadata = new BaseField();\r\n      this.indexSelectedMetadata = null;\r\n    }\r\n    this.dialogMetadataRef = this.dialog.open(this.dialogMetadata, {\r\n      disableClose: true,\r\n      hasBackdrop: true,\r\n      width: '75%'\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Metodo invocato dall'output dal dialog per aggiungere/modificare un metadata\r\n   * nei campi di tipo Allegato o Immagine. Prima di aggiungere il metadata nell'elenco\r\n   * contolla se esiste un altro metadata con lo stesso nome e nel caso genera un errore\r\n   * (i metadata, come per i campi della form, devono avere un nome univoco).\r\n   * @param metadata Metadata aggiunto o modificato, se null allora il dialog è stato chiuso senza fare modifiche.\r\n   */\r\n  onSaveMetadata(metadata: BaseField) {\r\n    if (metadata) {\r\n      if (\r\n        (this.field.FieldType === FieldTypeEnum.Allegato\r\n          && (this.field as AttachmentField).MetadataFields\r\n          && (this.field as AttachmentField).MetadataFields.find(\r\n            (m, i) => m.Label === metadata.Label\r\n              && (this.indexSelectedMetadata == null ? true : this.indexSelectedMetadata !== i)\r\n          )\r\n        ) ||\r\n        (this.field.FieldType === FieldTypeEnum.Immagine\r\n          && (this.field as ImageField).AttachDefinition.MetadataFields\r\n          && (this.field as ImageField).AttachDefinition.MetadataFields.find(\r\n            (m, i) => m.Label === metadata.Label\r\n              && (this.indexSelectedMetadata == null ? true : this.indexSelectedMetadata !== i)\r\n          )\r\n        )\r\n      ) {\r\n        EqpDynamicModuleDialogService.Warning('Impossibile inserire due metadata con la stessa label.');\r\n        throw new Error('Impossibile inserire due metadata con la stessa label.');\r\n      }\r\n\r\n      if (this.indexSelectedMetadata != null && this.indexSelectedMetadata >= 0) {\r\n        if (this.field.FieldType === FieldTypeEnum.Allegato) {\r\n          (this.field as AttachmentField).MetadataFields[this.indexSelectedMetadata] = metadata;\r\n        } else if (this.field.FieldType === FieldTypeEnum.Immagine) {\r\n          (this.field as ImageField).AttachDefinition.MetadataFields[this.indexSelectedMetadata] = metadata;\r\n        }\r\n      } else {\r\n        if (this.field.FieldType === FieldTypeEnum.Allegato) {\r\n          if (!(this.field as AttachmentField).MetadataFields) {\r\n            (this.field as AttachmentField).MetadataFields = new Array<BaseField>();\r\n          }\r\n          (this.field as AttachmentField).MetadataFields.push(metadata);\r\n        } else if (this.field.FieldType === FieldTypeEnum.Immagine) {\r\n          if (!(this.field as ImageField).AttachDefinition.MetadataFields) {\r\n            (this.field as ImageField).AttachDefinition.MetadataFields = new Array<BaseField>();\r\n          }\r\n          (this.field as ImageField).AttachDefinition.MetadataFields.push(metadata);\r\n        }\r\n      }\r\n    }\r\n    this.dialogMetadataRef.close();\r\n    this.setMetadataOrdinalPosition();\r\n    this.reloadMetadataTable();\r\n  }\r\n\r\n  /**\r\n   * Metodo per disabilitare il pulsante per salvare il campo inserito/modificato.\r\n   * @returns Restituisce un booleano, se true il salvataggio viene disabilitato.\r\n   */\r\n  disableSaveField(): boolean {\r\n    if (this.fieldFormGroup.invalid) {\r\n      return true;\r\n    }\r\n\r\n    switch (this.field.FieldType) {\r\n\r\n      case FieldTypeEnum['Elenco generico']:\r\n        if ((this.field as ListValueField).PresentationMode != ListPresentationEnum.Immagini) {\r\n          return !(this.field as ListValueField).ValuePairs || (this.field as ListValueField).ValuePairs.length === 0;\r\n        } else {\r\n          return (\r\n            !(this.field as ListValueField).ButtonImageList\r\n            || (this.field as ListValueField).ButtonImageList.length === 0\r\n            || !!(this.field as ListValueField).ButtonImageList.find(i => !i.ButtonKey || !i.ButtonValue)\r\n          );\r\n        }\r\n      case FieldTypeEnum.Lookup:\r\n        return !(this.field as LookupField).FieldNames || (this.field as LookupField).FieldNames.length === 0;\r\n      default:\r\n        return false;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per salvare il campo inserito/modificato.\r\n   * Se è stato inserito un field con la stessa label viene generato un errore (le label devono essere univoche).\r\n   * Una volta aggiunto/aggiornato il campo nell'elenco dei Field della Form chiude il dialog e ricarica la tabella\r\n   * che mostra l'elenco dei campi aggiunti alla form.\r\n   */\r\n  saveAndExitAddField(save: boolean) {\r\n    if (save) {\r\n      this.saveFieldEvent.emit(this.field);\r\n    } else {\r\n      this.saveFieldEvent.emit(null);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per ripristinare l'oggetto field al cambio del tipo selezionato.\r\n   * Lascia valorizzate solo le proprietà dell'oggetto BaseField comune a tutti i tipi di campo.\r\n   */\r\n  private restoreBaseFieldProperties() {\r\n    if (this.field) {\r\n      const tmpBaseField = JSON.parse(JSON.stringify(this.field));\r\n      this.field = new BaseField();\r\n      this.field.Label = tmpBaseField.Label;\r\n      this.field.Description = tmpBaseField.Description;\r\n      this.field.Required = tmpBaseField.Required;\r\n      this.field.FieldType = tmpBaseField.FieldType;\r\n      this.field.Formula = tmpBaseField.Formula;\r\n      this.field.ColSpanSizes = tmpBaseField.ColSpanSizes;\r\n      this.field.InListView = tmpBaseField.InListView;\r\n      this.field.Tooltip = tmpBaseField.Tooltip;\r\n      this.field.Readonly = tmpBaseField.Readonly;\r\n      this.field.FieldGroup = tmpBaseField.FieldGroup;\r\n      this.field.VisibleIf = tmpBaseField.VisibleIf;\r\n    }\r\n  }\r\n\r\n  private configureColumns() {\r\n    this.metadataColumns = [\r\n      {\r\n        key: 'action', display: '', type: TypeColumn.MenuAction, buttonMenuIcon: 'more_vert', styles: { flex: '0 0 6%' },\r\n        actions: [\r\n          { name: 'Modifica', icon: 'edit', fn: (element, index, col) => this.openMetadataDialog(element) },\r\n          { name: 'Elimina', icon: 'delete', fn: (element, index, col) => this.deleteMetadata(element) },\r\n        ]\r\n      },\r\n      { key: 'FieldType', display: 'Tipologia', type: TypeColumn.Enum, enumModel: FieldTypeEnum },\r\n      { key: 'Label', display: 'Label' },\r\n      { key: 'Description', display: 'Descrizione' },\r\n      {\r\n        key: 'Required', display: 'Obbligatorio',\r\n        value: (element) => !!element.Required,\r\n        type: TypeColumn.Boolean,\r\n        booleanValues: {\r\n          true: '<i class=\"fa fa-check success-color\"></i>',\r\n          false: '<i class=\"fa fa-close error-color\"></i>'\r\n        },\r\n        styles: { flex: '0 0 7%', cellAlignment: CellAlignmentEnum.CENTER }\r\n      },\r\n    ];\r\n  }\r\n\r\n  /**\r\n   * Metodo per eliminare un metadata aggiunto per un campo di tipo Allegato o Immagine.\r\n   * @param metadata Metadata da eliminare.\r\n   */\r\n  private deleteMetadata(metadata: BaseField) {\r\n    EqpDynamicModuleDialogService.Confirm('Eliminare il metadata selezionato?', () => {\r\n      if (this.field.FieldType === FieldTypeEnum.Allegato) {\r\n        (this.field as AttachmentField).MetadataFields.splice((this.field as AttachmentField).MetadataFields.indexOf(metadata), 1);\r\n      } else if (this.field.FieldType === FieldTypeEnum.Immagine) {\r\n        (this.field as ImageField).AttachDefinition.MetadataFields.splice((this.field as ImageField).AttachDefinition.MetadataFields.indexOf(metadata), 1);\r\n      }\r\n      this.setMetadataOrdinalPosition();\r\n      this.reloadMetadataTable();\r\n    }, false, 'Richiesta conferma');\r\n  }\r\n\r\n  /**\r\n   * Imposta l'ordinamento dei metadata all'interno dei campi di tipo Allegato e Immagine.\r\n   */\r\n  private setMetadataOrdinalPosition() {\r\n    if (this.field.FieldType === FieldTypeEnum.Allegato) {\r\n      if ((this.field as AttachmentField).MetadataFields) {\r\n        (this.field as AttachmentField).MetadataFields.forEach(metadata => {\r\n          metadata.OrdinalPosition = (this.field as AttachmentField).MetadataFields.indexOf(metadata);\r\n        });\r\n      }\r\n    } else if (this.field.FieldType === FieldTypeEnum.Immagine) {\r\n      if ((this.field as ImageField).AttachDefinition.MetadataFields) {\r\n        (this.field as ImageField).AttachDefinition.MetadataFields.forEach(metadata => {\r\n          metadata.OrdinalPosition = (this.field as ImageField).AttachDefinition.MetadataFields.indexOf(metadata);\r\n        });\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per ricaricare i dati della tabella dei metadata visualizzata nella creazione/modifica \r\n   * dei campi di tipo Allegato o Immagine.\r\n   */\r\n  private reloadMetadataTable() {\r\n    if (this.metadataFieldsTable) {\r\n      this.metadataFieldsTable.reloadDatatable();\r\n    }\r\n  }\r\n\r\n\r\n\r\n}\r\n","<div class=\"container-fluid\" style=\"max-height: 70vh !important; overflow-x: hidden; overflow-y: auto;\">\r\n    <div class=\"row title\">\r\n        <div class=\"header-title-standard\">{{indexField != null && indexField >= 0 ? \"Modifica\"\r\n            : \"Aggiungi\"}} campo</div>\r\n    </div>\r\n    <form [formGroup]=\"fieldFormGroup\">\r\n        <div class=\"row\">\r\n            <div class=\"col-sm-12 col-md-4 mt-2 tipoCampo\">\r\n                <mat-label>Tipo campo *</mat-label>\r\n                <eqp-select [enumData]=\"FieldTypeEnum\" [(ngModelInput)]=\"field.FieldType\" [showCancelButton]=\"false\"\r\n                    (ngModelInputChange)=\"onFieldTypeChange()\" [formGroupInput]=\"fieldFormGroup\"\r\n                    [formControlNameInput]=\"'FieldType'\" [enumDataToExclude]=\"fieldTypesToExclude\">\r\n                </eqp-select>\r\n            </div>\r\n\r\n            <div class=\"col-sm-12 col-md-4 mt-2\">\r\n                <mat-label> Codice * </mat-label>\r\n                <mat-form-field>\r\n                    <input formControlName=\"Label\" required matInput [(ngModel)]=\"field.Label\">\r\n                </mat-form-field>\r\n            </div>\r\n\r\n            <div class=\"col-sm-12 col-md-4 mt-2\">\r\n                <mat-label> Descrizione * </mat-label>\r\n                <mat-form-field>\r\n                    <input name=\"Description\" formControlName=\"Description\" required matInput\r\n                        [(ngModel)]=\"field.Description\">\r\n                </mat-form-field>\r\n            </div>\r\n\r\n            <div class=\"col-sm-12 col-md-4 mt-2\">\r\n                <mat-label> Tooltip </mat-label>\r\n                <mat-form-field>\r\n                    <input name=\"Tooltip\" formControlName=\"Tooltip\" matInput [(ngModel)]=\"field.Tooltip\" >\r\n                </mat-form-field>\r\n            </div>\r\n\r\n            <div class=\"col-sm-12 col-md-4 mt-2\">\r\n                <mat-label> Formula (Javascript) </mat-label>\r\n                <mat-form-field>\r\n                    <input formControlName=\"Formula\" matInput [(ngModel)]=\"field.Formula\"\r\n                        [matAutocomplete]=\"formulaAutocomplete\" (keyup)=\"setFormulaAutocompleteOptions($event)\"\r\n                        (focus)=\"setFormulaAutocompleteOptions(null)\">\r\n                    <mat-autocomplete #formulaAutocomplete=\"matAutocomplete\">\r\n                        <mat-option *ngFor=\"let option of formulaAutocompleteOptions\" [value]=\"option.value\">\r\n                            {{option.label}}\r\n                        </mat-option>\r\n                    </mat-autocomplete>\r\n                </mat-form-field>\r\n            </div>\r\n\r\n            <div class=\"col-sm-12 col-md-4 mt-2\" *ngIf=\"formFieldsGroups\">\r\n                <mat-label>Sezione</mat-label>\r\n                <eqp-select [arrayData]=\"formFieldsGroups\" [(ngModelInput)]=\"field.FieldGroup\"\r\n                    [arrayKeyProperty]=\"'Name'\" [arrayValueProperty]=\"'Name'\" [formGroupInput]=\"fieldFormGroup\"\r\n                    [formControlNameInput]=\"'FieldGroup'\" required [includeFullObject]=\"false\">\r\n                </eqp-select>\r\n            </div>\r\n            <div class=\"col-sm-12 col-md-4 mt-2\">\r\n                <mat-label>Larghezza campo</mat-label>\r\n                <eqp-select [arrayData]=\"availableColSpanSizes\" [(ngModelInput)]=\"field.ColSpanSizes\"\r\n                    [arrayKeyProperty]=\"'key'\" [arrayValueProperty]=\"'value'\"\r\n                    (ngModelInputChange)=\"onColSpanSizeSelect()\" [isMultiSelect]=\"true\"\r\n                    [formGroupInput]=\"fieldFormGroup\" [formControlNameInput]=\"'ColSpanSizes'\"\r\n                    [includeFullObject]=\"false\">\r\n                </eqp-select>\r\n            </div>\r\n            <div class=\"col-sm-12 col-md-4 mt-2\">\r\n                <mat-label> Label css </mat-label>\r\n                <mat-form-field>\r\n                    <input name=\"LabelstyleCSS\" formControlName=\"LabelstyleCSS\" matInput\r\n                        [(ngModel)]=\"field.LabelstyleCSS\">\r\n                </mat-form-field>\r\n            </div>\r\n            <div class=\"col-sm-12 col-md-4 mt-2\">\r\n                <mat-label> Field css </mat-label>\r\n                <mat-form-field>\r\n                    <input name=\"FieldstyleCSS\" formControlName=\"FieldstyleCSS\" matInput\r\n                        [(ngModel)]=\"field.FieldstyleCSS\">\r\n                </mat-form-field>\r\n            </div>\r\n\r\n            <div class=\"col-sm-12 col-md-4 mt-2 d-flex align-items-center\">\r\n                <mat-slide-toggle [(ngModel)]=\"field.Required\" formControlName=\"Required\" color=\"primary\">\r\n                    Obbligatorio\r\n                </mat-slide-toggle>\r\n            </div>\r\n            <div class=\"col-sm-12 col-md-4 mt-2 d-flex align-items-center\">\r\n                <mat-slide-toggle [(ngModel)]=\"field.Readonly\" formControlName=\"Readonly\" color=\"primary\">\r\n                    ReadOnly\r\n                </mat-slide-toggle>\r\n            </div>\r\n            <div class=\"col-sm-12 col-md-4 mt-2\">\r\n                <mat-label> VisibleIf </mat-label>\r\n                <mat-form-field>\r\n                    <input name=\"VisibleIf\" formControlName=\"VisibleIf\" matInput [(ngModel)]=\"field.VisibleIf\"  [matAutocomplete]=\"VisibleIfAutocomplete\" (keyup)=\"setVisibleIfAutocompleteOptions($event)\"\r\n                    (focus)=\"setVisibleIfAutocompleteOptions(null)\">\r\n                    <mat-autocomplete #VisibleIfAutocomplete=\"matAutocomplete\">\r\n                        <mat-option *ngFor=\"let option of VisibleIfAutocompleteOptions\" [value]=\"option.value\">\r\n                            {{option.label}}\r\n                        </mat-option>\r\n                    </mat-autocomplete>\r\n                </mat-form-field>\r\n            </div>\r\n            <div class=\"col-sm-12 col-md-4 mt-2 align-self-center\"\r\n                [hidden]=\"(field.VisibleIf != null || field.VisibleIf != undefined) && field.VisibleIf != ''\">\r\n                <div class=\"d-flex align-items-center\">\r\n                    <mat-slide-toggle [(ngModel)]=\"field.InListView\" formControlName=\"InListView\" color=\"primary\"\r\n                        [disabled]=\"fieldFormGroup.controls['InListView'].disabled\">\r\n                        Visibile\r\n                    </mat-slide-toggle>\r\n                </div>\r\n            </div>\r\n            <ng-container *ngTemplateOutlet=\"fieldTypeFormTemplate\">\r\n            </ng-container>\r\n        </div>\r\n    </form>\r\n</div>\r\n\r\n<div class=\"d-flex justify-content-end mt-2 mb-1\">\r\n    <div class=\"buttonsForm\">\r\n        <button class=\"btn mat-raised-button cancel\" (click)=\"saveAndExitAddField(false)\" type=\"button\">\r\n            Annulla\r\n        </button>\r\n        <button class=\"mr-2 save\" mat-raised-button color=\"primary\" (click)=\"saveAndExitAddField(true)\"\r\n            [disabled]=\"disableSaveField()\" type=\"button\">\r\n            Salva\r\n        </button>\r\n    </div>\r\n</div>\r\n\r\n\r\n<!-- FORM PROPRIETÀ CAMPI DI TESTO -->\r\n<ng-template #textFieldFormTemplate>\r\n    <div class=\"col-sm-12 col-md-4\">\r\n        <mat-label>Maschera</mat-label>\r\n        <eqp-select [enumData]=\"TextMaskEnum\" [(ngModelInput)]=\"field.TextMask\" [formGroupInput]=\"fieldFormGroup\"\r\n            [formControlNameInput]=\"'TextMask'\">\r\n        </eqp-select>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Lunghezza minima </mat-label>\r\n        <mat-form-field>\r\n            <input id=\"lengthMin\" formControlName=\"MinLenght\" type=\"number\" [min]=\"0\" matInput\r\n                [(ngModel)]=\"field.MinLenght\">\r\n        </mat-form-field>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Lunghezza massima </mat-label>\r\n        <mat-form-field>\r\n            <input id=\"lengthMax\" formControlName=\"MaxLenght\" type=\"number\" [min]=\"0\" matInput\r\n                [(ngModel)]=\"field.MaxLenght\">\r\n        </mat-form-field>\r\n    </div>\r\n</ng-template>\r\n\r\n<!-- FORM PROPRIETÀ CAMPI AREA DI TESTO -->\r\n<ng-template #textareaFieldFormTemplate>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Righe </mat-label>\r\n        <mat-form-field class=\"righe\">\r\n            <input id=\"rows\" formControlName=\"Rows\" type=\"number\" [min]=\"0\" matInput [(ngModel)]=\"field.Rows\">\r\n        </mat-form-field>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Lunghezza minima </mat-label>\r\n        <mat-form-field>\r\n            <input id=\"lengthMin\" formControlName=\"MinLenght\" type=\"number\" [min]=\"0\" matInput\r\n                [(ngModel)]=\"field.MinLenght\">\r\n        </mat-form-field>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Lunghezza massima </mat-label>\r\n        <mat-form-field>\r\n            <input id=\"lengthMax\" formControlName=\"MaxLenght\" type=\"number\" [min]=\"0\" matInput\r\n                [(ngModel)]=\"field.MaxLenght\">\r\n        </mat-form-field>\r\n    </div>\r\n</ng-template>\r\n\r\n<!-- FORM PROPRIETÀ CAMPI BOOLEANI -->\r\n<ng-template #booleadFieldFormTemplate>\r\n    <div class=\"col-sm-12 col-md-4 mt-2 d-flex align-items-center\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-slide-toggle [(ngModel)]=\"field.IsTristate\" formControlName=\"IsTristate\" color=\"primary\">\r\n            A tre stati\r\n        </mat-slide-toggle>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\">\r\n        <mat-label>Tipo di presentazione *</mat-label>\r\n        <eqp-select [enumData]=\"BoolPresentantioEnum\" [(ngModelInput)]=\"field.PresetationType\" required\r\n            [showCancelButton]=\"false\" [formGroupInput]=\"fieldFormGroup\" [formControlNameInput]=\"'PresetationType'\">\r\n        </eqp-select>\r\n    </div>\r\n</ng-template>\r\n\r\n<!-- FORM PROPRIETÀ CAMPI DATA -->\r\n<ng-template #dateFieldFormTemplate>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\">\r\n        <mat-label>Tipo di data</mat-label>\r\n        <eqp-select [enumData]=\"DateTimeTypeEnum\" [(ngModelInput)]=\"field.IsOnlyDate\" required\r\n            [showCancelButton]=\"false\" [formGroupInput]=\"fieldFormGroup\" [formControlNameInput]=\"'IsOnlyDate'\">\r\n        </eqp-select>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Formato </mat-label>\r\n        <mat-form-field>\r\n            <input formControlName=\"DateFormat\" matInput [(ngModel)]=\"field.DateFormat\"\r\n                [matTooltip]=\"'Indicare il formato seguendo la guida del pacchetto momentjs.'\">\r\n        </mat-form-field>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\">\r\n        <mat-label> Data minima </mat-label>\r\n        <eqp-datetimepicker *ngIf=\"field.IsOnlyDate == DateTimeTypeEnum['Solo data']\" class=\"date\"\r\n            [(ngModelInput)]=\"field.MinDate\" [formGroupInput]=\"fieldFormGroup\" [formControlNameInput]=\"'MinDate'\"\r\n            [pickerMode]=\"pickerModeEnum.DATE\" [UTCDate]=\"true\" [showSeconds]=\"false\">\r\n        </eqp-datetimepicker>\r\n        <eqp-datetimepicker *ngIf=\"field.IsOnlyDate == DateTimeTypeEnum['Data e ora']\" class=\"date\"\r\n            [(ngModelInput)]=\"field.MinDate\" [formGroupInput]=\"fieldFormGroup\" [formControlNameInput]=\"'MinDate'\"\r\n            [pickerMode]=\"pickerModeEnum.DATETIME\" [UTCDate]=\"true\" [showSeconds]=\"false\">\r\n        </eqp-datetimepicker>\r\n        <eqp-datetimepicker *ngIf=\"field.IsOnlyDate == DateTimeTypeEnum['Solo orario']\" class=\"date\"\r\n            [(ngModelInput)]=\"field.MinDate\" [formGroupInput]=\"fieldFormGroup\" [formControlNameInput]=\"'MinDate'\"\r\n            [pickerMode]=\"pickerModeEnum.TIME\" [UTCDate]=\"true\" [showSeconds]=\"false\">\r\n        </eqp-datetimepicker>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\">\r\n        <mat-label> Data massima </mat-label>\r\n        <eqp-datetimepicker *ngIf=\"field.IsOnlyDate == DateTimeTypeEnum['Solo data']\" class=\"date\"\r\n            [(ngModelInput)]=\"field.MaxDate\" [formGroupInput]=\"fieldFormGroup\" [formControlNameInput]=\"'MaxDate'\"\r\n            [pickerMode]=\"pickerModeEnum.DATE\" [UTCDate]=\"true\" [showSeconds]=\"false\">\r\n        </eqp-datetimepicker>\r\n        <eqp-datetimepicker *ngIf=\"field.IsOnlyDate == DateTimeTypeEnum['Data e ora']\" class=\"date\"\r\n            [(ngModelInput)]=\"field.MaxDate\" [formGroupInput]=\"fieldFormGroup\" [formControlNameInput]=\"'MaxDate'\"\r\n            [pickerMode]=\"pickerModeEnum.DATETIME\" [UTCDate]=\"true\" [showSeconds]=\"false\">\r\n        </eqp-datetimepicker>\r\n        <eqp-datetimepicker *ngIf=\"field.IsOnlyDate == DateTimeTypeEnum['Solo orario']\" class=\"date\"\r\n            [(ngModelInput)]=\"field.MaxDate\" [formGroupInput]=\"fieldFormGroup\" [formControlNameInput]=\"'MaxDate'\"\r\n            [pickerMode]=\"pickerModeEnum.TIME\" [UTCDate]=\"true\" [showSeconds]=\"false\">\r\n        </eqp-datetimepicker>\r\n    </div>\r\n</ng-template>\r\n\r\n<!-- FORM PROPRIETÀ CAMPI NUMERICI -->\r\n<ng-template #numericFieldFormTemplate>\r\n    <div class=\"col-sm-12 col-md-4 mt-2 d-flex align-items-center\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-slide-toggle [(ngModel)]=\"field.IsInteger\" formControlName=\"IsInteger\" color=\"primary\">\r\n            Valore intero\r\n        </mat-slide-toggle>\r\n    </div>\r\n    <div *ngIf=\"!field.IsInteger\" class=\"col-sm-12 col-md-4 mt-2\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Separatore decimali </mat-label>\r\n        <mat-form-field>\r\n            <input formControlName=\"DecimalSeparator\" matInput [(ngModel)]=\"field.DecimalSeparator\">\r\n        </mat-form-field>\r\n    </div>\r\n    <div *ngIf=\"!field.IsInteger\" class=\"col-sm-12 col-md-4 mt-2\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Precisione decimali </mat-label>\r\n        <mat-form-field>\r\n            <input formControlName=\"DecimalPrecision\" type=\"number\" [min]=\"0\" matInput\r\n                [(ngModel)]=\"field.DecimalPrecision\">\r\n        </mat-form-field>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Separatore migliaia </mat-label>\r\n        <mat-form-field>\r\n            <input formControlName=\"ThousandsSeparator\" matInput [(ngModel)]=\"field.ThousandsSeparator\">\r\n        </mat-form-field>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Simbolo valuta </mat-label>\r\n        <mat-form-field>\r\n            <input formControlName=\"CurrencySymbol\" matInput [(ngModel)]=\"field.CurrencySymbol\">\r\n        </mat-form-field>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Valore minimo </mat-label>\r\n        <mat-form-field>\r\n            <input formControlName=\"MinValue\" type=\"number\" [min]=\"0\" matInput [(ngModel)]=\"field.MinValue\">\r\n        </mat-form-field>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Valore massimo </mat-label>\r\n        <mat-form-field>\r\n            <input formControlName=\"MaxValue\" type=\"number\" [min]=\"0\" matInput [(ngModel)]=\"field.MaxValue\">\r\n        </mat-form-field>\r\n    </div>\r\n</ng-template>\r\n\r\n<!-- FORM PROPRIETÀ CAMPI ALLEGATO -->\r\n<ng-template #attachmentFieldFormTemplate>\r\n    <div class=\"col-sm-12 col-md-4 mt-2 d-flex align-items-center\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-slide-toggle [(ngModel)]=\"field.IsMultiAttach\" formControlName=\"IsMultiAttach\" color=\"primary\">\r\n            Allegati multipli\r\n        </mat-slide-toggle>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\">\r\n        <mat-label>Estensioni accettate</mat-label>\r\n        <eqp-select [arrayData]=\"AvailableFileExtensions.concat(AvailableImageExtensions)\"\r\n            [(ngModelInput)]=\"field.AllowedExtensions\" [arrayKeyProperty]=\"'key'\" [arrayValueProperty]=\"'value'\"\r\n            [isMultiSelect]=\"true\" [formGroupInput]=\"fieldFormGroup\" [formControlNameInput]=\"'AllowedExtensions'\"\r\n            [includeFullObject]=\"false\">\r\n        </eqp-select>\r\n    </div>\r\n    <div class=\"col-sm-12 mt-2\">\r\n        <div class=\"row mt-2\">\r\n            <div class=\"col-sm-12 col-md-6\">\r\n                <div class=\"header-title-standard\">\r\n                    Elenco metadata\r\n                </div>\r\n            </div>\r\n            <div class=\"col-sm-12 col-md-6 text-right buttonsForm\">\r\n                <button class=\"btn btn-primary save\" mat-raised-button color=\"primary\" type=\"button\"\r\n                    (click)=\"openMetadataDialog()\">\r\n                    <mat-icon>add</mat-icon>\r\n                    <span style=\"margin-left: 10px;\">Aggiungi allegato</span>\r\n                </button>\r\n            </div>\r\n        </div>\r\n        <eqp-table #metadataFieldsTable [createMatCard]=\"false\" [columns]=\"metadataColumns\"\r\n            [data]=\"field.MetadataFields\" [emptyTableMessage]=\"'Nessun metadata inserito'\" [searchText]=\"'Cerca'\">\r\n        </eqp-table>\r\n    </div>\r\n</ng-template>\r\n\r\n<!-- FORM PROPRIETÀ CAMPI IMMAGINE -->\r\n<ng-template #imageFieldFormTemplate>\r\n    <div class=\"col-sm-12 col-md-4 mt-2 mb-2 d-flex align-items-center\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-slide-toggle [(ngModel)]=\"field.ImageIsContextualAttachment\" formControlName=\"ImageIsContextualAttachment\"\r\n            color=\"primary\" (ngModelChange)=\"onImageIsContextualAttachmentChange()\">\r\n            Immagine pre-caricata nel campo\r\n        </mat-slide-toggle>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2 mb-2 d-flex align-items-center\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-slide-toggle [(ngModel)]=\"field.EnableDrawing\" formControlName=\"EnableDrawing\" color=\"primary\">\r\n            Abilita il disegno\r\n        </mat-slide-toggle>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2 d-flex align-items-center\" [formGroup]=\"fieldFormGroup\"\r\n        *ngIf=\"!field.ImageIsContextualAttachment\">\r\n        <mat-slide-toggle [(ngModel)]=\"field.AttachDefinition.IsMultiAttach\" formControlName=\"IsMultiAttach\"\r\n            color=\"primary\">\r\n            Immagini multiple\r\n        </mat-slide-toggle>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\" *ngIf=\"!field.ImageIsContextualAttachment\">\r\n        <mat-label>Estensioni accettate</mat-label>\r\n        <eqp-select [arrayData]=\"AvailableImageExtensions\" [(ngModelInput)]=\"field.AttachDefinition.AllowedExtensions\"\r\n            [arrayKeyProperty]=\"'key'\" [arrayValueProperty]=\"'value'\" [isMultiSelect]=\"true\"\r\n            [formGroupInput]=\"fieldFormGroup\" [formControlNameInput]=\"'AllowedExtensions'\" [includeFullObject]=\"false\">\r\n        </eqp-select>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\" [formGroup]=\"fieldFormGroup\" *ngIf=\"field.ImageIsContextualAttachment\">\r\n        <mat-label> Nome immagine </mat-label>\r\n        <mat-form-field>\r\n            <input formControlName=\"ImgName\" matInput [(ngModel)]=\"field.ImgName\" required>\r\n        </mat-form-field>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-8 mt-2\" [formGroup]=\"fieldFormGroup\" *ngIf=\"field.ImageIsContextualAttachment\">\r\n        <eqp-attachments [attachmentsList]=\"field._contextualAttachments\" [showMatCard]=\"false\" [allowOnlyImages]=\"true\"\r\n            [isDisabled]=\"false\" [showInlinePreview]=\"true\" [multipleAttachment]=\"false\" [showHeader]=\"false\"\r\n            (localEditedAttachments)=\"catchContextualAttachmentChange($event)\" #contextualAttachmentEqpAttachments>\r\n        </eqp-attachments>\r\n    </div>\r\n    <div class=\"col-sm-12 mt-2\">\r\n        <div class=\"row mt-2\">\r\n            <div class=\"col-sm-12 col-md-6\">\r\n                <div class=\"header-title-standard\">\r\n                    Elenco metadata\r\n                </div>\r\n            </div>\r\n            <div class=\"col-sm-12 col-md-6 text-right buttonsForm\">\r\n                <button class=\"btn btn-primary save\" mat-raised-button color=\"primary\" type=\"button\"\r\n                    (click)=\"openMetadataDialog()\">\r\n                    <mat-icon>add</mat-icon>\r\n                    <span style=\"margin-left: 10px;\">Aggiungi</span>\r\n                </button>\r\n            </div>\r\n        </div>\r\n        <eqp-table #metadataFieldsTable [createMatCard]=\"false\" [columns]=\"metadataColumns\"\r\n            [data]=\"field.AttachDefinition.MetadataFields\" [emptyTableMessage]=\"'Nessun metadata inserito'\"\r\n            [searchText]=\"'Cerca'\">\r\n        </eqp-table>\r\n    </div>\r\n</ng-template>\r\n\r\n<!-- FORM PROPRIETÀ CAMPI LISTA DI VALORI -->\r\n<ng-template #listValueFieldFormTemplate>\r\n    <div class=\"col-sm-12 col-md-4 mt-2 d-flex align-items-center\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-slide-toggle [(ngModel)]=\"field.IsMultiChoiche\" formControlName=\"IsMultiChoiche\" color=\"primary\">\r\n            Scelta multipla\r\n        </mat-slide-toggle>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\">\r\n        <mat-label>Tipo di presentazione*</mat-label>\r\n        <eqp-select [enumData]=\"ListPresentationEnum\" [(ngModelInput)]=\"field.PresentationMode\" required\r\n            [showCancelButton]=\"false\" [formGroupInput]=\"fieldFormGroup\" [formControlNameInput]=\"'PresentationMode'\"\r\n            (ngModelInputChange)=\"onPresentationModeChange()\">\r\n        </eqp-select>\r\n    </div>\r\n    <div class=\"col-sm-12 mt-2\" *ngIf=\"field.PresentationMode != ListPresentationEnum.Immagini\">\r\n        <div class=\"row\">\r\n            <h4 class=\"key-value-list-section-title\"> </h4>\r\n            <div class=\"col-md-4\">\r\n                <mat-label> Label opzione (invio per confermare)</mat-label>\r\n                <mat-form-field>\r\n                    <input matInput [(ngModel)]=\"keyValueObject.key\" (keyup)=\"onMultiSelectInputKeyup($event, null)\">\r\n                </mat-form-field>\r\n            </div>\r\n            <div class=\"col-md-4\">\r\n                <mat-label> Valore opzione (invio per confermare)</mat-label>\r\n                <mat-form-field>\r\n                    <input matInput [(ngModel)]=\"keyValueObject.value\" (keyup)=\"onMultiSelectInputKeyup($event, null)\">\r\n                </mat-form-field>\r\n            </div>\r\n            <div class=\"col-md-4 d-flex align-items-center\">\r\n                <span class=\"mr-3\">Opzioni inserite:</span>\r\n                <ul class=\"value-pairs-list\">\r\n                    <li *ngFor=\"let keyValuePair of getDictionaryKeyValue()\">\r\n                        <mat-icon class=\"mr-1\" (click)=\"deleteKeyFromDictionary(keyValuePair.key)\">close\r\n                        </mat-icon>\r\n                        <span><b>Label: </b> {{keyValuePair.key}} - <b>Valore: </b> {{keyValuePair.value}}</span>\r\n                    </li>\r\n                </ul>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-12 mt-2\" *ngIf=\"field.PresentationMode == ListPresentationEnum.Immagini\">\r\n        <eqp-attachments [attachmentsList]=\"field.ButtonImageList\" [showMatCard]=\"false\" [allowOnlyImages]=\"true\"\r\n            [isDisabled]=\"false\" [showInlinePreview]=\"true\" [multipleAttachment]=\"true\" [showHeader]=\"false\"\r\n            [allowedTypes]=\"[AttachmentType.FILE]\" (localEditedAttachments)=\"catchButtonImagesChange($event)\"\r\n            (onComponentLoaded)=\"configureButtonImagesColumns($event)\">\r\n        </eqp-attachments>\r\n    </div>\r\n</ng-template>\r\n\r\n<!-- FORM PROPRIETÀ CAMPI LOOKUP -->\r\n<ng-template #lookupFieldFormTemplate>\r\n    <div class=\"col-sm-12 col-md-4 mt-2 d-flex align-items-center\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-slide-toggle [(ngModel)]=\"field.UseAsGetOrDiscard\" formControlName=\"UseAsGetOrDiscard\" color=\"primary\"\r\n            matTooltip=\"Se true la lookup viene visualizzata in una modale per lo scegli scarta\">\r\n            Usa per scegli o scarta\r\n        </mat-slide-toggle>\r\n    </div>\r\n    <div class=\"col-sm-12 col-md-4 mt-2\" [formGroup]=\"fieldFormGroup\">\r\n        <mat-label> Nome entità </mat-label>\r\n        <mat-form-field matTooltip=\"Nome dell'entità relazionata\">\r\n            <input formControlName=\"EntitySourceName\" required matInput [(ngModel)]=\"field.EntitySourceName\">\r\n        </mat-form-field>\r\n    </div>\r\n    <div class=\"col-sm-12 mt-2\">\r\n        <div class=\"row\">\r\n            <div class=\"col-md-4\">\r\n                <mat-label> Nomi dei campi (invio per confermare) </mat-label>\r\n                <mat-form-field\r\n                    matTooltip=\"Elenco di campi ordinato che verrà visualizzato nella lookup (premere invio per confermare)\">\r\n                    <input matInput (keyup)=\"onMultiSelectInputKeyup($event, 'FieldNames')\">\r\n                </mat-form-field>\r\n            </div>\r\n            <div class=\"col-md-8 d-flex align-items-center\">\r\n                <span class=\"mr-3\">Nomi selezionati:</span>\r\n                <div class=\"extension-container\" *ngFor=\"let extension of field.FieldNames; let i = index\">\r\n                    <span>{{extension}}</span>\r\n                    <mat-icon class=\"ml-1\" (click)=\"field.FieldNames.splice(i,1)\">close\r\n                    </mat-icon>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n\r\n<!-- DIALOG PER AGGIUNGERE UN METADATA NEI CAMPI DI TIPO ALLEGATO O IMMAGINE -->\r\n<ng-template #dialogMetadata>\r\n    <eqp-dynamic-module-add-form-field [field]=\"selectedMetadata\" [availableFields]=\"availableFields\"\r\n        [indexField]=\"indexSelectedMetadata\" (saveFieldEvent)=\"onSaveMetadata($event)\" [fieldTypesToExclude]=\"[6,7,10]\">\r\n    </eqp-dynamic-module-add-form-field>\r\n</ng-template>\r\n\r\n<ng-template #buttonImagesKeyValueInputColumn let-row=\"row\" let-col=\"col\">\r\n    <mat-form-field>\r\n        <mat-label> {{col.display}} </mat-label>\r\n        <input matInput [(ngModel)]=\"row[col.key]\" required>\r\n    </mat-form-field>\r\n</ng-template>"]}