@eqproject/eqp-dynamic-module 2.10.33 → 2.10.35

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (24) hide show
  1. package/esm2020/lib/components/exported/eqp-dynamic-module-configurator/eqp-dynamic-module-configurator.component.mjs +3 -3
  2. package/esm2020/lib/components/private/action-button-creator/action-button-creator.component.mjs +11 -4
  3. package/esm2020/lib/components/private/add-form-field/add-form-field.component.mjs +4 -4
  4. package/esm2020/lib/components/private/dynamic-module-field-fix/dynamic-module-field.component.mjs +1 -1
  5. package/esm2020/lib/components/private/field-templates/action-button-field-template/action-button-field-template.component.mjs +36 -15
  6. package/esm2020/lib/components/private/field-templates/attachment-field-template/attachment-field-template.component.mjs +3 -3
  7. package/esm2020/lib/components/private/field-templates/boolean-field-template/boolean-field-template.component.mjs +24 -8
  8. package/esm2020/lib/components/private/field-templates/list-value-field-template/list-value-field-template.component.mjs +2 -2
  9. package/esm2020/lib/components/private/graphs/graph/graph.component.mjs +7 -7
  10. package/esm2020/lib/directives/dynamic-loader/dynamic-loader.directive.mjs +5 -5
  11. package/esm2020/lib/directives/speech-to-text/speech-to-text.directive.mjs +4 -4
  12. package/esm2020/lib/models/fields/attachmentField.model.mjs +1 -1
  13. package/esm2020/lib/services/utilityHelper.services.mjs +9 -9
  14. package/fesm2015/eqproject-eqp-dynamic-module.mjs +98 -54
  15. package/fesm2015/eqproject-eqp-dynamic-module.mjs.map +1 -1
  16. package/fesm2020/eqproject-eqp-dynamic-module.mjs +98 -54
  17. package/fesm2020/eqproject-eqp-dynamic-module.mjs.map +1 -1
  18. package/lib/components/private/action-button-creator/action-button-creator.component.d.ts +2 -1
  19. package/lib/components/private/field-templates/action-button-field-template/action-button-field-template.component.d.ts +6 -1
  20. package/lib/components/private/field-templates/boolean-field-template/boolean-field-template.component.d.ts +2 -0
  21. package/lib/components/private/form-records/list-view-form-record/list-view-form-record.component.d.ts +1 -1
  22. package/lib/components/private/form-records/list-view-form-record/single-record/single-record.component.d.ts +1 -1
  23. package/lib/models/fields/attachmentField.model.d.ts +1 -1
  24. package/package.json +1 -1
@@ -326,7 +326,7 @@ export class DynamicModuleFieldFixComponent {
326
326
  }
327
327
  }
328
328
  DynamicModuleFieldFixComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DynamicModuleFieldFixComponent, deps: [{ token: i1.MatDialog }, { token: i2.UtilityHelperService }], target: i0.ɵɵFactoryTarget.Component });
