sf-crud 12.0.1-beta3 → 12.0.1-beta30
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/bundles/sf-crud.umd.js +625 -87
- package/bundles/sf-crud.umd.js.map +1 -1
- package/esm2015/lib/components/control/control.component.js +74 -9
- package/esm2015/lib/components/registro/registro.component.js +179 -25
- package/esm2015/lib/components/registro-child/registro-child.component.js +196 -0
- package/esm2015/lib/components/tablero/tablero.component.js +60 -18
- package/esm2015/lib/sf-crud.module.js +32 -12
- package/esm2015/lib/sf-crud.service.js +16 -2
- package/esm2015/lib/shared/models/crud-config.model.js +43 -0
- package/esm2015/lib/shared/models/data-temp-crud.model.js +6 -0
- package/esm2015/lib/shared/models/shema.model.js +7 -0
- package/esm2015/lib/shared/services/general.service.js +1 -1
- package/esm2015/public-api.js +2 -1
- package/fesm2015/sf-crud.js +534 -62
- package/fesm2015/sf-crud.js.map +1 -1
- package/lib/components/control/control.component.d.ts +11 -2
- package/lib/components/registro/registro.component.d.ts +30 -9
- package/lib/components/registro-child/registro-child.component.d.ts +35 -0
- package/lib/components/tablero/tablero.component.d.ts +15 -4
- package/lib/sf-crud.module.d.ts +77 -73
- package/lib/sf-crud.service.d.ts +4 -0
- package/lib/shared/{services/models → models}/crud-config.model.d.ts +7 -1
- package/lib/shared/models/data-temp-crud.model.d.ts +4 -0
- package/lib/shared/{services/models → models}/shema.model.d.ts +1 -0
- package/lib/shared/services/general.service.d.ts +1 -1
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/esm2015/lib/shared/services/models/crud-config.model.js +0 -43
- package/esm2015/lib/shared/services/models/shema.model.js +0 -7
|
@@ -0,0 +1,196 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import { Shema } from '../../shared/models/shema.model';
|
|
3
|
+
import * as jsonpath from 'jsonpath';
|
|
4
|
+
import { MessageService } from 'primeng/api';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "primeng/dynamicdialog";
|
|
7
|
+
import * as i2 from "primeng/api";
|
|
8
|
+
import * as i3 from "primeng/toast";
|
|
9
|
+
import * as i4 from "../control/control.component";
|
|
10
|
+
import * as i5 from "@angular/common";
|
|
11
|
+
import * as i6 from "primeng/button";
|
|
12
|
+
import * as i7 from "primeng/ripple";
|
|
13
|
+
export class RegistroChildComponent {
|
|
14
|
+
constructor(ref, config, messageService) {
|
|
15
|
+
this.ref = ref;
|
|
16
|
+
this.config = config;
|
|
17
|
+
this.messageService = messageService;
|
|
18
|
+
this.esquema = new Shema();
|
|
19
|
+
}
|
|
20
|
+
ngOnInit() {
|
|
21
|
+
var _a;
|
|
22
|
+
this.uiEsquema = this.config.data.uiEsquema[0];
|
|
23
|
+
this.esquema = this.config.data.esquema;
|
|
24
|
+
this.data = (_a = this.config.data) === null || _a === void 0 ? void 0 : _a.data;
|
|
25
|
+
if (!this.data) {
|
|
26
|
+
this.data = this.createObject(this.esquema);
|
|
27
|
+
jsonpath.value(this.data, '$..id', this.config.data.id);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
getControl(scope) {
|
|
31
|
+
return jsonpath.query(this.esquema, scope)[0];
|
|
32
|
+
}
|
|
33
|
+
getValue(scope) {
|
|
34
|
+
return jsonpath.query(this.data, scope.replace('.properties', ''))[0];
|
|
35
|
+
}
|
|
36
|
+
setValue(value, scope) {
|
|
37
|
+
switch (typeof (value)) {
|
|
38
|
+
case 'object':
|
|
39
|
+
if (Array.isArray(value))
|
|
40
|
+
value.forEach((val) => jsonpath.value(this.data, val.scope.replace('.properties', ''), val.value));
|
|
41
|
+
else
|
|
42
|
+
jsonpath.value(this.data, scope.replace('.properties', ''), value);
|
|
43
|
+
break;
|
|
44
|
+
default:
|
|
45
|
+
jsonpath.value(this.data, scope.replace('.properties', ''), value);
|
|
46
|
+
break;
|
|
47
|
+
}
|
|
48
|
+
this.applyValuesOnEvent('onChange', this.esquema, scope.replace('$..properties.', ''));
|
|
49
|
+
}
|
|
50
|
+
createObject(esquema) {
|
|
51
|
+
let object = {};
|
|
52
|
+
switch (esquema.type) {
|
|
53
|
+
case 'numeric':
|
|
54
|
+
return (esquema === null || esquema === void 0 ? void 0 : esquema.default) || 0;
|
|
55
|
+
case 'string':
|
|
56
|
+
case 'date':
|
|
57
|
+
return (esquema === null || esquema === void 0 ? void 0 : esquema.default) ? this.setDefaultValue(esquema.default) : null;
|
|
58
|
+
case 'boolean':
|
|
59
|
+
return (esquema === null || esquema === void 0 ? void 0 : esquema.default) || false;
|
|
60
|
+
case 'file':
|
|
61
|
+
return null;
|
|
62
|
+
case 'array':
|
|
63
|
+
case 'object':
|
|
64
|
+
for (const key in esquema === null || esquema === void 0 ? void 0 : esquema.properties) {
|
|
65
|
+
Object.defineProperty(object, key, { value: this.createObject(esquema === null || esquema === void 0 ? void 0 : esquema.properties[key]), writable: true, enumerable: true, configurable: true });
|
|
66
|
+
}
|
|
67
|
+
break;
|
|
68
|
+
default:
|
|
69
|
+
break;
|
|
70
|
+
}
|
|
71
|
+
return object;
|
|
72
|
+
}
|
|
73
|
+
setDefaultValue(value) {
|
|
74
|
+
let data = null;
|
|
75
|
+
let uactivo;
|
|
76
|
+
switch (value) {
|
|
77
|
+
case '@uactivo':
|
|
78
|
+
uactivo = JSON.parse(localStorage.getItem('oSessionTFM') || '{}');
|
|
79
|
+
if (!uactivo)
|
|
80
|
+
console.log('Validar configuracion de sesion');
|
|
81
|
+
else
|
|
82
|
+
data = `${uactivo.UsuarioSistema.TDOC}-${uactivo.UsuarioSistema.NDOC}`;
|
|
83
|
+
break;
|
|
84
|
+
case '@tdocactivo':
|
|
85
|
+
uactivo = JSON.parse(sessionStorage.getItem('usrSesion') || '{}');
|
|
86
|
+
if (!uactivo)
|
|
87
|
+
console.log('Validar configuracion de sesion');
|
|
88
|
+
else
|
|
89
|
+
data = uactivo.UsuarioSistema.TDOC;
|
|
90
|
+
break;
|
|
91
|
+
case '@ndocactivo':
|
|
92
|
+
uactivo = JSON.parse(sessionStorage.getItem('usrSesion') || '{}');
|
|
93
|
+
if (!uactivo)
|
|
94
|
+
console.log('Validar configuracion de sesion');
|
|
95
|
+
else
|
|
96
|
+
data = uactivo.UsuarioSistema.NDOC;
|
|
97
|
+
break;
|
|
98
|
+
case '@hoy':
|
|
99
|
+
data = new Date();
|
|
100
|
+
break;
|
|
101
|
+
default:
|
|
102
|
+
data = value;
|
|
103
|
+
break;
|
|
104
|
+
}
|
|
105
|
+
return data;
|
|
106
|
+
}
|
|
107
|
+
submit() {
|
|
108
|
+
this.applyValuesOnEvent('onSubmit', this.esquema);
|
|
109
|
+
if (!this.validateData())
|
|
110
|
+
return;
|
|
111
|
+
this.ref.close(this.data);
|
|
112
|
+
}
|
|
113
|
+
cancel() {
|
|
114
|
+
this.applyValuesOnEvent('onCancel', this.esquema);
|
|
115
|
+
this.ref.close();
|
|
116
|
+
}
|
|
117
|
+
validateData() {
|
|
118
|
+
if (this.esquema.validations.type == 'local')
|
|
119
|
+
return this.validateDataLocal();
|
|
120
|
+
return true;
|
|
121
|
+
}
|
|
122
|
+
validateDataLocal() {
|
|
123
|
+
let err = [];
|
|
124
|
+
this.esquema.validations.required.forEach((x) => {
|
|
125
|
+
if (!jsonpath.query(this.data, x.field)[0])
|
|
126
|
+
err.push(x.message);
|
|
127
|
+
});
|
|
128
|
+
if (err.length != 0)
|
|
129
|
+
this.messageService.add({ severity: 'warn', detail: err.join('. ') });
|
|
130
|
+
return err.length == 0;
|
|
131
|
+
}
|
|
132
|
+
applyValuesOnEvent(event, esquema, scope) {
|
|
133
|
+
if (scope) {
|
|
134
|
+
if (esquema.properties[scope][event]) {
|
|
135
|
+
esquema.properties[scope][event].forEach((value) => {
|
|
136
|
+
this.setValueEvent(this.data, value);
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
else {
|
|
141
|
+
for (const key in esquema.properties) {
|
|
142
|
+
if (esquema.properties[key][event]) {
|
|
143
|
+
esquema.properties[key][event].forEach((value) => {
|
|
144
|
+
this.setValueEvent(this.data, value);
|
|
145
|
+
});
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
setValueEvent(data, params) {
|
|
151
|
+
var _a;
|
|
152
|
+
let value;
|
|
153
|
+
switch (params.op) {
|
|
154
|
+
case 'sum':
|
|
155
|
+
value = jsonpath.query(data, params === null || params === void 0 ? void 0 : params.scope[0]).reduce((acc, cur) => acc += (params === null || params === void 0 ? void 0 : params.key) ? cur[params.key] : cur, 0);
|
|
156
|
+
break;
|
|
157
|
+
case 'concat':
|
|
158
|
+
let array = [];
|
|
159
|
+
(_a = params === null || params === void 0 ? void 0 : params.key) === null || _a === void 0 ? void 0 : _a.reduce((acc, cur) => {
|
|
160
|
+
array.push(jsonpath.query(data, cur)[0]);
|
|
161
|
+
}, []);
|
|
162
|
+
if (params === null || params === void 0 ? void 0 : params.separator)
|
|
163
|
+
jsonpath.value(data, params.scope[0], array.join((params === null || params === void 0 ? void 0 : params.separator) || ' '));
|
|
164
|
+
break;
|
|
165
|
+
case 'enable':
|
|
166
|
+
jsonpath.value(this.esquema, params.scope[0], false);
|
|
167
|
+
break;
|
|
168
|
+
case 'disabled':
|
|
169
|
+
jsonpath.value(this.esquema, params.scope[0], true);
|
|
170
|
+
break;
|
|
171
|
+
case 'replace:endpoint':
|
|
172
|
+
jsonpath.value(this.esquema, params.scope[0], jsonpath.query(this.esquema, params.scope[1])[0].replace(params.scope[2], jsonpath.query(data, `$..${params.key}`)));
|
|
173
|
+
break;
|
|
174
|
+
case 'setNull':
|
|
175
|
+
jsonpath.value(this.data, `$.${params.key}`, null);
|
|
176
|
+
break;
|
|
177
|
+
default:
|
|
178
|
+
break;
|
|
179
|
+
}
|
|
180
|
+
return value;
|
|
181
|
+
}
|
|
182
|
+
sendNotification(message) {
|
|
183
|
+
this.messageService.add(message);
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
RegistroChildComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: RegistroChildComponent, deps: [{ token: i1.DynamicDialogRef }, { token: i1.DynamicDialogConfig }, { token: i2.MessageService }], target: i0.ɵɵFactoryTarget.Component });
|
|
187
|
+
RegistroChildComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: RegistroChildComponent, selector: "lib-registro-child", providers: [MessageService], ngImport: i0, template: "<p-toast></p-toast>\n<div *ngFor=\"let element of uiEsquema.elements\" [class]=\"element?.class\" #a>\n <ng-container [ngSwitch]=\"element.type\">\n <div *ngSwitchCase=\"'Label'\" [style]=\"element?.style\">\n {{element?.label}}\n </div>\n <ng-container *ngSwitchCase=\"'HorizontalLayout'\">\n <div *ngFor=\"let el of element.elements\" [class]=\"el?.class\">\n <ng-container [ngSwitch]=\"el.type\">\n <sf-control *ngSwitchCase=\"'Control'\" [control]=\"getControl(el.scope)\" [label]=\"el.label\"\n [value]=\"getValue(el.scope)\" (setValue)=\"setValue($event, el.scope)\"\n (sendNotification)=\"sendNotification($event)\"></sf-control>\n </ng-container>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'VerticalLayout'\">\n <div *ngFor=\"let el of element.elements\" [class]=\"el?.class\">\n <ng-container [ngSwitch]=\"el.type\">\n <sf-control *ngSwitchCase=\"'Control'\" [control]=\"getControl(el.scope)\" [label]=\"el.label\"\n [value]=\"getValue(el.scope)\" (setValue)=\"setValue($event, el.scope)\"\n (sendNotification)=\"sendNotification($event)\"></sf-control>\n </ng-container>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'Control'\">\n <sf-control [control]=\"getControl(element.scope)\" [label]=\"element.label\"></sf-control>\n </ng-container>\n </ng-container>\n</div>\n<div class=\"card-footer mt-2\">\n <button pButton pRipple type=\"button\" label=\"Guardar\" (click)=\"submit()\" class=\"mr-2\"></button>\n <button pButton pRipple type=\"button\" label=\"Cancelar\" (click)=\"cancel()\" class=\"p-button-danger\"></button>\n</div>", components: [{ type: i3.Toast, selector: "p-toast", inputs: ["key", "autoZIndex", "baseZIndex", "style", "styleClass", "position", "preventOpenDuplicates", "preventDuplicates", "showTransformOptions", "hideTransformOptions", "showTransitionOptions", "hideTransitionOptions", "breakpoints"], outputs: ["onClose"] }, { type: i4.ControlComponent, selector: "sf-control", inputs: ["control", "label", "value", "appendTo"], outputs: ["setValue", "sendNotification"] }], directives: [{ type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i5.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i5.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i6.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { type: i7.Ripple, selector: "[pRipple]" }] });
|
|
188
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: RegistroChildComponent, decorators: [{
|
|
189
|
+
type: Component,
|
|
190
|
+
args: [{
|
|
191
|
+
selector: 'lib-registro-child',
|
|
192
|
+
templateUrl: './registro-child.component.html',
|
|
193
|
+
providers: [MessageService]
|
|
194
|
+
}]
|
|
195
|
+
}], ctorParameters: function () { return [{ type: i1.DynamicDialogRef }, { type: i1.DynamicDialogConfig }, { type: i2.MessageService }]; } });
|
|
196
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"registro-child.component.js","sourceRoot":"","sources":["../../../../../../projects/sf-crud/src/lib/components/registro-child/registro-child.component.ts","../../../../../../projects/sf-crud/src/lib/components/registro-child/registro-child.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit } from '@angular/core';\nimport { DynamicDialogConfig, DynamicDialogRef } from 'primeng/dynamicdialog';\nimport { Shema } from '../../shared/models/shema.model';\nimport * as jsonpath from 'jsonpath';\nimport { MessageService } from 'primeng/api';\nimport { Message } from '@angular/compiler/src/i18n/i18n_ast';\n\n@Component({\n  selector: 'lib-registro-child',\n  templateUrl: './registro-child.component.html',\n  providers: [MessageService]\n})\nexport class RegistroChildComponent implements OnInit {\n\n  public uiEsquema: any;\n  public esquema: Shema = new Shema();\n  public data: any;\n\n  constructor(\n    public ref: DynamicDialogRef,\n    public config: DynamicDialogConfig,\n    private messageService: MessageService\n  ) { }\n\n  ngOnInit(): void {\n    this.uiEsquema = this.config.data.uiEsquema[0];\n    this.esquema = this.config.data.esquema;\n    this.data = this.config.data?.data;\n    if (!this.data) {\n      this.data = this.createObject(this.esquema);\n      jsonpath.value(this.data, '$..id', this.config.data.id);\n    }\n  }\n\n  getControl(scope: string) {\n    return jsonpath.query(this.esquema, scope)[0];\n  }\n\n  getValue(scope: string) {\n    return jsonpath.query(this.data, scope.replace('.properties', ''))[0];\n  }\n\n  setValue(value: any, scope: string) {\n    switch (typeof (value)) {\n      case 'object':\n        if (Array.isArray(value)) value.forEach((val: any) => jsonpath.value(this.data, val.scope.replace('.properties', ''), val.value))\n        else jsonpath.value(this.data, scope.replace('.properties', ''), value);\n        break;\n      default:\n        jsonpath.value(this.data, scope.replace('.properties', ''), value);\n        break;\n    }\n    this.applyValuesOnEvent('onChange', this.esquema, scope.replace('$..properties.', ''));\n  }\n\n  createObject(esquema: Shema) {\n    let object = {};\n    switch (esquema.type) {\n      case 'numeric':\n        return esquema?.default || 0;\n      case 'string':\n      case 'date':\n        return esquema?.default ? this.setDefaultValue(esquema.default) : null;\n      case 'boolean':\n        return esquema?.default || false;\n      case 'file':\n        return null;\n      case 'array':\n      case 'object':\n        for (const key in esquema?.properties) {\n          Object.defineProperty(object, key, { value: this.createObject(esquema?.properties[key]), writable: true, enumerable: true, configurable: true })\n        }\n        break;\n      default:\n        break;\n    }\n    return object;\n  }\n\n  setDefaultValue(value: string) {\n    let data = null;\n    let uactivo;\n    switch (value) {\n      case '@uactivo':\n        uactivo = JSON.parse(localStorage.getItem('oSessionTFM') || '{}')\n        if (!uactivo) console.log('Validar configuracion de sesion')\n        else data = `${uactivo.UsuarioSistema.TDOC}-${uactivo.UsuarioSistema.NDOC}`\n        break;\n      case '@tdocactivo':\n        uactivo = JSON.parse(sessionStorage.getItem('usrSesion') || '{}')\n        if (!uactivo) console.log('Validar configuracion de sesion')\n        else data = uactivo.UsuarioSistema.TDOC\n        break;\n      case '@ndocactivo':\n        uactivo = JSON.parse(sessionStorage.getItem('usrSesion') || '{}')\n        if (!uactivo) console.log('Validar configuracion de sesion')\n        else data = uactivo.UsuarioSistema.NDOC\n        break;\n      case '@hoy':\n        data = new Date();\n        break;\n      default:\n        data = value;\n        break;\n    }\n    return data\n  }\n\n  submit() {\n    this.applyValuesOnEvent('onSubmit', this.esquema);\n    if (!this.validateData()) return;\n    this.ref.close(this.data);\n  }\n\n  cancel() {\n    this.applyValuesOnEvent('onCancel', this.esquema);\n    this.ref.close();\n  }\n\n  validateData() {\n    if (this.esquema.validations.type == 'local') return this.validateDataLocal();\n    return true;\n  }\n\n  validateDataLocal() {\n    let err: string[] = []\n    this.esquema.validations.required.forEach((x: any) => {\n      if (!jsonpath.query(this.data, x.field)[0]) err.push(x.message);\n    })\n    if (err.length != 0) this.messageService.add({ severity: 'warn', detail: err.join('. ') })\n    return err.length == 0;\n  }\n\n  applyValuesOnEvent(event: string, esquema: Shema, scope?: string) {\n    if (scope) {\n      if (esquema.properties[scope][event]) {\n        esquema.properties[scope][event].forEach((value: any) => {\n          this.setValueEvent(this.data, value)\n        })\n      }\n    } else {\n      for (const key in esquema.properties) {\n        if (esquema.properties[key][event]) {\n          esquema.properties[key][event].forEach((value: any) => {\n            this.setValueEvent(this.data, value)\n          })\n        }\n      }\n    }\n  }\n\n  setValueEvent(data: any, params: { op: string, scope: string[], key: any, separator: string }) {\n    let value;\n    switch (params.op) {\n      case 'sum':\n        value = jsonpath.query(data, params?.scope[0]).reduce((acc, cur) => acc += params?.key ? cur[params.key] : cur, 0)\n        break;\n      case 'concat':\n        let array: string[] = []\n        params?.key?.reduce((acc: any[], cur: string) => {\n          array.push(jsonpath.query(data, cur)[0])\n        }, [])\n        if (params?.separator) jsonpath.value(data, params.scope[0], array.join(params?.separator || ' '))\n        break;\n      case 'enable':\n        jsonpath.value(this.esquema, params.scope[0], false)\n        break;\n      case 'disabled':\n        jsonpath.value(this.esquema, params.scope[0], true)\n        break;\n      case 'replace:endpoint':\n        jsonpath.value(this.esquema, params.scope[0], jsonpath.query(this.esquema, params.scope[1])[0].replace(params.scope[2], jsonpath.query(data, `$..${params.key}`)))\n        break;\n      case 'setNull':\n        jsonpath.value(this.data, `$.${params.key}`, null);\n        break;\n      default:\n        break;\n    }\n    return value;\n  }\n\n  sendNotification(message: Message) {\n    this.messageService.add(message)\n  }\n}\n","<p-toast></p-toast>\n<div *ngFor=\"let element of uiEsquema.elements\" [class]=\"element?.class\" #a>\n    <ng-container [ngSwitch]=\"element.type\">\n        <div *ngSwitchCase=\"'Label'\" [style]=\"element?.style\">\n            {{element?.label}}\n        </div>\n        <ng-container *ngSwitchCase=\"'HorizontalLayout'\">\n            <div *ngFor=\"let el of element.elements\" [class]=\"el?.class\">\n                <ng-container [ngSwitch]=\"el.type\">\n                    <sf-control *ngSwitchCase=\"'Control'\" [control]=\"getControl(el.scope)\" [label]=\"el.label\"\n                        [value]=\"getValue(el.scope)\" (setValue)=\"setValue($event, el.scope)\"\n                        (sendNotification)=\"sendNotification($event)\"></sf-control>\n                </ng-container>\n            </div>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'VerticalLayout'\">\n            <div *ngFor=\"let el of element.elements\" [class]=\"el?.class\">\n                <ng-container [ngSwitch]=\"el.type\">\n                    <sf-control *ngSwitchCase=\"'Control'\" [control]=\"getControl(el.scope)\" [label]=\"el.label\"\n                        [value]=\"getValue(el.scope)\" (setValue)=\"setValue($event, el.scope)\"\n                        (sendNotification)=\"sendNotification($event)\"></sf-control>\n                </ng-container>\n            </div>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'Control'\">\n            <sf-control [control]=\"getControl(element.scope)\" [label]=\"element.label\"></sf-control>\n        </ng-container>\n    </ng-container>\n</div>\n<div class=\"card-footer mt-2\">\n    <button pButton pRipple type=\"button\" label=\"Guardar\" (click)=\"submit()\" class=\"mr-2\"></button>\n    <button pButton pRipple type=\"button\" label=\"Cancelar\" (click)=\"cancel()\" class=\"p-button-danger\"></button>\n</div>"]}
|
|
@@ -1,17 +1,19 @@
|
|
|
1
|
-
import { Component, Input } from '@angular/core';
|
|
2
|
-
import { CrudConfig } from '../../shared/
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { CrudConfig } from '../../shared/models/crud-config.model';
|
|
3
|
+
import * as _ from "lodash";
|
|
4
|
+
import * as jsonpath from 'jsonpath';
|
|
3
5
|
import * as i0 from "@angular/core";
|
|
4
6
|
import * as i1 from "../../shared/services/general.service";
|
|
5
7
|
import * as i2 from "@angular/router";
|
|
6
8
|
import * as i3 from "primeng/blockui";
|
|
7
9
|
import * as i4 from "primeng/toolbar";
|
|
8
10
|
import * as i5 from "primeng/table";
|
|
9
|
-
import * as i6 from "
|
|
10
|
-
import * as i7 from "
|
|
11
|
-
import * as i8 from "primeng/
|
|
12
|
-
import * as i9 from "primeng/
|
|
13
|
-
import * as i10 from "primeng/
|
|
14
|
-
import * as i11 from "primeng/
|
|
11
|
+
import * as i6 from "primeng/splitbutton";
|
|
12
|
+
import * as i7 from "@angular/common";
|
|
13
|
+
import * as i8 from "primeng/api";
|
|
14
|
+
import * as i9 from "primeng/button";
|
|
15
|
+
import * as i10 from "primeng/ripple";
|
|
16
|
+
import * as i11 from "primeng/inputtext";
|
|
15
17
|
export class TableroComponent {
|
|
16
18
|
constructor(generalService, router) {
|
|
17
19
|
this.generalService = generalService;
|
|
@@ -19,6 +21,8 @@ export class TableroComponent {
|
|
|
19
21
|
this.opciones = [];
|
|
20
22
|
this.idEntidad = '';
|
|
21
23
|
this.idKatios = '';
|
|
24
|
+
this.onSelectAction = new EventEmitter();
|
|
25
|
+
this.items = [];
|
|
22
26
|
this.crudConfig = new CrudConfig();
|
|
23
27
|
this.enProceso = false;
|
|
24
28
|
this.data = [];
|
|
@@ -33,7 +37,6 @@ export class TableroComponent {
|
|
|
33
37
|
.then(res => {
|
|
34
38
|
this.crudConfig = res;
|
|
35
39
|
this.getInfoTablero(this.crudConfig.tablero);
|
|
36
|
-
this.loadOptions();
|
|
37
40
|
})
|
|
38
41
|
.catch(err => {
|
|
39
42
|
console.log(err);
|
|
@@ -41,9 +44,10 @@ export class TableroComponent {
|
|
|
41
44
|
});
|
|
42
45
|
}
|
|
43
46
|
getInfoTablero(configTablero) {
|
|
44
|
-
this.generalService.genericRequest(configTablero.method, configTablero.server, configTablero.endpoint)
|
|
47
|
+
this.generalService.genericRequest(configTablero.method, configTablero.server, this.aplyKeys(configTablero.keys, configTablero.endpoint, this.dataExt))
|
|
45
48
|
.then((res) => {
|
|
46
49
|
this.data = res.data;
|
|
50
|
+
this.loadOptions();
|
|
47
51
|
this.enProceso = false;
|
|
48
52
|
})
|
|
49
53
|
.catch(err => {
|
|
@@ -52,10 +56,11 @@ export class TableroComponent {
|
|
|
52
56
|
});
|
|
53
57
|
}
|
|
54
58
|
loadOptions() {
|
|
59
|
+
this.items = [];
|
|
55
60
|
this.btn.create = this.opciones.find(x => x.label == 'Crear');
|
|
56
|
-
this.
|
|
57
|
-
|
|
58
|
-
|
|
61
|
+
this.opciones.filter((opc) => opc.valor.action).forEach(opc => {
|
|
62
|
+
this.items.push({ label: opc.label, icon: opc.icon, command: () => this.execAction(opc.valor) });
|
|
63
|
+
});
|
|
59
64
|
}
|
|
60
65
|
redirect(accion, data) {
|
|
61
66
|
var _a, _b;
|
|
@@ -64,21 +69,52 @@ export class TableroComponent {
|
|
|
64
69
|
this.router.navigateByUrl(((_b = (_a = this.btn.create) === null || _a === void 0 ? void 0 : _a.valor) === null || _b === void 0 ? void 0 : _b.redirect) || '');
|
|
65
70
|
break;
|
|
66
71
|
case 'read':
|
|
67
|
-
this.router.navigateByUrl(this.btn.read.valor.redirect
|
|
72
|
+
this.router.navigateByUrl(this.aplyKeys(this.crudConfig.tablero.keys, this.btn.read.valor.redirect, data));
|
|
68
73
|
break;
|
|
69
74
|
case 'update':
|
|
70
|
-
this.router.navigateByUrl(this.btn.update.valor.redirect
|
|
75
|
+
this.router.navigateByUrl(this.aplyKeys(this.crudConfig.tablero.keys, this.btn.update.valor.redirect, data));
|
|
71
76
|
break;
|
|
72
77
|
case 'delete':
|
|
73
|
-
this.router.navigateByUrl(this.btn.delete.valor.redirect
|
|
78
|
+
this.router.navigateByUrl(this.aplyKeys(this.crudConfig.tablero.keys, this.btn.delete.valor.redirect, data));
|
|
79
|
+
break;
|
|
80
|
+
default:
|
|
81
|
+
break;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
aplyKeys(keys, endpoint, data) {
|
|
85
|
+
keys.forEach(key => {
|
|
86
|
+
var _a, _b, _c, _d;
|
|
87
|
+
switch (key.key) {
|
|
88
|
+
case '@ndoc':
|
|
89
|
+
endpoint = endpoint.replace(key.key, ((_b = (_a = this.user) === null || _a === void 0 ? void 0 : _a.UsuarioSistema) === null || _b === void 0 ? void 0 : _b.NDOC) || '');
|
|
90
|
+
break;
|
|
91
|
+
case '@tdoc':
|
|
92
|
+
endpoint = endpoint.replace(key.key, ((_d = (_c = this.user) === null || _c === void 0 ? void 0 : _c.UsuarioSistema) === null || _d === void 0 ? void 0 : _d.TDOC) || '');
|
|
93
|
+
break;
|
|
94
|
+
case '@idKatios':
|
|
95
|
+
endpoint = endpoint.replace(key.key, this.idKatios);
|
|
96
|
+
break;
|
|
97
|
+
default:
|
|
98
|
+
if (endpoint.includes(key.key) && data)
|
|
99
|
+
endpoint = endpoint.replace(key.key, jsonpath.query(data, (key === null || key === void 0 ? void 0 : key.scope) || '')[0]);
|
|
100
|
+
break;
|
|
101
|
+
}
|
|
102
|
+
});
|
|
103
|
+
return endpoint;
|
|
104
|
+
}
|
|
105
|
+
execAction(params) {
|
|
106
|
+
switch (params.action) {
|
|
107
|
+
case 'redirect':
|
|
108
|
+
this.router.navigateByUrl(this.aplyKeys(this.crudConfig.tablero.keys, params.link, this.itemSelected));
|
|
74
109
|
break;
|
|
75
110
|
default:
|
|
111
|
+
this.onSelectAction.emit({ data: _.cloneDeep(this.itemSelected), params });
|
|
76
112
|
break;
|
|
77
113
|
}
|
|
78
114
|
}
|
|
79
115
|
}
|
|
80
116
|
TableroComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TableroComponent, deps: [{ token: i1.GeneralService }, { token: i2.Router }], target: i0.ɵɵFactoryTarget.Component });
|
|
81
|
-
TableroComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TableroComponent, selector: "sf-crudtablero", inputs: { opciones: "opciones", idEntidad: "idEntidad", idKatios: "idKatios" }, ngImport: i0, template: "<p-blockUI [blocked]=\"enProceso\">\r\n <i class=\"pi pi-cog pi-spin\" style=\"font-size: 50px\"></i>\r\n</p-blockUI>\r\n\r\n<div class=\"card\" *ngIf=\"!enProceso\">\r\n <p-toolbar styleClass=\"mb-4 gap-2\">\r\n <ng-template pTemplate=\"left\">\r\n <button *ngIf=\"btn.create\" pButton pRipple [label]=\"btn.create.label\" [icon]=\"btn.create.icon\"\r\n class=\"p-button-success mr-2\" (click)=\"redirect('create')\"></button>\r\n </ng-template>\r\n </p-toolbar>\r\n <p-table #dt [columns]=\"crudConfig.tablero.columns\" [value]=\"data\" [rowHover]=\"true\" [rows]=\"10\" [paginator]=\"true\"\r\n [globalFilterFields]=\"crudConfig.tablero?.filters || []\" [tableStyle]=\"{'min-width': '75rem'}\"\r\n currentPageReportTemplate=\"Registro {first} al {last} de {totalRecords}
|
|
117
|
+
TableroComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TableroComponent, selector: "sf-crudtablero", inputs: { opciones: "opciones", idEntidad: "idEntidad", idKatios: "idKatios", user: "user", dataExt: "dataExt" }, outputs: { onSelectAction: "onSelectAction" }, ngImport: i0, template: "<p-blockUI [blocked]=\"enProceso\">\r\n <i class=\"pi pi-cog pi-spin\" style=\"font-size: 50px\"></i>\r\n</p-blockUI>\r\n\r\n<div class=\"card\" *ngIf=\"!enProceso\">\r\n <p-toolbar styleClass=\"mb-4 gap-2\">\r\n <ng-template pTemplate=\"left\">\r\n <button *ngIf=\"btn.create\" pButton pRipple [label]=\"btn.create.label\" [icon]=\"btn.create.icon\"\r\n class=\"p-button-success mr-2\" (click)=\"redirect('create')\"></button>\r\n </ng-template>\r\n </p-toolbar>\r\n <p-table #dt [columns]=\"crudConfig.tablero.columns\" [value]=\"data\" [rowHover]=\"true\" [rows]=\"10\" [paginator]=\"true\"\r\n [globalFilterFields]=\"crudConfig.tablero?.filters || []\" [tableStyle]=\"{'min-width': '75rem'}\"\r\n currentPageReportTemplate=\"Registro {first} al {last} de {totalRecords}\" [showCurrentPageReport]=\"true\">\r\n <ng-template pTemplate=\"caption\">\r\n <div class=\"flex align-items-center justify-content-between\">\r\n <h5 class=\"m-0\">{{crudConfig.tablero?.label || idEntidad}}</h5>\r\n <span class=\"p-input-icon-left\">\r\n <i class=\"pi pi-search\"></i>\r\n <input pInputText type=\"text\" (input)=\"dt.filterGlobal($event.target.value, 'contains')\"\r\n placeholder=\"Buscar...\" />\r\n </span>\r\n </div>\r\n </ng-template>\r\n <ng-template pTemplate=\"header\" let-columns>\r\n <tr>\r\n <th *ngFor=\"let col of columns\">\r\n {{col.label}}\r\n </th>\r\n <th>Acci\u00F3n</th>\r\n </tr>\r\n </ng-template>\r\n <ng-template pTemplate=\"body\" let-rowData let-columns=\"columns\">\r\n <tr>\r\n <ng-container *ngFor=\"let col of columns\" [ngSwitch]=\"col.type\">\r\n <td *ngSwitchCase=\"'text'\">{{rowData[col.col]}}</td>\r\n <td *ngSwitchCase=\"'date:yyyy-mm-dd'\">{{rowData[col.col] | date: 'yyyy-MM-dd'}}</td>\r\n <td *ngSwitchCase=\"'currency:USD'\">{{rowData[col.col] | currency: 'USD'}}</td>\r\n </ng-container>\r\n <td>\r\n <p-splitButton icon=\"pi pi-align-justify\" [model]=\"items\" appendTo=\"body\"\r\n (onDropdownClick)=\"itemSelected = rowData\"></p-splitButton>\r\n </td>\r\n </tr>\r\n </ng-template>\r\n </p-table>\r\n</div>", components: [{ type: i3.BlockUI, selector: "p-blockUI", inputs: ["target", "autoZIndex", "baseZIndex", "styleClass", "blocked"] }, { type: i4.Toolbar, selector: "p-toolbar", inputs: ["style", "styleClass"] }, { type: i5.Table, selector: "p-table", inputs: ["frozenColumns", "frozenValue", "style", "styleClass", "tableStyle", "tableStyleClass", "paginator", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "paginatorDropdownAppendTo", "paginatorDropdownScrollHeight", "currentPageReportTemplate", "showCurrentPageReport", "showJumpToPageDropdown", "showFirstLastIcon", "showPageLinks", "defaultSortOrder", "sortMode", "resetPageOnSort", "selectionMode", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "rowTrackBy", "lazy", "lazyLoadOnInit", "compareSelectionBy", "csvSeparator", "exportFilename", "filters", "globalFilterFields", "filterDelay", "filterLocale", "expandedRowKeys", "editingRowKeys", "rowExpandMode", "scrollable", "scrollDirection", "rowGroupMode", "scrollHeight", "virtualScroll", "virtualScrollDelay", "virtualRowHeight", "frozenWidth", "responsive", "contextMenu", "resizableColumns", "columnResizeMode", "reorderableColumns", "loading", "loadingIcon", "showLoader", "rowHover", "customSort", "showInitialSortBadge", "autoLayout", "exportFunction", "stateKey", "stateStorage", "editMode", "groupRowsBy", "minBufferPx", "maxBufferPx", "responsiveLayout", "breakpoint", "value", "columns", "first", "rows", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection"], outputs: ["selectionChange", "contextMenuSelectionChange", "onRowSelect", "onRowUnselect", "onPage", "onSort", "onFilter", "onLazyLoad", "onRowExpand", "onRowCollapse", "onContextMenuSelect", "onColResize", "onColReorder", "onRowReorder", "onEditInit", "onEditComplete", "onEditCancel", "onHeaderCheckboxToggle", "sortFunction", "firstChange", "rowsChange", "onStateSave", "onStateRestore"] }, { type: i6.SplitButton, selector: "p-splitButton", inputs: ["model", "icon", "iconPos", "label", "style", "styleClass", "menuStyle", "menuStyleClass", "disabled", "tabindex", "appendTo", "dir", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onClick", "onDropdownClick"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { type: i9.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { type: i10.Ripple, selector: "[pRipple]" }, { type: i11.InputText, selector: "[pInputText]" }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i7.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i7.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }], pipes: { "date": i7.DatePipe, "currency": i7.CurrencyPipe } });
|
|
82
118
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TableroComponent, decorators: [{
|
|
83
119
|
type: Component,
|
|
84
120
|
args: [{
|
|
@@ -91,5 +127,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
91
127
|
type: Input
|
|
92
128
|
}], idKatios: [{
|
|
93
129
|
type: Input
|
|
130
|
+
}], user: [{
|
|
131
|
+
type: Input
|
|
132
|
+
}], dataExt: [{
|
|
133
|
+
type: Input
|
|
134
|
+
}], onSelectAction: [{
|
|
135
|
+
type: Output
|
|
94
136
|
}] } });
|
|
95
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tablero.component.js","sourceRoot":"","sources":["../../../../../../projects/sf-crud/src/lib/components/tablero/tablero.component.ts","../../../../../../projects/sf-crud/src/lib/components/tablero/tablero.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\nimport { GeneralService } from '../../shared/services/general.service';\r\nimport { ConfigTablero, CrudConfig } from '../../shared/services/models/crud-config.model';\r\n\r\n@Component({\r\n  selector: 'sf-crudtablero',\r\n  templateUrl: './tablero.component.html'\r\n})\r\nexport class TableroComponent implements OnInit {\r\n\r\n  @Input() opciones: any[] = [];\r\n  @Input() idEntidad: string = '';\r\n  @Input() idKatios: string = '';\r\n\r\n  public crudConfig: CrudConfig = new CrudConfig();\r\n  public enProceso: boolean = false;\r\n  public data: any[] = [];\r\n  public btn: { create: any, read: any, update: any, delete: any } = { create: undefined, read: undefined, update: undefined, delete: undefined }\r\n\r\n  constructor(\r\n    private generalService: GeneralService,\r\n    private router: Router\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    this.loadConfigCrud()\r\n  }\r\n\r\n  loadConfigCrud() {\r\n    this.enProceso = true;\r\n    this.generalService.getCrudByEntidad(this.idKatios, this.idEntidad)\r\n      .then(res => {\r\n        this.crudConfig = res;\r\n        this.getInfoTablero(this.crudConfig.tablero);\r\n        this.loadOptions();\r\n      })\r\n      .catch(err => {\r\n        console.log(err);\r\n        this.enProceso = false;\r\n      })\r\n  }\r\n\r\n  getInfoTablero(configTablero: ConfigTablero) {\r\n    this.generalService.genericRequest(configTablero.method, configTablero.server, configTablero.endpoint)\r\n      .then((res: any) => {\r\n        this.data = res.data;\r\n        this.enProceso = false;\r\n      })\r\n      .catch(err => {\r\n        console.log(err);\r\n        this.enProceso = false;\r\n      })\r\n  }\r\n\r\n  loadOptions() {\r\n    this.btn.create = this.opciones.find(x => x.label == 'Crear');\r\n    this.btn.read = this.opciones.find(x => x.label == 'Visualizar');\r\n    this.btn.update = this.opciones.find(x => x.label == 'Editar');\r\n    this.btn.delete = this.opciones.find(x => x.label == 'Eliminar');\r\n  }\r\n\r\n  redirect(accion: string, data?:any) {\r\n    switch (accion) {\r\n      case 'create':\r\n        this.router.navigateByUrl(this.btn.create?.valor?.redirect || '');\r\n        break;\r\n      case 'read':\r\n        this.router.navigateByUrl(this.btn.read.valor.redirect.replace('$id', data[this.crudConfig.tablero.key]));\r\n        break\r\n      case 'update':\r\n        this.router.navigateByUrl(this.btn.update.valor.redirect.replace('$id', data[this.crudConfig.tablero.key]));\r\n        break\r\n      case 'delete':\r\n        this.router.navigateByUrl(this.btn.delete.valor.redirect.replace('$id', data[this.crudConfig.tablero.key]));\r\n        break\r\n      default:\r\n        break\r\n    }\r\n  }\r\n}\r\n","<p-blockUI [blocked]=\"enProceso\">\r\n    <i class=\"pi pi-cog pi-spin\" style=\"font-size: 50px\"></i>\r\n</p-blockUI>\r\n\r\n<div class=\"card\" *ngIf=\"!enProceso\">\r\n    <p-toolbar styleClass=\"mb-4 gap-2\">\r\n        <ng-template pTemplate=\"left\">\r\n            <button *ngIf=\"btn.create\" pButton pRipple [label]=\"btn.create.label\" [icon]=\"btn.create.icon\"\r\n                class=\"p-button-success mr-2\" (click)=\"redirect('create')\"></button>\r\n        </ng-template>\r\n    </p-toolbar>\r\n    <p-table #dt [columns]=\"crudConfig.tablero.columns\" [value]=\"data\" [rowHover]=\"true\" [rows]=\"10\" [paginator]=\"true\"\r\n        [globalFilterFields]=\"crudConfig.tablero?.filters || []\" [tableStyle]=\"{'min-width': '75rem'}\"\r\n        currentPageReportTemplate=\"Registro {first} al {last} de {totalRecords} {{idEntidad}}\"\r\n        [showCurrentPageReport]=\"true\">\r\n        <ng-template pTemplate=\"caption\">\r\n            <div class=\"flex align-items-center justify-content-between\">\r\n                <h5 class=\"m-0\">{{idEntidad}}</h5>\r\n                <span class=\"p-input-icon-left\">\r\n                    <i class=\"pi pi-search\"></i>\r\n                    <input pInputText type=\"text\" (input)=\"dt.filterGlobal($event.target.value, 'contains')\"\r\n                        placeholder=\"Buscar...\" />\r\n                </span>\r\n            </div>\r\n        </ng-template>\r\n        <ng-template pTemplate=\"header\" let-columns>\r\n            <tr>\r\n                <th *ngFor=\"let col of columns\">\r\n                    {{col.label}}\r\n                </th>\r\n                <th>Acción</th>\r\n            </tr>\r\n        </ng-template>\r\n        <ng-template pTemplate=\"body\" let-rowData let-columns=\"columns\">\r\n            <tr>\r\n                <td *ngFor=\"let col of columns\">\r\n                    {{rowData[col.col]}}\r\n                </td>\r\n                <th>\r\n                    <button *ngIf=\"btn.read\" pButton pRipple [pTooltip]=\"btn.read.label\" [icon]=\"btn.read.icon\"\r\n                        class=\"p-button-rounded p-button-info mr-2\" (click)=\"redirect('read', rowData)\"></button>\r\n                    <button *ngIf=\"btn.update\" pButton pRipple [pTooltip]=\"btn.update.label\" [icon]=\"btn.update.icon\"\r\n                        class=\"p-button-rounded p-button-warning mr-2\" (click)=\"redirect('update', rowData)\"></button>\r\n                    <button *ngIf=\"btn.delete\" pButton pRipple [pTooltip]=\"btn.delete.label\" [icon]=\"btn.delete.icon\"\r\n                        class=\"p-button-rounded p-button-danger mr-2\" (click)=\"redirect('delete', rowData)\"></button>\r\n                </th>\r\n            </tr>\r\n        </ng-template>\r\n    </p-table>\r\n</div>"]}
|
|
137
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tablero.component.js","sourceRoot":"","sources":["../../../../../../projects/sf-crud/src/lib/components/tablero/tablero.component.ts","../../../../../../projects/sf-crud/src/lib/components/tablero/tablero.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { ConfigTablero, CrudConfig } from '../../shared/models/crud-config.model';\r\nimport { GeneralService } from '../../shared/services/general.service';\r\nimport { MenuItem } from 'primeng/api';\r\nimport { Router } from '@angular/router';\r\nimport * as _ from \"lodash\";\r\nimport * as jsonpath from 'jsonpath';\r\n\r\n@Component({\r\n  selector: 'sf-crudtablero',\r\n  templateUrl: './tablero.component.html'\r\n})\r\nexport class TableroComponent implements OnInit {\r\n\r\n  @Input() opciones: any[] = [];\r\n  @Input() idEntidad: string = '';\r\n  @Input() idKatios: string = '';\r\n  @Input() user: any;\r\n  @Input() dataExt: any;\r\n  @Output() onSelectAction: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  public items: MenuItem[] = [];\r\n  public crudConfig: CrudConfig = new CrudConfig();\r\n  public enProceso: boolean = false;\r\n  public data: any[] = [];\r\n  public btn: { create: any, read: any, update: any, delete: any } = { create: undefined, read: undefined, update: undefined, delete: undefined }\r\n  public itemSelected: any;\r\n\r\n  constructor(\r\n    private generalService: GeneralService,\r\n    private router: Router\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    this.loadConfigCrud()\r\n  }\r\n\r\n  loadConfigCrud() {\r\n    this.enProceso = true;\r\n    this.generalService.getCrudByEntidad(this.idKatios, this.idEntidad)\r\n      .then(res => {\r\n        this.crudConfig = res;\r\n        this.getInfoTablero(this.crudConfig.tablero);\r\n      })\r\n      .catch(err => {\r\n        console.log(err);\r\n        this.enProceso = false;\r\n      })\r\n  }\r\n\r\n  getInfoTablero(configTablero: ConfigTablero) {\r\n    this.generalService.genericRequest(configTablero.method, configTablero.server, this.aplyKeys(configTablero.keys, configTablero.endpoint, this.dataExt))\r\n      .then((res: any) => {\r\n        this.data = res.data;\r\n        this.loadOptions();\r\n        this.enProceso = false;\r\n      })\r\n      .catch(err => {\r\n        console.log(err);\r\n        this.enProceso = false;\r\n      })\r\n  }\r\n\r\n  loadOptions() {\r\n    this.items = [];\r\n    this.btn.create = this.opciones.find(x => x.label == 'Crear');\r\n    this.opciones.filter((opc: any) => opc.valor.action).forEach(opc => {\r\n      this.items.push({ label: opc.label, icon: opc.icon, command: () => this.execAction(opc.valor) })\r\n    })\r\n  }\r\n\r\n  redirect(accion: string, data?: any) {\r\n    switch (accion) {\r\n      case 'create':\r\n        this.router.navigateByUrl(this.btn.create?.valor?.redirect || '');\r\n        break;\r\n      case 'read':\r\n        this.router.navigateByUrl(this.aplyKeys(this.crudConfig.tablero.keys, this.btn.read.valor.redirect, data));\r\n        break\r\n      case 'update':\r\n        this.router.navigateByUrl(this.aplyKeys(this.crudConfig.tablero.keys, this.btn.update.valor.redirect, data));\r\n        break\r\n      case 'delete':\r\n        this.router.navigateByUrl(this.aplyKeys(this.crudConfig.tablero.keys, this.btn.delete.valor.redirect, data));\r\n        break\r\n      default:\r\n        break\r\n    }\r\n  }\r\n\r\n  aplyKeys(keys: { key: string, scope?: string }[], endpoint: string, data?: any) {\r\n    keys.forEach(key => {\r\n      switch (key.key) {\r\n        case '@ndoc':\r\n          endpoint = endpoint.replace(key.key, this.user?.UsuarioSistema?.NDOC || '')\r\n          break;\r\n        case '@tdoc':\r\n          endpoint = endpoint.replace(key.key, this.user?.UsuarioSistema?.TDOC || '')\r\n          break;\r\n        case '@idKatios':\r\n          endpoint = endpoint.replace(key.key, this.idKatios)\r\n          break;\r\n        default:\r\n          if (endpoint.includes(key.key) && data) endpoint = endpoint.replace(key.key, jsonpath.query(data, key?.scope || '')[0]);\r\n          break;\r\n      }\r\n    });\r\n    return endpoint;\r\n  }\r\n\r\n  execAction(params: any) {\r\n    switch (params.action) {\r\n      case 'redirect':\r\n        this.router.navigateByUrl(this.aplyKeys(this.crudConfig.tablero.keys, params.link, this.itemSelected));\r\n        break;\r\n      default:\r\n        this.onSelectAction.emit({ data: _.cloneDeep(this.itemSelected), params })\r\n        break;\r\n    }\r\n  }\r\n}\r\n","<p-blockUI [blocked]=\"enProceso\">\r\n    <i class=\"pi pi-cog pi-spin\" style=\"font-size: 50px\"></i>\r\n</p-blockUI>\r\n\r\n<div class=\"card\" *ngIf=\"!enProceso\">\r\n    <p-toolbar styleClass=\"mb-4 gap-2\">\r\n        <ng-template pTemplate=\"left\">\r\n            <button *ngIf=\"btn.create\" pButton pRipple [label]=\"btn.create.label\" [icon]=\"btn.create.icon\"\r\n                class=\"p-button-success mr-2\" (click)=\"redirect('create')\"></button>\r\n        </ng-template>\r\n    </p-toolbar>\r\n    <p-table #dt [columns]=\"crudConfig.tablero.columns\" [value]=\"data\" [rowHover]=\"true\" [rows]=\"10\" [paginator]=\"true\"\r\n        [globalFilterFields]=\"crudConfig.tablero?.filters || []\" [tableStyle]=\"{'min-width': '75rem'}\"\r\n        currentPageReportTemplate=\"Registro {first} al {last} de {totalRecords}\" [showCurrentPageReport]=\"true\">\r\n        <ng-template pTemplate=\"caption\">\r\n            <div class=\"flex align-items-center justify-content-between\">\r\n                <h5 class=\"m-0\">{{crudConfig.tablero?.label || idEntidad}}</h5>\r\n                <span class=\"p-input-icon-left\">\r\n                    <i class=\"pi pi-search\"></i>\r\n                    <input pInputText type=\"text\" (input)=\"dt.filterGlobal($event.target.value, 'contains')\"\r\n                        placeholder=\"Buscar...\" />\r\n                </span>\r\n            </div>\r\n        </ng-template>\r\n        <ng-template pTemplate=\"header\" let-columns>\r\n            <tr>\r\n                <th *ngFor=\"let col of columns\">\r\n                    {{col.label}}\r\n                </th>\r\n                <th>Acción</th>\r\n            </tr>\r\n        </ng-template>\r\n        <ng-template pTemplate=\"body\" let-rowData let-columns=\"columns\">\r\n            <tr>\r\n                <ng-container *ngFor=\"let col of columns\" [ngSwitch]=\"col.type\">\r\n                    <td *ngSwitchCase=\"'text'\">{{rowData[col.col]}}</td>\r\n                    <td *ngSwitchCase=\"'date:yyyy-mm-dd'\">{{rowData[col.col] | date: 'yyyy-MM-dd'}}</td>\r\n                    <td *ngSwitchCase=\"'currency:USD'\">{{rowData[col.col] | currency: 'USD'}}</td>\r\n                </ng-container>\r\n                <td>\r\n                    <p-splitButton icon=\"pi pi-align-justify\" [model]=\"items\" appendTo=\"body\"\r\n                        (onDropdownClick)=\"itemSelected = rowData\"></p-splitButton>\r\n                </td>\r\n            </tr>\r\n        </ng-template>\r\n    </p-table>\r\n</div>"]}
|