sf-crud 12.3.2 → 13.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (49) hide show
  1. package/fesm2022/sf-crud.mjs +3252 -0
  2. package/fesm2022/sf-crud.mjs.map +1 -0
  3. package/{sf-crud.d.ts → index.d.ts} +5 -5
  4. package/lib/components/control/control.component.d.ts +67 -66
  5. package/lib/components/file-upload/file-upload.component.d.ts +34 -34
  6. package/lib/components/form/form.component.d.ts +63 -63
  7. package/lib/components/registro/registro.component.d.ts +109 -109
  8. package/lib/components/step/step.component.d.ts +27 -27
  9. package/lib/components/tablero/tablero.component.d.ts +53 -52
  10. package/lib/directives/format-address.pipe.d.ts +7 -7
  11. package/lib/sf-crud.component.d.ts +8 -8
  12. package/lib/sf-crud.module.d.ts +94 -90
  13. package/lib/sf-crud.routing.module.d.ts +7 -7
  14. package/lib/sf-crud.service.d.ts +135 -135
  15. package/lib/shared/models/Conditions.model.d.ts +32 -32
  16. package/lib/shared/models/Empresa.model.d.ts +11 -11
  17. package/lib/shared/models/Reason.model.d.ts +5 -5
  18. package/lib/shared/models/crud-config.model.d.ts +109 -110
  19. package/lib/shared/models/shema.model.d.ts +37 -37
  20. package/lib/shared/services/general.service.d.ts +20 -20
  21. package/lib/shared/services/notification.service.d.ts +26 -27
  22. package/lib/shared/services/step.service.d.ts +27 -27
  23. package/package.json +20 -15
  24. package/public-api.d.ts +12 -12
  25. package/bundles/sf-crud.umd.js +0 -3786
  26. package/bundles/sf-crud.umd.js.map +0 -1
  27. package/esm2015/lib/components/control/control.component.js +0 -394
  28. package/esm2015/lib/components/file-upload/file-upload.component.js +0 -143
  29. package/esm2015/lib/components/form/form.component.js +0 -289
  30. package/esm2015/lib/components/registro/registro.component.js +0 -757
  31. package/esm2015/lib/components/step/step.component.js +0 -79
  32. package/esm2015/lib/components/tablero/tablero.component.js +0 -220
  33. package/esm2015/lib/directives/format-address.pipe.js +0 -22
  34. package/esm2015/lib/sf-crud.component.js +0 -26
  35. package/esm2015/lib/sf-crud.module.js +0 -359
  36. package/esm2015/lib/sf-crud.routing.module.js +0 -23
  37. package/esm2015/lib/sf-crud.service.js +0 -531
  38. package/esm2015/lib/shared/models/Conditions.model.js +0 -81
  39. package/esm2015/lib/shared/models/Empresa.model.js +0 -2
  40. package/esm2015/lib/shared/models/Reason.model.js +0 -7
  41. package/esm2015/lib/shared/models/crud-config.model.js +0 -76
  42. package/esm2015/lib/shared/models/shema.model.js +0 -11
  43. package/esm2015/lib/shared/services/general.service.js +0 -74
  44. package/esm2015/lib/shared/services/notification.service.js +0 -83
  45. package/esm2015/lib/shared/services/step.service.js +0 -63
  46. package/esm2015/public-api.js +0 -16
  47. package/esm2015/sf-crud.js +0 -5
  48. package/fesm2015/sf-crud.js +0 -3134
  49. package/fesm2015/sf-crud.js.map +0 -1
