brainloper-ui 1.0.26 → 1.0.27
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/src/app/modules/brainloper-ui/components/data-table/table-modal/table-modal.component.mjs +3 -3
- package/fesm2015/brainloper-ui.mjs +2 -2
- package/fesm2015/brainloper-ui.mjs.map +1 -1
- package/fesm2020/brainloper-ui.mjs +2 -2
- package/fesm2020/brainloper-ui.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -83,9 +83,9 @@ export class TableModalComponent {
|
|
|
83
83
|
this.data.columns.map((element) => {
|
|
84
84
|
if (element.paramsCombo && element.paramsCombo.returnDataSelect) {
|
|
85
85
|
element.identifierCombo = element.paramsCombo.selectionField !== element.ID ? element.paramsCombo.selectionField : element.ID;
|
|
86
|
-
let x = this.dataCombo[element.identifierCombo].find(x => x[element.identifierCombo] == this.modalForm.value[element.
|
|
86
|
+
let x = this.dataCombo[element.identifierCombo].find(x => x[element.identifierCombo] == this.modalForm.value[element.ID]);
|
|
87
87
|
if (x) {
|
|
88
|
-
this.modalForm.addControl(element.
|
|
88
|
+
this.modalForm.addControl(element.ID + 'Combo', new FormControl(x));
|
|
89
89
|
}
|
|
90
90
|
}
|
|
91
91
|
});
|
|
@@ -112,4 +112,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
112
112
|
type: Inject,
|
|
113
113
|
args: [MAT_DIALOG_DATA]
|
|
114
114
|
}] }, { type: i2.FormBuilder }, { type: i3.HttpService }]; } });
|
|
115
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-modal.component.js","sourceRoot":"","sources":["../../../../../../../../../src/app/modules/brainloper-ui/components/data-table/table-modal/table-modal.component.ts","../../../../../../../../../src/app/modules/brainloper-ui/components/data-table/table-modal/table-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Inject } from '@angular/core';\r\nimport { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\r\nimport { FormBuilder, FormGroup, FormControl, Validators } from '@angular/forms';\r\nimport { HttpService } from '../../../../services/http.service';\r\nimport { forkJoin } from 'rxjs';\r\nimport { map } from 'rxjs/operators';\r\n\r\n@Component({\r\n  selector: 'app-table-modal',\r\n  templateUrl: './table-modal.component.html',\r\n  styleUrls: ['./table-modal.component.scss'],\r\n})\r\nexport class TableModalComponent implements OnInit {\r\n  modalForm: FormGroup = new FormGroup({});\r\n  dataCombo = {};\r\n\r\n\r\n  constructor(\r\n    public dialogRef: MatDialogRef<TableModalComponent>,\r\n    @Inject(MAT_DIALOG_DATA) public data,\r\n    private formBuilder: FormBuilder,\r\n    private http: HttpService\r\n  ) {}\r\n\r\n  onNoClick(): void {\r\n    this.dialogRef.close();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    let group = {};\r\n    let httpRequests = [];\r\n\r\n    // Usamos map en lugar de forEach para evitar efectos secundarios\r\n    this.data.columns.map((element) => {\r\n      if (!element.disregardForAdd) {\r\n        if (element.type === 'combo') {\r\n          this.dataCombo[element.paramsCombo.selectionField !== element.ID ? element.paramsCombo.selectionField : element.ID] = '';\r\n        }\r\n\r\n        let initialValue = this.data.action === 'edit' ? element.value : '';\r\n        if (element.type === 'date' && element.value) {\r\n          let s = element.value.split('/');\r\n          initialValue = `${s[2]}-${s[1]}-${s[0]}`;\r\n        }\r\n\r\n        group[element.ID] = element.required ? new FormControl(initialValue, Validators.required) : new FormControl(initialValue);\r\n\r\n        if (element.paramsCombo) {\r\n          httpRequests.push(this.createHttpRequest(element, group));\r\n        }\r\n      }\r\n    });\r\n\r\n    if (httpRequests.length > 0) {\r\n      forkJoin(httpRequests).subscribe(() => {\r\n        this.modalForm = new FormGroup(group);\r\n      });\r\n    } else {\r\n      this.modalForm = new FormGroup(group);\r\n    }\r\n  }\r\n\r\n  // Extraemos la creación de la solicitud HTTP a su propia función para mejorar la legibilidad\r\n  createHttpRequest(element, group) {\r\n    return this.http\r\n      .getData(element.paramsCombo.url, element.paramsCombo.urlParams)\r\n      .pipe(\r\n        map((res) => {\r\n          if (res['code'] === 0) {\r\n            element.identifierCombo = element.paramsCombo.selectionField !== element.ID ? element.paramsCombo.selectionField : element.ID;\r\n            this.dataCombo[element.identifierCombo] = res['body'];\r\n\r\n            if (this.data.action !== 'edit') {\r\n              return;\r\n            }\r\n\r\n            this.dataCombo[element.identifierCombo].some((data) => {\r\n              if (\r\n                data[element.paramsCombo.selectionField] === element.value ||\r\n                data[element.paramsCombo.visibleField] === element.value\r\n              ) {\r\n                var value = data[element.paramsCombo.selectionField]\r\n                element.value = value\r\n                group[element.ID].setValue(value);\r\n                return true;\r\n              }\r\n              return false;\r\n            });\r\n\r\n          }\r\n        })\r\n      );\r\n  }\r\n\r\n\r\n  onSubmit() {\r\n    if (this.modalForm.valid) {\r\n\r\n      this.data.columns.map((element) => {\r\n        if (element.paramsCombo && element.paramsCombo.returnDataSelect) {\r\n          element.identifierCombo = element.paramsCombo.selectionField !== element.ID ? element.paramsCombo.selectionField : element.ID;\r\n          let x = this.dataCombo[element.identifierCombo].find(x => x[element.identifierCombo] == this.modalForm.value[element.identifierCombo])\r\n          if(x){\r\n            this.modalForm.addControl(element.identifierCombo + 'Combo', new FormControl(x));\r\n          }\r\n        }\r\n    });\r\n      this.dialogRef.close(this.modalForm.value);\r\n    }\r\n  }\r\n\r\n  onChange(id: any, $event, type: string) {\r\n    switch (type) {\r\n      case 'combo':\r\n        this.modalForm.get(id).setValue($event.value);\r\n        break;\r\n\r\n      default:\r\n        this.modalForm.get(id).setValue($event.target.value);\r\n        break;\r\n    }\r\n  }\r\n}\r\n","<div>\r\n    <div style='display:flex; justify-content: space-between;'>\r\n        <div>\r\n            <strong>\r\n                <h3 *ngIf='data.action==\"edit\"'> Editar </h3>\r\n                <h3 *ngIf='data.action==\"add\"'> Agregar </h3>\r\n            </strong>\r\n        </div>\r\n        <div mat-dialog-close>\r\n            <i class=\"fa fa-times-circle\" style=\"font-size: 150%; position: relative;\"></i>\r\n        </div>\r\n    </div>\r\n\r\n    <form [formGroup]=\"modalForm\">\r\n\r\n        <div *ngFor='let input of data.columns'>\r\n\r\n\r\n\r\n                <div *ngIf='data.action==\"edit\"; else Agregar'>\r\n                  <mat-form-field *ngIf=\"!input.disregardForEdit\">\r\n                    <div *ngIf='input.type==\"combo\"; else otherInputEdit'>\r\n\r\n                        <mat-select [value]=\"input.value\" (selectionChange)='onChange(input.ID,$event, input.type)'\r\n                            placeholder='{{input.label}}' [required]=\"input.required\">\r\n                            <mat-option *ngFor='let data of dataCombo[input.identifierCombo]'\r\n                                [value]='data[input.paramsCombo.selectionField]'>\r\n                                {{data[input.paramsCombo.visibleField]}}</mat-option>\r\n                        </mat-select>\r\n                    </div>\r\n\r\n                    <ng-template #otherInputEdit>\r\n                        <input [type]='input.type' [name]='input.ID' [value]='input.value'\r\n                            (input)='onChange(input.ID,$event, input.type)' matInput [placeholder]='input.label' [required]=\"input.required\" />\r\n                    </ng-template>\r\n\r\n                    <mat-error>Campo Obligatorio</mat-error>\r\n                  </mat-form-field>\r\n\r\n                </div>\r\n\r\n                <ng-template #Agregar>\r\n                  <mat-form-field *ngIf=\"!input.disregardForAdd\">\r\n                    <div *ngIf='input.type==\"combo\"; else otherInput'>\r\n\r\n                        <mat-select (selectionChange)='onChange(input.ID,$event, input.type)' placeholder='{{input.label}}' [required]=\"input.required\">\r\n                            <mat-option *ngFor='let data of dataCombo[input.identifierCombo]'\r\n                                [value]='data[input.paramsCombo.selectionField]'>\r\n                                {{data[input.paramsCombo.visibleField]}}</mat-option>\r\n                        </mat-select>\r\n\r\n                    </div>\r\n\r\n                    <ng-template #otherInput>\r\n                        <input [type]='input.type' [name]='input.ID' (input)='onChange(input.ID, $event, input.type)'\r\n                            matInput [placeholder]='input.label' [required]=\"input.required\"  />\r\n\r\n                    </ng-template>\r\n                    <mat-error>Campo Obligatorio</mat-error>\r\n                  </mat-form-field>\r\n                </ng-template>\r\n\r\n\r\n\r\n\r\n        </div>\r\n\r\n        <button *ngIf='data.action==\"add\" || data.action==\"edit\"'\r\n            (click)='onSubmit()'\r\n            color='primary'\r\n            mat-raised-button\r\n            [disabled]=\"!modalForm.valid\">Guardar</button>\r\n\r\n    </form>\r\n</div>\r\n\r\n"]}
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-modal.component.js","sourceRoot":"","sources":["../../../../../../../../../src/app/modules/brainloper-ui/components/data-table/table-modal/table-modal.component.ts","../../../../../../../../../src/app/modules/brainloper-ui/components/data-table/table-modal/table-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Inject } from '@angular/core';\r\nimport { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\r\nimport { FormBuilder, FormGroup, FormControl, Validators } from '@angular/forms';\r\nimport { HttpService } from '../../../../services/http.service';\r\nimport { forkJoin } from 'rxjs';\r\nimport { map } from 'rxjs/operators';\r\n\r\n@Component({\r\n  selector: 'app-table-modal',\r\n  templateUrl: './table-modal.component.html',\r\n  styleUrls: ['./table-modal.component.scss'],\r\n})\r\nexport class TableModalComponent implements OnInit {\r\n  modalForm: FormGroup = new FormGroup({});\r\n  dataCombo = {};\r\n\r\n\r\n  constructor(\r\n    public dialogRef: MatDialogRef<TableModalComponent>,\r\n    @Inject(MAT_DIALOG_DATA) public data,\r\n    private formBuilder: FormBuilder,\r\n    private http: HttpService\r\n  ) {}\r\n\r\n  onNoClick(): void {\r\n    this.dialogRef.close();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    let group = {};\r\n    let httpRequests = [];\r\n\r\n    // Usamos map en lugar de forEach para evitar efectos secundarios\r\n    this.data.columns.map((element) => {\r\n      if (!element.disregardForAdd) {\r\n        if (element.type === 'combo') {\r\n          this.dataCombo[element.paramsCombo.selectionField !== element.ID ? element.paramsCombo.selectionField : element.ID] = '';\r\n        }\r\n\r\n        let initialValue = this.data.action === 'edit' ? element.value : '';\r\n        if (element.type === 'date' && element.value) {\r\n          let s = element.value.split('/');\r\n          initialValue = `${s[2]}-${s[1]}-${s[0]}`;\r\n        }\r\n\r\n        group[element.ID] = element.required ? new FormControl(initialValue, Validators.required) : new FormControl(initialValue);\r\n\r\n        if (element.paramsCombo) {\r\n          httpRequests.push(this.createHttpRequest(element, group));\r\n        }\r\n      }\r\n    });\r\n\r\n    if (httpRequests.length > 0) {\r\n      forkJoin(httpRequests).subscribe(() => {\r\n        this.modalForm = new FormGroup(group);\r\n      });\r\n    } else {\r\n      this.modalForm = new FormGroup(group);\r\n    }\r\n  }\r\n\r\n  // Extraemos la creación de la solicitud HTTP a su propia función para mejorar la legibilidad\r\n  createHttpRequest(element, group) {\r\n    return this.http\r\n      .getData(element.paramsCombo.url, element.paramsCombo.urlParams)\r\n      .pipe(\r\n        map((res) => {\r\n          if (res['code'] === 0) {\r\n            element.identifierCombo = element.paramsCombo.selectionField !== element.ID ? element.paramsCombo.selectionField : element.ID;\r\n            this.dataCombo[element.identifierCombo] = res['body'];\r\n\r\n            if (this.data.action !== 'edit') {\r\n              return;\r\n            }\r\n\r\n            this.dataCombo[element.identifierCombo].some((data) => {\r\n              if (\r\n                data[element.paramsCombo.selectionField] === element.value ||\r\n                data[element.paramsCombo.visibleField] === element.value\r\n              ) {\r\n                var value = data[element.paramsCombo.selectionField]\r\n                element.value = value\r\n                group[element.ID].setValue(value);\r\n                return true;\r\n              }\r\n              return false;\r\n            });\r\n\r\n          }\r\n        })\r\n      );\r\n  }\r\n\r\n\r\n  onSubmit() {\r\n    if (this.modalForm.valid) {\r\n\r\n      this.data.columns.map((element) => {\r\n        if (element.paramsCombo && element.paramsCombo.returnDataSelect) {\r\n          element.identifierCombo = element.paramsCombo.selectionField !== element.ID ? element.paramsCombo.selectionField : element.ID;\r\n          let x = this.dataCombo[element.identifierCombo].find(x => x[element.identifierCombo] == this.modalForm.value[element.ID])\r\n          if(x){\r\n            this.modalForm.addControl(element.ID + 'Combo', new FormControl(x));\r\n          }\r\n        }\r\n    });\r\n      this.dialogRef.close(this.modalForm.value);\r\n    }\r\n  }\r\n\r\n  onChange(id: any, $event, type: string) {\r\n    switch (type) {\r\n      case 'combo':\r\n        this.modalForm.get(id).setValue($event.value);\r\n        break;\r\n\r\n      default:\r\n        this.modalForm.get(id).setValue($event.target.value);\r\n        break;\r\n    }\r\n  }\r\n}\r\n","<div>\r\n    <div style='display:flex; justify-content: space-between;'>\r\n        <div>\r\n            <strong>\r\n                <h3 *ngIf='data.action==\"edit\"'> Editar </h3>\r\n                <h3 *ngIf='data.action==\"add\"'> Agregar </h3>\r\n            </strong>\r\n        </div>\r\n        <div mat-dialog-close>\r\n            <i class=\"fa fa-times-circle\" style=\"font-size: 150%; position: relative;\"></i>\r\n        </div>\r\n    </div>\r\n\r\n    <form [formGroup]=\"modalForm\">\r\n\r\n        <div *ngFor='let input of data.columns'>\r\n\r\n\r\n\r\n                <div *ngIf='data.action==\"edit\"; else Agregar'>\r\n                  <mat-form-field *ngIf=\"!input.disregardForEdit\">\r\n                    <div *ngIf='input.type==\"combo\"; else otherInputEdit'>\r\n\r\n                        <mat-select [value]=\"input.value\" (selectionChange)='onChange(input.ID,$event, input.type)'\r\n                            placeholder='{{input.label}}' [required]=\"input.required\">\r\n                            <mat-option *ngFor='let data of dataCombo[input.identifierCombo]'\r\n                                [value]='data[input.paramsCombo.selectionField]'>\r\n                                {{data[input.paramsCombo.visibleField]}}</mat-option>\r\n                        </mat-select>\r\n                    </div>\r\n\r\n                    <ng-template #otherInputEdit>\r\n                        <input [type]='input.type' [name]='input.ID' [value]='input.value'\r\n                            (input)='onChange(input.ID,$event, input.type)' matInput [placeholder]='input.label' [required]=\"input.required\" />\r\n                    </ng-template>\r\n\r\n                    <mat-error>Campo Obligatorio</mat-error>\r\n                  </mat-form-field>\r\n\r\n                </div>\r\n\r\n                <ng-template #Agregar>\r\n                  <mat-form-field *ngIf=\"!input.disregardForAdd\">\r\n                    <div *ngIf='input.type==\"combo\"; else otherInput'>\r\n\r\n                        <mat-select (selectionChange)='onChange(input.ID,$event, input.type)' placeholder='{{input.label}}' [required]=\"input.required\">\r\n                            <mat-option *ngFor='let data of dataCombo[input.identifierCombo]'\r\n                                [value]='data[input.paramsCombo.selectionField]'>\r\n                                {{data[input.paramsCombo.visibleField]}}</mat-option>\r\n                        </mat-select>\r\n\r\n                    </div>\r\n\r\n                    <ng-template #otherInput>\r\n                        <input [type]='input.type' [name]='input.ID' (input)='onChange(input.ID, $event, input.type)'\r\n                            matInput [placeholder]='input.label' [required]=\"input.required\"  />\r\n\r\n                    </ng-template>\r\n                    <mat-error>Campo Obligatorio</mat-error>\r\n                  </mat-form-field>\r\n                </ng-template>\r\n\r\n\r\n\r\n\r\n        </div>\r\n\r\n        <button *ngIf='data.action==\"add\" || data.action==\"edit\"'\r\n            (click)='onSubmit()'\r\n            color='primary'\r\n            mat-raised-button\r\n            [disabled]=\"!modalForm.valid\">Guardar</button>\r\n\r\n    </form>\r\n</div>\r\n\r\n"]}
|
|
@@ -510,9 +510,9 @@ class TableModalComponent {
|
|
|
510
510
|
this.data.columns.map((element) => {
|
|
511
511
|
if (element.paramsCombo && element.paramsCombo.returnDataSelect) {
|
|
512
512
|
element.identifierCombo = element.paramsCombo.selectionField !== element.ID ? element.paramsCombo.selectionField : element.ID;
|
|
513
|
-
let x = this.dataCombo[element.identifierCombo].find(x => x[element.identifierCombo] == this.modalForm.value[element.
|
|
513
|
+
let x = this.dataCombo[element.identifierCombo].find(x => x[element.identifierCombo] == this.modalForm.value[element.ID]);
|
|
514
514
|
if (x) {
|
|
515
|
-
this.modalForm.addControl(element.
|
|
515
|
+
this.modalForm.addControl(element.ID + 'Combo', new FormControl(x));
|
|
516
516
|
}
|
|
517
517
|
}
|
|
518
518
|
});
|