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.
- package/esm2020/src/app/modules/brainloper-ui/components/data-table/table-modal/table-modal.component.mjs +19 -9
- package/fesm2015/brainloper-ui.mjs +18 -8
- package/fesm2015/brainloper-ui.mjs.map +1 -1
- package/fesm2020/brainloper-ui.mjs +18 -8
- package/fesm2020/brainloper-ui.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -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
|
|
62
|
-
|
|
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
|
|
489
|
-
|
|
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
|
}
|