@@ -1,143 +0,0 @@
1
- import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
2
- import * as moment from 'moment';
3
- import * as i0 from "@angular/core";
4
- import * as i1 from "primeng/api";
5
- import * as i2 from "primeng/button";
6
- import * as i3 from "primeng/ripple";
7
- import * as i4 from "@angular/common";
8
- export class FileUploadComponent {
9
- constructor(messageSerice) {
10
- this.messageSerice = messageSerice;
11
- this.files = [];
12
- this.loading = false;
13
- this.accept = "image/*,application/pdf";
14
- this.onUpload = new EventEmitter();
15
- this.onDeleteFile = new EventEmitter();
16
- this.newFiles = [];
17
- window.addEventListener("paste", (e) => {
18
- var _a;
19
- if (((_a = e.clipboardData) === null || _a === void 0 ? void 0 : _a.files) && e.clipboardData.files.length > 0) {
20
- this.appendFile(e.clipboardData.files[0]);
21
- }
22
- });
23
- }
24
- ngOnChanges(changes) {
25
- }
26
- ngOnInit() {
27
- }
28
- appendFile(file) {
29
- const allowedTypes = this.accept.split(",");
30
- const allowedFile = allowedTypes.some(pattern => {
31
- const regexObj = new RegExp(pattern);
32
- const match = regexObj.exec(file.type);
33
- return match ? (match === null || match === void 0 ? void 0 : match.length) > 0 : false;
34
- });
35
- if (allowedFile) {
36
- const newFile = new File([file], this.getName(file), { type: file.type });
37
- if (this.limit == 1) {
38
- this.newFiles = [newFile];
39
- }
40
- else
41
- this.newFiles.push(newFile);
42
- this.files.push({ name: newFile.name, url: window.URL.createObjectURL(newFile) });
43
- }
44
- else {
45
- this.messageSerice.add({ severity: "warn", detail: "Tipo de archivo no válido" });
46
- }
47
- }
48
- emitFiles() {
49
- this.loading = true;
50
- this.onUpload.emit(this.newFiles);
51
- }
52
- getName(file) {
53
- let sName = "";
54
- let date = new Date();
55
- if (this.configName !== undefined) {
56
- let name = this.configName.split('|');
57
- name.forEach(item => {
58
- if (item.indexOf("DATE@") != -1)
59
- sName += (moment(date)).format(item.split('@')[1]);
60
- else if (item.indexOf("@") == -1)
61
- sName += item;
62
- });
63
- let ext = this.getExt(file);
64
- sName += ext ? "." + ext : "";
65
- }
66
- else
67
- sName = file.name;
68
- return sName;
69
- }
70
- getExt(file) {
71
- let ext = undefined;
72
- let aux = file.name.split('.');
73
- if (aux.length > 0)
74
- ext = aux[aux.length - 1];
75
- return ext;
76
- }
77
- appendFiles($event) {
78
- if ($event.target.files.length > 0) {
79
- this.appendFile($event.target.files[0]);
80
- }
81
- if (this.limit == this.files.length) {
82
- this.stopAnimation();
83
- this.emitFiles();
84
- }
85
- else
86
- this.startAnimation();
87
- this.fileUploader.nativeElement.value = "";
88
- }
89
- dropFile(archivo) {
90
- this.files.forEach((f, index) => {
91
- if (f == archivo) {
92
- this.files.splice(index, 1);
93
- this.onDeleteFile.emit(index);
94
- }
95
- });
96
- }
97
- openFile(archivo) {
98
- window.open(archivo.url, '_blank');
99
- window.addEventListener('focus', () => URL.revokeObjectURL(archivo.url));
100
- }
101
- startAnimation() {
102
- const button = document.querySelector('.button-upload');
103
- if (button) {
104
- button.classList.add('animate-pulse');
105
- }
106
- }
107
- stopAnimation() {
108
- const button = document.querySelector('.button-upload');
109
- if (button) {
110
- button.classList.remove('animate-pulse');
111
- }
112
- }
113
- }
114
- FileUploadComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FileUploadComponent, deps: [{ token: i1.MessageService }], target: i0.ɵɵFactoryTarget.Component });
115
- FileUploadComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: FileUploadComponent, selector: "sf-file-upload", inputs: { limit: "limit", files: "files", loading: "loading", configName: "configName", accept: "accept" }, outputs: { onUpload: "onUpload", onDeleteFile: "onDeleteFile" }, viewQueries: [{ propertyName: "fileUploader", first: true, predicate: ["fileUpload"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div id=\"screen\" #screen>\r\n <div class=\"fileUp\">\r\n <div class=\"botones\">\r\n <input type=\"file\" (change)=\"appendFiles($event)\" class=\"file-input\" #fileUpload multiple>\r\n <button pButton pRipple type=\"button\" icon=\"pi pi-plus\" class=\"p-button-info\" (click)=\"fileUpload.click()\"\r\n [disabled]=\"limit == files.length\" [loading]=\"loading\"></button>\r\n <button *ngIf=\"limit != 1\" pButton pRipple type=\"button\" icon=\"pi pi-upload\" class=\"button-upload p-button-info\"\r\n (click)=\"emitFiles()\" [disabled]=\"files.length == 0 || loading\" [loading]=\"loading\"></button>\r\n </div>\r\n\r\n <hr>\r\n <div class=\"imgs\">\r\n <ul>\r\n <li *ngFor=\"let file of files; let i = index\" [ngSwitch]=\"file.type\">\r\n <p>{{i+1}}. {{files[i].name}}</p>\r\n <div>\r\n <button pButton pRipple type=\"button\" icon=\"pi pi-external-link\" class=\"p-button-rounded\"\r\n (click)=\"openFile(file)\"></button>\r\n <button pButton pRipple type=\"button\" icon=\"pi pi-times\" class=\"p-button-rounded p-button-danger\"\r\n (click)=\"dropFile(file)\"></button>\r\n </div>\r\n </li>\r\n </ul>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: ["#screen{container-type:inline-size}iframe{width:100%;padding:10px;text-align:center}.fileUp{border:1.5px solid gray;border-radius:5px;text-align:center}.fileUp .imgs{min-height:40px;margin-block:7px;max-height:135px;overflow-y:scroll}.fileUp hr{color:gray;margin:0}.fileUp .imgs ul li{text-decoration:none;display:flex;margin-block:5px;padding-inline:5px}.fileUp .imgs ul{padding-inline-start:30px}.fileUp .imgs ul li div{text-decoration:none;display:grid;grid-template-columns:50% 50%;margin-block:5px;margin-right:5px}.fileUp .botones *{margin-block:7px;margin-inline:10px}.fileUp .imgs ul li p{text-align:left;white-space:nowrap;width:100%;overflow:hidden;text-overflow:ellipsis}.fileUp .imgs ul li p,.fileUp .imgs ul li button{margin-block:auto;margin-inline:5px;text-align:left}.fileUp .imgs ul li img,.fileUp .imgs ul li iframe{text-align:center;width:80%;padding-inline:10%}.file-input{display:none}::ng-deep .p-button.p-button-info,.p-buttonset.p-button-info>.p-button,.p-splitbutton.p-button-info>.p-button{background:var(--secondary-color)!important;border:var(--secondary-color)!important;color:#fff}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.animate-pulse{animation:pulse 1.5s infinite}@container (width < 768px){.fileUp .imgs ul li {display: grid; grid-template-columns: 60% 40%;} .fileUp .imgs ul li img,.fileUp .imgs ul li iframe {display: none;}}\n"], directives: [{ type: i2.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { type: i3.Ripple, selector: "[pRipple]" }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i4.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }] });
116
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FileUploadComponent, decorators: [{
117
- type: Component,
118
- args: [{
119
- selector: 'sf-file-upload',
120
- templateUrl: './file-upload.component.html',
121
- styleUrls: ['./file-upload.component.css']
122
- }]
123
- }], ctorParameters: function () { return [{ type: i1.MessageService }]; }, propDecorators: { limit: [{
124
- type: Input
125
- }], files: [{
126
- type: Input
127
- }], loading: [{
128
- type: Input
129
- }], configName: [{
130
- type: Input
131
- }], accept: [{
132
- type: Input
133
- }], onUpload: [{
134
- type: Output
135
- }], onDeleteFile: [{
136
- type: Output
137
- }], fileUploader: [{
138
- type: ViewChild,
139
- args: ['fileUpload']
140
- }] } });
141
- export class Archivo {
142
- }
143
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload.component.js","sourceRoot":"","sources":["../../../../../../projects/sf-crud/src/lib/components/file-upload/file-upload.component.ts","../../../../../../projects/sf-crud/src/lib/components/file-upload/file-upload.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, ViewChild } from '@angular/core';\r\nimport * as moment from 'moment';\r\nimport { MessageService } from 'primeng/api';\r\n\r\n@Component({\r\n  selector: 'sf-file-upload',\r\n  templateUrl: './file-upload.component.html',\r\n  styleUrls: ['./file-upload.component.css']\r\n})\r\nexport class FileUploadComponent implements OnInit, OnChanges {\r\n\r\n\r\n  @Input() limit!: number;\r\n  @Input() files: Archivo[] = [];\r\n  @Input() loading = false;\r\n  @Input() configName: string | undefined;\r\n  @Input() accept: string  = \"image/*,application/pdf\";\r\n  @Output() onUpload = new EventEmitter<File[]>();\r\n  @Output() onDeleteFile = new EventEmitter<number>();\r\n  @ViewChild('fileUpload') fileUploader!: ElementRef;\r\n\r\n  newFiles: File[] = [];\r\n  private animationInterval: any;\r\n\r\n  constructor(\r\n    private messageSerice: MessageService) {\r\n      window.addEventListener(\"paste\", (e: any) =>{\r\n        if (e.clipboardData?.files && e.clipboardData.files.length > 0){\r\n          this.appendFile(e.clipboardData.files[0]);\r\n        }\r\n      });\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n  }\r\n\r\n  appendFile(file: File){\r\n    const allowedTypes = this.accept.split(\",\");\r\n    const allowedFile = allowedTypes.some(pattern => {\r\n      const regexObj = new RegExp(pattern);\r\n      const match = regexObj.exec(file.type);\r\n      return match ? match?.length > 0: false\r\n    })\r\n\r\n    if (allowedFile){\r\n      const newFile = new File([file], this.getName(file), {type: file.type})\r\n      if (this.limit == 1){\r\n        this.newFiles = [newFile]\r\n      }else this.newFiles.push(newFile)\r\n      this.files.push({name: newFile.name, url: window.URL.createObjectURL(newFile)})\r\n    }else{\r\n      this.messageSerice.add({severity: \"warn\", detail: \"Tipo de archivo no válido\"})\r\n    }\r\n\r\n  }\r\n\r\n  emitFiles(){\r\n    this.loading = true;\r\n    this.onUpload.emit(this.newFiles)\r\n  }\r\n\r\n  getName(file: File){\r\n    let sName = \"\"\r\n\r\n    let date: Date = new Date();\r\n    if(this.configName !== undefined){\r\n      let name =  this.configName.split('|');\r\n      name.forEach(item => {\r\n        if (item.indexOf(\"DATE@\") != -1)\r\n          sName += (moment(date)).format(item.split('@')[1]);\r\n        else if(item.indexOf(\"@\") == -1)\r\n        sName += item\r\n      })\r\n      let ext = this.getExt(file)\r\n      sName += ext ? \".\" + ext: \"\"\r\n    }\r\n    else sName = file.name;\r\n    return sName\r\n  }\r\n  getExt(file: File) {\r\n    let ext = undefined\r\n    let aux = file.name.split('.')\r\n    if (aux.length > 0) ext = aux[aux.length - 1]\r\n    return ext\r\n  }\r\n\r\n  appendFiles($event: any){\r\n    if($event.target.files.length > 0){\r\n      this.appendFile($event.target.files[0]);\r\n    }\r\n    if (this.limit == this.files.length) {\r\n      this.stopAnimation()\r\n      this.emitFiles()\r\n    }\r\n    else this.startAnimation()\r\n    this.fileUploader.nativeElement.value = \"\";\r\n  }\r\n\r\n  dropFile(archivo: Archivo){\r\n    this.files.forEach((f, index) => {\r\n      if(f == archivo){\r\n        this.files.splice(index, 1);\r\n        this.onDeleteFile.emit(index)\r\n      }\r\n    });\r\n  }\r\n\r\n\r\n  openFile(archivo: Archivo) {\r\n    window.open(archivo.url, '_blank');\r\n    window.addEventListener('focus', () => URL.revokeObjectURL(archivo.url));\r\n  }\r\n\r\n  startAnimation() {\r\n    const button = document.querySelector('.button-upload');\r\n    if (button) {\r\n      button.classList.add('animate-pulse');\r\n    }\r\n  }\r\n\r\n  stopAnimation() {\r\n    const button = document.querySelector('.button-upload');\r\n    if (button) {\r\n      button.classList.remove('animate-pulse');\r\n    }\r\n  }\r\n}\r\n\r\nexport class Archivo {\r\n  public url! : string\r\n  public name! : string\r\n}\r\n","<div id=\"screen\" #screen>\r\n    <div class=\"fileUp\">\r\n        <div class=\"botones\">\r\n            <input type=\"file\" (change)=\"appendFiles($event)\" class=\"file-input\" #fileUpload multiple>\r\n            <button pButton pRipple type=\"button\" icon=\"pi pi-plus\" class=\"p-button-info\" (click)=\"fileUpload.click()\"\r\n                [disabled]=\"limit == files.length\" [loading]=\"loading\"></button>\r\n            <button *ngIf=\"limit != 1\" pButton pRipple type=\"button\" icon=\"pi pi-upload\" class=\"button-upload p-button-info\"\r\n                (click)=\"emitFiles()\" [disabled]=\"files.length == 0 || loading\" [loading]=\"loading\"></button>\r\n        </div>\r\n\r\n        <hr>\r\n        <div class=\"imgs\">\r\n            <ul>\r\n                <li *ngFor=\"let file of files; let i = index\" [ngSwitch]=\"file.type\">\r\n                    <p>{{i+1}}. {{files[i].name}}</p>\r\n                    <div>\r\n                        <button pButton pRipple type=\"button\" icon=\"pi pi-external-link\" class=\"p-button-rounded\"\r\n                        (click)=\"openFile(file)\"></button>\r\n                        <button pButton pRipple type=\"button\" icon=\"pi pi-times\" class=\"p-button-rounded p-button-danger\"\r\n                        (click)=\"dropFile(file)\"></button>\r\n                    </div>\r\n                </li>\r\n            </ul>\r\n        </div>\r\n    </div>\r\n</div>\r\n"]}
@@ -1,289 +0,0 @@
1
- import { Component, Input, ViewChildren } from '@angular/core';
2
- import * as jsonpath from 'jsonpath';
3
- import { ChangeData } from '../../sf-crud.service';
4
- import { Tooltip } from 'primeng/tooltip';
5
- import * as i0 from "@angular/core";
6
- import * as i1 from "primeng/api";
7
- import * as i2 from "../../sf-crud.service";
8
- import * as i3 from "@angular/platform-browser";
9
- import * as i4 from "../../shared/services/step.service";
10
- import * as i5 from "sf-ado";
11
- import * as i6 from "../control/control.component";
12
- import * as i7 from "sf-pdfsign";
13
- import * as i8 from "sf-simulador";
14
- import * as i9 from "primeng/button";
15
- import * as i10 from "primeng/table";
16
- import * as i11 from "primeng/toast";
17
- import * as i12 from "@angular/common";
18
- import * as i13 from "primeng/tooltip";
19
- import * as i14 from "primeng/ripple";
20
- import * as i15 from "../../directives/format-address.pipe";
21
- export class FormComponent {
22
- constructor(messageService, crudService, domSanitizer, stepService, adoService, jwtService) {
23
- this.messageService = messageService;
24
- this.crudService = crudService;
25
- this.domSanitizer = domSanitizer;
26
- this.stepService = stepService;
27
- this.adoService = adoService;
28
- this.jwtService = jwtService;
29
- this.isDialog = false;
30
- this.isAddressDialog = false;
31
- this.controlsLoaded = false;
32
- this.isMobile = false;
33
- this.loading = { inProgress: true, target: undefined };
34
- if (window.innerWidth <= 768)
35
- this.isMobile = true;
36
- window.addEventListener('resize', () => {
37
- if (window.innerWidth <= 768)
38
- this.isMobile = true;
39
- });
40
- }
41
- ngOnChanges(changes) {
42
- this.buildControls();
43
- }
44
- ngOnInit() {
45
- try {
46
- if (this.isAddressDialog)
47
- this.currentAddress = this.data.currentValue;
48
- this.jwtService.idKatios = this.crudService.idKatios;
49
- this.jwtService.servidorIntegraciones = this.crudService.environment.ServidorIntegraciones;
50
- this.adoService.servidorIntegraciones = this.crudService.environment.ServidorIntegraciones;
51
- this.idKatios = this.crudService.idKatios;
52
- this.stepService.requestApproved$.subscribe((approved) => {
53
- if (!this.isDialog && approved) {
54
- this.uiEsquema = this.crudService.getUIEsquema(this.stepService.currentIndex);
55
- this.esquema = this.crudService.getEsquema(this.stepService.currentIndex);
56
- this.data = this.crudService.getData(this.stepService.currentIndex);
57
- this.registro = this.crudService.getRegistro(this.stepService.currentIndex);
58
- this.buildControls();
59
- }
60
- });
61
- }
62
- catch (error) {
63
- console.error(error);
64
- }
65
- }
66
- emitLoadingForm($event) {
67
- this.loading.inProgress = $event;
68
- Promise.resolve().then(() => this.crudService.formLoading = this.loading); //si no se usa asi el enproceso totea con el simulador
69
- }
70
- buildControls() {
71
- var _a, _b, _c;
72
- this.visible = [];
73
- this.controlsLoaded = false;
74
- this.controls = [];
75
- this.values = [];
76
- //address
77
- if (this.isAddressDialog)
78
- this.newAddress = this.crudService.armarNuevaDireccion("string", this.data, this.crudService.getValue("$..separador", this.data));
79
- this.uiEsquema.elements.forEach((layout, i) => {
80
- var _a;
81
- let isVisible = layout.conditions ? this.crudService.isConditionsCompleted(layout.conditions, this.registro.conditions || [], this.data) : true;
82
- this.visible.push(layout.elements ? layout.elements.map(() => isVisible) : [isVisible]);
83
- this.controls.push([]);
84
- this.values.push([]);
85
- (_a = layout.elements) === null || _a === void 0 ? void 0 : _a.forEach((element, j) => {
86
- if (element.conditions)
87
- this.visible[i][j] = this.crudService.isConditionsCompleted(element.conditions, this.registro.conditions || [], this.data);
88
- if (element.ngStyle && typeof (element.ngStyle) == "string")
89
- element.ngStyle = JSON.parse(element.ngStyle);
90
- if (element.url) {
91
- this.controls[i].push(undefined);
92
- let url = this.crudService.applyStringKeys(element.url);
93
- this.values[i].push(this.domSanitizer.bypassSecurityTrustResourceUrl(url));
94
- }
95
- else if (!element.scope) {
96
- this.controls[i].push(undefined);
97
- this.values[i].push(undefined);
98
- }
99
- else {
100
- try {
101
- this.controls[i].push(this.crudService.getControl(element.scope, this.esquema));
102
- this.controls[i][j].scope = element.scope;
103
- this.values[i].push(this.crudService.getValue(element.scope, this.data));
104
- }
105
- catch (e) {
106
- console.log(element);
107
- console.error(e);
108
- console.log(this.controls[i]);
109
- console.log(this.values[i]);
110
- }
111
- }
112
- });
113
- });
114
- this.controlsLoaded = true;
115
- let idProceso = (_b = (_a = this.data.ADO) === null || _a === void 0 ? void 0 : _a.dataProceso) === null || _b === void 0 ? void 0 : _b.idProceso;
116
- if (idProceso && ((_c = this.proceso) === null || _c === void 0 ? void 0 : _c.id) != idProceso)
117
- this.refreshIntegracion(idProceso);
118
- }
119
- refreshIntegracion(idProceso) {
120
- this.emitLoadingForm(true);
121
- return Promise.all([
122
- this.adoService.getProceso(idProceso).then((proceso) => {
123
- this.proceso = proceso;
124
- this.data.ADO.proceso = this.proceso;
125
- })
126
- ])
127
- .finally(() => this.emitLoadingForm(false));
128
- }
129
- extracControlFromTableElements(i, j, col) {
130
- const property = this.controls[i][j].properties[col.col];
131
- return property;
132
- }
133
- extracValueFromTableElements(i, j, k, col) {
134
- const value = this.values[i][j][k][col.col];
135
- return value;
136
- }
137
- setValue(value, scope, i, j) {
138
- var _a;
139
- scope = scope.replaceAll('..properties', '');
140
- if (scope) {
141
- let control = this.controls[i][j];
142
- this.values[i][j] = value;
143
- jsonpath.value(this.data, scope, value);
144
- this.crudService.changeData = new ChangeData(value, scope, this.crudService.index);
145
- this.uiEsquema.elements.forEach((layout, iLayout) => {
146
- var _a;
147
- if (layout.conditions) {
148
- let isVisible = this.crudService.isConditionsCompleted(layout.conditions, this.crudService.getRegistro(this.crudService.index).conditions || [], this.data);
149
- if (layout.elements)
150
- this.visible[iLayout] = layout.elements.map(() => isVisible);
151
- else
152
- this.visible[iLayout][0] = isVisible;
153
- }
154
- (_a = layout.elements) === null || _a === void 0 ? void 0 : _a.forEach((element, indexEl) => {
155
- if (element.conditions) {
156
- this.visible[iLayout][indexEl] = this.crudService.isConditionsCompleted(element.conditions, this.registro.conditions || [], this.data);
157
- }
158
- });
159
- });
160
- (_a = control.applyKeys) === null || _a === void 0 ? void 0 : _a.forEach((i) => {
161
- let key = this.registro.keys ? this.registro.keys[i] : undefined;
162
- if (key)
163
- this.crudService.applyKey(key, this.registro, key.indexData ? this.crudService.getData(key.indexData) : this.data);
164
- });
165
- this.buildControls();
166
- }
167
- this.crudService.applyValuesOnEvent('onChange', this.esquema, undefined, this.data);
168
- }
169
- sendNotification(message) {
170
- this.messageService.add(message);
171
- }
172
- applyValuesFromObject(event) {
173
- if (event.optionValue) {
174
- for (let i = 0; i < event.optionValue.length; i++) {
175
- const optionVal = event.optionValue[i];
176
- const newVal = event.data ? this.aplyFormatValue(optionVal.scope, event.data[optionVal.key]) : null;
177
- jsonpath.value(this.data, optionVal.scope.replace('.properties', ''), this.aplyFormatValue(optionVal.scope, event.data[optionVal.key]));
178
- this.setValueByScope(optionVal.scope, newVal);
179
- }
180
- }
181
- }
182
- setValueByScope(scope, newVal) {
183
- for (let i = 0; i < this.controls.length; i++) {
184
- const row = this.controls[i];
185
- row.forEach((el, j) => {
186
- if (el.scope && el.scope.replace('.properties', '') == scope.replace('.properties', '')) {
187
- this.values[i][j] = newVal;
188
- }
189
- });
190
- }
191
- }
192
- aplyFormatValue(scope, value) {
193
- const control = jsonpath.query(this.esquema, scope)[0];
194
- let resp;
195
- switch (control.type) {
196
- case 'date':
197
- resp = new Date(`${value}`);
198
- break;
199
- case 'numeric':
200
- resp = +value;
201
- break;
202
- default:
203
- resp = value;
204
- break;
205
- }
206
- return resp;
207
- }
208
- editRow(element, data, index) {
209
- this.stepService.addCustomChildrenEvent("onClickedEditButton", { element, data, index });
210
- }
211
- deleteRow(element, index) {
212
- this.stepService.addCustomChildrenEvent("onClickedDeleteButton", { element, index });
213
- }
214
- addObjectArray(element) {
215
- this.stepService.addCustomChildrenEvent("onClickedAddButton", { element });
216
- }
217
- openPopUpDireccion(scope) {
218
- this.stepService.addCustomChildrenEvent("onClickedAddress", { scope });
219
- }
220
- onStateDocument(state) {
221
- this.data.pdf.signed = state.toUpperCase() == "FIRMADO";
222
- }
223
- onSimuladorChange($event) {
224
- Promise.resolve().then(() => Object.assign(this.data, $event));
225
- }
226
- goToADO() {
227
- var _a;
228
- let url = window.location.href;
229
- let callback = url.split('?')[0] + `?id=${this.data.idForm}`;
230
- let idProceso = (_a = this.data.ADO.dataProceso) === null || _a === void 0 ? void 0 : _a.idProceso;
231
- let dataProceso = this.data.ADO.dataProceso;
232
- dataProceso.ctivo = this.data.idForm;
233
- //this.data.ADO.idTransaction = null
234
- //this.data.ADO.idProceso = null
235
- if (idProceso) {
236
- window.location.href = `${this.crudService.environment.WebUtilities}GWV/ADO/${this.crudService.idKatios}?id=${idProceso}`;
237
- window.location.reload();
238
- }
239
- else if (dataProceso) {
240
- window.location.href = `${this.crudService.environment.WebUtilities}GWV/ADO/${this.crudService.idKatios}?dataProceso=${btoa(JSON.stringify(dataProceso))}&callback=${encodeURIComponent(callback)}`;
241
- window.location.reload();
242
- }
243
- }
244
- onTouchDescription(id, alignRight = true) {
245
- const foundTooltip = this.tooltips.find(tooltip => tooltip.el.nativeElement.id === id);
246
- try {
247
- foundTooltip.activate();
248
- alignRight ? foundTooltip.alignRight() : foundTooltip.alignTop();
249
- }
250
- catch (ex) { }
251
- }
252
- onUnTouchDescription(descripcion) {
253
- const foundTooltip = this.tooltips.find(tooltip => tooltip.el.nativeElement.id === descripcion);
254
- try {
255
- foundTooltip.deactivate();
256
- }
257
- catch (ex) { }
258
- }
259
- copyToClipboard(idProceso) {
260
- let url = `${this.crudService.environment.WebUtilities}GWV/ADO/${this.crudService.idKatios}?id=${idProceso}`;
261
- navigator.clipboard.writeText(url);
262
- }
263
- }
264
- FormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FormComponent, deps: [{ token: i1.MessageService }, { token: i2.SfCrudService }, { token: i3.DomSanitizer }, { token: i4.StepService }, { token: i5.AdoService }, { token: i5.JWTService }], target: i0.ɵɵFactoryTarget.Component });
265
- FormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: FormComponent, selector: "app-form", inputs: { uiEsquema: "uiEsquema", esquema: "esquema", data: "data", isDialog: "isDialog", isAddressDialog: "isAddressDialog", separador: "separador" }, viewQueries: [{ propertyName: "tooltips", predicate: Tooltip, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div *ngIf=\"controlsLoaded\" class=\"frm-container\">\r\n <ng-container *ngIf=\"isAddressDialog && currentAddress\">\r\n Direcci\u00F3n actual: {{currentAddress | formatAddress: separador}}\r\n <br>\r\n </ng-container>\r\n <br>\r\n <ng-container *ngIf=\"isAddressDialog\">\r\n Direcci\u00F3n nueva: {{newAddress | formatAddress: separador}}\r\n </ng-container>\r\n <div *ngFor=\"let element of uiEsquema.elements; let i = index\" [class]=\"element?.class\" #a>\r\n <ng-container [ngSwitch]=\"element.type\" *ngIf=\"visible[i][0]\">\r\n <div class=\"label\" *ngSwitchCase=\"'Label'\" [style]=\"element?.style\">\r\n {{element?.label}}\r\n </div>\r\n <ng-container *ngSwitchCase=\"'HorizontalLayout'\">\r\n <div *ngFor=\"let el of element.elements; let j =index\" [class]=\"el?.class\">\r\n <ng-container [ngSwitch]=\"el.type\" *ngIf=\"visible[i][j]\">\r\n <sf-control *ngSwitchCase=\"'Control'\" [control]=\"controls[i][j]\" [label]=\"el.label\"\r\n [value]=\"values[i][j]\" (setValue)=\"setValue($event, el.scope, i, j)\"\r\n (sendNotification)=\"sendNotification($event)\"\r\n (sendObject)=\"applyValuesFromObject($event)\"\r\n (addressClicked)=\"openPopUpDireccion(el.scope)\"></sf-control>\r\n <div *ngSwitchCase=\"'Texto'\" [ngStyle]=\"{'height': '100%', 'margin-block': 'auto'}\">\r\n <p>{{el.label}}</p>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'VerticalLayout'\">\r\n <div *ngFor=\"let el of element.elements; let j =index\" [class]=\"el?.class\">\r\n <ng-container [ngSwitch]=\"el.type\" *ngIf=\"visible[i][j]\">\r\n <sf-control *ngSwitchCase=\"'Control'\" [control]=\"controls[i][j]\" [label]=\"el.label\"\r\n [value]=\"values[i][j]\" (setValue)=\"setValue($event, el.scope, i, j)\"\r\n (sendNotification)=\"sendNotification($event)\"\r\n (sendObject)=\"applyValuesFromObject($event)\"\r\n (addressClicked)=\"openPopUpDireccion(el.scope)\"></sf-control>\r\n <div *ngSwitchCase=\"'PDF'\" class=\"pdf\">\r\n <iframe [src]=\"values[i][j]\" frameborder=\"0\" allow=\"geolocation *; camera *;\"></iframe>\r\n </div>\r\n <div *ngSwitchCase=\"'PDF-SIGN'\">\r\n <sf-sign [allowDownload]=\"true\" [idkatios]=\"idKatios\" [tdoc]=\"data.pdf.tdoc\" [ndoc]=\"data.pdf.ndoc\"\r\n [idDocument]=\"data.pdf.id\" [typeDocument]=\"data.pdf.idDoc\"\r\n (stateDocument)=\"onStateDocument($event)\"></sf-sign>\r\n </div>\r\n <ng-container *ngSwitchCase=\"'SIMULADOR'\">\r\n <sf-simulador [simulador]=\"data\" [otherToolTips]=\"data.otherTooltips\"\r\n (simuladorChange)=\"onSimuladorChange($event)\" (enProceso)=\"emitLoadingForm($event)\"></sf-simulador>\r\n </ng-container>\r\n <div *ngSwitchCase=\"'ADO'\" class=\"buttons\">\r\n <p-button *ngIf=\"!data?.ADO?.dataProceso?.idProceso\" [ngStyle]=\"el?.ngStyle\" (click)=\"goToADO()\" label=\"Validar identidad\"></p-button>\r\n </div>\r\n <div *ngSwitchCase=\"'ADO'\">\r\n <div *ngIf=\"data?.ADO?.dataProceso?.idProceso\">\r\n <div class=\"data-ado-container\">\r\n <ng-container *ngIf=\"proceso\">\r\n <i *ngIf=\"proceso?.respuestaProceso?.EsExitoso === true\" pTooltip=\"Validado\" tooltipPosition=\"top\" id=\"Validado\" class=\"pi pi-user\" style=\"color: green\"\r\n (touchstart)=\"onTouchDescription('Validado', false)\" (touchend)=\"onUnTouchDescription('Validado')\"></i>\r\n <i *ngIf=\"proceso?.respuestaProceso?.EsExitoso === false\" pTooltip=\"No validado\" tooltipPosition=\"top\" id=\"No-Validado\" class=\"pi pi-user\" style=\"color: red\"\r\n (touchstart)=\"onTouchDescription('No-Validado', false)\" (touchend)=\"onUnTouchDescription('No-Validado')\"></i>\r\n <i *ngIf=\"!proceso?.respuestaProceso\" pTooltip=\"Sin validar\" tooltipPosition=\"top\" class=\"pi pi-user\" id=\"Sin-Validar\" style=\"color: gray\"\r\n (touchstart)=\"onTouchDescription('Sin-Validar', false)\" (touchend)=\"onUnTouchDescription('Sin-Validar')\"></i>\r\n </ng-container>\r\n <div class=\"buttons\">\r\n <button pButton icon=\"pi pi-external-link\" (click)=\"goToADO()\" pTooltip=\"Abrir\" [disabled]=\"!proceso\"></button>\r\n <button pButton icon=\"pi pi-copy\" (click)=\"copyToClipboard(proceso.id)\" pTooltip=\"Copiar\" [disabled]=\"!proceso\"></button>\r\n <button pButton icon=\"pi pi-refresh\" (click)=\"refreshIntegracion(proceso.id)\" pTooltip=\"Refrescar\" [disabled]=\"!proceso\"></button>\r\n </div>\r\n </div>\r\n <p class=\"result-ado\" *ngIf=\"proceso && !proceso.respuestaProceso && proceso.estado == 'PROCESANDO'\">Procesando</p>\r\n <p class=\"result-ado\" *ngIf=\"proceso && proceso.respuestaProceso && proceso.estado == 'TERMINADO'\">{{proceso.respuestaProceso.Detalle ?? proceso.respuestaProceso.Mensaje}}</p>\r\n </div>\r\n </div>\r\n <ng-container *ngSwitchCase=\"'Table'\">\r\n <p-table [value]=\"values[i][j]\" [columns]=\"controls[i][j].config.columns\">\r\n <ng-template pTemplate=\"caption\">\r\n <div class=\"flex align-items-center justify-content-between\">\r\n <button pButton pRipple icon=\"pi pi-plus\" (click)=\"addObjectArray(el)\"\r\n class=\"p-button-success\" [disabled]=\"controls[i][j].disabled === true\"></button>\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 <ng-container>\r\n <th></th>\r\n </ng-container>\r\n </tr>\r\n </ng-template>\r\n <ng-template pTemplate=\"body\" let-rowData let-columns=\"columns\" let-rowIndex=\"rowIndex\">\r\n <tr>\r\n <ng-container *ngFor=\"let col of columns\" [ngSwitch]=\"col.type\">\r\n <ng-container *ngSwitchCase=\"'control'\">\r\n <sf-control [control]=\"extracControlFromTableElements(i, j, col)\" [label]=\"\"\r\n [value]=\"extracValueFromTableElements(i, j, rowIndex, col)\"\r\n (sendNotification)=\"sendNotification($event)\"\r\n (sendObject)=\"applyValuesFromObject($event)\"\r\n (setValue)=\"setValue($event, extracValueFromTableElements(i, j, rowIndex, col).scope, i, j)\"\r\n [showTempValue]=\"true\"\r\n >\r\n </sf-control>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'text'\">\r\n <td>{{rowData[col.col]}}</td>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'address'\">\r\n <td>{{rowData[col.col] | formatAddress: extracControlFromTableElements(i, j, col).separador }}</td>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'currency:USD'\">\r\n <td>{{rowData[col.col] | currency: 'USD'}}</td>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'date:yyyy-mm-dd'\">\r\n <td>{{rowData[col.col] | date: 'yyyy-mm-dd'}}</td>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'date:dd/mm/yyyy'\">\r\n <td>{{rowData[col.col] | date: 'dd/MM/yyyy'}}</td>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'boolean'\">\r\n <td>\r\n <i *ngIf=\"rowData[col.col]\" class=\"pi pi-check\"></i>\r\n <i *ngIf=\"!rowData[col.col]\" class=\"pi pi-times\"></i>\r\n </td>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container>\r\n <td>\r\n <button pButton pRipple type=\"button\"\r\n (click)=\"editRow(el, rowData, rowIndex)\" icon=\"pi pi-pencil\"\r\n class=\"p-button-rounded p-button-info mr-1\"></button>\r\n <button pButton pRipple type=\"button\" (click)=\"deleteRow(el, rowIndex)\" [disabled]=\"controls[i][j].disabled === true\"\r\n icon=\"pi pi-trash\" class=\"p-button-rounded p-button-danger\"></button>\r\n </td>\r\n </ng-container>\r\n </tr>\r\n </ng-template>\r\n </p-table>\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n</div>\r\n\r\n<p-toast *ngIf=\"isDialog\"></p-toast>\r\n", styles: [":not(.col-12) .label{display:flex;justify-content:center;align-items:center;padding-inline:.5rem;margin-bottom:15px;margin-top:20px;border-radius:13px;font-size:18px;font-size:inherit;background-color:var(--primary-color);text-align:center;color:var(--normal-text-color)}.pdf{display:flex;width:100%;height:80vh;& iframe{width:80%;margin-inline:10%}}.data-ado-container{display:flex;margin-inline:auto;align-items:center;width:-moz-fit-content;width:fit-content;&>*{margin-inline:4px}&>div{display:flex;align-items:center;&>*{margin-inline:4px}}}i.pi-user{font-size:2rem}.result-ado{min-height:1rem;text-align:center}sf-simulador{display:flow-root;width:80%;margin-inline:auto;margin-bottom:35px}sf-sign{display:block;margin-inline:auto;width:80%;& pdf-viewer{min-height:130vh!important;max-height:130vh!important}}.buttons{display:flex;justify-content:space-evenly}.buttons ::ng-deep .p-button.p-component{border-radius:35px}::ng-deep *{box-shadow:none}.frm-container ::ng-deep .p-inputtext:focus,.frm-container ::ng-deep .p-inputtext:active,.frm-container ::ng-deep .p-inputwrapper:focus,.frm-container ::ng-deep .p-inputwrapper:active{border-color:var(--button-color)}.frm-container ::ng-deep .p-button{background-color:var(--button-color);border-color:var(--button-color)}.frm-container ::ng-deep .p-button:hover{background-color:var(--button-color);filter:brightness(85%)}.frm-container ::ng-deep :not(:disabled):active,.frm-container ::ng-deep :not(.p-disabled) .p-inputtext:hover,.frm-container ::ng-deep :not(.p-disabled) .p-inputwrapper:hover,.frm-container ::ng-deep :not(.p-disabled) .p-inputwrapper-focus,.frm-container ::ng-deep .p-radiobutton-box .p-highlight,.frm-container ::ng-deep .p-radiobutton .p-radiobutton-box:not(.p-disabled):hover{border-color:var(--button-color)}.frm-container ::ng-deep .p-radiobutton .p-radiobutton-box.p-highlight{background:var(--button-color);border-color:var(--button-color)!important}.frm-container ::ng-deep .p-button.p-button-success,.p-buttonset.p-button-success>.p-button,.p-splitbutton.p-button-success>.p-button{background:var(--button-color);border-color:var(--button-color)!important}@media screen and (max-width:765px){:not(.col-12) .label{height:-moz-fit-content;height:fit-content}.field{margin-bottom:.5rem}.pdf>iframe{width:100%;margin-inline:0}sf-sign{width:100%;& pdf-viewer{min-height:60vh!important;max-height:120vh!important}}sf-simulador{display:block;width:100%;margin-inline:auto}.data-ado-container{text-align:center;& .buttons{max-width:80vw;flex-direction:row}}.buttons{flex-direction:column;align-items:center}}.frm-container ::ng-deep .p-radiobutton .p-radiobutton-box:not(.p-disabled):not(.p-highlight):hover{border-color:var(--secondary-color)!important}.frm-container ::ng-deep .p-button.p-button-success:enabled:focus,.p-buttonset.p-button-success>.p-button:enabled:focus,.p-splitbutton.p-button-success>.p-button:enabled:focus{box-shadow:inset 0 0 #fff}.frm-container ::ng-deep .p-radiobutton .p-radiobutton-box.p-highlight:not(.p-disabled):hover{color:var(--secondary-color)!important}.frm-container ::ng-deep .p-radiobutton .p-radiobutton-box:not(.p-disabled).p-focus{box-shadow:inset 0 0 0 1px var(--secondary-color)!important}.frm-container ::ng-deep .p-radiobutton .p-radiobutton-box .p-radiobutton-icon{background-color:#fff}.frm-container ::ng-deep .p-slider:not(.p-disabled):hover{background-color:#e5e7eb}.frm-container ::ng-deep .p-slider{background-color:#e5e7eb}.frm-container ::ng-deep .p-slider:not(.p-disabled):hover .p-slider-range{background-color:var(--primary-color)!important}.frm-container ::ng-deep .p-button:enabled:active{background:var(--secondary-color)!important;border-color:var(--secondary-color)!important}.frm-container ::ng-deep .p-slider:not(.p-disabled):hover .p-slider-handle{border-color:var(--primary-color)!important}.frm-container ::ng-deep .p-button:focus{box-shadow:inset 0 0 0 1px var(--secondary-color)!important}.frm-container ::ng-deep .p-button:enabled:hover{background:var(--secondary-color)!important;border-color:var(--secondary-color)!important}.frm-container ::ng-deep .p-button.p-button-info,.p-buttonset.p-button-info>.p-button,.p-splitbutton.p-button-info>.p-button{background:var(--secondary-color)!important;border:1px solid var(--secondary-color)!important}\n"], components: [{ type: i6.ControlComponent, selector: "sf-control", inputs: ["showTempValue", "control", "label", "value", "appendTo"], outputs: ["setValue", "sendObject", "addressClicked"] }, { type: i7.SignComponent, selector: "sf-sign", inputs: ["idkatios", "tdoc", "ndoc", "idDocument", "typeDocument", "allowDownload"], outputs: ["stateDocument", "loading"] }, { type: i8.SfSimuladorComponent, selector: "sf-simulador", inputs: ["simulador", "otherToolTips", "labels"], outputs: ["simuladorChange", "enProceso"] }, { type: i9.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "style", "styleClass", "badgeClass"], outputs: ["onClick", "onFocus", "onBlur"] }, { type: i10.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: i11.Toast, selector: "p-toast", inputs: ["key", "autoZIndex", "baseZIndex", "style", "styleClass", "position", "preventOpenDuplicates", "preventDuplicates", "showTransformOptions", "hideTransformOptions", "showTransitionOptions", "hideTransitionOptions", "breakpoints"], outputs: ["onClose"] }], directives: [{ type: i12.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i12.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i12.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i12.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i12.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i13.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { type: i9.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { type: i1.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { type: i14.Ripple, selector: "[pRipple]" }], pipes: { "formatAddress": i15.FormatAddressPipe, "currency": i12.CurrencyPipe, "date": i12.DatePipe } });
266
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FormComponent, decorators: [{
267
- type: Component,
268
- args: [{
269
- selector: 'app-form',
270
- templateUrl: './form.component.html',
271
- styleUrls: ['./form.component.css']
272
- }]
273
- }], ctorParameters: function () { return [{ type: i1.MessageService }, { type: i2.SfCrudService }, { type: i3.DomSanitizer }, { type: i4.StepService }, { type: i5.AdoService }, { type: i5.JWTService }]; }, propDecorators: { uiEsquema: [{
274
- type: Input
275
- }], esquema: [{
276
- type: Input
277
- }], data: [{
278
- type: Input
279
- }], isDialog: [{
280
- type: Input
281
- }], isAddressDialog: [{
282
- type: Input
283
- }], separador: [{
284
- type: Input
285
- }], tooltips: [{
286
- type: ViewChildren,
287
- args: [Tooltip]
288
- }] } });
289
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../projects/sf-crud/src/lib/components/form/form.component.ts","../../../../../../projects/sf-crud/src/lib/components/form/form.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAA+C,YAAY,EAAE,MAAM,eAAe,CAAC;AAG5G,OAAO,KAAK,QAAQ,MAAM,UAAU,CAAC;AAGrC,OAAO,EAAE,UAAU,EAA0B,MAAM,uBAAuB,CAAC;AAM3E,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;;;;;;;;;;;;;;;;;AAO1C,MAAM,OAAO,aAAa;IAuBxB,YACU,cAA8B,EAC9B,WAA0B,EAC1B,YAA0B,EAC1B,WAAwB,EACxB,UAAsB,EACtB,UAAsB;QALtB,mBAAc,GAAd,cAAc,CAAgB;QAC9B,gBAAW,GAAX,WAAW,CAAe;QAC1B,iBAAY,GAAZ,YAAY,CAAc;QAC1B,gBAAW,GAAX,WAAW,CAAa;QACxB,eAAU,GAAV,UAAU,CAAY;QACtB,eAAU,GAAV,UAAU,CAAY;QAzBvB,aAAQ,GAAE,KAAK,CAAC;QAChB,oBAAe,GAAE,KAAK,CAAC;QAOhC,mBAAc,GAAG,KAAK,CAAC;QAGvB,aAAQ,GAAG,KAAK,CAAC;QAgBf,IAAI,CAAC,OAAO,GAAG,EAAC,UAAU,EAAE,IAAI,EAAE,MAAM,EAAE,SAAS,EAAC,CAAC;QACrD,IAAI,MAAM,CAAC,UAAU,IAAI,GAAG;YAAE,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAA;QAClD,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,GAAG,EAAE;YACrC,IAAI,MAAM,CAAC,UAAU,IAAI,GAAG;gBAAE,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAA;QACpD,CAAC,CAAC,CAAC;IACL,CAAC;IACD,WAAW,CAAC,OAAsB;QAChC,IAAI,CAAC,aAAa,EAAE,CAAA;IACtB,CAAC;IAGD,QAAQ;QACN,IAAI;YACF,IAAI,IAAI,CAAC,eAAe;gBAAE,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAA;YACtE,IAAI,CAAC,UAAU,CAAC,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAA;YACpD,IAAI,CAAC,UAAU,CAAC,qBAAqB,GAAG,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,qBAAqB,CAAA;YAC1F,IAAI,CAAC,UAAU,CAAC,qBAAqB,GAAG,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,qBAAqB,CAAA;YAC1F,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAA;YACzC,IAAI,CAAC,WAAW,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC,QAAQ,EAAE,EAAE;gBACvD,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,QAAQ,EAAC;oBAC7B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,CAAA;oBAC7E,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,CAAA;oBACzE,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;oBACpE,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,CAAA;oBAC3E,IAAI,CAAC,aAAa,EAAE,CAAC;iBACtB;YACH,CAAC,CAAC,CAAA;SACH;QAAC,OAAO,KAAK,EAAE;YACd,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;SACrB;IACH,CAAC;IAED,eAAe,CAAC,MAAe;QAC7B,IAAI,CAAC,OAAO,CAAC,UAAU,GAAG,MAAM,CAAA;QAChC,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,CAAA,CAAA,sDAAsD;IACjI,CAAC;IAID,aAAa;;QACX,IAAI,CAAC,OAAO,GAAG,EAAE,CAAA;QACjB,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;QAC5B,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAA;QAClB,IAAI,CAAC,MAAM,GAAG,EAAE,CAAA;QAEhB,SAAS;QACT,IAAI,IAAI,CAAC,eAAe;YAAE,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,mBAAmB,CAAC,QAAQ,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,cAAc,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,CAAA;QAE3J,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,MAAW,EAAE,CAAS,EAAE,EAAE;;YACzD,IAAI,SAAS,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,qBAAqB,CAAC,MAAM,CAAC,UAAU,EAAE,IAAI,CAAC,QAAQ,CAAC,UAAU,IAAI,EAAE,EAAE,IAAI,CAAC,IAAI,CAAC,CAAA,CAAC,CAAC,IAAI,CAAA;YAC9I,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAA,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC,CAAA,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAA;YACrF,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;YACtB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;YAEpB,MAAA,MAAM,CAAC,QAAQ,0CAAE,OAAO,CAAC,CAAC,OAAY,EAAE,CAAS,EAAE,EAAE;gBACnD,IAAI,OAAO,CAAC,UAAU;oBAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,qBAAqB,CAAC,OAAO,CAAC,UAAU,EAAE,IAAI,CAAC,QAAQ,CAAC,UAAU,IAAI,EAAE,EAAE,IAAI,CAAC,IAAI,CAAC,CAAA;gBAEnJ,IAAI,OAAO,CAAC,OAAO,IAAI,OAAM,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,QAAQ;oBAAG,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAA;gBAC1G,IAAI,OAAO,CAAC,GAAG,EAAC;oBACd,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;oBAChC,IAAI,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,OAAO,CAAC,GAAG,CAAC,CAAA;oBACvD,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,8BAA8B,CAAC,GAAG,CAAC,CAAC,CAAA;iBAC3E;qBACI,IAAI,CAAC,OAAO,CAAC,KAAK,EAAC;oBACtB,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;oBAChC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;iBAC/B;qBAAI;oBACH,IAAG;wBACD,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAA;wBAC/E,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAA;wBACzC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,CAAA;qBACzE;oBAAA,OAAM,CAAC,EAAC;wBACP,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;wBACpB,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;wBAChB,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAA;wBAC7B,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAA;qBAC5B;iBAEF;YAEH,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,IAAI,SAAS,GAAG,MAAA,MAAA,IAAI,CAAC,IAAI,CAAC,GAAG,0CAAE,WAAW,0CAAE,SAAS,CAAA;QACrD,IAAI,SAAS,IAAI,CAAA,MAAA,IAAI,CAAC,OAAO,0CAAE,EAAE,KAAI,SAAS;YAAE,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAA;IACpF,CAAC;IAED,kBAAkB,CAAC,SAAiB;QAClC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAA;QAC1B,OAAO,OAAO,CAAC,GAAG,CAAC;YACf,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE;gBACrD,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;gBACtB,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAA;YACtC,CAAC,CAAC;SACL,CAAC;aACD,OAAO,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,CAAA;IAC7C,CAAC;IAED,8BAA8B,CAAC,CAAK,EAAE,CAAK,EAAE,GAAO;QAClD,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACzD,OAAO,QAAQ,CAAA;IACjB,CAAC;IAED,4BAA4B,CAAC,CAAK,EAAE,CAAK,EAAE,CAAK,EAAE,GAAO;QACvD,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QAC5C,OAAO,KAAK,CAAA;IACd,CAAC;IAED,QAAQ,CAAC,KAAU,EAAE,KAAU,EAAE,CAAS,EAAE,CAAS;;QACnD,KAAK,GAAG,KAAK,CAAC,UAAU,CAAC,cAAc,EAAE,EAAE,CAAC,CAAA;QAC5C,IAAI,KAAK,EAAE;YACT,IAAI,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;YACjC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC;YAC1B,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;YACxC,IAAI,CAAC,WAAW,CAAC,UAAU,GAAG,IAAI,UAAU,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAA;YAClF,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,MAAW,EAAE,OAAe,EAAE,EAAE;;gBAC/D,IAAI,MAAM,CAAC,UAAU,EAAC;oBACpB,IAAI,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,qBAAqB,CAAC,MAAM,CAAC,UAAU,EAAE,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,UAAU,IAAI,EAAE,EAAE,IAAI,CAAC,IAAI,CAAC,CAAA;oBAC3J,IAAG,MAAM,CAAC,QAAQ;wBAAE,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC,CAAA;;wBAC3E,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,SAAS,CAAA;iBAC1C;gBAED,MAAA,MAAM,CAAC,QAAQ,0CAAE,OAAO,CAAC,CAAC,OAAY,EAAE,OAAe,EAAE,EAAE;oBACzD,IAAI,OAAO,CAAC,UAAU,EAAC;wBACrB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,qBAAqB,CAAC,OAAO,CAAC,UAAU,EAAE,IAAI,CAAC,QAAQ,CAAC,UAAU,IAAI,EAAE,EAAE,IAAI,CAAC,IAAI,CAAC,CAAA;qBACvI;gBACH,CAAC,CAAC,CAAA;YACJ,CAAC,CAAC,CAAA;YACF,MAAA,OAAO,CAAC,SAAS,0CAAE,OAAO,CAAC,CAAC,CAAS,EAAE,EAAE;gBACvC,IAAI,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAA;gBAChE,IAAI,GAAG;oBAAE,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,GAAG,EAAE,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YAC7H,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,aAAa,EAAE,CAAA;SACrB;QACD,IAAI,CAAC,WAAW,CAAC,kBAAkB,CAAC,UAAU,EAAE,IAAI,CAAC,OAAO,EAAE,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;IACtF,CAAC;IAGD,gBAAgB,CAAC,OAAgB;QAC/B,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;IAClC,CAAC;IAED,qBAAqB,CAAC,KAAU;QAC9B,IAAI,KAAK,CAAC,WAAW,EAAC;YACpB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBACjD,MAAM,SAAS,GAAG,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;gBACvC,MAAM,MAAM,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAA,CAAC,CAAC,IAAI,CAAC;gBACnG,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,aAAa,EAAC,EAAE,CAAC,EAAE,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAA;gBACtI,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,KAAK,EAAE,MAAM,CAAC,CAAA;aAC9C;SACF;IACH,CAAC;IAED,eAAe,CAAC,KAAa,EAAE,MAAW;QACxC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAC7C,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;YAC7B,GAAG,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE;gBACpB,IAAI,EAAE,CAAC,KAAK,IAAI,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,aAAa,EAAC,EAAE,CAAC,IAAG,KAAK,CAAC,OAAO,CAAC,aAAa,EAAC,EAAE,CAAC,EAAC;oBACnF,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,MAAM,CAAA;iBAC3B;YACH,CAAC,CAAC,CAAA;SACH;IACH,CAAC;IAED,eAAe,CAAC,KAAa,EAAE,KAAU;QACvC,MAAM,OAAO,GAAG,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAA;QACtD,IAAI,IAAI,CAAC;QACT,QAAQ,OAAO,CAAC,IAAI,EAAE;YACpB,KAAK,MAAM;gBACT,IAAI,GAAG,IAAI,IAAI,CAAC,GAAG,KAAK,EAAE,CAAC,CAAA;gBAC3B,MAAM;YACR,KAAK,SAAS;gBACZ,IAAI,GAAG,CAAC,KAAK,CAAA;gBACb,MAAM;YACR;gBACE,IAAI,GAAG,KAAK,CAAA;gBACZ,MAAM;SACT;QACD,OAAO,IAAI,CAAA;IACb,CAAC;IAED,OAAO,CAAC,OAAY,EAAE,IAAS,EAAE,KAAa;QAC5C,IAAI,CAAC,WAAW,CAAC,sBAAsB,CAAC,qBAAqB,EAAE,EAAC,OAAO,EAAE,IAAI,EAAE,KAAK,EAAC,CAAC,CAAA;IACxF,CAAC;IAED,SAAS,CAAC,OAAY,EAAE,KAAa;QACnC,IAAI,CAAC,WAAW,CAAC,sBAAsB,CAAC,uBAAuB,EAAE,EAAC,OAAO,EAAE,KAAK,EAAC,CAAC,CAAA;IACpF,CAAC;IAED,cAAc,CAAC,OAAY;QACzB,IAAI,CAAC,WAAW,CAAC,sBAAsB,CAAC,oBAAoB,EAAE,EAAC,OAAO,EAAC,CAAC,CAAA;IAC1E,CAAC;IAED,kBAAkB,CAAC,KAAa;QAC9B,IAAI,CAAC,WAAW,CAAC,sBAAsB,CAAC,kBAAkB,EAAE,EAAC,KAAK,EAAC,CAAC,CAAA;IACtE,CAAC;IAED,eAAe,CAAC,KAAa;QAC3B,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,GAAG,KAAK,CAAC,WAAW,EAAE,IAAI,SAAS,CAAA;IACzD,CAAC;IAED,iBAAiB,CAAC,MAAiB;QACjC,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC,CAAA;IAChE,CAAC;IAED,OAAO;;QACL,IAAI,GAAG,GAAG,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC;QAC/B,IAAI,QAAQ,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,OAAO,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;QAC7D,IAAI,SAAS,GAAG,MAAA,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,WAAW,0CAAE,SAAS,CAAA;QACpD,IAAI,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,WAAW,CAAA;QAC3C,WAAW,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAA;QACpC,oCAAoC;QACpC,gCAAgC;QAChC,IAAI,SAAS,EAAC;YACZ,MAAM,CAAC,QAAQ,CAAC,IAAI,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,YAAY,WAAW,IAAI,CAAC,WAAW,CAAC,QAAQ,OAAO,SAAS,EAAE,CAAA;YACzH,MAAM,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;SAC1B;aACI,IAAI,WAAW,EAAC;YACnB,MAAM,CAAC,QAAQ,CAAC,IAAI,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,YAAY,WAAW,IAAI,CAAC,WAAW,CAAC,QAAQ,gBAAgB,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,aAAa,kBAAkB,CAAC,QAAQ,CAAC,EAAE,CAAA;YACnM,MAAM,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;SAC1B;IACH,CAAC;IACD,kBAAkB,CAAC,EAAU,EAAE,UAAU,GAAC,IAAI;QAC5C,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,aAAa,CAAC,EAAE,KAAK,EAAE,CAAE,CAAC;QACxF,IAAG;YACD,YAAY,CAAC,QAAQ,EAAE,CAAC;YACxB,UAAU,CAAC,CAAC,CAAC,YAAY,CAAC,UAAU,EAAE,CAAA,CAAC,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;SACjE;QAAA,OAAM,EAAE,EAAC,GAAE;IACd,CAAC;IAED,oBAAoB,CAAC,WAAmB;QACtC,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,aAAa,CAAC,EAAE,KAAK,WAAW,CAAE,CAAC;QACjG,IAAG;YACD,YAAY,CAAC,UAAU,EAAE,CAAC;SAC3B;QAAA,OAAM,EAAE,EAAC,GAAE;IACd,CAAC;IAED,eAAe,CAAC,SAAiB;QAC/B,IAAI,GAAG,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,YAAY,WAAW,IAAI,CAAC,WAAW,CAAC,QAAQ,OAAO,SAAS,EAAE,CAAA;QAC5G,SAAS,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,CAAC,CAAA;IACpC,CAAC;;2GA/QU,aAAa;+FAAb,aAAa,qOAoBV,OAAO,qECvCvB,kgXAkJA;4FD/Ha,aAAa;kBALzB,SAAS;mBAAC;oBACT,QAAQ,EAAE,UAAU;oBACpB,WAAW,EAAE,uBAAuB;oBACpC,SAAS,EAAE,CAAC,sBAAsB,CAAC;iBACpC;wOAEU,SAAS;sBAAjB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBAciB,QAAQ;sBAA9B,YAAY;uBAAC,OAAO","sourcesContent":["import { Component, Input, OnChanges, OnInit, QueryList, SimpleChanges, ViewChildren } from '@angular/core';\r\n\r\nimport { Message, MessageService } from 'primeng/api';\r\nimport * as jsonpath from 'jsonpath';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\nimport { Shema } from '../../shared/models/shema.model';\r\nimport { ChangeData, Loading, SfCrudService } from '../../sf-crud.service';\r\nimport { ConfigRegistro } from '../../shared/models/crud-config.model';\r\nimport { StepService } from '../../shared/services/step.service';\r\nimport { Simulador } from 'sf-simulador';\r\nimport * as _ from \"lodash\";\r\nimport { AdoService, JWTService, ProcesoADO } from 'sf-ado';\r\nimport { Tooltip } from 'primeng/tooltip';\r\n\r\n@Component({\r\n  selector: 'app-form',\r\n  templateUrl: './form.component.html',\r\n  styleUrls: ['./form.component.css']\r\n})\r\nexport class FormComponent implements OnChanges, OnInit{\r\n  @Input() uiEsquema: any;\r\n  @Input() esquema!: Shema;\r\n  @Input() data: any;\r\n  @Input() isDialog= false;\r\n  @Input() isAddressDialog= false;\r\n  @Input() separador?: string;\r\n  newAddress?: string;\r\n  currentAddress?: string;\r\n  registro!: ConfigRegistro;\r\n  values!: any[][];\r\n  controls!: any[][];\r\n  controlsLoaded = false;\r\n  idKatios!: string;\r\n  visible!: boolean[][];\r\n  isMobile = false;\r\n  urlADO?: string;\r\n  proceso: ProcesoADO | undefined;\r\n  private loading!:Loading;\r\n\r\n  @ViewChildren(Tooltip) tooltips!: QueryList <Tooltip>;\r\n\r\n\r\n  constructor(\r\n    private messageService: MessageService,\r\n    private crudService: SfCrudService,\r\n    private domSanitizer: DomSanitizer,\r\n    private stepService: StepService,\r\n    private adoService: AdoService,\r\n    private jwtService: JWTService\r\n  ) {\r\n    this.loading = {inProgress: true, target: undefined};\r\n    if (window.innerWidth <= 768) this.isMobile = true\r\n    window.addEventListener('resize', () => {\r\n      if (window.innerWidth <= 768) this.isMobile = true\r\n    });\r\n  }\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    this.buildControls()\r\n  }\r\n\r\n\r\n  ngOnInit(): void {\r\n    try {\r\n      if (this.isAddressDialog) this.currentAddress = this.data.currentValue\r\n      this.jwtService.idKatios = this.crudService.idKatios\r\n      this.jwtService.servidorIntegraciones = this.crudService.environment.ServidorIntegraciones\r\n      this.adoService.servidorIntegraciones = this.crudService.environment.ServidorIntegraciones\r\n      this.idKatios = this.crudService.idKatios\r\n      this.stepService.requestApproved$.subscribe((approved) => {\r\n        if (!this.isDialog && approved){\r\n          this.uiEsquema = this.crudService.getUIEsquema(this.stepService.currentIndex)\r\n          this.esquema = this.crudService.getEsquema(this.stepService.currentIndex)\r\n          this.data = this.crudService.getData(this.stepService.currentIndex);\r\n          this.registro = this.crudService.getRegistro(this.stepService.currentIndex)\r\n          this.buildControls();\r\n        }\r\n      })\r\n    } catch (error) {\r\n      console.error(error)\r\n    }\r\n  }\r\n\r\n  emitLoadingForm($event: boolean){\r\n    this.loading.inProgress = $event\r\n    Promise.resolve().then(() => this.crudService.formLoading = this.loading)//si no se usa asi el enproceso totea con el simulador\r\n  }\r\n\r\n\r\n\r\n  buildControls(){\r\n    this.visible = []\r\n    this.controlsLoaded = false;\r\n    this.controls = []\r\n    this.values = []\r\n\r\n    //address\r\n    if (this.isAddressDialog) this.newAddress = this.crudService.armarNuevaDireccion(\"string\", this.data, this.crudService.getValue(\"$..separador\", this.data))\r\n\r\n    this.uiEsquema.elements.forEach((layout: any, i: number) => {\r\n      let isVisible = layout.conditions ? this.crudService.isConditionsCompleted(layout.conditions, this.registro.conditions || [], this.data): true\r\n      this.visible.push(layout.elements? layout.elements.map(() => isVisible): [isVisible])\r\n      this.controls.push([])\r\n      this.values.push([])\r\n\r\n      layout.elements?.forEach((element: any, j: number) => {\r\n        if (element.conditions)  this.visible[i][j] = this.crudService.isConditionsCompleted(element.conditions, this.registro.conditions || [], this.data)\r\n\r\n        if (element.ngStyle && typeof(element.ngStyle) == \"string\")  element.ngStyle = JSON.parse(element.ngStyle)\r\n        if (element.url){\r\n          this.controls[i].push(undefined)\r\n          let url = this.crudService.applyStringKeys(element.url)\r\n          this.values[i].push(this.domSanitizer.bypassSecurityTrustResourceUrl(url))\r\n        }\r\n        else if (!element.scope){\r\n          this.controls[i].push(undefined)\r\n          this.values[i].push(undefined)\r\n        }else{\r\n          try{\r\n            this.controls[i].push(this.crudService.getControl(element.scope, this.esquema))\r\n            this.controls[i][j].scope = element.scope\r\n            this.values[i].push(this.crudService.getValue(element.scope, this.data))\r\n          }catch(e){\r\n            console.log(element)\r\n            console.error(e)\r\n            console.log(this.controls[i])\r\n            console.log(this.values[i])\r\n          }\r\n\r\n        }\r\n\r\n      });\r\n    });\r\n    this.controlsLoaded = true;\r\n    let idProceso = this.data.ADO?.dataProceso?.idProceso\r\n    if (idProceso && this.proceso?.id != idProceso) this.refreshIntegracion(idProceso)\r\n  }\r\n\r\n  refreshIntegracion(idProceso: number){\r\n    this.emitLoadingForm(true)\r\n    return Promise.all([\r\n        this.adoService.getProceso(idProceso).then((proceso) => {\r\n          this.proceso = proceso\r\n          this.data.ADO.proceso = this.proceso\r\n        })\r\n    ])\r\n    .finally(() => this.emitLoadingForm(false))\r\n  }\r\n\r\n  extracControlFromTableElements(i:any, j:any, col:any){\r\n    const property = this.controls[i][j].properties[col.col];\r\n    return property\r\n  }\r\n\r\n  extracValueFromTableElements(i:any, j:any, k:any, col:any){\r\n    const value = this.values[i][j][k][col.col];\r\n    return value\r\n  }\r\n\r\n  setValue(value: any, scope: any, i: number, j: number) {\r\n    scope = scope.replaceAll('..properties', '')\r\n    if (scope) {\r\n      let control = this.controls[i][j]\r\n      this.values[i][j] = value;\r\n      jsonpath.value(this.data, scope, value);\r\n      this.crudService.changeData = new ChangeData(value, scope, this.crudService.index)\r\n      this.uiEsquema.elements.forEach((layout: any, iLayout: number) => {\r\n        if (layout.conditions){\r\n          let isVisible = this.crudService.isConditionsCompleted(layout.conditions, this.crudService.getRegistro(this.crudService.index).conditions || [], this.data)\r\n          if(layout.elements) this.visible[iLayout] = layout.elements.map(() => isVisible)\r\n          else this.visible[iLayout][0] = isVisible\r\n        }\r\n\r\n        layout.elements?.forEach((element: any, indexEl: number) => {\r\n          if (element.conditions){\r\n            this.visible[iLayout][indexEl] = this.crudService.isConditionsCompleted(element.conditions, this.registro.conditions || [], this.data)\r\n          }\r\n        })\r\n      })\r\n      control.applyKeys?.forEach((i: number) => {\r\n        let key = this.registro.keys ? this.registro.keys[i] : undefined\r\n        if (key) this.crudService.applyKey(key, this.registro, key.indexData ? this.crudService.getData(key.indexData) : this.data)\r\n      });\r\n      this.buildControls()\r\n    }\r\n    this.crudService.applyValuesOnEvent('onChange', this.esquema, undefined, this.data);\r\n  }\r\n\r\n\r\n  sendNotification(message: Message) {\r\n    this.messageService.add(message)\r\n  }\r\n\r\n  applyValuesFromObject(event: any) {\r\n    if (event.optionValue){\r\n      for (let i = 0; i < event.optionValue.length; i++) {\r\n        const optionVal = event.optionValue[i];\r\n        const newVal = event.data ? this.aplyFormatValue(optionVal.scope, event.data[optionVal.key]): null;\r\n        jsonpath.value(this.data, optionVal.scope.replace('.properties',''), this.aplyFormatValue(optionVal.scope, event.data[optionVal.key]))\r\n        this.setValueByScope(optionVal.scope, newVal)\r\n      }\r\n    }\r\n  }\r\n\r\n  setValueByScope(scope: string, newVal: any){\r\n    for (let i = 0; i < this.controls.length; i++) {\r\n      const row = this.controls[i];\r\n      row.forEach((el, j) => {\r\n        if (el.scope && el.scope.replace('.properties','')== scope.replace('.properties','')){\r\n          this.values[i][j] = newVal\r\n        }\r\n      })\r\n    }\r\n  }\r\n\r\n  aplyFormatValue(scope: string, value: any) {\r\n    const control = jsonpath.query(this.esquema, scope)[0]\r\n    let resp;\r\n    switch (control.type) {\r\n      case 'date':\r\n        resp = new Date(`${value}`)\r\n        break;\r\n      case 'numeric':\r\n        resp = +value\r\n        break;\r\n      default:\r\n        resp = value\r\n        break;\r\n    }\r\n    return resp\r\n  }\r\n\r\n  editRow(element: any, data: any, index: number) {\r\n    this.stepService.addCustomChildrenEvent(\"onClickedEditButton\", {element, data, index})\r\n  }\r\n\r\n  deleteRow(element: any, index: number) {\r\n    this.stepService.addCustomChildrenEvent(\"onClickedDeleteButton\", {element, index})\r\n  }\r\n\r\n  addObjectArray(element: any) {\r\n    this.stepService.addCustomChildrenEvent(\"onClickedAddButton\", {element})\r\n  }\r\n\r\n  openPopUpDireccion(scope: string){\r\n    this.stepService.addCustomChildrenEvent(\"onClickedAddress\", {scope})\r\n  }\r\n\r\n  onStateDocument(state: string){\r\n    this.data.pdf.signed = state.toUpperCase() == \"FIRMADO\"\r\n  }\r\n\r\n  onSimuladorChange($event: Simulador) {\r\n    Promise.resolve().then(() => Object.assign(this.data, $event))\r\n  }\r\n\r\n  goToADO(){\r\n    let url = window.location.href;\r\n    let callback = url.split('?')[0] + `?id=${this.data.idForm}`;\r\n    let idProceso = this.data.ADO.dataProceso?.idProceso\r\n    let dataProceso = this.data.ADO.dataProceso\r\n    dataProceso.ctivo = this.data.idForm\r\n    //this.data.ADO.idTransaction = null\r\n    //this.data.ADO.idProceso = null\r\n    if (idProceso){\r\n      window.location.href = `${this.crudService.environment.WebUtilities}GWV/ADO/${this.crudService.idKatios}?id=${idProceso}`\r\n      window.location.reload();\r\n    }\r\n    else if (dataProceso){\r\n      window.location.href = `${this.crudService.environment.WebUtilities}GWV/ADO/${this.crudService.idKatios}?dataProceso=${btoa(JSON.stringify(dataProceso))}&callback=${encodeURIComponent(callback)}`\r\n      window.location.reload();\r\n    }\r\n  }\r\n  onTouchDescription(id: string, alignRight=true) {\r\n    const foundTooltip = this.tooltips.find(tooltip => tooltip.el.nativeElement.id === id)!;\r\n    try{\r\n      foundTooltip.activate();\r\n      alignRight ? foundTooltip.alignRight(): foundTooltip.alignTop();\r\n    }catch(ex){}\r\n  }\r\n\r\n  onUnTouchDescription(descripcion: string) {\r\n    const foundTooltip = this.tooltips.find(tooltip => tooltip.el.nativeElement.id === descripcion)!;\r\n    try{\r\n      foundTooltip.deactivate();\r\n    }catch(ex){}\r\n  }\r\n\r\n  copyToClipboard(idProceso: string){\r\n    let url = `${this.crudService.environment.WebUtilities}GWV/ADO/${this.crudService.idKatios}?id=${idProceso}`\r\n    navigator.clipboard.writeText(url)\r\n  }\r\n}\r\n","<div *ngIf=\"controlsLoaded\" class=\"frm-container\">\r\n  <ng-container *ngIf=\"isAddressDialog && currentAddress\">\r\n    Dirección actual: {{currentAddress | formatAddress: separador}}\r\n    <br>\r\n  </ng-container>\r\n  <br>\r\n  <ng-container *ngIf=\"isAddressDialog\">\r\n    Dirección nueva: {{newAddress | formatAddress: separador}}\r\n  </ng-container>\r\n    <div *ngFor=\"let element of uiEsquema.elements; let i = index\" [class]=\"element?.class\" #a>\r\n        <ng-container [ngSwitch]=\"element.type\" *ngIf=\"visible[i][0]\">\r\n            <div class=\"label\" *ngSwitchCase=\"'Label'\" [style]=\"element?.style\">\r\n                {{element?.label}}\r\n            </div>\r\n            <ng-container *ngSwitchCase=\"'HorizontalLayout'\">\r\n                <div *ngFor=\"let el of element.elements; let j =index\" [class]=\"el?.class\">\r\n                    <ng-container [ngSwitch]=\"el.type\" *ngIf=\"visible[i][j]\">\r\n                        <sf-control *ngSwitchCase=\"'Control'\" [control]=\"controls[i][j]\" [label]=\"el.label\"\r\n                            [value]=\"values[i][j]\" (setValue)=\"setValue($event, el.scope, i, j)\"\r\n                            (sendNotification)=\"sendNotification($event)\"\r\n                            (sendObject)=\"applyValuesFromObject($event)\"\r\n                            (addressClicked)=\"openPopUpDireccion(el.scope)\"></sf-control>\r\n                          <div *ngSwitchCase=\"'Texto'\" [ngStyle]=\"{'height': '100%', 'margin-block': 'auto'}\">\r\n                            <p>{{el.label}}</p>\r\n                          </div>\r\n                    </ng-container>\r\n                </div>\r\n            </ng-container>\r\n            <ng-container *ngSwitchCase=\"'VerticalLayout'\">\r\n                <div *ngFor=\"let el of element.elements; let j =index\" [class]=\"el?.class\">\r\n                    <ng-container [ngSwitch]=\"el.type\" *ngIf=\"visible[i][j]\">\r\n                        <sf-control *ngSwitchCase=\"'Control'\" [control]=\"controls[i][j]\" [label]=\"el.label\"\r\n                            [value]=\"values[i][j]\" (setValue)=\"setValue($event, el.scope, i, j)\"\r\n                            (sendNotification)=\"sendNotification($event)\"\r\n                            (sendObject)=\"applyValuesFromObject($event)\"\r\n                            (addressClicked)=\"openPopUpDireccion(el.scope)\"></sf-control>\r\n                        <div *ngSwitchCase=\"'PDF'\" class=\"pdf\">\r\n                            <iframe [src]=\"values[i][j]\" frameborder=\"0\" allow=\"geolocation *; camera *;\"></iframe>\r\n                        </div>\r\n                        <div *ngSwitchCase=\"'PDF-SIGN'\">\r\n                            <sf-sign [allowDownload]=\"true\" [idkatios]=\"idKatios\" [tdoc]=\"data.pdf.tdoc\" [ndoc]=\"data.pdf.ndoc\"\r\n                                [idDocument]=\"data.pdf.id\" [typeDocument]=\"data.pdf.idDoc\"\r\n                                (stateDocument)=\"onStateDocument($event)\"></sf-sign>\r\n                        </div>\r\n                        <ng-container *ngSwitchCase=\"'SIMULADOR'\">\r\n                            <sf-simulador  [simulador]=\"data\" [otherToolTips]=\"data.otherTooltips\"\r\n                                (simuladorChange)=\"onSimuladorChange($event)\" (enProceso)=\"emitLoadingForm($event)\"></sf-simulador>\r\n                        </ng-container>\r\n                        <div *ngSwitchCase=\"'ADO'\" class=\"buttons\">\r\n                            <p-button *ngIf=\"!data?.ADO?.dataProceso?.idProceso\" [ngStyle]=\"el?.ngStyle\" (click)=\"goToADO()\" label=\"Validar identidad\"></p-button>\r\n                        </div>\r\n                        <div *ngSwitchCase=\"'ADO'\">\r\n                          <div *ngIf=\"data?.ADO?.dataProceso?.idProceso\">\r\n                            <div class=\"data-ado-container\">\r\n                              <ng-container *ngIf=\"proceso\">\r\n                                <i *ngIf=\"proceso?.respuestaProceso?.EsExitoso === true\" pTooltip=\"Validado\" tooltipPosition=\"top\" id=\"Validado\" class=\"pi pi-user\" style=\"color: green\"\r\n                                (touchstart)=\"onTouchDescription('Validado', false)\" (touchend)=\"onUnTouchDescription('Validado')\"></i>\r\n                                <i *ngIf=\"proceso?.respuestaProceso?.EsExitoso === false\" pTooltip=\"No validado\" tooltipPosition=\"top\" id=\"No-Validado\" class=\"pi pi-user\" style=\"color: red\"\r\n                                (touchstart)=\"onTouchDescription('No-Validado', false)\" (touchend)=\"onUnTouchDescription('No-Validado')\"></i>\r\n                                <i *ngIf=\"!proceso?.respuestaProceso\" pTooltip=\"Sin validar\" tooltipPosition=\"top\" class=\"pi pi-user\" id=\"Sin-Validar\" style=\"color: gray\"\r\n                                (touchstart)=\"onTouchDescription('Sin-Validar', false)\" (touchend)=\"onUnTouchDescription('Sin-Validar')\"></i>\r\n                              </ng-container>\r\n                              <div class=\"buttons\">\r\n                                <button pButton icon=\"pi pi-external-link\" (click)=\"goToADO()\" pTooltip=\"Abrir\" [disabled]=\"!proceso\"></button>\r\n                                <button pButton icon=\"pi pi-copy\" (click)=\"copyToClipboard(proceso.id)\" pTooltip=\"Copiar\" [disabled]=\"!proceso\"></button>\r\n                                <button pButton icon=\"pi pi-refresh\" (click)=\"refreshIntegracion(proceso.id)\" pTooltip=\"Refrescar\" [disabled]=\"!proceso\"></button>\r\n                              </div>\r\n                            </div>\r\n                            <p class=\"result-ado\" *ngIf=\"proceso && !proceso.respuestaProceso && proceso.estado == 'PROCESANDO'\">Procesando</p>\r\n                            <p class=\"result-ado\" *ngIf=\"proceso && proceso.respuestaProceso && proceso.estado == 'TERMINADO'\">{{proceso.respuestaProceso.Detalle ?? proceso.respuestaProceso.Mensaje}}</p>\r\n                          </div>\r\n                        </div>\r\n                        <ng-container *ngSwitchCase=\"'Table'\">\r\n                            <p-table [value]=\"values[i][j]\" [columns]=\"controls[i][j].config.columns\">\r\n                                <ng-template pTemplate=\"caption\">\r\n                                    <div class=\"flex align-items-center justify-content-between\">\r\n                                        <button pButton pRipple icon=\"pi pi-plus\" (click)=\"addObjectArray(el)\"\r\n                                            class=\"p-button-success\" [disabled]=\"controls[i][j].disabled === true\"></button>\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                                        <ng-container>\r\n                                            <th></th>\r\n                                        </ng-container>\r\n                                    </tr>\r\n                                </ng-template>\r\n                                <ng-template pTemplate=\"body\" let-rowData let-columns=\"columns\" let-rowIndex=\"rowIndex\">\r\n                                    <tr>\r\n                                        <ng-container *ngFor=\"let col of columns\" [ngSwitch]=\"col.type\">\r\n                                            <ng-container *ngSwitchCase=\"'control'\">\r\n                                                <sf-control [control]=\"extracControlFromTableElements(i, j, col)\" [label]=\"\"\r\n                                                    [value]=\"extracValueFromTableElements(i, j, rowIndex, col)\"\r\n                                                    (sendNotification)=\"sendNotification($event)\"\r\n                                                    (sendObject)=\"applyValuesFromObject($event)\"\r\n                                                    (setValue)=\"setValue($event, extracValueFromTableElements(i, j, rowIndex, col).scope, i, j)\"\r\n                                                    [showTempValue]=\"true\"\r\n                                                    >\r\n                                                </sf-control>\r\n                                            </ng-container>\r\n                                            <ng-container *ngSwitchCase=\"'text'\">\r\n                                                <td>{{rowData[col.col]}}</td>\r\n                                            </ng-container>\r\n                                            <ng-container *ngSwitchCase=\"'address'\">\r\n                                              <td>{{rowData[col.col] | formatAddress: extracControlFromTableElements(i, j, col).separador }}</td>\r\n                                            </ng-container>\r\n                                            <ng-container *ngSwitchCase=\"'currency:USD'\">\r\n                                                <td>{{rowData[col.col] | currency: 'USD'}}</td>\r\n                                            </ng-container>\r\n                                            <ng-container *ngSwitchCase=\"'date:yyyy-mm-dd'\">\r\n                                                <td>{{rowData[col.col] | date: 'yyyy-mm-dd'}}</td>\r\n                                            </ng-container>\r\n                                            <ng-container *ngSwitchCase=\"'date:dd/mm/yyyy'\">\r\n                                                <td>{{rowData[col.col] | date: 'dd/MM/yyyy'}}</td>\r\n                                            </ng-container>\r\n                                            <ng-container *ngSwitchCase=\"'boolean'\">\r\n                                                <td>\r\n                                                    <i *ngIf=\"rowData[col.col]\" class=\"pi pi-check\"></i>\r\n                                                    <i *ngIf=\"!rowData[col.col]\" class=\"pi pi-times\"></i>\r\n                                                </td>\r\n                                            </ng-container>\r\n                                        </ng-container>\r\n                                        <ng-container>\r\n                                            <td>\r\n                                                <button pButton pRipple type=\"button\"\r\n                                                    (click)=\"editRow(el, rowData, rowIndex)\" icon=\"pi pi-pencil\"\r\n                                                    class=\"p-button-rounded p-button-info mr-1\"></button>\r\n                                                <button pButton pRipple type=\"button\" (click)=\"deleteRow(el, rowIndex)\" [disabled]=\"controls[i][j].disabled === true\"\r\n                                                    icon=\"pi pi-trash\" class=\"p-button-rounded p-button-danger\"></button>\r\n                                            </td>\r\n                                        </ng-container>\r\n                                    </tr>\r\n                                </ng-template>\r\n                            </p-table>\r\n                        </ng-container>\r\n                    </ng-container>\r\n                </div>\r\n            </ng-container>\r\n        </ng-container>\r\n    </div>\r\n</div>\r\n\r\n<p-toast *ngIf=\"isDialog\"></p-toast>\r\n"]}