329
- DynamicModuleFieldFixComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DynamicModuleFieldFixComponent, selector: "dynamic-module-field-fix", inputs: { configurations: "configurations", endPointConfiguration: "endPointConfiguration", field: "field", form: "form", record: "record", formulaObject: "formulaObject", inConfig: "inConfig", userID: "userID", QueryEditorComponent: "QueryEditorComponent" }, outputs: { recordChange: "recordChange", out: "out", fireTrigger: "fireTrigger" }, viewQueries: [{ propertyName: "dialogInnerFormRecord", first: true, predicate: ["dialogInnerFormRecord"], descendants: true, static: true }, { propertyName: "fieldTemplate", predicate: ["fieldTemplate"], descendants: true }, { propertyName: "listInnerFormRecords", predicate: ["listInnerFormRecords"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"field.DataGetter.DataGetterType == DataGetterTypeEnum['Manuale'] || field.DataGetter.DataGetterType == DataGetterTypeEnum['Formula']\"> \r\n <ng-container [ngTemplateOutlet]=\"fieldsTemplate\" [ngTemplateOutletContext]=\"{ field: field, record: record, forcedValues: null }\"></ng-container>\r\n</ng-container>\r\n\r\n<ng-container *ngIf=\"field.DataGetter.DataGetterType == DataGetterTypeEnum['Da database']\"> \r\n \r\n <div class=\"row datagetter\">\r\n <div class=\"col-12\">\r\n <ng-container *ngIf=\"DBGetterFieldsLoaded\" [ngTemplateOutlet]=\"fieldsDBGTemplate\" [ngTemplateOutletContext]=\"{ field: field, record: record }\"></ng-container>\r\n <dbgetter \r\n *ngIf=\"loadedDBGetter\"\r\n class=\"dbgetter\"\r\n [configurations]=\"configurations\"\r\n [hidden]=\"!field.InListView\" \r\n [form]=\"form\" \r\n [(record)]=\"record\" \r\n [field]=\"field\" \r\n [DirectlyOpenTable]=\"directlyOpenTable\" \r\n [QueryEditorComponent]=\"QueryEditorComponent\" \r\n [inConfig]=\"inConfig\" \r\n (out)=\"onExternalComponentOut($event)\" \r\n (doReload)=\"reloadDBGetter()\"\r\n (selectedValue)=\"onSelectedValue($event)\">\r\n </dbgetter>\r\n </div>\r\n </div>\r\n</ng-container>\r\n\r\n<ng-container *ngIf=\"field.DataGetter.DataGetterType == DataGetterTypeEnum['Da modulo dinamico']\"> \r\n \r\n <div class=\"row\" *ngIf=\"dmloaded\">\r\n <div class=\"col-12\">\r\n <ng-container [ngTemplateOutlet]=\"fieldsTemplate\" [ngTemplateOutletContext]=\"{ field: field, record: record }\"></ng-container>\r\n </div>\r\n </div>\r\n</ng-container>\r\n\r\n<ng-template #fieldsTemplate>\r\n\r\n <text-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Campo di testo']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </text-field-template>\r\n\r\n <textarea-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Area di testo']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </textarea-field-template>\r\n\r\n <action-button-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Bottone azione']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\" (fireTrigger)=\"onFireTrigger($event)\">\r\n </action-button-field-template>\r\n\r\n <boolean-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Booleano']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </boolean-field-template>\r\n\r\n <date-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Data e/o ora']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </date-field-template>\r\n\r\n <numeric-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Campo numerico']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </numeric-field-template>\r\n\r\n <list-value-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Elenco generico']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </list-value-field-template>\r\n\r\n <attachment-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Allegato']\"\r\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </attachment-field-template>\r\n\r\n <image-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Immagine']\" [endPointConfiguration]=\"endPointConfiguration\" [inConfig]=\"inConfig\"\r\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\" (imageDraw)=\"onImageDraw($event)\">\r\n </image-field-template> \r\n\r\n <image-with-markers-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Immagine con markers']\" [endPointConfiguration]=\"endPointConfiguration\" [inConfig]=\"inConfig\"\r\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\" (imageMark)=\"onImageMark($event)\">\r\n </image-with-markers-field-template> \r\n\r\n <image-field-selector-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Elenco immagini']\"\r\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\"\r\n >\r\n </image-field-selector-template>\r\n\r\n <label-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Etichetta']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </label-field-template>\r\n\r\n <!-- FORM DI DETTAGLIO (LASCIARE IN FONDO) -->\r\n <list-form-record #listInnerFormRecords *ngIf=\"field.FieldType == FieldTypeEnum['Form di dettaglio']\"\r\n [form]=\"getInnerFormFromField(field)\" [configurations]=\"configList\"\r\n (onAddViewEditRecord)=\"onAddViewEditInnerFormRecord($event, field)\">\r\n </list-form-record>\r\n</ng-template>\r\n\r\n<ng-template #fieldsDBGTemplate>\r\n\r\n <text-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Campo di testo']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </text-field-template>\r\n\r\n <list-value-dbg-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Elenco generico']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </list-value-dbg-template>\r\n \r\n \r\n <!-- Non gestiti (funzionano a culo) -->\r\n\r\n <date-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Data e/o ora']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </date-field-template> \r\n \r\n <textarea-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Area di testo']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </textarea-field-template> \r\n\r\n <boolean-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Booleano']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </boolean-field-template> \r\n\r\n <numeric-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Campo numerico']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </numeric-field-template> \r\n\r\n\r\n\r\n</ng-template>", styles: [".dbgetterfield{align-items:center;justify-content:flex-start;height:80px}.dbgetterfield span{margin-right:15px}.datagetter .col-12{position:relative}.datagetter .dbgetter{position:absolute;right:13px;top:6px}\n"], dependencies: [{ kind: "directive", type: i3.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i5.TextFieldTemplateComponent, selector: "text-field-template", inputs: ["field", "record", "formulaObject", "inConfig"], outputs: ["recordChange"] }, { kind: "component", type: i6.BooleanFieldTemplateComponent, selector: "boolean-field-template", inputs: ["field", "record", "formulaObject"], outputs: ["recordChange"] }, { kind: "component", type: i7.DateFieldTemplateComponent, selector: "date-field-template", inputs: ["field", "record", "formulaObject", "inConfig"], outputs: ["recordChange"] }, { kind: "component", type: i8.TextareaFieldTemplateComponent, selector: "textarea-field-template", inputs: ["field", "record", "formulaObject"], outputs: ["recordChange"] }, { kind: "component", type: i9.NumericFieldTemplateComponent, selector: "numeric-field-template", inputs: ["field", "record", "formulaObject", "inConfig"], outputs: ["recordChange"] }, { kind: "component", type: i10.ListValueFieldTemplateComponent, selector: "list-value-field-template", inputs: ["field", "record", "formulaObject", "inConfig"], outputs: ["recordChange"] }, { kind: "component", type: i11.AttachmentFieldTemplateComponent, selector: "attachment-field-template", inputs: ["onlyImages", "field", "record", "formulaObject", "inConfig"], outputs: ["recordChange", "onAttachmentsChange"] }, { kind: "component", type: i12.ImageFieldTemplateComponent, selector: "image-field-template", inputs: ["endPointConfiguration", "record", "formulaObject", "field", "inConfig"], outputs: ["recordChange", "imageDraw"] }, { kind: "component", type: i13.ListFormRecordComponent, selector: "list-form-record", inputs: ["configurations", "endPointConfiguration", "formID", "form", "externalButtons", "actionButtons", "contestualizationParams"], outputs: ["onViewRecord", "onAddViewEditRecord", "onDeleteRecord", "onAfterDeleteRecord"] }, { kind: "component", type: i14.ImageFieldSelectorTemplateComponent, selector: "image-field-selector-template", inputs: ["record", "formulaObject", "field", "inConfig"], outputs: ["recordChange"] }, { kind: "component", type: i15.LabelFieldTemplateComponent, selector: "label-field-template", inputs: ["field", "record", "formulaObject", "inConfig"], outputs: ["recordChange"] }, { kind: "component", type: i16.ImageWithMarkersFieldTemplateComponent, selector: "image-with-markers-field-template", inputs: ["endPointConfiguration", "record", "formulaObject", "field", "inConfig"], outputs: ["recordChange", "imageMark"] }, { kind: "component", type: i17.DbgetterComponent, selector: "dbgetter", inputs: ["configurations", "form", "field", "record", "inConfig", "DirectlyOpenTable", "QueryEditorComponent", "data"], outputs: ["out", "selectedValue", "doReload"] }, { kind: "component", type: i18.ActionButtonFieldTemplateComponent, selector: "action-button-field-template", inputs: ["field", "record", "formulaObject", "inConfig"], outputs: ["fireTrigger"] }, { kind: "component", type: i19.ListValueDbgTemplateComponent, selector: "list-value-dbg-template", inputs: ["field", "record"] }] });
329
+ DynamicModuleFieldFixComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DynamicModuleFieldFixComponent, selector: "dynamic-module-field-fix", inputs: { configurations: "configurations", endPointConfiguration: "endPointConfiguration", field: "field", form: "form", record: "record", formulaObject: "formulaObject", inConfig: "inConfig", userID: "userID", QueryEditorComponent: "QueryEditorComponent" }, outputs: { recordChange: "recordChange", out: "out", fireTrigger: "fireTrigger" }, viewQueries: [{ propertyName: "dialogInnerFormRecord", first: true, predicate: ["dialogInnerFormRecord"], descendants: true, static: true }, { propertyName: "fieldTemplate", predicate: ["fieldTemplate"], descendants: true }, { propertyName: "listInnerFormRecords", predicate: ["listInnerFormRecords"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"field.DataGetter.DataGetterType == DataGetterTypeEnum['Manuale'] || field.DataGetter.DataGetterType == DataGetterTypeEnum['Formula']\"> \r\n <ng-container [ngTemplateOutlet]=\"fieldsTemplate\" [ngTemplateOutletContext]=\"{ field: field, record: record, forcedValues: null }\"></ng-container>\r\n</ng-container>\r\n\r\n<ng-container *ngIf=\"field.DataGetter.DataGetterType == DataGetterTypeEnum['Da database']\"> \r\n \r\n <div class=\"row datagetter\">\r\n <div class=\"col-12\">\r\n <ng-container *ngIf=\"DBGetterFieldsLoaded\" [ngTemplateOutlet]=\"fieldsDBGTemplate\" [ngTemplateOutletContext]=\"{ field: field, record: record }\"></ng-container>\r\n <dbgetter \r\n *ngIf=\"loadedDBGetter\"\r\n class=\"dbgetter\"\r\n [configurations]=\"configurations\"\r\n [hidden]=\"!field.InListView\" \r\n [form]=\"form\" \r\n [(record)]=\"record\" \r\n [field]=\"field\" \r\n [DirectlyOpenTable]=\"directlyOpenTable\" \r\n [QueryEditorComponent]=\"QueryEditorComponent\" \r\n [inConfig]=\"inConfig\" \r\n (out)=\"onExternalComponentOut($event)\" \r\n (doReload)=\"reloadDBGetter()\"\r\n (selectedValue)=\"onSelectedValue($event)\">\r\n </dbgetter>\r\n </div>\r\n </div>\r\n</ng-container>\r\n\r\n<ng-container *ngIf=\"field.DataGetter.DataGetterType == DataGetterTypeEnum['Da modulo dinamico']\"> \r\n \r\n <div class=\"row\" *ngIf=\"dmloaded\">\r\n <div class=\"col-12\">\r\n <ng-container [ngTemplateOutlet]=\"fieldsTemplate\" [ngTemplateOutletContext]=\"{ field: field, record: record }\"></ng-container>\r\n </div>\r\n </div>\r\n</ng-container>\r\n\r\n<ng-template #fieldsTemplate>\r\n\r\n <text-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Campo di testo']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </text-field-template>\r\n\r\n <textarea-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Area di testo']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </textarea-field-template>\r\n\r\n <action-button-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Bottone azione']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\" (fireTrigger)=\"onFireTrigger($event)\">\r\n </action-button-field-template>\r\n\r\n <boolean-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Booleano']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </boolean-field-template>\r\n\r\n <date-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Data e/o ora']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </date-field-template>\r\n\r\n <numeric-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Campo numerico']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </numeric-field-template>\r\n\r\n <list-value-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Elenco generico']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </list-value-field-template>\r\n\r\n <attachment-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Allegato']\"\r\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </attachment-field-template>\r\n\r\n <image-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Immagine']\" [endPointConfiguration]=\"endPointConfiguration\" [inConfig]=\"inConfig\"\r\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\" (imageDraw)=\"onImageDraw($event)\">\r\n </image-field-template> \r\n\r\n <image-with-markers-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Immagine con markers']\" [endPointConfiguration]=\"endPointConfiguration\" [inConfig]=\"inConfig\"\r\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\" (imageMark)=\"onImageMark($event)\">\r\n </image-with-markers-field-template> \r\n\r\n <image-field-selector-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Elenco immagini']\"\r\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\"\r\n >\r\n </image-field-selector-template>\r\n\r\n <label-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Etichetta']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </label-field-template>\r\n\r\n <!-- FORM DI DETTAGLIO (LASCIARE IN FONDO) -->\r\n <list-form-record #listInnerFormRecords *ngIf=\"field.FieldType == FieldTypeEnum['Form di dettaglio']\"\r\n [form]=\"getInnerFormFromField(field)\" [configurations]=\"configList\"\r\n (onAddViewEditRecord)=\"onAddViewEditInnerFormRecord($event, field)\">\r\n </list-form-record>\r\n</ng-template>\r\n\r\n<ng-template #fieldsDBGTemplate>\r\n\r\n <text-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Campo di testo']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </text-field-template>\r\n\r\n <list-value-dbg-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Elenco generico']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </list-value-dbg-template>\r\n \r\n \r\n <!-- Non gestiti (funzionano a culo) -->\r\n\r\n <date-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Data e/o ora']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </date-field-template> \r\n \r\n <textarea-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Area di testo']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </textarea-field-template> \r\n\r\n <boolean-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Booleano']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </boolean-field-template> \r\n\r\n <numeric-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Campo numerico']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </numeric-field-template> \r\n\r\n\r\n\r\n</ng-template>", styles: [".dbgetterfield{align-items:center;justify-content:flex-start;height:80px}.dbgetterfield span{margin-right:15px}.datagetter .col-12{position:relative}.datagetter .dbgetter{position:absolute;right:13px;top:6px}\n"], dependencies: [{ kind: "directive", type: i3.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i5.TextFieldTemplateComponent, selector: "text-field-template", inputs: ["field", "record", "formulaObject", "inConfig"], outputs: ["recordChange"] }, { kind: "component", type: i6.BooleanFieldTemplateComponent, selector: "boolean-field-template", inputs: ["field", "record", "formulaObject"], outputs: ["recordChange"] }, { kind: "component", type: i7.DateFieldTemplateComponent, selector: "date-field-template", inputs: ["field", "record", "formulaObject", "inConfig"], outputs: ["recordChange"] }, { kind: "component", type: i8.TextareaFieldTemplateComponent, selector: "textarea-field-template", inputs: ["field", "record", "formulaObject"], outputs: ["recordChange"] }, { kind: "component", type: i9.NumericFieldTemplateComponent, selector: "numeric-field-template", inputs: ["field", "record", "formulaObject", "inConfig"], outputs: ["recordChange"] }, { kind: "component", type: i10.ListValueFieldTemplateComponent, selector: "list-value-field-template", inputs: ["field", "record", "formulaObject", "inConfig"], outputs: ["recordChange"] }, { kind: "component", type: i11.AttachmentFieldTemplateComponent, selector: "attachment-field-template", inputs: ["onlyImages", "field", "record", "formulaObject", "inConfig"], outputs: ["recordChange", "onAttachmentsChange"] }, { kind: "component", type: i12.ImageFieldTemplateComponent, selector: "image-field-template", inputs: ["endPointConfiguration", "record", "formulaObject", "field", "inConfig"], outputs: ["recordChange", "imageDraw"] }, { kind: "component", type: i13.ListFormRecordComponent, selector: "list-form-record", inputs: ["configurations", "endPointConfiguration", "formID", "form", "externalButtons", "actionButtons", "contestualizationParams"], outputs: ["onViewRecord", "onAddViewEditRecord", "onDeleteRecord", "onAfterDeleteRecord"] }, { kind: "component", type: i14.ImageFieldSelectorTemplateComponent, selector: "image-field-selector-template", inputs: ["record", "formulaObject", "field", "inConfig"], outputs: ["recordChange"] }, { kind: "component", type: i15.LabelFieldTemplateComponent, selector: "label-field-template", inputs: ["field", "record", "formulaObject", "inConfig"], outputs: ["recordChange"] }, { kind: "component", type: i16.ImageWithMarkersFieldTemplateComponent, selector: "image-with-markers-field-template", inputs: ["endPointConfiguration", "record", "formulaObject", "field", "inConfig"], outputs: ["recordChange", "imageMark"] }, { kind: "component", type: i17.DbgetterComponent, selector: "dbgetter", inputs: ["configurations", "form", "field", "record", "inConfig", "DirectlyOpenTable", "QueryEditorComponent", "data"], outputs: ["out", "selectedValue", "doReload"] }, { kind: "component", type: i18.ActionButtonFieldTemplateComponent, selector: "action-button-field-template", inputs: ["field", "record", "formulaObject", "inConfig"], outputs: ["fireTrigger", "recordChange"] }, { kind: "component", type: i19.ListValueDbgTemplateComponent, selector: "list-value-dbg-template", inputs: ["field", "record"] }] });
330
330
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DynamicModuleFieldFixComponent, decorators: [{
331
331
  type: Component,
332
332
  args: [{ selector: 'dynamic-module-field-fix', template: "<ng-container *ngIf=\"field.DataGetter.DataGetterType == DataGetterTypeEnum['Manuale'] || field.DataGetter.DataGetterType == DataGetterTypeEnum['Formula']\"> \r\n <ng-container [ngTemplateOutlet]=\"fieldsTemplate\" [ngTemplateOutletContext]=\"{ field: field, record: record, forcedValues: null }\"></ng-container>\r\n</ng-container>\r\n\r\n<ng-container *ngIf=\"field.DataGetter.DataGetterType == DataGetterTypeEnum['Da database']\"> \r\n \r\n <div class=\"row datagetter\">\r\n <div class=\"col-12\">\r\n <ng-container *ngIf=\"DBGetterFieldsLoaded\" [ngTemplateOutlet]=\"fieldsDBGTemplate\" [ngTemplateOutletContext]=\"{ field: field, record: record }\"></ng-container>\r\n <dbgetter \r\n *ngIf=\"loadedDBGetter\"\r\n class=\"dbgetter\"\r\n [configurations]=\"configurations\"\r\n [hidden]=\"!field.InListView\" \r\n [form]=\"form\" \r\n [(record)]=\"record\" \r\n [field]=\"field\" \r\n [DirectlyOpenTable]=\"directlyOpenTable\" \r\n [QueryEditorComponent]=\"QueryEditorComponent\" \r\n [inConfig]=\"inConfig\" \r\n (out)=\"onExternalComponentOut($event)\" \r\n (doReload)=\"reloadDBGetter()\"\r\n (selectedValue)=\"onSelectedValue($event)\">\r\n </dbgetter>\r\n </div>\r\n </div>\r\n</ng-container>\r\n\r\n<ng-container *ngIf=\"field.DataGetter.DataGetterType == DataGetterTypeEnum['Da modulo dinamico']\"> \r\n \r\n <div class=\"row\" *ngIf=\"dmloaded\">\r\n <div class=\"col-12\">\r\n <ng-container [ngTemplateOutlet]=\"fieldsTemplate\" [ngTemplateOutletContext]=\"{ field: field, record: record }\"></ng-container>\r\n </div>\r\n </div>\r\n</ng-container>\r\n\r\n<ng-template #fieldsTemplate>\r\n\r\n <text-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Campo di testo']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </text-field-template>\r\n\r\n <textarea-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Area di testo']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </textarea-field-template>\r\n\r\n <action-button-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Bottone azione']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\" (fireTrigger)=\"onFireTrigger($event)\">\r\n </action-button-field-template>\r\n\r\n <boolean-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Booleano']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </boolean-field-template>\r\n\r\n <date-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Data e/o ora']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </date-field-template>\r\n\r\n <numeric-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Campo numerico']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </numeric-field-template>\r\n\r\n <list-value-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Elenco generico']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </list-value-field-template>\r\n\r\n <attachment-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Allegato']\"\r\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </attachment-field-template>\r\n\r\n <image-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Immagine']\" [endPointConfiguration]=\"endPointConfiguration\" [inConfig]=\"inConfig\"\r\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\" (imageDraw)=\"onImageDraw($event)\">\r\n </image-field-template> \r\n\r\n <image-with-markers-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Immagine con markers']\" [endPointConfiguration]=\"endPointConfiguration\" [inConfig]=\"inConfig\"\r\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\" (imageMark)=\"onImageMark($event)\">\r\n </image-with-markers-field-template> \r\n\r\n <image-field-selector-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Elenco immagini']\"\r\n [matTooltip]=\"field.Description\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\"\r\n >\r\n </image-field-selector-template>\r\n\r\n <label-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Etichetta']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </label-field-template>\r\n\r\n <!-- FORM DI DETTAGLIO (LASCIARE IN FONDO) -->\r\n <list-form-record #listInnerFormRecords *ngIf=\"field.FieldType == FieldTypeEnum['Form di dettaglio']\"\r\n [form]=\"getInnerFormFromField(field)\" [configurations]=\"configList\"\r\n (onAddViewEditRecord)=\"onAddViewEditInnerFormRecord($event, field)\">\r\n </list-form-record>\r\n</ng-template>\r\n\r\n<ng-template #fieldsDBGTemplate>\r\n\r\n <text-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Campo di testo']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </text-field-template>\r\n\r\n <list-value-dbg-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Elenco generico']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </list-value-dbg-template>\r\n \r\n \r\n <!-- Non gestiti (funzionano a culo) -->\r\n\r\n <date-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Data e/o ora']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </date-field-template> \r\n \r\n <textarea-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Area di testo']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </textarea-field-template> \r\n\r\n <boolean-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Booleano']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </boolean-field-template> \r\n\r\n <numeric-field-template #fieldTemplate *ngIf=\"field.FieldType == FieldTypeEnum['Campo numerico']\"\r\n [matTooltip]=\"field.Tooltip\" [(record)]=\"record\" [formulaObject]=\"formulaObject\" [field]=\"field\" (recordChange)=\"onRecordChange()\">\r\n </numeric-field-template> \r\n\r\n\r\n\r\n</ng-template>", styles: [".dbgetterfield{align-items:center;justify-content:flex-start;height:80px}.dbgetterfield span{margin-right:15px}.datagetter .col-12{position:relative}.datagetter .dbgetter{position:absolute;right:13px;top:6px}\n"] }]
@@ -10,6 +10,7 @@ export class ActionButtonFieldTemplateComponent {
10
10
  this.formulaObject = {};
11
11
  this.inConfig = false;
12
12
  this.fireTrigger = new EventEmitter();
13
+ this.recordChange = new EventEmitter();
13
14
  }
14
15
  ngOnInit() {
15
16
  this.updateField();
@@ -31,19 +32,26 @@ export class ActionButtonFieldTemplateComponent {
31
32
  GlobalService.debugLog("btn InListView - " + this.field.InListView);
32
33
  }
33
34
  generateAction(actionButton) {
34
- var fireTrigger = new FireTrigger();
35
- fireTrigger.trigger = new Trigger();
36
- fireTrigger.trigger.CID = actionButton.ButtonCode;
37
- fireTrigger.trigger.conditions = null;
38
- fireTrigger.trigger.description = actionButton.Label;
39
- fireTrigger.trigger.execution = actionButton.execution;
40
- fireTrigger.trigger.formulas = actionButton.formulas;
41
- fireTrigger.form = null; // Verrà impostato a livello superiore
42
- fireTrigger.formulas = actionButton.formulas;
43
- fireTrigger.record = this.record;
44
- fireTrigger.userPatient = null; // Verrà impostato a livello superiore
45
- fireTrigger.userMedicalExamination = null;
46
- this.evaluateFormulasAndFireTrigger(fireTrigger);
35
+ if (actionButton.execution == 'execute_formula') {
36
+ // caso esecuzione semplice
37
+ let res = UtilityHelperService.EvaluateFieldFormula(actionButton.formulas[0].value, this.record, this.formulaObject);
38
+ this.onRecordValueChange();
39
+ }
40
+ else {
41
+ var fireTrigger = new FireTrigger();
42
+ fireTrigger.trigger = new Trigger();
43
+ fireTrigger.trigger.CID = actionButton.ButtonCode;
44
+ fireTrigger.trigger.conditions = null;
45
+ fireTrigger.trigger.description = actionButton.Label;
46
+ fireTrigger.trigger.execution = actionButton.execution;
47
+ fireTrigger.trigger.formulas = actionButton.formulas;
48
+ fireTrigger.form = null; // Verrà impostato a livello superiore
49
+ fireTrigger.formulas = actionButton.formulas;
50
+ fireTrigger.record = this.record;
51
+ fireTrigger.userPatient = null; // Verrà impostato a livello superiore
52
+ fireTrigger.userMedicalExamination = null;
53
+ this.evaluateFormulasAndFireTrigger(fireTrigger);
54
+ }
47
55
  }
48
56
  evaluateFormulasAndFireTrigger(triggerToFire) {
49
57
  const formulas = JSON.parse(JSON.stringify(triggerToFire.formulas));
@@ -79,9 +87,20 @@ export class ActionButtonFieldTemplateComponent {
79
87
  triggerToFire.formulas = evaluatedFormulas;
80
88
  this.fireTrigger.emit(triggerToFire);
81
89
  }
90
+ /**
91
+ * Metodo per emettere l'evento che il valore del record è cambiato.
92
+ */
93
+ onRecordValueChange() {
94
+ if (!this.field.Formula) {
95
+ this.recordChange.emit(this.record);
96
+ }
97
+ if (!this.field.VisibleIf) {
98
+ this.recordChange.emit(this.record);
99
+ }
100
+ }
82
101
  }
83
102
  ActionButtonFieldTemplateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ActionButtonFieldTemplateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
84
- ActionButtonFieldTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: ActionButtonFieldTemplateComponent, selector: "action-button-field-template", inputs: { field: "field", record: "record", formulaObject: "formulaObject", inConfig: "inConfig" }, outputs: { fireTrigger: "fireTrigger" }, ngImport: i0, template: "<button [ngStyle]=\"FieldstyleObj\" class=\"btn btn-primary\" (click)=\"generateAction(field)\">\r\n <mat-icon *ngIf=\"field.Icon\">{{field.Icon}}</mat-icon> {{field.ButtonLabel}}\r\n</button>", styles: [""], dependencies: [{ kind: "component", type: i1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
103
+ ActionButtonFieldTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: ActionButtonFieldTemplateComponent, selector: "action-button-field-template", inputs: { field: "field", record: "record", formulaObject: "formulaObject", inConfig: "inConfig" }, outputs: { fireTrigger: "fireTrigger", recordChange: "recordChange" }, ngImport: i0, template: "<button [ngStyle]=\"FieldstyleObj\" class=\"btn btn-primary\" (click)=\"generateAction(field)\">\r\n <mat-icon *ngIf=\"field.Icon\">{{field.Icon}}</mat-icon> {{field.ButtonLabel}}\r\n</button>", styles: [""], dependencies: [{ kind: "component", type: i1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
85
104
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ActionButtonFieldTemplateComponent, decorators: [{
86
105
  type: Component,
87
106
  args: [{ selector: 'action-button-field-template', template: "<button [ngStyle]=\"FieldstyleObj\" class=\"btn btn-primary\" (click)=\"generateAction(field)\">\r\n <mat-icon *ngIf=\"field.Icon\">{{field.Icon}}</mat-icon> {{field.ButtonLabel}}\r\n</button>" }]
@@ -95,5 +114,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
95
114
  type: Input
96
115
  }], fireTrigger: [{
97
116
  type: Output
117
+ }], recordChange: [{
118
+ type: Output
98
119
  }] } });
99
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-button-field-template.component.js","sourceRoot":"","sources":["../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/action-button-field-template/action-button-field-template.component.ts","../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/action-button-field-template/action-button-field-template.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport { Record } from '../../../../models/record.model';\r\nimport { FireTrigger, Trigger, TriggerPropertyTypeEnum } from '../../../../models/trigger.model';\r\nimport { ActionButtonField } from '../../../../models/fields/actionButton.model';\r\nimport { UtilityHelperService } from '../../../../services/utilityHelper.services';\r\nimport { GlobalService } from '../../../../services/global.service';\r\n\r\n@Component({\r\n  selector: 'action-button-field-template',\r\n  templateUrl: './action-button-field-template.component.html',\r\n  styleUrls: ['./action-button-field-template.component.scss']\r\n})\r\nexport class ActionButtonFieldTemplateComponent {\r\n\r\n  //variabili esterne per l'input dei campi\r\n  @Input() field: ActionButtonField;\r\n  @Input() record: Record;\r\n  @Input() formulaObject: any = {};\r\n  @Input() inConfig: boolean = false;\r\n\r\n  @Output() fireTrigger: EventEmitter<FireTrigger> = new EventEmitter<FireTrigger>();\r\n\r\n  FieldstyleObj: any;\r\n\r\n  constructor() { }\r\n\r\n  ngOnInit(): void {\r\n    this.updateField();\r\n    this.initStyles();\r\n  }\r\n  initStyles() {\r\n    //Funzione per parsare il campo stylecss dell'oggetto field ed applicarlo all'html\r\n    if (this.field.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)\r\n      this.FieldstyleObj = UtilityHelperService.initStyles(this.field.FieldstyleCSS);\r\n  }\r\n\r\n\r\n  /**\r\n   * Metodo per aggiornare il valore del campo quando questo è rappresentato da una formula.\r\n   */\r\n  updateField() {\r\n    if (this.field.VisibleIf) {\r\n      this.field.InListView = UtilityHelperService.EvaluateFieldFormula(this.field.VisibleIf, this.record, this.formulaObject);\r\n    }\r\n    this.field.InListView = this.field.InListView ? true : false;\r\n    GlobalService.debugLog(\"btn InListView - \" + this.field.InListView)\r\n  }\r\n\r\n  generateAction(actionButton: ActionButtonField) {\r\n    var fireTrigger: FireTrigger = new FireTrigger();\r\n\r\n    fireTrigger.trigger = new Trigger();\r\n    fireTrigger.trigger.CID = actionButton.ButtonCode;\r\n    fireTrigger.trigger.conditions = null;\r\n    fireTrigger.trigger.description = actionButton.Label;\r\n    fireTrigger.trigger.execution = actionButton.execution;\r\n    fireTrigger.trigger.formulas = actionButton.formulas;\r\n\r\n    fireTrigger.form = null; // Verrà impostato a livello superiore\r\n    fireTrigger.formulas = actionButton.formulas;\r\n    fireTrigger.record = this.record;\r\n    fireTrigger.userPatient = null;  // Verrà impostato a livello superiore\r\n    fireTrigger.userMedicalExamination = null;\r\n\r\n    this.evaluateFormulasAndFireTrigger(fireTrigger);\r\n  }\r\n\r\n  evaluateFormulasAndFireTrigger(triggerToFire: FireTrigger) {\r\n\r\n    const formulas = JSON.parse(JSON.stringify(triggerToFire.formulas));\r\n    const evaluatedFormulas: { [key: string]: any } = {}; // Oggetto associativo\r\n\r\n    GlobalService.debugLog(\"checkTriggers - evaluate formulas \", formulas);\r\n    if (formulas && Object.keys(formulas).length > 0) {\r\n      Object.keys(formulas).forEach((key) => {\r\n        const formulaObj = formulas[key];\r\n        const formula = formulaObj.value;\r\n        let temp;\r\n\r\n        GlobalService.debugLog(\"checkTriggers - formulas[key] \", formulaObj);\r\n\r\n        if (formulaObj.type == TriggerPropertyTypeEnum.DMMODULE) {  // assegno id/code del modulo selezionato\r\n          temp = formula;\r\n          GlobalService.debugLog(\"checkTriggers - assigned DMMODULE - id/code \", formula);\r\n\r\n        } else if (formulaObj.type == TriggerPropertyTypeEnum.DROPDOWN_LIST) {\r\n          // se la proprietà non esiste è assegnato value - modifica di una configurazione dichiarata in precedenza come string\r\n\r\n          temp =\r\n            formulaObj?.selectedAllowedValue?.key ? formulaObj.selectedAllowedValue.key\r\n              : (\r\n                UtilityHelperService.EvaluateFieldFormula(\r\n                  formula,\r\n                  this.record,\r\n                  this.formulaObject\r\n                )\r\n              );\r\n\r\n\r\n          GlobalService.debugLog(\"checkTriggers - assigned DROPDOWN_LIST-  selectedAllowedValue \", formulaObj.selectedAllowedValue);\r\n\r\n        } else {\r\n          // passo all'eval quando è stringa e assegno il valore calcolato\r\n          temp = UtilityHelperService.EvaluateFieldFormula(\r\n            formula,\r\n            this.record,\r\n            this.formulaObject\r\n          );\r\n          GlobalService.debugLog(\"checkTriggers - assigned - .value  formula \", formula);\r\n          GlobalService.debugLog(\"checkTriggers - assigned > value  formulaObj.type \", formulaObj);\r\n\r\n        }\r\n\r\n        evaluatedFormulas[formulaObj.key] = temp;\r\n      });\r\n    }\r\n\r\n    GlobalService.debugLog(\"checkTriggers - assigned-  evaluatedFormulas \", evaluatedFormulas);\r\n    triggerToFire.formulas = evaluatedFormulas;\r\n    this.fireTrigger.emit(triggerToFire);\r\n  }\r\n\r\n\r\n\r\n}\r\n","<button [ngStyle]=\"FieldstyleObj\" class=\"btn btn-primary\" (click)=\"generateAction(field)\">\r\n    <mat-icon *ngIf=\"field.Icon\">{{field.Icon}}</mat-icon> {{field.ButtonLabel}}\r\n</button>"]}
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-button-field-template.component.js","sourceRoot":"","sources":["../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/action-button-field-template/action-button-field-template.component.ts","../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/action-button-field-template/action-button-field-template.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport { Record } from '../../../../models/record.model';\r\nimport { FireTrigger, Trigger, TriggerPropertyTypeEnum } from '../../../../models/trigger.model';\r\nimport { ActionButtonField } from '../../../../models/fields/actionButton.model';\r\nimport { UtilityHelperService } from '../../../../services/utilityHelper.services';\r\nimport { GlobalService } from '../../../../services/global.service';\r\n\r\n@Component({\r\n  selector: 'action-button-field-template',\r\n  templateUrl: './action-button-field-template.component.html',\r\n  styleUrls: ['./action-button-field-template.component.scss']\r\n})\r\nexport class ActionButtonFieldTemplateComponent {\r\n\r\n  //variabili esterne per l'input dei campi\r\n  @Input() field: ActionButtonField;\r\n  @Input() record: Record;\r\n  @Input() formulaObject: any = {};\r\n  @Input() inConfig: boolean = false;\r\n\r\n  @Output() fireTrigger: EventEmitter<FireTrigger> = new EventEmitter<FireTrigger>();\r\n  @Output() recordChange: EventEmitter<Record> = new EventEmitter<Record>();\r\n\r\n  FieldstyleObj: any;\r\n\r\n  constructor() { }\r\n\r\n  ngOnInit(): void {\r\n    this.updateField();\r\n    this.initStyles();\r\n  }\r\n  initStyles() {\r\n    //Funzione per parsare il campo stylecss dell'oggetto field ed applicarlo all'html\r\n    if (this.field.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)\r\n      this.FieldstyleObj = UtilityHelperService.initStyles(this.field.FieldstyleCSS);\r\n  }\r\n\r\n\r\n  /**\r\n   * Metodo per aggiornare il valore del campo quando questo è rappresentato da una formula.\r\n   */\r\n  updateField() {\r\n    if (this.field.VisibleIf) {\r\n      this.field.InListView = UtilityHelperService.EvaluateFieldFormula(this.field.VisibleIf, this.record, this.formulaObject);\r\n    }\r\n    this.field.InListView = this.field.InListView ? true : false;\r\n    GlobalService.debugLog(\"btn InListView - \" + this.field.InListView)\r\n  }\r\n\r\n  generateAction(actionButton: ActionButtonField) {\r\n    if (actionButton.execution == 'execute_formula') {\r\n      // caso esecuzione semplice\r\n      let res = UtilityHelperService.EvaluateFieldFormula(\r\n        actionButton.formulas[0].value,\r\n        this.record,\r\n        this.formulaObject\r\n      );\r\n      this.onRecordValueChange();\r\n    } else {\r\n      var fireTrigger: FireTrigger = new FireTrigger();\r\n\r\n      fireTrigger.trigger = new Trigger();\r\n      fireTrigger.trigger.CID = actionButton.ButtonCode;\r\n      fireTrigger.trigger.conditions = null;\r\n      fireTrigger.trigger.description = actionButton.Label;\r\n      fireTrigger.trigger.execution = actionButton.execution;\r\n      fireTrigger.trigger.formulas = actionButton.formulas;\r\n\r\n      fireTrigger.form = null; // Verrà impostato a livello superiore\r\n      fireTrigger.formulas = actionButton.formulas;\r\n      fireTrigger.record = this.record;\r\n      fireTrigger.userPatient = null;  // Verrà impostato a livello superiore\r\n      fireTrigger.userMedicalExamination = null;\r\n\r\n      this.evaluateFormulasAndFireTrigger(fireTrigger);\r\n    }\r\n  }\r\n\r\n  evaluateFormulasAndFireTrigger(triggerToFire: FireTrigger) {\r\n\r\n    const formulas = JSON.parse(JSON.stringify(triggerToFire.formulas));\r\n    const evaluatedFormulas: { [key: string]: any } = {}; // Oggetto associativo\r\n\r\n    GlobalService.debugLog(\"checkTriggers - evaluate formulas \", formulas);\r\n    if (formulas && Object.keys(formulas).length > 0) {\r\n      Object.keys(formulas).forEach((key) => {\r\n        const formulaObj = formulas[key];\r\n        const formula = formulaObj.value;\r\n        let temp;\r\n\r\n        GlobalService.debugLog(\"checkTriggers - formulas[key] \", formulaObj);\r\n\r\n        if (formulaObj.type == TriggerPropertyTypeEnum.DMMODULE) {  // assegno id/code del modulo selezionato\r\n          temp = formula;\r\n          GlobalService.debugLog(\"checkTriggers - assigned DMMODULE - id/code \", formula);\r\n\r\n        } else if (formulaObj.type == TriggerPropertyTypeEnum.DROPDOWN_LIST) {\r\n          // se la proprietà non esiste è assegnato value - modifica di una configurazione dichiarata in precedenza come string\r\n\r\n          temp =\r\n            formulaObj?.selectedAllowedValue?.key ? formulaObj.selectedAllowedValue.key\r\n              : (\r\n                UtilityHelperService.EvaluateFieldFormula(\r\n                  formula,\r\n                  this.record,\r\n                  this.formulaObject\r\n                )\r\n              );\r\n\r\n\r\n          GlobalService.debugLog(\"checkTriggers - assigned DROPDOWN_LIST-  selectedAllowedValue \", formulaObj.selectedAllowedValue);\r\n\r\n        } else {\r\n          // passo all'eval quando è stringa e assegno il valore calcolato\r\n          temp = UtilityHelperService.EvaluateFieldFormula(\r\n            formula,\r\n            this.record,\r\n            this.formulaObject\r\n          );\r\n          GlobalService.debugLog(\"checkTriggers - assigned - .value  formula \", formula);\r\n          GlobalService.debugLog(\"checkTriggers - assigned > value  formulaObj.type \", formulaObj);\r\n\r\n        }\r\n\r\n        evaluatedFormulas[formulaObj.key] = temp;\r\n      });\r\n    }\r\n\r\n    GlobalService.debugLog(\"checkTriggers - assigned-  evaluatedFormulas \", evaluatedFormulas);\r\n    triggerToFire.formulas = evaluatedFormulas;\r\n    this.fireTrigger.emit(triggerToFire);\r\n  }\r\n\r\n\r\n  /**\r\n   * Metodo per emettere l'evento che il valore del record è cambiato.\r\n   */\r\n  onRecordValueChange() {\r\n    if (!this.field.Formula) {\r\n      this.recordChange.emit(this.record);\r\n    }\r\n    if (!this.field.VisibleIf) {\r\n      this.recordChange.emit(this.record);\r\n    }\r\n  }\r\n\r\n}\r\n","<button [ngStyle]=\"FieldstyleObj\" class=\"btn btn-primary\" (click)=\"generateAction(field)\">\r\n    <mat-icon *ngIf=\"field.Icon\">{{field.Icon}}</mat-icon> {{field.ButtonLabel}}\r\n</button>"]}
@@ -116,10 +116,10 @@ export class AttachmentFieldTemplateComponent {
116
116
  }
117
117
  }
118
118
  AttachmentFieldTemplateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: AttachmentFieldTemplateComponent, deps: [{ token: i1.UtilityHelperService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
119
- AttachmentFieldTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: AttachmentFieldTemplateComponent, selector: "attachment-field-template", inputs: { onlyImages: "onlyImages", field: "field", record: "record", formulaObject: "formulaObject", inConfig: "inConfig" }, outputs: { recordChange: "recordChange", onAttachmentsChange: "onAttachmentsChange" }, viewQueries: [{ propertyName: "eqpAttachments", first: true, predicate: ["eqpAttachments"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<p *ngIf=\"!field.IsMultiAttach\" class=\"mb-2\">\r\n {{field.Description + (field.Required ? \" *\" : \"\")}}\r\n</p>\r\n<div class=\"row\" *ngIf=\"!field.IsMultiAttach && record[field.Name] && record[field.Name][0]\">\r\n <!-- <div class=\"mt-2\" *ngFor=\"let metadata of field.MetadataFields\"\r\n [ngClass]=\"utilityService.getFieldSyleClass(metadata)\">\r\n <dynamic-module-field-fix [field]=\"metadata\" [record]=\"record[field.Name][0]\"\r\n (recordChange)=\"updateMetadataValidity()\">\r\n </dynamic-module-field-fix>\r\n </div> -->\r\n</div>\r\n\r\n<eqp-attachments [attachmentsList]=\"record[field.Name]\" [showMatCard]=\"true\" [allowOnlyImages]=\"onlyImages\"\r\n [isDisabled]=\"field.FormFormGroup.disabled\" [showInlinePreview]=\"true\" [multipleAttachment]=\"field.IsMultiAttach\"\r\n [disableAction]=\"field.FormFormGroup.disabled\" [acceptedFileTypes]=\"field.AllowedExtensions\" [showHeader]=\"true\"\r\n [headerTitle]=\"field.Description + (field.Required ? ' *' : '')\" (localEditedAttachments)=\"catchAttachmentList($event)\"\r\n #eqpAttachments>\r\n</eqp-attachments>\r\n\r\n<!-- TEMPLATE PER VISUALIZZARE LA COLONNA DELLA SEZIONE NELLA TABELLA DEI FIELDS -->\r\n<!-- <ng-template #metadataColumnTemplate let-row=\"row\" let-col=\"col\">\r\n <dynamic-module-field-fix [field]=\"getFieldFromMetadata(col, row)\" [record]=\"row\"\r\n (recordChange)=\"updateMetadataValidity()\">\r\n </dynamic-module-field-fix>\r\n</ng-template> -->", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.EqpAttachmentsComponent, selector: "eqp-attachments", inputs: ["disableAction", "showHeader", "headerTitle", "attachmentsList", "showMatCard", "multipleAttachment", "loadMultipleFiles", "attachmentsColumns", "emptyTableMessage", "allowOnlyImages", "acceptedFileTypes", "isDisabled", "showInlinePreview", "getAttachmentEndpoint", "productionBaseUrl", "compressionOptions", "allowedTypes", "isEqpTableMultiLanguage", "tablePaginatorVisible", "isTableSearcheable", "tablePaginatorSize", "separatedUploadButtons", "showPreview", "singleAttachmentDragAndDrop", "cropOptions", "cropDialogClass", "downloadTooltipPosition", "openLinkLabel", "addButtonLabel", "downloadLabel", "deleteLabel", "fileNameLabel", "previewLabel", "uploadFileLabel", "confirmLabel", "abortLabel", "saveLabel", "exitLabel", "uploadWithDropboxLabel", "cropLabel", "eqpTableSearchText", "deleteDialogTitle", "deleteDialogMessage", "noImageSelectedErrorMessage", "wrongTypeSelectedErrorMessage", "videoPreviewErrorMessage", "flipHorinzontalLabel", "flipVerticalLabel", "rotateRightLabel", "rotateLeftLabel"], outputs: ["localEditedAttachments", "abortAddAttachment", "downloadAttachment", "onDeleteAttachment"] }] });
119
+ AttachmentFieldTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: AttachmentFieldTemplateComponent, selector: "attachment-field-template", inputs: { onlyImages: "onlyImages", field: "field", record: "record", formulaObject: "formulaObject", inConfig: "inConfig" }, outputs: { recordChange: "recordChange", onAttachmentsChange: "onAttachmentsChange" }, viewQueries: [{ propertyName: "eqpAttachments", first: true, predicate: ["eqpAttachments"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<p *ngIf=\"!field.isMultiAttach\" class=\"mb-2\">\r\n {{field.Description + (field.Required ? \" *\" : \"\")}}\r\n</p>\r\n<div class=\"row\" *ngIf=\"!field.isMultiAttach && record[field.Name] && record[field.Name][0]\">\r\n <!-- <div class=\"mt-2\" *ngFor=\"let metadata of field.MetadataFields\"\r\n [ngClass]=\"utilityService.getFieldSyleClass(metadata)\">\r\n <dynamic-module-field-fix [field]=\"metadata\" [record]=\"record[field.Name][0]\"\r\n (recordChange)=\"updateMetadataValidity()\">\r\n </dynamic-module-field-fix>\r\n </div> -->\r\n</div>\r\n\r\n\r\n<eqp-attachments [attachmentsList]=\"record[field.Name]\" [showMatCard]=\"true\" [allowOnlyImages]=\"onlyImages\"\r\n [isDisabled]=\"field.FormFormGroup.disabled\" [showInlinePreview]=\"true\" [multipleAttachment]=\"field.isMultiAttach\"\r\n [disableAction]=\"field.FormFormGroup.disabled\" [acceptedFileTypes]=\"field.AllowedExtensions\" [showHeader]=\"true\"\r\n [headerTitle]=\"field.Description + (field.Required ? ' *' : '')\" (localEditedAttachments)=\"catchAttachmentList($event)\"\r\n #eqpAttachments>\r\n</eqp-attachments>\r\n\r\n<!-- TEMPLATE PER VISUALIZZARE LA COLONNA DELLA SEZIONE NELLA TABELLA DEI FIELDS -->\r\n<!-- <ng-template #metadataColumnTemplate let-row=\"row\" let-col=\"col\">\r\n <dynamic-module-field-fix [field]=\"getFieldFromMetadata(col, row)\" [record]=\"row\"\r\n (recordChange)=\"updateMetadataValidity()\">\r\n </dynamic-module-field-fix>\r\n</ng-template> -->", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.EqpAttachmentsComponent, selector: "eqp-attachments", inputs: ["disableAction", "showHeader", "headerTitle", "attachmentsList", "showMatCard", "multipleAttachment", "loadMultipleFiles", "attachmentsColumns", "emptyTableMessage", "allowOnlyImages", "acceptedFileTypes", "isDisabled", "showInlinePreview", "getAttachmentEndpoint", "productionBaseUrl", "compressionOptions", "allowedTypes", "isEqpTableMultiLanguage", "tablePaginatorVisible", "isTableSearcheable", "tablePaginatorSize", "separatedUploadButtons", "showPreview", "singleAttachmentDragAndDrop", "cropOptions", "cropDialogClass", "downloadTooltipPosition", "openLinkLabel", "addButtonLabel", "downloadLabel", "deleteLabel", "fileNameLabel", "previewLabel", "uploadFileLabel", "confirmLabel", "abortLabel", "saveLabel", "exitLabel", "uploadWithDropboxLabel", "cropLabel", "eqpTableSearchText", "deleteDialogTitle", "deleteDialogMessage", "noImageSelectedErrorMessage", "wrongTypeSelectedErrorMessage", "videoPreviewErrorMessage", "flipHorinzontalLabel", "flipVerticalLabel", "rotateRightLabel", "rotateLeftLabel"], outputs: ["localEditedAttachments", "abortAddAttachment", "downloadAttachment", "onDeleteAttachment"] }] });
120
120
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: AttachmentFieldTemplateComponent, decorators: [{
121
121
  type: Component,
122
- args: [{ selector: 'attachment-field-template', template: "<p *ngIf=\"!field.IsMultiAttach\" class=\"mb-2\">\r\n {{field.Description + (field.Required ? \" *\" : \"\")}}\r\n</p>\r\n<div class=\"row\" *ngIf=\"!field.IsMultiAttach && record[field.Name] && record[field.Name][0]\">\r\n <!-- <div class=\"mt-2\" *ngFor=\"let metadata of field.MetadataFields\"\r\n [ngClass]=\"utilityService.getFieldSyleClass(metadata)\">\r\n <dynamic-module-field-fix [field]=\"metadata\" [record]=\"record[field.Name][0]\"\r\n (recordChange)=\"updateMetadataValidity()\">\r\n </dynamic-module-field-fix>\r\n </div> -->\r\n</div>\r\n\r\n<eqp-attachments [attachmentsList]=\"record[field.Name]\" [showMatCard]=\"true\" [allowOnlyImages]=\"onlyImages\"\r\n [isDisabled]=\"field.FormFormGroup.disabled\" [showInlinePreview]=\"true\" [multipleAttachment]=\"field.IsMultiAttach\"\r\n [disableAction]=\"field.FormFormGroup.disabled\" [acceptedFileTypes]=\"field.AllowedExtensions\" [showHeader]=\"true\"\r\n [headerTitle]=\"field.Description + (field.Required ? ' *' : '')\" (localEditedAttachments)=\"catchAttachmentList($event)\"\r\n #eqpAttachments>\r\n</eqp-attachments>\r\n\r\n<!-- TEMPLATE PER VISUALIZZARE LA COLONNA DELLA SEZIONE NELLA TABELLA DEI FIELDS -->\r\n<!-- <ng-template #metadataColumnTemplate let-row=\"row\" let-col=\"col\">\r\n <dynamic-module-field-fix [field]=\"getFieldFromMetadata(col, row)\" [record]=\"row\"\r\n (recordChange)=\"updateMetadataValidity()\">\r\n </dynamic-module-field-fix>\r\n</ng-template> -->" }]
122
+ args: [{ selector: 'attachment-field-template', template: "<p *ngIf=\"!field.isMultiAttach\" class=\"mb-2\">\r\n {{field.Description + (field.Required ? \" *\" : \"\")}}\r\n</p>\r\n<div class=\"row\" *ngIf=\"!field.isMultiAttach && record[field.Name] && record[field.Name][0]\">\r\n <!-- <div class=\"mt-2\" *ngFor=\"let metadata of field.MetadataFields\"\r\n [ngClass]=\"utilityService.getFieldSyleClass(metadata)\">\r\n <dynamic-module-field-fix [field]=\"metadata\" [record]=\"record[field.Name][0]\"\r\n (recordChange)=\"updateMetadataValidity()\">\r\n </dynamic-module-field-fix>\r\n </div> -->\r\n</div>\r\n\r\n\r\n<eqp-attachments [attachmentsList]=\"record[field.Name]\" [showMatCard]=\"true\" [allowOnlyImages]=\"onlyImages\"\r\n [isDisabled]=\"field.FormFormGroup.disabled\" [showInlinePreview]=\"true\" [multipleAttachment]=\"field.isMultiAttach\"\r\n [disableAction]=\"field.FormFormGroup.disabled\" [acceptedFileTypes]=\"field.AllowedExtensions\" [showHeader]=\"true\"\r\n [headerTitle]=\"field.Description + (field.Required ? ' *' : '')\" (localEditedAttachments)=\"catchAttachmentList($event)\"\r\n #eqpAttachments>\r\n</eqp-attachments>\r\n\r\n<!-- TEMPLATE PER VISUALIZZARE LA COLONNA DELLA SEZIONE NELLA TABELLA DEI FIELDS -->\r\n<!-- <ng-template #metadataColumnTemplate let-row=\"row\" let-col=\"col\">\r\n <dynamic-module-field-fix [field]=\"getFieldFromMetadata(col, row)\" [record]=\"row\"\r\n (recordChange)=\"updateMetadataValidity()\">\r\n </dynamic-module-field-fix>\r\n</ng-template> -->" }]
123
123
  }], ctorParameters: function () { return [{ type: i1.UtilityHelperService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { onlyImages: [{
124
124
  type: Input
125
125
  }], field: [{
@@ -138,4 +138,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
138
138
  type: ViewChild,
139
139
  args: ["eqpAttachments", { static: true }]
140
140
  }] } });
141
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attachment-field-template.component.js","sourceRoot":"","sources":["../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/attachment-field-template/attachment-field-template.component.ts","../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/attachment-field-template/attachment-field-template.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectorRef, Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, TemplateRef, ViewChild } from '@angular/core';\r\nimport { Record } from '../../../../models/record.model';\r\nimport { AttachmentField, AvailableFileExtensions, AvailableImageExtensions } from '../../../../models/fields/attachmentField.model';\r\nimport { IBaseFieldComponent } from '../../../../interfaces/iBaseFieldComponent.interface';\r\nimport { UtilityHelperService } from '../../../../services/utilityHelper.services';\r\nimport { EqpAttachmentsComponent } from '@eqproject/eqp-attachments';\r\nimport { UntypedFormGroup } from '@angular/forms';\r\nimport { ConfigColumn, TypeColumn } from '@eqproject/eqp-table';\r\nimport { DataGetterTypeEnum } from '../../../../models/baseField.model';\r\n\r\n@Component({\r\n  selector: 'attachment-field-template',\r\n  templateUrl: './attachment-field-template.component.html',\r\n  styleUrls: ['./attachment-field-template.component.scss']\r\n})\r\nexport class AttachmentFieldTemplateComponent implements OnInit, OnChanges, IBaseFieldComponent, AfterViewInit {\r\n\r\n  @Input() onlyImages: boolean = false;\r\n  @Input() field: AttachmentField;\r\n  @Input() record: Record;\r\n  @Input() formulaObject: any = {};\r\n  @Input() inConfig: boolean = false;\r\n  @Output() recordChange: EventEmitter<Record> = new EventEmitter<Record>();\r\n  @Output() onAttachmentsChange: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @ViewChild(\"eqpAttachments\", { static: true }) eqpAttachments: EqpAttachmentsComponent;\r\n  //@ViewChild('metadataColumnTemplate', { static: true }) metadataColumnTemplate: TemplateRef<any>;\r\n\r\n  //metadataFormGroups: Array<UntypedFormGroup> = new Array<UntypedFormGroup>();\r\n\r\n  constructor(\r\n    public utilityService: UtilityHelperService,\r\n    private cdr: ChangeDetectorRef\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    // Nel caso in cui sono in modifica di un Record aggiorno il valore\r\n    // e il validator del FormControl. Se non viene eseguita questa riga\r\n    // l'utente deve modificare la selezione fatta per aggiornare la form.\r\n    this.setFormControlValue();\r\n\r\n    // Sempre nel caso in cui sono in modifica creo i FormGroup che rappresentano\r\n    // gli eventuali metadata degli allegati recuperati.\r\n  //\r\n\r\n    if (!this.field.AllowedExtensions) {\r\n      this.field.AllowedExtensions = AvailableFileExtensions.concat(AvailableImageExtensions).map(ext => ext.key);\r\n    }\r\n    this.updateField();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    // Dopo aver renderizzato il DOM, se il campo ammette molteplici allegati\r\n    // configuro le colonne della eqp-table in eqp-attachments.\r\n    // if (this.field.IsMultiAttach) {\r\n    //   this.configureMultiAttachmentColumns();\r\n    // }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    // Se viene modificato il valore di \"ngModelInput\" allora aggiorna l'input\r\n    if (changes['record'] != undefined && changes['record'].firstChange == false && JSON.stringify(changes['record'].currentValue) != JSON.stringify(changes['record'].previousValue)) {\r\n      this.record = changes['record'].currentValue;\r\n      this.updateField();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per aggiornare il valore del campo quando questo è rappresentato da una formula.\r\n   */\r\n  updateField() {\r\n    if ((this.field.DataGetter.DataGetterType == DataGetterTypeEnum.Manuale || this.field.DataGetter.DataGetterType == DataGetterTypeEnum.Formula) && this.field.Formula) {\r\n      this.record[this.field.Name] = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, this.formulaObject);\r\n    }\r\n    if (this.field.VisibleIf) {\r\n      this.field.InListView = UtilityHelperService.EvaluateFieldFormula(this.field.VisibleIf, this.record, this.formulaObject);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per intercettare le modifiche agli allegati caricati.\r\n   * Se il campo prevede dei metadata allora per ogni allegato caricato crea un FormGroup\r\n   * per gestire la validazione degli input che l'utente può/deve riempire. I FormGroup \r\n   * seguono lo stesso ordine degli allegati caricati.\r\n   * @param event Contiene la lista aggiornata degli Attachment caricati dall'utente.\r\n   */\r\n  catchAttachmentList(event) {\r\n    this.record[this.field.Name] = event;\r\n\r\n   // this.createMetadataFormGroups();\r\n\r\n    this.setFormControlValue();\r\n    this.onRecordValueChange();\r\n    \r\n    // Scateno un evento di output necessario al componente ImageFieldTemplate al\r\n    // variare degli allegati caricati. Viene usato per aprire il dialog per disegnare\r\n    // sull'immagine caricata in base alla configurazione del Field.\r\n    this.onAttachmentsChange.emit();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  /**\r\n   * Metodo per aggiornare lo stato di validazione del FormControl che rappresenta \r\n   * il campo Allegato (non i metadata al suo interno). Se tra le form dei metadata\r\n   * ne trova una invalida allora marca il controllo come invalido.\r\n   */\r\n  // updateMetadataValidity() {\r\n  //   if (this.metadataFormGroups.find(form => form.invalid)) {\r\n  //     this.field.FormFormGroup.controls[this.field.Name].setErrors({ 'incorrect': true });\r\n  //   } else {\r\n  //     this.field.FormFormGroup.controls[this.field.Name].setErrors(null);\r\n  //   }\r\n  //   this.onRecordValueChange();\r\n  // }\r\n\r\n  /**\r\n   * Metodo per recuperare il BaseField che rappresenta il metadata nella riga della eqp-table\r\n   * in base alla colonna e alla riga. Una volta trovato il BaseField gli viene associato il \r\n   * FormGroup di cui fa parte.\r\n   * @param col Colonna della eqp-table.\r\n   * @param row Riga della eqp-table (in questo caso eredita da IAttachment).\r\n   * @returns Restituisce un BaseField per renderizzare il campo nella eqp-table degli allegati multipli.\r\n   */\r\n  // getFieldFromMetadata(col: ConfigColumn, row: any) {\r\n  //   var baseField = JSON.parse(JSON.stringify(this.field.MetadataFields.find(metadata => metadata.Name === col.key)));\r\n  //   baseField.FormFormGroup = this.metadataFormGroups[this.record[this.field.Name].indexOf(row)];\r\n  //   return baseField;\r\n  // }\r\n\r\n  /**\r\n   * Metodo per aggiornare il valore e il validator del FormControl associato al campo.\r\n   */\r\n  private setFormControlValue() {\r\n    this.field.FormFormGroup.controls[this.field.Name].setValue(this.record[this.field.Name]);\r\n  }\r\n\r\n  /**\r\n   * Metodo per emettere l'evento che il valore del record è cambiato.\r\n   */\r\n  private onRecordValueChange() {\r\n    if (!this.field.Formula) {\r\n      this.recordChange.emit(this.record);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per aggiungere alle colonne di eqp-attachments le colonne per modificare i metadata\r\n   * configurati per il campo Allegato o Immagine.\r\n   */\r\n  // private configureMultiAttachmentColumns() {\r\n  //   if (this.eqpAttachments && this.eqpAttachments.attachmentsColumns && this.field.MetadataFields && this.field.MetadataFields.length > 0) {\r\n  //     this.field.MetadataFields.forEach(metadata => {\r\n  //       this.eqpAttachments.attachmentsColumns.splice(\r\n  //         this.eqpAttachments.attachmentsColumns.length - 1, 0,\r\n  //         { key: metadata.Name, display: metadata.Label, type: TypeColumn.ExternalTemplate, externalTemplate: this.metadataColumnTemplate }\r\n  //       );\r\n  //     });\r\n  //   }\r\n  // }\r\n\r\n  /**\r\n   * Metodo per creare i FormGroup che rappresentano i metadata degli allegati caricati.\r\n   */\r\n  // private createMetadataFormGroups() {\r\n  //   if (this.field.MetadataFields && this.field.MetadataFields.length > 0) {\r\n  //     this.metadataFormGroups = [];\r\n  //     if (this.record[this.field.Name] && this.record[this.field.Name].length > 0) {\r\n  //       this.record[this.field.Name].forEach(attachment => {\r\n  //         this.metadataFormGroups.push(this.utilityService.CreateFormFormGroup(this.field.MetadataFields, attachment, this.field.FormFormGroup.disabled, !this.field.IsMultiAttach));\r\n  //       });\r\n  //     }\r\n\r\n  //     this.updateMetadataValidity();\r\n  //   }\r\n  // }\r\n}","<p *ngIf=\"!field.IsMultiAttach\" class=\"mb-2\">\r\n    {{field.Description + (field.Required ? \" *\" : \"\")}}\r\n</p>\r\n<div class=\"row\" *ngIf=\"!field.IsMultiAttach && record[field.Name] && record[field.Name][0]\">\r\n    <!-- <div class=\"mt-2\" *ngFor=\"let metadata of field.MetadataFields\"\r\n        [ngClass]=\"utilityService.getFieldSyleClass(metadata)\">\r\n        <dynamic-module-field-fix [field]=\"metadata\" [record]=\"record[field.Name][0]\"\r\n            (recordChange)=\"updateMetadataValidity()\">\r\n        </dynamic-module-field-fix>\r\n    </div> -->\r\n</div>\r\n\r\n<eqp-attachments [attachmentsList]=\"record[field.Name]\" [showMatCard]=\"true\" [allowOnlyImages]=\"onlyImages\"\r\n    [isDisabled]=\"field.FormFormGroup.disabled\" [showInlinePreview]=\"true\" [multipleAttachment]=\"field.IsMultiAttach\"\r\n    [disableAction]=\"field.FormFormGroup.disabled\" [acceptedFileTypes]=\"field.AllowedExtensions\" [showHeader]=\"true\"\r\n    [headerTitle]=\"field.Description + (field.Required ? ' *' : '')\" (localEditedAttachments)=\"catchAttachmentList($event)\"\r\n    #eqpAttachments>\r\n</eqp-attachments>\r\n\r\n<!-- TEMPLATE PER VISUALIZZARE LA COLONNA DELLA SEZIONE NELLA TABELLA DEI FIELDS -->\r\n<!-- <ng-template #metadataColumnTemplate let-row=\"row\" let-col=\"col\">\r\n    <dynamic-module-field-fix [field]=\"getFieldFromMetadata(col, row)\" [record]=\"row\"\r\n        (recordChange)=\"updateMetadataValidity()\">\r\n    </dynamic-module-field-fix>\r\n</ng-template> -->"]}
141
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attachment-field-template.component.js","sourceRoot":"","sources":["../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/attachment-field-template/attachment-field-template.component.ts","../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/attachment-field-template/attachment-field-template.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectorRef, Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, TemplateRef, ViewChild } from '@angular/core';\r\nimport { Record } from '../../../../models/record.model';\r\nimport { AttachmentField, AvailableFileExtensions, AvailableImageExtensions } from '../../../../models/fields/attachmentField.model';\r\nimport { IBaseFieldComponent } from '../../../../interfaces/iBaseFieldComponent.interface';\r\nimport { UtilityHelperService } from '../../../../services/utilityHelper.services';\r\nimport { EqpAttachmentsComponent } from '@eqproject/eqp-attachments';\r\nimport { UntypedFormGroup } from '@angular/forms';\r\nimport { ConfigColumn, TypeColumn } from '@eqproject/eqp-table';\r\nimport { DataGetterTypeEnum } from '../../../../models/baseField.model';\r\n\r\n@Component({\r\n  selector: 'attachment-field-template',\r\n  templateUrl: './attachment-field-template.component.html',\r\n  styleUrls: ['./attachment-field-template.component.scss']\r\n})\r\nexport class AttachmentFieldTemplateComponent implements OnInit, OnChanges, IBaseFieldComponent, AfterViewInit {\r\n\r\n  @Input() onlyImages: boolean = false;\r\n  @Input() field: AttachmentField;\r\n  @Input() record: Record;\r\n  @Input() formulaObject: any = {};\r\n  @Input() inConfig: boolean = false;\r\n  @Output() recordChange: EventEmitter<Record> = new EventEmitter<Record>();\r\n  @Output() onAttachmentsChange: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @ViewChild(\"eqpAttachments\", { static: true }) eqpAttachments: EqpAttachmentsComponent;\r\n  //@ViewChild('metadataColumnTemplate', { static: true }) metadataColumnTemplate: TemplateRef<any>;\r\n\r\n  //metadataFormGroups: Array<UntypedFormGroup> = new Array<UntypedFormGroup>();\r\n\r\n  constructor(\r\n    public utilityService: UtilityHelperService,\r\n    private cdr: ChangeDetectorRef\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    // Nel caso in cui sono in modifica di un Record aggiorno il valore\r\n    // e il validator del FormControl. Se non viene eseguita questa riga\r\n    // l'utente deve modificare la selezione fatta per aggiornare la form.\r\n    this.setFormControlValue();\r\n\r\n    // Sempre nel caso in cui sono in modifica creo i FormGroup che rappresentano\r\n    // gli eventuali metadata degli allegati recuperati.\r\n  //\r\n\r\n    if (!this.field.AllowedExtensions) {\r\n      this.field.AllowedExtensions = AvailableFileExtensions.concat(AvailableImageExtensions).map(ext => ext.key);\r\n    }\r\n    this.updateField();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    // Dopo aver renderizzato il DOM, se il campo ammette molteplici allegati\r\n    // configuro le colonne della eqp-table in eqp-attachments.\r\n    // if (this.field.IsMultiAttach) {\r\n    //   this.configureMultiAttachmentColumns();\r\n    // }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    // Se viene modificato il valore di \"ngModelInput\" allora aggiorna l'input\r\n    if (changes['record'] != undefined && changes['record'].firstChange == false && JSON.stringify(changes['record'].currentValue) != JSON.stringify(changes['record'].previousValue)) {\r\n      this.record = changes['record'].currentValue;\r\n      this.updateField();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per aggiornare il valore del campo quando questo è rappresentato da una formula.\r\n   */\r\n  updateField() {\r\n    if ((this.field.DataGetter.DataGetterType == DataGetterTypeEnum.Manuale || this.field.DataGetter.DataGetterType == DataGetterTypeEnum.Formula) && this.field.Formula) {\r\n      this.record[this.field.Name] = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, this.formulaObject);\r\n    }\r\n    if (this.field.VisibleIf) {\r\n      this.field.InListView = UtilityHelperService.EvaluateFieldFormula(this.field.VisibleIf, this.record, this.formulaObject);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per intercettare le modifiche agli allegati caricati.\r\n   * Se il campo prevede dei metadata allora per ogni allegato caricato crea un FormGroup\r\n   * per gestire la validazione degli input che l'utente può/deve riempire. I FormGroup \r\n   * seguono lo stesso ordine degli allegati caricati.\r\n   * @param event Contiene la lista aggiornata degli Attachment caricati dall'utente.\r\n   */\r\n  catchAttachmentList(event) {\r\n    this.record[this.field.Name] = event;\r\n\r\n   // this.createMetadataFormGroups();\r\n\r\n    this.setFormControlValue();\r\n    this.onRecordValueChange();\r\n    \r\n    // Scateno un evento di output necessario al componente ImageFieldTemplate al\r\n    // variare degli allegati caricati. Viene usato per aprire il dialog per disegnare\r\n    // sull'immagine caricata in base alla configurazione del Field.\r\n    this.onAttachmentsChange.emit();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  /**\r\n   * Metodo per aggiornare lo stato di validazione del FormControl che rappresenta \r\n   * il campo Allegato (non i metadata al suo interno). Se tra le form dei metadata\r\n   * ne trova una invalida allora marca il controllo come invalido.\r\n   */\r\n  // updateMetadataValidity() {\r\n  //   if (this.metadataFormGroups.find(form => form.invalid)) {\r\n  //     this.field.FormFormGroup.controls[this.field.Name].setErrors({ 'incorrect': true });\r\n  //   } else {\r\n  //     this.field.FormFormGroup.controls[this.field.Name].setErrors(null);\r\n  //   }\r\n  //   this.onRecordValueChange();\r\n  // }\r\n\r\n  /**\r\n   * Metodo per recuperare il BaseField che rappresenta il metadata nella riga della eqp-table\r\n   * in base alla colonna e alla riga. Una volta trovato il BaseField gli viene associato il \r\n   * FormGroup di cui fa parte.\r\n   * @param col Colonna della eqp-table.\r\n   * @param row Riga della eqp-table (in questo caso eredita da IAttachment).\r\n   * @returns Restituisce un BaseField per renderizzare il campo nella eqp-table degli allegati multipli.\r\n   */\r\n  // getFieldFromMetadata(col: ConfigColumn, row: any) {\r\n  //   var baseField = JSON.parse(JSON.stringify(this.field.MetadataFields.find(metadata => metadata.Name === col.key)));\r\n  //   baseField.FormFormGroup = this.metadataFormGroups[this.record[this.field.Name].indexOf(row)];\r\n  //   return baseField;\r\n  // }\r\n\r\n  /**\r\n   * Metodo per aggiornare il valore e il validator del FormControl associato al campo.\r\n   */\r\n  private setFormControlValue() {\r\n    this.field.FormFormGroup.controls[this.field.Name].setValue(this.record[this.field.Name]);\r\n  }\r\n\r\n  /**\r\n   * Metodo per emettere l'evento che il valore del record è cambiato.\r\n   */\r\n  private onRecordValueChange() {\r\n    if (!this.field.Formula) {\r\n      this.recordChange.emit(this.record);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per aggiungere alle colonne di eqp-attachments le colonne per modificare i metadata\r\n   * configurati per il campo Allegato o Immagine.\r\n   */\r\n  // private configureMultiAttachmentColumns() {\r\n  //   if (this.eqpAttachments && this.eqpAttachments.attachmentsColumns && this.field.MetadataFields && this.field.MetadataFields.length > 0) {\r\n  //     this.field.MetadataFields.forEach(metadata => {\r\n  //       this.eqpAttachments.attachmentsColumns.splice(\r\n  //         this.eqpAttachments.attachmentsColumns.length - 1, 0,\r\n  //         { key: metadata.Name, display: metadata.Label, type: TypeColumn.ExternalTemplate, externalTemplate: this.metadataColumnTemplate }\r\n  //       );\r\n  //     });\r\n  //   }\r\n  // }\r\n\r\n  /**\r\n   * Metodo per creare i FormGroup che rappresentano i metadata degli allegati caricati.\r\n   */\r\n  // private createMetadataFormGroups() {\r\n  //   if (this.field.MetadataFields && this.field.MetadataFields.length > 0) {\r\n  //     this.metadataFormGroups = [];\r\n  //     if (this.record[this.field.Name] && this.record[this.field.Name].length > 0) {\r\n  //       this.record[this.field.Name].forEach(attachment => {\r\n  //         this.metadataFormGroups.push(this.utilityService.CreateFormFormGroup(this.field.MetadataFields, attachment, this.field.FormFormGroup.disabled, !this.field.IsMultiAttach));\r\n  //       });\r\n  //     }\r\n\r\n  //     this.updateMetadataValidity();\r\n  //   }\r\n  // }\r\n}","<p *ngIf=\"!field.isMultiAttach\" class=\"mb-2\">\r\n    {{field.Description + (field.Required ? \" *\" : \"\")}}\r\n</p>\r\n<div class=\"row\" *ngIf=\"!field.isMultiAttach && record[field.Name] && record[field.Name][0]\">\r\n    <!-- <div class=\"mt-2\" *ngFor=\"let metadata of field.MetadataFields\"\r\n        [ngClass]=\"utilityService.getFieldSyleClass(metadata)\">\r\n        <dynamic-module-field-fix [field]=\"metadata\" [record]=\"record[field.Name][0]\"\r\n            (recordChange)=\"updateMetadataValidity()\">\r\n        </dynamic-module-field-fix>\r\n    </div> -->\r\n</div>\r\n\r\n\r\n<eqp-attachments [attachmentsList]=\"record[field.Name]\" [showMatCard]=\"true\" [allowOnlyImages]=\"onlyImages\"\r\n    [isDisabled]=\"field.FormFormGroup.disabled\" [showInlinePreview]=\"true\" [multipleAttachment]=\"field.isMultiAttach\"\r\n    [disableAction]=\"field.FormFormGroup.disabled\" [acceptedFileTypes]=\"field.AllowedExtensions\" [showHeader]=\"true\"\r\n    [headerTitle]=\"field.Description + (field.Required ? ' *' : '')\" (localEditedAttachments)=\"catchAttachmentList($event)\"\r\n    #eqpAttachments>\r\n</eqp-attachments>\r\n\r\n<!-- TEMPLATE PER VISUALIZZARE LA COLONNA DELLA SEZIONE NELLA TABELLA DEI FIELDS -->\r\n<!-- <ng-template #metadataColumnTemplate let-row=\"row\" let-col=\"col\">\r\n    <dynamic-module-field-fix [field]=\"getFieldFromMetadata(col, row)\" [record]=\"row\"\r\n        (recordChange)=\"updateMetadataValidity()\">\r\n    </dynamic-module-field-fix>\r\n</ng-template> -->"]}
@@ -27,10 +27,26 @@ export class BooleanFieldTemplateComponent {
27
27
  this.updateField();
28
28
  this.initStyles();
29
29
  }
30
- ngOnChanges(changes) {
30
+ checkReadonly() {
31
31
  if (this.field.ReadonlyIf) {
32
32
  this.field.Readonly = UtilityHelperService.EvaluateFieldFormula(this.field.ReadonlyIf, this.record, this.formulaObject);
33
33
  }
34
+ if (this.field.Readonly) {
35
+ this.field.FormFormGroup.controls[this.field.Name].disable();
36
+ }
37
+ else {
38
+ this.field.FormFormGroup.controls[this.field.Name].enable();
39
+ }
40
+ }
41
+ checkVisibility(defaultValue) {
42
+ if (this.field.VisibleIf) {
43
+ this.field.InListView = UtilityHelperService.EvaluateFieldFormula(this.field.VisibleIf, this.record, this.formulaObject);
44
+ if (!this.field.InListView && !this.field.Maintain_Value) {
45
+ this.record[this.field.Name] = defaultValue;
46
+ }
47
+ }
48
+ }
49
+ ngOnChanges(changes) {
34
50
  // Se viene modificato il valore di "ngModelInput" allora aggiorna l'input
35
51
  if (changes['record'] != undefined && changes['record'].firstChange == false && JSON.stringify(changes['record'].currentValue) != JSON.stringify(changes['record'].previousValue)) {
36
52
  this.record = changes['record'].currentValue;
@@ -41,15 +57,15 @@ export class BooleanFieldTemplateComponent {
41
57
  * Metodo per aggiornare il valore del campo quando questo è rappresentato da una formula.
42
58
  */
43
59
  updateField() {
60
+ // Gestione del readonly
61
+ this.checkReadonly();
62
+ // Gestione del valore legato alla visibilità
63
+ this.checkVisibility(false);
64
+ // Gestione del valore calcolato da formula
44
65
  if ((this.field.DataGetter.DataGetterType == DataGetterTypeEnum.Manuale || this.field.DataGetter.DataGetterType == DataGetterTypeEnum.Formula) && this.field.Formula) {
45
66
  this.record[this.field.Name] = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, this.formulaObject);
46
67
  }
47
- if (this.field.VisibleIf) {
48
- this.field.InListView = UtilityHelperService.EvaluateFieldFormula(this.field.VisibleIf, this.record, this.formulaObject);
49
- if (!this.field.InListView && !this.field.Maintain_Value) {
50
- this.record[this.field.Name] = false;
51
- }
52
- }
68
+ // Gestione del valore di default
53
69
  if (this.field.DataGetter.DataGetterType == DataGetterTypeEnum.Manuale && this.record[this.field.Name] == null) {
54
70
  this.record[this.field.Name] = this.field.DataGetter.DataGetterValue;
55
71
  }
@@ -77,4 +93,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
77
93
  }], recordChange: [{
78
94
  type: Output
79
95
  }] } });
80
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"boolean-field-template.component.js","sourceRoot":"","sources":["../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/boolean-field-template/boolean-field-template.component.ts","../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/boolean-field-template/boolean-field-template.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { Record } from '../../../../models/record.model';\r\nimport { BooleanField, BoolPresentantioEnum } from '../../../../models/fields/booleanField.model';\r\nimport { IBaseFieldComponent } from '../../../../interfaces/iBaseFieldComponent.interface';\r\nimport { UtilityHelperService } from '../../../../services/utilityHelper.services';\r\nimport { DataGetterTypeEnum } from '../../../../models/baseField.model';\r\n\r\n@Component({\r\n  selector: 'boolean-field-template',\r\n  templateUrl: './boolean-field-template.component.html',\r\n  styleUrls: ['./boolean-field-template.component.scss']\r\n})\r\nexport class BooleanFieldTemplateComponent implements OnInit, OnChanges, IBaseFieldComponent {\r\n\r\n  @Input() field: BooleanField;\r\n  @Input() record: Record;\r\n  @Input() formulaObject: any = {};\r\n  @Output() recordChange: EventEmitter<Record> = new EventEmitter<Record>();\r\n//variabili per gestire il css della label e del field\r\nFieldstyleObj: any;\r\nLabelstyleObj: any;\r\n\r\n  BoolPresentantioEnum = BoolPresentantioEnum;\r\n\r\n  constructor() { }\r\n\r\n  initStyles() {\r\n    //Funzione per parsare il campo stylecss dell'oggetto field ed applicarlo all'html\r\n    if(this.field.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)   \r\n    this.FieldstyleObj= UtilityHelperService.initStyles(this.field.FieldstyleCSS);\r\n  }\r\n  \r\n  ngOnInit(): void {\r\n    if (this.record[this.field.Name] == undefined || this.record[this.field.Name] == null) {\r\n      this.record[this.field.Name] = this.field.IsTristate ? null : false;\r\n    }\r\n\r\n    this.updateField();\r\n    this.initStyles();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (this.field.ReadonlyIf) {\r\n      this.field.Readonly = UtilityHelperService.EvaluateFieldFormula(this.field.ReadonlyIf, this.record, this.formulaObject);\r\n    }\r\n    // Se viene modificato il valore di \"ngModelInput\" allora aggiorna l'input\r\n    if (changes['record'] != undefined && changes['record'].firstChange == false && JSON.stringify(changes['record'].currentValue) != JSON.stringify(changes['record'].previousValue)) {\r\n      this.record = changes['record'].currentValue;\r\n      this.updateField();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per aggiornare il valore del campo quando questo è rappresentato da una formula.\r\n   */\r\n  updateField() {\r\n    if ((this.field.DataGetter.DataGetterType == DataGetterTypeEnum.Manuale || this.field.DataGetter.DataGetterType == DataGetterTypeEnum.Formula) && this.field.Formula) {\r\n      this.record[this.field.Name] = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, this.formulaObject);\r\n    }\r\n    if (this.field.VisibleIf) {\r\n      this.field.InListView = UtilityHelperService.EvaluateFieldFormula(this.field.VisibleIf, this.record, this.formulaObject);\r\n      if(!this.field.InListView && !this.field.Maintain_Value){\r\n        this.record[this.field.Name]=false;\r\n        \r\n      }  \r\n    \r\n    }\r\n    if (this.field.DataGetter.DataGetterType == DataGetterTypeEnum.Manuale && this.record[this.field.Name] == null) {\r\n      this.record[this.field.Name] = this.field.DataGetter.DataGetterValue;\r\n    }    \r\n  }\r\n\r\n  /**\r\n   * Metodo per emettere l'evento che il valore del record è cambiato.\r\n   */\r\n  onRecordValueChange() {\r\n    if (!this.field.Formula) {\r\n      this.recordChange.emit(this.record);\r\n    }\r\n  }\r\n}\r\n","<div [formGroup]=\"field.FormFormGroup\">\r\n\r\n    <!-- VISUALIZZAZIONE A TOGGLE -->\r\n    <mat-slide-toggle color=\"primary\" *ngIf=\"field.PresetationType == BoolPresentantioEnum.Toggle\"\r\n        [formControlName]=\"field.Name\" [disabled]=\"field.FormFormGroup.disabled\" [required]=\"field.Required\"\r\n        [(ngModel)]=\"record[field.Name]\" (ngModelChange)=\"onRecordValueChange()\">\r\n        {{field.Description + (field.Required ? \" *\" : \"\")}}\r\n    </mat-slide-toggle>\r\n\r\n    <!-- VISUALIZZAZIONE A RADIOBUTTON -->\r\n    <mat-label [ngStyle]=\"LabelstyleObj\" class=\"mr-3\" *ngIf=\"field.PresetationType == BoolPresentantioEnum['Radio button']\">\r\n        {{field.Description + (field.Required ? \" *\" : \"\")}}\r\n    </mat-label>\r\n    <mat-radio-group *ngIf=\"field.PresetationType == BoolPresentantioEnum['Radio button']\"\r\n        [formControlName]=\"field.Name\" [disabled]=\"field.FormFormGroup.disabled\" [required]=\"field.Required\"\r\n        [(ngModel)]=\"record[field.Name]\" (ngModelChange)=\"onRecordValueChange()\">\r\n        <mat-radio-button class=\"mr-2\" [value]=\"true\" color=\"primary\"> Si </mat-radio-button>\r\n        <mat-radio-button class=\"mr-2 ps-2\" [value]=\"false\" color=\"primary\"> No </mat-radio-button>\r\n        <mat-radio-button class=\"mr-2 ps-2\" [value]=\"null\" color=\"primary\" *ngIf=\"field.IsTristate\"> ND\r\n        </mat-radio-button>\r\n    </mat-radio-group>\r\n\r\n    <!-- VISUALIZZAZIONE A CHECKBOX -->\r\n    <mat-checkbox class=\"mr-2\" *ngIf=\"field.PresetationType == BoolPresentantioEnum.Checkbox\"\r\n        [disabled]=\"field.FormFormGroup.disabled\" [required]=\"field.Required\" [formControlName]=\"field.Name\"\r\n        [(ngModel)]=\"record[field.Name]\" (ngModelChange)=\"onRecordValueChange()\">\r\n        {{field.Description + (field.Required ? \" *\" : \"\")}}\r\n    </mat-checkbox>\r\n\r\n    <!-- TODO: Visualizzazione \"Stringa true o false\" e \"Numerico 0 o 1\" ?? -->\r\n</div>"]}
96
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"boolean-field-template.component.js","sourceRoot":"","sources":["../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/boolean-field-template/boolean-field-template.component.ts","../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/boolean-field-template/boolean-field-template.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { Record } from '../../../../models/record.model';\r\nimport { BooleanField, BoolPresentantioEnum } from '../../../../models/fields/booleanField.model';\r\nimport { IBaseFieldComponent } from '../../../../interfaces/iBaseFieldComponent.interface';\r\nimport { UtilityHelperService } from '../../../../services/utilityHelper.services';\r\nimport { DataGetterTypeEnum } from '../../../../models/baseField.model';\r\n\r\n@Component({\r\n  selector: 'boolean-field-template',\r\n  templateUrl: './boolean-field-template.component.html',\r\n  styleUrls: ['./boolean-field-template.component.scss']\r\n})\r\nexport class BooleanFieldTemplateComponent implements OnInit, OnChanges, IBaseFieldComponent {\r\n\r\n  @Input() field: BooleanField;\r\n  @Input() record: Record;\r\n  @Input() formulaObject: any = {};\r\n  @Output() recordChange: EventEmitter<Record> = new EventEmitter<Record>();\r\n//variabili per gestire il css della label e del field\r\nFieldstyleObj: any;\r\nLabelstyleObj: any;\r\n\r\n  BoolPresentantioEnum = BoolPresentantioEnum;\r\n\r\n  constructor() { }\r\n\r\n  initStyles() {\r\n    //Funzione per parsare il campo stylecss dell'oggetto field ed applicarlo all'html\r\n    if(this.field.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)   \r\n    this.FieldstyleObj= UtilityHelperService.initStyles(this.field.FieldstyleCSS);\r\n  }\r\n  \r\n  ngOnInit(): void {\r\n    if (this.record[this.field.Name] == undefined || this.record[this.field.Name] == null) {\r\n      this.record[this.field.Name] = this.field.IsTristate ? null : false;\r\n    }\r\n\r\n    this.updateField();\r\n    this.initStyles();\r\n  }\r\n\r\n  checkReadonly(){\r\n    if (this.field.ReadonlyIf) {\r\n      this.field.Readonly = UtilityHelperService.EvaluateFieldFormula(this.field.ReadonlyIf, this.record, this.formulaObject);\r\n    }\r\n    if(this.field.Readonly){\r\n      this.field.FormFormGroup.controls[this.field.Name].disable();\r\n    } else {\r\n      this.field.FormFormGroup.controls[this.field.Name].enable();\r\n    }\r\n  }\r\n  checkVisibility(defaultValue: any){\r\n    \r\n    if (this.field.VisibleIf) {\r\n      this.field.InListView = UtilityHelperService.EvaluateFieldFormula(this.field.VisibleIf, this.record, this.formulaObject);\r\n      if(!this.field.InListView && !this.field.Maintain_Value){\r\n        this.record[this.field.Name]=defaultValue;\r\n      }  \r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    // Se viene modificato il valore di \"ngModelInput\" allora aggiorna l'input\r\n    if (changes['record'] != undefined && changes['record'].firstChange == false && JSON.stringify(changes['record'].currentValue) != JSON.stringify(changes['record'].previousValue)) {\r\n      this.record = changes['record'].currentValue;\r\n      this.updateField();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per aggiornare il valore del campo quando questo è rappresentato da una formula.\r\n   */\r\n  updateField() {\r\n    // Gestione del readonly\r\n    this.checkReadonly();\r\n    // Gestione del valore legato alla visibilità\r\n    this.checkVisibility(false);\r\n    // Gestione del valore calcolato da formula\r\n    if ((this.field.DataGetter.DataGetterType == DataGetterTypeEnum.Manuale || this.field.DataGetter.DataGetterType == DataGetterTypeEnum.Formula) && this.field.Formula) {\r\n      this.record[this.field.Name] = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, this.formulaObject);\r\n    }\r\n    // Gestione del valore di default\r\n    if (this.field.DataGetter.DataGetterType == DataGetterTypeEnum.Manuale && this.record[this.field.Name] == null) {\r\n      this.record[this.field.Name] = this.field.DataGetter.DataGetterValue;\r\n    }    \r\n  }\r\n\r\n  /**\r\n   * Metodo per emettere l'evento che il valore del record è cambiato.\r\n   */\r\n  onRecordValueChange() {\r\n    if (!this.field.Formula) {\r\n      this.recordChange.emit(this.record);\r\n    }\r\n  }\r\n}\r\n","<div [formGroup]=\"field.FormFormGroup\">\r\n\r\n    <!-- VISUALIZZAZIONE A TOGGLE -->\r\n    <mat-slide-toggle color=\"primary\" *ngIf=\"field.PresetationType == BoolPresentantioEnum.Toggle\"\r\n        [formControlName]=\"field.Name\" [disabled]=\"field.FormFormGroup.disabled\" [required]=\"field.Required\"\r\n        [(ngModel)]=\"record[field.Name]\" (ngModelChange)=\"onRecordValueChange()\">\r\n        {{field.Description + (field.Required ? \" *\" : \"\")}}\r\n    </mat-slide-toggle>\r\n\r\n    <!-- VISUALIZZAZIONE A RADIOBUTTON -->\r\n    <mat-label [ngStyle]=\"LabelstyleObj\" class=\"mr-3\" *ngIf=\"field.PresetationType == BoolPresentantioEnum['Radio button']\">\r\n        {{field.Description + (field.Required ? \" *\" : \"\")}}\r\n    </mat-label>\r\n    <mat-radio-group *ngIf=\"field.PresetationType == BoolPresentantioEnum['Radio button']\"\r\n        [formControlName]=\"field.Name\" [disabled]=\"field.FormFormGroup.disabled\" [required]=\"field.Required\"\r\n        [(ngModel)]=\"record[field.Name]\" (ngModelChange)=\"onRecordValueChange()\">\r\n        <mat-radio-button class=\"mr-2\" [value]=\"true\" color=\"primary\"> Si </mat-radio-button>\r\n        <mat-radio-button class=\"mr-2 ps-2\" [value]=\"false\" color=\"primary\"> No </mat-radio-button>\r\n        <mat-radio-button class=\"mr-2 ps-2\" [value]=\"null\" color=\"primary\" *ngIf=\"field.IsTristate\"> ND\r\n        </mat-radio-button>\r\n    </mat-radio-group>\r\n\r\n    <!-- VISUALIZZAZIONE A CHECKBOX -->\r\n    <mat-checkbox class=\"mr-2\" *ngIf=\"field.PresetationType == BoolPresentantioEnum.Checkbox\"\r\n        [disabled]=\"field.FormFormGroup.disabled\" [required]=\"field.Required\" [formControlName]=\"field.Name\"\r\n        [(ngModel)]=\"record[field.Name]\" (ngModelChange)=\"onRecordValueChange()\">\r\n        {{field.Description + (field.Required ? \" *\" : \"\")}}\r\n    </mat-checkbox>\r\n\r\n    <!-- TODO: Visualizzazione \"Stringa true o false\" e \"Numerico 0 o 1\" ?? -->\r\n</div>"]}