brainloper-ui 1.0.16 → 1.0.17

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.
@@ -45,9 +45,13 @@ export class TableModalComponent {
45
45
  }
46
46
  }
47
47
  });
48
- this.modalForm = new FormGroup(group);
49
48
  if (httpRequests.length > 0) {
50
- forkJoin(httpRequests).subscribe();
49
+ forkJoin(httpRequests).subscribe(() => {
50
+ this.modalForm = new FormGroup(group);
51
+ });
52
+ }
53
+ else {
54
+ this.modalForm = new FormGroup(group);
51
55
  }
52
56
  }
53
57
  // Extraemos la creación de la solicitud HTTP a su propia función para mejorar la legibilidad
@@ -58,13 +62,19 @@ export class TableModalComponent {
58
62
  if (res['code'] === 0) {
59
63
  element.identifierCombo = element.paramsCombo.selectionField !== element.ID ? element.paramsCombo.selectionField : element.ID;
60
64
  this.dataCombo[element.identifierCombo] = res['body'];
61
- if (this.data.action === 'edit') {
62
- this.dataCombo[element.identifierCombo].forEach((data) => {
63
- if (data[element.paramsCombo.selectionField] === element.value) {
64
- group[element.ID].setValue(data[element.paramsCombo.selectionField]);
65
- }
66
- });
65
+ if (this.data.action !== 'edit') {
66
+ return;
67
67
  }
68
+ this.dataCombo[element.identifierCombo].some((data) => {
69
+ if (data[element.paramsCombo.selectionField] === element.value ||
70
+ data[element.paramsCombo.visibleField] === element.value) {
71
+ var value = data[element.paramsCombo.selectionField];
72
+ element.value = value;
73
+ group[element.ID].setValue(value);
74
+ return true;
75
+ }
76
+ return false;
77
+ });
68
78
  }
69
79
  }));
70
80
  }
@@ -93,4 +103,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
93
103
  type: Inject,
94
104
  args: [MAT_DIALOG_DATA]
95
105
  }] }, { type: i2.FormBuilder }, { type: i3.HttpService }]; } });
96
- //# 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.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    this.modalForm = new FormGroup(group);\r\n    if (httpRequests.length > 0) {\r\n      forkJoin(httpRequests).subscribe();\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              this.dataCombo[element.identifierCombo].forEach((data) => {\r\n                if (data[element.paramsCombo.selectionField] === element.value) {\r\n                  group[element.ID].setValue(data[element.paramsCombo.selectionField]);\r\n                }\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      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.ID]'\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"]}
106
+ //# 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.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      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.ID]'\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"]}
@@ -472,9 +472,13 @@ class TableModalComponent {
472
472
  }
473
473
  }
474
474
  });
475
- this.modalForm = new FormGroup(group);
476
475
  if (httpRequests.length > 0) {
477
- forkJoin(httpRequests).subscribe();
476
+ forkJoin(httpRequests).subscribe(() => {
477
+ this.modalForm = new FormGroup(group);
478
+ });
479
+ }
480
+ else {
481
+ this.modalForm = new FormGroup(group);
478
482
  }
479
483
  }
480
484
  // Extraemos la creación de la solicitud HTTP a su propia función para mejorar la legibilidad
@@ -485,13 +489,19 @@ class TableModalComponent {
485
489
  if (res['code'] === 0) {
486
490
  element.identifierCombo = element.paramsCombo.selectionField !== element.ID ? element.paramsCombo.selectionField : element.ID;
487
491
  this.dataCombo[element.identifierCombo] = res['body'];
488
- if (this.data.action === 'edit') {
489
- this.dataCombo[element.identifierCombo].forEach((data) => {
490
- if (data[element.paramsCombo.selectionField] === element.value) {
491
- group[element.ID].setValue(data[element.paramsCombo.selectionField]);
492
- }
493
- });
492
+ if (this.data.action !== 'edit') {
493
+ return;
494
494
  }
495
+ this.dataCombo[element.identifierCombo].some((data) => {
496
+ if (data[element.paramsCombo.selectionField] === element.value ||
497
+ data[element.paramsCombo.visibleField] === element.value) {
498
+ var value = data[element.paramsCombo.selectionField];
499
+ element.value = value;
500
+ group[element.ID].setValue(value);
501
+ return true;
502
+ }
503
+ return false;
504
+ });
495
505
  }
496
506
  }));
497
507
  }